:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#090d14;color:#e5edf7}*{box-sizing:border-box}body{margin:0;min-width:320px;background:radial-gradient(circle at 50% 0%,rgba(40,70,120,.28),transparent 42%),#090d14}button{font:inherit}.app-shell{min-height:100vh;padding:24px}.topbar{display:flex;align-items:center;justify-content:flex-start;gap:12px;max-width:1180px;margin:0 auto 18px}.topbar>div{margin-right:auto}.topbar h1{margin:0;font-size:28px;letter-spacing:0}.topbar p{margin:4px 0 0;color:#93a4ba}.primary-button{border:1px solid #446189;background:#1c3659;color:#f8fafc;border-radius:8px;padding:10px 16px;cursor:pointer}.secondary-button{border:1px solid #33445f;background:#111c2b;color:#d9e5f5;border-radius:8px;padding:10px 16px;cursor:pointer}.danger-button{width:100%;border:1px solid #7f1d1d;background:#7f1d1d3d;color:#fecaca;border-radius:8px;padding:10px 12px;cursor:pointer}.compact-button{width:auto;min-width:92px;padding:8px 12px}.primary-button:disabled,.secondary-button:disabled,.danger-button:disabled{opacity:.6;cursor:progress}.game-layout{display:grid;grid-template-columns:minmax(580px,min(820px,calc((100vh - 250px)*1.104))) 300px;gap:22px;justify-content:center;align-items:start}.mobile-game-history{display:none}.board-stage{position:relative;padding-top:60px;padding-bottom:64px;width:100%}.replay-banner{position:absolute;right:10px;bottom:10px;z-index:3;display:flex;gap:10px;align-items:center;border:1px solid #34506f;border-radius:8px;background:#0d1c30f0;padding:8px 10px;color:#bfdbfe;font-size:13px}.player-panel-layer{position:absolute;inset:0;z-index:2;pointer-events:none}.player-panel-group{position:absolute;display:grid;grid-template-columns:max-content minmax(46px,auto) max-content;gap:10px;align-items:center;width:max-content;min-width:246px;max-width:332px;min-height:54px;border:1px solid #1d2c42;border-radius:8px;background:#0d1420bd;padding:8px 10px}.player-panel-top-left{top:2px;left:0}.player-panel-top-right{top:2px;right:0}.player-panel-bottom{bottom:4px;left:50%;transform:translate(-50%)}.player-panel-identity{display:grid;gap:3px;min-width:0}.player-panel-group small{color:#93a4ba;font-size:12px}.player-panel-group strong{color:#e5edf7;font-size:18px;letter-spacing:0;white-space:nowrap}.player-panel-turn{border-color:#d9a935;box-shadow:0 0 0 1px #d9a93542}.player-panel-defeated{opacity:.62}.player-panel-captures{display:grid;gap:3px;min-width:0;max-width:148px}.capture-row{display:flex;align-items:center;min-width:0}.capture-strip{display:flex;flex-wrap:wrap;align-items:center;min-height:20px;gap:3px;min-width:0}.capture-empty{color:#71839a;font-size:11px}.capture-piece{width:18px;height:18px;flex:0 0 auto;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}.capture-piece circle{stroke:#111827;stroke-width:2}.board{display:block;width:100%;border:1px solid #1d2c42;border-radius:8px;background:#0d1420}.board-bg{fill:#0d1420}.cell{fill:#111c2b;stroke:#26374f;stroke-width:1.4;cursor:default}.cell-center{fill:#18263a;stroke:#dfb85f}.recent-move{pointer-events:none}.recent-move-cell{fill:transparent;stroke-width:3;opacity:.8}.recent-move-secondary .recent-move-cell{stroke-width:2.2;opacity:.48}.recent-move-capture{stroke-dasharray:8 5}.recent-move-rojo .recent-move-cell{stroke:#fca5a5}.recent-move-verde .recent-move-cell{stroke:#86efac}.recent-move-azul .recent-move-cell{stroke:#93c5fd}.cell-move{fill:#203553;stroke:#7aa2d8;cursor:pointer}.board-turn-rojo .cell-move{fill:#35202a;stroke:#fca5a5}.board-turn-verde .cell-move{fill:#183126;stroke:#86efac}.board-turn-azul .cell-move{fill:#203553;stroke:#93c5fd}.cell-drop-target{fill:#25466e;stroke:#facc15;stroke-width:2.5}.move-dot{fill:#9bc6ff;stroke:#e5edf7e0;stroke-width:2;pointer-events:none}.board-turn-rojo .move-dot{fill:#fca5a5}.board-turn-verde .move-dot{fill:#86efac}.board-turn-azul .move-dot{fill:#93c5fd}.board-turn-rojo .move-dot.captura{fill:#fecaca;stroke:#ef4444}.board-turn-verde .move-dot.captura{fill:#bbf7d0;stroke:#22c55e}.board-turn-azul .move-dot.captura{fill:#bfdbfe;stroke:#3b82f6}.piece{cursor:pointer;touch-action:none}.piece circle{stroke:#111827;stroke-width:2}.piece-active circle{stroke:#e5edf7}.piece-selected circle{stroke:#facc15;stroke-width:4}.piece-ghost{opacity:.35}.piece-dragging{pointer-events:none;filter:drop-shadow(0 12px 16px rgba(0,0,0,.35))}.piece-dragging circle{stroke:#facc15;stroke-width:4}.piece-evaluation-badge{pointer-events:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.38))}.piece-evaluation-badge rect{stroke-width:1}.piece-evaluation-badge text{fill:currentColor;font-size:10px;font-weight:800;letter-spacing:.01em}.piece-evaluation-badge-mejor{color:#86efac}.piece-evaluation-badge-mejor rect{fill:#14532deb;stroke:#86efac8c}.piece-evaluation-badge-buena{color:#bfdbfe}.piece-evaluation-badge-buena rect{fill:#1e40afeb;stroke:#93c5fd8c}.piece-evaluation-badge-imprecision{color:#fef08a}.piece-evaluation-badge-imprecision rect{fill:#713f12eb;stroke:#fde0478c}.piece-evaluation-badge-error{color:#fed7aa}.piece-evaluation-badge-error rect{fill:#7c2d12eb;stroke:#fdba748c}.piece-evaluation-badge-grave{color:#fecaca}.piece-evaluation-badge-grave rect{fill:#7f1d1deb;stroke:#fca5a599}.hud{display:flex;flex-direction:column;height:min(820px,calc(100vh - 190px));min-height:0;overflow:hidden;border:1px solid #1d2c42;border-radius:8px;background:#0d1420eb;padding:18px}.hud section+section{margin-top:18px}.hud h2{margin:0 0 10px;font-size:15px;color:#c7d2e3}dl{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0}dt{color:#93a4ba}dd{margin:0;text-align:right}.hud-status{display:grid;gap:14px}.hud-status-top{display:flex;justify-content:space-between;gap:8px;align-items:center}.connection-badge,.status-badge{border:1px solid #26374f;border-radius:999px;padding:4px 9px;color:#9fb1c9;font-size:12px;line-height:1;white-space:nowrap}.connection-online{border-color:#4ade8075;background:#4ade801c;color:#86efac}.status-badge{color:#c7d2e3}.hud-label{display:block;margin-bottom:3px;color:#93a4ba;font-size:13px}.hud-current-turn{display:block;font-size:28px;line-height:1;letter-spacing:0}.hud-move-number{display:flex;justify-content:space-between;border-top:1px solid #1d2c42;padding-top:10px;color:#93a4ba}.hud-move-number strong{color:#e5edf7}.hud-history{display:flex;min-height:0;flex:1;flex-direction:column;border-top:1px solid #1d2c42;padding-top:14px}.history-controls{display:flex;gap:5px;align-items:center;margin-bottom:8px}.history-control-button{min-width:30px;padding:5px 7px}.history-live-button{margin-left:auto;min-width:64px;padding:5px 8px}.clock-list{display:grid;gap:8px}.clock-row{display:flex;justify-content:space-between}.presence-dot{display:inline-block;width:8px;height:8px;margin-right:8px;border-radius:999px;vertical-align:middle}.presence-online{background:#4ade80}.presence-offline{background:#475569}.history-list{display:grid;gap:6px;min-height:0;flex:1;align-content:start;overflow:auto;margin:0;padding-left:0;color:#c7d2e3;font-size:13px;list-style:none}.history-row{border-radius:6px;line-height:1.25}.history-tree .history-row{margin-left:calc(var(--history-depth, 0) * 18px)}.history-row-branch{border-left:1px solid rgba(122,162,216,.28);padding-left:5px}.history-row-selected{background:#d9a9351f;box-shadow:inset 0 0 0 1px #d9a93552}.history-row-button{display:grid;grid-template-columns:24px 22px 1fr;gap:5px;align-items:center;width:100%;border:0;border-radius:6px;background:transparent;padding:4px 3px;color:inherit;font:inherit;text-align:left;cursor:pointer}.history-row-button:hover{background:#94a3b814}.history-row-button:focus-visible{outline:2px solid #7aa2d8;outline-offset:1px}.history-number{color:#93a4ba;text-align:right}.history-piece{width:20px;height:20px;flex:0 0 auto;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}.history-piece circle{stroke:#111827;stroke-width:2}.history-move{display:inline-flex;align-items:center;gap:6px;min-width:0;line-height:20px;white-space:nowrap}.history-move-symbol,.history-capture-symbol{display:inline-flex;align-items:center;justify-content:center;min-width:10px}.history-capture-symbol{color:#fca5a5;font-weight:800}.history-evaluation{flex:0 0 auto;width:max-content;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:700;letter-spacing:.01em}.history-evaluation-mejor{background:#4ade8029;color:#86efac}.history-evaluation-buena{background:#60a5fa29;color:#93c5fd}.history-evaluation-pending{background:#94a3b81f;color:#94a3b8}.history-evaluation-imprecision{background:#facc1529;color:#fde047}.history-evaluation-error{background:#fb923c29;color:#fdba74}.history-evaluation-grave{background:#f871712e;color:#fca5a5}.history-list em{grid-column:3;color:#f6d58a;font-style:normal}.muted{margin:0;color:#71839a}.player{font-weight:700}.player-rojo{color:#ff7b7b}.player-verde{color:#65d690}.player-azul{color:#86b6ff}.notice,.result,.error,.empty-state{border-radius:8px}.notice{border:1px solid #a8873d;background:#7e571738;padding:12px;color:#f6d58a}.result{border:1px solid #4d7c5d;background:#165c363d;padding:14px;text-align:center}.result-action{width:100%;margin-top:12px}.system-messages{position:fixed;left:50%;bottom:18px;z-index:40;display:grid;gap:10px;width:min(720px,calc(100vw - 32px));transform:translate(-50%);pointer-events:none}.system-message{border-radius:8px;padding:12px 14px;box-shadow:0 16px 32px #00000052;pointer-events:auto}.system-message-error{border:1px solid #7f1d1d;background:#450a0af5;color:#fecaca;white-space:pre-wrap}.system-message-feedback{border:1px solid #34506f;background:#0d1c30f5;color:#bfdbfe;animation:feedback-fade-out 4.8s ease forwards}@keyframes feedback-fade-out{0%,72%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}.error,.feedback,.room-banner,.room-lobby{max-width:1180px;margin:0 auto 18px;padding:12px}.error{border:1px solid #7f1d1d;background:#7f1d1d3d;color:#fecaca;white-space:pre-wrap}.feedback{border:1px solid #34506f;background:#1e3a5f47;color:#bfdbfe}.room-banner{display:flex;align-items:center;gap:12px;border:1px solid #33445f;border-radius:8px;background:#0d1420eb;color:#c7d2e3}.room-banner strong{color:#f8fafc;font-size:20px;letter-spacing:.08em}.room-lobby{display:grid;gap:14px;border:1px solid #33445f;border-radius:8px;background:#0d1420eb}.room-lobby-header,.room-actions,.setting-row{display:flex;align-items:center}.room-lobby-header,.setting-row{justify-content:space-between}.room-lobby-header span,.setting-row span,.settings-grid span,.room-lobby p{color:#93a4ba}.room-lobby-header strong{display:block;color:#f8fafc;font-size:28px;letter-spacing:.1em}.room-lobby-header p{margin-top:8px}.room-status-pill{align-self:start;border:1px solid #33445f;border-radius:999px;padding:5px 10px;color:#d9e5f5;background:#0b1220}.room-panel{display:grid;gap:12px;border:1px solid #24364f;border-radius:8px;padding:14px;background:#070d188c}.room-panel h2{margin:0;color:#f8fafc;font-size:15px}.settings-grid{display:grid;grid-template-columns:140px 1fr;gap:10px 16px;margin-top:22px}.room-lobby .settings-grid{margin-top:0}.seat-list{display:grid;gap:8px}.seat-row{display:grid;grid-template-columns:minmax(180px,1fr) 92px 258px;gap:14px;align-items:center;border:1px solid #24364f;border-radius:8px;padding:10px 12px;background:#0b1220}.seat-row-rojo{border-left:4px solid #d84040}.seat-row-verde{border-left:4px solid #2f9e62}.seat-row-azul{border-left:4px solid #3b82f6}.seat-row-closed{background:#0b122094}.seat-row-closed .seat-main,.seat-row-closed .seat-ready{opacity:.52}.seat-main{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:center}.seat-color{font-weight:700}.seat-ready{border:1px solid #33445f;border-radius:999px;padding:5px 9px;color:#93a4ba;text-align:center;white-space:nowrap}.seat-ready-on{border-color:#2f9e62;background:#2f9e622e;color:#8ff0b6}.seat-actions{display:grid;grid-template-columns:92px 158px;justify-content:flex-end;gap:8px}.seat-mode-select{min-width:0;border:1px solid #33445f;border-radius:8px;background:#0b1220;color:#e5edf7;padding:7px 8px;font:inherit}.presence-bot{background:#d9a935}.seat-action-placeholder{visibility:hidden}.seat-own-color{display:inline-flex;align-items:center;justify-content:center;border:1px solid #33445f;border-radius:8px;background:#94a3b814;color:#c7d2e1;font-weight:700;white-space:nowrap}.open-colors{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center}.open-colors>span{color:#93a4ba}.color-chip-list{display:flex;flex-wrap:wrap;gap:8px}.color-chip{border:1px solid #33445f;border-radius:999px;padding:5px 10px;color:#f8fafc;font-weight:700}.color-chip-rojo{background:#d8404033}.color-chip-verde{background:#2f9e6233}.color-chip-azul{background:#3b82f633}.color-chip-closed{opacity:.35;text-decoration:line-through}.room-lobby p{margin:0}.room-setup{display:grid;gap:18px}.room-config{display:grid;gap:12px}.room-config label{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center}.room-config label span{color:#93a4ba}.room-config select{min-width:0;border:1px solid #33445f;border-radius:8px;background:#0b1220;color:#e5edf7;padding:10px 12px;font:inherit}.setting-row{gap:16px;margin-top:6px}.setting-row input{width:18px;height:18px}.room-actions{gap:10px;margin-top:4px}.room-actions .danger-button{width:auto;min-width:180px}.empty-state{max-width:720px;margin:80px auto 0;padding:28px;border:1px solid #1d2c42;background:#0d1420eb}.empty-state h2{margin:0 0 8px}.empty-state p{margin:0;color:#93a4ba}.home-lobby{display:grid;gap:16px;max-width:820px;margin:58px auto 0}.home-primary,.lobby-panel{border:1px solid #1d2c42;border-radius:8px;background:#0d1420eb;padding:20px}.home-primary{display:grid;gap:16px}.home-primary h2{margin:0;font-size:23px}.home-primary h3,.lobby-panel h3{margin:6px 0 0;font-size:15px;color:#c7d2e3}.quick-match-actions{display:grid;grid-template-columns:minmax(220px,1fr) minmax(220px,1.1fr);gap:10px}.quick-config-toggle,.quick-play-button{min-height:44px}.quick-config-toggle{display:inline-flex;align-items:center;justify-content:space-between;gap:12px}.quick-config-chevron{display:inline-grid;place-items:center;width:18px;height:18px;transition:transform .16s ease}.quick-config-chevron.is-open{transform:rotate(180deg)}.quick-play-button{font-weight:800;box-shadow:0 0 0 1px #6da6ff3d}.quick-match-config{display:grid;gap:10px;border:1px solid #26374f;border-radius:8px;padding:12px;background:#0b1220}.quick-match-config-controls{display:grid;grid-template-columns:minmax(150px,.6fr) minmax(280px,1fr);gap:10px}.quick-match-config-controls label{display:grid;gap:6px}.quick-match-config-controls label span{color:#93a4ba;font-size:13px}.quick-match-config-controls select{min-width:0;border:1px solid #33445f;border-radius:8px;background:#0b1220;color:#e5edf7;padding:10px 12px;font:inherit}.quick-match-availability{margin:0;color:#b8c7dc;display:grid;gap:4px}.quick-match-availability p{margin:0}.quick-match-waiting{gap:18px}.quick-match-progress{display:flex;align-items:baseline;gap:10px}.quick-match-progress strong{font-size:28px;color:#e5edf7}.quick-match-progress span{color:#93a4ba}.recovery-panel{border-color:#34506f;background:#0f1b2bf5}.recovery-list{display:grid;gap:8px;margin-top:12px}.recovery-row{display:grid;grid-template-columns:82px 1fr 92px 62px auto;gap:10px;align-items:center;border:1px solid #26374f;border-radius:8px;padding:9px 10px;background:#0b1220}.recovery-row small{color:#93a4ba}.recovery-row strong{text-align:right}.public-rooms{display:grid;gap:10px}.lobby-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.public-rooms h3,.join-room-panel h3{margin:0;font-size:15px;color:#c7d2e3}.room-row{display:grid;grid-template-columns:112px 1fr 72px 72px auto;gap:10px;align-items:center;border:1px solid #33445f;border-radius:8px;background:#0b1220;color:#e5edf7;padding:10px 12px}.room-row span{font-weight:700;letter-spacing:.08em}.room-row small{color:#93a4ba}.debug-tools>button{margin-top:14px}.join-room-panel .join-form{margin-top:12px}.join-form{display:grid;grid-template-columns:1fr 120px auto;gap:10px;margin-top:22px}.join-form:has(input+button){grid-template-columns:1fr auto}.join-form input,.join-form select{min-width:0;border:1px solid #33445f;border-radius:8px;background:#0b1220;color:#e5edf7;padding:10px 12px;font:inherit}@media(max-width:720px){.app-shell{padding:14px max(12px,env(safe-area-inset-right)) calc(14px + env(safe-area-inset-bottom)) max(12px,env(safe-area-inset-left))}.topbar{margin-bottom:14px}.topbar h1{font-size:24px}.topbar p{font-size:13px}.home-lobby{margin-top:20px}.quick-match-actions,.quick-match-config-controls,.join-form,.join-form:has(input+button),.room-config label,.settings-grid,.open-colors{grid-template-columns:1fr}.lobby-panel-header{align-items:stretch;flex-direction:column}.home-primary,.lobby-panel,.empty-state,.room-lobby{padding:16px}.empty-state{margin-top:28px}.primary-button,.secondary-button,.danger-button,.join-form input,.join-form select,.room-config select,.quick-match-config-controls select,.seat-mode-select{min-height:44px}.recovery-row,.room-row{grid-template-columns:1fr auto}.recovery-row>:not(:first-child):not(:last-child),.room-row>:not(:first-child):not(:last-child){grid-column:1}.recovery-row>:last-child,.room-row>:last-child{grid-column:2;grid-row:1 / span 4;align-self:stretch}.room-lobby-header,.room-actions,.setting-row{align-items:stretch;flex-direction:column}.seat-row{grid-template-columns:1fr auto;gap:10px}.seat-actions{grid-column:1 / -1;grid-template-columns:minmax(0,1fr) minmax(0,1.5fr)}.room-actions .danger-button{width:100%}}@media(max-width:720px)and (orientation:portrait){.game-layout{display:flex;flex-direction:column;gap:12px;width:100%}.mobile-game-history{display:grid;grid-template-columns:44px minmax(0,1fr) 44px;gap:8px;align-items:stretch;order:1;border:1px solid #1d2c42;border-radius:8px;background:#0d1420f0;padding:8px}.mobile-history-button{min-width:44px;min-height:52px;padding:0;font-size:28px;line-height:1}.mobile-history-current{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:5px;min-width:0;overflow:hidden;border-radius:6px;background:#0b1220;padding:7px 5px;color:#c7d2e3;font-size:12px;text-align:center}.mobile-history-current .history-move{gap:4px;font-size:12px}.mobile-history-current .history-piece{width:18px;height:18px}.mobile-history-live{flex-basis:100%;border:0;background:transparent;padding:2px;color:#93c5fd;font-size:11px;cursor:pointer}.board-stage{order:2;display:flex;flex-direction:column;gap:8px;padding:0}.board{order:1;width:100%;height:auto}.player-panel-layer{position:static;order:2;display:grid;gap:7px;pointer-events:none}.player-panel-group{position:static;grid-template-columns:minmax(0,1fr) auto minmax(80px,1fr);width:100%;min-width:0;max-width:none;min-height:48px;padding:7px 9px;transform:none}.player-panel-group strong{font-size:16px}.player-panel-captures{justify-self:end;max-width:120px}.capture-strip{justify-content:flex-end}.replay-banner{display:none}.hud{order:3;height:auto;overflow:visible;padding:14px}.hud-history{display:none}.hud section+section{margin-top:14px}.hud-status{grid-template-columns:1fr 1fr;align-items:end}.hud-status-top,.hud-move-number{grid-column:1 / -1}.hud-current-turn{font-size:24px}}
