html,body{margin:0;padding:0}:root{--bg:#f5f1e8;--surface:#ede7d8;--surface-2:#e3dcc9;--ink:#18211b;--ink-soft:#2a352e;--muted:#76817a;--border:#d6cebd;--accent:#3d6b4a;--accent-soft:#3d6b4a59;--accent-bg:#3d6b4a14;--accent-ink:#f5f1e8;--ok:#3d6b4a;--err:#a23d3d}*{box-sizing:border-box}html,body,#root{background:var(--bg);height:100%;color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,system-ui,-apple-system,sans-serif}.screen{flex-direction:column;gap:18px;max-width:480px;min-height:100%;margin:0 auto;padding:22px 20px 32px;display:flex}.screen.loading,.screen.error{color:var(--muted);letter-spacing:1px;justify-content:center;align-items:center;font-size:14px}header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:baseline;padding-bottom:14px;display:flex}.title{letter-spacing:-.5px;color:var(--ink);font-family:Fraunces,serif;font-size:26px;font-weight:600}.day{color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;font-size:11px}.header-right{align-items:center;gap:12px;display:flex}.icon-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;padding:0;font-family:Fraunces,serif;font-size:13px;font-weight:600;line-height:1;transition:color .12s,border-color .12s;display:inline-flex}.icon-btn:hover{color:var(--accent);border-color:var(--accent-soft)}.puzzle-bar{text-align:center;padding:28px 12px 24px}.puzzle-bar .word{color:var(--ink);font-family:Fraunces,serif;font-size:36px;font-weight:500;line-height:1.05;display:inline-block}.puzzle-bar .end{color:var(--accent);font-style:italic}.puzzle-bar .arrow{color:var(--muted);letter-spacing:6px;-webkit-user-select:none;user-select:none;margin:14px 0;font-size:13px;display:block}.meta{color:var(--muted);letter-spacing:1px;text-transform:uppercase;justify-content:space-between;padding:0 4px;font-size:11px;display:flex}.chain{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.chain li{background:var(--surface);border:1px solid var(--border);border-radius:10px;flex-wrap:nowrap;align-items:baseline;gap:14px;padding:12px 16px;font-size:17px;transition:border-color .12s;display:flex}.chain li.first{border-color:var(--accent-soft);background:var(--accent-bg)}.chain li.last-win{border-color:var(--accent);background:var(--accent-bg);animation:1.4s cubic-bezier(.22,1,.36,1) win-pulse}@keyframes win-pulse{0%{box-shadow:0 0 0 0 var(--accent-soft);transform:scale(.85)}35%{transform:scale(1.06);box-shadow:0 0 0 18px #3d6b4a00}60%{transform:scale(.99)}to{transform:scale(1)}}.chain .num{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;min-width:18px;font-family:Fraunces,serif;font-size:13px}.chain li.first .num,.chain li.last-win .num{color:var(--accent)}.chain .word{color:var(--ink);font-weight:500}.chain .pct{color:var(--muted);font-variant-numeric:tabular-nums;letter-spacing:.3px;margin-left:auto;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px}.chain li.first .pct,.chain li.last-win .pct{color:var(--accent)}.nudge{text-align:center;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-soft);letter-spacing:.3px;border-radius:8px;padding:10px 14px;font-size:13px;animation:2s ease-in-out infinite nudge-pulse}.nudge em{font-family:Fraunces,serif;font-style:italic;font-weight:500}@keyframes nudge-pulse{0%,to{background:var(--accent-bg)}50%{background:#3d6b4a29}}.input-row{gap:8px;margin-top:6px;display:flex}.input-row input{background:var(--surface);border:1px solid var(--border);color:var(--ink);border-radius:10px;outline:none;flex:1;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .12s}.input-row input::placeholder{color:var(--muted)}.input-row input:focus{border-color:var(--accent)}.input-row button{background:var(--accent);color:var(--accent-ink);letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border:none;border-radius:10px;padding:0 22px;font-family:inherit;font-size:13px;font-weight:600;transition:opacity .12s}.input-row button:disabled{opacity:.35;cursor:not-allowed}.actions{justify-content:center;gap:24px;padding:4px 0;display:flex}.text-btn{color:var(--muted);letter-spacing:.5px;cursor:pointer;background:0 0;border:none;padding:6px 4px;font-family:inherit;font-size:13px;transition:color .12s}.text-btn:hover:not(:disabled){color:var(--ink)}.text-btn:disabled{opacity:.35;cursor:not-allowed}.text-btn.danger{color:var(--err);opacity:.7}.text-btn.danger:hover:not(:disabled){color:var(--err);opacity:1}.confirm{background:var(--surface-2);border:1px solid var(--err);border-radius:10px;flex-direction:column;gap:10px;padding:14px 16px;display:flex}.confirm-msg{color:var(--ink);font-size:14px}.confirm-actions{justify-content:flex-end;gap:16px;display:flex}.feedback{text-align:center;letter-spacing:.3px;border-radius:8px;padding:10px 14px;font-size:13px}.feedback.rejected{color:var(--err);background:#a23d3d14;border:1px solid #a23d3d33}.feedback.ok{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-soft)}.feedback.hint{color:var(--ink-soft);text-align:left;background:#b48c3c14;border:1px solid #b48c3c4d;padding:10px 14px}.hint-tag{color:var(--bg);letter-spacing:1.5px;text-transform:uppercase;background:#b48c3cb3;border-radius:4px;margin-right:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-block}.input-preview{color:var(--muted);letter-spacing:.3px;margin-top:-8px;padding-left:4px;font-size:12px}.preview-sim{color:var(--accent);font-weight:500}.preview-unknown{color:var(--err);opacity:.7}.guesses{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-top:4px;padding:14px 16px}.guesses-header{letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-size:10px;font-weight:600}.guesses-sub{text-transform:none;letter-spacing:0;opacity:.8;margin-left:4px;font-size:10px;font-weight:400}.chain-label{letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);text-align:right;margin-top:-4px;margin-bottom:-8px;font-size:10px}.chain-label em{color:var(--accent);font-style:italic}.guesses-list{flex-direction:column;gap:4px;max-height:280px;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.guess{color:var(--ink-soft);border-radius:6px;grid-template-columns:28px 1fr 80px 44px;align-items:center;gap:8px;padding:4px 6px;font-size:13px;display:grid}.guess.is-current{background:var(--accent-bg);border:1px solid var(--accent-soft);padding:3px 5px}.guess-rank{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;font-size:10px}.guess-word{font-weight:500}.guess-too-far .guess-word{color:var(--muted);text-decoration:line-through}.guess-unknown .guess-word{color:var(--err);opacity:.6;font-style:italic}.guess-hint .guess-word{color:var(--accent)}.guess-hint .guess-word:after{content:" 💡";font-size:10px}.guess-bar{background:var(--surface-2);border-radius:3px;height:6px;overflow:hidden}.guess-bar-fill{background:var(--accent-soft);border-radius:3px;height:100%;display:block}.is-current .guess-bar-fill{background:var(--accent)}.guess-pct{color:var(--muted);text-align:right;font-variant-numeric:tabular-nums;font-size:12px}.is-current .guess-pct{color:var(--accent);font-weight:600}.pico-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);text-align:center;margin-top:4px;font-size:10px;font-weight:600}.compass-grid{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.compass-chip{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--ink);border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;font-family:inherit;transition:all .12s;display:flex}.compass-chip:hover{border-color:var(--accent);background:var(--accent-bg)}.compass-chip.closer{border-color:var(--accent-soft)}.compass-chip.farther{opacity:.7}.chip-word{font-size:15px;font-weight:500}.chip-pct{color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px}.compass-chip.closer .chip-pct{color:var(--accent);font-weight:600}.compass-promo{color:var(--muted);text-align:center;letter-spacing:.3px;font-size:12px}.compass-promo.subtle{opacity:.85;margin-top:-4px}.compass-promo a{color:var(--accent);border-bottom:1px dashed var(--accent-soft);font-weight:600;text-decoration:none}.compass-promo a:hover{border-bottom-style:solid}.win{background:var(--surface);border:1px solid var(--accent);text-align:center;border-radius:14px;flex-direction:column;gap:14px;margin-top:8px;padding:22px;display:flex}.win.forfeit{border-color:var(--muted)}.win .banner{color:var(--accent);font-family:Fraunces,serif;font-size:22px;font-style:italic;font-weight:500}.win.forfeit .banner{color:var(--muted)}.optimal-reveal{background:var(--bg);border:1px solid var(--border);text-align:left;border-radius:10px;padding:14px}.optimal-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:10px;font-weight:600}.optimal-chain{color:var(--ink);font-family:Fraunces,serif;font-size:16px;line-height:1.5}.optimal-chain .accent{color:var(--accent)}.optimal-chain .sep{color:var(--muted);margin:0 4px}.distance-arc{background:var(--bg);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:6px;padding:14px 12px 8px;display:flex}.arc-title{letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);text-align:left;font-size:10px;font-weight:600}.distance-arc svg{width:100%;height:auto;display:block}.distance-arc .grid-line{stroke:var(--border);stroke-width:1px}.distance-arc .grid-label{fill:var(--muted);font-family:ui-monospace,monospace;font-size:9px}.distance-arc .goal-line{stroke:var(--accent-soft);stroke-width:1px;stroke-dasharray:2 3}.distance-arc .goal-label{fill:var(--accent);letter-spacing:1px;text-transform:uppercase;font-size:9px;font-weight:600}.distance-arc .user-line{stroke:var(--accent);stroke-width:2px;fill:none}.distance-arc .user-dot{fill:var(--accent)}.distance-arc .opt-line{stroke:var(--muted);stroke-width:1px;stroke-dasharray:3 3;fill:none;opacity:.6}.distance-arc .opt-dot{fill:var(--muted);opacity:.6}.distance-arc .x-label{fill:var(--muted);font-family:ui-monospace,monospace;font-size:9px}.arc-legend{color:var(--muted);letter-spacing:.5px;justify-content:flex-end;gap:14px;font-size:11px;display:flex}.arc-legend .swatch{vertical-align:middle;width:12px;height:2px;margin-right:5px;display:inline-block}.arc-legend .swatch.user{background:var(--accent)}.arc-legend .swatch.opt{background:var(--muted);border-top:1px dashed var(--muted);opacity:.6;height:0}.win .share{background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;text-align:left;color:var(--ink-soft);border-radius:8px;margin:0;padding:14px;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:13px}.win button{background:var(--accent);color:var(--accent-ink);letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border:none;border-radius:10px;padding:12px 22px;font-family:inherit;font-size:13px;font-weight:600}.next-up{border-top:1px solid var(--border);color:var(--muted);letter-spacing:.5px;flex-direction:column;gap:4px;padding-top:12px;font-size:13px;display:flex}.next-up .streak{color:var(--accent);font-family:Fraunces,serif;font-size:16px;font-style:italic;font-weight:500}.next-up .countdown{font-variant-numeric:tabular-nums}.dev-panel{background:var(--surface-2);border:1px dashed var(--muted);border-radius:10px;flex-direction:column;gap:14px;margin-top:24px;padding:16px;font-size:13px;display:flex}.dev-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding-bottom:10px;display:flex}.dev-tag{background:var(--ink);color:var(--bg);letter-spacing:1.5px;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.dev-current{color:var(--ink);font-family:Fraunces,serif;font-size:13px}.dev-panel section{flex-direction:column;gap:6px;display:flex}.dev-panel label{color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;font-size:10px;font-weight:600}.dev-row{flex-wrap:wrap;gap:6px;display:flex}.dev-row input{background:var(--bg);border:1px solid var(--border);min-width:80px;color:var(--ink);border-radius:6px;outline:none;flex:1;padding:8px 10px;font-family:inherit;font-size:13px}.dev-row input:focus{border-color:var(--accent)}.dev-row button{background:var(--ink);color:var(--bg);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border:none;border-radius:6px;padding:8px 12px;font-family:inherit;font-size:11px;font-weight:600}.dev-row button:hover{background:var(--accent)}.dev-output{background:var(--bg);border:1px solid var(--border);white-space:pre-wrap;color:var(--ink-soft);border-radius:6px;margin:0;padding:10px;font-family:ui-monospace,monospace;font-size:12px}.dev-validation{color:var(--err);background:#a23d3d14;border-radius:6px;padding:8px 12px;font-size:12px}.tutorial{background:var(--bg);z-index:10;flex-direction:column;animation:.28s fadein;display:flex;position:fixed;inset:0}@keyframes fadein{0%{opacity:0}to{opacity:1}}.tutorial-frame{flex-direction:column;flex:1;width:100%;max-width:480px;margin:0 auto;padding:36px 24px 28px;display:flex}.tutorial-progress{gap:6px;margin-bottom:36px;display:flex}.tutorial-progress .pip{background:var(--border);border-radius:2px;flex:1;height:3px;transition:background .24s}.tutorial-progress .pip.active{background:var(--accent)}.tutorial-body{flex-direction:column;flex:1;justify-content:center;gap:28px;display:flex}.tutorial h1{color:var(--ink);letter-spacing:-.5px;margin:0;font-family:Fraunces,serif;font-size:34px;font-weight:500;line-height:1.15}.tutorial h1 em{color:var(--accent);font-style:italic}.tutorial p{color:var(--ink-soft);margin:0;font-size:17px;line-height:1.55}.tutorial p .accent{color:var(--accent);font-weight:500}.tutorial-example{background:var(--surface);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex}.tutorial-example .step{align-items:baseline;gap:14px;padding:8px 4px;display:flex}.tutorial-example .step .num{color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;min-width:18px;font-family:Fraunces,serif;font-size:13px}.tutorial-example .step .word{color:var(--ink);font-family:Fraunces,serif;font-size:22px;font-weight:500}.tutorial-example .step.start .word,.tutorial-example .step.end .word{color:var(--accent)}.tutorial-example .step.end .word{font-style:italic}.tutorial-pair{flex-direction:column;gap:14px;display:flex}.tutorial-pair .row{border-radius:10px;justify-content:space-between;align-items:baseline;padding:14px 18px;font-family:Fraunces,serif;font-size:18px;display:flex}.tutorial-pair .row.good{background:var(--accent-bg);border:1px solid var(--accent-soft);color:var(--ink)}.tutorial-pair .row.bad{color:var(--ink);background:#a23d3d0f;border:1px solid #a23d3d33}.tutorial-pair .verdict{letter-spacing:1.5px;text-transform:uppercase;font-family:Inter,sans-serif;font-size:11px;font-weight:600}.tutorial-pair .row.good .verdict{color:var(--accent)}.tutorial-pair .row.bad .verdict{color:var(--err)}.tutorial-cta{gap:12px;margin-top:24px;display:flex}.tutorial-cta button{background:var(--accent);color:var(--accent-ink);letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;border:none;border-radius:10px;flex:1;padding:14px 22px;font-family:inherit;font-size:13px;font-weight:600}.tutorial-cta button.ghost{color:var(--muted);border:1px solid var(--border);background:0 0;flex:none}.tutorial-sandbox-hint{color:var(--muted);text-align:center;margin-top:8px;font-size:13px}.def-link{color:var(--muted);opacity:.5;vertical-align:baseline;margin:0 4px 0 6px;font-size:11px;line-height:1;text-decoration:none;transition:opacity .12s,color .12s;display:inline-block}.def-link:hover{opacity:1;color:var(--accent)}.optimal-chain .def-link,.compass-chip .def-link{margin:0 2px 0 4px;font-size:10px}.compass-chip .def-link{position:absolute;top:6px;right:8px}.compass-chip{position:relative}.confetti{pointer-events:none;z-index:1000;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.confetti-piece{opacity:0;border-radius:2px;width:8px;height:14px;animation:1.6s cubic-bezier(.18,.7,.42,1) forwards confetti-fly;position:absolute;transform:translate(0,0)rotate(0)}@keyframes confetti-fly{0%{opacity:0;transform:translate(0,0)rotate(0)scale(.4)}18%{opacity:1}to{opacity:0;transform:translate3d(var(--dx), calc(var(--dy) + 220px), 0) rotate(var(--rot)) scale(1)}}.win{animation:.48s cubic-bezier(.22,1,.36,1) win-banner-in}@keyframes win-banner-in{0%{opacity:0;transform:scale(.92)translateY(8px)}60%{transform:scale(1.02)}to{opacity:1;transform:scale(1)translateY(0)}}.win .banner{animation:.7s cubic-bezier(.22,1,.36,1) .12s backwards banner-text-in}@keyframes banner-text-in{0%{opacity:0;letter-spacing:-.5px;transform:translateY(-4px)}to{opacity:1;letter-spacing:0;transform:translateY(0)}}
