:root{color:#1f2933;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input{font:inherit}#root{min-height:100svh}.app-shell{--page:#f4f6f8;--surface:#fff;--surface-soft:#f8fafb;--ink:#1f2933;--muted:#6b7785;--line:#dce3ea;--line-strong:#c6d0da;--nav:#171a1d;--nav-soft:#22272b;--blue:#1678b7;--blue-soft:#e8f3fa;--green:#1f8a5b;--green-soft:#e8f5ee;--orange:#d97706;--orange-soft:#fff3df;--red:#c24135;--shadow:0 16px 34px #1f293314;background:var(--page);color:var(--ink)}.brand,.identity,.panel-heading,.topbar,.topbar-actions,.search-box,.metric,.status-line,.document-row,.news-row,.action-button,.service-pill{align-items:center;display:flex}.brand-name,.identity-name,.row-title{margin:0;font-weight:750}.brand-context,.identity-meta,.row-meta,.subtitle,.eyebrow,.news-row p,.timeline-item p{color:var(--muted);margin:0}.eyebrow{color:var(--blue);letter-spacing:.08em;text-transform:uppercase;font-size:12px;font-weight:800}h1,h2,h3{letter-spacing:0;margin:0}h1{font-size:30px;line-height:1.15}h2{font-size:17px;line-height:1.25}h3{font-size:14px;line-height:1.35}.subtitle{margin-top:6px;font-size:14px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}button:focus-visible,a:focus-visible,input:focus-visible{outline-offset:2px;outline:3px solid #1678b742}.icon-button,.download-button{background:var(--surface-soft);border:1px solid var(--line);color:var(--ink);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;display:inline-flex}.icon-button:hover,.download-button:hover{border-color:var(--blue);color:var(--blue)}.icon{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;width:20px;height:20px}.metric{background:#ffffff24;border:1px solid #ffffff3d;border-radius:8px;flex-direction:column;justify-content:center;gap:4px;min-width:96px;min-height:92px}.metric span{color:#dfe8ef;font-size:12px;font-weight:700}.metric strong{font-size:24px}.metric.blue{box-shadow:inset 0 -3px #58b8f0}.metric.green{box-shadow:inset 0 -3px #58c28b}.metric.orange{box-shadow:inset 0 -3px #ffb252}.panel{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;flex-direction:column;gap:16px;min-height:260px;padding:18px;display:flex}.panel-heading{border-bottom:1px solid var(--line);gap:9px;min-height:36px;padding-bottom:12px}.panel-heading .icon{color:var(--blue)}.app-shell{grid-template-columns:280px minmax(0,1fr);min-height:100svh;display:grid}.workspace{flex-direction:column;gap:22px;min-width:0;padding:28px;display:flex}.sidebar{background:var(--nav);color:#f4f6f8;flex-direction:column;gap:24px;min-height:100svh;padding:24px 18px;display:flex;position:sticky;top:0}.brand{gap:12px;min-height:52px}.brand-mark{color:#fff;background:linear-gradient(135deg,#1681bc,#39a87b);border-radius:8px;place-items:center;width:48px;height:48px;font-size:28px;font-weight:800;display:grid}.brand-name{letter-spacing:0;font-size:21px}.brand-context{color:#aab4be;font-size:13px}.identity{background:var(--nav-soft);border:1px solid #ffffff14;border-radius:8px;gap:12px;padding:12px}.avatar{color:var(--nav);background:#e7eef5;border-radius:8px;flex:0 0 42px;place-items:center;width:42px;height:42px;font-weight:800;display:grid}.identity-name{color:#fff;font-size:14px}.identity-meta{color:#aab4be;font-size:12px}.role-switch{background:#ffffff14;border-radius:8px;grid-template-columns:repeat(3,1fr);gap:4px;padding:4px;display:grid}.role-button{color:#cbd5df;cursor:pointer;font:inherit;background:0 0;border:0;border-radius:6px;height:34px;font-size:13px}.role-button[aria-pressed=true]{color:var(--nav);background:#fff;font-weight:750}.nav-groups{flex-direction:column;gap:20px;display:flex}.nav-group{gap:6px;display:grid}.nav-heading{color:#8d99a4;letter-spacing:.08em;text-transform:uppercase;margin:0 0 2px;padding:0 10px;font-size:11px;font-weight:800}.nav-item{color:#d7dde3;cursor:pointer;font:inherit;text-align:left;background:0 0;border:0;border-radius:8px;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:10px;min-height:42px;padding:0 10px;font-size:14px;text-decoration:none;display:grid}.nav-item:hover,.nav-item:focus-visible,.nav-item[aria-current=page]{color:#fff;background:#2b3136;outline:none}.nav-item[aria-current=page]{box-shadow:inset 3px 0 0 var(--blue)}.nav-badge{background:var(--orange);color:#fff;text-align:center;border-radius:999px;min-width:24px;padding:2px 6px;font-size:12px}.topbar{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;justify-content:space-between;min-height:92px;padding:18px 20px}.topbar-actions{gap:10px}.search-box{background:var(--surface-soft);border:1px solid var(--line);border-radius:8px;gap:8px;width:min(320px,28vw);height:42px;padding:0 12px}.search-box input{color:var(--ink);font:inherit;background:0 0;border:0;outline:0;width:100%;min-width:0}.hero-panel{color:#fff;background:linear-gradient(90deg,#171a1df0,#171a1dc2),radial-gradient(circle at 78% 30%,#39a87ba6,#0000 30%),linear-gradient(135deg,#1678b7,#171a1d 58%,#d97706);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:24px;min-height:172px;padding:26px;display:grid;overflow:hidden}.hero-panel .eyebrow,.hero-panel p{color:#dfe8ef}.hero-panel h2{max-width:680px;margin:8px 0;font-size:27px}.hero-metrics{grid-template-columns:repeat(3,minmax(96px,1fr));gap:10px;display:grid}.quick-actions{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;display:grid}.action-button{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--line-strong);color:var(--ink);cursor:pointer;font:inherit;text-align:left;border-radius:8px;justify-content:space-between;gap:10px;min-height:58px;padding:0 14px;font-weight:750;text-decoration:none}.action-button span{flex:1}.action-button.blue{border-left-color:var(--blue)}.action-button.green{border-left-color:var(--green)}.action-button.orange{border-left-color:var(--orange)}.action-button:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.dashboard-grid{grid-template-columns:repeat(12,minmax(0,1fr));gap:18px;display:grid}.panel:first-child,.panel:nth-child(2){grid-column:span 6}.panel:nth-child(3),.panel:nth-child(4),.panel:nth-child(5),.panel:nth-child(6){grid-column:span 3}.timeline{gap:10px;display:grid}.timeline-item{border:1px solid var(--line);border-left:4px solid var(--blue);border-radius:8px;grid-template-columns:68px minmax(0,1fr);gap:14px;min-height:74px;padding:12px;display:grid}.timeline-item.green{border-left-color:var(--green)}.timeline-item.orange{border-left-color:var(--orange)}.timeline-item time{color:var(--blue);font-weight:800}.timeline-item p{font-size:13px}.absence-list{gap:10px;display:grid}.absence-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:16px;min-height:72px;padding:4px 0 12px;display:flex}.absence-row:last-child{border-bottom:0}.status-stack{text-align:right;flex-direction:column;align-items:flex-end;gap:6px;display:flex}.status-pill{border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;display:inline-flex}.status-pill.warning{background:var(--orange-soft);color:#9a5100}.grades-table{border:1px solid var(--line);border-radius:8px;overflow:hidden}.table-row{grid-template-columns:minmax(0,1.5fr) 54px 52px;gap:10px;min-height:42px;padding:10px 12px;display:grid}.table-row+.table-row{border-top:1px solid var(--line)}.table-head{background:var(--surface-soft);color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:800}.table-row strong{color:var(--green);text-align:right}.news-list{gap:10px;display:grid}.news-row{border-bottom:1px solid var(--line);align-items:flex-start;gap:12px;min-height:58px;padding-bottom:10px}.news-row:last-child{border-bottom:0}.news-row time{color:var(--blue);font-weight:800}.news-row p{font-size:13px}.document-list{gap:10px;display:grid}.document-row{border-bottom:1px solid var(--line);grid-template-columns:48px minmax(0,1fr) 38px;gap:12px;min-height:56px;padding-bottom:10px;display:grid}.document-row:last-child{border-bottom:0}.document-date{color:var(--blue);font-weight:800}.download-button{width:34px;height:34px}.platform-panel,.platform-status{gap:10px;display:grid}.platform-panel{gap:16px}.api-toggle{background:var(--surface-soft);border-radius:8px;grid-template-columns:repeat(2,1fr);gap:4px;padding:4px;display:grid}.api-toggle button{color:var(--muted);cursor:pointer;font:inherit;background:0 0;border:0;border-radius:6px;min-height:36px}.api-toggle button[aria-pressed=true]{background:var(--ink);color:#fff;font-weight:800}.status-line{border-bottom:1px solid var(--line);grid-template-columns:22px minmax(0,1fr) auto;gap:10px;min-height:42px;padding-bottom:8px;display:grid}.status-line strong{color:var(--green)}.services-strip{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.service-pill{background:var(--surface);border:1px solid var(--line);color:var(--muted);cursor:pointer;font:inherit;border-radius:8px;justify-content:center;min-height:56px;font-weight:800}.service-pill:hover{border-color:var(--blue);color:var(--blue)}.page-view{flex-direction:column;gap:18px;display:flex}.page-header{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;padding:18px 20px}.page-header h2{margin-top:4px;font-size:26px}.page-placeholder{background:var(--surface);border:1px dashed var(--line-strong);box-shadow:var(--shadow);color:var(--line-strong);border-radius:8px;justify-content:center;align-items:center;min-height:360px;display:flex}.page-placeholder .icon{width:46px;height:46px}.auth-page{flex-direction:column;gap:18px;display:flex}.auth-panel{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;grid-template-columns:46px minmax(0,1fr) auto;align-items:center;gap:18px;min-height:180px;padding:22px;display:grid}.auth-panel>.icon{color:var(--blue);width:34px;height:34px}.auth-content{gap:6px;display:grid}.auth-content h3{margin:0;font-size:22px}.auth-error{color:var(--orange);margin:0;font-weight:700}.auth-action,.session-button{background:var(--ink);border:1px solid var(--ink);color:#fff;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;display:inline-flex}.auth-action{min-height:42px;padding:0 16px}.auth-action:disabled,.session-button:disabled{cursor:not-allowed;opacity:.6}.session-button{height:42px;padding:0 12px}.session-button .icon,.auth-action .icon{width:18px;height:18px}.api-state-panel,.api-list,.api-form-panel,.api-detail-panel{background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px}.api-state-panel{grid-template-columns:46px minmax(0,1fr) auto;align-items:center;gap:18px;min-height:160px;padding:22px;display:grid}.api-state-panel>.icon{color:var(--blue);width:34px;height:34px}.api-state-panel h3,.api-detail-panel h3{margin:0 0 6px;font-size:20px}.api-state-panel p,.api-detail-panel p{color:var(--muted);margin:0}.api-warning{color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;align-items:center;gap:10px;padding:12px 14px;display:flex}.api-list{display:grid;overflow:hidden}.api-row{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;min-height:74px;padding:16px 18px;display:grid}.api-row:last-child{border-bottom:0}.api-row-title{color:var(--ink);margin:0 0 4px;font-weight:800}.api-row-meta{color:var(--muted);margin:0;font-size:13px}.api-row-stack{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.api-pill{background:var(--surface-soft);border:1px solid var(--line);color:var(--ink);border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800;display:inline-flex}.api-form-panel,.api-detail-panel{gap:16px;padding:20px;display:grid}.api-form-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.api-form-grid label{color:var(--muted);gap:6px;font-size:13px;font-weight:700;display:grid}.api-form-grid input,.api-form-grid select{background:var(--surface-soft);border:1px solid var(--line);color:var(--ink);font:inherit;border-radius:8px;min-height:42px;padding:0 10px}.api-result{background:var(--surface-soft);border:1px solid var(--line);color:var(--ink);border-radius:8px;margin:0;padding:12px}@media (width<=760px){.api-state-panel,.api-row,.api-form-grid{grid-template-columns:1fr}.api-row-stack{justify-content:flex-start}}@media (width<=1220px){.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.panel:nth-child(3),.panel:nth-child(4),.panel:nth-child(5),.panel:nth-child(6){grid-column:span 6}.hero-panel{grid-template-columns:1fr}.hero-metrics{grid-template-columns:repeat(3,minmax(0,160px))}}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{min-height:auto;position:static}.nav-groups{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}.workspace{padding:18px}.topbar{flex-direction:column;align-items:stretch;gap:16px}.topbar-actions,.search-box{width:100%}.panel:nth-child(n){grid-column:span 12}.services-strip{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=640px){.sidebar,.workspace{padding:14px}.brand,.identity{align-items:flex-start}.nav-groups,.quick-actions,.services-strip,.hero-metrics{grid-template-columns:1fr}.nav-item{min-height:44px}.hero-panel{padding:20px}.hero-panel h2{font-size:23px}.timeline-item,.document-row,.table-row{grid-template-columns:1fr}.absence-row{flex-direction:column}.status-stack{text-align:left;align-items:flex-start}}
