:root{color-scheme:dark;--app-bg: #070a12;--app-bg-deep: #030711;--app-surface: rgba(15, 23, 42, .78);--app-surface-strong: rgba(17, 24, 39, .94);--app-ink: #f8fafc;--app-muted: #a7b3c6;--app-border: rgba(148, 163, 184, .18);--app-shadow: 0 24px 70px rgba(0, 0, 0, .38);--app-accent: #38bdf8;--app-accent-hover: #7dd3fc;--app-accent-soft: rgba(56, 189, 248, .14);--app-warm: #fb923c;--surface-panel: rgba(15, 23, 42, .82);--surface-banner: rgba(17, 24, 39, .92);--border-strong: rgba(148, 163, 184, .35);--text-strong: #f8fafc;--text-muted: #cbd5e1;--accent: #0ea5e9;--accent-hover: #38bdf8;--shadow-lg: 0 22px 60px rgba(0, 0, 0, .35)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 16% 0%,rgba(56,189,248,.18),transparent 28%),radial-gradient(circle at 90% 12%,rgba(251,146,60,.12),transparent 26%),linear-gradient(180deg,var(--app-bg) 0%,var(--app-bg-deep) 100%);color:var(--app-ink);font-family:Avenir Next,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}.app-shell{width:min(1100px,calc(100vw - 32px));margin:0 auto;padding:48px 0 72px}.app-hero-card,.app-card{position:relative;overflow:hidden;border:1px solid var(--app-border);border-radius:24px;background:linear-gradient(180deg,#ffffff09,#ffffff03),#0f172a42;box-shadow:var(--app-shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);transition:background .18s ease,border-color .18s ease}.app-hero-card>*,.app-card>*{position:relative;z-index:1}.app-hero-card:hover,.app-card:hover{border-color:#38bdf857}.app-hero-card{padding:32px}.app-hero-card-accent{background:linear-gradient(135deg,#38bdf81a,#fb923c14),var(--app-surface)}.app-eyebrow{margin:0 0 10px;color:var(--app-muted);font-size:.84rem;letter-spacing:.18em;text-transform:uppercase}.app-title{margin:0;font-size:clamp(2.2rem,6vw,4.5rem);line-height:.94}.app-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.app-service-dot{flex:0 0 auto;width:.9rem;height:.9rem;margin-top:.35rem;border-radius:999px;border:1px solid rgba(248,250,252,.28);background:#ef4444;box-shadow:0 0 18px #ef444461}.app-service-dot.is-online{background:#22c55e;box-shadow:0 0 18px #22c55e61}.app-service-dot.is-offline{background:#ef4444}.app-subtitle{margin:14px 0 0;max-width:42rem;color:var(--app-muted);font-size:1.02rem}.app-grid{display:grid;gap:20px;margin-top:24px;grid-template-columns:repeat(2,minmax(0,1fr))}.app-card{padding:24px}.app-card-wide{grid-column:1 / -1}.app-card-title{margin:0 0 14px;font-size:1.1rem}.app-copy{margin:0;color:var(--app-muted)}.error-boundary-card{max-width:42rem;margin:8vh auto 0}.error-boundary-title{font-size:clamp(2rem,5vw,3.5rem)}.app-list{margin:0;padding-left:18px;color:var(--app-muted)}.app-action-stack{margin:10px;display:flex;flex-wrap:wrap;gap:12px}.app-action-stack-vertical{flex-direction:column;align-items:stretch}.app-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 16px;border-radius:999px;border:1px solid transparent;font:inherit;font-weight:600;cursor:pointer;transition:background-color .16s ease,border-color .16s ease,color .16s ease,opacity .16s ease,transform .16s ease}.app-button:hover:not(:disabled){transform:translateY(-1px)}.app-button:disabled{cursor:not-allowed;opacity:.58}.app-button:focus-visible,.app-chip:focus-visible,.app-input:focus-visible,.app-list-button:focus-visible{outline:3px solid rgba(56,189,248,.48);outline-offset:3px}.app-button-primary{background:var(--app-accent);color:#02111f}.app-button-primary:hover:not(:disabled){background:var(--app-accent-hover)}.app-button-secondary{background:var(--app-surface-strong);color:var(--app-ink);border-color:var(--app-border)}.app-button-secondary:hover:not(:disabled){background:#1e293bf5}.app-key-values{margin:0;display:grid;gap:12px}.app-key-values div{display:flex;justify-content:space-between;gap:16px;padding-bottom:10px;border-bottom:1px solid rgba(148,163,184,.12)}.app-key-values div:last-child{padding-bottom:0;border-bottom:0}.app-key-values dt{color:var(--app-muted)}.app-key-values dd{margin:0;font-weight:600}@media(max-width:760px){.app-shell{width:min(100vw - 20px,1100px);padding-top:24px}.app-grid{grid-template-columns:1fr}.app-card-wide{grid-column:auto}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.app-chip-row{display:flex;flex-wrap:wrap;gap:12px}.app-ruleset-card{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,.8fr);gap:20px;align-items:start}.app-ruleset-summary{margin:0;padding:14px 16px;display:grid;gap:8px;border:1px solid rgba(148,163,184,.14);border-radius:18px;background:#0f172a38;color:var(--app-muted);font-size:.92rem}.app-ruleset-summary li{margin-left:16px}.app-chip{min-height:42px;padding:0 16px;border-radius:999px;border:1px solid var(--app-border);background:var(--app-surface-strong);color:var(--app-ink);font:inherit;font-weight:600;cursor:pointer}.app-chip.is-selected{background:var(--app-accent-soft);border-color:#38bdf85c;color:var(--app-accent)}.app-form{display:flex;flex-wrap:wrap;gap:12px}.app-input{flex:1 1 280px;min-height:46px;padding:0 14px;border-radius:16px;border:1px solid var(--app-border);background:var(--app-surface-strong);color:var(--app-ink);font:inherit}.app-save-status{align-self:center;color:var(--app-muted);font-weight:700}.app-name-summary{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-bottom:16px}.app-name-summary-label{margin:0 0 4px;color:var(--app-muted);font-size:.9rem}.app-name-summary-value{margin:0;font-size:1.35rem;font-weight:700}.app-feedback{margin:14px 0 0;color:var(--app-warm);font-weight:600}.app-matchmaking-stage{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:220px;margin-top:24px;border-radius:22px;border:1px solid var(--app-border);background:radial-gradient(circle at center,rgba(56,189,248,.14),transparent 58%),#0f172a75}.app-matchmaking-orb{width:88px;height:88px;border-radius:999px;background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.92),transparent 34%),radial-gradient(circle at center,#38bdf8c7,#38bdf829);box-shadow:0 0 0 12px #38bdf814,0 18px 44px #38bdf838}.app-matchmaking-stage.is-found .app-matchmaking-orb{background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.92),transparent 34%),radial-gradient(circle at center,#127d56d1,#127d562e);box-shadow:0 0 0 12px #127d5614,0 18px 44px #127d5638}.app-matchmaking-stage.is-error .app-matchmaking-orb{background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.92),transparent 34%),radial-gradient(circle at center,#9f4f2fd1,#9f4f2f2e);box-shadow:0 0 0 12px #9f4f2f14,0 18px 44px #9f4f2f38}.app-matchmaking-label{margin:0;color:var(--app-muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.82rem}@media(max-width:760px){.app-ruleset-card{grid-template-columns:1fr}.app-name-summary{align-items:flex-start;flex-direction:column}}.game-board-wrap{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;width:100%;min-height:0;padding:1.5rem;border:1px solid rgba(255,255,255,.08);border-radius:32px;background:linear-gradient(180deg,#ffffff09,#ffffff04),#0206176b;box-shadow:var(--shadow-lg)}.board-svg{position:relative;z-index:1;background-color:transparent;min-width:100px;width:min(68vmin,720px);height:auto;filter:drop-shadow(0 20px 40px rgba(0,0,0,.35));user-select:none;-webkit-user-select:none}.board-background-rect{fill:#0f172ab8;stroke:#ffffff29;transition:fill .14s ease,stroke .14s ease,transform .14s ease}.board-background-rect.board-cycle-highlight{fill:#581c875c;stroke:#f472b6d1}.board-background-rect.board-collapse-target{fill:#1e293bf0;stroke:#f472b6b8}.board-background-rect.board-collapsed-x{fill:#1e40af57;stroke:#7dd3fccc}.board-background-rect.board-collapsed-o{fill:#9a341257;stroke:#fdba74d1}.board-little-cell-rect{fill:#ffffff06;stroke:#ffffff1f;stroke-width:.03;pointer-events:none}.board-cell{cursor:pointer}.board-cell:focus-visible{outline:none}.board-cell:hover .board-background-rect,.board-cell:focus-visible .board-background-rect{fill:#1e293beb;stroke:#f8fafc52}.board-cell:hover .board-background-rect.board-collapsed-x,.board-cell:focus-visible .board-background-rect.board-collapsed-x{fill:#1e40af66;stroke:#7dd3fce0}.board-cell:hover .board-background-rect.board-collapsed-o,.board-cell:focus-visible .board-background-rect.board-collapsed-o{fill:#9a341266;stroke:#fdba74e6}.q-layer-group rect{pointer-events:none}svg text{dominant-baseline:middle;text-align:middle;user-select:none;-webkit-user-select:none}.classic-text{font-family:Avenir Next,Segoe UI,sans-serif;font-size:48px;-webkit-user-select:none;user-select:none;pointer-events:none;font-weight:700}.classic-text.board-classic-x{fill:#e0f2fe;filter:drop-shadow(0 0 18px rgba(96,165,250,.45))}.classic-text.board-classic-o{fill:#ffedd5;filter:drop-shadow(0 0 18px rgba(251,146,60,.42))}.classic-token{font-size:2.1rem;letter-spacing:.04em}.quantum-symbol,.choosing-symbol{paint-order:stroke;stroke:#0f172a8c;stroke-width:2px;transition:transform .16s ease,filter .16s ease,opacity .16s ease;text-anchor:middle;dominant-baseline:middle;user-select:none;-webkit-user-select:none}.quantum-orbital{pointer-events:none;opacity:.82}.quantum-core,.quantum-orbit{fill:none;vector-effect:non-scaling-stroke}.quantum-core{stroke-width:1.35}.quantum-core-x,.quantum-orbit-x{stroke:#93c5fd7a}.quantum-core-o,.quantum-orbit-o{stroke:#fdba7475}.quantum-core-x{fill:#60a5fa1a}.quantum-core-o{fill:#fb923c1a}.quantum-orbit{stroke-width:1.1;stroke-dasharray:2.2 2.8;filter:drop-shadow(0 0 4px rgba(255,255,255,.08))}.quantum-entanglement-layer{pointer-events:none}.quantum-entanglement-line{pointer-events:none;stroke-width:2.4;stroke-linecap:round;opacity:.28;filter:drop-shadow(0 0 8px rgba(15,23,42,.4));animation:entanglementPulse 6.4s ease-in-out infinite;transition:opacity .22s ease,stroke-width .22s ease,filter .22s ease}.quantum-entanglement-line-x{stroke:#60a5fac7}.quantum-entanglement-line-o{stroke:#fb923cc2}.cycle-entanglement-line{opacity:.48}.collapse-preview-orbital{animation:orbitalSpin 2.8s linear infinite;transform-box:fill-box;transform-origin:center;filter:drop-shadow(0 0 6px rgba(248,250,252,.2))}.collapse-preview-origin-orbital{animation-duration:2.2s}.cycle-involved-symbol{stroke-width:3px}.cycle-involved-symbol:hover{transform:scale(1.08);transform-box:fill-box;transform-origin:center;filter:brightness(1.2)}.cycle-involved-symbol-x{fill:#0967e1!important;stroke:#022f65eb;filter:drop-shadow(0 0 4px rgba(96,165,250,.8)) drop-shadow(0 0 8px rgba(96,165,250,.6))}.cycle-involved-symbol-o{fill:#e42407!important;stroke:#570707eb;filter:drop-shadow(0 0 4px rgba(251,146,60,.8)) drop-shadow(0 0 8px rgba(251,146,60,.6))}.cycle-not-involved-symbol{opacity:.25;filter:blur(.5px);transition:all .2s ease}.cycle-not-involved-symbol-x{fill:#1e3a8a;stroke:#60a5fa40}.cycle-not-involved-symbol-o{fill:#7c2d12;stroke:#fb923c40}.collapse-context-symbol{opacity:1;stroke-width:3px;filter:drop-shadow(0 0 2px rgba(255,255,255,.2))}.collapse-choice-symbol{opacity:1;stroke-width:3.2px;filter:drop-shadow(0 0 4px rgba(248,250,252,.2))}.collapse-passive-symbol{opacity:.82;stroke-width:2.7px}.collapse-outside-symbol{opacity:.26}.collapse-preview-symbol{opacity:1!important;filter:brightness(1.22) drop-shadow(0 0 8px rgba(248,250,252,.42));transform:scale(1.08);transform-box:fill-box;transform-origin:center}.collapse-preview-choice-symbol{stroke-width:3.6px;filter:brightness(1.28) drop-shadow(0 0 10px rgba(248,250,252,.52)) drop-shadow(0 0 16px rgba(59,130,246,.24))}.collapse-preview-origin-symbol{filter:brightness(1.28) drop-shadow(0 0 10px rgba(248,250,252,.5)) drop-shadow(0 0 16px rgba(244,114,182,.32))}.collapse-preview-auto-symbol{stroke-width:3px;filter:brightness(1.16) drop-shadow(0 0 7px rgba(248,250,252,.34)) drop-shadow(0 0 12px rgba(244,114,182,.14))}.collapse-rest-choice-symbol{opacity:.56!important;stroke-width:2.9px;filter:saturate(.92) drop-shadow(0 0 4px rgba(248,250,252,.14))}.collapse-rest-symbol{opacity:.16!important;stroke-width:2px;filter:saturate(.5) blur(.18px)}.collapse-preview-line{opacity:.92;stroke-width:3.6;filter:drop-shadow(0 0 10px rgba(248,250,252,.34))}.cycle-path-line,.cycle-path-node{pointer-events:none}.winning-line-glow{stroke:#facc1557;stroke-width:18;filter:drop-shadow(0 0 18px rgba(250,204,21,.42))}.winning-line-core{stroke:#fde047;stroke-width:8}@keyframes entanglementPulse{0%,to{opacity:.22;filter:drop-shadow(0 0 6px rgba(15,23,42,.22))}50%{opacity:.42;filter:drop-shadow(0 0 10px rgba(255,255,255,.14))}}@keyframes orbitalSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-game-view{width:min(1320px,calc(100vw - 24px));margin:0 auto;padding:24px 0;min-height:100vh;display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:20px;align-items:start}.app-game-controls{position:sticky;top:20px;display:grid;gap:12px;align-content:start;min-width:0}.app-game-content{min-width:0}.app-room-layout{display:grid;gap:18px;width:100%}.app-room-main{display:grid;gap:18px;grid-template-columns:minmax(0,1fr) minmax(240px,300px);align-items:start;min-width:0}.app-player-sidebar{display:grid;gap:16px;align-content:start;min-width:0}.app-game-action-stack{display:grid;gap:12px}.app-game-view .status-banner{grid-area:auto;align-self:stretch;width:100%}.app-game-view .game-board-wrap{grid-area:auto;min-height:auto;aspect-ratio:1;padding:clamp(12px,2vw,22px);border-radius:24px}.app-game-view .board-svg{width:min(100%,70vh,760px);max-width:100%;height:auto}.app-game-view .player-display-container,.app-game-view .history-panel,.app-game-view .match-actions-panel,.app-game-view .game-inline-panel,.app-game-view .wave-expression-panel{width:100%}.status-banner{position:relative;min-width:0;min-height:72px;padding:1rem 1.5rem;border:1px solid var(--border-strong);border-radius:18px;background:var(--surface-banner);box-shadow:var(--shadow-lg);color:var(--text-strong);font-size:1.15rem;font-weight:600;letter-spacing:.01em;text-align:center;transition:color .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease,transform .18s ease}.status-banner[data-tone=mark-x]{color:#e0f2fe;border-color:#7dd3fc66;background:linear-gradient(135deg,#1e40af7a,#0f172aeb),var(--surface-banner);text-shadow:0 0 12px rgba(96,165,250,.55),0 0 24px rgba(96,165,250,.28)}.status-banner[data-tone=mark-o]{color:#ffedd5;border-color:#fb923c61;background:linear-gradient(135deg,#9a341270,#0f172aeb),var(--surface-banner);text-shadow:0 0 10px rgba(251,146,60,.36),0 0 20px rgba(251,146,60,.18)}.status-banner[data-tone=waiting]{color:#fef3c7;border-color:#facc1547;background:linear-gradient(135deg,#78350f5c,#0f172aeb),var(--surface-banner)}.status-banner[data-tone=starting]{color:#fce7f3;border-color:#f472b652;background:linear-gradient(135deg,#9d174d57,#0f172aeb),var(--surface-banner)}.status-banner[data-tone=spectator],.status-banner[data-tone=neutral]{color:var(--text-strong)}.status-banner.is-emphasized{animation:statusBannerPulse 3.4s ease-in-out infinite}.player-display-container{display:flex;flex-direction:column;gap:.85rem;padding:1rem 1.05rem 1.05rem;border:1px solid rgba(255,255,255,.08);border-radius:20px;background:linear-gradient(180deg,#ffffff12,#ffffff08),#0f172ac7;box-shadow:0 14px 36px #0003;color:var(--text-strong);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.player-display-container[data-tone=mark-x]{border-color:#60a5fa2e}.player-display-container[data-tone=mark-o]{border-color:#fb923c2e}.player-display-container.is-active{transform:translateY(-1px)}.player-display-container[data-tone=mark-x].is-active{box-shadow:0 14px 36px #0000003d,0 0 0 1px #60a5fa24,0 0 24px #60a5fa1f}.player-display-container[data-tone=mark-o].is-active{box-shadow:0 14px 36px #0000003d,0 0 0 1px #fb923c1f,0 0 24px #fb923c1a}.player-display-container.is-winner{border-color:#facc153d;box-shadow:0 14px 36px #0000003d,0 0 24px #facc151a}.player-display-container.is-dimmed{opacity:.72}.player-card-header{display:flex;align-items:center;gap:.75rem}.player-mark-badge{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:999px;font-size:.95rem;font-weight:800;letter-spacing:.02em;background:#ffffff14;border:1px solid rgba(255,255,255,.08)}.player-display-container[data-tone=mark-x] .player-mark-badge{color:#dbeafe;background:#1e40af57;border-color:#7dd3fc3d}.player-display-container[data-tone=mark-o] .player-mark-badge{color:#ffedd5;background:#9a341257;border-color:#fdba7433}.player-label{margin:0;color:#cbd5e1c7;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.player-display-container .name{margin:0;color:var(--text-strong);font-size:1.1rem;font-weight:700;letter-spacing:.2px}.player-chip-row{display:flex;flex-wrap:wrap;gap:.45rem}.player-chip{display:flex;align-items:center;gap:.4rem;margin:0;padding:.38rem .62rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:#ffffff0d;color:#e2e8f0e0;font-size:.8rem;line-height:1}.player-chip-status{color:#e2e8f0c7}.player-timer-panel{display:flex;align-items:baseline;justify-content:space-between;gap:.85rem;padding:.85rem .95rem;border-radius:16px;background:#0206176b;border:1px solid rgba(255,255,255,.06)}.player-timer-label{margin:0;color:#cbd5e1b3;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}.player-display-container.is-active .player-timer-panel{border-color:#ffffff1f;background:#02061794}.timer{margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:1.15rem;font-weight:700}.player-timer-value{color:var(--text-strong)}.game-action-button,.game-secondary-button,.history-button,.summary-close{display:inline-flex;align-items:center;justify-content:center;border:0;color:#fff;font:inherit;font-weight:700;cursor:pointer;transition:background-color .16s ease,opacity .16s ease,transform .16s ease}.game-action-button{width:100%;min-height:48px;margin:0;padding:.85rem 1.5rem;border-radius:14px;background:var(--accent);box-shadow:0 10px 24px #d0204338}.game-action-button:hover{background:var(--accent-hover)}.game-secondary-button{width:100%;min-height:48px;margin:0;padding:.85rem 1rem;border:1px solid rgba(248,250,252,.12);border-radius:14px;background:#f8fafc1f}.game-secondary-button:hover{background:#f8fafc33}.game-action-button:disabled,.game-secondary-button:disabled,.history-button:disabled{cursor:not-allowed;opacity:.58}.history-panel,.match-actions-panel,.game-inline-panel,.leave-prompt-panel{display:flex;flex-direction:column;gap:.8rem;padding:1rem;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,#ffffff09,#ffffff04),#0206176b;box-shadow:var(--shadow-lg)}.leave-prompt-panel{border-color:#f871712e;background:linear-gradient(180deg,#7f1d1d29,#0f172abd),#0206176b}.history-label,.match-actions-title,.game-inline-panel h3,.leave-prompt-title{margin:0;color:var(--text-strong)}.history-label{font-size:.95rem;line-height:1.5}.wave-expression-panel{padding:.85rem 1rem;border:1px solid rgba(125,211,252,.1);border-radius:18px;background:linear-gradient(90deg,#60a5fa12,#fb923c0d),#02061757;box-shadow:0 14px 36px #00000029}.wave-expression-value{display:block;max-height:5.5rem;overflow:auto;color:#e2e8f0db;font-size:.9rem;line-height:1.55;white-space:normal;overflow-wrap:anywhere}.wave-expression-symbol,.wave-expression-operator,.wave-expression-more,.wave-expression-empty{color:#cbd5e1c7}.wave-expression-term.is-x{color:#bfdbfe;text-shadow:0 0 14px rgba(96,165,250,.22)}.wave-expression-term.is-o{color:#fed7aa;text-shadow:0 0 14px rgba(251,146,60,.2)}.wave-expression-term{display:inline-block;font-weight:800;transition:color .16s ease,filter .16s ease,opacity .16s ease,transform .16s ease}.wave-expression-term.is-cycle.is-x{color:#60a5fa;filter:drop-shadow(0 0 4px rgba(96,165,250,.8)) drop-shadow(0 0 8px rgba(96,165,250,.6))}.wave-expression-term.is-cycle.is-o{color:#fb923c;filter:drop-shadow(0 0 4px rgba(251,146,60,.8)) drop-shadow(0 0 8px rgba(251,146,60,.6))}.wave-expression-term.is-outside-cycle{opacity:.25;filter:blur(.4px) saturate(.65)}.wave-expression-term.is-preview{opacity:1;transform:scale(1.06);filter:brightness(1.28) drop-shadow(0 0 10px rgba(248,250,252,.52)) drop-shadow(0 0 16px rgba(59,130,246,.24))}.wave-expression-term.is-preview.is-o{filter:brightness(1.24) drop-shadow(0 0 10px rgba(248,250,252,.46)) drop-shadow(0 0 16px rgba(251,146,60,.24))}.wave-expression-term.is-preview-rest{opacity:.32;filter:saturate(.72)}.match-actions-title,.leave-prompt-title{font-size:1rem;font-weight:700}.match-actions-body,.game-inline-panel p,.leave-prompt-body{margin:0;color:var(--text-muted);font-size:.94rem;line-height:1.55}.history-actions,.match-actions-buttons,.leave-prompt-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.55rem}.match-actions-buttons,.leave-prompt-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.history-button{width:100%;min-height:44px;margin:0;padding:0;border-radius:12px;border:1px solid rgba(248,250,252,.1);background:#f8fafc1f;font-size:1.25rem;line-height:1}.history-button:hover{background:#f8fafc33}.history-live-button{background:#0ea5e92e;border-color:#38bdf83d}.match-actions-buttons button,.leave-prompt-actions button{width:100%;white-space:normal;text-wrap:balance}.game-toast{position:fixed;left:50%;bottom:2rem;z-index:9;transform:translate(-50%,1rem);min-width:min(32rem,calc(100vw - 2rem));max-width:min(32rem,calc(100vw - 2rem));padding:.95rem 1.2rem;border:1px solid rgba(249,115,22,.28);border-radius:16px;background:#111827f0;color:var(--text-strong);box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease;text-align:center}.game-toast.is-visible{opacity:1;transform:translate(-50%)}.summary-modal,.status-overlay{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:1rem;pointer-events:none}.summary-modal.is-visible,.status-overlay.is-visible{pointer-events:auto}.summary-card,.status-overlay-card{width:min(26rem,calc(100vw - 2rem));padding:1.25rem;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:linear-gradient(180deg,#ffffff0f,#ffffff06),#0f172af5;box-shadow:var(--shadow-lg);color:var(--text-strong)}.summary-close{width:auto;min-height:38px;margin:0 0 .85rem auto;padding:0 .8rem;border-radius:999px;background:#f8fafc1f}.summary-title,.status-overlay-title{margin:0;color:var(--text-strong);font-size:1.25rem;line-height:1.2}.summary-body,.status-overlay-body{margin:.85rem 0 0;color:var(--text-muted);line-height:1.55}.summary-meta{display:grid;gap:.6rem;margin-top:1rem}.summary-meta-row{display:flex;justify-content:space-between;gap:1rem;padding:.7rem .85rem;border-radius:12px;background:#ffffff0a}.summary-actions,.status-overlay-actions{display:grid;gap:.65rem;margin-top:1rem}.status-overlay-countdown{margin:1rem 0 0;color:var(--text-strong);font-size:2.5rem;font-weight:800;text-align:center}.game-inline-panel p{margin-top:8px}@media(max-width:760px){.app-game-view{width:min(100vw - 20px,1100px);grid-template-columns:1fr;padding-top:12px}.app-game-controls{position:static;order:2}.app-game-content{order:1}.app-room-main{grid-template-columns:1fr}.app-game-view .board-svg{width:min(100%,92vw,560px)}.match-actions-buttons,.leave-prompt-actions{grid-template-columns:1fr}}@keyframes statusBannerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.015)}}.app-section-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:14px}.app-stack-list{display:grid;gap:14px}.app-list-card,.app-list-button{display:grid;gap:8px;padding:18px;border:1px solid var(--app-border);border-radius:18px;background:var(--app-surface-strong);color:var(--app-ink);text-align:left}.app-list-button{width:100%;cursor:pointer;font:inherit}.app-list-button.is-selected{border-color:#38bdf861;box-shadow:inset 0 0 0 1px #38bdf82e}.app-list-card-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.app-status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:32px;width:fit-content;padding:0 12px;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:#94a3b81f;color:var(--app-muted)}.app-status-pill.is-live{background:#38bdf824;color:var(--app-accent)}.app-status-pill.is-waiting{background:#fb923c24;color:var(--app-warm)}.app-status-pill.is-offline{background:#94a3b81f;color:var(--app-muted)}.app-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px}.app-detail-grid div{padding:12px 14px;border:1px solid var(--app-border);border-radius:14px;background:var(--app-surface-strong)}.app-detail-grid dt{margin-bottom:4px;color:var(--app-muted);font-size:.84rem}.app-detail-grid dd{margin:0;font-weight:600}.app-code-block{margin:0;padding:18px;overflow:auto;border-radius:18px;border:1px solid var(--app-border);background:#020617b3;color:#dbeafe;font:.92rem/1.5 SFMono-Regular,Menlo,monospace}.app-confirm-panel{display:grid;gap:12px;margin-top:14px;padding:14px;border:1px solid rgba(251,146,60,.24);border-radius:16px;background:#fb923c14}.app-confirm-panel h3{margin:0;font-size:1rem}@media(max-width:760px){.app-section-head,.app-list-card-row{align-items:flex-start;flex-direction:column}}
