:root{--bg: #0f1419;--bg-soft: #161d26;--panel: #1c2530;--panel-2: #222d3a;--border: #2c3845;--text: #e7edf3;--text-dim: #9fb0c0;--muted: #6f8294;--accent: #f0a868;--accent-2: #e08e4a;--accent-ink: #2a1a08;--good: #5fd28a;--good-bg: rgba(95, 210, 138, .12);--warn: #f2a65a;--warn-bg: rgba(242, 166, 90, .12);--progress: #7cc1ff;--progress-bg: rgba(124, 193, 255, .12);--sq-light: #e9d3b0;--sq-dark: #ad7d56;--sq-light-2: #f0dfc2;--sq-dark-2: #bf8e64;--sel: #f7d774;--target: rgba(60, 200, 120, .55);--removed: #ff6b6b;--last: rgba(247, 215, 116, .5);--radius: 14px;--radius-sm: 9px;--shadow: 0 10px 30px rgba(0, 0, 0, .35);color-scheme:dark}@media (prefers-color-scheme: light){:root{--bg: #f3f1ea;--bg-soft: #ffffff;--panel: #ffffff;--panel-2: #f6f2ea;--border: #e2dccf;--text: #20262e;--text-dim: #51606e;--muted: #8a98a6;--accent: #c97b34;--accent-2: #b3692a;--accent-ink: #fff6ec;--shadow: 0 10px 30px rgba(60, 50, 30, .12)}}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(1200px 600px at 80% -10%,rgba(240,168,104,.1),transparent 60%),var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.5}h1,h2,h3,h4{margin:0 0 .4em;line-height:1.2}a{color:var(--accent)}.app{min-height:100%;display:flex;flex-direction:column}.topnav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem clamp(1rem,4vw,2rem);border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg-soft) 80%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.brand{font-weight:800;font-size:1.3rem;letter-spacing:-.02em;text-decoration:none;color:var(--text)}.brand-go,.hero-go{color:var(--accent)}.topnav-links{display:flex;gap:.3rem}.navlink{text-decoration:none;color:var(--text-dim);padding:.4rem .8rem;border-radius:999px;font-weight:600;font-size:.92rem;transition:background .15s,color .15s}.navlink:hover{color:var(--text);background:var(--panel-2)}.navlink.active{color:var(--accent-ink);background:var(--accent)}.content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:clamp(1rem,3vw,2rem)}.footer{border-top:1px solid var(--border);padding:1rem;text-align:center;color:var(--muted);font-size:.85rem}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:clamp(1rem,2.5vw,1.5rem);box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;gap:.5rem;border:1px solid transparent;border-radius:999px;padding:.6rem 1.1rem;font-weight:700;font-size:.95rem;cursor:pointer;text-decoration:none;transition:transform .06s,background .15s,border-color .15s,opacity .15s;font-family:inherit}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-lg{padding:.8rem 1.5rem;font-size:1.05rem}.btn-primary{background:var(--accent);color:var(--accent-ink)}.btn-primary:hover{background:var(--accent-2)}.btn-ghost{background:var(--panel-2);color:var(--text);border-color:var(--border)}.btn-ghost:hover{background:var(--panel)}.home{display:grid;gap:1.5rem}.hero{text-align:center;padding:clamp(1.5rem,5vw,3rem) 1rem}.hero-title{font-size:clamp(2.6rem,9vw,4.5rem);font-weight:900;letter-spacing:-.03em;margin-bottom:.3rem}.hero-tagline{font-size:clamp(1rem,2.6vw,1.25rem);color:var(--text-dim);max-width:36ch;margin:0 auto 1.5rem}.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}.rules-list{margin:0;padding-left:1.1rem;display:grid;gap:.7rem}.rules-list li{color:var(--text-dim)}.rules-list strong{color:var(--text)}.examples p{color:var(--text-dim);margin-top:0}.show-tell{display:grid;grid-template-columns:auto minmax(0,1fr);gap:clamp(1rem,4vw,2.5rem);align-items:center}.show-tell-points h2{margin-bottom:.9rem}.point-list{list-style:none;margin:0 0 1.2rem;padding:0;display:grid;gap:.85rem}.point-list li{color:var(--text-dim)}.point-k{color:var(--text);font-weight:700;margin-right:.35rem}.home-demo{display:grid;gap:.8rem;justify-items:center}.demo-board{width:min(320px,78vw);aspect-ratio:1 / 1;display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(5,1fr);border:5px solid #5a3d29;border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}.demo-sq{position:relative;display:flex;align-items:center;justify-content:center}.demo-piece{width:82%;height:82%;object-fit:contain;filter:drop-shadow(0 2px 2px rgba(0,0,0,.32)) drop-shadow(0 0 1px rgba(255,255,255,.45))}.demo-stone{width:74%;height:74%;display:block;filter:drop-shadow(0 2px 2px rgba(0,0,0,.3));animation:demo-pop .25s ease-out}@keyframes demo-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.demo-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--removed);opacity:0;animation:demo-flash-anim 1s ease-out}@keyframes demo-flash-anim{0%{opacity:.7}to{opacity:0}}.demo-caption{margin:0;color:var(--text-dim);font-weight:600;min-height:2.6em;text-align:center;max-width:28ch}@media (max-width: 720px){.show-tell{grid-template-columns:1fr;justify-items:center}.show-tell-points{text-align:center}.point-list li{text-align:left}}.puzzle,.sandbox{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:1.5rem;align-items:start}.puzzle-main,.sandbox-main{display:grid;gap:1rem;min-width:0}.puzzle-head .badge{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .55rem;border-radius:999px;background:var(--panel-2);color:var(--text-dim);margin-right:.4rem;border:1px solid var(--border)}.badge-theme{color:var(--accent)}.puzzle-title{font-size:1.4rem;margin-top:.5rem}.puzzle-prompt{color:var(--text-dim);margin:0}.turn-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap}.turn-pill{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;padding:.4rem .85rem;border-radius:999px;border:1px solid var(--border);background:var(--panel-2)}.turn-dot{width:.9rem;height:.9rem;border-radius:50%;border:1px solid rgba(0,0,0,.35)}.turn-dot-w{background:#f4f1ea}.turn-dot-b{background:#1a1a1a;border-color:#fff6}.turn-solved{background:var(--good-bg);color:var(--good);border-color:transparent}.turn-thinking{background:var(--progress-bg);color:var(--progress);border-color:color-mix(in srgb,var(--progress) 35%,transparent)}.spinner-sm{width:1rem;height:1rem;border-width:2px}.seg-group{display:inline-flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}.seg-btn{flex:1 1 auto;min-width:4.5rem;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.5rem .7rem;font-family:inherit;font-weight:700;font-size:.88rem;cursor:pointer;transition:background .15s,border-color .15s,opacity .15s}.seg-btn:hover:not(:disabled){border-color:var(--accent)}.seg-btn.seg-active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,var(--panel-2));color:var(--accent)}.seg-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-pill{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;font-size:.9rem;padding:.45rem .9rem;border-radius:999px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s,color .15s}.toggle-pill:disabled{opacity:.5;cursor:not-allowed}.toggle-state{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;opacity:.55;padding:.05rem .45rem;border-radius:999px;background:color-mix(in srgb,currentColor 14%,transparent)}.toggle-pill.toggle-on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.toggle-pill.toggle-on .toggle-state{opacity:.7}.board-wrap{width:100%}.board-area{position:relative;width:100%}.promo-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000073;z-index:5;border-radius:var(--radius)}.promo-picker{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:.9rem 1rem 1rem;max-width:92%}.promo-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.6rem}.promo-title{font-weight:700;font-size:.95rem;color:var(--text)}.promo-close{border:none;background:transparent;color:var(--text-dim);font-size:1.25rem;line-height:1;cursor:pointer;padding:0 .2rem;border-radius:var(--radius-sm);font-family:inherit}.promo-close:hover{color:var(--text)}.promo-options{display:flex;gap:.5rem}.promo-option{width:clamp(48px,13vw,64px);height:clamp(48px,13vw,64px);display:flex;align-items:center;justify-content:center;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;padding:.25rem;transition:background .15s,border-color .15s}.promo-option:hover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,var(--panel-2))}.promo-piece{width:100%;height:100%;object-fit:contain;pointer-events:none;filter:drop-shadow(0 2px 2px rgba(0,0,0,.32)) drop-shadow(0 0 1px rgba(255,255,255,.45))}.board{width:100%;max-width:560px;margin:0 auto;aspect-ratio:1 / 1;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);border-radius:var(--radius);overflow:hidden;border:6px solid #5a3d29;box-shadow:var(--shadow);background:#5a3d29;touch-action:none}.sq-draggable{cursor:grab}.board-dragging,.board-dragging .sq-draggable{cursor:grabbing}.sq-dragging .piece{opacity:0}.drag-piece{position:fixed;z-index:1000;pointer-events:none;object-fit:contain;transform:translate(-50%,-50%);filter:drop-shadow(0 6px 9px rgba(0,0,0,.4))}.sq{position:relative;border:none;padding:0;margin:0;cursor:default;display:flex;align-items:center;justify-content:center;font-family:inherit;outline:none;-webkit-tap-highlight-color:transparent}.sq-light{background:var(--sq-light)}.sq-dark{background:var(--sq-dark)}.sq-clickable{cursor:pointer}.sq-clickable:hover{filter:brightness(1.06)}.sq-selected{background:var(--sel)!important}.sq-last:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--last);pointer-events:none}.sq:focus-visible{box-shadow:inset 0 0 0 3px var(--progress);z-index:2}.coord{position:absolute;font-size:clamp(.5rem,1.4vw,.7rem);font-weight:700;opacity:.65;-webkit-user-select:none;user-select:none;pointer-events:none;color:#28190ccc}.sq-dark .coord{color:#faf0e1d9}.coord-rank{top:2px;left:3px}.coord-file{bottom:2px;right:4px}.piece{width:86%;height:86%;object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;z-index:1;filter:drop-shadow(0 2px 2px rgba(0,0,0,.32))}.piece-b{filter:drop-shadow(0 2px 2px rgba(0,0,0,.32)) drop-shadow(0 0 1px rgba(255,255,255,.45))}.stone{width:77%;height:77%;z-index:1;pointer-events:none;filter:drop-shadow(0 2px 2px rgba(0,0,0,.32))}.stone-svg{width:100%;height:100%;display:block}.stone-b{filter:drop-shadow(0 2px 2px rgba(0,0,0,.32)) drop-shadow(0 0 1px rgba(255,255,255,.45))}.move-dot{position:absolute;width:26%;height:26%;border-radius:50%;background:var(--target);pointer-events:none}.capture-ring{position:absolute;top:8%;right:8%;bottom:8%;left:8%;border-radius:50%;border:4px solid var(--target);pointer-events:none}.sq-removed:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--removed);opacity:0;animation:flash 1.3s ease-out;pointer-events:none;z-index:3}@keyframes flash{0%{opacity:.75}to{opacity:0}}.banner{border-radius:var(--radius-sm);padding:.85rem 1rem;font-weight:600;display:flex;gap:.7rem;align-items:flex-start}.banner p{margin:.25rem 0 0;font-weight:500}.banner-success{background:var(--good-bg);color:var(--good);border:1px solid color-mix(in srgb,var(--good) 35%,transparent)}.banner-icon{font-size:1.4rem;line-height:1.4}.banner-result{font-weight:800;margin-top:.4rem!important}.banner-warn{background:var(--warn-bg);color:var(--warn);border:1px solid color-mix(in srgb,var(--warn) 35%,transparent)}.banner-progress{background:var(--progress-bg);color:var(--progress);border:1px solid color-mix(in srgb,var(--progress) 35%,transparent)}.puzzle-controls{display:flex;gap:.6rem;flex-wrap:wrap}.puzzle-side h3,.sandbox-side h3{font-size:1rem;margin-bottom:.7rem}.advanced{margin-top:1rem;border-top:1px solid var(--border);padding-top:.85rem}.advanced>summary{cursor:pointer;list-style:none;display:flex;align-items:center;gap:.45rem;font-size:1rem;font-weight:700;color:var(--text);-webkit-user-select:none;user-select:none}.advanced>summary::-webkit-details-marker{display:none}.advanced>summary:before{content:"▸";font-size:.8em;opacity:.6;transition:transform .15s ease}.advanced[open]>summary:before{transform:rotate(90deg)}.advanced:not([open]) .advanced-body{display:none}.advanced-body{margin-top:.85rem}.puzzle-list{list-style:none;margin:0 0 1rem;padding:0;display:grid;gap:.4rem}.puzzle-link{width:100%;text-align:left;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .7rem;cursor:pointer;color:var(--text);font-family:inherit;display:grid;gap:.15rem}.puzzle-link:hover{border-color:var(--accent)}.puzzle-link.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 16%,var(--panel-2))}.puzzle-link-title{font-weight:700}.puzzle-link-meta{font-size:.78rem;color:var(--muted)}.hint-box{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.8rem}.hint-box h4{margin:0 0 .3rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;color:var(--accent)}.hint-box p{margin:0;font-size:.88rem;color:var(--text-dim)}.move-log{list-style:none;margin:0 0 1rem;padding:0;max-height:280px;overflow-y:auto;display:grid;gap:.25rem;font-size:.88rem}.move-log li{display:flex;align-items:center;gap:.5rem;padding:.25rem .35rem;border-radius:6px}.move-log li:nth-child(odd){background:var(--panel-2)}.log-side{width:1.4rem;height:1.4rem;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:800;font-size:.72rem}.log-w{background:#f4f1ea;color:#222}.log-b{background:#1a1a1a;color:#eee;border:1px solid rgba(255,255,255,.25)}.log-text{flex:1;font-variant-numeric:tabular-nums}.log-cap{color:var(--removed);font-weight:700;font-size:.8rem}.captured-chips{display:flex;flex-wrap:wrap;gap:.35rem}.chip{background:color-mix(in srgb,var(--removed) 18%,var(--panel-2));color:var(--text);border:1px solid color-mix(in srgb,var(--removed) 40%,transparent);border-radius:999px;padding:.15rem .55rem;font-size:.8rem;font-weight:600}.muted{color:var(--muted)}.panel-center{display:grid;place-items:center;gap:1rem;padding:3rem 1rem;text-align:center}.spinner{width:2.2rem;height:2.2rem;border-radius:50%;border:3px solid var(--border);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 820px){.puzzle,.sandbox{grid-template-columns:1fr}.puzzle-side,.sandbox-side{order:2}}@media (max-width: 380px){.topnav{flex-direction:column;gap:.5rem;align-items:flex-start}.navlink{padding:.35rem .6rem}}.daily-head-row{display:flex;align-items:baseline;justify-content:space-between;gap:.8rem;flex-wrap:wrap;margin-bottom:.5rem}.daily-title{font-size:1.3rem;margin:0}.daily-number{color:var(--accent)}.daily-date{font-size:.85rem;color:var(--muted);font-variant-numeric:tabular-nums}.daily-share{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.daily-share-text p{margin:.2rem 0 0;font-size:.85rem}.daily-share-fallback{width:100%;margin-top:.5rem;resize:vertical;font-family:inherit;font-size:.85rem;padding:.5rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--panel-2);color:var(--text)}.daily-aside-intro{font-size:.85rem;margin:0 0 1rem}.daily-list-link{margin-top:1rem}.online-lobby{display:grid;place-items:start center;padding-top:clamp(.5rem,4vw,2rem)}.online-panel{width:100%;max-width:440px}.online-intro{margin:0 0 1.2rem;font-size:.92rem}.online-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}.online-share{flex-direction:column;align-items:stretch}.online-share-text p{margin:.25rem 0 .6rem;font-weight:500}.online-share-url{display:flex;gap:.5rem;flex-wrap:wrap}.online-url-input{flex:1 1 200px;min-width:0;font-family:inherit;font-size:.85rem;padding:.55rem .7rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--panel-2);color:var(--text)}.online-side-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin:0 0 .4rem;font-size:.9rem}.online-side-label{color:var(--text-dim)}.online-side-value{font-weight:700}.online-tip{font-size:.82rem;margin:.5rem 0 0}
