@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";@import"https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700&display=swap";:root{--bg: #0B0F14;--bg-1: #11161D;--bg-2: #161C25;--bg-3: #1E2531;--line: #232B38;--line-2: #2D3543;--ink: #E6EDF3;--ink-dim: #B6C2CF;--ink-mute: #7D8896;--ink-faint: #525C6B;--accent: #39D353;--accent-dim: #2BA84A;--accent-soft: rgba(57, 211, 83, .12);--mode-normal: #4C8DFF;--mode-insert: #39D353;--mode-visual: #FF8A3D;--mode-command: #F5C451;--mode-replace: #E5484D;--level-beginner: #39D353;--level-intermediate: #F5C451;--level-advanced: #E5484D;--level-bonus: #B388FF;--radius-sm: 4px;--radius: 6px;--radius-lg: 10px;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--font-ui: "Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--shadow-sm: 0 1px 0 rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 8px 24px rgba(0,0,0,.4);--shadow-lg: 0 24px 60px rgba(0,0,0,.55)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--font-ui);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{min-height:100vh;background-image:radial-gradient(rgba(255,255,255,.025) 1px,transparent 1px);background-size:24px 24px;background-position:0 0}button{font-family:inherit;color:inherit}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.app{min-height:100vh;display:flex;flex-direction:column}.route-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:100;pointer-events:none}.route-progress-bar{height:100%;background:var(--accent);box-shadow:0 0 8px var(--accent);transform-origin:left}.route-progress-bar.loading{animation:route-progress-grow 2.2s cubic-bezier(.1,.7,.3,1) forwards}.route-progress-bar.done{width:100%;animation:route-progress-finish .4s ease forwards}@keyframes route-progress-grow{0%{width:0}40%{width:55%}80%{width:82%}to{width:92%}}@keyframes route-progress-finish{0%{opacity:1}to{opacity:0}}@media (prefers-reduced-motion: reduce){.route-progress-bar.loading{animation:none;width:92%}}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:24px;height:56px;padding:0 24px;background:#0b0f14d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-weight:600;letter-spacing:-.01em}.brand-mark{width:26px;height:26px;display:grid;place-items:center;background:var(--accent);color:#0b0f14;border-radius:5px;font-family:var(--font-mono);font-weight:700;font-size:13px;line-height:1}.brand-mark:before{content:":";transform:translateY(-1px)}.brand-name{font-size:14px;color:var(--ink)}.brand-name b{color:var(--accent);font-weight:600}.nav{display:flex;gap:2px;margin-left:8px}.nav a,.nav button{background:transparent;border:0;color:var(--ink-mute);font-size:13px;padding:8px 12px;border-radius:var(--radius);cursor:pointer;font-family:var(--font-mono);letter-spacing:.01em;display:flex;align-items:center;gap:6px;transition:color .12s ease,background .12s ease}.nav a .nk,.nav button .nk{display:inline-grid;place-items:center;width:18px;height:18px;font-size:10px;color:var(--ink-faint);border:1px solid var(--line);border-radius:3px;background:var(--bg-1)}.nav a:hover,.nav button:hover{color:var(--ink);background:var(--bg-1)}.nav a.active,.nav button.active{color:var(--ink);background:var(--bg-2)}.nav a.active .nk,.nav button.active .nk{color:var(--accent);border-color:var(--accent-dim)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.streak{display:flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--line);border-radius:999px;font-family:var(--font-mono);font-size:12px;color:var(--ink-dim);background:var(--bg-1)}.streak .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}.xp{font-family:var(--font-mono);font-size:12px;color:var(--ink-mute)}.xp b{color:var(--accent);font-weight:600}.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#4c8dff,#b388ff);display:grid;place-items:center;color:#fff;font-family:var(--font-mono);font-weight:600;font-size:12px;text-decoration:none;border:0;padding:0;cursor:pointer}.user-menu{position:relative}.user-menu-pop{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:6px;z-index:50}.user-menu-head{padding:8px 10px 10px;border-bottom:1px solid var(--line);margin-bottom:6px}.user-menu-name{font-size:13px;font-weight:600;color:var(--ink)}.user-menu-email{font-size:11px;color:var(--ink-mute);font-family:var(--font-mono)}.user-menu-item{display:block;width:100%;text-align:left;padding:8px 10px;border:0;background:transparent;color:var(--ink-dim);font-size:13px;border-radius:var(--radius-sm);cursor:pointer;text-decoration:none}.user-menu-item:hover{background:var(--bg-3);color:var(--ink)}.user-menu-danger{color:var(--mode-replace)}.user-menu-danger:hover{background:#e5484d1f;color:var(--mode-replace)}.page-profile{max-width:720px;margin:0 auto;padding:40px 24px 80px}.profile-head{display:flex;align-items:center;gap:18px;margin-bottom:28px}.profile-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#4c8dff,#b388ff);display:grid;place-items:center;color:#fff;font-family:var(--font-mono);font-weight:600;font-size:22px;flex-shrink:0}.profile-head h1{font-size:22px;margin:0}.profile-sub{color:var(--ink-mute);font-family:var(--font-mono);font-size:13px;margin-top:2px}.profile-providers{display:flex;gap:6px;margin-top:8px}.provider-chip{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-dim)}.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px;margin-bottom:28px}.profile-stat{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);padding:14px;text-align:center}.profile-stat b{display:block;font-size:18px;color:var(--ink)}.profile-stat span{font-size:11px;color:var(--ink-mute);font-family:var(--font-mono)}.profile-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}.profile-card h2{font-size:16px;margin:0 0 16px}.profile-note{color:var(--ink-mute);font-size:13px;margin:-6px 0 16px}.profile-form{display:flex;flex-direction:column;gap:14px}.profile-form .btn{align-self:flex-start}.profile-banner{padding:10px 12px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}.profile-banner.ok{background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-dim)}.profile-banner.err{background:#e5484d1f;color:var(--mode-replace);border:1px solid var(--mode-replace)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-1);color:var(--ink);font-family:var(--font-ui);font-size:14px;font-weight:500;cursor:pointer;transition:transform 80ms ease,background .12s ease,border-color .12s ease}.btn:hover{background:var(--bg-2);border-color:var(--line-2)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:active{transform:none}.btn-primary{background:var(--accent);color:#07120a;border-color:var(--accent);font-weight:600}.btn-primary:hover{background:#4ce066;border-color:#4ce066}.btn-ghost{background:transparent}.btn-mono{font-family:var(--font-mono);font-size:13px;letter-spacing:.01em}.btn-sm{padding:6px 10px;font-size:12px}.btn-block{width:100%;justify-content:center}.kbd{font-family:var(--font-mono);font-size:11px;padding:2px 5px;border:1px solid var(--line-2);border-bottom-width:2px;border-radius:3px;background:var(--bg-2);color:var(--ink-dim);line-height:1}.editor{background:#0a0d12;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-family:var(--font-mono);font-size:13px;display:flex;flex-direction:column;width:100%}.sandbox-editor .editor,.editor-area .editor{flex:1;min-width:0}.editor-titlebar{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#0e131a;border-bottom:1px solid var(--line);font-size:11px;color:var(--ink-mute)}.editor-dots{display:flex;gap:6px}.editor-dots span{width:10px;height:10px;border-radius:50%;background:#2d3543}.editor-dots span:nth-child(1){background:#ff5f57}.editor-dots span:nth-child(2){background:#febc2e}.editor-dots span:nth-child(3){background:#28c840}.editor-file{font-family:var(--font-mono);color:var(--ink-dim);display:flex;align-items:center;gap:6px}.editor-file .modified{color:var(--accent)}.editor-body{display:flex;flex:1;min-height:0;overflow:hidden;position:relative}.gutter{padding:12px 12px 12px 16px;text-align:right;color:var(--ink-faint);-webkit-user-select:none;user-select:none;border-right:1px solid var(--line);background:#0a0d12;min-width:56px;font-variant-numeric:tabular-nums}.gutter .ln{line-height:1.7}.gutter .ln.cursor{color:var(--ink)}.code{flex:1;padding:12px 16px;overflow:auto;white-space:pre;line-height:1.7;color:var(--ink);position:relative}.code .line{position:relative}.code .line.cursor-line{background:linear-gradient(to right,#4c8dff0f,#4c8dff00);margin:0 -16px;padding:0 16px}.tok-key{color:#ff8a3d}.tok-str{color:#39d353}.tok-fn{color:#4c8dff}.tok-num{color:#b388ff}.tok-com{color:var(--ink-faint);font-style:italic}.tok-typ{color:#f5c451}.tok-op{color:#b6c2cf}.tok-pun{color:var(--ink-mute)}.cursor-block{display:inline-block;width:.6em;height:1em;background:var(--mode-normal);vertical-align:text-bottom;margin:0 -.05em;animation:blink 1.1s steps(1) infinite}.cursor-bar{display:inline-block;width:2px;height:1.1em;background:var(--mode-insert);vertical-align:text-bottom;margin:0 -1px;animation:blink 1.1s steps(1) infinite}.cursor-overlay{background:#ff8a3d40;outline:1px solid var(--mode-visual)}@keyframes blink{50%{opacity:0}}.modebar{display:flex;align-items:stretch;background:#0e131a;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:11px;color:var(--ink-mute)}.modebar .mode{padding:5px 12px;font-weight:700;letter-spacing:.08em;color:#0b0f14;display:flex;align-items:center;gap:6px}.modebar .mode.NORMAL{background:var(--mode-normal)}.modebar .mode.INSERT{background:var(--mode-insert)}.modebar .mode.VISUAL{background:var(--mode-visual)}.modebar .mode.COMMAND{background:var(--mode-command)}.modebar .mode.REPLACE{background:var(--mode-replace);color:#fff}.modebar .seg{padding:5px 10px;border-right:1px solid var(--line);display:flex;align-items:center;gap:6px}.modebar .seg:last-child{border-right:0;margin-left:auto}.modebar .seg.git,.modebar .seg.pos{color:var(--ink-dim)}.cmdline{padding:4px 12px;background:#06080b;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:12px;color:var(--ink);display:flex;gap:0;min-height:26px;align-items:center}.cmdline .prompt{color:var(--mode-command);margin-right:2px}.surface{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius)}.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}.h1{font-size:64px;line-height:1.02;letter-spacing:-.03em;margin:0;font-weight:600}.h2{font-size:32px;line-height:1.1;letter-spacing:-.02em;margin:0;font-weight:600}.h3{font-size:20px;line-height:1.2;letter-spacing:-.01em;margin:0;font-weight:600}.h4{font-size:15px;line-height:1.3;margin:0;font-weight:600}.lede{color:var(--ink-dim);font-size:18px;line-height:1.55}.mono{font-family:var(--font-mono)}.page-landing{padding:64px 48px 96px;max-width:1280px;margin:0 auto}.hero{display:grid;grid-template-columns:1.1fr 1.3fr;gap:64px;align-items:center}.hero-prompt{font-family:var(--font-mono);font-size:12px;color:var(--ink-mute);margin-bottom:24px;display:flex;align-items:center;gap:8px}.hero-prompt:before{content:"$";color:var(--accent)}.hero h1{margin-bottom:20px}.hero h1 .accent{color:var(--accent)}.hero h1 .cursor-h{display:inline-block;width:.5em;height:.85em;background:var(--accent);vertical-align:-.05em;margin-left:4px;animation:blink 1.1s steps(1) infinite}.hero .lede{max-width:460px;margin-bottom:32px}.cta-row{display:flex;gap:12px;margin-bottom:32px;flex-wrap:wrap}.badges{display:flex;flex-wrap:wrap;gap:8px}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--bg-1);border:1px solid var(--line);border-radius:999px;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim)}.badge .tick{color:var(--accent);font-weight:700}.hero-editor-wrap{position:relative}.hero-editor-wrap:before{content:"";position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;background:radial-gradient(closest-side,rgba(57,211,83,.08),transparent 70%);pointer-events:none}.metrics-strip{margin-top:80px;padding:24px 32px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-1);display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.metric .v{font-family:var(--font-mono);font-size:28px;color:var(--ink);letter-spacing:-.02em}.metric .v .accent{color:var(--accent)}.metric .l{font-size:12px;color:var(--ink-mute);margin-top:4px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}.page-curriculum{display:grid;grid-template-columns:280px 1fr;min-height:calc(100vh - 56px)}.curr-sidebar{border-right:1px solid var(--line);background:var(--bg-1);padding:24px 16px;overflow-y:auto;position:sticky;top:56px;height:calc(100vh - 56px)}.curr-sidebar h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--ink-mute);text-transform:uppercase;padding:0 12px;margin:0 0 12px}.module-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);cursor:pointer;margin-bottom:2px;color:var(--ink-dim);transition:background .12s ease,color .12s ease}.module-item:hover,.module-item.active{background:var(--bg-2);color:var(--ink)}.module-item.active .module-num{color:var(--accent);border-color:var(--accent-dim)}.module-item.locked{opacity:.55;cursor:not-allowed}.module-num{font-family:var(--font-mono);font-size:11px;width:22px;height:22px;display:grid;place-items:center;border-radius:4px;background:var(--bg-2);border:1px solid var(--line);color:var(--ink-mute);flex-shrink:0}.module-item.active .module-num{background:var(--bg-3)}.module-meta{flex:1;min-width:0}.module-meta .name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.module-meta .prog{font-family:var(--font-mono);font-size:10px;color:var(--ink-faint);margin-top:1px}.module-check{width:14px;height:14px;flex-shrink:0}.curr-main{padding:32px 40px;overflow-y:auto}.curr-head{margin-bottom:28px}.curr-head .row{display:flex;align-items:baseline;gap:16px;margin-bottom:12px}.curr-head .row .eyebrow{color:var(--accent)}.curr-head h2{margin-bottom:8px}.curr-head .desc{color:var(--ink-dim);max-width:640px;font-size:15px}.progress{margin-top:20px;display:flex;align-items:center;gap:16px}.progress-bar{flex:1;height:6px;background:var(--bg-2);border-radius:999px;overflow:hidden;border:1px solid var(--line)}.progress-bar .fill{height:100%;background:var(--accent);border-radius:999px}.progress-label{font-family:var(--font-mono);font-size:12px;color:var(--ink-dim);min-width:100px;text-align:right}.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px;margin-top:24px}.lesson-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:12px;position:relative;transition:transform .12s ease,border-color .12s ease}.lesson-card:hover{border-color:var(--line-2);transform:translateY(-1px)}.lesson-card.locked{opacity:.55}.lesson-card .top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.lesson-card .num{font-family:var(--font-mono);font-size:11px;color:var(--ink-faint);letter-spacing:.08em}.lesson-card .title{font-size:16px;font-weight:600;letter-spacing:-.01em;margin:4px 0 0}.lesson-card .desc{font-size:13px;color:var(--ink-mute);line-height:1.5;flex:1}.lesson-card .bot{display:flex;align-items:center;justify-content:space-between}.level-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}.level-badge .dot{width:6px;height:6px;border-radius:50%}.level-badge.beginner{color:var(--level-beginner);background:#39d3531a}.level-badge.beginner .dot{background:var(--level-beginner)}.level-badge.intermediate{color:var(--level-intermediate);background:#f5c4511a}.level-badge.intermediate .dot{background:var(--level-intermediate)}.level-badge.advanced{color:var(--level-advanced);background:#e5484d1a}.level-badge.advanced .dot{background:var(--level-advanced)}.level-badge.bonus{color:var(--level-bonus);background:#b388ff1a}.level-badge.bonus .dot{background:var(--level-bonus)}.status-pill{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);display:inline-flex;align-items:center;gap:6px}.status-pill.done{color:var(--accent)}.status-pill.in-progress{color:var(--mode-command)}.status-pill.locked{color:var(--ink-faint)}.go-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius-sm);background:var(--bg-2);border:1px solid var(--line);font-family:var(--font-mono);font-size:12px;color:var(--ink);cursor:pointer}.go-btn:hover{background:var(--bg-3);border-color:var(--accent-dim);color:var(--accent)}.go-btn:disabled{cursor:not-allowed;opacity:.7}.go-btn:disabled:hover{background:var(--bg-2);border-color:var(--line);color:var(--ink)}.lesson-card.done .go-btn{background:var(--accent-soft);border-color:var(--accent-dim);color:var(--accent)}.page-lesson{display:grid;grid-template-columns:1fr 1fr;gap:0;height:calc(100vh - 56px)}.lesson-left{border-right:1px solid var(--line);padding:28px 36px;overflow-y:auto;display:flex;flex-direction:column;gap:20px;min-width:360px}.breadcrumbs{display:flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:12px;color:var(--ink-mute)}.breadcrumbs a{color:var(--ink-mute);cursor:pointer}.breadcrumbs a:hover{color:var(--ink)}.breadcrumbs .sep{color:var(--ink-faint)}.breadcrumbs .curr{color:var(--ink)}.stepper{display:flex;align-items:center;gap:6px;margin-left:auto}.stepper .step{width:8px;height:8px;border-radius:50%;background:var(--bg-2);border:1px solid var(--line)}.stepper .step.done{background:var(--accent);border-color:var(--accent)}.stepper .step.current{background:var(--bg-2);border-color:var(--accent);box-shadow:0 0 0 3px #39d35326}.task-card{padding:20px 22px;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius)}.task-card h2{font-size:22px;margin:0 0 10px;letter-spacing:-.01em;font-weight:600}.task-card p{color:var(--ink-dim);margin:0 0 12px}.task-card p:last-child{margin-bottom:0}.task-card code{font-family:var(--font-mono);background:var(--bg);padding:1px 5px;border-radius:3px}.task-card .goal{font-family:var(--font-mono);font-size:12px;color:var(--ink-mute);margin-top:14px;padding:10px 12px;background:var(--bg);border-left:2px solid var(--accent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.hints{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.hint-row{border-bottom:1px solid var(--line)}.hint-row:last-child{border-bottom:0}.hint-head{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;color:var(--ink-dim);font-size:13px;width:100%;background:transparent;border:0;text-align:left}.hint-head:hover{background:var(--bg-2);color:var(--ink)}.hint-head .chev{margin-left:auto;color:var(--ink-faint);transition:transform .15s ease}.hint-head.open .chev{transform:rotate(90deg)}.hint-head .hint-num{font-family:var(--font-mono);font-size:10px;width:18px;height:18px;display:grid;place-items:center;background:var(--bg-2);color:var(--ink-mute);border-radius:4px;border:1px solid var(--line)}.hint-body{padding:0 16px 14px 44px;font-size:13px;color:var(--ink-dim);font-family:var(--font-ui)}.hint-body code{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--line);padding:1px 5px;border-radius:3px;color:var(--accent);font-size:12px}.feedback{border-radius:var(--radius);padding:14px 16px;display:flex;gap:12px;align-items:flex-start}.feedback.success{background:#39d35314;border:1px solid rgba(57,211,83,.25);color:#b6f2c5}.feedback.fail{background:#e5484d14;border:1px solid rgba(229,72,77,.25);color:#f5b7b9}.feedback.warn{background:#f5c45114;border:1px solid rgba(245,196,81,.25);color:#f2da9c}.feedback .icon{font-family:var(--font-mono);font-weight:700}.feedback .body{font-size:13px;line-height:1.55}.feedback .body b{color:#fff;font-weight:600}.feedback .body code{font-family:var(--font-mono);padding:1px 5px;border-radius:3px;background:#0000004d}.lesson-right{display:flex;flex-direction:column;padding:20px;gap:14px;background:var(--bg);min-height:0;min-width:360px}.editor-area{flex:1;min-height:0;display:flex}.editor-actions{display:flex;gap:8px}.editor-actions .right{margin-left:auto;display:flex;gap:8px;align-items:center}.page-cheatsheet{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 56px)}.cs-sidebar{border-right:1px solid var(--line);background:var(--bg-1);padding:24px 12px;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto}.cs-cat{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius);cursor:pointer;color:var(--ink-dim);font-size:13px;width:100%;background:transparent;border:0;text-align:left}.cs-cat:hover,.cs-cat.active{background:var(--bg-2);color:var(--ink)}.cs-cat.active .cs-tag{color:var(--accent)}.cs-cat .cs-tag{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-faint)}.cs-cat .cs-dot{width:6px;height:6px;border-radius:50%}.cs-main{padding:28px 32px;overflow-y:auto}.cs-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:24px}.cs-search{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px}.cs-search input{flex:1;background:transparent;border:0;color:var(--ink);font-family:var(--font-mono);font-size:13px;outline:none}.cs-search input::placeholder{color:var(--ink-faint)}.cs-search .kbd{margin-left:auto}.cs-toggle{display:inline-flex;align-items:center;gap:8px;padding:6px;border-radius:var(--radius);background:var(--bg-1);border:1px solid var(--line)}.cs-toggle button{border:0;background:transparent;padding:5px 12px;border-radius:4px;cursor:pointer;font-family:var(--font-mono);font-size:12px;color:var(--ink-mute)}.cs-toggle button.active{background:var(--bg-3);color:var(--ink)}.cs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.cs-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:10px;transition:border-color .12s ease;position:relative;cursor:pointer;text-align:left;font:inherit;color:inherit}.cs-card:hover{border-color:var(--line-2)}.cs-card.learned{border-color:var(--accent-dim);background:var(--accent-soft)}.cs-card.learned:after{content:"";position:absolute;top:12px;right:12px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.cs-key{font-family:var(--font-mono);font-size:26px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.cs-key .modifier{color:var(--ink-mute);font-weight:400}.cs-desc{color:var(--ink-dim);font-size:13px;line-height:1.5}.cs-eg{font-family:var(--font-mono);font-size:11px;color:var(--ink-mute);padding-top:10px;border-top:1px dashed var(--line);display:flex;align-items:center;gap:6px}.cs-eg:before{content:"›";color:var(--accent)}.page-cmd{padding:40px 24px 80px}.cmd-inner{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.cmd-head{display:flex;flex-direction:column;gap:12px}.cmd-cat{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;padding:4px 10px;border:1px solid var(--line);border-radius:999px;background:var(--bg-1);font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);letter-spacing:.04em}.cmd-cat .cs-dot{width:7px;height:7px;border-radius:50%}.cmd-key{font-size:44px;line-height:1}.cmd-terminal{box-shadow:var(--shadow-md);border-radius:var(--radius)}.cmd-eg{font-size:13px;border:0;padding-top:0}.cmd-tryrow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-family:var(--font-mono);font-size:11px;color:var(--ink-mute)}.cmd-try-note{display:inline-flex;align-items:center;gap:8px;margin-right:auto}.cmd-try-note .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}.cmd-try-note code{font-family:var(--font-mono);background:var(--bg);border:1px solid var(--line);padding:1px 5px;border-radius:3px;color:var(--accent)}.cmd-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:8px;flex-wrap:wrap}.page-sandbox{padding:20px;height:calc(100vh - 56px);display:flex;flex-direction:column;gap:14px}.sandbox-toolbar{display:flex;align-items:center;gap:10px;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius);padding:8px 10px}.sandbox-toolbar .note{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--ink-mute);display:flex;align-items:center;gap:8px}.sandbox-toolbar .note .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px var(--accent)}.file-tabs{display:flex;gap:2px}.file-tab{font-family:var(--font-mono);font-size:12px;padding:6px 10px;border-radius:4px;color:var(--ink-mute);background:transparent;border:0;cursor:pointer}.file-tab:hover{background:var(--bg-2);color:var(--ink)}.file-tab.active{background:var(--bg-3);color:var(--ink)}.file-tab .fext{color:var(--ink-faint)}.file-tab.active .fext{color:var(--accent)}.sandbox-editor{flex:1;min-height:0;display:flex}.page-auth{min-height:calc(100vh - 56px);display:grid;place-items:center;padding:48px 24px}.auth-card{width:100%;max-width:420px;background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-md)}.auth-card h1{font-size:24px;margin:0 0 6px;font-weight:600;letter-spacing:-.01em}.auth-card .sub{color:var(--ink-mute);font-size:14px;margin-bottom:24px}.auth-field{margin-bottom:16px}.auth-field label{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:6px}.auth-field input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);color:var(--ink);font-family:var(--font-ui);font-size:14px;outline:none}.auth-field input:focus{border-color:var(--accent-dim)}.auth-field input::placeholder{color:var(--ink-faint)}.auth-error{background:#e5484d14;border:1px solid rgba(229,72,77,.25);color:#f5b7b9;padding:10px 12px;border-radius:var(--radius);font-size:13px;margin-bottom:16px}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--ink-faint);font-family:var(--font-mono);font-size:11px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--line)}.auth-alt{margin-top:20px;text-align:center;font-size:13px;color:var(--ink-mute)}.auth-alt a{color:var(--accent)}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;border-radius:var(--radius);border:1px solid var(--line);background:var(--bg-2);color:var(--ink);font-size:14px;font-weight:500;cursor:pointer}.google-btn:hover{background:var(--bg-3);border-color:var(--line-2)}.github-btn{margin-top:10px}.github-btn svg{color:var(--ink)}.footer{border-top:1px solid var(--line);padding:28px 48px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;color:var(--ink-mute);font-size:13px}.footer .footer-brand{font-family:var(--font-mono);color:var(--ink-dim)}.footer .footer-links{display:flex;gap:16px;margin-left:auto;flex-wrap:wrap}.footer .footer-links a{color:var(--ink-mute);font-family:var(--font-mono);font-size:12px}.footer .footer-links a:hover{color:var(--ink)}.error-page{min-height:calc(100vh - 56px);display:grid;place-items:center;padding:48px 24px}.error-card{max-width:520px;text-align:center}.error-card .code{font-family:var(--font-mono);font-size:64px;color:var(--accent);letter-spacing:-.02em}.error-card h1{font-size:24px;margin:8px 0}.error-card p{color:var(--ink-mute);margin-bottom:20px}.muted{color:var(--ink-mute)}.faint{color:var(--ink-faint)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--line-2)}.ad-slot{position:relative;display:flex;align-items:stretch;justify-content:stretch}.ad-placeholder{flex:1;position:relative;background:repeating-linear-gradient(135deg,transparent 0,transparent 6px,rgba(255,255,255,.018) 6px,rgba(255,255,255,.018) 12px),var(--bg-1);border:1px dashed var(--line-2);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 16px;font-family:var(--font-mono);color:var(--ink-faint);text-align:center;overflow:hidden}.ad-placeholder-corner{position:absolute;font-family:var(--font-mono);font-size:14px;color:var(--ink-faint);line-height:1;opacity:.55}.ad-placeholder-corner.ad-tl{top:6px;left:8px}.ad-placeholder-corner.ad-tr{top:6px;right:8px}.ad-placeholder-corner.ad-bl{bottom:6px;left:8px}.ad-placeholder-corner.ad-br{bottom:6px;right:8px}.ad-placeholder-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);padding:2px 8px;background:var(--bg);border:1px solid var(--line);border-radius:3px}.ad-placeholder-size{font-size:11px;color:var(--ink-mute)}.ad-placeholder-note{font-size:10px;color:var(--ink-faint);opacity:.7;margin-top:2px}.ad-slot[data-ad-size="320x50"] .ad-placeholder,.ad-slot[data-ad-size="728x90"] .ad-placeholder{flex-direction:row;gap:14px;justify-content:center}.ad-slot[data-ad-size="320x50"] .ad-placeholder-note,.ad-slot[data-ad-size="728x90"] .ad-placeholder-note{margin-top:0}.how-to-page{max-width:760px;margin:0 auto;padding:48px 24px}.how-to-page .breadcrumb{font-family:var(--font-mono);font-size:12px;color:var(--ink-mute);margin-bottom:20px}.how-to-page .breadcrumb a{color:var(--ink-mute)}.how-to-page .breadcrumb a:hover{color:var(--ink)}.how-to-page .h1{font-size:48px}.how-to-page .lede{margin:16px 0}.how-to-page .section-title{font-size:24px;font-weight:600;letter-spacing:-.02em;margin:40px 0 16px}.how-to-page .editor{margin:32px 0}.how-to-page kbd{font-family:var(--font-mono);font-size:12px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:1px 6px;color:var(--ink)}.how-to-page code{font-family:var(--font-mono);font-size:.92em;color:var(--accent)}.quick-answer{background:var(--bg-2);border:1px solid var(--accent);border-radius:var(--radius-lg);padding:24px 28px;margin:32px 0}.quick-answer h2{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 16px}.command-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}.command-pill{background:var(--bg-3);border:1px solid var(--line-2);border-radius:var(--radius);padding:10px 14px}.command-pill .cmd{font-family:var(--font-mono);font-size:18px;color:var(--accent);display:block;margin-bottom:4px}.command-pill .cmd-desc{font-size:12px;color:var(--ink-mute)}.exit-card{background:var(--bg-1);border:1px solid var(--line);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:12px}.exit-card:hover{border-color:var(--line-2)}.exit-card .ec-cmd{font-family:var(--font-mono);font-size:22px;color:var(--accent);margin-bottom:8px}.exit-card .ec-when{font-size:13px;color:var(--ink-dim);margin-bottom:12px}.exit-card .ec-how{font-family:var(--font-mono);font-size:13px;color:var(--ink)}.exit-card .ec-warning{font-size:12px;color:var(--mode-command);background:#f5c45114;border-radius:var(--radius-sm);padding:6px 10px;margin-top:8px}.how-to-page .step-list{color:var(--ink-dim);font-size:16px;line-height:1.6;padding-left:22px}.how-to-page .step-list li{margin-bottom:12px}.how-to-page .step-list strong{color:var(--ink)}.cta-box{background:var(--accent-soft);border:1px solid var(--accent-dim);border-radius:var(--radius-lg);padding:28px 32px;text-align:center;margin-top:48px}.how-to-page .related-links{margin-top:32px;font-size:14px;color:var(--ink-mute);text-align:center}.how-to-page .related-links a{color:var(--accent)}
