:root{--bg: #0b0e13;--bg-raise: #11151d;--bg-panel: #131822;--line: #222a38;--line-soft: #1a2130;--text: #e8e1d5;--text-dim: #97a0b1;--text-faint: #5c6878;--accent: #ffad33;--accent-deep: #e2603f;--ok: #3ddc97;--error: #ff5c5c;--mars-1: #1b1612;--mars-2: #221a14;--font-display: "Bricolage Grotesque", sans-serif;--font-body: "Atkinson Hyperlegible", sans-serif;--font-mono: "JetBrains Mono", monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}h1,h2,h3{font-family:var(--font-display);font-weight:700;margin:0;letter-spacing:-.01em}::selection{background:#ffad334d}#root:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:999;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}.mono-label{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--text-faint)}.btn-ghost{background:transparent;border:1px solid var(--line);color:var(--text-dim);font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;padding:8px 14px;border-radius:6px;transition:border-color .15s,color .15s,background .15s}.btn-ghost:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn-ghost:disabled{opacity:.4;cursor:default}.btn-ghost.small{padding:4px 10px;font-size:10px}.btn-run{position:relative;background:var(--accent);color:#14100a;border:none;font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:.1em;padding:12px 22px;border-radius:6px;display:inline-flex;align-items:center;gap:12px;transition:transform .12s,box-shadow .2s,background .15s;box-shadow:0 0 #ffad3366}.btn-run:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px -6px #ffad338c}.btn-run:disabled{opacity:.55;cursor:default}.btn-run.running{animation:signal-pulse 1.4s ease-out infinite}@keyframes signal-pulse{0%{box-shadow:0 0 #ffad3373}to{box-shadow:0 0 0 18px #ffad3300}}.kbd{font-size:10px;font-weight:500;background:#0000002e;padding:2px 6px;border-radius:4px}.star{color:#2c3445;transition:color .2s}.star.on{color:var(--accent);text-shadow:0 0 10px rgba(255,173,51,.45)}.intro{position:relative;min-height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;background:radial-gradient(1200px 500px at 50% 118%,rgba(226,96,63,.22),transparent 70%),radial-gradient(2px 2px at 18% 22%,rgba(232,225,213,.5),transparent 100%),radial-gradient(1.5px 1.5px at 76% 14%,rgba(232,225,213,.4),transparent 100%),radial-gradient(1px 1px at 32% 64%,rgba(232,225,213,.35),transparent 100%),radial-gradient(2px 2px at 88% 42%,rgba(232,225,213,.3),transparent 100%),radial-gradient(1px 1px at 56% 30%,rgba(232,225,213,.45),transparent 100%),radial-gradient(1.5px 1.5px at 8% 48%,rgba(232,225,213,.3),transparent 100%),var(--bg)}.intro-horizon{position:absolute;bottom:-40vh;left:50%;transform:translate(-50%);width:160vw;height:60vh;border-radius:50% 50% 0 0;background:linear-gradient(180deg,#2a1d14,#1b130d 60%);box-shadow:0 -1px #ffad3359,0 -18px 60px -12px #e2603f73}.intro-inner{position:relative;z-index:2;max-width:880px;padding:48px 32px 22vh;text-align:left}.intro-kicker{display:inline-block;color:var(--accent);border:1px solid rgba(255,173,51,.35);padding:6px 12px;border-radius:99px;margin-bottom:28px;animation:rise .7s ease both}.intro-title{font-size:clamp(40px,7vw,84px);line-height:1.02;letter-spacing:-.03em;margin-bottom:32px;animation:rise .7s .1s ease both}.intro-title .accent{color:var(--accent)}.intro-cols{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:760px;color:var(--text-dim);font-size:16px;margin-bottom:40px;animation:rise .7s .22s ease both}.intro-cols strong{color:var(--text)}.intro-cta{font-size:15px;padding:16px 32px;animation:rise .7s .34s ease both}.intro-meta{display:flex;gap:28px;margin-top:36px;animation:rise .7s .46s ease both}@keyframes rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:720px){.intro-cols{grid-template-columns:1fr}}.map-screen{height:100%;display:flex;flex-direction:column}.map-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px;border-bottom:1px solid var(--line-soft);background:#0b0e13d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brand{background:none;border:none;color:var(--text);font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:.18em;display:inline-flex;align-items:center;gap:10px}.brand-mark{color:var(--accent);font-size:13px}.star-total .star{margin-right:6px}.map-scroll{overflow-y:auto;padding:36px 24px 80px;max-width:1060px;width:100%;margin:0 auto}.mission-block{position:relative;padding:0 0 36px 40px;animation:rise .5s ease both}.mission-block:before{content:"";position:absolute;left:11px;top:8px;bottom:-8px;width:1px;background:repeating-linear-gradient(180deg,var(--line) 0 6px,transparent 6px 12px)}.mission-block:last-child:before{display:none}.mission-block:after{content:"";position:absolute;left:6px;top:6px;width:11px;height:11px;border-radius:50%;border:2px solid var(--accent);background:var(--bg)}.mission-block.locked{opacity:.45}.mission-block.locked:after{border-color:var(--text-faint)}.mission-head{display:flex;align-items:baseline;gap:16px;margin-bottom:16px}.mission-code{color:var(--accent);font-size:13px}.mission-head h2{font-size:24px}.mission-tagline{margin:2px 0 0;color:var(--text-faint);font-size:14px}.mission-done{margin-left:auto;color:var(--ok);border:1px solid rgba(61,220,151,.35);padding:4px 10px;border-radius:99px}.level-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.level-card{position:relative;text-align:left;background:var(--bg-panel);border:1px solid var(--line);border-radius:8px;padding:12px 14px;display:flex;flex-direction:column;gap:5px;color:var(--text);transition:border-color .15s,transform .15s,box-shadow .2s}.level-card:hover:not(.locked){border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 26px -14px #ffad3359}.level-card.locked{opacity:.5;cursor:default}.level-card.kind-uitleg{border-left:3px solid var(--accent)}.level-card.kind-missie{border-left:3px solid var(--accent-deep)}.level-id{color:var(--text-faint)}.level-name{font-family:var(--font-display);font-weight:700;font-size:15px;line-height:1.25}.level-kind{font-size:9px}.level-stars{font-size:13px;letter-spacing:2px}.level-card .lock{position:absolute;top:10px;right:10px;font-size:11px;filter:grayscale(1);opacity:.7}.play-screen{height:100%;display:flex;flex-direction:column}.play-header{display:flex;align-items:center;gap:20px;padding:10px 18px;border-bottom:1px solid var(--line-soft)}.play-title{display:flex;flex-direction:column}.play-title h1{font-size:19px}.play-header-right{margin-left:auto;display:flex;align-items:center;gap:14px}.star-row{font-size:16px;letter-spacing:3px}.speed{min-width:46px}.play-body{flex:1;display:grid;grid-template-columns:320px 1fr 440px;gap:12px;padding:12px;min-height:0}.panel{background:var(--bg-panel);border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--line-soft);flex-shrink:0}.panel-head .mono-label{color:var(--text-dim)}.telemetry{color:var(--accent)!important}.tab-row{display:flex;border-bottom:1px solid var(--line-soft);flex-shrink:0}.tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-faint);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;padding:12px 6px;transition:color .15s,border-color .15s}.tab.on{color:var(--accent);border-bottom-color:var(--accent)}.panel-scroll{overflow-y:auto;padding:18px;min-height:0}.lesson-body h2{font-size:21px;line-height:1.2;margin-bottom:12px}.lesson-body h3{font-size:15px;margin:22px 0 8px;color:var(--accent)}.lesson-body p{margin:0 0 12px;color:var(--text-dim)}.lesson-body strong{color:var(--text)}.lesson-body ul,.lesson-body ol{margin:0 0 12px;padding-left:20px;color:var(--text-dim)}.lesson-body li{margin-bottom:4px}.lesson-body code,.hint-box code{font-family:var(--font-mono);font-size:.86em;background:#ffad331a;color:var(--accent);padding:1px 5px;border-radius:4px}.md-code{background:var(--bg);border:1px solid var(--line-soft);border-radius:8px;padding:12px 14px;margin:0 0 14px;overflow-x:auto}.md-code code{font-family:var(--font-mono);font-size:12.5px;line-height:1.6;color:var(--text);background:none;padding:0}.hint-box{border:1px dashed var(--line);border-radius:8px;padding:10px 14px;margin:16px 0}.hint-box summary{cursor:pointer;font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--accent)}.hint-box p{margin:10px 0 2px}.star-legend{margin-top:22px;border-top:1px solid var(--line-soft);padding-top:14px}.star-legend h3{font-size:13px;margin-bottom:8px}.star-legend p{margin:0 0 6px;font-size:13px;color:var(--text-dim)}.star-legend .star{margin-right:8px}.command-dock{display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start}.cmd-chip{font-family:var(--font-mono);font-size:12px;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:6px 10px;border-radius:6px}.dock-note{width:100%;color:var(--text-faint);font-size:12.5px;margin-top:10px}.terrain{display:flex;flex-direction:column}.grid-frame{flex:1;display:flex;align-items:center;justify-content:center;padding:18px;min-height:0;background:radial-gradient(600px 300px at 50% 110%,rgba(226,96,63,.08),transparent 70%),var(--bg-raise)}.grid-board{position:relative;display:grid;gap:3px;width:100%;max-width:100%;max-height:100%;margin:auto;container-type:inline-size}.tile{position:relative;border-radius:5px;background:linear-gradient(135deg,rgba(255,173,51,.04),transparent 55%),var(--mars-2);border:1px solid rgba(255,173,51,.06)}.tile-rock{background:radial-gradient(60% 50% at 35% 35%,#3a3f4d,#262b36 70%),#1d212b;border-color:#333a49;box-shadow:inset 0 2px 6px #ffffff0f,inset 0 -3px 6px #00000080}.tile-crevasse{background:linear-gradient(180deg,#060709 30%,#0c0e13);border-color:#000;box-shadow:inset 0 4px 14px #000000e6}.tile-crevasse:after{content:"";position:absolute;top:18%;right:24%;bottom:18%;left:24%;border-radius:40% 60% 55% 45%;background:#000;box-shadow:0 0 8px 2px #000c}.tile-base{background:radial-gradient(70% 70% at 50% 50%,rgba(61,220,151,.16),transparent 75%),var(--mars-2);border-color:#3ddc9773}.base-beacon{position:absolute;top:16%;right:16%;bottom:16%;left:16%;border:2px dashed rgba(61,220,151,.7);border-radius:50%;animation:beacon-spin 9s linear infinite}.base-beacon:after{content:"";position:absolute;top:30%;right:30%;bottom:30%;left:30%;border-radius:50%;background:#3ddc9780;animation:beacon-pulse 1.6s ease-in-out infinite}@keyframes beacon-spin{to{transform:rotate(360deg)}}@keyframes beacon-pulse{0%,to{opacity:.4;transform:scale(.85)}50%{opacity:.9;transform:scale(1.05)}}.tile-zone{border-color:#ffad338c}.tile-zone:before{content:"";position:absolute;top:18%;right:18%;bottom:18%;left:18%;border:2px solid rgba(255,173,51,.55);border-radius:50%}.tile-zone:after{content:"";position:absolute;top:38%;right:38%;bottom:38%;left:38%;border-radius:50%;background:#ffad3340}.tile-door{background:repeating-linear-gradient(45deg,#2a3140 0,#2a3140 8px,#1c212c 8px,#1c212c 16px);border-color:#3d68ae;box-shadow:inset 0 0 0 2px #508cdc80}.tile-door-open{background:var(--mars-2);border-color:#508cdc59;box-shadow:inset 0 0 10px #508cdc26}.sample{position:absolute;top:22%;right:22%;bottom:22%;left:22%;filter:drop-shadow(0 0 6px rgba(255,173,51,.6));animation:sample-bob 2.4s ease-in-out infinite}.sample svg{width:100%;height:100%}.sample[data-count]:after{content:attr(data-count);position:absolute;top:-6px;right:-6px;font-family:var(--font-mono);font-size:9px;background:var(--accent);color:#14100a;border-radius:99px;padding:0 4px}@keyframes sample-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-7%)}}.rover-layer{position:absolute;top:0;left:0;z-index:5;transition:transform .18s cubic-bezier(.3,.1,.3,1);pointer-events:none}.rover-sprite{width:100%;height:100%;padding:6%;transition:transform .16s ease}.rover-sprite svg{width:100%;height:100%;overflow:visible}.rover-sprite.is-crashed{animation:crash-shake .5s ease}.rover-sprite.is-dead{filter:grayscale(.9) brightness(.55);animation:fall-in .6s ease forwards}@keyframes crash-shake{0%,to{translate:0 0}20%{translate:-6% 0}40%{translate:5% 0}60%{translate:-4% 0}80%{translate:3% 0}}@keyframes fall-in{to{scale:.4;opacity:.25;rotate:28deg}}.cargo-light{animation:beacon-pulse 1.2s ease-in-out infinite}.rover-bubble{position:absolute;bottom:102%;left:50%;transform:translate(-50%);background:var(--text);color:#14100a;font-size:12px;font-weight:700;padding:5px 10px;border-radius:8px;white-space:nowrap;max-width:240px;overflow:hidden;text-overflow:ellipsis;z-index:6}.rover-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--text)}.grid-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text-faint);font-family:var(--font-mono);font-size:13px;background:var(--bg-raise);padding:24px;text-align:center}.signal-dots{display:flex;gap:8px}.signal-dots span{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:dot-blink 1.2s ease-in-out infinite}.signal-dots span:nth-child(2){animation-delay:.2s}.signal-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-blink{0%,to{opacity:.25}50%{opacity:1}}.console{border-top:1px solid var(--line-soft);height:148px;display:flex;flex-direction:column;flex-shrink:0}.console-lines{flex:1;overflow-y:auto;padding:8px 14px;font-family:var(--font-mono);font-size:12px;line-height:1.7}.console-line{color:var(--text-dim)}.console-line .prefix{color:var(--text-faint);margin-right:4px}.console-line.ok{color:var(--ok)}.console-line.error{color:var(--error)}.console-line.say{color:var(--accent)}.code-panel{display:flex;flex-direction:column}.editor-host{flex:1;min-height:0;overflow:auto;background:var(--bg)}.editor-host .cm-editor{height:100%}.run-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-top:1px solid var(--line-soft);flex-shrink:0}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#05070ac7;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fade .25s ease}@keyframes fade{0%{opacity:0}}.dialog{background:var(--bg-panel);border:1px solid var(--line);border-radius:14px;padding:34px 38px;max-width:480px;width:calc(100% - 40px);text-align:center;animation:rise .4s cubic-bezier(.2,.9,.3,1.2) both;box-shadow:0 40px 80px -30px #000c}.stamp{display:inline-block;color:var(--ok);border:1px solid rgba(61,220,151,.4);padding:5px 12px;border-radius:99px;margin-bottom:16px}.dialog h2{font-size:30px;letter-spacing:-.02em}.dialog-sub{color:var(--text-faint);margin:4px 0 18px;font-size:14px}.dialog-stars{font-size:44px;letter-spacing:10px;margin-bottom:18px}.big-star{display:inline-block;color:#2c3445}.big-star.on{color:var(--accent);text-shadow:0 0 24px rgba(255,173,51,.6);animation:star-pop .5s cubic-bezier(.2,.9,.3,1.4) both}@keyframes star-pop{0%{transform:scale(.2) rotate(-30deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.dialog-breakdown{list-style:none;margin:0 0 8px;padding:0;text-align:left}.dialog-breakdown li{display:flex;align-items:baseline;gap:10px;padding:7px 0;border-bottom:1px solid var(--line-soft);font-size:14px;color:var(--text-dim)}.dialog-breakdown li.earned{color:var(--text)}.dialog-breakdown .check{font-family:var(--font-mono);color:var(--ok);width:14px}.dialog-breakdown li.missed .check{color:var(--text-faint)}.robust-dots .dot{margin-left:4px}.robust-dots .dot.ok{color:var(--ok)}.robust-dots .dot.fail{color:var(--error)}.dialog-tip{color:var(--text-faint);font-size:13px;margin:10px 0 0}.dialog-actions{display:flex;justify-content:center;gap:10px;margin-top:22px}@media(max-width:1180px){.play-body{grid-template-columns:280px 1fr 380px}}@media(max-width:980px){.play-body{grid-template-columns:1fr;grid-template-rows:auto auto auto;overflow-y:auto}.play-screen{height:auto;min-height:100%}.briefing{order:1;max-height:320px}.terrain{order:0}.code-panel{order:2;min-height:420px}}
