:root{--page-bg: #f4f6f5;--content-bg: #f4f6f5;--surface: #ffffff;--surface-muted: #fbfcfc;--surface-soft: #eef4f1;--surface-elevated: #ffffff;--border: #d7dedb;--border-soft: #e3e9e6;--text-strong: #17201d;--text-title: #21302b;--text-body: #40514c;--text-muted: #667672;--primary: #246b59;--primary-hover: #1e5b4c;--primary-soft: #e0f0ea;--accent: #8dc63f;--focus: #b8d9ce;--danger: #8c2f25;--danger-bg: #fff1ef;--warn: #5f4610;--warn-bg: #fbf4d8;color:#17201d;background:var(--page-bg);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}:root[data-theme=dark]{--page-bg: #0d1218;--content-bg: #0d1218;--surface: #141c24;--surface-muted: #101922;--surface-soft: #192531;--surface-elevated: #17222d;--border: #2d3c47;--border-soft: #24323d;--text-strong: #edf4f2;--text-title: #f4f9f7;--text-body: #c8d6d1;--text-muted: #9fb0ab;--primary: #2d806b;--primary-hover: #34927b;--primary-soft: #18392f;--accent: #8dc63f;--focus: #4a8372;--danger: #ffbbb4;--danger-bg: #321d1e;--warn: #f0d281;--warn-bg: #322917;color:var(--text-strong);background:var(--page-bg)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--text-strong);background:var(--page-bg);transition:background-color .18s ease,color .18s ease}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}.app-shell--admin .sidebar{background:linear-gradient(180deg,#101822fc,#060a11fc),#101822}.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}.admin-mode-badge{display:inline-flex;align-items:center;width:fit-content;min-height:30px;border:1px solid rgba(141,198,63,.42);border-radius:8px;padding:0 10px;color:#dff1d2;background:#8dc63f1f;font-size:.82rem;font-weight:750}.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.32rem;font-weight:760}.topbar__title{display:flex;align-items:center;min-width:0}.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--danger{border-color:#d9aaa4;color:#8c2f25;background:#fff5f3}.button--compact{width:auto;min-height:34px;white-space:nowrap}.button--admin-refresh{width:fit-content;min-width:170px;color:#fff;background:#182534;border-color:#263b50}.button:disabled,.icon-button:disabled{cursor:wait;opacity:.65}.icon-button{width:38px;height:38px;padding:0}.theme-toggle{width:auto;min-width:94px;padding:0 12px}.theme-toggle__label{font-size:.84rem;font-weight:750}.login-theme-toggle{position:absolute;z-index:3;top:18px;right:18px;border-color:#d7dedb52;color:#eef6f2;background:#08121cad;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.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))}.admin-command{display:grid;gap:18px}.admin-hero{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid #cfd8d4;border-radius:8px;padding:18px;color:#eef6f2;background:linear-gradient(135deg,#142334fa,#0e2127f5),#142334}.admin-hero h2,.admin-hero p{margin:0}.admin-hero h2{color:#fff;font-size:1.32rem}.admin-hero p{margin-top:4px;color:#c8d9d3}.admin-kpis{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:10px}.admin-kpi{display:grid;gap:4px;min-height:104px;border:1px solid #d7dedb;border-radius:8px;padding:13px;background:#fff}.admin-kpi__icon{display:grid;place-items:center;width:34px;height:34px;border-radius:8px;color:#246b59;background:#e0f0ea}.admin-kpi span:not(.admin-kpi__icon){color:#667672;font-size:.86rem}.admin-kpi strong{color:#182534;font-size:1.35rem}.admin-tabs{display:flex;flex-wrap:wrap;gap:8px;border:1px solid #d7dedb;border-radius:8px;padding:8px;background:#fff}.admin-tab{display:inline-flex;align-items:center;gap:8px;min-height:38px;border:1px solid transparent;border-radius:8px;padding:0 12px;color:#40514c;background:transparent;font-weight:700}.admin-tab--active,.admin-tab:hover{border-color:#c7d2ce;color:#182534;background:#eef4f1}.admin-section-body{display:grid;gap:18px}.admin-layout{display:grid;grid-template-columns:minmax(420px,1.25fr) minmax(320px,.85fr);gap:18px;align-items:start}.admin-layout--overview{grid-template-columns:minmax(320px,.85fr) minmax(420px,1.15fr)}.admin-panel--users,.admin-panel--audit{grid-row:span 2}.admin-user-list,.admin-role-list,.admin-module-list,.audit-list,.security-check-list{display:grid;gap:10px}.admin-user-row{display:grid;grid-template-columns:minmax(190px,.75fr) minmax(260px,1fr) auto;align-items:center;gap:12px;border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.admin-user-row--expanded{grid-template-columns:minmax(200px,.7fr) minmax(260px,1fr) minmax(260px,1fr) auto}.admin-user-row__identity,.admin-user-row__actions,.admin-role-card,.admin-module-row,.security-check{display:grid;gap:6px}.admin-user-row__identity strong,.admin-role-card strong,.admin-module-row strong{color:#1d2b26}.admin-user-row__identity small,.admin-role-card small,.admin-module-row small{overflow-wrap:anywhere}.admin-user-meta{display:grid;gap:4px;color:#667672;font-size:.86rem}.admin-user-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(160px,1fr));gap:10px}.admin-role-picker{display:flex;flex-wrap:wrap;gap:8px}.role-toggle{grid-auto-flow:column;align-items:center;gap:6px;width:fit-content;min-height:32px;border:1px solid #d7dedb;border-radius:999px;padding:0 10px;color:#26332f;background:#fff;font-size:.84rem}.role-toggle input{width:15px;height:15px;padding:0}.admin-user-row__actions{justify-items:end}.admin-role-card{border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.permission-cloud{display:flex;flex-wrap:wrap;gap:6px}.permission-pill{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 8px;color:#315145;background:#e4f1ec;font-size:.76rem;font-weight:650}.admin-module-row{grid-template-columns:minmax(0,1fr) auto auto;align-items:center;border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.admin-module-row--editable{grid-template-columns:minmax(240px,.8fr) minmax(320px,1.2fr) auto}.admin-module-summary,.admin-module-pills{display:grid;gap:6px}.admin-module-pills{grid-auto-flow:column;align-items:center;justify-content:start}.admin-module-edit-grid{display:grid;grid-template-columns:repeat(2,minmax(150px,1fr));gap:10px}.admin-module-edit-grid__wide{grid-column:1 / -1}.audit-row{display:grid;grid-template-columns:76px minmax(0,1fr) minmax(120px,auto);align-items:center;gap:10px;border:1px solid #e3e9e6;border-radius:8px;padding:11px 12px;background:#fbfcfc}.traffic-list{display:grid;gap:10px}.traffic-row{display:grid;grid-template-columns:76px 70px 58px minmax(220px,1fr) minmax(180px,.7fr) minmax(140px,auto);align-items:center;gap:10px;border:1px solid #e3e9e6;border-radius:8px;padding:11px 12px;background:#fbfcfc}.traffic-list--compact .traffic-row{grid-template-columns:76px 58px 48px minmax(180px,1fr) auto}.traffic-row--suspicious{border-color:#e8b2aa;background:#fff7f5}.traffic-row time,.traffic-agent{color:#667672;font-size:.82rem}.traffic-method,.traffic-status{display:inline-flex;align-items:center;justify-content:center;min-height:28px;border-radius:8px;color:#21302b;background:#e8eeee;font-size:.78rem;font-weight:800}.traffic-status--warn{color:#8c2f25;background:#fae0dd}.traffic-path{display:grid;min-width:0}.traffic-path strong,.traffic-path small,.traffic-agent{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.traffic-path strong{color:#1d2b26}.traffic-path small{color:#667672}.audit-row time{color:#667672;font-size:.82rem;font-weight:700}.audit-row strong,.audit-row small{display:block}.audit-row strong{color:#1d2b26}.audit-row .pill{justify-self:end;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.security-check{border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fbfcfc}.security-check span{color:#667672;font-size:.84rem}.security-check strong{color:#1d2b26}.security-check small{color:#1f614d;font-weight:700}.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}.pill--danger{color:#8c2f25;background:#fae0dd}.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:88px;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}.employee-workspace,.employee-section{display:grid;gap:18px}.employee-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,320px);gap:18px;align-items:center;border:1px solid #d7dedb;border-radius:8px;padding:22px;background:linear-gradient(135deg,#fffffff5,#eff6f2f5),#fff}.employee-hero h2,.employee-hero p{margin:0}.employee-hero h2{color:#21302b;font-size:1.45rem}.employee-hero p{max-width:760px;margin-top:8px;color:#667672}.employee-hero--compact{padding:18px}.employee-status-card{display:grid;gap:4px;justify-self:stretch;border:1px solid #cfd8d4;border-radius:8px;padding:14px;background:#fff}.employee-status-card--active{border-color:#246b5961;background:#eef8f3}.employee-status-card span,.employee-card span,.employee-progress span,.employee-request-summary span{color:#667672;font-size:.86rem}.employee-status-card strong,.employee-card strong,.employee-progress strong,.employee-request-summary strong,.employee-day-card strong,.employee-request-row strong,.employee-doc-card strong,.time-summary-card strong,.time-action-card strong{color:#1d2b26}.employee-tabs,.time-work-tabs{display:flex;flex-wrap:wrap;gap:8px;border:1px solid #d7dedb;border-radius:8px;padding:8px;background:#fff}.employee-tab,.time-work-tab{display:inline-flex;align-items:center;gap:8px;min-height:38px;border:1px solid transparent;border-radius:8px;padding:0 12px;color:#40514c;background:transparent;font-weight:700}.employee-tab--active,.employee-tab:hover,.time-work-tab--active,.time-work-tab:hover{border-color:#c7d2ce;color:#182534;background:#eef4f1}.employee-section,.employee-section-grid{border:1px solid #d7dedb;border-radius:8px;padding:18px;background:#fff}.employee-section-grid{display:grid;grid-template-columns:repeat(3,minmax(180px,1fr));gap:12px}.employee-card,.employee-action-card,.employee-request-summary article,.employee-day-card,.employee-request-row,.employee-doc-card,.time-summary-card,.time-action-card{display:grid;gap:6px;border:1px solid #e3e9e6;border-radius:8px;padding:14px;background:#fbfcfc}.employee-card>svg{color:#246b59}.employee-card--primary{border-color:#246b5957;background:#eef8f3}.employee-card strong,.employee-request-summary strong,.time-summary-card strong{font-size:1.22rem}.employee-card small,.employee-action-card small,.employee-day-card small,.employee-request-row small,.employee-doc-card small,.time-summary-card small,.time-action-card small{color:#667672}.employee-action-card{grid-column:1 / -1;grid-template-columns:minmax(0,1fr) auto;align-items:center}.employee-progress{display:grid;gap:10px;border:1px solid #e3e9e6;border-radius:8px;padding:14px;background:#fbfcfc}.employee-progress>div:first-child{display:flex;align-items:center;justify-content:space-between;gap:12px}.employee-progress__track{overflow:hidden;height:10px;border-radius:999px;background:#e4ebe8}.employee-progress__track span{display:block;height:100%;border-radius:inherit;background:#246b59}.employee-day-list,.employee-request-list,.employee-doc-grid{display:grid;gap:10px}.employee-day-card,.employee-request-row,.employee-doc-card{grid-template-columns:minmax(0,1fr) auto;align-items:center}.employee-day-card--today{border-color:#8dc63fa6;background:#f6fbef}.employee-day-card span{color:#246b59;font-weight:750}.employee-request-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.employee-doc-card{grid-template-columns:24px minmax(0,1fr) auto}.employee-doc-grid--catalog{grid-template-columns:repeat(2,minmax(260px,1fr))}.employee-doc-card--catalog{align-items:start;min-height:112px}.employee-profile-checks{display:grid;grid-template-columns:repeat(2,minmax(240px,1fr));gap:10px}.employee-profile-checks article{display:grid;grid-template-columns:24px minmax(0,1fr);gap:10px;border:1px solid #e3e9e6;border-radius:8px;padding:14px;background:#fbfcfc}.employee-profile-checks strong,.employee-profile-checks small{display:block}.employee-profile-checks strong{color:#1d2b26}.employee-profile-checks small{color:#667672}.request-workspace{display:grid;gap:18px}.request-bar{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,380px);gap:12px;align-items:stretch}.request-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,360px);gap:18px;align-items:center;border:1px solid #d7dedb;border-radius:8px;padding:22px;background:linear-gradient(135deg,#fffffffa,#f0f6f3fa),#fff}.request-hero h2,.request-hero p{margin:0}.request-hero h2{color:#21302b;font-size:1.45rem}.request-hero p{max-width:760px;margin-top:8px;color:#667672}.request-hero__stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.request-hero__stats article{display:grid;gap:4px;border:1px solid #e3e9e6;border-radius:8px;padding:14px;background:#fbfcfc}.request-hero__stats span{color:#667672;font-size:.84rem}.request-hero__stats strong{color:#1d2b26;font-size:1.3rem}.request-hero__stats--compact article{min-height:56px;padding:10px 12px}.vacation-balance-grid{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:10px}.vacation-balance-grid article{display:grid;gap:3px;border:1px solid #e3e9e6;border-radius:8px;padding:12px;background:#fff}.vacation-balance-grid span,.vacation-balance-grid small{color:#667672;font-size:.84rem}.vacation-balance-grid strong{color:#1d2b26;font-size:1.35rem}.request-tabs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;border:1px solid #d7dedb;border-radius:8px;padding:8px;background:#fff}.request-tab{display:inline-flex;align-items:center;gap:8px;min-height:38px;border:1px solid transparent;border-radius:8px;padding:0 12px;color:#40514c;background:transparent;font-weight:700}.request-tab--active,.request-tab:hover{border-color:#c7d2ce;color:#182534;background:#eef4f1}.time-work-layout{display:grid;grid-template-columns:minmax(320px,.85fr) minmax(0,1.15fr);gap:18px;align-items:start}.time-work-layout--tabbed{grid-template-columns:minmax(0,1fr)}.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-clock-panel--compact{padding:20px}.time-work-section,.time-work-section-grid{display:grid;gap:18px}.time-work-section-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}.time-summary-card--hero{border-color:#246b5957;background:#eef8f3}.time-action-card{grid-column:1 / -1;grid-template-columns:minmax(0,1fr) auto;align-items:center}.time-request-panel{max-width:760px}.work-calendar{overflow-x:auto;display:grid;gap:12px;padding-bottom:4px}.work-calendar__weekdays,.work-calendar__grid{display:grid;grid-template-columns:repeat(7,minmax(92px,1fr));gap:8px;min-width:720px}.work-calendar__weekdays span{color:#667672;font-size:.82rem;font-weight:800;text-align:center}.work-calendar__empty,.work-calendar-day{min-height:94px;border-radius:8px}.work-calendar__empty{border:1px dashed #e3e9e6;background:#f6f8f7}.work-calendar-day{display:grid;align-content:space-between;gap:8px;border:1px solid #d7dedb;padding:10px;background:#fff}.work-calendar-day div{display:flex;align-items:flex-start;justify-content:space-between;gap:6px}.work-calendar-day strong{color:#1d2b26;font-size:1.15rem}.work-calendar-day span{border-radius:999px;padding:2px 7px;font-size:.72rem;font-weight:800}.work-calendar-day small{color:#667672;font-weight:700}.work-calendar-day--ok{border-color:#92c8b6;background:#eaf7f1}.work-calendar-day--ok span{color:#1f614d;background:#d3ecdf}.work-calendar-day--under{border-color:#e4aaa2;background:#fff3f1}.work-calendar-day--under span{color:#8c2f25;background:#f6ddd9}.work-calendar-day--pending{border-color:#ddc576;background:#fff8df}.work-calendar-day--pending span{color:#6f520f;background:#f5e8b1}.work-calendar-day--vacation{border-color:#9fb9e8;background:#eef4ff}.work-calendar-day--vacation span{color:#274f91;background:#dbe8ff}.work-calendar-day--remote{border-color:#9ed2c1;background:#ecfaf5}.work-calendar-day--remote span{color:#226754;background:#d8f0e7}.work-calendar-day--off,.work-calendar-day--future,.work-calendar-day--neutral{border-color:#e3e9e6;background:#fbfcfc}.work-calendar-day--off span,.work-calendar-day--future span,.work-calendar-day--neutral span{color:#687773;background:#edf1ef}.work-calendar-legend{display:flex;flex-wrap:wrap;gap:12px;color:#667672;font-size:.84rem;font-weight:700}.work-calendar-legend span{display:inline-flex;align-items:center;gap:6px}.legend-dot{display:inline-block;width:10px;height:10px;border-radius:999px;background:#c7d2ce}.legend-dot--ok{background:#2d806b}.legend-dot--under{background:#c34f42}.legend-dot--pending{background:#d7ad2b}.legend-dot--vacation{background:#5d82c6}.legend-dot--remote{background:#2d806b}.legend-dot--neutral{background:#a9b6b1}.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(5,minmax(82px,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}:root[data-theme=light] .login-shell{color:#17201d;background:linear-gradient(90deg,#f4f8f6f0,#f1f7f4db 42%,#f1f7f457),url(/brand/komag_wejscie_tlo.jpg) right center / cover no-repeat,#f1f6f3}:root[data-theme=light] .login-shell:before{background:linear-gradient(180deg,#246b593d,#8dc63f00)}:root[data-theme=light] .login-clean{border-color:#246b5933;border-left-color:#246b59;color:#17201d;background:#ffffffd1;box-shadow:0 24px 64px #1423342e}:root[data-theme=light] .login-theme-toggle{border-color:#246b5933;color:#17201d;background:#fffc}:root[data-theme=light] .login-subtitle,:root[data-theme=light] .login-loading,:root[data-theme=light] .login-dev>span{color:#40514c}:root[data-theme=light] .login-option{border-color:#246b592e;color:#17201d;background:#ffffffb8}:root[data-theme=light] .login-option small{color:#667672}:root[data-theme=dark] .app-shell,:root[data-theme=dark] .content-shell{color:var(--text-strong);background:var(--content-bg)}:root[data-theme=dark] .topbar{border-bottom-color:var(--border)}:root[data-theme=dark] .topbar h2,:root[data-theme=dark] .panel h2,:root[data-theme=dark] .portal-hero h2,:root[data-theme=dark] .employee-hero h2,:root[data-theme=dark] .request-hero h2,:root[data-theme=dark] .module-card__body strong,:root[data-theme=dark] .entry-row__title,:root[data-theme=dark] .compact-row strong,:root[data-theme=dark] .employee-status-card strong,:root[data-theme=dark] .employee-card strong,:root[data-theme=dark] .employee-progress strong,:root[data-theme=dark] .employee-request-summary strong,:root[data-theme=dark] .employee-day-card strong,:root[data-theme=dark] .employee-request-row strong,:root[data-theme=dark] .employee-doc-card strong,:root[data-theme=dark] .employee-profile-checks strong,:root[data-theme=dark] .request-hero__stats strong,:root[data-theme=dark] .vacation-balance-grid strong,:root[data-theme=dark] .time-summary-card strong,:root[data-theme=dark] .time-action-card strong,:root[data-theme=dark] .work-calendar-day strong,:root[data-theme=dark] .time-day-row>strong,:root[data-theme=dark] .time-kpi-grid strong,:root[data-theme=dark] .metric-value,:root[data-theme=dark] .portal-kpis strong,:root[data-theme=dark] .profile-grid strong,:root[data-theme=dark] .metric-stack strong,:root[data-theme=dark] .admin-kpi strong,:root[data-theme=dark] .admin-user-row__identity strong,:root[data-theme=dark] .admin-role-card strong,:root[data-theme=dark] .admin-module-row strong,:root[data-theme=dark] .audit-row strong,:root[data-theme=dark] .traffic-path strong,:root[data-theme=dark] .security-check strong{color:var(--text-title)}:root[data-theme=dark] .eyebrow,:root[data-theme=dark] .panel p,:root[data-theme=dark] .panel small,:root[data-theme=dark] .compact-row small,:root[data-theme=dark] .entry-row small,:root[data-theme=dark] .portal-hero p,:root[data-theme=dark] .employee-hero p,:root[data-theme=dark] .request-hero p,:root[data-theme=dark] .request-hero__stats span,:root[data-theme=dark] .vacation-balance-grid span,:root[data-theme=dark] .vacation-balance-grid small,:root[data-theme=dark] .employee-status-card span,:root[data-theme=dark] .employee-card span,:root[data-theme=dark] .employee-card small,:root[data-theme=dark] .employee-action-card small,:root[data-theme=dark] .employee-progress span,:root[data-theme=dark] .employee-request-summary span,:root[data-theme=dark] .employee-day-card small,:root[data-theme=dark] .employee-request-row small,:root[data-theme=dark] .employee-doc-card small,:root[data-theme=dark] .employee-profile-checks small,:root[data-theme=dark] .time-summary-card small,:root[data-theme=dark] .time-action-card small,:root[data-theme=dark] .work-calendar__weekdays span,:root[data-theme=dark] .work-calendar-day small,:root[data-theme=dark] .work-calendar-legend,:root[data-theme=dark] .module-card__body small,:root[data-theme=dark] .portal-kpis span,:root[data-theme=dark] .profile-grid span,:root[data-theme=dark] .metric-stack span,:root[data-theme=dark] .time-kpi-grid span,:root[data-theme=dark] .time-day-row small,:root[data-theme=dark] .time-day-row span,:root[data-theme=dark] .admin-kpi span:not(.admin-kpi__icon),:root[data-theme=dark] .admin-user-meta,:root[data-theme=dark] .traffic-row time,:root[data-theme=dark] .traffic-agent,:root[data-theme=dark] .traffic-path small,:root[data-theme=dark] .audit-row time,:root[data-theme=dark] .security-check span,:root[data-theme=dark] label{color:var(--text-muted)}:root[data-theme=dark] .panel,:root[data-theme=dark] .admin-tabs,:root[data-theme=dark] .admin-kpi,:root[data-theme=dark] .admin-user-row,:root[data-theme=dark] .admin-role-card,:root[data-theme=dark] .admin-module-row,:root[data-theme=dark] .audit-row,:root[data-theme=dark] .traffic-row,:root[data-theme=dark] .security-check,:root[data-theme=dark] .entry-row,:root[data-theme=dark] .compact-row,:root[data-theme=dark] .module-table__row,:root[data-theme=dark] .portal-hero,:root[data-theme=dark] .employee-hero,:root[data-theme=dark] .request-hero,:root[data-theme=dark] .request-tabs,:root[data-theme=dark] .employee-tabs,:root[data-theme=dark] .employee-section,:root[data-theme=dark] .employee-section-grid,:root[data-theme=dark] .time-work-tabs,:root[data-theme=dark] .portal-kpis article,:root[data-theme=dark] .profile-grid article,:root[data-theme=dark] .metric-stack article,:root[data-theme=dark] .employee-status-card,:root[data-theme=dark] .employee-card,:root[data-theme=dark] .employee-action-card,:root[data-theme=dark] .employee-request-summary article,:root[data-theme=dark] .employee-day-card,:root[data-theme=dark] .employee-request-row,:root[data-theme=dark] .employee-doc-card,:root[data-theme=dark] .employee-profile-checks article,:root[data-theme=dark] .request-hero__stats article,:root[data-theme=dark] .vacation-balance-grid article,:root[data-theme=dark] .time-summary-card,:root[data-theme=dark] .time-action-card,:root[data-theme=dark] .work-calendar-day,:root[data-theme=dark] .module-card,:root[data-theme=dark] .time-kpi-grid article,:root[data-theme=dark] .time-day-row,:root[data-theme=dark] .login-panel,:root[data-theme=dark] .empty-state{border-color:var(--border-soft);color:var(--text-strong);background:var(--surface)}:root[data-theme=dark] .admin-user-row,:root[data-theme=dark] .admin-role-card,:root[data-theme=dark] .admin-module-row,:root[data-theme=dark] .audit-row,:root[data-theme=dark] .traffic-row,:root[data-theme=dark] .security-check,:root[data-theme=dark] .entry-row,:root[data-theme=dark] .compact-row,:root[data-theme=dark] .module-table__row,:root[data-theme=dark] .portal-kpis article,:root[data-theme=dark] .profile-grid article,:root[data-theme=dark] .metric-stack article,:root[data-theme=dark] .employee-status-card,:root[data-theme=dark] .employee-card,:root[data-theme=dark] .employee-action-card,:root[data-theme=dark] .employee-request-summary article,:root[data-theme=dark] .employee-day-card,:root[data-theme=dark] .employee-request-row,:root[data-theme=dark] .employee-doc-card,:root[data-theme=dark] .employee-profile-checks article,:root[data-theme=dark] .request-hero__stats article,:root[data-theme=dark] .vacation-balance-grid article,:root[data-theme=dark] .time-summary-card,:root[data-theme=dark] .time-action-card,:root[data-theme=dark] .work-calendar-day,:root[data-theme=dark] .time-kpi-grid article,:root[data-theme=dark] .time-day-row{background:var(--surface-muted)}:root[data-theme=dark] .admin-tab,:root[data-theme=dark] .employee-tab,:root[data-theme=dark] .request-tab,:root[data-theme=dark] .time-work-tab{color:var(--text-body)}:root[data-theme=dark] .admin-tab--active,:root[data-theme=dark] .admin-tab:hover,:root[data-theme=dark] .employee-tab--active,:root[data-theme=dark] .employee-tab:hover,:root[data-theme=dark] .request-tab--active,:root[data-theme=dark] .request-tab:hover,:root[data-theme=dark] .time-work-tab--active,:root[data-theme=dark] .time-work-tab:hover,:root[data-theme=dark] .module-card:hover{border-color:#3f6558;color:var(--text-title);background:var(--surface-soft)}:root[data-theme=dark] input,:root[data-theme=dark] select,:root[data-theme=dark] textarea{border-color:#344650;color:var(--text-strong);background:#0f1720}:root[data-theme=dark] input::placeholder,:root[data-theme=dark] textarea::placeholder{color:#788b85}:root[data-theme=dark] input:focus,:root[data-theme=dark] select:focus,:root[data-theme=dark] textarea:focus,:root[data-theme=dark] button:focus-visible{outline-color:var(--focus)}:root[data-theme=dark] .user-chip,:root[data-theme=dark] .button,:root[data-theme=dark] .icon-button,:root[data-theme=dark] .role-toggle{border-color:#344650;color:var(--text-strong);background:var(--surface-elevated)}:root[data-theme=dark] .button--primary{border-color:var(--primary);color:#fff;background:var(--primary)}:root[data-theme=dark] .button--primary:hover,:root[data-theme=dark] .login-primary:hover{border-color:var(--primary-hover);background:var(--primary-hover)}:root[data-theme=dark] .button--danger{border-color:#6e3532;color:var(--danger);background:var(--danger-bg)}:root[data-theme=dark] .button--admin-refresh{border-color:#40566a;color:#fff;background:#203144}:root[data-theme=dark] .admin-kpi__icon,:root[data-theme=dark] .module-card__icon,:root[data-theme=dark] .login-card__icon{color:#9ad7c4;background:var(--primary-soft)}:root[data-theme=dark] .permission-pill{color:#bfe4d8;background:#18392f}:root[data-theme=dark] .status-badge,:root[data-theme=dark] .pill,:root[data-theme=dark] .traffic-method,:root[data-theme=dark] .traffic-status{color:#d7e4df;background:#263440}:root[data-theme=dark] .status-badge--draft,:root[data-theme=dark] .pill--muted{color:#b7c4c0;background:#24313b}:root[data-theme=dark] .status-badge--submitted{color:var(--warn);background:var(--warn-bg)}:root[data-theme=dark] .status-badge--approved{color:#a7dccb;background:#15372d}:root[data-theme=dark] .status-badge--rejected,:root[data-theme=dark] .traffic-status--warn,:root[data-theme=dark] .pill--danger{color:var(--danger);background:var(--danger-bg)}:root[data-theme=dark] .pill--remote{color:#a9d1f0;background:#172f47}:root[data-theme=dark] .form-error,:root[data-theme=dark] .empty-state--error,:root[data-theme=dark] .traffic-row--suspicious{border-color:#6e3532;color:var(--danger);background:var(--danger-bg)}:root[data-theme=dark] .notice{border-color:#6d5b26;color:var(--warn);background:var(--warn-bg)}:root[data-theme=dark] .time-day-row--today{border-color:#8dc63fb8;background:#14251b}:root[data-theme=dark] .employee-status-card--active,:root[data-theme=dark] .employee-card--primary,:root[data-theme=dark] .employee-day-card--today,:root[data-theme=dark] .time-summary-card--hero{border-color:#8dc63f9e;background:#14251b}:root[data-theme=dark] .employee-progress__track{background:#22313a}:root[data-theme=dark] .employee-progress__track span{background:#8dc63f}:root[data-theme=dark] .employee-day-card span{color:#a7dccb}:root[data-theme=dark] .work-calendar__empty{border-color:#24323d;background:#111a22}:root[data-theme=dark] .work-calendar-day--ok{border-color:#356f5e;background:#12372c}:root[data-theme=dark] .work-calendar-day--ok span{color:#bfe4d8;background:#1c4b3e}:root[data-theme=dark] .work-calendar-day--under{border-color:#6e3532;background:#321d1e}:root[data-theme=dark] .work-calendar-day--under span{color:#ffbbb4;background:#552927}:root[data-theme=dark] .work-calendar-day--pending{border-color:#6d5b26;background:#322917}:root[data-theme=dark] .work-calendar-day--pending span{color:#f0d281;background:#54431b}:root[data-theme=dark] .work-calendar-day--vacation{border-color:#385989;background:#15243a}:root[data-theme=dark] .work-calendar-day--vacation span{color:#cfe1ff;background:#243f68}:root[data-theme=dark] .work-calendar-day--remote{border-color:#366e5f;background:#123127}:root[data-theme=dark] .work-calendar-day--remote span{color:#cdeee3;background:#1d5344}:root[data-theme=dark] .work-calendar-day--off,:root[data-theme=dark] .work-calendar-day--future,:root[data-theme=dark] .work-calendar-day--neutral{border-color:#24323d;background:#101922}:root[data-theme=dark] .work-calendar-day--off span,:root[data-theme=dark] .work-calendar-day--future span,:root[data-theme=dark] .work-calendar-day--neutral span{color:#b7c4c0;background:#24313b}:root[data-theme=dark] .empty-state{border-color:#3a4a54;background:#111a22}:root[data-theme=dark] .login-card,:root[data-theme=dark] .login-panel{color:var(--text-strong);background:var(--surface)}:root[data-theme=dark] .login-card h3,:root[data-theme=dark] .login-panel h2{color:var(--text-title)}:root[data-theme=dark] .login-card p,:root[data-theme=dark] .login-panel p{color:var(--text-muted)}@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,.admin-layout,.portal-hero,.employee-hero,.request-hero,.request-bar,.employee-section-grid,.employee-doc-grid--catalog,.employee-profile-checks,.time-work-section-grid,.vacation-balance-grid,.time-work-layout,.module-page-grid{grid-template-columns:1fr}.admin-kpis{grid-template-columns:repeat(2,minmax(160px,1fr))}.admin-panel--users,.admin-panel--audit{grid-row:auto}.module-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}.employee-action-card,.time-action-card{grid-template-columns:1fr}}@media(max-width:640px){.content-shell{padding:14px}.topbar{align-items:flex-start;flex-direction:column}.topbar__actions,.user-chip{width:100%}.topbar__actions{flex-wrap:wrap}.topbar__actions .theme-toggle{flex:1 1 126px}.topbar__actions .user-chip{justify-content:flex-start}.login-shell{padding:16px}.login-theme-toggle{top:12px;right:12px;min-width:86px}.official-login-brand,.login-primary--clean{width:100%}.login-card,.login-card__header{grid-template-columns:1fr}.admin-hero{align-items:flex-start;flex-direction:column}.employee-tabs,.request-tabs,.time-work-tabs{display:grid;grid-template-columns:1fr}.form-grid,.entry-row,.compact-row,.module-table__row,.admin-kpis,.admin-user-row,.admin-user-row--expanded,.admin-user-edit-grid,.admin-module-edit-grid,.admin-module-row,.audit-row,.traffic-row,.time-clock-status,.time-kpi-grid,.vacation-balance-grid,.time-day-row,.portal-kpis,.profile-grid,.employee-request-summary,.employee-day-card,.employee-request-row,.employee-doc-card,.employee-profile-checks article,.request-bar,.module-grid,.module-card{grid-template-columns:1fr}.entry-row__actions{justify-content:flex-start}.admin-user-row__actions,.audit-row .pill,.traffic-row .pill{justify-self:stretch}.time-clock-button{width:100%}.time-day-row>strong{text-align:left}}
