:root{--bg: oklch(.985 .003 250);--surface: oklch(1 0 0);--surface-2: oklch(.975 .004 250);--surface-3: oklch(.96 .005 250);--border: oklch(.92 .006 250);--border-strong: oklch(.86 .008 250);--fg: oklch(.18 .012 260);--fg-2: oklch(.38 .012 260);--fg-3: oklch(.55 .01 260);--fg-4: oklch(.7 .008 260);--accent: oklch(.55 .13 170);--accent-hover: oklch(.48 .13 170);--accent-soft: oklch(.96 .025 170);--accent-soft-2: oklch(.91 .05 170);--accent-ink: oklch(.34 .1 170);--gold: oklch(.74 .13 70);--gold-soft: oklch(.96 .04 80);--gold-ink: oklch(.45 .13 60);--success: oklch(.62 .15 160);--success-soft: oklch(.95 .04 160);--warning: oklch(.72 .16 70);--warning-soft: oklch(.96 .05 80);--danger: oklch(.6 .21 25);--danger-soft: oklch(.96 .04 25);--info: oklch(.62 .16 230);--info-soft: oklch(.95 .04 230);--code-bg: oklch(.18 .014 260);--code-surface: oklch(.22 .014 260);--code-border: oklch(.3 .014 260);--code-fg: oklch(.9 .008 260);--code-muted: oklch(.55 .012 260);--code-keyword: oklch(.72 .18 320);--code-string: oklch(.78 .14 130);--code-number: oklch(.78 .14 50);--code-comment: oklch(.45 .01 260);--code-fn: oklch(.75 .14 230);--radius: 10px;--radius-sm: 6px;--radius-lg: 16px;--shadow-sm: 0 1px 2px oklch(.2 .02 260 / .04);--shadow: 0 1px 2px oklch(.2 .02 260 / .04), 0 4px 12px oklch(.2 .02 260 / .04);--shadow-lg: 0 4px 6px oklch(.2 .02 260 / .04), 0 12px 32px oklch(.2 .02 260 / .08);--font-sans: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--topbar-bg: oklch(1 0 0 / .7)}[data-theme=dark]{--bg: oklch(.155 .018 255);--surface: oklch(.21 .015 254);--surface-2: oklch(.25 .013 254);--surface-3: oklch(.29 .011 254);--border: oklch(.275 .013 254);--border-strong: oklch(.365 .015 254);--fg: oklch(.955 .008 250);--fg-2: oklch(.815 .008 250);--fg-3: oklch(.625 .008 250);--fg-4: oklch(.46 .008 250);--accent: oklch(.66 .14 170);--accent-hover: oklch(.6 .16 170);--accent-soft: oklch(.31 .06 170);--accent-soft-2: oklch(.385 .09 170);--accent-ink: oklch(.86 .11 170);--shadow-sm: 0 1px 2px oklch(0 0 0 / .35);--shadow: 0 1px 2px oklch(0 0 0 / .4), 0 8px 24px oklch(0 0 0 / .32);--shadow-lg: 0 4px 6px oklch(0 0 0 / .45), 0 16px 48px oklch(0 0 0 / .4);--topbar-bg: oklch(.21 .015 254 / .85);--code-bg: oklch(.165 .018 256);--code-fg: oklch(.92 .012 254)}[data-theme=dark] body{background:radial-gradient(ellipse at top,oklch(.21 .025 250 / .55) 0%,transparent 60%),var(--bg);background-attachment:fixed}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;padding:0}a{color:inherit;text-decoration:none}input,textarea{font-family:inherit;color:inherit}.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}.app.chrome-hidden{grid-template-columns:1fr}.nav-text{white-space:nowrap}.sidebar .nav-text,.sidebar .nav-label,.sidebar .brand-name,.sidebar .portal-pill,.sidebar .nav-item .badge,.sidebar .profile-chip .meta{transition:opacity .15s ease}.sidebar-collapse-btn{margin-left:auto;flex-shrink:0;width:28px;height:28px;border-radius:6px;display:grid;place-items:center;color:var(--fg-3);transition:background .12s,color .12s,opacity .12s}.sidebar-collapse-btn:hover{background:var(--surface-2);color:var(--fg)}@media(min-width:769px){.app.sidebar-collapsed{grid-template-columns:64px 1fr}.app.sidebar-collapsed>.sidebar{position:fixed;top:0;left:0;bottom:0;width:64px;overflow-x:hidden;z-index:150;transition:width .2s ease,box-shadow .2s ease}.app.sidebar-collapsed>.sidebar:hover{width:248px;box-shadow:var(--shadow-lg)}.app.sidebar-collapsed>.main{grid-column:2}.app.sidebar-collapsed>.sidebar .nav-text,.app.sidebar-collapsed>.sidebar .nav-label,.app.sidebar-collapsed>.sidebar .brand-name,.app.sidebar-collapsed>.sidebar .portal-pill,.app.sidebar-collapsed>.sidebar .nav-item .badge,.app.sidebar-collapsed>.sidebar .profile-chip .meta,.app.sidebar-collapsed>.sidebar .sidebar-collapse-btn{opacity:0;pointer-events:none}.app.sidebar-collapsed>.sidebar:hover .nav-text,.app.sidebar-collapsed>.sidebar:hover .nav-label,.app.sidebar-collapsed>.sidebar:hover .brand-name,.app.sidebar-collapsed>.sidebar:hover .portal-pill,.app.sidebar-collapsed>.sidebar:hover .nav-item .badge,.app.sidebar-collapsed>.sidebar:hover .profile-chip .meta,.app.sidebar-collapsed>.sidebar:hover .sidebar-collapse-btn{opacity:1;pointer-events:auto}}@media(max-width:768px){.sidebar-collapse-btn{display:none}}.sidebar{background:var(--surface);border-right:1px solid var(--border);padding:20px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-nav{scrollbar-width:none;-ms-overflow-style:none}.sidebar-nav::-webkit-scrollbar{width:0;height:0}.brand{display:flex;align-items:center;gap:10px;padding:4px 10px 18px 4px}.brand-mark{width:28px;height:28px;flex-shrink:0;border-radius:8px;object-fit:contain}.brand-name{font-weight:700;font-size:15px;letter-spacing:-.01em}.nav-section{margin-top:8px}.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);font-weight:600;padding:8px 10px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--radius-sm);color:var(--fg-2);font-size:13.5px;font-weight:500;width:100%;text-align:left;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-2);color:var(--fg)}.nav-item.active{background:var(--accent-soft);color:var(--accent-ink)}.nav-item .icon{width:16px;height:16px;flex-shrink:0;opacity:.9}.nav-item .badge{margin-left:auto;font-size:11px;background:var(--surface-3);color:var(--fg-3);padding:1px 6px;border-radius:999px;font-weight:600}.nav-item.active .badge{background:#ffffff80;color:var(--accent-ink)}.sidebar-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.profile-chip{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius);width:100%}.profile-chip:hover{background:var(--surface-2)}.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#ed7665,#ca488f);flex-shrink:0;display:grid;place-items:center;color:#fff;font-weight:700;font-size:11.5px}.profile-chip .meta{text-align:left;flex:1;min-width:0}.profile-chip .name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-chip .role{font-size:11.5px;color:var(--fg-3)}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:60px;border-bottom:1px solid var(--border);background:var(--topbar-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:0 32px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10}.search{flex:1;max-width:420px;position:relative}.search input{width:100%;height:36px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);padding:0 12px 0 36px;font-size:13.5px;outline:none;transition:border .12s,background .12s}.search input:focus{border-color:var(--accent);background:var(--surface)}.search-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--fg-4)}.search .kbd{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--fg-4);border:1px solid var(--border);border-radius:4px;padding:1px 5px;background:var(--surface);font-family:var(--font-mono)}.topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);display:grid;place-items:center;color:var(--fg-2);transition:background .12s,color .12s;position:relative}.icon-btn:hover{background:var(--surface-2);color:var(--fg)}.icon-btn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}.page{padding:32px 40px 64px;max-width:1280px;width:100%}.page-wide{max-width:none;padding:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:36px;padding:0 14px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:600;border:1px solid transparent;transition:all .12s;white-space:nowrap}.btn-primary{background:var(--fg);color:var(--bg)}.btn-primary:hover{background:#25292f}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-hover)}.btn-ghost{color:var(--fg-2)}.btn-ghost:hover{background:var(--surface-2);color:var(--fg)}.btn-outline{border-color:var(--border-strong);background:var(--surface);color:var(--fg)}.btn-outline:hover{background:var(--surface-2)}.btn-success{background:var(--success-soft);border-color:var(--success);color:var(--success)}.btn-success:disabled{opacity:1;cursor:default}.btn-lg{height:42px;padding:0 18px;font-size:14px}.btn-sm{height:30px;padding:0 10px;font-size:12.5px}.h1{font-size:26px;font-weight:700;letter-spacing:-.02em;line-height:1.2;margin:0}.h2{font-size:20px;font-weight:700;letter-spacing:-.015em;line-height:1.25;margin:0}.h3{font-size:16px;font-weight:650;letter-spacing:-.01em;line-height:1.3;margin:0}.h4{font-size:14px;font-weight:600;letter-spacing:-.005em;margin:0}.eyebrow{font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--fg-3)}.muted{color:var(--fg-3)}.muted-2{color:var(--fg-4)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.card-pad{padding:20px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:28px}.page-head .sub{margin-top:4px;color:var(--fg-3);font-size:14px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}.stat{padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.stat-label{font-size:12px;color:var(--fg-3);font-weight:500;display:flex;align-items:center;gap:8px}.stat-value{font-size:28px;font-weight:700;letter-spacing:-.02em;margin-top:8px;line-height:1.1}.stat-trend{font-size:12px;margin-top:6px;color:var(--success);display:flex;align-items:center;gap:4px;font-weight:500}.stat-trend.down{color:var(--danger)}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:16px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-head .link{font-size:13px;color:var(--fg-3);font-weight:500}.section-head .link:hover{color:var(--fg)}.continue-card{display:grid;grid-template-columns:160px 1fr auto;gap:18px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:all .15s;text-align:left;width:100%}.continue-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.continue-thumb{height:96px;border-radius:8px;background:linear-gradient(135deg,#becdf6,#ca99d6);position:relative;overflow:hidden}.continue-thumb.t-2{background:linear-gradient(135deg,#9fdadd,#4fa8e1)}.continue-thumb.t-3{background:linear-gradient(135deg,#ecd69b,#ef945f)}.continue-thumb.t-4{background:linear-gradient(135deg,#a6dcbe,#69cab8 50%,#3ec1b4 75%,#1abcb2 87.5%,#01b9b1,#00b6af);background:linear-gradient(135deg,#a6dcbe,#69cab8 50%,#3ec1b4 75%,#1abcb2 87.5%,color(xyz 0.252 0.38 0.477),color(xyz 0.239 0.367 0.47))}.continue-thumb:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(135deg,transparent 0 49%,oklch(1 0 0 / .12) 49% 51%,transparent 51%);background-size:14px 14px}.continue-thumb .play{position:absolute;bottom:8px;left:8px;background:#fffffff2;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:var(--fg)}.continue-body{min-width:0}.continue-body .meta{font-size:11.5px;color:var(--fg-3);font-weight:500;margin-bottom:4px;display:flex;align-items:center;gap:8px}.continue-body .title{font-size:15px;font-weight:650;letter-spacing:-.01em;margin-bottom:8px}.continue-body .module{font-size:12.5px;color:var(--fg-3);margin-bottom:10px}.progress{height:5px;background:var(--surface-3);border-radius:999px;overflow:hidden}.progress>span{display:block;height:100%;background:var(--accent);border-radius:999px}.progress-row{display:flex;align-items:center;gap:10px}.progress-row .progress{flex:1}.progress-row .pct{font-size:11.5px;color:var(--fg-3);font-variant-numeric:tabular-nums;font-weight:600}.list{display:flex;flex-direction:column;gap:10px}.schedule-item{display:grid;grid-template-columns:56px 1fr auto;gap:12px;align-items:center;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface)}.schedule-time{text-align:center}.schedule-time .day{font-size:11px;color:var(--fg-3);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.schedule-time .date{font-size:18px;font-weight:700;letter-spacing:-.02em;line-height:1.1}.schedule-item .title{font-size:13.5px;font-weight:600}.schedule-item .sub{font-size:12px;color:var(--fg-3);margin-top:2px}.pill{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface-2);color:var(--fg-2);white-space:nowrap}.pill-accent{background:var(--accent-soft);border-color:var(--accent-soft-2);color:var(--accent-ink)}.pill-success{background:var(--success-soft);border-color:var(--success-soft);color:var(--success)}.pill-warn{background:var(--warning-soft);border-color:var(--warning-soft);color:#7f4400;color:oklch(.45 .13 60)}.pill-info{background:var(--info-soft);border-color:var(--info-soft);color:var(--info)}.pill-danger{background:var(--danger-soft);border-color:var(--danger-soft);color:var(--danger)}.dot-sep{width:3px;height:3px;border-radius:50%;background:var(--fg-4);display:inline-block}.chart-card{padding:20px 22px}.chart{display:grid;grid-template-columns:repeat(14,1fr);gap:8px;align-items:end;height:140px;margin-top:16px}.chart .bar{background:var(--surface-3);border-radius:4px 4px 2px 2px;position:relative;transition:background .12s}.chart .bar.active{background:var(--accent)}.chart .bar:hover{background:var(--accent-hover)}.chart-axis{display:grid;grid-template-columns:repeat(14,1fr);gap:8px;margin-top:10px;font-size:11px;color:var(--fg-4);text-align:center}.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:22px;flex-wrap:wrap}.chip{height:32px;padding:0 12px;border:1px solid var(--border);background:var(--surface);color:var(--fg-2);border-radius:999px;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px}.chip.active{background:var(--fg);color:var(--bg);border-color:var(--fg)}.chip:hover:not(.active){background:var(--surface-2)}.course-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.course-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;text-align:left;display:flex;flex-direction:column;transition:all .18s}.course-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-2px)}.course-cover{aspect-ratio:16 / 9;background:linear-gradient(135deg,#becdf6,#ca99d6);position:relative;overflow:hidden}.course-cover.c-2{background:linear-gradient(135deg,#9fdadd,#4fa8e1)}.course-cover.c-3{background:linear-gradient(135deg,#ecd69b,#ef945f)}.course-cover.c-4{background:linear-gradient(135deg,#a6dcbe,#69cab8 50%,#3ec1b4 75%,#1abcb2 87.5%,#01b9b1,#00b6af);background:linear-gradient(135deg,#a6dcbe,#69cab8 50%,#3ec1b4 75%,#1abcb2 87.5%,color(xyz 0.252 0.38 0.477),color(xyz 0.239 0.367 0.47))}.course-cover.c-5{background:linear-gradient(135deg,#feb9b8,#de77ab)}.course-cover.c-6{background:linear-gradient(135deg,#e3c0eb,#8e93f3)}.course-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(135deg,transparent 0 49.5%,oklch(1 0 0 / .1) 49.5% 50.5%,transparent 50.5%);background-size:22px 22px}.course-cover .tag{position:absolute;top:12px;left:12px;background:#ffffffeb;font-size:11px;font-weight:700;padding:4px 8px;border-radius:5px;color:var(--fg);text-transform:uppercase;letter-spacing:.04em}.course-body{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}.course-body .level{font-size:11.5px;color:var(--fg-3);font-weight:600;margin-bottom:6px;display:flex;align-items:center;gap:8px}.course-body .title{font-size:16px;font-weight:650;letter-spacing:-.01em;line-height:1.3;margin-bottom:6px}.course-body .desc{font-size:13px;color:var(--fg-3);line-height:1.5;margin-bottom:14px;flex:1}.course-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--border);font-size:12px;color:var(--fg-3)}.course-foot .instructor{display:flex;align-items:center;gap:8px}.avatar-xs{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#f09080,#c3518d);flex-shrink:0}.rating{display:inline-flex;align-items:center;gap:4px;font-weight:600;color:var(--fg-2)}.rating .star{color:#ecaa0b}.course-hero{display:grid;grid-template-columns:1fr 360px;gap:32px;margin-bottom:36px}.crumbs{font-size:12.5px;color:var(--fg-3);margin-bottom:14px;display:flex;align-items:center;gap:6px}.crumbs .sep{color:var(--fg-4)}.crumbs a:hover{color:var(--fg)}.hero-title{font-size:34px;font-weight:700;letter-spacing:-.025em;line-height:1.15;margin:0 0 12px}.hero-sub{font-size:15.5px;color:var(--fg-3);line-height:1.55;max-width:60ch;margin-bottom:22px}.hero-meta{display:flex;align-items:center;gap:22px;flex-wrap:wrap;font-size:13px;color:var(--fg-2)}.hero-meta strong{color:var(--fg);font-weight:700}.enroll-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:sticky;top:80px}.enroll-preview{aspect-ratio:16 / 9;border-radius:8px;background:linear-gradient(135deg,#becdf6,#ca99d6);position:relative;overflow:hidden;margin-bottom:16px}.enroll-preview:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(135deg,transparent 0 49.5%,oklch(1 0 0 / .12) 49.5% 50.5%,transparent 50.5%);background-size:22px 22px}.enroll-preview .play-big{position:absolute;top:0;right:0;bottom:0;left:0;margin:auto;width:52px;height:52px;border-radius:50%;background:#fffffff2;display:grid;place-items:center;color:var(--fg);box-shadow:var(--shadow)}.enroll-price{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}.enroll-price .amount{font-size:28px;font-weight:700;letter-spacing:-.02em}.enroll-price .strike{font-size:14px;color:var(--fg-4);text-decoration:line-through}.enroll-price .save{font-size:12px;font-weight:700;color:var(--success);margin-left:auto}.enroll-feats{margin:16px 0 0;padding:16px 0 0;border-top:1px solid var(--border);list-style:none;font-size:13px;color:var(--fg-2);display:flex;flex-direction:column;gap:8px}.enroll-feats li{display:flex;align-items:center;gap:10px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px}.tab{padding:10px 14px;font-size:13.5px;font-weight:600;color:var(--fg-3);position:relative;border-radius:6px 6px 0 0}.tab:hover,.tab.active{color:var(--fg)}.tab.active:after{content:"";position:absolute;inset:auto 0 -1px;height:2px;background:var(--fg);border-radius:2px 2px 0 0}.module{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);margin-bottom:10px;overflow:hidden}.module-head{display:flex;align-items:center;gap:12px;padding:14px 18px;width:100%;text-align:left}.module-head .num{width:26px;height:26px;border-radius:50%;background:var(--surface-3);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--fg-2);flex-shrink:0}.module-head .title{font-size:14.5px;font-weight:650;letter-spacing:-.005em}.module-head .sub{font-size:12px;color:var(--fg-3);margin-top:2px}.module-head .right{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:12px;color:var(--fg-3)}.module-head .chev{transition:transform .18s}.module.open .chev{transform:rotate(180deg)}.module.locked{opacity:.6}.module.locked .module-head{cursor:not-allowed}.module.locked .module-head .num{background:var(--surface-2)}.module-body{border-top:1px solid var(--border);padding:6px 0}.lesson-row{display:grid;grid-template-columns:28px 1fr auto auto;gap:12px;align-items:center;padding:10px 18px 10px 50px;font-size:13.5px;color:var(--fg-2);width:100%;text-align:left;transition:background .1s}.lesson-row:hover{background:var(--surface-2)}.lesson-row .ico{width:22px;height:22px;border-radius:6px;background:var(--surface-3);display:grid;place-items:center;color:var(--fg-3)}.lesson-row.done .ico{background:var(--success-soft);color:var(--success)}.lesson-row.current .ico{background:var(--accent);color:#fff}.lesson-row .duration{font-size:12px;color:var(--fg-3);font-variant-numeric:tabular-nums}.lesson-layout{display:grid;grid-template-columns:1fr 360px;min-height:calc(100vh - 60px)}.lesson-main{padding:32px 40px;min-width:0}.video{aspect-ratio:16 / 9;background:var(--code-bg);border-radius:var(--radius-lg);position:relative;overflow:hidden;margin-bottom:24px}.video-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 40%,oklch(.45 .14 280 / .4),transparent 60%),radial-gradient(circle at 70% 60%,oklch(.45 .15 220 / .35),transparent 60%),linear-gradient(135deg,#151b24,#080d16)}.video-content{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:24px;font-family:var(--font-mono);font-size:12px;color:#babec4}.video .play-btn{width:76px;height:76px;border-radius:50%;background:#fffffff2;color:var(--fg);display:grid;place-items:center;cursor:pointer;transition:transform .15s;box-shadow:0 8px 32px #0000004d}.video .play-btn:hover{transform:scale(1.08)}.video-controls{position:absolute;inset:auto 0 0 0;padding:14px 20px;background:linear-gradient(to top,oklch(0 0 0 / .7),transparent);color:#fff;display:flex;align-items:center;gap:14px;font-size:12px;font-variant-numeric:tabular-nums}.video-scrub{flex:1;height:4px;background:#ffffff40;border-radius:999px;position:relative;cursor:pointer}.video-scrub>span{display:block;height:100%;background:#fff;border-radius:999px}.video-scrub:after{content:"";position:absolute;width:12px;height:12px;background:#fff;border-radius:50%;top:50%;transform:translate(-50%,-50%);left:38%}.lesson-info .h1{font-size:24px;margin-bottom:8px}.lesson-info .meta{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--fg-3);margin-bottom:22px}.lesson-tabs{margin-top:28px}.lesson-notes{font-size:14px;line-height:1.65;color:var(--fg-2)}.lesson-notes h3{font-size:15px;font-weight:650;color:var(--fg);margin:24px 0 10px;letter-spacing:-.01em}.lesson-notes p{margin:0 0 12px}.lesson-notes ul{margin:0 0 12px;padding-left:20px}.lesson-notes li{margin-bottom:6px}.markdown-body{font-size:14.5px;line-height:1.7;color:var(--fg-2);margin-top:16px}.markdown-body h1,.markdown-body h2,.markdown-body h3,.markdown-body h4{color:var(--fg);font-weight:650;letter-spacing:-.01em;margin:22px 0 10px}.markdown-body h1{font-size:22px}.markdown-body h2{font-size:18px}.markdown-body h3{font-size:16px}.markdown-body h4{font-size:14px}.markdown-body p{margin:0 0 12px}.markdown-body ul,.markdown-body ol{margin:0 0 12px;padding-left:22px}.markdown-body li{margin-bottom:4px}.markdown-body a{color:var(--accent);text-decoration:underline}.markdown-body code{background:var(--surface-2);padding:1px 6px;border-radius:4px;font-family:var(--font-mono);font-size:13px}.markdown-body pre{background:var(--code-bg, #0f1117);color:var(--code-fg, #e6e8ee);padding:14px 16px;border-radius:8px;overflow:auto;font-family:var(--font-mono);font-size:13px;margin:12px 0}.markdown-body pre code{background:transparent;padding:0;color:inherit;font-size:inherit}.markdown-body blockquote{margin:14px 0;padding:12px 16px;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:6px;color:var(--accent-ink);font-size:13.5px}.markdown-body blockquote p:last-child{margin-bottom:0}.markdown-body table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}.markdown-body th,.markdown-body td{border:1px solid var(--border);padding:6px 10px;text-align:left}.markdown-body th{background:var(--surface-2);font-weight:650}.markdown-body img{max-width:100%;border-radius:6px}.markdown-body hr{border:0;border-top:1px solid var(--border);margin:18px 0}.lesson-body{margin-top:18px}.callout{background:var(--accent-soft);border-left:3px solid var(--accent);padding:14px 16px;border-radius:6px;margin:14px 0;font-size:13.5px;color:var(--accent-ink)}.callout-info{background:#3884ff1a;border-left-color:#3884ff;color:var(--fg)}.callout-tip{background:#22c55e1a;border-left-color:#22c55e;color:var(--fg)}.callout-warning{background:#f59e0b1f;border-left-color:#f59e0b;color:var(--fg)}.block-editor{display:flex;flex-direction:column;gap:4px}.block-empty{padding:12px;text-align:center;border:1px dashed var(--border);border-radius:6px;font-size:13px}.block-row{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 10px 10px}.block-row .block-head{display:flex;align-items:center;gap:8px;padding-bottom:6px;margin-bottom:6px;border-bottom:1px dashed var(--border)}.block-row .block-head .handle{display:inline-flex;padding:4px;color:var(--fg-2)}.block-row .block-body{display:flex;flex-direction:column;gap:6px}.block-add-between{display:flex;justify-content:center;align-items:center;height:14px;opacity:0;transition:opacity .1s}.block-add-between:hover,.block-add-between.open{opacity:1}.block-add-btn{background:var(--accent);color:#fff;border:none;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 4px #00000026}.block-add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:transparent}.block-add-menu{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg, 0 12px 32px rgba(0,0,0,.25));padding:4px;z-index:1001;min-width:280px;max-width:360px;max-height:380px;overflow-y:auto}.block-add-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:transparent;cursor:pointer;border-radius:6px;text-align:left;color:var(--fg)}.block-add-menu-item:hover{background:var(--surface-2)}.block-add-menu-item .name{font-size:13px;font-weight:600}.block-add-menu-item .desc{font-size:11px;color:var(--fg-2)}.mcq-block{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:16px;margin:14px 0}.mcq-question{font-weight:650;margin-bottom:12px;font-size:14.5px}.mcq-options{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.mcq-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;text-align:left;font-size:13.5px;color:var(--fg)}.mcq-option:hover{border-color:var(--accent)}.mcq-option.selected{border-color:var(--accent);background:var(--accent-soft)}.mcq-option.correct{border-color:var(--success, #22c55e);background:#22c55e1a}.mcq-option.incorrect{border-color:var(--danger, #ef4444);background:#ef44441a}.mcq-option .key{flex:0 0 22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--surface-2);font-size:11px;font-weight:700}.mcq-actions{display:flex;align-items:center;gap:12px}.mcq-result{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600}.mcq-result.correct{color:var(--success, #22c55e)}.mcq-result.incorrect{color:var(--danger, #ef4444)}.mcq-explanation{margin-top:10px;font-size:13px;color:var(--fg-2)}.lesson-type-tabs{display:flex;gap:6px;flex-wrap:wrap}.lesson-type-tabs .chip{padding:6px 14px;font-size:12.5px}.field-stack{display:flex;flex-direction:column;gap:14px}.field-row{display:flex;gap:8px;align-items:stretch}.field-row>.input,.field-row>.select{flex:1}.field-row>.btn{flex-shrink:0}.section-card .body .field-help{margin-top:-2px}.lesson-block-embed{margin:18px 0}.lesson-block-embed .coding-layout.stacked,.coding-layout.stacked{display:flex;flex-direction:column;grid-template-columns:none}.lesson-block-embed .coding-layout.stacked .problem-pane,.coding-layout.stacked .problem-pane{max-height:none;border-right:none;border-bottom:1px solid var(--border)}.coding-layout.stacked{height:auto}.coding-layout.stacked .editor{min-height:340px}.coding-layout.stacked .problem-head{position:static}.lesson-blocks{display:flex;flex-direction:column}.lesson-block{margin-bottom:4px}.lesson-editor-page{display:flex;flex-direction:column;height:100vh;height:100dvh;background:var(--bg)}.lesson-editor-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;background:var(--topbar-bg, var(--surface));border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex-shrink:0}.lesson-editor-crumbs{display:flex;align-items:center;gap:10px;min-width:0;flex:1 1 auto;overflow:hidden}.lesson-editor-crumbs .crumbs{font-size:13px;margin-bottom:0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lesson-editor-crumbs .crumbs button{background:none;border:none;padding:0;font:inherit;color:var(--fg-3);cursor:pointer}.lesson-editor-crumbs .crumbs button:hover{color:var(--fg)}.lesson-editor-crumbs .crumbs .strong{color:var(--fg);font-weight:600}.lesson-editor-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.dirty-flag{font-size:11.5px;color:var(--fg-3);padding:4px 8px;background:var(--surface-2);border-radius:var(--radius-sm, 6px);margin-right:4px}.lesson-editor-split{flex:1 1 auto;min-height:0;display:grid;grid-template-columns:minmax(400px,1fr) minmax(400px,1fr);gap:0;overflow:hidden}.lesson-editor-pane{overflow-y:auto;padding:20px}.lesson-editor-pane-left{border-right:1px solid var(--border);background:var(--surface)}.lesson-editor-pane-right{background:var(--bg)}.lesson-editor-preview-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;margin:-20px -20px 18px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:-20px;z-index:1;color:var(--fg-2)}.lesson-editor-preview-body{max-width:760px;margin:0 auto}.lesson-preview .lesson-preview-meta{margin:4px 0 18px}.lesson-preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:48px 16px;text-align:center;border:1px dashed var(--border);border-radius:var(--radius, 8px);background:var(--surface);color:var(--fg-3)}@media(max-width:1100px){.lesson-editor-split{grid-template-columns:1fr}.lesson-editor-pane-left{border-right:none;border-bottom:1px solid var(--border)}}@keyframes spin-rotate{to{transform:rotate(360deg)}}.spinner{display:inline-block;border-style:solid;border-color:var(--border-strong) var(--border-strong) var(--accent) var(--accent);border-radius:50%;animation:spin-rotate .7s linear infinite;vertical-align:middle;box-sizing:border-box}.spinner-block{display:flex;align-items:center;justify-content:center;gap:10px;padding:28px 16px;color:var(--fg-2)}.spinner-inline{display:inline-flex;align-items:center;gap:8px;color:var(--fg-2)}.spinner-fullpage{display:flex;align-items:center;justify-content:center;gap:12px;min-height:200px;color:var(--fg-2)}.spinner-label{font-size:13px;color:var(--fg-3)}.code-snippet{background:var(--code-bg);color:var(--code-fg);border-radius:8px;padding:16px 18px;font-family:var(--font-mono);font-size:13px;line-height:1.65;overflow-x:auto;margin:12px 0}.lesson-side{border-left:1px solid var(--border);background:var(--surface);padding:24px;overflow-y:auto}.lesson-side-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin:-4px 0 16px}.lesson-side-tab{display:inline-flex;align-items:center;gap:6px;padding:8px 10px;font-size:13px;font-weight:600;color:var(--fg-3);position:relative;border-radius:6px 6px 0 0}.lesson-side-tab svg{color:var(--accent)}.lesson-side-tab:hover,.lesson-side-tab.active{color:var(--fg)}.lesson-side-tab.active:after{content:"";position:absolute;inset:auto 0 -1px;height:2px;background:var(--fg);border-radius:2px 2px 0 0}.lesson-side.tutor-active{position:sticky;top:60px;height:calc(100vh - 60px);display:flex;flex-direction:column;overflow:hidden}.outline-item{display:grid;grid-template-columns:24px 1fr auto;gap:10px;align-items:center;padding:9px 10px;border-radius:6px;text-align:left;width:100%;font-size:13px;color:var(--fg-2)}.outline-item:hover{background:var(--surface-2)}.outline-item.current{background:var(--accent-soft);color:var(--accent-ink)}.outline-item.done{color:var(--fg-3)}.outline-item .ico{width:20px;height:20px;border-radius:5px;background:var(--surface-3);display:grid;place-items:center;color:var(--fg-3)}.outline-item.done .ico{background:var(--success-soft);color:var(--success)}.outline-item.current .ico{background:var(--accent);color:#fff}.outline-item .duration{font-size:11.5px;color:var(--fg-4);font-variant-numeric:tabular-nums}.outline-group{margin-bottom:14px}.outline-group .label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);font-weight:700;padding:4px 10px 8px}.quiz-shell{max-width:760px;margin:0 auto;padding:40px 24px 80px}.quiz-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.quiz-meta{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--fg-3)}.quiz-timer{display:inline-flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;font-size:13px;font-weight:600;font-variant-numeric:tabular-nums}.quiz-progress{margin-bottom:32px}.qp-bar{height:5px;background:var(--surface-3);border-radius:999px;overflow:hidden}.qp-bar>span{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .3s}.qp-meta{display:flex;justify-content:space-between;font-size:12.5px;color:var(--fg-3);margin-bottom:8px;font-weight:500}.q-eyebrow{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.q-text{font-size:22px;font-weight:600;letter-spacing:-.015em;line-height:1.4;margin:0 0 28px}.q-options{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}.quiz-shell.quiz-preview-scope,.results-shell.quiz-preview-scope{max-width:100%;margin:0;padding:0}.quiz-preview-scope .quiz-head,.quiz-preview-scope .quiz-progress{margin-bottom:18px}.quiz-preview-scope .q-text{font-size:18px;margin-bottom:18px}.quiz-preview-scope .q-options{gap:8px;margin-bottom:18px}.quiz-preview-scope .q-option{padding:12px 14px;font-size:14px}.quiz-preview-scope .q-actions{margin-top:4px}.quiz-preview-scope .results-icon{width:64px;height:64px;margin-bottom:16px}.quiz-preview-scope .score-big{font-size:42px}.quiz-preview-scope .results-stats{margin:22px 0}.q-option{display:grid;grid-template-columns:32px 1fr auto;gap:14px;align-items:center;padding:16px 18px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--surface);text-align:left;font-size:14.5px;color:var(--fg);transition:all .15s}.q-option:hover{border-color:var(--border-strong);background:var(--surface-2)}.q-option .key{width:28px;height:28px;border-radius:7px;background:var(--surface-3);display:grid;place-items:center;font-size:12.5px;font-weight:700;color:var(--fg-2);font-family:var(--font-mono)}.q-option.selected{border-color:var(--accent);background:var(--accent-soft)}.q-option.selected .key{background:var(--accent);color:#fff}.q-option.correct{border-color:var(--success);background:var(--success-soft)}.q-option.correct .key{background:var(--success);color:#fff}.q-option.incorrect{border-color:var(--danger);background:var(--danger-soft)}.q-option.incorrect .key{background:var(--danger);color:#fff}.q-option .indicator{width:20px;height:20px;display:grid;place-items:center;color:var(--fg-4);opacity:0}.q-option.selected .indicator,.q-option.correct .indicator,.q-option.incorrect .indicator{opacity:1}.q-actions{display:flex;align-items:center;justify-content:space-between}.q-actions .left{display:flex;gap:8px}.q-feedback{padding:16px 18px;border-radius:var(--radius);margin-bottom:24px;font-size:14px;display:flex;align-items:flex-start;gap:12px}.q-feedback.correct{background:var(--success-soft);color:var(--success)}.q-feedback.incorrect{background:var(--danger-soft);color:var(--danger)}.q-feedback .body{color:var(--fg-2);margin-top:4px;font-size:13.5px}.q-feedback strong{color:var(--fg)}.coding-layout{display:grid;grid-template-columns:minmax(0,var(--problem-w, 1fr)) 7px minmax(0,var(--editor-w, 1fr));height:calc(100vh - 60px);overflow:hidden}.coding-page{height:calc(100vh - 60px);display:flex;flex-direction:column;overflow:hidden}.coding-page-bar{flex:0 0 auto;display:flex;align-items:center;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--surface)}.coding-page-body{flex:1;min-height:0;overflow:auto}.coding-page-body .coding-layout{height:100%}.coding-fullscreen{display:flex;flex-direction:column;height:100vh;min-height:0}.coding-fs-bar{flex:0 0 auto;height:52px;display:flex;align-items:center;gap:16px;padding:0 16px;border-bottom:1px solid var(--border);background:var(--surface)}.coding-fs-title{flex:1;min-width:0;display:flex;align-items:center;gap:8px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.coding-fs-actions{display:flex;align-items:center;gap:8px}.coding-fs-body{flex:1;min-height:0;overflow:auto}.coding-fullscreen .coding-fs-body .coding-layout{height:100%}.coding-loading{display:grid;place-items:center;height:calc(100vh - 120px)}.pane-divider{position:relative;cursor:col-resize;background:var(--border);display:grid;place-items:center;transition:background .15s}.pane-divider:hover,.pane-divider:active{background:var(--accent)}.pane-divider-grip{width:3px;height:34px;border-radius:3px;background:var(--fg-4);opacity:.5}.pane-divider:hover .pane-divider-grip{background:#fff;opacity:.9}.problem-pane{border-right:1px solid var(--border);overflow-y:auto;background:var(--surface)}.problem-head{padding:22px 28px 18px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:2}.problem-head h1{font-size:20px;font-weight:700;letter-spacing:-.015em;margin:0 0 8px;display:flex;align-items:center;gap:10px}.problem-head .num{font-family:var(--font-mono);color:var(--fg-4);font-size:14px;font-weight:600}.problem-head .meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.problem-body{padding:22px 28px 40px;font-size:14px;line-height:1.65;color:var(--fg-2)}.problem-body h3{font-size:14px;font-weight:700;color:var(--fg);margin:22px 0 10px;letter-spacing:-.005em}.problem-body p{margin:0 0 12px}.problem-body code{font-family:var(--font-mono);font-size:12.5px;background:var(--surface-3);padding:1px 5px;border-radius:4px;color:var(--fg)}.example{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:12px;font-family:var(--font-mono);font-size:12.5px;line-height:1.7}.example .label{color:var(--fg-3);font-weight:700}.example .val{color:var(--fg)}.constraints{margin:0;padding-left:18px;font-family:var(--font-mono);font-size:12.5px;color:var(--fg-2)}.constraints li{margin-bottom:4px}.editor-pane{display:flex;flex-direction:row;background:var(--code-bg);min-width:0;min-height:0}.editor-main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;background:var(--code-bg)}.coding-ai-rail{flex:0 0 300px;min-height:0;display:flex;flex-direction:column;border-left:1px solid var(--code-border);background:var(--code-surface);overflow:hidden}.coding-ai-rail.collapsed{flex-basis:46px}.ai-rail-inner{flex:1;min-height:0;display:flex;flex-direction:column}.ai-rail-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--code-border)}.ai-rail-title{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--code-fg)}.ai-rail-title svg{color:var(--accent)}.ai-rail-toggle{display:inline-flex;border:0;background:transparent;color:var(--code-muted);cursor:pointer;padding:2px;border-radius:6px}.ai-rail-toggle:hover{background:var(--code-border);color:var(--code-fg)}.ai-rail-actions{flex:0 0 auto;display:flex;flex-direction:column;gap:8px;padding:12px;border-bottom:1px solid var(--code-border)}.ai-rail-actions .btn{justify-content:flex-start}.ai-rail-body{flex:1;min-height:0;overflow-y:auto;padding:12px;font-size:13px;color:var(--code-fg)}.ai-rail-empty{display:flex;align-items:center;gap:6px;font-size:12.5px;line-height:1.5}.ai-rail-empty svg{color:var(--accent);flex:0 0 auto}.ai-rail-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px 0;border:0;background:transparent;color:var(--code-muted);cursor:pointer}.ai-rail-tab:hover{color:var(--code-fg)}.ai-rail-tab svg{color:var(--accent)}.ai-rail-tab-label{writing-mode:vertical-rl;transform:rotate(180deg);font-size:12px;font-weight:700;letter-spacing:.02em}.coding-layout.stacked .editor-pane{flex-direction:column}.coding-ai-rail.stacked{flex-basis:auto;border-left:0;border-top:1px solid var(--code-border)}.coding-ai-rail.stacked .ai-rail-body{max-height:320px}.editor-head{padding:10px 14px;border-bottom:1px solid var(--code-border);display:flex;align-items:center;gap:10px;background:var(--code-surface)}.lang-select{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;border:1px solid var(--code-border);background:var(--code-bg);color:var(--code-fg);border-radius:6px;font-size:12.5px;font-weight:600}.editor-head .ico-btn{width:30px;height:30px;border-radius:6px;display:grid;place-items:center;color:var(--code-muted)}.editor-head .ico-btn:hover{background:var(--code-border);color:var(--code-fg)}.editor-head .right{margin-left:auto;display:flex;align-items:center;gap:8px}.btn-run{background:var(--code-surface);border:1px solid var(--code-border);color:var(--code-fg)}.btn-run:hover{background:var(--code-border)}.btn-submit{background:var(--success);color:#fff}.btn-submit:hover{background:#008758;background:oklch(.55 .16 160)}.editor{flex:1;position:relative;font-family:var(--font-mono);font-size:13px;line-height:1.6;overflow:hidden;background:var(--code-bg);min-height:0}.gutter{position:absolute;top:0;left:0;bottom:0;width:46px;overflow:hidden;padding:16px 10px 16px 0;text-align:right;color:var(--code-muted);-webkit-user-select:none;user-select:none;border-right:1px solid var(--code-border);font-variant-numeric:tabular-nums;font-size:12px;pointer-events:none}.gutter-line{height:20.8px}.code-area{position:absolute;top:0;right:0;bottom:0;left:46px;padding:16px 18px;color:var(--code-fg);caret-color:var(--code-fg);white-space:pre;outline:none;background:transparent;border:0;resize:none;font-family:var(--font-mono);font-size:13px;line-height:1.6;width:calc(100% - 46px);height:100%;overflow:auto;-moz-tab-size:4;tab-size:4}.code-area::placeholder{color:var(--code-muted)}.code-area .kw{color:var(--code-keyword);font-weight:500}.code-area .st{color:var(--code-string)}.code-area .nm{color:var(--code-number)}.code-area .cm{color:var(--code-comment);font-style:italic}.code-area .fn{color:var(--code-fn)}.console{border-top:1px solid var(--code-border);background:var(--code-surface);max-height:40%;min-height:180px;display:flex;flex-direction:column}.console-tabs{display:flex;gap:2px;padding:6px 10px 0;border-bottom:1px solid var(--code-border)}.console-tab{padding:8px 12px;font-size:12.5px;color:var(--code-muted);font-weight:600;border-radius:6px 6px 0 0;position:relative}.console-tab.active{color:var(--code-fg)}.console-tab.active:after{content:"";position:absolute;inset:auto 4px -1px 4px;height:2px;background:var(--accent);border-radius:2px 2px 0 0}.console-body{padding:12px 16px;font-family:var(--font-mono);font-size:12.5px;color:var(--code-fg);overflow-y:auto;flex:1}.console-tab-count{margin-left:6px;padding:1px 6px;border-radius:999px;font-size:10.5px;font-weight:700;font-variant-numeric:tabular-nums}.console-tab-count.pass{background:var(--success);color:#fff}.console-tab-count.fail{background:var(--danger);color:#fff}.run-summary{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:12.5px;font-weight:600;border-bottom:1px solid var(--code-border)}.run-summary.ok{color:#5ed99e;background:#0a372366}.run-summary.bad{color:#ff958d;color:oklch(.78 .13 25);background:#51232066}.run-summary-text{flex:1}.run-summary-ms{color:var(--code-muted);font-weight:500;font-variant-numeric:tabular-nums}.test-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.test-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:7px;border:1px solid var(--code-border);background:var(--code-bg);color:var(--code-muted);font-size:12px;font-weight:600;cursor:pointer;transition:border-color .12s,color .12s}.test-chip:hover{color:var(--code-fg)}.test-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--code-muted)}.test-chip.pass .dot{background:var(--success)}.test-chip.fail .dot{background:var(--danger)}.test-chip.active{color:var(--code-fg);border-color:var(--accent);background:var(--code-surface)}.test-chip.pass.active{border-color:var(--success)}.test-chip.fail.active{border-color:var(--danger)}.test-detail{display:flex;flex-direction:column}.console-empty,.console-running{display:flex;align-items:center;gap:8px;padding:18px 4px;font-size:12.5px;color:var(--code-muted)}.console-empty kbd{font-family:var(--font-mono);font-size:11px;padding:1px 5px;border-radius:4px;border:1px solid var(--code-border);background:var(--code-bg);color:var(--code-fg)}.console-output{margin:0;white-space:pre-wrap}.io-block{background:var(--code-bg);border:1px solid var(--code-border);border-radius:6px;padding:8px 12px;margin:6px 0;font-size:12px;line-height:1.6;color:var(--code-fg)}.io-block pre{margin:0;white-space:pre-wrap;word-break:break-word}.io-block.mismatch,.io-block.error{border-color:var(--danger)}.io-block.error .label,.io-block.error pre{color:var(--danger)}.io-block .label{color:var(--code-muted);font-size:11px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:4px}.profile-hero{display:grid;grid-template-columns:96px 1fr auto;gap:24px;align-items:center;padding:24px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);margin-bottom:24px}.avatar-lg{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,#ed7665,#ca488f);display:grid;place-items:center;color:#fff;font-weight:700;font-size:36px;letter-spacing:-.02em}.profile-hero .name{font-size:24px;font-weight:700;letter-spacing:-.02em;margin:0}.profile-hero .handle{font-size:14px;color:var(--fg-3);margin-top:4px}.profile-hero .bio{font-size:13.5px;color:var(--fg-2);margin-top:12px;max-width:60ch;line-height:1.5}.profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}.achievement-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.badge-card{padding:20px 16px;text-align:center;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface)}.badge-icon{width:64px;height:64px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;font-size:28px;background:var(--accent-soft);color:var(--accent-ink);border:2px solid var(--accent-soft-2)}.badge-card.locked .badge-icon{background:var(--surface-3);color:var(--fg-4);border-color:var(--border)}.badge-card .b-name{font-size:13.5px;font-weight:650;letter-spacing:-.005em}.badge-card .b-sub{font-size:12px;color:var(--fg-3);margin-top:4px}.badge-card.locked{opacity:.55}.heatmap{display:grid;grid-template-columns:repeat(18,1fr);gap:4px;margin-top:14px;max-width:380px}.heat-cell{aspect-ratio:1;background:var(--surface-3);border-radius:3px;transition:transform .12s ease,outline-color .12s ease;outline:1px solid transparent}.heat-cell:hover{transform:scale(1.18);outline-color:var(--border)}.heat-cell.l1{background:#cbeee0}.heat-cell.l2{background:#82c8b0}.heat-cell.l3{background:#37a585}.heat-cell.l4{background:#00755a;background:oklch(.5 .13 170)}.heat-legend{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--fg-3);margin-top:12px;justify-content:flex-start}.heat-legend .sq{width:11px;height:11px;border-radius:3px}.results-shell{max-width:760px;margin:0 auto;padding:60px 24px;text-align:center}.results-icon{width:88px;height:88px;border-radius:50%;background:var(--success-soft);color:var(--success);display:grid;place-items:center;margin:0 auto 24px}.results-icon.fail{background:var(--danger-soft);color:var(--danger)}.score-big{font-size:56px;font-weight:700;letter-spacing:-.03em;line-height:1;margin:8px 0}.results-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:36px 0;text-align:left}.results-stat{padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.results-stat .label{font-size:12px;color:var(--fg-3);font-weight:500}.results-stat .value{font-size:22px;font-weight:700;letter-spacing:-.015em;margin-top:6px}.quiz-review{text-align:left;margin:8px 0 28px}.quiz-review-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.quiz-review-head .h4{margin:0}.review-item{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:16px;margin-bottom:12px}.review-q{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.5;margin-bottom:12px}.review-mark{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:grid;place-items:center}.review-mark.correct{background:var(--success-soft);color:var(--success)}.review-mark.incorrect{background:var(--danger-soft);color:var(--danger)}.review-opts{display:flex;flex-direction:column;gap:6px}.review-opt{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm, 8px);font-size:13px}.review-opt.correct{border-color:var(--success);background:var(--success-soft)}.review-opt.incorrect{border-color:var(--danger);background:var(--danger-soft)}.review-opt .key{width:22px;height:22px;flex-shrink:0;display:grid;place-items:center;border-radius:6px;background:var(--bg-2, var(--surface));font-size:12px;font-weight:600}.review-opt .tag{margin-left:auto;font-size:11px;font-weight:600;color:var(--fg-3);white-space:nowrap}.review-opt .tag.ok{color:var(--success)}.review-exp{margin-top:10px;padding:10px 12px;background:var(--bg-2, var(--accent-soft));border-radius:var(--radius-sm, 8px);font-size:13px;color:var(--fg-2);line-height:1.5}.row{display:flex;align-items:center;gap:12px}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.gap-2{gap:8px}.gap-3{gap:12px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mt-5{margin-top:32px}.mb-3{margin-bottom:16px}.full-bleed{margin-left:-40px;margin-right:-40px}.projects-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;margin-bottom:14px;text-align:left;width:100%;display:block;transition:all .15s}.project-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.project-card .head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}.project-card .marker{width:44px;height:44px;border-radius:10px;display:grid;place-items:center;font-size:18px;flex-shrink:0;background:var(--accent-soft);color:var(--accent-ink);border:1px solid var(--accent-soft-2)}.project-card .marker.m-gold{background:var(--gold-soft);color:var(--gold-ink);border-color:#f3dab2}.project-card .marker.m-info{background:var(--info-soft);color:var(--info);border-color:#bde5f9}.project-card .marker.m-rose{background:#ffedec;background:oklch(.96 .04 20);color:#ac3031;border-color:#ffd1d0;border-color:oklch(.9 .06 20)}.project-card .title{font-size:16px;font-weight:650;letter-spacing:-.01em;margin-bottom:4px}.project-card .sub{font-size:12.5px;color:var(--fg-3)}.project-card .right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:6px}.objectives{margin:14px 0 0;padding:14px 0 0;border-top:1px solid var(--border)}.objectives .label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);font-weight:700;margin-bottom:10px}.obj-list{display:flex;flex-direction:column;gap:8px;margin:0;padding:0;list-style:none}.obj-list li{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--fg-2);line-height:1.5}.obj-check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);background:var(--surface);display:grid;place-items:center;color:transparent;margin-top:2px}.obj-check.done{background:var(--accent);border-color:var(--accent);color:#fff}.obj-list li.done{color:var(--fg-3);text-decoration:line-through;text-decoration-color:var(--fg-4)}.project-foot{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--border);font-size:12.5px;color:var(--fg-3)}.project-foot .group{display:flex;align-items:center;gap:8px}.project-foot strong{color:var(--fg);font-weight:650}.avatar-stack{display:flex;align-items:center}.avatar-stack>*{margin-left:-6px;border:2px solid var(--surface)}.avatar-stack>*:first-child{margin-left:0}.avatar-stack .more{width:22px;height:22px;border-radius:50%;background:var(--surface-3);color:var(--fg-3);font-size:10.5px;font-weight:700;display:grid;place-items:center}.deadline-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}.deadline-card .date-block{width:46px;text-align:center;flex-shrink:0;padding:4px 0;border-radius:8px;background:var(--surface-2);border:1px solid var(--border)}.deadline-card .date-block.urgent{background:#ffece9;background:oklch(.96 .05 25);border-color:#ffd1cd;border-color:oklch(.9 .07 25);color:var(--danger)}.deadline-card .date-block .m{font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);font-weight:700;line-height:1.1}.deadline-card .date-block.urgent .m{color:var(--danger)}.deadline-card .date-block .d{font-size:16px;font-weight:700;letter-spacing:-.01em;line-height:1.1;color:var(--fg)}.deadline-card .date-block.urgent .d{color:var(--danger)}.deadline-card .body{flex:1;min-width:0}.deadline-card .title{font-size:13px;font-weight:650;letter-spacing:-.005em}.deadline-card .sub{font-size:11.5px;color:var(--fg-3);margin-top:2px}.internship-hero{display:grid;grid-template-columns:1fr auto;gap:24px;padding:24px 28px;border-radius:var(--radius-lg);background:radial-gradient(circle at 100% 0%,oklch(.95 .06 175 / .6),transparent 50%),linear-gradient(180deg,var(--surface),var(--surface));border:1px solid var(--border);margin-bottom:24px}.internship-hero .role{font-size:13px;color:var(--fg-3);font-weight:600;margin-bottom:6px}.internship-hero h1{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0 0 4px}.internship-hero .company{font-size:14px;color:var(--fg-2);margin-bottom:18px}.internship-hero .meta-grid{display:grid;grid-template-columns:repeat(4,auto);gap:28px;margin-top:4px}.internship-hero .meta-grid .label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--fg-4);margin-bottom:4px}.internship-hero .meta-grid .val{font-size:14px;font-weight:650;letter-spacing:-.005em}.intern-progress{width:220px;display:flex;flex-direction:column;justify-content:center;gap:8px}.intern-progress .pct-big{font-size:36px;font-weight:700;letter-spacing:-.025em;line-height:1}.intern-progress .progress{height:6px}.doc-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.doc-row{display:grid;grid-template-columns:36px 1fr 130px 110px 100px;gap:14px;align-items:center;padding:14px 18px;border-top:1px solid var(--border);font-size:13.5px;text-align:left;width:100%}.doc-row:first-of-type{border-top:0}.doc-row.head{background:var(--surface-2);font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);font-weight:700;padding:10px 18px}.doc-row .doc-ico{width:36px;height:36px;border-radius:8px;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center}.doc-row.head .doc-ico{background:transparent}.doc-row .doc-name{font-weight:650}.doc-row .doc-sub{font-size:12px;color:var(--fg-3);margin-top:2px;font-weight:500}.due-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--fg-2);font-variant-numeric:tabular-nums}.due-pill.urgent{color:var(--danger)}.due-pill.done{color:var(--fg-4)}.report-card{display:grid;grid-template-columns:56px 1fr auto;gap:16px;align-items:center;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;text-align:left;width:100%}.report-card:hover{border-color:var(--border-strong)}.report-card .week{font-family:var(--font-mono);text-align:center}.report-card .week .label{font-size:9.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-3);font-weight:700}.report-card .week .num{font-size:22px;font-weight:700;letter-spacing:-.02em}.report-card .body{min-width:0}.report-card .title{font-size:14px;font-weight:650;letter-spacing:-.005em}.report-card .sub{font-size:12px;color:var(--fg-3);margin-top:2px}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 10px;text-align:center;min-height:110px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.day-card.office{background:var(--accent-soft);border-color:var(--accent-soft-2);color:var(--accent-ink)}.day-card.office .name,.day-card.office .num{color:var(--accent-ink)}.day-card.remote .name,.day-card.remote .num{color:var(--fg-2)}.day-card.off{background:var(--surface-2);color:var(--fg-4)}.day-card.off .name,.day-card.off .num{color:var(--fg-4)}.day-card.today{outline:2px solid var(--fg);outline-offset:-2px}.day-card .name{font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--fg-3)}.day-card .num{font-size:22px;font-weight:700;letter-spacing:-.02em;line-height:1}.day-card .tag{margin-top:auto;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:6px;background:#fff9}.day-card.remote .tag{background:var(--surface-3);color:var(--fg-2)}.day-card.off .tag{background:transparent;color:var(--fg-4)}.day-card .event{font-size:11px;color:inherit;opacity:.85;font-weight:500}.mentor-card{display:grid;grid-template-columns:48px 1fr auto;gap:14px;align-items:center;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.mentor-card .avatar{width:48px;height:48px;font-size:16px}.timeline{position:relative;padding-left:22px}.timeline:before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--border)}.tl-item{position:relative;padding:0 0 18px;font-size:13px}.tl-item:last-child{padding-bottom:0}.tl-item .dot{position:absolute;left:-22px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--surface);border:2px solid var(--border-strong)}.tl-item.done .dot{background:var(--accent);border-color:var(--accent)}.tl-item.current .dot{background:var(--gold);border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-soft)}.tl-item .date{font-size:11.5px;color:var(--fg-3);font-weight:600;font-variant-numeric:tabular-nums}.tl-item .title{font-size:13.5px;font-weight:650;margin-top:2px}.tl-item .sub{font-size:12.5px;color:var(--fg-3);margin-top:2px}.tl-item.done .title{color:var(--fg-3)}.drop{border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:22px;text-align:center;background:var(--surface-2);color:var(--fg-3);font-size:13px;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .15s;cursor:pointer}.drop:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-ink)}.drop strong{font-weight:650;color:var(--fg)}.drop:hover strong{color:var(--accent-ink)}.portal-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:2px 7px;border-radius:4px;background:var(--accent-soft);color:var(--accent-ink);border:1px solid var(--accent-soft-2);margin-left:6px}.portal-pill.admin{background:#e7effc;color:#203351;border-color:#d0d8e5}.role-switch{margin-top:10px;width:100%;display:flex;background:var(--surface-2);padding:3px;border-radius:8px;border:1px solid var(--border);font-size:12px;font-weight:600}.role-switch button{flex:1;padding:6px 0;border-radius:6px;color:var(--fg-3);display:inline-flex;align-items:center;justify-content:center;gap:6px}.role-switch button.active{background:var(--surface);color:var(--fg);box-shadow:var(--shadow-sm)}.admin-badge{font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;padding:2px 6px;border-radius:4px;background:#dbe5f6;color:#203351;font-weight:700;margin-left:8px;vertical-align:middle}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12.5px;font-weight:600;color:var(--fg-2)}.field-help{font-size:11.5px;color:var(--fg-3)}.input,.textarea,.select{width:100%;height:36px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);padding:0 12px;font-size:13.5px;color:var(--fg);outline:none;transition:border .12s,box-shadow .12s;font-family:inherit}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.textarea{height:auto;padding:10px 12px;resize:vertical;min-height:90px;line-height:1.5}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2370768a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row.three{grid-template-columns:repeat(3,1fr)}.toggle{position:relative;width:38px;height:22px;border-radius:999px;background:var(--surface-3);transition:background .15s;flex-shrink:0;cursor:pointer;border:none}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:left .15s}.toggle.on{background:var(--accent)}.toggle.on:after{left:18px}.toggle-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.toggle-row .body{flex:1}.toggle-row .name{font-size:13.5px;font-weight:650}.toggle-row .desc{font-size:12px;color:var(--fg-3);margin-top:2px}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table{width:100%;border-collapse:collapse;font-size:13.5px}.table thead{background:var(--surface-2)}.table th{font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);font-weight:700;padding:11px 16px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.table th.right{text-align:right}.table th.center{text-align:center}.table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--fg-2)}.table td.right{text-align:right;font-variant-numeric:tabular-nums}.table td.center{text-align:center}.table tr:last-child td{border-bottom:0}.table tbody tr:hover{background:var(--surface-2)}.cell-strong{font-weight:650;color:var(--fg)}.cell-sub{font-size:12px;color:var(--fg-3);margin-top:2px}.row-actions{display:inline-flex;gap:4px;opacity:0;transition:opacity .15s}.table tbody tr:hover .row-actions{opacity:1}.ico-action{width:28px;height:28px;border-radius:6px;display:grid;place-items:center;color:var(--fg-3)}.ico-action:hover{background:var(--surface-3);color:var(--fg)}.ico-action.danger:hover{background:var(--danger-soft);color:var(--danger)}.table-toolbar{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--surface)}.table-toolbar .input{height:32px;font-size:13px;max-width:260px}.checkbox{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border-strong);background:var(--surface);display:inline-grid;place-items:center;color:#fff;flex-shrink:0}.checkbox.on{background:var(--accent);border-color:var(--accent)}.admin-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}.kpi{padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);position:relative}.kpi .label{font-size:12px;color:var(--fg-3);font-weight:600;display:flex;align-items:center;gap:8px}.kpi .value{font-size:32px;font-weight:700;letter-spacing:-.025em;margin-top:8px;line-height:1.05;font-variant-numeric:tabular-nums}.kpi .delta{font-size:12px;margin-top:6px;color:var(--success);font-weight:600}.kpi .delta.down{color:var(--danger)}.sparkline{position:absolute;inset:auto 14px 14px auto;width:80px;height:28px;opacity:.7}.editor-grid{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden}.section-card .head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.section-card .head .title{font-size:14px;font-weight:650;letter-spacing:-.005em}.section-card .head .sub{font-size:12px;color:var(--fg-3);margin-top:2px}.section-card .body{padding:18px}.builder-list{display:flex;flex-direction:column;gap:6px}.builder-item{display:grid;grid-template-columns:18px 28px 1fr auto auto;gap:10px;align-items:center;padding:8px 10px 8px 8px;border-radius:7px;border:1px solid var(--border);background:var(--surface)}.builder-item:hover{background:var(--surface-2)}.builder-item .handle{color:var(--fg-4);cursor:grab;display:grid;place-items:center}.builder-item .ord{font-family:var(--font-mono);font-size:11.5px;font-weight:600;color:var(--fg-3);text-align:center}.builder-item .name{font-size:13px;font-weight:600}.builder-item .meta{font-size:11.5px;color:var(--fg-3)}.add-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1.5px dashed var(--border-strong);border-radius:8px;color:var(--fg-3);font-size:13px;font-weight:600;width:100%;margin-top:6px;transition:all .12s}.add-row:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.q-builder-opt{display:grid;grid-template-columns:28px 1fr 32px;gap:10px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:7px;background:var(--surface);margin-bottom:6px}.q-builder-opt.correct{border-color:var(--success);background:var(--success-soft)}.q-builder-opt .input{border:0;background:transparent;height:28px;line-height:28px;padding:0;font-size:13px}.q-builder-opt .input:focus{box-shadow:none}.q-builder-opt .radio{width:22px;height:22px;border-radius:50%;border:2px solid var(--border-strong);background:var(--surface);display:grid;place-items:center;cursor:pointer}.q-builder-opt.correct .radio{background:var(--success);border-color:var(--success);color:#fff}.qb-shell{display:grid;grid-template-columns:264px minmax(0,1fr) 300px;gap:16px;align-items:start}@media(max-width:1100px){.qb-shell{grid-template-columns:1fr}.qb-pane.sticky{position:static}}.qb-pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.qb-pane.sticky{position:sticky;top:16px}.qb-pane-title{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-3);margin-bottom:12px}.qb-qlist{display:flex;flex-direction:column;gap:6px}.qb-qitem{display:grid;grid-template-columns:20px 1fr 16px;gap:9px;align-items:start;width:100%;padding:9px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:pointer;text-align:left;transition:background .12s,border-color .12s}.qb-qitem:hover{background:var(--surface-2)}.qb-qitem.active{border-color:var(--success);background:var(--success-soft)}.qb-qitem .num{font-size:12px;font-weight:700;color:var(--fg-3);line-height:1.4}.qb-qitem.active .num{color:var(--success)}.qb-qitem .qtext{font-size:12.5px;color:var(--fg-2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.qb-qitem .qtext.empty{color:var(--fg-4);font-style:italic}.qb-qitem .del{display:grid;place-items:center;color:var(--fg-4);opacity:0;transition:opacity .12s}.qb-qitem:hover .del,.qb-qitem.active .del{opacity:1}.qb-qitem .del:hover{color:var(--danger, #dc2626)}.qb-setting{margin-bottom:14px}.qb-toggle-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-top:1px solid var(--border)}.qb-toggle-line .lbl{font-size:13px;font-weight:600;color:var(--fg-2)}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.asset-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-align:left;transition:all .15s}.asset-tile:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.asset-thumb{aspect-ratio:4 / 3;background:var(--surface-2);display:grid;place-items:center;color:var(--fg-3);position:relative;border-bottom:1px solid var(--border)}.asset-thumb.video{background:linear-gradient(135deg,#1c222b,#0c121a);color:#caced4}.asset-thumb.pdf{background:#ffedeb;background:oklch(.96 .04 25);color:#ac3031}.asset-thumb.img{background:linear-gradient(135deg,#b1e5d1,#5dcbd1)}.asset-thumb.zip{background:#fff0d7;background:oklch(.96 .04 80);color:#925000;color:oklch(.5 .13 60)}.asset-thumb .ext{position:absolute;bottom:8px;left:8px;font-family:var(--font-mono);font-size:10.5px;font-weight:700;padding:2px 6px;border-radius:4px;background:#00000073;color:#fff;letter-spacing:.05em;text-transform:uppercase}.asset-meta{padding:10px 12px}.asset-meta .name{font-size:13px;font-weight:650;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-meta .sub{font-size:11.5px;color:var(--fg-3);margin-top:2px}.reports-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:22px;flex-wrap:wrap}.reports-toolbar .student-picker{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:13px}.reports-toolbar .student-picker .avatar{width:26px;height:26px}.report-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.report-layout{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start}.report-picker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;position:sticky;top:12px}.report-picker-list{display:flex;flex-direction:column;gap:2px;max-height:calc(100vh - 200px);overflow-y:auto}.report-picker-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:1px solid transparent;border-radius:var(--radius-sm);background:none;cursor:pointer;text-align:left;color:inherit}.report-picker-item:hover{background:var(--surface-2)}.report-picker-item.active{background:var(--accent-soft);border-color:var(--accent)}.report-picker-meta{display:flex;flex-direction:column;line-height:1.3;min-width:0}.report-picker-meta .cell-strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-row{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden}.report-row-head{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;background:var(--surface-2);border:none;cursor:pointer;text-align:left;color:inherit}.report-row-head:hover{background:var(--surface-3)}.report-row-title{display:flex;flex-direction:column;line-height:1.3;flex:1;min-width:0}.report-row-stats{display:flex;flex-direction:column;align-items:flex-end;font-size:12.5px;white-space:nowrap}.report-subtable{margin:0}.report-subtable thead th{background:var(--surface)}@media(max-width:860px){.report-layout{grid-template-columns:1fr}.report-picker{position:static}}.widget{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;position:relative}.widget-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.widget-head .title{font-size:13.5px;font-weight:650;letter-spacing:-.005em;display:flex;align-items:center;gap:8px}.widget-head .title .ico{width:22px;height:22px;border-radius:6px;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center}.widget-head .actions{display:flex;gap:4px;color:var(--fg-4)}.widget .big-num{font-size:38px;font-weight:700;letter-spacing:-.025em;line-height:1.05}.widget .big-sub{font-size:12.5px;color:var(--fg-3);margin-top:4px}.w-3{grid-column:span 3}.w-4{grid-column:span 4}.w-5{grid-column:span 5}.w-6{grid-column:span 6}.w-7{grid-column:span 7}.w-8{grid-column:span 8}.w-9{grid-column:span 9}.w-12{grid-column:span 12}.gauge{position:relative;width:100%;aspect-ratio:2 / 1}.skill-bar-row{display:grid;grid-template-columns:1fr 80px;gap:14px;align-items:center;margin-bottom:12px;font-size:13px}.skill-bar-row:last-child{margin-bottom:0}.skill-bar-row .name{font-weight:600}.skill-bar-row .meta{font-size:11.5px;color:var(--fg-3);margin-top:2px}.skill-bar{height:6px;background:var(--surface-3);border-radius:999px;overflow:hidden}.skill-bar>span{display:block;height:100%;border-radius:999px}.skill-bar>.me{background:var(--accent)}.skill-bar>.peer{position:absolute;height:14px;width:2px;background:var(--fg-2);top:-4px;border-radius:1px}.skill-bar-wrap{position:relative;margin-top:8px}.skill-val{text-align:right;font-variant-numeric:tabular-nums;font-weight:700;font-size:13px}.tag-list{display:flex;flex-direction:column;gap:8px}.tag-row{display:grid;grid-template-columns:24px 1fr auto;gap:10px;align-items:center;padding:8px 10px;border-radius:7px;background:var(--surface-2);font-size:13px}.tag-row.up{background:var(--success-soft)}.tag-row.down{background:var(--danger-soft)}.tag-row .arr{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:var(--surface);color:var(--fg-3)}.tag-row.up .arr{background:var(--success);color:#fff}.tag-row.down .arr{background:var(--danger);color:#fff}.tag-row .num{font-weight:700;font-variant-numeric:tabular-nums;font-size:12.5px}.tag-row.up .num{color:var(--success)}.tag-row.down .num{color:var(--danger)}.mini-bars{display:flex;align-items:end;gap:4px;height:56px;margin-top:12px}.mini-bars .b{flex:1;background:var(--surface-3);border-radius:3px 3px 1px 1px;min-height:4px}.mini-bars .b.acc{background:var(--accent)}.matrix{display:grid;grid-template-columns:80px repeat(7,1fr);gap:4px;margin-top:12px}.matrix .lbl{font-size:11px;color:var(--fg-3);font-weight:600;display:flex;align-items:center}.matrix .cell{aspect-ratio:2 / 1;border-radius:4px;background:var(--surface-3);display:grid;place-items:center;font-size:10.5px;color:#00000073;font-weight:600}.matrix .cell.l1{background:#cff1e4}.matrix .cell.l2{background:#92d9bf;color:#fff}.matrix .cell.l3{background:#24a684;color:#fff}.matrix .cell.l4{background:#00755a;background:oklch(.5 .13 170);color:#fff}.insight{display:grid;grid-template-columns:32px 1fr;gap:12px;padding:12px;border-radius:8px;background:var(--surface-2);margin-bottom:8px}.insight .ico{width:32px;height:32px;border-radius:8px;background:var(--accent-soft);color:var(--accent-ink);display:grid;place-items:center;flex-shrink:0}.insight.gold .ico{background:var(--gold-soft);color:var(--gold-ink)}.insight.danger .ico{background:var(--danger-soft);color:var(--danger)}.insight.info .ico{background:var(--info-soft);color:var(--info)}.insight .name{font-size:13px;font-weight:650;letter-spacing:-.005em}.insight .body{font-size:12.5px;color:var(--fg-3);line-height:1.5;margin-top:2px}.legend-row{display:flex;align-items:center;gap:14px;font-size:11.5px;color:var(--fg-3);margin-top:10px}.legend-row .sw{display:inline-block;width:10px;height:10px;border-radius:2px}.add-widget{border:1.5px dashed var(--border-strong);background:var(--surface);border-radius:var(--radius);display:grid;place-items:center;font-size:13px;font-weight:600;color:var(--fg-3);min-height:180px;transition:all .15s}.add-widget:hover{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e121773;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;display:grid;place-items:center;padding:40px 20px}.modal{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:540px;max-height:calc(100vh - 80px);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.modal .head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal .head .title{font-size:16px;font-weight:650;letter-spacing:-.01em}.modal .body{padding:22px;overflow-y:auto;min-height:0;flex:1 1 auto;display:flex;flex-direction:column;gap:14px}.modal .foot{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--surface-2)}.lb-podium{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:14px;align-items:end;margin-bottom:28px}.podium-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 18px 18px;text-align:center;position:relative;overflow:hidden}.podium-card.gold{background:linear-gradient(180deg,oklch(.97 .04 80),var(--surface) 65%);border-color:#f4d29b}.podium-card.silver{background:linear-gradient(180deg,oklch(.96 .01 260),var(--surface) 65%);border-color:#d3d8e0}.podium-card.bronze{background:linear-gradient(180deg,oklch(.95 .05 40),var(--surface) 65%);border-color:#ffcab7;border-color:oklch(.88 .08 40)}.podium-card .rank{font-size:38px;font-weight:800;letter-spacing:-.03em;line-height:1}.podium-card.gold .rank{color:#8a5600;color:oklch(.5 .13 70)}.podium-card.silver .rank{color:#44484e}.podium-card.bronze .rank{color:#983e1b}.podium-card .crown{position:absolute;top:12px;right:14px;font-size:22px}.podium-card .avatar-md{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#ed7665,#ca488f);display:grid;place-items:center;color:#fff;font-weight:700;font-size:22px;margin:12px auto 10px}.podium-card .who{font-size:15px;font-weight:650;letter-spacing:-.005em}.podium-card .meta{font-size:12px;color:var(--fg-3);margin-top:2px}.podium-card .pts{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:13px;font-weight:700;margin-top:12px;font-variant-numeric:tabular-nums}.lb-row{display:grid;grid-template-columns:48px minmax(0,1fr) 64px 86px 92px;gap:10px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);font-size:13.5px;transition:background .12s}.lb-row:last-child{border-bottom:0}.lb-row:hover{background:var(--surface-2)}.lb-row.you{background:var(--accent-soft);position:sticky;bottom:0;z-index:1;border-top:1px solid var(--accent-soft-2)}.lb-row.you:hover{background:var(--accent-soft)}.lb-rank{font-family:var(--font-mono);font-size:15px;font-weight:700;color:var(--fg-2);text-align:center;font-variant-numeric:tabular-nums}.lb-rank.top{color:#8a5600;color:oklch(.5 .13 70)}.lb-delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}.lb-delta.up{color:var(--success)}.lb-delta.down{color:var(--danger)}.lb-delta.flat{color:var(--fg-4)}.lb-pts{text-align:right;font-weight:700;font-variant-numeric:tabular-nums;font-size:15px;letter-spacing:-.01em}.lb-pts .unit{font-size:11px;color:var(--fg-3);font-weight:600;margin-left:3px}.lb-spark{width:100%;max-width:80px;height:24px}.disc-layout{display:grid;grid-template-columns:188px minmax(0,1fr);gap:18px;align-items:start}.disc-rail{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:18px}.disc-rail>*{margin-top:0!important}.disc-cat{display:flex;flex-direction:column;gap:2px}.disc-cat .label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);font-weight:700;padding:4px 10px 10px}.disc-cat-item{display:grid;grid-template-columns:16px 1fr auto;gap:10px;align-items:center;padding:8px 12px;border-radius:7px;font-size:13px;font-weight:500;color:var(--fg-2);text-align:left;width:100%}.disc-cat-item:hover{background:var(--surface-2);color:var(--fg)}.disc-cat-item.active{background:var(--accent-soft);color:var(--accent-ink)}.disc-cat-item .dot{width:8px;height:8px;border-radius:50%}.disc-cat-item .count{font-size:11px;color:var(--fg-4);font-variant-numeric:tabular-nums}.disc-cat-item.active .count{color:var(--accent-ink)}.thread{display:grid;grid-template-columns:36px minmax(0,1fr) 60px;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--surface);transition:background .1s;text-align:left}.thread:hover{background:var(--surface-2)}.thread:last-child{border-bottom:0}.thread .avatar{width:36px;height:36px;font-size:12px}.thread .title{font-size:14px;font-weight:650;letter-spacing:-.005em;line-height:1.3;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.thread.unread .title:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;flex-shrink:0}.thread .preview{font-size:12.5px;color:var(--fg-3);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.thread .meta{font-size:11.5px;color:var(--fg-3);margin-top:6px;display:flex;align-items:center;gap:8px}.thread .meta strong{color:var(--fg-2);font-weight:650}.thread .replies{text-align:right;font-size:12px;color:var(--fg-3)}.thread .replies .num{font-size:17px;font-weight:700;color:var(--fg);font-variant-numeric:tabular-nums;line-height:1.1}.thread .replies .lbl{font-size:11px;color:var(--fg-4)}.thread .when{text-align:right;font-size:11.5px;color:var(--fg-3)}.thread .pill-tags{display:inline-flex;gap:4px;flex-wrap:wrap}.disc-side-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.contributor-row{display:grid;grid-template-columns:26px 1fr auto;gap:10px;align-items:center;padding:7px 0;border-bottom:1px dashed var(--border)}.contributor-row:last-child{border-bottom:0}.contributor-row .name{font-size:13px;font-weight:600}.contributor-row .meta{font-size:11.5px;color:var(--fg-3)}.contributor-row .score{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--accent-ink)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{width:100%;max-width:400px;padding:40px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.login-card .brand{display:flex;flex-direction:column;align-items:center;gap:12px;justify-content:center;margin-bottom:32px}.login-card .brand-logo{width:auto;height:64px;object-fit:contain}.login-card .brand-name{font-size:22px;font-weight:700;letter-spacing:-.02em}.login-card h1{font-size:20px;font-weight:700;text-align:center;margin-bottom:8px}.login-card .sub{text-align:center;color:var(--fg-3);font-size:13.5px;margin-bottom:24px}.login-card .field{margin-bottom:16px}.login-card .error{color:var(--danger);font-size:13px;margin-bottom:12px;text-align:center}.login-card .demo-accounts{margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}.login-card .demo-accounts h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);margin-bottom:12px}.demo-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;margin-bottom:8px;transition:border-color .15s;text-align:left}.demo-btn:hover{border-color:var(--accent)}.demo-btn .avatar{width:32px;height:32px;font-size:11px}.demo-btn .name{font-size:13px;font-weight:600}.demo-btn .role{font-size:11.5px;color:var(--fg-3)}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);margin-top:4px;z-index:100;max-height:400px;overflow-y:auto}.search-section-label{padding:8px 12px;font-size:11px;font-weight:700;color:var(--fg-3);text-transform:uppercase;letter-spacing:.05em}.search-result{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;text-align:left;font-size:13px;color:var(--fg)}.search-result:hover{background:var(--surface-2)}.hamburger{display:none}@media(max-width:1024px){.app{grid-template-columns:220px 1fr}.sidebar{width:220px}.course-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:-280px;top:0;bottom:0;width:260px;z-index:200;transition:left .25s ease;box-shadow:var(--shadow-lg)}.sidebar.open{left:0}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}.sidebar-overlay.show{display:block}.hamburger{display:flex!important}.course-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid,.projects-layout,.disc-layout{grid-template-columns:1fr}.disc-cat,.disc-rail{display:none}.coding-layout,.coding-page-body .coding-layout{display:flex;flex-direction:column;height:auto}.pane-divider{display:none}.problem-pane{max-height:50vh;overflow-y:auto;border-right:none;border-bottom:1px solid var(--border)}.editor-pane{min-height:70vh;flex-direction:column}.coding-ai-rail,.coding-ai-rail.collapsed{flex-basis:auto;border-left:0;border-top:1px solid var(--code-border)}.lesson-layout{grid-template-columns:1fr}.course-hero{flex-direction:column}.enroll-card{width:100%}.lb-podium{gap:8px}.podium-card{padding:16px 12px}.week-grid{grid-template-columns:repeat(4,1fr)}.intern-progress{width:100%;text-align:center}.internship-hero{flex-direction:column}.modal{width:95vw;max-width:95vw;margin:16px}.topbar{padding:8px 12px}.search input{width:100%;min-width:0}.page,.page-wide{padding:16px}.page-head{flex-direction:column;gap:8px}}@media(max-width:480px){.stat-grid{grid-template-columns:1fr}.week-grid{grid-template-columns:repeat(3,1fr)}.lb-podium{flex-direction:column}.filter-bar{flex-wrap:wrap}.topbar-actions .btn{display:none}.results-stats{flex-wrap:wrap}.course-body .title{font-size:14px}}.ai-tag{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-3)}.ai-tag svg{color:var(--accent)}.ai-tutor-panel{display:flex;flex-direction:column;flex:1;min-height:0}.ai-msg-list{flex:1;overflow-y:auto;padding:2px 2px 12px;display:flex;flex-direction:column;gap:12px}.ai-msg{max-width:88%;font-size:13.5px;line-height:1.55}.ai-msg.user{align-self:flex-end;background:var(--accent-soft);color:var(--fg);padding:9px 13px;border-radius:14px 14px 4px}.ai-msg.assistant{align-self:flex-start;background:var(--surface-2);border:1px solid var(--border);color:var(--fg);padding:10px 13px;border-radius:14px 14px 14px 4px}.ai-msg-text{white-space:pre-wrap}.ai-input-row{display:flex;align-items:flex-end;gap:8px;padding:12px 0 0;border-top:1px solid var(--border);margin-top:4px}.ai-input{flex:1;resize:none;overflow-y:hidden;border:1px solid var(--border);border-radius:10px;padding:9px 11px;font:inherit;font-size:13.5px;line-height:1.45;background:var(--bg);color:var(--fg)}.ai-input:focus{outline:none;border-color:var(--accent)}.ai-tutor-bar{display:flex;align-items:center;gap:6px;padding:0 0 10px;margin-bottom:4px;border-bottom:1px solid var(--border)}.ai-tutor-iconbtn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;color:var(--fg-3);border:1px solid transparent}.ai-tutor-iconbtn:hover{color:var(--fg);background:var(--surface-2);border-color:var(--border)}.ai-tutor-history{position:relative}.ai-tutor-hist-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40}.ai-tutor-hist-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:41;width:260px;max-height:320px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow, 0 8px 24px rgba(0, 0, 0, .18));padding:6px}.ai-tutor-hist-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-3);padding:6px 8px 8px}.ai-tutor-hist-empty{font-size:13px;color:var(--fg-3);padding:6px 8px 10px}.ai-tutor-hist-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:8px 9px;border-radius:7px;font-size:13px;color:var(--fg)}.ai-tutor-hist-item svg{color:var(--accent);flex:none}.ai-tutor-hist-item:hover{background:var(--surface-2)}.ai-tutor-hist-item.active{background:var(--accent-soft)}.ai-tutor-hist-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-output{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:13px;line-height:1.55;color:var(--fg)}.ai-help-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.ai-typing{display:inline-flex;gap:4px;padding:4px 0}.ai-typing span{width:6px;height:6px;border-radius:50%;background:var(--fg-3);animation:aiBlink 1.2s infinite ease-in-out both}.ai-typing span:nth-child(2){animation-delay:.18s}.ai-typing span:nth-child(3){animation-delay:.36s}@keyframes aiBlink{0%,80%,to{opacity:.2}40%{opacity:1}}.ai-markdown>*:first-child{margin-top:0}.ai-markdown>*:last-child{margin-bottom:0}.ai-markdown p{margin:0 0 8px}.ai-markdown h3,.ai-markdown h4,.ai-markdown h5,.ai-markdown h6{margin:12px 0 6px;font-size:14px;font-weight:700}.ai-markdown ul,.ai-markdown ol{margin:4px 0 10px;padding-left:20px}.ai-markdown li{margin:3px 0}.ai-markdown code{font-family:var(--font-mono);font-size:.86em;background:var(--code-bg);color:var(--code-fg);padding:1px 5px;border-radius:5px}.ai-markdown pre.ai-code{background:var(--code-surface);border:1px solid var(--code-border);border-radius:var(--radius-sm);padding:11px 13px;overflow-x:auto;margin:8px 0}.ai-markdown pre.ai-code code{background:none;padding:0;color:var(--code-fg)}.btn-ai{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;background:var(--surface);color:var(--fg);border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-weight:600;font-size:12.5px;cursor:pointer;white-space:nowrap;transition:all .12s}.btn-ai svg{color:var(--accent)}.btn-ai:hover{background:var(--surface-2)}.btn-ai:disabled{opacity:.55;cursor:not-allowed}.ai-inline-trigger{display:inline-flex;align-items:center;gap:5px;background:none;border:none;padding:0;font-size:12px;font-weight:600;color:var(--accent);cursor:pointer;white-space:nowrap}.ai-inline-trigger svg{color:var(--accent)}.ai-inline-trigger:hover{text-decoration:underline}.ai-inline-trigger:disabled{opacity:.55;cursor:not-allowed;text-decoration:none}.run-summary .ai-inline-trigger{color:inherit}.run-summary .ai-inline-trigger svg{color:inherit}.sa-toolbar{position:fixed;z-index:80;display:inline-flex;align-items:center;gap:2px;padding:4px;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:calc(100vw - 16px);animation:sa-fade .12s ease-out}.sa-brand{display:inline-flex;align-items:center;padding:0 4px 0 6px;color:var(--accent)}.sa-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--fg);font:inherit;font-size:13px;font-weight:500;padding:6px 9px;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap}.sa-action:hover{background:var(--accent-soft);color:var(--accent-ink)}.sa-popover{position:fixed;z-index:80;width:340px;max-width:calc(100vw - 16px);max-height:min(360px,calc(100vh - 16px));display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;animation:sa-fade .12s ease-out}.sa-pop-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 10px 9px 12px;border-bottom:1px solid var(--border)}.sa-pop-title{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--fg)}.sa-pop-title svg{color:var(--accent)}.sa-pop-close{display:inline-flex;border:0;background:transparent;color:var(--fg-3);cursor:pointer;padding:2px;border-radius:var(--radius-sm)}.sa-pop-close:hover{background:var(--surface-2);color:var(--fg)}.sa-pop-body{padding:12px;overflow-y:auto;font-size:13.5px;line-height:1.55;color:var(--fg)}.sa-pop-note{font-size:13px;color:var(--fg-3)}.sa-pop-foot{padding:8px 12px;border-top:1px solid var(--border);background:var(--bg)}.sa-nudge{position:fixed;z-index:75;display:inline-flex;align-items:center;gap:8px;padding:6px 8px 6px 11px;background:var(--surface);border:1px solid var(--border-strong);border-radius:999px;box-shadow:var(--shadow);font-size:12.5px;color:var(--fg-2);animation:sa-fade-in .18s ease-out}.sa-nudge-go{display:inline-flex;align-items:center;gap:5px;border:0;background:transparent;color:var(--accent-ink);font:inherit;font-weight:600;cursor:pointer;padding:0}.sa-nudge-go svg{color:var(--accent)}.sa-nudge-dismiss{display:inline-flex;border:0;background:transparent;color:var(--fg-3);cursor:pointer;padding:2px;border-radius:999px}.sa-nudge-dismiss:hover{color:var(--fg)}@keyframes sa-fade{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:none}}@keyframes sa-fade-in{0%{opacity:0}to{opacity:1}}.coding-nudge{display:flex;align-items:center;gap:10px;padding:7px 12px;background:var(--accent-soft);border-top:1px solid var(--border);color:var(--accent-ink);font-size:12.5px;animation:sa-fade-in .18s ease-out}.coding-nudge-text{display:inline-flex;align-items:center;gap:6px}.coding-nudge-text svg{color:var(--accent)}.coding-nudge-go{margin-left:auto;border:1px solid var(--border-strong);background:var(--surface);color:var(--fg);font:inherit;font-weight:600;padding:3px 10px;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap}.coding-nudge-go:hover{background:var(--surface-2)}.coding-nudge-dismiss{display:inline-flex;border:0;background:transparent;color:var(--accent-ink);cursor:pointer;padding:2px;border-radius:var(--radius-sm);opacity:.7}.coding-nudge-dismiss:hover{opacity:1}.explain-mistake{margin-top:8px}.review-item .explain-mistake{margin-top:6px}.lesson-block.has-explain{position:relative}.block-explain{position:absolute;top:2px;right:2px;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--accent);cursor:pointer;opacity:0;box-shadow:var(--shadow-sm);transition:opacity .12s ease,background .12s ease}.lesson-block.has-explain:hover .block-explain,.block-explain:focus-visible{opacity:.9}.block-explain:hover{opacity:1;background:var(--accent-soft)}.pill{display:inline-flex;align-items:center;gap:4px}.slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.slot-card{display:flex;flex-direction:column;gap:12px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .15s,box-shadow .15s}.slot-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.slot-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.slot-topic{font-size:15px;font-weight:700;letter-spacing:-.01em;line-height:1.3}.slot-speaker{display:flex;align-items:center;gap:10px}.slot-speaker-avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-ink);font-size:13px;font-weight:700;flex-shrink:0}.slot-speaker-name{font-size:13px;font-weight:600}.slot-speaker-role{font-size:11px;color:var(--fg-3)}.slot-meta{display:flex;flex-wrap:wrap;gap:12px}.slot-meta-item{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--fg-3)}.slot-desc{font-size:13px;color:var(--fg-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.slot-capacity{display:grid;grid-template-columns:1fr 1fr;gap:8px}.slot-cap{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);font-size:11px;color:var(--fg-3)}.slot-cap svg{color:var(--fg-3)}.slot-cap strong{font-size:12px;color:var(--fg);font-weight:700}.slot-cap.offline{border-color:var(--accent-soft-2);background:var(--accent-soft);color:var(--accent-ink)}.slot-cap.offline svg,.slot-cap.offline strong{color:var(--accent-ink)}.slot-cap.offline.full{border-color:var(--warning-soft);background:var(--warning-soft);color:#7f4400;color:oklch(.45 .13 60)}.slot-cap.offline.full svg,.slot-cap.offline.full strong{color:#7f4400;color:oklch(.45 .13 60)}.slot-actions{display:flex;align-items:center;gap:8px;margin-top:auto}.btn.danger{color:var(--danger)}.slot-list{display:flex;flex-direction:column;gap:12px}.slot-cc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .15s,box-shadow .15s}.slot-cc:hover,.slot-cc.expanded{border-color:var(--border-strong);box-shadow:var(--shadow)}.slot-cc-trigger{display:block;width:100%;text-align:left;background:none;border:none;padding:0;cursor:pointer;font-family:inherit;color:inherit}.slot-cover{position:relative;height:78px;background:linear-gradient(135deg,#becdf6,#ca99d6);overflow:hidden}.slot-cover.c-2{background:linear-gradient(135deg,#9fdadd,#4fa8e1)}.slot-cover.c-3{background:linear-gradient(135deg,#ecd69b,#ef945f)}.slot-cover.c-4{background:linear-gradient(135deg,#a6dcbe,#69cab8 50%,#3ec1b4 75%,#1abcb2 87.5%,#01b9b1,#00b6af);background:linear-gradient(135deg,#a6dcbe,#69cab8 50%,#3ec1b4 75%,#1abcb2 87.5%,color(xyz 0.252 0.38 0.477),color(xyz 0.239 0.367 0.47))}.slot-cover.c-5{background:linear-gradient(135deg,#feb9b8,#de77ab)}.slot-cover.c-6{background:linear-gradient(135deg,#e3c0eb,#8e93f3)}.slot-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(135deg,transparent 0 49.5%,oklch(1 0 0 / .1) 49.5% 50.5%,transparent 50.5%);background-size:20px 20px}.slot-cover-icon{position:absolute;bottom:8px;left:12px;color:#ffffffd9;z-index:1}.slot-cover-badge{position:absolute;top:8px;right:8px;z-index:1}.slot-card-head{display:flex;align-items:center;gap:10px;padding:11px 13px}.slot-card-headings{flex:1;min-width:0}.slot-cc .slot-topic{font-size:14px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-cc .slot-speaker-name{margin-top:2px;color:var(--fg-3);font-weight:500}.slot-chev{color:var(--fg-3);flex-shrink:0;transition:transform .2s ease}.slot-cc.expanded .slot-chev{transform:rotate(180deg)}.slot-card-detail{display:flex;flex-direction:column;gap:12px;padding:4px 14px 16px}.slot-seats{display:flex;flex-direction:column;gap:8px;padding:12px 14px;border:1px solid var(--accent-soft-2);border-radius:10px;background:var(--accent-soft)}.slot-seats.full{border-color:var(--warning-soft);background:var(--warning-soft)}.slot-seats-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.slot-seats-label{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--accent-ink)}.slot-seats.full .slot-seats-label{color:#7f4400;color:oklch(.45 .13 60)}.slot-seats-count{font-size:13px;color:var(--accent-ink)}.slot-seats-count strong{font-size:18px;font-weight:800}.slot-seats.full .slot-seats-count{color:#7f4400;color:oklch(.45 .13 60)}.slot-seats-bar{height:7px;border-radius:999px;overflow:hidden;background:#ffffff8c}.slot-seats-bar span{display:block;height:100%;border-radius:999px;background:var(--accent);transition:width .3s ease}.slot-seats.full .slot-seats-bar span{background:#bb6800;background:oklch(.6 .16 60)}.slot-seats-sub{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:500;color:var(--accent-ink)}.slot-seats.full .slot-seats-sub{color:#7f4400;color:oklch(.45 .13 60)}.slot-admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.slot-admin-stats>div{text-align:center}.slot-admin-stats strong{display:block;font-size:17px;font-weight:700}.slot-admin-stats span{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--fg-3)}.slot-admin-stats .warn strong{color:#a75c00;color:oklch(.55 .15 60)}.mode-option{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 14px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .15s,background .15s;font-family:inherit}.mode-option:hover{border-color:var(--border-strong)}.mode-option.selected{border-color:var(--accent);background:var(--accent-soft)}.mode-option-icon{width:38px;height:38px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;background:var(--surface-2);color:var(--fg-2)}.mode-option.selected .mode-option-icon{background:var(--surface);color:var(--accent-ink)}.mode-option-body{flex:1;min-width:0}.mode-option-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}.mode-option-sub{font-size:12px;color:var(--fg-3);margin-top:3px;line-height:1.4}.mode-radio{width:18px;height:18px;border-radius:50%;flex-shrink:0;border:2px solid var(--border-strong);position:relative}.mode-option.selected .mode-radio{border-color:var(--accent)}.mode-option.selected .mode-radio:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border-radius:50%;background:var(--accent)}.slot-waitlist-note{display:flex;gap:8px;align-items:flex-start;font-size:12px;line-height:1.45;color:#7f4400;color:oklch(.45 .13 60);background:var(--warning-soft);border-radius:8px;padding:10px 12px}.slot-waitlist-note svg{flex-shrink:0;margin-top:1px}.roster{display:flex;flex-direction:column;gap:18px}.roster-group{display:flex;flex-direction:column;gap:6px}.roster-head{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--fg-3);padding-bottom:4px}.roster-empty{font-size:12px;color:var(--fg-4);padding:2px 0 4px}.roster-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.roster-who{display:flex;align-items:center;gap:10px;min-width:0}.notif-wrap{position:relative;display:inline-flex}.notif-btn{position:relative}.notif-count{position:absolute;top:2px;right:2px;min-width:15px;height:15px;padding:0 3px;border-radius:999px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;line-height:15px;text-align:center;border:2px solid var(--surface);box-sizing:content-box}.notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-width:calc(100vw - 32px);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:60;overflow:hidden;display:flex;flex-direction:column;max-height:70vh}.notif-panel-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.notif-panel-title{font-size:14px;font-weight:700}.notif-list{overflow-y:auto;display:flex;flex-direction:column}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px;color:var(--fg-3);font-size:13px}.notif-item{display:flex;gap:11px;align-items:flex-start;padding:12px 16px;border-bottom:1px solid var(--border);background:none;border-left:none;border-right:none;border-top:none;text-align:left;cursor:pointer;width:100%;font-family:inherit;transition:background .12s}.notif-item:hover{background:var(--surface-2)}.notif-item.unread,.notif-item.unread:hover{background:var(--accent-soft)}.notif-item-icon{width:30px;height:30px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;background:var(--surface-2);color:var(--fg-2)}.notif-item-icon.slot_promoted{background:var(--success-soft);color:var(--success)}.notif-item-icon.slot_cancelled{background:var(--danger-soft);color:var(--danger)}.notif-item-icon.slot_new{background:var(--info-soft);color:var(--info)}.notif-item-body{flex:1;min-width:0}.notif-item-title{font-size:13px;font-weight:600;line-height:1.35}.notif-item-text{font-size:12px;color:var(--fg-2);line-height:1.4;margin-top:2px}.notif-item-time{font-size:11px;color:var(--fg-4);margin-top:4px}.notif-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0;margin-top:6px}@media(max-width:560px){.slot-grid{grid-template-columns:1fr}}.badge-card-btn{font:inherit;cursor:pointer;text-align:center;width:100%}.badge-card-btn:hover{border-color:var(--accent);transform:translateY(-1px);transition:all .12s}.badge-icon-img{overflow:hidden;padding:0}.badge-icon-img img{width:100%;height:100%;object-fit:cover}.certificate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.certificate-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden;display:flex;flex-direction:column}.cert-thumb{display:block;width:100%;padding:0;border:0;border-bottom:1px solid var(--border);background:var(--surface-2);cursor:pointer;aspect-ratio:16 / 11;overflow:hidden}.cert-thumb img{width:100%;height:100%;object-fit:contain}.cert-body{padding:14px;display:flex;flex-direction:column;gap:4px}.cert-title{font-size:14px;font-weight:700}.cert-meta{font-size:12px}.cert-date{font-size:11.5px}.cert-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.cert-modal-image{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center}.cert-modal-image img{max-width:100%;height:auto;border-radius:6px}.badge-config-body{display:grid;grid-template-columns:1fr 1fr;gap:20px}.badge-overlay-grid-head{display:flex;gap:6px;font-size:11px;color:var(--fg-3);margin-bottom:4px}.badge-overlay-grid-head span{width:56px;text-align:center}.badge-overlay-grid-head span:first-child{flex:2;text-align:left}.badge-overlay-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}.badge-overlay-row .input{width:56px}.badge-overlay-row .input:first-child{flex:2;width:auto}.badge-color-input{width:36px;height:36px;padding:2px;border:1px solid var(--border);border-radius:var(--radius-sm);background:none;cursor:pointer}.badge-preview{position:relative;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-2);overflow:hidden;min-height:180px;display:flex;align-items:center;justify-content:center}.badge-preview img{width:100%;height:auto;display:block}.badge-preview-text{position:absolute;white-space:nowrap;line-height:1;font-weight:700;pointer-events:none}.badge-preview-empty{padding:24px;text-align:center}@media(max-width:760px){.badge-config-body{grid-template-columns:1fr}}.locked-card{text-align:center;padding:48px 24px;border:1px dashed var(--border, #d8d8e0);border-radius:12px;color:var(--fg-3, #6b6b76);background:var(--surface-2, #f7f7fa)}.assessment-row{display:flex;width:100%;padding:10px 14px;border-top:1px solid var(--border, #e7e7ee)}.assessment-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;flex-wrap:wrap}.assessment-info{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg-2, #3a3a44)}.arena-module{border:1px solid var(--border, #e7e7ee);border-radius:12px;margin-bottom:14px;background:var(--surface, #fff);overflow:hidden}.arena-module.locked{opacity:.75}.arena-module-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface-2, #f7f7fa);border-bottom:1px solid var(--border, #e7e7ee)}.arena-module-title{display:flex;align-items:center;gap:8px;font-weight:600}.arena-problems{display:flex;flex-direction:column}.arena-problem{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:10px 16px;border:none;border-bottom:1px solid var(--border, #eee);background:transparent;cursor:pointer;font-size:14px;color:var(--fg, #1a1a22)}.arena-problem:last-child{border-bottom:none}.arena-problem:hover:not(:disabled){background:var(--surface-2, #f4f4f8)}.arena-problem:disabled{cursor:not-allowed;opacity:.55}.arena-problem-ico{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--surface-2, #eee);color:var(--fg-2, #555);flex-shrink:0}.arena-problem-name{flex:1}.arena-locked-note{display:flex;align-items:center;gap:6px;font-size:12px;padding:8px 16px;border-top:1px dashed var(--border, #e7e7ee)}
