:root{--bg:#0f1115;--panel:#171a21;--panel-2:#1f232c;--border:#2a2f3a;--text:#e8eaed;--muted:#9aa3b2;--accent:#6ea8fe;--celebrate:#34d399;--affirm:#6ee7b7;--nudge:#fbbf24;--correct:#fb923c;--alert:#f87171}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.app{width:-moz-fit-content;width:fit-content;max-width:1560px;margin:0 auto;padding:clamp(16px,2.5vw,28px) clamp(14px,2.5vw,24px) 48px}.app h1{font-size:clamp(20px,2.2vw,26px);font-weight:650;margin:0 0 2px}.app .tagline{color:var(--muted);font-size:clamp(13px,1.2vw,15px);margin:0 0 clamp(14px,2vw,22px)}.layout{display:flex;gap:clamp(14px,2vw,24px);align-items:flex-start}.board-col{display:flex;gap:10px;flex:0 0 auto;min-width:0;align-items:stretch}.board-wrap{flex:none;width:var(--board-size);aspect-ratio:1/1}.sidebar{flex:0 0 360px;width:360px;display:flex;flex-direction:column;gap:14px}.status{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted);min-height:22px}.dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.dot.thinking{animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.3}50%{opacity:1}}.controls{display:flex;gap:8px}.controls button{flex:1 1;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-icon{flex:0 0 auto}.action-row{display:flex;gap:8px;margin-bottom:8px}.takeback-btn{flex:1 1}.copy-btn{white-space:nowrap;display:inline-flex;align-items:center;gap:5px}.copy-btn,.copy-icon{flex:0 0 auto}.takeback-icon{display:inline-block;position:relative;top:2px}.level-note{margin:8px 0 0;font-size:13px;color:var(--muted);text-align:center}.level-note strong{color:var(--text);font-weight:600}button{font:inherit;cursor:pointer;border:1px solid var(--border);background:var(--panel-2);color:var(--text);padding:8px 14px;border-radius:8px;transition:border-color .15s,background .15s}button.primary,button:hover{border-color:var(--accent)}button.primary{background:var(--accent);color:#0b1020;font-weight:600}button:disabled{opacity:.5;cursor:not-allowed}.coach-card{position:relative;background:var(--panel);border:1px solid var(--border);border-left-width:4px;border-radius:12px;padding:16px;min-height:120px}.coach-orb-wrap{display:flex;justify-content:center;margin:14px 0 24px}.coach-orb{position:relative;flex:none;width:120px;height:120px;pointer-events:none;isolation:isolate}.search-tree-bloom{position:absolute;inset:0;width:100%;height:100%;z-index:2;overflow:visible;pointer-events:none}@keyframes stb-grow{0%{opacity:0}to{opacity:1}}.search-tree-bloom .stb-edge,.search-tree-bloom .stb-node{animation:stb-grow .5s ease-out both}.orb-blob{z-index:1;position:absolute;inset:3px;border:1.5px solid rgba(167,130,255,.9);border-radius:50%;background:radial-gradient(circle at 50% 50%,#010615 0,#061333 28%,#1a3f86 60%,#3f7ddd 84%,#7eb2f4 100%);opacity:.55;filter:blur(.4px);transition:opacity 1.1s ease-in-out,border-color 1.1s ease-in-out,filter 1.1s ease-in-out}.orb-blob:first-child{transform:rotate(6deg);border-radius:58% 42% 55% 45%/52% 48% 52% 48%}.orb-blob:nth-child(2){transform:rotate(-12deg);border-radius:46% 54% 40% 60%/58% 44% 56% 42%}.orb-blob:nth-child(3){transform:rotate(15deg);border-radius:52% 48% 60% 40%/44% 56% 42% 58%}.orb-blob:nth-child(4){transform:rotate(-8deg);border-radius:60% 40% 47% 53%/50% 55% 45% 50%}.orb-blob:nth-child(5){transform:rotate(3deg);border-radius:48% 52% 53% 47%/53% 47% 52% 48%}.coach-orb.thinking .orb-blob{opacity:.6;border-color:rgba(178,138,250,.92);filter:blur(.4px) saturate(1.1) brightness(1.05)}.coach-card.celebrate{border-left-color:var(--celebrate)}.coach-card.affirm{border-left-color:var(--affirm)}.coach-card.nudge{border-left-color:var(--nudge)}.coach-card.correct{border-left-color:var(--correct)}.coach-card.alert{border-left-color:var(--alert)}.card-title{display:flex;align-items:center;gap:9px;margin-bottom:14px}.card-title-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.opening-icon{flex:none;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent);background:var(--panel-2);border:1px solid var(--border)}.opening-icon svg{width:15px;height:15px}.badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:999px;background:var(--panel-2);color:var(--muted)}.badge.celebrate{color:#052e1f;background:var(--celebrate)}.badge.affirm{color:#052e1f;background:var(--affirm)}.badge.nudge{color:#3a2c00;background:var(--nudge)}.badge.correct{color:#3a1c00;background:var(--correct)}.badge.alert{color:#3a0a0a;background:var(--alert)}.coach-move{font-size:13px;color:var(--muted);margin-left:auto;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.coach-praise{font-size:15px;line-height:1.5;margin:0 0 8px}.coach-insight{font-size:14px;line-height:1.55;color:#d4d8df;margin:0 0 10px}.move-ref{border-radius:4px;padding:0 3px;font-weight:600;color:var(--text);background:rgba(110,168,254,.13);box-shadow:inset 0 0 0 1px rgba(110,168,254,.22);cursor:pointer;white-space:nowrap;transition:background .12s,box-shadow .12s}.move-ref.pinned,.move-ref:focus-visible,.move-ref:hover{background:rgba(110,168,254,.3);box-shadow:inset 0 0 0 1px rgba(110,168,254,.5);outline:none}.square-ref{border-radius:4px;padding:0 2px;font-weight:600;color:var(--text);-webkit-text-decoration:underline dotted rgba(110,168,254,.7);text-decoration:underline dotted rgba(110,168,254,.7);text-underline-offset:2px;cursor:pointer;white-space:nowrap;transition:background .12s}.square-ref.pinned,.square-ref:focus-visible,.square-ref:hover{background:rgba(110,168,254,.22);outline:none}.coach-meta{margin-top:12px;font-size:12px;color:var(--muted);display:flex;gap:12px}.coach-actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px}.show-best-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;font-size:12.5px;font-weight:500;line-height:1;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--muted);transition:background .15s,border-color .15s,color .15s}.show-best-btn:hover{border-color:var(--muted);color:var(--text)}.show-best-btn.active{background:var(--panel-2);border-color:#3a4150;color:var(--text)}.show-best-icon{flex:none;opacity:.8}.coach-empty{color:var(--muted);font-size:14px;text-align:center}.coach-card .status{margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}.coach-engine{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap;margin:-4px 0 22px;min-height:22px}.coach-engine-info{display:inline-flex;align-items:baseline;gap:6px;font-size:13.5px;color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;opacity:.82}.ce-eval{color:var(--text);font-weight:600}.ce-depth{opacity:.85}.ce-positions{opacity:.92}.ce-nps{color:var(--muted);opacity:.85;font-weight:400}.ce-maxed{font-size:10px;text-transform:uppercase;letter-spacing:.04em;opacity:.55}.ce-deepen{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;padding:0;border-radius:50%;color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--panel-2));border:1px solid color-mix(in srgb,var(--accent) 32%,var(--border));vertical-align:middle}.ce-deepen:hover{background:color-mix(in srgb,var(--accent) 26%,var(--panel-2));border-color:var(--accent)}.ce-deepen svg{flex:none}.ce-info-wrap{position:absolute;top:12px;right:12px;z-index:6}.ce-info,.ce-info-wrap{display:inline-flex;align-items:center}.ce-info{justify-content:center;width:16px;height:16px;padding:0;border-radius:50%;font-family:Georgia,Times New Roman,serif;font-style:italic;font-weight:700;font-size:10px;line-height:1;color:var(--muted);background:var(--panel-2);border:1px solid var(--border);cursor:pointer}.ce-info:hover,.ce-info[aria-expanded=true]{color:var(--text);border-color:color-mix(in srgb,var(--text) 30%,var(--border))}.ce-info-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:20;width:250px;display:flex;flex-direction:column;gap:6px;padding:12px 13px;text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.28);font-size:12px;line-height:1.45;font-weight:400;font-feature-settings:normal;font-variant-numeric:normal;color:var(--muted);opacity:1;white-space:normal;cursor:default}.ce-info-pop:before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px}.ce-info-title{color:var(--text);font-size:13px;font-weight:700}.ce-info-sub{margin-bottom:2px}.ce-info-row b{color:var(--text);font-weight:600}.ce-info-foot{margin-top:2px;padding-top:8px;border-top:1px solid var(--border);opacity:.85}.ce-info-note{padding:7px 9px;border-radius:7px;color:var(--text);background:color-mix(in srgb,var(--nudge) 12%,var(--panel-2));border:1px solid color-mix(in srgb,var(--nudge) 30%,var(--border))}.coach-fallback{display:flex;align-items:flex-start;gap:8px;margin:0 0 14px;padding:8px 10px;font-size:12px;line-height:1.45;color:var(--muted);background:color-mix(in srgb,var(--nudge) 10%,var(--panel-2));border:1px solid color-mix(in srgb,var(--nudge) 28%,var(--border));border-radius:8px}.coach-fallback strong{color:var(--text);font-weight:600}.coach-fallback-icon{flex:none;margin-top:1px;color:var(--nudge)}.coach-fallback-body{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.coach-retry-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;color:var(--text);background:color-mix(in srgb,var(--nudge) 18%,var(--panel-2));border:1px solid color-mix(in srgb,var(--nudge) 40%,var(--border));border-radius:7px;cursor:pointer;transition:background .15s,border-color .15s}.coach-retry-btn:hover:not(:disabled){background:color-mix(in srgb,var(--nudge) 28%,var(--panel-2));border-color:var(--nudge)}.coach-retry-btn:disabled{opacity:.65;cursor:default}.coach-retry-btn .spin{animation:coach-retry-spin .8s linear infinite;transform-origin:center}@keyframes coach-retry-spin{to{transform:rotate(1turn)}}@media (prefers-reduced-motion:reduce){.coach-retry-btn .spin{animation:none}}.opening-card{position:relative;background:var(--panel);border-left-color:var(--border);border-left-width:1px;border:1px solid var(--border);border-left:4px solid var(--accent);border-radius:12px;padding:16px}.opening-lead{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px}.opening-count{font-size:24px;font-weight:750;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--text)}.opening-count-label{font-size:13px;color:var(--muted);line-height:1.4}.opening-wdl{margin-top:12px}.wdl-bar{display:flex;height:10px;border-radius:5px;overflow:hidden;background:var(--panel-2)}.wdl-white{background:#e9edf3}.wdl-draw{background:#8b93a3}.wdl-black{background:#2a2f3a}.wdl-legend{display:flex;margin-top:6px;font-size:11px;color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.wdl-leg{overflow:visible;white-space:nowrap}.wdl-leg-white{text-align:left}.wdl-leg-draw{text-align:center}.wdl-leg-black{text-align:right}.opening-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:14px}.opening-name{font-size:14px;font-weight:600;color:var(--text)}.opening-eco{font-size:11px;font-weight:700;letter-spacing:.03em;color:var(--muted);background:var(--panel-2);border:1px solid var(--border);border-radius:5px;padding:1px 6px}.opening-inbook{position:absolute;top:16px;right:16px;font-size:11px;font-weight:600;color:#052e1f;background:var(--affirm);border-radius:999px;padding:2px 8px}.opening-repertoire{margin:10px 0 0;font-size:13px;line-height:1.45;color:var(--accent)}.opening-games-details{margin-top:12px}.opening-games-summary{font-size:11px;color:var(--muted);cursor:pointer;list-style:none;display:flex;align-items:center;gap:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.opening-games-summary::-webkit-details-marker{display:none}.opening-games-summary:before{content:"▸";font-size:9px;transition:transform .15s ease}.opening-games-details[open]>.opening-games-summary:before{transform:rotate(90deg)}.opening-games-summary:hover{color:var(--accent)}.opening-games{margin-top:8px;display:flex;flex-direction:column;gap:4px}.opening-game-link{font-size:12px;color:var(--accent);text-decoration:none;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.opening-game-link:hover{text-decoration:underline}.opening-game-link.static{color:var(--muted);font-style:italic}.opening-card>.opening-name-row:first-child{margin-top:0}.opening-tabs{display:flex;gap:4px;margin-top:12px;padding:3px;background:var(--panel-2);border-radius:8px}.opening-tab{flex:1 1;border:none;background:transparent;color:var(--muted);font-size:12px;font-weight:600;padding:5px 8px;border-radius:6px;cursor:pointer;transition:background .12s,color .12s}.opening-tab:hover:not(:disabled){color:var(--text)}.opening-tab.active{background:var(--border);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.35),inset 0 0 0 1px rgba(110,168,254,.35)}.opening-tab:disabled{opacity:.4;cursor:default}.opening-card .opening-lead{margin-top:12px}.opening-trend{margin-top:14px}.opening-trend-title{font-size:11px;color:var(--muted);margin-bottom:6px}.trend-bars{display:flex;align-items:flex-end;gap:6px;height:72px}.trend-col{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.trend-bar-track{flex:1 1;width:100%;display:flex;align-items:flex-end}.trend-bar-fill{position:relative;width:100%;background:var(--accent);border-radius:3px 3px 0 0;min-height:2px}.trend-bar-count{position:absolute;left:0;right:0;text-align:center;font-size:9px;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;pointer-events:none;white-space:nowrap}.trend-bar-count.inside{top:3px;color:var(--bg);font-weight:600}.trend-bar-count.above{bottom:100%;margin-bottom:3px;color:var(--accent)}.trend-year{font-size:10px;color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}@keyframes shimmer{0%{opacity:.45}50%{opacity:.9}to{opacity:.45}}.skeleton-pill,.trend-bar-fill.skeleton{background:var(--panel-2);animation:shimmer 1.2s ease-in-out infinite}.skeleton-pill{display:inline-block;width:60%;height:8px;border-radius:4px}.trend-col:nth-child(2) .skeleton,.trend-col:nth-child(2) .skeleton-pill{animation-delay:.1s}.trend-col:nth-child(3) .skeleton,.trend-col:nth-child(3) .skeleton-pill{animation-delay:.2s}.trend-col:nth-child(4) .skeleton,.trend-col:nth-child(4) .skeleton-pill{animation-delay:.3s}.trend-col:nth-child(5) .skeleton,.trend-col:nth-child(5) .skeleton-pill{animation-delay:.4s}.trend-col:nth-child(6) .skeleton,.trend-col:nth-child(6) .skeleton-pill{animation-delay:.5s}.evalbar{flex:none;width:clamp(22px,2.2vmin,30px);align-self:stretch;background:#111;border:1px solid var(--border);border-radius:6px;position:relative;overflow:hidden;display:flex;flex-direction:column-reverse}.evalbar .white-fill{background:#e9edf3;width:100%;transition:height .4s ease}.evalbar .label{position:absolute;left:0;right:0;text-align:center;font-size:10px;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.evalbar .label.top{top:3px;color:#cfd6e0}.evalbar .label.bottom{bottom:3px;color:#20242c}.overlay{position:fixed;inset:0;background:rgba(8,10,14,.85);display:flex;align-items:center;justify-content:center;z-index:50}.modal{position:relative;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;width:440px;max-width:92vw}.modal-close{position:absolute;top:14px;right:14px;width:30px;height:30px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:14px;line-height:1;cursor:pointer}.modal-close:hover{color:var(--text);background:rgba(255,255,255,.06)}.modal h2{margin:0 0 6px;font-size:19px}.modal p{margin:0 0 18px;color:var(--muted);font-size:14px;line-height:1.5}.modal p.lead{margin-bottom:22px}.confirm-modal{width:380px}.confirm-actions{display:flex;justify-content:flex-end;gap:8px}.confirm-actions button{flex:0 0 auto}.setup-section{margin-bottom:20px}.section-label{margin:0 0 6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.modal p.section-help{margin:0 0 12px;font-size:13px}.section-label-row{gap:6px}.info-inline,.section-label-row{display:inline-flex;align-items:center}.info-inline{position:relative;line-height:1}.info-inline-pop{left:0;right:auto;max-width:280px;text-transform:none;letter-spacing:normal}.tier-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-bottom:12px}.tier-grid button{flex-direction:column;padding:14px 8px;text-align:center}.tier-grid button.selected{border-color:var(--accent);background:rgba(110,168,254,.12)}.tier-grid .t-name{font-weight:650;display:block}.tier-grid .t-elo{font-size:12px;color:var(--muted)}.elo-row{display:flex;gap:8px;align-items:center;justify-content:center;margin-bottom:0}.elo-row label{font-size:13px;color:var(--muted)}.elo-row input{font:inherit;background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;width:110px}.takeback-row{display:flex;gap:8px;align-items:center;justify-content:space-between;margin-bottom:0}.takeback-row label{font-size:13px;color:var(--muted)}.takeback-row select{font:inherit;background:var(--panel-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px}.spoiler-row{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--muted);cursor:pointer}.spoiler-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent,#5b8bb0);cursor:pointer}:root{--g-brilliant:#1bbfa6;--g-great:#5b8bb0;--g-best:#7eaa4e;--g-good:#84a667;--g-miss:#e0813f;--g-inaccuracy:#e6b53e;--g-mistake:#e07f3a;--g-blunder:#e0533f;--g-forced:#84a667}.glyph-brilliant{color:var(--g-brilliant)}.glyph-great{color:var(--g-great)}.glyph-best{color:var(--g-best)}.glyph-good{color:var(--g-good)}.glyph-miss{color:var(--g-miss)}.glyph-inaccuracy{color:var(--g-inaccuracy)}.glyph-mistake{color:var(--g-mistake)}.glyph-blunder{color:var(--g-blunder)}.glyph-forced{color:var(--g-forced)}.coach-body{display:flex;align-items:flex-start;gap:10px}.coach-text{flex:1 1;min-width:0}.glyph-chip{flex:none;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;margin-top:1px;border-radius:6px;font-weight:800;font-size:13px;color:#fff;background:var(--g-good);animation:glyph-pop .35s cubic-bezier(.18,1.5,.5,1) both}.glyph-chip.brilliant{background:var(--g-brilliant)}.glyph-chip.great{background:var(--g-great)}.glyph-chip.best{background:var(--g-best)}.glyph-chip.good{background:var(--g-good)}.glyph-chip.miss{background:var(--g-miss)}.glyph-chip.inaccuracy{background:var(--g-inaccuracy);color:#3a2c00}.glyph-chip.mistake{background:var(--g-mistake)}.glyph-chip.blunder{background:var(--g-blunder)}.glyph-chip.forced{background:var(--g-forced)}.glyph-chip.big{animation:glyph-pop-big .5s cubic-bezier(.18,1.6,.4,1) both}.board-wrap{position:relative}.board-overlay{container-type:size;z-index:5}.arrow-overlay,.board-overlay{position:absolute;inset:0;pointer-events:none}.arrow-overlay{width:100%;height:100%;z-index:4;animation:arrow-in .22s ease-out}@keyframes arrow-in{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){.arrow-overlay{animation:none}}.arrow-badges{position:absolute;inset:0;pointer-events:none;container-type:size;z-index:6;animation:arrow-in .22s ease-out}.arrow-badge{position:absolute;transform:translate(-50%,-50%);min-width:4.6cqw;height:4.6cqw;padding:0 .8cqw;box-sizing:border-box;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:2.9cqw;line-height:1;color:#fff;border:.5cqw solid rgba(255,255,255,.95);box-shadow:0 1px 4px rgba(0,0,0,.45)}@media (prefers-reduced-motion:reduce){.arrow-badges{animation:none}}.sq-glyph{position:absolute;transform:translate(-50%,-50%) scale(0);width:9cqw;height:9cqw;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:5cqw;color:#fff;background:var(--g-good);border:.6cqw solid rgba(255,255,255,.9);box-shadow:0 2px 6px rgba(0,0,0,.35);animation:sq-pop .7s forwards}.sq-glyph.brilliant{background:var(--g-brilliant)}.sq-glyph.great{background:var(--g-great)}.sq-glyph.best{background:var(--g-best)}.sq-glyph.good{background:var(--g-good)}.sq-glyph.miss{background:var(--g-miss)}.sq-glyph.inaccuracy{background:var(--g-inaccuracy);color:#3a2c00}.sq-glyph.mistake{background:var(--g-mistake)}.sq-glyph.blunder{background:var(--g-blunder)}.sq-glyph.forced{background:var(--g-forced)}.sq-glyph.big{animation:sq-pop .75s forwards,sq-glow 1.6s ease-in-out .7s infinite}@keyframes glyph-pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}@keyframes glyph-pop-big{0%{transform:scale(.3) rotate(-8deg);opacity:0}60%{transform:scale(1.18) rotate(3deg)}to{transform:scale(1) rotate(0);opacity:1}}@keyframes sq-pop{0%{transform:translate(-50%,-50%) scale(0);animation-timing-function:cubic-bezier(.22,1,.36,1)}40%{transform:translate(-50%,-50%) scale(1);animation-timing-function:cubic-bezier(.45,0,.3,1)}to{transform:translate(calc(-50% + 5.5cqw),calc(-50% - 5.5cqw)) scale(.55)}}@keyframes sq-glow{0%,to{box-shadow:0 2px 6px rgba(0,0,0,.35)}50%{box-shadow:0 0 16px 3px currentColor}}.promo-overlay{position:absolute;inset:0;z-index:8;container-type:size;background:rgba(8,10,15,.45);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);animation:result-fade .14s ease forwards}.promo-piece{position:absolute;width:12.5%;height:12.5%;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;background:#f8fafc;border:.4cqw solid rgba(8,10,15,.25);cursor:pointer;transition:background .12s ease,transform .12s ease}.promo-piece>span{display:block;width:82%;height:82%}.promo-piece:first-of-type{border-top-left-radius:6px;border-top-right-radius:6px}.promo-piece:focus-visible,.promo-piece:hover{background:#ffffff;border-color:rgba(8,10,15,.35);box-shadow:0 .6cqw 1.6cqw rgba(8,10,15,.5);transform:scale(1.07);outline:none;z-index:1}.result-overlay{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;padding:16px;background:rgba(8,10,15,.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:result-fade .18s ease forwards}.result-card{position:relative;text-align:center;background:var(--panel);border:1px solid var(--border);border-top:4px solid var(--accent);border-radius:14px;padding:26px 30px 22px;min-width:min(280px,80%);box-shadow:0 16px 48px rgba(0,0,0,.55);animation:result-pop .22s cubic-bezier(.18,1.4,.4,1) forwards}.result-card.win{border-top-color:var(--celebrate)}.result-card.loss{border-top-color:var(--alert)}.result-card.draw{border-top-color:var(--muted)}.result-title{font-size:clamp(22px,2.6vw,30px);font-weight:700;letter-spacing:-.01em;margin-bottom:6px}.result-card.win .result-title{color:var(--celebrate)}.result-card.loss .result-title{color:var(--alert)}.result-detail{color:var(--muted);font-size:14px;margin-bottom:18px}.result-newgame{width:100%}.result-close{position:absolute;top:8px;right:8px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;padding:0;font-size:20px;line-height:1;border-radius:8px;border:1px solid transparent;background:transparent;color:var(--muted)}.result-close:hover{color:var(--text);border-color:var(--border);background:var(--panel-2)}@keyframes result-fade{0%{opacity:0}to{opacity:1}}@keyframes result-pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width:820px){.layout{flex-direction:column;align-items:stretch}.board-col{width:100%;justify-content:center}.board-col-wrap{--board-size:min(calc(100vw - 70px),78vh);width:100%;align-items:center}.chat-panel{align-self:center}.sidebar{flex:none;width:100%;min-width:0}}.discuss-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;font-size:12.5px;font-weight:500;line-height:1;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--muted);transition:background .15s,border-color .15s,color .15s}.discuss-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.discuss-btn:disabled{opacity:.45;cursor:not-allowed}.board-col-wrap{--board-size:min(calc(100vh - 170px),calc(100vw - 480px),1040px);display:flex;flex-direction:column;gap:14px;flex:0 0 auto;min-width:0}.chat-panel{align-self:flex-end;width:var(--board-size);animation:chat-open .2s ease forwards}@keyframes chat-open{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.chat-card{display:flex;flex-direction:column;width:100%;max-height:460px;background:var(--panel);border:1px solid var(--border);border-top:4px solid var(--accent);border-radius:14px;box-shadow:0 10px 32px rgba(0,0,0,.4);overflow:hidden}.chat-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.chat-title{flex:1 1;font-weight:600;font-size:15px}.chat-close{border:none;background:transparent;color:var(--muted);padding:4px 8px;font-size:15px}.chat-close:hover{color:var(--text);border-color:transparent}.chat-messages{flex:1 1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.chat-msg{max-width:82%;padding:9px 13px;border-radius:14px;font-size:14px;line-height:1.5}.chat-msg p{margin:0}.chat-msg p+p{margin-top:8px}.chat-msg.coach{align-self:flex-start;background:var(--panel-2);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-msg.user{align-self:flex-end;background:var(--accent);color:#0b1020;border-bottom-right-radius:4px}.chat-tool-chip{font-size:12px;color:var(--muted);font-style:italic}.chat-error{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.chat-retry{font:inherit;font-size:13px;padding:5px 12px;border-radius:8px;border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer}.chat-retry:hover{border-color:var(--accent)}.chat-typing{display:inline-flex;gap:4px;align-items:center}.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:chat-bounce 1.2s ease-in-out infinite}.chat-typing span:nth-child(2){animation-delay:.18s}.chat-typing span:nth-child(3){animation-delay:.36s}@keyframes chat-bounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-4px);opacity:1}}.chat-input{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border)}.chat-input input{flex:1 1;min-width:0;font:inherit;font-size:14px;padding:9px 12px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text)}.chat-input input:focus{outline:none;border-color:var(--accent)}.chat-msg>span>:first-child,.chat-msg>span>p:first-child{margin-top:0}.chat-msg p{margin:0 0 8px}.chat-msg p:last-child{margin-bottom:0}.chat-msg strong{font-weight:650}.chat-msg ol,.chat-msg ul{margin:6px 0;padding-left:18px}.chat-msg li{margin:2px 0}