/* AI Project Universe V3.9 — Student Performance complete data + vertical scroll */
:root{
  color-scheme:dark;
  --bg:#07111f;--panel:#0d1a2e;--panel-2:#111f36;--panel-3:#152640;
  --line:rgba(148,163,184,.18);--text:#f3f7fb;--muted:#95a5ba;
  --brand:#7c5cff;--brand-2:#14b8a6;--cyan:#22d3ee;--green:#34d399;
  --amber:#fbbf24;--red:#fb7185;--shadow:0 22px 70px rgba(0,0,0,.34);
}
*{box-sizing:border-box}
html,body{width:100%;min-height:100%;height:auto!important;max-height:none!important;margin:0;overflow-x:hidden!important;overflow-y:auto!important;overscroll-behavior-y:contain;scrollbar-gutter:stable;-webkit-overflow-scrolling:touch;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
body{position:relative!important;inset:auto!important;touch-action:pan-y pinch-zoom}
button,input,select,textarea{font:inherit}
a{color:inherit;text-decoration:none}
button{cursor:pointer}
.sp-app{display:grid;grid-template-columns:260px minmax(0,1fr);align-items:start;min-height:100vh;min-height:100dvh;background:radial-gradient(circle at 78% 0,rgba(124,92,255,.13),transparent 36%),linear-gradient(180deg,#081321,#07111f)}
.sp-sidebar{position:sticky;top:0;align-self:start;height:100vh;height:100dvh;overflow-y:auto;overscroll-behavior:contain;border-right:1px solid var(--line);background:linear-gradient(180deg,#0a1526,#08111f);padding:22px 14px 20px;display:flex;flex-direction:column;gap:24px;z-index:20}
.sp-brand{display:flex;align-items:center;gap:12px;padding:0 8px 4px}.sp-brand__mark{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(145deg,var(--brand),var(--cyan));box-shadow:0 12px 30px rgba(124,92,255,.3);font-weight:900}.sp-brand strong{display:block;font-size:14px;letter-spacing:.02em}.sp-brand small{display:block;margin-top:3px;color:var(--muted);font-size:10px;letter-spacing:.09em;text-transform:uppercase}
.sp-nav-label{padding:0 10px;color:#667892;font-size:9px;font-weight:800;letter-spacing:.14em;text-transform:uppercase}.sp-nav{display:grid;gap:6px}.sp-nav a{display:flex;align-items:center;gap:11px;padding:11px 12px;border:1px solid transparent;border-radius:11px;color:#aebcd0;font-size:13px;font-weight:650;transition:.18s}.sp-nav a:hover{background:rgba(255,255,255,.045);color:#fff}.sp-nav a.is-active{color:#fff;background:linear-gradient(135deg,rgba(124,92,255,.26),rgba(34,211,238,.11));border-color:rgba(124,92,255,.35);box-shadow:inset 3px 0 0 var(--brand)}.sp-nav__icon{width:20px;text-align:center;font-size:15px}
.sp-side-foot{margin-top:auto;border-top:1px solid var(--line);padding:15px 9px 0;color:#73839a;font-size:10px;line-height:1.6}.sp-side-foot strong{color:#cbd6e5}
.sp-main{min-width:0;min-height:0;padding:34px clamp(20px,4vw,58px) 72px;overflow:visible!important}.sp-view{display:none;max-width:1440px;margin:0 auto}.sp-view.is-active{display:block}.sp-page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px}.sp-kicker{display:inline-flex;align-items:center;gap:7px;color:#8de6db;font-size:11px;font-weight:850;letter-spacing:.12em;text-transform:uppercase}.sp-kicker::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--brand-2);box-shadow:0 0 14px var(--brand-2)}h1{font-size:clamp(30px,4vw,52px);line-height:1.03;margin:9px 0 9px;letter-spacing:-.045em}.sp-page-head p{margin:0;color:var(--muted);max-width:780px;line-height:1.65}.sp-head-actions{display:flex;gap:9px;flex-wrap:wrap;justify-content:flex-end}
.sp-btn{border:1px solid var(--line);background:#13243c;color:#eef4fa;border-radius:11px;padding:10px 13px;font-size:12px;font-weight:800;box-shadow:0 8px 25px rgba(0,0,0,.14);transition:.16s}.sp-btn:hover{transform:translateY(-1px);filter:brightness(1.12)}.sp-btn--primary{border-color:transparent;background:linear-gradient(135deg,var(--brand),#4f8cff);color:white}.sp-btn--danger{border-color:rgba(251,113,133,.35);background:rgba(251,113,133,.12);color:#fecdd3}.sp-btn--ghost{background:transparent}.sp-btn--small{padding:7px 9px;font-size:10px}.sp-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}
.sp-grid{display:grid;gap:16px}.sp-grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}.sp-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}.sp-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}.sp-card{min-width:0;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(18,34,57,.96),rgba(11,24,42,.96));box-shadow:var(--shadow);padding:20px}.sp-card--soft{box-shadow:none;background:rgba(14,29,50,.75)}.sp-card h2,.sp-card h3{margin:0 0 7px}.sp-card h2{font-size:20px}.sp-card h3{font-size:15px}.sp-card p{color:var(--muted);line-height:1.55}.sp-metric{position:relative;overflow:hidden}.sp-metric::after{content:"";position:absolute;width:110px;height:110px;border-radius:50%;right:-48px;top:-48px;background:var(--metric-glow,rgba(124,92,255,.2))}.sp-metric small{display:block;color:#8fa1b9;font-size:10px;text-transform:uppercase;letter-spacing:.09em;font-weight:800}.sp-metric strong{display:block;margin:9px 0 5px;font-size:clamp(25px,3vw,38px);font-variant-numeric:tabular-nums}.sp-metric span{font-size:11px;color:#8ea0b7}.sp-metric--green{--metric-glow:rgba(52,211,153,.16)}.sp-metric--amber{--metric-glow:rgba(251,191,36,.16)}.sp-metric--red{--metric-glow:rgba(251,113,133,.15)}
.sp-section{margin-top:18px}.sp-section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.sp-section-head h2{font-size:19px;margin:0}.sp-section-head p{margin:3px 0 0;color:var(--muted);font-size:12px}.sp-status{display:inline-flex;align-items:center;gap:7px;border:1px solid rgba(52,211,153,.28);background:rgba(52,211,153,.09);color:#9ff3cf;padding:7px 10px;border-radius:999px;font-size:10px;font-weight:850;text-transform:uppercase;letter-spacing:.06em}.sp-status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 12px var(--green)}
.sp-bars{display:grid;gap:13px}.sp-bar{display:grid;grid-template-columns:110px minmax(0,1fr) 50px;align-items:center;gap:10px}.sp-bar label{font-size:12px;color:#c9d4e3}.sp-track{height:10px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden}.sp-fill{height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,var(--brand),var(--cyan));transition:width .35s ease}.sp-fill--low{background:linear-gradient(90deg,#10b981,#6ee7b7)}.sp-fill--medium{background:linear-gradient(90deg,#f59e0b,#fde68a)}.sp-fill--high{background:linear-gradient(90deg,#ef4444,#fda4af)}.sp-bar b{font-size:11px;color:#cbd6e5;text-align:right}
.sp-chart{width:100%;height:260px;display:block;border-radius:14px;background:linear-gradient(180deg,rgba(124,92,255,.055),rgba(34,211,238,.02));border:1px solid rgba(255,255,255,.06)}.sp-chart text{fill:#8192aa;font-size:11px}.sp-chart .grid{stroke:rgba(148,163,184,.12);stroke-width:1}.sp-chart .line{fill:none;stroke:url(#spLine);stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.sp-chart .area{fill:url(#spArea)}.sp-chart circle{fill:#0b1728;stroke:#89f1e4;stroke-width:3}
.sp-toolbar{display:grid;grid-template-columns:minmax(220px,1fr) repeat(3,minmax(130px,.32fr));gap:10px;margin-bottom:13px}.sp-control,.sp-form input,.sp-form select,.sp-form textarea{width:100%;border:1px solid rgba(148,163,184,.22);border-radius:11px;background:#09182b;color:#eef5fb;padding:11px 12px;outline:none}.sp-control:focus,.sp-form input:focus,.sp-form select:focus,.sp-form textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(124,92,255,.14)}.sp-actions{display:flex;flex-wrap:wrap;gap:8px}.sp-table-wrap{width:100%;overflow-x:auto;overflow-y:visible!important;border:1px solid var(--line);border-radius:15px;background:#0a1729}.sp-table{width:100%;min-width:980px;border-collapse:separate;border-spacing:0}.sp-table th,.sp-table td{padding:12px 13px;border-bottom:1px solid rgba(148,163,184,.12);text-align:left;vertical-align:top}.sp-table th{position:sticky;top:0;z-index:3;background:#13243b;color:#aebed2;font-size:10px;text-transform:uppercase;letter-spacing:.07em}.sp-table td{font-size:12px;color:#d8e2ee}.sp-table tbody tr:hover{background:rgba(124,92,255,.05)}.sp-table code{color:#8de6db;font-size:11px}.sp-table small{display:block;color:#7f91a9;margin-top:4px}.sp-empty{text-align:center!important;color:#7e8fa7!important;padding:44px!important}.sp-row-actions{display:flex;gap:6px;white-space:nowrap}.sp-check{accent-color:var(--brand)}
.sp-badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 8px;font-size:9px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.sp-badge--low{color:#a7f3d0;background:rgba(16,185,129,.12)}.sp-badge--medium{color:#fde68a;background:rgba(245,158,11,.13)}.sp-badge--high{color:#fecdd3;background:rgba(239,68,68,.13)}.sp-badge--active{color:#bae6fd;background:rgba(14,165,233,.12)}.sp-badge--support{color:#fecdd3;background:rgba(239,68,68,.13)}.sp-score{font-size:15px;font-weight:900;font-variant-numeric:tabular-nums}.sp-score--good{color:#6ee7b7}.sp-score--mid{color:#fde68a}.sp-score--bad{color:#fda4af}
.sp-form{display:grid;gap:13px}.sp-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.sp-field{display:grid;gap:6px}.sp-field--wide{grid-column:1/-1}.sp-field label{font-size:10px;color:#aebed1;text-transform:uppercase;letter-spacing:.07em;font-weight:800}.sp-form textarea{min-height:92px;resize:vertical}.sp-form-hint{color:#74869f;font-size:10px;line-height:1.5}.sp-inline-note{border:1px solid rgba(34,211,238,.2);background:rgba(34,211,238,.06);border-radius:12px;padding:12px;color:#a9dae2;font-size:11px;line-height:1.55}
.sp-predict-output{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.sp-output{border:1px solid var(--line);border-radius:13px;padding:14px;background:rgba(255,255,255,.035)}.sp-output small{display:block;color:#7f91a8;font-size:9px;text-transform:uppercase;letter-spacing:.08em}.sp-output strong{display:block;margin-top:7px;font-size:22px}.sp-model-equation{font-family:"SFMono-Regular",Consolas,monospace;color:#9ff3e7;line-height:1.7;word-break:break-word}.sp-list{display:grid;gap:10px}.sp-list-item{display:flex;justify-content:space-between;gap:14px;padding:13px;border:1px solid var(--line);border-radius:13px;background:rgba(255,255,255,.028)}.sp-list-item strong{font-size:12px}.sp-list-item p{margin:4px 0 0;font-size:11px}.sp-list-item__meta{text-align:right;white-space:nowrap;color:#9db0c5;font-size:11px}.sp-recommend{border-left:3px solid var(--brand);padding-left:13px}.sp-recommend--high{border-left-color:var(--red)}.sp-recommend--medium{border-left-color:var(--amber)}
.sp-footer{margin-top:28px;padding:22px 0 16px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;color:#71839b;font-size:10px;line-height:1.6}.sp-scroll-end{height:0;display:none!important;display:grid;place-items:center;color:#53667f;font-size:10px;text-transform:uppercase;letter-spacing:.13em}
.sp-modal{width:min(720px,calc(100vw - 28px));max-height:calc(100vh - 40px);overflow:auto;border:1px solid var(--line);border-radius:18px;background:#0b182a;color:var(--text);box-shadow:0 30px 100px rgba(0,0,0,.65);padding:0}.sp-modal::backdrop{background:rgba(2,8,18,.82);backdrop-filter:blur(5px)}.sp-modal-head{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#0b182a;z-index:2}.sp-modal-body{padding:20px}.sp-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.sp-detail{border:1px solid var(--line);border-radius:12px;padding:12px;background:rgba(255,255,255,.03)}.sp-detail small{display:block;color:#7c8da5;font-size:9px;text-transform:uppercase;letter-spacing:.07em}.sp-detail strong{display:block;margin-top:6px;font-size:14px}.sp-toast{position:fixed;left:50%;bottom:24px;z-index:999;transform:translate(-50%,18px);opacity:0;pointer-events:none;background:#101f34;color:white;border:1px solid var(--line);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow);transition:.2s;font-size:12px}.sp-toast.is-visible{transform:translate(-50%,0);opacity:1}.sp-file{position:absolute;opacity:0;pointer-events:none}
html::-webkit-scrollbar,body::-webkit-scrollbar,.sp-sidebar::-webkit-scrollbar{width:12px}.sp-sidebar::-webkit-scrollbar{width:8px}html::-webkit-scrollbar-track,body::-webkit-scrollbar-track,.sp-sidebar::-webkit-scrollbar-track{background:#07111f}html::-webkit-scrollbar-thumb,body::-webkit-scrollbar-thumb,.sp-sidebar::-webkit-scrollbar-thumb{border:3px solid #07111f;border-radius:999px;background:linear-gradient(180deg,var(--brand),var(--cyan));box-shadow:0 0 14px rgba(124,92,255,.32)}
@media(max-width:1100px){.sp-grid--4{grid-template-columns:repeat(2,minmax(0,1fr))}.sp-grid--3{grid-template-columns:repeat(2,minmax(0,1fr))}.sp-grid--2{grid-template-columns:1fr}.sp-toolbar{grid-template-columns:1fr 1fr}.sp-toolbar input{grid-column:1/-1}.sp-predict-output{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:820px){.sp-app{grid-template-columns:1fr}.sp-sidebar{position:relative;height:auto;max-height:none;border-right:0;border-bottom:1px solid var(--line);padding-bottom:14px}.sp-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.sp-nav a{justify-content:center;text-align:center;flex-direction:column;gap:4px;padding:9px 5px;font-size:10px}.sp-side-foot,.sp-nav-label{display:none}.sp-main{padding:22px 14px 28px;min-height:0}.sp-page-head{flex-direction:column}.sp-head-actions{justify-content:flex-start}.sp-form-grid{grid-template-columns:1fr}.sp-field--wide{grid-column:auto}.sp-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.sp-grid--4,.sp-grid--3{grid-template-columns:1fr}.sp-toolbar{grid-template-columns:1fr}.sp-toolbar input{grid-column:auto}.sp-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.sp-predict-output{grid-template-columns:1fr}.sp-bar{grid-template-columns:80px minmax(0,1fr) 42px}.sp-footer{flex-direction:column}.sp-detail-grid{grid-template-columns:1fr}}
@media print{.sp-sidebar,.sp-head-actions,.sp-actions,.sp-toolbar,.sp-row-actions,.sp-toast{display:none!important}.sp-app{display:block}.sp-main{padding:0;background:white;color:black}.sp-card{box-shadow:none;border:1px solid #ccc;background:white;color:black}.sp-card p,.sp-page-head p{color:#555}.sp-view{display:block!important;page-break-after:always}}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
