.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}:root{--color-primary: #f0e8d8;--color-primary-hover: #d9cfc0;--color-secondary: #a09080;--color-tertiary: #2a2520;--color-tertiary-hover: #332d28;--color-border: #3a3228;--color-border-light: #342e28;--color-surface: #221e1a;--color-bg: #1a1612;--color-accent: rgba(212, 168, 83, .25);--color-danger: #ff6b6b;--color-brand: #5b9cf6;--color-brand-hover: #3b7dd8;--color-brand-light: rgba(91, 156, 246, .15);--font-base: "Roboto", sans-serif;color-scheme:dark}@media(prefers-color-scheme:light){:root:not([data-theme=dark]){--color-primary: #1a1a1a;--color-primary-hover: #333;--color-secondary: #555;--color-tertiary: #f5f5f5;--color-tertiary-hover: #e8e8e8;--color-border: #e0e0e0;--color-border-light: #ddd;--color-surface: #fafafa;--color-bg: #ffffff;--color-accent: rgba(155, 199, 0, .2);--color-danger: #d32f2f;--color-brand: #2563eb;--color-brand-hover: #1d4ed8;--color-brand-light: rgba(37, 99, 235, .12);color-scheme:light}}[data-theme=light]{--color-primary: #1a1a1a;--color-primary-hover: #333;--color-secondary: #555;--color-tertiary: #f5f5f5;--color-tertiary-hover: #e8e8e8;--color-border: #e0e0e0;--color-border-light: #ddd;--color-surface: #fafafa;--color-bg: #ffffff;--color-accent: rgba(155, 199, 0, .2);--color-danger: #d32f2f;--color-brand: #2563eb;--color-brand-hover: #1d4ed8;--color-brand-light: rgba(37, 99, 235, .12);color-scheme:light}[data-theme=dark]{--color-primary: #f0e8d8;--color-primary-hover: #d9cfc0;--color-secondary: #a09080;--color-tertiary: #2a2520;--color-tertiary-hover: #332d28;--color-border: #3a3228;--color-border-light: #342e28;--color-surface: #221e1a;--color-bg: #1a1612;--color-accent: rgba(212, 168, 83, .25);--color-danger: #ff6b6b;--color-brand: #5b9cf6;--color-brand-hover: #3b7dd8;--color-brand-light: rgba(91, 156, 246, .15);color-scheme:dark}.app-header__logo-wrap{position:relative;height:32px;width:calc(32px * 811 / 308);flex-shrink:0}.app-header__logo{position:absolute;top:0;right:0;bottom:0;left:0;height:100%;width:100%;object-fit:contain;object-position:left center;opacity:0;animation:none}.app-header__logo--chaturanga{animation:logo-brand-a 12s ease-in-out infinite}.app-header__logo--shatranj{animation:logo-brand-b 12s ease-in-out infinite}.player-panel__captured--black-pieces .player-panel__piece{filter:drop-shadow(0 0 1px rgba(212,168,83,.95)) drop-shadow(0 0 2px rgba(212,168,83,.5))}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .player-panel__captured--black-pieces .player-panel__piece{filter:none}}[data-theme=light] .player-panel__captured--black-pieces .player-panel__piece{filter:none}.toolbar__icon--black-piece{filter:drop-shadow(0 0 2px rgba(212,168,83,.9)) drop-shadow(0 0 4px rgba(212,168,83,.5))}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .toolbar__icon--black-piece{filter:none}}[data-theme=light] .toolbar__icon--black-piece{filter:none}.app{min-height:100vh;background-color:var(--color-bg);color:var(--color-primary);font-family:var(--font-base)}.app-header{display:flex;align-items:center;gap:12px;padding:6px 16px;border-bottom:1px solid var(--color-border);background:var(--color-bg)}.app-header__mode-tabs{display:flex;gap:2px;background:var(--color-tertiary);border:1px solid var(--color-border-light);border-radius:6px;padding:2px}.app-header__mode-tab{padding:5px 14px;font-size:13px;font-weight:600;border:none;border-radius:4px;background:none;color:var(--color-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.app-header__mode-tab:hover:not(:disabled){background:var(--color-tertiary-hover);color:var(--color-primary)}.app-header__mode-tab--active{background:var(--color-primary);color:#fff}.app-header__mode-tab--active:hover:not(:disabled){background:var(--color-primary-hover)}.app-header__mode-tab:disabled{opacity:.4;cursor:default}:root{--header-h: 45px}.app-header__nav-mobile{display:none;position:static}.app-header__menu-btn{display:flex;align-items:center;justify-content:center;position:relative;width:36px;height:36px;border:1px solid var(--color-border-light);border-radius:6px;background:var(--color-bg);cursor:pointer;transition:background .15s;padding:0;overflow:hidden}.app-header__menu-btn:hover{background:var(--color-tertiary-hover)}.app-header__menu-btn--open{background:var(--color-tertiary)}.app-header__hamburger-bars,.app-header__hamburger-close{display:flex;align-items:center;justify-content:center;position:absolute;top:0;right:0;bottom:0;left:0;color:var(--color-primary);transition:opacity .2s ease-out,transform .2s ease-out}.app-header__hamburger-bars{opacity:1;transform:rotate(0) scale(1)}.app-header__hamburger-close{opacity:0;transform:rotate(-45deg) scale(.7)}.app-header__menu-btn--open .app-header__hamburger-bars{opacity:0;transform:rotate(45deg) scale(.7)}.app-header__menu-btn--open .app-header__hamburger-close{opacity:1;transform:rotate(0) scale(1)}.app-header__hamburger-bars svg,.app-header__hamburger-close svg{width:18px;height:18px}.app-header__menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:299;pointer-events:none;transition:background .32s cubic-bezier(.4,0,.2,1)}.app-header__menu-backdrop--open{background:#00000073;pointer-events:auto}.app-header__menu-panel{position:fixed;top:var(--header-h);left:0;width:min(300px,82vw);height:calc(100dvh - var(--header-h));background:var(--color-bg);border-right:1px solid var(--color-border);list-style:none;margin:0;padding:10px 8px;z-index:300;overflow-y:auto;overscroll-behavior:contain;transform:translate(-100%);transition:transform .32s cubic-bezier(.4,0,.2,1)}.app-header__menu-panel--open{transform:translate(0)}.app-header__menu-panel li>*,.app-header__menu-panel li>a{opacity:0;transform:translate(-10px);transition:none}.app-header__menu-panel--open li>*,.app-header__menu-panel--open li>a{opacity:1;transform:translate(0);transition:opacity .2s ease-out var(--item-delay, 0ms),transform .2s ease-out var(--item-delay, 0ms)}.app-header__menu-divider{opacity:1!important;transform:none!important;transition:none!important}body.menu-open{overflow:hidden}.app-header__menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:7px;background:none;color:var(--color-primary);font-size:14px;font-weight:500;cursor:pointer;text-align:left;text-decoration:none;transition:background .1s}.app-header__menu-item:hover:not(:disabled){background:var(--color-tertiary)}.app-header__menu-item--active{font-weight:700;color:var(--color-primary)}.app-header__menu-item:disabled{opacity:.4;cursor:default}.app-header__menu-item-icon{width:20px;height:20px;flex-shrink:0;color:var(--color-secondary);display:flex;align-items:center}.app-header__menu-item-icon svg{width:20px;height:20px}.app-header__menu-item-check{margin-left:auto;width:16px;height:16px;flex-shrink:0;color:var(--color-primary)}.app-header__site-links{display:flex;align-items:center;gap:4px}.app-header__site-link{font-size:14px;font-weight:500;color:var(--color-secondary);text-decoration:none;padding:5px 10px;border-radius:4px;transition:color .15s,background .15s}.app-header__site-link:hover{color:var(--color-primary);background:var(--color-tertiary-hover, rgba(255, 255, 255, .06))}@keyframes theme-icon-enter{0%{opacity:0;transform:rotate(-90deg) scale(.6)}to{opacity:1;transform:rotate(0) scale(1)}}.app-header__theme-icon-wrap{display:flex;align-items:center;justify-content:center;animation:theme-icon-enter .2s ease-out}.app-header__preferences-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--color-border-light);border-radius:6px;background:none;color:var(--color-secondary);cursor:pointer;padding:0;font-size:14px;transition:background .15s,color .15s;flex-shrink:0}.app-header__preferences-btn:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.app-header__theme-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--color-border-light);border-radius:6px;background:none;color:var(--color-secondary);cursor:pointer;padding:0;font-size:14px;transition:background .15s,color .15s;flex-shrink:0}.app-header__theme-btn:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.app-header__help-btn{position:relative;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--color-border-light);border-radius:6px;background:none;cursor:pointer;padding:0;flex-shrink:0;overflow:hidden;transition:border-color .15s}.app-header__help-btn:hover{border-color:var(--color-gold, #d4a853)}.app-header__help-board{width:100%;height:100%;display:block;border-radius:4px;opacity:.8}.app-header__help-q{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:900;color:#fff;text-shadow:0 0 5px rgba(0,0,0,.95),0 1px 3px rgba(0,0,0,.8);pointer-events:none;font-family:Arial,sans-serif;line-height:1}@keyframes help-btn-glow{0%,to{box-shadow:0 0 4px 1px var(--color-brand, #5b9cf6)}50%{box-shadow:0 0 10px 4px var(--color-brand, #5b9cf6)}}.app-header__help-btn--glow{border-color:var(--color-brand, #5b9cf6);animation:help-btn-glow 2s ease-in-out infinite}.app-header__auth{margin-left:auto;display:flex;align-items:center;gap:8px}.app-header__mobile-signin{display:none;align-items:center;gap:6px}.app-header__user{font-size:13px;font-weight:500;color:var(--color-secondary)}.app-header__signin-group{display:flex;align-items:center;gap:4px}.app-header__signin-label{font-size:11px;font-weight:600;color:var(--color-secondary);white-space:nowrap}.app-header__oauth-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;font-size:14px;padding:0;color:var(--color-primary);transition:background-color .15s;flex-shrink:0}.app-header__oauth-btn:hover{background:var(--color-tertiary-hover)}.app-header__oauth-lichess-icon,.site-nav__lichess-icon,.site-layout__oauth-lichess-icon{filter:none}[data-theme=dark] .app-header__oauth-lichess-icon,[data-theme=dark] .site-nav__lichess-icon,[data-theme=dark] .site-layout__oauth-lichess-icon{filter:invert(1)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .app-header__oauth-lichess-icon,:root:not([data-theme=light]) .site-nav__lichess-icon,:root:not([data-theme=light]) .site-layout__oauth-lichess-icon{filter:invert(1)}}.app-header__signin-btn{display:flex;align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;border:1px solid var(--color-border);border-radius:4px;background-color:var(--color-bg);color:var(--color-primary);cursor:pointer;transition:background-color .15s}.app-header__signin-btn:hover{background:var(--color-tertiary-hover);border-color:var(--color-border)}.app-header__signout-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:5px 10px;border:1px solid var(--color-border);border-radius:4px;background:none;color:var(--color-secondary);font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background-color .15s,color .15s}.app-header__signout-btn:after{content:""}.app-header__signout-btn:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.game-layout__body{display:flex;flex-direction:row;min-height:0;flex:1}.game-footer{border-top:1px solid var(--color-border);padding:8px 16px;display:flex;flex-direction:column;align-items:center;gap:4px}.game-footer__divider{display:none}.game-footer__made-in{font-size:12px;color:var(--color-secondary)}.game-footer__x-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--color-secondary);text-decoration:none;transition:text-decoration .15s}.game-footer__x-link:hover{text-decoration:underline}.game-footer__x-icon{width:13px;height:13px;flex-shrink:0}.app-header__menu-divider{height:1px;background:var(--color-border);margin:4px 12px}.game-layout__main{display:flex;gap:16px;padding:16px;flex:1;min-width:0}@media(min-width:769px){.game-layout__main{justify-content:center}}.game-layout__board-area{display:flex;flex-direction:column;align-items:center;gap:4px;transition:--board-size .45s cubic-bezier(.4,0,.2,1)}.game-layout__board-and-eval{display:flex;flex-direction:row;align-items:stretch;gap:0;position:relative}@keyframes eval-bar-noodle-hide{0%{width:14px;margin-right:6px}28%{width:0px;margin-right:0}40%{width:0px;margin-right:0}55%{width:5px;margin-right:3px}65%{width:3px;margin-right:2px}to{width:0px;margin-right:0}}.eval-bar-slide{width:0;margin-right:0;overflow:hidden;flex-shrink:0;align-self:stretch;display:flex;transition:width .22s ease-out,margin-right .22s ease-out}.eval-bar-slide--visible{width:14px;margin-right:6px}.eval-bar-slide--hiding{transition:none;animation:eval-bar-noodle-hide .75s cubic-bezier(.4,0,.2,1) forwards}.eval-bar{width:14px;display:flex;flex-direction:column;border-radius:3px;overflow:hidden;flex-shrink:0;align-self:stretch}.eval-bar__black{background:#2a2520;position:relative;transition:height .4s ease;flex-shrink:0}.eval-bar__white{background:#f0e8d8;position:relative;transition:height .4s ease;flex-shrink:0}.eval-bar__label{position:absolute;left:50%;transform:translate(-50%);font-size:9px;font-weight:600;line-height:1;white-space:nowrap;pointer-events:none}.eval-bar__black .eval-bar__label{color:#f0e8d8}.eval-bar__white .eval-bar__label{color:#2a2520}.eval-bar__label--top{top:4px}.eval-bar__label--bottom{bottom:4px}.eval-bar__label--mate{font-size:8px}.eval-bar__label--sm{font-size:7.5px}.eval-bar__label--xs{font-size:6.5px}@keyframes eval-label-in{0%{opacity:0}to{opacity:1}}.eval-bar__label{animation:eval-label-in .2s ease-out}@keyframes eval-mate-pulse{0%{filter:brightness(1)}50%{filter:brightness(1.8)}to{filter:brightness(1)}}.eval-bar--mate-pulse .eval-bar__black,.eval-bar--mate-pulse .eval-bar__white{animation:eval-mate-pulse .4s ease-in-out}.game-layout__board-wrap{position:relative}.game-layout__board-blocked{pointer-events:none}.game-layout__board-lock{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#00000073;border-radius:4px;color:#fff;pointer-events:all}.game-layout__board-lock-icon{width:32px;height:32px;opacity:.9}.game-layout__board-lock-text{font-size:14px;font-weight:500;letter-spacing:.02em;opacity:.9}.game-layout__board-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;border-radius:4px;color:#fff;pointer-events:all}.game-layout__board-overlay--reconnecting{background:#0009}.game-layout__board-overlay--error{background:#000000b8}.game-layout__board-overlay-spinner{display:inline-block;width:28px;height:28px;border:3px solid rgba(255,255,255,.25);border-top-color:#fff;border-radius:50%;animation:board-overlay-spin .8s linear infinite}@keyframes board-overlay-spin{to{transform:rotate(360deg)}}.game-layout__board-overlay-text{font-size:14px;font-weight:500;letter-spacing:.02em;opacity:.9;text-align:center;padding:0 16px}.game-layout__board-overlay-reset{margin-top:4px;padding:8px 20px;background:var(--color-brand);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer}.game-layout__board-overlay-reset:hover{background:var(--color-brand-hover)}.pvp-gate__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:15;background:#0000008c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);display:flex;align-items:flex-end;justify-content:center;border-radius:4px;overflow:hidden}.pvp-gate__card{width:100%;background:var(--color-surface, var(--color-bg));border-top:1px solid var(--color-border);border-radius:16px 16px 0 0;padding:1.5rem 1.25rem 2rem;animation:pvp-gate-slide-up .22s cubic-bezier(.34,1.1,.64,1) both;max-height:92%;overflow-y:auto}@keyframes pvp-gate-slide-up{0%{transform:translateY(100%);opacity:.4}to{transform:translateY(0);opacity:1}}@media(min-width:540px){.pvp-gate__backdrop{align-items:center}.pvp-gate__card{width:min(360px,92%);border-radius:16px;border:1px solid var(--color-border);animation:pvp-gate-pop-in .18s cubic-bezier(.34,1.1,.64,1) both}@keyframes pvp-gate-pop-in{0%{transform:scale(.93);opacity:0}to{transform:scale(1);opacity:1}}}.pvp-gate__auth{display:flex;flex-direction:column;gap:1rem}.pvp-gate__auth-header{display:flex;flex-direction:column;gap:.3rem}.pvp-gate__auth-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-gold, #d4a853)}.pvp-gate__auth-title{font-size:1.1rem;font-weight:700;color:var(--color-primary);margin:0}.pvp-gate__auth-sub{font-size:.8rem;color:var(--color-secondary);margin:0}.pvp-gate__guest-btn{width:100%;background:transparent;color:var(--color-gold, #d4a853);border:1.5px solid var(--color-gold, #d4a853);border-radius:10px;padding:.7rem 1rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.pvp-gate__guest-btn:hover:not(:disabled){background:#d4a85314}.pvp-gate__guest-btn:disabled{opacity:.45;cursor:not-allowed}.pvp-gate__divider{display:flex;align-items:center;gap:.6rem;font-size:.75rem;color:var(--color-secondary);opacity:.7}.pvp-gate__divider:before,.pvp-gate__divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.pvp-gate__oauth-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.pvp-gate__oauth-btn{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-tertiary, rgba(255,255,255,.04));color:var(--color-primary);font-size:.82rem;font-weight:500;cursor:pointer;transition:background .12s,transform .1s}.pvp-gate__oauth-btn:hover{background:var(--color-tertiary-hover, rgba(255,255,255,.09));transform:translateY(-1px)}.pvp-gate__oauth-btn--lichess img{filter:invert(1)}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .pvp-gate__oauth-btn--lichess img{filter:none}}[data-theme=light] .pvp-gate__oauth-btn--lichess img{filter:none}.pvp-gate__lobby .pvp-lobby{padding:0;background:none;border:none;border-radius:0;box-shadow:none}.match-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;background:#0009;border-radius:4px}.match-overlay__card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:24px 28px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 8px 32px #0006;min-width:240px}.match-overlay__title{font-size:20px;font-weight:700;margin:0;color:var(--color-primary)}.match-overlay__players{display:flex;align-items:center;gap:16px}.match-overlay__player{display:flex;flex-direction:column;align-items:center;gap:6px}.match-overlay__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.match-overlay__rating{font-size:11px;color:var(--color-secondary);margin-top:-2px}.match-overlay__name{font-size:13px;font-weight:600;color:var(--color-primary);max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match-overlay__color-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.05em}.match-overlay__color-badge--white{background:#f5f5f5;color:#333;border:1px solid #ccc}.match-overlay__color-badge--black{background:#333;color:#f5f5f5;border:1px solid #555}.match-overlay__vs{font-size:14px;font-weight:700;color:var(--color-secondary);flex-shrink:0}.match-overlay__countdown{font-size:12px;color:var(--color-secondary);margin:0}.game-layout__side-panel{flex:1;min-width:260px;max-width:360px;display:flex;flex-direction:column;gap:0;position:sticky;top:16px;max-height:calc(100vh - 88px);overflow:hidden}.toolbar-wrapper{display:flex;flex-direction:column;overflow:visible}.toolbar{display:flex;align-items:center;gap:2px;padding:4px 8px;background-color:var(--color-tertiary);border:1px solid var(--color-border);border-radius:8px 8px 0 0;flex-wrap:nowrap}.toolbar--secondary{border-radius:0 0 8px 8px;border-top:none;overflow:visible;position:relative}.toolbar__drawer-track{overflow:hidden;max-height:0;transition:max-height .2s cubic-bezier(.5,0,.75,0)}.toolbar__drawer-track--open{max-height:80px;transition:max-height .36s cubic-bezier(.34,1.56,.64,1)}.toolbar__drawer-track>.toolbar--secondary{border:none;transform:translateY(-12px);transition:transform .2s cubic-bezier(.5,0,.75,0)}.toolbar__drawer-track--open>.toolbar--secondary{transform:translateY(0);transition:transform .38s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--color-border);border-top:none}.toolbar--drawer-open{border-radius:8px 8px 0 0;animation:toolbar-breathe-back .36s cubic-bezier(.34,1.56,.64,1) both}@keyframes toolbar-breathe-back{0%{transform:none}35%{transform:scaleY(.97) translateY(-1px)}to{transform:none}}.toolbar__drawer-track--open .toolbar--secondary .toolbar__icon-btn{animation:drawer-item-in .22s ease-out both;animation-delay:calc(30ms + var(--drawer-item-idx, 0) * 25ms)}.toolbar__drawer-track--open .toolbar--secondary .toolbar__icon-btn:disabled{opacity:.45}@keyframes drawer-item-in{0%{opacity:0}to{opacity:1}}.toolbar__more-handle{flex:0 0 auto;align-self:stretch;display:flex;align-items:center;justify-content:center;border:none;background:none;cursor:pointer;color:var(--color-secondary);border-left:1px solid var(--color-border-light);border-radius:0 6px 0 0;padding:0 6px;margin-left:auto;transition:background .15s,color .15s}.toolbar__more-handle:hover{background:#0000000f;color:var(--color-primary)}.toolbar__more-handle--open{border-radius:0}.toolbar__more-icon{font-size:11px;transition:transform .22s cubic-bezier(.4,0,.2,1)}.toolbar__more-handle--open .toolbar__more-icon{transform:rotate(180deg)}.toolbar__more-handle--locked{cursor:default;opacity:.35;pointer-events:none}.toolbar--tools{border-radius:0;border-top:none;gap:2px}.toolbar__group{display:flex;align-items:center;gap:2px}.toolbar__divider{width:1px;height:24px;background-color:var(--color-border-light);margin:0 2px;flex-shrink:0}.toolbar__group--difficulty{flex:1;min-width:90px;gap:4px}.toolbar__icon-btn{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:3px;flex:1;min-width:0;min-height:52px;padding:8px 2px;border:none;border-radius:8px;background:none;color:var(--color-secondary);cursor:pointer;transition:background .15s,color .15s,opacity .3s}.toolbar__icon-btn:hover:not(:disabled){background:#0000000f;color:var(--color-primary)}.toolbar__icon-btn:disabled{opacity:.45;cursor:default}.toolbar__icon-btn--active{color:var(--color-brand)}.toolbar__icon-btn--active:hover:not(:disabled){color:var(--color-brand)}.toolbar__icon-btn--ready{animation:ready-pulse 1.5s ease-in-out infinite}@keyframes ready-pulse{0%,to{transform:scale(1);color:var(--color-brand)}50%{transform:scale(1.12);color:var(--color-brand)}}@keyframes pawn-flip{0%{transform:scaleY(1);opacity:1}45%{transform:scaleY(0);opacity:0}55%{transform:scaleY(0);opacity:0}to{transform:scaleY(1);opacity:1}}.toolbar__icon--flipping{animation:pawn-flip .3s ease-in-out}@keyframes undo-spin{0%{transform:rotate(0)}to{transform:rotate(-360deg)}}.toolbar__icon--undo-spin{animation:undo-spin .35s ease-in-out}.toolbar__icon-btn--danger:hover:not(:disabled){color:var(--color-danger);background:#dc1e1e14}.toolbar__icon{display:block;width:18px;height:18px;flex-shrink:0;object-fit:contain}.toolbar__icon--lg{width:22px;height:22px;margin:-2px 0}.toolbar__help-board{border-radius:2px;overflow:hidden}.toolbar__label{font-size:9px;font-weight:500;line-height:1;letter-spacing:.01em;white-space:normal;text-align:center}.toolbar__icon-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center}.toolbar__icon-badge{position:absolute;bottom:-3px;right:-6px;font-size:.58rem;font-weight:800;line-height:1;color:var(--color-brand);background:var(--color-tertiary);border-radius:2px;padding:0 1px;pointer-events:none;-webkit-user-select:none;user-select:none}.toolbar__icon-badge--inf{font-size:.78rem}.toolbar__icon-btn:disabled .toolbar__icon-badge{color:currentColor}@keyframes confirm-in{0%{opacity:0;transform:scaleX(.95)}to{opacity:1;transform:scaleX(1)}}@keyframes confirm-shake{0%{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}to{transform:translate(0)}}.toolbar--confirm{justify-content:space-between;gap:8px;padding:10px 12px;min-height:52px;transform-origin:left center;animation:confirm-in .2s ease-out}.toolbar--confirm--danger{animation:confirm-in .2s ease-out,confirm-shake .12s ease-in-out .22s 2}.toolbar__confirm-msg{font-size:12px;font-weight:500;color:var(--color-secondary);flex:1}.toolbar__confirm-actions{display:flex;gap:6px;flex-shrink:0}.toolbar__flat-btn{padding:5px 12px;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;background:#00000012;color:var(--color-secondary);transition:background .15s,color .15s}.toolbar__flat-btn:hover{background:#0000001f;color:var(--color-primary)}.toolbar__flat-btn--danger{background:#dc1e1e1f;color:var(--color-danger)}.toolbar__flat-btn--danger:hover{background:#dc1e1e38;color:var(--color-danger)}.toolbar__flat-btn--safe{background:#1ea0501f;color:var(--color-success, #1a9e4e)}.toolbar__flat-btn--safe:hover{background:#1ea05038;color:var(--color-success, #1a9e4e)}.toolbar__difficulty-label{display:flex;align-items:center;gap:3px;white-space:nowrap}.toolbar__difficulty-name{font-size:11px;font-weight:600;color:var(--color-secondary);white-space:nowrap}.toolbar__difficulty-level{font-size:10px;font-weight:500;color:var(--color-secondary)}.toolbar__info-btn{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:1px solid var(--color-border);background:none;color:var(--color-secondary);font-size:9px;font-weight:700;cursor:help;padding:0;line-height:1;flex-shrink:0;position:relative}.toolbar__info-btn:hover{border-color:var(--color-secondary);color:var(--color-secondary)}.toolbar__tooltip{display:none;position:absolute;z-index:1000;top:calc(100% + 8px);left:0;width:max-content;max-width:min(280px,calc(100vw - 32px));background:linear-gradient(145deg,beige,tan);color:#333;text-align:left;text-decoration:none;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #0000004d;font-size:.9em;line-height:1.4;white-space:pre-wrap;border:1px solid #8b4513}.toolbar__tooltip:after{content:"";position:absolute;bottom:100%;left:4px;border:5px solid transparent;border-bottom-color:tan}.toolbar__info-btn:hover .toolbar__tooltip{display:block}.toolbar__slider{flex:1;min-width:50px;height:4px;cursor:pointer;accent-color:var(--color-brand)}.status-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 10px;border:1px solid var(--color-border);border-top:none;background-color:var(--color-surface);font-size:13px}.status-bar--ended{background-color:var(--color-accent);justify-content:center;font-weight:600}.status-bar__turn{display:flex;align-items:center;gap:6px;min-width:0;flex:1;overflow:hidden}.status-bar__pawn{width:14px;height:14px;flex-shrink:0}.status-bar__text{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-bar__badges{display:flex;gap:4px;flex-shrink:0}.status-bar__badge{padding:1px 6px;border-radius:3px;font-size:11px;font-weight:600}.status-bar__badge--thinking{background-color:var(--color-accent);color:var(--color-secondary);animation:thinking-pulse 1.2s ease-in-out infinite}.status-bar__badge--check{background-color:#dc1e1e33;color:var(--color-danger)}.status-bar__badge--history{background-color:#6464ff1a;color:var(--color-secondary)}@keyframes thinking-pulse{0%,to{opacity:.6}50%{opacity:1}}.deep-analysis-banner{display:flex;flex-direction:column;gap:.3rem;padding:.45rem .75rem;font-size:.8rem;color:var(--color-gold);background:var(--color-tertiary);border:1px solid var(--color-border);border-radius:6px;transition:opacity .4s ease-out}.deep-analysis-banner--fading{opacity:0;pointer-events:none}.deep-analysis-banner__row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}@keyframes analysis-spin{to{transform:rotate(360deg)}}@keyframes analysis-breath{0%,to{opacity:.55}60%{opacity:1}}.deep-analysis-banner__spinner{display:inline-block;width:10px;height:10px;border:2px solid var(--color-gold-muted, #b8882e);border-top-color:var(--color-gold);border-radius:50%;animation:analysis-spin 1.4s cubic-bezier(.4,0,.6,1) infinite,analysis-breath 2.8s ease-in-out infinite;flex-shrink:0}.deep-analysis-banner__label{font-weight:500}.deep-analysis-banner__elapsed{opacity:.65;font-variant-numeric:tabular-nums}.deep-analysis-banner__progress{font-variant-numeric:tabular-nums;opacity:.85}.deep-analysis-banner__sep{opacity:.4}.deep-analysis-banner__tel{font-size:.72rem;font-variant-numeric:tabular-nums;color:var(--color-secondary);opacity:.85;letter-spacing:.01em}@keyframes chip-enter{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes count-tick{0%{transform:scale(1)}40%{transform:scale(1.45)}to{transform:scale(1)}}@keyframes bar-settle{0%{box-shadow:none}35%{box-shadow:0 0 14px 3px color-mix(in srgb,var(--color-brand) 55%,transparent)}to{box-shadow:none}}@keyframes brilliant-beacon{0%,to{box-shadow:0 0 5px 1px color-mix(in srgb,#1bada6 35%,transparent)}50%{box-shadow:0 0 12px 3px color-mix(in srgb,#1bada6 65%,transparent)}}.analysis-summary-bar{display:flex;gap:6px;padding:4px 0;-webkit-user-select:none;user-select:none}.analysis-summary-bar--settled{animation:bar-settle .9s ease-out forwards}.analysis-summary-bar__chip{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 6px;border-radius:6px;background:color-mix(in srgb,var(--chip-color) 18%,var(--color-tertiary));border:1px solid color-mix(in srgb,var(--chip-color) 45%,transparent);font-size:.78rem;font-weight:600;color:var(--color-primary);white-space:nowrap;cursor:pointer;transition:background .2s,border-color .2s,transform .12s;animation:chip-enter .35s ease-out both}.analysis-summary-bar__chip:hover{background:color-mix(in srgb,var(--chip-color) 28%,var(--color-tertiary));border-color:color-mix(in srgb,var(--chip-color) 65%,transparent);transform:translateY(-1px)}.analysis-summary-bar__chip:active{transform:translateY(0)}.analysis-summary-bar__chip--brilliant{animation-name:chip-enter,brilliant-beacon;animation-duration:.35s,2.5s;animation-timing-function:ease-out,ease-in-out;animation-delay:0ms,.5s;animation-iteration-count:1,infinite;animation-fill-mode:both,none}.analysis-summary-bar__symbol{font-size:11px;font-weight:800;color:var(--chip-color);font-family:Arial,sans-serif;line-height:1}.analysis-summary-bar__count{font-size:.95rem;font-weight:700;color:var(--chip-color);font-variant-numeric:tabular-nums;animation:count-tick .25s ease-out}.analysis-summary-bar__label{font-size:.72rem;font-weight:500;opacity:.85}.analysis-accuracy-row{display:flex;align-items:center;justify-content:space-between;padding:5px 10px;font-size:.73rem;color:var(--color-secondary);background:var(--color-tertiary);border:1px solid var(--color-border);border-radius:6px;animation:chip-enter .4s .15s ease-out both}.analysis-accuracy-row__player{display:flex;align-items:center;gap:5px}.analysis-accuracy-row__pawn{width:18px;height:18px;flex-shrink:0;display:block}.analysis-accuracy-row__pawn--black{filter:drop-shadow(0 0 3px #c8a84b) drop-shadow(0 0 6px rgba(200,168,75,.5))}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .analysis-accuracy-row__pawn--black{filter:none}}[data-theme=light] .analysis-accuracy-row__pawn--black{filter:none}.analysis-accuracy-row__pct{font-size:.85rem;font-weight:700;color:var(--color-primary);font-variant-numeric:tabular-nums}.analysis-accuracy-row__label{opacity:.5;text-transform:uppercase;letter-spacing:.06em;font-size:.63rem;font-weight:600}.pvp-disconnect-banner{padding:.5rem .75rem;font-size:.8rem;color:var(--color-error, #e05252);background:color-mix(in srgb,var(--color-error, #e05252) 12%,var(--color-tertiary));border:1px solid color-mix(in srgb,var(--color-error, #e05252) 40%,transparent);border-radius:6px;text-align:center}.critical-rail{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--color-tertiary);border:1px solid var(--color-border);border-bottom:none;border-radius:8px 8px 0 0;overflow:hidden}.critical-rail__label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;opacity:.5;white-space:nowrap;flex-shrink:0}.critical-rail__scroll{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;scroll-snap-type:x mandatory}.critical-rail__scroll::-webkit-scrollbar{display:none}.critical-rail__badge{display:flex;flex-direction:column;align-items:center;gap:1px;padding:4px 8px;border-radius:6px;border:1px solid color-mix(in srgb,var(--badge-color, #96a0b0) 40%,transparent);background:color-mix(in srgb,var(--badge-color, #96a0b0) 12%,var(--color-secondary-bg, transparent));color:var(--color-primary);cursor:pointer;font-size:.7rem;scroll-snap-align:start;transition:background .15s,transform .1s;white-space:nowrap;flex-shrink:0}.critical-rail__badge:hover{background:color-mix(in srgb,var(--badge-color, #96a0b0) 22%,var(--color-secondary-bg, transparent));transform:scale(1.05)}.critical-rail__badge--active{background:color-mix(in srgb,var(--badge-color, #96a0b0) 28%,var(--color-secondary-bg, transparent));border-color:var(--badge-color, #96a0b0)}.critical-rail__icon{font-size:.85rem;line-height:1}.critical-rail__move-id{font-size:.65rem;font-variant-numeric:tabular-nums;font-weight:600}.critical-rail__side{font-size:.55rem;opacity:.7;margin-left:1px}.move-tray{background:var(--color-tertiary);border:1px solid var(--color-border);border-top:none;border-bottom:none;padding:10px 12px;display:flex;flex-direction:column;gap:8px;animation:chip-enter .25s ease-out both}.move-tray__header{display:flex;align-items:center;justify-content:space-between;gap:8px}.move-tray__title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.move-tray__move-id{font-size:.75rem;font-weight:600;color:var(--color-secondary)}.move-tray__rating-badge{font-size:.7rem;font-weight:700;padding:2px 7px;border-radius:10px;color:#fff;letter-spacing:.02em}.move-tray__close{background:none;border:none;cursor:pointer;color:var(--color-secondary);font-size:.75rem;padding:4px;border-radius:4px;display:flex;align-items:center;opacity:.6;flex-shrink:0}.move-tray__close:hover{opacity:1;background:var(--color-border)}.move-tray__body{display:flex;flex-direction:column;gap:6px}.move-tray__move-row,.move-tray__best-row{display:flex;align-items:center;gap:8px;font-size:.8rem}.move-tray__played-label,.move-tray__best-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;opacity:.5;min-width:38px}.move-tray__played-san,.move-tray__best-san{font-weight:700;font-variant-numeric:tabular-nums;font-size:.9rem}.move-tray__best-label,.move-tray__best-san{color:#5b8a3c}.move-tray__line-row{display:flex;align-items:flex-start;gap:8px;font-size:.8rem}.move-tray__line-chips{display:flex;flex-wrap:wrap;align-items:center;gap:3px}.move-tray__san-with-icon{display:inline-flex;align-items:center;gap:2px}.move-tray__san-piece-icon{display:inline-block;flex-shrink:0;object-fit:contain;vertical-align:middle}.move-tray__line-chip{display:inline-flex;align-items:center;gap:3px;font-weight:700;font-size:.85rem;color:#5b8a3c;background:color-mix(in srgb,#5b8a3c 10%,var(--color-tertiary));border:1px solid color-mix(in srgb,#5b8a3c 30%,transparent);border-radius:4px;padding:1px 5px;cursor:pointer;transition:background .15s,border-color .15s}.move-tray__line-chip:hover{background:color-mix(in srgb,#5b8a3c 20%,var(--color-tertiary));border-color:color-mix(in srgb,#5b8a3c 50%,transparent)}.move-tray__line-chip--active{background:color-mix(in srgb,#5b8a3c 35%,var(--color-tertiary));border-color:#5b8a3c;color:#fff}.move-tray__chip-play-icon{font-size:.6rem;margin-right:2px;opacity:.75;flex-shrink:0}.move-tray__line-chip--playing{background:color-mix(in srgb,#e07b20 30%,var(--color-tertiary));border-color:#e07b20;color:#fff}.move-tray__line-chip--playing .move-tray__chip-play-icon{opacity:1}.move-tray__cp-loss{font-size:.7rem;color:var(--color-secondary);margin-left:auto;opacity:.7}.move-tray__key-moment{display:flex;flex-direction:column;gap:2px;border-left:3px solid #e07b20;padding:5px 8px;border-radius:0 4px 4px 0;background:color-mix(in srgb,currentColor 6%,var(--color-tertiary))}.move-tray__key-moment-label{font-size:.65rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--color-secondary);opacity:.7}.move-tray__key-moment-desc{font-size:.8rem;font-weight:600;color:var(--color-primary);line-height:1.3}.move-tray__san-piece-icon--black{filter:drop-shadow(0 0 2px rgba(212,168,83,.9)) drop-shadow(0 0 4px rgba(212,168,83,.5))}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .move-tray__san-piece-icon--black{filter:none}}[data-theme=light] .move-tray__san-piece-icon--black{filter:none}.move-tray__insight{display:flex;align-items:flex-start;gap:6px;font-size:.78rem;color:var(--color-secondary);background:color-mix(in srgb,var(--color-accent, #8b6a3b) 8%,var(--color-tertiary));border:1px solid color-mix(in srgb,var(--color-accent, #8b6a3b) 25%,transparent);border-radius:6px;padding:7px 9px;line-height:1.4}.move-tray__insight-icon{font-size:.85rem;flex-shrink:0;margin-top:1px}.move-tray__insight-text{color:var(--color-primary);opacity:.85}.move-tray__footer{display:flex;gap:8px;font-size:.62rem;color:var(--color-secondary);opacity:.5;padding-top:2px;border-top:1px solid var(--color-border);flex-wrap:wrap}.insight-banner{position:relative;display:flex;align-items:flex-start;gap:8px;padding:10px 12px;background:color-mix(in srgb,#8b6a3b 12%,var(--color-tertiary));border:1px solid color-mix(in srgb,#8b6a3b 35%,transparent);border-top:none;border-bottom:none;font-size:.8rem;cursor:pointer;transform:translateY(8px);opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .35s ease;pointer-events:none}.insight-banner--visible{transform:translateY(0);opacity:1;pointer-events:auto}.insight-banner__icon{font-size:1rem;flex-shrink:0}.insight-banner__text{flex:1;line-height:1.4;color:var(--color-primary)}.insight-banner__dismiss{background:none;border:none;cursor:pointer;font-size:1rem;line-height:1;color:var(--color-secondary);padding:0 2px;opacity:.6;flex-shrink:0}.insight-banner__dismiss:hover{opacity:1}.move-history{background-color:var(--color-tertiary);border:1px solid var(--color-border);border-top:none;border-radius:0 0 8px 8px}.game-layout__side-panel>.move-history:first-child{border-top:1px solid var(--color-border);border-radius:8px}.move-history{padding:8px;display:flex;flex-direction:column;flex:1;min-height:0;-webkit-user-select:none;user-select:none}.move-history__header{display:flex;align-items:center;justify-content:space-between;padding-bottom:6px;border-bottom:1px solid var(--color-border);margin-bottom:6px}.move-history__title{margin:0;padding:0 4px;font-size:12px;font-weight:600;opacity:.6;text-transform:uppercase;letter-spacing:.05em}.move-history__list{overflow-y:auto;overflow-x:hidden;flex:1;scroll-behavior:smooth}.move-history__empty{font-size:13px;color:var(--color-secondary);padding:12px 8px;text-align:center}.move-history__row{display:flex;align-items:flex-start;gap:4px;padding:1px 0}.move-history__number{flex:0 0 2em;font-size:12px;opacity:.4;text-align:right;padding-right:2px;padding-top:4px}.move-history__move{flex:1 1 0;min-width:0;background:none;border:none;cursor:pointer;padding:2px 4px 3px;border-radius:4px;text-align:left;text-decoration:none;font-family:var(--font-base);font-size:14px;font-weight:700;color:var(--color-primary);display:flex;flex-direction:column;gap:2px;min-height:30px}.move-history__main-row,.move-history__sub-row{display:flex;align-items:center;gap:4px;min-width:0}.move-history__san-row{display:inline-flex;align-items:baseline;gap:3px;min-width:0;overflow:hidden}.move-history__text{display:contents}.move-history__text-top{display:inline-flex;align-items:baseline;gap:3px}.move-history__move--critical{border-left:3px solid var(--critical-color, #e07b20);padding-left:1px}.move-history__critical-label{display:block;font-size:.68rem;color:var(--critical-color, #e07b20);font-weight:600;margin-top:1px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.move-history__move:hover{background-color:#0000000f}.move-history__move--empty{cursor:default}.move--current{background-color:var(--color-accent);font-weight:700}.move-history__nav{display:flex;align-items:center;gap:2px}.move-history__nav-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;font-size:12px;cursor:pointer;background:none;border:none;border-radius:8px;color:var(--color-secondary);padding:0;transition:background .15s,color .15s}.move-history__nav-btn:hover:not(:disabled){background:#0000000f;color:var(--color-primary)}.move-history__nav-btn:disabled{opacity:.25;cursor:default}.move-history__badge,.move-history__badge-spacer{display:inline-flex;flex-shrink:0;width:14px;height:14px}.move-history__badge{align-items:center;justify-content:center;border-radius:50%;font-size:7px;font-weight:800;color:#fff;line-height:1;letter-spacing:0;font-family:var(--font-base)}.move-history__rating-label{font-size:10px;font-weight:400;color:var(--color-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.move-history__geo-attrib{display:flex;align-items:center;gap:3px;margin-top:2px}.move-history__geo-handle{font-size:9px;color:var(--color-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.move-history__histogram{flex:0 0 56px;width:56px;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-end;gap:3px;padding:4px 0 3px 4px;overflow:hidden}.move-history__hist-row{display:flex;align-items:center;justify-content:flex-end;gap:3px}.move-history__hist-label{font-size:8px;font-weight:500;color:var(--color-secondary);opacity:.7;white-space:nowrap;min-width:0;text-align:right;flex-shrink:1;overflow:hidden;text-overflow:ellipsis}.move-history__hist-bar{display:block;height:3px;border-radius:2px;min-width:2px;max-width:28px;flex-shrink:0}.move-history__hist-bar--white{background:#d8cfc0;opacity:.7}.move-history__hist-bar--black{background:#8a7a60;opacity:.8}[data-theme=light] .move-history__hist-bar--white{background:#999}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .move-history__hist-bar--white{background:#999}}.move-history__time{font-size:9px;color:var(--color-secondary);opacity:.65;font-variant-numeric:tabular-nums;font-weight:400}.move-history__move--preloaded{opacity:.6}.move-history__nav-btn--play:disabled{opacity:.4}.move-history__piece-icon{display:block;flex-shrink:0;width:16px;height:16px;object-fit:contain}.move-history__piece-icon--black{filter:drop-shadow(0 0 2px rgba(212,168,83,.9)) drop-shadow(0 0 4px rgba(212,168,83,.5))}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .move-history__piece-icon--black{filter:none}}[data-theme=light] .move-history__piece-icon--black{filter:none}.move-history__sarathi-badge{font-size:10px;vertical-align:middle;opacity:.8}.move-history__premove-row{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-top:1px solid var(--color-border-light);background:#ff780012}.move-history__premove-label{font-size:12px;color:var(--color-secondary)}.move-history__premove-cancel{width:22px;height:22px;border:none;border-radius:4px;background:none;color:var(--color-secondary);cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s,color .12s}.move-history__premove-cancel:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.player-panel{display:flex;flex-direction:column;width:var(--board-size);padding:4px 0}.player-panel__top-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.player-panel__left{display:flex;align-items:center;gap:8px;min-width:0}.player-panel__avatar-wrap{position:relative;flex-shrink:0;width:34px;height:34px}.player-panel__avatar{width:34px;height:34px;border-radius:50%;overflow:hidden;object-fit:cover}.player-panel__flag-badge{position:absolute;top:-1px;right:-2px;font-size:12px;line-height:1;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 0 1px rgba(0,0,0,.4))}.player-panel__name-group{display:flex;flex-direction:column;flex:1;min-width:0}.player-panel__name-row{display:flex;align-items:center;gap:5px;min-width:0}.player-panel__name{font-size:13px;font-weight:600;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@keyframes player-name-reveal{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.player-panel__name--reveal{animation:player-name-reveal .35s cubic-bezier(.22,1,.36,1) both}.player-panel__info-btn{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;border:1px solid #ccc;background:none;color:#999;font-size:9px;font-weight:700;font-style:italic;cursor:help;padding:0;line-height:1;flex-shrink:0;position:relative}.player-panel__info-btn:hover{border-color:var(--color-secondary);color:var(--color-secondary)}.player-panel__tooltip{position:absolute;z-index:300;top:calc(100% + 8px);left:0;width:260px;background:linear-gradient(145deg,beige,tan);color:#2a2a2a;text-align:left;text-decoration:none;border-radius:8px;padding:12px 14px;box-shadow:0 4px 16px #00000047;font-size:12px;font-weight:400;font-style:normal;line-height:1.5;white-space:normal;border:1px solid #8b4513;pointer-events:none;opacity:0;visibility:hidden;transform:scale(.88) translateY(-4px);transform-origin:top left;transition:opacity .18s ease-out,transform .18s ease-out,visibility 0s linear .18s}.player-panel__tooltip:after{content:"";position:absolute;bottom:100%;left:8px;border:5px solid transparent;border-bottom-color:tan}.player-panel__info-btn:hover .player-panel__tooltip,.player-panel__info-btn:focus .player-panel__tooltip{opacity:1;visibility:visible;transform:scale(1) translateY(0);transition:opacity .18s ease-out,transform .18s ease-out,visibility 0s linear 0s}.player-panel__subtitle{font-size:10px;font-weight:500;color:#999;white-space:nowrap;padding:0 5px}.player-panel__captured{display:flex;align-items:center;flex-wrap:nowrap;gap:1px;overflow:hidden;max-height:0;transition:max-height .25s ease;padding-left:3px;margin-left:-3px}.player-panel__captured--visible{max-height:15px;margin-top:4px}.player-panel__piece-group{position:relative;display:inline-flex;align-items:center;flex-shrink:0}.player-panel__piece{width:15px;height:15px;flex-shrink:0}.player-panel__piece-count{font-size:9px;font-weight:700;color:var(--color-secondary);line-height:1;margin-left:1px;vertical-align:super}.player-panel__advantage{font-size:12px;font-weight:700;color:var(--color-secondary);margin-right:3px;line-height:1;flex-shrink:0}.player-panel__rating{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--color-muted, #888);line-height:1;margin-top:2px}.player-panel__rating-primary{font-weight:600;color:var(--color-secondary)}.player-panel__rating-inline{font-size:.8em;color:var(--color-muted, #888);margin-left:3px;white-space:nowrap}.player-panel__rating-pvp{font-size:10px;opacity:.75}.rolling-digits{display:inline-flex;overflow:hidden;vertical-align:baseline;line-height:1.2}.rolling-digits__digit{display:inline-block}@keyframes digit-roll-up{0%{transform:translateY(100%);opacity:0}20%{opacity:1}to{transform:translateY(0);opacity:1}}@keyframes digit-roll-down{0%{transform:translateY(-100%);opacity:0}20%{opacity:1}to{transform:translateY(0);opacity:1}}.rolling-digits__digit--up{animation:digit-roll-up .55s cubic-bezier(.22,1,.36,1) both}.rolling-digits__digit--down{animation:digit-roll-down .55s cubic-bezier(.22,1,.36,1) both}.rolling-digits__digit:nth-child(1){animation-delay:0ms}.rolling-digits__digit:nth-child(2){animation-delay:40ms}.rolling-digits__digit:nth-child(3){animation-delay:80ms}.rolling-digits__digit:nth-child(4){animation-delay:.12s}.rolling-digits__digit:nth-child(5){animation-delay:.16s}@keyframes rating-delta-fade{0%{opacity:0}10%{opacity:1}70%{opacity:1}to{opacity:0}}.player-panel__rating-delta{display:inline-block;margin-left:4px;font-size:.75em;font-weight:600;white-space:nowrap;pointer-events:none;animation:rating-delta-fade 3.5s ease-in-out forwards}.player-panel__rating-delta--gain{color:#4caf50}.player-panel__rating-delta--loss{color:#f44336}.player-panel__clock{display:flex;align-items:center;gap:5px;flex-shrink:0;padding:5px 10px;border-radius:6px;background:var(--color-tertiary);border:1px solid var(--color-border);font-size:15px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-secondary);letter-spacing:.02em}.player-panel__clock--active{background:var(--color-surface);color:var(--color-primary)}.player-panel__clock--warning{color:#f59e0b;border-color:#f59e0b66}.player-panel__clock--danger{color:var(--color-danger);border-color:#dc1e1e66;animation:clock-danger-pulse .8s ease-in-out infinite}@keyframes clock-danger-pulse{0%,to{opacity:1}50%{opacity:.5}}.player-panel__clock-icon{width:11px;height:11px;flex-shrink:0;opacity:.7}.player-panel__clock-time{font-variant-numeric:tabular-nums}.player-panel--concluded .player-panel__avatar{filter:grayscale(100%);opacity:.5;transition:filter .4s ease,opacity .4s ease}.player-panel--concluded .player-panel__name{color:var(--text-muted, #888);transition:color .4s ease}.player-panel__disconnected{display:inline-flex;align-items:center;color:#f44336;flex-shrink:0;margin-left:2px;position:relative;cursor:default}.player-panel__disconnected-icon{width:13px;height:13px}.player-panel__disconnected:hover .player-panel__signal-tooltip{display:block}.player-panel__signal{display:inline-flex;align-items:center;color:var(--color-muted, #888);cursor:default;flex-shrink:0;margin-left:2px;position:relative}.player-panel__signal-tooltip{display:none;position:absolute;z-index:300;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--color-surface, #fff);border:1px solid var(--color-border, #ccc);border-radius:6px;padding:4px 8px;font-size:11px;white-space:nowrap;color:var(--color-primary);box-shadow:0 2px 8px #00000026;pointer-events:none}.player-panel__signal-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--color-border, #ccc)}.player-panel__signal:hover .player-panel__signal-tooltip{display:block}.player-panel__edit-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0 2px;color:#aaa;flex-shrink:0}.player-panel__edit-btn:hover{color:var(--color-primary)}.player-panel__edit-input{font:inherit;font-size:13px;font-weight:600;color:var(--color-primary);background:none;border:none;border-bottom:1px solid currentColor;width:100px;outline:none;padding:0}.player-panel__edit-action-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:2px 3px;border-radius:3px;font-size:11px;flex-shrink:0}.player-panel__edit-action-btn:disabled{opacity:.4;cursor:not-allowed}.player-panel__edit-action-btn--cancel{color:#888}.player-panel__edit-action-btn--cancel:hover:not(:disabled){color:#ef4444;background:#ef44441a}.player-panel__edit-action-btn--confirm{color:#888}.player-panel__edit-action-btn--confirm:hover:not(:disabled){color:#22c55e;background:#22c55e1a}.player-panel__edit-error{display:block;font-size:10px;color:#ef4444;margin-top:2px;line-height:1.3}.player-panel__auth-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0 2px;color:#aaa;flex-shrink:0}.player-panel__auth-btn:hover{color:var(--color-primary)}.player-panel__sarathi-user{display:flex;align-items:center;gap:4px;flex-shrink:0}.player-panel__sarathi-sep{font-size:13px;font-weight:300;color:var(--color-secondary);opacity:.5;padding:0 1px;-webkit-user-select:none;user-select:none}.player-panel__sarathi-avatar{width:34px;height:34px;border-radius:50%;flex-shrink:0;overflow:hidden}.player-panel__sarathi-avatar-bg{fill:var(--color-tertiary)}.player-panel__sarathi-user-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;cursor:pointer;padding:0;border-radius:4px;transition:opacity .15s}.player-panel__sarathi-user-btn:hover{opacity:.8}.player-panel__sarathi-user-name{font-size:12px;font-weight:600;color:var(--color-primary);white-space:nowrap}@keyframes sarathi-avatar-glow{0%{filter:drop-shadow(0 0 0px rgba(234,179,8,0))}6.25%{filter:drop-shadow(0 0 7px rgba(234,179,8,1)) drop-shadow(0 0 14px rgba(234,179,8,.55))}18.75%{filter:drop-shadow(0 0 0px rgba(234,179,8,0))}to{filter:drop-shadow(0 0 0px rgba(234,179,8,0))}}@keyframes sarathi-text-sweep{0%,12%{background-position:100% center}25%{background-position:0% center}to{background-position:0% center}}.player-panel__sarathi-user--waiting{opacity:.5}.player-panel__sarathi-user--waiting .player-panel__sarathi-avatar{animation:sarathi-avatar-glow 4s linear infinite}.player-panel__sarathi-user--waiting .player-panel__sarathi-user-name{background:linear-gradient(90deg,var(--color-secondary) 0%,var(--color-secondary) 35%,#fde68a 43%,#eab308 50%,#fde68a 57%,var(--color-secondary) 65%,var(--color-secondary) 100%);background-size:300% 100%;background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:sarathi-text-sweep 4s linear infinite;animation-delay:.5s}.player-panel__sarathi-user--active{opacity:1}.player-panel__sarathi-user--deactivated{opacity:.3;pointer-events:none}.player-panel__sarathi-user--hidden{display:none}@keyframes sarathi-flying-solo{0%{opacity:0;transform:translateY(4px)}15%{opacity:1;transform:translateY(0)}70%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.player-panel__sarathi-user--flying-solo{pointer-events:none}.player-panel__sarathi-solo{font-size:11px;font-style:italic;color:var(--color-secondary);white-space:nowrap;pointer-events:none;animation:sarathi-flying-solo 2.4s ease-in-out both}.sarathi-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000059;animation:modal-backdrop-in .18s ease-out both}.sarathi-modal__backdrop--closing{animation:modal-backdrop-out .2s ease-in both}.sarathi-modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:20px;width:min(360px,calc(100vw - 32px));box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;gap:14px}.sarathi-modal__header{display:flex;align-items:center;justify-content:space-between}.sarathi-modal__title-row{display:flex;align-items:center;gap:8px}.sarathi-modal__sparkle{font-size:22px;line-height:1}.sarathi-modal__title{margin:0;font-size:18px;font-weight:700;color:var(--color-primary)}.sarathi-modal__close{background:none;border:none;cursor:pointer;color:var(--color-secondary);font-size:16px;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .15s}.sarathi-modal__close:hover{color:var(--color-primary)}.sarathi-modal__tagline{margin:0;font-size:13px;color:var(--color-secondary);line-height:1.4}.sarathi-modal__tabs{display:flex;gap:4px;background:var(--color-tertiary);border:1px solid var(--color-border);border-radius:8px;padding:3px}.sarathi-modal__tab{flex:1;padding:6px 4px;border:none;border-radius:6px;background:none;color:var(--color-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;text-align:center}.sarathi-modal__tab--active{background:var(--color-bg);color:var(--color-primary);font-weight:700;box-shadow:0 1px 4px #0000001a}.sarathi-modal__mode-desc{margin:0;font-size:14px;color:var(--color-secondary);min-height:2.5em;line-height:1.5}.sarathi-modal__param-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sarathi-modal__param-label{font-size:13px;font-weight:600;color:var(--color-primary);white-space:nowrap}.sarathi-modal__param-hint{font-size:11px;color:var(--color-secondary);flex-basis:100%}.sarathi-modal__stepper{display:flex;align-items:center;gap:0;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.sarathi-modal__stepper-btn{background:var(--color-tertiary);border:none;width:28px;height:28px;cursor:pointer;font-size:16px;font-weight:700;color:var(--color-primary);display:flex;align-items:center;justify-content:center;transition:background .15s}.sarathi-modal__stepper-btn:hover:not(:disabled){background:var(--color-border)}.sarathi-modal__stepper-btn:disabled{opacity:.35;cursor:default}.sarathi-modal__stepper-val{font-size:14px;font-weight:700;min-width:32px;text-align:center;color:var(--color-primary);padding:0 4px}.sarathi-modal__toggle-pair{display:flex;border:1px solid var(--color-border);border-radius:6px;overflow:hidden}.sarathi-modal__toggle-btn{padding:5px 14px;border:none;background:var(--color-tertiary);color:var(--color-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.sarathi-modal__toggle-btn--active{background:var(--color-surface, #fff);color:var(--color-primary);font-weight:700}.sarathi-modal__strength{display:flex;flex-direction:column;gap:8px}.sarathi-modal__strength-header{display:flex;justify-content:space-between;align-items:baseline}.sarathi-modal__strength-label{font-size:12px;font-weight:600;color:var(--color-secondary);text-transform:uppercase;letter-spacing:.04em}.sarathi-modal__strength-name{font-size:13px;font-weight:700;color:var(--color-primary)}.sarathi-modal__slider{width:100%;accent-color:var(--color-primary);cursor:pointer;height:4px}.sarathi-modal__strength-ticks{display:flex;justify-content:space-between;padding:0 2px}.sarathi-modal__tick{width:4px;height:4px;border-radius:50%;background:var(--color-primary);transition:background .15s}.sarathi-modal__tick--active{background:var(--color-primary)}.sarathi-modal__unrated-notice{margin:0;font-size:11px;color:var(--color-secondary);text-align:center;opacity:.7}.sarathi-modal__actions{display:flex;gap:8px;justify-content:flex-end}.sarathi-modal__btn{padding:8px 18px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.sarathi-modal__btn--activate{background:#eab308;color:#000}.sarathi-modal__btn--activate:hover{background:#ca9a06}.sarathi-modal__btn--remove{background:var(--color-tertiary);color:var(--color-secondary);border:1px solid var(--color-border)}.sarathi-modal__btn--remove:hover{color:#ef4444;border-color:#ef4444}.toolbar__signin-google{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:1px solid #dadce0;border-radius:50%;background:#fff;cursor:pointer;padding:0;flex-shrink:0;transition:border-color .15s,box-shadow .15s}.toolbar__signin-google:hover{border-color:#aaa;box-shadow:0 1px 3px #0000001f}.toolbar__slider[style*=--cap]{background:linear-gradient(to right,var(--color-brand) 0%,var(--color-brand) var(--cap, 100%),#ddd var(--cap, 100%),#ddd 100%);-webkit-appearance:none;-moz-appearance:none;appearance:none;height:4px;border-radius:2px}.toolbar__slider[style*=--cap]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--color-brand);cursor:pointer;border:none}.toolbar__slider[style*=--cap]::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--color-brand);cursor:pointer;border:none}@keyframes modal-backdrop-in{0%{opacity:0}to{opacity:1}}@keyframes modal-backdrop-out{0%{opacity:1}to{opacity:0}}@keyframes modal-panel-in{0%{opacity:0;transform:scale(.88) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modal-panel-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.88) translateY(8px)}}.timer-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:400;animation:modal-backdrop-in .18s ease-out}.timer-modal__backdrop--closing{animation:modal-backdrop-out .2s ease-in forwards}.timer-modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:20px;width:min(320px,calc(100vw - 32px));box-shadow:0 8px 32px #0006}.timer-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.timer-modal__title{display:flex;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:600;color:var(--color-primary)}.timer-modal__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:none;color:var(--color-secondary);cursor:pointer;font-size:14px;transition:background .15s,color .15s}.timer-modal__close:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.timer-modal__options{display:flex;flex-direction:column;gap:6px}.timer-modal__option{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid var(--color-border);border-radius:8px;background:none;color:var(--color-primary);cursor:pointer;transition:background .12s,border-color .12s}.timer-modal__option:hover{background:var(--color-tertiary-hover);border-color:var(--color-secondary)}.timer-modal__option--active{background:var(--color-accent);border-color:var(--color-secondary)}.timer-modal__option-label{font-size:14px;font-weight:600}.timer-modal__option-sub{font-size:12px;color:var(--color-secondary)}.difficulty-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:400;animation:modal-backdrop-in .18s ease-out}.difficulty-modal__backdrop--closing{animation:modal-backdrop-out .2s ease-in forwards}.difficulty-modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:20px;width:min(340px,calc(100vw - 32px));box-shadow:0 8px 32px #0006}.difficulty-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.difficulty-modal__title{display:flex;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:600;color:var(--color-primary)}.difficulty-modal__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:none;color:var(--color-secondary);cursor:pointer;font-size:14px;transition:background .15s,color .15s}.difficulty-modal__close:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.difficulty-modal__body{display:flex;flex-direction:column;gap:14px}.difficulty-modal__level-header{display:flex;align-items:baseline;gap:10px}.difficulty-modal__level-num{font-size:13px;color:var(--color-secondary);font-weight:500}.difficulty-modal__scholar{font-size:18px;font-weight:700;color:var(--color-primary)}.difficulty-modal__slider-row{display:flex;align-items:center;gap:10px}.difficulty-modal__slider-label{font-size:11px;color:var(--color-secondary);min-width:10px;text-align:center}.difficulty-modal__slider{flex:1;height:4px;accent-color:var(--color-primary);cursor:pointer}.difficulty-modal__description{font-size:13px;color:var(--color-secondary);line-height:1.55;margin:0;max-height:120px;overflow-y:auto}.difficulty-modal__signin-group{display:flex;align-items:center;gap:8px;padding:9px 14px;border:1px solid var(--color-border);border-radius:8px}.difficulty-modal__signin-label{flex:1;font-size:13px;color:var(--color-secondary)}.difficulty-modal__signin-icon{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;font-size:14px;padding:0;color:var(--color-primary);transition:background-color .15s;flex-shrink:0}.difficulty-modal__signin-icon:hover{background:var(--color-tertiary-hover)}.difficulty-modal__signin{display:flex;align-items:center;gap:8px;padding:9px 14px;border:1px solid var(--color-border);border-radius:8px;background:none;color:var(--color-secondary);font-size:13px;cursor:pointer;transition:background .12s,border-color .12s}.difficulty-modal__signin:hover{background:var(--color-tertiary-hover);border-color:var(--color-secondary);color:var(--color-primary)}.pvp-lobby{padding:12px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);display:flex;flex-direction:column;gap:10px}.pvp-lobby__title{margin:0;font-size:13px;font-weight:600;color:var(--color-primary)}.pvp-lobby__label{margin:0;font-size:12px;color:var(--color-secondary)}.pvp-lobby__row{display:flex;gap:6px;flex-wrap:wrap}.pvp-lobby__divider{font-size:11px;color:var(--color-secondary);text-align:center}.pvp-lobby__input{flex:1;min-width:0;padding:5px 8px;font-size:13px;border:1px solid var(--color-border);border-radius:4px;outline:none;background:var(--color-bg);color:var(--color-primary)}.pvp-lobby__input:focus{border-color:var(--color-brand)}.pvp-lobby__btn{width:100%;padding:8px 12px;font-size:13px;font-weight:600;border-radius:6px;cursor:pointer;transition:opacity .15s,background .15s;white-space:nowrap;text-align:center}.pvp-lobby__btn--searching{background:var(--color-tertiary);color:var(--color-secondary);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;gap:8px;cursor:default;opacity:1}.pvp-lobby__spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--color-border);border-top-color:var(--color-brand);border-radius:50%;animation:pvp-lobby-spin .7s linear infinite;flex-shrink:0}@keyframes pvp-lobby-spin{to{transform:rotate(360deg)}}.pvp-lobby__btn--primary{background:var(--color-brand);color:#fff;border:none}.pvp-lobby__btn--primary:hover:not(:disabled){background:var(--color-brand-hover)}.pvp-lobby__btn--secondary{background:var(--color-surface);color:var(--color-primary);border:1px solid var(--color-border)}.pvp-lobby__btn--secondary:hover:not(:disabled){background:var(--color-tertiary)}.pvp-lobby__btn--ghost{background:none;color:var(--color-secondary);border:none;padding:4px 0;font-size:12px;font-weight:400;width:auto;align-self:center}.pvp-lobby__btn:disabled{opacity:.4;cursor:default}.pvp-lobby__code-area{display:flex;flex-direction:column;gap:6px}.pvp-lobby__code-row{display:flex;align-items:center;gap:8px}.pvp-lobby__code{flex:1;padding:4px 8px;background:var(--color-tertiary);border:1px solid var(--color-border-light);border-radius:4px;font-size:13px;font-family:var(--font-base);word-break:break-all}.pvp-lobby__error{margin:0;font-size:12px;color:var(--color-danger)}.pvp-lobby__tc-row{display:flex;gap:4px}.pvp-lobby__tc-btn--active{color:var(--color-brand)!important}.pvp-lobby__tabs{display:flex;background:var(--color-tertiary);border:1px solid var(--color-border);border-radius:20px;padding:3px;gap:2px}.pvp-lobby__tab{flex:1;padding:5px 8px;font-size:12px;font-weight:600;border:none;border-radius:17px;background:transparent;color:var(--color-secondary);cursor:pointer;transition:background .15s,color .15s}.pvp-lobby__tab--active{background:var(--color-brand);color:#fff;box-shadow:0 1px 3px #0000002e}.pvp-lobby__tab:not(.pvp-lobby__tab--active):hover{background:var(--color-tertiary-hover);color:var(--color-brand)}.pvp-lobby__waiting{margin:0;font-size:11px;color:var(--color-secondary);text-align:center;display:flex;align-items:center;justify-content:center;gap:5px}@keyframes pvp-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}.pvp-lobby__online-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#4caf50;flex-shrink:0;animation:pvp-pulse 1.4s ease-in-out infinite}.pvp-lobby__action-bar{width:100%;box-sizing:border-box;border-radius:8px;background:var(--color-tertiary);border:1px solid var(--color-border)}.pvp-lobby__action-msg{display:flex;align-items:center;gap:6px}.pvp-lobby__expiry-inline{font-size:11px;color:var(--color-secondary)}@media(max-width:600px){.player-panel__info-btn{position:static}.player-panel__name-row{position:relative}.player-panel__tooltip{position:absolute;top:calc(100% + 6px);left:0;right:0;width:min(300px,calc(100vw - 32px));max-width:none}.player-panel__tooltip:after{display:none}.toolbar__info-btn{position:static}.toolbar__group--difficulty{position:relative}.toolbar__tooltip{position:absolute;top:calc(100% + 6px);left:0;right:0;width:auto;max-width:none}.toolbar__tooltip:after{display:none}}@media(max-width:768px){.app-header__nav-mobile{display:flex}.game-layout__body{flex-direction:column}.game-layout__main{flex-direction:column;align-items:center;gap:8px;padding:8px}.game-layout__side-panel{flex:none;width:100%;max-width:min(95vw,560px);position:static;max-height:none;overflow:visible}.game-layout__board-area--analysis{--board-size: min( calc(75vw - 36px) , 420px)}.app-header{padding:6px 10px;gap:8px}.app-header__site-links{display:none}.app-header__mobile-signin{display:flex}}@media(min-width:769px)and (max-width:900px)and (orientation:portrait){.game-layout__main{flex-direction:column;align-items:center;gap:8px;padding:8px}.game-layout__side-panel{flex:none;width:100%;max-width:min(95vw,560px);min-width:unset;position:static;max-height:none;overflow:visible}:root{--board-size: calc(100vw - 32px) }}@media(max-width:480px){.move-history__list{max-height:clamp(180px,35vh,380px)}.toolbar{gap:4px;padding:4px 6px}}.help-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500;padding:1rem;animation:modal-backdrop-in .18s ease-out}.help-modal-overlay--closing{animation:modal-backdrop-out .2s ease-in forwards}@keyframes modal-origin-in{0%{opacity:0;transform:translate(var(--hm-dx, 0px),var(--hm-dy, 0px)) scale(.04)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes modal-origin-out{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(var(--hm-dx, 0px),var(--hm-dy, 0px)) scale(.04)}}.help-modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;box-shadow:0 12px 40px #0006;display:flex;flex-direction:column;gap:1rem}@keyframes piece-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.help-modal__card-img{animation:piece-float 3s ease-in-out infinite}.help-modal__card:nth-child(1) .help-modal__card-img{animation-delay:0ms}.help-modal__card:nth-child(2) .help-modal__card-img{animation-delay:.4s}.help-modal__card:nth-child(3) .help-modal__card-img{animation-delay:.8s}.help-modal__card:nth-child(4) .help-modal__card-img{animation-delay:1.2s}.help-modal__card:nth-child(5) .help-modal__card-img{animation-delay:1.6s}.help-modal__card:nth-child(6) .help-modal__card-img{animation-delay:2s}.help-modal__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.help-modal__title{display:flex;align-items:center;gap:.4rem;font-size:1rem;font-weight:700;color:var(--color-primary);margin:0}.help-modal__back{display:flex;align-items:center;gap:.4rem;background:none;border:none;color:var(--color-secondary);font-size:.85rem;font-weight:600;cursor:pointer;padding:.25rem 0;transition:color .15s}.help-modal__back:hover{color:var(--color-primary)}.help-modal__close{background:none;border:none;color:var(--color-secondary);font-size:1.4rem;line-height:1;cursor:pointer;padding:.2rem .4rem;border-radius:6px;transition:color .15s,background .15s;margin-left:auto}.help-modal__close:hover{color:var(--color-primary);background:var(--color-tertiary-hover)}.help-modal__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.help-modal__card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:.75rem .5rem .6rem;background:var(--color-tertiary);border:1px solid var(--color-border);border-radius:10px;cursor:pointer;transition:background .12s,border-color .12s}.help-modal__card:hover{background:var(--color-tertiary-hover);border-color:var(--color-gold, #d4a853)}.help-modal__card-img{width:48px;height:48px;pointer-events:none}.help-modal__card-name{font-size:.82rem;font-weight:700;color:var(--color-primary);line-height:1.2}.help-modal__card-label{font-size:.72rem;color:var(--color-secondary);line-height:1}.help-modal__detail{display:flex;flex-direction:column;gap:.75rem}.help-modal__video-wrap{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;background:#000}.help-modal__video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:none}.help-modal__detail-body{display:flex;align-items:flex-start;gap:.75rem}.help-modal__detail-piece{width:52px;height:52px;flex-shrink:0}.help-modal__detail-name{font-size:1rem;font-weight:700;color:var(--color-gold, #d4a853);margin:0 0 .35rem}.help-modal__detail-label{font-weight:400;color:var(--color-secondary);font-size:.9rem}.help-modal__detail-aliases{display:flex;gap:.75rem;flex-wrap:wrap;margin:0 0 .4rem}.help-modal__detail-alias{font-size:.78rem;color:var(--color-secondary)}.help-modal__detail-moves{font-size:.88rem;color:var(--color-primary);line-height:1.5;margin:0}.help-modal__tip{font-size:.78rem;color:var(--color-secondary);line-height:1.5;padding:10px 12px;margin-top:8px;border-top:1px solid var(--color-border-light);border-radius:0 0 8px 8px}.help-modal__tip strong{color:var(--color-primary)}@keyframes help-enter-right{0%{opacity:0;transform:translate(14px)}to{opacity:1;transform:translate(0)}}@keyframes help-enter-left{0%{opacity:0;transform:translate(-14px)}to{opacity:1;transform:translate(0)}}.help-modal__detail--in{animation:help-enter-right .16s ease-out both}.help-modal__grid--in{animation:help-enter-left .16s ease-out both}.help-modal__title--in{animation:help-enter-left .12s ease-out both}.help-modal__back--in{animation:help-enter-right .12s ease-out both}.help-modal__tabs{display:flex;gap:4px;padding:0 16px 12px;border-bottom:1px solid var(--color-border, #2a2a2a)}.help-modal__tab{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;border:1px solid var(--color-border, #2a2a2a);background:transparent;color:var(--color-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.help-modal__tab:hover{background:var(--color-surface-2, #1e1e1e);color:var(--color-primary, #f0e6cc)}.help-modal__tab--active{background:var(--clr-gold-dim, rgba(212, 168, 83, .15));border-color:var(--clr-gold, #d4a853);color:var(--clr-gold, #d4a853)}.help-modal__geo{padding:16px;display:flex;flex-direction:column;gap:12px}.help-modal__geo--in{animation:help-enter-up .12s ease-out both}.help-modal__geo-intro{font-size:.85rem;color:var(--color-secondary);line-height:1.5;margin:0}.help-modal__geo-rules{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.help-modal__geo-rules li{font-size:.82rem;color:var(--color-secondary);line-height:1.5;padding:8px 12px;background:var(--color-surface-2, #1a1a1a);border-radius:8px;border-left:3px solid var(--clr-gold, #d4a853)}.help-modal__geo-rules li strong{color:var(--color-primary, #f0e6cc);display:block;margin-bottom:2px;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.help-modal__geo-link{display:inline-flex;align-items:center;justify-content:center;padding:8px 20px;border-radius:999px;background:var(--clr-gold-dim, rgba(212, 168, 83, .15));border:1px solid var(--clr-gold, #d4a853);color:var(--clr-gold, #d4a853);font-size:.82rem;font-weight:600;text-decoration:none;transition:background .15s;align-self:flex-start}.help-modal__geo-link:hover{background:var(--clr-gold-dim-hover, rgba(212, 168, 83, .25))}.site-nav__signin-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-secondary);padding:6px 14px 2px}.site-nav__signin-google-icon{width:16px;height:16px;flex-shrink:0}.sound-btn{position:absolute;top:0;right:0;transform:translateY(-50%);z-index:10;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:5px 5px 0;background:var(--color-bg-elevated, rgba(0, 0, 0, .12));color:var(--color-secondary);cursor:pointer;font-size:11px;transition:background .15s,color .15s}.sound-btn:hover{background:var(--color-bg-hover, rgba(0, 0, 0, .18));color:var(--color-primary)}.sound-btn--sound{color:var(--color-primary)}.sound-btn--haptic{color:var(--color-secondary)}.sound-btn--mute{opacity:.45}.settings-modal__backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:400;animation:modal-backdrop-in .18s ease-out}.settings-modal__backdrop--closing{animation:modal-backdrop-out .2s ease-in forwards}.settings-modal{background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;padding:20px;width:min(340px,calc(100vw - 32px));box-shadow:0 8px 32px #0006}.settings-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.settings-modal__title{display:flex;align-items:center;gap:8px;margin:0;font-size:15px;font-weight:600;color:var(--color-primary)}.settings-modal__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:none;color:var(--color-secondary);cursor:pointer;font-size:14px;transition:background .15s,color .15s}.settings-modal__close:hover{background:var(--color-tertiary-hover);color:var(--color-primary)}.settings-modal__row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.settings-modal__row+.settings-modal__row{border-top:1px solid var(--color-border-light)}.settings-modal__row-label{font-size:13px;font-weight:500;color:var(--color-primary);flex-shrink:0;min-width:64px}.settings-modal__row-toggle{display:flex;border:1px solid var(--color-border);border-radius:7px;overflow:hidden}.settings-modal__toggle-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 12px;border:none;border-right:1px solid var(--color-border);background:none;color:var(--color-secondary);cursor:pointer;font-size:13px;font-weight:500;transition:background .12s,color .12s;white-space:nowrap}.settings-modal__toggle-btn:last-child{border-right:none}.settings-modal__toggle-btn:hover:not(:disabled){background:var(--color-tertiary-hover);color:var(--color-primary)}.settings-modal__toggle-btn--active{background:var(--color-brand-light);color:var(--color-brand)}.settings-modal__toggle-btn--active:hover:not(:disabled){background:var(--color-brand-light);color:var(--color-brand)}.settings-modal__toggle-btn--disabled{opacity:.4;cursor:not-allowed}.settings-modal__divider{height:1px;background:var(--color-border);margin:16px 0 12px}.settings-modal__save-btn{width:100%;padding:9px 14px;border:1px solid var(--color-brand);border-radius:7px;background:none;color:var(--color-brand);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.settings-modal__save-btn:hover{background:var(--color-brand);color:#fff}.settings-modal__name-edit{display:flex;align-items:center;gap:4px;flex:1}.settings-modal__name-input{flex:1;padding:4px 8px;font-size:13px;font-family:var(--font-base);background:var(--color-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-primary);outline:none}.settings-modal__name-input:focus{border-color:var(--color-brand)}.settings-modal__name-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;border:none;cursor:pointer;font-size:12px;padding:0;transition:background .15s}.settings-modal__name-btn--confirm{background:var(--color-brand);color:#fff}.settings-modal__name-btn--cancel{background:var(--color-tertiary);color:var(--color-secondary)}.settings-modal__name-display{background:none;border:none;cursor:pointer;font-size:13px;font-family:var(--font-base);color:var(--color-primary);padding:4px 8px;border-radius:6px;border:1px solid transparent;transition:border-color .15s;text-align:left}.settings-modal__name-display:hover{border-color:var(--color-border)}.settings-modal__name-error{font-size:11px;color:#ef4444;margin-top:2px}
