:root{--font-sans:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--color-primary:#1a3c2e;--color-primary-dark:#14532d;--color-primary-mid:#166534;--color-primary-light:#16a34a;--color-primary-subtle:#dcfce7;--color-primary-bg:#f0fdf4;--color-selected-bg:#e8f5e9;--color-selected-border:#2d6a4f;--color-sidebar-bg:#1a3c2e;--color-sidebar-text:#fff;--color-sidebar-muted:#fff9;--color-sidebar-hover:#ffffff14;--color-sidebar-active:#ffffff26;--color-sidebar-accent:#4ade80;--color-text-primary:#111827;--color-text-secondary:#374151;--color-bg-page:#f9fafb;--color-bg-card:#fff;--color-bg-hover:#f3f4f6;--color-danger-bg:#fef2f2;--color-warning-bg:#fef9c3;--color-info-bg:#dbeafe;--color-success-bg:#dcfce7;--kpi-color-1:#1a3c2e;--kpi-color-2:#0284c7;--kpi-color-3:#ea580c;--kpi-color-4:#dc2626;--kpi-color-5:#7c3aed;--kpi-color-6:#db2777;--kpi-color-7:#0891b2;--color-brand:#0f4b33;--color-brand-hover:#0c3f2b;--color-brand-soft:#eaf4ef;--color-bg:#f6f8fa;--color-surface:#fff;--color-border:#e6eaf0;--color-border-strong:#d1d8e1;--color-text:#1f2937;--color-text-muted:#6b7280;--color-text-soft:#9ca3af;--color-inverse:#fff;--color-success:#1f8f5f;--color-warning:#f4a62a;--color-danger:#e15454;--color-info:#4b86e8;--color-danger-strong:#b91c1c;--color-draft-note:#0f766e;--color-step-badge-bg:#e5e7eb;--color-step-badge-text:#475569;--color-status-draft-foreground:#8a5500;--color-status-draft-background:#fff7ed;--color-status-submitted-foreground:#1d4ed8;--color-status-submitted-background:#eff6ff;--color-status-returned-foreground:#a11f1f;--color-status-returned-background:#fef2f2;--color-status-reviewed-foreground:#5b21b6;--color-status-reviewed-background:#f5f3ff;--color-status-finalized-foreground:#065f46;--color-status-finalized-background:#ecfdf5;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-pill:9999px;--shadow-card:0 2px 10px #1018280d;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--space-3xl:32px;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:13px;--font-size-md:14px;--font-size-lg:16px;--font-size-xl:18px;--font-size-2xl:22px;--font-size-3xl:28px;--transition-fast:.12s ease;--transition-base:.18s ease;--bp-sm:640px;--bp-md:768px;--bp-lg:1024px;--bp-xl:1280px;--bp-2xl:1536px;--sidebar-width:168px;--header-height:64px}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);margin:0}.app-shell{background:var(--color-bg);min-height:100vh}.app-main-content{margin-left:var(--sidebar-width);flex-direction:column;min-height:100vh;display:flex}.app-content-inner{padding:var(--space-6)}.app-page-header{z-index:40;min-height:var(--header-height);border-bottom:1px solid var(--color-border);background:var(--color-surface);padding:var(--space-3) var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex;position:sticky;top:0}.app-page-header__title{color:var(--color-text);margin:0;font-size:28px;font-weight:700}.app-page-header__subtitle{color:var(--color-text-muted);margin:2px 0 0;font-size:12px}.app-top-actions{align-items:center;gap:var(--space-2);display:flex}.app-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.app-card--pad-sm{padding:var(--space-4)}.app-card--pad-md{padding:var(--space-5)}.app-card--pad-lg{padding:var(--space-6)}.btn-primary,.btn-secondary{border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;height:36px;padding:0 14px;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:var(--color-brand);color:var(--color-inverse);border:none}.btn-primary:hover{background:var(--color-brand-hover)}.btn-secondary{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text)}.status-badge{border-radius:var(--radius-pill);align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-badge--success{color:var(--color-success);background:color-mix(in srgb, var(--color-success) 12%, white)}.status-badge--warning{color:#9a5a00;background:color-mix(in srgb, var(--color-warning) 20%, white)}.status-badge--danger{color:#942a2a;background:color-mix(in srgb, var(--color-danger) 16%, white)}.status-badge--info{color:#2452a3;background:color-mix(in srgb, var(--color-info) 18%, white)}.data-table-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{color:var(--color-text-muted);text-align:left;padding:14px 16px;font-size:12px;font-weight:600}.data-table td{color:var(--color-text);border-top:1px solid #eef1f4;padding:14px 16px;font-size:14px}@media (width<=1024px){.app-main-content{margin-left:64px}}@media (width<=768px){.app-main-content{margin-left:0}.app-content-inner{padding:var(--space-4)}.app-page-header__title{font-size:20px}.app-page-header__subtitle{display:none}}:root{--brand-primary:#0f3d2e;--brand-dark:#14543f;--brand-light:#e8f3ee;--brand-accent:#22c55e;--border-green:#2f7d32;--sidebar-bg:#fff;--sidebar-text:#fff;--sidebar-muted:#fff9;--sidebar-active:#ffffff26;--sidebar-hover:#ffffff14;--sidebar-border:#ffffff1f;--bg-base:#f7f8fa;--bg-surface:#fff;--bg-subtle:#eff1f5;--kpi-1:#2563eb;--kpi-2:#059669;--kpi-3:#d97706;--kpi-4:#dc2626;--kpi-5:#7c3aed;--kpi-6:#db2777;--kpi-7:#0891b2;--text-primary:#1f2937;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-inverse:#fff;--border-subtle:#e5e7eb;--border-medium:#d1d5db;--border-strong:#9ca3af;--success:#059669;--warning:#d97706;--error:#dc2626;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 2px 8px #00000012;--shadow-md:0 4px 16px #0000001a;--shadow-lg:0 8px 32px #0000001f;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--font-sans:"Inter", sans-serif;--font-mono:ui-monospace, "Cascadia Code", Consolas, monospace}body{font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-base);-webkit-font-smoothing:antialiased;font-size:14px}.score-value{font-family:var(--font-mono);font-feature-settings:"tnum"}:root{--primary:var(--brand-primary);--primary-light:var(--kpi-1);--danger:var(--error);--gray-50:var(--bg-base);--gray-100:var(--bg-subtle);--gray-200:var(--border-subtle);--gray-700:var(--text-secondary);--gray-900:var(--text-primary);--radius:var(--radius-lg);--shadow:var(--shadow-xs);--shadow-lg:var(--shadow-md)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--gray-50);color:var(--gray-900)}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--primary);color:#fff;width:260px;padding:24px 16px}.sidebar h2{margin-bottom:8px;font-size:16px}.sidebar p{opacity:.7;margin-bottom:32px;font-size:12px}.sidebar nav a{color:#fff;border-radius:8px;align-items:center;gap:12px;margin-bottom:4px;padding:12px 16px;font-size:14px;text-decoration:none;transition:background .2s;display:flex}.sidebar nav a:hover,.sidebar nav a.active{background:#ffffff26}.main-content{flex:1;max-width:1200px;padding:32px}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.dashboard-header h1{font-size:28px}.dashboard-header p{color:#6b7280;margin-top:4px}.summary-cards{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;display:grid}.card{border-radius:var(--radius);box-shadow:var(--shadow);text-align:center;background:#fff;padding:24px}.card-icon{margin-bottom:8px;font-size:32px}.card-value{color:var(--primary);font-size:28px;font-weight:700}.card-label{color:#6b7280;margin-top:4px;font-size:13px}.dashboard-section{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:24px;padding:24px}.dashboard-section h2{margin-bottom:16px;font-size:18px}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table thead{background:var(--gray-100)}.data-table th{text-align:left;color:var(--gray-700);border-bottom:2px solid var(--gray-200);padding:12px 16px;font-weight:600}.data-table td{border-bottom:1px solid var(--gray-200);padding:12px 16px}.data-table tr:hover{background:var(--gray-50)}.kpi-performance-page{box-sizing:border-box;width:100%;max-width:100%}.obs-score-header{color:#fff;border-radius:var(--radius) var(--radius) 0 0;justify-content:space-between;align-items:center;padding:20px;display:flex}.obs-total{font-size:24px;font-weight:700}.form-section{border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;margin-bottom:16px;padding:20px}.form-section h3{color:var(--gray-700);margin-bottom:12px;font-size:16px}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-grid input,.form-grid select{border:1px solid var(--gray-200);border-radius:8px;padding:10px 12px;font-size:14px}.indicator-row{border-bottom:1px solid var(--gray-100);align-items:center;gap:12px;padding:10px 0;display:flex}.indicator-label{flex:1;font-size:14px}.score-buttons{gap:4px;display:flex}.score-btn{border:2px solid var(--gray-200);cursor:pointer;background:#fff;border-radius:50%;width:36px;height:36px;font-weight:600;transition:all .2s}.score-btn.active{background:var(--primary-light);color:#fff;border-color:var(--primary-light)}.indicator-notes{border:1px solid var(--gray-200);border-radius:6px;width:150px;padding:6px 10px;font-size:12px}.category-header{justify-content:space-between;align-items:center;display:flex}.category-score{color:var(--primary);font-size:16px;font-weight:700}.progress-bar{background:var(--gray-200);border-radius:4px;width:120px;height:8px;margin-right:8px;display:inline-block;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .5s}.badge,.status-badge{border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.trend-chart{align-items:flex-end;gap:16px;height:200px;padding:20px 0;display:flex}.trend-bar-wrapper{flex-direction:column;flex:1;align-items:center;display:flex}.trend-bar{color:#fff;border-radius:8px 8px 0 0;justify-content:center;align-items:flex-start;width:100%;min-height:20px;padding-top:8px;font-size:13px;font-weight:600;display:flex}.trend-label{text-align:center;color:var(--gray-700);margin-top:8px;font-size:11px}.trend-visits{color:#9ca3af;font-size:10px}.filter-bar{flex-wrap:wrap;gap:12px;margin-bottom:24px;display:flex}.filter-bar select{border:1px solid var(--gray-200);border-radius:8px;padding:10px 14px;font-size:14px}.export-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 20px}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--radius);background:#fff;width:90%;max-width:800px;max-height:90vh;padding:32px;position:relative;overflow-y:auto}.modal-close{cursor:pointer;background:0 0;border:none;font-size:20px;position:absolute;top:12px;right:16px}@media (width<=768px){.sidebar{display:none}.summary-cards{grid-template-columns:1fr 1fr}.form-grid{grid-template-columns:1fr}.indicator-row{flex-wrap:wrap}.indicator-notes{width:100%}.kpi-pills{justify-content:flex-start}}body{background:#f9fafb;margin:0;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif}*{box-sizing:border-box}.login-page{background:#eef2f7;grid-template-rows:1fr auto;grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.branding-panel{color:#1e2b4a;background:linear-gradient(#eef2f7 0%,#edf2f8 100%);justify-content:center;align-items:center;padding:3rem;display:flex;position:relative;overflow:hidden}.branding-panel:before,.branding-panel:after{content:none}.branding-content{z-index:2;width:min(620px,100%);position:relative}.branding-content h1{letter-spacing:-.02em;color:#1e2b4a;margin:1.6rem 0 0;font-family:Plus Jakarta Sans,sans-serif;font-size:clamp(2rem,2.9vw,3rem);line-height:1.2}.branding-content p{color:#6b7280;max-width:460px;margin-top:.8rem;font-family:Inter,sans-serif;font-size:1rem}.eyebrow,.brand-lockup{display:none}.dept-head{align-items:center;gap:.7rem;display:flex}.dept-seal{border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;display:flex;overflow:hidden}.seal-svg{object-fit:contain;width:64px;height:64px}.dept-title{letter-spacing:.02em;color:#1f2937;margin:0;font-family:Plus Jakarta Sans,sans-serif;font-size:.95rem;font-weight:700}.dept-subtitle{color:#6b7280;margin:.15rem 0 0;font-family:Inter,sans-serif;font-size:.82rem}.title-accent{background:#2563eb;border-radius:999px;width:48px;height:4px;margin-top:.8rem}.feature-list{gap:.65rem;margin-top:1.35rem;display:grid}.feature-item{align-items:flex-start;gap:.62rem;display:flex}.feature-icon{color:#fff;background:#2563eb;border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:.75rem;font-weight:700;display:grid}.feature-item h4{color:#1f2937;margin:0;font-family:Inter,sans-serif;font-size:.87rem}.feature-item p{color:#6b7280;margin:.08rem 0 0;font-family:Inter,sans-serif;font-size:.79rem}.fi-svg{width:18px;height:18px}.dashboard-preview{z-index:2;background:#fff;border:1px solid #e5e7eb;border-radius:12px;max-height:240px;margin-top:1rem;padding:.75rem;position:relative;overflow:hidden;box-shadow:0 8px 26px #0f172a17}.hero-grid,.hero-grid span,.hero-bars,.hero-bars i{display:none}.preview-header{color:#6b7280;justify-content:space-between;margin-bottom:.4rem;font-size:.65rem;display:flex}.quarter-select-wrap{position:relative}.quarter-select{color:#475569;background:#fff;border:1px solid #dbe3ef;border-radius:6px;padding:.12rem 1rem .12rem .35rem;font-size:.62rem}.preview-stats{grid-template-columns:repeat(4,1fr);gap:.35rem;display:grid}.preview-stats>div{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;gap:.06rem;padding:.35rem .35rem .5rem;display:grid;position:relative}.preview-stats strong{color:#111827;font-size:.86rem;display:block}.preview-stats em{color:#6b7280;font-size:.62rem;font-style:normal;font-weight:500}.preview-stats small{color:#6b7280;font-size:.6rem}.icon-badge{border-radius:6px;place-items:center;width:22px;height:22px;display:grid;position:absolute;top:.3rem;right:.35rem}.icon-badge svg{width:12px;height:12px}.icon-badge.blue{color:#3b82f6;background:#3b82f624}.icon-badge.green{color:#22c55e;background:#22c55e24}.icon-badge.amber{color:#f59e0b;background:#f59e0b24}.icon-badge.purple{color:#a855f7;background:#a855f724}.preview-charts{grid-template-columns:1.6fr 1.2fr;gap:.4rem;margin-top:.45rem;display:grid}.chart-block{gap:.18rem;display:grid}.chart-title{color:#374151;margin:0;font-size:.62rem;font-weight:600}.line-chart,.donut-chart{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;height:98px}.line-chart{grid-template-columns:25px 1fr;gap:.25rem;padding:.3rem .35rem .2rem .25rem;display:grid}.line-y-axis{color:#94a3b8;align-content:space-between;justify-items:end;font-size:.52rem;display:grid}.line-plot{grid-template-rows:1fr auto;display:grid}.line-plot svg{width:100%;height:80px}.line-x-axis{color:#64748b;justify-content:space-between;padding:0 .25rem;font-size:.54rem;display:flex}.donut-chart{background:0 0;border:none;flex:0 0 52px;width:52px;height:52px;position:relative}.donut-chart:after{content:"";border:10px solid #22c55e;border-color:#22c55e #3b82f6 #f59e0b #ef4444;border-radius:50%;width:46px;height:46px;margin:auto;position:absolute;inset:0}.donut-wrap{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:.42rem;min-height:98px;padding:.32rem .35rem;display:flex}.donut-legend{color:#64748b;flex:1;margin:0;padding:0;font-size:.52rem;line-height:1.25;list-style:none}.donut-legend li{justify-content:space-between;align-items:center;gap:.2rem;display:flex}.legend{border-radius:50%;width:6px;height:6px;display:inline-block}.legend.green{background:#22c55e}.legend.blue{background:#3b82f6}.legend.amber{background:#f59e0b}.legend.orange{background:#f97316}.legend.red{background:#ef4444}.donut-legend b{color:#334155;font-size:.52rem}.login-panel{background:#f4f6fb;place-items:center;padding:2rem 2.3rem;display:grid}.login-card{background:#fff;border:1px solid #edf0f6;border-radius:16px;gap:.75rem;width:min(440px,100%);padding:2.5rem 2.35rem;display:grid;box-shadow:0 8px 24px #1118270d}.shield-icon{color:#fff;background:#255fdb;border-radius:50%;place-items:center;width:56px;height:56px;margin:0 auto .3rem;display:grid;box-shadow:0 6px 16px #2563eb40}.shield-icon span{display:none}.shield-svg{width:20px;height:20px}.login-card h2{color:#111827;text-align:center;letter-spacing:-.01em;margin:0;font-family:Plus Jakarta Sans,sans-serif;font-size:2rem;font-weight:700}.muted-text{color:#6b7280;text-align:center;margin-bottom:.8rem;font-family:Inter,sans-serif;font-size:.9rem}.login-card label{color:#374151;font-family:Inter,sans-serif;font-size:.84rem;font-weight:600}.login-card input{background:#fff;border:1.5px solid #d1d5db;border-radius:9px;width:100%;padding:.78rem 2.8rem .78rem 2.1rem;font-family:Inter,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.login-card input:focus{border-color:#1e40af;outline:none;box-shadow:0 0 0 3px #1e40af1f}.login-actions{justify-content:space-between;align-items:center;gap:1rem;margin:.3rem 0 .7rem;font-size:.9rem;display:flex}.remember-row,.remember-label{white-space:nowrap}.login-actions a{color:#1e3a8a;font-weight:500}.remember-me{cursor:pointer;align-items:center;gap:.5rem;display:inline-flex}.remember-check{accent-color:#1e40af;width:16px;height:16px}.input-wrap{position:relative}.input-icon{color:#9ca3af;pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:.7rem;transform:translateY(-50%)}.field-svg{width:14px;height:14px}.password-toggle{color:#6b7280;cursor:pointer;text-align:center;background:0 0;border:none;min-width:34px;font-size:.74rem;position:absolute;top:50%;right:.55rem;transform:translateY(-50%)}.eye-svg{width:14px;height:14px}.login-error{color:#dc2626;margin-top:-.2rem;font-size:.82rem}.primary-btn{color:#fff;cursor:pointer;background:#1e3a8a;border:none;border-radius:10px;min-height:50px;margin-top:.2rem;padding:1rem;font-family:Inter,sans-serif;font-size:1rem;font-weight:600;transition:background .2s,box-shadow .2s;box-shadow:0 6px 20px #1e3a8a4d}.primary-btn:hover{background:#1e40af;box-shadow:0 8px 22px #1e3a8a54}.primary-btn:disabled{opacity:.85;cursor:not-allowed}.support-text{color:#4b5563;text-align:center;margin-top:.45rem;font-family:Inter,sans-serif;font-size:.85rem}.support-text a{color:#1e40af}.trust-text{color:#9ca3af;text-align:center;border-top:1px solid #e5e7eb;margin-top:.25rem;padding-top:.8rem;font-family:Inter,sans-serif;font-size:.78rem}.trust-icon{vertical-align:text-bottom;margin-right:.35rem;display:inline-flex}.lock-svg{width:12px;height:12px}.login-footer{text-align:center;color:#9ca3af;grid-column:1/-1;padding:.55rem 0 .9rem;font-family:Inter,sans-serif;font-size:.82rem}.branding-panel:after{content:"";pointer-events:none;z-index:1;background:radial-gradient(circle at 12% 100%,#94a3b833 0 115px,#0000 116px),radial-gradient(circle at 40% 102%,#94a3b829 0 102px,#0000 103px),radial-gradient(circle at 66% 104%,#94a3b821 0 94px,#0000 95px),linear-gradient(#94a3b800,#94a3b824);height:210px;position:absolute;bottom:0;left:0;right:38%}.dashboard-layout{background:var(--bg-base);align-items:stretch;min-height:100vh;display:flex}.dashboard-layout:not(.kpi-portal-layout){background:#f9fafb;display:flex}.dashboard-layout:not(.kpi-portal-layout) .sidebar{color:#4b5563;background:#fff;border-right:1px solid #e5e7eb;flex-direction:column;flex-shrink:0;width:240px;min-height:100vh;padding:1rem .75rem;display:flex;position:sticky;top:0;overflow-y:auto}.dashboard-layout:not(.kpi-portal-layout) .sidebar-brand{align-items:center;gap:.65rem;padding:.25rem .35rem 1.05rem;display:flex}.dashboard-layout:not(.kpi-portal-layout) .sidebar-brand-icon{color:#1d4ed8;background:#eff6ff;border-radius:10px;place-items:center;width:32px;height:32px;display:grid}.dashboard-layout:not(.kpi-portal-layout) .sidebar-title{color:#0f172a;letter-spacing:-.02em;margin:0;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:800}.dashboard-layout:not(.kpi-portal-layout) .sidebar nav{gap:.28rem;display:grid}.dashboard-layout:not(.kpi-portal-layout) .sidebar nav a{color:#4b5563;border-radius:9px;align-items:center;gap:.65rem;padding:.66rem .7rem;font-size:.86rem;font-weight:500;text-decoration:none;transition:background .2s,color .2s,box-shadow .2s;display:flex}.dashboard-layout:not(.kpi-portal-layout) .sidebar nav a:hover,.dashboard-layout:not(.kpi-portal-layout) .sidebar nav a.active{color:#1d4ed8;background:#eff6ff;font-weight:700}.dashboard-layout:not(.kpi-portal-layout) .sidebar-help{color:#6b7280;border-top:1px solid #e5e7eb;align-items:flex-start;gap:.6rem;margin-top:auto;padding:1rem .45rem .25rem;display:flex}.dashboard-layout:not(.kpi-portal-layout) .sidebar-help p{color:#374151;margin:0 0 .15rem;font-size:.82rem;font-weight:700}.dashboard-layout:not(.kpi-portal-layout) .sidebar-help a{color:#1d4ed8;font-size:.76rem;font-weight:700;text-decoration:none}.dashboard-layout .sidebar{border-right:1px solid var(--border-subtle);z-index:100;background:#fff;flex-direction:column;flex-shrink:0;width:230px;min-height:100vh;display:flex;position:sticky;top:0}.dashboard-layout .sidebar-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:14px;display:flex}.dashboard-layout .sidebar-logo{border-radius:var(--radius-md);object-fit:contain;width:40px;height:40px}.dashboard-layout .sidebar-title{color:var(--text-primary);margin:0;font-size:15px;font-weight:800;line-height:1.2}.dashboard-layout .sidebar-subtitle{color:var(--text-secondary);font-size:11px}.dashboard-layout .sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:10px 8px;display:flex}.dashboard-layout .sidebar-item{color:var(--text-secondary);border-radius:12px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.dashboard-layout .sidebar-item svg{flex-shrink:0;width:17px;height:17px}.dashboard-layout .sidebar-item:hover{background:var(--brand-light);color:var(--brand-primary)}.dashboard-layout .sidebar-item.active{background:var(--brand-primary);color:var(--text-inverse);box-shadow:0 1px 3px #0f3d2e40}.dashboard-layout .sidebar-footer{border-top:1px solid var(--border-subtle);background:linear-gradient(180deg, var(--brand-primary), var(--brand-dark));border-radius:10px 10px 0 0;margin:auto 8px 8px;padding:14px 12px}.dashboard-layout .sidebar-footer-logo{width:32px;height:32px;margin-bottom:6px}.dashboard-layout .sidebar-footer-text{color:var(--text-inverse);margin:0;font-size:10px;line-height:1.35}.dashboard-main{background:#f1f3f6;flex-direction:column;flex:1;width:100%;min-width:0;display:flex}.dashboard-layout:not(.kpi-portal-layout) .dashboard-main{margin-left:0}.topbar{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);z-index:20;justify-content:space-between;align-items:center;gap:1rem;height:60px;padding:0 24px;display:flex;position:sticky;top:0}.dashboard-layout:not(.kpi-portal-layout) .topbar{background:#fff;border-bottom:1px solid #e5e7eb;height:auto;min-height:64px;padding:.6rem 1.5rem}.topbar-title h1{color:var(--text-primary);margin:0;font-size:26px;font-weight:700;line-height:1}.dashboard-layout:not(.kpi-portal-layout) .topbar-title h1{color:#111827;letter-spacing:-.03em;font-family:Plus Jakarta Sans,sans-serif;font-size:1.45rem;font-weight:800}.topbar-title p{color:var(--text-muted);margin:2px 0 0;font-size:12px;line-height:1.2}.dashboard-layout:not(.kpi-portal-layout) .topbar-title p{color:#6b7280;margin:.15rem 0 0;font-size:.82rem}.topbar input{color:#0f172a;background:#f8fafc;border:1px solid #dbe3ef;border-radius:999px;width:min(460px,100%);padding:.72rem 1rem;font-family:Inter,sans-serif}.topbar input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1f}.topbar-right{align-items:center;gap:.55rem;display:flex}.topbar-right button{border:1px solid var(--border-subtle);background:var(--bg-surface);cursor:pointer;color:var(--text-primary);border-radius:8px;align-items:center;gap:.45rem;padding:7px 12px;font-size:13px;font-weight:500;transition:background .15s;display:inline-flex;position:relative}.topbar-right button:hover{background:var(--bg-subtle)}.topbar-notification span{background:var(--brand-accent);color:#0b3d24;border-radius:999px;place-items:center;min-width:18px;height:18px;font-size:.68rem;font-weight:800;display:grid;position:absolute;top:-7px;right:-6px}.topbar-right .topbar-export{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff;font-weight:600}.topbar-right .topbar-export:hover{background:var(--brand-dark);border-color:var(--brand-dark);color:#fff;box-shadow:none}.dashboard-layout:not(.kpi-portal-layout) .topbar-right .topbar-export{background:#1d4ed8;border-color:#1d4ed8}.dashboard-layout:not(.kpi-portal-layout) .topbar-right .topbar-export:hover{background:#1e40af;border-color:#1e40af}.content{flex:1;align-content:start;gap:1rem;width:100%;min-width:0;padding:1rem 1.25rem 1.25rem;display:grid}.content>*{width:100%;min-width:0}.table-wrapper{width:100%;min-width:0;overflow-x:auto}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem;display:grid}.card{background:#fff;border-radius:16px;padding:1rem;box-shadow:0 10px 28px #0f172a12}.page-panel{box-shadow:none;background:0 0;border:none;border-radius:0;margin:0;padding:0}.dashboard-layout:not(.kpi-portal-layout) .page-panel{background:#fff;border:1px solid #e5e7eb;border-radius:14px;margin:1.25rem;padding:1rem;box-shadow:0 1px 2px #0f172a0a}.page-breadcrumb{color:var(--text-muted);margin:0;font-size:.82rem}.dashboard-layout:not(.kpi-portal-layout) .page-breadcrumb{color:#6b7280;margin-bottom:.85rem}.visit-flow{gap:1rem;display:grid}.visit-stepper{grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;display:grid}.visit-stepper button{color:#475569;cursor:pointer;background:#f8fafc;border:1px solid #dbe3ef;border-radius:12px;align-items:center;gap:.55rem;padding:.75rem;font-weight:700;display:flex}.visit-stepper button span{color:#475569;background:#e5e7eb;border-radius:50%;place-items:center;width:26px;height:26px;display:grid}.visit-stepper button.active{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.visit-stepper button.active span{color:#fff;background:#1d4ed8}.visit-step-pane{display:none}.visit-step-pane.active{gap:1rem;display:grid}.visit-step-actions{flex-wrap:wrap;justify-content:space-between;gap:.75rem;display:flex}.visit-step-actions button{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:9px;padding:.62rem .85rem;font-weight:700}.visit-step-actions .primary-step-btn{color:#fff;background:#1d4ed8;border-color:#1d4ed8}.visit-summary-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;gap:1rem;padding:1rem;display:grid}.visit-summary-card h3,.visit-summary-card p{margin:0}.visit-summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;display:grid}.visit-summary-grid div{background:#fff;border:1px solid #e5e7eb;border-radius:10px;gap:.25rem;padding:.85rem;display:grid}.visit-summary-grid span{color:#6b7280;font-size:.85rem}.visit-summary-grid strong{color:#111827;font-size:1.35rem}.card-label{color:#6b7280;margin:0}.card-value{color:#111827;letter-spacing:-.03em;margin:.45rem 0 .25rem;font-size:1.9rem;font-weight:750}.card-trend{color:#10b981;margin:0}.chart-card h3,.card h3{color:#111827;margin:0 0 .8rem}.chart-placeholder{color:#64748b;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;place-items:center;min-height:140px;display:grid}.bottom-grid{grid-template-columns:1.5fr 1fr;gap:1rem;display:grid}table{border-collapse:collapse;width:100%}th,td{text-align:left;color:#374151;border-bottom:1px solid #e5e7eb;padding:.6rem .2rem}.alerts-list{color:#374151;gap:.55rem;margin:0;padding-left:1rem;display:grid}.kpi-form-header{justify-content:space-between;align-items:center;gap:.8rem;display:flex}.kpi-form-header span{color:#1e40af;font-size:.9rem}@media (width<=980px){.login-page,.dashboard-layout{display:block}.branding-panel{min-height:auto;padding:1.3rem 1rem}.hero-visual{width:min(420px,100%)}.login-card{width:min(430px,100%);padding:2rem 1.25rem}.bottom-grid{grid-template-columns:1fr}.topbar{flex-direction:row}.kpi-form-header{flex-direction:column;align-items:flex-start}.visit-stepper{grid-template-columns:1fr}}@media (width<=768px){.dashboard-layout .sidebar{display:none}.dashboard-main{margin-left:0}.topbar{padding:.6rem 1rem}.content{padding:.75rem}.branding-panel{display:none}.login-panel{min-height:100vh;padding:1.5rem 1rem}.login-footer{padding-bottom:1.2rem}}.schools-filter-bar{align-items:flex-end;gap:var(--space-3,12px);margin:var(--space-4,16px) 0 var(--space-3,12px);flex-wrap:wrap;display:flex}.schools-filter-field{flex-direction:column;flex:160px;gap:4px;min-width:140px;display:flex}.schools-filter-label{color:var(--color-text-muted,#6b7280);font-size:12px;font-weight:600}.schools-filter-input{border:1px solid var(--color-border,#e6eaf0);border-radius:var(--radius-sm,8px);width:100%;height:40px;font-size:14px;font-family:var(--font-sans,Inter, system-ui, sans-serif);color:var(--color-text,#1f2937);background:var(--color-surface,#fff);padding:0 12px}.schools-filter-bar>.schools-filter-input{flex:160px;min-width:140px}.schools-filter-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:32px}.schools-filter-input::placeholder{color:var(--color-text-muted,#6b7280)}.schools-filter-input:focus{border-color:var(--color-brand,#0f4b33);box-shadow:0 0 0 3px color-mix(in srgb, var(--color-brand,#0f4b33) 18%, transparent);outline:none}.schools-filter-meta{justify-content:space-between;align-items:center;gap:var(--space-3,12px);margin-bottom:var(--space-4,16px);flex-wrap:wrap;display:flex}.schools-filter-count{color:var(--color-text-muted,#6b7280);font-size:13px}.schools-filter-empty{padding:var(--space-4,16px) 0;color:var(--color-text-muted,#6b7280);margin:0;font-size:14px}.school-report-btn{align-items:center;gap:6px;padding:6px 12px;font-size:13px;display:inline-flex}.school-report-modal-backdrop{z-index:1200;background:#0f172a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.school-report-modal{background:#fff;border-radius:12px;width:100%;max-width:520px;overflow:hidden;box-shadow:0 20px 60px #00000040}.school-report-modal__header{border-bottom:1px solid #eaecef;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;display:flex}.school-report-modal__title{color:#111827;margin:0;font-size:16px;font-weight:700}.school-report-modal__subtitle{color:#6b7280;margin:4px 0 0;font-size:13px}.school-report-modal__close-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:6px;width:30px;height:30px}.school-report-modal__close-btn:hover{color:#111827;background:#f3f4f6}.school-report-modal__meta-grid{background:#f9fafb;border-bottom:1px solid #eaecef;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:16px 24px;display:grid}.school-report-modal__meta-item{gap:2px;display:grid}.school-report-modal__meta-label{text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;font-size:11px}.school-report-modal__meta-value{color:#111827;font-size:14px;font-weight:600}.school-report-modal__preview-area{padding:20px 24px}.school-report-modal__preview-icon-wrap{text-align:center;margin-bottom:12px}.school-report-modal__preview-icon{color:var(--brand-primary,#0f4b33);opacity:.75}.school-report-modal__preview-label{color:#374151;margin:0 0 8px;font-size:13px;font-weight:600}.school-report-modal__preview-list{margin:0;padding:0;list-style:none}.school-report-modal__preview-list-item{color:#4b5563;border-bottom:1px solid #f0f2f5;padding:6px 0;font-size:13px}.school-report-modal__preview-list-item:last-child{border-bottom:none}.school-report-modal__footer{background:#fafafa;border-top:1px solid #eaecef;justify-content:flex-end;gap:10px;padding:14px 24px;display:flex}@media (width<=480px){.school-report-modal-backdrop{padding:0}.school-report-modal{border-radius:0;flex-direction:column;max-width:none;height:100dvh;display:flex}.school-report-modal__preview-area{flex:1;overflow:auto}.school-report-modal__meta-grid{grid-template-columns:1fr}}.auth-loading,.forbidden-page{justify-content:center;align-items:center;min-height:240px;padding:2rem;display:flex}.forbidden-page__card{text-align:center;max-width:420px}.forbidden-page__code{color:#64748b;margin:0 0 .5rem;font-size:3rem;font-weight:700}.forbidden-page__message{color:#475569;margin:0 0 1.5rem}
