:root{--bg: #04070f;--surface: #0b1120;--border: #1a2a45;--accent: #00ffe0;--accent2: #ff6aff;--warn: #ffb800;--err: #ff4545;--ok: #39ff87;--text: #cde4ff;--muted: #4a6080;--glow: 0 0 12px rgba(0,255,224,.45);--glow2: 0 0 12px rgba(255,106,255,.45)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Space Mono,monospace;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(rgba(0,255,224,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,224,.03) 1px,transparent 1px);background-size:40px 40px}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.07) 2px,rgba(0,0,0,.07) 4px)}#app{position:relative;z-index:1;max-width:960px;margin:0 auto;padding:16px}header{display:flex;align-items:center;justify-content:space-between;padding:16px 0 20px;border-bottom:1px solid var(--border);margin-bottom:18px}.logo{font-family:Syne,sans-serif;font-size:2rem;font-weight:800;letter-spacing:-1px;background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:10px}.streak-badge{display:flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:5px 13px;font-size:.75rem;color:var(--warn)}.icon-btn{width:34px;height:34px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.icon-btn:hover{border-color:var(--accent);box-shadow:var(--glow)}.icon-btn.active{border-color:var(--accent);box-shadow:var(--glow);color:var(--accent)}.small-btn{padding:10px 16px;border-radius:10px;border:none;cursor:pointer;font-family:Syne,sans-serif;font-weight:700;font-size:.8rem;letter-spacing:.8px;transition:opacity .2s,box-shadow .2s,transform .1s}.small-btn.primary{background:linear-gradient(135deg,var(--accent),#0099aa);color:#04070f;box-shadow:0 0 16px #00ffe03d}.small-btn.secondary{background:#ffffff0f;color:var(--text);border:1px solid var(--border)}.small-btn.secondary:hover{background:#00ffe014}.small-btn.danger{background:linear-gradient(135deg,var(--err),#ff8a8a);color:#04070f}.button-row{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.mode-row{display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:18px}.mode-pill{padding:5px 14px;border-radius:18px;font-size:.75rem;font-family:Space Mono,monospace;letter-spacing:1px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--muted);transition:all .2s}.mode-pill.active{color:var(--accent);border-color:var(--accent);box-shadow:var(--glow)}.custom-banner{margin:10px 0;padding:12px 16px;border-radius:12px;background:#ff6aff1f;border:1px solid rgba(255,106,255,.25);color:var(--accent2);text-align:center;font-weight:700;letter-spacing:1px}.history-row{display:flex;align-items:flex-start;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 11px;animation:slideIn .3s ease both;font-size:.78rem;cursor:pointer}.history-row:hover{border-color:var(--accent)}.history-stage-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.history-stage-pill{border:none;outline:none;cursor:pointer;font-size:.65rem;padding:3px 8px;border-radius:999px;background:#ffffff0d;color:var(--muted);transition:all .2s}.history-stage-pill:hover{background:#ff6aff29;color:var(--accent2)}.history-stage-pill.active{background:#ff6aff3d;color:#fff;border:1px solid rgba(255,106,255,.35)}.dev-panel{display:none;margin-top:14px;padding:14px 16px;border:1px solid rgba(0,255,224,.16);border-radius:12px;background:#00ffe00a;font-size:.78rem;color:var(--text)}.dev-panel.visible{display:block;border-color:var(--accent);box-shadow:var(--glow)}.dev-line{margin-bottom:6px}.diff-row{display:flex;gap:8px;justify-content:center;margin-bottom:18px;animation:fadeUp .4s ease both}.diff-pill{padding:5px 16px;border-radius:20px;font-size:.72rem;font-family:Space Mono,monospace;letter-spacing:1px;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--muted);transition:all .2s}.diff-pill:hover{color:var(--text);border-color:var(--muted)}.diff-pill.active{background:#00ffe01a;border-color:var(--accent);color:var(--accent);box-shadow:var(--glow)}.diff-pill.active.hard{background:#ff6aff1a;border-color:var(--accent2);color:var(--accent2);box-shadow:var(--glow2)}.graph-section{animation:fadeUp .5s .1s ease both}.graph-label-row{display:flex;gap:10px;margin-bottom:6px}.graph-label{flex:1;text-align:center;font-family:Syne,sans-serif;font-size:.65rem;letter-spacing:3px;color:var(--muted);text-transform:uppercase}.graph-row{display:flex;gap:10px;justify-content:center;align-items:stretch}.graph-wrap{flex:1;position:relative;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#020810;transition:border-color .3s,box-shadow .3s}.graph-wrap.highlight{border-color:var(--ok);box-shadow:0 0 12px #39ff8766}.graph-wrap canvas{display:block;width:100%!important;height:210px!important}.graph-arrow{display:flex;align-items:center;justify-content:center;align-self:stretch;font-size:1.4rem;color:var(--muted);padding:0 2px}.graph-right{display:flex;gap:12px;align-items:flex-start;flex:1;min-width:0}.guess-panel{display:flex;flex-direction:column;gap:10px;width:54px;flex-shrink:0;margin-top:0;padding-top:0;position:relative;top:-26px}.guess-panel:before{content:"VIEW";font-family:Syne,sans-serif;font-size:.72rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px;text-align:center}.guess-tab{width:42px;height:38px;display:flex;align-items:center;justify-content:center;padding:0;border-radius:14px;border:1px solid var(--border);background:#ffffff0a;color:var(--muted);cursor:pointer;font-family:Space Mono,monospace;font-size:.72rem;letter-spacing:1px;text-transform:none;transition:all .18s ease}.guess-tab:hover{border-color:var(--accent2);background:#ff6aff1f;color:var(--text)}.guess-tab.active{background:linear-gradient(135deg,#ff6aff38,#ff6aff1f);color:#fff;border-color:#ff6aff73;box-shadow:0 0 14px #ff6aff2e;transform:translate(-5px);text-shadow:0 0 8px rgba(255,106,255,.45)}.hover-tooltip{position:absolute;pointer-events:none;background:#04070ff5;color:#f8fafc;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:8px 10px;font-family:Space Mono,monospace;font-size:.78rem;z-index:150;white-space:nowrap;transform:translate(-50%,-120%)}.hover-tooltip{position:fixed;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 10px;font:10px Space Mono,monospace;color:var(--text);pointer-events:none;white-space:nowrap}.graph-tools{display:grid;grid-template-columns:1fr 1fr;gap:34px;margin-top:10px}.graph-tools .guess-panel{position:static;top:auto;width:auto;flex-direction:row;align-items:center;gap:8px}.graph-tools .guess-panel:before{margin:0 4px 0 0}.graph-tools .guess-tab.active{transform:translateY(-2px)}#baseGuessTabs:before{content:"BASE"}#guessTabs:before{content:"TARGET"}.graph-tools .guess-tab:hover{border-color:var(--accent);background:#00ffe014;color:var(--text)}.graph-tools .guess-tab.active{background:#00ffe01a;border-color:var(--accent);color:var(--accent);box-shadow:var(--glow);text-shadow:none}#guessTabs .guess-tab:hover{border-color:var(--accent2);background:#ff6aff1a}#guessTabs .guess-tab.active{background:#ff6aff1a;border-color:var(--accent2);color:var(--accent2);box-shadow:var(--glow2)}.input-section{margin-top:18px;animation:fadeUp .5s .2s ease both}.chip-groups{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.chip-group-label{font-size:.6rem;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-bottom:3px}.chip-row{display:flex;gap:5px;flex-wrap:wrap}.chip{font-size:.63rem;padding:3px 9px;border-radius:4px;background:#00ffe012;border:1px solid rgba(0,255,224,.2);color:var(--accent);cursor:pointer;transition:all .15s;font-family:Space Mono,monospace}.chip:hover{background:#00ffe026}.chip.op2{color:var(--accent2);background:#ff6aff12;border-color:#ff6aff33}.chip.op2:hover{background:#ff6aff26}.chip.op3{color:var(--warn);background:#ffb80012;border-color:#ffb80033}.chip.op3:hover{background:#ffb80026}.input-row{display:flex;gap:8px;align-items:stretch}.equation-row{display:none}.dsl-preview{flex:1;min-height:38px;display:flex;align-items:center;padding:8px 11px;border:1px solid rgba(0,255,224,.14);border-radius:10px;background:#00ffe00a;color:var(--muted);font-size:.72rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}#guess,#equation-guess{flex:1;padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:Space Mono,monospace;font-size:.88rem;outline:none;transition:border-color .2s,box-shadow .2s}#guess:focus,#equation-guess:focus{border-color:var(--accent);box-shadow:var(--glow)}#guess::placeholder,#equation-guess::placeholder{color:var(--muted)}#submit-btn{padding:11px 20px;border-radius:10px;border:none;cursor:pointer;font-family:Syne,sans-serif;font-weight:700;font-size:.88rem;background:linear-gradient(135deg,var(--accent),#0099aa);color:#04070f;letter-spacing:1px;transition:opacity .2s,box-shadow .2s,transform .1s;box-shadow:0 0 16px #00ffe04d}#submit-btn:hover{opacity:.9;box-shadow:0 0 24px #00ffe080}#submit-btn:active{transform:scale(.97)}#submit-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.attempts-row{display:flex;gap:6px;justify-content:center;margin-top:10px}.attempt-pip{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:var(--glow);transition:all .3s}.attempt-pip.used{background:var(--muted);box-shadow:none}.attempt-pip.last{background:var(--err);box-shadow:0 0 8px #ff454580}#feedback-bar{margin-top:10px;min-height:24px;text-align:center;font-size:.78rem;color:var(--muted);transition:color .3s}#hint-bar{margin-top:8px;min-height:18px;text-align:center;font-size:.68rem;color:var(--muted)}.history-section{margin-top:18px;animation:fadeUp .5s .3s ease both}.history-title{font-size:.62rem;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:8px;text-align:center}#history-list{display:flex;flex-direction:column;gap:5px}.history-row{display:flex;align-items:flex-start;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 11px;animation:slideIn .3s ease both;font-size:.78rem}.history-num{color:var(--muted);min-width:16px}.history-body{flex:1;display:flex;flex-direction:column;gap:4px}.history-expr{font-family:Space Mono,monospace;color:var(--text);word-break:break-all}.history-tags{display:flex;gap:4px;flex-wrap:wrap}.history-err{font-size:.68rem;color:var(--muted);margin-top:2px}.tag{font-size:.62rem;padding:2px 7px;border-radius:4px;font-family:Space Mono,monospace}.tag.ok{background:#39ff871f;color:var(--ok);border:1px solid rgba(57,255,135,.3)}.tag.err{background:#ff45451f;color:var(--err);border:1px solid rgba(255,69,69,.3)}.tag.warn{background:#ffb8001f;color:var(--warn);border:1px solid rgba(255,184,0,.3)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#04070fd9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;pointer-events:none;transition:opacity .3s}.modal-overlay.open{opacity:1;pointer-events:all}.modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px 30px;max-width:520px;width:92%;max-height:85vh;overflow-y:auto;transform:translateY(20px);transition:transform .3s;position:relative}.modal-overlay.open .modal{transform:translateY(0)}.modal-close{position:absolute;top:12px;right:12px;width:26px;height:26px;border-radius:6px;background:var(--border);border:none;cursor:pointer;color:var(--text);font-size:.85rem;display:flex;align-items:center;justify-content:center}.modal h2{font-family:Syne,sans-serif;font-size:1.25rem;margin-bottom:14px;background:linear-gradient(90deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal h3{font-family:Syne,sans-serif;font-size:.85rem;color:var(--accent);margin:14px 0 6px;letter-spacing:1px}.modal p,.modal li{font-size:.8rem;line-height:1.75;color:var(--text)}.modal ul{padding-left:16px}.modal code{background:#00ffe01a;padding:1px 5px;border-radius:3px;color:var(--accent);font-family:Space Mono,monospace}.modal hr{border:none;border-top:1px solid var(--border);margin:12px 0}.modal .answer-box{background:#00ffe00d;border:1px solid rgba(0,255,224,.2);border-radius:8px;padding:10px 14px;font-size:.82rem;font-family:Space Mono,monospace;color:var(--accent);margin:10px 0;word-break:break-all}.tutorial-rail{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0 14px}.tutorial-dot{width:28px;height:26px;border-radius:8px;border:1px solid var(--border);background:#ffffff0a;color:var(--muted);cursor:pointer;font:.68rem Space Mono,monospace}.tutorial-dot.complete{color:var(--ok);border-color:#39ff8759;background:#39ff8714}.tutorial-dot.next{color:var(--accent);border-color:var(--accent)}.tutorial-dot.latest{box-shadow:var(--glow2);border-color:var(--accent2);color:var(--accent2)}.tutorial-dot.active{box-shadow:var(--glow);border-color:var(--accent);color:#fff;transform:translateY(-1px)}.result-modal .big-emoji{font-size:2.8rem;text-align:center;margin-bottom:6px}.result-modal .result-title{font-family:Syne,sans-serif;font-size:1.4rem;font-weight:800;text-align:center;margin-bottom:10px}.result-modal .answer-box{background:#00ffe00d;border:1px solid rgba(0,255,224,.2);border-radius:8px;padding:10px 14px;font-size:.82rem;font-family:Space Mono,monospace;color:var(--accent);margin:10px 0;word-break:break-all}.stats-row{display:flex;gap:10px;justify-content:center;margin:14px 0}.stat-box{flex:1;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px;text-align:center}.stat-box .val{font-family:Syne,sans-serif;font-size:1.7rem;font-weight:800;color:var(--accent)}.stat-box .lbl{font-size:.62rem;color:var(--muted);margin-top:2px;letter-spacing:1px}.share-btn{width:100%;padding:11px;border-radius:10px;border:none;cursor:pointer;font-family:Syne,sans-serif;font-weight:700;font-size:.88rem;background:linear-gradient(135deg,var(--accent2),#aa00ff);color:#fff;letter-spacing:1px;margin-top:8px;transition:opacity .2s}.share-btn:hover{opacity:.9}#toast-container{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:6px;align-items:center;pointer-events:none}.toast{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:7px 16px;font-size:.78rem;color:var(--text);box-shadow:0 4px 20px #0006;animation:toastIn .3s ease both;white-space:nowrap}.toast.good{border-color:var(--ok);color:var(--ok)}.toast.bad{border-color:var(--err);color:var(--err)}.toast.info{border-color:var(--accent);color:var(--accent)}#confetti-canvas{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:150}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}@keyframes graphReveal{0%{opacity:0;transform:scaleY(.75)}to{opacity:1;transform:scaleY(1)}}.shaking{animation:shake .4s ease}@media (max-width:600px){.logo{font-size:1.4rem}.graph-row{flex-direction:column}.graph-arrow{transform:rotate(90deg);min-height:30px}.graph-tools{display:flex;align-items:flex-start;flex-direction:column}.graph-tools .guess-panel{flex-wrap:wrap}}
