:root{--bg:#eef3fb;--bg-soft:#f8fbff;--surface:#fff;--surface-soft:#f9fbff;--text:#0f172a;--muted:#5b6b82;--border:#d7e2f0;--primary:#0f6cdb;--primary-strong:#0a58b5;--danger:#be2e3a;--success:#0d8a55;--shadow:0 18px 40px #11204014}*{box-sizing:border-box}::selection{color:#0b2f64;background:#bfdcff}html,body{min-height:100%}body{color:var(--text);background:radial-gradient(1200px 450px at 10% -10%, #d7e7ff 0%, transparent 60%), radial-gradient(900px 420px at 90% -18%, #d2f4eb 0%, transparent 58%), linear-gradient(180deg, var(--bg-soft) 0%, var(--bg) 100%);margin:0;font-family:Manrope,Avenir Next,Segoe UI,sans-serif;overflow-x:hidden}h1,h2,h3{letter-spacing:-.02em;margin:0;font-family:Sora,Manrope,Avenir Next,sans-serif}h1{font-size:clamp(1.7rem,2.4vw,2.2rem)}h2{font-size:clamp(1.15rem,1.6vw,1.45rem)}h3{font-size:clamp(1rem,1.2vw,1.16rem)}p{margin:0}a{color:inherit;text-decoration:none}.page-shell{min-height:calc(100vh - 88px)}.container{width:min(1700px,100vw - 32px);margin:0 auto}.card{background:linear-gradient(180deg, var(--surface) 0%, var(--surface-soft) 100%);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;padding:16px}.grid{gap:12px;display:grid}.grid-4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.filters-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.quick-range-bar{flex-wrap:wrap;gap:8px;display:flex}.quick-range-btn{width:auto;min-width:120px}.filter-submit,.employee-filter-submit{align-self:end}.filter-actions{justify-content:flex-start;align-self:end;gap:8px;display:flex}.filter-actions button,.filter-actions .button-link{white-space:nowrap;flex:none;width:auto;min-width:142px}.button-link{cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:100%;padding:10px 12px;font-family:inherit;font-size:14px;font-weight:700;text-decoration:none;display:inline-flex}.button-link.secondary{color:var(--text);border:1px solid var(--border);background:#fff}.button-link.secondary:hover{box-shadow:0 8px 16px #10182814}.employee-filter-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.employee-filter-control{align-content:start;display:grid}.employee-filter-control-label{align-items:flex-end;min-height:34px;display:flex}.full-span{grid-column:1/-1}.employee-checklist{border:1px solid var(--border);background:#fff;border-radius:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;max-height:220px;padding:10px;display:grid;overflow-y:auto}.employee-status-grid{grid-template-columns:repeat(2,minmax(280px,1fr));gap:12px;display:grid}.employee-status-panel{align-content:start;gap:8px;display:grid}.employee-checklist-vertical{grid-template-columns:1fr;max-height:300px}.saved-filter-bar{grid-template-columns:minmax(220px,1fr) minmax(180px,1fr) repeat(4,minmax(120px,auto));align-items:flex-end;gap:8px;display:grid}label{color:var(--muted);margin-bottom:6px;font-size:12px;font-weight:600;display:block}input,select,textarea,button{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:10px;padding:10px 12px;font-family:inherit;font-size:14px}textarea{resize:vertical}input:focus,select:focus,textarea:focus,button:focus{border-color:#7ab2f8;outline:none;box-shadow:0 0 0 3px #3e82e82e}button{background:linear-gradient(180deg, var(--primary) 0%, var(--primary-strong) 100%);color:#fff;cursor:pointer;border:none;font-weight:700;transition:transform .15s,box-shadow .2s,opacity .2s}button:hover{transform:translateY(-1px);box-shadow:0 8px 20px #0f6cdb47}button:disabled{cursor:not-allowed;opacity:.7;box-shadow:none;transform:none}button.secondary{color:var(--text);border:1px solid var(--border);background:#fff}button.secondary:hover{box-shadow:0 8px 16px #10182814}table{border-collapse:collapse;border-radius:10px;width:100%;overflow:hidden}th,td{text-align:left;border-bottom:1px solid var(--border);padding:9px;font-size:13px}th{color:var(--muted);background:#f5f9ff;font-weight:700}tbody tr:hover{background:#f9fbff}.badge{border-radius:999px;padding:3px 8px;font-size:11px;font-weight:700;display:inline-block}.badge.success{color:var(--success);background:#e8fbf2}.badge.danger{color:var(--danger);background:#fff0f2}.badge.warning{color:#b54708;background:#fff7e8}.badge.neutral{color:#475467;background:#edf2f7}.row{align-items:center;gap:10px;display:flex}.space-between{justify-content:space-between}.tracker-wrap{width:100%;padding-bottom:6px;overflow:visible}.tracker-wrap svg{width:100%;max-width:100%;height:auto;display:block}.chart-interactive-wrap{position:relative}.chart-tooltip{color:#fff;white-space:pre-line;pointer-events:none;z-index:4;background:#0f172af0;border-radius:8px;padding:6px 8px;font-size:12px;font-weight:600;line-height:1.25;position:absolute;transform:translate(-50%,-112%);box-shadow:0 10px 24px #02061747}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-12{margin-bottom:12px}.nav{z-index:40;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe0;position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;gap:12px;min-height:64px;padding:10px 0;display:flex}.nav-main{align-items:center;gap:16px;min-width:0;display:flex}.nav-brand{white-space:nowrap;color:#1c2b44;align-items:center;gap:10px;font-size:1rem;font-weight:800;display:inline-flex}.nav-brand-mark{border-radius:8px}.nav-links{flex-wrap:wrap;gap:8px;display:flex}.nav-link{color:var(--muted);white-space:nowrap;border-radius:10px;padding:7px 11px;font-size:14px;font-weight:600}.nav-link:hover{color:#0f4c99;background:#eaf3ff}.nav-link.active{color:#fff;background:linear-gradient(180deg, var(--primary) 0%, var(--primary-strong) 100%)}.logout-btn{white-space:nowrap;width:auto}.login-wrap{place-items:center;min-height:calc(100vh - 170px);padding-block:28px;display:grid}.login-card{width:100%;max-width:430px}.login-logo{margin-bottom:12px;display:block}.site-footer{border-top:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffeb}.footer-inner{justify-content:space-between;align-items:center;gap:12px;min-height:76px;display:flex}.footer-copy{color:var(--muted);font-size:13px;font-weight:600}.footer-logo{width:148px;height:auto;display:block}@media (max-width:900px){.container{width:calc(100vw - 20px)}.card{border-radius:14px;padding:14px}.grid-2{grid-template-columns:1fr}.nav-inner{flex-wrap:wrap;align-items:flex-start}.nav-main{flex-direction:column;align-items:flex-start;gap:8px;width:100%}.nav-links{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;width:100%;padding-bottom:2px;overflow-x:auto}.logout-btn{margin-left:auto}.footer-inner{min-height:68px}}@media (max-width:640px){.filters-grid,.employee-filter-grid{grid-template-columns:1fr}.employee-checklist{grid-template-columns:1fr;max-height:260px}.employee-status-grid{grid-template-columns:1fr}.employee-checklist-vertical{max-height:240px}.saved-filter-bar{grid-template-columns:1fr 1fr}.quick-range-btn{width:100%;min-width:0}.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}th,td{padding:7px;font-size:12px}.footer-logo{width:132px}}@media (max-width:420px){.grid-4,.saved-filter-bar{grid-template-columns:1fr}input,select,textarea,button{font-size:16px}.footer-inner{flex-direction:column;justify-content:center;align-items:flex-start;padding:12px 0}.footer-logo{width:120px;margin-left:auto}}.summary-period-tabs{flex-wrap:wrap;gap:8px;display:flex}.summary-tab{width:auto;min-width:96px;padding:8px 12px;font-size:13px}.summary-tab.active{color:#fff;background:linear-gradient(180deg, var(--primary) 0%, var(--primary-strong) 100%);border:none}.summary-pager-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.summary-pager-actions{align-items:center;gap:8px;display:flex}.summary-pager-actions button{width:auto;min-width:72px}@media (max-width:640px){.summary-period-tabs{width:100%}.summary-tab{flex:calc(50% - 8px);min-width:0}.summary-pager-footer{align-items:flex-start}}.nav-controls{align-items:center;gap:8px;margin-left:auto;display:flex}.nav-menu-toggle,.logout-btn{white-space:nowrap;width:auto}.nav-drawer{flex-wrap:wrap;gap:8px;padding:0 0 12px;display:none}.nav-drawer.open{display:flex}@media (max-width:900px){.nav-inner{flex-wrap:nowrap;align-items:center}.nav-controls{gap:6px}.nav-drawer.open{grid-template-columns:1fr;display:grid}.nav-drawer .nav-link{width:100%}}@media (max-width:640px){.nav-brand{font-size:.95rem}.nav-brand span{text-overflow:ellipsis;max-width:180px;overflow:hidden}.nav-menu-toggle,.logout-btn{padding:8px 10px}}.resource-filter-actions{align-items:flex-end;gap:8px;display:flex}.resource-filter-actions button,.resource-filter-actions .button-link{width:auto;min-width:142px}.resource-entry-form,.resource-capacity-form{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.budget-settings-wrap{gap:14px}.budget-setting-actions button{width:auto;min-width:150px}.pivot-table th,.pivot-table td{white-space:nowrap;padding:7px 8px;font-size:12px}.pivot-table th:first-child,.pivot-table td:first-child{z-index:2;background:#fff;position:sticky;left:0}.pivot-table thead th:first-child{background:#f5f9ff}.pivot-table tbody tr[style] td:first-child{background:#ecf3ff}.resource-form-action{align-self:end}.table-scroll-shell{gap:8px;max-width:100%;display:grid}.table-scroll-controls{justify-content:flex-end;gap:8px;display:flex}.table-scroll-viewport{-webkit-overflow-scrolling:touch;max-width:100%;overflow:auto hidden}@media (max-width:640px){.resource-filter-actions{flex-direction:column;width:100%}.resource-filter-actions button,.resource-filter-actions .button-link{width:100%}.budget-setting-actions{flex-direction:column;width:100%}.budget-setting-actions button{width:100%}}.loading-skeleton{background:linear-gradient(90deg,#eef3fb 0%,#e5edf8 45%,#f2f6fd 100%) 0 0/240% 100%;border-radius:10px;animation:1.2s ease-in-out infinite loadingPulse}.loading-line{height:12px}.loading-line.title{border-radius:12px;width:min(340px,80%);height:28px}.loading-line.subtitle{width:min(560px,95%)}.loading-card{height:94px}.loading-chart{height:300px}@keyframes loadingPulse{0%{background-position:100% 0}to{background-position:0 0}}
