*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep:#0a0e1a;--bg-panel:#111827;--accent-green:#22c55e;--accent-green-dk:#1a4a2e;--accent-green-md:#2d7a4a;--accent-green-lt:#a8e6c0;--blue-mid:#7a9fc2;--cream:#f4edd7;--purple-soft:#c4a8f0;--surface-0:#0a0e1a;--surface-1:#111827;--surface-2:#1e2840;--surface-3:#2a3a5a;--surface-4:#1e2840;--board-light:#b8cce0;--board-dark:#2d4a6a;--board-light-highlight:#c8e070;--board-dark-highlight:#7aaa20;--board-legal-dot:#0000002e;--board-legal-capture:#0000002e;--board-last-move-light:#c8e070;--board-last-move-dark:#7aaa20;--board-check:#e83030;--accent-primary:#22c55e;--accent-primary-dim:#1a4a2e;--accent-secondary:#7a9fc2;--accent-success:#22c55e;--accent-danger:#e23636;--accent-warning:#eea62b;--text-primary:#ededed;--text-secondary:#ffffff8c;--text-tertiary:#fff6;--text-inverse:#101218;--body-text:#ffffff80;--mono-muted:#ffffff8c;--mono-dim:#fff6;--font-sans:"Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"IBM Plex Mono", "SF Mono", "Fira Code", monospace;--font-pixel:"Press Start 2P", monospace;--font-retro:"VT323", monospace;--font-gothic:"Cinzel", serif;--font-prose:"IM Fell English", serif;--font-code:"Space Mono", monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.125rem;--text-xl:1.375rem;--text-2xl:1.75rem;--text-3xl:2.25rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:18px;--radius-xl:24px;--radius-pill:28px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #00000059;--shadow-lg:0 8px 32px #0006;--shadow-xl:0 16px 48px #00000080;--shadow-glow-green:0 0 20px #22c55e33;--shadow-glow-cyan:0 0 20px #25d1f433;--shadow-glow-amber:0 0 20px #f4a82533;--glass-bg:#0a0e1af7;--glass-border:#22c55e1f;--glass-blur:blur(16px);--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--duration-fast:.12s;--duration-normal:.2s;--duration-slow:.35s;--board-size:min(70vh, 560px);--square-size:calc(var(--board-size) / 8);--nav-height:72px;--content-max:1280px;--page-pad-desktop:80px;--page-pad-mobile:18px}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-deep);color:var(--text-primary);min-height:100vh;line-height:1.5;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 20% 20%,#22c55e0a 0%,#0000 60%),radial-gradient(at 80% 80%,#7a9fc208 0%,#0000 60%);position:fixed;inset:0}#app{z-index:1;min-height:100vh;position:relative}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.game-layout{gap:var(--space-6);max-width:1200px;padding:var(--space-6);grid-template-columns:1fr auto 320px;align-items:center;min-height:100vh;margin:0 auto;display:grid}.game-layout.game-layout--no-eval{grid-template-columns:auto 320px;justify-content:center}.game-layout--no-eval .game-layout__eval,.game-layout--no-eval #widget-engine{display:none!important}.game-layout__eval{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.game-layout__board{gap:var(--space-4);flex-direction:column;display:flex}.game-layout__panel{gap:var(--space-4);height:calc(var(--board-size) + 120px);flex-direction:column;display:flex}.top-bar{padding:var(--space-3) var(--space-6);border-bottom:1px solid var(--surface-4);-webkit-backdrop-filter:blur(16px);z-index:100;background:#111318cc;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.logo{align-items:center;gap:var(--space-2);font-size:var(--text-lg);letter-spacing:-.02em;color:var(--text-primary);font-weight:700;text-decoration:none;display:flex}.logo__icon{font-size:var(--text-xl)}.logo__accent{color:var(--accent-primary)}.player-bar{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--surface-1);border:1px solid var(--surface-4);min-width:var(--board-size);justify-content:space-between;align-items:center;display:flex}.player-bar__info{align-items:center;gap:var(--space-3);display:flex}.player-bar__avatar{border-radius:var(--radius-full);background:var(--surface-3);width:36px;height:36px;font-weight:600;font-size:var(--text-sm);color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.player-bar__name{font-weight:600;font-size:var(--text-base)}.player-bar__rating{font-size:var(--text-sm);color:var(--text-secondary);font-family:var(--font-mono)}.player-bar__clock{font-family:var(--font-mono);font-size:var(--text-xl);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);background:var(--surface-2);text-align:center;min-width:100px;transition:background var(--duration-normal) var(--ease-out), color var(--duration-normal) var(--ease-out);font-weight:600}.player-bar__clock--active{background:var(--accent-primary-dim);color:var(--accent-primary);box-shadow:var(--shadow-glow-cyan)}.player-bar__clock--low{color:var(--accent-danger);background:#e2363626;animation:1s ease-in-out infinite clock-pulse}@keyframes clock-pulse{0%,to{opacity:1}50%{opacity:.7}}.board-container{width:var(--board-size);height:var(--board-size);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);border:2px solid var(--surface-4);position:relative;overflow:hidden}.board{user-select:none;touch-action:none;-webkit-touch-callout:none;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:100%;height:100%;display:grid}.square{cursor:pointer;transition:background var(--duration-fast) var(--ease-out);touch-action:none;justify-content:center;align-items:center;display:flex;position:relative}.square--light{background:var(--board-light-bg,none), var(--board-light);background-position:50%;background-size:cover}.square--dark{background:var(--board-dark-bg,none), var(--board-dark);background-position:50%;background-size:cover}.square--selected.square--light{background:var(--board-light-highlight)}.square--selected.square--dark{background:var(--board-dark-highlight)}.square--last-move.square--light{background:var(--board-last-move-light)}.square--last-move.square--dark{background:var(--board-last-move-dark)}.square--check{background:radial-gradient(ellipse at center, var(--board-check) 0%, #e8303099 30%, #e8303033 60%, transparent 100%)!important}.square--twitch-highlight{animation:2s ease-in-out infinite twitch-pulse;box-shadow:inset 0 0 12px #9146ff,0 0 12px #9146ff!important}@keyframes twitch-pulse{0%,to{box-shadow:inset 0 0 8px #9146ff,0 0 8px #9146ff!important}50%{box-shadow:inset 0 0 20px #9146ff,0 0 20px #9146ff!important}}.square--legal:after{content:"";background:var(--board-legal-dot);pointer-events:none;border-radius:50%;width:28%;height:28%;position:absolute}.square--legal-capture:after{content:"";border:3px solid var(--board-legal-capture);pointer-events:none;background:0 0;border-radius:50%;width:85%;height:85%;position:absolute}.square:hover:not(.square--selected){filter:brightness(1.06)}.square__coord-file,.square__coord-rank{font-family:var(--font-mono);pointer-events:none;opacity:.5;font-size:10px;font-weight:600;position:absolute}.square__coord-file{bottom:2px;right:4px}.square__coord-rank{top:2px;left:4px}.square--light .square__coord-file,.square--light .square__coord-rank{color:var(--board-dark)}.square--dark .square__coord-file,.square--dark .square__coord-rank{color:var(--board-light)}.piece{width:78%;height:78%;font-size:calc(var(--square-size) * .65);cursor:grab;transition:transform var(--duration-fast) var(--ease-spring);z-index:2;justify-content:center;align-items:center;line-height:1;display:flex;position:relative}.piece[data-color=w]{color:var(--piece-white-color,#fff);text-shadow:0 0 6px var(--piece-white-glow,transparent);background-image:var(--piece-white-bg,none);--backing-bg:#ffffff14;--backing-border:#ffffff2e}.piece[data-color=b]{color:var(--piece-black-color,#1a1a1a);text-shadow:0 0 6px var(--piece-black-glow,transparent);background-image:var(--piece-black-bg,none);--backing-bg:#00000040;--backing-border:#00000059}.piece:before{content:"";background-color:var(--backing-border);z-index:-1;transition:all var(--duration-fast) var(--ease-out);display:none;position:absolute;inset:0}.piece:after{content:"";background-color:var(--backing-bg);background-image:inherit;z-index:-1;transition:all var(--duration-fast) var(--ease-out);background-position:50%;background-repeat:no-repeat;background-size:cover;display:none;position:absolute;inset:1.5px}.piece[data-backing]:not([data-backing=none]):before,.piece[data-backing]:not([data-backing=none]):after,[data-backing]:not([data-backing=none]) .piece:before,[data-backing]:not([data-backing=none]) .piece:after{display:block}.piece[data-backing=circle]:before,.piece[data-backing=circle]:after,[data-backing=circle] .piece:before,[data-backing=circle] .piece:after{clip-path:none;border-radius:50%}.piece[data-backing=square]:before,.piece[data-backing=square]:after,[data-backing=square] .piece:before,[data-backing=square] .piece:after{clip-path:none;border-radius:15%}.piece[data-backing=hexagon]:before,.piece[data-backing=hexagon]:after,[data-backing=hexagon] .piece:before,[data-backing=hexagon] .piece:after{clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);border-radius:0}.piece[data-backing=octagon]:before,.piece[data-backing=octagon]:after,[data-backing=octagon] .piece:before,[data-backing=octagon] .piece:after{clip-path:polygon(30% 0%,70% 0%,100% 30%,100% 70%,70% 100%,30% 100%,0% 70%,0% 30%);border-radius:0}.piece[data-backing=shield]:before,.piece[data-backing=shield]:after,[data-backing=shield] .piece:before,[data-backing=shield] .piece:after{clip-path:polygon(0% 0%,100% 0%,100% 50%,50% 100%,0% 50%);border-radius:0}.piece[data-backing=star]:before,.piece[data-backing=star]:after,[data-backing=star] .piece:before,[data-backing=star] .piece:after{clip-path:polygon(50% 0%,65% 35%,100% 35%,72% 57%,82% 90%,50% 70%,18% 90%,28% 57%,0% 35%,35% 35%);border-radius:0}.piece[data-backing=flower]:before,.piece[data-backing=flower]:after,[data-backing=flower] .piece:before,[data-backing=flower] .piece:after{clip-path:polygon(50% 5%,64% 0%,78% 8%,80% 23%,95% 25%,100% 39%,93% 53%,95% 68%,80% 73%,75% 88%,60% 93%,50% 85%,40% 93%,25% 88%,20% 73%,5% 68%,7% 53%,0% 39%,5% 25%,20% 23%,22% 8%,36% 0%);border-radius:0}.piece[data-backing=diamond]:before,.piece[data-backing=diamond]:after,[data-backing=diamond] .piece:before,[data-backing=diamond] .piece:after{clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);border-radius:0}.piece:hover{transform:scale(1.08)}.piece:active{cursor:grabbing;transform:scale(1.12)}.piece--dragging{z-index:1000;pointer-events:none;filter:drop-shadow(0 8px 16px #00000080);will-change:transform, top, left;transition:none;position:fixed;transform:scale(1.15);width:calc(var(--square-size) * .78)!important;height:calc(var(--square-size) * .78)!important}.piece--dropping{transition:transform var(--duration-normal) var(--ease-spring)}.eval-bar{width:28px;height:var(--board-size);background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--surface-4);position:relative;overflow:hidden}.eval-bar__fill{background:var(--text-primary);transition:height var(--duration-slow) var(--ease-out);border-radius:0 0 var(--radius-sm) var(--radius-sm);position:absolute;bottom:0;left:0;right:0}.eval-bar__label{font-family:var(--font-mono);writing-mode:vertical-lr;text-orientation:mixed;z-index:2;font-size:10px;font-weight:600;position:absolute;left:50%;transform:translate(-50%)}.eval-bar__label--white{bottom:var(--space-2);color:var(--surface-0)}.eval-bar__label--black{top:var(--space-2);color:var(--text-primary)}.side-panel{gap:var(--space-4);flex-direction:column;height:100%;display:flex}.move-list{padding:var(--space-4);scrollbar-width:thin;scrollbar-color:var(--surface-3) transparent;flex:1;overflow-y:auto}.move-list__header{font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3);font-weight:600}.move-list__row{gap:var(--space-2);padding:var(--space-1) 0;font-family:var(--font-mono);font-size:var(--text-sm);grid-template-columns:32px 1fr 1fr;align-items:center;display:grid}.move-list__number{color:var(--text-tertiary);text-align:right;font-size:var(--text-xs)}.move-list__move{padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.move-list__move:hover{background:var(--surface-3)}.move-list__move--active{background:var(--accent-primary-dim);color:var(--accent-primary)}.game-controls{gap:var(--space-2);padding:var(--space-3) var(--space-4);border-top:1px solid var(--surface-4);display:flex}.game-controls__btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);flex:1;font-weight:500;display:flex}.game-controls__btn:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--surface-3)}.game-controls__btn--danger:hover{color:var(--accent-danger);background:#e236361f;border-color:#e236364d}.game-controls__btn--primary{background:var(--accent-primary-dim);color:var(--accent-primary);border-color:var(--accent-primary-dim)}.game-controls__btn--primary:hover{background:var(--accent-primary);color:var(--text-inverse)}.centaur-panel{padding:var(--space-4)}.centaur-panel__header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);font-size:var(--text-sm);color:var(--accent-primary);text-transform:uppercase;letter-spacing:.08em;font-weight:600;display:flex}.centaur-panel__header:before{content:"";background:var(--accent-primary);width:8px;height:8px;box-shadow:0 0 8px var(--accent-primary);border-radius:50%;animation:2s ease-in-out infinite engine-pulse}@keyframes engine-pulse{0%,to{opacity:1;box-shadow:0 0 8px var(--accent-primary)}50%{opacity:.6;box-shadow:0 0 16px var(--accent-primary)}}.engine-line{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);margin-bottom:var(--space-2);transition:background var(--duration-fast) var(--ease-out);cursor:pointer;display:flex}.engine-line:hover{background:var(--surface-2)}.engine-line__eval{font-family:var(--font-mono);font-size:var(--text-sm);text-align:right;min-width:48px;font-weight:700}.engine-line__eval--positive{color:var(--accent-success)}.engine-line__eval--negative{color:var(--accent-danger)}.engine-line__eval--even{color:var(--text-secondary)}.engine-line__moves{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.engine-line__depth{font-family:var(--font-mono);color:var(--text-tertiary);flex-shrink:0;margin-left:auto;font-size:10px}.modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:200;opacity:0;transition:opacity var(--duration-normal) var(--ease-out);pointer-events:none;background:#08090cd9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay--visible{opacity:1;pointer-events:all}.modal{-webkit-overflow-scrolling:touch;width:90%;max-width:480px;max-height:90dvh;padding:var(--space-8);transition:transform var(--duration-slow) var(--ease-spring);overflow-y:auto;transform:translateY(16px)scale(.97)}.modal-overlay--visible .modal{transform:translateY(0)scale(1)}.modal__header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-start;display:flex}.modal__title{font-size:var(--text-2xl);margin-bottom:var(--space-2);letter-spacing:-.02em;font-weight:700}.modal__subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:0}.modal__close{border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.modal__close:hover{background:var(--surface-3);color:var(--text-primary)}.modal__section{margin-bottom:var(--space-6)}.modal__label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2);font-weight:600}.option-group{gap:var(--space-2);display:flex}.option-group--wrap{flex-wrap:wrap}.option-btn{padding:var(--space-3) var(--space-4);border:1px solid var(--surface-4);border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;text-align:center;transition:all var(--duration-fast) var(--ease-out);flex:1;font-weight:500}.option-btn--sm{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);flex:0 auto}.option-btn:hover{background:var(--surface-3);color:var(--text-primary)}.option-btn--active{background:var(--accent-primary-dim);color:var(--accent-primary);border-color:var(--accent-primary)}.modal__action-wrap{padding-top:var(--space-4);background:linear-gradient(to top, var(--glass-bg) 60%, transparent);position:sticky;bottom:0}.modal__action{width:100%;padding:var(--space-4);border-radius:var(--radius-md);background:var(--accent-primary);color:var(--text-inverse);font-family:var(--font-sans);font-size:var(--text-base);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;font-weight:600}.modal__action:hover{filter:brightness(1.1);box-shadow:var(--shadow-glow-cyan)}@media (width<=480px){.modal-overlay{align-items:flex-end}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:100%;max-height:92dvh;padding:var(--space-6) var(--space-5) env(safe-area-inset-bottom,var(--space-6))}.option-group{flex-wrap:wrap}.option-btn{min-width:calc(50% - var(--space-2));flex:0 auto}#difficulty-options{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}#difficulty-options .option-btn{flex:unset;min-width:unset}.modal__section{margin-bottom:var(--space-4)}.modal__label{margin-bottom:var(--space-1);font-size:10px}}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}@media (width<=960px){:root{--board-size:min(85vw, 480px)}.game-layout{padding:var(--space-4);justify-items:center;gap:var(--space-4);grid-template-columns:1fr}.game-layout__eval{display:none}.game-layout__panel{width:100%;max-width:var(--board-size);height:auto}}@media (width<=480px){:root{--board-size:96vw}}.view-toggle{border:1px solid var(--surface-4);border-radius:var(--radius-sm);display:flex;overflow:hidden}.view-toggle__btn{padding:var(--space-1) var(--space-4);background:var(--surface-2);color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--text-xs);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);letter-spacing:.05em;border:none;font-weight:600}.view-toggle__btn:hover{background:var(--surface-3);color:var(--text-primary)}.view-toggle__btn--active{background:var(--accent-primary-dim);color:var(--accent-primary)}.view-toggle__btn+.view-toggle__btn{border-left:1px solid var(--surface-4)}.board-mount{width:var(--board-size);min-height:var(--board-size)}.board-mount--3d{border-radius:var(--radius-md);box-shadow:var(--shadow-xl);border:2px solid var(--surface-4);width:var(--board-size);height:var(--board-size);overflow:hidden}.skin-panel{padding:var(--space-4)}.skin-panel__header{font-size:var(--text-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-3);font-weight:600}.skin-grid{gap:var(--space-2);grid-template-columns:repeat(2,1fr);max-height:160px;padding-right:4px;display:grid;overflow-y:auto}.skin-grid::-webkit-scrollbar{width:6px}.skin-grid::-webkit-scrollbar-track{background:var(--surface-1);border-radius:var(--radius-sm)}.skin-grid::-webkit-scrollbar-thumb{background:var(--surface-4);border-radius:var(--radius-sm)}.skin-grid::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.skin-btn{align-items:center;gap:var(--space-2);padding:var(--space-2);border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex}.skin-btn:hover{background:var(--surface-3);border-color:var(--surface-3)}.skin-btn--active{border-color:var(--accent-primary);background:var(--accent-primary-dim)}.skin-btn__preview{border:1px solid #ffffff14;border-radius:4px;flex-shrink:0;width:24px;height:24px}.skin-btn__name{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.skin-btn--active .skin-btn__name{color:var(--accent-primary)}.skin-upload{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--surface-4)}.skin-upload__title{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--space-2);font-weight:600}.skin-upload__row{gap:var(--space-2);flex-direction:column;display:flex}.skin-upload__btn{padding:var(--space-2) var(--space-3);border:1px dashed var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-1);color:var(--text-secondary);font-size:var(--text-xs);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-align:center;justify-content:center;align-items:center;font-weight:500;display:flex}.skin-upload__btn:hover{border-color:var(--accent-primary);color:var(--text-primary);background:var(--surface-2)}.skin-upload__targets{gap:var(--space-1);margin-top:var(--space-1);grid-template-columns:repeat(2,1fr);display:grid}.skin-upload__target-label{align-items:center;gap:var(--space-1);font-size:var(--text-xxs,10px);color:var(--text-secondary);cursor:pointer;padding:4px;display:flex}.skin-upload__target-label input{accent-color:var(--accent-primary)}.pov-controls{border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-1);padding:var(--space-3);gap:var(--space-2);flex-direction:column;display:flex}.pov-controls__title{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--surface-4);padding-bottom:var(--space-1);margin-bottom:var(--space-2);font-weight:600}.pov-controls__layout{justify-content:space-around;align-items:center;gap:var(--space-4);display:flex}.pov-dpad{flex-shrink:0;width:90px;height:90px;position:relative}.pov-dpad__btn{border:1px solid var(--surface-4);background:var(--surface-2);width:26px;height:26px;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:12px;display:flex;position:absolute}.pov-dpad__btn:hover{background:var(--surface-3);border-color:var(--accent-primary);color:var(--accent-primary)}.pov-dpad__btn:active{transform:scale(.9)}.pov-dpad__btn--up{top:0;left:32px}.pov-dpad__btn--left{top:32px;left:0}.pov-dpad__btn--center{background:var(--surface-3);border-color:var(--surface-4);font-size:9px;top:32px;left:32px}.pov-dpad__btn--center:hover{background:var(--accent-primary-dim);border-color:var(--accent-primary);color:var(--accent-primary)}.pov-dpad__btn--right{top:32px;right:0}.pov-dpad__btn--down{bottom:0;left:32px}.pov-hand-toggle{justify-content:center;align-items:center;gap:var(--space-1);border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);height:90px;color:var(--text-secondary);font-family:var(--font-mono);font-size:var(--text-xs);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);padding:var(--space-2);flex-direction:column;flex-grow:1;display:flex}.pov-hand-toggle:hover{background:var(--surface-3);color:var(--text-primary)}.pov-hand-toggle--active{background:var(--accent-primary-dim);border-color:var(--accent-primary);color:var(--accent-primary)}.pov-hand-icon{transition:transform var(--duration-fast) var(--ease-out);margin-bottom:2px}.pov-hand-toggle:hover .pov-hand-icon{transform:translateY(-2px)}.pov-hand-toggle--active .pov-hand-icon{animation:.4s ease-in-out handWiggle}@keyframes handWiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}.pov-height-controls{gap:var(--space-2);flex-direction:column;flex-shrink:0;align-items:center;display:flex}.pov-height-btn{border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);width:28px;height:28px;color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-size:11px;font-family:var(--font-mono);justify-content:center;align-items:center;padding:0;font-weight:700;display:flex}.pov-height-btn:hover{background:var(--surface-3);border-color:var(--accent-primary);color:var(--accent-primary)}.pov-height-btn:active{transform:scale(.9)}.pov-mini-board-container{margin-top:var(--space-3);gap:var(--space-2);border-top:1px solid var(--surface-4);padding-top:var(--space-3);flex-direction:column;display:flex}.pov-mini-board__title{font-size:10px;font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1);font-weight:600}.pov-mini-board{border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-3);grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:144px;height:144px;margin:0 auto;display:grid;overflow:hidden}.pov-mini-square{aspect-ratio:1;cursor:default;user-select:none;transition:all var(--duration-fast) var(--ease-out);justify-content:center;align-items:center;font-size:14px;display:flex}.pov-mini-square--light{background:#d4b89614}.pov-mini-square--dark{background:#0003}.pov-mini-square--has-piece{cursor:pointer}.pov-mini-square--has-piece:hover{background:var(--accent-primary-dim);color:var(--accent-primary)}.pov-mini-square--active{background:var(--accent-primary-dim);box-shadow:inset 0 0 0 1.5px var(--accent-primary);color:var(--accent-primary)}.pov-mini-piece{pointer-events:none;line-height:1}.pov-mini-piece--white{color:#fff;text-shadow:0 0 2px #fff6}.pov-mini-piece--black{color:#94a3b8;text-shadow:0 0 2px #0009}.pov-focus-toggle-container{margin-top:var(--space-3);gap:var(--space-2);border-top:1px solid var(--surface-4);padding-top:var(--space-3);flex-direction:column;display:flex}.pov-focus-toggle__title{font-size:10px;font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1);font-weight:600}.widget-slot{display:contents}.widget{border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);transition:box-shadow var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out);flex-direction:column;display:flex;overflow:hidden}.widget-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--surface-4);cursor:grab;user-select:none;background:#0f111c66;justify-content:space-between;align-items:center;display:flex}.widget-header:active{cursor:grabbing}.widget-title{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.widget-actions{gap:var(--space-1);align-items:center;display:flex}.widget-action-btn{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);width:24px;height:24px;transition:all var(--duration-fast) var(--ease-out);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex}.widget-action-btn:hover{background:var(--surface-3);color:var(--text-primary)}.widget-action-btn:active{transform:scale(.9)}.widget-content{flex-direction:column;flex:1;display:flex;overflow:auto}.widget--popped{z-index:1000;box-shadow:0 12px 40px #00000080, 0 0 16px var(--accent-primary-dim);border-color:var(--accent-primary);resize:both;will-change:transform, top, left, width, height;min-width:240px;min-height:120px;position:fixed}.widget--collapsed .widget-content{display:none!important}.widget--collapsed{resize:none!important;height:auto!important;min-height:0!important}@media (width<=767px){.widget--popped{animation:slideUp .3s var(--ease-out);transform:translateY(0);border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;resize:none!important;width:100%!important;max-height:70vh!important;position:fixed!important;inset:auto 0 0!important;box-shadow:0 -12px 30px #0009!important}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.widget--popped .widget-header{cursor:default;border-top:4px solid var(--accent-primary);padding-top:var(--space-2)}}@media (width<=959px){:root{--glass-blur:none}}.v4-nav{z-index:100;-webkit-backdrop-filter:blur(16px);background:#0a0e1af7;border-bottom:1px solid #22c55e1f;position:sticky;top:0}.v4-nav__inner{justify-content:space-between;align-items:center;max-width:1280px;height:72px;margin:0 auto;padding:0 80px;display:flex}.v4-nav__brand{align-items:center;gap:10px;text-decoration:none;display:flex}.v4-nav__logo-wrap{flex:none;width:34px;height:34px;position:relative}.v4-nav__logo-glow{pointer-events:none;border:1.5px solid #22c55e;border-radius:12px;position:absolute;inset:-3px;box-shadow:0 0 12px #22c55e80}.v4-nav__logo-img{border-radius:9px;display:block;position:relative}.v4-nav__wordmark{color:#fff;letter-spacing:.8px;font-size:16px;font-weight:800}.v4-nav__center{align-items:center;gap:40px;display:flex}.v4-nav__link{color:#ffffff8c;cursor:pointer;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.v4-nav__link:hover{color:#fff}.v4-nav__right{align-items:center;gap:14px;display:flex}.v4-nav__auth,.v4-nav__profile{align-items:center;gap:14px;display:inline-flex}.v4-nav__play-btn{color:#a8e6c0;letter-spacing:.3px;cursor:pointer;background:#1a4a2e;border:1px solid #2d7a4a;border-radius:24px;align-items:center;padding:10px 24px;font-size:14px;font-weight:700;text-decoration:none;transition:box-shadow .2s,transform .15s;display:inline-flex;box-shadow:0 2px 14px #22c55e38}.v4-nav__play-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #22c55e59}.v4-hero{background:#0a0e1a;padding:100px 0 40px;position:relative;overflow:hidden}.v4-hero__checker{opacity:.025;pointer-events:none;background:repeating-conic-gradient(#c2c8d0 0% 25%,#6a7080 0% 50%) 50%/12.5% 12.5%;border-radius:8px;width:760px;height:760px;position:absolute;top:-80px;right:-100px}.v4-hero__dots{opacity:.03;pointer-events:none;background:repeating-conic-gradient(#7090ff 0% 25%,#0000 0% 50%) 0 0/40px 40px;position:absolute;inset:0}.v4-hero__grid{grid-template-columns:1fr 500px;align-items:center;gap:80px;max-width:1280px;margin:0 auto;padding:0 80px;display:grid}.v4-hero__copy{position:relative}.v4-hero__eyebrow{letter-spacing:3px;color:#4a90c8;text-transform:uppercase;margin-bottom:20px;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-hero__headline{color:#fff;letter-spacing:-1.5px;text-wrap:pretty;max-width:640px;margin-bottom:24px;font-size:56px;font-weight:800;line-height:1.03}.v4-hero__subhead{color:#ffffff80;max-width:520px;margin-bottom:40px;font-size:18px;line-height:1.7}.v4-hero__ctas{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.v4-hero__cta-green{cursor:pointer;color:#a8e6c0;letter-spacing:.3px;background:#1a4a2e;border:none;border-radius:28px;align-items:center;padding:14px 34px;font-size:15px;font-weight:700;text-decoration:none;transition:box-shadow .2s,transform .15s;display:inline-flex;box-shadow:0 4px 20px #22c55e40}.v4-hero__cta-green:hover{transform:translateY(-2px);box-shadow:0 6px 28px #22c55e66}.v4-hero__cta-ghost{cursor:pointer;color:#ffffffa6;background:0 0;border:1.5px solid #ffffff2e;border-radius:28px;align-items:center;gap:8px;padding:13px 28px;font-size:15px;font-weight:500;text-decoration:none;transition:border-color .2s;display:inline-flex}.v4-hero__cta-ghost:hover{border-color:#ffffff59}.v4-hero__social-btn{cursor:pointer;border:1px solid;border-radius:24px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s;display:inline-flex}.v4-hero__social-btn:hover{opacity:.85}.v4-ir{background:#0d2018;border:1px solid #2d7a4a;border-radius:22px;padding:30px;box-shadow:0 8px 40px #0006}.v4-ir__header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.v4-ir__title{color:#a8e6c0;letter-spacing:1px;margin-bottom:5px;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-ir__sub{color:#2d7a4a;align-items:center;gap:5px;font-family:IBM Plex Mono,monospace;font-size:9px;display:flex}.v4-ir__diamond{color:#22c55e}.v4-ir__live-dot{background:#22c55e;border-radius:50%;width:9px;height:9px;animation:1.4s step-end infinite v4-live-blink;box-shadow:0 0 10px #22c55ecc}@keyframes v4-live-blink{0%,to{opacity:1}50%{opacity:.3}}.v4-ir__bars{border-bottom:1px solid #1a4a2e;align-items:flex-end;gap:5px;height:88px;margin-bottom:20px;padding-bottom:8px;display:flex}.v4-ir__bar{border-radius:2px 2px 0 0;flex:1}.v4-ir__stats{gap:10px;margin-bottom:20px;display:flex}.v4-ir__stat-card{background:#0a1810;border:1px solid #1a4a2e;border-radius:12px;flex:1;padding:14px 12px}.v4-ir__stat-val{color:#a8e6c0;margin-bottom:4px;font-family:IBM Plex Mono,monospace;font-size:22px;font-weight:600;line-height:1}.v4-ir__stat-lbl{color:#2d7a4a;letter-spacing:.3px;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-ir__scale-lbl{color:#2d7a4a;letter-spacing:.5px;margin-bottom:7px;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-ir__scale-row{align-items:center;gap:8px;display:flex}.v4-ir__scale-track{background:#0a1810;border:1px solid #1a4a2e;border-radius:3px;flex:1;height:6px;overflow:hidden}.v4-ir__scale-fill{background:linear-gradient(90deg,#22c55e,#1a4a2e);border-radius:3px;width:35%;height:100%}.v4-ir__scale-range{color:#2d7a4a;white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-hero__act-row{justify-content:space-between;align-items:center;max-width:1280px;margin:40px auto 0;padding:0 80px;display:flex}.v4-act-label{letter-spacing:1.5px;color:#1e2840;font-family:IBM Plex Mono,monospace;font-size:9px}.v4-act-dots{gap:5px;display:flex}.v4-act-dot{background:#1e2438;border-radius:50%;width:6px;height:6px}.v4-act-dot--active{background:#4a90c8}.v4-section-label{max-width:1280px;margin:16px auto 0;padding:0 80px}.v4-section-label--right{text-align:right;margin-top:24px}.v4-transition-line{background:linear-gradient(90deg,#0000,#22c55e4d,#0000);height:2px}.v4-transition-fade{background:linear-gradient(#111827,#7a9fc2);height:44px}.v4-live{background:#111827;padding-bottom:72px}.v4-live__ticker{background:#0d131f;border-bottom:1px solid #1e2840;padding:13px 80px}.v4-live__ticker-inner{align-items:center;gap:12px;max-width:1280px;margin:0 auto;display:flex}.v4-live__red-dot{background:#ef4444;border-radius:50%;flex:none;width:8px;height:8px;box-shadow:0 0 8px #ef4444b3}.v4-live__ticker-live{color:#fff;letter-spacing:2px;font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600}.v4-live__ticker-info{color:#4a5060;letter-spacing:.5px;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-live__ticker-sep{background:#1e2840;width:1px;height:16px;margin:0 6px}.v4-live__ticker-spec{color:#333;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-live__ticker-clock{color:#2a3040;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-live__board-area{grid-template-columns:12px 480px 1fr 210px;align-items:start;gap:24px;max-width:1280px;margin:0 auto;padding:44px 80px 0;display:grid}.v4-live__eval{border:1px solid #2a3a5a;border-radius:4px;flex-direction:column;width:12px;height:480px;display:flex;overflow:hidden}.v4-live__eval-white{background:#d4dde8}.v4-live__eval-black{background:#1a2040;flex:1}.v4-live__board-wrap{flex:none;position:relative}.v4-live__board{width:480px;height:480px;position:relative}.v4-live__board .hero__mini-board{border:2px solid #2a3a5a;border-radius:6px;width:480px;height:480px}.v4-live__eval-badge{color:#4a90c8;backdrop-filter:blur(4px);background:#000000e6;border:1px solid #2a3050;border-radius:4px;padding:4px 10px;font-family:IBM Plex Mono,monospace;font-size:11px;position:absolute;bottom:8px;left:8px}.v4-live__rail{flex-direction:column;gap:12px;height:480px;display:flex}.v4-live__player{background:#0d1f14;border:1px solid #1a4a2e;border-radius:14px;align-items:center;gap:14px;padding:16px 18px;display:flex}.v4-live__player-avatar{border:1.5px solid;border-radius:50%;flex:none;justify-content:center;align-items:center;width:46px;height:46px;font-family:sans-serif;font-size:26px;display:flex}.v4-live__player-avatar--w{background:linear-gradient(135deg,#2d7a4a,#1a4a2e);border-color:#2d7a4a}.v4-live__player-avatar--b{background:linear-gradient(135deg,#1a4a2e,#0d2018);border-color:#1a4a2e}.v4-live__player-info{flex:1;min-width:0}.v4-live__player-name{color:#fff;margin-bottom:4px;font-size:17px;font-weight:700}.v4-live__player-meta{align-items:center;gap:8px;display:flex}.v4-live__player-model{color:#2d7a4a;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-live__ir-badge{color:#22c55e;background:#0a1810;border:1px solid #1a4a2e;border-radius:4px;padding:2px 7px;font-family:IBM Plex Mono,monospace;font-size:9px}.v4-live__player-rating{text-align:right;flex:none}.v4-live__player-elo{color:#a8e6c0;font-family:IBM Plex Mono,monospace;font-size:24px;font-weight:600;line-height:1}.v4-live__player-time{color:#2d7a4a;margin-top:3px;font-family:IBM Plex Mono,monospace;font-size:9px}.v4-live__moves{background:#0d1422;border:1px solid #252e50;border-radius:14px;flex:1;padding:16px 18px}.v4-live__moves-hdr,.v4-live__chat-hdr{color:#4a90c8;letter-spacing:1px;margin-bottom:12px;font-family:IBM Plex Mono,monospace;font-size:9px}.v4-live__move-row{gap:16px;padding:2px 0;font-family:IBM Plex Mono,monospace;font-size:13px;display:flex}.v4-live__move-row--active{background:#22c55e0f;border-radius:5px;padding:4px 5px}.v4-live__move-num{color:#2a3040;width:28px}.v4-live__move-w{color:#c2c8d0;flex:1}.v4-live__move-w--best{color:#22c55e;font-weight:600}.v4-live__move-b{color:#6a7080}.v4-live__chat{background:#0d1422;border:1px solid #252e50;border-radius:14px;padding:14px 18px}.v4-live__chat-hdr{margin-bottom:10px}.v4-live__chat-msg{margin-bottom:6px;font-size:13px}.v4-live__also-hdr{color:#2a3040;letter-spacing:1.5px;margin-bottom:12px;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-live__also-card{cursor:pointer;border:1px solid #ffffff12;border-radius:8px;margin-bottom:10px;transition:border-color .2s;overflow:hidden}.v4-live__also-card:hover{border-color:#ffffff26}.v4-live__also-thumb{height:100px}.v4-live__also-info{background:#0d1422;padding:9px 11px}.v4-live__also-name{color:#c2c8d0;margin-bottom:2px;font-size:11px;font-weight:600}.v4-live__also-viewers{color:#3a5060;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-manifesto{background:#7a9fc2;padding:88px 0 80px}.v4-manifesto__grid{grid-template-columns:1fr 520px;align-items:center;gap:88px;max-width:1280px;margin:0 auto;padding:0 80px;display:grid}.v4-manifesto__ornament{color:#c4a8f0;user-select:none;margin-bottom:16px;font-size:30px;line-height:1}.v4-manifesto__pill{background:#c4a8f0;border-radius:30px;align-items:center;margin-bottom:24px;padding:6px 16px;display:inline-flex}.v4-manifesto__pill span{color:#2a1a4e;letter-spacing:.3px;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:600}.v4-manifesto__headline{color:#fff;letter-spacing:-1.5px;text-wrap:pretty;margin-bottom:24px;font-size:54px;font-weight:800;line-height:1.02}.v4-manifesto__headline-cream{color:#f4edd7}.v4-manifesto__divider{align-items:center;gap:14px;margin-bottom:24px;display:flex}.v4-manifesto__divider-line{background:linear-gradient(90deg,#0000,#ffffff4d);flex:1;height:1px}.v4-manifesto__divider-line--r{background:linear-gradient(270deg,#0000,#ffffff4d)}.v4-manifesto__divider-pieces{color:#ffffff73;letter-spacing:10px;font-family:sans-serif;font-size:18px}.v4-manifesto__body{color:#ffffffb8;max-width:460px;font-size:17px;line-height:1.75}.v4-manifesto__card{background:#f4edd7;border-radius:26px;padding:34px;position:relative;overflow:hidden;box-shadow:0 10px 50px #00000047}.v4-manifesto__card-stripe{background:linear-gradient(90deg,#1a4a2e,#22c55e,#1a4a2e);height:4px;position:absolute;top:0;left:0;right:0}.v4-manifesto__card-body{color:#5a4a2a;margin-bottom:26px;padding-top:8px;font-size:14px;line-height:1.75}.v4-manifesto__card-stats{gap:10px;margin-bottom:26px;display:flex}.v4-manifesto__card-stat{text-align:center;background:#f0f8f2;border:1px solid #1a4a2e;border-radius:14px;flex:1;padding:16px 12px}.v4-manifesto__card-stat-val{color:#1a4a2e;margin-bottom:5px;font-family:IBM Plex Mono,monospace;font-size:22px;font-weight:600;line-height:1}.v4-manifesto__card-stat-lbl{color:#2d7a4a;letter-spacing:.3px;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-manifesto__card-ctas{flex-direction:column;gap:11px;display:flex}.v4-manifesto__card-btn{text-align:center;cursor:pointer;border-radius:26px;padding:15px;font-size:15px;font-weight:700;text-decoration:none;transition:transform .15s;display:block}.v4-manifesto__card-btn:hover{transform:translateY(-1px)}.v4-manifesto__card-btn--green{color:#a8e6c0;letter-spacing:.3px;background:#1a4a2e;box-shadow:0 3px 14px #1a4a2e66}.v4-manifesto__card-btn--dark{color:#1a1a1a;background:0 0;border:1.5px solid #1a1a1a;font-size:14px;font-weight:600}.v4-modes{background:#7a9fc2;padding:0 0 88px}.v4-modes__inner{max-width:1280px;margin:0 auto;padding:0 80px}.v4-modes__badge-row{justify-content:center;padding-bottom:20px;display:flex}.v4-modes__headline{color:#fff;text-align:center;letter-spacing:-.8px;margin-bottom:30px;font-size:44px;font-weight:800}.v4-modes__spotlight{border-radius:22px;height:220px;margin-bottom:16px;position:relative;overflow:hidden;box-shadow:0 8px 40px #00000059}.v4-modes__spotlight-bg{background:linear-gradient(to top right,#0000 49%,#d8d0ba 49.5% 50.5%,#0000 51%),#ede6d0 linear-gradient(to top left,#0000 49%,#d8d0ba 49.5% 50.5%,#0000 51%);position:absolute;inset:0}.v4-modes__spotlight-gradient{background:linear-gradient(90deg,#080812f0 0%,#08081280 50%,#0000 100%);position:absolute;inset:0}.v4-modes__spotlight-content{flex-direction:column;justify-content:space-between;height:100%;padding:40px 52px;display:flex;position:relative}.v4-modes__spotlight-badge{letter-spacing:2.5px;color:#c4a8f0;margin-bottom:10px;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-modes__spotlight-title{color:#fff;letter-spacing:-.8px;font-size:48px;font-weight:800;line-height:1.02}.v4-modes__spotlight-desc{color:#fff9;margin-top:6px;font-size:15px}.v4-modes__spotlight-cta{cursor:pointer;color:#2a1a4e;background:#c4a8f0;border:none;border-radius:22px;padding:11px 30px;font-size:14px;font-weight:700;transition:transform .15s;display:inline-flex}.v4-modes__spotlight-cta:hover{transform:translateY(-1px)}.v4-modes__spotlight-dots{gap:7px;display:flex;position:absolute;bottom:22px;right:32px}.v4-modes__spotlight-dot{background:#ffffff59;border-radius:2px;width:7px;height:4px}.v4-modes__spotlight-dot--active{background:#fff;width:28px}.v4-modes__grid{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.v4-modes__card{border-radius:18px;height:210px;overflow:hidden}.v4-modes__card--syntax{background:linear-gradient(135deg,#3a4050,#55606c);border:1px solid #6a7282;grid-column:span 2;align-items:flex-end;display:flex;position:relative}.v4-modes__card-checker{opacity:.38;background:repeating-conic-gradient(#4a505a 0% 25%,#3a4050 0% 50%) 50%/14px 14px;position:absolute;inset:0}.v4-modes__card-bottom{justify-content:space-between;align-items:flex-end;width:100%;padding:24px 28px;display:flex;position:relative}.v4-modes__card-title--syntax{color:#c2c8d0;letter-spacing:.5px;margin-bottom:5px;font-size:28px;font-weight:800}.v4-modes__card-sub--syntax{color:#8a909a;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-modes__card-live{flex:none;align-items:center;gap:7px;display:flex}.v4-modes__card-live-text{color:#22c55e;font-family:IBM Plex Mono,monospace;font-size:12px;font-weight:600}.v4-modes__card--cream{background:#f4edd7;border:1px solid #d4c9ab;flex-direction:column;display:flex}.v4-modes__card-checker-cream{background:repeating-conic-gradient(#c8c0a8 0% 25%,#f4edd7 0% 50%) 50%/12.5% 12.5%;flex:1}.v4-modes__card-bottom-cream{border-top:1px solid #d4c9ab;padding:16px 18px}.v4-modes__card-title--cream{color:#3a2a1a;margin-bottom:3px;font-size:16px;font-weight:700}.v4-modes__card-sub--cream{color:#9a8a6a;font-family:IBM Plex Mono,monospace;font-size:8px}.v4-modes__card--logo{background:#0a0e1a;border:1.5px solid #1a4a2e;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:relative}.v4-modes__card-logo-svg{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.v4-modes__card-logo-mark{width:64px;height:64px;position:relative}.v4-modes__card-logo-glow{border:1.5px solid #22c55e;border-radius:20px;position:absolute;inset:-4px;box-shadow:0 0 22px #22c55e8c}.v4-modes__card-logo-img{border-radius:16px;display:block;position:relative}.v4-modes__card-logo-text{color:#22c55e;letter-spacing:3px;font-family:IBM Plex Mono,monospace;font-size:9px;position:relative}.v4-modes__card--otb{background:#e8eaee;border:1px solid #7a8292;flex-direction:column;display:flex}.v4-modes__card-checker-otb{background:repeating-conic-gradient(#d0d4da 0% 25%,#e8eaee 0% 50%) 50%/12.5% 12.5%;flex:1}.v4-modes__card--more{background:0 0;border:1px dashed #c4a8f0;flex-direction:column;grid-column:span 2;justify-content:center;align-items:center;gap:14px;display:flex}.v4-modes__card-more-text{color:#c4a8f0;letter-spacing:2px;font-family:IBM Plex Mono,monospace;font-size:13px;font-weight:600}.v4-modes__card-more-dots{gap:5px;display:flex}.v4-modes__card-more-dot{background:#c4a8f0;border-radius:50%;width:5px;height:5px}.v4-proof{background:#0d2018;border-top:1px solid #1a4a2e;padding:88px 0}.v4-proof__grid{grid-template-columns:1fr 1fr;align-items:center;gap:88px;max-width:1280px;margin:0 auto;padding:0 80px;display:grid}.v4-proof__badge{background:#1a4a2e;border:1px solid #2d7a4a;border-radius:30px;align-items:center;gap:8px;margin-bottom:26px;padding:6px 18px;display:inline-flex}.v4-proof__badge-diamond{color:#22c55e;font-size:13px}.v4-proof__badge-text{color:#a8e6c0;letter-spacing:.3px;font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:600}.v4-proof__headline{color:#a8e6c0;letter-spacing:-.5px;text-wrap:pretty;margin-bottom:20px;font-size:46px;font-weight:700;line-height:1.2}.v4-proof__bar{background:#1a4a2e;border-radius:2px;height:3px;overflow:hidden}.v4-proof__bar-fill{background:linear-gradient(90deg,#22c55e,#1a4a2e);border-radius:2px;width:72%;height:100%}.v4-proof__stats{gap:16px;display:flex}.v4-proof__stat{background:#0a1810;border:1px solid #1a4a2e;border-radius:18px;flex:1;padding:26px 22px}.v4-proof__stat-val{color:#a8e6c0;margin-bottom:8px;font-family:IBM Plex Mono,monospace;font-size:38px;font-weight:600;line-height:1}.v4-proof__stat-lbl{color:#2d7a4a;letter-spacing:.3px;font-family:IBM Plex Mono,monospace;font-size:9px}.v4-footer{background:#0f0f0f;border-top:1px solid #1a1a1a;padding:64px 0 0}.v4-footer__grid{grid-template-columns:1.6fr 1fr 1fr 1fr;gap:60px;max-width:1280px;margin:0 auto;padding:0 80px;display:grid}.v4-footer__brand-row{align-items:center;gap:10px;margin-bottom:16px;display:flex}.v4-footer__blurb{color:#3a3a3a;max-width:220px;margin-bottom:20px;font-size:13px;line-height:1.7}.v4-footer__domain{color:#222;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-footer__col{flex-direction:column;gap:13px;display:flex}.v4-footer__col-hdr{color:#333;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:5px;font-family:IBM Plex Mono,monospace;font-size:9px}.v4-footer__link{color:#444;cursor:pointer;font-size:13px;text-decoration:none;transition:color .2s}.v4-footer__link:hover{color:#888}.v4-footer__bottom{border-top:1px solid #1a1a1a;justify-content:space-between;align-items:center;max-width:1280px;margin:44px auto 0;padding:20px 80px;display:flex}.v4-footer__copyright{color:#222;font-family:IBM Plex Mono,monospace;font-size:10px}.v4-footer__ticker{color:#333;font-family:IBM Plex Mono,monospace;font-size:10px;transition:opacity .3s}.v4-footer__play-btn{cursor:pointer;color:#a8e6c0;background:#1a4a2e;border:none;border-radius:22px;align-items:center;padding:11px 26px;font-size:13px;font-weight:700;text-decoration:none;transition:transform .15s;display:inline-flex;box-shadow:0 2px 12px #22c55e33}.v4-footer__play-btn:hover{transform:translateY(-1px)}.hero__mini-board{border:2px solid #2a3a5a;border-radius:6px;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:480px;height:480px;display:grid;overflow:hidden}.hero-sq{user-select:none;justify-content:center;align-items:center;font-size:2.2rem;line-height:1;display:flex}.hero-sq--light{background:#b8cce0}.hero-sq--dark{background:#2d4a6a}.hero-sq--highlight{background:#c8e070}.hero-sq--dark.hero-sq--highlight{background:#7aaa20}.hero-piece{filter:drop-shadow(0 1px 2px #0006);font-size:2.4rem}.hero-piece--white{color:#f0e8d0}.hero-piece--black{color:#0a0e1a}@media (width<=768px){.v4-nav__inner{padding:0 18px}.v4-nav__center{display:none}.v4-hero{padding:60px 0 30px}.v4-hero__grid{grid-template-columns:1fr;gap:40px;padding:0 18px}.v4-hero__headline{letter-spacing:-.8px;font-size:30px}.v4-hero__subhead{margin-bottom:24px;font-size:15px}.v4-hero__ctas{flex-direction:column}.v4-hero__act-row{padding:0 18px}.v4-live__ticker{padding:10px 18px}.v4-live__board-area{grid-template-columns:8px 1fr;gap:12px;padding:24px 18px 0}.v4-live__board,.v4-live__board .hero__mini-board,.hero__mini-board{aspect-ratio:1;width:100%;height:auto}.v4-live__eval{aspect-ratio:auto;align-self:stretch;height:auto}.v4-live__rail,.v4-live__also{display:none}.v4-section-label{padding:0 18px}.v4-manifesto__grid{grid-template-columns:1fr;gap:40px;padding:0 18px}.v4-manifesto__headline{font-size:32px}.v4-modes__inner{padding:0 18px}.v4-modes__headline{font-size:28px}.v4-modes__spotlight{height:160px}.v4-modes__spotlight-content{padding:24px}.v4-modes__spotlight-title{font-size:30px}.v4-modes__grid{grid-template-columns:1fr 1fr}.v4-modes__card--syntax{grid-column:span 2;height:140px}.v4-modes__card--more{grid-column:span 2;height:120px}.v4-modes__card{height:160px}.v4-proof__grid{grid-template-columns:1fr;gap:40px;padding:0 18px}.v4-proof__headline{font-size:28px}.v4-proof__stats{flex-wrap:wrap}.v4-proof__stat{min-width:calc(50% - 8px)}.v4-footer__grid{grid-template-columns:1fr;gap:30px;padding:0 18px}.v4-footer__bottom{text-align:center;flex-direction:column;gap:12px;padding:16px 18px}}@media (prefers-reduced-motion:reduce){.v4-ir__live-dot,.v4-live__red-dot{animation:none}.v4-nav__play-btn,.v4-hero__cta-green,.v4-hero__cta-ghost,.v4-footer__play-btn,.v4-manifesto__card-btn,.v4-modes__spotlight-cta{transition:none}}.social-widget{flex-direction:column;height:100%;display:flex}.social-tabs{border-bottom:1px solid var(--surface-4);margin-bottom:var(--space-3);gap:var(--space-1);display:flex}.social-tab{color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-xs);padding:var(--space-2) 0;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);text-align:center;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;font-weight:600}.social-tab:hover{color:var(--text-primary)}.social-tab--active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.social-content{flex:1;overflow-y:auto}.social-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);margin:var(--space-3) 0 var(--space-2) 0;font-size:10px;font-weight:700}.friends-list{gap:var(--space-2);flex-direction:column;display:flex}.friend-item{padding:var(--space-2) var(--space-3);border:1px solid var(--glass-border);border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-out);background:#ffffff05;justify-content:space-between;align-items:center;display:flex}.friend-item:hover{background:#ffffff0a;border-color:#bebebe26}.friend-item--pending{opacity:.85;border-style:dashed}.friend-item__info{align-items:center;gap:var(--space-2);display:flex}.friend-item__status{border-radius:var(--radius-full);background:var(--text-tertiary);flex-shrink:0;width:7px;height:7px;display:inline-block}.friend-item__status--online{background:var(--accent-success);box-shadow:0 0 8px var(--accent-success);animation:2s ease-in-out infinite presence-glow}@keyframes presence-glow{0%,to{opacity:.6}50%{opacity:1}}.friend-item__name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.friend-item__meta{color:var(--text-secondary);margin-top:1px;font-size:10px}.friend-item__challenge-btn{border:1px solid var(--glass-border);color:var(--text-primary);padding:3px var(--space-2);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);background:#bebebe14;font-size:10px;font-weight:600}.friend-item__challenge-btn:hover{background:var(--accent-primary);color:var(--surface-0);border-color:var(--accent-primary);box-shadow:var(--shadow-glow-cyan)}.friend-item__challenge-btn--disabled{opacity:.4;cursor:not-allowed}.friend-item__actions{gap:var(--space-1);display:flex}.friend-action-btn{border-radius:var(--radius-sm);border:1px solid var(--glass-border);width:20px;height:20px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);background:0 0;justify-content:center;align-items:center;font-size:10px;display:flex}.friend-action-btn--accept:hover{color:var(--accent-success);background:#2ecc7126;border-color:#2ecc714d}.friend-action-btn--decline:hover,.friend-action-btn--cancel:hover{color:var(--accent-danger);background:#e74c3c26;border-color:#e74c3c4d}.social-empty-state{text-align:center;padding:var(--space-6) 0;font-size:var(--text-xs);color:var(--text-tertiary)}.friend-add-form-container{padding:var(--space-2) 0}.social-search-form{gap:var(--space-2);display:flex}.social-search-input{background:var(--surface-2);border:1px solid var(--surface-4);color:var(--text-primary);border-radius:var(--radius-sm);padding:6px var(--space-2);font-size:var(--text-sm);outline:none;flex:1;transition:border-color .2s}.social-search-input:focus{border-color:var(--accent-primary)}.social-search-submit{background:var(--accent-primary);color:var(--surface-0);font-size:var(--text-xs);padding:0 var(--space-3);border-radius:var(--radius-sm);cursor:pointer;border:none;font-weight:600}.social-error{color:var(--accent-danger);font-size:var(--text-xs);margin-top:var(--space-2)}.social-success{color:var(--accent-success);font-size:var(--text-xs);margin-top:var(--space-2)}.chat-drawer{background:var(--glass-bg);width:320px;height:100vh;backdrop-filter:var(--glass-blur);border-left:1px solid var(--glass-border);z-index:1000;transition:transform var(--duration-slow) var(--ease-out);box-shadow:var(--shadow-xl);position:fixed;top:0;right:0;transform:translate(100%)}.chat-drawer--open{transform:translate(0)}.chat-drawer__toggle{transform-origin:0;background:var(--surface-1);border:1px solid var(--surface-4);color:var(--text-primary);padding:6px var(--space-3);border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:pointer;box-shadow:var(--shadow-md);border-bottom:none;font-size:11px;font-weight:600;transition:all .2s;position:absolute;top:50%;left:-70px;transform:rotate(-90deg)translate(-50%,-50%)}.chat-drawer__toggle:hover{background:var(--surface-2);color:var(--accent-primary)}.chat-container{flex-direction:column;height:100%;display:flex}.chat-header{padding:var(--space-4);border-bottom:1px solid var(--surface-4);justify-content:space-between;align-items:center;display:flex}.chat-header__title{font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.chat-header__close-btn{color:var(--text-secondary);font-size:var(--text-base);cursor:pointer;background:0 0;border:none}.chat-messages{padding:var(--space-4);gap:var(--space-3);scroll-behavior:smooth;flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-system-msg{text-align:center;color:var(--text-tertiary);opacity:.8;margin:var(--space-1) 0;font-size:10px}.chat-bubble{max-width:80%;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);word-wrap:break-word;line-height:1.4}.chat-bubble--them{background:var(--surface-2);border:1px solid var(--glass-border);color:var(--text-primary);border-bottom-left-radius:2px;align-self:flex-start}.chat-bubble--me{background:var(--accent-primary-dim);color:var(--text-primary);border-bottom-right-radius:2px;align-self:flex-end}.chat-bubble__sender{opacity:.8;margin-bottom:2px;font-size:9px;font-weight:700}.chat-quick-grid{gap:var(--space-1);padding:var(--space-2) var(--space-4);border-top:1px solid var(--surface-4);background:#0000001a;grid-template-columns:repeat(2,1fr);display:grid}.chat-quick-btn{border:1px solid var(--glass-border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;text-align:center;white-space:nowrap;text-overflow:ellipsis;background:#ffffff08;padding:4px;font-size:10px;transition:all .15s;overflow:hidden}.chat-quick-btn:hover{color:var(--text-primary);background:#ffffff14}.chat-form{padding:var(--space-4);gap:var(--space-2);border-top:1px solid var(--surface-4);background:var(--surface-1);display:flex}#chat-message-input{background:var(--surface-2);border:1px solid var(--surface-4);color:var(--text-primary);border-radius:var(--radius-sm);padding:var(--space-2);font-size:var(--text-sm);outline:none;flex:1}.chat-send-btn{background:var(--accent-primary);color:var(--surface-0);font-size:var(--text-xs);padding:0 var(--space-3);border-radius:var(--radius-sm);cursor:pointer;border:none;font-weight:600}.matchmaking-overlay{backdrop-filter:blur(12px);z-index:2000;animation:fade-in .25s var(--ease-out);background:#06090fd9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.matchmaking-card{text-align:center;max-width:350px;padding:var(--space-8) var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--glass-border)}.matchmaking-spinner{border-radius:var(--radius-full);border:3px solid #bebebe1a;border-top-color:var(--accent-primary);border-right-color:var(--accent-primary);width:50px;height:50px;margin:0 auto var(--space-6) auto;animation:1s linear infinite mm-spin}@keyframes mm-spin{to{transform:rotate(360deg)}}.matchmaking-status{font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:600}.matchmaking-timer{font-size:var(--text-xs);color:var(--text-secondary);font-family:var(--font-mono);margin-bottom:var(--space-6)}.matchmaking-cancel-btn{border:1px solid var(--surface-4);color:var(--text-secondary);font-size:var(--text-xs);padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);cursor:pointer;background:0 0;font-weight:600;transition:all .2s}.matchmaking-cancel-btn:hover{color:var(--accent-danger);background:#e74c3c1a;border-color:#e74c3c4d}.challenge-toast{right:var(--space-4);bottom:var(--space-4);z-index:3000;opacity:0;width:320px;transition:all var(--duration-slow) var(--ease-spring);pointer-events:none;position:fixed;transform:translateY(150%)}.challenge-toast--visible{opacity:1;pointer-events:auto;transform:translateY(0)}.challenge-toast__card{padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--accent-primary-dim);box-shadow:var(--shadow-lg), var(--shadow-glow-cyan)}.challenge-toast__title{font-size:var(--text-sm);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700}.challenge-toast__meta{color:var(--text-secondary);margin-bottom:var(--space-4);font-size:11px;line-height:1.4}.challenge-toast__actions{gap:var(--space-2);display:flex}.challenge-toast-btn{font-size:var(--text-xs);padding:var(--space-2) 0;border-radius:var(--radius-sm);cursor:pointer;text-align:center;border:none;flex:1;font-weight:600;transition:all .2s}.challenge-toast-btn--accept{background:var(--accent-primary);color:var(--surface-0)}.challenge-toast-btn--accept:hover{box-shadow:var(--shadow-glow-cyan);opacity:.9}.challenge-toast-btn--decline{background:var(--surface-2);border:1px solid var(--surface-4);color:var(--text-primary)}.challenge-toast-btn--decline:hover{background:var(--surface-3)}@supports (padding:env(safe-area-inset-top)){body{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.v4-nav{padding-top:max(var(--space-3), env(safe-area-inset-top));padding-left:max(var(--space-6), env(safe-area-inset-left));padding-right:max(var(--space-6), env(safe-area-inset-right))}.top-bar{padding-top:max(var(--space-2), env(safe-area-inset-top));padding-left:max(var(--space-3), env(safe-area-inset-left));padding-right:max(var(--space-3), env(safe-area-inset-right))}.game-layout{padding-bottom:max(var(--space-4), env(safe-area-inset-bottom))}.modal{margin-bottom:env(safe-area-inset-bottom)}.widget-popout.widget-popout--popped{padding-bottom:max(var(--space-4), env(safe-area-inset-bottom))}}button,a,input,select,textarea,.option-btn,.auth-form__submit-btn,.hero__btn--primary,.hero__btn--secondary{touch-action:manipulation}@media (orientation:landscape) and (height<=500px){:root{--board-size:min(80vh, 360px)}.game-layout{gap:var(--space-3);grid-template-rows:1fr;grid-template-columns:auto 1fr}.game-layout__eval{display:none}.player-bar{padding:var(--space-1) var(--space-2)}.hero{min-height:calc(100dvh - 60px)}}.tournament-page{max-width:1100px;padding:var(--space-6) var(--space-6) var(--space-16);min-height:100vh;animation:tournament-fadeIn .4s var(--ease-out);margin:0 auto}@keyframes tournament-fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.tournament-page__header{margin-bottom:var(--space-8);justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.tournament-page__title{font-size:var(--text-3xl);letter-spacing:-.03em;margin-bottom:var(--space-1);background:linear-gradient(135deg, var(--text-primary) 40%, var(--accent-primary) 100%);-webkit-text-fill-color:transparent;background-clip:text;font-weight:700}.tournament-page__subtitle{color:var(--text-secondary);font-size:var(--text-sm)}.tournament-create-btn{padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-primary), #0da6f2);color:var(--text-inverse);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-glow-cyan);white-space:nowrap;border:none;font-weight:600}.tournament-create-btn:hover{filter:brightness(1.15);transform:translateY(-1px);box-shadow:0 0 28px #25d1f459}.tournament-grid{gap:var(--space-5);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.tournament-card{padding:var(--space-5) var(--space-6);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);gap:var(--space-3);flex-direction:column;display:flex;position:relative;overflow:hidden}.tournament-card:before{content:"";opacity:0;transition:opacity var(--duration-normal) var(--ease-out);pointer-events:none;background:linear-gradient(135deg,#25d1f408 0%,#0000 60%);position:absolute;inset:0}.tournament-card:hover{border-color:var(--accent-primary-dim);box-shadow:var(--shadow-lg), var(--shadow-glow-cyan);transform:translateY(-2px)}.tournament-card:hover:before{opacity:1}.tournament-card__status{align-self:flex-start}.tournament-card__name{font-size:var(--text-lg);letter-spacing:-.01em;color:var(--text-primary);font-weight:700;line-height:1.3}.tournament-card__meta{gap:var(--space-3);flex-wrap:wrap;display:flex}.tournament-card__meta-item{align-items:center;gap:var(--space-1);font-size:var(--text-xs);color:var(--text-secondary);font-weight:500;display:flex}.tournament-card__meta-icon{font-size:14px;line-height:1}.tournament-card__footer{padding-top:var(--space-3);border-top:1px solid var(--surface-4);justify-content:space-between;align-items:center;margin-top:auto;display:flex}.tournament-card__players,.tournament-card__rounds{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);align-items:center;gap:var(--space-1);display:flex}.tournament-badge{padding:2px var(--space-3);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.08em;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.tournament-badge--upcoming{color:var(--accent-warning);background:#f4a8251f;border:1px solid #f4a82540}.tournament-badge--active{color:var(--accent-primary);background:#25d1f41f;border:1px solid #25d1f440;animation:2.5s ease-in-out infinite badge-pulse}@keyframes badge-pulse{0%,to{box-shadow:0 0 #25d1f426}50%{box-shadow:0 0 10px 2px #25d1f440}}.tournament-badge--completed{color:var(--accent-success);background:#28bd661f;border:1px solid #28bd6640}.tournament-card--skeleton{pointer-events:none;min-height:140px}.skeleton-line{border-radius:var(--radius-sm);background:linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);background-size:200% 100%;height:14px;animation:1.8s ease-in-out infinite skeleton-shimmer}.skeleton-line--title{width:70%;height:18px;margin-bottom:var(--space-3)}.skeleton-line--short{width:40%;margin-bottom:var(--space-2)}.skeleton-line--medium{width:55%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.tournament-empty{padding:var(--space-16);text-align:center;color:var(--text-secondary);justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;grid-column:1/-1;display:flex}.tournament-empty__icon{opacity:.4;font-size:3rem}.tournament-back-link{align-items:center;gap:var(--space-1);color:var(--accent-primary);font-size:var(--text-sm);margin-bottom:var(--space-4);transition:opacity var(--duration-fast) var(--ease-out);font-weight:500;text-decoration:none;display:inline-flex}.tournament-back-link:hover{opacity:.75}.tournament-detail-header{padding:var(--space-6) var(--space-8);justify-content:space-between;align-items:flex-start;gap:var(--space-6);margin-bottom:var(--space-6);flex-wrap:wrap;display:flex}.tournament-detail-header__name{font-size:var(--text-2xl);letter-spacing:-.02em;margin-bottom:var(--space-3);font-weight:700}.tournament-detail-header__meta{gap:var(--space-3);flex-wrap:wrap;align-items:center;display:flex}.tournament-detail-meta-tag{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--surface-2);font-size:var(--text-xs);color:var(--text-secondary);border:1px solid var(--surface-4);font-weight:500;display:inline-flex}.tournament-detail-header__actions{gap:var(--space-3);flex-wrap:wrap;align-items:center;display:flex}.tournament-register-btn{padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-primary), #0da6f2);color:var(--text-inverse);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;font-weight:600}.tournament-register-btn:hover{filter:brightness(1.1);box-shadow:var(--shadow-glow-cyan)}.tournament-register-btn:disabled{opacity:.6;cursor:not-allowed}.tournament-registered-badge{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);color:var(--accent-success);font-size:var(--text-xs);background:#28bd661f;border:1px solid #28bd6640;font-weight:600}.tournament-export-btn{padding:var(--space-2) var(--space-4);border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-xs);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap;font-weight:500}.tournament-export-btn:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--accent-primary-dim)}.tournament-detail-columns{gap:var(--space-5);grid-template-columns:1fr 1fr;align-items:start;display:grid}.tournament-detail-section .widget{overflow:hidden}.tournament-table-wrapper{scrollbar-width:thin;scrollbar-color:var(--surface-3) transparent;overflow-x:auto}.tournament-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.tournament-table thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;border-bottom:2px solid var(--surface-4);white-space:nowrap;background:var(--glass-bg);z-index:1;font-weight:700;position:sticky;top:0}.tournament-table tbody tr{transition:background var(--duration-fast) var(--ease-out)}.tournament-table tbody tr:nth-child(2n){background:#1d202a66}.tournament-table tbody tr:hover{background:#40aabf0f}.tournament-table td{padding:var(--space-3) var(--space-4);white-space:nowrap;border-bottom:1px solid #ffffff08}.tournament-rank{color:var(--text-tertiary);text-align:center;width:36px;font-weight:700}.tournament-player-name{color:var(--text-primary);font-weight:600}.tournament-score{color:var(--accent-primary);font-weight:700}.tournament-pairings{flex-direction:column;gap:2px;display:flex}.tournament-pairing{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);transition:background var(--duration-fast) var(--ease-out);display:flex}.tournament-pairing:hover{background:var(--surface-2)}.tournament-pairing--active{border-left:3px solid var(--accent-primary);background:#40aabf0f}.tournament-pairing--completed{opacity:.7}.tournament-pairing--bye{opacity:.6;font-style:italic}.tournament-pairing__board{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);text-align:center;min-width:24px;padding:2px var(--space-2);background:var(--surface-2);border-radius:4px;font-weight:700}.tournament-pairing__matchup{align-items:center;gap:var(--space-2);flex:1;min-width:0;display:flex}.tournament-pairing__player{align-items:center;gap:var(--space-2);font-size:var(--text-sm);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-weight:500;display:flex;overflow:hidden}.tournament-pairing__player--white{text-align:right;justify-content:flex-end}.tournament-pairing__player--black{justify-content:flex-start}.tournament-pairing__color-dot{border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;width:10px;height:10px}.tournament-pairing__color-dot--white{background:#e8e0d0}.tournament-pairing__color-dot--black{background:#2a2520}.tournament-pairing__vs{color:var(--text-tertiary);text-transform:uppercase;padding:0 var(--space-1);flex-shrink:0;font-size:10px;font-weight:700}.tournament-pairing__rating{font-family:var(--font-mono);color:var(--text-tertiary);flex-shrink:0;font-size:10px}.tournament-pairing__result{font-family:var(--font-mono);font-size:var(--text-xs);padding:2px var(--space-3);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;font-weight:700}.tournament-result--decisive{color:var(--accent-primary);background:#25d1f41f}.tournament-result--draw{color:var(--accent-warning);background:#f4a8251f}.tournament-result--live{color:var(--accent-success);background:#28bd661f;animation:2.5s ease-in-out infinite badge-pulse}.tournament-result--scheduled{color:var(--text-tertiary)}.tournament-result--bye{background:var(--surface-2);color:var(--text-tertiary)}.tournament-detail-loading{padding:var(--space-16);justify-content:center;align-items:center;gap:var(--space-4);color:var(--text-secondary);flex-direction:column;display:flex}.tournament-spinner{border:3px solid var(--surface-4);border-top-color:var(--accent-primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tournament-create-container{padding:var(--space-8) 0;justify-content:center;display:flex}.tournament-create-card{width:100%;max-width:560px;padding:var(--space-8)}.tournament-create-card__title{font-size:var(--text-2xl);letter-spacing:-.02em;margin-bottom:var(--space-2);font-weight:700}.tournament-create-card__subtitle{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-8)}.tournament-form{gap:var(--space-5);flex-direction:column;display:flex}.tournament-form__group{gap:var(--space-2);flex-direction:column;display:flex}.tournament-form__row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.tournament-form__label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.tournament-form__input,.tournament-form__select{padding:var(--space-3) var(--space-4);border:1px solid var(--surface-4);border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);transition:border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);outline:none}.tournament-form__input:focus,.tournament-form__select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #25d1f41a}.tournament-form__select{appearance:none;cursor:pointer;padding-right:var(--space-8);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%23666' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat}.tournament-form__select option{background:var(--surface-1);color:var(--text-primary)}.tournament-form__error{padding:var(--space-3) var(--space-4);border-radius:var(--radius-sm);color:var(--accent-danger);font-size:var(--text-xs);background:#e236361a;border:1px solid #e2363633}.tournament-form__submit{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--accent-primary), #0da6f2);color:var(--text-inverse);font-family:var(--font-sans);font-size:var(--text-base);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);margin-top:var(--space-4);border:none;font-weight:600;display:flex}.tournament-form__submit:hover{filter:brightness(1.1);box-shadow:var(--shadow-glow-cyan);transform:translateY(-1px)}.tournament-form__submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.tournament-form__submit-icon{font-size:var(--text-lg)}@media (width<=768px){.tournament-grid,.tournament-detail-columns{grid-template-columns:1fr}.tournament-detail-header{padding:var(--space-4) var(--space-5);flex-direction:column}.tournament-detail-header__actions{justify-content:flex-start;width:100%}.tournament-form__row{grid-template-columns:1fr}.tournament-page__header{gap:var(--space-3);flex-direction:column}.tournament-create-card{padding:var(--space-5)}.tournament-pairing__matchup{align-items:stretch;gap:var(--space-1);flex-direction:column}.tournament-pairing__player--white{text-align:left;justify-content:flex-start}.tournament-pairing__vs{text-align:center;padding:0}}@media (width<=480px){.tournament-page{padding:var(--space-4) var(--space-3) var(--space-12)}.tournament-page__title{font-size:var(--text-2xl)}.tournament-card{padding:var(--space-4)}}.auth-error-card{text-align:center;padding:var(--space-4) 0;animation:fadeInUpBounce .6s var(--ease-out) both}.auth-error-card__icon{margin-bottom:var(--space-3);font-size:3rem;animation:2s ease-in-out infinite pawnPulse;display:inline-block}.auth-error-card__title{font-size:var(--text-lg);color:var(--accent-primary);margin-bottom:var(--space-2);font-weight:700}.auth-error-card__subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-5);line-height:1.5}.auth-error-card__scoresheet{border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-4);margin-bottom:var(--space-5);gap:var(--space-3);background:#ffffff08;flex-direction:column;display:flex}.scoresheet-row{align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-primary);text-align:left;font-weight:500;display:flex}.scoresheet-icon{font-size:var(--text-base)}.auth-error-card__copy{font-size:var(--text-xs);color:var(--text-secondary);margin-bottom:var(--space-5);line-height:1.6}.auth-error-card__cta{transition:all var(--duration-fast) var(--ease-out);box-shadow:0 0 15px #e65c0033}.auth-error-card__cta:hover{transform:translateY(-2px);box-shadow:0 0 25px #e65c0066}@keyframes fadeInUpBounce{0%{opacity:0;transform:translateY(20px)scale(.95)}60%{opacity:1;transform:translateY(-4px)scale(1.01)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes pawnPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.fanfare-overlay{background:var(--surface-0);z-index:20000;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0;overflow:hidden}.fanfare-grid{pointer-events:none;background-image:linear-gradient(#00d4ff0a 1px,#0000 1px),linear-gradient(90deg,#00d4ff0a 1px,#0000 1px);background-size:50px 50px;animation:20s linear infinite gridMove;position:absolute;inset:-100px;transform:perspective(500px)rotateX(60deg)translateY(0)}@keyframes gridMove{0%{transform:perspective(500px)rotateX(60deg)translateY(0)}to{transform:perspective(500px)rotateX(60deg)translateY(50px)}}.fanfare-glow{pointer-events:none;background:radial-gradient(circle at 30% 30%,#00d4ff1f 0%,#0000 60%),radial-gradient(circle at 70% 70%,#ffaa0014 0%,#0000 60%);position:absolute;inset:0}.fanfare-canvas{pointer-events:none;z-index:1;position:absolute;inset:0}.fanfare-card{z-index:2;background:var(--glass-bg);width:420px;max-width:90%;-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-xl), 0 0 30px #00d4ff1a;text-align:center}.fanfare-card__terminal{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--accent-primary);text-align:left;opacity:1;max-height:200px;line-height:1.6;transition:opacity .2s;overflow-y:auto}.terminal-line{margin-bottom:var(--space-2);white-space:pre-wrap;animation:.2s ease-out forwards typeLine}@keyframes typeLine{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.fanfare-card__main{text-align:center}.fanfare-card__icon{margin-bottom:var(--space-4);font-size:3rem;animation:1.5s ease-in-out infinite fanfareHeartbeat;display:inline-block}@keyframes fanfareHeartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.15)rotate(5deg)}}.fanfare-card__title{font-size:var(--text-lg);letter-spacing:-.01em;color:var(--text-primary);margin-bottom:var(--space-1);font-weight:800}.fanfare-card__name{font-size:var(--text-xl);color:var(--accent-primary);margin-bottom:2px;font-weight:700}.fanfare-card__username{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-4)}.fanfare-card__status{border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--accent-primary);margin-bottom:var(--space-6);background:#00d4ff14;border:1px solid #00d4ff33;align-items:center;gap:8px;padding:4px 14px;font-weight:600;display:inline-flex}.status-pulse{background:var(--accent-primary);width:8px;height:8px;box-shadow:0 0 8px var(--accent-primary);border-radius:50%;animation:1.5s ease-in-out infinite statusBlink}@keyframes statusBlink{0%,to{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.fanfare-card__progress{border-radius:var(--radius-full);background:#ffffff0f;width:100%;height:4px;overflow:hidden}.fanfare-card__progress-fill{background:linear-gradient(90deg, var(--accent-primary), var(--accent-secondary));border-radius:var(--radius-full);width:0%;height:100%;transition:width 2.2s cubic-bezier(.16,1,.3,1)}.account-page{animation:fadeInPage .4s var(--ease-out) forwards}@keyframes fadeInPage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rating-box{background:var(--surface-1);box-shadow:var(--shadow-md)}.rating-box:hover{transform:translateY(-2px);background:#ffffff05!important}.cas-ring{transform:scaleX(-1)rotate(-90deg)}.board-wrapper{width:var(--board-size);height:var(--board-size);position:relative}.board-pause-overlay{-webkit-backdrop-filter:blur(12px);z-index:100;border-radius:var(--radius-md);border:1px solid var(--surface-4);width:100%;height:100%;color:var(--text-primary);text-align:center;padding:var(--space-6);box-sizing:border-box;background:#0a0818e6;flex-direction:column;justify-content:center;align-items:center;animation:.3s cubic-bezier(.16,1,.3,1) forwards overlayFadeIn;display:flex;position:absolute;top:0;left:0}@keyframes overlayFadeIn{0%{opacity:0;backdrop-filter:blur()}to{opacity:1;backdrop-filter:blur(12px)}}.board-pause-overlay__content{align-items:center;gap:var(--space-4);flex-direction:column;max-width:80%;display:flex}.board-pause-overlay__title{font-family:var(--font-display);font-size:var(--text-4xl);letter-spacing:.1em;color:var(--accent-primary);text-shadow:0 0 20px #7d44ff99,0 0 40px #7d44ff4d;font-weight:800;animation:2s ease-in-out infinite textPulse}@keyframes textPulse{0%,to{filter:brightness();transform:scale(1)}50%{filter:brightness(1.2);transform:scale(1.03)}}.board-pause-overlay__reason{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.board-pause-overlay__btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border:2px solid var(--accent-primary);border-radius:var(--radius-md);background:var(--accent-primary-dim);color:var(--accent-primary);font-family:var(--font-sans);font-size:var(--text-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);font-weight:700;display:flex;box-shadow:0 0 15px #7d44ff33}.board-pause-overlay__btn:hover{background:var(--accent-primary);color:var(--text-inverse);transform:translateY(-2px);box-shadow:0 0 25px #7d44ff99}.board-pause-overlay__btn:active{transform:translateY(0)}.board-pause-overlay__note{font-size:var(--text-xs);color:var(--text-muted);max-width:250px;margin-top:var(--space-4);opacity:.8;line-height:1.4}.pause-control-panel{padding:var(--space-3) var(--space-4);border-top:1px solid var(--surface-4);justify-content:space-between;align-items:center;gap:var(--space-3);background:#ffffff05;display:flex}.pause-btn{align-items:center;gap:var(--space-2);padding:6px var(--space-3);border:1px solid var(--accent-primary-dim);border-radius:var(--radius-sm);color:var(--accent-primary);font-family:var(--font-sans);font-size:var(--text-xs);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);background:#7d44ff14;font-weight:600;display:flex}.pause-btn:hover:not(:disabled){background:var(--accent-primary);color:var(--text-inverse);box-shadow:0 0 12px #7d44ff4d}.pause-btn:disabled{opacity:.4;cursor:not-allowed;border-color:var(--surface-4);background:var(--surface-2);color:var(--text-muted)}.pause-lives{align-items:center;gap:6px;display:flex}.pause-life-icon{filter:drop-shadow(0 0 5px #ff4a4a99);font-size:16px;transition:all .5s cubic-bezier(.175,.885,.32,1.275);display:inline-block}.pause-life-icon.used{opacity:0;margin-right:-18px;transform:scale(0)rotate(45deg)}.pause-auto-info{color:var(--text-muted);text-align:right;max-width:150px;font-size:10px;line-height:1.3}.piece[data-color=w]{filter:url(#svg-white-piece-outline)!important}.piece[data-color=b]{filter:url(#svg-black-piece-outline)!important}.ui-theme-carbon{--surface-0:#0c0d0f;--surface-1:#121417;--surface-2:#181b20;--surface-3:#20242b;--surface-4:#1d2026;--glass-bg:#121417b3;--glass-border:#1d202680;--text-primary:#e8eaf0;--text-secondary:#a0a5b5}.ui-theme-copper{--surface-0:#020a0b;--surface-1:#051517;--surface-2:#092023;--surface-3:#12383c;--surface-4:#0f2d30;--glass-bg:#051517b3;--glass-border:#0f2d3080;--text-primary:#e0f2f1;--text-secondary:#80cbc4}.ui-theme-cobalt{--surface-0:#050810;--surface-1:#0a1020;--surface-2:#0f1730;--surface-3:#1b2950;--surface-4:#142240;--glass-bg:#0a1020b3;--glass-border:#14224080;--text-primary:#e3f2fd;--text-secondary:#90caf9}.ui-theme-orange{--surface-0:#0f0f0d;--surface-1:#171714;--surface-2:#20201c;--surface-3:#35352e;--surface-4:#2a2a24;--glass-bg:#171714b3;--glass-border:#2a2a2480;--text-primary:#fff8e1;--text-secondary:#ffe082}.ui-theme-amethyst{--surface-0:#07020f;--surface-1:#100524;--surface-2:#180835;--surface-3:#2a0f5a;--surface-4:#200a40;--glass-bg:#100524b3;--glass-border:#200a4080;--text-primary:#f3e5f5;--text-secondary:#ce93d8}.ui-theme-laser{--surface-0:#090312;--surface-1:#150821;--surface-2:#200c32;--surface-3:#3c145e;--surface-4:#2d0b4a;--glass-bg:#150821b3;--glass-border:#2d0b4a80;--text-primary:#fae8ff;--text-secondary:#f3d9fa}.ui-theme-plum{--surface-0:#110c18;--surface-1:#1b1424;--surface-2:#251c32;--surface-3:#403154;--surface-4:#31273d;--glass-bg:#1b1424b3;--glass-border:#31273d80;--text-primary:#f5f3f7;--text-secondary:#dcd7e3}.ui-theme-void{--surface-0:#040108;--surface-1:#0a0414;--surface-2:#120724;--surface-3:#220d44;--surface-4:#18082e;--glass-bg:#0a0414b3;--glass-border:#18082e80;--text-primary:#f1ecf7;--text-secondary:#d1c4e9}.board-theme-carbon_synth{--board-light:#0f8;--board-dark:#151618;--accent-primary:#0f8;--piece-white-color:#e5ffef;--piece-black-color:#08090a;--piece-white-outline:#08090a;--piece-black-outline:#0f8}.board-theme-hyper_cobalt{--board-light:#cde8ff;--board-dark:#0a1c3d;--accent-primary:#2979ff;--piece-white-color:#e3f2fd;--piece-black-color:#020408;--piece-white-outline:#020408;--piece-black-outline:#2979ff}.board-theme-oxidized_copper{--board-light:#ff7043;--board-dark:#005c53;--accent-primary:#ff7043;--piece-white-color:#ffefe0;--piece-black-color:#010606;--piece-white-outline:#010606;--piece-black-outline:#ff7043}.board-theme-cyber_orange{--board-light:#ffe082;--board-dark:#3e2723;--accent-primary:#ffb300;--piece-white-color:#fffdf0;--piece-black-color:#0b0705;--piece-white-outline:#0b0705;--piece-black-outline:#ffb300}.board-theme-neon_amethyst{--board-light:#e4ff3a;--board-dark:#2b005c;--accent-primary:#e4ff3a;--piece-white-color:#f9f0ff;--piece-black-color:#06020c;--piece-white-outline:#06020c;--piece-white-stroke:#06020c;--piece-black-outline:#e4ff3a;--piece-black-stroke:#e4ff3a}.board-theme-orchid_laser{--board-light:#00e5ff;--board-dark:#3d0c5a;--accent-primary:#00e5ff;--piece-white-color:#f0fdff;--piece-black-color:#08010c;--piece-white-outline:#08010c;--piece-white-stroke:#08010c;--piece-black-outline:#00e5ff;--piece-black-stroke:#00e5ff}.board-theme-plum_phantom{--board-light:#e0e0e0;--board-dark:#321e42;--accent-primary:#e0e0e0;--piece-white-color:#fff;--piece-black-color:#0c0612;--piece-white-outline:#0c0612;--piece-white-stroke:#0c0612;--piece-black-outline:#e0e0e0;--piece-black-stroke:#e0e0e0}.board-theme-violet_void{--board-light:#0f6;--board-dark:#18032e;--accent-primary:#0f6;--piece-white-color:#e8ffe8;--piece-black-color:#04000a;--piece-white-outline:#04000a;--piece-white-stroke:#04000a;--piece-black-outline:#0f6;--piece-black-stroke:#0f6}.board-lockout-overlay{-webkit-backdrop-filter:blur(12px);z-index:100;border-radius:var(--radius-md);padding:var(--space-6);text-align:center;background:#0a0e1ad9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.board-lockout-overlay__content{align-items:center;gap:var(--space-4);flex-direction:column;max-width:420px;animation:.4s cubic-bezier(.16,1,.3,1) modalSlideIn;display:flex}.board-lockout-overlay__icon{filter:drop-shadow(0 0 10px var(--accent-danger,#f50));font-size:3.5rem}.board-lockout-overlay__title{font-size:var(--text-lg);color:var(--text-primary);letter-spacing:.05em;text-transform:uppercase;font-weight:700}.board-lockout-overlay__desc{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.board-lockout-overlay__btn{width:100%;padding:var(--space-3) var(--space-4);background:var(--accent-primary,#0f8);color:var(--text-inverse,#0c0d0f);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);border:none;font-weight:600}.board-lockout-overlay__btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0f86}.board-lockout-overlay__btn--secondary{color:var(--text-primary);border:1px solid var(--surface-4);background:0 0;margin-top:-6px}.board-lockout-overlay__btn--secondary:hover{background:var(--surface-2);box-shadow:none}.board-lockout-overlay__status{font-size:var(--text-xs);min-height:1.25rem;font-weight:500}.captcha-overlay{-webkit-backdrop-filter:blur(8px);z-index:11000;background:#040208cc;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.captcha-modal{width:380px;padding:var(--space-6);border-radius:var(--radius-lg);align-items:center;gap:var(--space-5);box-shadow:var(--shadow-xl);flex-direction:column;display:flex}.captcha-modal__header{text-align:center}.captcha-modal__title{font-size:var(--text-base);letter-spacing:.05em;color:var(--text-primary);margin-bottom:var(--space-2);font-weight:700}.captcha-modal__subtitle{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.4}.captcha-board{border:4px solid var(--surface-4);border-radius:var(--radius-md);box-shadow:var(--shadow-md);grid-template-rows:repeat(4,60px);grid-template-columns:repeat(4,60px);display:grid;overflow:hidden}.captcha-square{cursor:pointer;justify-content:center;align-items:center;width:60px;height:60px;display:flex;position:relative}.captcha-square--light{background:var(--board-light,#0f8);opacity:.85}.captcha-square--dark{background:var(--board-dark,#151618)}.captcha-square--target{background:#ff550026}.captcha-target-indicator{border:3px dashed var(--accent-danger,#f50);border-radius:50%;width:24px;height:24px;animation:8s linear infinite spin}.captcha-piece{cursor:grab;z-index:10;justify-content:center;align-items:center;width:100%;height:100%;transition:transform .2s;display:flex}.captcha-piece--selected{filter:drop-shadow(0 0 12px var(--accent-primary,#0f8));transform:scale(1.15)}.captcha-modal__status{font-size:var(--text-xs);text-align:center;min-height:var(--space-5);font-weight:600}.captcha-modal__actions{width:100%}.captcha-modal__btn-cancel{width:100%;padding:var(--space-3);color:var(--text-secondary);border:1px solid var(--surface-4);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast);background:0 0;font-weight:600}.captcha-modal__btn-cancel:hover{background:var(--surface-2);color:var(--text-primary)}.board-theme-neon_amethyst .piece[data-color=w],.board-theme-neon_amethyst .piece[data-color=b]{--piece-outline-outer:var(--accent-primary,#e4ff3a);--piece-outline-inner:#06020c;filter:url(#svg-double-outline)!important}.board-theme-orchid_laser .piece[data-color=w],.board-theme-orchid_laser .piece[data-color=b]{--piece-outline-outer:var(--accent-primary,#00e5ff);--piece-outline-inner:#08010c;filter:url(#svg-double-outline)!important}.board-theme-plum_phantom .piece[data-color=w],.board-theme-plum_phantom .piece[data-color=b]{--piece-outline-outer:var(--accent-primary,#e0e0e0);--piece-outline-inner:#0c0612;filter:url(#svg-double-outline)!important}.board-theme-violet_void .piece[data-color=w],.board-theme-violet_void .piece[data-color=b]{--piece-outline-outer:var(--accent-primary,#0f6);--piece-outline-inner:#04000a;filter:url(#svg-double-outline)!important}.curator-container{gap:var(--space-5);max-width:1400px;padding:var(--space-5);box-sizing:border-box;flex-direction:column;min-height:100vh;margin:0 auto;display:flex}.curator-header{padding:var(--space-5) var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);justify-content:space-between;align-items:center;display:flex}.curator-header__title{font-size:var(--text-xl);color:var(--text-primary);margin:0 0 var(--space-1) 0;letter-spacing:-.02em;font-weight:800}.curator-header__subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin:0}.curator-header__actions{gap:var(--space-3);display:flex}.curator-btn{padding:var(--space-2-5) var(--space-4);font-size:var(--text-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);align-items:center;gap:var(--space-2);border:1px solid #0000;font-weight:600;display:inline-flex}.curator-btn--primary{background:var(--accent-primary,#0f8);color:var(--text-inverse,#0c0d0f)}.curator-btn--primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px #00ff8859}.curator-btn--secondary{color:var(--text-primary);border:1px solid var(--surface-4);background:0 0}.curator-btn--secondary:hover{background:var(--surface-2);border-color:var(--text-secondary)}.curator-btn--success{background:var(--accent-success,#0f6);color:#04000a}.curator-btn--success:hover{box-shadow:0 4px 12px #00ff664d}.curator-btn--danger{background:var(--accent-danger,#f50);color:var(--text-primary)}.curator-btn--danger:hover{box-shadow:0 4px 12px #ff55004d}.curator-workspace{gap:var(--space-5);grid-template-columns:280px 1fr 400px;align-items:start;display:grid}.curator-sidebar{gap:var(--space-4);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--glass-bg);flex-direction:column;height:600px;display:flex;overflow-y:auto}.curator-section-title{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin:0 0 var(--space-3) 0;border-bottom:1px solid var(--surface-4);padding-bottom:var(--space-2);font-weight:700}.curator-list{gap:var(--space-2);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.curator-item{padding:var(--space-3);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast) ease;background:#ffffff05;border:1px solid #0000;justify-content:space-between;align-items:center;display:flex}.curator-item:hover{background:var(--surface-2);border-color:var(--surface-4)}.curator-item--active{background:var(--surface-3)!important;border-color:var(--accent-primary,#0f8)!important}.curator-item__name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.status-badge{text-transform:uppercase;padding:var(--space-1) var(--space-2);border-radius:var(--radius-xs);letter-spacing:.02em;font-size:10px;font-weight:700}.status-badge--pending{color:#ffb300;background:#ffb30026;border:1px solid #ffb3004d}.status-badge--approved{color:var(--accent-primary,#0f8);background:#00ff8826;border:1px solid #00ff884d}.status-badge--denied{color:var(--accent-danger,#f50);background:#ff550026;border:1px solid #ff55004d}.curator-preview-panel{align-items:center;gap:var(--space-4);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--glass-bg);flex-direction:column;min-height:600px;display:flex}.curator-board-legend{gap:var(--space-4);font-size:var(--text-xs);color:var(--text-secondary);flex-wrap:wrap;justify-content:center;display:flex}.legend-item{align-items:center;gap:var(--space-1-5);display:flex}.legend-dot{border-radius:50%;width:12px;height:12px;display:inline-block}.curator-controls{gap:var(--space-4);padding:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--glass-bg);flex-direction:column;min-height:600px;display:flex}.curator-status-banner{padding:var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-xs);align-items:center;gap:var(--space-2);display:flex}.curator-status-banner--pending{color:#ffe082;background:#ffb3001a;border:1px solid #ffb30033}.curator-status-banner--approved{color:var(--accent-primary,#0f8);background:#00ff881a;border:1px solid #0f83}.curator-status-banner--denied{color:#ffab91;background:#ff55001a;border:1px solid #f503}.curator-form{gap:var(--space-4);flex-direction:column;flex-grow:1;display:flex}.form-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.form-group{gap:var(--space-1-5);flex-direction:column;display:flex}.form-group label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:700}.color-picker-wrapper{align-items:center;gap:var(--space-2);background:var(--surface-1);border:1px solid var(--surface-4);border-radius:var(--radius-sm);padding:var(--space-2);display:flex}.color-picker-wrapper input[type=color]{-webkit-appearance:none;border-radius:var(--radius-xs);cursor:pointer;background:0 0;border:none;width:28px;height:28px;padding:0}.color-picker-wrapper input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-picker-wrapper input[type=color]::-webkit-color-swatch{border:1px solid var(--surface-4);border-radius:var(--radius-xs)}.hex-label{font-size:var(--text-xs);color:var(--text-primary);font-family:monospace;font-weight:600}.form-sliders{gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--surface-4);flex-direction:column;display:flex}.slider-group{gap:var(--space-1);flex-direction:column;display:flex}.slider-label-row{font-size:var(--text-xs);justify-content:space-between;font-weight:600;display:flex}.slider-group label{color:var(--text-secondary)}.slider-val{color:var(--accent-primary,#0f8);font-family:monospace}.slider-group input[type=range]{width:100%;accent-color:var(--accent-primary,#0f8);background:var(--surface-1);border-radius:var(--radius-xs);outline:none;height:6px}.curator-decisions{gap:var(--space-2);padding-top:var(--space-4);border-top:1px solid var(--surface-4);flex-direction:column;margin-top:auto;display:flex}.curator-decisions button{justify-content:center;width:100%}.curator-modal-overlay{-webkit-backdrop-filter:blur(12px);z-index:12000;padding:var(--space-4);background:#040208d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.curator-modal{width:600px;max-width:100%;padding:var(--space-6);border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--glass-bg);box-shadow:var(--shadow-2xl);gap:var(--space-4);flex-direction:column;display:flex}.curator-modal__header{justify-content:space-between;align-items:center;display:flex}.curator-modal__header h4{font-size:var(--text-md);color:var(--text-primary);margin:0;font-weight:800}.curator-modal__close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:24px;line-height:1}.curator-modal__close:hover{color:var(--text-primary)}.curator-modal__desc{font-size:var(--text-xs);color:var(--text-secondary);margin:0;line-height:1.4}.curator-modal__json{background:var(--surface-0);border:1px solid var(--surface-4);border-radius:var(--radius-sm);width:100%;height:250px;padding:var(--space-3);color:var(--text-primary);resize:none;box-sizing:border-box;outline:none;font-family:monospace;font-size:11px}.curator-modal__footer{justify-content:flex-end;gap:var(--space-2);display:flex}.modal--settings{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);grid-template-rows:auto auto 1fr auto;display:grid}.settings-tabs{gap:var(--space-4);padding:0 var(--space-6);border-bottom:1px solid var(--surface-4);background:#0003;display:flex}.settings-tab-btn{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);background:0 0;border:none;border-bottom:2px solid #0000;outline:none;font-weight:700}.settings-tab-btn:hover{color:var(--text-primary)}.settings-tab-btn--active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.settings-content{padding:var(--space-6);gap:var(--space-6);flex-direction:column;display:flex;overflow-y:auto}.settings-tab-content{animation:fadeIn var(--duration-normal) var(--ease-out)}.skin-upload__btn{text-align:center;border:1px dashed var(--accent-primary);padding:var(--space-2-5);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out);background:#ffffff05;font-weight:700;display:block}.skin-upload__btn:hover{border-color:var(--accent-primary-hover,#00ffa3);background:#00ff880d;box-shadow:0 0 10px #00ff8826}input[type=range]{-webkit-appearance:none;border-radius:var(--radius-full);background:var(--surface-4);width:100%;height:6px;margin:var(--space-2) 0;transition:background var(--duration-fast);outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent-primary);cursor:pointer;width:16px;height:16px;box-shadow:0 0 8px var(--accent-primary-dim);transition:transform var(--duration-fast) var(--ease-out), background-color var(--duration-fast);border-radius:50%}input[type=range]::-webkit-slider-thumb:hover{background:var(--accent-primary-hover,#00ffa3);transform:scale(1.2)}.curator-board-container{background:var(--surface-0);padding:var(--space-2);border-radius:var(--radius-md);border:1px solid var(--surface-4);box-shadow:var(--shadow-lg);justify-content:center;align-items:center;display:flex}.curator-board{aspect-ratio:1;border-radius:var(--radius-sm);grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);width:100%;max-width:416px;display:grid;overflow:hidden}.curator-square{aspect-ratio:1;justify-content:center;align-items:center;display:flex;position:relative}.curator-square--light{background-color:var(--board-light)}.curator-square--dark{background-color:var(--board-dark)}.curator-square .piece{cursor:default;user-select:none;pointer-events:none;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;width:80%;height:80%;display:flex}.curator-square .piece:hover{transform:none}.nav-profile__btn-settings:hover{transform:rotate(45deg);box-shadow:0 0 8px #00ff884d;color:var(--accent-primary)!important;border-color:var(--accent-primary)!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.dungeon-container{gap:var(--space-4);width:100%;height:100%;padding:var(--space-4);box-sizing:border-box;display:flex}.dungeon-board{aspect-ratio:1;border:2px solid var(--border-color);border-radius:var(--radius-md);grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);height:100%;max-height:80vh;display:grid;overflow:hidden;box-shadow:0 10px 30px #00000080}.dungeon-square{background-size:cover;justify-content:center;align-items:center;transition:all .2s ease-in-out;display:flex;position:relative}.dungeon-square[data-terrain=stone]{background-color:#2c303a}.dungeon-square[data-terrain=stone]:nth-child(odd){background-color:#353945}.dungeon-square[data-terrain=lava]{background-color:#5c1818;animation:2s infinite alternate lava-pulse;box-shadow:inset 0 0 15px #ff4500}.dungeon-square[data-terrain=water]{background-color:#1c3d5a;box-shadow:inset 0 0 10px #3182ce}.dungeon-square[data-terrain=mystic]{background-color:#4a1c5a;box-shadow:inset 0 0 12px #9f7aea}.dungeon-square[data-terrain=chamber]{background-color:#5a4a1c;border:1px dashed gold;box-shadow:inset 0 0 15px #ffd70066}.dungeon-square[data-terrain=wall]{background-color:#1a1a1a;background-image:repeating-linear-gradient(45deg,#222 25%,#0000 25% 75%,#222 75%,#222),repeating-linear-gradient(45deg,#222 25%,#1a1a1a 25% 75%,#222 75%,#222);background-position:0 0,10px 10px;background-size:20px 20px;border:1px solid #333}.dungeon-square--fog:after{content:"";backdrop-filter:blur(8px);z-index:10;pointer-events:none;background:#0a0e1af2;position:absolute;inset:0}.dungeon-piece{z-index:5;filter:drop-shadow(0 4px 6px #00000080);width:80%;height:80%}.dungeon-monster{z-index:5;filter:drop-shadow(0 4px 6px #00000080);user-select:none;font-size:32px}.dungeon-boss{z-index:5;filter:drop-shadow(0 0 12px #f0f);user-select:none;font-size:40px;animation:1.5s infinite alternate boss-pulse}.dungeon-hp-container{z-index:6;background:#0009;border:1px solid #ffffff1a;border-radius:2px;width:80%;height:4px;position:absolute;bottom:4px;left:10%;overflow:hidden}.dungeon-hp-bar{background:linear-gradient(90deg,#ff4500,#32cd32);height:100%;transition:width .3s}.dungeon-status-badge{z-index:6;font-size:11px;position:absolute;top:2px;right:2px}.dungeon-hot-potato{color:#ff4500;z-index:6;background:#000000b3;border:1px solid #ff4500;border-radius:4px;padding:1px 4px;font-size:12px;font-weight:700;animation:1s infinite alternate potato-bounce;position:absolute;top:2px;left:2px}.dungeon-sidebar{gap:var(--space-4);flex-direction:column;width:320px;display:flex}.dungeon-piece-profile h3{color:var(--accent-primary);margin-bottom:var(--space-2)}.dungeon-piece-profile p{font-size:var(--text-sm);color:var(--text-secondary);margin:var(--space-1) 0}.dungeon-log{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-3);gap:var(--space-2);flex-direction:column;flex:1;display:flex}.dungeon-log h4{border-bottom:1px solid var(--border-color);margin:0;padding-bottom:4px}.dungeon-log div{color:var(--text-secondary);font-family:monospace;font-size:11px;line-height:1.4}@keyframes lava-pulse{0%{box-shadow:inset 0 0 10px #ff4500}to{box-shadow:inset 0 0 25px #ff8c00}}@keyframes boss-pulse{0%{filter:drop-shadow(0 0 8px #f0f);transform:scale(1)}to{filter:drop-shadow(0 0 20px #e02424);transform:scale(1.1)}}@keyframes potato-bounce{0%{transform:translateY(0)}to{transform:translateY(-4px)}}.dungeon-float-text{font-weight:700;font-size:var(--text-sm);z-index:100;pointer-events:none;animation:1s ease-out forwards float-up;position:absolute}@keyframes float-up{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-30px)}}.dungeon-board--shake{animation:.3s ease-in-out board-shake}@keyframes board-shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}@keyframes mystic-pulse{0%{box-shadow:inset 0 0 12px #9f7aea}to{box-shadow:inset 0 0 25px #d53f8c}}@keyframes water-ripple{0%{box-shadow:inset 0 0 10px #3182ce}to{box-shadow:inset 0 0 25px #63b3ed}}.dungeon-square[data-terrain=mystic]{animation:2.5s ease-in-out infinite alternate mystic-pulse}.dungeon-square[data-terrain=water]{animation:3s ease-in-out infinite alternate water-ripple}.dungeon-selected{outline-offset:-2px;z-index:8;outline:2px solid #fbbf24;box-shadow:inset 0 0 20px #fbbf2466}.dungeon-legal-move{position:relative}.dungeon-legal-move:before{content:"";pointer-events:none;z-index:7;background-color:#34d399b3;border-radius:50%;width:16px;height:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dungeon-ability-target{z-index:7;border:1px solid #f87171;box-shadow:inset 0 0 25px #f8717199}@keyframes live-blink{0%,to{opacity:1}50%{opacity:.3}}@keyframes shimmer-sweep{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes countdown-bar{0%{width:100%}to{width:0%}}@keyframes mote-rise{0%{opacity:.6;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-260px)scale(.35)}}@keyframes new-event-flash{0%{background:#9b7ff526}to{background:0 0}}@keyframes sel-pulse{0%,to{box-shadow:inset 0 0 8px #9b7ff54d}50%{box-shadow:inset 0 0 16px #9b7ff599}}@keyframes leader-pulse{0%,to{box-shadow:0 0 8px #f1c40f4d}50%{box-shadow:0 0 20px #f1c40f99}}@keyframes portal-spin{0%,to{opacity:.6}50%{opacity:1}}@keyframes dragon-glow{0%,to{border-color:#9b7ff54d;box-shadow:0 0 8px #9b7ff533}50%{border-color:#9b7ff5cc;box-shadow:0 0 24px #9b7ff580}}@keyframes chat-wave{0%,to{transform:scaleY(1)}50%{transform:scaleY(.18)}}@keyframes crt-flicker{0%,97%{opacity:1}98%{opacity:.88}to{opacity:1}}@keyframes portrait-glow{0%,to{text-shadow:0 0 6px #9b7ff54d}50%{text-shadow:0 0 14px #9b7ff5b3}}@keyframes bone-sel{0%,to{box-shadow:inset 0 0 8px #e0d8c833}50%{box-shadow:inset 0 0 16px #e0d8c880}}@keyframes grave-pulse{0%,to{box-shadow:0 0 8px #b48c2833}50%{box-shadow:0 0 20px #b48c2880}}@keyframes scry-breathe{0%,to{box-shadow:0 0 12px #e0d8c814}50%{box-shadow:0 0 28px #e0d8c833}}.battle-v4-canvas{transform-origin:0 0;width:1920px;height:1080px;font-family:Space Mono,monospace;position:relative;overflow:hidden}.battle-v4-hud{z-index:50;backdrop-filter:blur(8px);align-items:center;height:56px;padding:0 20px;display:flex;position:absolute;top:0;left:0;right:0}.battle-v4-left{z-index:10;flex-direction:column;width:224px;display:flex;position:absolute;top:56px;bottom:80px;left:0;overflow:hidden}.battle-v4-center{z-index:10;flex-direction:column;justify-content:center;align-items:center;gap:10px;display:flex;position:absolute;inset:56px 264px 80px 224px}.battle-v4-right{z-index:10;flex-direction:column;width:264px;display:flex;position:absolute;top:56px;bottom:80px;right:0;overflow:hidden}.battle-v4-actionbar{z-index:50;backdrop-filter:blur(8px);align-items:center;height:80px;padding:0 20px;display:flex;position:absolute;bottom:0;left:0;right:0}.battle-v4-board{grid-template-rows:repeat(8,70px);grid-template-columns:repeat(8,70px);display:grid;position:relative}.battle-v4-cell{box-sizing:border-box;justify-content:center;align-items:center;width:70px;height:70px;display:flex;position:relative;overflow:hidden}.battle-v4-cell-hp{z-index:5;border-radius:0 0 2px 2px;height:6px;transition:width .3s;position:absolute;top:0;left:0;right:0}.battle-v4-cell-hp--high{background:linear-gradient(90deg,#22c55e,#4ade80)}.battle-v4-cell-hp--mid{background:linear-gradient(90deg,#eab308,#facc15)}.battle-v4-cell-hp--low{background:linear-gradient(90deg,#ef4444,#f87171)}[data-theme=dungeon].battle-v4-canvas{background:radial-gradient(at 50% 0,#1a1438,#0a0818,#080614)}[data-theme=dungeon] .battle-v4-hud{background:linear-gradient(90deg,#080614,#130f28,#080614);border-bottom:1px solid #9b7ff533}[data-theme=dungeon] .battle-v4-left{background:linear-gradient(160deg,#17132e,#100d22,#0e0b1e);border-right:1px solid #9b7ff526}[data-theme=dungeon] .battle-v4-right{background:linear-gradient(200deg,#17132e,#100d22,#0e0b1e);border-left:1px solid #9b7ff526}[data-theme=dungeon] .battle-v4-actionbar{background:linear-gradient(90deg,#080614,#130f28,#130f28,#080614);border-top:1px solid #9b7ff533}[data-theme=dungeon] .battle-v4-board{background:repeating-conic-gradient(#9b7ff508 0% 25%,#0000 0% 50%) 0 0/16px 16px,linear-gradient(135deg,#1a1538,#100d26);border:6px solid #9b7ff559;border-radius:12px;padding:8px;box-shadow:0 0 140px #9b7ff58c,0 0 280px #9b7ff533,inset 0 0 100px #000000fa}[data-theme=dungeon] .battle-v4-cell--light{background:#a89dc8}[data-theme=dungeon] .battle-v4-cell--light:after{content:"";pointer-events:none;background:radial-gradient(circle at 35% 35%,#ffffff14 0%,#0000 52%);position:absolute;inset:0}[data-theme=dungeon] .battle-v4-cell--dark{background:#4a3860}[data-theme=dungeon] .battle-v4-cell--dark:after{content:"";pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 8px,#9b7ff50a 8px 9px),repeating-linear-gradient(90deg,#0000,#0000 8px,#9b7ff50a 8px 9px);position:absolute;inset:0}[data-theme=dungeon] .cell-selected{animation:1.6s ease-in-out infinite sel-pulse;box-shadow:inset 0 0 12px #9b7ff580;background:#b8a8e8!important}[data-theme=dungeon] .cell-valid-move:before{content:"";z-index:3;pointer-events:none;background:radial-gradient(circle,#c8bedc73 30%,#9b7ff51f 60%,#0000 70%);border-radius:50%;width:24px;height:24px;position:absolute}[data-theme=dungeon] .cell-capturable:before{content:"";z-index:3;pointer-events:none;background:radial-gradient(circle,#ef444499 35%,#0000 65%);border-radius:50%;width:28px;height:28px;position:absolute;box-shadow:0 0 10px #ef444466}[data-theme=dungeon] .cell-capturable:after{content:"";z-index:3;pointer-events:none;border:2px solid #ef444480;border-radius:50%;width:36px;height:36px;position:absolute}[data-theme=dungeon] .cell-threat{background-color:#ef444414!important}[data-theme=dungeon] .cell-leader{animation:2s ease-in-out infinite leader-pulse;box-shadow:0 0 14px #f1c40f66,inset 0 0 6px #f1c40f26}[data-theme=dungeon] .battle-v4-piece-card{cursor:pointer;background:#ffffff08;border:1px solid #9b7ff51f;border-radius:8px;margin:2px 6px;padding:8px 10px;transition:background .2s,border-color .2s,box-shadow .2s}[data-theme=dungeon] .battle-v4-piece-card:hover{background:#9b7ff50f;border-color:#9b7ff540}[data-theme=dungeon] .piece-card-selected{background:#2d1a5e;border:2px solid #9b7ff5;box-shadow:0 0 16px #9b7ff54d}[data-theme=dungeon] .piece-card-fallen{opacity:.5;filter:grayscale(.4)}[data-theme=dungeon] .battle-v4-terminal{z-index:40;background:linear-gradient(145deg,#302a38,#1e1826);border-radius:18px;width:310px;padding:10px;position:absolute;bottom:88px;left:232px;box-shadow:0 8px 32px #0009}[data-theme=dungeon] .battle-v4-terminal-screen{color:#9b7ff5;background:#060410;border-radius:10px;height:140px;padding:10px;font-family:Space Mono,monospace;font-size:11px;animation:8s ease-in-out infinite crt-flicker;position:relative;overflow:hidden}[data-theme=dungeon] .battle-v4-terminal-screen:before{content:"";pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#9b7ff508 2px 4px);position:absolute;inset:0}[data-theme=dungeon] .battle-v4-terminal-screen:after{content:"";pointer-events:none;z-index:3;background:radial-gradient(#0000 50%,#0009 100%);position:absolute;inset:0}[data-theme=dungeon] .battle-v4-terminal-phosphor{pointer-events:none;z-index:1;position:absolute;inset:0;box-shadow:inset 0 0 40px #9b7ff50f}[data-theme=dungeon] .battle-v4-vote{border-bottom:1px solid #9b7ff51a;padding:10px 12px}[data-theme=dungeon] .battle-v4-vote-bar{border-radius:4px;height:22px;margin:4px 0;position:relative;overflow:hidden}[data-theme=dungeon] .battle-v4-vote-bar--yes{background:linear-gradient(90deg,#22c55e,#16a34a)}[data-theme=dungeon] .battle-v4-vote-bar--yes:after{content:"";background:linear-gradient(90deg,#0000 0%,#fff3 40% 60%,#0000 100%) 0 0/200% 100%;animation:2.2s linear infinite shimmer-sweep;position:absolute;inset:0}[data-theme=dungeon] .battle-v4-vote-bar--no{background:linear-gradient(90deg,#ef4444,#dc2626)}[data-theme=dungeon] .battle-v4-spawn{border-bottom:1px solid #9b7ff51a;padding:10px 12px}[data-theme=dungeon] .battle-v4-spawn-btn{color:#c8b8ff;cursor:pointer;background:#9b7ff514;border:2px solid #9b7ff54d;border-radius:10px;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px;font-family:Space Mono,monospace;font-size:12px;transition:border-color .3s,box-shadow .3s;animation:2.5s ease-in-out infinite dragon-glow;display:flex}[data-theme=dungeon] .battle-v4-spawn-btn:hover{border-color:#9b7ff5;box-shadow:0 0 20px #9b7ff566}[data-theme=dungeon] .battle-v4-events{flex:1;padding:8px 10px;overflow-y:auto}[data-theme=dungeon] .battle-v4-event-item{color:#c8bedcb3;border-bottom:1px solid #9b7ff50f;padding:6px 8px;font-size:11px}[data-theme=dungeon] .battle-v4-event-item--new{animation:4s ease-out new-event-flash}[data-theme=dungeon] .battle-v4-chat-bars{align-items:flex-end;gap:3px;height:32px;padding:8px 12px;display:flex}[data-theme=dungeon] .battle-v4-chat-bar{transform-origin:bottom;background:#9b7ff580;border-radius:2px;width:4px;animation:1.2s ease-in-out infinite chat-wave}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(2){animation-delay:.1s}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(3){animation-delay:.2s}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(4){animation-delay:.3s}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(5){animation-delay:.4s}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(6){animation-delay:.5s}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(7){animation-delay:.6s}[data-theme=dungeon] .battle-v4-chat-bar:nth-child(8){animation-delay:.7s}[data-theme=dungeon] .battle-v4-action-btn{color:#c8b8ff;cursor:pointer;background:#1e1a3a;border:1px solid #3d2a8a;border-radius:10px;padding:10px 18px;font-family:Space Mono,monospace;font-size:12px;transition:background .2s,border-color .2s,box-shadow .2s}[data-theme=dungeon] .battle-v4-action-btn:hover{background:#2a2450;border-color:#5a3db8}[data-theme=dungeon] .battle-v4-action-btn--highlight{background:#2d1a5e;border:2px solid #9b7ff5;box-shadow:0 0 12px #9b7ff54d}[data-theme=dungeon] .battle-v4-action-btn--end-turn{color:#fff;background:linear-gradient(135deg,#c32,#f42);border:1px solid #ff442280;font-weight:700}[data-theme=dungeon] .battle-v4-action-btn--end-turn:hover{box-shadow:0 0 16px #f426}[data-theme=dungeon] .battle-v4-motes{pointer-events:none;z-index:5;position:absolute;inset:0;overflow:hidden}[data-theme=dungeon] .battle-v4-mote{background:#9b7ff580;border-radius:50%;width:4px;height:4px;animation:6s ease-out infinite mote-rise;position:absolute;box-shadow:0 0 6px #9b7ff566}[data-theme=dungeon] .battle-v4-combat-stats{color:#c8b8ff;background:#13102a;border:1px solid #2d1a5e;border-radius:12px;align-items:center;gap:16px;padding:12px 16px;font-size:12px;display:flex}[data-theme=gothic].battle-v4-canvas{background:radial-gradient(at 50% -10%,#1e1a14,#0e0c0a,#090806);font-family:Cinzel,Space Mono,serif}[data-theme=gothic] .battle-v4-hud{background:linear-gradient(90deg,#090806,#1a1612,#090806);border-bottom:1px solid #e0d8c81f}[data-theme=gothic] .battle-v4-left{background:linear-gradient(160deg,#1a1612,#120f0c,#0e0c0a);border-right:1px solid #e0d8c81a}[data-theme=gothic] .battle-v4-right{background:linear-gradient(200deg,#1a1612,#120f0c,#0e0c0a);border-left:1px solid #e0d8c81a}[data-theme=gothic] .battle-v4-actionbar{background:linear-gradient(90deg,#090806,#1a1612,#1a1612,#090806);border-top:1px solid #e0d8c81f}[data-theme=gothic] .battle-v4-board{border:7px solid #161210;border-radius:8px;box-shadow:0 0 80px #e8e0d014,inset 0 0 100px #000000f2}[data-theme=gothic] .battle-v4-cell--light{background:#2c2824}[data-theme=gothic] .battle-v4-cell--dark{background:#1c1814}[data-theme=gothic] .cell-selected{border:2px solid #e0d8c866;animation:2s ease-in-out infinite bone-sel;background:#3a3430!important}[data-theme=gothic] .cell-valid-move:before{content:"";z-index:3;pointer-events:none;background:radial-gradient(circle,#e0d8c84d 30%,#0000 65%);border-radius:50%;width:22px;height:22px;position:absolute}[data-theme=gothic] .cell-capturable:before{content:"";z-index:3;pointer-events:none;background:radial-gradient(circle,#8a1a1a99 35%,#0000 65%);border-radius:50%;width:26px;height:26px;position:absolute;box-shadow:0 0 10px #8a1a1a66}[data-theme=gothic] .cell-capturable:after{content:"";z-index:3;pointer-events:none;border:2px solid #8a1a1a73;border-radius:50%;width:34px;height:34px;position:absolute}[data-theme=gothic] .cell-threat{background-color:#8a1a1a14!important}[data-theme=gothic] .cell-leader{animation:2s ease-in-out infinite grave-pulse;box-shadow:0 0 12px #b48c284d,inset 0 0 6px #b48c281a}[data-theme=gothic] .battle-v4-piece-card{cursor:pointer;background:#e0d8c808;border:1px solid #e0d8c814;border-radius:6px;margin:2px 6px;padding:8px 10px;font-family:Cinzel,serif;transition:background .2s,border-color .2s}[data-theme=gothic] .battle-v4-piece-card:hover{background:#e0d8c80f;border-color:#e0d8c826}[data-theme=gothic] .piece-card-selected{background:#e0d8c814;border:2px solid #e0d8c859;box-shadow:0 0 12px #e0d8c81a}[data-theme=gothic] .piece-card-fallen{opacity:.45;filter:grayscale(.5)sepia(.2)}[data-theme=gothic] .piece-card-king{background:#8a602812}[data-theme=gothic] .piece-card-queen{background:#5a1a281f}[data-theme=gothic] .piece-card-rook{background:#3a54680f}[data-theme=gothic] .piece-card-bishop{background:#2a40300f}[data-theme=gothic] .piece-card-knight{background:#463c500f}[data-theme=gothic] .piece-card-pawn{background:#32302c0a}[data-theme=gothic] .battle-v4-terminal{z-index:40;background:linear-gradient(145deg,#2a2420,#1a1610,#141210);border:2px solid #e0d8c814;border-radius:14px;width:310px;padding:10px;position:absolute;bottom:88px;left:232px;box-shadow:0 8px 32px #000000b3}[data-theme=gothic] .battle-v4-terminal:before{content:"††† SCRYING GLASS  †††";text-align:center;letter-spacing:2px;color:#e0d8c859;padding:4px 0 8px;font-family:Cinzel,serif;font-size:9px;display:block}[data-theme=gothic] .battle-v4-terminal-screen{color:#e0d8c899;background:#080604;border-radius:8px;height:140px;padding:10px;font-family:IM Fell English,serif;font-size:12px;font-style:italic;animation:6s ease-in-out infinite scry-breathe;position:relative;overflow:hidden}[data-theme=gothic] .battle-v4-terminal-screen:before{content:"";pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,#0000,#0000 3px,#e0d8c804 3px 6px);position:absolute;inset:0}[data-theme=gothic] .battle-v4-terminal-screen:after{content:"";pointer-events:none;z-index:3;background:radial-gradient(#0000 40%,#000000b3 100%);position:absolute;inset:0}[data-theme=gothic] .battle-v4-vote{border-bottom:1px solid #e0d8c80f;padding:10px 12px}[data-theme=gothic] .battle-v4-vote-bar{border-radius:3px;height:22px;margin:4px 0;position:relative;overflow:hidden}[data-theme=gothic] .battle-v4-vote-bar--yes{background:linear-gradient(90deg,#4a6a2a,#3a5a1a)}[data-theme=gothic] .battle-v4-vote-bar--no{background:linear-gradient(90deg,#8a1a1a,#6a1010)}[data-theme=gothic] .battle-v4-spawn{border-bottom:1px solid #e0d8c80f;padding:10px 12px}[data-theme=gothic] .battle-v4-spawn-btn{color:#e0d8c8b3;cursor:pointer;background:#b48c280f;border:2px solid #b48c2840;border-radius:8px;justify-content:center;align-items:center;gap:6px;width:100%;padding:10px;font-family:Cinzel,serif;font-size:12px;transition:border-color .3s,box-shadow .3s;display:flex}[data-theme=gothic] .battle-v4-spawn-btn:hover{border-color:#b48c2880;box-shadow:0 0 16px #b48c2833}[data-theme=gothic] .battle-v4-events{flex:1;padding:8px 10px;overflow-y:auto}[data-theme=gothic] .battle-v4-event-item{color:#e0d8c880;border-bottom:1px solid #e0d8c80a;padding:6px 8px;font-family:IM Fell English,serif;font-size:11px;font-style:italic}[data-theme=gothic] .battle-v4-event-item--new{animation:4s ease-out new-event-flash}[data-theme=gothic] .battle-v4-chat-bars{align-items:flex-end;gap:3px;height:32px;padding:8px 12px;display:flex}[data-theme=gothic] .battle-v4-chat-bar{transform-origin:bottom;background:#e0d8c84d;border-radius:2px;width:4px;animation:1.4s ease-in-out infinite chat-wave}[data-theme=gothic] .battle-v4-chat-bar:nth-child(2){animation-delay:.12s}[data-theme=gothic] .battle-v4-chat-bar:nth-child(3){animation-delay:.24s}[data-theme=gothic] .battle-v4-chat-bar:nth-child(4){animation-delay:.36s}[data-theme=gothic] .battle-v4-chat-bar:nth-child(5){animation-delay:.48s}[data-theme=gothic] .battle-v4-chat-bar:nth-child(6){animation-delay:.6s}[data-theme=gothic] .battle-v4-chat-bar:nth-child(7){animation-delay:.72s}[data-theme=gothic] .battle-v4-chat-bar:nth-child(8){animation-delay:.84s}[data-theme=gothic] .battle-v4-action-btn{color:#e0d8c8b3;cursor:pointer;background:#1a1610;border:1px solid #e0d8c826;border-radius:8px;padding:10px 18px;font-family:Cinzel,serif;font-size:12px;transition:background .2s,border-color .2s,box-shadow .2s}[data-theme=gothic] .battle-v4-action-btn:hover{background:#222018;border-color:#e0d8c840}[data-theme=gothic] .battle-v4-action-btn--highlight{background:#e0d8c814;border:2px solid #e0d8c84d;box-shadow:0 0 10px #e0d8c814}[data-theme=gothic] .battle-v4-action-btn--end-turn{color:#e0d8c8e6;background:linear-gradient(135deg,#8a1a1ae6,#a82828e6);border:1px solid #a8282880;font-weight:700}[data-theme=gothic] .battle-v4-action-btn--end-turn:hover{box-shadow:0 0 14px #8a1a1a4d}[data-theme=gothic] .battle-v4-combat-stats{color:#e0d8c8b3;background:#141210;border:1px solid #e0d8c81a;border-radius:10px;align-items:center;gap:16px;padding:12px 16px;font-family:Cinzel,serif;font-size:12px;display:flex}[data-theme=gothic] .battle-v4-motes{pointer-events:none;z-index:5;position:absolute;inset:0;overflow:hidden}[data-theme=gothic] .battle-v4-mote{background:#e0d8c840;border-radius:50%;width:3px;height:3px;animation:8s ease-out infinite mote-rise;position:absolute;box-shadow:0 0 4px #e0d8c826}@media (width<=768px){.battle-v4-canvas{width:393px;height:852px;transform:none!important}.battle-v4-hud{height:44px;padding:0 12px}.battle-v4-left,.battle-v4-right{display:none}.battle-v4-center{inset:44px 0 0}.battle-v4-board{grid-template-rows:repeat(8,40px);grid-template-columns:repeat(8,40px)}.battle-v4-cell{width:40px;height:40px}.battle-v4-cell-hp{height:4px}.battle-v4-terminal{border-radius:8px;width:100%;height:58px;position:relative;bottom:0;left:0}.battle-v4-terminal-screen{height:42px;padding:6px;font-size:9px}.battle-v4-actionbar{flex-wrap:wrap;gap:6px;height:auto;padding:8px}.battle-v4-action-btn{padding:8px 12px;font-size:11px}.battle-v4-combat-stats{border-radius:8px;gap:8px;padding:8px 10px;font-size:10px}.battle-v4-twitch-strip{flex-direction:row;align-items:center;gap:8px;padding:6px 12px;display:flex;overflow-x:auto}}@media (width>=769px){.battle-v4-twitch-strip{display:none}}.battle-v4-divider{border:none;width:100%;height:1px;margin:0}[data-theme=dungeon] .battle-v4-divider{background:#9b7ff51f}[data-theme=gothic] .battle-v4-divider{background:#e0d8c814}.battle-v4-pill{letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;border-radius:100px;align-items:center;padding:2px 8px;font-size:10px;font-weight:600;display:inline-flex}[data-theme=dungeon] .battle-v4-pill{color:#c8b8ff;background:#9b7ff51f;border:1px solid #9b7ff533}[data-theme=gothic] .battle-v4-pill{color:#e0d8c899;background:#e0d8c80f;border:1px solid #e0d8c81a;font-family:Cinzel,serif}.battle-v4-ap-pip{box-sizing:border-box;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;transition:background .2s,border-color .2s,box-shadow .2s;display:inline-flex}[data-theme=dungeon] .battle-v4-ap-pip--filled{background:#9b7ff599;border:2px solid #9b7ff5;box-shadow:0 0 6px #9b7ff54d}[data-theme=dungeon] .battle-v4-ap-pip--empty{background:0 0;border:2px solid #9b7ff533}[data-theme=gothic] .battle-v4-ap-pip--filled{background:#e0d8c859;border:2px solid #e0d8c880;box-shadow:0 0 4px #e0d8c826}[data-theme=gothic] .battle-v4-ap-pip--empty{background:0 0;border:2px solid #e0d8c81f}.battle-v4-grid-texture{pointer-events:none;z-index:1;background:repeating-conic-gradient(#80808008 0% 25%,#0000 0% 50%) 0 0/16px 16px;position:absolute;inset:0}.battle-v4-scanlines{pointer-events:none;z-index:2;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#0000000a 2px 4px);position:absolute;inset:0}.battle-v4-vignette{pointer-events:none;z-index:3;background:radial-gradient(#0000 50%,#00000080 100%);position:absolute;inset:0}.admin-module{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6)}.admin-module__title{font-size:var(--text-md);color:var(--text-primary);margin-bottom:var(--space-2);font-weight:700}.admin-module__desc{font-size:var(--text-xs);color:var(--text-tertiary);margin-bottom:var(--space-4)}.admin-field{margin-bottom:var(--space-4)}.admin-field label{font-size:var(--text-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-weight:600;display:block}.admin-field select,.admin-field textarea,.admin-field input[type=text],.admin-field input[type=number],.admin-field input[type=password]{width:100%;padding:var(--space-2);background:var(--bg-secondary);border:1px solid var(--surface-4);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--text-sm)}.admin-actions{gap:var(--space-2);display:flex}.admin-btn{padding:var(--space-2);background:var(--bg-secondary);border:1px solid var(--surface-4);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);flex:1;font-weight:600}.admin-btn--primary{background:var(--accent-primary,#22c55e);color:#fff;border-color:var(--accent-primary,#22c55e)}.admin-btn--danger{color:#fff;background:#ef4444;border-color:#ef4444}.admin-response{margin-top:var(--space-4);padding:var(--space-4);border:1px solid var(--surface-4);border-radius:var(--radius-sm);font-family:monospace;font-size:var(--text-xs);color:#a8e6c0;white-space:pre-wrap;background:#0a0e1a;max-height:400px;display:none;overflow-y:auto}.admin-log{margin-top:var(--space-3);color:var(--text-tertiary);font-size:10px}
