.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}}*,: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}}.title-word{color:var(--frg-gold,#ffd369)}.title-clash{color:var(--frg-coral,#e8785e)}.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}.wc-prelobby{justify-content:center;padding:16px 0;display:flex}.wc-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}.wc-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}.wc-prelobby__subtitle{text-align:center;color:var(--frg-text-secondary,#c7bfb3);margin:-8px 0 0;font-size:13px}.wc-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.wc-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}.wc-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.wc-prelobby__form{flex-direction:column;gap:12px;display:flex}.wc-prelobby__field{flex-direction:column;gap:6px;display:flex}.wc-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}.wc-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}.wc-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.wc-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.wc-prelobby__submit,.wc-prelobby__back{width:100%}.wc-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}.wc-prelobby__dots{justify-content:center;gap:6px;display:flex}.wc-prelobby__dots span{background:var(--frg-coral,#e8785e);border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite wc-dot-pulse}.wc-prelobby__dots span:nth-child(2){animation-delay:.2s}.wc-prelobby__dots span:nth-child(3){animation-delay:.4s}@keyframes wc-dot-pulse{0%,to{opacity:.4;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}.wc-game{gap:.8rem;max-width:600px}.wc-scores{justify-content:center;align-items:center;gap:.8rem;width:100%;display:flex}.wc-player{background:var(--surface);border:1px solid #f2ebe00f;border-radius:10px;flex-direction:column;align-items:center;gap:.1rem;min-width:110px;padding:.5rem 1rem;transition:all .3s;display:flex}.wc-player.active{border-color:var(--gold);box-shadow:0 0 15px #ffd70026}.wc-player.you .wc-player-name{color:var(--gold)}.wc-player-name{color:var(--text-dim);font-size:.75rem}.wc-player-score{font-size:1.8rem;font-weight:800}.wc-bag-count{color:var(--text-dim);text-align:center;font-size:.75rem}.wc-result{color:var(--gold);text-align:center;font-size:1.3rem;font-weight:700;animation:.5s ease-out celebrate}.wc-board{aspect-ratio:1;background:var(--surface);border:1px solid #f2ebe00f;border-radius:10px;grid-template-columns:repeat(13,1fr);gap:2px;width:min(520px,95vw);padding:4px;display:grid}.wc-cell{aspect-ratio:1;cursor:pointer;background:var(--surface-light);color:var(--text);border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-family:inherit;font-size:clamp(.5rem,2.2vw,.85rem);transition:all .15s;display:flex;position:relative}.wc-cell:hover:not(.wc-cell-filled):not(.wc-cell-disabled){background:#f2ebe014}.wc-cell-disabled{cursor:default;opacity:.7}.bonus-2l{background:#1a4a6b}.bonus-3l{background:#1a5a3a}.bonus-2w{background:#6b3a1a}.bonus-3w{background:#6b1a2a}.bonus-center{background:#4a3a6b}.wc-bonus-label{color:#f2ebe080;font-size:clamp(.35rem,1.5vw,.6rem);font-weight:700;line-height:1}.wc-cell-filled{cursor:default;background:#c4973a}.wc-cell-pending{background:#d4a74a;animation:.2s ease-out tilePlace;box-shadow:0 0 8px #d4a74a80}@keyframes tilePlace{0%{transform:scale(.7)}to{transform:scale(1)}}.wc-tile-letter{color:#1a1a2e;align-items:baseline;gap:1px;font-size:clamp(.55rem,2.5vw,.95rem);font-weight:800;display:flex}.wc-tile-blank{opacity:.8;font-style:italic}.wc-tile-value{opacity:.7;font-size:clamp(.3rem,1vw,.5rem);font-weight:600}.wc-rack{background:var(--surface);border:1px solid #f2ebe00f;border-radius:10px;justify-content:center;gap:6px;min-height:56px;padding:.6rem;display:flex}.wc-rack-tile{cursor:pointer;background:#c4973a;border:2px solid #a07a2a;border-radius:6px;justify-content:center;align-items:center;width:44px;height:44px;font-family:inherit;transition:all .15s;display:flex;position:relative}.wc-rack-tile:hover{transform:translateY(-4px);box-shadow:0 6px 15px #0006}.wc-rack-selected{border-color:var(--gold);transform:translateY(-6px);box-shadow:0 6px 20px #ffd70066}.wc-rack-letter{color:#1a1a2e;align-items:baseline;gap:1px;font-size:1.2rem;font-weight:800;display:flex}.wc-rack-value{color:#1a1a2e;opacity:.6;font-size:.55rem;font-weight:600}.wc-actions{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.wc-waiting-turn{color:var(--text-dim);font-size:.9rem;animation:1.5s ease-in-out infinite pulse}.wc-challenge-bar{background:var(--surface);border:1px solid var(--gold);border-radius:10px;flex-wrap:wrap;justify-content:center;align-items:center;gap:.8rem;padding:.6rem 1rem;font-size:.85rem;animation:.3s fadeIn;display:flex}.btn-challenge{background:var(--accent);color:var(--color-text,#f2ebe0);cursor:pointer;border:none;border-radius:8px;padding:.4rem 1rem;font-family:inherit;font-size:.85rem;font-weight:700;transition:all .2s}.btn-challenge:hover{transform:translateY(-1px);box-shadow:0 4px 12px #e5317066}.btn-accept{color:var(--text-dim);cursor:pointer;background:0 0;border:1px solid #f2ebe026;border-radius:8px;padding:.4rem 1rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s}.btn-accept:hover{color:var(--text);border-color:#f2ebe04d}.wc-challenge-banner{text-align:center;border-radius:10px;padding:.6rem 1rem;font-size:.9rem;font-weight:600;animation:.3s fadeIn}.wc-challenge-banner.success{border:1px solid var(--o-color);color:var(--o-color);background:#4ecdc426}.wc-challenge-banner.fail{border:1px solid var(--x-color);color:var(--x-color);background:#ff6b6b26}.wc-message{color:var(--x-color);text-align:center;font-size:.85rem;font-weight:600;animation:.2s fadeIn}.wc-blank-picker{background:var(--surface);border:1px solid var(--gold);text-align:center;border-radius:10px;padding:.8rem;animation:.2s fadeIn}.wc-blank-picker p{color:var(--text-dim);margin-bottom:.5rem;font-size:.85rem}.wc-blank-letters{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.wc-blank-btn{color:#1a1a2e;cursor:pointer;background:#c4973a;border:1px solid #a07a2a;border-radius:4px;width:30px;height:30px;font-family:inherit;font-size:.75rem;font-weight:700;transition:all .15s}.wc-blank-btn:hover{background:#d4a74a;transform:scale(1.1)}.wc-lobby-players{text-align:center}.wc-lobby-players h3{color:var(--text-dim);margin-bottom:.5rem;font-size:.85rem}.wc-player-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.wc-player-item{background:var(--surface-light);border-radius:8px;align-items:center;gap:.6rem;padding:.5rem .8rem;font-size:.9rem;display:flex}.wc-player-num{background:var(--accent);width:24px;height:24px;color:var(--color-text,#f2ebe0);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex}.wc-host-badge{color:var(--gold);background:#ffd70026;border-radius:10px;margin-left:auto;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.wc-waiting-host{flex-direction:column;align-items:center;gap:.5rem;display:flex}.wc-scores-multi{flex-wrap:wrap;justify-content:center;gap:.4rem;width:100%;display:flex}.wc-player-score-card{background:var(--surface);border:1px solid #f2ebe00f;border-radius:10px;flex-direction:column;align-items:center;gap:.1rem;min-width:80px;padding:.4rem .8rem;transition:all .3s;display:flex}.wc-player-score-card.active{border-color:var(--player-color);box-shadow:0 0 12px color-mix(in srgb, var(--player-color) 30%, transparent)}.wc-player-score-card.left{opacity:.4}.wc-psm-name{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;max-width:80px;font-size:.65rem;overflow:hidden}.wc-player-score-card.active .wc-psm-name{color:var(--player-color)}.wc-psm-score{font-size:1.4rem;font-weight:800}@media (width<=480px){.wc-game{gap:.5rem}.wc-board{border-radius:6px;gap:1px;width:min(520px,98vw);padding:2px}.wc-cell{border-radius:2px}.wc-rack{flex-wrap:wrap;gap:4px;padding:.4rem}.wc-rack-tile{border-radius:4px;width:38px;height:38px}.wc-rack-letter{font-size:1rem}.wc-rack-value{font-size:.45rem}.wc-scores{gap:.4rem}.wc-player{min-width:80px;padding:.4rem .6rem}.wc-player-score{font-size:1.4rem}.wc-scores-multi{gap:.3rem}.wc-player-score-card{min-width:60px;padding:.3rem .5rem}.wc-psm-name{max-width:60px;font-size:.55rem}.wc-psm-score{font-size:1.1rem}.wc-bag-count{font-size:.65rem}.wc-actions{gap:.4rem}.wc-challenge-bar{gap:.5rem;padding:.5rem .8rem;font-size:.75rem}.wc-challenge-banner{font-size:.8rem}.wc-blank-picker{padding:.6rem}.wc-blank-btn{width:28px;height:28px;font-size:.7rem}.wc-result{font-size:1.1rem}}@media (width<=360px){.wc-board{border-radius:0;width:100vw}.wc-rack-tile{width:34px;height:34px}.wc-player-score-card{min-width:50px;padding:.2rem .4rem}.wc-psm-name{max-width:50px;font-size:.5rem}.wc-psm-score{font-size:.95rem}}@media (pointer:coarse){.wc-rack-tile{min-width:40px;min-height:40px}.wc-rack-tile:hover{transform:none}.wc-rack-selected{transform:translateY(-4px)}.wc-cell:hover:not(.wc-cell-filled):not(.wc-cell-disabled){background:var(--surface-light)}.btn-challenge,.btn-accept{min-height:44px;padding:.5rem 1.2rem}.wc-blank-btn{width:36px;height:36px;font-size:.85rem}}
