:root{--primary:#5b6fb3;--sky:#57c4f2;--green:#afcc46;--orange:#f6a64a;--magenta:#dc388d;--ink:#1e293b;--text:#475569;--muted:#94a3b8;--border:#e2e8f0;--surface:#fff;--bg:#f5f7fb;--sidebar:180px;font-family:Inter,"Segoe UI",Arial,sans-serif;color:var(--text);background:var(--bg);font-synthesis:none}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg)}button,select{font:inherit}svg{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;z-index:20;display:flex;width:var(--sidebar);flex-direction:column;border-right:1px solid var(--border);background:#fff}.brand{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:3px solid var(--primary)}.brand-mark{display:grid;width:2.65rem;height:2.65rem;place-items:center;border-radius:.65rem;background:var(--primary);color:#fff;font-size:.85rem;font-weight:800;letter-spacing:.03em}.brand>div:last-child{display:grid;min-width:0}.brand strong{color:#334155;font-size:.9rem}.brand span{color:var(--muted);font-size:.68rem}.sidebar nav{flex:1;padding:.8rem}.nav-title{display:block;padding:.6rem .7rem .35rem;color:var(--muted);font-size:.62rem;font-weight:800;letter-spacing:.09em;text-transform:uppercase}.nav-link{display:flex;align-items:center;gap:.65rem;margin:.12rem 0;padding:.62rem .7rem;border-radius:.45rem;color:#64748b;font-size:.78rem;font-weight:600;text-decoration:none;transition:.15s}.nav-link svg{width:1.1rem}.nav-link:hover,.nav-link.active{background:rgba(91,111,179,.1);color:var(--primary)}.sidebar-note{display:grid;gap:.12rem;margin:.8rem;padding:.8rem;border:1px solid var(--border);border-radius:.6rem;background:#f8fafc}.sidebar-note span{color:var(--muted);font-size:.62rem;font-weight:700;text-transform:uppercase}.sidebar-note strong{color:#334155;font-size:.8rem}.sidebar-note small{color:var(--muted);font-size:.65rem}.page{width:calc(100% - var(--sidebar));margin-left:var(--sidebar)}.mobile-header{display:none}.dashboard{width:100%;max-width:1650px;margin:auto;padding:clamp(1rem,2.2vw,1.8rem)}.page-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.2rem}.eyebrow{color:var(--primary);font-size:.67rem;font-weight:800;letter-spacing:.11em;text-transform:uppercase}.page-heading h1{margin:.2rem 0 .25rem;color:var(--ink);font-size:clamp(1.55rem,2.2vw,2.05rem);line-height:1.15}.page-heading p{margin:0;color:#64748b;font-size:.84rem}.cutoff{display:flex;align-items:center;gap:.65rem;min-width:220px;padding:.72rem .85rem;border:1px solid var(--border);border-radius:.65rem;background:#fff}.cutoff svg{width:1.15rem;color:var(--primary)}.cutoff div{display:grid}.cutoff span{color:var(--muted);font-size:.6rem;font-weight:800;text-transform:uppercase}.cutoff strong{color:#334155;font-size:.76rem}.header-actions{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}.session-card{display:flex;align-items:center;gap:.65rem;min-width:220px;padding:.72rem .85rem;border:1px solid var(--border);border-radius:.65rem;background:#fff}.session-card>svg{width:1.15rem;color:var(--primary)}.session-card div{display:grid;flex:1}.session-card span{color:var(--muted);font-size:.6rem;font-weight:800;text-transform:uppercase}.session-card strong{color:#334155;font-size:.76rem}.session-card button{display:grid;width:28px;height:28px;place-items:center;border:0;border-radius:4px;background:transparent;color:var(--muted);cursor:pointer}.session-card button:hover{background:rgba(239,68,68,.14);color:#ef4444}.session-card button svg{width:1rem;color:inherit}.filters{display:grid;grid-template-columns:minmax(140px,.8fr) repeat(3,minmax(170px,1fr)) auto;align-items:end;gap:.7rem;margin-bottom:.85rem;padding:.85rem;border:1px solid var(--border);border-radius:.72rem;background:#fff;box-shadow:0 1px 2px rgba(15,23,42,.03)}.filters label{display:grid;min-width:0;gap:.28rem}.filters label span{color:#64748b;font-size:.61rem;font-weight:800;letter-spacing:.03em;text-transform:uppercase}.filters select{width:100%;height:38px;padding:0 1.8rem 0 .6rem;border:1px solid #cbd5e1;border-radius:.42rem;background:#fff;color:#334155;font-size:.71rem;text-overflow:ellipsis}.filters select:focus{border-color:var(--primary);outline:3px solid rgba(91,111,179,.12)}.reset-button{display:flex;height:38px;align-items:center;justify-content:center;gap:.35rem;padding:0 .75rem;border:1px solid #d9deec;border-radius:.42rem;background:#f7f8fc;color:var(--primary);font-size:.7rem;font-weight:700;cursor:pointer}.reset-button svg{width:.95rem}.reset-button:disabled{cursor:default;opacity:.4}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.8rem;margin-bottom:.8rem}.kpi{display:flex;min-width:0;align-items:center;gap:.75rem;padding:.95rem;border:1px solid var(--border);border-radius:.72rem;background:#fff;box-shadow:0 2px 7px rgba(15,23,42,.04)}.kpi-icon{display:grid;width:2.45rem;height:2.45rem;flex:none;place-items:center;border-radius:.62rem}.kpi-icon svg{width:1.15rem}.kpi>div:last-child{display:grid;min-width:0}.kpi span{color:#64748b;font-size:.62rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.kpi strong{overflow:hidden;margin:.08rem 0;color:var(--ink);font-size:clamp(.95rem,1.35vw,1.22rem);text-overflow:ellipsis;white-space:nowrap}.kpi small{color:var(--muted);font-size:.62rem}.kpi.blue .kpi-icon{background:rgba(91,111,179,.12);color:var(--primary)}.kpi.cyan .kpi-icon{background:rgba(87,196,242,.16);color:#159bcf}.kpi.green .kpi-icon{background:rgba(175,204,70,.2);color:#76920e}.kpi.orange .kpi-icon{background:rgba(246,166,74,.18);color:#d67a10}.chart-grid{display:grid;gap:.8rem;margin-bottom:.8rem}.main-grid{grid-template-columns:minmax(0,1.75fr) minmax(290px,.85fr)}.bottom-grid{grid-template-columns:minmax(350px,1fr) minmax(450px,1.35fr)}.card{min-width:0;padding:.95rem;border:1px solid var(--border);border-radius:.72rem;background:#fff;box-shadow:0 2px 7px rgba(15,23,42,.035)}.card-heading{display:flex;min-height:2.5rem;align-items:flex-start;justify-content:space-between;gap:.7rem}.card-heading h2{margin:0;color:#334155;font-size:.9rem}.card-heading p{margin:.12rem 0 0;color:var(--muted);font-size:.65rem}.card-heading small{color:var(--muted);font-size:.64rem;white-space:nowrap}.progress-pill{padding:.28rem .55rem;border-radius:99px;background:rgba(175,204,70,.2);color:#647f0a;font-size:.7rem;font-weight:800}.monthly-chart{height:250px;margin-top:.45rem}.monthly-chart svg{width:100%;height:100%;overflow:visible}.axis-label{fill:#94a3b8;font-size:10px}.grid-line{stroke:#e2e8f0;stroke-width:1;stroke-dasharray:3 3}.area-fill{fill:url(#areaGradient);stroke:none}.area-line{fill:none;stroke:var(--primary);stroke-width:2.5}.month-bar{fill:var(--sky);opacity:.72}.chart-dot{fill:#fff;stroke:var(--primary);stroke-width:2}.chart-tooltip{position:fixed;z-index:50;display:none;pointer-events:none;padding:.5rem .6rem;border:1px solid var(--border);border-radius:.42rem;background:#fff;box-shadow:0 8px 20px rgba(15,23,42,.14);font-size:.67rem}.donut-layout{display:grid;grid-template-columns:minmax(145px,.85fr) minmax(130px,1fr);align-items:center;gap:.75rem;height:250px}.donut{position:relative;width:min(170px,100%);aspect-ratio:1;margin:auto;border-radius:50%}.donut:after{position:absolute;inset:25%;content:"";border-radius:50%;background:#fff}.donut>div{position:absolute;inset:0;z-index:1;display:grid;place-content:center;text-align:center}.donut strong{max-width:95px;color:#334155;font-size:.78rem}.donut span{color:var(--muted);font-size:.58rem}.legend{display:grid;gap:.55rem}.legend-item{display:grid;grid-template-columns:8px 1fr;gap:.45rem;align-items:start}.legend-dot{width:8px;height:8px;margin-top:.16rem;border-radius:50%}.legend-item div{display:grid}.legend-item span{color:#64748b;font-size:.63rem;line-height:1.25}.legend-item strong{color:#334155;font-size:.65rem}.program-bars{display:grid;gap:.68rem;margin-top:.65rem}.program-row{display:grid;grid-template-columns:145px 1fr 48px;align-items:center;gap:.55rem}.program-name{overflow:hidden;color:#475569;font-size:.62rem;text-overflow:ellipsis;white-space:nowrap}.bar-track{position:relative;height:14px;border-radius:3px;background:#e2e8f0}.bar-pim{position:absolute;inset:0 auto 0 0;border-radius:3px;background:#cbd5e1}.bar-dev{position:absolute;inset:3px auto 3px 0;border-radius:2px;background:var(--primary)}.program-value{color:#64748b;font-size:.6rem;text-align:right}.table-wrap{max-height:300px;overflow:auto;margin-top:.45rem}.table-card table{width:100%;border-collapse:collapse;font-size:.65rem}.table-card th{position:sticky;top:0;z-index:1;padding:.52rem .42rem;background:#f8fafc;color:#64748b;font-size:.57rem;letter-spacing:.04em;text-align:right;text-transform:uppercase}.table-card th:first-child{text-align:left}.table-card td{padding:.52rem .42rem;border-bottom:1px solid #edf0f4;color:#475569;text-align:right;white-space:nowrap}.table-card td:first-child{max-width:230px;overflow:hidden;text-align:left;text-overflow:ellipsis}.advance-cell{display:grid;grid-template-columns:minmax(42px,1fr) 35px;align-items:center;gap:.35rem}.mini-track{height:5px;overflow:hidden;border-radius:99px;background:#e2e8f0}.mini-track span{display:block;height:100%;border-radius:inherit;background:var(--green)}.advance-cell strong{font-size:.62rem}footer{padding:.3rem 0;color:var(--muted);font-size:.59rem;text-align:right}.sidebar-overlay{display:none}.empty{display:grid;min-height:180px;place-items:center;color:var(--muted);font-size:.75rem}@media(max-width:1180px){.filters{grid-template-columns:repeat(2,minmax(0,1fr)) auto}.kpi-grid{grid-template-columns:repeat(2,1fr)}.bottom-grid{grid-template-columns:1fr}}@media(max-width:850px){:root{--sidebar:0px}.sidebar{width:248px;transform:translateX(-100%);transition:transform .2s}.sidebar.open{transform:translateX(0)}.sidebar-overlay.visible{position:fixed;inset:0;z-index:15;display:block;background:rgba(15,23,42,.38)}.page{width:100%;margin:0}.mobile-header{position:sticky;top:0;z-index:10;display:flex;height:52px;align-items:center;gap:.75rem;padding:0 .8rem;background:#1e293b;color:#fff}.mobile-header button{min-width:36px;border:0;background:transparent;color:#fff;font-size:1.2rem}.mobile-header strong{font-size:.82rem}.page-heading{display:grid}.cutoff{width:100%}.main-grid{grid-template-columns:1fr}}@media(max-width:600px){.dashboard{padding:.8rem}.filters{grid-template-columns:1fr}.reset-button{width:100%}.kpi-grid{grid-template-columns:1fr}.card{padding:.75rem}.donut-layout{height:auto;grid-template-columns:1fr}.donut{width:145px}.program-row{grid-template-columns:105px 1fr 42px}.monthly-chart{height:220px}}
