@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--bg: #070b12;--panel: rgba(16, 24, 35, .65);--panel-strong: rgba(19, 29, 41, .9);--border: #1f2a3a;--text: #e6f3ed;--muted: #98a6b3;--accent: #35c46e;--accent-2: #59f0a0;--danger: #f87171;--shadow: 0 20px 70px rgba(0, 0, 0, .35);--input: rgba(7, 11, 18, .6);--track: rgba(255, 255, 255, .08);--progress-bg: rgba(255, 255, 255, .06);--surface-1: rgba(255, 255, 255, .02);--alert-error-bg: rgba(248, 113, 113, .14);--alert-error-border: rgba(248, 113, 113, .55);--alert-success-bg: rgba(89, 240, 160, .15);--alert-success-border: rgba(89, 240, 160, .55);--alert-warning-bg: rgba(250, 204, 21, .14);--alert-warning-border: rgba(250, 204, 21, .5);--alert-info-bg: rgba(56, 189, 248, .14);--alert-info-border: rgba(56, 189, 248, .45);--chart-snap-type: x mandatory;--chart-snap-align: start;color-scheme:dark}body{background:var(--bg)}.page{min-height:100vh;color:var(--text)}.app-page{display:grid;grid-template-columns:minmax(280px,320px) 1fr;gap:clamp(14px,2vw,20px);padding:clamp(16px,4vw,28px);position:relative}.app-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(53,196,110,.12),transparent 35%),radial-gradient(circle at 80% 30%,rgba(53,196,110,.08),transparent 35%),radial-gradient(circle at 50% 70%,rgba(18,36,52,.9),transparent 45%);pointer-events:none;z-index:0;filter:blur(50px)}.glass{background:var(--panel);border:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow);border-radius:18px}.sidebar{position:sticky;top:20px;height:calc(100vh - 40px);padding:28px 20px 24px;display:flex;flex-direction:column;gap:18px;z-index:1;min-width:0}.sidebar-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.sidebar-head h2{margin:14px 0 6px}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);background:#ffffff08}.pill.glow{border-color:#35c46e80;color:var(--text);box-shadow:0 0 0 6px #35c46e1f,0 10px 30px #35c46e26}.inline-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:flex-start;width:100%}.inline-form input{min-width:0;height:46px}.inline-form button{padding:12px 18px;height:46px;display:flex;align-items:center;justify-content:center;align-self:start}.course-list{display:grid;gap:8px;overflow:auto;padding-right:2px;max-height:calc(100vh - 260px)}.course-item{width:100%;text-align:left;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface-1);color:var(--text);display:flex;justify-content:space-between;align-items:center;transition:transform .12s ease,border-color .12s ease,background .15s ease}.course-item:hover{transform:translateY(-2px);border-color:var(--accent);background:#35c46e0f}.course-item.active{border-color:var(--accent);box-shadow:0 12px 30px #35c46e2e;background:linear-gradient(120deg,#35c46e29,#35c46e0a)}.chevron{opacity:.7}.content{display:flex;flex-direction:column;gap:18px;position:relative;z-index:1;min-width:0}.credit-line{margin:12px 0 4px;font-size:.95rem}.credit-line a,.dashboard-footer a{color:var(--accent-2);text-decoration:none;border-bottom:1px solid rgba(89,240,160,.35)}.credit-line a:hover,.dashboard-footer a:hover{color:#c8ffe3;border-bottom-color:#c8ffe399}.hero{position:relative;padding:24px 24px 22px;overflow:hidden}.hero:after{content:"";position:absolute;top:-40px;right:-40px;bottom:-40px;left:-40px;background:radial-gradient(circle at 80% 0%,rgba(53,196,110,.14),transparent 50%),linear-gradient(135deg,#ffffff0a,#35c46e0f);pointer-events:none;z-index:0}.hero h1{margin:8px 0 6px;letter-spacing:-.02em}.hero p,.hero h1,.hero .hero-actions,.hero .hero-badges{position:relative;z-index:1}.hero-actions{display:flex;gap:14px;margin-top:16px;flex-wrap:wrap;align-items:center}.hero-actions button{min-width:150px}.hero-badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-left:auto;margin-top:16px;min-width:280px;width:100%}.badge-card{padding:12px 14px;min-height:78px;border-radius:14px;border:1px solid var(--border);background:#ffffff08;display:grid;align-content:center;text-align:center;gap:6px}.badge-card strong{display:block;line-height:1.1;letter-spacing:.01em}.summary-grid,.analytics,.chart-card,.two-col .card{position:relative}.card{padding:18px;border-radius:18px;border:1px solid var(--border)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.analytics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;gap:18px}.metric-card{border-radius:14px;border:1px solid var(--border);background:#ffffff05;min-height:168px;padding:16px}.metric-note{display:grid;align-content:center;justify-items:center;text-align:center;gap:8px}.metric-note h2{margin:0;font-size:clamp(2rem,3.2vw,2.6rem);line-height:1;letter-spacing:.01em;font-weight:800}.metric-ring-card{display:grid;align-content:center;justify-items:center;text-align:center;gap:8px}.metric-ring-card .score-ring__value{width:62px;height:62px;font-size:.95rem}.metric-weight-card{align-content:center}.metric-progress{display:grid;align-content:center;gap:8px}.metric-progress h3{margin:0;font-size:clamp(1.4rem,2.2vw,1.75rem)}.metric-counts{line-height:1.5;letter-spacing:.01em}.analytics-meta-row{margin-top:-4px;margin-bottom:2px;display:flex;align-items:center;justify-content:center;gap:20px;min-height:26px}.analytics-meta-row p{margin:0}.progress{width:100%;background:var(--progress-bg);border-radius:999px;height:8px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:999px;box-shadow:0 0 12px #35c46e80}.score-ring{display:grid;place-items:center;gap:8px;position:relative;text-align:center}.score-ring svg{filter:drop-shadow(0 12px 30px rgba(53,196,110,.2))}.score-ring__track{fill:none;stroke:var(--track)}.score-ring__progress{fill:none;stroke-linecap:round;transform:rotate(-90deg);transform-origin:60px 60px}.score-ring__glow{fill:none;stroke-opacity:.35;filter:blur(6px);transform:rotate(-90deg);transform-origin:60px 60px}.score-ring__value{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;font-weight:700;background:radial-gradient(circle,#070b12e6,#070b1299);border-radius:50%;width:70px;height:70px;box-shadow:0 10px 24px #00000059,0 0 0 1px var(--border);line-height:1}.chart-card{display:flex;flex-direction:column;gap:20px}.impersonation-banner,.admin-panel{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.admin-panel{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:24px;align-items:start}.admin-panel__intro{display:grid;gap:12px;align-content:start;max-width:280px}.admin-panel__intro h3{margin:10px 0 8px}.admin-panel__content{min-width:0;display:grid;gap:12px}.chart-head{display:flex;justify-content:space-between;align-items:center;row-gap:8px;column-gap:16px}.chart-head h3{margin:6px 0 4px}.bar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;align-items:end}.chart-area{--plot-height: 240px;position:relative;min-height:344px;width:100%;overflow:hidden;padding:16px 0 24px}.chart-plot{position:relative;height:calc(var(--plot-height) + 52px)}.chart-scroll{width:100%;height:100%;overflow-x:auto;overflow-y:hidden;padding-bottom:10px;scrollbar-width:thin;scrollbar-color:rgba(164,179,199,.7) rgba(255,255,255,.06)}.chart-scroll::-webkit-scrollbar{height:10px}.chart-scroll::-webkit-scrollbar-track{background:#ffffff0d;border-radius:999px}.chart-scroll::-webkit-scrollbar-thumb{background:linear-gradient(90deg,#78889cf2,#c2ccd9f2);border-radius:999px;border:2px solid rgba(7,11,18,.55)}.chart-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(90deg,#90a2b8fa,#dce5effa)}.plot-surface{position:relative;min-width:100%;height:var(--plot-height)}.plot-surface:before,.plot-surface:after{content:"";position:absolute;top:0;bottom:0;width:36px;pointer-events:none;z-index:3}.plot-surface:before{left:46px;background:linear-gradient(90deg,#070b12eb,#070b1200)}.plot-surface:after{right:0;background:linear-gradient(270deg,#070b12eb,#070b1200)}.guide-line{position:absolute;left:0;right:0;color:var(--muted);font-size:12px;display:flex;align-items:center;gap:6px;transform:translateY(50%)}.guide-label{width:28px;text-align:right;flex:0 0 28px;margin-right:18px}.guide-stroke{flex:1;height:1px;background:#ffffff17}.guide-line-pass .guide-stroke{background:#59f0a047}.bars{position:absolute;top:0;right:0;bottom:0;left:46px;display:grid;gap:10px;justify-content:stretch;align-items:end;padding:0 24px 0 10px;min-width:0;overflow:visible}.bar-col{display:grid;gap:12px;grid-template-rows:var(--plot-height) auto;align-items:end;min-width:0}.bar-stack{position:relative;height:100%;width:min(118px,100%);border-radius:14px;overflow:visible;display:flex;align-items:flex-end;justify-content:center;justify-self:center}.bar-shadow{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#ffffff08,#090f1924);border:1px solid rgba(255,255,255,.08);border-radius:14px}.bar-fill{position:relative;width:76%;border-radius:12px 12px 10px 10px;background:linear-gradient(180deg,rgba(52,211,153,calc(.65 + var(--bar-strength, .6) * .25)),#0f2419);box-shadow:0 12px 28px rgba(53,196,110,calc(.18 + var(--bar-strength, .6) * .18));transition:transform .16s ease,box-shadow .16s ease;z-index:1}.bar-stack:hover .bar-fill{transform:translateY(-4px) scale(1.02);box-shadow:0 24px 45px #35c46e52}.bar-stack.is-failing .bar-fill{background:linear-gradient(180deg,rgba(102,116,132,calc(.52 + var(--bar-strength, .6) * .2)),#121a24);box-shadow:0 12px 26px #49566742}.bar-stack.is-passing .bar-fill{box-shadow:0 14px 34px rgba(53,196,110,calc(.22 + var(--bar-strength, .6) * .24))}.bar-bubble{position:absolute;left:50%;transform:translate(-50%);white-space:nowrap;background:var(--panel-strong);padding:4px 8px;border-radius:8px;font-weight:700;color:var(--text);border:1px solid var(--border);box-shadow:0 10px 22px #00000040;line-height:1.2;min-width:62px;text-align:center;z-index:2}.bar-bubble.is-empty{color:var(--muted);min-width:78px}.bar-placeholder{position:absolute;left:50%;bottom:18px;transform:translate(-50%);min-width:56px;display:grid;place-items:center}.bar-placeholder span{display:inline-block;font-size:13px;letter-spacing:.22em;font-weight:700;color:#c2cbd69e;padding:2px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.25);background:#94a3b814}.bar-label{font-size:11px;color:var(--muted);text-align:center;width:100%;display:grid;justify-items:center;gap:3px;line-height:1.35;min-height:52px}.bar-label-name{max-width:118px;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2;white-space:normal;font-size:11px;line-height:1.25;text-wrap:balance}.bar-label-weight{font-size:10px;color:#e6f3edb8;letter-spacing:.04em;text-transform:uppercase}.pass-line{position:absolute;left:46px;right:18px;border-top:1px dashed rgba(255,255,255,.35);z-index:1}.admin-actions-cell{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.admin-mobile-list{display:none}.admin-mobile-card{border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;background:#ffffff08;display:grid;gap:10px}.admin-mobile-card__head{display:flex;justify-content:space-between;gap:10px;align-items:center}.admin-mobile-card__actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.pass-line span{position:absolute;right:14px;top:-14px;font-size:12px;color:var(--muted);white-space:nowrap;background:#070b12b8;padding:2px 8px;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.section-head{display:flex;justify-content:space-between;align-items:flex-start}.table-wrap{overflow:auto;margin-top:12px;border-radius:12px;min-width:0}th,td{text-align:left;padding:10px 8px}table{width:100%;border-collapse:collapse}thead{color:var(--muted);font-size:13px}tbody tr{border-top:1px solid rgba(255,255,255,.05)}tbody tr:hover{background:#35c46e0a}.assessment-row{cursor:pointer}.assessment-row:focus-visible{outline:2px solid rgba(89,240,160,.55);outline-offset:-2px}.auth-page{display:grid;place-items:center;padding:40px}.auth-shell{min-height:100vh;display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;padding:40px;align-items:center}.auth-hero{padding:28px;border-radius:18px;border:1px solid var(--border);background:radial-gradient(circle at 20% 20%,rgba(53,196,110,.12),transparent 45%),var(--panel-strong);box-shadow:var(--shadow)}.benefits{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:8px}.benefits li:before{content:\"• \";color:var(--accent)}.auth-card{padding:26px;border-radius:18px;border:1px solid var(--border);background:var(--panel-strong);box-shadow:var(--shadow);display:grid;gap:14px}.auth-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}button.small{padding:8px 12px;font-size:13px}.app-alert{position:fixed;top:16px;left:50%;transform:translate(-50%);width:min(92vw,620px);padding:12px 14px;border-radius:12px;border:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 18px 32px #00000059;z-index:40;display:flex;align-items:center;justify-content:space-between;gap:12px}.app-alert p{margin:0}.app-alert.error{background:var(--alert-error-bg);border-color:var(--alert-error-border)}.app-alert.success{background:var(--alert-success-bg);border-color:var(--alert-success-border)}.app-alert.warning{background:var(--alert-warning-bg);border-color:var(--alert-warning-border)}.app-alert.info{background:var(--alert-info-bg);border-color:var(--alert-info-border)}.alert-close{white-space:nowrap}label{display:grid;gap:6px;font-size:14px;color:var(--muted)}.field-with-error{display:grid;gap:6px;min-width:0}.field-error{margin:0;font-size:12px;color:#fda4af}input,button,textarea{font:inherit}input,textarea{padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:var(--input);color:var(--text);outline:none;transition:border-color .12s ease,box-shadow .12s ease}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px #35c46e2e}input.input-invalid,textarea.input-invalid{border-color:#f87171a6;box-shadow:0 0 0 4px #f8717124}textarea{min-height:120px;resize:vertical}button{border-radius:12px;border:1px solid transparent;padding:10px 14px;background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#04130a;font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .15s ease,filter .12s ease}button:hover{transform:translateY(-1px);box-shadow:0 12px 30px #35c46e52}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:transparent;color:var(--text);border-color:var(--border)}button.ghost:hover{border-color:var(--accent);box-shadow:0 8px 22px #35c46e33}button.danger{background:linear-gradient(120deg,#ff6b6b,#f87171);color:#330b0b}.actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;width:100%;margin-top:16px;padding-top:10px;border-top:1px solid rgba(255,255,255,.06)}.actions button{width:100%;min-width:0;white-space:normal;text-wrap:balance;line-height:1.15;min-height:48px;padding-inline:10px}.muted{color:var(--muted)}.muted.tiny{font-size:12px}.k{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.center{text-align:center}.dashboard-footer{margin-top:4px;padding:10px 2px 2px;color:var(--muted);font-size:.9rem;text-align:center}@media (max-width: 1080px){.app-page{grid-template-columns:1fr;padding:clamp(14px,4vw,20px)}.sidebar{position:relative;height:auto;top:0}.analytics{grid-template-columns:1fr}.analytics-meta-row{flex-direction:column;gap:4px;margin-top:-2px}.course-list{max-height:none}}@media (max-width: 900px){.auth-shell{padding:24px 18px;gap:16px;grid-template-columns:1fr}.hero-badges{min-width:0;grid-template-columns:repeat(2,minmax(0,1fr))}.chart-area{--plot-height: 220px;padding-top:16px}.pass-line span{right:auto;left:8px}.bar-col{min-width:0}table{min-width:520px}}@media (max-width: 720px){.app-page{padding:12px;gap:12px}.app-alert{width:calc(100vw - 24px);left:12px;transform:none}.sidebar{padding:14px}.chart-head{flex-direction:column;gap:10px}.impersonation-banner,.admin-panel{flex-direction:column}.admin-panel{grid-template-columns:1fr;gap:16px}.admin-panel__intro{max-width:none}.inline-form{grid-template-columns:1fr}.inline-form button{width:100%}.hero-actions{flex-wrap:wrap;gap:12px}.hero-actions button{min-width:0;flex:1 1 160px}.section-head{flex-direction:column;gap:8px}.actions{grid-template-columns:1fr;gap:8px}.chart-scroll{scroll-snap-type:x mandatory;padding-bottom:8px}.plot-surface{min-width:max-content}.bars{gap:14px}.bar-col{min-width:124px;scroll-snap-align:start}.bar-stack{width:108px}.bar-label-name{max-width:116px;font-size:10px}}@media (max-width: 540px){.auth-shell{padding:14px 12px}.auth-card,.auth-hero{padding:18px}.auth-card-head{flex-direction:column;gap:12px}.hero{padding:18px}.card{padding:16px}.bars{gap:8px}.chart-area{--plot-height: 210px;min-height:314px;padding-top:24px;padding-bottom:22px}.bar-col{min-width:118px}.bar-stack{width:96px}.bar-label{min-height:54px}.admin-table-wrap{display:none}.admin-mobile-list{display:grid;gap:12px;margin-top:12px}.admin-mobile-card__actions{grid-template-columns:1fr}.assessment-edit-col{display:none}.assessment-table-wrap{overflow-x:hidden}.assessment-table{min-width:0;table-layout:fixed}.assessment-table th,.assessment-table td{padding:9px 6px;font-size:.95rem}.assessment-table th:nth-child(1),.assessment-table td:nth-child(1){width:54%}.assessment-table th:nth-child(2),.assessment-table td:nth-child(2){width:23%}.assessment-table th:nth-child(3),.assessment-table td:nth-child(3){width:23%}.assessment-table td:nth-child(1){overflow-wrap:anywhere;word-break:break-word}.pass-line span{top:-12px;font-size:11px}.hero-badges{grid-template-columns:1fr}.pill{font-size:11px}.app-alert{flex-direction:column;align-items:flex-start}.actions{grid-template-columns:1fr}}:root{font-family:Space Grotesk,system-ui,-apple-system,Segoe UI,sans-serif;background-color:#070b12;color:#e6f3ed;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% 20%,rgba(53,196,110,.12),transparent 30%),radial-gradient(circle at 90% 10%,rgba(18,36,52,.5),transparent 35%),linear-gradient(160deg,#05080f,#0a121b 40%,#0a140d);color:#e6f3ed}a{color:inherit;text-decoration:none}#root{min-height:100vh}
