.leave-game-modal__overlay{z-index:var(--z-modal,1000);transition:background var(--duration-normal,.2s) var(--ease-standard,cubic-bezier(.4, 0, .2, 1));background:0 0;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.leave-game-modal__overlay--visible{background:#00000080}.leave-game-modal__sheet{width:100%;max-width:var(--max-width,420px);background:var(--color-bg-card,#161224);border-top-left-radius:var(--radius-round,24px);border-top-right-radius:var(--radius-round,24px);padding:var(--space-md,12px) var(--space-xl,20px) var(--space-3xl,32px);box-shadow:var(--shadow-lg,0 20px 60px #00000080);transition:transform var(--duration-slow,.32s) var(--ease-spring,cubic-bezier(.34, 1.56, .64, 1));transform:translateY(100%)}.leave-game-modal__sheet--visible{transform:translateY(0)}.leave-game-modal__sheet__handle{background:var(--color-dimmed,#ffffff26);border-radius:var(--radius-pill,9999px);width:36px;height:4px;margin:0 auto var(--space-xl,20px)}.leave-game-modal__sheet__title{font-family:var(--font-display,"Syne", "Outfit", sans-serif);font-size:var(--font-lg,17px);color:var(--color-white,#fafafa);margin:0 0 var(--space-md,12px);font-weight:800}.leave-game-modal__sheet__body{font-size:var(--font-sm,12px);color:var(--color-muted,#ffffff80);margin:0 0 var(--space-xl,20px);line-height:1.5}.leave-game-modal__sheet__actions{gap:var(--space-sm,8px);flex-direction:column;display:flex}.leave-game-modal__btn{min-height:48px;font-family:var(--font-display,"Syne", "Outfit", sans-serif);font-size:var(--font-md,15px);border-radius:var(--radius-md,8px);cursor:pointer;transition:transform var(--duration-fast,.12s) ease, opacity var(--duration-fast,.12s) ease;border:none;font-weight:700}.leave-game-modal__btn:hover{transform:scale(1.02)}.leave-game-modal__btn:active{transform:scale(.98)}.leave-game-modal__btn--leave{background:var(--color-coral,#ff6b6b);color:var(--color-white,#fafafa)}.leave-game-modal__btn--stay{border:1px solid var(--color-border,#ffffff14);color:var(--color-muted,#ffffff80);background:0 0}.leave-game-modal__btn--stay:hover{color:var(--color-white,#fafafa);border-color:var(--color-dimmed,#ffffff26)}.opponent-status-overlay{z-index:var(--z-modal,1000);padding:var(--space-xl,20px);animation:opponent-status-overlay-fade-in var(--duration-normal,.2s) var(--ease-standard,cubic-bezier(.4, 0, .2, 1));background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.opponent-status-overlay--transient{background:#00000059}.opponent-status-overlay__card{width:100%;max-width:var(--max-width,420px);background:var(--color-bg-card,#161224);border-radius:var(--radius-round,24px);padding:var(--space-3xl,32px) var(--space-xl,20px);box-shadow:var(--shadow-lg,0 20px 60px #00000080);text-align:center;animation:opponent-status-overlay-card-in var(--duration-slow,.32s) var(--ease-spring,cubic-bezier(.34, 1.56, .64, 1))}.opponent-status-overlay__title{font-family:var(--font-display,"Syne", "Outfit", sans-serif);font-size:var(--font-lg,17px);color:var(--color-white,#fafafa);margin:0 0 var(--space-md,12px);font-weight:800;line-height:1.3}.opponent-status-overlay__body{font-size:var(--font-sm,12px);color:var(--color-muted,#ffffff80);margin:0 0 var(--space-xl,20px);line-height:1.5}.opponent-status-overlay__slot{gap:var(--space-sm,8px);flex-direction:column;display:flex}.opponent-status-overlay__btn{width:100%;min-height:48px;font-family:var(--font-display,"Syne", "Outfit", sans-serif);font-size:var(--font-md,15px);border-radius:var(--radius-md,8px);cursor:pointer;background:var(--color-coral,#ff6b6b);color:var(--color-white,#fafafa);transition:transform var(--duration-fast,.12s) ease, opacity var(--duration-fast,.12s) ease;border:none;font-weight:700}.opponent-status-overlay__btn:hover{transform:scale(1.02)}.opponent-status-overlay__btn:active{transform:scale(.98)}.opponent-status-overlay__btn--secondary{border:1px solid var(--color-muted,#ffffff4d);color:var(--color-muted,#ffffff80);margin-top:var(--space-md,12px);background:0 0}@keyframes opponent-status-overlay-fade-in{0%{opacity:0}to{opacity:1}}@keyframes opponent-status-overlay-card-in{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (prefers-reduced-motion:reduce){.opponent-status-overlay,.opponent-status-overlay__card{animation:none}.opponent-status-overlay__btn{transition:none}.opponent-status-overlay__btn:hover,.opponent-status-overlay__btn:active{transform:none}}.igs-shell{background:var(--frg-canvas,#1a1426);min-height:100dvh;color:var(--frg-text,#f4ece0);font-family:var(--frg-font-body,"Outfit", sans-serif);flex-direction:column;display:flex}.igs-shell__content{box-sizing:border-box;flex:auto;width:100%;max-width:1280px;margin:0 auto;padding:16px}.igs-shell__content--has-bottom{padding-bottom:calc(var(--igs-bottom-h,72px) + env(safe-area-inset-bottom) + 16px)}.igs-shell__bottom{z-index:100;padding-bottom:env(safe-area-inset-bottom);background:var(--frg-card,#221a2e);border-top:1px solid var(--frg-border-hairline,#f4ece00f);position:sticky;bottom:0}@media (width>=1024px){.igs-shell__content{padding:24px}.igs-shell__content--has-bottom{padding-bottom:24px}}.igs-header{z-index:100;padding-top:env(safe-area-inset-top);background:var(--frg-card,#221a2e);border-bottom:1px solid var(--frg-border-hairline,#f4ece00f);position:sticky;top:0}.igs-header__inner{height:var(--igs-header-h,56px);justify-content:space-between;align-items:center;gap:12px;max-width:1280px;margin:0 auto;padding:0 16px;display:flex}.igs-header__brand{align-items:center;gap:8px;min-width:0;display:flex}.igs-header__mascot{flex-shrink:0;width:32px;height:32px}.igs-header__wordmark{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);white-space:nowrap;font-size:16px;font-weight:600}.igs-header__divider{color:var(--frg-text-tertiary,#8c8478);font-size:14px}.igs-header__game-title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);white-space:nowrap;text-overflow:ellipsis;font-size:18px;font-weight:500;overflow:hidden}.igs-header__room{flex-direction:column;flex:none;align-items:center;gap:2px;display:none}.igs-header__room-label{font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.08em;color:var(--frg-text-tertiary,#8c8478);text-transform:uppercase;font-size:10px;font-weight:600}.igs-header__room-code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.15em;color:var(--frg-gold,#ffd369);font-feature-settings:"tnum";border-bottom:1px solid var(--frg-gold,#ffd369);padding-bottom:2px;font-size:16px;font-weight:700}@media (width>=600px){.igs-header__room{display:flex}}@media (width>=1024px){.igs-header__game-title{font-size:20px}.igs-header__inner{padding:0 24px}}.igs-header__leave{min-height:44px;color:var(--frg-text-secondary,#c7bfb3);cursor:pointer;border-radius:var(--frg-radius-chip,8px);background:0 0;border:none;align-items:center;gap:6px;padding:8px 12px;font-family:inherit;font-size:14px;font-weight:500;transition:color .2s,background .2s;display:inline-flex}.igs-header__leave:hover{color:var(--frg-text,#f4ece0);background:var(--frg-hover,#332a3f)}.igs-header__leave-icon{flex-shrink:0}.igs-btn{border-radius:var(--frg-radius-card,12px);cursor:pointer;box-sizing:border-box;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:0 16px;font-family:inherit;font-size:14px;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s,border-color .2s;display:inline-flex}.igs-btn:disabled{opacity:.5;cursor:not-allowed}.igs-btn--primary{background:var(--frg-coral,#e8785e);color:#1a1426}.igs-btn--primary:not(:disabled):hover{box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);transform:translateY(-1px)}.igs-btn--ghost{color:var(--frg-text-secondary,#c7bfb3);border:1px solid var(--frg-border-default,#f4ece01a);background:0 0}.igs-btn--ghost:not(:disabled):hover{color:var(--frg-text,#f4ece0);border-color:var(--frg-border-strong,#f4ece033);background:var(--frg-hover,#332a3f)}.igs-btn--md{min-height:44px;padding:0 16px;font-size:14px}.igs-btn--lg{min-height:48px;padding:0 20px;font-size:15px}@media (width>=1024px){.igs-btn--lg{min-height:44px}}.igs-lobby{flex-direction:column;gap:20px;max-width:480px;margin:0 auto;padding:16px 0 32px;display:flex}.igs-lobby__hero{flex-direction:column;align-items:center;gap:12px;padding:24px 16px;display:flex}.igs-lobby__eyebrow{font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.12em;text-transform:uppercase;color:var(--frg-text-tertiary,#8c8478);font-size:11px;font-weight:600}.igs-lobby__roomcode{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;color:var(--frg-text,#f4ece0);font-feature-settings:"tnum";border-bottom:2px solid var(--frg-gold,#ffd369);padding-bottom:8px;font-size:56px;font-weight:700;line-height:1}.igs-lobby__share{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:8px;display:flex}.igs-lobby__share-btn{color:var(--frg-text-secondary,#c7bfb3);border:1px solid var(--frg-border-default,#f4ece01a);border-radius:var(--frg-radius-chip,8px);cursor:pointer;background:0 0;min-height:36px;padding:8px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:color .2s,border-color .2s,background .2s}.igs-lobby__share-btn:not(:disabled):hover{color:var(--frg-text,#f4ece0);border-color:var(--frg-border-strong,#f4ece033);background:var(--frg-hover,#332a3f)}.igs-lobby__share-btn:disabled{opacity:.4;cursor:not-allowed}@media (width>=1024px){.igs-lobby__roomcode{font-size:80px}}.igs-lobby__card{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);flex-direction:column;gap:12px;padding:20px;display:flex}.igs-lobby__card-title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin:0;font-size:16px;font-weight:600}.igs-lobby__seats{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.igs-lobby__seat{border-radius:var(--frg-radius-chip,8px);background:var(--frg-input,#2b2236);align-items:center;gap:12px;padding:8px;display:flex}.igs-lobby__seat--empty{border:1px dashed var(--frg-border-hairline,#f4ece00f);background:0 0}.igs-lobby__avatar{background:var(--frg-hover,#332a3f);width:36px;height:36px;color:var(--frg-text,#f4ece0);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:inline-flex;overflow:hidden}.igs-lobby__avatar img{object-fit:cover;width:100%;height:100%}.igs-lobby__avatar--empty{border:1px dashed var(--frg-border-hairline,#f4ece00f);background:0 0}.igs-lobby__seat-name{color:var(--frg-text,#f4ece0);flex:1;font-size:14px;font-weight:500}.igs-lobby__seat-name--empty{color:var(--frg-text-tertiary,#8c8478);font-style:italic;font-weight:400}.igs-lobby__you{color:var(--frg-gold,#ffd369);font-size:12px;font-weight:600}.igs-lobby__host-pill{background:var(--frg-coral,#e8785e);color:#1a1426;font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.08em;border-radius:var(--frg-radius-pill,9999px);text-transform:uppercase;padding:3px 8px;font-size:10px;font-weight:700}.igs-lobby__settings{flex-direction:column;gap:12px;display:flex}.igs-lobby__setting{flex-direction:column;gap:8px;display:flex}.igs-lobby__setting-label{font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.08em;color:var(--frg-text-tertiary,#8c8478);text-transform:uppercase;font-size:11px;font-weight:600}.igs-lobby__chips{flex-wrap:wrap;gap:6px;display:flex}.igs-lobby__chip{background:var(--frg-input,#2b2236);color:var(--frg-text-secondary,#c7bfb3);border-radius:var(--frg-radius-chip,8px);cursor:pointer;border:1px solid #0000;min-height:36px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background .2s,color .2s,border-color .2s}.igs-lobby__chip--active{background:var(--frg-coral,#e8785e);color:#1a1426}.igs-lobby__chip:not(.igs-lobby__chip--active):hover{border-color:var(--frg-border-default,#f4ece01a);color:var(--frg-text,#f4ece0)}.igs-lobby__cta{flex-direction:column;align-items:stretch;gap:12px;padding:0 4px;display:flex}.igs-lobby__start{width:100%;min-height:48px;font-size:15px}.igs-lobby__leave{width:100%}.igs-lobby__error{color:var(--frg-danger,#d96459);text-align:center;margin:0;font-size:13px;font-weight:500}.igs-bottombar{height:var(--igs-bottom-h,72px);align-items:center;gap:12px;max-width:1280px;margin:0 auto;padding:0 16px;display:flex}.igs-bottombar__slot{flex:1 1 0;align-items:center;min-width:0;display:flex}.igs-bottombar__slot--start{justify-content:flex-start}.igs-bottombar__slot--center{flex:none;justify-content:center}.igs-bottombar__slot--end{justify-content:flex-end}.igs-bottombar__primary{min-height:48px;padding:0 20px}.igs-bottombar__leave{border:1px solid var(--frg-border-default,#f4ece01a);border-radius:var(--frg-radius-chip,8px);width:44px;height:44px;color:var(--frg-text-secondary,#c7bfb3);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.igs-bottombar__leave:hover{color:var(--frg-text,#f4ece0);border-color:var(--frg-border-strong,#f4ece033);background:var(--frg-hover,#332a3f)}@media (width>=1024px){.igs-bottombar,.igs-shell__bottom{display:none}}.igs-scoreboard{align-items:stretch;gap:8px;width:100%;display:flex}.igs-scoreboard--horizontal{flex-wrap:wrap;justify-content:center}.igs-scoreboard--card{flex-direction:column;margin:0;padding:0;list-style:none}.igs-scoreboard__chip,.igs-scoreboard__row{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-chip,8px);align-items:center;gap:8px;min-width:0;padding:8px 12px;transition:border-color .2s,transform .2s;display:flex}.igs-scoreboard__chip{flex:1 1 0;justify-content:space-between;max-width:200px}.igs-scoreboard__chip--active,.igs-scoreboard__row--active{border-color:var(--frg-coral,#e8785e);border-width:2px;padding:7px 11px}.igs-scoreboard__draws{border:1px dashed var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-chip,8px);background:0 0;flex-direction:column;justify-content:center;align-items:center;min-width:60px;padding:6px 12px;display:flex}.igs-scoreboard__draws-label{font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.08em;color:var(--frg-text-tertiary,#8c8478);text-transform:uppercase;font-size:10px;font-weight:600}.igs-scoreboard__cell{align-items:center;gap:8px;min-width:0;display:flex}.igs-scoreboard__avatar{background:var(--frg-hover,#332a3f);width:28px;height:28px;color:var(--frg-text,#f4ece0);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex;overflow:hidden}.igs-scoreboard__avatar--fallback{background:var(--frg-input,#2b2236)}.igs-scoreboard__marker{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);font-size:14px;font-weight:700}.igs-scoreboard__name{color:var(--frg-text,#f4ece0);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.igs-scoreboard__chip--you .igs-scoreboard__name,.igs-scoreboard__row--you .igs-scoreboard__name{color:var(--frg-gold,#ffd369)}.igs-scoreboard__you-tag{color:var(--frg-text-tertiary,#8c8478);font-size:11px}.igs-scoreboard__score{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);font-feature-settings:"tnum";margin-left:8px;font-size:18px;font-weight:700}.igs-turn{background:var(--frg-coral,#e8785e);color:#1a1426;border-radius:var(--frg-radius-pill,9999px);font-feature-settings:"tnum";align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:600;display:inline-flex}.igs-turn--badge{background:var(--frg-input,#2b2236);color:var(--frg-text,#f4ece0);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-chip,8px)}.igs-turn--active{animation:1.6s ease-in-out infinite igs-turn-pulse}.igs-turn__text{white-space:nowrap}.igs-turn__timer{opacity:.85;font-feature-settings:"tnum";font-weight:700}@keyframes igs-turn-pulse{0%,to{opacity:1}50%{opacity:.78}}.igs-endgame__overlay{z-index:1000;background:#140e1aeb;justify-content:center;align-items:center;padding:16px;animation:.2s ease-out forwards igs-fade-in;display:flex;position:fixed;inset:0}.igs-endgame__card{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);text-align:center;width:100%;max-width:360px;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);outline:none;flex-direction:column;align-items:center;gap:12px;padding:32px 24px;animation:.2s ease-out forwards igs-fade-in;display:flex}.igs-endgame__card--win{animation:.5s ease-out forwards igs-celebrate}.igs-endgame__crown{color:var(--frg-gold,#ffd369);margin-bottom:4px}.igs-endgame__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin:0;font-size:28px;font-weight:700;line-height:1.15}@media (width>=600px){.igs-endgame__title{font-size:32px}}.igs-endgame__scoreline{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-gold,#ffd369);font-feature-settings:"tnum";margin:0;font-size:18px;font-weight:600}.igs-endgame__body{color:var(--frg-text-secondary,#c7bfb3);margin:0;font-size:14px;line-height:1.5}.igs-endgame__actions{flex-direction:column;gap:8px;width:100%;margin-top:12px;display:flex}.igs-endgame__actions .igs-btn{width:100%}@media (width>=600px){.igs-endgame__actions{flex-direction:row}.igs-endgame__actions .igs-btn{flex:1 1 0}}@keyframes igs-fade-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes igs-celebrate{0%{opacity:0;transform:scale(.7)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.igs-endgame__card,.igs-endgame__card--win,.igs-endgame__overlay,.igs-turn--active{animation:none!important}.igs-btn{transition:none!important}}:root{--frg-canvas:#1a1426;--frg-card:#221a2e;--frg-input:#2b2236;--frg-hover:#332a3f;--frg-text:#f4ece0;--frg-text-secondary:#c7bfb3;--frg-text-tertiary:#8c8478;--frg-coral:#e8785e;--frg-gold:#ffd369;--frg-teal:#4ecdc4;--frg-purple:#a78bfa;--frg-success:#7fb069;--frg-warning:#e8b65a;--frg-danger:#d96459;--frg-radius-card:12px;--frg-radius-chip:8px;--frg-radius-pill:9999px;--frg-shadow-card:0 8px 24px #00000059;--frg-font-headline:"Syne", sans-serif;--frg-font-body:"Outfit", sans-serif;--frg-font-label:"Plus Jakarta Sans", sans-serif;--frg-motion-spring:.2s cubic-bezier(.2, .8, .2, 1);--frg-border-hairline:#f4ece00f;--frg-border-default:#f4ece01a;--frg-border-strong:#f4ece033;--igs-header-h:56px;--igs-bottom-h:72px}@media (width>=1024px){:root{--igs-header-h:64px}}.title-chess{color:var(--frg-text,#f4ece0);letter-spacing:.08em}.app{z-index:1;background:var(--frg-canvas,#1a1426);flex-direction:column;min-height:100vh;display:flex;position:relative}.app--online{align-items:stretch;padding:0}.app--online>.btn-hub-back{clip:rect(0, 0, 0, 0);white-space:nowrap;pointer-events:none;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.ch-prelobby{justify-content:center;padding:16px 0;display:flex}.ch-prelobby__card{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);width:100%;max-width:420px;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);flex-direction:column;gap:16px;padding:24px 20px;display:flex}.ch-prelobby__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);text-align:center;margin:0;font-size:22px;font-weight:700}.ch-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.ch-prelobby__tab{color:var(--frg-text-secondary,#c7bfb3);cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1 1 0;min-height:40px;padding:10px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:background .2s,color .2s}.ch-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.ch-prelobby__form{flex-direction:column;gap:12px;display:flex}.ch-prelobby__field{flex-direction:column;gap:6px;display:flex}.ch-prelobby__label{font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.08em;color:var(--frg-text-tertiary,#8c8478);text-transform:uppercase;font-size:11px;font-weight:600}.ch-prelobby__input{background:var(--frg-input,#2b2236);color:var(--frg-text,#f4ece0);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);outline:none;min-height:44px;padding:0 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.ch-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.ch-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.ch-prelobby__submit,.ch-prelobby__back{width:100%}.ch-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}.chess-game .chess-layout{flex-direction:column;align-items:center;gap:16px;width:100%;display:flex}@media (width>=1024px){.chess-game .chess-layout{flex-direction:row;justify-content:center;align-items:flex-start;gap:28px}}.chess-board-wrapper{width:min(90vmin,560px);max-width:100%}.chess-board{aspect-ratio:1;background:var(--surface);border-radius:var(--radius);border:1px solid #f2ebe00f;grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);gap:0;width:100%;padding:10px;display:grid;box-shadow:0 20px 60px #0000004d}.chess-square{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;transition:background-color .15s;display:flex;position:relative}.chess-square.light{background:#f4ece0}.chess-square.dark{background:#2b2236}.chess-square[aria-disabled=true]{cursor:default}.chess-square.selected{box-shadow:inset 0 0 0 3px var(--frg-coral,#e8785e)}.chess-square.last-move:before{content:"";border:2px solid var(--frg-coral,#e8785e);pointer-events:none;box-sizing:border-box;position:absolute;inset:0}.chess-square.legal-move-empty:after{content:"";pointer-events:none;background:#00000059;border-radius:50%;width:28%;height:28%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.chess-square.legal-move-capture:after{content:"";pointer-events:none;box-sizing:border-box;border:4px solid #00000073;border-radius:50%;width:92%;height:92%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes chess-check-pulse{0%,to{background-color:#e6394673}50%{background-color:#e63946bf}}.chess-square.in-check{animation:1.2s ease-in-out infinite chess-check-pulse}.chess-piece{pointer-events:none;filter:drop-shadow(0 2px 3px #0006);z-index:1;width:100%;height:100%;position:relative}.board-label{text-transform:lowercase;opacity:.6;pointer-events:none;color:#000000b3;font-size:10px;font-weight:700;position:absolute}.chess-square.dark .board-label{color:#f2ebe0d9}.file-label{bottom:2px;right:4px}.rank-label{top:2px;left:4px}.board-waiting{opacity:.85;pointer-events:none;transition:opacity .3s}.chess-players-bar{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:8px;display:flex}.chess-player-chip{background:var(--surface);border:1px solid #f2ebe014;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-weight:600;transition:border-color .2s,transform .2s;display:flex}.chess-player-chip.active{border-color:var(--gold,gold);transform:scale(1.03)}.chess-player-me{background:#f2ebe00d}.chess-player-swatch{border:2px solid #333;border-radius:50%;width:14px;height:14px;display:inline-block}.chess-swatch-white{background:#f8f8f8}.chess-swatch-black{background:#1a1a1a;border-color:#ccc}.check-banner{color:#ff6b6b;text-shadow:0 0 12px #ff6b6b99}.chess-rejected-flash{color:#ff8a8a;text-align:center;background:#e6394633;border:1px solid #e6394666;border-radius:8px;max-width:400px;margin:8px auto;padding:8px 14px;font-size:14px;animation:.3s ease-out chess-flash}@keyframes chess-flash{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.move-history{background:var(--surface);border-radius:var(--radius);border:1px solid #f2ebe00f;width:min(90vmin,560px);max-width:100%;max-height:260px;padding:12px 16px;font-family:Poppins,system-ui,sans-serif;overflow-y:auto}@media (width>=1024px){.move-history{width:240px;max-height:560px}}.move-history-title{text-transform:uppercase;letter-spacing:.1em;color:var(--gold,gold);opacity:.85;margin:0 0 8px;font-size:14px}.move-history-empty{opacity:.55;margin:0;font-size:13px;font-style:italic}.move-history-list{flex-direction:column;gap:4px;margin:0;padding:0;list-style:none;display:flex}.move-history-row{border-radius:4px;grid-template-columns:32px 1fr 1fr;gap:8px;padding:4px 6px;font-size:14px;display:grid}.move-history-row:nth-child(odd){background:#f2ebe008}.move-number{opacity:.55;font-variant-numeric:tabular-nums}.move-san{font-variant-numeric:tabular-nums;font-weight:600}.move-san.move-current{color:var(--gold,gold);text-shadow:0 0 6px #ffd70059}.chess-actions{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:12px;display:flex}.btn-secondary{color:inherit;cursor:pointer;background:#f2ebe014;border:1px solid #f2ebe026;border-radius:8px;padding:8px 16px;font-weight:600;transition:background-color .2s,border-color .2s}.btn-secondary:hover:not(:disabled){background:#f2ebe024;border-color:#f2ebe04d}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.promotion-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;animation:.2s ease-out chess-flash;display:flex;position:fixed;inset:0}.promotion-card{background:var(--surface);border-radius:var(--radius);text-align:center;border:1px solid #f2ebe01f;width:92vw;max-width:420px;padding:24px;box-shadow:0 24px 64px #00000080}.promotion-title{margin:0 0 16px;font-size:18px}.promotion-options{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;display:grid}.promotion-option{color:inherit;cursor:pointer;background:#f2ebe00d;border:1px solid #f2ebe01a;border-radius:10px;flex-direction:column;align-items:center;gap:6px;min-width:44px;min-height:44px;padding:10px 6px;transition:background-color .2s,border-color .2s,transform .15s;display:flex}.promotion-option:hover{border-color:var(--gold,gold);background:#f2ebe01f;transform:translateY(-2px)}.promotion-option .chess-piece{width:56px;height:56px}.promotion-label{opacity:.85;font-size:12px;font-weight:600}.promotion-cancel{margin-top:0}@media (width<=640px){.chess-board-wrapper{width:94vmin}.chess-board{padding:6px}.move-history{width:94vmin;max-height:180px}.move-history-row{font-size:13px}}@media (pointer:coarse){.chess-square{min-width:44px;min-height:44px}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#1a1426;--surface:#221a2e;--surface-light:#2b2236;--x-color:#e8785e;--x-glow:#e8785e73;--o-color:#4ecdc4;--o-glow:#4ecdc473;--text:#f4ece0;--text-dim:#c7bfb3;--accent:#e8785e;--gold:#ffd369;--radius:12px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Outfit,Poppins,sans-serif;overflow-x:hidden}.stars{display:none}@keyframes twinkle{0%{opacity:.5}to{opacity:1}}.app{z-index:1;flex-direction:column;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex;position:relative}.btn-hub-back{z-index:100;color:var(--text-dim);cursor:pointer;background:#221a2ee6;border:1px solid #f4ece01a;border-radius:10px;padding:.5rem 1rem;font-family:inherit;font-size:.8rem;font-weight:600;transition:all .2s;position:fixed;top:1rem;left:1rem}.btn-hub-back:hover{color:var(--text);background:#221a2ef2;border-color:#f4ece033}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.15)}}@keyframes celebrate{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.title{letter-spacing:.05em;gap:.4em;margin-bottom:2rem;font-size:3rem;font-weight:800;animation:.6s ease-out slideDown;display:flex}.x-marker{color:var(--x-color);text-shadow:0 0 10px var(--x-glow);font-weight:700}.o-marker{color:var(--o-color);text-shadow:0 0 10px var(--o-glow);font-weight:700}.pulse{animation:1s ease-in-out infinite pulse}.setup{animation:.5s ease-out fadeIn}.setup-card{background:var(--surface);border-radius:var(--radius);border:1px solid #f4ece00f;flex-direction:column;gap:1.5rem;width:min(420px,90vw);padding:2.5rem 2rem;display:flex;box-shadow:0 8px 24px #00000059}.setup-card h2{text-align:center;color:var(--text-dim);font-size:1.3rem;font-weight:600}.input-group{flex-direction:column;gap:.5rem;display:flex}.input-group label{align-items:center;gap:.5em;font-size:.95rem;font-weight:600;display:flex}.input-group .marker{font-size:1.2rem}.input-group input{background:var(--surface-light);color:var(--text);border:1px solid #f4ece01a;border-radius:10px;outline:none;padding:.8rem 1rem;font-family:inherit;font-size:1rem;transition:border-color .3s}.input-group input:focus{border-color:var(--accent);box-shadow:none}.input-group input::placeholder{color:var(--text-dim);opacity:.5}.btn-start{background:var(--accent);color:#1a1426;cursor:pointer;letter-spacing:.03em;border:none;border-radius:12px;margin-top:.5rem;padding:.9rem;font-family:inherit;font-size:1.1rem;font-weight:700;transition:transform .2s,box-shadow .2s}.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000059}.btn-start:active{transform:translateY(0)}.btn-play-again{background:var(--accent);color:#1a1426;cursor:pointer;border:none;border-radius:12px;padding:.7rem 1.8rem;font-family:inherit;font-size:1rem;font-weight:700;transition:transform .2s,box-shadow .2s;animation:.3s ease-out fadeIn}.btn-play-again:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000059}.btn-play-again:active{transform:translateY(0)}.btn-back{color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #f4ece01a;border-radius:12px;padding:.7rem 1.5rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.btn-back:hover{color:var(--text);background:#f4ece008;border-color:#f4ece033}.btn-waiting{opacity:.6;cursor:wait!important}.mode-card{gap:1.2rem}.mode-btn{background:var(--surface-light);cursor:pointer;color:var(--text);border:1px solid #f4ece00f;border-radius:14px;flex-direction:column;align-items:center;gap:.3rem;padding:1.5rem;font-family:inherit;transition:all .25s;display:flex}.mode-btn:hover{border-color:#f4ece026;transform:translateY(-3px);box-shadow:0 8px 24px #00000059}.mode-btn:active{transform:translateY(0)}.mode-btn-local:hover{border-color:var(--x-color)}.mode-btn-online:hover{border-color:var(--o-color)}.mode-icon{font-size:2rem}.mode-label{font-size:1.15rem;font-weight:700}.mode-desc{color:var(--text-dim);font-size:.8rem}.lobby-card{gap:1rem}.lobby-tabs{background:var(--surface-light);border-radius:10px;gap:0;display:flex;overflow:hidden}.lobby-tab{color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex:1;padding:.7rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.lobby-tab.active{background:var(--accent);color:#1a1426}.lobby-form{flex-direction:column;gap:1rem;display:flex}.lobby-subtext{text-align:center;color:var(--text-dim);font-size:.9rem}.room-code-display{justify-content:center;padding:1rem;display:flex}.room-code{letter-spacing:.3em;color:var(--gold);text-shadow:none;-webkit-user-select:all;user-select:all;font-family:Courier New,monospace;font-size:3rem;font-weight:800}.input-code{text-align:center;letter-spacing:.3em;text-transform:uppercase;font-weight:700;font-size:1.4rem!important}.waiting-dots{justify-content:center;gap:.5rem;display:flex}.waiting-dots span{background:var(--o-color);border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite bounce}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}.lobby-error{text-align:center;color:var(--x-color);font-size:.85rem;font-weight:600;animation:.2s fadeIn}.game{flex-direction:column;align-items:center;gap:1.5rem;width:min(500px,95vw);animation:.5s ease-out fadeIn;display:flex}.game-actions{flex-wrap:wrap;justify-content:center;gap:.8rem;display:flex}.scoreboard{justify-content:center;gap:.5rem;width:100%;display:flex}.score-item{background:var(--surface);border:1px solid #f4ece00f;border-radius:12px;flex-direction:column;align-items:center;gap:.2rem;min-width:100px;padding:.6rem 1.2rem;transition:all .3s;display:flex}.score-item.active{border-color:var(--accent);box-shadow:none;transform:translateY(-3px)}.score-marker{font-size:1.2rem}.score-name{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:100px;font-size:.75rem;overflow:hidden}.score-label{color:var(--text-dim);font-size:.75rem}.score-value{font-size:1.5rem;font-weight:800}.score-you .score-name{color:var(--gold)}.turn-indicator{background:var(--surface);text-align:center;border:1px solid #f4ece00f;border-radius:12px;justify-content:center;align-items:center;min-height:52px;padding:.8rem 1.5rem;font-size:1.1rem;font-weight:600;transition:all .3s;display:flex}.turn-indicator.result{background:var(--surface);border-color:var(--gold);box-shadow:0 8px 24px #00000059}.turn-text{align-items:center;gap:.4em;animation:.3s fadeIn;display:flex}.win-text{color:var(--gold);align-items:center;gap:.4em;animation:.5s ease-out celebrate;display:flex}.draw-text{color:var(--text-dim);animation:.3s fadeIn}.overlay-card{background:var(--surface);border-radius:var(--radius);text-align:center;border:1px solid #f4ece01a;flex-direction:column;gap:1rem;max-width:400px;padding:2.5rem 2rem;animation:.3s ease-out fadeIn;display:flex}.overlay-card h2{color:var(--x-color)}.overlay-card p{color:var(--text-dim)}.board-waiting{opacity:.7;transition:opacity .3s}.opponent-turn-text{opacity:.8}@media (pointer:coarse){.btn-start,.btn-back,.btn-play-again,.lobby-tab,.mode-btn{min-height:48px}.input-group input{min-height:48px;font-size:16px}}@media (width<=480px){.app{padding:1.2rem .8rem}.title{margin-bottom:1.2rem;font-size:2.2rem}.setup-card{gap:1rem;width:min(420px,95vw);padding:1.5rem 1rem}.setup-card h2{font-size:1.1rem}.scoreboard{gap:.3rem}.score-item{min-width:70px;padding:.4rem .6rem}.score-value{font-size:1.2rem}.score-name{max-width:70px;font-size:.65rem}.turn-indicator{padding:.6rem 1rem;font-size:.95rem}.game{gap:1rem}.game-actions{gap:.4rem}.btn-start{padding:.8rem;font-size:1rem}.btn-back{padding:.6rem 1rem;font-size:.8rem}.btn-hub-back{padding:.4rem .8rem;font-size:.7rem;top:.5rem;left:.5rem}.room-code{font-size:2.2rem}.lobby-tabs{font-size:.8rem}.mode-btn{padding:1.2rem}.mode-icon{font-size:1.6rem}.mode-label{font-size:1rem}.overlay-card{margin:0 .5rem;padding:1.5rem 1rem}}@media (width<=360px){.title{font-size:1.8rem}.setup-card{padding:1.2rem .8rem}.score-item{min-width:60px;padding:.3rem .4rem}}
