*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a14;--panel:#14141f;--panel2:#1d1d2c;--border:#2a2a3a;--accent:#8b6cd6;--accent-h:#a288e3;--accent-glow:#8b6cd659;--text:#c5c5d6;--text-dim:#6c6c80;--text-h:#f0f0f8;--card-super:#fbbf24;--card-ghost:#c9a3ff;--card-freeze:#6dd9ff;--card-double:#5dd29f;--win:#4ade80;--loss:#f87171;--draw:#c9a227;--green:var(--win);--green-h:#6ee896;--danger:var(--loss);--gold:var(--card-super);--violet:var(--accent);--violet-dim:var(--accent-glow);--font-heading:"Antonio", "Inter", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--noise-opacity:.03;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000080, 0 2px 6px #0000004d;--shadow-lg:0 12px 48px #000000b3, 0 4px 16px #0006}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-size:14px;line-height:1.5}.panel-noise{isolation:isolate;position:relative}.panel-noise:before{content:"";opacity:var(--noise-opacity);border-radius:inherit;pointer-events:none;z-index:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");position:absolute;inset:0}.panel-noise>*{z-index:1;position:relative}.app{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}@supports (height:100dvh){.app{min-height:100dvh}}@media (width<=767px){.app{align-items:flex-start;padding:0}}@keyframes rise-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.rise{animation:.4s ease-out both rise-in}.rise-1{animation-delay:50ms}.rise-2{animation-delay:.12s}.rise-3{animation-delay:.19s}.rise-4{animation-delay:.26s}@keyframes card-pulse{0%,to{opacity:1}50%{opacity:.55}}@keyframes check-pulse{0%,to{box-shadow:inset 0 0 0 2px #f87171d9,inset 0 0 18px #f8717180}50%{box-shadow:inset 0 0 0 2px #f87171,inset 0 0 28px #f87171cc}}@media (prefers-reduced-motion:reduce){@keyframes check-pulse{0%,to{}}}.theme-picker{z-index:200;align-items:center;gap:6px;display:flex;position:fixed;top:12px;right:14px}.theme-tile{background:var(--panel);border:1.5px solid var(--border);cursor:pointer;font-family:var(--font-body);color:var(--text-dim);letter-spacing:.04em;touch-action:manipulation;border-radius:8px;align-items:center;gap:8px;min-height:44px;padding:7px 11px 7px 8px;font-size:11px;font-weight:600;transition:border-color .18s ease-out,color .18s ease-out,box-shadow .18s ease-out;display:flex}.theme-tile:hover{border-color:var(--swatch-color);color:var(--text-h)}.theme-tile.active{border-color:var(--swatch-color);color:var(--text-h);box-shadow:0 0 10px color-mix(in srgb, var(--swatch-color) 45%, transparent)}.theme-tile-board{border-radius:3px;flex-shrink:0;grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;width:22px;height:22px;display:grid;overflow:hidden;box-shadow:0 0 0 1px #ffffff14}.theme-tile-board span{display:block}.theme-tile-name{white-space:nowrap}.fop{background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-top-color:#ffffff12;position:relative}.modal-overlay{z-index:100;background-color:#000000d1;background-image:linear-gradient(#000000d1,#000000d1),repeating-conic-gradient(#ffffff04 0% 25%,#0000 0% 50%);background-position:0 0;background-repeat:repeat;background-size:cover,48px 48px;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--panel);border:1px solid var(--border);text-align:center;width:440px;max-width:95vw;box-shadow:var(--shadow-lg);border-top-color:#ffffff17;border-radius:10px;padding:44px 40px;animation:.35s ease-out both rise-in}@media (width<=767px){.modal{padding:32px 22px}}.modal-logo{margin-bottom:10px;font-size:52px;line-height:1}.modal-title{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.03em;margin-bottom:4px;font-size:26px;font-weight:800}.modal-subtitle{color:var(--text-dim);margin-bottom:32px;font-size:13px}.field-group{text-align:left;border:none;margin-bottom:22px}.field-group legend{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);width:100%;margin-bottom:10px;font-size:10px;font-weight:600}.level-buttons,.color-buttons{flex-wrap:wrap;gap:6px;display:flex}.radio-card{cursor:pointer;flex:auto}.radio-card input[type=radio]{display:none}.radio-card span{background:var(--panel2);border:1px solid var(--border);text-align:center;font-size:13px;font-family:var(--font-body);color:var(--text);white-space:nowrap;border-top-color:#ffffff0d;border-radius:6px;padding:9px 10px;transition:border-color .18s ease-out,color .18s ease-out,background .18s ease-out;display:block}.radio-card input:checked+span{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);border-color:var(--accent);color:#fff;box-shadow:0 0 10px color-mix(in srgb, var(--accent) 40%, transparent);font-weight:700}.radio-card:hover span{border-color:var(--accent);color:var(--text-h)}.btn-primary{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#fff;font-size:14px;font-weight:700;font-family:var(--font-body);cursor:pointer;letter-spacing:.02em;border:none;border-radius:6px;padding:10px 20px;transition:box-shadow .18s ease-out,filter .18s ease-out}.btn-primary:hover{box-shadow:0 0 14px color-mix(in srgb, var(--accent) 55%, transparent);filter:brightness(1.1)}.btn-large{width:100%;margin-top:8px;padding:14px;font-size:15px}.btn-control{background:var(--panel2);color:var(--text);border:1px solid var(--border);font-size:13px;font-family:var(--font-body);cursor:pointer;text-align:center;white-space:nowrap;border-top-color:#ffffff0d;border-radius:6px;flex:1;padding:8px 12px;transition:border-color .18s ease-out,color .18s ease-out,box-shadow .18s ease-out}.home-header .btn-control{flex:none}.btn-control:hover:not(:disabled){border-color:var(--accent);color:var(--text-h);box-shadow:0 0 8px color-mix(in srgb, var(--accent) 25%, transparent)}.btn-control:disabled{opacity:.35;cursor:not-allowed}.btn-control.btn-primary{color:#fff}.btn-back{color:var(--text-dim);font-size:13px;font-family:var(--font-body);cursor:pointer;background:0 0;border:none;margin-top:14px;padding:4px 8px;transition:color .18s ease-out;display:block}.btn-back:hover{color:var(--text)}.btn-logout{border:1px solid var(--border);font-size:12px;font-family:var(--font-body);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;transition:color .18s ease-out,border-color .18s ease-out}.btn-logout:hover{color:var(--danger);border-color:var(--danger)}.btn-mygames{border:1px solid var(--border);font-size:12px;font-family:var(--font-body);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;transition:all .18s ease-out}.btn-mygames:hover{color:var(--accent-h);border-color:var(--accent);box-shadow:0 0 8px color-mix(in srgb, var(--accent) 25%, transparent)}.auth-btn-primary{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#fff;font-size:14px;font-weight:600;font-family:var(--font-body);cursor:pointer;letter-spacing:.01em;border:none;border-radius:6px;margin-top:4px;padding:12px;transition:box-shadow .18s ease-out,filter .18s ease-out}.auth-btn-primary:hover:not(:disabled){box-shadow:0 0 18px color-mix(in srgb, var(--accent) 45%, transparent);filter:brightness(1.08)}.auth-btn-primary:disabled{opacity:.45;cursor:not-allowed}.game-layout{align-items:flex-start;gap:16px;width:100%;max-width:1040px;animation:.4s ease-out both rise-in;display:flex}.board-section{flex-direction:column;flex:none;gap:0;display:flex}.board-wrapper{width:min(600px,100vw - 376px)}.game-stacked{flex-direction:column;align-items:stretch;gap:0;max-width:640px;margin:0 auto;animation:none}.game-stacked .board-section{width:100%}.game-stacked .board-wrapper{width:100%;max-width:100%;margin:0 auto}.mp-strip{background:var(--panel);flex-shrink:0;align-items:center;gap:10px;min-height:52px;padding:8px 14px;transition:background .3s,box-shadow .3s;display:flex}.mp-strip-opp{border-bottom:1px solid var(--border)}.mp-strip-me{border-top:1px solid var(--border)}.mp-strip-active{background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 12%, var(--panel)) 0%, var(--panel) 80%);box-shadow:inset 0 0 0 1px var(--accent-glow)}.mp-cards-strip{background:var(--panel2);border-top:1px solid var(--border);flex-shrink:0;overflow:hidden}.mp-cards-strip .cards-body{gap:6px;padding:10px 12px}.mp-cards-strip .cards-row{gap:0}.mp-cards-strip .cards-label{display:none}.mp-cards-strip .card-slots{flex:1;gap:6px;min-width:0}.mp-cards-strip .card-wrapper{aspect-ratio:58/86;flex:1 1 0;width:auto;min-width:0;max-width:64px;height:auto}.mp-cards-strip .card{width:100%;height:100%}.strip-menu-btn{border:1px solid var(--border);width:38px;height:38px;color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;margin-left:auto;font-size:20px;line-height:1;transition:border-color .18s,color .18s,background .18s}.strip-menu-btn:hover{border-color:var(--accent);color:var(--accent-h);background:color-mix(in srgb, var(--accent) 10%, transparent)}.mp-strip .strip-settings-btn{margin-left:auto;flex:none!important}.game-over-bar{background:var(--panel);border-top:1px solid var(--border);align-items:center;gap:16px;padding:14px 18px;animation:.32s ease-out both rise-in;display:flex}.game-over-bar.game-over-win{box-shadow:inset 0 1px 0 color-mix(in srgb, var(--win) 40%, transparent)}.game-over-bar.game-over-loss{box-shadow:inset 0 1px 0 color-mix(in srgb, var(--loss) 40%, transparent)}.game-over-bar.game-over-draw{box-shadow:inset 0 1px 0 color-mix(in srgb, var(--draw) 40%, transparent)}.game-over-label{font-family:var(--font-heading);letter-spacing:.18em;text-transform:uppercase;flex:1;font-size:22px;font-weight:700}.game-over-win .game-over-label{color:var(--win)}.game-over-loss .game-over-label{color:var(--loss)}.game-over-draw .game-over-label{color:var(--draw)}.game-over-cta{flex:none!important;width:auto!important;min-width:0!important;margin-top:0!important;padding:10px 22px!important;font-size:14px!important}.drawer-overlay{z-index:200;opacity:0;pointer-events:none;background:#05050c99;justify-content:center;align-items:flex-end;transition:opacity .25s;display:flex;position:fixed;inset:0}.drawer-overlay.drawer-open{opacity:1;pointer-events:auto}.drawer-panel{background:var(--panel);border:1px solid var(--border);border-top-color:var(--accent);border-radius:14px 14px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:80vh;transition:transform .3s;display:flex;transform:translateY(100%);box-shadow:0 -18px 48px #0000008c}.drawer-overlay.drawer-open .drawer-panel{transform:translateY(0)}.drawer-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.drawer-title{font-family:var(--font-heading);letter-spacing:.2em;text-transform:uppercase;color:var(--text-h);font-size:13px;font-weight:700}.drawer-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:28px;line-height:1;transition:color .18s}.drawer-close:hover{color:var(--text-h)}.drawer-moves{flex:1 1 0;min-height:0;padding:4px 0;overflow-y:auto}.drawer-moves .move-history{display:block;overflow:visible}.drawer-moves .move-history-body{flex:none;max-height:none}.drawer-actions{border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:12px 18px 18px;display:flex}.drawer-actions .btn-control{flex:1}.mobile-opp-bar,.mobile-bottom-panel,.mobile-me-bar{display:none}@media (width<=767px){.app{align-items:stretch;padding:0}.game-layout{flex-direction:column;align-items:stretch;gap:0;width:100%;max-width:100vw;animation:none}.sidebar{display:none!important}.mobile-opp-bar{background:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;order:1;align-items:center;gap:10px;min-height:52px;padding:8px 14px;display:flex}.board-section{order:2;width:100%}.board-wrapper{width:100%}.board-wrapper-inner,.status-bar{border-left:none;border-right:none;border-radius:0}.mobile-bottom-panel{background:var(--panel2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;flex-shrink:0;order:3;display:flex}.mobile-tab-bar{background:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.mobile-tab-btn{cursor:pointer;color:var(--text-dim);font-family:var(--font-body);touch-action:manipulation;background:0 0;border:none;border-bottom:2px solid #0000;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:8px 0;transition:color .15s,border-color .15s;display:flex;position:relative}.mobile-tab-btn.mtab-active{color:var(--accent);border-bottom-color:var(--accent)}.mtab-icon{font-size:17px;line-height:1}.mtab-label{letter-spacing:.07em;text-transform:uppercase;font-size:9px;font-weight:600}.mtab-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;position:absolute;top:6px;right:calc(50% - 14px)}.mobile-tab-content{min-height:100px;max-height:200px;overflow-y:auto}.mobile-tab-content .cards-body{padding:10px 12px}.mobile-tab-content .move-history{flex:none;display:block;overflow:visible}.mobile-tab-content .move-history-body{flex:none;max-height:200px}.mobile-controls-tab{padding:8px 12px}.mobile-controls-tab .game-controls{flex-wrap:wrap;padding:0}.mobile-me-bar{background:var(--panel);border-top:1px solid var(--border);flex-shrink:0;order:4;align-items:center;gap:10px;min-height:52px;padding:8px 14px;display:flex}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:18px 18px 0 0;width:100%;max-width:100%;max-height:92vh;padding:28px 20px 32px;overflow-y:auto}.modal-logo{font-size:28px}.level-buttons,.color-buttons{gap:6px}.radio-card span{padding:7px 10px;font-size:12px}.mode-tabs{gap:0}.mode-tab{padding:9px 14px;font-size:13px}.mobile-tab-content .card-wrapper,.mobile-tab-content .card{width:48px;height:67px}.mobile-tab-content .card-symbol{font-size:16px}.mobile-tab-content .card-label{font-size:8px}.mobile-tab-content .cards-label{width:44px;font-size:9px}.mobile-tab-content .card-slots{gap:5px}.mobile-tab-content .draw-prompt{padding:6px 12px;font-size:12px}.theme-picker{gap:5px;top:10px;right:12px}.theme-tile{justify-content:center;gap:0;min-width:44px;min-height:44px;padding:9px}.theme-tile-board{width:26px;height:26px}.theme-tile-name{display:none}.board-wrapper{touch-action:none}.superhorse-info,.ghostbishop-info,.freeze-info{border-left:none;border-right:none;border-radius:0;margin:0;padding:7px 12px;font-size:12px}}.status-bar{background:var(--panel);border:2px solid color-mix(in srgb, var(--accent) 45%, var(--border));border-top:none;border-radius:0 0 6px 6px;justify-content:space-between;align-items:center;padding:6px 14px;display:flex}.status-level{color:var(--text-dim);font-size:11px;font-style:italic}.status-text{color:var(--text-h);font-size:13px;font-weight:600}.status-text.thinking,.status-text.notification{color:var(--gold)}.board-wrapper-inner{border:2px solid color-mix(in srgb, var(--accent) 45%, var(--border));border-bottom:none;border-radius:6px 6px 0 0;overflow:hidden}.sidebar{border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow-sm);border-top-color:#ffffff12;border-radius:10px;flex-direction:column;flex:0 0 360px;align-self:stretch;gap:0;display:flex;overflow:hidden}.sidebar-divider{background:var(--border);flex-shrink:0;height:1px}.sidebar-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-h);border-left:3px solid var(--accent);background:linear-gradient(90deg, color-mix(in srgb, var(--accent) 12%, var(--panel)) 0%, var(--panel) 70%);flex-shrink:0;justify-content:space-between;align-items:center;padding:5px 14px 5px 11px;font-size:10px;font-weight:700;display:flex}.player-card{flex-shrink:0;align-items:center;gap:10px;padding:12px 14px;display:flex}.player-avatar{background:var(--panel2);border:1px solid var(--border);width:32px;height:32px;font-family:var(--font-heading);color:var(--accent);letter-spacing:0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.player-info{flex:1;min-width:0}.player-name{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.04em;white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:600;overflow:hidden}.player-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;font-size:10px}.player-timer{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:13px;font-family:var(--font-body);flex-shrink:0}.player-timer.warn{color:#e05555;font-weight:600}.player-captured{flex-wrap:wrap;align-items:center;gap:1px;margin-top:2px;display:flex}.player-captured-piece{font-size:13px;line-height:1}.player-score{color:var(--gold);margin-left:3px;font-size:10px;font-weight:700}.captured-panel{flex-shrink:0;padding:8px 14px}.captured-row{align-items:center;gap:8px;min-height:22px;display:flex}.captured-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);flex-shrink:0;width:52px;font-size:10px;font-weight:600}.captured-pieces{flex-wrap:wrap;align-items:center;gap:1px;display:flex}.captured-piece{font-size:14px;line-height:1}.score-diff{color:var(--gold);margin-left:4px;font-size:11px;font-weight:700}.captured-divider{background:var(--border);height:1px;margin:3px 0}.move-history{flex-direction:column;flex:1 1 0;min-height:0;display:flex;overflow:hidden}.move-history-body{flex:1 1 0;max-height:360px;padding:4px 0;overflow-y:auto}@media (width<=767px){.move-history-body{max-height:140px}}.move-row{align-items:center;gap:4px;padding:3px 14px;display:flex}.move-row:nth-child(2n){background:#ffffff05}.move-num{color:var(--text-dim);flex-shrink:0;width:22px;font-size:11px}.move-san{color:var(--text-h);cursor:pointer;border-radius:4px;flex:1;padding:1px 4px;font-family:Courier New,monospace;font-size:13px;transition:background .15s}.move-san:hover{background:var(--panel2)}.move-san.move-active{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#000}.move-black{color:var(--text)}.live-btn{border:1px solid var(--accent);color:var(--accent);cursor:pointer;font-size:10px;font-family:var(--font-body);background:0 0;border-radius:10px;padding:2px 8px;font-weight:600;transition:background .18s ease-out,color .18s ease-out}.live-btn:hover{background:var(--accent);color:#000}.no-moves{color:var(--text-dim);text-align:center;padding:14px;font-size:12px;font-style:italic}.move-history-body::-webkit-scrollbar{width:4px}.move-history-body::-webkit-scrollbar-track{background:0 0}.move-history-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.game-controls{flex-direction:row;flex-shrink:0;gap:6px;padding:10px 12px;display:flex}@media (width<=767px){.btn-control{padding:10px 6px;font-size:12px}}.cards-body{flex-direction:column;gap:8px;padding:10px 14px 14px;display:flex}.cards-row{align-items:center;gap:10px;display:flex}.cards-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);flex-shrink:0;width:52px;font-size:10px;font-weight:600}.card-slots{gap:8px;display:flex}.card-wrapper{perspective:600px;z-index:0;transform-origin:50%;width:58px;height:86px;transition:transform .22s cubic-bezier(.18,.89,.32,1.28)}.card-wrapper-active{z-index:10;transform:scale(1.18)translateY(-6px)}.card{width:58px;height:86px;transform-style:preserve-3d;cursor:default;transition:transform .28s cubic-bezier(.34,.78,.4,1.12);position:relative}.card.revealed{transform:rotateY(180deg)}.card.drawable{cursor:pointer;animation:1.1s ease-in-out infinite card-pulse}.card-back,.card-front{backface-visibility:hidden;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;inset:0;overflow:hidden}.card-back{border:1px solid color-mix(in srgb, var(--accent) 22%, var(--border));background:url(/card-background.png) 50%/cover no-repeat,linear-gradient(160deg,#14141f 0%,#06060c 100%);border-top-color:#ffffff14;box-shadow:inset 0 1px #ffffff0d,inset 0 -18px 28px #0006}.card-back-mark{display:none}.card-front{background:radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--card-color,var(--text-dim)) 22%, transparent) 0%, transparent 60%), linear-gradient(180deg, var(--panel2) 0%, var(--panel) 100%);border:1px solid color-mix(in srgb, var(--card-color,var(--text-dim)) 50%, var(--border));border-top-color:color-mix(in srgb, var(--card-color,var(--text-dim)) 65%, var(--border));transform:rotateY(180deg);box-shadow:inset 0 1px #ffffff0a,inset 0 -22px 28px #00000059}.card-blank .card-front{border-color:var(--border);border-top-color:#ffffff0f;box-shadow:inset 0 1px #ffffff08}.card.card-has-art .card-front{background:linear-gradient(180deg, transparent 60%, #000000c7 100%), var(--card-art) center/cover no-repeat, linear-gradient(180deg, var(--panel2) 0%, var(--panel) 100%);justify-content:flex-end;padding-bottom:4px}.card.card-has-art .card-label{z-index:2;color:#fff;text-shadow:0 1px 2px #000000b3;position:relative}.card-symbol{color:var(--card-color,var(--text-dim));filter:drop-shadow(0 0 6px color-mix(in srgb, var(--card-color,transparent) 55%, transparent));font-size:26px;line-height:1}.card-blank .card-symbol{filter:none}.card-label{font-family:var(--font-heading);letter-spacing:.12em;text-transform:uppercase;color:var(--text-h);text-align:center;padding:0 4px;font-size:8px;font-weight:700;line-height:1}.card-blank .card-label{color:var(--text-dim)}.card-doublemove{letter-spacing:-3px;font-weight:700}.card-ghost,.card-doublemove{font-size:22px}.card-blank-text{font-size:28px}.draw-prompt{letter-spacing:.06em;color:var(--accent-h);text-align:center;font-size:12px;font-weight:600;animation:1.1s ease-in-out infinite card-pulse}.draw-prompt.dim{color:var(--text-dim);font-style:italic;font-weight:400;animation:none}.card.card-active .card-front{border-color:var(--accent);box-shadow:inset 0 1px 0 #ffffff0f, 0 0 22px color-mix(in srgb, var(--accent) 75%, transparent), 0 0 6px var(--accent-glow)}.card.card-spent .card-front{filter:grayscale(.6)brightness(.7)}.card-tappable{cursor:pointer}.rules-overlay{z-index:220;background:#05050cb3;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out both rules-overlay-in;display:flex;position:fixed;inset:0}@keyframes rules-overlay-in{0%{opacity:0}to{opacity:1}}.rules-popover{background:radial-gradient(130% 80% at 50% 0%, color-mix(in srgb, var(--card-color) 22%, transparent) 0%, transparent 60%), linear-gradient(180deg, var(--panel2) 0%, var(--panel) 100%);border:1px solid color-mix(in srgb, var(--card-color) 55%, var(--border));border-top-color:color-mix(in srgb, var(--card-color) 70%, var(--border));text-align:center;width:100%;max-width:360px;box-shadow:0 24px 60px #000000a6, 0 0 32px color-mix(in srgb, var(--card-color) 35%, transparent);border-radius:14px;padding:28px 22px 22px;animation:.28s cubic-bezier(.34,.78,.4,1.12) both rules-pop-in;position:relative}@keyframes rules-pop-in{0%{opacity:0;transform:translateY(12px)scale(.94)}to{opacity:1;transform:translateY(0)scale(1)}}.rules-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:24px;line-height:1;transition:color .18s;position:absolute;top:8px;right:12px}.rules-close:hover{color:var(--text-h)}.rules-symbol{filter:drop-shadow(0 0 12px color-mix(in srgb, var(--card-color) 55%, transparent));margin-bottom:10px;font-size:52px;line-height:1}.rules-name{font-family:var(--font-heading);letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px;font-size:22px;font-weight:700}.rules-desc{color:var(--text-h);margin-bottom:12px;font-size:14px;line-height:1.5}.rules-example{color:var(--text-dim);font-size:13px;font-style:italic;line-height:1.5}.settings-overlay{z-index:240;background:#05050cb3;justify-content:center;align-items:center;padding:24px;animation:.2s ease-out both rules-overlay-in;display:flex;position:fixed;inset:0}.settings-panel{background:var(--panel);border:1px solid var(--border);border-top-color:#ffffff0f;border-radius:14px;flex-direction:column;width:100%;max-width:480px;max-height:86vh;animation:.28s cubic-bezier(.34,.78,.4,1.12) both rules-pop-in;display:flex;overflow-y:auto;box-shadow:0 24px 60px #000000a6}.settings-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px 14px;display:flex}.settings-title{font-family:var(--font-heading);letter-spacing:.2em;text-transform:uppercase;color:var(--text-h);font-size:16px;font-weight:700}.settings-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:28px;line-height:1;transition:color .18s}.settings-close:hover{color:var(--text-h)}.settings-section{border-bottom:1px solid var(--border);padding:18px 22px}.settings-section:last-child{border-bottom:none}.settings-section-title{font-family:var(--font-heading);letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);margin-bottom:12px;font-size:11px;font-weight:700}.settings-toggle{color:var(--text-h);cursor:pointer;align-items:center;gap:10px;font-size:14px;display:flex}.settings-toggle input{width:16px;height:16px;accent-color:var(--accent)}.settings-radio-group{flex-wrap:wrap;gap:14px;margin-bottom:8px;display:flex}.settings-radio{color:var(--text);cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.settings-radio input{accent-color:var(--accent)}.settings-hint{color:var(--text-dim);margin-top:8px;font-size:12px;line-height:1.5}.settings-theme-picker .theme-picker{flex-flow:wrap;gap:6px;display:flex;position:static}.settings-theme-picker .theme-tile{border-width:1px;gap:0;min-width:32px;min-height:32px;padding:5px}.settings-theme-picker .theme-tile-board{width:22px;height:22px}.settings-theme-picker .theme-tile-name{display:none}.site-theme-swatch{border-radius:3px;flex-shrink:0;width:22px;height:22px;display:flex;overflow:hidden;box-shadow:0 0 0 1px #ffffff14}.site-theme-swatch span{flex:1;height:100%;display:block}.btn-icon{width:36px;font-size:16px;flex:none!important;padding:8px 0!important}.game-end-overlay{z-index:260;background:#05050cc7;justify-content:center;align-items:center;padding:24px;animation:.25s ease-out both rules-overlay-in;display:flex;position:fixed;inset:0;overflow-y:auto}.game-end-modal{background:var(--panel);border:1px solid var(--border);text-align:center;width:100%;max-width:560px;box-shadow:0 28px 70px #000000b3, 0 0 36px var(--accent-glow);border-top-color:#ffffff0f;border-radius:16px;flex-direction:column;gap:16px;padding:32px 28px 24px;animation:.32s cubic-bezier(.34,.78,.4,1.12) both rules-pop-in;display:flex;position:relative}.game-end-victory{box-shadow:0 28px 70px #000000b3, 0 0 36px color-mix(in srgb, var(--win) 40%, transparent);border-color:color-mix(in srgb, var(--win) 35%, var(--border))}.game-end-defeat{box-shadow:0 28px 70px #000000b3, 0 0 36px color-mix(in srgb, var(--loss) 35%, transparent);border-color:color-mix(in srgb, var(--loss) 30%, var(--border))}.game-end-draw{box-shadow:0 28px 70px #000000b3, 0 0 36px color-mix(in srgb, var(--draw) 35%, transparent);border-color:color-mix(in srgb, var(--draw) 30%, var(--border))}.game-end-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:28px;line-height:1;position:absolute;top:10px;right:14px}.game-end-close:hover{color:var(--text-h)}.game-end-result{font-family:var(--font-heading);letter-spacing:.16em;text-transform:uppercase;font-size:44px;font-weight:700;line-height:1}.game-end-players{color:var(--text);letter-spacing:.04em;font-size:14px}.game-end-vs{color:var(--text-dim);text-transform:uppercase;letter-spacing:.18em;margin:0 6px;font-size:11px}.game-end-canvas-wrap{border:1px solid var(--border);border-radius:10px;width:100%;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff08}.game-end-canvas{width:100%;height:auto;display:block}.game-end-actions{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.game-end-actions>*{flex:1}html.force-reduced-motion .card,html.force-reduced-motion .card-wrapper,html.force-reduced-motion .fracture-overlay path,html.force-reduced-motion .card.drawable,html.force-reduced-motion .showcase-card,html.force-reduced-motion .home-page,html.force-reduced-motion .auth-container,html.force-reduced-motion .rules-popover,html.force-reduced-motion .settings-panel{transition:none!important;animation:none!important}.fracture-overlay{pointer-events:none;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.fracture-overlay path{stroke:var(--card-color,var(--accent));stroke-width:1.1px;stroke-linecap:round;stroke-linejoin:round;fill:none;stroke-dasharray:1;stroke-dashoffset:1px;filter:drop-shadow(0 0 2px color-mix(in srgb, var(--card-color,var(--accent)) 80%, transparent));transition:stroke-dashoffset .35s cubic-bezier(.4,0,.2,1)}.card.card-active .fracture-overlay path{stroke-dashoffset:0}.card.card-active .fracture-overlay path:nth-child(2){transition-delay:40ms}.card.card-active .fracture-overlay path:nth-child(3){transition-delay:80ms}.card.card-active .fracture-overlay path:nth-child(4){transition-delay:60ms}.card.card-active .fracture-overlay path:nth-child(5){transition-delay:.1s}.card.card-active .fracture-overlay path:nth-child(6){transition-delay:.12s}@media (prefers-reduced-motion:reduce){.card,.card-wrapper,.fracture-overlay path,.card.drawable{transition:none!important;animation:none!important}}.mp-player-bar{background:var(--panel);border:1px solid var(--border);border-top-color:#ffffff0f;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 14px;display:flex}.mp-player-bar-me{border-color:color-mix(in srgb, var(--accent) 40%, var(--border));margin-top:4px;margin-bottom:0}.mp-name{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.04em;font-size:13px;font-weight:600}.mp-timer{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:12px}.mp-timer.mp-timer-warn{color:#e05555;font-weight:600}.game-result-banner{text-align:center;font-family:var(--font-heading);letter-spacing:.08em;text-transform:uppercase;border-radius:6px;padding:12px 20px;font-size:18px;font-weight:800;animation:.4s ease-out both rise-in}.game-result-banner.win{color:#7ddc9c;background:#122410fa;border:1px solid #4caf76;box-shadow:0 0 28px #4caf764d,inset 0 0 20px #4caf760f}.game-result-banner.loss{color:#e07070;background:#1e0a0afa;border:1px solid #b83232;box-shadow:0 0 28px #b8323240,inset 0 0 20px #b832320f}.game-result-banner.draw{border:1px solid var(--accent);color:var(--accent-h);box-shadow:0 0 22px color-mix(in srgb, var(--accent) 30%, transparent), inset 0 0 14px color-mix(in srgb, var(--accent) 8%, transparent);background:#0e1018fa}.auth-loading{color:var(--text-dim);font-size:15px}.auth-container{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:100vh;padding:24px 16px;animation:.4s ease-out both rise-in;display:flex}.auth-header{flex-direction:column;align-items:center;gap:8px;margin-bottom:36px;display:flex}.auth-tagline{letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim);font-size:13px;font-weight:500}.hero-banner{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;max-width:480px;height:auto;display:block}.hero-banner-sm{max-width:280px}.auth-layout{grid-template-columns:minmax(280px,1fr) auto;align-items:center;gap:56px;width:100%;max-width:880px;display:grid}.auth-title{font-family:var(--font-heading);color:var(--text-h);letter-spacing:.06em;margin-bottom:28px;font-size:36px;font-weight:700}.auth-showcase{flex-direction:column;align-items:center;gap:28px;display:flex}.showcase-stage{width:200px;height:296px;position:relative}.showcase-card{background:radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--card-color) 24%, transparent) 0%, transparent 60%), linear-gradient(180deg, var(--panel2) 0%, var(--panel) 100%);border:1px solid color-mix(in srgb, var(--card-color) 45%, var(--border));border-top-color:color-mix(in srgb, var(--card-color) 55%, var(--border));opacity:0;pointer-events:none;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:18px;transition:opacity .7s,transform .7s;display:flex;position:absolute;inset:0;transform:scale(.94)translateY(10px);box-shadow:0 18px 42px #0000008c,inset 0 1px #ffffff0a}.showcase-card-active{opacity:1;box-shadow:0 18px 42px #0000008c, 0 0 36px color-mix(in srgb, var(--card-color) 35%, transparent), inset 0 1px 0 #ffffff0f;transform:scale(1)translateY(0)}.showcase-symbol{color:var(--card-color);filter:drop-shadow(0 0 12px color-mix(in srgb, var(--card-color) 50%, transparent));font-size:76px;line-height:1}.showcase-name{font-family:var(--font-heading);letter-spacing:.12em;text-transform:uppercase;color:var(--text-h);font-size:18px;font-weight:700}.showcase-caption{text-align:center;flex-direction:column;align-items:center;gap:6px;min-height:52px;display:flex}.showcase-caption-name{font-family:var(--font-heading);letter-spacing:.14em;text-transform:uppercase;font-size:15px;font-weight:700}.showcase-caption-desc{color:var(--text);max-width:280px;font-size:14px;line-height:1.4}.auth-subtitle{color:var(--text-h);text-align:center;margin-bottom:6px;font-size:18px;font-weight:600}.auth-hint{color:var(--text-dim);text-align:center;margin-bottom:20px;font-size:13px}.auth-card{background:var(--panel);border:1px solid var(--border);width:380px;max-width:95vw;box-shadow:var(--shadow-lg);border-top-color:#ffffff17;border-radius:10px;padding:36px 32px}.auth-tabs{border-bottom:1px solid var(--border);margin-bottom:24px;display:flex}.auth-tab{font-size:14px;font-weight:600;font-family:var(--font-body);color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:10px;transition:color .18s ease-out,border-color .18s ease-out}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-tab:hover:not(.active){color:var(--text-h)}.auth-form{flex-direction:column;gap:12px;display:flex}.auth-input{background:var(--panel2);border:1px solid var(--border);font-size:14px;font-family:var(--font-body);color:var(--text-h);border-radius:6px;width:100%;padding:11px 14px;transition:border-color .18s ease-out,box-shadow .18s ease-out}.auth-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);outline:none}.auth-input::placeholder{color:var(--text-dim)}.auth-error{color:var(--danger);font-size:13px}.auth-message{color:var(--green-h);font-size:13px}.auth-divider{text-align:center;color:var(--text-dim);margin:16px 0;font-size:12px;position:relative}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);width:40%;height:1px;position:absolute;top:50%}.auth-divider:before{left:0}.auth-divider:after{right:0}.auth-btn-google{background:var(--panel2);border:1px solid var(--border);width:100%;font-size:14px;font-weight:600;font-family:var(--font-body);color:var(--text-h);cursor:pointer;border-top-color:#ffffff0f;border-radius:6px;padding:10px;transition:border-color .18s ease-out,color .18s ease-out}.auth-btn-google:hover{border-color:var(--accent);color:var(--accent-h)}.home-page{flex-direction:column;align-self:flex-start;gap:36px;width:100%;max-width:960px;padding:28px 24px 48px;animation:.4s ease-out both rise-in;display:flex}.home-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;padding-bottom:18px;display:flex}.home-header-left{flex-direction:column;gap:6px;display:flex}.home-tagline{letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim);font-size:12px;font-weight:500}.home-header-right{align-items:center;gap:10px;display:flex}.home-username{color:var(--text-dim);margin-right:6px;font-size:13px}.btn-control-quiet{color:var(--text-dim)!important;border-color:#0000!important}.btn-control-quiet:hover{color:var(--text-h)!important;border-color:var(--border)!important}.section-title{font-family:var(--font-heading);letter-spacing:.18em;text-transform:uppercase;color:var(--text-h);margin-bottom:14px;font-size:13px;font-weight:700}.section-title-dim{color:var(--text-dim)}.active-games-section{flex-direction:column;gap:24px;display:flex}.active-games-strip{scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;gap:12px;padding-bottom:4px;display:flex;overflow-x:auto}.active-games-strip::-webkit-scrollbar{height:6px}.active-games-strip::-webkit-scrollbar-track{background:0 0}.active-games-strip::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.active-game-card{scroll-snap-align:start;background:var(--panel);border:1px solid var(--border);cursor:pointer;width:220px;font-family:var(--font-body);color:var(--text);text-align:left;border-top-color:#ffffff0f;border-radius:10px;flex-direction:column;flex:none;gap:10px;padding:14px 16px;transition:border-color .18s,transform .18s,box-shadow .18s;display:flex}.active-game-card:hover{border-color:color-mix(in srgb, var(--accent) 55%, var(--border));transform:translateY(-2px);box-shadow:0 10px 26px #00000059}.active-game-card.my-turn{border-color:color-mix(in srgb, var(--accent) 60%, var(--border));box-shadow:0 0 0 1px var(--accent-glow), 0 8px 20px #00000059}.active-game-card.my-turn:hover{box-shadow:0 0 0 1px var(--accent-glow), 0 12px 28px #00000073}.agc-top{align-items:baseline;gap:6px;font-size:14px;display:flex}.agc-color{color:var(--text-h);font-size:18px;line-height:1}.agc-vs{color:var(--text-dim);font-size:11px}.agc-opp{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:600;overflow:hidden}.agc-bottom{justify-content:space-between;align-items:center;gap:8px;display:flex}.agc-badge{letter-spacing:.1em;text-transform:uppercase;border-radius:4px;padding:3px 7px;font-size:10px;font-weight:700}.agc-your-turn{background:var(--accent-glow);color:var(--accent-h)}.agc-their-turn{background:color-mix(in srgb, var(--text-dim) 18%, transparent);color:var(--text-dim)}.agc-waiting{background:color-mix(in srgb, var(--card-super) 14%, transparent);color:var(--card-super)}.agc-time{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:11px}.home-play-section{flex-direction:column;gap:18px;display:flex}.mode-cards{grid-template-columns:1fr 1fr;gap:12px;display:grid}.mode-card{background:var(--panel);border:1px solid var(--border);cursor:pointer;font-family:var(--font-body);color:var(--text);text-align:left;border-top-color:#ffffff0f;border-radius:10px;flex-direction:column;align-items:flex-start;gap:8px;padding:20px 22px;transition:border-color .18s,transform .18s,box-shadow .18s;display:flex}.mode-card:hover{border-color:color-mix(in srgb, var(--accent) 55%, var(--border));transform:translateY(-2px);box-shadow:0 10px 26px #00000059}.mode-card-active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-glow), 0 10px 26px #0006}.mode-card-icon{font-size:28px;line-height:1}.mode-card-title{font-family:var(--font-heading);letter-spacing:.08em;text-transform:uppercase;color:var(--text-h);font-size:18px;font-weight:700}.mode-card-desc{color:var(--text-dim);font-size:13px}.play-form{flex-direction:column;gap:18px;margin-top:6px;display:flex}.home-hero-section{justify-content:center;padding:12px 0;display:flex}.mode-tabs{border:1px solid var(--border);border-radius:7px;margin-bottom:22px;display:flex;overflow:hidden}.mode-tab{background:var(--panel2);color:var(--text-dim);font-size:13px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:none;flex:1;padding:10px;transition:background .18s ease-out,color .18s ease-out}.mode-tab:not(:last-child){border-right:1px solid var(--border)}.mode-tab.active{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#fff}.mode-tab:not(.active):hover{color:var(--text-h);background:var(--panel)}.modal-user-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:14px;display:flex}.modal-username{color:var(--text-dim);font-size:13px}.modal-user-actions{align-items:center;gap:6px;display:flex}.online-section{flex-direction:column;gap:14px;display:flex}.online-explainer{color:var(--text-dim);font-size:13px;line-height:1.6}.join-page{flex-direction:column;align-self:flex-start;gap:32px;width:100%;max-width:880px;padding:24px 24px 48px;animation:.4s ease-out both rise-in;display:flex}.join-header{justify-content:space-between;align-items:center;gap:14px;display:flex}.join-header-spacer{flex-shrink:0;width:36px}.join-header-right{flex-shrink:0}.join-layout{grid-template-columns:minmax(280px,1fr) auto;align-items:center;gap:56px;width:100%;display:grid}.join-card{background:var(--panel);border:1px solid var(--border);width:380px;max-width:100%;box-shadow:var(--shadow-lg);text-align:center;border-top-color:#ffffff0f;border-radius:14px;flex-direction:column;gap:14px;padding:32px 28px;display:flex}.join-card-error{margin:0 auto}.join-eyebrow{font-family:var(--font-heading);letter-spacing:.22em;text-transform:uppercase;color:var(--accent-h);font-size:11px;font-weight:700}.join-icon{font-size:44px;line-height:1}.join-title{font-family:var(--font-heading);letter-spacing:.08em;text-transform:uppercase;color:var(--text-h);font-size:26px;font-weight:700}.join-subtitle{color:var(--text-dim);font-size:14px;line-height:1.5}.join-cta{margin-top:6px}.join-cancel{margin-top:4px}.invite-link{background:var(--panel2);border:1px solid color-mix(in srgb, var(--accent) 45%, var(--border));border-top-color:color-mix(in srgb, var(--accent) 60%, var(--border));text-align:left;box-shadow:inset 0 1px 0 #ffffff0a, 0 0 18px var(--accent-glow);border-radius:8px;align-items:center;gap:8px;margin-top:4px;padding:10px 12px;display:flex}.invite-link-text{color:var(--text);word-break:break-all;letter-spacing:.01em;flex:1;font-family:Courier New,monospace;font-size:11px}.invite-copy{letter-spacing:.04em;font-weight:700;background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%)!important;color:#fff!important;border:none!important;flex:none!important;padding:6px 14px!important}.invite-copy:hover{filter:brightness(1.1);box-shadow:0 0 10px var(--accent-glow)}.invite-link-box{background:var(--panel2);border:1px solid color-mix(in srgb, var(--accent) 45%, var(--border));text-align:left;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;display:flex}.btn-copy{background:linear-gradient(180deg, var(--accent-h) 0%, var(--accent) 100%);color:#fff;font-size:12px;font-weight:600;font-family:var(--font-body);cursor:pointer;border:none;border-radius:5px;flex-shrink:0;padding:6px 11px;transition:filter .18s ease-out}.btn-copy:hover{filter:brightness(1.1)}.superhorse-info{background:color-mix(in srgb, var(--gold) 5%, var(--panel));border:1px solid color-mix(in srgb, var(--gold) 40%, transparent);border-radius:7px;flex-direction:column;gap:7px;padding:10px 14px;display:flex}.shi-title{font-family:var(--font-heading);color:var(--gold);text-align:center;letter-spacing:.06em;font-size:12px;font-weight:700}.shi-body{align-items:center;gap:12px;display:flex}.shi-grid{flex-shrink:0;grid-template-rows:repeat(7,18px);grid-template-columns:repeat(7,18px);gap:1px;display:grid}.shi-cell{background:#ffffff08;border-radius:3px;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;display:flex}.shi-knight{color:var(--text-h);background:#ffffff17;font-size:13px}.shi-normal{background:#50a05066}.shi-extra{background:#c9a22780}.shi-legend{color:var(--text-dim);flex-direction:column;gap:5px;font-size:11px;display:flex}.shi-dot{vertical-align:middle;border-radius:50%;width:10px;height:10px;margin-right:5px;display:inline-block}.shi-dot.normal{background:#50a050cc}.shi-dot.extra{background:#c9a227e6}.ghostbishop-info{background:color-mix(in srgb, var(--violet) 5%, var(--panel));border:1px solid color-mix(in srgb, var(--violet) 40%, transparent);border-radius:7px;flex-direction:column;gap:7px;padding:10px 14px;display:flex}.gbi-title{font-family:var(--font-heading);color:var(--violet);text-align:center;letter-spacing:.06em;font-size:12px;font-weight:700}.gbi-body{align-items:center;gap:12px;display:flex}.gbi-grid{flex-shrink:0;grid-template-rows:repeat(9,16px);grid-template-columns:repeat(9,16px);gap:1px;display:grid}.gbi-cell{background:#ffffff08;border-radius:2px;justify-content:center;align-items:center;width:16px;height:16px;font-size:11px;display:flex}.gbi-bishop{color:var(--text-h);background:#ffffff17;font-size:12px}.gbi-normal{background:#50a05066}.gbi-ghost{background:#a07adc80}.gbi-legend{color:var(--text-dim);flex-direction:column;gap:5px;font-size:11px;display:flex}.gbi-dot{vertical-align:middle;border-radius:50%;width:10px;height:10px;margin-right:5px;display:inline-block}.gbi-dot.normal{background:#50a050cc}.gbi-dot.ghost{background:#a07adce6}.freeze-info{background:color-mix(in srgb, #6ab4ff 5%, var(--panel));color:#8cc8ffe6;text-align:center;border:1px solid #64b4ff80;border-radius:7px;padding:10px 14px;font-size:12px;font-weight:600;animation:1.1s ease-in-out infinite card-pulse}.history-page{flex-direction:column;align-self:flex-start;gap:24px;width:100%;max-width:960px;padding:28px 24px 48px;animation:.4s ease-out both rise-in;display:flex}.history-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:14px;padding-bottom:18px;display:flex}.history-header-left{flex-direction:column;gap:10px;display:flex}.history-header-top{align-items:center;gap:18px;display:flex}.history-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.history-page-title{font-family:var(--font-heading);letter-spacing:.12em;text-transform:uppercase;color:var(--text-h);font-size:28px;font-weight:700}.history-empty{color:var(--text-dim);text-align:center;padding:60px 0;font-style:italic}.history-stats{flex-wrap:wrap;gap:12px;display:flex}.hs-pill{background:var(--panel);border:1px solid var(--border);border-radius:8px;align-items:baseline;gap:8px;min-width:96px;padding:10px 14px;display:flex}.hs-val{font-family:var(--font-heading);letter-spacing:.04em;font-size:22px;font-weight:700}.hs-label{letter-spacing:.14em;text-transform:uppercase;color:var(--text-dim);font-size:11px;font-weight:600}.hs-pill-win .hs-val{color:var(--win)}.hs-pill-loss .hs-val{color:var(--loss)}.hs-pill-draw .hs-val{color:var(--draw)}.hs-pill-win{border-color:color-mix(in srgb, var(--win) 35%, var(--border))}.hs-pill-loss{border-color:color-mix(in srgb, var(--loss) 35%, var(--border))}.hs-pill-draw{border-color:color-mix(in srgb, var(--draw) 35%, var(--border))}.history-tabs{border-bottom:1px solid var(--border);gap:4px;margin-top:-10px;display:flex}.history-tab{font-family:var(--font-heading);letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:none;align-items:center;gap:8px;margin-bottom:-1px;padding:10px 18px;font-size:12px;font-weight:700;transition:color .18s,border-color .18s;display:inline-flex}.history-tab:hover:not(.active){color:var(--text-h)}.history-tab.active{color:var(--text-h);border-bottom-color:var(--accent)}.history-tab-badge,.history-tab-count{min-width:22px;height:20px;font-family:var(--font-body);letter-spacing:.04em;border-radius:10px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.history-tab-badge{background:var(--accent);color:#fff;box-shadow:0 0 10px var(--accent-glow)}.history-tab-count{background:var(--panel2);color:var(--text-dim);border:1px solid var(--border)}.history-active-list{flex-direction:column;gap:24px;display:flex}.active-games-strip-grid{flex-wrap:wrap;overflow-x:visible}.active-games-strip-grid .active-game-card{flex:240px;width:auto;max-width:340px}.my-games-btn{align-items:center;gap:8px;display:inline-flex;position:relative}.my-games-badge{background:var(--accent);color:#fff;min-width:20px;height:18px;font-family:var(--font-body);box-shadow:0 0 10px var(--accent-glow);border-radius:9px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.history-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.game-card{--result-color:var(--text-dim);background:var(--panel);border:1px solid var(--border);cursor:pointer;font-family:var(--font-body);color:var(--text);text-align:left;border-top-color:#ffffff0d;border-radius:10px;flex-direction:column;gap:10px;padding:14px 16px;transition:border-color .18s,transform .18s,box-shadow .18s;display:flex}.game-card.gc-win{--result-color:var(--win)}.game-card.gc-loss{--result-color:var(--loss)}.game-card.gc-draw{--result-color:var(--draw)}.game-card:hover{border-color:color-mix(in srgb, var(--result-color) 60%, var(--border));box-shadow:0 12px 28px #0006, 0 0 18px color-mix(in srgb, var(--result-color) 25%, transparent);transform:translateY(-2px)}.gc-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.gc-result-badge{letter-spacing:.12em;text-transform:uppercase;background:color-mix(in srgb, var(--result-color) 18%, transparent);color:var(--result-color);border-radius:4px;padding:3px 9px;font-size:10px;font-weight:700;display:inline-block}.gc-date{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:11px}.gc-opp{align-items:baseline;gap:8px;font-size:16px;display:flex}.gc-color{color:var(--text-h);font-size:22px;line-height:1}.gc-vs-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-size:11px}.gc-opp-name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:15px;font-weight:600;overflow:hidden}.gc-bottom{color:var(--text-dim);align-items:center;gap:6px;margin-top:auto;font-size:12px;display:flex}.gc-reason{text-transform:capitalize}.result-badge{letter-spacing:.12em;text-transform:uppercase;border-radius:4px;padding:3px 9px;font-size:10px;font-weight:700;display:inline-block}.result-win{background:color-mix(in srgb, var(--win) 18%, transparent);color:var(--win)}.result-loss{background:color-mix(in srgb, var(--loss) 18%, transparent);color:var(--loss)}.result-draw{background:color-mix(in srgb, var(--draw) 14%, transparent);color:var(--draw)}.replay-page{align-self:flex-start;width:100%;padding:16px 0 36px;animation:.4s ease-out both rise-in}.replay-page.game-stacked{max-width:640px;margin:0 auto}.replay-header{flex-wrap:wrap;align-items:center;gap:12px;padding:0 14px 14px;display:flex}.replay-back-btn{flex:none}.replay-reason{color:var(--text-dim);text-transform:capitalize;letter-spacing:.08em;font-size:11px}.replay-settings-btn{margin-left:auto}.replay-controls{background:var(--panel);border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:10px 14px;display:flex}.replay-btn{min-width:44px;min-height:38px;flex:none!important;padding:8px 14px!important}.replay-ply{color:var(--text-h);text-align:center;font-variant-numeric:tabular-nums;min-width:72px;font-size:13px;font-weight:600}.replay-moves-section{background:var(--panel);border-top:1px solid var(--border);flex-direction:column;display:flex}.replay-moves-header{font-family:var(--font-heading);letter-spacing:.2em;text-transform:uppercase;color:var(--text-dim);border-bottom:1px solid var(--border);padding:12px 16px 8px;font-size:11px;font-weight:700}.replay-moves-body{max-height:360px;padding:4px 0;overflow-y:auto}.replay-moves-body::-webkit-scrollbar{width:4px}.replay-moves-body::-webkit-scrollbar-track{background:0 0}.replay-moves-body::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.card-tag{color:var(--violet);font-size:10px;font-family:var(--font-body);vertical-align:middle;margin-left:4px;display:inline-block}@media (width<=767px){.replay-page{padding:8px 0 24px}.replay-page.game-stacked{max-width:100vw}.replay-header{gap:8px;padding:0 12px 10px}.replay-btn{min-width:44px;min-height:44px;padding:0!important}.replay-ply{font-size:13px}.replay-moves-body{max-height:240px}.auth-title{margin-bottom:18px;font-size:28px}.auth-card{padding:28px 20px}.auth-input{font-size:16px}.auth-header{margin-bottom:24px}.auth-tagline{letter-spacing:.18em;font-size:11px}.auth-layout{grid-template-columns:1fr;gap:28px;max-width:380px}.showcase-stage{width:160px;height:240px}.showcase-symbol{font-size:58px}.showcase-name{font-size:15px}.showcase-caption-desc{max-width:260px;font-size:13px}.theme-picker{display:none}.home-page{gap:24px;max-width:100%;padding:16px 14px 32px}.home-header{gap:14px;padding-bottom:14px}.home-header-right{flex-wrap:wrap;gap:8px}.home-username{display:none}.home-tagline{font-size:10px}.hero-banner-sm{max-width:200px}.hero-banner{max-width:320px}.mode-cards{grid-template-columns:1fr}.mode-card{padding:16px}.mode-card-icon{font-size:24px}.mode-card-title{font-size:16px}.mode-card-desc{font-size:12px}.active-game-card{width:200px}.home-hero-section{padding:4px 0}.history-page{gap:18px;max-width:100%;padding:16px 14px 32px}.history-page-title{font-size:22px}.history-header{gap:10px;padding-bottom:14px}.history-header-left{gap:12px}.history-stats{gap:8px}.hs-pill{min-width:84px;padding:8px 12px}.hs-val{font-size:18px}.hs-label{font-size:9px}.history-grid{grid-template-columns:1fr;gap:10px}.history-tab{letter-spacing:.14em;padding:9px 14px;font-size:11px}.active-games-strip-grid .active-game-card{flex:100%;width:100%}.join-page{gap:22px;max-width:100%;padding:16px 14px 32px}.join-layout{grid-template-columns:1fr;gap:24px;max-width:380px;margin:0 auto}.join-card{width:100%;padding:24px 20px}.join-title{font-size:22px}.invite-link{flex-direction:column;align-items:stretch;gap:10px}.invite-link-text{font-size:10px}.invite-copy{text-align:center;width:100%;padding:10px!important}.invite-link-box{flex-direction:column;align-items:stretch;gap:10px}.btn-copy{text-align:center;width:100%;padding:10px}.auth-container{min-height:100svh;padding:20px 16px}.mp-player-bar{padding:8px 14px;font-size:13px}}
