:root{--surface-1: #FFFFFF;--surface-2: #F8FAFC;--surface-3: #EEF2F7;--surface-inset: #F1F5F9;--border: #E2E8F0;--border-strong: #CBD5E1;--text-1: #0F172A;--text-2: #475569;--text-3: #94A3B8;--text-on-accent: #FFFFFF;--accent: #2563EB;--accent-hover: #1D4ED8;--accent-pressed: #1E40AF;--accent-soft: #DBEAFE;--accent-softer: #EFF6FF;--success: #16A34A;--success-soft: #DCFCE7;--warning: #D97706;--warning-soft: #FEF3C7;--danger: #DC2626;--danger-soft: #FEE2E2;--info: #0891B2;--info-soft: #CFFAFE;--chart-1: #2563EB;--chart-2: #16A34A;--chart-3: #D97706;--chart-4: #9333EA;--chart-5: #0891B2;--chart-6: #DB2777;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(15,23,42,.04);--shadow-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);--shadow-md: 0 4px 12px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04);--shadow-lg: 0 12px 32px rgba(15,23,42,.08), 0 4px 12px rgba(15,23,42,.06);--shadow-pop: 0 24px 64px rgba(15,23,42,.16)}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-sans);font-size:16px;line-height:1.5;color:var(--text-1);background:var(--surface-2);-webkit-font-smoothing:antialiased;font-feature-settings:"cv11","ss01"}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit;color:inherit}h1,h2,h3,h4,p{margin:0}h1{font-size:32px;font-weight:700;line-height:1.2;letter-spacing:-.01em}h2{font-size:24px;font-weight:600;line-height:1.25;letter-spacing:-.005em}h3{font-size:18px;font-weight:600;line-height:1.3}@media(max-width:640px){h1{font-size:24px}h2{font-size:20px}h3{font-size:17px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;padding:0 16px;height:40px;font-size:14px;transition:background .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease,transform 80ms ease;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{height:32px;font-size:13px;padding:0 12px}.btn-lg{height:48px;font-size:15px;padding:0 20px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary:active{background:var(--accent-pressed)}.btn-ghost{background:transparent;color:var(--text-1);border-color:var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-3)}.btn-soft{background:var(--accent-soft);color:var(--accent);border-color:transparent}.btn-soft:hover:not(:disabled){background:#c8ddfe}.btn-text{background:transparent;color:var(--accent);border-color:transparent;padding:0 8px}.btn-text:hover{background:var(--accent-softer)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger-ghost{background:transparent;color:var(--danger);border-color:var(--border)}.btn-danger-ghost:hover{background:var(--danger-soft);border-color:var(--danger)}.input,.textarea,.select{width:100%;border:1px solid var(--border);background:var(--surface-1);border-radius:var(--radius-md);padding:0 12px;height:40px;font-size:14px;color:var(--text-1);transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input.error{border-color:var(--danger)}.input.error:focus{box-shadow:0 0 0 3px var(--danger-soft)}.textarea{padding:10px 12px;height:auto;min-height:96px;resize:vertical;line-height:1.5}.input::placeholder,.textarea::placeholder{color:var(--text-3)}label.field{display:block}label.field>.label-text{display:block;font-size:13px;font-weight:500;color:var(--text-2);margin-bottom:6px}label.field>.help{font-size:13px;color:var(--text-3);margin-top:6px}label.field>.err{font-size:13px;color:var(--danger);margin-top:6px}.card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.card-pad{padding:20px}.card-pad-lg{padding:28px}.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:3px 10px;border-radius:var(--radius-full);background:var(--surface-3);color:var(--text-2);border:1px solid transparent;white-space:nowrap}.tag-accent{background:var(--accent-soft);color:var(--accent)}.tag-success{background:var(--success-soft);color:#166534}.tag-warning{background:var(--warning-soft);color:#92400e}.tag-danger{background:var(--danger-soft);color:#991b1b}.tag-info{background:var(--info-soft);color:#155e75}.tag-outline{background:transparent;border-color:var(--border);color:var(--text-2)}.tag-dot:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:var(--surface-3);color:var(--text-2);font-weight:600;font-size:13px;flex-shrink:0;border:1px solid var(--surface-1);letter-spacing:0}.avatar-sm{width:24px;height:24px;font-size:11px}.avatar-md{width:32px;height:32px;font-size:12px}.avatar-lg{width:40px;height:40px;font-size:14px}.avatar-xl{width:64px;height:64px;font-size:22px}.row{display:flex}.col{display:flex;flex-direction:column}.center{display:flex;align-items:center;justify-content:center}.muted{color:var(--text-2)}.dim{color:var(--text-3)}.tabular{font-variant-numeric:tabular-nums}.divider{height:1px;background:var(--border);border:0;margin:0}.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.app-shell.collapsed{grid-template-columns:72px 1fr}.app-sidebar{background:var(--surface-1);border-right:1px solid var(--border);padding:16px 12px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh;overflow-y:auto}.app-topbar{height:56px;background:var(--surface-1);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:30}.app-content{padding:32px 48px;max-width:1280px;margin:0 auto;width:100%}@media(max-width:1024px){.app-content{padding:24px}}.nav-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--radius-md);color:var(--text-2);text-decoration:none;font-size:14px;font-weight:500;border:none;background:transparent;width:100%;text-align:left;cursor:pointer;transition:background .1s}.nav-item:hover{background:var(--surface-3);color:var(--text-1)}.nav-item.active{background:var(--accent-softer);color:var(--accent)}.nav-item.active svg{color:var(--accent)}.nav-section{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;padding:16px 12px 6px}.table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.table th{text-align:left;font-weight:600;color:var(--text-2);padding:10px 12px;font-size:12px;background:var(--surface-2);border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em}.table td{padding:14px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr.hoverable:hover td{background:var(--surface-2);cursor:pointer}.kpi{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;display:flex;flex-direction:column;gap:4px}.kpi-label{font-size:12px;color:var(--text-2);font-weight:500;text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:28px;font-weight:600;font-variant-numeric:tabular-nums;line-height:1.1;color:var(--text-1)}.kpi-delta{font-size:13px;display:inline-flex;align-items:center;gap:4px}.kpi-delta.up{color:var(--success)}.kpi-delta.down{color:var(--danger)}.kpi-hint{font-size:12px;color:var(--text-3)}.banner{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-radius:var(--radius-md);font-size:14px;border:1px solid var(--border);background:var(--surface-2)}.banner.info{background:var(--info-soft);border-color:#a5f3fc;color:#155e75}.banner.success{background:var(--success-soft);border-color:#bbf7d0;color:#166534}.banner.warning{background:var(--warning-soft);border-color:#fde68a;color:#92400e}.banner.danger{background:var(--danger-soft);border-color:#fecaca;color:#991b1b}.skel{background:linear-gradient(90deg,var(--surface-3) 0%,#E5E9F0 50%,var(--surface-3) 100%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.progress{height:6px;background:var(--surface-3);border-radius:999px;overflow:hidden}.progress>.fill{height:100%;background:var(--accent);border-radius:999px;transition:width .22s ease}.stepper{display:flex;gap:4px;align-items:center}.stepper .step{display:flex;align-items:center;gap:8px;color:var(--text-3);font-size:13px;font-weight:500}.stepper .step .num{width:24px;height:24px;border-radius:999px;background:var(--surface-3);color:var(--text-2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.stepper .step.active .num{background:var(--accent);color:#fff}.stepper .step.active{color:var(--text-1)}.stepper .step.done .num{background:var(--success);color:#fff}.stepper .step.done{color:var(--text-1)}.stepper .sep{flex:1;height:1px;background:var(--border);min-width:16px;max-width:48px}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a6b;z-index:50;animation:fade .16s ease}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:100%;background:var(--surface-1);z-index:60;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slide-right .22s cubic-bezier(.2,.8,.2,1)}.drawer-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.drawer-body{flex:1;overflow-y:auto;padding:20px 24px}.drawer-footer{padding:16px 24px;border-top:1px solid var(--border)}@keyframes slide-right{0%{transform:translate(100%)}to{transform:none}}.viewport-mobile{width:375px;min-height:720px;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative}.student-frame{background:var(--surface-2);min-height:100vh;display:flex;flex-direction:column}.student-frame .stu-header{height:64px;background:var(--surface-1);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-frame .stu-content{flex:1;padding:20px 16px 96px}.student-frame .stu-bottom-bar{position:sticky;bottom:0;background:var(--surface-1);border-top:1px solid var(--border);padding:12px 16px;display:flex;gap:12px;align-items:center}.qcard{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.option-card{display:flex;align-items:center;gap:12px;border:1px solid var(--border);background:var(--surface-1);border-radius:var(--radius-md);padding:14px 16px;cursor:pointer;font-size:14px;transition:border-color .1s,background .1s;min-height:56px}.option-card:hover{border-color:var(--border-strong)}.option-card.selected{border-color:var(--accent);background:var(--accent-softer);box-shadow:0 0 0 1px var(--accent)}.option-card .radio-box{width:20px;height:20px;border-radius:999px;border:2px solid var(--border-strong);flex-shrink:0;display:flex;align-items:center;justify-content:center}.option-card.selected .radio-box{border-color:var(--accent)}.option-card.selected .radio-box:after{content:"";width:10px;height:10px;border-radius:999px;background:var(--accent)}.option-card .check-box{width:20px;height:20px;border-radius:4px;border:2px solid var(--border-strong);flex-shrink:0}.option-card.selected .check-box{background:var(--accent);border-color:var(--accent);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='white' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='3,8 6.5,11.5 13,4.5'/></svg>");background-size:14px;background-position:center;background-repeat:no-repeat}.scale{display:flex;gap:8px;flex-wrap:wrap}.scale .opt{flex:1;min-width:44px;height:48px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface-1);font-size:16px;font-weight:500;color:var(--text-1);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .1s}.scale .opt:hover{border-color:var(--border-strong)}.scale .opt.selected{background:var(--accent);color:#fff;border-color:var(--accent)}.rubric-row{display:flex;flex-direction:column;gap:8px;padding:14px 0}.rubric-row+.rubric-row{border-top:1px solid var(--border)}.rubric-row .rubric-name{font-weight:500;font-size:14px}.rubric-row .rubric-desc{font-size:13px;color:var(--text-2)}.rubric-pills{display:flex;gap:6px;flex-wrap:wrap}.rubric-pill{padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-full);font-size:13px;cursor:pointer;background:var(--surface-1);color:var(--text-1);transition:all .1s}.rubric-pill:hover{border-color:var(--border-strong)}.rubric-pill.selected{background:var(--accent);color:#fff;border-color:var(--accent)}.icon{width:18px;height:18px;flex-shrink:0}.icon-sm{width:14px;height:14px}.icon-lg{width:24px;height:24px}.search-input{position:relative}.search-input .input{padding-left:40px}.search-input svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-3)}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;font-size:11px;font-family:var(--font-mono);background:var(--surface-1);border:1px solid var(--border);border-radius:4px;color:var(--text-2);box-shadow:0 1px 0 var(--border)}.bread{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-2)}.bread a{color:var(--text-2);text-decoration:none}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.confetti span{position:absolute;width:8px;height:14px;opacity:.9;animation:drop 2.4s cubic-bezier(.4,.6,.6,1) forwards}@keyframes drop{0%{transform:translateY(-20px) rotate(0)}to{transform:translateY(110vh) rotate(720deg);opacity:0}}.hist-bar{fill:var(--accent);transition:fill .1s}.hist-bar:hover{fill:var(--accent-hover)}.heat-cell{stroke:var(--surface-1);stroke-width:1}.page-header{display:flex;flex-wrap:wrap;align-items:flex-end;gap:16px;justify-content:space-between;margin-bottom:24px}.page-header .meta{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:6px}.page-header .actions{display:flex;gap:8px;flex-wrap:wrap}.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}@media(max-width:1024px){.grid-12{grid-template-columns:repeat(6,1fr)}}@media(max-width:640px){.grid-12{grid-template-columns:1fr}}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-9{grid-column:span 9}.col-12{grid-column:span 12}@media(max-width:1024px){.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9{grid-column:span 6}}@media(max-width:640px){.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-12{grid-column:span 1}}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:24px;overflow-x:auto}.tabs .tab{padding:10px 16px;font-size:14px;font-weight:500;color:var(--text-2);background:transparent;border:0;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color .1s,border-color .1s}.tabs .tab:hover{color:var(--text-1)}.tabs .tab.active{color:var(--accent);border-bottom-color:var(--accent)}.switch{width:36px;height:22px;background:var(--surface-3);border-radius:999px;border:1px solid var(--border);padding:1px;cursor:pointer;position:relative;flex-shrink:0;transition:background .12s}.switch:after{content:"";width:18px;height:18px;background:#fff;border-radius:999px;display:block;box-shadow:var(--shadow-sm);transition:transform .14s ease}.switch.on{background:var(--accent);border-color:var(--accent)}.switch.on:after{transform:translate(14px)}.h-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.role-banner{position:fixed;top:12px;left:50%;transform:translate(-50%);background:var(--text-1);color:#fff;font-size:12px;padding:6px 14px;border-radius:999px;z-index:80;font-weight:500;box-shadow:var(--shadow-md);display:none}.tnum{font-variant-numeric:tabular-nums}.anon-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface-3);color:var(--text-2);padding:2px 8px;border-radius:999px;font-size:12px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#0f172a66;display:flex;justify-content:flex-end;animation:fade .15s}@keyframes fade{0%{opacity:0}to{opacity:1}}.drawer{background:#fff;height:100vh;display:flex;flex-direction:column;box-shadow:-8px 0 32px #0f172a1f;animation:slidein .2s cubic-bezier(.2,.8,.2,1)}@keyframes slidein{0%{transform:translate(40px);opacity:0}to{transform:none;opacity:1}}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.drawer-body{flex:1;overflow-y:auto}.drawer-footer{padding:16px 20px;border-top:1px solid var(--border);background:var(--surface-2)}.tweaks-panel{position:fixed;right:16px;bottom:16px;z-index:50;width:280px;max-height:calc(100vh - 32px);background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 12px 40px #0f172a29;display:flex;flex-direction:column}.tweaks-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.tweaks-body{padding:14px;overflow-y:auto}.tweaks-section{margin-bottom:16px}.tweaks-section:last-child{margin-bottom:0}.tweaks-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.tweaks-segmented{display:flex;padding:3px;background:var(--surface-2);border-radius:8px;gap:2px}.tweaks-segmented button{flex:1;padding:6px 8px;border:0;border-radius:6px;background:transparent;font-size:12px;color:var(--text-2);cursor:pointer;font-weight:500}.tweaks-segmented button.on{background:#fff;color:var(--text-1);box-shadow:0 1px 3px #00000014}.tweaks-segmented button:hover:not(.on){color:var(--text-1)}.tweaks-links{display:grid;grid-template-columns:1fr 1fr;gap:4px}.tweaks-links button{padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:#fff;font-size:12px;cursor:pointer;text-align:left;color:var(--text-1)}.tweaks-links button:hover{background:var(--accent-softer);border-color:var(--accent);color:var(--accent)}.color-swatch{width:32px;height:32px;border-radius:8px;border:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;position:relative}.color-swatch.on{box-shadow:0 0 0 2px #fff inset,0 0 0 2px currentColor}.tweaks-fab{position:fixed;right:16px;bottom:16px;z-index:50;display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:999px;background:var(--text-1);color:#fff;border:0;font-size:13px;font-weight:500;cursor:pointer;box-shadow:0 8px 24px #0f172a2e}.sg-section{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;margin-bottom:20px}.sg-h{font-size:13px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:20px}.sg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media(max-width:1024px){.sg-grid{grid-template-columns:repeat(2,1fr)}}.sg-row{display:flex;gap:10px;flex-wrap:wrap}.swatch{display:flex;flex-direction:column;gap:4px;padding:14px;border:1px solid var(--border);border-radius:10px}.swatch-color{height:56px;border-radius:8px;margin-bottom:8px}.states-matrix{width:100%;border-collapse:separate;border-spacing:12px}.states-matrix th{text-align:left;font-size:13px;font-weight:600;color:var(--text-2);padding:8px 12px;text-transform:uppercase;letter-spacing:.04em}.states-matrix tbody th{font-size:14px;color:var(--text-1);width:200px;vertical-align:top;padding-top:24px;text-transform:none;letter-spacing:0}.states-matrix td{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px;vertical-align:top}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px}.page-header h1{font-size:28px;font-weight:700;letter-spacing:-.01em;line-height:1.2}.bread{font-size:13px;color:var(--text-2);display:flex;gap:6px;align-items:center}.bread a{color:inherit;text-decoration:none;cursor:pointer}.bread a:hover{color:var(--accent)}.bread .sep{color:var(--text-3)}
