:root{color-scheme:dark;--bg: #060810;--bg-grid: #1a2034;--panel: #181f33;--panel-elev: #20283e;--line: #353f5a;--line-strong: #5a678a;--text: #fbf3df;--text-dim: #c4bba0;--muted: #99a3bc;--amber: #ffc14d;--amber-soft: #ffc14d33;--magenta: #ff7aa3;--mint: #87f7c8;--warn: #ff8a6c;--modal-overlay: rgba(0, 0, 0, .62);--button-fg: #16110a;--board-frame-bg: linear-gradient(180deg, #0e1320, #0a0e17);--board-frame-border: var(--line);--board-frame-shadow: 0 0 0 transparent;--input-bg: #050810;--input-bg-focus: #0a0f1c;--input-placeholder: #5a6478;--share-pre-bg: #050810;--error-bg: #2a1818;--error-fg: #ffc1b0;--danger-border: #4a2a26;--pip-off: #444a5a;--r-red: #ff5959;--r-green: #4ade80;--r-blue: #60a5fa;--r-yellow: #fbbf24;--font-display: "Major Mono Display", ui-monospace, monospace;--font-body: "Sora", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace}:root[data-theme=light]{color-scheme:light;--bg: #f4ead4;--bg-grid: #ddc99a;--panel: #fcf6e3;--panel-elev: #fffbe9;--line: #c8b58a;--line-strong: #8a7548;--text: #1a1f2e;--text-dim: #5a5238;--muted: #8a7f63;--amber: #c8881e;--amber-soft: rgba(200, 136, 30, .18);--magenta: #c2487a;--mint: #1c8a5a;--warn: #b5421e;--modal-overlay: rgba(40, 30, 10, .42);--button-fg: #1a1f2e;--board-frame-bg: linear-gradient(180deg, #e8d6a0 0%, #dec88a 100%);--board-frame-border: var(--line-strong);--board-frame-shadow: 0 14px 40px -16px rgba(40, 30, 10, .4);--input-bg: #fffefa;--input-bg-focus: #fffce8;--input-placeholder: #b8a87a;--share-pre-bg: #fffce8;--error-bg: #f5d8c8;--error-fg: #7a2810;--danger-border: #d8a896;--pip-off: #c4b894}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-body);font-weight:400;background:radial-gradient(ellipse 80% 60% at 50% -10%,#1c2336 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 100% 110%,#2a1830 0%,transparent 65%),linear-gradient(180deg,var(--bg) 0%,#0a0d14 100%);background-attachment:fixed;color:var(--text);min-height:100vh;letter-spacing:.005em;position:relative;overflow-x:hidden;transition:color .2s ease}[data-theme=light] body{background:radial-gradient(ellipse 80% 60% at 50% -10%,#f7e2a4 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 100% 110%,#f0c8aa 0%,transparent 65%),linear-gradient(180deg,var(--bg) 0%,#ead68f 100%)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,var(--bg-grid) 1px,transparent 1px),linear-gradient(to bottom,var(--bg-grid) 1px,transparent 1px);background-size:38px 38px;background-position:-1px -1px;opacity:.6;pointer-events:none;z-index:0;-webkit-mask-image:radial-gradient(ellipse 100% 80% at 50% 40%,#000 40%,transparent 100%);mask-image:radial-gradient(ellipse 100% 80% at 50% 40%,#000 40%,transparent 100%)}[data-theme=light] body:before{opacity:.55}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.012) 0 1px,transparent 1px 3px);pointer-events:none;z-index:1;mix-blend-mode:overlay}[data-theme=light] body:after{display:none}.app{position:relative;z-index:2;min-height:100vh;padding:28px 28px 60px;display:flex;flex-direction:column;align-items:center}.topbar{width:100%;max-width:1180px;display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;font-family:var(--font-display);text-transform:lowercase;gap:14px}.topbar .right{display:flex;align-items:center;gap:14px}.topbar-icon{background:transparent;border:1px solid var(--line);color:var(--muted);width:34px;height:34px;padding:0;border-radius:4px;display:grid;place-items:center;cursor:pointer;transition:color .16s,border-color .16s,transform .38s cubic-bezier(.2,.8,.2,1);flex-shrink:0}.topbar-icon:hover{color:var(--amber);border-color:var(--amber);filter:none;box-shadow:none}.topbar-icon:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.topbar-icon svg{display:block}.topbar .brand{font-size:18px;letter-spacing:.18em;color:var(--text)}.topbar .brand-link{background:transparent;border:none;padding:0;cursor:pointer;font-family:var(--font-display);text-transform:lowercase;transition:color .15s}.topbar .brand-link:hover{color:var(--amber);filter:none;box-shadow:none}.topbar .brand-link:focus-visible{outline:2px solid var(--amber);outline-offset:4px}.topbar .brand .dot{color:var(--amber)}.topbar .meta{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-dim);letter-spacing:.15em;text-transform:uppercase}.lobby{width:100%;max-width:520px;margin:4vh auto 0;position:relative;animation:lobby-in .6s cubic-bezier(.2,.8,.2,1) both}@keyframes lobby-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.patch-banner{position:relative;padding:12px 16px 14px;margin:0 0 18px;background:var(--panel);border:1px solid var(--line);border-radius:4px;box-shadow:0 6px 18px -14px #00000073}.patch-banner:before,.patch-banner:after{content:"";position:absolute;width:14px;height:14px;border:1.5px solid var(--amber);pointer-events:none}.patch-banner:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.patch-banner:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.patch-banner-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.patch-banner-badge{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--bg);background:var(--amber);padding:2px 7px;border-radius:2px;flex-shrink:0}.patch-banner-date{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:lowercase;color:var(--text-dim);flex-shrink:0}.patch-banner-title{font-family:var(--font-body);font-size:14px;color:var(--text);flex:1 1 auto;min-width:0}.patch-banner-close{background:transparent;border:none;color:var(--text-dim);font-size:20px;line-height:1;padding:2px 8px;cursor:pointer;border-radius:2px;transition:color .14s,background .14s}.patch-banner-close:hover{color:var(--amber);background:#ffc14d14}.patch-banner-list{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.patch-banner-list li{font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--text-dim);padding-left:14px;position:relative}.patch-banner-list li:before{content:"›";position:absolute;left:0;color:var(--amber);opacity:.7}@media (max-width: 700px){.patch-banner{padding:10px 12px 12px;margin-bottom:14px}.patch-banner-list li{font-size:11px}}.lobby .hero{padding:0 4px 20px;text-align:left}.lobby .hero .kicker{font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;color:var(--amber);text-transform:uppercase;margin-bottom:10px}.lobby .hero h1{font-family:var(--font-display);font-size:clamp(40px,7vw,64px);line-height:.95;letter-spacing:.02em;margin:0 0 12px;text-transform:lowercase;color:var(--text);text-shadow:0 2px 24px rgba(255,193,77,.08)}.lobby .hero h1 .accent{color:var(--amber)}.lobby .hero .subtitle{font-size:14px;color:var(--text-dim);letter-spacing:.01em;max-width:38ch;line-height:1.5}.lobby .card{position:relative;background:linear-gradient(180deg,var(--panel-elev) 0%,var(--panel) 100%);border:1px solid var(--line);padding:26px 26px 24px;margin-top:18px;border-radius:2px}.lobby .multiplayer-card{padding-top:22px}.lobby .multiplayer-card .card-heading{margin:-4px 0 18px;padding-bottom:14px;border-bottom:1px dashed var(--line)}.lobby .multiplayer-card .card-eyebrow{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;color:var(--magenta);text-transform:uppercase;margin-bottom:6px}.lobby .multiplayer-card .card-sub{display:block;font-size:13px;color:var(--muted);letter-spacing:.02em}.daily-card{position:relative;margin-top:22px;padding:24px 26px;border:1.5px solid var(--amber);border-radius:4px;cursor:pointer;overflow:hidden;background:linear-gradient(135deg,#3a2810,#1f1408 65%,#0c0803);transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s;box-shadow:0 0 0 1px #ffc14d26,0 12px 32px -16px #ffc14d4d}.daily-card:hover{transform:translateY(-2px);box-shadow:0 0 0 1px #ffc14d4d,0 18px 40px -16px #ffc14d8c}[data-theme=light] .daily-card{background:linear-gradient(135deg,#fff5d4,#fbe5b3 60%,#f5d690);box-shadow:0 0 0 1px #c8881e2e,0 8px 24px -14px #78501466}[data-theme=light] .daily-card:hover{box-shadow:0 0 0 1px #c8881e59,0 16px 36px -14px #78501480}.daily-card:active{transform:translateY(0)}.daily-card:focus-visible{outline:2px solid var(--amber);outline-offset:3px}.daily-card:before,.daily-card:after{content:"";position:absolute;width:16px;height:16px;border:1.5px solid var(--amber);pointer-events:none}.daily-card:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.daily-card:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.daily-card-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 40% 80% at 100% 0%,rgba(255,180,68,.18),transparent 60%),radial-gradient(ellipse 50% 70% at 0% 100%,rgba(255,92,142,.1),transparent 60%);pointer-events:none}.daily-card-inner{position:relative}.daily-eyebrow{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.3em;color:var(--amber);text-transform:uppercase}.daily-card-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px}.daily-streak{font-family:var(--font-mono);font-size:12px;font-weight:600;color:var(--amber);letter-spacing:.06em;display:inline-flex;align-items:baseline;gap:4px;white-space:nowrap}.daily-streak strong{font-size:18px;font-variant-numeric:tabular-nums;color:var(--amber)}.daily-streak .best{color:var(--text-dim);font-weight:400;font-size:10px;margin-left:6px}.daily-streak.lapsed{opacity:.5;filter:grayscale(.5)}.daily-streak.lapsed strong{color:var(--muted)}.streak-line{margin-top:12px;font-size:14px;color:var(--text);display:flex;align-items:baseline;gap:6px}.streak-line strong{font-family:var(--font-mono);font-size:22px;color:var(--amber);font-variant-numeric:tabular-nums}.streak-line .streak-best{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);letter-spacing:.04em}.daily-headline{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;margin-bottom:10px}.daily-date{font-family:var(--font-mono);font-weight:600;font-size:17px;color:var(--text);letter-spacing:.04em}.daily-status{font-size:13px;color:var(--text);margin-bottom:14px;display:flex;flex-direction:column;gap:4px}.daily-status strong{color:var(--amber);font-weight:500}.daily-result{font-family:var(--font-mono);font-size:12px;color:var(--mint);letter-spacing:.04em}.daily-cta{font-family:var(--font-display);font-size:14px;letter-spacing:.1em;text-transform:lowercase;color:var(--amber)}.blitz-card{position:relative;margin-top:14px;padding:16px 20px;border:1.5px solid var(--mint);border-radius:4px;cursor:pointer;background:linear-gradient(135deg,#0d2820,#061812);transition:transform .2s cubic-bezier(.2,.8,.2,1),box-shadow .2s;box-shadow:0 0 0 1px #87f7c81f,0 8px 24px -14px #87f7c84d}.blitz-card:hover{transform:translateY(-2px);box-shadow:0 0 0 1px #87f7c84d,0 14px 32px -14px #87f7c880}[data-theme=light] .blitz-card{background:linear-gradient(135deg,#d9f0e2,#bde3cd);box-shadow:0 0 0 1px #1c8a5a2e,0 8px 22px -12px #1c8a5a73}[data-theme=light] .blitz-card:hover{box-shadow:0 0 0 1px #1c8a5a59,0 14px 30px -12px #1c8a5a8c}.blitz-card:focus-visible{outline:2px solid var(--mint);outline-offset:3px}.blitz-eyebrow{font-family:var(--font-display);font-size:18px;letter-spacing:.18em;color:var(--mint);text-transform:lowercase;margin-bottom:6px}.blitz-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);letter-spacing:.05em;margin-bottom:10px}.blitz-cta{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--mint)}.big-optimal{font-family:var(--font-mono);font-weight:700;font-size:88px;color:var(--amber);line-height:.95;text-align:center;margin:8px 0 6px;font-variant-numeric:tabular-nums;text-shadow:0 0 28px rgba(255,193,77,.4)}[data-theme=light] .big-optimal{text-shadow:0 0 14px rgba(200,136,30,.3)}.big-optimal-sub{text-align:center;font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase}.big-optimal-sub strong{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums}.board-frame.blitz-shake{animation:blitz-shake .45s cubic-bezier(.36,.07,.19,.97)}@keyframes blitz-shake{10%,90%{transform:translate(-3px)}20%,80%{transform:translate(4px)}30%,50%,70%{transform:translate(-6px)}40%,60%{transform:translate(6px)}}.blitz-delta{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:64px;font-weight:700;letter-spacing:.02em;pointer-events:none;animation:blitz-delta 1.1s cubic-bezier(.2,.8,.2,1) forwards;z-index:5;text-shadow:0 0 24px currentColor}.blitz-delta.plus{color:var(--mint)}.blitz-delta.minus{color:var(--warn)}.blitz-throne-optimal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-weight:700;font-size:64px;font-variant-numeric:tabular-nums;line-height:.95;color:var(--amber);pointer-events:none;z-index:4;text-shadow:0 0 18px color-mix(in srgb,currentColor 70%,transparent),0 0 36px color-mix(in srgb,currentColor 45%,transparent),0 2px 6px rgba(0,0,0,.6)}[data-theme=light] .blitz-throne-optimal{text-shadow:0 0 18px color-mix(in srgb,currentColor 55%,transparent),0 2px 6px rgba(0,0,0,.4)}@media (max-width: 700px){.blitz-throne-optimal{font-size:36px}}.blitz-timer-strip{font-family:var(--font-mono);font-weight:700;font-size:28px;letter-spacing:.04em;color:var(--mint);font-variant-numeric:tabular-nums;line-height:1}.blitz-timer-strip.low{color:var(--warn);animation:blitz-pulse 1s ease-in-out infinite}.blitz-unranked-pill{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.22em;text-transform:lowercase;color:var(--warn);border:1px dotted color-mix(in srgb,var(--warn) 65%,transparent);background:color-mix(in srgb,var(--warn) 6%,transparent);padding:4px 10px 3px;border-radius:2px;-webkit-user-select:none;user-select:none;cursor:help}.command-bar-right .blitz-unranked-pill+.command-primary{margin-left:10px}@media (max-width: 700px){.blitz-unranked-pill{font-size:9px;letter-spacing:.18em;padding:3px 8px 2px}}.blitz-delta{z-index:5}@keyframes blitz-delta{0%{opacity:0;transform:translate(-50%,-30%) scale(.6)}20%{opacity:1;transform:translate(-50%,-50%) scale(1)}80%{opacity:1;transform:translate(-50%,-55%) scale(1)}to{opacity:0;transform:translate(-50%,-90%) scale(1)}}.blitz-timer.low .timer{animation:blitz-pulse 1s ease-in-out infinite}@keyframes blitz-pulse{50%{color:#ff8a6c8c}}.custom-card{position:relative;margin-top:14px;padding:18px 22px;border:1.5px solid var(--line-strong);border-radius:4px;cursor:pointer;background:linear-gradient(135deg,#14202c,#0e1722);transition:transform .2s cubic-bezier(.2,.8,.2,1),border-color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:space-between;gap:16px}.custom-card:hover{transform:translateY(-1px);border-color:#6ec3ff;box-shadow:0 12px 28px -16px #6ec3ff80}[data-theme=light] .custom-card{background:linear-gradient(135deg,#d8ecf7,#bcdcef);border-color:var(--line-strong);box-shadow:0 8px 22px -14px #2c7eb573}[data-theme=light] .custom-card:hover{border-color:#2c7eb5;box-shadow:0 14px 28px -12px #2c7eb58c}.custom-eyebrow{font-family:var(--font-display);font-size:17px;letter-spacing:.18em;color:#6ec3ff;text-transform:lowercase;margin:0}[data-theme=light] .custom-eyebrow{color:#2c7eb5}.custom-cta{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#6ec3ff;white-space:nowrap}[data-theme=light] .custom-cta{color:#2c7eb5}.tool-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.tool-grid.four{grid-template-columns:repeat(4,1fr)}.tool-btn,.tool-symbol{background:transparent;color:var(--text);border:1.5px solid var(--line);padding:9px 6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s;border-radius:3px}.tool-btn:hover,.tool-symbol:hover{border-color:var(--text-dim);filter:none;box-shadow:none}.tool-btn.selected,.tool-symbol.selected{border-color:var(--amber);color:var(--amber);box-shadow:inset 0 0 0 1px var(--amber-soft)}.tool-robot{background:transparent;border:1.5px solid var(--line);padding:8px 4px;font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:lowercase;font-weight:600;color:var(--text);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:border-color .15s;border-radius:3px}.tool-robot[data-color=Red]{color:var(--r-red)}.tool-robot[data-color=Green]{color:var(--r-green)}.tool-robot[data-color=Blue]{color:var(--r-blue)}.tool-robot[data-color=Yellow]{color:var(--r-yellow)}.tool-robot .swatch{width:12px;height:12px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor}.tool-robot:hover{border-color:currentColor;filter:none;box-shadow:none}.tool-robot.selected{border-color:currentColor;box-shadow:inset 0 0 0 1px currentColor,0 0 10px -2px currentColor}.tool-btn.full{width:100%}.placed-list{display:flex;flex-direction:column;gap:6px}.placed-row{display:grid;grid-template-columns:14px 1fr 24px;align-items:center;gap:8px;padding:6px 8px;border:1px solid var(--line);border-radius:3px;font-size:12px;font-family:var(--font-mono);color:var(--text)}.placed-row[data-color=Red]{color:var(--r-red)}.placed-row[data-color=Green]{color:var(--r-green)}.placed-row[data-color=Blue]{color:var(--r-blue)}.placed-row[data-color=Yellow]{color:var(--r-yellow)}.placed-row .swatch{width:10px;height:10px;border-radius:50%;background:currentColor;box-shadow:0 0 4px currentColor}.placed-row .swatch.ring{background:transparent;border:2px solid currentColor}.placed-row span:nth-child(2){color:var(--text);font-size:11px;letter-spacing:.04em}.placed-remove{background:transparent;border:1px solid var(--line);color:var(--muted);width:22px;height:22px;padding:0;border-radius:3px;cursor:pointer;font-size:14px;line-height:1}.placed-remove:hover{color:var(--warn);border-color:var(--warn);filter:none;box-shadow:none}.lab-card{position:relative;margin-top:14px;padding:18px 22px;border:1.5px solid var(--line-strong);border-radius:4px;cursor:pointer;background:linear-gradient(135deg,#20162e,#15101e);transition:transform .2s cubic-bezier(.2,.8,.2,1),border-color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:space-between;gap:16px}.lab-card:hover{transform:translateY(-1px);border-color:var(--magenta);box-shadow:0 12px 28px -16px #ff7aa380}[data-theme=light] .lab-card{background:linear-gradient(135deg,#f6dde8,#ecc3d4);border-color:var(--line-strong);box-shadow:0 8px 22px -14px #c2487a73}[data-theme=light] .lab-card:hover{border-color:var(--magenta);box-shadow:0 14px 28px -12px #c2487a8c}.lab-card:focus-visible{outline:2px solid var(--magenta);outline-offset:3px}.special-card{position:relative;margin-top:14px;padding:20px 24px;border:1.5px solid var(--amber);border-radius:4px;cursor:pointer;background:radial-gradient(ellipse 80% 100% at 0% 100%,rgba(255,193,77,.18),transparent 60%),linear-gradient(135deg,#1f1607,#110c04);transition:transform .2s cubic-bezier(.2,.8,.2,1),border-color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:space-between;gap:16px;overflow:hidden}.special-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,rgba(255,193,77,.06) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,193,77,.06) 1px,transparent 1px);background-size:12px 12px;pointer-events:none}.special-card:hover{transform:translateY(-1px);box-shadow:0 16px 36px -16px #ffc14d8c,inset 0 0 0 1px #ffc14d66}[data-theme=light] .special-card{background:radial-gradient(ellipse 80% 100% at 0% 100%,rgba(255,193,77,.35),transparent 60%),linear-gradient(135deg,#f7e6b8,#f0d690);box-shadow:0 10px 22px -12px #b4821e66}[data-theme=light] .special-card:hover{box-shadow:0 16px 32px -12px #b4821e8c}.special-card:focus-visible{outline:2px solid var(--amber);outline-offset:3px}.special-card-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%}.special-eyebrow{font-family:var(--font-display);font-size:18px;letter-spacing:.2em;color:var(--amber);text-transform:lowercase}.special-headline{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;color:var(--text-dim);text-transform:uppercase}.special-headline strong{color:var(--amber);font-weight:700;font-size:16px;margin-right:2px}.special-cta{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--amber);white-space:nowrap}@media (max-width: 540px){.special-card-inner{flex-direction:column;align-items:flex-start;gap:8px}}.lab-eyebrow{font-family:var(--font-display);font-size:17px;letter-spacing:.18em;color:var(--magenta);text-transform:lowercase;margin:0}.lab-cta{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--magenta);white-space:nowrap}.crit-grid{display:flex;flex-direction:column;gap:8px}.crit-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:4px 0;font-size:13px;color:var(--text)}.crit-row input[type=number]{padding:4px 8px;font-size:13px;width:60px}.crit-row input[type=checkbox]{accent-color:var(--magenta);width:14px;height:14px}.crit-pair{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);color:var(--muted)}.crit-pair input{width:50px}.stat-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;font-family:var(--font-mono);border-bottom:1px dashed var(--line)}.stat-row:last-child{border-bottom:none}.stat-row .stat-name{color:var(--muted);letter-spacing:.04em;text-transform:uppercase}.stat-row .stat-val{color:var(--text);font-weight:500}.lobby .card:before,.lobby .card:after,.bracket-frame:before,.bracket-frame:after{content:"";position:absolute;width:14px;height:14px;border:1px solid var(--amber);pointer-events:none}.lobby .card:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.lobby .card:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.field-label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;color:var(--text-dim);text-transform:uppercase;margin:0 0 8px}.lobby .field{margin-bottom:18px}.lobby .field:last-child{margin-bottom:4px}.lobby .row{display:grid;grid-template-columns:1fr auto;gap:10px}.lobby .row.tight{grid-template-columns:90px 1fr auto}.lobby .mp-row{display:grid;grid-template-columns:minmax(0,1fr) 105px auto;grid-template-rows:auto auto;column-gap:8px;row-gap:6px;align-items:stretch}.lobby .mp-row>label.field-label{margin-bottom:0;align-self:end}.lobby .mp-row>input{height:42px;padding-top:0;padding-bottom:0;box-sizing:border-box}.lobby .mp-row>button{height:42px;align-self:end}@media (max-width: 380px){.lobby .mp-row{grid-template-columns:minmax(0,1fr) 88px auto;column-gap:6px}}.divider{display:flex;align-items:center;gap:10px;margin:22px 0 18px;color:var(--muted);font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--line)}input,select{background:var(--input-bg);color:var(--text);border:1px solid var(--line);padding:11px 13px;border-radius:2px;font-family:var(--font-mono);font-size:14px;width:100%;outline:none;transition:border-color .15s,background .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--amber);background:var(--input-bg-focus);box-shadow:0 0 0 1px var(--amber-soft)}input::placeholder{color:var(--input-placeholder);letter-spacing:.05em}input.code{text-transform:uppercase;font-family:var(--font-mono);font-weight:700;letter-spacing:.32em;text-align:center;font-size:17px}button{background:var(--amber);color:var(--button-fg);border:none;padding:11px 20px;border-radius:2px;font-family:var(--font-display);font-size:13px;letter-spacing:.18em;text-transform:lowercase;cursor:pointer;transition:transform .1s,box-shadow .2s,filter .15s;white-space:nowrap}button:hover:not(:disabled){filter:brightness(1.08);box-shadow:0 0 0 1px var(--amber),0 0 16px -4px var(--amber)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.35;cursor:not-allowed}button.ghost{background:transparent;color:var(--text);border:1px solid var(--line-strong)}button.ghost:hover:not(:disabled){border-color:var(--amber);box-shadow:0 0 0 1px var(--amber-soft);filter:none}button.danger{background:transparent;color:var(--warn);border:1px solid var(--danger-border)}button.danger:hover:not(:disabled){border-color:var(--warn);box-shadow:0 0 12px -4px var(--warn);filter:none}button.full{width:100%}.error{margin-top:14px;padding:10px 12px;background:var(--error-bg);border-left:2px solid var(--warn);color:var(--error-fg);font-size:12px;font-family:var(--font-mono);letter-spacing:.04em;animation:shake .2s cubic-bezier(.36,.07,.19,.97)}@keyframes shake{10%,90%{transform:translate(-1px)}30%,70%{transform:translate(2px)}50%{transform:translate(-3px)}}.lobby .footnote{margin-top:22px;font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.12em;text-align:center}.game{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:28px;align-items:start;width:100%;max-width:1400px;animation:lobby-in .5s cubic-bezier(.2,.8,.2,1) both}.game>.board-frame,.game>.board-column{justify-self:center}.game.game-solo{grid-template-columns:minmax(0,1fr)}.game.has-details{display:grid;grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:stretch;gap:24px;width:100%;max-width:1400px}.game.has-details>.board-column{grid-column:2;justify-self:center}.game.has-details>.details-panel{grid-column:3;justify-self:start}.game.has-details>.sidebar{grid-column:1;justify-self:end;max-width:340px;width:100%}.board-column{display:flex;flex-direction:column;align-items:center;gap:10px}.meta-strip{font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.18em;text-transform:lowercase;color:var(--text-dim);font-variant-numeric:tabular-nums;display:inline-flex;gap:8px;align-items:baseline}.meta-strip .meta-num{color:var(--text)}.meta-strip .meta-solved{color:var(--mint)}.mobile-robot-strip{display:none}@media (max-width: 700px){.mobile-robot-strip{display:block;width:100%}.mobile-robot-strip .robot-row{margin:0}}.command-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}.command-bar-left{display:flex;align-items:center;gap:4px;justify-self:start}.command-bar-center{justify-self:center}.command-bar-right{display:flex;align-items:center;justify-self:end}@media (max-width: 700px){.command-bar{grid-template-columns:auto 1fr;grid-template-areas:"left   center" "right  right";row-gap:10px}.command-bar-left{grid-area:left}.command-bar-center{grid-area:center;justify-self:end}.command-bar-right{grid-area:right;justify-self:stretch;justify-content:center}.command-bar-right .command-primary{width:100%;min-height:72px;padding:18px 16px;font-size:14px}}.command-bar .icon-btn{background:transparent;border:none;color:var(--text-dim);width:30px;height:30px;padding:0;border-radius:3px;display:grid;place-items:center;cursor:pointer;transition:color .16s,background .16s;flex-shrink:0}.command-bar .icon-btn:hover:not(:disabled){color:var(--amber);background:#ffc14d14;box-shadow:none;filter:none}.command-bar .icon-btn:disabled{opacity:.3;cursor:not-allowed}.command-bar .icon-btn svg{display:block}.command-bar .command-primary{padding:8px 16px;font-size:12px;font-family:var(--font-mono);font-weight:600;letter-spacing:.16em;text-transform:lowercase}.meta-strip.subtle{font-size:11px;font-weight:500;letter-spacing:.16em;color:color-mix(in srgb,var(--text-dim) 78%,transparent)}[data-theme=light] .meta-strip.subtle{color:color-mix(in srgb,var(--text-dim) 62%,transparent)}.rr-icon-flame{color:#ff6a2c;filter:drop-shadow(0 0 3px rgba(255,106,44,.55));vertical-align:-2px}[data-theme=light] .rr-icon-flame{color:#d6480f;filter:drop-shadow(0 0 2px rgba(214,72,15,.4))}.daily-streak.lapsed .rr-icon-flame{color:var(--muted);filter:none}.mode-pill-strip{display:flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:14px;padding:4px 0 0;width:100%}.mode-pill-strip-label{font-family:var(--font-mono);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.22em;color:var(--muted);flex:0 0 auto}.mode-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid var(--line);border-radius:3px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:lowercase;color:var(--text-dim);cursor:pointer;transition:color .16s,border-color .16s,background .16s,transform .16s;position:relative}.mode-pill .mode-pill-glyph{font-size:12px;line-height:1;opacity:.85}.mode-pill:hover{transform:translateY(-1px);filter:none;box-shadow:none}.mode-pill:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.mode-pill.amber:hover{color:var(--amber);border-color:var(--amber);background:#ffc14d14}.mode-pill.mint:hover{color:var(--mint);border-color:var(--mint);background:#87f7c814}.mode-pill.magenta:hover{color:var(--magenta);border-color:var(--magenta);background:#ff7aa31a}@media (max-width: 700px){.mode-pill-strip{gap:8px;padding-top:2px}.mode-pill{padding:8px 12px;font-size:11px}.mode-pill-strip-label{width:100%;text-align:center;padding-bottom:2px}}.lobby-snapshot{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px 18px;margin-top:18px;padding:10px 14px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:lowercase;color:var(--text-dim);opacity:.85}.lobby-snapshot .snapshot-chip{display:inline-flex;align-items:baseline;gap:6px}.lobby-snapshot .snapshot-chip .glyph{font-size:13px;opacity:.9}.lobby-snapshot .snapshot-chip .num{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}.topbar .live-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--amber);box-shadow:0 0 6px #ffc14d99;margin-right:4px;flex-shrink:0}.topbar .room-meta{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-dim);letter-spacing:.18em;text-transform:uppercase;margin-right:4px}@media (max-width: 700px){.topbar .live-dot,.topbar .room-meta{display:none}}.details-panel{width:280px;background:var(--panel);border:1px solid var(--line);border-radius:4px;position:relative;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 24px -16px #0006}.details-panel:focus{outline:none}[data-theme=light] .details-panel{background:var(--panel);border-color:var(--line-strong);box-shadow:0 6px 18px -12px #281e0a4d}.details-panel:before,.details-panel:after{content:"";position:absolute;width:14px;height:14px;border:1.5px solid var(--line-strong);pointer-events:none}.details-panel:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.details-panel:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.details-tabs{display:flex;gap:0;border-bottom:1px solid var(--line);flex-shrink:0;background:var(--panel-elev)}.details-tab{flex:1 1 0;min-width:0}.details-tab{background:transparent;border:none;border-right:1px solid var(--line);padding:10px 8px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:lowercase;color:var(--muted);cursor:pointer;transition:color .16s,background .16s}.details-tab:hover:not(.active){color:var(--text-dim);background:#ffffff05}.details-tab.active{color:var(--text);background:var(--panel);position:relative;filter:none;box-shadow:none}.details-tabs.accent-amber .details-tab.active{box-shadow:inset 0 -2px 0 var(--amber)}.details-tabs.accent-mint .details-tab.active{box-shadow:inset 0 -2px 0 var(--mint)}.details-tabs.accent-magenta .details-tab.active{box-shadow:inset 0 -2px 0 var(--magenta)}.details-collapse{background:transparent;border:none;border-left:1px solid var(--line);color:var(--muted);font-family:var(--font-mono);font-size:12px;width:32px;cursor:pointer;transition:color .16s;display:none}.details-collapse:hover{color:var(--text-dim);filter:none;box-shadow:none}.details-content{flex:1 1 auto;overflow:hidden;display:flex;flex-direction:column;min-height:0}.details-section{padding:14px 16px 16px;display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.details-section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:10px}.details-section-label{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.22em;color:var(--muted)}.details-section-count{font-family:var(--font-mono);font-weight:700;font-size:26px;color:var(--text);font-variant-numeric:tabular-nums;line-height:1}.details-meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:-4px 0 8px}.details-empty{font-family:var(--font-body);font-size:12px;line-height:1.5;color:var(--text-dim);padding:8px 0}.details-empty p{margin:0 0 12px}.move-list{list-style:none;margin:0;padding:0;font-family:var(--font-mono);font-size:12px;font-variant-numeric:tabular-nums;flex:1 1 auto;overflow-y:auto;min-height:0}.move-list-empty{font-family:var(--font-body);font-size:12px;color:var(--text-dim);padding:8px 0;font-style:italic}.move-row{display:grid;grid-template-columns:28px 12px 7ch 1fr 14px 1fr 6ch;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid color-mix(in srgb,var(--line) 40%,transparent)}.move-row:last-child{border-bottom:none}.move-row .index{color:var(--muted);text-align:right}.move-row .swatch{width:12px;height:12px;border-radius:2px;border:1px solid color-mix(in srgb,#000 30%,transparent)}.move-row .color{color:var(--text-dim);letter-spacing:.04em}.move-row .arrow{grid-column:5;color:var(--text);display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;transition:transform .12s}.move-row .dir{grid-column:7;color:var(--muted);letter-spacing:.04em;text-align:right;white-space:nowrap}.move-row.active{background:color-mix(in srgb,var(--amber) 10%,transparent);border-radius:2px}.move-row.active .arrow,.move-row.active .index{color:var(--amber)}.details-secondary-btn{margin-top:10px;padding:8px 12px;background:transparent;border:1px solid var(--line);border-radius:3px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:lowercase;color:var(--text-dim);cursor:pointer;transition:color .16s,border-color .16s,background .16s;width:100%}.details-secondary-btn:hover{color:var(--text);border-color:var(--line-strong);background:#ffffff0a;filter:none;box-shadow:none}.details-secondary-btn.warn:hover{color:var(--warn);border-color:var(--warn);background:color-mix(in srgb,var(--warn) 10%,transparent)}.details-stepper{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:8px;margin-top:12px;padding:8px 10px;background:var(--input-bg);border:1px solid var(--line);border-radius:3px}.details-stepper .icon-btn{background:transparent;border:none;color:var(--text-dim);width:30px;height:30px;padding:0;border-radius:3px;display:grid;place-items:center;cursor:pointer;font-family:var(--font-mono);font-size:16px;line-height:1;transition:color .16s,background .16s}.details-stepper .icon-btn:hover:not(:disabled){color:var(--amber);background:#ffc14d14}.details-stepper .icon-btn:disabled{opacity:.3;cursor:not-allowed}.details-stepper-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:lowercase;color:var(--muted);text-align:center;font-variant-numeric:tabular-nums}.details-stepper-label strong{color:var(--text);font-weight:700}@media (max-width: 1080px){.game.has-details{grid-template-columns:minmax(0,1fr)}.game.has-details>.board-column{grid-column:1}.game.has-details>.details-panel{grid-column:1;justify-self:stretch;width:100%;max-width:560px;margin:0 auto;align-self:start}.details-collapse{display:block}.details-panel.mobile-collapsed .details-content{display:none}.details-panel.mobile-collapsed .details-tabs{border-bottom:none}}@media (max-width: 700px){.details-tab{padding:12px 6px;font-size:10px;letter-spacing:.16em}.details-section{padding:12px 14px 14px}.details-section-count{font-size:22px}}.board-frame{position:relative;padding:18px;background:var(--board-frame-bg);border:1px solid var(--board-frame-border);border-radius:4px;max-width:100%;margin:0 auto;box-shadow:var(--board-frame-shadow)}[data-theme=light] .board-frame canvas{box-shadow:0 0 0 2px #1a1f2e,0 6px 18px -8px #0006}[data-theme=light] .board-frame .frame-label{background:#dec88a}.board-frame:before,.board-frame:after{content:"";position:absolute;width:22px;height:22px;border:1.5px solid var(--amber);pointer-events:none}.board-frame:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.board-frame:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.board-frame .frame-label{position:absolute;top:-10px;left:24px;background:var(--bg);padding:0 10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.3em;color:var(--amber);text-transform:uppercase}.board-resize-handle{position:absolute;right:4px;bottom:4px;width:14px;height:14px;cursor:nwse-resize;touch-action:none;-webkit-user-select:none;user-select:none;z-index:4;background:linear-gradient(135deg,transparent 0%,transparent 38%,var(--text-dim) 38%,var(--text-dim) 50%,transparent 50%,transparent 70%,var(--text-dim) 70%,var(--text-dim) 82%,transparent 82%);opacity:.55;transition:opacity .16s,filter .16s}.board-resize-handle:hover{opacity:1;filter:brightness(1.4)}[data-theme=light] .board-resize-handle{opacity:.65}@media (max-width: 700px){.board-resize-handle{display:none}}.board-empty{width:100%;aspect-ratio:1 / 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;color:var(--muted);font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;text-align:center;padding:0 16px}.board-empty .standby{color:var(--text-dim)}.board-empty .room-code-big{font-family:var(--font-mono);font-weight:700;font-size:64px;letter-spacing:.18em;color:var(--amber);text-shadow:0 0 30px rgba(255,180,68,.35);animation:pulse-glow 2.4s ease-in-out infinite}@keyframes pulse-glow{0%,to{text-shadow:0 0 30px rgba(255,180,68,.25)}50%{text-shadow:0 0 50px rgba(255,180,68,.55)}}.sidebar{display:flex;flex-direction:column;gap:16px}.panel{position:relative;background:linear-gradient(180deg,var(--panel-elev) 0%,var(--panel) 100%);border:1px solid var(--line);padding:16px 18px;border-radius:2px;animation:panel-in .35s cubic-bezier(.2,.8,.2,1) both;box-shadow:0 1px #ffffff0a inset,0 6px 18px -10px #0009}.panel+.panel{animation-delay:60ms}.panel+.panel+.panel{animation-delay:.12s}@keyframes panel-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.panel .label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.28em;color:var(--text);text-transform:uppercase;margin:0 0 10px;display:flex;align-items:center;gap:8px}.panel .label:before{content:"";width:6px;height:6px;background:var(--amber);display:inline-block}.room-panel .room-code{font-family:var(--font-mono);font-weight:700;font-size:32px;letter-spacing:.2em;color:var(--amber);margin:4px 0 10px;text-shadow:0 0 16px rgba(255,180,68,.25)}.room-panel .meta-line{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;display:flex;justify-content:space-between;border-top:1px dashed var(--line);padding-top:10px;margin-top:12px}.room-panel .meta-line strong{color:var(--text);font-weight:500}.players{list-style:none;padding:0;margin:8px 0 0}.players li{display:grid;grid-template-columns:14px 1fr auto;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:14px;color:var(--text)}.players li:last-child{border-bottom:none}.players .pip{width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 6px var(--mint)}.players .pip.off{background:var(--pip-off);box-shadow:none}.players .name{color:var(--text)}.players .name.you{color:var(--amber);font-weight:500}.players .crown{display:inline-block;width:12px;height:12px;margin-left:4px;background:var(--amber);clip-path:polygon(0 100%,0 35%,25% 60%,50% 0,75% 60%,100% 35%,100% 100%);vertical-align:-1px}.players .score{font-family:var(--font-mono);font-weight:500;color:var(--text);font-variant-numeric:tabular-nums;font-size:14px}.players li.dim{opacity:.45}.phase-panel{background:linear-gradient(180deg,#1c1530 0%,var(--panel) 100%)}[data-theme=light] .phase-panel{background:linear-gradient(180deg,#f0e1f0 0%,var(--panel) 100%)}.phase-panel .phase-line{font-family:var(--font-display);font-size:18px;letter-spacing:.08em;color:var(--text);text-transform:lowercase;margin-bottom:4px}.phase-panel .phase-line .pulse{display:inline-block;width:6px;height:6px;background:var(--magenta);border-radius:50%;margin-right:8px;animation:blink 1.2s ease-in-out infinite;vertical-align:2px}@keyframes blink{50%{opacity:.25}}.phase-panel .timer{font-family:var(--font-mono);font-size:28px;font-weight:500;color:var(--amber);font-variant-numeric:tabular-nums;letter-spacing:.04em;margin:6px 0 4px}.phase-panel .target-line{font-size:13px;color:var(--muted);margin-top:8px;letter-spacing:.02em}.phase-panel .target-line .robot-chip{display:inline-block;padding:1px 8px 2px;border-radius:999px;margin:0 2px;font-family:var(--font-display);font-size:10px;letter-spacing:.18em;text-transform:lowercase;color:#14110a;font-weight:700}.bids-panel .bids{list-style:none;padding:0;margin:8px 0;min-height:28px}.bids-panel .bids li{display:grid;grid-template-columns:1fr auto;padding:7px 0;border-bottom:1px solid var(--line);font-size:14px;font-family:var(--font-mono);color:var(--text)}.bids-panel .bids li:last-child{border-bottom:none}.bids-panel .bids li .moves{font-weight:600;font-variant-numeric:tabular-nums;color:var(--text)}.bids-panel .bids li.lowest .moves{color:var(--mint);text-shadow:0 0 8px rgba(121,247,197,.35)}.bids-panel .bids li.lowest .name:before{content:"▸ ";color:var(--mint)}.bids-panel .empty{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;padding:8px 0 10px}.bid-input{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:12px}.bid-input input{padding:10px 12px}.hint{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.1em;margin-top:8px;line-height:1.5;position:relative;padding-right:18px}.hint-dismiss{position:absolute;top:-2px;right:-2px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);font-size:14px;font-family:var(--font-mono);line-height:1;cursor:pointer;opacity:.5;transition:opacity .15s ease,color .15s ease;padding:0}.hint-dismiss:hover{opacity:1;color:var(--text)}.host-actions{margin-top:12px;border-top:1px dashed var(--line);padding-top:12px}.host-actions button{width:100%}.robot-row{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.robot-btn{background:transparent;color:var(--text);border:1.5px solid var(--line);padding:12px 0;font-family:var(--font-display);font-size:14px;letter-spacing:.1em;text-transform:lowercase;cursor:pointer;transition:all .16s;display:flex;flex-direction:column;align-items:center;gap:4px}.robot-btn .swatch{width:14px;height:14px;border-radius:50%;box-shadow:0 0 10px currentColor;background:currentColor}.robot-btn[data-color=Red]{color:var(--r-red)}.robot-btn[data-color=Green]{color:var(--r-green)}.robot-btn[data-color=Blue]{color:var(--r-blue)}.robot-btn[data-color=Yellow]{color:var(--r-yellow)}.robot-btn:hover{border-color:currentColor;background:#ffffff08}.robot-btn.selected{border-color:currentColor;box-shadow:inset 0 0 0 1px currentColor,0 0 12px -2px currentColor;background:#ffffff0a}.demo-panel .pass{margin-top:14px;width:100%}.spectator{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);letter-spacing:.05em;padding:8px 0}.spectator strong{color:var(--amber);font-weight:500}.spectator .dots:after{content:"…";display:inline-block;animation:dots 1.6s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}to{content:"…"}}.reveal{text-align:left;background:linear-gradient(180deg,#1a2b1f 0%,var(--panel) 100%);border-color:#2a4a35;animation:panel-in .4s ease-out both}.reveal.fail{background:linear-gradient(180deg,#2b1a1a 0%,var(--panel) 100%);border-color:#4a2828}[data-theme=light] .reveal{background:linear-gradient(180deg,#d8edd9 0%,var(--panel) 100%);border-color:#94c298}[data-theme=light] .reveal.fail{background:linear-gradient(180deg,#f3d2c5 0%,var(--panel) 100%);border-color:#d49a85}.reveal .label:before{background:var(--mint)}.reveal.fail .label:before{background:var(--warn)}.reveal .winner-line{font-family:var(--font-display);font-size:18px;letter-spacing:.06em;color:var(--mint);text-transform:lowercase;margin:4px 0}.reveal.fail .winner-line{color:var(--warn)}.reveal .moves-line{font-family:var(--font-mono);font-size:26px;font-weight:500;color:var(--text);margin:4px 0;font-variant-numeric:tabular-nums}.reveal .optimal{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:.18em;text-transform:uppercase;margin-top:8px}.reveal .optimal strong{color:var(--amber);font-weight:500}.gameover{background:radial-gradient(ellipse 100% 80% at 50% 0%,#2c1f3a 0%,var(--panel) 70%);border-color:var(--magenta);box-shadow:0 0 40px -16px var(--magenta);text-align:center;padding:24px 18px}[data-theme=light] .gameover{background:radial-gradient(ellipse 100% 80% at 50% 0%,#f3dce4 0%,var(--panel) 70%);box-shadow:0 12px 32px -14px #c2487a66}.gameover h2{font-family:var(--font-display);font-size:22px;letter-spacing:.18em;text-transform:lowercase;margin:6px 0 18px;color:var(--magenta)}.gameover ol{list-style:none;padding:0;margin:0;text-align:left}.gameover ol li{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:15px}.gameover ol li:last-child{border-bottom:none}.gameover ol li .rank{font-family:var(--font-mono);font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.gameover ol li .score{font-family:var(--font-mono);font-weight:500;color:var(--amber);font-variant-numeric:tabular-nums}.gameover ol li.first{font-size:18px}.gameover ol li.first .rank{color:var(--amber);font-weight:700}.gameover ol li.first .name{color:var(--amber)}.gameover ol li.first .score{color:var(--mint);text-shadow:0 0 8px rgba(121,247,197,.4)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:grid;place-items:center;z-index:100;padding:16px;animation:modal-fade .16s ease-out}@keyframes modal-fade{0%{opacity:0}}.modal{position:relative;background:linear-gradient(180deg,var(--panel-elev) 0%,var(--panel) 100%);border:1px solid var(--line);border-radius:4px;padding:24px 26px;width:100%;max-width:420px;animation:modal-pop .24s cubic-bezier(.2,.8,.2,1) both;box-shadow:0 32px 70px -22px #000000a6}.modal:before,.modal:after{content:"";position:absolute;width:16px;height:16px;border:1px solid var(--amber);pointer-events:none}.modal:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.modal:after{bottom:-1px;right:-1px;border-left:none;border-top:none}@keyframes modal-pop{0%{opacity:0;transform:scale(.94) translateY(8px)}}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px dashed var(--line)}.modal-title{font-family:var(--font-display);font-size:22px;letter-spacing:.18em;color:var(--text);text-transform:lowercase}.modal-close{background:transparent;border:1px solid var(--line);color:var(--muted);width:32px;height:32px;padding:0;border-radius:4px;font-size:18px;font-family:var(--font-mono);cursor:pointer;line-height:1;transition:color .15s,border-color .15s}.modal-close:hover{color:var(--amber);border-color:var(--amber);filter:none;box-shadow:none}.modal-section{margin-bottom:18px}.modal-section:last-child{margin-bottom:0}.modal-section-label{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.28em;color:var(--text-dim);text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:8px}.modal-section-label:before{content:"";width:6px;height:6px;background:var(--amber);display:inline-block}.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.theme-option{background:transparent;border:1.5px solid var(--line);border-radius:4px;padding:10px 6px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color .16s,box-shadow .16s,transform .2s;font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;color:var(--text);text-transform:uppercase;font-weight:600}.theme-option:hover{border-color:var(--text-dim);transform:translateY(-1px);filter:none;box-shadow:none}.theme-option.selected{border-color:var(--amber);box-shadow:inset 0 0 0 1px var(--amber-soft),0 0 14px -4px var(--amber)}.theme-swatch{width:100%;height:56px;border-radius:3px;border:1px solid var(--line);position:relative;overflow:hidden}.theme-swatch-dark{background:radial-gradient(ellipse 60% 80% at 30% 100%,rgba(255,193,77,.18),transparent 60%),linear-gradient(135deg,#060810,#181f33)}.theme-swatch-dark:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,#1a2034 1px,transparent 1px),linear-gradient(to bottom,#1a2034 1px,transparent 1px);background-size:8px 8px;opacity:.6}.theme-swatch-dark:after{content:"";position:absolute;width:12px;height:12px;background:#ffc14d;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px #ffc14d}.theme-swatch-light{background:linear-gradient(135deg,#f4ead4,#fcf6e3)}.theme-swatch-light:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,#d8c89a 1px,transparent 1px),linear-gradient(to bottom,#d8c89a 1px,transparent 1px);background-size:8px 8px;opacity:.6}.theme-swatch-light:after{content:"";position:absolute;width:12px;height:12px;background:#c8881e;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%)}.theme-swatch-system{background:linear-gradient(90deg,#060810,#060810 50%,#f4ead4 50%,#f4ead4)}.theme-swatch-system:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(90deg,transparent 0%,transparent 49.5%,rgba(0,0,0,.5) 49.5%,rgba(0,0,0,.5) 50.5%,transparent 50.5%);opacity:1}.theme-swatch-system:after{content:"";position:absolute;width:12px;height:12px;border-radius:50%;background:linear-gradient(90deg,#ffc14d,#ffc14d 50%,#c8881e 50%,#c8881e);top:50%;left:50%;transform:translate(-50%,-50%)}.modal-footnote{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:.12em;margin-top:14px;text-align:center}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:14px;color:var(--text)}.keybind-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:8px}.keybind-head .modal-section-label{margin-bottom:0}.keybind-reset{background:transparent;border:none;padding:0;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .16s}.keybind-reset:hover{color:var(--amber);filter:none;box-shadow:none}.keybind-list{display:flex;flex-direction:column;gap:4px}.keybind-row{display:grid;grid-template-columns:minmax(80px,1fr) auto;align-items:center;gap:12px;padding:4px 0}.keybind-label{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:lowercase;color:var(--text-dim)}.keybind-swatch{display:inline-block;width:10px;height:10px;border-radius:2px;border:1px solid color-mix(in srgb,#000 30%,transparent)}.keybind-slots{display:grid;grid-template-columns:repeat(3,64px);gap:6px}.keybind-key{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.08em;padding:6px;background:var(--input-bg);border:1px solid var(--line);border-radius:3px;color:var(--text);cursor:pointer;transition:color .16s,border-color .16s,background .16s;text-align:center;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.keybind-key:hover{border-color:var(--line-strong)}.keybind-key.empty{color:var(--muted)}.keybind-key.listening{color:var(--amber);border-color:var(--amber);background:color-mix(in srgb,var(--amber) 10%,var(--input-bg));animation:keybind-pulse 1.2s ease-in-out infinite;font-size:9px;letter-spacing:.12em}@keyframes keybind-pulse{0%,to{box-shadow:0 0 0 0 transparent}50%{box-shadow:0 0 0 3px color-mix(in srgb,var(--amber) 20%,transparent)}}@media (max-width: 540px){.keybind-slots{grid-template-columns:repeat(3,56px)}.keybind-key{padding:6px 4px;font-size:10px}}.toggle{display:inline-flex;align-items:center;gap:10px;background:transparent;border:none;padding:0;cursor:pointer;font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);transition:color .16s;white-space:nowrap}.toggle:hover{filter:none;box-shadow:none}.toggle:hover .toggle-track{border-color:var(--text-dim)}.toggle:focus-visible{outline:none}.toggle:focus-visible .toggle-track{box-shadow:0 0 0 2px var(--amber-soft)}.toggle .toggle-track{position:relative;width:42px;height:22px;border-radius:999px;background:var(--input-bg);border:1px solid var(--line);transition:background .2s,border-color .2s;flex-shrink:0}.toggle .toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--muted);transition:left .2s cubic-bezier(.2,.8,.2,1),background .2s,box-shadow .2s}.toggle.on{color:var(--mint)}.toggle.on .toggle-track{background:#87f7c82e;border-color:var(--mint)}[data-theme=light] .toggle.on .toggle-track{background:#1c8a5a2e}.toggle.on .toggle-knob{left:22px;background:var(--mint);box-shadow:0 0 8px var(--mint)}.toggle-label{font-weight:600;font-variant-numeric:tabular-nums;min-width:24px}.account-line{font-family:var(--font-mono);font-size:13px;color:var(--text);letter-spacing:.04em;line-height:1.5}.account-line.dim{color:var(--text-dim);font-size:12px}.signin-form{display:block}.signin-form input{padding:9px 11px;font-size:13px}.signin-field{display:block;margin-top:10px}.signin-field-label{display:block;font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.28em;color:var(--text-dim);text-transform:uppercase;margin-bottom:5px}.signin-error{margin-top:10px;padding:8px 10px;border:1px solid var(--warn);border-radius:3px;font-family:var(--font-mono);font-size:11px;color:var(--warn);letter-spacing:.04em;background:color-mix(in srgb,var(--warn) 10%,transparent)}.signin-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.signin-actions button{padding:9px 8px;font-size:12px;letter-spacing:.18em;white-space:nowrap;min-width:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.stat-cell{background:var(--input-bg);border:1px solid var(--line);border-radius:3px;padding:8px 6px;text-align:center;min-height:56px;display:flex;flex-direction:column;justify-content:center}.stat-cell.big{grid-column:span 2;border-color:var(--amber);box-shadow:0 0 12px -4px var(--amber-soft) inset;background:linear-gradient(180deg,color-mix(in srgb,var(--amber) 8%,var(--input-bg)),var(--input-bg))}.stat-num{font-family:var(--font-display);font-size:22px;letter-spacing:.04em;color:var(--text);line-height:1.05}.stat-cell.big .stat-num{font-size:32px;color:var(--amber)}.stat-label{margin-top:4px;font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim)}.stat-sub{margin-top:2px;font-family:var(--font-mono);font-size:9px;color:var(--muted);letter-spacing:.08em}.lb-list{list-style:none;margin:0;padding:0}.lb-row{display:grid;grid-template-columns:56px 1fr auto;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px dashed var(--line)}.lb-row:last-child{border-bottom:none}.lb-row.rank-1{color:var(--amber)}.lb-row.rank-2{color:var(--text)}.lb-row.rank-3{color:var(--mint)}.lb-rank{display:inline-flex;align-items:baseline;gap:4px;font-family:var(--font-display);font-size:18px;letter-spacing:.02em;white-space:nowrap}.lb-rank-num{font-variant-numeric:tabular-nums}.lb-crown{font-size:14px;line-height:1}.lb-name{font-family:var(--font-mono);font-size:14px;letter-spacing:.04em;color:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-score{font-family:var(--font-display);font-size:22px;font-variant-numeric:tabular-nums;letter-spacing:.02em}.lb-score .lb-unit{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:lowercase;color:var(--muted)}.lb-grid{display:flex;flex-direction:column;gap:18px;max-width:540px;margin:0 auto}.lb-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:14px 16px 16px;box-shadow:0 8px 24px -16px #0006}[data-theme=light] .lb-card{border-color:var(--line-strong);box-shadow:0 6px 18px -12px #281e0a4d}.lb-card:before,.lb-card:after{content:"";position:absolute;width:12px;height:12px;border:1px solid var(--amber);pointer-events:none}.lb-card:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.lb-card:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.lb-card-head{display:flex;flex-direction:column;margin:-14px -16px 12px;border-bottom:1px solid var(--line)}.lb-card-title{font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.2em;text-transform:lowercase;color:var(--amber);padding:14px 16px}.lb-tabs-inline{display:flex}.lb-tabs-inline .lb-tab{flex:1 1 0;min-width:0;background:transparent;border:none;border-right:1px solid var(--line);padding:14px 8px;font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.2em;text-transform:lowercase;color:var(--text-dim);cursor:pointer;transition:color .16s,background .16s}.lb-tabs-inline .lb-tab:last-child{border-right:none}.lb-tabs-inline .lb-tab:hover:not(.active){color:var(--text);background:#ffffff08}.lb-tabs-inline .lb-tab.active{color:var(--amber);background:#ffc14d0f;box-shadow:inset 0 -2px 0 var(--amber)}[data-theme=light] .lb-tabs-inline .lb-tab:hover:not(.active){background:#00000008}.lb-countdown{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:var(--text-dim);padding:10px 16px 0}.profile-headline{font-family:var(--font-display);font-size:28px;letter-spacing:.06em;color:var(--text);margin-bottom:18px}.profile-stat{padding:18px 12px;border:1px solid var(--amber);border-radius:3px;background:linear-gradient(180deg,color-mix(in srgb,var(--amber) 8%,var(--input-bg)),var(--input-bg));margin-bottom:14px}.profile-stat-num{font-family:var(--font-display);font-size:56px;color:var(--amber);letter-spacing:.02em;line-height:1}.profile-stat-label{margin-top:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-dim)}.profile-dash-wrap{max-width:540px;margin:0 auto}.stats-dash{display:grid;grid-template-columns:1fr;gap:14px}@keyframes dash-card-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.dash-card{position:relative;padding:18px 20px;background:var(--panel);border:1px solid var(--line);border-radius:4px;box-shadow:0 6px 18px -14px #00000073;opacity:0;animation:dash-card-in .42s cubic-bezier(.22,.61,.36,1) forwards}.dash-card:before,.dash-card:after{content:"";position:absolute;width:18px;height:18px;border:1.5px solid var(--amber);pointer-events:none}.dash-card:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.dash-card:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.dash-card-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--amber);margin-bottom:14px}.dash-mint{color:var(--mint)}.dash-amber{color:var(--amber)}.dash-empty{font-family:var(--font-mono);font-size:12px;letter-spacing:.18em;text-transform:lowercase;color:var(--text-dim);text-align:center;padding:18px 0}.dash-headline-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.dash-bignum{padding:14px 10px;border:1px solid color-mix(in srgb,var(--line) 70%,transparent);border-radius:3px;background:var(--input-bg);text-align:center}.dash-bignum-value{font-family:var(--font-mono);font-weight:700;font-size:38px;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}.dash-bignum-label{margin-top:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:lowercase;color:var(--text-dim)}.dash-headline-foot{margin-top:12px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;color:var(--text-dim);text-align:center;text-transform:lowercase}.dash-blitz-hero{text-align:center;margin-bottom:18px}.dash-blitz-best-num{font-family:var(--font-mono);font-weight:700;font-size:64px;line-height:1;color:var(--amber);font-variant-numeric:tabular-nums;letter-spacing:.01em}.dash-blitz-best-label{margin-top:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--text-dim)}.dash-blitz-sub{margin-top:12px;display:inline-flex;align-items:baseline;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:lowercase;color:var(--text-dim)}.dash-blitz-sub strong{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums;margin:0 2px}.dash-dot{opacity:.4}.dash-meta-row{display:flex;align-items:baseline;justify-content:space-between;font-family:var(--font-mono);font-size:13px;letter-spacing:.06em}.dash-meta-row>span{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim)}.dash-meta-row>strong{font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}.dash-histogram{display:flex;flex-direction:column;gap:3px;margin-top:2px}.dash-hist-row{display:grid;grid-template-columns:28px 1fr 36px;align-items:center;gap:8px;height:22px}.dash-hist-label{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);text-align:right;font-variant-numeric:tabular-nums}.dash-hist-bar-wrap{position:relative;height:12px;background:color-mix(in srgb,var(--line) 60%,transparent);border-radius:2px;overflow:hidden}.dash-hist-bar{display:block;height:100%;background:linear-gradient(90deg,color-mix(in srgb,var(--amber) 80%,transparent),var(--amber));border-radius:2px;transition:width .48s cubic-bezier(.22,.61,.36,1)}.dash-hist-count{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);font-variant-numeric:tabular-nums;text-align:right}.dash-hist-row.is-empty .dash-hist-bar{background:transparent}.dash-hist-row.is-empty .dash-hist-count{opacity:.4}.dash-hist-row.is-best .dash-hist-label{color:var(--mint);font-weight:700}.dash-hist-row.is-best .dash-hist-bar{background:linear-gradient(90deg,color-mix(in srgb,var(--mint) 70%,transparent),var(--mint));box-shadow:0 0 8px -2px color-mix(in srgb,var(--mint) 60%,transparent)}.dash-hist-row.is-best .dash-hist-count{color:var(--mint);font-weight:700}.dash-blitz-best-num{display:inline-flex;align-items:center;gap:10px;justify-content:center}.dash-blitz-best-num .rr-icon-flame{transform:translateY(-2px)}.dash-streak-num{display:inline-block;line-height:1}@media (max-width: 700px){.dash-card{padding:14px}.dash-blitz-best-num{font-size:52px}.dash-bignum-value{font-size:32px}}body.modal-open{overflow:hidden}@media (max-width: 1080px){.game{grid-template-columns:minmax(0,1fr);gap:18px}.sidebar{max-width:560px;margin:0 auto;width:100%}}@media (max-width: 700px){.app{padding:14px 12px 40px}.topbar{margin-bottom:14px;flex-wrap:wrap;gap:6px}.topbar .brand{font-size:16px}.topbar .meta{display:none}.topbar .right{margin-left:auto}.board-frame{padding:10px}.board-frame .frame-label{left:16px;font-size:9px}.lobby{margin-top:2vh}.lobby .hero h1{font-size:36px}.lobby .card{padding:18px}.lobby .row,.lobby .row.tight{grid-template-columns:1fr}.room-panel .room-code{font-size:26px}.phase-panel .phase-line{font-size:16px}.phase-panel .timer{font-size:24px}.panel{padding:14px}button{padding:13px 18px;font-size:12px}input,select{padding:13px 14px;font-size:16px}input.code{font-size:18px;letter-spacing:.28em}}@media (max-width: 380px){.lobby .hero h1{font-size:30px}.room-panel .room-code{font-size:22px}.board-empty .room-code-big{font-size:44px}}.archive-view{display:flex;justify-content:center;align-items:flex-start;width:100%;padding:0 16px;animation:lobby-in .5s cubic-bezier(.2,.8,.2,1) both}.archive-panel{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:24px 28px 28px;width:100%;max-width:min(820px,100%);margin:0 auto;box-shadow:0 12px 32px #00000052}.archive-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.archive-title{font-family:var(--font-body);font-size:22px;font-weight:600;color:var(--text)}.archive-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:14px 12px;margin-bottom:18px;background:var(--panel-elev);border-radius:4px}.archive-stats .stat{display:flex;flex-direction:column;align-items:center;gap:4px}.archive-stats .stat-num{font-family:var(--font-body);font-size:28px;font-weight:600;color:var(--amber);line-height:1}.archive-stats .stat-name{font-family:var(--font-body);font-size:12px;color:var(--muted)}.cal-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.cal-nav .ghost{width:40px;padding:8px 10px;font-size:18px;font-weight:600}.cal-title{font-family:var(--font-body);font-size:18px;font-weight:600;color:var(--text)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:6px}.cal-weekdays>div{text-align:center;font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--muted);padding:6px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.cal-cell{position:relative;aspect-ratio:1 / 1;background:var(--panel-elev);border:1px solid var(--line);border-radius:4px;cursor:pointer;font-family:var(--font-body);font-size:13px;color:var(--text-dim);padding:0;transition:border-color .12s ease,background .12s ease}.cal-cell:hover:not(:disabled){border-color:var(--amber);color:var(--text)}.cal-cell:disabled{cursor:default;opacity:.35;background:transparent}.cal-cell.pad{background:transparent;border:none;cursor:default}.cal-cell.today{border-color:var(--amber);border-width:2px}.cal-cell.played-same{background:#ffc14d2e;border-color:var(--amber);color:var(--text)}.cal-cell.played-late{background:#87f7c81f;border-color:var(--mint);color:var(--text)}.cal-cell.missing{opacity:.4;cursor:not-allowed}.cal-num{position:absolute;top:5px;left:7px;font-size:12px;font-weight:500;opacity:.75;font-family:var(--font-body)}.cal-mark{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:28px;pointer-events:none}.cal-mark.same{color:var(--amber);text-shadow:0 0 10px rgba(255,193,77,.65)}.cal-mark.late{color:var(--mint)}.cal-mark.today-dot{color:var(--amber);font-size:40px;line-height:0}.archive-legend{display:flex;flex-wrap:wrap;gap:12px 22px;margin-top:20px;padding-top:16px;border-top:1px dashed var(--line);font-family:var(--font-body);font-size:13px;color:var(--muted)}.archive-legend>span{display:flex;align-items:center;gap:6px}.cal-swatch{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:2px;font-size:12px}.cal-swatch.played-same{background:#ffc14d33;color:var(--amber)}.cal-swatch.played-late{background:#87f7c826;color:var(--mint)}.cal-swatch.today{background:var(--amber);color:var(--bg);font-weight:700}.daily-history-link{margin-top:8px;background:transparent;border:none;color:var(--text-dim);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;padding:4px 0 0;align-self:flex-start;transition:color .15s ease}.daily-history-link:hover{color:var(--amber)}.daily-week{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin:12px 0 14px}.daily-week-cell{position:relative;aspect-ratio:1 / 1;background:#ffffff0a;border:1px solid var(--line);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:2px;min-height:44px;cursor:pointer;font-family:inherit;color:inherit;transition:border-color .12s ease,transform .12s ease}.daily-week-cell:hover{border-color:var(--amber);transform:translateY(-1px)}.daily-week-cell:focus-visible{outline:2px solid var(--amber);outline-offset:2px}.daily-week-cell .dwc-letter{font-family:var(--font-body);font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.08em;line-height:1;text-transform:uppercase}.daily-week-cell .dwc-mark{font-size:18px;line-height:1;margin-top:1px}.daily-week-cell.state-empty .dwc-mark:before{content:"·";color:var(--muted);opacity:.4}.daily-week-cell.state-same{background:#ffc14d2e;border-color:var(--amber)}.daily-week-cell.state-same .dwc-mark{color:var(--amber);text-shadow:0 0 8px rgba(255,193,77,.55)}.daily-week-cell.state-late{background:#87f7c81f;border-color:var(--mint)}.daily-week-cell.state-late .dwc-mark{color:var(--mint)}.daily-week-cell.state-today{border-color:var(--amber);border-width:2px;animation:dwc-pulse 1.6s ease-in-out infinite}.daily-week-cell.state-today .dwc-mark{color:var(--amber);font-size:26px}@keyframes dwc-pulse{0%,to{box-shadow:0 0 #ffc14d00}50%{box-shadow:0 0 0 4px #ffc14d2e}}.workshop-page{width:100%;max-width:1100px;margin:3vh auto 0;padding:0 24px;animation:lobby-in .6s cubic-bezier(.2,.8,.2,1) both}.workshop-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:22px}.workshop-title{font-family:var(--font-display);font-size:44px;letter-spacing:-.02em;margin:4px 0 6px}.workshop-slot-count{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--text-dim);text-transform:uppercase;margin-top:2px}.workshop-head-actions{display:flex;gap:10px;align-items:center}.hub-new{font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:10px 16px}.hub-new:disabled{opacity:.4;cursor:not-allowed}.hub-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}@media (max-width: 880px){.hub-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 580px){.hub-grid{grid-template-columns:1fr}.workshop-page{padding:0 14px}}.hub-thumb{display:block;width:100%;height:auto;aspect-ratio:1 / 1}.hub-thumb-empty{display:flex;align-items:center;justify-content:center;background:#0a0d12;color:var(--text-dim);font-family:var(--font-mono);border-radius:4px}.hub-card-body{display:flex;flex-direction:column;gap:10px}.hub-card{position:relative;border:1px solid var(--line);background:var(--bg-card, rgba(255, 255, 255, .02));padding:14px 14px 12px;display:flex;flex-direction:column;gap:10px;cursor:pointer;transition:border-color .14s ease,transform .14s ease,box-shadow .14s ease}.hub-card:hover{border-color:var(--amber);transform:translateY(-1px);box-shadow:0 10px 24px -16px #ffc14d73}.hub-card.is-published:hover{border-color:var(--mint);box-shadow:0 10px 24px -16px #87f7c873}.hub-card:focus-visible{outline:2px solid var(--amber);outline-offset:3px}.hub-card:before,.hub-card:after{content:"";position:absolute;width:10px;height:10px;border:1px solid var(--amber);pointer-events:none}.hub-card:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.hub-card:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.hub-card.is-published:before,.hub-card.is-published:after{border-color:var(--mint)}.hub-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.hub-name{color:var(--text);font-size:16px;font-weight:500;letter-spacing:-.005em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hub-status{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;padding:3px 8px;border:1px solid var(--line);white-space:nowrap}.hub-status.is-draft{color:var(--text-dim)}.hub-status.is-pub{color:var(--mint);border-color:var(--mint)}.hub-meta{display:flex;flex-wrap:wrap;gap:12px;font-family:var(--font-mono);font-size:11px;color:var(--text-dim);letter-spacing:.04em}.hub-meta-item strong{color:var(--text);font-weight:500}.hub-meta-id{margin-left:auto;opacity:.55}.hub-actions{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.hub-actions button{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:6px 10px;flex:1 1 auto}.hub-actions .hub-delete{color:var(--warn, #ff7aa3);flex:0 1 auto}.hub-actions .hub-delete:hover:not(:disabled){border-color:var(--warn, #ff7aa3)}.hub-empty{padding:32px 0;text-align:center;font-family:var(--font-mono);color:var(--text-dim)}.hub-empty-line1{font-size:14px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}.hub-empty-line2{font-size:12px;opacity:.7}.owner-next-action{display:flex;flex-direction:column;align-items:stretch;gap:6px;margin-top:12px}.owner-next-btn{width:100%;font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:12px 16px}.owner-next-msg{font-family:var(--font-mono);font-size:12px;color:var(--mint);letter-spacing:.06em;padding:10px 14px;border:1px solid var(--mint);text-align:center}.owner-next-tick{margin-right:6px;font-weight:700}.owner-next-error{margin-top:4px}.editor-title-strip{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-dim)}.editor-title-strip:hover{color:var(--amber)}.editor-title-strip:focus-within{color:var(--amber)}.editor-title{flex:1;min-width:0;background:transparent;border:none;border-bottom:1px dashed transparent;color:var(--text);font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:-.01em;padding:4px 0 6px}.editor-title::placeholder{color:var(--text-dim);opacity:.55}.editor-title:hover:not(:focus){border-bottom-color:var(--line)}.editor-title:focus{outline:none;border-bottom-color:var(--amber)}.editor-title:read-only{color:var(--text-dim);cursor:not-allowed}.game.has-details>.editor-side{grid-column:3;justify-self:start;display:flex;flex-direction:column;gap:10px;width:340px;max-width:340px;padding-top:50px}.editor-mode-toggle{display:flex;border:1px solid var(--line);background:var(--panel);box-shadow:0 8px 24px -16px #0006}[data-theme=light] .editor-mode-toggle{border-color:var(--line-strong);box-shadow:0 6px 18px -12px #281e0a4d}.editor-mode-tab{flex:1;background:transparent;border:none;color:var(--text-dim);font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;padding:12px 0;cursor:pointer;transition:color .12s ease,background .12s ease}.editor-mode-tab:hover:not(:disabled):not(.active){color:var(--text)}.editor-mode-tab.active{color:var(--amber);background:#ffc14d14;border-bottom:1px solid var(--amber);margin-bottom:-1px}.editor-mode-tab:disabled{opacity:.4;cursor:not-allowed}.editor-side-body{position:relative;padding:14px 14px 16px;border:1px solid var(--line);background:var(--panel);box-shadow:0 8px 24px -16px #0006}[data-theme=light] .editor-side-body{border-color:var(--line-strong);box-shadow:0 6px 18px -12px #281e0a4d}.editor-side-body:before,.editor-side-body:after{content:"";position:absolute;width:10px;height:10px;border:1px solid var(--amber);pointer-events:none}.editor-side-body:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.editor-side-body:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.game.has-details>.editor-side>.details-panel{width:100%;max-width:none}.autosave-pill{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-dim);padding:2px 8px;white-space:nowrap;transition:opacity .2s ease}.autosave-pill.autosave-saving{color:var(--text-dim)}.autosave-pill.autosave-saved{color:var(--mint)}.autosave-pill.autosave-error{color:var(--warn)}
