:root{color:#17201d;background:#f4f6f5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f4f6f5}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}.sidebar{display:flex;flex-direction:column;gap:28px;padding:24px 18px;color:#f7fbf8;background:linear-gradient(180deg,#142334fa,#081019fa),#142334}.brand-block{display:flex;align-items:center;gap:12px;min-height:48px}.brand-block--official{align-items:center}.brand-logo-card{display:grid;place-items:center;width:154px;min-width:154px;height:56px;border-radius:8px;background:#fff;box-shadow:0 10px 24px #0000002e}.brand-logo{display:block;width:128px;height:auto}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border:1px solid #bfd8cd;border-radius:8px;color:#15241f;background:#dce9e4;font-weight:800}.brand-block h1,.brand-block p,.topbar h2,.topbar p,.panel h2,.panel p{margin:0}.brand-block h1{font-size:1.15rem;letter-spacing:0}.brand-block p{color:#bfd8cd;font-size:.86rem}.module-nav{display:grid;gap:8px}.module-nav__item{display:grid;grid-template-columns:22px minmax(0,1fr);align-items:center;gap:10px;min-height:42px;width:100%;border:1px solid transparent;border-radius:8px;padding:9px 10px;color:#d8e6e0;background:transparent;text-align:left}.module-nav__item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module-nav__item:hover,.module-nav__item--active{border-color:#8dc63f8c;color:#fff;background:#8dc63f24}.content-shell{display:grid;align-content:start;gap:18px;padding:22px;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:64px;border-bottom:1px solid #d7dedb;padding-bottom:16px}.topbar h2{color:#26332f;font-size:1.15rem;font-weight:650}.eyebrow{display:block;margin-bottom:2px;color:#5b6b66;font-size:.84rem}.topbar__actions{display:flex;align-items:center;gap:8px}.user-chip,.button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;border:1px solid #c7d2ce;border-radius:8px;color:#1f2c28;background:#fff}.user-chip{max-width:260px;padding:0 12px}.user-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.button{width:100%;padding:0 14px;font-weight:650}.button--primary{border-color:#246b59;color:#fff;background:#246b59}.button:disabled,.icon-button:disabled{cursor:wait;opacity:.65}.icon-button{width:38px;height:38px;padding:0}.icon-button--approve{border-color:#8bb8a8;color:#1f6a52}.icon-button--reject{border-color:#e2aaa4;color:#a13f34}.notice{display:inline-flex;align-items:center;gap:8px;width:fit-content;min-height:34px;border:1px solid #d7c283;border-radius:8px;padding:0 10px;color:#5f4610;background:#fbf4d8;font-size:.9rem}.workspace-grid,.admin-grid{display:grid;grid-template-columns:minmax(300px,380px) minmax(0,1fr);gap:18px;align-items:start}.admin-grid{grid-template-columns:repeat(2,minmax(280px,1fr))}.panel{display:grid;gap:16px;min-width:0;border:1px solid #d7dedb;border-radius:8px;padding:18px;background:#fff}.panel--wide{grid-column:span 1}.admin-grid .panel--wide{grid-column:1 / -1}.panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel h2{color:#21302b;font-size:1.05rem;font-weight:700}.panel p,.panel small,.compact-row small,.entry-row small{color:#667672}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}label{display:grid;gap:6px;color:#40514c;font-size:.9rem;font-weight:600}input,select,textarea{width:100%;min-width:0;border:1px solid #c7d2ce;border-radius:8px;padding:9px 10px;color:#16211d;background:#fff}textarea{resize:vertical}input:focus,select:focus,textarea:focus,button:focus-visible{outline:3px solid #b8d9ce;outline-offset:1px}.switch{grid-auto-flow:column;align-items:center;width:fit-content;color:#26332f}.switch input{width:18px;height:18px}.form-error{border:1px solid #e6b0aa;border-radius:8px;padding:10px;color:#8c2f25;background:#fff1ef}.entry-list,.compact-list{display:grid;gap:10px}.entry-row,.compact-row,.module-table__row{display:grid;gap:10px;border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.entry-row{grid-template-columns:minmax(0,1fr) auto;align-items:center}.entry-row__title{display:flex;flex-wrap:wrap;align-items:center;gap:8px;color:#1c2a25;font-weight:700}.entry-row p{margin:4px 0;overflow-wrap:anywhere}.entry-row__actions{display:flex;gap:6px}.status-badge,.pill{display:inline-flex;align-items:center;justify-content:center;min-height:26px;border-radius:999px;padding:0 9px;color:#24332e;background:#e8eeee;font-size:.8rem;font-weight:650}.status-badge--draft{color:#4b5361;background:#e8ecf2}.status-badge--submitted{color:#5f4610;background:#fbf0c7}.status-badge--approved{color:#1f614d;background:#dcefe7}.status-badge--rejected{color:#8c2f25;background:#fae0dd}.pill--muted{color:#687773;background:#edf1ef}.pill--remote{color:#254f7b;background:#e0edf8}.compact-row{grid-template-columns:minmax(0,1fr) auto;align-items:center}.compact-row strong,.compact-row small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact-row--stacked{grid-template-columns:minmax(0,1fr)}.module-table{display:grid;gap:8px}.module-table__row{grid-template-columns:minmax(160px,1fr) minmax(180px,1.2fr) auto auto;align-items:center}.module-table__row span,.module-table__row small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-state{display:grid;place-items:center;min-height:220px;border:1px dashed #bdc9c5;border-radius:8px;padding:28px;color:#53635e;background:#fff;text-align:center}.empty-state--error{border-color:#e6b0aa;color:#8c2f25;background:#fff7f5}.empty-state--compact{min-height:96px;padding:16px}.portal-layout,.module-page-grid{display:grid;gap:18px}.portal-hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:18px;align-items:stretch;border:1px solid #d7dedb;border-radius:8px;padding:22px;background:#fff}.portal-hero h2,.portal-hero p{margin:0}.portal-hero h2{color:#21302b;font-size:1.4rem}.portal-hero p{max-width:720px;margin-top:8px;color:#667672}.portal-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.portal-kpis article,.profile-grid article,.metric-stack article{display:grid;gap:4px;border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.portal-kpis strong,.profile-grid strong,.metric-stack strong{color:#1d2b26;font-size:1.05rem}.portal-kpis span,.profile-grid span,.metric-stack span{color:#667672;font-size:.86rem}.module-grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px}.module-card{display:grid;grid-template-columns:42px minmax(0,1fr) 24px;align-items:center;gap:12px;min-height:126px;border:1px solid #d7dedb;border-radius:8px;padding:16px;color:#1f2c28;background:#fff;text-align:left}.module-card:hover{border-color:#246b59;background:#f4faf7}.module-card__icon{display:grid;place-items:center;width:42px;height:42px;border-radius:8px;color:#246b59;background:#e0f0ea}.module-card__body{display:grid;gap:5px;min-width:0}.module-card__body strong{color:#1f2c28;font-size:1rem}.module-card__body small{display:-webkit-box;overflow:hidden;color:#667672;-webkit-box-orient:vertical;-webkit-line-clamp:2}.module-page-grid{grid-template-columns:repeat(2,minmax(280px,1fr));align-items:start}.module-page-grid .panel--wide{grid-column:1 / -1}.profile-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.metric-stack{display:grid;gap:10px}.time-work-layout{display:grid;grid-template-columns:minmax(320px,.85fr) minmax(0,1.15fr);gap:18px;align-items:start}.time-work-layout .panel--wide{grid-column:1 / -1}.time-clock-panel{background:linear-gradient(135deg,#142334f5,#0d2227eb),#142334}.time-clock-status{display:flex;align-items:center;justify-content:space-between;gap:18px}.time-clock-status h2,.time-clock-status p{margin:0}.time-clock-status h2{color:#fff;font-size:1.45rem}.time-clock-status p{color:#c7dbd4}.time-clock-button{width:fit-content;min-width:180px}.time-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.time-kpi-grid article{display:grid;gap:4px;border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.time-kpi-grid span{color:#667672;font-size:.86rem}.time-kpi-grid strong,.metric-value{color:#1d2b26;font-size:1.1rem}.metric-value--ok{color:#1f614d}.metric-value--warn{color:#a13f34}.time-day-list{display:grid;gap:8px}.time-day-row{display:grid;grid-template-columns:minmax(150px,1fr) repeat(4,minmax(90px,auto));align-items:center;gap:10px;border:1px solid #e3e9e6;border-radius:8px;padding:11px 12px;background:#fbfcfc}.time-day-row--today{border-color:#8dc63fa6;background:#f6fbef}.time-day-row strong,.time-day-row small{display:block}.time-day-row small,.time-day-row span{color:#667672}.time-day-row>strong{color:#1d2b26;text-align:right}.login-shell{position:relative;overflow:hidden;display:grid;align-items:center;justify-items:start;min-height:100vh;padding:clamp(24px,6vw,72px);color:#f4f7f5;background:linear-gradient(90deg,#070f17f5,#0a1621e6 44%,#0a16219e),url(/brand/komag_wejscie_tlo.jpg) right center / cover no-repeat,#0a1621}.login-shell:before{position:absolute;inset:0 auto 0 0;width:min(18vw,220px);background:linear-gradient(180deg,#8dc63f5c,#8dc63f00);content:"";pointer-events:none}.login-layout{position:relative;z-index:1;display:grid;grid-template-columns:minmax(320px,430px) minmax(280px,340px);gap:clamp(18px,4vw,34px);align-items:center;width:min(100%,820px)}.login-clean{position:relative;z-index:1;display:grid;justify-items:start;gap:20px;width:min(100%,430px);border:1px solid rgba(141,198,63,.32);border-left:5px solid #8dc63f;border-radius:8px;padding:clamp(24px,5vw,36px);background:#08121cbd;box-shadow:0 24px 64px #00000057;text-align:left;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.login-layout .login-clean{width:100%}.official-login-brand{display:grid;place-items:center;width:min(100%,302px);border-radius:8px;padding:18px 20px;background:#fff;box-shadow:0 16px 32px #00000038}.official-login-logo{display:block;width:min(100%,262px);height:auto}.login-subtitle{margin:0 0 4px;color:#d8e6e1;font-size:1rem;font-weight:600}.login-stage{display:grid;grid-template-columns:minmax(280px,.95fr) minmax(340px,460px);grid-template-rows:auto 1fr auto;align-items:center;gap:32px 56px;min-height:calc(100vh - 64px);max-width:1180px;margin:0 auto}.login-brand{display:flex;align-items:center;gap:12px;grid-column:1 / -1;align-self:start}.login-brand h1,.login-brand p,.login-copy h2,.login-copy p,.login-card h3,.login-card p{margin:0}.login-brand h1{font-size:1.15rem;letter-spacing:0}.login-brand p{color:#bfd8cd}.login-copy{display:grid;gap:12px;max-width:620px}.login-copy .eyebrow{color:#a9d5c5}.login-copy h2{max-width:760px;color:#fff;font-size:clamp(2.1rem,5vw,4.4rem);line-height:1.03;letter-spacing:0}.login-copy p{max-width:580px;color:#d5e4de;font-size:1.05rem}.login-card{display:grid;gap:22px;border:1px solid rgba(215,222,219,.3);border-radius:8px;padding:24px;color:#17201d;background:#fff;box-shadow:0 18px 56px #00000038}.login-card__header{display:grid;grid-template-columns:46px minmax(0,1fr);align-items:center;gap:14px}.login-card__icon{display:grid;place-items:center;width:46px;height:46px;border-radius:8px;color:#246b59;background:#e0f0ea}.login-card h3{color:#1d2b26;font-size:1.1rem}.login-card p{color:#667672}.login-primary{display:flex;align-items:center;justify-content:space-between;min-height:48px;width:100%;border:1px solid #246b59;border-radius:8px;padding:0 16px;color:#fff;background:#246b59;font-weight:750}.login-primary:hover{background:#1e5b4c}.login-primary--clean{width:min(100%,310px);min-height:48px;border-color:#8dc63f;color:#08121b;background:#8dc63f;box-shadow:0 14px 30px #8dc63f33}.login-primary--clean:hover{border-color:#9bd34e;background:#9bd34e}.login-dev{display:grid;gap:10px;border-top:1px solid #e3e9e6;padding-top:16px}.login-dev--clean{width:min(100%,380px);border-top:0;padding-top:6px}.login-dev>span{color:#aebdb8;font-size:.85rem;font-weight:700}.login-footnotes{display:flex;flex-wrap:wrap;gap:12px;grid-column:1 / -1;align-self:end;color:#c7dbd4}.login-footnotes span,.login-loading{display:inline-flex;align-items:center;gap:8px}.login-loading{grid-column:1 / -1;min-height:70px;color:#d5e4de}.login-panel{display:grid;gap:20px;max-width:620px;border:1px solid #d7dedb;border-radius:8px;padding:24px;background:#fff}.login-panel h2,.login-panel p{margin:0}.login-panel h2{color:#21302b;font-size:1.2rem}.login-panel p{color:#667672}.login-options{display:grid;gap:10px}.login-option{display:grid;grid-template-columns:28px minmax(0,1fr);align-items:center;gap:12px;min-height:62px;border:1px solid rgba(199,210,206,.28);border-radius:8px;padding:10px 12px;color:#eef6f2;background:#ffffff0f;text-align:left}.login-option:hover{border-color:#8dc63fb8;background:#8dc63f1f}.login-option strong,.login-option small{display:block}.login-option small{color:#aebdb8}.test-accounts{position:relative;z-index:1;display:grid;gap:14px;border:1px solid rgba(199,210,206,.22);border-radius:8px;padding:18px;color:#eef6f2;background:#08121ca8;box-shadow:0 22px 54px #00000047;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.test-accounts__label{color:#d8e6e1;font-size:.9rem;font-weight:750}.test-account-list{display:grid;gap:10px}.test-account-card{display:grid;gap:12px;border:1px solid rgba(141,198,63,.28);border-left:4px solid #8dc63f;border-radius:8px;padding:12px;background:#ffffff12}.test-account-card strong,.test-account-card small{display:block}.test-account-card strong{color:#fff}.test-account-card small{color:#aebdb8}.test-account-card dl{display:grid;gap:6px;margin:0}.test-account-card dl div{display:grid;grid-template-columns:48px minmax(0,1fr);gap:8px;align-items:baseline}.test-account-card dt,.test-account-card dd{margin:0}.test-account-card dt{color:#aebdb8;font-size:.78rem;text-transform:uppercase}.test-account-card dd{overflow-wrap:anywhere;color:#fff;font-weight:750}@media(max-width:980px){.app-shell{grid-template-columns:1fr}.login-shell{justify-items:center;padding:22px}.login-clean{justify-items:center;text-align:center}.login-layout{grid-template-columns:1fr;width:min(100%,430px)}.login-stage{grid-template-columns:1fr;gap:28px}.sidebar{padding:16px}.module-nav{grid-auto-flow:column;grid-auto-columns:minmax(160px,1fr);overflow-x:auto}.workspace-grid,.admin-grid,.portal-hero,.time-work-layout,.module-page-grid{grid-template-columns:1fr}.module-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}}@media(max-width:640px){.content-shell{padding:14px}.topbar{align-items:flex-start;flex-direction:column}.topbar__actions,.user-chip{width:100%}.login-shell{padding:16px}.official-login-brand,.login-primary--clean{width:100%}.login-card,.login-card__header,.form-grid,.entry-row,.compact-row,.module-table__row,.time-clock-status,.time-kpi-grid,.time-day-row,.portal-kpis,.profile-grid,.module-grid,.module-card{grid-template-columns:1fr}.entry-row__actions{justify-content:flex-start}.time-clock-button{width:100%}.time-day-row>strong{text-align:left}}
