:root{color-scheme:dark;--bg: #0c0d0e;--bg-elevated: #101214;--surface: #121416;--surface-raised: #17191c;--surface-soft: #1b1e21;--surface-hover: #202428;--surface-active: #252a2f;--ink: #e5e7e9;--ink-strong: #f6f7f8;--muted: #92979d;--muted-2: #6e747a;--line: #282c30;--line-soft: #202428;--line-strong: #3a3f45;--accent: #8da6ff;--accent-strong: #a8baff;--accent-soft: rgba(116, 145, 255, .13);--accent-line: rgba(139, 163, 255, .32);--success: #69c59a;--success-soft: rgba(89, 190, 142, .12);--success-line: rgba(89, 190, 142, .3);--warning: #d6ad67;--warning-soft: rgba(214, 173, 103, .12);--danger: #ef858a;--danger-soft: rgba(239, 108, 116, .11);--danger-line: rgba(239, 108, 116, .28);--purple: #c19bdf;--cyan: #78bdca;--shadow-popover: 0 18px 50px rgba(0, 0, 0, .44), 0 2px 10px rgba(0, 0, 0, .24);--shadow-modal: 0 32px 96px rgba(0, 0, 0, .58), 0 4px 18px rgba(0, 0, 0, .32);--radius-xs: 5px;--radius-sm: 7px;--radius-md: 10px;--radius-lg: 14px;--topbar-h: 50px;--rail-w: 60px;--font-ui: Inter, Pretendard, ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", sans-serif;--font-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--ease: cubic-bezier(.2, .8, .2, 1);font-family:var(--font-ui);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}html[data-theme=light]{color-scheme:light;--bg: #f3f3f1;--bg-elevated: #f7f7f5;--surface: #fbfbfa;--surface-raised: #ffffff;--surface-soft: #f2f2ef;--surface-hover: #ececea;--surface-active: #e5e6e3;--ink: #2c3033;--ink-strong: #151719;--muted: #72787e;--muted-2: #9aa0a5;--line: #dfe1dd;--line-soft: #e9eae7;--line-strong: #c8cbc7;--accent: #486bd9;--accent-strong: #3157c5;--accent-soft: rgba(67, 98, 205, .09);--accent-line: rgba(67, 98, 205, .24);--success: #2f8a61;--success-soft: rgba(42, 139, 94, .09);--success-line: rgba(42, 139, 94, .24);--warning: #9e6b20;--warning-soft: rgba(168, 107, 25, .1);--danger: #c14f56;--danger-soft: rgba(193, 79, 86, .08);--danger-line: rgba(193, 79, 86, .22);--purple: #855aaa;--cyan: #2f7f8c;--shadow-popover: 0 20px 52px rgba(30, 35, 32, .16), 0 2px 8px rgba(30, 35, 32, .08);--shadow-modal: 0 36px 96px rgba(30, 35, 32, .22), 0 4px 18px rgba(30, 35, 32, .1)}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0;overflow:hidden}body{background:var(--bg);color:var(--ink);font-size:13px;line-height:1.45}button,input,textarea,select{font:inherit}button,input,textarea,summary{-webkit-tap-highlight-color:transparent}button{border:0;color:inherit}button:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:disabled{cursor:not-allowed;opacity:.46}button:not(:disabled){cursor:pointer}svg{display:block;flex:0 0 auto}h1,h2,h3,p,dl,dd,pre{margin:0}h1,h2,h3,strong{color:var(--ink-strong)}code,pre,kbd{font-family:var(--font-mono)}kbd{display:inline-flex;min-width:18px;height:18px;align-items:center;justify-content:center;padding:0 5px;border:1px solid var(--line);border-bottom-color:var(--line-strong);border-radius:4px;background:var(--surface-raised);color:var(--muted);font-size:10px;line-height:1;box-shadow:0 1px 0 var(--line)}::selection{background:#7491ff47}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{border:3px solid transparent;border-radius:999px;background:color-mix(in srgb,var(--muted-2) 55%,transparent);background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:color-mix(in srgb,var(--muted) 65%,transparent);background-clip:padding-box}::-webkit-scrollbar-corner{background:transparent}.eyebrow{display:block;color:var(--muted-2);font-size:9px;font-weight:760;letter-spacing:.12em;line-height:1.2;text-transform:uppercase}.app-shell{display:flex;flex-direction:column;width:100%;height:100%;min-width:860px;background:var(--bg)}.app-shell.focus-mode .topbar{display:none}.app-body{display:flex;min-width:0;min-height:0;flex:1;height:calc(100% - var(--topbar-h))}.app-shell.focus-mode .app-body{height:100%}.main-region{position:relative;min-width:0;min-height:0;flex:1;overflow:hidden;background:var(--bg)}.main-view{width:100%;height:100%;min-width:0;min-height:0}.topbar{position:relative;z-index:60;display:grid;grid-template-columns:minmax(280px,1fr) minmax(250px,420px) minmax(300px,1fr);align-items:center;height:var(--topbar-h);min-height:var(--topbar-h);padding:0 12px 0 10px;border-bottom:1px solid var(--line-soft);background:color-mix(in srgb,var(--surface) 96%,transparent)}.topbar-left,.topbar-right{display:flex;align-items:center;min-width:0}.topbar-left{gap:10px;overflow:hidden}.topbar-center{display:flex;justify-content:center;min-width:0}.topbar-right{justify-content:flex-end;gap:7px}.topbar-sidebar-toggle{display:none!important}.breadcrumbs{display:flex;align-items:center;min-width:0;gap:5px;color:var(--muted);white-space:nowrap}.breadcrumbs span,.breadcrumbs strong{max-width:240px;overflow:hidden;text-overflow:ellipsis}.breadcrumbs>span:first-child{color:var(--ink-strong);font-size:11px;font-weight:790;letter-spacing:.08em}.breadcrumbs strong{color:var(--ink);font-weight:640}.topbar-subtitle{flex:0 0 auto;padding-left:3px;color:var(--muted-2);font-size:11px}.command-trigger{display:flex;width:min(100%,390px);height:30px;align-items:center;gap:8px;padding:0 7px 0 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted);text-align:left;transition:border-color .12s var(--ease),background .12s var(--ease)}.command-trigger:hover{border-color:var(--line-strong);background:var(--surface-soft)}.command-trigger span{min-width:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.command-trigger kbd{height:17px;min-width:34px;border-color:transparent;background:var(--surface-hover);box-shadow:none}.icon-button,.toolbar-button,.text-button,.primary-button,.secondary-button,.danger-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;white-space:nowrap;transition:color .12s var(--ease),background .12s var(--ease),border-color .12s var(--ease),transform .12s var(--ease)}.icon-button{width:30px;height:30px;padding:0;border:1px solid transparent;border-radius:7px;background:transparent;color:var(--muted)}.icon-button:hover,.icon-button.is-active{border-color:var(--line);background:var(--surface-hover);color:var(--ink-strong)}.icon-button.tiny{width:24px;height:24px;border-radius:6px}.toolbar-button{height:30px;padding:0 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted);font-size:12px;font-weight:600}.toolbar-button:hover:not(:disabled),.toolbar-button.is-success,.toolbar-button.is-active{border-color:var(--line-strong);background:var(--surface-hover);color:var(--ink-strong)}.toolbar-button.is-danger{border-color:var(--danger-line);background:var(--danger-soft);color:var(--danger)}.text-button{padding:0;background:transparent;color:var(--muted);font-size:12px}.text-button:hover{color:var(--ink-strong)}.text-button.danger{color:var(--danger)}.primary-button,.secondary-button,.danger-button{min-height:32px;padding:0 12px;border-radius:7px;font-size:12px;font-weight:660}.primary-button{border:1px solid color-mix(in srgb,var(--accent) 62%,var(--line));background:var(--accent);color:#0b1023}html[data-theme=light] .primary-button{color:#fff}.primary-button:hover:not(:disabled){background:var(--accent-strong);transform:translateY(-1px)}.primary-button.compact,.secondary-button.compact{min-height:30px;padding-inline:10px}.secondary-button{border:1px solid var(--line);background:var(--surface-raised);color:var(--ink)}.secondary-button:hover:not(:disabled){border-color:var(--line-strong);background:var(--surface-hover)}.danger-button{border:1px solid var(--danger-line);background:var(--danger);color:#201012}html[data-theme=light] .danger-button{color:#fff}.full-button{width:100%}.danger-hover:hover{border-color:var(--danger-line);background:var(--danger-soft);color:var(--danger)}.privacy-chip,.kernel-chip{display:inline-flex;height:25px;align-items:center;gap:6px;padding:0 8px;border:1px solid var(--line);border-radius:999px;background:var(--surface-raised);color:var(--muted);font-size:10px;font-weight:610}.kernel-chip{max-width:160px}.kernel-chip>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--muted-2);box-shadow:0 0 0 3px color-mix(in srgb,var(--muted-2) 15%,transparent)}.kernel-chip.is-ready .status-dot{background:var(--success);box-shadow:0 0 0 3px var(--success-soft)}.kernel-chip.is-busy .status-dot{background:var(--warning);animation:pulse-dot 1.1s ease-in-out infinite}.kernel-chip.is-error .status-dot{background:var(--danger)}.nav-rail{position:relative;z-index:45;display:flex;width:var(--rail-w);min-width:var(--rail-w);flex-direction:column;align-items:center;padding:9px 7px 8px;border-right:1px solid var(--line-soft);background:var(--surface)}.nav-brand{display:grid;width:100%;height:36px;place-items:center;margin-bottom:7px}.brand-mark{display:grid;width:29px;height:29px;place-items:center;border:1px solid var(--line-strong);border-radius:8px;background:var(--ink-strong);color:var(--bg);font-size:14px;font-weight:840;letter-spacing:-.04em}.nav-primary,.nav-secondary{display:flex;width:100%;flex-direction:column;align-items:center;gap:4px}.nav-primary{flex:1}.rail-button,.rail-icon-button{position:relative;display:flex;width:44px;align-items:center;justify-content:center;border-radius:8px;background:transparent;color:var(--muted)}.rail-button{height:43px;flex-direction:column;gap:3px;font-size:9px;font-weight:600}.rail-button:before{position:absolute;left:-7px;width:2px;height:20px;border-radius:0 4px 4px 0;background:transparent;content:""}.rail-button:hover,.rail-button.is-active,.rail-icon-button:hover{background:var(--surface-hover);color:var(--ink-strong)}.rail-button.is-active:before{background:var(--accent)}.rail-button.is-active{color:var(--accent-strong)}.rail-icon-button{height:34px}.context-sidebar{position:relative;z-index:40;display:flex;min-width:238px;max-width:380px;min-height:0;flex-direction:column;overflow:hidden;border-right:1px solid var(--line-soft);background:var(--surface)}.sidebar-heading{display:flex;height:61px;min-height:61px;align-items:center;justify-content:space-between;padding:11px 12px 9px 14px}.sidebar-heading h2{margin-top:4px;font-size:14px;font-weight:680;letter-spacing:-.01em}.sidebar-search{display:flex;height:30px;align-items:center;gap:7px;margin:0 10px 9px;padding:0 8px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted-2)}.sidebar-search:focus-within{border-color:var(--accent-line);box-shadow:0 0 0 2px var(--accent-soft)}.sidebar-search input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--ink);font-size:12px}.sidebar-search input::placeholder{color:var(--muted-2)}.sidebar-search button{display:grid;width:19px;height:19px;place-items:center;padding:0;border-radius:4px;background:transparent;color:var(--muted)}.sidebar-scroll,.sidebar-home-content{min-height:0;flex:1;overflow:auto;padding:0 8px 12px}.sidebar-home-content{padding-top:2px}.sidebar-section{margin-top:14px}.sidebar-section-title{padding:0 7px 6px;color:var(--muted-2);font-size:9px;font-weight:750;letter-spacing:.09em;text-transform:uppercase}.compact-card{border:1px solid var(--line);border-radius:9px;background:var(--surface-raised)}.progress-card{padding:11px 11px 10px}.progress-card-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:9px}.progress-card-row strong{font-size:18px;font-weight:730;letter-spacing:-.04em}.progress-card-row span{color:var(--muted);font-size:10px}.progress-track,.course-track{height:3px;overflow:hidden;border-radius:999px;background:var(--surface-hover)}.progress-track span,.course-track span{display:block;height:100%;border-radius:inherit;background:var(--accent)}.sidebar-action-row,.notebook-row,.exercise-row,.file-row,.chapter-row,.section-row{width:100%;border:1px solid transparent;background:transparent;color:var(--muted);text-align:left}.sidebar-action-row{display:grid;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:44px;padding:5px 7px;border-radius:7px}.sidebar-action-row:hover,.notebook-row:hover,.exercise-row:hover,.file-row:hover:not(:disabled),.chapter-row:hover,.section-row:hover,.notebook-row.is-active,.exercise-row.is-active,.file-row.is-active,.section-row.is-active{background:var(--surface-hover);color:var(--ink)}.action-icon{display:grid;width:27px;height:27px;place-items:center;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted)}.sidebar-action-row>span:nth-child(2),.notebook-row>span,.exercise-row>span:nth-child(2){display:flex;min-width:0;flex-direction:column;gap:1px}.sidebar-action-row strong,.notebook-row strong,.exercise-row strong,.section-row strong{overflow:hidden;font-size:11px;font-weight:610;text-overflow:ellipsis;white-space:nowrap}.sidebar-action-row small,.notebook-row small,.exercise-row small,.section-row small{overflow:hidden;color:var(--muted-2);font-size:9px;text-overflow:ellipsis;white-space:nowrap}.primary-sidebar-button{display:flex;width:calc(100% - 2px);height:31px;align-items:center;justify-content:center;gap:7px;margin:2px 1px 8px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--ink);font-size:11px;font-weight:630}.primary-sidebar-button:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.notebook-row{position:relative;display:grid;grid-template-columns:18px minmax(0,1fr) auto;align-items:center;gap:7px;min-height:39px;padding:5px 8px;border-radius:7px}.notebook-row.is-active,.exercise-row.is-active,.file-row.is-active,.section-row.is-active{color:var(--ink-strong)}.notebook-row.is-active:before,.exercise-row.is-active:before,.file-row.is-active:before,.section-row.is-active:before{position:absolute;left:-8px;width:2px;height:20px;border-radius:0 2px 2px 0;background:var(--accent);content:""}.row-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:0}.notebook-row.is-active .row-dot{opacity:1}.chapter-group{margin-bottom:1px}.chapter-row{display:grid;grid-template-columns:25px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:34px;padding:5px 7px;border-radius:7px}.chapter-index,.exercise-chapter,.chapter-badge{display:inline-grid;place-items:center;font-family:var(--font-mono);font-size:9px;font-weight:700}.chapter-index{color:var(--muted-2)}.chapter-copy{overflow:hidden;color:var(--ink);font-size:11px;font-weight:610;text-overflow:ellipsis;white-space:nowrap}.completion-mark{display:grid;width:16px;height:16px;place-items:center;border-radius:50%;color:var(--muted-2)}.completion-mark.is-done{background:var(--success-soft);color:var(--success)}.section-list{padding:1px 0 5px 17px}.section-row{position:relative;display:grid;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:7px;min-height:38px;padding:4px 7px;border-radius:7px}.section-state{display:grid;width:13px;height:13px;place-items:center;border:1px solid var(--line-strong);border-radius:50%}.section-state.is-done{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.section-row>span:last-child{display:flex;min-width:0;flex-direction:column}.exercise-row{position:relative;display:grid;grid-template-columns:27px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:42px;padding:6px 8px;border-radius:7px}.exercise-chapter{width:25px;height:25px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted)}.file-row{position:relative;display:flex;height:30px;align-items:center;gap:7px;padding-right:8px;border-radius:6px;font-size:11px}.file-row:disabled{opacity:1;color:var(--muted-2)}.file-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-empty{display:grid;min-height:100px;place-items:center;color:var(--muted-2);font-size:11px}.sidebar-resizer{position:relative;z-index:44;width:4px;min-width:4px;margin-left:-2px;cursor:col-resize}.sidebar-resizer span,.splitter span{position:absolute;inset-block:0;left:50%;width:1px;transform:translate(-50%);background:transparent}.sidebar-resizer:hover span,.sidebar-resizer:active span,.splitter:hover span,.splitter:active span{background:var(--accent)}.dashboard-view{overflow:auto;padding:clamp(26px,4vw,54px) clamp(24px,4.5vw,70px) 72px}.dashboard-view>*{max-width:1280px;margin-inline:auto}.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(280px,.65fr);align-items:end;gap:44px;min-height:270px;padding:30px 0 42px;border-bottom:1px solid var(--line)}.hero-copy h1{max-width:700px;margin-top:15px;font-size:clamp(36px,5vw,62px);font-weight:660;letter-spacing:-.055em;line-height:.98}.hero-copy>p{max-width:590px;margin-top:21px;color:var(--muted);font-size:14px;line-height:1.75}.hero-actions{display:flex;gap:8px;margin-top:25px}.hero-status-panel{display:grid;grid-template-columns:94px minmax(0,1fr);align-items:center;gap:18px;padding:18px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.hero-progress-ring{display:grid;width:88px;height:88px;place-items:center;border-radius:50%;background:conic-gradient(var(--accent) var(--progress),var(--surface-hover) 0)}.hero-progress-ring:before{position:absolute;width:72px;height:72px;border-radius:50%;background:var(--surface);content:""}.hero-progress-ring{position:relative}.hero-progress-ring>div{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.hero-progress-ring strong{font-size:19px;letter-spacing:-.04em}.hero-progress-ring span{color:var(--muted-2);font-size:8px}.hero-status-copy{display:flex;min-width:0;flex-direction:column;gap:5px}.hero-status-copy>span{color:var(--muted-2);font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.hero-status-copy strong{overflow:hidden;font-size:14px;text-overflow:ellipsis;white-space:nowrap}.hero-status-copy small{color:var(--muted);font-size:10px}.dashboard-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:12px;margin-top:12px}.dashboard-panel{min-width:0;min-height:210px;padding:17px;border:1px solid var(--line);border-radius:11px;background:var(--surface);contain:layout paint}.continue-panel{grid-column:span 7}.system-panel{grid-column:span 5}.recent-panel,.practice-panel-card{grid-column:span 6}.panel-header,.section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header h2,.section-header h2{margin-top:4px;font-size:14px;font-weight:650}.continue-content{display:grid;grid-template-columns:52px minmax(0,1fr);align-items:center;gap:16px;margin-top:26px}.chapter-badge{width:50px;height:50px;border:1px solid var(--accent-line);border-radius:10px;background:var(--accent-soft);color:var(--accent-strong);font-size:13px}.continue-content>div:last-child{min-width:0}.continue-content span{color:var(--muted);font-size:10px}.continue-content h3{margin-top:4px;overflow:hidden;font-size:18px;font-weight:650;letter-spacing:-.025em;text-overflow:ellipsis;white-space:nowrap}.continue-content p,.practice-prompt-mini p{margin-top:7px;color:var(--muted);font-size:11px;line-height:1.65}.continue-footer{display:flex;align-items:center;gap:16px;margin-top:25px;padding-top:12px;border-top:1px solid var(--line-soft);color:var(--muted-2);font-size:10px}.continue-footer span{display:inline-flex;align-items:center;gap:6px}.system-badge,.difficulty-chip,.language-chip,.score-chip{display:inline-flex;height:22px;align-items:center;padding:0 8px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:9px;font-weight:650}.system-badge.is-ok{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.system-list{display:grid;gap:0;margin-top:17px}.system-list>div{display:flex;min-height:31px;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line-soft)}.system-list dt{color:var(--muted);font-size:10px}.system-list dd{max-width:65%;overflow:hidden;color:var(--ink);font-size:10px;text-overflow:ellipsis;white-space:nowrap}.system-panel .full-button{margin-top:14px}.recent-list{display:grid;margin-top:12px}.recent-row{display:grid;grid-template-columns:29px minmax(0,1fr) auto;min-height:39px;align-items:center;gap:8px;padding:4px 5px;border-radius:7px;background:transparent;color:var(--muted);text-align:left}.recent-row:hover{background:var(--surface-hover);color:var(--ink)}.recent-icon{display:grid;width:27px;height:27px;place-items:center;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised)}.recent-row>span:nth-child(2){display:flex;min-width:0;flex-direction:column}.recent-row strong{overflow:hidden;font-size:11px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.recent-row small{color:var(--muted-2);font-size:9px}.empty-compact{display:flex;min-height:105px;align-items:center;justify-content:center;gap:8px;color:var(--muted-2);font-size:11px}.practice-prompt-mini{display:grid;grid-template-columns:44px minmax(0,1fr);gap:13px;margin:28px 0 22px}.practice-number{display:grid;width:42px;height:42px;place-items:center;border:1px solid var(--line);border-radius:10px;background:var(--surface-raised);color:var(--accent-strong);font-family:var(--font-mono);font-size:12px}.practice-prompt-mini h3{font-size:15px}.course-overview{margin-top:12px;padding:18px;border:1px solid var(--line);border-radius:11px;background:var(--surface)}.section-header>span{color:var(--muted);font-size:10px}.course-bars{display:grid;gap:3px;margin-top:16px}.course-bar-row{display:grid;grid-template-columns:28px minmax(130px,.6fr) minmax(100px,1fr) 40px;min-height:28px;align-items:center;gap:10px}.course-index,.course-count{color:var(--muted-2);font-family:var(--font-mono);font-size:9px}.course-title{overflow:hidden;color:var(--ink);font-size:10px;text-overflow:ellipsis;white-space:nowrap}.course-count{text-align:right}.study-split{display:grid;grid-template-columns:minmax(0,var(--reader-ratio)) 6px minmax(0,calc(100% - var(--reader-ratio) - 6px));width:100%;height:100%;min-height:0}.reader-pane,.study-notebook-pane{min-width:0;min-height:0;overflow:hidden;background:var(--surface)}.reader-pane{display:flex;flex-direction:column}.reader-toolbar,.notebook-toolbar,.practice-toolbar,.file-toolbar{position:relative;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:50px;padding:0 11px 0 14px;border-bottom:1px solid var(--line-soft);background:var(--surface)}.reader-location{display:flex;min-width:0;align-items:center;gap:10px}.section-id{display:grid;min-width:36px;height:24px;place-items:center;border:1px solid var(--line);border-radius:6px;background:var(--surface-raised);color:var(--accent-strong);font-family:var(--font-mono);font-size:9px;font-weight:700}.reader-location>div{display:flex;min-width:0;flex-direction:column}.reader-location strong{overflow:hidden;max-width:320px;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.reader-location small{overflow:hidden;max-width:320px;color:var(--muted-2);font-size:9px;text-overflow:ellipsis;white-space:nowrap}.reader-page-controls,.reader-actions{display:flex;align-items:center;gap:4px}.reader-page-controls label{display:flex;height:28px;align-items:center;gap:4px;padding:0 7px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted-2)}.reader-page-controls label span{font-size:8px;font-weight:700;letter-spacing:.06em}.reader-page-controls input{width:33px;padding:0;border:0;outline:0;background:transparent;color:var(--ink);font-family:var(--font-mono);font-size:10px;text-align:right}.reader-page-controls input::-webkit-outer-spin-button,.reader-page-controls input::-webkit-inner-spin-button{margin:0;appearance:none}.reader-page-controls small{font-size:9px}.reader-stage{position:relative;min-height:0;flex:1;overflow:hidden;background:var(--bg-elevated)}.book-frame{width:100%;height:100%;border:0;background:#fff}.book-empty-state{display:flex;width:100%;height:100%;min-height:440px;align-items:center;justify-content:center;flex-direction:column;padding:40px;text-align:center}.book-object{position:relative;width:82px;height:96px;margin-bottom:25px;border:1px solid var(--line-strong);border-radius:3px 10px 10px 3px;background:var(--surface-raised);box-shadow:8px 8px 0 var(--surface-hover)}.book-object:before{position:absolute;inset:12px 15px auto;height:3px;background:var(--accent);content:""}.book-object span{position:absolute;left:15px;right:15px;height:1px;background:var(--line-strong)}.book-object span:first-child{top:34px}.book-object span:last-child{top:46px}.book-empty-state h2{max-width:440px;margin-top:10px;font-size:21px;font-weight:650;letter-spacing:-.03em}.book-empty-state p{max-width:470px;margin:12px 0 20px;color:var(--muted);line-height:1.7}.book-empty-state small{margin-top:12px;color:var(--muted-2);font-size:9px}.reader-notes-panel{position:absolute;z-index:20;inset:10px 10px 10px auto;display:flex;width:min(370px,calc(100% - 20px));flex-direction:column;overflow:hidden;border:1px solid var(--line-strong);border-radius:10px;background:var(--surface-raised);box-shadow:var(--shadow-popover)}.reader-notes-panel header{display:flex;min-height:54px;align-items:center;justify-content:space-between;padding:9px 10px 8px 13px;border-bottom:1px solid var(--line)}.reader-notes-panel h3{margin-top:3px;font-size:12px}.reader-notes-panel textarea{min-height:240px;flex:1;resize:none;border:0;outline:0;padding:14px;background:transparent;color:var(--ink);line-height:1.75}.reader-notes-panel textarea::placeholder{color:var(--muted-2)}.reader-notes-panel footer{display:flex;min-height:34px;align-items:center;gap:6px;padding:0 13px;border-top:1px solid var(--line);color:var(--muted-2);font-size:9px}.splitter{position:relative;z-index:12;width:6px;cursor:col-resize;background:var(--bg)}.study-notebook-pane{border-left:1px solid var(--line-soft)}.learn-view.is-resizing,.learn-view.is-resizing *{cursor:col-resize!important;user-select:none!important}.lab-view{background:var(--surface)}.notebook-workspace{display:flex;width:100%;height:100%;min-width:0;min-height:0;flex-direction:column;background:var(--surface)}.notebook-toolbar{min-height:50px;padding-left:12px}.notebook-title-wrap,.notebook-actions,.file-title-block,.file-toolbar-actions,.practice-title-block,.practice-toolbar-actions{display:flex;min-width:0;align-items:center}.notebook-title-wrap{flex:1;gap:8px}.notebook-icon,.file-type-icon{display:grid;width:27px;height:27px;flex:0 0 auto;place-items:center;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--accent-strong)}.notebook-title-input{width:min(360px,48vw);min-width:120px;border:1px solid transparent;border-radius:5px;outline:0;padding:3px 5px;background:transparent;color:var(--ink-strong);font-size:12px;font-weight:630}.notebook-title-input:hover,.notebook-title-input:focus{border-color:var(--line);background:var(--surface-raised)}.save-indicator{display:inline-flex;flex:0 0 auto;align-items:center;gap:5px;color:var(--muted-2);font-size:9px}.save-indicator>span{width:5px;height:5px;border-radius:50%;background:var(--success)}.save-indicator.is-dirty>span,.save-indicator.is-saving>span{background:var(--warning)}.save-indicator.is-error>span{background:var(--danger)}.notebook-actions,.file-toolbar-actions,.practice-toolbar-actions{gap:5px}.notebook-body{display:flex;min-width:0;min-height:0;flex:1}.notebook-scroll{min-width:0;min-height:0;flex:1;overflow:auto;background:var(--bg-elevated);scroll-behavior:smooth}.notebook-cells{width:min(920px,calc(100% - 48px));min-width:520px;margin:0 auto;padding:28px 0 120px}.notebook-workspace.is-embedded .notebook-cells{width:calc(100% - 22px);min-width:360px;padding-top:13px}.notebook-cell{position:relative;display:grid;grid-template-columns:48px minmax(0,1fr);margin-bottom:11px;border:1px solid var(--line);border-radius:9px;background:var(--surface);content-visibility:auto;contain-intrinsic-size:260px;transition:border-color .12s var(--ease),box-shadow .12s var(--ease)}.notebook-cell:focus-within,.notebook-cell.status-running{border-color:var(--accent-line);box-shadow:0 0 0 2px var(--accent-soft)}.notebook-cell.status-error{border-color:var(--danger-line)}.cell-rail{display:flex;min-height:92px;align-items:center;flex-direction:column;gap:8px;padding-top:35px;border-right:1px solid var(--line-soft);color:var(--muted-2)}.cell-run-button,.cell-type-icon{display:grid;width:25px;height:25px;place-items:center;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted)}.execution-count{font-family:var(--font-mono);font-size:8px}.cell-main{min-width:0;padding:0 0 2px}.cell-header{display:flex;height:34px;align-items:center;justify-content:space-between;padding:0 7px 0 10px;border-bottom:1px solid var(--line-soft)}.cell-kind-switch,.segmented-control{display:inline-flex;padding:2px;border:1px solid var(--line);border-radius:6px;background:var(--surface-raised)}.cell-kind-switch button,.segmented-control button{height:21px;padding:0 7px;border-radius:4px;background:transparent;color:var(--muted-2);font-size:9px}.cell-kind-switch button:hover,.cell-kind-switch button.is-active,.segmented-control button:hover,.segmented-control button.is-active{background:var(--surface-hover);color:var(--ink-strong)}.cell-header-actions{position:relative;display:flex;align-items:center;gap:5px}.cell-time{color:var(--muted-2);font-family:var(--font-mono);font-size:8px}.cell-menu{position:absolute;z-index:40;top:27px;right:0;display:grid;width:154px;padding:4px;border:1px solid var(--line-strong);border-radius:8px;background:var(--surface-raised);box-shadow:var(--shadow-popover)}.cell-menu button{display:flex;height:29px;align-items:center;gap:8px;padding:0 8px;border-radius:5px;background:transparent;color:var(--muted);font-size:10px;text-align:left}.cell-menu button:hover:not(:disabled){background:var(--surface-hover);color:var(--ink)}.cell-menu button.is-danger{color:var(--danger)}.note-cell-editor{display:block;width:100%;min-height:80px;resize:vertical;border:0;outline:0;padding:14px 16px 16px;background:transparent;color:var(--ink);font-size:13px;line-height:1.72}.note-cell-editor::placeholder{color:var(--muted-2)}.cell-stdin{display:flex;min-height:35px;align-items:center;gap:8px;padding:4px 10px;border-top:1px solid var(--line-soft);color:var(--muted-2)}.cell-stdin span{font-family:var(--font-mono);font-size:8px;font-weight:700}.cell-stdin input{min-width:0;flex:1;border:0;outline:0;padding:4px 6px;border-radius:4px;background:var(--surface-raised);color:var(--ink);font-family:var(--font-mono);font-size:10px}.cell-output{display:grid;gap:0;border-top:1px solid var(--line);background:color-mix(in srgb,var(--bg-elevated) 82%,var(--surface))}.cell-output.has-error{background:var(--danger-soft)}.output-block{display:grid;grid-template-columns:60px minmax(0,1fr);min-height:38px;gap:8px;padding:8px 11px}.output-block+.output-block{border-top:1px solid var(--line-soft)}.output-label{padding-top:2px;color:var(--muted-2);font-family:var(--font-mono);font-size:8px;font-weight:700;text-transform:uppercase}.output-block pre,.output-block strong{min-width:0;overflow:auto;color:var(--ink);font-family:var(--font-mono);font-size:11px;font-weight:400;line-height:1.6;white-space:pre-wrap;word-break:break-word}.output-block.error-block pre,.output-block.error-block strong{color:var(--danger)}.result-block pre{color:var(--cyan)}.insert-cell-button{position:absolute;z-index:3;bottom:-10px;left:50%;display:grid;width:21px;height:21px;place-items:center;transform:translate(-50%) scale(.84);border:1px solid var(--line-strong);border-radius:50%;background:var(--surface-raised);color:var(--muted-2);opacity:0;transition:opacity .12s var(--ease),transform .12s var(--ease),color .12s var(--ease)}.notebook-cell:hover .insert-cell-button,.insert-cell-button:focus-visible{transform:translate(-50%) scale(1);opacity:1}.insert-cell-button:hover{color:var(--accent-strong)}.notebook-add-row{display:flex;justify-content:center;gap:6px;padding-top:4px}.notebook-add-row button{display:inline-flex;height:30px;align-items:center;gap:6px;padding:0 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface);color:var(--muted);font-size:10px}.notebook-add-row button:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.variable-inspector{width:260px;min-width:220px;max-width:340px;min-height:0;overflow:hidden;border-left:1px solid var(--line-soft);background:var(--surface)}.variable-inspector>header{display:flex;min-height:50px;align-items:center;justify-content:space-between;padding:9px 12px 8px 14px;border-bottom:1px solid var(--line-soft)}.variable-inspector h3{margin-top:3px;font-size:12px}.variable-inspector>header>span{display:grid;min-width:20px;height:20px;place-items:center;border-radius:999px;background:var(--surface-hover);color:var(--muted);font-size:9px}.variable-list{height:calc(100% - 50px);overflow:auto;padding:7px}.variable-row{padding:9px;border:1px solid transparent;border-radius:7px}.variable-row:hover{border-color:var(--line);background:var(--surface-raised)}.variable-row>div{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.variable-row strong{font-family:var(--font-mono);font-size:10px}.variable-row span{color:var(--muted-2);font-size:8px}.variable-row pre{margin-top:5px;overflow:hidden;color:var(--muted);font-size:9px;line-height:1.55;text-overflow:ellipsis;white-space:nowrap}.inspector-empty,.console-empty{display:flex;min-height:140px;align-items:center;justify-content:center;flex-direction:column;gap:10px;padding:20px;color:var(--muted-2);font-size:10px;text-align:center}.notebook-empty-state,.empty-main-view{display:flex;align-items:center;justify-content:center;flex-direction:column;background:var(--bg-elevated);text-align:center}.notebook-empty-state{height:100%}.empty-symbol{display:grid;width:52px;height:52px;place-items:center;margin-bottom:16px;border:1px solid var(--line);border-radius:13px;background:var(--surface-raised);color:var(--muted)}.notebook-empty-state h2,.empty-main-view h2{font-size:16px;font-weight:650}.notebook-empty-state p,.empty-main-view p{max-width:380px;margin-top:8px;color:var(--muted)}.empty-main-view .primary-button{margin-top:18px}.code-editor{--editor-line-height: 21px;display:grid;grid-template-columns:42px minmax(0,1fr);width:100%;min-height:calc(var(--editor-rows) * var(--editor-line-height) + 22px);max-height:calc(var(--editor-rows) * var(--editor-line-height) + 22px);overflow:hidden;background:#101214;color:#d8dce1}html[data-theme=light] .code-editor{background:#f7f7f5;color:#2a2e32}.code-gutter{height:100%;overflow:hidden;padding:11px 9px 11px 0;border-right:1px solid color-mix(in srgb,var(--line) 82%,transparent);background:color-mix(in srgb,#0f1113 90%,var(--surface));color:#555d65;font-family:var(--font-mono);font-size:10px;line-height:var(--editor-line-height);text-align:right;user-select:none}html[data-theme=light] .code-gutter{background:#f1f1ee;color:#9a9fa3}.code-gutter span{display:block;height:var(--editor-line-height)}.code-layer{position:relative;min-width:0;height:100%;overflow:hidden}.code-highlight,.code-textarea{position:absolute;inset:0;width:100%;height:100%;margin:0;overflow:auto;padding:11px 13px;border:0;outline:0;font-family:var(--font-mono);font-size:12px;font-variant-ligatures:none;line-height:var(--editor-line-height);tab-size:4;white-space:pre}.code-highlight{pointer-events:none}.code-textarea{z-index:2;resize:none;background:transparent;caret-color:var(--accent-strong);color:transparent;-webkit-text-fill-color:transparent}.code-textarea::selection{background:#718fff52;-webkit-text-fill-color:transparent}.code-editor.is-focused{box-shadow:inset 2px 0 0 var(--accent)}.code-editor.is-readonly .code-textarea{cursor:default}.tok-keyword{color:#c39be2}.tok-builtin{color:#7fb0f4}.tok-string{color:#9fc58f}.tok-number{color:#d5a76e}.tok-comment{color:#616a73;font-style:italic}.tok-operator{color:#86bbc4}.tok-decorator{color:#e3bd7b}html[data-theme=light] .tok-keyword{color:#7b3aa3}html[data-theme=light] .tok-builtin{color:#245aa7}html[data-theme=light] .tok-string{color:#39713a}html[data-theme=light] .tok-number{color:#a05b19}html[data-theme=light] .tok-comment{color:#90969a}html[data-theme=light] .tok-operator{color:#2f7884}html[data-theme=light] .tok-decorator{color:#8a621d}.practice-view,.files-view{display:flex;min-height:0;flex-direction:column;background:var(--surface)}.practice-toolbar,.file-toolbar{min-height:55px;padding-inline:14px 11px}.practice-title-block,.file-title-block{gap:9px}.practice-title-block>div,.file-title-block>div{display:flex;min-width:0;flex-direction:column}.practice-title-block h1,.file-title-block h1{overflow:hidden;font-size:12px;font-weight:640;text-overflow:ellipsis;white-space:nowrap}.practice-title-block>div>span,.file-title-block>div>span{overflow:hidden;max-width:390px;color:var(--muted-2);font-size:9px;text-overflow:ellipsis;white-space:nowrap}.exercise-number{display:grid;height:25px;place-items:center;padding:0 8px;border:1px solid var(--line);border-radius:6px;background:var(--surface-raised);color:var(--accent-strong);font-family:var(--font-mono);font-size:9px;font-weight:700}.practice-layout{display:grid;grid-template-columns:minmax(230px,.72fr) minmax(420px,1.55fr) minmax(250px,.85fr);min-height:0;flex:1;overflow:hidden}.problem-panel,.solution-panel,.result-panel{min-width:0;min-height:0;overflow:auto;background:var(--surface)}.problem-panel,.result-panel{padding:22px 19px}.problem-panel{border-right:1px solid var(--line-soft)}.result-panel{border-left:1px solid var(--line-soft)}.solution-panel{display:flex;flex-direction:column;background:var(--bg-elevated)}.problem-heading h2,.solution-heading h2,.result-heading h2,.file-console-panel header h2{margin-top:5px;font-size:14px;font-weight:650}.problem-prompt{margin-top:22px;color:var(--ink);font-size:13px;line-height:1.85;white-space:pre-line}.problem-spec{display:grid;gap:0;margin-top:25px;border-block:1px solid var(--line-soft)}.problem-spec>div{display:flex;min-height:37px;align-items:center;justify-content:space-between;gap:10px;border-bottom:1px solid var(--line-soft)}.problem-spec>div:last-child{border-bottom:0}.problem-spec span{color:var(--muted);font-size:10px}.problem-spec code,.problem-spec strong{color:var(--ink);font-size:10px;font-weight:600}.practice-tip{display:flex;gap:10px;margin-top:22px;padding:11px;border:1px solid var(--line);border-radius:8px;background:var(--surface-raised);color:var(--muted)}.practice-tip>svg{margin-top:2px;color:var(--accent-strong)}.practice-tip strong{font-size:10px}.practice-tip p{margin-top:4px;font-size:9px;line-height:1.65}.solution-heading,.result-heading{display:flex;min-height:66px;align-items:center;justify-content:space-between;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line-soft);background:var(--surface)}.solution-meta{display:flex;gap:5px}.solution-meta span{height:21px;padding:0 7px;border:1px solid var(--line);border-radius:999px;color:var(--muted);font-size:8px;line-height:19px}.solution-panel .code-editor{min-height:0;max-height:none;flex:1}.solution-shortcut{display:flex;min-height:36px;align-items:center;justify-content:flex-end;gap:4px;padding:0 12px;border-top:1px solid var(--line-soft);background:var(--surface);color:var(--muted-2);font-size:9px}.solution-shortcut span{margin-left:3px}.score-chip.is-pass{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.result-empty{display:flex;min-height:320px;align-items:center;justify-content:center;flex-direction:column;color:var(--muted);text-align:center}.result-empty-icon{display:grid;width:48px;height:48px;place-items:center;margin-bottom:14px;border:1px solid var(--line);border-radius:12px;background:var(--surface-raised);color:var(--muted-2)}.result-empty p{margin-top:6px;color:var(--muted-2);font-size:10px}.test-results{padding-top:16px}.test-summary{display:flex;align-items:center;gap:11px;padding-bottom:16px}.test-summary-icon{display:grid;width:34px;height:34px;place-items:center;border-radius:9px;background:var(--danger-soft);color:var(--danger)}.test-summary-icon.is-pass{background:var(--success-soft);color:var(--success)}.test-summary>div:last-child{display:flex;flex-direction:column}.test-summary strong{font-size:11px}.test-summary span{color:var(--muted-2);font-size:9px}.grade-error{margin-bottom:10px;padding:10px;border:1px solid var(--danger-line);border-radius:7px;background:var(--danger-soft)}.grade-error strong{color:var(--danger);font-family:var(--font-mono);font-size:10px}.grade-error p{margin-top:4px;color:var(--muted);font-size:10px}.test-case-list{display:grid;gap:5px}.test-case{overflow:hidden;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised)}.test-case.is-pass{border-color:var(--success-line)}.test-case summary{display:grid;grid-template-columns:22px minmax(0,1fr) auto;min-height:36px;align-items:center;gap:6px;padding:0 9px;list-style:none;color:var(--muted);font-size:10px;cursor:pointer}.test-case summary::-webkit-details-marker{display:none}.test-case summary strong{color:var(--muted-2);font-size:9px}.test-status{display:grid;width:18px;height:18px;place-items:center;border-radius:50%;background:var(--danger-soft);color:var(--danger)}.test-case.is-pass .test-status{background:var(--success-soft);color:var(--success)}.test-details{display:grid;gap:8px;padding:10px;border-top:1px solid var(--line)}.test-details>div{display:grid;grid-template-columns:45px minmax(0,1fr);gap:7px}.test-details span{color:var(--muted-2);font-size:8px;text-transform:uppercase}.test-details pre{overflow:auto;color:var(--ink);font-size:9px;white-space:pre-wrap}.file-title-block{flex:1}.file-toolbar-actions{justify-content:flex-end}.file-editor-layout{display:grid;grid-template-columns:minmax(420px,1.6fr) minmax(300px,.8fr);min-height:0;flex:1;overflow:hidden}.file-editor-panel,.file-console-panel{min-width:0;min-height:0}.file-editor-panel{display:flex;background:var(--bg-elevated)}.file-editor-panel .code-editor{min-height:0;max-height:none;flex:1}.file-console-panel{display:flex;flex-direction:column;border-left:1px solid var(--line-soft);background:var(--surface)}.file-console-panel>header{display:flex;min-height:55px;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--line-soft)}.file-console-panel>header>span{color:var(--muted-2);font-size:9px}.file-console{min-height:0;flex:1;overflow:auto;padding:14px;background:var(--bg-elevated)}.file-console.has-error{background:color-mix(in srgb,var(--danger-soft) 45%,var(--bg-elevated))}.file-console>pre{color:var(--ink);font-size:11px;line-height:1.65;white-space:pre-wrap;word-break:break-word}.file-console.has-error>pre:last-of-type{color:var(--danger)}.overlay-backdrop{position:fixed;z-index:1000;inset:0;display:grid;place-items:center;padding:24px;background:#030506ad;backdrop-filter:blur(5px);animation:overlay-in .13s var(--ease)}.modal-card{width:min(560px,calc(100vw - 32px));max-height:min(760px,calc(100vh - 48px));overflow:auto;border:1px solid var(--line-strong);border-radius:13px;background:var(--surface-raised);box-shadow:var(--shadow-modal);animation:modal-in .16s var(--ease)}.modal-header{display:flex;min-height:62px;align-items:center;justify-content:space-between;padding:11px 12px 10px 17px;border-bottom:1px solid var(--line)}.modal-header h2{margin-top:5px;font-size:15px;font-weight:650}.modal-footer{display:flex;min-height:59px;align-items:center;justify-content:flex-end;gap:7px;padding:11px 15px;border-top:1px solid var(--line)}.privacy-notice{display:flex;gap:11px;margin:16px;padding:12px;border:1px solid var(--success-line);border-radius:9px;background:var(--success-soft);color:var(--success)}.privacy-notice>svg{margin-top:1px}.privacy-notice strong{color:var(--success);font-size:11px}.privacy-notice p{margin-top:4px;color:var(--muted);font-size:10px;line-height:1.55}.privacy-notice code{color:var(--ink)}.book-auth-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;margin:0 16px 12px;padding:12px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.book-auth-panel label{display:grid;gap:6px}.book-auth-panel label span{color:var(--muted);font-size:10px;font-weight:700}.book-auth-panel input{width:100%;min-width:0;height:34px;padding:0 10px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--ink);font:inherit}.connected-book-row{display:grid;grid-template-columns:38px minmax(0,1fr) auto;align-items:center;gap:10px;margin:0 16px 12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.book-file-icon{display:grid;width:36px;height:36px;place-items:center;border:1px solid var(--line);border-radius:8px;background:var(--surface-raised);color:var(--accent-strong)}.connected-book-row>div{display:flex;min-width:0;flex-direction:column}.connected-book-row strong{overflow:hidden;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.connected-book-row span{color:var(--muted-2);font-size:9px}.book-dropzone{display:flex;width:calc(100% - 32px);min-height:190px;align-items:center;justify-content:center;flex-direction:column;gap:8px;margin:0 16px 16px;border:1px dashed var(--line-strong);border-radius:10px;background:var(--surface);color:var(--muted)}.book-dropzone:hover,.book-dropzone.is-dragging{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.dropzone-icon{display:grid;width:46px;height:46px;place-items:center;margin-bottom:3px;border:1px solid var(--line);border-radius:12px;background:var(--surface-raised)}.book-dropzone strong{font-size:12px}.book-dropzone>span:last-child{color:var(--muted-2);font-size:9px}.modal-form-field{display:grid;gap:7px;padding:22px 17px 28px}.modal-form-field label{color:var(--muted);font-size:10px;font-weight:600}.modal-form-field input{height:38px;border:1px solid var(--line);border-radius:8px;outline:0;padding:0 11px;background:var(--surface);color:var(--ink)}.modal-form-field input:focus{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}.settings-modal{width:min(650px,calc(100vw - 32px))}.settings-content{padding:4px 17px 20px}.settings-section{padding:18px 0;border-bottom:1px solid var(--line)}.settings-section:last-child{border-bottom:0}.settings-section>header h3,.privacy-section h3{font-size:12px}.settings-section>header p,.privacy-section p{margin-top:4px;color:var(--muted);font-size:10px}.settings-row{display:flex;min-height:54px;align-items:center;justify-content:space-between;gap:16px;margin-top:8px}.settings-row>div:first-child{display:flex;min-width:0;flex-direction:column}.settings-row strong{font-size:11px}.settings-row span{color:var(--muted-2);font-size:9px}.settings-password-form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;align-items:end;gap:10px;margin-top:12px}.settings-password-form label{display:grid;gap:6px;min-width:0}.settings-password-form label span{color:var(--muted-2);font-size:10px}.settings-password-form input{width:100%;height:38px;border:1px solid var(--line);border-radius:8px;padding:0 11px;background:var(--surface-soft);color:var(--text);font:inherit}.settings-password-form button{min-width:116px;height:38px}.settings-system-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;margin-top:12px}.settings-system-grid>div{padding:10px;border:1px solid var(--line);border-radius:7px;background:var(--surface)}.settings-system-grid dt{color:var(--muted-2);font-size:8px;text-transform:uppercase}.settings-system-grid dd{margin-top:4px;color:var(--ink);font-family:var(--font-mono);font-size:10px}.privacy-section{display:flex;gap:12px;align-items:center}.privacy-emblem{display:grid;width:42px;height:42px;flex:0 0 auto;place-items:center;border:1px solid var(--success-line);border-radius:10px;background:var(--success-soft);color:var(--success)}.confirm-detail{padding:24px 18px 30px;color:var(--muted);font-size:12px;line-height:1.75}.command-backdrop{place-items:start center;padding-top:min(16vh,150px)}.command-palette{width:min(640px,calc(100vw - 32px));overflow:hidden;border:1px solid var(--line-strong);border-radius:12px;background:var(--surface-raised);box-shadow:var(--shadow-modal);animation:modal-in .16s var(--ease)}.command-search{display:flex;height:54px;align-items:center;gap:10px;padding:0 12px 0 15px;border-bottom:1px solid var(--line);color:var(--muted)}.command-search input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--ink-strong);font-size:13px}.command-search input::placeholder{color:var(--muted-2)}.command-results{max-height:min(55vh,500px);overflow:auto;padding:6px}.command-group-label{padding:9px 8px 5px;color:var(--muted-2);font-size:8px;font-weight:750;letter-spacing:.08em;text-transform:uppercase}.command-row{display:grid;width:100%;grid-template-columns:31px minmax(0,1fr) auto;min-height:42px;align-items:center;gap:9px;padding:5px 7px;border-radius:7px;background:transparent;color:var(--muted);text-align:left}.command-row.is-selected{background:var(--surface-hover);color:var(--ink)}.command-icon{display:grid;width:29px;height:29px;place-items:center;border:1px solid var(--line);border-radius:7px;background:var(--surface)}.command-row>span:nth-child(2){display:flex;min-width:0;flex-direction:column}.command-row strong{overflow:hidden;font-size:11px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.command-row small{overflow:hidden;color:var(--muted-2);font-size:9px;text-overflow:ellipsis;white-space:nowrap}.command-empty{display:flex;min-height:150px;align-items:center;justify-content:center;flex-direction:column;gap:9px;color:var(--muted-2);font-size:10px}.command-footer{display:flex;height:34px;align-items:center;justify-content:flex-end;gap:13px;padding:0 10px;border-top:1px solid var(--line);color:var(--muted-2);font-size:9px}.command-footer span{display:inline-flex;align-items:center;gap:3px}.toast-region{position:fixed;z-index:1300;right:14px;bottom:14px;display:grid;width:min(360px,calc(100vw - 28px));gap:7px;pointer-events:none}.toast-item{display:grid;grid-template-columns:28px minmax(0,1fr);align-items:center;gap:9px;min-height:54px;padding:8px 11px;border:1px solid var(--line-strong);border-radius:9px;background:var(--surface-raised);box-shadow:var(--shadow-popover);animation:toast-in .18s var(--ease)}.toast-icon{display:grid;width:26px;height:26px;place-items:center;border-radius:7px;background:var(--surface-hover);color:var(--muted)}.toast-item.is-success .toast-icon{background:var(--success-soft);color:var(--success)}.toast-item.is-danger .toast-icon{background:var(--danger-soft);color:var(--danger)}.toast-item>div{display:flex;min-width:0;flex-direction:column}.toast-item strong{font-size:10px}.toast-item span{overflow:hidden;color:var(--muted);font-size:9px;text-overflow:ellipsis;white-space:nowrap}.floating-command-hint{position:fixed;z-index:80;right:13px;bottom:11px;display:none;height:27px;align-items:center;gap:6px;padding:0 8px;border:1px solid var(--line);border-radius:7px;background:var(--surface-raised);color:var(--muted);font-size:9px;box-shadow:var(--shadow-popover)}.boot-screen{display:flex;width:100%;height:100%;align-items:center;justify-content:center;flex-direction:column;background:var(--bg)}.boot-mark{display:grid;width:48px;height:48px;place-items:center;margin-bottom:14px;border:1px solid var(--line-strong);border-radius:13px;background:var(--ink-strong);color:var(--bg);font-size:22px;font-weight:850}.boot-screen>div:nth-child(2){display:flex;align-items:center;flex-direction:column}.boot-screen strong{font-size:14px}.boot-screen span{margin-top:4px;color:var(--muted);font-size:10px}.boot-progress{display:block;width:150px;height:2px;margin-top:17px!important;overflow:hidden;border-radius:999px;background:var(--surface-hover)}.boot-progress i{display:block;width:42%;height:100%;background:var(--accent);animation:boot-slide 1.15s ease-in-out infinite}.mini-spinner,.large-spinner{display:inline-block;border:2px solid color-mix(in srgb,currentColor 24%,transparent);border-top-color:currentColor;border-radius:50%;animation:spin .7s linear infinite}.mini-spinner{width:13px;height:13px}.large-spinner{width:28px;height:28px}html[data-density=comfortable]{--topbar-h: 54px}html[data-density=comfortable] .rail-button{height:47px}html[data-density=comfortable] .notebook-row,html[data-density=comfortable] .exercise-row,html[data-density=comfortable] .section-row{min-height:45px}html[data-density=comfortable] .notebook-cells{padding-top:36px}@media(max-width:1250px){.topbar{grid-template-columns:minmax(230px,1fr) minmax(220px,350px) minmax(250px,1fr)}.privacy-chip{display:none}.dashboard-hero{grid-template-columns:minmax(0,1.25fr) minmax(250px,.7fr);gap:28px}.practice-layout{grid-template-columns:240px minmax(390px,1fr) 250px}.variable-inspector{width:225px}}@media(max-width:1050px){.topbar{grid-template-columns:minmax(220px,1fr) minmax(210px,300px) auto}.kernel-chip span:last-child{display:none}.kernel-chip{width:25px;padding:0;justify-content:center}.dashboard-hero{grid-template-columns:1fr;align-items:start}.hero-status-panel{max-width:440px}.dashboard-panel{grid-column:span 12}.practice-layout{grid-template-columns:220px minmax(420px,1fr)}.result-panel{display:none}.file-editor-layout{grid-template-columns:minmax(420px,1fr) 290px}.reader-location small{display:none}}@media(max-width:900px){.app-shell{min-width:0}.topbar{grid-template-columns:minmax(0,1fr) auto}.topbar-center{display:none}.topbar-sidebar-toggle{display:inline-flex!important}.nav-rail{display:none}.context-sidebar{position:absolute;z-index:70;inset:var(--topbar-h) auto 0 0;box-shadow:var(--shadow-popover)}.sidebar-resizer,.app-shell.sidebar-collapsed .context-sidebar{display:none}.practice-layout,.file-editor-layout{grid-template-columns:1fr}.problem-panel,.file-console-panel{display:none}.study-split{grid-template-columns:1fr}.reader-pane,.splitter,.variable-inspector{display:none}.floating-command-hint{display:flex}}@media(max-width:640px){.topbar-subtitle,.breadcrumbs>span:nth-of-type(2),.breadcrumbs>svg:nth-of-type(1){display:none}.dashboard-view{padding:18px 14px 70px}.dashboard-hero{min-height:0;padding:28px 0}.hero-copy h1{font-size:38px}.hero-actions{flex-wrap:wrap}.hero-status-panel{grid-template-columns:76px minmax(0,1fr)}.hero-progress-ring{width:72px;height:72px}.hero-progress-ring:before{width:59px;height:59px}.reader-actions .toolbar-button,.notebook-actions .toolbar-button span,.practice-toolbar-actions .toolbar-button{display:none}.notebook-cells,.notebook-workspace.is-embedded .notebook-cells{width:calc(100% - 12px);min-width:0}.notebook-cell{grid-template-columns:38px minmax(0,1fr)}.cell-rail{padding-top:34px}.course-bar-row{grid-template-columns:25px minmax(0,1fr) 55px}.course-track,.privacy-chip,.kernel-chip{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-dot{0%,to{opacity:.45}50%{opacity:1}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-in{0%{opacity:0;transform:translateY(-7px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toast-in{0%{opacity:0;transform:translateY(7px)}to{opacity:1;transform:translateY(0)}}@keyframes boot-slide{0%{transform:translate(-120%)}50%{transform:translate(70%)}to{transform:translate(270%)}}:root,html[data-theme=light]{color-scheme:light;--bg: #f7f7fa;--bg-elevated: #f3f3f7;--surface: #ffffff;--surface-raised: #ffffff;--surface-soft: #f7f6fa;--surface-hover: #f1effa;--surface-active: #eae6fb;--ink: #383542;--ink-strong: #17151f;--muted: #726e7d;--muted-2: #9a96a5;--line: #e5e3eb;--line-soft: #efedf3;--line-strong: #d4d0dc;--accent: #6c4df6;--accent-strong: #5738dc;--accent-soft: #f0ecff;--accent-line: #cfc3ff;--success: #258a63;--success-soft: #eaf8f1;--success-line: #bfe8d5;--warning: #a86b17;--warning-soft: #fff5df;--danger: #d24d62;--danger-soft: #fff0f3;--danger-line: #f1c0c8;--purple: #7957eb;--cyan: #43a6b8;--shadow-popover: 0 14px 40px rgba(31, 24, 56, .12), 0 2px 8px rgba(31, 24, 56, .05);--shadow-modal: 0 30px 90px rgba(31, 24, 56, .18), 0 4px 16px rgba(31, 24, 56, .08);--radius-xs: 6px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--topbar-h: 64px;--rail-w: 0px}html[data-density=comfortable],html[data-density=compact]{--topbar-h: 64px}html[data-theme=dark]{color-scheme:dark;--bg: #171721;--bg-elevated: #1c1c28;--surface: #20202c;--surface-raised: #262635;--surface-soft: #2b2b3b;--surface-hover: #303044;--surface-active: #393750;--ink: #dedce7;--ink-strong: #f8f7fb;--muted: #a29eae;--muted-2: #797586;--line: #373647;--line-soft: #2d2c3c;--line-strong: #4a485d;--accent: #967cff;--accent-strong: #b4a3ff;--accent-soft: rgba(137, 105, 255, .15);--accent-line: rgba(165, 140, 255, .38);--success: #69c49b;--success-soft: rgba(65, 177, 126, .14);--success-line: rgba(101, 198, 154, .32);--warning: #e0ad59;--warning-soft: rgba(220, 166, 72, .14);--danger: #f18294;--danger-soft: rgba(237, 103, 126, .13);--danger-line: rgba(241, 130, 148, .32);--shadow-popover: 0 18px 50px rgba(0, 0, 0, .36), 0 2px 8px rgba(0, 0, 0, .22);--shadow-modal: 0 36px 100px rgba(0, 0, 0, .5), 0 4px 20px rgba(0, 0, 0, .28)}body{background:var(--bg);color:var(--ink);font-size:14px;line-height:1.55}::selection{background:#6c4df63d}.eyebrow,.section-label,.sidebar-caption{display:block;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:0;line-height:1.25;text-transform:none}.section-label{color:var(--muted-2)}.app-shell{min-width:920px;background:var(--bg)}.app-body{height:calc(100% - var(--topbar-h))}.main-region{background:var(--bg)}.nav-rail{display:none!important}.focus-exit-button{position:fixed;z-index:220;top:14px;right:16px;display:inline-flex;min-height:38px;align-items:center;gap:8px;padding:0 10px 0 12px;border:1px solid var(--line);border-radius:10px;background:color-mix(in srgb,var(--surface) 94%,transparent);box-shadow:var(--shadow-popover);color:var(--ink);font-size:12px;font-weight:760;backdrop-filter:blur(10px)}.focus-exit-button:hover{border-color:var(--accent-line);color:var(--accent-strong)}.focus-exit-button kbd{padding:2px 5px;border:1px solid var(--line);border-radius:5px;background:var(--surface-soft);color:var(--muted-2);font-size:9px}.icon-button,.toolbar-button,.primary-button,.secondary-button,.danger-button,.text-button{border-radius:9px;transition:background-color .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease}.icon-button{width:38px;height:38px;color:var(--muted)}.icon-button:hover,.icon-button.is-active{border-color:transparent;background:var(--surface-hover);color:var(--ink-strong)}.icon-button.tiny{width:30px;height:30px;border-radius:8px}.toolbar-button,.primary-button,.secondary-button,.danger-button{min-height:38px;padding:0 15px;font-size:13px;font-weight:700}.toolbar-button{height:38px;border:1px solid var(--line);background:var(--surface);color:var(--ink)}.toolbar-button:hover:not(:disabled),.toolbar-button.is-active{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.toolbar-button.is-success{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.primary-button{border:1px solid var(--accent);background:var(--accent);color:#fff!important;box-shadow:none}.primary-button:hover:not(:disabled){border-color:var(--accent-strong);background:var(--accent-strong);transform:none}.primary-button.compact,.secondary-button.compact{min-height:36px;padding-inline:13px}.secondary-button{border:1px solid var(--line);background:var(--surface);color:var(--ink-strong)}.secondary-button:hover:not(:disabled){border-color:var(--line-strong);background:var(--surface-soft)}.text-button{color:var(--accent-strong);font-size:13px;font-weight:700}.text-button:hover{color:var(--accent)}kbd{height:20px;min-width:20px;border:1px solid var(--line);border-bottom-color:var(--line-strong);border-radius:5px;background:var(--surface-soft);box-shadow:none;color:var(--muted);font-size:10px}.topbar{z-index:80;display:grid;grid-template-columns:minmax(520px,1fr) minmax(120px,260px) auto;height:var(--topbar-h);min-height:var(--topbar-h);gap:20px;padding:0 24px;border-bottom:1px solid var(--line-soft);background:color-mix(in srgb,var(--surface) 97%,transparent);box-shadow:0 1px #17151f05}.topbar-brand-area,.topbar-right,.topbar-context,.brand-button,.top-navigation{display:flex;align-items:center;min-width:0}.topbar-brand-area{gap:20px}.topbar-right{justify-content:flex-end;gap:6px}.topbar-sidebar-toggle{display:inline-flex!important;margin-right:-10px}.brand-button{flex:0 0 auto;gap:9px;padding:0;background:transparent}.brand-mark{display:grid;width:35px;height:35px;place-items:center;border:0;border-radius:10px;background:var(--accent);color:#fff}.brand-wordmark{color:var(--ink-strong);font-size:16px;font-weight:850;letter-spacing:-.035em}.top-navigation{align-self:stretch;gap:4px}.top-navigation button{position:relative;display:flex;height:100%;align-items:center;gap:7px;padding:0 13px;background:transparent;color:var(--muted);font-size:14px;font-weight:700}.top-navigation button:after{position:absolute;right:12px;bottom:-1px;left:12px;height:3px;border-radius:3px 3px 0 0;background:transparent;content:""}.top-navigation button:hover{color:var(--ink-strong)}.top-navigation button.is-active{color:var(--accent-strong)}.top-navigation button.is-active:after{background:var(--accent)}.topbar-context{justify-content:center;gap:8px;overflow:hidden;white-space:nowrap}.topbar-context strong{overflow:hidden;color:var(--ink);font-size:13px;font-weight:700;text-overflow:ellipsis}.topbar-context span{flex:0 0 auto;color:var(--muted-2);font-size:12px}.command-trigger{width:104px;height:38px;gap:7px;padding:0 8px 0 11px;border:1px solid var(--line);border-radius:9px;background:var(--surface-soft);color:var(--muted)}.command-trigger:hover{border-color:var(--line-strong);background:var(--surface-hover)}.command-trigger span{flex:1;color:var(--ink);font-size:12px}.command-trigger kbd{height:19px;min-width:28px;background:var(--surface)}.privacy-chip,.kernel-chip{height:30px;padding:0 10px;border:0;border-radius:999px;background:var(--surface-soft);color:var(--muted);font-size:11px;font-weight:650}.kernel-chip{max-width:150px}.status-dot{width:7px;height:7px;box-shadow:none}.kernel-chip.is-ready .status-dot{background:var(--success);box-shadow:none}.context-sidebar{z-index:50;min-width:252px;max-width:360px;border-right:1px solid var(--line-soft);background:var(--surface)}.sidebar-heading{height:78px;min-height:78px;padding:18px 16px 12px 20px}.sidebar-caption{margin-bottom:4px;color:var(--muted-2)}.sidebar-heading h2{margin:0;font-size:19px;font-weight:800;letter-spacing:-.025em}.sidebar-create-button{display:grid;width:34px;height:34px;place-items:center;border:1px solid var(--line);border-radius:9px;background:var(--surface);color:var(--accent-strong)}.sidebar-create-button:hover{border-color:var(--accent-line);background:var(--accent-soft)}.sidebar-search{height:40px;gap:8px;margin:0 14px 13px;padding:0 11px;border:1px solid var(--line);border-radius:10px;background:var(--surface-soft)}.sidebar-search:focus-within{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}.sidebar-search input{font-size:13px}.sidebar-scroll,.sidebar-home-content{padding:0 10px 18px}.progress-card{margin-bottom:10px;padding:14px;border:1px solid var(--line-soft);border-radius:12px;background:var(--surface-soft)}.progress-card-row{margin-bottom:10px}.progress-card-row>div{display:flex;align-items:baseline;gap:7px}.progress-card-row>div span{color:var(--muted);font-size:12px}.progress-card-row strong{font-size:20px;font-weight:850;color:var(--accent-strong)}.progress-card-row>span{color:var(--muted-2);font-size:11px}.progress-track,.course-track{height:6px;background:#e8e6ee}html[data-theme=dark] .progress-track,html[data-theme=dark] .course-track{background:#393848}.progress-track span,.course-track span{background:var(--accent)}.primary-sidebar-button{width:100%;height:40px;margin:0 0 12px;border:1px solid var(--accent-line);border-radius:10px;background:var(--accent-soft);color:var(--accent-strong);font-size:13px;font-weight:750}.primary-sidebar-button:hover{border-color:var(--accent);background:var(--accent);color:#fff}.chapter-group{margin-bottom:3px}.chapter-row{grid-template-columns:31px minmax(0,1fr) auto;min-height:44px;padding:7px 9px;border-radius:10px}.chapter-row:hover{background:var(--surface-soft)}.chapter-index{color:var(--muted-2);font-size:10px}.chapter-copy{color:var(--ink-strong);font-size:13px;font-weight:740}.chapter-chevron{display:grid;place-items:center;color:var(--muted-2);transition:transform .15s var(--ease),color .15s var(--ease)}.chapter-chevron.is-open{transform:rotate(90deg);color:var(--accent-strong)}.section-list-shell{display:grid;grid-template-rows:0fr;opacity:0;transform:translateY(-3px);transition:grid-template-rows .18s var(--ease),opacity .14s var(--ease),transform .18s var(--ease)}.section-list-shell.is-open{grid-template-rows:1fr;opacity:1;transform:translateY(0)}.section-list{min-height:0;overflow:hidden;padding:3px 0 9px 17px}.section-row{grid-template-columns:18px minmax(0,1fr);min-height:48px;gap:9px;padding:6px 10px;border-radius:10px}.section-row:hover{background:var(--surface-soft)}.section-row.is-active{background:var(--accent-soft);color:var(--accent-strong)}.section-row.is-active:before,.notebook-row.is-active:before,.exercise-row.is-active:before,.file-row.is-active:before{display:none}.section-row strong{color:inherit;font-size:13px;font-weight:720}.section-row small{margin-top:2px;color:var(--muted-2);font-size:11px}.section-state{width:15px;height:15px;border-color:var(--line-strong)}.notebook-row,.exercise-row{min-height:54px;padding:7px 9px;border-radius:10px}.notebook-row{grid-template-columns:34px minmax(0,1fr) auto;gap:9px}.exercise-row{grid-template-columns:32px minmax(0,1fr) auto;gap:9px}.notebook-row:hover,.exercise-row:hover{background:var(--surface-soft)}.notebook-row.is-active,.exercise-row.is-active{background:var(--accent-soft);color:var(--accent-strong)}.notebook-row strong,.exercise-row strong{color:inherit;font-size:13px;font-weight:720}.notebook-row small,.exercise-row small{margin-top:2px;font-size:11px}.list-leading-icon,.exercise-chapter{display:grid;width:32px;height:32px;place-items:center;border:1px solid var(--line);border-radius:9px;background:var(--surface-soft);color:var(--muted)}.exercise-chapter{font-size:10px}.is-active .list-leading-icon,.exercise-row.is-active .exercise-chapter{border-color:var(--accent-line);background:var(--surface);color:var(--accent-strong)}.file-row{height:38px;border-radius:9px;font-size:13px}.file-row:hover:not(:disabled){background:var(--surface-soft)}.file-row.is-active{background:var(--accent-soft);color:var(--accent-strong)}.sidebar-empty{min-height:150px;padding:24px;color:var(--muted-2);font-size:12px;text-align:center}.sidebar-resizer{z-index:54;width:6px;min-width:6px;margin-left:-3px}.sidebar-resizer:hover span,.sidebar-resizer:active span,.splitter:hover span,.splitter:active span{width:2px;background:var(--accent)}.dashboard-view{overflow:auto;padding:42px 36px 80px;background:var(--bg)}.dashboard-view>*{max-width:1180px;margin-inline:auto}.dashboard-welcome{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;margin-bottom:28px}.welcome-label{display:block;margin-bottom:9px;color:var(--accent-strong);font-size:13px;font-weight:800}.dashboard-welcome h1{font-size:clamp(30px,3.6vw,44px);font-weight:850;letter-spacing:-.045em;line-height:1.15}.dashboard-welcome p{max-width:620px;margin-top:10px;color:var(--muted);font-size:15px}.welcome-actions{display:flex;flex:0 0 auto;gap:9px}.resume-card{display:grid;grid-template-columns:210px minmax(0,1fr) 200px;align-items:center;gap:30px;min-height:236px;padding:30px 34px;border:1px solid #ded6ff;border-radius:18px;background:#f0ecff}html[data-theme=dark] .resume-card{border-color:#494166;background:#28253a}.resume-illustration{position:relative;display:grid;width:172px;height:158px;place-items:center;border-radius:28px;background:#dfd5ff}html[data-theme=dark] .resume-illustration{background:#37304d}.resume-book{position:relative;width:98px;height:112px;border:3px solid #2a2340;border-radius:8px 17px 17px 8px;background:#fff;box-shadow:9px 9px #7a5cf0}.resume-book:before{position:absolute;top:0;bottom:0;left:13px;width:2px;background:#e2deec;content:""}.resume-book span{position:absolute;left:28px;right:16px;height:3px;border-radius:3px;background:#b8aecf}.resume-book span:nth-child(1){top:28px;background:#6c4df6}.resume-book span:nth-child(2){top:49px}.resume-book span:nth-child(3){top:66px}.resume-code{position:absolute;right:2px;bottom:12px;display:grid;width:54px;height:44px;place-items:center;border:3px solid #2a2340;border-radius:11px;background:#252238;color:#fff;font-family:var(--font-mono);font-size:13px;font-weight:800}.resume-copy{min-width:0}.resume-caption{display:block;margin-bottom:9px;color:var(--accent-strong);font-size:12px;font-weight:800}.resume-copy>small{display:block;color:var(--muted);font-size:12px}.resume-copy h2{margin-top:4px;font-size:28px;font-weight:850;letter-spacing:-.035em}.resume-copy p{margin-top:8px;color:var(--muted);font-size:14px}.resume-progress-row{display:grid;grid-template-columns:minmax(0,1fr) 42px;align-items:center;gap:12px;margin-top:24px}.resume-progress-track{height:8px;overflow:hidden;border-radius:999px;background:#6049a429}.resume-progress-track span{display:block;height:100%;border-radius:inherit;background:var(--accent)}.resume-progress-row strong{color:var(--accent-strong);font-size:13px;text-align:right}.resume-action{display:flex;align-items:flex-end;flex-direction:column;gap:16px}.resume-action>span{color:var(--muted);font-size:12px}.dashboard-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:14px}.dashboard-card{display:flex;min-height:245px;flex-direction:column;padding:23px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}.dashboard-card-icon{display:grid;width:44px;height:44px;place-items:center;margin-bottom:22px;border-radius:13px}.dashboard-card-icon.is-purple{background:var(--accent-soft);color:var(--accent-strong)}.dashboard-card-icon.is-mint{background:var(--success-soft);color:var(--success)}.dashboard-card-copy>span,.dashboard-card-header>div>span{color:var(--muted-2);font-size:12px;font-weight:700}.dashboard-card-copy h2,.dashboard-card-header h2{margin-top:4px;font-size:19px;font-weight:830;letter-spacing:-.025em}.dashboard-card-copy p{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.7}.card-link{display:flex;width:fit-content;align-items:center;gap:3px;margin-top:auto;padding:0;background:transparent;color:var(--accent-strong);font-size:13px;font-weight:800}.dashboard-card-header{display:flex;align-items:flex-start;justify-content:space-between}.recent-notebook-card .recent-list{margin-top:14px}.recent-row{min-height:48px;padding:6px 4px;border-radius:9px}.recent-row:hover{background:var(--surface-soft)}.recent-icon{width:34px;height:34px;border:0;border-radius:10px;background:var(--surface-soft);color:var(--muted)}.recent-row strong{font-size:13px}.recent-row small{font-size:11px}.local-status{display:inline-flex;width:fit-content;align-items:center;gap:7px;margin-top:auto;color:var(--muted);font-size:12px}.local-status .status-dot.is-ok{background:var(--success)}.course-overview{margin-top:14px;padding:25px;border:1px solid var(--line);border-radius:16px;background:var(--surface)}.section-header h2{margin-top:3px;font-size:20px;font-weight:830}.section-header>span{color:var(--muted);font-size:12px}.course-bars{gap:5px;margin-top:21px}.course-bar-row{grid-template-columns:34px minmax(180px,.75fr) minmax(120px,1fr) 46px;min-height:36px;gap:14px}.course-index,.course-count{font-size:10px}.course-title{color:var(--ink);font-size:12px}.course-track{height:6px}.learn-view{background:var(--bg)}.study-split{grid-template-columns:minmax(0,var(--reader-ratio)) 8px minmax(0,calc(100% - var(--reader-ratio) - 8px))}.reader-pane,.study-notebook-pane{background:var(--surface)}.reader-pane{border-right:0}.study-notebook-pane{border-left:0}.reader-toolbar,.notebook-toolbar,.practice-toolbar,.file-toolbar{min-height:62px;padding:0 16px 0 18px;border-bottom:1px solid var(--line-soft);background:var(--surface)}.reader-location{gap:11px}.section-id{min-width:42px;height:32px;border:0;border-radius:9px;background:var(--accent-soft);color:var(--accent-strong);font-size:10px}.reader-location>div{gap:1px}.reader-context-trail{display:flex;order:0;max-width:min(420px,34vw);align-items:center;gap:4px;color:var(--muted-2);font-size:11px}.reader-context-trail span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-context-trail span:first-child{color:var(--accent-strong);font-weight:740}.reader-location small:not(.reader-context-trail){order:0;max-width:300px;color:var(--muted-2);font-size:11px}.reader-location strong{order:1;max-width:360px;color:var(--ink-strong);font-size:14px;font-weight:780}.reader-book-chip{display:inline-flex;min-width:0;max-width:min(220px,18vw);height:30px;align-items:center;gap:6px;padding:0 9px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--muted);font-size:11px;font-weight:680}.reader-book-chip span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.reader-book-chip.is-connected{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.reader-page-controls{gap:3px}.reader-page-controls label{height:36px;gap:5px;padding:0 10px;border-radius:9px;background:var(--surface-soft)}.reader-page-controls label span{font-size:10px;letter-spacing:0}.reader-page-controls input{width:38px;font-size:12px}.reader-page-controls small{font-size:10px}.reader-actions{gap:4px}.reader-stage{background:#ececf1}html[data-theme=dark] .reader-stage{background:#15151e}.book-frame{background:#fff}.book-empty-state{min-height:440px;padding:48px}.book-object{width:92px;height:110px;margin-bottom:24px;border:2px solid #353044;border-radius:7px 16px 16px 7px;background:#fff;box-shadow:10px 10px #d8d0fa}.book-object:before{height:5px;border-radius:4px;background:var(--accent)}.book-empty-label{color:var(--accent-strong);font-size:12px;font-weight:800}.book-empty-state h2{margin-top:8px;font-size:24px;font-weight:850}.book-empty-state p{max-width:500px;margin:11px 0 22px;color:var(--muted);font-size:14px}.book-empty-state small{margin-top:12px;font-size:11px}.reader-notes-panel{inset:16px 16px 16px auto;width:min(390px,calc(100% - 32px));border:1px solid var(--line);border-radius:14px;background:var(--surface)}.reader-notes-panel header{min-height:66px;padding:12px 12px 11px 17px}.reader-notes-panel header span{color:var(--muted-2);font-size:11px;font-weight:700}.reader-notes-panel h3{margin-top:3px;font-size:14px}.reader-notes-panel textarea{min-height:260px;padding:18px;font-size:14px}.reader-notes-panel footer{min-height:42px;padding:0 17px;font-size:11px}.lesson-footer{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);min-height:70px;align-items:center;gap:14px;padding:9px 14px;border-top:1px solid var(--line-soft);background:var(--surface)}.lesson-nav-button{display:flex;min-width:0;align-items:center;gap:10px;padding:7px 8px;border-radius:10px;background:transparent;color:var(--muted);text-align:left}.lesson-nav-button:hover:not(:disabled){background:var(--surface-soft);color:var(--ink-strong)}.lesson-nav-button>span{display:flex;min-width:0;flex-direction:column}.lesson-nav-button small{color:var(--muted-2);font-size:10px}.lesson-nav-button strong{overflow:hidden;max-width:230px;color:inherit;font-size:12px;font-weight:720;text-overflow:ellipsis;white-space:nowrap}.lesson-nav-button.is-next{justify-content:flex-end;text-align:right}.lesson-complete-button{display:inline-flex;min-height:42px;align-items:center;gap:7px;padding:0 18px;border:1px solid var(--accent);border-radius:10px;background:var(--accent);color:#fff;font-size:13px;font-weight:800}.lesson-complete-button.is-complete{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.splitter{width:8px;background:var(--bg)}.lab-view,.notebook-workspace{background:var(--surface)}.notebook-toolbar{padding-left:16px}.notebook-title-wrap{gap:9px}.notebook-icon,.file-type-icon{width:34px;height:34px;border:0;border-radius:10px;background:var(--accent-soft);color:var(--accent-strong)}.notebook-title-copy{display:grid;min-width:0;gap:1px}.notebook-context-trail{display:flex;max-width:min(420px,34vw);align-items:center;gap:4px;color:var(--muted);font-size:11px}.notebook-context-trail span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notebook-context-trail span:first-child{color:var(--accent-strong);font-weight:740}.notebook-title-input{width:min(420px,46vw);padding:5px 7px;font-size:14px;font-weight:780}.notebook-title-input:hover,.notebook-title-input:focus{border-color:var(--line);background:var(--surface-soft)}.save-indicator{gap:6px;font-size:11px}.save-indicator>span{width:7px;height:7px}.notebook-status-chip{display:inline-flex;height:30px;align-items:center;gap:6px;padding:0 9px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--muted);font-size:11px;font-weight:720;white-space:nowrap}.notebook-status-chip strong{color:inherit;font-size:11px}.notebook-status-chip.is-saved,.notebook-status-chip.is-kernel-ready{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.notebook-status-chip.is-saving,.notebook-status-chip.is-kernel-busy{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.notebook-status-chip.is-dirty,.notebook-status-chip.is-kernel-idle{border-color:color-mix(in srgb,var(--warning) 42%,var(--line));background:var(--warning-soft);color:var(--warning)}.notebook-status-chip.is-error,.notebook-status-chip.is-kernel-error{border-color:var(--danger-line);background:var(--danger-soft);color:var(--danger)}.notebook-actions{gap:6px}.notebook-scroll{background:var(--bg-elevated)}.notebook-cells{width:min(980px,calc(100% - 56px));min-width:520px;padding:30px 0 130px}.notebook-workspace.is-embedded .notebook-cells{width:calc(100% - 24px);min-width:0;padding-top:16px}.notebook-workspace.is-embedded .variable-inspector{display:none}.notebook-workspace.is-embedded .notebook-toolbar{gap:8px}.notebook-workspace.is-embedded .notebook-title-input{width:min(260px,32vw)}.notebook-cell{grid-template-columns:50px minmax(0,1fr);margin-bottom:14px;border:1px solid var(--line);border-radius:13px;background:var(--surface);box-shadow:0 1px #17151f05}.notebook-cell:focus-within,.notebook-cell.status-running{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}.cell-rail{min-height:98px;gap:9px;padding-top:39px;border-right-color:var(--line-soft)}.cell-run-button,.cell-type-icon{width:29px;height:29px;border-radius:9px;background:var(--surface-soft)}.cell-run-button:hover:not(:disabled){border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.execution-count{font-size:9px}.cell-header{height:40px;padding:0 9px 0 11px}.cell-kind-switch,.segmented-control{padding:3px;border:0;border-radius:8px;background:var(--surface-soft)}.cell-kind-switch button,.segmented-control button{height:25px;padding:0 9px;border-radius:6px;font-size:10px;font-weight:700}.cell-kind-switch button.is-active,.segmented-control button.is-active{background:var(--surface);color:var(--ink-strong);box-shadow:0 1px 3px #1f183814}.cell-time{font-size:9px}.note-cell-editor{min-height:90px;padding:17px 18px 20px;font-size:14px}.cell-stdin{min-height:42px;padding:6px 12px}.cell-stdin span{font-size:9px}.cell-stdin input{padding:6px 8px;border-radius:7px;background:var(--surface-soft);font-size:11px}.cell-output{border-top-color:var(--line);background:#f7f7fa}html[data-theme=dark] .cell-output{background:#1b1b27}.output-block{grid-template-columns:68px minmax(0,1fr);min-height:42px;padding:10px 13px}.output-label{font-size:9px}.output-block pre,.output-block strong{font-size:12px}.insert-cell-button{bottom:-11px;width:24px;height:24px;background:var(--surface)}.notebook-add-row button{height:36px;padding:0 13px;border-radius:9px;background:var(--surface);font-size:12px}.variable-inspector{width:276px;min-width:240px;border-left:0;background:var(--bg-elevated)}.variable-inspector>header{min-height:62px;padding:12px 15px}.variable-inspector h3{margin-top:3px;font-size:14px}.variable-inspector>header>span{min-width:24px;height:24px;font-size:10px}.variable-list{height:calc(100% - 62px);padding:9px}.variable-row{padding:11px;border-radius:9px}.variable-row:hover{border-color:var(--line);background:var(--surface-soft)}.variable-row strong{font-size:11px}.variable-row span{font-size:9px}.variable-row pre{font-size:10px}.code-editor{--editor-bg: var(--surface-raised);--editor-ink: var(--ink-strong);--editor-gutter-bg: var(--surface-soft);--editor-gutter-ink: var(--muted-2);--editor-line: var(--line);--tok-keyword: var(--purple);--tok-builtin: var(--accent-strong);--tok-string: var(--success);--tok-number: var(--warning);--tok-comment: var(--muted-2);--tok-operator: var(--cyan);--tok-decorator: var(--warning);--editor-line-height: 23px;--editor-padding-y: 28px;grid-template-columns:46px minmax(0,1fr);min-height:calc(var(--editor-rows) * var(--editor-line-height) + var(--editor-padding-y));max-height:calc(var(--editor-rows) * var(--editor-line-height) + var(--editor-padding-y));background:var(--editor-bg);color:var(--editor-ink)}.code-gutter{padding:12px 10px 12px 0;border-right-color:var(--editor-line);background:var(--editor-gutter-bg);color:var(--editor-gutter-ink);font-size:10px}.code-layer{min-height:0}.code-highlight,.code-textarea{padding:14px 16px;font-size:14px}.code-textarea{caret-color:var(--accent-strong)}.code-textarea::selection{background:var(--accent-soft)}.code-editor.is-focused{box-shadow:inset 3px 0 0 var(--accent)}.tok-keyword{color:var(--tok-keyword)}.tok-builtin{color:var(--tok-builtin)}.tok-string{color:var(--tok-string)}.tok-number{color:var(--tok-number)}.tok-comment{color:var(--tok-comment)}.tok-operator{color:var(--tok-operator)}.tok-decorator{color:var(--tok-decorator)}.practice-view{--practice-bg: var(--bg);--practice-surface: var(--surface);--practice-surface-2: var(--surface-soft);--practice-line: var(--line);--practice-ink: var(--ink);--practice-ink-strong: var(--ink-strong);--practice-muted: var(--muted);background:var(--practice-bg);color:var(--practice-ink)}.practice-view h1,.practice-view h2,.practice-view h3,.practice-view strong{color:var(--practice-ink-strong)}.practice-toolbar{min-height:66px;padding-inline:18px 16px;border-bottom-color:var(--practice-line);background:var(--practice-surface)}.practice-title-block{gap:11px}.exercise-number{height:32px;padding:0 10px;border:0;border-radius:9px;background:var(--accent-soft);color:var(--accent-strong);font-size:10px}.practice-title-block h1{font-size:15px;font-weight:780}.practice-title-block>div{min-width:0}.practice-context-trail{display:flex;max-width:min(360px,34vw);align-items:center;gap:4px;margin-bottom:2px;color:var(--practice-muted);font-size:11px}.practice-context-trail span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.practice-context-trail span:first-child{color:var(--accent-strong);font-weight:740}.practice-toolbar .toolbar-button{border-color:var(--practice-line);background:var(--practice-surface-2);color:var(--practice-ink)}.practice-toolbar .icon-button{color:var(--practice-muted)}.practice-toolbar .icon-button:hover{background:var(--practice-surface-2);color:var(--practice-ink)}.practice-status-chip{display:inline-flex;height:30px;align-items:center;gap:6px;padding:0 9px;border:1px solid var(--practice-line);border-radius:8px;background:var(--practice-surface-2);color:var(--practice-muted);font-size:11px;font-weight:720;white-space:nowrap}.practice-status-chip strong{color:inherit;font-size:11px}.practice-status-chip span{color:var(--muted-2);font-size:10px;font-weight:680}.practice-status-chip.is-running{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.practice-status-chip.is-pass{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.practice-status-chip.is-fail{border-color:var(--danger-line);background:var(--danger-soft);color:var(--danger)}.practice-layout{grid-template-columns:360px minmax(620px,1fr);background:var(--practice-bg)}.problem-panel{display:block;padding:30px 26px;border-right:1px solid var(--practice-line);background:var(--practice-surface)}.problem-heading h2{margin-top:5px;font-size:21px;font-weight:830}.practice-view .section-label{color:var(--muted-2)}.problem-prompt{margin-top:24px;color:var(--practice-ink);font-size:14px;line-height:1.9}.problem-spec{margin-top:28px;border-block-color:var(--practice-line)}.problem-spec>div{min-height:44px;border-bottom-color:var(--practice-line)}.problem-spec span{color:var(--practice-muted);font-size:11px}.problem-spec code,.problem-spec strong{color:var(--practice-ink);font-size:11px}.practice-tip{gap:11px;margin-top:24px;padding:14px;border-color:var(--practice-line);border-radius:11px;background:var(--practice-surface-2);color:var(--practice-muted)}.practice-tip strong{font-size:12px}.practice-tip p{margin-top:5px;font-size:11px;line-height:1.7}.practice-tip>svg{color:var(--accent-strong)}.practice-workspace{display:grid;min-width:0;min-height:0;grid-template-rows:minmax(460px,1.55fr) minmax(210px,.7fr);overflow:hidden}.solution-panel{min-height:0;background:var(--practice-bg)}.solution-panel .code-editor,.file-editor-panel .code-editor{height:100%;min-height:0;max-height:none}.solution-heading,.result-heading{min-height:58px;padding:11px 16px;border-bottom-color:var(--practice-line);background:var(--practice-surface)}.solution-heading h2,.result-heading h2{margin-top:3px;font-size:14px}.solution-meta span{height:25px;padding:0 9px;border-color:var(--practice-line);color:var(--practice-muted);font-size:9px;line-height:23px}.solution-shortcut{min-height:38px;border-top-color:var(--practice-line);background:var(--practice-surface);color:var(--practice-muted)}.solution-shortcut kbd{border-color:var(--practice-line);background:var(--practice-surface-2);color:var(--practice-muted)}.result-panel{display:block;min-height:0;padding:0;border-top:1px solid var(--practice-line);border-left:0;background:var(--practice-surface)}.result-panel>.result-heading{position:sticky;top:0;z-index:2}.result-empty{min-height:160px;color:var(--practice-muted)}.result-empty-icon{width:44px;height:44px;margin-bottom:10px;border-color:var(--practice-line);background:var(--practice-surface-2);color:var(--practice-muted)}.result-empty strong{font-size:12px}.result-empty p{color:var(--muted-2);font-size:10px}.test-results{padding:15px 17px 22px}.test-summary{padding-bottom:13px}.test-summary span{color:var(--practice-muted)}.test-case-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.test-case{border-color:var(--practice-line);background:var(--practice-surface-2)}.test-case summary{min-height:40px;color:var(--practice-muted)}.test-case summary strong{color:var(--practice-muted)}.test-details{border-top-color:var(--practice-line)}.test-details span{color:var(--muted-2)}.test-details pre{color:var(--practice-ink)}.grade-error{border-color:var(--danger-line);background:var(--danger-soft)}.files-view{background:var(--surface)}.file-toolbar{min-height:64px}.file-title-block{gap:10px}.file-title-block>div{min-width:0}.file-title-block h1{font-size:14px;font-weight:780}.file-context-trail{display:flex;max-width:min(460px,38vw);align-items:center;gap:4px;margin-bottom:2px;color:var(--muted);font-size:11px}.file-context-trail span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-context-trail span:first-child{color:var(--accent-strong);font-weight:740}.file-title-block>div>span:not(.file-context-trail){max-width:460px;margin-top:2px;font-size:11px}.file-status-chip{display:inline-flex;height:30px;align-items:center;gap:6px;padding:0 9px;border:1px solid var(--line);border-radius:8px;background:var(--surface-soft);color:var(--muted);font-size:11px;font-weight:720;white-space:nowrap}.file-status-chip strong{color:inherit;font-size:11px}.file-status-chip span{color:var(--muted-2);font-size:10px;font-weight:680}.file-status-chip.is-running{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-strong)}.file-status-chip.is-saved{border-color:var(--success-line);background:var(--success-soft);color:var(--success)}.file-status-chip.is-dirty{border-color:color-mix(in srgb,var(--warning) 42%,var(--line));background:var(--warning-soft);color:var(--warning)}.file-status-chip.is-error{border-color:var(--danger-line);background:var(--danger-soft);color:var(--danger)}.language-chip{height:27px;padding:0 9px;border:0;background:var(--surface-soft);font-size:10px}.file-editor-layout{grid-template-columns:minmax(560px,1fr) 320px}.file-editor-panel{background:var(--surface-raised)}.file-console-panel{border-left-color:var(--line-soft);background:var(--surface)}.file-console-panel>header{min-height:60px;padding:11px 16px}.file-console-panel>header h2{margin-top:3px;font-size:14px}.file-console-panel>header>span{font-size:10px}.file-console{padding:16px;background:var(--surface-soft);color:var(--ink)}.file-console>pre{color:var(--ink);font-size:12px}.file-console.has-error{background:var(--danger-soft)}.console-empty{color:var(--muted)}.notebook-empty-state,.empty-main-view{background:var(--bg-elevated)}.empty-symbol{width:58px;height:58px;margin-bottom:17px;border:0;border-radius:16px;background:var(--accent-soft);color:var(--accent-strong)}.notebook-empty-state h2,.empty-main-view h2{font-size:19px;font-weight:820}.notebook-empty-state p,.empty-main-view p{margin-top:8px;font-size:13px}.overlay-backdrop{background:#1916257a;backdrop-filter:blur(3px)}.modal-card{border-color:var(--line);border-radius:17px;background:var(--surface)}.modal-header{min-height:70px;padding:13px 15px 12px 21px}.modal-header h2{margin-top:3px;font-size:18px;font-weight:820}.modal-footer{min-height:68px;padding:13px 18px}.privacy-notice{margin:20px;padding:14px;border-radius:11px}.privacy-notice strong{font-size:12px}.privacy-notice p{font-size:11px}.connected-book-row{margin:0 20px 14px;padding:12px;border-radius:11px}.book-dropzone{width:calc(100% - 40px);min-height:210px;margin:0 20px 20px;border-radius:14px}.book-dropzone strong{font-size:14px}.book-dropzone>span:last-child{font-size:11px}.dropzone-icon{width:52px;height:52px;border:0;border-radius:15px;background:var(--accent-soft);color:var(--accent-strong)}.modal-form-field{gap:8px;padding:26px 21px 34px}.modal-form-field label{font-size:12px}.modal-form-field input{height:44px;border-radius:10px;padding:0 13px;font-size:14px}.settings-content{padding:4px 21px 22px}.settings-section{padding:21px 0}.settings-section>header h3,.privacy-section h3{font-size:14px}.settings-section>header p,.privacy-section p{font-size:11px}.settings-row{min-height:62px}.settings-row strong{font-size:13px}.settings-row span{font-size:11px}.settings-system-grid>div{padding:12px;border-radius:10px}.command-palette{border-color:var(--line);border-radius:16px}.command-search{height:62px;padding:0 15px 0 18px}.command-search input{font-size:15px}.command-results{padding:8px}.command-row{min-height:50px;padding:6px 9px;border-radius:10px}.command-row.is-selected{background:var(--accent-soft);color:var(--accent-strong)}.command-icon{width:34px;height:34px;border:0;border-radius:9px;background:var(--surface-soft)}.command-row strong{font-size:13px}.command-row small{font-size:11px}.toast-item{min-height:62px;padding:10px 13px;border-color:var(--line);border-radius:12px}.toast-item strong{font-size:12px}.toast-item span{font-size:11px}.boot-mark{border:0;background:var(--accent);color:#fff}.auth-screen{display:grid;min-height:100vh;place-items:center;padding:24px;background:var(--bg)}.auth-panel{width:min(100%,420px);border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow-popover)}.auth-brand{display:flex;gap:12px;align-items:center;padding:22px 22px 18px;border-bottom:1px solid var(--line-soft)}.auth-brand strong{display:block;font-size:18px}.auth-brand span:last-child{color:var(--text-muted);font-size:12px}.auth-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding:12px 14px 0}.auth-tabs button{height:38px;border:1px solid transparent;border-radius:9px;background:transparent;color:var(--text-muted);font-weight:720}.auth-tabs button.is-active{border-color:var(--line);background:var(--surface-soft);color:var(--text)}.auth-form{display:grid;gap:13px;padding:18px 22px 22px}.auth-form label{display:grid;gap:7px;color:var(--text-muted);font-size:12px;font-weight:700}.auth-form input{height:42px;width:100%;border:1px solid var(--line);border-radius:9px;padding:0 12px;background:var(--surface-soft);color:var(--text)}.auth-check{display:flex!important;grid-template-columns:none;align-items:center;gap:9px!important}.auth-check input{width:16px;height:16px}.auth-submit{display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;border:0;border-radius:10px;background:var(--accent);color:#fff;font-weight:780}.room-grid-view{min-height:100%;overflow:auto;padding:26px;background:var(--bg);color:var(--ink)}.room-workbench{display:grid;gap:16px;margin-bottom:20px;border:1px solid var(--line);border-radius:8px;padding:18px;background:var(--surface)}.room-grid-head{display:flex;align-items:center;justify-content:space-between;gap:20px}.room-grid-head h1{margin-top:4px;font-size:24px;letter-spacing:0}.room-primary-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;border:1px solid var(--accent-line);border-radius:8px;padding:0 13px;background:var(--accent);color:#fff;font-weight:780}.room-stat-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.room-stat-strip span{display:flex;min-height:52px;align-items:center;justify-content:space-between;border:1px solid var(--line-soft);border-radius:8px;padding:0 12px;background:var(--surface-soft);color:var(--muted);font-size:12px;font-weight:720}.room-stat-strip strong{color:var(--ink-strong);font-size:22px}.room-toolbar{display:grid;grid-template-columns:minmax(240px,1fr) auto;gap:12px;align-items:center}.room-search-field{display:flex;height:42px;align-items:center;gap:9px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:var(--bg-elevated);color:var(--muted)}.room-search-field:focus-within{border-color:var(--accent-line);box-shadow:0 0 0 3px var(--accent-soft)}.room-search-field input{min-width:0;flex:1;border:0;outline:0;background:transparent;color:var(--ink)}.room-search-field input::placeholder{color:var(--muted-2)}.room-filter-tabs{display:inline-flex;gap:4px;border:1px solid var(--line);border-radius:8px;padding:4px;background:var(--bg-elevated)}.room-filter-tabs button{min-height:32px;border-radius:6px;padding:0 11px;background:transparent;color:var(--muted);font-size:12px;font-weight:760}.room-filter-tabs button.is-active{background:var(--surface);color:var(--ink-strong);box-shadow:0 1px 3px color-mix(in srgb,var(--ink) 9%,transparent)}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(236px,1fr));gap:14px}.room-card{position:relative;min-height:238px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--ink);overflow:hidden;transition:border-color .14s var(--ease),background .14s var(--ease),transform .14s var(--ease)}.room-card:hover{border-color:var(--line-strong);background:var(--surface-raised);transform:translateY(-1px)}.room-card-action,.room-new-card{display:grid;width:100%;height:100%;min-height:238px;border:0;background:transparent;color:inherit;text-align:left}.room-new-card{place-items:center;align-content:center;gap:9px;border:1.5px dashed var(--line-strong);background:var(--bg-elevated);text-align:center}.room-new-card strong{font-size:22px}.room-new-card small{color:var(--muted);font-size:12px}.room-new-icon{display:grid;width:74px;height:74px;place-items:center;border-radius:50%;background:var(--surface-soft);color:var(--ink-strong)}.room-thumb{display:grid;min-height:124px;place-items:center;margin:12px 12px 0;border-radius:6px;background:var(--surface-raised);color:var(--ink-strong)}.room-thumb span{margin-top:-22px;color:var(--muted-2);font-size:10px;font-weight:820;letter-spacing:0}.room-card-body{display:grid;gap:8px;padding:13px 14px 15px}.room-title-row,.room-meta-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.room-title-row strong{min-width:0;overflow:hidden;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.room-type-pill{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 9px;background:var(--surface-soft);color:var(--ink);font-size:11px;font-weight:800}.room-meta-row time{color:var(--muted);font-size:11px}.room-file-line{min-width:0;overflow:hidden;color:var(--muted-2);font-size:11px;font-weight:680;text-overflow:ellipsis;white-space:nowrap}.room-description{display:-webkit-box;min-height:30px;overflow:hidden;color:var(--muted);font-size:12px;line-height:1.45;-webkit-box-orient:vertical;-webkit-line-clamp:2}.room-card-cta{display:inline-flex;width:fit-content;align-items:center;gap:4px;margin-top:2px;color:var(--accent-strong);font-size:12px;font-weight:820}.room-card:hover .room-card-cta{text-decoration:underline;text-underline-offset:3px}.room-empty{display:grid;justify-items:center;gap:8px;margin-top:28px;padding:34px;border:1px solid var(--line);border-radius:8px;background:var(--surface);color:var(--muted)}.room-empty strong{color:var(--ink-strong)}.room-dialog-backdrop{color:var(--text)}.room-dialog{display:grid;gap:14px;width:min(100%,440px);border:1px solid var(--line);border-radius:12px;padding:18px;background:var(--surface);box-shadow:var(--shadow-popover)}.room-dialog-head{display:flex;align-items:center;justify-content:space-between;gap:16px}.room-dialog h2{margin-top:3px;font-size:19px}.room-dialog label{display:grid;gap:7px;color:var(--text-muted);font-size:12px;font-weight:720}.room-dialog input,.room-dialog textarea{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 11px;background:var(--surface-soft);color:var(--text);resize:vertical}.room-dialog input{min-height:42px}.room-dialog-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border:0;border-radius:9px;background:var(--accent);color:#fff;font-weight:780}.admin-view{display:grid;align-content:start;gap:18px;padding:26px;overflow:auto;background:var(--bg-elevated)}.admin-header,.admin-summary,.admin-user-row,.admin-audit,.admin-room-panel{border:1px solid var(--line);background:var(--surface)}.admin-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-radius:12px}.admin-header h1{margin-top:3px;font-size:22px}.admin-summary{display:grid;grid-template-columns:repeat(3,minmax(0,160px)) minmax(180px,auto);gap:12px;padding:14px;border-radius:12px}.admin-summary>div,.admin-summary>button{min-height:62px;border:1px solid var(--line-soft);border-radius:10px;background:var(--surface-soft)}.admin-summary>div{display:grid;align-content:center;padding:10px 12px}.admin-summary span,.admin-user-row span{color:var(--text-muted);font-size:11px}.admin-summary strong{font-size:22px}.admin-summary>button{display:flex;align-items:center;justify-content:center;gap:8px;color:var(--text);font-weight:760}.admin-table{display:grid;gap:8px}.admin-room-panel{display:grid;gap:14px;padding:16px;border-radius:12px}.admin-room-form{display:grid;grid-template-columns:minmax(160px,1fr) minmax(220px,1.4fr) auto;gap:10px;align-items:end}.admin-room-form label{display:grid;gap:7px;color:var(--text-muted);font-size:11px;font-weight:720}.admin-room-form input{width:100%;min-height:38px;border:1px solid var(--line);border-radius:8px;padding:0 10px;background:var(--surface-soft);color:var(--text)}.admin-room-form button,.admin-room-request-row button{min-height:38px;border:1px solid var(--line);border-radius:8px;padding:0 12px;background:var(--surface-soft);color:var(--text);font-weight:740}.admin-room-form button{display:inline-flex;align-items:center;justify-content:center;gap:7px}.admin-room-request-list{display:grid;gap:8px}.admin-room-request-row{display:grid;grid-template-columns:minmax(220px,1fr) 82px auto;gap:12px;align-items:center;min-height:62px;border:1px solid var(--line-soft);border-radius:9px;padding:11px 12px;background:var(--surface-soft)}.admin-room-request-row strong{display:block;font-size:13px}.admin-room-request-row span,.admin-room-request-row small{display:block;color:var(--text-muted);font-size:11px}.admin-room-request-row small{margin-top:4px}.admin-user-row{display:grid;grid-template-columns:minmax(180px,1fr) 72px 72px auto;align-items:center;gap:12px;min-height:68px;padding:12px 14px;border-radius:10px}.admin-user-row strong{display:block;font-size:13px}.status-badge,.role-badge{display:inline-flex;align-items:center;justify-content:center;min-height:28px;border-radius:999px;background:var(--surface-soft);font-weight:760}.status-badge.is-active{color:var(--success)}.status-badge.is-pending{color:var(--warning)}.status-badge.is-disabled,.status-badge.is-rejected{color:var(--danger)}.admin-actions{display:flex;justify-content:flex-end;gap:7px;flex-wrap:wrap}.admin-actions button,.icon-text-button{min-height:34px;border:1px solid var(--line);border-radius:8px;padding:0 10px;background:var(--surface-soft);color:var(--text);font-weight:720}.icon-text-button{display:inline-flex;align-items:center;gap:7px}.admin-empty{display:grid;min-height:160px;place-items:center;color:var(--text-muted)}.admin-audit{display:grid;gap:12px;padding:16px;border-radius:12px}.admin-section-heading{display:flex;align-items:center;justify-content:space-between;gap:14px}.admin-section-heading h2{margin-top:3px;font-size:17px}.admin-audit-list{display:grid;gap:8px}.admin-audit-row{display:grid;grid-template-columns:minmax(140px,1fr) minmax(120px,1fr) auto;align-items:center;gap:12px;min-height:44px;padding:10px 12px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface-soft)}.admin-audit-row strong{font-size:12px}.admin-audit-row span,.admin-audit-row time{color:var(--text-muted);font-size:11px}@media(max-width:1380px){.topbar{grid-template-columns:minmax(500px,1fr) auto}.topbar-context,.privacy-chip{display:none}.resume-card{grid-template-columns:180px minmax(0,1fr) 190px}.resume-illustration{width:155px}.practice-layout{grid-template-columns:320px minmax(560px,1fr)}}@media(max-width:1160px){.top-navigation button{padding-inline:10px}.top-navigation button svg{display:none}.kernel-chip span:last-child{display:none}.kernel-chip{width:30px;padding:0;justify-content:center}.dashboard-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.local-card{grid-column:span 2;min-height:200px}.resume-card{grid-template-columns:160px minmax(0,1fr)}.resume-action{grid-column:2;align-items:flex-start;flex-direction:row;justify-content:space-between}.practice-layout{grid-template-columns:290px minmax(520px,1fr)}.test-case-list{grid-template-columns:1fr}.variable-inspector{width:240px}}@media(max-width:960px){.app-shell{min-width:0}.topbar{grid-template-columns:minmax(0,1fr) auto;padding:0 12px}.top-navigation button span{display:none}.top-navigation button svg{display:block}.top-navigation button{width:42px;justify-content:center;padding:0}.command-trigger{width:40px;padding:0;justify-content:center}.command-trigger span,.command-trigger kbd{display:none}.context-sidebar{position:absolute;z-index:75;inset:var(--topbar-h) auto 0 0;box-shadow:var(--shadow-popover)}.sidebar-resizer,.app-shell.sidebar-collapsed .context-sidebar{display:none}.dashboard-view{padding:30px 22px 70px}.dashboard-welcome{align-items:flex-start;flex-direction:column}.resume-card{grid-template-columns:130px minmax(0,1fr);padding:24px}.resume-illustration{width:120px;height:130px}.resume-book{width:76px;height:90px}.dashboard-card-grid{grid-template-columns:1fr}.local-card{grid-column:auto}.practice-layout{grid-template-columns:1fr;overflow:auto}.problem-panel{max-height:360px;border-right:0;border-bottom:1px solid var(--practice-line)}.practice-workspace{min-height:700px}.file-editor-layout{grid-template-columns:1fr}.file-console-panel,.variable-inspector{display:none}.study-split{grid-template-columns:1fr}.reader-pane,.splitter{display:none}.room-grid-view{padding:26px 20px 70px}.room-grid-head{align-items:flex-start;flex-direction:column}.room-toolbar{grid-template-columns:1fr}.room-filter-tabs{width:100%}.room-filter-tabs button{flex:1}.admin-room-form,.admin-room-request-row,.admin-user-row{grid-template-columns:1fr;align-items:start}.admin-actions{justify-content:flex-start}}@media(max-width:680px){.brand-wordmark{display:none}.topbar-brand-area{gap:7px}.top-navigation{gap:0}.topbar-right .kernel-chip,.topbar-right>.icon-button:nth-last-of-type(2){display:none}.dashboard-view{padding:24px 14px 60px}.dashboard-welcome h1{font-size:32px}.welcome-actions{width:100%}.welcome-actions button{flex:1}.resume-card{grid-template-columns:1fr}.resume-illustration{display:none}.resume-action{grid-column:auto;align-items:stretch;flex-direction:column}.resume-action .primary-button{width:100%}.course-bar-row{grid-template-columns:30px minmax(0,1fr) 40px}.course-track,.practice-toolbar-actions .toolbar-button{display:none}.notebook-cells,.notebook-workspace.is-embedded .notebook-cells{width:calc(100% - 14px);min-width:0}.notebook-cell{grid-template-columns:40px minmax(0,1fr)}.cell-rail{padding-top:40px}.auth-screen{padding:14px}.admin-view{padding:16px}.room-workbench{padding:14px}.room-stat-strip,.room-grid{grid-template-columns:1fr}.room-card,.room-card-action,.room-new-card{min-height:218px}.room-thumb{min-height:116px}.admin-header,.admin-summary{grid-template-columns:1fr}.admin-header{align-items:stretch;flex-direction:column}.admin-audit-row,.settings-password-form{grid-template-columns:1fr}.settings-password-form button{width:100%}}@media(prefers-reduced-motion:reduce){.section-list-shell,.chapter-chevron{transition:none}}
