@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";.driver-active .driver-overlay,.driver-active *{pointer-events:none}.driver-active .driver-active-element,.driver-active .driver-active-element *,.driver-popover,.driver-popover *{pointer-events:auto}@keyframes animate-fade-in{0%{opacity:0}to{opacity:1}}.driver-fade .driver-overlay{animation:animate-fade-in .2s ease-in-out}.driver-fade .driver-popover{animation:animate-fade-in .2s}.driver-popover{all:unset;box-sizing:border-box;color:#2d2d2d;margin:0;padding:15px;border-radius:5px;min-width:250px;max-width:300px;box-shadow:0 1px 10px #0006;z-index:1000000000;position:fixed;top:0;right:0;background-color:#fff}.driver-popover *{font-family:Helvetica Neue,Inter,ui-sans-serif,"Apple Color Emoji",Helvetica,Arial,sans-serif}.driver-popover-title{font:19px/normal sans-serif;font-weight:700;display:block;position:relative;line-height:1.5;zoom:1;margin:0}.driver-popover-close-btn{all:unset;position:absolute;top:0;right:0;width:32px;height:28px;cursor:pointer;font-size:18px;font-weight:500;color:#d2d2d2;z-index:1;text-align:center;transition:color;transition-duration:.2s}.driver-popover-close-btn:hover,.driver-popover-close-btn:focus{color:#2d2d2d}.driver-popover-title[style*=block]+.driver-popover-description{margin-top:5px}.driver-popover-description{margin-bottom:0;font:14px/normal sans-serif;line-height:1.5;font-weight:400;zoom:1}.driver-popover-footer{margin-top:15px;text-align:right;zoom:1;display:flex;align-items:center;justify-content:space-between}.driver-popover-progress-text{font-size:13px;font-weight:400;color:#727272;zoom:1}.driver-popover-footer button{all:unset;display:inline-block;box-sizing:border-box;padding:3px 7px;text-decoration:none;text-shadow:1px 1px 0 #fff;background-color:#fff;color:#2d2d2d;font:12px/normal sans-serif;cursor:pointer;outline:0;zoom:1;line-height:1.3;border:1px solid #ccc;border-radius:3px}.driver-popover-footer .driver-popover-btn-disabled{opacity:.5;pointer-events:none}:not(body):has(>.driver-active-element){overflow:hidden!important}.driver-no-interaction,.driver-no-interaction *{pointer-events:none!important}.driver-popover-footer button:hover,.driver-popover-footer button:focus{background-color:#f7f7f7}.driver-popover-navigation-btns{display:flex;flex-grow:1;justify-content:flex-end}.driver-popover-navigation-btns button+button{margin-left:4px}.driver-popover-arrow{content:"";position:absolute;border:5px solid #fff}.driver-popover-arrow-side-over{display:none}.driver-popover-arrow-side-left{left:100%;border-right-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-right{right:100%;border-left-color:transparent;border-bottom-color:transparent;border-top-color:transparent}.driver-popover-arrow-side-top{top:100%;border-right-color:transparent;border-bottom-color:transparent;border-left-color:transparent}.driver-popover-arrow-side-bottom{bottom:100%;border-left-color:transparent;border-top-color:transparent;border-right-color:transparent}.driver-popover-arrow-side-center{display:none}.driver-popover-arrow-side-left.driver-popover-arrow-align-start,.driver-popover-arrow-side-right.driver-popover-arrow-align-start{top:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-start,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-start{left:15px}.driver-popover-arrow-align-end.driver-popover-arrow-side-left,.driver-popover-arrow-align-end.driver-popover-arrow-side-right{bottom:15px}.driver-popover-arrow-side-top.driver-popover-arrow-align-end,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-end{right:15px}.driver-popover-arrow-side-left.driver-popover-arrow-align-center,.driver-popover-arrow-side-right.driver-popover-arrow-align-center{top:50%;margin-top:-5px}.driver-popover-arrow-side-top.driver-popover-arrow-align-center,.driver-popover-arrow-side-bottom.driver-popover-arrow-align-center{left:50%;margin-left:-5px}.driver-popover-arrow-none{display:none}:root{color-scheme:light;--bg: #f4eeff;--bg2: #fbf8ff;--card: #ffffff;--ink: #251c3d;--muted: #6d6593;--faint: #9a93bb;--line: #e9e0fb;--line-soft: #f1ebff;--violet: #7c5cff;--pink: #ff5c9d;--teal: #12b3a3;--orange: #ff9f43;--blue: #4c8dff;--green: #1faf6b;--red: #ef4f6b;--shadow: 0 12px 32px rgba(124, 92, 255, .13);--shadow-sm: 0 4px 14px rgba(124, 92, 255, .1);--radius: 14px;--sans: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace;font-family:var(--sans);color:var(--ink)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 12% -8%,rgba(124,92,255,.14),transparent 38%),radial-gradient(circle at 92% 0%,rgba(255,92,157,.12),transparent 34%),var(--bg);background-attachment:fixed;color:var(--ink)}button,input,textarea{font:inherit;color:inherit}button{cursor:pointer}::selection{background:#7c5cff40}.app{width:min(1840px,100%);margin:0 auto;padding:18px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px;padding:14px 18px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.brand{display:flex;align-items:center;gap:13px}.logo{filter:drop-shadow(0 4px 8px rgba(124,92,255,.3))}.brand h1{margin:0;font-size:1.6rem;font-weight:700;letter-spacing:-.5px;color:var(--violet)}.tagline{display:block;margin-top:2px;color:var(--muted);font-size:.82rem}.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.locale-switch{display:flex;align-items:center;gap:4px;height:38px;padding:0 8px;border:1px solid var(--line);border-radius:999px;background:var(--bg2)}.locale-switch svg{color:var(--violet)}.locale-switch button{height:26px;padding:0 10px;border:0;border-radius:999px;background:transparent;color:var(--muted);font-size:.74rem;font-weight:600}.locale-switch button.active{background:var(--violet);color:#fff}.score,.progress{display:flex;align-items:center;gap:7px;height:38px;padding:0 13px;border:1px solid var(--line);border-radius:999px;background:var(--bg2)}.score svg{color:var(--orange)}.score strong{font-size:.95rem;color:var(--violet);display:inline-block;animation:pop .4s cubic-bezier(.2,1.4,.4,1)}.score span{color:var(--muted);font-size:.78rem}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.5);color:var(--pink)}to{transform:scale(1)}}.progress{position:relative;width:116px;justify-content:center;overflow:hidden}.progress span{position:absolute;top:0;bottom:0;left:0;right:auto;background:linear-gradient(90deg,#7c5cff59,#ff5c9d59);transition:width .45s cubic-bezier(.2,1,.3,1)}.progress b{position:relative;font-size:.78rem;font-weight:700}.icon-btn{display:inline-grid;place-items:center;width:38px;height:38px;border:1px solid var(--line);border-radius:11px;background:var(--bg2);color:var(--ink);transition:transform .14s,box-shadow .14s,border-color .14s,background .14s}.icon-btn.sm{width:30px;height:30px;border-radius:9px}.icon-btn.ghost{border-color:transparent;background:transparent;color:var(--faint)}.icon-btn:hover:not(:disabled){transform:translateY(-1px);border-color:var(--violet);box-shadow:var(--shadow-sm)}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.workspace{display:grid;grid-template-columns:250px minmax(0,1fr) 360px;gap:16px;align-items:start}.lesson-rail,.repo-panel{display:grid;gap:14px;align-content:start}.stage{display:grid;gap:16px;min-width:0}.lesson-rail,.mission-card,.workbench,.cheatsheet,.panel-block{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.rail-head,.panel-bar{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line-soft);color:var(--violet);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.4px}.rail-head h2{margin:0;font:inherit}.panel-bar .dim{margin-left:auto;font-family:var(--mono);font-size:.72rem;text-transform:none;letter-spacing:0;color:var(--muted)}.lesson-rail{padding-bottom:12px}.chapter{padding:4px 12px}.chapter h3{margin:12px 0 8px;color:var(--pink);font-size:.66rem;letter-spacing:.8px;text-transform:uppercase}.lesson{display:grid;gap:3px;width:100%;text-align:left;margin-bottom:7px;padding:9px 11px;border:1px solid var(--line);border-radius:11px;background:var(--bg2);color:var(--ink);transition:transform .14s,border-color .14s,box-shadow .14s}.lesson:hover:not(:disabled){transform:translateY(-1px);border-color:var(--violet);box-shadow:var(--shadow-sm)}.lesson.active{border-color:var(--violet);background:#7c5cff14;box-shadow:inset 0 0 0 1px #7c5cff4d}.lesson.locked{opacity:.5;cursor:not-allowed}.lesson.locked:hover{transform:none;border-color:var(--line);box-shadow:none}.lesson-topic{display:flex;align-items:center;gap:5px;color:var(--pink);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.lesson strong{font-size:.86rem;font-weight:600}.lesson small{color:var(--muted);font-size:.7rem;font-family:var(--mono)}.lesson.done small{color:var(--green)}.cheatsheet{padding-bottom:8px}.cheat-row{display:grid;gap:2px;padding:8px 14px;border-top:1px solid var(--line-soft)}.cheat-row code{color:var(--violet);font-size:.72rem;font-weight:700;font-family:var(--mono)}.cheat-row span{color:var(--muted);font-size:.72rem}.mission-card{padding:16px}.mission-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.eyebrow{margin:0 0 5px;color:var(--pink);font-size:.66rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.mission-head h2{margin:0;font-size:1.5rem;letter-spacing:-.5px}.stepper{display:flex;gap:6px}.goal{margin:12px 0 16px;font-size:1.02rem}.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.badge{padding:12px;border:1px solid var(--line);border-radius:12px;background:var(--bg2)}.badge strong{display:flex;align-items:center;gap:5px;margin-bottom:6px;font-size:.66rem;letter-spacing:.4px;text-transform:uppercase}.badge p{margin:0;color:var(--muted);font-size:.84rem;line-height:1.5}.badge.what strong{color:var(--violet)}.badge.why strong{color:var(--teal)}.badge.analogy strong{color:var(--blue)}.badge.caveat{border-color:#ef4f6b59;background:#ef4f6b0d}.badge.caveat strong{color:var(--red)}.compare{margin-top:14px;border:1px solid var(--line);border-radius:12px;overflow:hidden}.compare table{width:100%;border-collapse:collapse}.compare th,.compare td{padding:9px 12px;text-align:left;font-size:.82rem;border-bottom:1px solid var(--line-soft);vertical-align:top}.compare thead th{color:var(--violet);font-size:.72rem;text-transform:uppercase;background:var(--bg2)}.compare tbody th{color:var(--muted);font-weight:600;width:34%}.compare td:nth-child(2){color:var(--teal)}.compare td:nth-child(3){color:var(--blue)}.verdict{margin:0;padding:10px 12px;font-size:.84rem;color:var(--muted);background:var(--bg2)}.verdict strong{color:var(--orange)}.example-row{display:flex;gap:8px;margin-top:14px}.example-snippet{flex:1;margin:0;padding:11px 13px;border:1px solid var(--line);border-radius:11px;background:#1c1530;color:#c9b6ff;font-family:var(--mono);font-size:.82rem;white-space:pre-wrap;overflow-x:auto}.run-example{display:flex;align-items:center;gap:6px;padding:0 14px;border:1px solid var(--teal);border-radius:11px;background:#12b3a31a;color:var(--teal);font-size:.78rem;font-weight:700;white-space:nowrap;transition:transform .14s,background .14s}.run-example:hover{transform:translateY(-1px);background:#12b3a333}.task{margin-top:14px;padding:13px;border:1px solid var(--violet);border-radius:12px;background:#7c5cff0f}.task-head{display:flex;align-items:center;gap:7px;color:var(--violet);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.task p{margin:0 0 8px;font-size:.92rem}.focus-hint{margin:0 0 10px!important;padding:7px 10px;border-left:3px solid var(--orange);border-radius:0 8px 8px 0;background:#ff9f431f;color:#b56a14;font-size:.8rem;font-weight:600}.checklist{list-style:none;margin:0;padding:0;display:grid;gap:6px}.checklist li{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.84rem;transition:color .16s}.checklist li.checked{color:var(--green)}.check-box{display:grid;place-items:center;width:18px;height:18px;flex-shrink:0;color:var(--faint);font-weight:700}.checklist li.checked .check-box{color:#fff;background:var(--green);border-radius:6px;animation:pop .4s cubic-bezier(.2,1.4,.4,1)}.notes{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:var(--bg2)}.notes summary{padding:9px 13px;cursor:pointer;color:var(--teal);font-size:.8rem;font-weight:600}.notes ul{margin:0;padding:0 16px 12px 32px;display:grid;gap:5px}.notes li{color:var(--muted);font-size:.82rem}.progress-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:14px;padding:11px 13px;border:1px solid var(--line);border-radius:12px;background:var(--bg2)}.progress-footer>span{display:flex;align-items:center;gap:7px;color:var(--muted);font-size:.84rem}.progress-footer.done{border-color:#1faf6b73;background:#1faf6b14}.progress-footer.done>span{color:var(--green)}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border:0;border-radius:11px;background:var(--violet);color:#fff;font-size:.82rem;font-weight:700;transition:transform .14s,box-shadow .14s}.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.workbench{display:flex;flex-direction:column;overflow:hidden}.work-tabs{display:flex;border-bottom:1px solid var(--line);background:var(--bg2)}.work-tabs button{display:flex;align-items:center;gap:6px;padding:11px 16px;border:0;border-right:1px solid var(--line-soft);background:transparent;color:var(--muted);font-size:.8rem;font-weight:600}.work-tabs button.active{color:var(--violet);background:#7c5cff14;box-shadow:inset 0 -2px 0 var(--violet)}.work-body{display:flex;min-height:340px}.work-body>*{flex:1;min-width:0}.terminal-panel{display:flex;flex-direction:column;min-height:340px;overflow:hidden;border-radius:0 0 var(--radius) var(--radius)}.term-out{flex:1;min-height:0;overflow-y:auto;padding:12px 14px;background:#1a1430;font-size:.82rem;line-height:1.55;font-family:var(--mono)}.term-line{white-space:pre-wrap;word-break:break-word;color:#d7ccf5;animation:termIn .14s ease}@keyframes termIn{0%{opacity:.3}to{opacity:1}}.tone-cmd{color:#c9b6ff;font-weight:700}.tone-ok{color:#4be0a0}.tone-err{color:#ff8da3}.tone-dim{color:#8b81ad}.tone-accent{color:#ffc46b}.tone-add{color:#4be0a0}.tone-del{color:#ff8da3}.tone-branch{color:#ff9ec8;font-weight:700}.term-input-row{display:flex;align-items:center;gap:9px;padding:10px 14px;border-top:1px solid #2c2350;background:#14102a}.term-prompt{color:#8be9d4;font-weight:700;font-size:.84rem;font-family:var(--mono);white-space:nowrap}.term-input{flex:1;min-width:0;border:0;outline:none;background:transparent;color:#ece6ff;font-size:.84rem;font-family:var(--mono)}.term-input::placeholder{color:#6a6090}.term-hint{flex-shrink:0;color:#6a6090;font-size:.68rem;font-family:var(--mono);white-space:nowrap}.files-panel{display:flex;min-height:340px}.files-list{width:44%;border-right:1px solid var(--line);padding:10px;overflow-y:auto;display:grid;gap:6px;align-content:start}.new-file{display:flex;gap:6px;margin-bottom:4px}.new-file input{flex:1;min-width:0;height:30px;padding:0 10px;border:1px solid var(--line);border-radius:9px;background:var(--bg2);font-size:.78rem;outline:none}.new-file input:focus{border-color:var(--violet)}.file-row{display:flex;align-items:center;gap:4px}.file-open{flex:1;display:flex;align-items:center;gap:8px;padding:7px 9px;border:1px solid transparent;border-radius:9px;background:transparent;text-align:left;font-family:var(--mono);font-size:.78rem;color:var(--ink)}.file-row.active .file-open,.file-open:hover{background:var(--bg2);border-color:var(--line)}.file-editor{flex:1;display:flex}.file-input{flex:1;resize:none;border:0;outline:none;padding:13px;background:#1a1430;color:#ece6ff;font-family:var(--mono);font-size:.84rem;line-height:1.6}.file-empty{flex:1;display:grid;place-content:center;justify-items:center;gap:8px;color:var(--faint);padding:20px;text-align:center}.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:var(--faint)}.dot.staged{background:var(--green)}.dot.modified{background:var(--orange)}.dot.untracked{background:var(--blue)}.dot.conflict{background:var(--red)}.dot.clean{background:var(--line)}.panel-block{padding-bottom:12px}.panel-block h3{display:flex;align-items:center;gap:6px;margin:0;padding:11px 13px;border-bottom:1px solid var(--line-soft);color:var(--teal);font-size:.72rem;text-transform:uppercase;letter-spacing:.4px}.empty{margin:0;padding:14px;color:var(--muted);font-size:.8rem}.empty.ok{color:var(--green)}.graph{position:relative;padding:4px 0}.graph-gutter{position:absolute;top:0;left:0}.graph-edge{fill:none;stroke:var(--line);stroke-width:2}.graph-dot{stroke:var(--card);stroke-width:2;transition:r .2s}.graph-dot.head{stroke:var(--violet);stroke-width:2.5}.graph-rows{position:relative}.graph-row{display:flex;align-items:center;gap:8px;padding-right:12px;animation:rowIn .24s ease both}@keyframes rowIn{0%{opacity:0;transform:translate(6px)}to{opacity:1;transform:translate(0)}}.graph-refs{display:flex;align-items:center;gap:4px;flex-shrink:0}.ref-chip{padding:1px 6px;border-radius:999px;font-size:.6rem;font-weight:700;background:var(--line);color:var(--muted);white-space:nowrap}.ref-chip.head{background:var(--violet);color:#fff}.ref-chip.remote{background:#4c8dff2e;color:var(--blue)}.ref-chip.tag{background:#ff9f4333;color:#b56a14}.graph-id{font-family:var(--mono);font-size:.66rem;color:var(--faint)}.graph-msg{font-size:.8rem;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-list,.branch-list{padding:10px 13px;display:grid;gap:6px}.status-row{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.76rem;color:var(--ink)}.status-row em{margin-left:auto;font-style:normal;font-size:.66rem;color:var(--muted);text-transform:uppercase}.branch-list{display:flex;flex-wrap:wrap;gap:6px}.branch-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;background:var(--bg2);border:1px solid var(--line);font-size:.74rem;font-family:var(--mono);color:var(--muted)}.branch-chip.current{border-color:var(--violet);color:var(--violet);font-weight:700}.branch-chip.remote{color:var(--blue);border-color:#4c8dff4d}.celebration{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;pointer-events:none;overflow:hidden}.sparks{position:absolute;top:0;right:0;bottom:0;left:0}.spark{position:absolute;top:-12px;width:9px;height:9px;border-radius:2px;opacity:0;animation:sparkFall 1.7s cubic-bezier(.3,.7,.5,1) forwards}@keyframes sparkFall{0%{opacity:1;transform:translate(0) rotate(0)}to{opacity:0;transform:translate(var(--drift, 0),102vh) rotate(540deg)}}.celebrate-toast{position:absolute;left:50%;top:22%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:14px 20px;border:1px solid var(--line);border-radius:14px;background:var(--card);box-shadow:var(--shadow);animation:toastIn .32s cubic-bezier(.2,1.3,.4,1)}.celebrate-toast svg{color:var(--orange)}.celebrate-toast strong{display:block;font-size:.96rem;color:var(--violet)}.celebrate-toast span{color:var(--green);font-size:.8rem;font-weight:700}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-14px)}to{opacity:1;transform:translate(-50%)}}.driver-popover.gg-tour{background:var(--card);color:var(--ink);border-radius:14px;box-shadow:var(--shadow);font-family:var(--sans);max-width:320px}.driver-popover.gg-tour .driver-popover-title{font-size:1rem;color:var(--violet)}.driver-popover.gg-tour .driver-popover-description{color:var(--muted);font-size:.84rem;line-height:1.5}.driver-popover.gg-tour .driver-popover-progress-text{color:var(--faint);font-size:.72rem}.driver-popover.gg-tour button{text-shadow:none;border-radius:9px;border:1px solid var(--line);background:var(--bg2);color:var(--ink);font-family:var(--sans);font-size:.8rem}.driver-popover.gg-tour .driver-popover-next-btn{background:var(--violet);color:#fff;border-color:var(--violet)}@media(max-width:1240px){.workspace{grid-template-columns:224px minmax(0,1fr) 320px;gap:12px}}@media(max-width:980px){.workspace{grid-template-columns:1fr}.stage{order:1}.repo-panel{order:2}.lesson-rail{order:3}.work-body,.terminal-panel,.files-panel{min-height:300px}}@media(max-width:560px){.app{padding:10px}.brand h1{font-size:1.3rem}.tagline{display:none}.mission-head h2{font-size:1.2rem}.badge-grid{grid-template-columns:1fr}.compare{overflow-x:auto}.score span,.term-hint{display:none}.files-panel{flex-direction:column}.files-list{width:100%;border-right:0;border-bottom:1px solid var(--line);max-height:160px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
