.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}}.c4-game{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:720px;margin:0 auto;padding:8px 0 16px;display:flex}.c4-game__turn-desktop{display:none}@media (width>=1024px){.c4-game__turn-desktop{justify-content:center;display:flex}}.c4-game__board-wrap{justify-content:center;width:100%;transition:opacity .2s;display:flex}.board-waiting,.c4-game__board-wrap--waiting{pointer-events:none;opacity:.65}.c4-board-wrapper{flex-direction:column;gap:4px;width:min(360px,95vw);display:flex}@media (width>=600px){.c4-board-wrapper{width:min(440px,80vw)}}@media (width>=1024px){.c4-board-wrapper{width:520px}}.c4-preview-row{aspect-ratio:7;grid-template-columns:repeat(7,1fr);gap:6px;padding:0 12px;display:grid}.c4-preview-slot{aspect-ratio:1;justify-content:center;align-items:center;display:flex}.c4-board{aspect-ratio:7/6;background:var(--frg-card,#221a2e);border-radius:var(--frg-radius-card,12px);border:1px solid var(--frg-border-hairline,#f4ece00f);width:100%;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);grid-template-columns:repeat(7,1fr);gap:6px;padding:12px;display:grid}.c4-column{cursor:pointer;border-radius:8px;grid-template-rows:repeat(6,1fr);gap:6px;min-width:32px;transition:background-color .2s;display:grid}.c4-column:hover{background:var(--frg-hover,#f4ece00a)}.c4-column-full{cursor:not-allowed;opacity:.85}.c4-column-full:hover{background:0 0}.c4-column-focused{outline:2px solid var(--frg-gold,#ffd369);outline-offset:2px}.c4-cell{background:var(--frg-input,#2b2236);aspect-ratio:1;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden;box-shadow:inset 0 3px 8px #00000080}.c4-piece{pointer-events:none;border-radius:50%;width:84%;height:84%}.c4-piece-red{background:radial-gradient(circle at 35% 30%, #ffa591, var(--frg-coral,#e8785e));box-shadow:0 0 0 1px #e8785e8c}.c4-piece-yellow{background:radial-gradient(circle at 35% 30%, #ffe6a8, var(--frg-gold,#ffd369));box-shadow:0 0 0 1px #ffd3698c}.c4-piece-preview{opacity:.4;transform:scale(.88)}@keyframes c4-drop{0%{transform:translateY(-620%)}to{transform:translateY(0)}}.c4-cell-dropping .c4-piece{animation:.42s cubic-bezier(.34,1.56,.64,1) c4-drop}.c4-cell-win{box-shadow:inset 0 0 0 2px var(--frg-coral,#e8785e), inset 0 3px 8px #00000080;animation:1.4s ease-in-out infinite alternate c4-win-pulse}@keyframes c4-win-pulse{0%{filter:brightness()}to{filter:brightness(1.18)}}@media (width<=480px){.c4-board{gap:4px;padding:8px}.c4-preview-row{gap:4px;padding:0 8px}.c4-column{gap:4px}}@media (width<=360px){.c4-board{gap:3px;padding:6px}.c4-preview-row{gap:3px;padding:0 6px}.c4-column{gap:3px}}@media (pointer:coarse){.c4-column{min-height:44px}}.c4-prelobby{justify-content:center;padding:16px 0;display:flex}.c4-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}.c4-prelobby__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);text-align:center;margin:0;font-size:24px;font-weight:700}.c4-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.c4-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}.c4-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.c4-prelobby__form{flex-direction:column;gap:12px;display:flex}.c4-prelobby__field{flex-direction:column;gap:6px;display:flex}.c4-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}.c4-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}.c4-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.c4-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.c4-prelobby__submit,.c4-prelobby__back{width:100%}.c4-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}@media (prefers-reduced-motion:reduce){.c4-cell-win,.c4-cell-dropping .c4-piece,.c4-column{transition:none!important;animation:none!important}}.title-chess{color:var(--frg-text,#f4ece0);letter-spacing:.08em}.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}}@media (prefers-reduced-motion:reduce){.hangman-board__part,.hangman-board__key{transition:none}}@media (width<=480px){.hangman-board__slot{width:28px;height:36px;font-size:1.2rem}.hangman-board__key{min-width:32px;min-height:44px;padding:4px;font-size:13px}.hangman-board__stickman{max-width:150px}}@media (width>=768px){.hangman-board{gap:20px;padding:24px 12px}.hangman-board__slot{width:44px;height:52px;font-size:1.75rem}}@media (width>=1024px){.hangman-board{max-width:700px;padding:32px 16px}}@keyframes twinkle{0%{opacity:.5}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}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)}}@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}}.hangman-board{max-width:600px;color:var(--frg-text,#f4ece0);flex-direction:column;align-items:center;gap:16px;margin:0 auto;padding:16px 8px;display:flex}.hangman-board__word{flex-wrap:wrap;justify-content:center;gap:8px;min-height:48px;display:flex}.hangman-board__slot{width:36px;height:44px;font-family:var(--frg-font-headline,"Syne", sans-serif);border-bottom:3px solid var(--frg-text-tertiary,#8c8478);text-transform:uppercase;color:var(--frg-text,#f4ece0);font-feature-settings:"tnum";justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;display:flex}.hangman-board__slot--revealed{border-bottom-color:var(--frg-coral,#e8785e);color:var(--frg-coral,#e8785e)}.hangman-board__keyboard{flex-direction:column;align-items:center;gap:6px;width:100%;display:flex}.hangman-board__keyboard-row{justify-content:center;gap:4px;display:flex}.hangman-board__key{border:1px solid var(--frg-border-default,#f4ece01a);border-radius:var(--frg-radius-chip,8px);background:var(--frg-input,#2b2236);min-width:32px;min-height:44px;color:var(--frg-text,#f4ece0);cursor:pointer;justify-content:center;align-items:center;padding:4px 8px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s,border-color .15s,transform .15s,opacity .15s;display:flex;position:relative}.hangman-board__key:hover:not(:disabled){background:var(--frg-hover,#332a3f);border-color:var(--frg-border-strong,#f4ece033)}.hangman-board__key:active:not(:disabled){transform:scale(.96)}.hangman-board__key--correct{border-color:var(--frg-success,#7fb069);color:var(--frg-success,#7fb069);background:#7fb0692e}.hangman-board__key--wrong{background:var(--frg-card,#221a2e);border-color:var(--frg-border-hairline,#f4ece00f);color:var(--frg-text-tertiary,#8c8478);opacity:.6}.hangman-board__key--disabled{opacity:.4;cursor:not-allowed}.hangman-board__key-mark{font-size:10px;position:absolute;top:-4px;right:-4px}.hangman-board__gallows{justify-content:center;display:flex}.hangman-board__stickman{max-width:200px;height:auto}.hangman-board__part{fill:none;stroke:var(--frg-text,#f4ece0);stroke-width:3px;stroke-linecap:round;opacity:0;transition:opacity .4s ease-in}.hangman-board__part--visible{opacity:1}.hangman-board{--color-text-muted:var(--frg-text-tertiary,#8c8478)}.hangman-board__turn{font-family:var(--frg-font-headline,"Syne", sans-serif);text-align:center;min-height:1.5em;color:var(--frg-text,#f4ece0);font-size:16px;font-weight:600}.hangman-board__scores{justify-content:center;gap:16px;display:flex}.hangman-board__score{border-radius:var(--frg-radius-pill,9999px);background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);color:var(--frg-text,#f4ece0);font-feature-settings:"tnum";padding:6px 14px;font-size:13px;font-weight:600}.hangman-board__score--winner{border-color:var(--frg-gold,#ffd369);color:var(--frg-gold,#ffd369)}.hangman-board__result-banner{text-align:center;font-family:var(--frg-font-headline,"Syne", sans-serif);border-radius:var(--frg-radius-card,12px);background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);color:var(--frg-text,#f4ece0);box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);padding:14px 24px;font-size:18px;font-weight:700}.hangman-board__play-again{border-radius:var(--frg-radius-card,12px);background:var(--frg-coral,#e8785e);color:#1a1426;cursor:pointer;border:none;min-height:44px;padding:0 24px;font-family:inherit;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s}.hangman-board__play-again:hover{box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);transform:translateY(-1px)}@media (prefers-reduced-motion:reduce){.hangman-board__part,.hangman-board__key{transition:none}}@media (width<=480px){.hangman-board__slot{width:28px;height:36px;font-size:1.2rem}.hangman-board__key{min-width:32px;min-height:44px;padding:4px;font-size:13px}.hangman-board__stickman{max-width:150px}}@media (width>=768px){.hangman-board{gap:20px;padding:24px 12px}.hangman-board__slot{width:44px;height:52px;font-size:1.75rem}}@media (width>=1024px){.hangman-board{max-width:700px;padding:32px 16px}}.hg-game{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:720px;margin:0 auto;padding:8px 12px 16px;display:flex}.hg-game__error{color:var(--frg-danger,#d96459);border:1px solid var(--frg-danger,#d96459);border-radius:var(--frg-radius-card,12px);text-align:center;background:#d964591f;width:100%;max-width:480px;padding:8px 14px;font-size:13px}.hg-prelobby{justify-content:center;padding:16px 0;display:flex}.hg-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}.hg-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}.hg-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.hg-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}.hg-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.hg-prelobby__form{flex-direction:column;gap:12px;display:flex}.hg-prelobby__field{flex-direction:column;gap:6px;display:flex}.hg-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}.hg-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}.hg-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.hg-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.hg-prelobby__submit,.hg-prelobby__back{width:100%}.hg-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}@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}}.checkers-board{--ck-red-piece:var(--frg-coral,#e8785e);--ck-red-piece-rim:#e8785e8c;--ck-black-piece:#15101d;--ck-black-piece-rim:#0000008c;--ck-crown-gold:var(--frg-gold,#ffd369);--ck-accent:var(--frg-coral,#e8785e);--ck-glow:var(--frg-coral,#e8785e);flex-direction:column;align-items:stretch;gap:12px;width:min(95vmin,480px);max-width:100%;margin:0 auto;padding:8px;display:flex}@media (width>=1024px){.checkers-board{width:480px}}.checkers-board__scores{justify-content:space-between;gap:8px;display:flex}.checkers-board__score{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);flex:1;align-items:center;gap:8px;min-width:0;padding:8px 12px;transition:border-color .2s;display:flex}.checkers-board__score--active{border-color:var(--frg-coral,#e8785e);border-width:2px;padding:7px 11px}.checkers-board__score-swatch{border-radius:50%;flex:0 0 14px;width:14px;height:14px}.checkers-board__score-swatch--red{background:var(--ck-red-piece);box-shadow:0 0 0 1px var(--ck-red-piece-rim)}.checkers-board__score-swatch--black{background:var(--ck-black-piece);box-shadow:0 0 0 1px var(--ck-black-piece-rim)}.checkers-board__score-name{white-space:nowrap;text-overflow:ellipsis;color:var(--frg-text,#f4ece0);font-size:14px;font-weight:600;overflow:hidden}.checkers-board__score-value{color:var(--frg-text-tertiary,#8c8478);white-space:nowrap;font-feature-settings:"tnum";margin-left:auto;font-size:13px}.checkers-board__turn-indicator{text-align:center;font-family:var(--frg-font-headline,"Syne", sans-serif);min-height:1.5em;color:var(--frg-text,#f4ece0);font-size:16px;font-weight:600}.checkers-board__grid{aspect-ratio:1;background:var(--frg-card,#221a2e);border-radius:var(--frg-radius-card,12px);border:1px solid var(--frg-border-hairline,#f4ece00f);width:100%;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);grid-template-rows:repeat(8,1fr);grid-template-columns:repeat(8,1fr);gap:0;padding:6px;display:grid}.checkers-board__cell{cursor:pointer;-webkit-user-select:none;user-select:none;outline:none;justify-content:center;align-items:center;min-width:36px;min-height:36px;transition:background-color .15s,box-shadow .15s;display:flex;position:relative}.checkers-board__cell:focus-visible{box-shadow:inset 0 0 0 3px var(--frg-coral,#e8785e)}.checkers-board__cell--light{background:#f4ece0}.checkers-board__cell--dark{background:#2b2236}.checkers-board__cell--selected{box-shadow:inset 0 0 0 3px var(--frg-coral,#e8785e)}.checkers-board__cell--selectable{cursor:pointer}.checkers-board__cell--selectable:hover{box-shadow:inset 0 0 0 2px var(--frg-coral,#e8785e)}.checkers-board__cell--legal-target:after{content:"";background:var(--frg-coral,#e8785e);pointer-events:none;opacity:.85;border-radius:50%;width:26%;height:26%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.checkers-board__cell--capture-target{box-shadow:inset 0 0 0 3px var(--frg-coral,#e8785e)}.checkers-board__cell--must-continue{box-shadow:inset 0 0 0 3px var(--frg-gold,#ffd369);animation:1.4s ease-in-out infinite checkersMustContinuePulse}.checkers-board__cell--capture-source{box-shadow:inset 0 0 0 2px #e8785e8c}@keyframes checkersMustContinuePulse{0%,to{box-shadow:inset 0 0 0 3px var(--frg-gold,#ffd369)}50%{box-shadow:inset 0 0 0 3px var(--frg-coral,#e8785e)}}.checkers-board__piece{border-radius:50%;justify-content:center;align-items:center;width:76%;height:76%;transition:opacity .3s,transform .3s;display:flex;position:relative}.checkers-board__piece--red{background:radial-gradient(circle at 30% 30%, #ffa591, var(--ck-red-piece) 70%);border:1.5px solid #e8785eb3;box-shadow:inset 0 -3px 6px #00000059,inset 0 2px 4px #f4ece04d,0 2px 6px #0006}.checkers-board__piece--black{background:radial-gradient(circle at 30% 30%, #2a2236, var(--ck-black-piece) 70%);border:1.5px solid var(--ck-black-piece-rim);box-shadow:inset 0 -3px 6px #0000008c,inset 0 2px 4px #f4ece01f,0 2px 6px #0006}.checkers-board__piece--king{animation:.45s ease-out checkersKingPromote}@keyframes checkersKingPromote{0%{transform:scale(.5)}50%{transform:scale(1.05)}to{transform:scale(1)}}.checkers-board__piece--captured{opacity:0;transform:scale(.7)}.checkers-board__crown{pointer-events:none;width:55%;height:auto;color:var(--ck-crown-gold);filter:drop-shadow(0 0 2px #00000080)}.checkers-board__result-banner{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);text-align:center;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);flex-direction:column;align-items:center;gap:12px;margin-top:8px;padding:16px 20px;display:flex}.checkers-board__result-text{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin:0;font-size:22px;font-weight:700}.checkers-board__actions{justify-content:center;gap:12px;margin-top:8px;display:flex}.checkers-board__btn{border-radius:var(--frg-radius-card,12px);cursor:pointer;border:1px solid #0000;min-width:44px;min-height:44px;padding:0 20px;font-family:inherit;font-size:14px;font-weight:600;transition:transform .15s,background .15s,border-color .15s}.checkers-board__btn--primary{background:var(--frg-coral,#e8785e);color:#1a1426}.checkers-board__btn--primary:hover{transform:translateY(-1px)}.checkers-board__btn--secondary{color:var(--frg-text-secondary,#c7bfb3);border-color:var(--frg-border-default,#f4ece01a);background:0 0}.checkers-board__btn--secondary:hover{background:var(--frg-hover,#332a3f);color:var(--frg-text,#f4ece0);border-color:var(--frg-border-strong,#f4ece033)}.checkers-board__btn:active{transform:translateY(1px)}.checkers-board__toast{background:var(--frg-card,#221a2e);color:var(--frg-text,#f4ece0);border:1px solid var(--frg-border-default,#f4ece01a);border-radius:var(--frg-radius-pill,9999px);box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);z-index:50;padding:10px 16px;font-size:13px;font-weight:600;animation:.2s ease-out checkersToastIn;position:fixed;bottom:96px;left:50%;transform:translate(-50%)}@media (width>=1024px){.checkers-board__toast{bottom:24px}}@keyframes checkersToastIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}@media (prefers-reduced-motion:reduce){.checkers-board__piece,.checkers-board__piece--king,.checkers-board__cell,.checkers-board__cell--must-continue,.checkers-board__btn,.checkers-board__toast{transition:none!important;animation:none!important}.checkers-board__piece--captured{opacity:0;transform:none}}.checkers-resign-dialog__overlay{z-index:100;opacity:0;background:#140e1aeb;justify-content:center;align-items:flex-end;transition:opacity .2s ease-out;display:flex;position:fixed;inset:0}@media (width>=600px){.checkers-resign-dialog__overlay{align-items:center}}.checkers-resign-dialog__overlay--visible{opacity:1}.checkers-resign-dialog__sheet{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);width:100%;max-width:420px;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);border-radius:20px 20px 0 0;padding:16px 20px 28px;transition:transform .25s ease-out;transform:translateY(100%)}@media (width>=600px){.checkers-resign-dialog__sheet{border-radius:var(--frg-radius-card,12px);opacity:0;transition:transform .2s ease-out,opacity .2s;transform:scale(.96)}}.checkers-resign-dialog__sheet--visible{transform:translateY(0)}@media (width>=600px){.checkers-resign-dialog__sheet--visible{opacity:1;transform:scale(1)}}.checkers-resign-dialog__sheet__handle{background:var(--frg-border-default,#f4ece01a);border-radius:9999px;width:36px;height:4px;margin:0 auto 12px}.checkers-resign-dialog__sheet__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin-bottom:8px;font-size:20px;font-weight:700}.checkers-resign-dialog__sheet__body{color:var(--frg-text-secondary,#c7bfb3);margin-bottom:18px;font-size:14px;line-height:1.5}.checkers-resign-dialog__sheet__actions{flex-direction:column;gap:10px;display:flex}@media (width>=600px){.checkers-resign-dialog__sheet__actions{flex-direction:row-reverse}.checkers-resign-dialog__btn{flex:1 1 0}}.checkers-resign-dialog__btn{border-radius:var(--frg-radius-card,12px);cursor:pointer;border:1px solid #0000;min-height:48px;padding:0 18px;font-family:inherit;font-size:15px;font-weight:600;transition:background .2s,border-color .2s}.checkers-resign-dialog__btn--confirm{background:var(--frg-danger,#d96459);color:#1a1426}.checkers-resign-dialog__btn--cancel{color:var(--frg-text-secondary,#c7bfb3);border-color:var(--frg-border-default,#f4ece01a);background:0 0}.checkers-resign-dialog__btn--cancel:hover{background:var(--frg-hover,#332a3f);color:var(--frg-text,#f4ece0)}@media (prefers-reduced-motion:reduce){.checkers-resign-dialog__overlay,.checkers-resign-dialog__sheet{transition:none!important}}@media (width<=480px){.checkers-board{gap:6px;padding:4px}.checkers-board__cell{min-width:36px;min-height:36px}.checkers-board__turn-indicator{font-size:14px}}@media (width>=768px){.checkers-board{gap:16px;padding:12px}.checkers-board__turn-indicator{font-size:16px}}@media (width>=1024px){.checkers-board__result-text{font-size:24px}}.title-checkers{color:var(--frg-coral,#e8785e);letter-spacing:.06em}.ck-game{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:720px;margin:0 auto;padding:8px 12px 16px;display:flex}.ck-game__error{color:var(--frg-danger,#d96459);border:1px solid var(--frg-danger,#d96459);border-radius:var(--frg-radius-card,12px);text-align:center;background:#d964591f;width:100%;max-width:480px;padding:8px 14px;font-size:13px}.ck-prelobby{justify-content:center;padding:16px 0;display:flex}.ck-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}.ck-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}.ck-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.ck-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}.ck-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.ck-prelobby__form{flex-direction:column;gap:12px;display:flex}.ck-prelobby__field{flex-direction:column;gap:6px;display:flex}.ck-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}.ck-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}.ck-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.ck-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.ck-prelobby__submit,.ck-prelobby__back{width:100%}.ck-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}@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}}.memory-board{perspective:1000px;gap:8px;width:min(92vmin,640px);max-width:100%;margin:0 auto;padding:4px;display:grid}.memory-board--4{grid-template-columns:repeat(4,1fr)}.memory-board--6{grid-template-columns:repeat(6,1fr)}.memory-board--8{grid-template-columns:repeat(8,1fr);gap:6px}.memory-card{cursor:pointer;aspect-ratio:1;perspective:1000px;border-radius:var(--frg-radius-card,12px);background:0 0;border:none;width:100%;min-width:44px;min-height:44px;padding:0;position:relative}.memory-card:focus-visible{outline:2px solid var(--frg-coral,#e8785e);outline-offset:2px}.memory-card--disabled{cursor:not-allowed;opacity:.85}.memory-card--selected{box-shadow:0 0 0 2px var(--frg-coral,#e8785e)}.memory-card--matched{opacity:.78}.memory-card--mismatch{outline:2px solid var(--frg-danger,#d96459);animation:.4s ease-out memory-card-mismatch-pulse}@keyframes memory-card-mismatch-pulse{0%{transform:translate(0)}25%{transform:translate(-3px)}50%{transform:translate(3px)}75%{transform:translate(-2px)}to{transform:translate(0)}}.memory-card__inner{width:100%;height:100%;transform-style:preserve-3d;transition:transform .2s cubic-bezier(.2,.8,.2,1);display:block;position:relative;transform:rotateY(0)}.memory-card--flipped .memory-card__inner{transform:rotateY(180deg)}.memory-card__face{border-radius:var(--frg-radius-card,12px);backface-visibility:hidden;justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.memory-card__face--back{background:var(--frg-card,var(--color-surface-glass,#221a2e));border:1px solid var(--frg-border-hairline,#f4ece00f)}.memory-card__face--front{background:var(--frg-input,#2b2236);border:1px solid var(--frg-border-hairline,#f4ece00f);transform:rotateY(180deg)}.memory-card__back-pattern{background:radial-gradient(circle,#ffd3692e 0%,#ffd36900 72%);border-radius:50%;width:38%;height:38%}.memory-card__shape{width:70%;height:70%}.memory-card__matcher-tag{border-radius:50%;width:10px;height:10px;position:absolute;top:4px;right:4px;box-shadow:0 0 0 2px #00000059}.player-status-strip{flex-direction:column;gap:4px;width:100%;max-width:640px;display:flex}.player-status-strip__chips{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.player-status-strip__chip{background:var(--frg-card,#221a2e);border:2px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-pill,9999px);font-feature-settings:"tnum";align-items:center;gap:8px;padding:6px 12px;font-weight:600;transition:transform .2s,border-color .2s;display:flex}.player-status-strip__chip--active,.player-status-strip__chip--current{box-shadow:none;transform:scale(1.04);border-color:var(--frg-coral,#e8785e)!important}.player-status-strip__dot{border-radius:50%;flex:0 0 10px;width:10px;height:10px}.player-status-strip__name{color:var(--frg-text,#f4ece0);font-size:14px}.player-status-strip__score{color:var(--frg-gold,#ffd369);font-feature-settings:"tnum";margin-left:6px;font-size:13px}.player-status-strip__announce{text-align:center;min-height:1.3em;color:var(--frg-text-tertiary,#8c8478);font-size:12px}@media (width<=520px){.memory-board{gap:6px}.memory-board--8{gap:4px}}@media (prefers-reduced-motion:reduce){.memory-card__inner{transition:opacity .1s linear;transform:none}.memory-card--flipped .memory-card__inner{transform:none}.memory-card__face{transition:opacity .1s linear}.memory-card__face--front{opacity:0;transform:none}.memory-card--flipped .memory-card__face--front{opacity:1}.memory-card--flipped .memory-card__face--back{opacity:0}.memory-card--mismatch{animation:none}}.title-memory-match{color:var(--frg-coral,#e8785e);letter-spacing:.06em}.mm-app{flex-direction:column;min-height:100dvh;display:flex}.mm-app.app--online{background:var(--frg-canvas,#1a1426);align-items:stretch;padding:0}.mm-app.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}.mm-game{flex-direction:column;align-items:center;gap:12px;width:100%;max-width:720px;margin:0 auto;padding:8px 12px 16px;display:flex}.mm-game__error{color:var(--frg-danger,#d96459);border:1px solid var(--frg-danger,#d96459);border-radius:var(--frg-radius-card,12px);text-align:center;background:#d964591f;width:100%;max-width:480px;padding:8px 14px;font-size:13px}.mm-game__resign-row{display:none}@media (width>=1024px){.mm-game__resign-row{justify-content:flex-end;width:100%;max-width:640px;display:flex}}.mm-game__resign-btn{color:var(--frg-danger,#d96459);border-color:var(--frg-danger,#d96459);background:0 0}.mm-game__resign-btn:hover{color:var(--frg-text,#f4ece0);background:#d9645924}.mm-flash{font-family:var(--frg-font-headline,"Syne", sans-serif);border-radius:var(--frg-radius-card,12px);pointer-events:none;z-index:50;padding:14px 22px;font-size:28px;font-weight:700;animation:.3s ease-out mm-flash-pop;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.mm-flash--match{background:var(--frg-success,#7fb069);color:#1a1426}.mm-flash--miss{background:var(--frg-danger,#d96459);color:var(--frg-text,#f4ece0)}@keyframes mm-flash-pop{0%{opacity:0;transform:translate(-50%,-50%)scale(.6)}60%{opacity:1;transform:translate(-50%,-50%)scale(1.1)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.mm-terminal{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:520px;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);flex-direction:column;align-items:center;gap:14px;padding:24px 20px;display:flex}.mm-terminal__banner{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin:0;font-size:24px}.mm-toast{background:var(--frg-card,#221a2e);color:var(--frg-text,#f4ece0);border:1px solid var(--frg-border-default,#f4ece01a);border-radius:var(--frg-radius-chip,8px);z-index:60;box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);padding:10px 16px;font-size:13px;position:fixed;bottom:96px;left:50%;transform:translate(-50%)}@media (width>=1024px){.mm-toast{bottom:24px}}.mm-a11y-hidden{visibility:hidden;width:0;height:0;position:absolute}.solo-timer{background:var(--frg-card,#221a2e);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-card,12px);flex-direction:column;align-items:center;gap:6px;width:100%;max-width:360px;padding:12px 16px;display:flex}.solo-timer__time{font-family:var(--frg-font-headline,"Syne", sans-serif);font-feature-settings:"tnum";color:var(--frg-text,#f4ece0)}.solo-timer__score{color:var(--frg-text-tertiary,#8c8478);font-feature-settings:"tnum";font-size:13px}.solo-timer__banner{flex-direction:column;align-items:center;gap:8px;margin-top:4px;display:flex}.mm-prelobby{justify-content:center;padding:16px 0;display:flex}.mm-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}.mm-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}.mm-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.mm-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}.mm-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.mm-prelobby__form{flex-direction:column;gap:12px;display:flex}.mm-prelobby__field{flex-direction:column;gap:6px;display:flex}.mm-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}.mm-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}.mm-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.mm-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.mm-prelobby__submit,.mm-prelobby__back{width:100%}.mm-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}.mm-lobby{flex-direction:column;gap:20px;max-width:480px;margin:0 auto;padding:16px 0 32px;display:flex}.mm-lobby__hero{flex-direction:column;align-items:center;gap:8px;padding:20px 16px;display:flex}.mm-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}.mm-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}@media (width>=1024px){.mm-lobby__roomcode{font-size:80px}}.mm-lobby__subtext{color:var(--frg-text-secondary,#c7bfb3);margin:4px 0 0;font-size:13px}.mm-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:18px;display:flex}.mm-lobby__card-title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin:0;font-size:14px;font-weight:600}.mm-lobby__seats{grid-template-columns:repeat(2,1fr);gap:8px;margin:0;padding:0;list-style:none;display:grid}.mm-lobby__seat{background:var(--frg-input,#2b2236);border:1px dashed var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-chip,8px);flex-direction:column;justify-content:center;align-items:center;gap:2px;min-height:56px;padding:10px;display:flex;position:relative}.mm-lobby__seat--filled{border-style:solid;border-color:var(--frg-border-default,#f4ece01a)}.mm-lobby__seat--p1.mm-lobby__seat--filled{border-color:var(--frg-coral,#e8785e)}.mm-lobby__seat--p2.mm-lobby__seat--filled{border-color:var(--frg-gold,#ffd369)}.mm-lobby__seat--p3.mm-lobby__seat--filled{border-color:var(--frg-purple,#a78bfa)}.mm-lobby__seat--p4.mm-lobby__seat--filled{border-color:var(--frg-teal,#4ecdc4)}.mm-lobby__seat-label{font-family:var(--frg-font-label,"Plus Jakarta Sans", sans-serif);letter-spacing:.08em;color:var(--frg-text-tertiary,#8c8478);font-size:10px}.mm-lobby__seat-name{color:var(--frg-text,#f4ece0);font-size:14px;font-weight:600}.mm-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);padding:2px 6px;font-size:9px;font-weight:700;position:absolute;top:6px;right:6px}.mm-lobby__option-row{flex-wrap:wrap;gap:8px;display:flex}.mm-lobby__option{background:var(--frg-input,#2b2236);min-width:80px;color:var(--frg-text,#f4ece0);border:1px solid var(--frg-border-hairline,#f4ece00f);border-radius:var(--frg-radius-chip,8px);cursor:pointer;flex-direction:column;flex:80px;align-items:center;gap:2px;min-height:56px;padding:10px;font-family:inherit;font-size:13px;transition:border-color .2s,background .2s;display:flex}.mm-lobby__option--active{border-color:var(--frg-coral,#e8785e);background:#e8785e14}.mm-lobby__option:disabled{cursor:not-allowed;opacity:.55}.mm-lobby__option-label{font-weight:600}.mm-lobby__option-sub{color:var(--frg-text-tertiary,#8c8478);font-size:11px}.mm-lobby__cta{flex-direction:column;align-items:stretch;gap:12px;padding:0 4px;display:flex}.mm-lobby__start,.mm-lobby__leave{width:100%}.mm-lobby__waiting{text-align:center;color:var(--frg-text-secondary,#c7bfb3);margin:0;font-size:14px;font-style:italic}.mm-lobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px;font-weight:500}.mm-resign-dialog__overlay{z-index:1000;opacity:0;background:#140e1aeb;justify-content:center;align-items:center;padding:16px;transition:opacity .2s;display:flex;position:fixed;inset:0}.mm-resign-dialog__overlay--visible{opacity:1}.mm-resign-dialog__sheet{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);opacity:0;flex-direction:column;gap:12px;padding:24px 20px;transition:transform .2s cubic-bezier(.2,.8,.2,1),opacity .2s;display:flex;transform:scale(.96)}.mm-resign-dialog__sheet--visible{opacity:1;transform:scale(1)}.mm-resign-dialog__sheet__handle{background:var(--frg-border-default,#f4ece01a);border-radius:9999px;width:36px;height:4px;margin:0 auto 4px}.mm-resign-dialog__sheet__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);margin:0;font-size:22px}.mm-resign-dialog__sheet__body{color:var(--frg-text-secondary,#c7bfb3);margin:0;font-size:14px;line-height:1.5}.mm-resign-dialog__sheet__actions{justify-content:center;gap:8px;margin-top:12px;display:flex}.mm-resign-dialog__btn{border-radius:var(--frg-radius-card,12px);cursor:pointer;border:1px solid #0000;flex:1 1 0;min-height:44px;padding:0 16px;font-family:inherit;font-size:14px;font-weight:600;transition:background .2s,border-color .2s}.mm-resign-dialog__btn--confirm{background:var(--frg-danger,#d96459);color:#1a1426}.mm-resign-dialog__btn--cancel{color:var(--frg-text-secondary,#c7bfb3);border-color:var(--frg-border-default,#f4ece01a);background:0 0}.mm-resign-dialog__btn--cancel:hover{color:var(--frg-text,#f4ece0);background:var(--frg-hover,#332a3f)}@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}}:root{--qm-accent:var(--frg-success);--qm-accent-soft:var(--frg-border-default)}.qm-lobby{flex-direction:column;gap:16px;width:100%;max-width:520px;margin:0 auto;padding:12px 12px 28px;display:flex}.qm-lobby__hero{flex-direction:column;align-items:center;gap:6px;padding:16px 12px 4px;display:flex}.qm-lobby__eyebrow{font-family:var(--frg-font-label);letter-spacing:.12em;text-transform:uppercase;color:var(--frg-text-tertiary);font-size:11px;font-weight:600}.qm-lobby__roomcode{font-family:var(--frg-font-headline);letter-spacing:.16em;color:var(--frg-text);font-feature-settings:"tnum";border-bottom:2px solid var(--frg-gold);padding-bottom:6px;font-size:48px;font-weight:700;line-height:1}.qm-lobby__subtext{color:var(--frg-text-secondary);text-align:center;margin:4px 0 0;font-size:13px}.qm-lobby__card{background:var(--frg-card);border:1px solid var(--frg-border-hairline);border-radius:var(--frg-radius-card);box-shadow:var(--frg-shadow-card);flex-direction:column;gap:12px;padding:16px;display:flex}.qm-lobby__card-title{font-family:var(--frg-font-headline);color:var(--frg-text);margin:0;font-size:14px;font-weight:600}.qm-lobby__roster{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.qm-lobby__player{background:var(--frg-input);border:1px solid var(--frg-border-hairline);border-radius:var(--frg-radius-chip);justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.qm-lobby__player--you{border-color:var(--frg-coral)}.qm-lobby__player-name{color:var(--frg-text);align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.qm-lobby__host-pill{background:var(--frg-coral);color:var(--frg-canvas);font-family:var(--frg-font-label);letter-spacing:.08em;border-radius:var(--frg-radius-pill);padding:2px 6px;font-size:9px;font-weight:700}.qm-lobby__level-chip{background:var(--qm-accent-soft);color:var(--frg-text);font-family:var(--frg-font-label);letter-spacing:.06em;text-transform:uppercase;border-radius:var(--frg-radius-pill);border:1px solid var(--frg-border-default);padding:4px 10px;font-size:11px;font-weight:600}.qm-lobby__levels{flex-direction:column;gap:6px;display:flex}.qm-lobby__levels-help{color:var(--frg-text-tertiary);margin:0;font-size:12px}.qm-lobby__level-grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}@media (width>=768px){.qm-lobby__level-grid{grid-template-columns:repeat(5,1fr)}}.qm-lobby__level-radio{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.qm-lobby__level-option{background:var(--frg-input);color:var(--frg-text);border:1px solid var(--frg-border-hairline);border-radius:var(--frg-radius-chip);cursor:pointer;flex-direction:column;align-items:flex-start;gap:2px;min-height:64px;padding:12px;transition:border-color .2s,background .2s;display:flex}.qm-lobby__level-option--active{border-color:var(--qm-accent);background:var(--frg-hover)}.qm-lobby__level-option--disabled{cursor:not-allowed;opacity:.55}.qm-lobby__level-label{font-family:var(--frg-font-headline);font-size:14px;font-weight:700}.qm-lobby__level-age{color:var(--frg-text-tertiary);font-size:11px}.qm-lobby__level-example{color:var(--frg-text-secondary);font-feature-settings:"tnum";margin-top:4px;font-size:12px}.qm-lobby__cta{flex-direction:column;gap:12px;padding:0 4px;display:flex}.qm-lobby__start,.qm-lobby__leave{width:100%}.qm-lobby__waiting{text-align:center;color:var(--frg-text-secondary);margin:0;font-size:14px;font-style:italic}.qm-lobby__error{text-align:center;color:var(--frg-danger);margin:0;font-size:13px;font-weight:500}.qm-prelobby{justify-content:center;padding:16px 12px;display:flex}.qm-prelobby__card{background:var(--frg-card);border:1px solid var(--frg-border-hairline);border-radius:var(--frg-radius-card);width:100%;max-width:420px;box-shadow:var(--frg-shadow-card);flex-direction:column;gap:16px;padding:24px 20px;display:flex}.qm-prelobby__title{font-family:var(--frg-font-headline);color:var(--frg-text);text-align:center;margin:0;font-size:22px;font-weight:700}.qm-prelobby__tabs{background:var(--frg-input);border-radius:var(--frg-radius-chip);gap:4px;padding:4px;display:flex}.qm-prelobby__tab{color:var(--frg-text-secondary);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}.qm-prelobby__tab--active{background:var(--frg-coral);color:var(--frg-canvas)}.qm-prelobby__form{flex-direction:column;gap:12px;display:flex}.qm-prelobby__field{flex-direction:column;gap:6px;display:flex}.qm-prelobby__label{font-family:var(--frg-font-label);letter-spacing:.08em;color:var(--frg-text-tertiary);text-transform:uppercase;font-size:11px;font-weight:600}.qm-prelobby__input{background:var(--frg-input);color:var(--frg-text);border:1px solid var(--frg-border-hairline);border-radius:var(--frg-radius-card);outline:none;min-height:44px;padding:0 14px;font-family:inherit;font-size:14px;transition:border-color .2s}.qm-prelobby__input:focus{border-color:var(--frg-coral)}.qm-prelobby__input--code{font-family:var(--frg-font-headline);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.qm-prelobby__submit,.qm-prelobby__back{width:100%}.qm-prelobby__error{text-align:center;color:var(--frg-danger);margin:0;font-size:13px}.qm-game{flex-direction:column;align-items:stretch;gap:14px;width:100%;max-width:720px;margin:0 auto;padding:12px;display:flex}.qm-game__round{justify-content:space-between;align-items:center;gap:10px;padding:8px 4px 0;display:flex}.qm-game__round-label{font-family:var(--frg-font-label);letter-spacing:.08em;text-transform:uppercase;color:var(--frg-text-tertiary);font-size:11px;font-weight:600}.qm-game__round-counter{font-family:var(--frg-font-headline);color:var(--frg-text);font-feature-settings:"tnum";font-size:18px;font-weight:700}.qm-game__scoreboard{width:100%}.qm-question{background:var(--frg-card);border:1px solid var(--frg-border-hairline);border-radius:var(--frg-radius-card);box-shadow:var(--frg-shadow-card);flex-direction:column;align-items:stretch;gap:14px;padding:20px 16px;transition:border-color .2s,background .2s;display:flex;position:relative}.qm-question--locked{border-color:var(--frg-danger);opacity:.85}.qm-question--win{border-color:var(--qm-accent);background:var(--frg-hover);animation:1.5s ease-out qm-win-flash}@keyframes qm-win-flash{0%{box-shadow:0 0 0 0 var(--qm-accent)}20%{box-shadow:0 0 0 6px var(--qm-accent-soft)}to{box-shadow:var(--frg-shadow-card)}}.qm-question__prompt{font-family:var(--frg-font-headline);color:var(--frg-text);text-align:center;font-feature-settings:"tnum";word-break:break-word;margin:0;font-size:clamp(2rem,8vw,4rem);font-weight:700;line-height:1.1}.qm-question__input-row{flex-direction:column;gap:10px;display:flex}@media (width>=768px){.qm-question__input-row{flex-direction:row;align-items:stretch}}.qm-question__input{background:var(--frg-input);color:var(--frg-text);border:1px solid var(--frg-border-default);border-radius:var(--frg-radius-card);min-height:56px;font-family:var(--frg-font-headline);letter-spacing:.04em;text-align:center;outline:none;flex:auto;padding:0 16px;font-size:24px;font-weight:700;transition:border-color .2s,background .2s}.qm-question__input:focus{border-color:var(--qm-accent)}.qm-question__input:disabled{opacity:.6;cursor:not-allowed}.qm-question__submit{background:var(--qm-accent);min-width:120px;min-height:56px;color:var(--frg-canvas);border-radius:var(--frg-radius-card);font-family:var(--frg-font-headline);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;padding:0 24px;font-size:16px;font-weight:700;transition:background .2s,opacity .2s}.qm-question__submit:hover:not(:disabled){background:var(--frg-success);filter:brightness(1.05)}.qm-question__submit:disabled{opacity:.55;cursor:not-allowed}.qm-banner{border-radius:var(--frg-radius-card);text-align:center;justify-content:center;align-items:center;gap:8px;padding:12px 14px;font-size:14px;font-weight:600;display:flex}.qm-banner--lockout{background:var(--frg-card);color:var(--frg-danger);border:1px solid var(--frg-danger)}.qm-banner--win{background:var(--frg-card);color:var(--qm-accent);border:1px solid var(--qm-accent);animation:.2s ease-out qm-banner-pop}.qm-banner__count{font-family:var(--frg-font-headline);font-feature-settings:"tnum";font-weight:700}@keyframes qm-banner-pop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.qm-question__speed-pill{background:var(--qm-accent);color:var(--frg-canvas);font-family:var(--frg-font-label);letter-spacing:.06em;border-radius:var(--frg-radius-pill);align-self:center;padding:6px 12px;font-size:12px;font-weight:700}@media (width>=768px){.qm-game{gap:18px;padding:18px}.qm-question{gap:20px;padding:32px 24px}.qm-lobby{max-width:640px}.qm-lobby__roomcode{font-size:64px}}.qm-app{flex-direction:column;min-height:100dvh;display:flex}.qm-app.app--online{background:var(--frg-canvas);align-items:stretch;padding:0}.qm-app.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}: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}.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}.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}}.ttt-game{flex-direction:column;align-items:center;gap:16px;width:100%;max-width:520px;margin:0 auto;padding:8px 0 16px;display:flex}.ttt-game__turn-desktop{display:none}@media (width>=1024px){.ttt-game__turn-desktop{justify-content:center;display:flex}}.ttt-game__board-wrap{justify-content:center;width:100%;transition:opacity .2s;display:flex}.ttt-game__board-wrap--waiting{opacity:.65}.ttt-game__claim{flex-direction:column;align-items:center;gap:8px;width:100%;max-width:280px;display:flex}.ttt-game__claim-hint{color:var(--frg-text-tertiary,#8c8478);text-align:center;margin:0;font-size:12px}.ttt-board{aspect-ratio:1;background:var(--frg-card,#221a2e);border-radius:var(--frg-radius-card,12px);border:1px solid var(--frg-border-hairline,#f4ece00f);width:min(360px,90vw);box-shadow:var(--frg-shadow-card,0 8px 24px #00000059);grid-template-columns:repeat(3,1fr);gap:8px;padding:12px;display:grid}@media (width>=600px){.ttt-board{gap:10px;width:min(440px,80vw);padding:14px}}@media (width>=1024px){.ttt-board{gap:12px;width:480px;padding:16px}}.ttt-board--disabled .ttt-cell--empty{cursor:default}.ttt-cell{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-card,12px);cursor:pointer;aspect-ratio:1;border:2px solid #0000;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:14%;transition:background .2s,border-color .2s,transform .15s;display:flex;position:relative;overflow:hidden}.ttt-cell--empty:hover{background:var(--frg-hover,#332a3f);border-color:var(--frg-border-default,#f4ece01a);transform:scale(1.03)}.ttt-cell--empty:active{transform:scale(.97)}.ttt-cell:disabled{cursor:not-allowed}.ttt-cell--last{border-color:var(--frg-coral,#e8785e)}.ttt-cell--win{border-color:var(--frg-coral,#e8785e);background:#e8785e1a;animation:1.6s ease-in-out infinite alternate ttt-win-pulse}@keyframes ttt-win-pulse{0%{filter:brightness()}to{filter:brightness(1.18)}}.ttt-mark{justify-content:center;align-items:center;width:100%;height:100%;animation:.35s cubic-bezier(.34,1.56,.64,1) ttt-pop;display:flex}.ttt-mark__svg{width:100%;height:100%}@keyframes ttt-pop{0%{opacity:0;transform:scale(0)rotate(-12deg)}to{opacity:1;transform:scale(1)rotate(0)}}.ttt-x__line{stroke:var(--frg-coral,#e8785e);stroke-width:10px;stroke-linecap:round;stroke-dasharray:85;stroke-dashoffset:85px;animation:.3s ease-out forwards ttt-draw}.ttt-x__line--2{animation-delay:.1s}.ttt-o__circle{fill:none;stroke:var(--frg-teal,#4ecdc4);stroke-width:8px;stroke-linecap:round;stroke-dasharray:189;stroke-dashoffset:189px;animation:.4s ease-out forwards ttt-draw-circle}@keyframes ttt-draw{to{stroke-dashoffset:0}}@keyframes ttt-draw-circle{to{stroke-dashoffset:0}}.ttt-prelobby{justify-content:center;padding:16px 0;display:flex}.ttt-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}.ttt-prelobby__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);text-align:center;margin:0;font-size:24px;font-weight:700}.ttt-prelobby__tabs{background:var(--frg-input,#2b2236);border-radius:var(--frg-radius-chip,8px);gap:4px;padding:4px;display:flex}.ttt-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}.ttt-prelobby__tab--active{background:var(--frg-coral,#e8785e);color:#1a1426}.ttt-prelobby__form{flex-direction:column;gap:12px;display:flex}.ttt-prelobby__field{flex-direction:column;gap:6px;display:flex}.ttt-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}.ttt-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}@media (width>=1024px){.ttt-prelobby__input{min-height:44px}}.ttt-prelobby__input:focus{border-color:var(--frg-coral,#e8785e)}.ttt-prelobby__input--code{font-family:var(--frg-font-headline,"Syne", sans-serif);letter-spacing:.18em;text-align:center;text-transform:uppercase;font-weight:700}.ttt-prelobby__submit,.ttt-prelobby__back{width:100%}.ttt-prelobby__error{text-align:center;color:var(--frg-danger,#d96459);margin:0;font-size:13px}.ttt-terminal{flex-direction:column;align-items:center;gap:20px;padding:32px 16px;display:flex}.ttt-terminal__title{font-family:var(--frg-font-headline,"Syne", sans-serif);color:var(--frg-text,#f4ece0);text-align:center;margin:0;font-size:28px;font-weight:700}@media (prefers-reduced-motion:reduce){.ttt-cell--win,.ttt-mark,.ttt-x__line,.ttt-o__circle,.ttt-cell{transition:none!important;animation:none!important}}.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}}:root{--color-surface:#1a1426;--color-surface-container:#221a2e;--color-surface-elevated:#2b2236;--color-surface-dim:var(--color-surface);--color-surface-container-lowest:var(--color-surface);--color-surface-container-low:var(--color-surface-container);--color-surface-container-high:var(--color-surface-container);--color-surface-container-highest:var(--color-surface-elevated);--color-surface-bright:var(--color-surface-elevated);--color-bg:var(--color-surface);--color-bg-card:var(--color-surface-container);--color-bg-card-hover:var(--color-surface-elevated);--color-bg-input:var(--color-surface-elevated);--color-bg-elevated:var(--color-surface-elevated);--color-accent:#e8785e;--color-accent-light:#ffb4a3;--color-accent-deep:#e8785e;--color-gold:#ffd369;--color-gold-warm:#ecc159;--color-teal:#4ecdc4;--color-purple:#a78bfa;--color-green:#7fb069;--color-coral:#ff6b6b;--color-blue:#7ec8e3;--color-white:#fafafa;--color-text:#f2ebe0;--color-on-surface:var(--color-text);--color-muted:#f2ebe09e;--color-text-secondary:#c7bfb3;--color-text-tertiary:#8c8478;--color-dimmed:#f2ebe02e;--color-border:#f2ebe01a;--color-outline-variant:#f2ebe00f;--font-family:"Outfit", -apple-system, sans-serif;--font-display:"Syne", "Outfit", sans-serif;--font-body:"Outfit", -apple-system, system-ui, sans-serif;--font-label:"Plus Jakarta Sans", "Outfit", sans-serif;--font-xs:11px;--font-sm:13px;--font-base:14px;--font-md:15px;--font-lg:16px;--font-xl:20px;--font-2xl:24px;--font-3xl:32px;--font-4xl:40px;--font-5xl:56px;--label-tracking:.08em;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:24px;--space-3xl:32px;--space-4xl:48px;--space-5xl:64px;--space-6xl:96px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:28px;--radius-card:12px;--radius-hero:28px;--radius-round:24px;--radius-pill:9999px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-standard:cubic-bezier(.4, 0, .2, 1);--ease-spring:cubic-bezier(.22, 1, .36, 1);--motion-spring:.2s cubic-bezier(.2, .8, .2, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--shadow-sm:0 1px 2px #14121b66;--shadow-md:0 8px 16px #14121b80;--shadow-lg:0 24px 48px #14121b80;--shadow-glow-warm:0 -40px 120px -40px #e8785e40, 0 40px 120px -40px #a78bfa2e;--shadow-glow-accent:0 0 20px #e8785e4d;--shadow-glow-gold:0 0 20px #ffd3694d;--shadow-glow-teal:0 0 20px #4ecdc44d;--shadow-light-leak:var(--shadow-lg);--shadow-tinted:var(--shadow-md);--blur-glass:blur(20px);--blur-glass-soft:blur(16px);--blur-nav:blur(24px);--z-base:0;--z-card:10;--z-nav:100;--z-modal:1000;--nav-height:80px;--max-width:430px;--header-top:56px;--color-bg-overlay:#14121bb8;--color-surface-2:var(--color-surface-container);--color-hairline:var(--color-outline-variant);--color-hairline-strong:var(--color-border);--glass-card-bg:#2b29334d;--glass-card-bg-hover:#2b29336b;--glass-pop-bg:#3b384266;--glass-nav-bg:#14121ba6;--glass-input-bg:#0f0d168c;--color-accent-gradient:linear-gradient(135deg, #ffb4a3 0%, #e8785e 100%);--color-accent-gradient-hover:linear-gradient(135deg, #ffc7b8 0%, #f08a70 100%);--color-gold-gradient:linear-gradient(135deg, #ffd369 0%, #ecc159 100%);--tone-accent-soft:#e8785e1f;--tone-gold-soft:#ffd3691f;--tone-teal-soft:#4ecdc41f;--tone-green-soft:#7fb0691f;--tone-purple-soft:#a78bfa1f;--font-display-sm:24px;--font-display-md:32px;--font-display-lg:40px;--font-display-xl:56px;--font-display-2xl:72px;--lh-tight:1.05;--lh-snug:1.2;--lh-normal:1.45;--lh-relaxed:1.6;--ls-tight:-.02em;--ls-display:-.03em;--sidebar-width:240px;--sidebar-width-collapsed:72px;--content-max:100%;--content-padding-mobile:20px;--content-padding-desktop:32px;--topbar-height-desktop:72px;--topbar-height-mobile:56px;--bottomnav-height-mobile:64px;--early-preview-banner-height:36px;--safe-area-bottom:env(safe-area-inset-bottom,0px);--safe-area-top:env(safe-area-inset-top,0px);--shadow-card:var(--shadow-md);--shadow-card-hover:var(--shadow-lg);--shadow-sidebar:1px 0 0 var(--color-hairline);--ring-focus:0 0 0 2px #e8785e80, 0 0 0 4px #e8785e2e;--font-feature-tabular:"tnum" 1, "lnum" 1;--color-bg-subtle:var(--color-surface)}@media (width>=1024px){:root{--content-padding:var(--content-padding-desktop)}}@media (width<=1023px){:root{--content-padding:var(--content-padding-mobile)}}@media (width<=599px){:root{--font-display-sm:20px;--font-display-md:24px;--font-display-lg:32px;--font-display-xl:40px;--font-display-2xl:48px;--font-5xl:40px;--font-4xl:32px;--font-3xl:24px;--font-2xl:20px}}:root{--dialog-mobile-bp:599px;--dialog-header-height:56px;--dialog-safe-bottom:env(safe-area-inset-bottom,0px)}.dialog-header{z-index:1;align-items:center;gap:var(--space-md);min-height:var(--dialog-header-height);padding:var(--space-sm) var(--space-md);background:var(--color-bg-card);border-bottom:1px solid #0000;display:flex;position:sticky;top:0}.dialog-header--scrolled{border-bottom-color:var(--color-border)}.dialog-header__title{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-white);text-align:left;flex:1;margin:0;font-weight:800}.dialog-header__action{flex-shrink:0}.dialog-close{border-radius:var(--radius-pill);width:44px;height:44px;color:var(--color-muted);cursor:pointer;transition:background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:24px;line-height:1;display:inline-flex}.dialog-close:hover{background:var(--color-dimmed);color:var(--color-white)}.dialog-close:focus-visible{outline:2px solid var(--color-teal);outline-offset:2px}.dialog-close:before{content:"×";font-weight:400}@media (width>=600px){.dialog-close--mobile-only{display:none}}@media (width<=599px){.dialog-fullscreen-mobile{align-items:stretch!important;padding:0!important}.dialog-fullscreen-mobile>*{width:100%!important;max-width:100%!important;height:100dvh!important;max-height:100vh!important;box-shadow:none!important;padding-bottom:calc(var(--space-3xl) + var(--dialog-safe-bottom))!important;border-radius:0!important}.dialog-bottomsheet-mobile{align-items:flex-end!important;padding:0!important}.dialog-bottomsheet-mobile>*{width:100%!important;max-width:100%!important;max-height:92vh!important;padding-bottom:calc(var(--space-3xl) + var(--dialog-safe-bottom))!important;border-bottom-right-radius:0!important;border-bottom-left-radius:0!important}}@media (prefers-reduced-motion:reduce){.dialog-fullscreen-mobile>*,.dialog-bottomsheet-mobile>*{transition:opacity var(--duration-fast) linear!important;transform:none!important}}.bottom-nav{z-index:var(--z-nav);height:calc(var(--bottomnav-height-mobile,64px) + env(safe-area-inset-bottom,0px));background:var(--color-bg);border-top:1px solid var(--color-hairline);padding:8px 12px calc(8px + env(safe-area-inset-bottom,0px));justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 24px #14121b8c}@media (width>=1024px){.bottom-nav{display:none}}.nav-item{color:var(--color-muted);font-family:inherit;font-size:var(--font-xs);border-radius:var(--radius-md);cursor:pointer;min-height:56px;transition:color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 12px;font-weight:500;display:flex;position:relative}.nav-item:hover{color:var(--color-white)}.nav-item--active{color:var(--color-accent)}.nav-item:before{content:"";border-radius:var(--radius-pill);transition:background var(--duration-fast) var(--ease-standard);pointer-events:none;z-index:0;background:0 0;position:absolute;inset:4px 12px}.nav-item--active:before{background:var(--tone-accent-soft)}.nav-item__icon,.nav-item__label{z-index:1;position:relative}.nav-item__icon{color:currentColor;justify-content:center;align-items:center;width:24px;height:24px;display:inline-flex}.nav-item__label{font-size:var(--font-xs);letter-spacing:.02em}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-hairline);z-index:50;flex-direction:column;gap:8px;height:100dvh;padding:24px 16px;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar__brand{align-items:center;gap:10px;padding:4px 8px 24px;display:flex}.sidebar__logo{width:36px;height:36px}.sidebar__wordmark{font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:var(--ls-tight);color:var(--color-text);font-weight:600}.sidebar__nav,.sidebar__section{flex-direction:column;gap:2px;padding:8px 0;display:flex}.sidebar__family{border-bottom:1px solid var(--color-hairline);flex-direction:column;gap:12px;margin-bottom:8px;padding:4px 4px 20px;display:flex}.sidebar__family-card{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);align-items:center;gap:12px;padding:12px 14px;display:flex}.sidebar__family-avatar{background:var(--color-accent);width:36px;height:36px;font-family:var(--font-display);color:var(--color-text);border-radius:50%;flex-shrink:0;place-items:center;font-size:16px;font-weight:700;display:grid}.sidebar__family-meta{flex-direction:column;gap:2px;min-width:0;display:flex}.sidebar__family-label{font-family:var(--font-label);text-transform:uppercase;letter-spacing:var(--label-tracking);color:var(--color-gold);font-size:10px;font-weight:600}.sidebar__family-name{font-family:var(--font-body);font-weight:600;font-size:var(--font-sm);letter-spacing:.04em;color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sidebar__new-game{background:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-md);width:100%;min-height:44px;color:var(--color-text);font-family:var(--font-body);font-size:var(--font-sm);cursor:pointer;transition:background var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-spring);justify-content:center;align-items:center;gap:6px;padding:10px 14px;font-weight:600;display:flex}.sidebar__new-game:hover{background:#f08a70;transform:translateY(-1px)}.sidebar__new-game-icon{font-size:var(--font-md);font-weight:600;line-height:1}.sidebar__section{border-top:1px solid var(--color-hairline);margin-top:auto;padding-top:12px}.sidebar__item{border-radius:var(--radius-md);color:var(--color-muted);font-family:inherit;font-size:var(--font-base);text-align:left;cursor:pointer;min-height:44px;transition:background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard), box-shadow var(--duration-fast) var(--ease-standard);background:0 0;border:none;align-items:center;gap:12px;padding:10px 12px;font-weight:500;display:flex;position:relative}.sidebar__item:hover{color:var(--color-text);background:#f2ebe00a}.sidebar__item:hover .sidebar__item-icon,.sidebar__item:hover .sidebar__icon{transform:scale(1.04)}.sidebar__item--active{background:var(--tone-accent-soft);color:var(--color-accent);box-shadow:inset 2px 0 0 var(--color-accent)}.sidebar__item--active .sidebar__item-icon{color:var(--color-accent)}.sidebar__item-icon,.sidebar__icon{color:currentColor;justify-content:center;align-items:center;width:24px;height:24px;transition:transform .16s;display:inline-flex}.sidebar__item--secondary{font-size:var(--font-sm);color:var(--color-muted)}.sidebar__footer{border-top:1px solid var(--color-hairline);flex-direction:column;gap:4px;margin-top:8px;padding-top:12px;display:flex}.sidebar__user{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:var(--font-base);cursor:pointer;text-align:left;align-items:center;gap:10px;width:100%;padding:10px 12px;display:flex}.sidebar__user:hover{background:var(--color-bg-card-hover)}.sidebar__user-avatar{background:var(--color-accent);width:32px;height:32px;color:var(--color-text);border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:700;display:grid}.sidebar__user-name{font-size:var(--font-sm);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.sidebar__signout{color:var(--color-muted);font-family:inherit;font-size:var(--font-xs);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 10px}.sidebar__signout:hover{color:var(--color-coral);background:#ff6b6b14}.top-bar{padding-top:var(--header-top);padding-bottom:var(--space-lg);align-items:center;gap:var(--space-md);display:flex}.top-bar__back{color:var(--color-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;transition:all .2s;display:flex}.top-bar__back:hover{color:var(--color-white);transform:translate(-2px)}.top-bar__back:active{transform:scale(.9)}.top-bar__title{font-size:var(--font-lg);color:var(--color-white);letter-spacing:-.3px;font-weight:600}.top-bar--home{z-index:var(--z-nav);height:calc(var(--topbar-height-mobile,56px) + env(safe-area-inset-top,0px));padding:env(safe-area-inset-top,0px) var(--content-padding-mobile,20px) 0;background:var(--color-bg);border-bottom:1px solid var(--color-hairline);padding-top:env(safe-area-inset-top,0px);justify-content:space-between;align-items:center;gap:var(--space-md);margin:0;padding-bottom:0;display:flex;position:fixed;top:0;left:0;right:0}body[data-early-preview=visible] .top-bar--home{top:var(--early-preview-banner-height,36px)}body[data-early-preview=visible] .app-shell--pinned-chrome{padding-top:calc(var(--topbar-height-mobile,56px) + env(safe-area-inset-top,0px) + var(--early-preview-banner-height,36px))}@media (width>=1024px){.top-bar--home{display:none}}.top-bar__lead{align-items:center;min-width:0;display:flex}.top-bar__actions{align-items:center;gap:var(--space-sm,8px);display:flex}.top-bar__brand{font-family:var(--font-display);color:var(--color-white);letter-spacing:-.3px;font-size:22px;font-weight:700}.topbar__greeting{font-family:var(--font-display);color:var(--color-white);letter-spacing:-.3px;font-size:22px;font-style:normal;font-weight:600;line-height:1.1}@media (width>=380px){.topbar__greeting,.top-bar__brand{font-size:24px}}.topbar__greeting-name{color:var(--color-gold);font-style:normal;font-weight:600}.topbar__bell{border-radius:var(--radius-pill);border:1px solid var(--color-hairline);width:32px;height:32px;color:var(--color-text);cursor:pointer;transition:background var(--duration-fast,.15s) var(--ease-standard,ease), border-color var(--duration-fast,.15s) var(--ease-standard,ease);background:0 0;place-items:center;padding:0;display:grid}.topbar__bell:hover{background:var(--color-bg-card);border-color:#f2ebe033}.topbar__bell:focus-visible{box-shadow:var(--ring-focus);outline:none}.topbar__avatar-btn{border:1px solid var(--color-hairline);cursor:pointer;width:32px;height:32px;transition:border-color var(--duration-fast,.15s) var(--ease-standard,ease), background var(--duration-fast,.15s) var(--ease-standard,ease);background:0 0;border-radius:50%;place-items:center;padding:0;display:grid}.topbar__avatar-btn:hover{border-color:var(--color-accent)}.topbar__avatar-btn:focus-visible{box-shadow:var(--ring-focus);outline:none}.topbar__avatar{font-family:var(--font-display);color:var(--color-white);font-size:14px;font-weight:600;line-height:1}.topbar-desktop{height:var(--topbar-height-desktop,72px);background:var(--color-bg);border-bottom:1px solid var(--color-hairline);z-index:var(--z-nav);position:sticky;top:0}.topbar-desktop__inner{max-width:var(--content-max);padding:0 var(--content-padding-desktop,var(--space-3xl));align-items:center;gap:12px;height:100%;margin:0 auto;display:flex}.topbar-desktop__spacer{flex:1}.topbar-desktop__icon-btn{border-radius:var(--radius-pill);border:1px solid var(--color-hairline);width:36px;height:36px;color:var(--color-text);cursor:pointer;transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard);background:0 0;place-items:center;padding:0;display:grid}.topbar-desktop__icon-btn:hover{background:var(--color-bg-card);border-color:#f2ebe033}.topbar-desktop__icon-btn:focus-visible{box-shadow:var(--ring-focus);outline:none}.topbar-desktop__avatar-btn{border:1px solid var(--color-hairline);cursor:pointer;width:36px;height:36px;min-height:36px;transition:border-color var(--duration-fast) var(--ease-standard);background:0 0;border-radius:50%;place-items:center;padding:0;display:grid}.topbar-desktop__avatar-btn:hover{border-color:var(--color-accent)}.topbar-desktop__avatar-btn:focus-visible{box-shadow:var(--ring-focus);outline:none}.topbar-desktop__avatar,.topbar-desktop__avatar-btn .topbar-desktop__avatar{background:var(--color-bg-card);width:32px;height:32px;font-family:var(--font-display);color:var(--color-text);border-radius:50%;place-items:center;font-size:13px;font-weight:600;display:grid}.app-shell--pinned-chrome{padding-top:calc(var(--topbar-height-mobile,56px) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--bottomnav-height-mobile,64px) + env(safe-area-inset-bottom,0px))}@media (width>=1024px){.app-shell--pinned-chrome{padding-top:0;padding-bottom:0}}.shell--desktop{padding-left:var(--sidebar-width);background:var(--color-bg);min-height:100dvh}.shell__main{flex-direction:column;min-width:0;min-height:100dvh;display:flex}.shell__content{flex:1;padding:0;overflow:hidden auto}.shell__app-shell--desktop{max-width:var(--content-max,1200px);padding:var(--content-padding-desktop,32px);min-height:auto;margin:0 auto;overflow:visible}.shell__app-shell--desktop:after{display:none}.btn{appearance:none;font-family:inherit;font-size:var(--font-base);letter-spacing:.01em;border-radius:var(--radius-2xl);cursor:pointer;min-height:48px;transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard), opacity var(--duration-fast) var(--ease-standard);border:none;justify-content:center;align-items:center;gap:10px;padding:12px 20px;font-weight:600;display:inline-flex;position:relative}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:not(:disabled):active{transform:translateY(1px)}.btn--primary{background:var(--color-accent-gradient);color:#601303;box-shadow:0 1px 0 #ffffff2e inset, var(--shadow-tinted)}.btn--primary:not(:disabled):hover{background:var(--color-accent-gradient-hover);box-shadow:0 1px 0 #ffffff38 inset, 0 16px 36px #14121ba6, var(--shadow-glow-accent);transform:translateY(-1px)}.btn--primary-hero{background:var(--color-accent-gradient);color:#601303;box-shadow:0 1px 0 #ffffff2e inset, var(--shadow-tinted)}.btn--primary-hero:not(:disabled):hover{background:var(--color-accent-gradient-hover);box-shadow:0 1px 0 #ffffff38 inset, 0 16px 36px #14121ba6, var(--shadow-glow-accent);transform:translateY(-1px)}.btn--secondary{color:var(--color-white);background:0 0;border:1px solid #ffffff26}.btn--secondary:not(:disabled):hover{background:#ffffff0a;border-color:#ffffff40}.btn--ghost{color:var(--color-muted);background:0 0}.btn--ghost:not(:disabled):hover{color:var(--color-white);background:#ffffff0a}.btn--social{background:var(--glass-card-bg);-webkit-backdrop-filter:var(--blur-glass-soft);color:var(--color-white);border:1px solid var(--color-hairline);justify-content:flex-start;padding-left:20px;position:relative}.btn--social:not(:disabled):hover{background:var(--glass-card-bg-hover);border-color:var(--color-hairline-strong)}.btn--coming-soon{opacity:.7}.coming-soon-badge{font-size:var(--font-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em;margin-left:auto;font-weight:500}.btn--sm{min-height:36px;font-size:var(--font-sm);border-radius:var(--radius-pill);padding:8px 14px}.btn--lg{min-height:56px;font-size:var(--font-md);padding:16px 28px}.btn--block{width:100%}.btn:focus-visible{box-shadow:var(--ring-focus);outline:none}.input-field{flex-direction:column;gap:6px;width:100%;display:flex}.input-field__label{font-size:var(--font-sm);color:var(--color-muted);letter-spacing:.02em;font-weight:500}.input-field__control{background:var(--color-bg-input);border:1px solid var(--color-hairline);border-radius:var(--radius-md);width:100%;min-height:48px;color:var(--color-white);font-family:inherit;font-size:var(--font-base);transition:border-color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard), box-shadow var(--duration-fast) var(--ease-standard);padding:12px 14px}.input-field__control::placeholder{color:#ffffff40}.input-field__control:hover:not(:disabled):not(:focus){border-color:#ffffff24}.input-field__control:focus{border-color:#e8785e80;outline:none;box-shadow:0 0 0 3px #e8785e26}.input-field__control:disabled{opacity:.5;cursor:not-allowed}.input-field__control[aria-invalid=true],.input-field--error .input-field__control{border-color:var(--color-coral)}.input-field__hint{font-size:var(--font-xs);color:var(--color-muted);min-height:16px}.input-field__hint--error{color:var(--color-coral)}.input-field__hint--valid{color:var(--color-green)}.reset-password__form{gap:var(--space-lg);margin-top:var(--space-xl);padding:0 var(--space-2xl) var(--space-4xl);flex-direction:column;display:flex}.reset-password__desc{color:var(--color-muted);font-size:var(--font-base);text-align:center;line-height:1.6}.reset-password__field-wrapper{position:relative}.reset-password__toggle{color:var(--color-muted);cursor:pointer;transition:color var(--duration-fast) ease;border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;bottom:12px;right:12px}.reset-password__toggle:hover{color:var(--color-white)}.reset-password__hint{font-size:var(--font-xs);margin-top:calc(var(--space-xs) * -1);margin-bottom:var(--space-xs);padding:0 var(--space-xs)}.reset-password__hint--error{color:var(--color-accent)}.reset-password__hint--valid{color:var(--color-teal)}.reset-password__error{color:var(--color-accent);font-size:var(--font-sm);text-align:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#e8785e1a;border:1px solid #e8785e33}.reset-password__success{text-align:center;padding:var(--space-xl) 0}.reset-password__success-icon{width:56px;height:56px;color:var(--color-teal);margin:0 auto var(--space-lg);background:#4ecdc426;border-radius:50%;justify-content:center;align-items:center;font-size:28px;font-weight:700;display:flex}.reset-password__success-title{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-white);margin:0 0 var(--space-md);font-weight:700}.reset-password__success-text{color:var(--color-text-secondary);font-size:var(--font-base);margin:0;line-height:1.6}.gtp{aspect-ratio:1;place-items:center;width:100%;max-width:100%;height:100%;max-height:100%;display:grid;position:relative}.gtp__svg{width:84%;height:84%;display:block}.gtp__word-row{justify-content:center;align-items:center;gap:clamp(1px,4%,4px);width:96%;height:100%;display:flex}.gtp__word-tile{aspect-ratio:1;border:clamp(1px, 4%, 2px) solid var(--color-gold);background:color-mix(in srgb, var(--color-gold) 10%, var(--color-bg-card));width:28%;font-family:var(--font-display);color:var(--color-gold);text-transform:uppercase;border-radius:clamp(2px,12%,6px);flex:none;place-items:center;font-size:clamp(9px,16%,18px);font-weight:700;line-height:1;display:grid;position:relative}.gtp__word-tile small{color:var(--color-text-secondary);font-size:clamp(5px,7%,9px);font-weight:600;line-height:1;position:absolute;bottom:6%;right:10%}.gtp__svg--ttt,.gtp__svg--chess{color:var(--color-text)}.gtp__svg--mm{color:var(--color-purple)}.gtp__svg--checkers,.gtp__svg--hangman,.gtp__svg--c4{color:var(--color-text)}.gtp__svg--trivia{color:var(--color-gold)}.gtp__svg--math{color:var(--color-text)}.pin-input{gap:var(--space-md);justify-content:center;display:flex}.pin-input__digit{border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-input);width:56px;height:56px;color:var(--color-white);font-size:var(--font-2xl);text-align:center;transition:border-color var(--duration-fast) ease;-webkit-tap-highlight-color:transparent;font-weight:700;font-family:var(--font-family);outline:none}.pin-input__digit:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #e8785e26}.pin-input--error .pin-input__digit{border-color:var(--color-coral);animation:.4s pinShake}.pin-input__digit:disabled{opacity:.4;cursor:not-allowed}@keyframes pinShake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.clf{gap:var(--space-lg);margin-top:var(--space-xl);padding:0 var(--space-2xl) var(--space-4xl);flex-direction:column;display:flex}.clf__pin-section{gap:var(--space-sm);flex-direction:column;display:flex}.clf__pin-label{font-size:var(--font-sm);color:var(--color-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.clf__error{color:var(--color-accent);font-size:var(--font-sm);text-align:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#e8785e1a;border:1px solid #e8785e33}.clf__countdown{color:var(--color-gold);font-size:var(--font-md);text-align:center;margin:0;font-weight:600}.login{min-height:100dvh;padding:32px var(--content-padding-mobile,20px) 40px;background:var(--color-bg);flex-direction:column;display:flex;position:relative;overflow:hidden}.login__glow{pointer-events:none;background:radial-gradient(at 12% 0,#e8785e24 0%,#0000 55%);position:absolute;inset:0}.login__marketing{z-index:1;flex:1;position:relative}.login__auth{z-index:1;margin-top:40px;position:relative}.login__logo{flex-direction:column;align-items:center;gap:14px;margin-bottom:36px;display:flex}.login__logo-icon{width:64px;height:64px}.login__logo-title{font-family:var(--font-display);font-size:var(--font-2xl);letter-spacing:var(--ls-tight);align-items:baseline;gap:4px;font-weight:600;display:flex}.login__logo-wordmark{color:var(--color-text)}.login__logo-domain{font-size:var(--font-sm);color:var(--color-text-secondary);letter-spacing:.05em;font-weight:500}.landing__hero{text-align:center;margin-bottom:28px}.landing__eyebrow{font-family:var(--font-label);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--label-tracking);color:var(--color-gold);margin-bottom:14px;font-weight:600}.landing__headline{font-family:var(--font-display);font-size:var(--font-display-lg);font-weight:700;line-height:var(--lh-tight);letter-spacing:var(--ls-display);color:var(--color-text);margin-bottom:16px}.landing__headline-accent{background:linear-gradient(135deg,#ffd369 0%,#ecc159 100%);color:#0000;-webkit-background-clip:text;background-clip:text;font-style:italic}.landing__subline{font-size:var(--font-md);color:var(--color-text-secondary);line-height:var(--lh-normal);max-width:480px;margin:0 auto}.landing__cta-stack{flex-direction:column;gap:12px;margin:28px 0 36px;display:flex}.landing__cta{border-radius:var(--radius-md);width:100%;min-height:48px;font-family:var(--font-body);font-size:var(--font-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-spring);padding:12px 24px;font-weight:600}.landing__cta--primary{background:var(--color-accent);border:1px solid var(--color-accent);color:var(--color-text)}.landing__cta--primary:hover{background:#f08a70;transform:translateY(-1px)}.landing__cta--secondary{color:var(--color-text);background:0 0;border:1px solid #f2ebe02e}.landing__cta--secondary:hover{border-color:#f2ebe052}.landing__cta--ghost{color:var(--color-gold);font-size:var(--font-sm);background:0 0;border:1px solid #0000;min-height:44px}.landing__cta--ghost:hover{color:var(--color-text)}.landing__preview{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:36px;display:grid}.landing__preview-tile{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;gap:8px;min-height:88px;padding:12px 8px;display:flex}.landing__preview-board{place-items:center;width:48px;height:48px;display:grid;position:relative}.landing__preview-label{font-family:var(--font-label);text-transform:uppercase;letter-spacing:var(--label-tracking);color:var(--color-text-secondary);font-size:10px;font-weight:600}.landing__features{flex-direction:column;gap:12px;margin-bottom:36px;list-style:none;display:flex}.landing__feature{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--color-text-secondary);line-height:var(--lh-normal);gap:14px;padding:16px;display:flex}.landing__feature strong{color:var(--color-text);margin-bottom:2px;font-weight:600;display:block}.landing__feature-icon{width:24px;height:24px;color:var(--color-gold);background:#ffd36924;border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:700;display:grid}.landing__footer{border-top:1px solid var(--color-hairline);text-align:center;flex-direction:column;gap:6px;margin-top:32px;padding-top:24px;display:flex}.landing__footer-brand{font-family:var(--font-display);font-weight:600;font-size:var(--font-md);color:var(--color-text)}.landing__footer-domain{color:var(--color-text-secondary);font-weight:500}.landing__footer-tagline{font-size:var(--font-xs);color:var(--color-text-tertiary);font-style:italic}.landing__footer-legal{font-size:var(--font-xs);color:var(--color-text-tertiary);margin-top:6px}.landing__footer-sep{color:var(--color-text-tertiary);margin:0 8px}.login__actions{flex-direction:column;gap:10px;display:flex}.login__divider{grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin:16px 0;display:grid}.login__divider-line{background:var(--color-hairline);height:1px}.login__divider-text{font-size:var(--font-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em}.login__child-pin-btn{border:1px dashed var(--color-hairline);width:100%;color:var(--color-muted);font-family:inherit;font-size:var(--font-sm);border-radius:var(--radius-md);cursor:pointer;background:0 0;min-height:44px;margin-top:16px;padding:12px;font-weight:600;display:block}.login__child-pin-btn:hover{color:var(--color-gold);border-color:#ffd3694d}.login__legal{font-size:var(--font-xs);color:var(--color-muted);text-align:center;line-height:var(--lh-normal);margin-top:20px}.login__link{color:var(--color-accent-light);text-decoration:none}.login__link:hover{text-decoration:underline}.login__form{padding:24px var(--content-padding-mobile,20px) 40px;flex-direction:column;gap:14px;max-width:460px;margin:0 auto;display:flex}.login__form-legal{font-size:var(--font-xs);color:var(--color-muted);text-align:center;line-height:var(--lh-normal);margin-top:8px}.login__field-hint{font-size:var(--font-xs);margin-top:-8px;margin-left:4px}.login__field-hint--error{color:var(--color-coral)}.login__field-hint--valid{color:var(--color-green)}.login__password-wrapper{position:relative}.login__password-toggle{color:var(--color-muted);cursor:pointer;background:0 0;border:none;min-height:32px;margin-top:12px;padding:6px;position:absolute;top:50%;right:12px;transform:translateY(0)}.login__password-toggle:hover{color:var(--color-white)}.login__age-confirm{font-size:var(--font-sm);color:var(--color-muted);cursor:pointer;line-height:var(--lh-normal);align-items:flex-start;gap:10px;display:flex}.login__age-confirm input{width:18px;height:18px;accent-color:var(--color-accent);flex-shrink:0;margin-top:2px}.login__error{border-radius:var(--radius-md);color:var(--color-coral);font-size:var(--font-sm);background:#ff6b6b1a;border:1px solid #ff6b6b40;padding:10px 14px}.login__forgot{color:var(--color-accent-light);font-family:inherit;font-size:var(--font-sm);cursor:pointer;background:0 0;border:none;margin:4px auto 0;padding:8px;text-decoration:underline}.login__forgot-desc{font-size:var(--font-sm);color:var(--color-muted);line-height:var(--lh-normal);margin-bottom:4px}.login__reset-sent{text-align:center;padding:24px 0}.login__reset-sent-icon{color:var(--color-accent);margin-bottom:12px;font-size:40px}.login__reset-sent-title{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-white);margin-bottom:8px;font-weight:700}.login__reset-sent-text{font-size:var(--font-sm);color:var(--color-muted);line-height:var(--lh-normal);margin-bottom:8px}.login__reset-sent-hint{font-size:var(--font-xs);color:var(--color-muted)}.login__actions,.login__child-pin-btn,.login__divider,.login__legal{display:none}@media (width>=1024px){.login{max-width:var(--content-max);grid-template-columns:1.4fr 460px;align-items:start;gap:64px;margin:0 auto;padding:60px 80px;display:grid}.login__marketing{flex-direction:column;justify-content:flex-start;display:flex}.login__auth{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-card);box-shadow:var(--shadow-md);align-self:start;margin-top:0;padding:32px;position:sticky;top:60px}.login__actions{flex-direction:column;gap:10px;display:flex}.login__child-pin-btn{display:block}.login__divider{display:grid}.login__legal{display:block}.landing__cta-stack,.landing__footer{display:none}.landing__hero{text-align:left}.landing__headline{font-size:var(--font-display-xl)}.landing__subline{max-width:540px;margin-left:0}.login__logo{flex-direction:row;align-items:flex-start;gap:16px}.login__logo-title{font-size:var(--font-3xl)}.landing__preview{grid-template-columns:repeat(4,1fr);max-width:520px}.landing__features{max-width:540px}}.jbc-overlay{z-index:var(--z-modal);padding:var(--space-xl);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.jbc-modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-round);width:100%;max-width:360px;padding:0 var(--space-2xl) var(--space-2xl);box-shadow:var(--shadow-lg);animation:slideUp .3s var(--ease-spring) both;flex-direction:column;display:flex;position:relative}.jbc-header{margin:0 calc(var(--space-2xl) * -1);padding-inline:var(--space-md)}.jbc-title{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-white);margin:0;font-weight:800}.jbc-subtitle{font-size:var(--font-sm);color:var(--color-muted);margin:var(--space-xs) 0 var(--space-xl)}.jbc-games{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.jbc-game-card{align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-md);background:linear-gradient(155deg, color-mix(in srgb, var(--card-color) 10%, var(--color-bg)), var(--color-bg));border:2px solid color-mix(in srgb, var(--card-color) 15%, transparent);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--duration-normal) ease, transform var(--duration-fast) ease, box-shadow var(--duration-normal) ease;flex-direction:column;display:flex}.jbc-game-card:hover{border-color:color-mix(in srgb, var(--card-color) 35%, transparent);transform:translateY(-2px)}.jbc-game-card--selected{border-color:var(--card-color);box-shadow:0 0 16px color-mix(in srgb, var(--card-color) 25%, transparent)}.jbc-game-icon{background:color-mix(in srgb, var(--card-color) 15%, transparent);width:48px;height:48px;color:var(--card-color);border-radius:50%;justify-content:center;align-items:center;display:flex}.jbc-game-name{font-family:var(--font-display);font-size:var(--font-sm);color:var(--color-white);font-weight:700}.jbc-input-group{margin-bottom:var(--space-lg)}.jbc-label{font-size:var(--font-sm);color:var(--color-muted);margin-bottom:var(--space-sm);font-weight:600;display:block}.jbc-input{width:100%;padding:var(--space-md) var(--space-lg);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-white);font-family:var(--font-display);font-size:var(--font-2xl);letter-spacing:8px;text-align:center;text-transform:uppercase;transition:border-color var(--duration-normal) ease;box-sizing:border-box;outline:none;font-weight:700}.jbc-input::placeholder{font-size:var(--font-base);letter-spacing:2px;color:var(--color-dimmed)}.jbc-input:focus{border-color:var(--color-teal)}.jbc-error{color:var(--color-coral);font-size:var(--font-sm);margin:0 0 var(--space-md)}.jbc-join-btn{width:100%;padding:var(--space-md) var(--space-xl);background:var(--color-teal);color:var(--color-bg);font-family:var(--font-display);font-size:var(--font-md);border-radius:var(--radius-md);cursor:pointer;transition:transform var(--duration-fast) ease, box-shadow var(--duration-normal) ease;border:none;font-weight:700}.jbc-join-btn:hover{box-shadow:var(--shadow-glow-teal);transform:translateY(-1px)}.jbc-join-btn:active{transform:translateY(0)}.fp-overlay{z-index:var(--z-modal);transition:background var(--duration-normal) var(--ease-standard);background:0 0;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.fp-overlay--visible{background:#00000080}.fp-sheet{width:100%;max-width:var(--max-width);background:var(--color-bg-card);border-top-left-radius:var(--radius-round);border-top-right-radius:var(--radius-round);padding:var(--space-md) var(--space-xl) var(--space-3xl);box-shadow:var(--shadow-lg);transition:transform var(--duration-slow) var(--ease-spring);transform:translateY(100%)}.fp-sheet--visible{transform:translateY(0)}.fp-sheet__handle{background:var(--color-dimmed);border-radius:var(--radius-pill);width:36px;height:4px;margin:0 auto var(--space-xl)}.fp-sheet__title{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-white);margin:0 0 var(--space-lg);font-weight:800}.fp-sheet__list{gap:var(--space-sm);flex-direction:column;display:flex}.fp-family{width:100%;padding:var(--space-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--duration-normal) var(--ease-standard), background var(--duration-normal) var(--ease-standard);justify-content:space-between;align-items:center;display:flex}.fp-family:hover{border-color:color-mix(in srgb, var(--color-teal) 30%, transparent)}.fp-family--active{border-color:var(--color-teal);background:color-mix(in srgb, var(--color-teal) 8%, var(--color-bg))}.fp-family__info{gap:var(--space-xs);text-align:left;flex-direction:column;display:flex}.fp-family__name{font-family:var(--font-display);font-size:var(--font-md);color:var(--color-white);font-weight:700}.fp-family__meta{align-items:center;gap:var(--space-xs);font-size:var(--font-sm);color:var(--color-muted);display:flex}.fp-family__meta svg{width:14px;height:14px}.fp-family__check{color:var(--color-teal);align-items:center;display:flex}.fp-family__check svg{width:20px;height:20px}.fp-sheet__cancel{margin-top:var(--space-lg);padding:var(--space-md);width:100%;min-height:44px;font-family:var(--font-display);font-size:var(--font-md);color:var(--color-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-normal) var(--ease-standard), border-color var(--duration-normal) var(--ease-standard);background:0 0;font-weight:700}.fp-sheet__cancel:hover{color:var(--color-white);border-color:var(--color-dimmed)}.cp-overlay{z-index:var(--z-modal);transition:background var(--duration-normal) var(--ease-standard);background:0 0;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.cp-overlay--visible{background:#00000080}.cp-sheet{width:100%;max-width:var(--max-width);background:var(--color-bg-card);border-top-left-radius:var(--radius-round);border-top-right-radius:var(--radius-round);padding:var(--space-md) var(--space-xl) var(--space-3xl);box-shadow:var(--shadow-lg);transition:transform var(--duration-slow) var(--ease-spring);transform:translateY(100%)}.cp-sheet--visible{transform:translateY(0)}.cp-sheet__handle{background:var(--color-dimmed);border-radius:var(--radius-pill);width:36px;height:4px;margin:0 auto var(--space-xl)}.cp-sheet__title{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-white);margin:0 0 var(--space-lg);font-weight:800}.cp-sheet__list{gap:var(--space-sm);flex-direction:column;display:flex}.cp-child{align-items:center;gap:var(--space-lg);width:100%;padding:var(--space-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--duration-normal) var(--ease-standard), background var(--duration-normal) var(--ease-standard);display:flex}.cp-child:hover{border-color:color-mix(in srgb, var(--color-purple) 30%, transparent);background:color-mix(in srgb, var(--color-purple) 5%, var(--color-bg))}.cp-child__name{font-family:var(--font-display);font-size:var(--font-md);color:var(--color-white);font-weight:700}.cp-sheet__cancel{margin-top:var(--space-lg);padding:var(--space-md);width:100%;min-height:44px;font-family:var(--font-display);font-size:var(--font-md);color:var(--color-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-normal) var(--ease-standard), border-color var(--duration-normal) var(--ease-standard);background:0 0;font-weight:700}.cp-sheet__cancel:hover{color:var(--color-white);border-color:var(--color-dimmed)}.ip-overlay{z-index:var(--z-modal);padding:var(--space-xl);transition:background var(--duration-normal) var(--ease-standard);background:0 0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ip-overlay--visible{background:#00000080}.ip-sheet{background:var(--color-bg-card);border-radius:var(--radius-round);width:100%;max-width:400px;max-height:min(80vh,520px);padding:0 var(--space-xl) var(--space-lg);box-shadow:var(--shadow-lg);opacity:0;transition:transform var(--duration-normal) var(--ease-spring), opacity var(--duration-normal) var(--ease-standard);flex-direction:column;display:flex;transform:scale(.95)}.ip-sheet--visible{opacity:1;transform:scale(1)}.ip-sheet__handle{display:none}.ip-sheet__header{margin:0 calc(var(--space-xl) * -1);padding-inline:var(--space-md)}.ip-sheet__title{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-white);text-align:center;margin:0;font-weight:800}.ip-sheet__list{gap:var(--space-sm);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.ip-empty{text-align:center;color:var(--color-muted);padding:var(--space-2xl) 0;font-size:var(--font-sm)}.ip-divider{align-items:center;gap:var(--space-md);padding:var(--space-md) 0 var(--space-xs);font-size:var(--font-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;display:flex}.ip-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.ip-member{align-items:center;gap:var(--space-lg);width:100%;min-height:56px;padding:var(--space-md) var(--space-lg);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--duration-normal) var(--ease-standard), background var(--duration-normal) var(--ease-standard), box-shadow var(--duration-normal) var(--ease-standard);display:flex}.ip-member:hover{border-color:color-mix(in srgb, var(--color-teal) 30%, transparent);background:color-mix(in srgb, var(--color-teal) 4%, var(--color-bg))}.ip-member--online{border-color:color-mix(in srgb, var(--color-green) 15%, transparent);box-shadow:0 0 12px color-mix(in srgb, var(--color-green) 8%, transparent)}.ip-member--offline .ip-member__name{color:var(--color-muted)}.ip-member--offline .ip-member__avatar-wrap{filter:grayscale(.8)}.ip-member--selected{border-color:color-mix(in srgb, var(--color-teal) 40%, transparent);background:color-mix(in srgb, var(--color-teal) 8%, var(--color-bg))}.ip-member__avatar-wrap{flex-shrink:0;position:relative}.ip-member__status{background:var(--color-muted);border:2px solid var(--color-bg);border-radius:50%;width:10px;height:10px;position:absolute;bottom:0;right:0}.ip-member__status--online{background:var(--color-green);animation:2s ease-in-out infinite ip-pulse-green;box-shadow:0 0 6px #5ee09c80}@keyframes ip-pulse-green{0%,to{box-shadow:0 0 6px #5ee09c80}50%{box-shadow:0 0 10px #5ee09cb3}}.ip-member__check{background:var(--color-teal);width:16px;height:16px;color:var(--color-bg);border:2px solid var(--color-bg);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:flex;position:absolute;bottom:-2px;right:-2px}.ip-member__check--locked{background:var(--color-teal)}.ip-member__info{text-align:left;flex-direction:column;gap:2px;display:flex}.ip-member__name{font-family:var(--font-display);font-size:var(--font-md);color:var(--color-white);font-weight:700}.ip-member__meta{font-size:var(--font-sm);color:var(--color-muted)}.ip-member__online-pill{color:var(--color-green);font-weight:600}.ip-member__offline-note{font-size:var(--font-xs);color:var(--color-muted);font-style:italic}.ip-sending{padding:var(--space-3xl) 0;justify-content:center;align-items:center;display:flex}.ip-sending__text{font-size:var(--font-md);color:var(--color-teal);font-weight:600}.ip-sent{padding:var(--space-3xl) 0;justify-content:center;align-items:center;display:flex}.ip-sent__text{font-size:var(--font-md);color:var(--color-green);font-weight:700}.ip-multi-cta{padding:var(--space-md) 0 0}.ip-multi-cta__btn{width:100%;min-height:48px;font-family:var(--font-display);font-size:var(--font-md);color:var(--color-bg);background:var(--color-teal);border-radius:var(--radius-pill);cursor:pointer;transition:transform var(--duration-fast) ease, opacity var(--duration-fast) ease;border:none;font-weight:700}.ip-multi-cta__btn:hover{transform:scale(1.02)}.ip-multi-cta__btn:active{transform:scale(.98)}.ip-multi-cta__counter{text-align:center;font-size:var(--font-xs);color:var(--color-muted);padding:var(--space-xs) 0 0}.ip-error{text-align:center;color:var(--color-coral);font-size:var(--font-sm);padding:var(--space-sm) 0}.ip-sheet__cancel{margin-top:var(--space-lg);padding:var(--space-md);width:100%;font-family:var(--font-display);font-size:var(--font-md);color:var(--color-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-normal) var(--ease-standard), border-color var(--duration-normal) var(--ease-standard);background:0 0;font-weight:700}.ip-sheet__cancel:hover{color:var(--color-white);border-color:var(--color-dimmed)}.game-picker__overlay{z-index:var(--z-modal);transition:background var(--duration-normal) var(--ease-standard);background:0 0;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.game-picker__overlay--visible{background:#00000080}.game-picker__sheet{width:100%;max-width:var(--max-width);background:var(--color-bg-card);border-top-left-radius:var(--radius-round);border-top-right-radius:var(--radius-round);max-height:70vh;padding:var(--space-md) var(--space-xl) var(--space-3xl);box-shadow:var(--shadow-lg);transition:transform var(--duration-slow) var(--ease-spring);flex-direction:column;display:flex;transform:translateY(100%)}.game-picker__sheet--visible{transform:translateY(0)}.game-picker__sheet__handle{background:var(--color-dimmed);border-radius:var(--radius-pill);width:36px;height:4px;margin:0 auto var(--space-xl)}.game-picker__sheet__title{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-white);margin:0 0 var(--space-lg);font-weight:800}.game-picker__sheet__list{gap:var(--space-sm);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.game-picker__game{align-items:center;gap:var(--space-lg);width:100%;min-height:56px;padding:var(--space-md) var(--space-lg);background:var(--color-bg);border:1px solid var(--color-border);border-left:3px solid var(--gp-game-color,var(--color-border));border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--duration-normal) var(--ease-standard), background var(--duration-normal) var(--ease-standard);display:flex}.game-picker__game:hover{border-color:color-mix(in srgb, var(--gp-game-color) 40%, transparent);background:color-mix(in srgb, var(--gp-game-color) 4%, var(--color-bg))}.game-picker__game--coming-soon{opacity:.45;cursor:default;filter:grayscale(.4)}.game-picker__game--coming-soon:hover{border-color:var(--color-border);background:var(--color-bg)}.game-picker__game__icon{border-radius:var(--radius-sm);background:color-mix(in srgb, var(--gp-game-color) 15%, transparent);width:40px;height:40px;color:var(--gp-game-color);flex-shrink:0;justify-content:center;align-items:center;display:flex}.game-picker__game__info{text-align:left;flex-direction:column;flex:1;gap:2px;display:flex}.game-picker__game__name{font-family:var(--font-display);font-size:var(--font-md);color:var(--color-white);font-weight:700}.game-picker__game__players{font-size:var(--font-xs);color:var(--color-muted)}.game-picker__game__badge{border-radius:var(--radius-pill);font-family:var(--font-display);letter-spacing:.5px;flex-shrink:0;padding:2px 10px;font-size:10px;font-weight:700;display:inline-block}.game-picker__game__badge--players{background:color-mix(in srgb, var(--gp-game-color) 15%, transparent);color:var(--gp-game-color)}.game-picker__game__badge--coming-soon{background:var(--color-dimmed);color:var(--color-muted);text-transform:uppercase}.game-picker__confirm{opacity:0;max-height:0;transition:max-height var(--duration-normal) var(--ease-standard), opacity var(--duration-normal) var(--ease-standard), padding var(--duration-normal) var(--ease-standard);overflow:hidden}.game-picker__confirm--open{opacity:1;max-height:160px;padding:var(--space-md) var(--space-lg)}.game-picker__confirm__inner{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);font-size:var(--font-sm);color:var(--color-muted);display:flex}.game-picker__confirm__send{width:100%;min-height:44px;font-family:var(--font-display);font-size:var(--font-md);color:var(--color-bg);background:var(--gp-game-color,var(--color-teal));border-radius:var(--radius-pill);cursor:pointer;transition:transform var(--duration-fast) ease, opacity var(--duration-fast) ease;border:none;font-weight:700}.game-picker__confirm__send:hover{transform:scale(1.02)}.game-picker__confirm__send:active{transform:scale(.98)}.game-picker__confirm__cancel{margin:var(--space-sm) auto 0;color:var(--color-muted);font-size:var(--font-sm);cursor:pointer;padding:var(--space-xs) var(--space-md);background:0 0;border:none;display:block}.game-picker__confirm__cancel:hover{color:var(--color-white)}.game-picker__sheet__note{text-align:center;font-size:var(--font-xs);color:var(--color-muted);padding:var(--space-sm) 0 0;font-style:italic}.game-picker__sheet__cancel{margin-top:var(--space-lg);padding:var(--space-md);width:100%;font-family:var(--font-display);font-size:var(--font-md);color:var(--color-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:color var(--duration-normal) var(--ease-standard), border-color var(--duration-normal) var(--ease-standard);background:0 0;font-weight:700}.game-picker__sheet__cancel:hover{color:var(--color-white);border-color:var(--color-dimmed)}.home{min-height:100dvh;padding:0 0 24px}.home__hero{padding:20px var(--content-padding-mobile,20px) 24px;position:relative;overflow:hidden}.home__hero-orb,.home__hero-orb--1,.home__hero-orb--2{display:none}.home__hero-body{z-index:2;position:relative}.home__headline{font-family:var(--font-display);font-size:var(--font-display-md);font-weight:700;line-height:var(--lh-tight);letter-spacing:var(--ls-display);color:var(--color-text);margin-bottom:20px}.home__headline-accent{color:inherit;font-style:normal;font-weight:inherit}.home__presence{z-index:2;max-width:720px;margin-bottom:18px;display:block;position:relative}.home__presence-head{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:10px;display:flex}.home__presence-title{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-gold);font-weight:600}.home__presence-count{letter-spacing:.08em;color:var(--color-coral);background:var(--tone-coral-soft,var(--tone-accent-soft));border-radius:var(--radius-pill);align-items:center;padding:3px 10px;font-size:10px;font-weight:700;display:inline-flex}.home__presence-list{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.home__presence-avatar,.home__presence-add{background:var(--color-bg-card);border:1px solid var(--color-hairline);width:40px;height:40px;color:var(--color-white);font-family:var(--font-display);font-size:var(--font-sm);border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid;position:relative;overflow:visible}.home__presence-avatar>span{line-height:1}.home__presence-avatar--online{box-shadow:0 0 0 2px var(--color-accent);border-color:var(--color-accent)}.home__presence-add{border-style:dashed;border-color:var(--color-hairline-strong,var(--color-hairline));color:var(--color-muted);cursor:pointer;font-family:inherit;font-size:var(--font-md);min-height:36px;transition:color var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard);padding:0;font-weight:700}.home__presence-add:hover,.home__presence-add:focus-visible{color:var(--color-white);border-color:var(--color-accent);background:var(--glass-card-bg-hover)}.home__family-row{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-pill);color:var(--color-white);font-size:var(--font-sm);align-items:center;gap:8px;margin-bottom:20px;padding:8px 14px;font-weight:500;display:inline-flex}.home__family-row--tappable{cursor:pointer;color:inherit;background:0 0;font-family:inherit}.home__family-row--tappable:hover{background:var(--color-bg-card-hover)}.home__family-chevron{color:var(--color-muted);display:inline-flex}.home__online-strip{z-index:2;margin-bottom:20px;position:relative}.home__online-avatars{scrollbar-width:none;gap:12px;padding:4px 2px;display:flex;overflow-x:auto}.home__online-avatars::-webkit-scrollbar{display:none}.home__hero-member{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;min-width:64px;min-height:auto;padding:4px;display:flex}.home__hero-member-avatar{border-radius:50%;position:relative}.home__hero-member-avatar--online:after{content:"";background:var(--color-green);width:12px;height:12px;box-shadow:0 0 0 2px var(--color-bg), 0 0 8px var(--color-green,#4ade80);border-radius:50%;position:absolute;bottom:0;right:0}.home__hero-member-name{font-size:var(--font-xs);color:var(--color-white);text-overflow:ellipsis;white-space:nowrap;max-width:64px;font-weight:500;overflow:hidden}.home__hero-member-status{color:var(--color-muted);font-size:10px}.home__hero-member--offline{opacity:.6}.home__hero-strip-sep{background:var(--color-hairline);flex-shrink:0;width:1px;margin:0 4px}.home__hero-strip-empty{font-size:var(--font-sm);color:var(--color-muted);padding:12px 0}.home__hero-strip-empty-link{color:var(--color-accent);font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;min-height:auto;padding:0;text-decoration:underline}.home__child-banner{background:color-mix(in srgb, var(--color-accent) 12%, var(--color-surface-container-high));border-radius:var(--radius-pill);width:auto;color:var(--color-white);font-size:var(--font-xs);border:none;align-self:flex-start;align-items:center;gap:8px;margin-bottom:16px;padding:6px 14px;display:inline-flex}.home__child-banner:before{content:"✓";background:var(--color-accent);width:16px;height:16px;color:var(--color-white);border-radius:50%;flex-shrink:0;place-items:center;font-size:10px;font-weight:700;line-height:1;display:inline-grid}.home__child-banner-text{color:var(--color-muted)}.home__child-banner-text strong{color:var(--color-white);font-weight:600}.home__child-banner-btn{color:var(--color-accent);font-family:inherit;font-size:var(--font-xs);border-radius:var(--radius-pill);cursor:pointer;background:0 0;border:1px solid #e8785e59;min-height:32px;padding:6px 10px;font-weight:600}.home__play-as-btn{background:var(--tone-gold-soft);border-radius:var(--radius-pill);color:var(--color-gold);font-family:inherit;font-size:var(--font-sm);cursor:pointer;border:1px solid #ffd36933;align-items:center;gap:6px;min-height:36px;padding:8px 14px;font-weight:600;display:inline-flex}.home__play-as-btn:hover{background:#ffd3692e}.home__featured{margin:0 var(--content-padding-mobile,20px) 24px;background:linear-gradient(135deg, var(--color-bg-card) 0%, var(--color-surface) 100%);border:1px solid var(--color-hairline);border-top:1px solid var(--color-accent);border-radius:var(--radius-card);cursor:pointer;box-shadow:var(--shadow-md);transition:transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard);padding:24px;position:relative;overflow:hidden}.home__featured:hover{border-color:#f2ebe02e;border-top-color:var(--color-accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.home__featured--coming-soon{opacity:.7;cursor:default}.home__featured--coming-soon:hover{box-shadow:var(--shadow-md);transform:none}.home__featured-pattern{display:none}.home__featured-content{flex-direction:column;gap:16px;display:flex;position:relative}.home__featured-frame{aspect-ratio:1;border-radius:var(--radius-md);background:color-mix(in srgb, var(--card-color,var(--color-accent)) 18%, var(--color-bg-elevated));border:1px solid color-mix(in srgb, var(--card-color,var(--color-accent)) 28%, var(--color-hairline));width:100%;max-width:240px;color:var(--color-text);place-items:center;margin:0 auto;display:grid}.home__featured-info{min-width:0}.home__featured-label{font-family:var(--font-label);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--label-tracking,.08em);color:var(--color-gold);margin-bottom:4px;font-weight:700}.home__featured-name{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-white);font-weight:700}.home__featured-desc{font-size:var(--font-sm);color:var(--color-muted);margin-top:4px}.home__featured-play{appearance:none;background:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-md);width:100%;color:var(--color-text);font-family:inherit;font-weight:700;font-size:var(--font-md);cursor:pointer;min-height:48px;transition:background var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-spring);justify-content:center;align-items:center;padding:12px 24px;display:inline-flex}.home__featured-play:hover{background:#f08a70;transform:translateY(-1px)}.home__game-badge--block{text-align:center;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);background:var(--color-bg-elevated);border:1px solid var(--color-hairline);border-radius:var(--radius-md);min-height:44px;padding:12px 24px;font-weight:700;line-height:1.4;display:block}.home__invite-pill{z-index:2;background:color-mix(in srgb, var(--color-bg) 65%, transparent);border:1px solid var(--color-hairline);border-radius:var(--radius-pill);min-height:24px;color:var(--color-text);font-family:var(--font-label);letter-spacing:.04em;cursor:pointer;transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-standard);align-items:center;gap:4px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex;position:absolute;top:8px;right:8px}.home__invite-pill:hover,.home__invite-pill:focus-visible{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-white);outline:none}.home__invite-pill__label--short{display:none}@media (width<=767px){.home__game-card .home__invite-pill{padding:4px 10px}.home__game-card .home__invite-pill__label--full{display:none}.home__game-card .home__invite-pill__label--short,.home__featured .home__invite-pill__label--full{display:inline}.home__featured .home__invite-pill__label--short{display:none}}.home__section-bar{padding:0 var(--content-padding-mobile,20px);align-items:baseline;gap:8px;margin-bottom:14px;display:flex}.home__section-title{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-white);font-weight:700}.home__section-count{font-size:var(--font-sm);color:var(--color-muted)}.home__games-grid{padding:0 var(--content-padding-mobile,20px);grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px;display:grid}.home__game-card{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);cursor:pointer;min-height:140px;box-shadow:none;animation:fadeIn .4s var(--ease-spring) both;transition:transform var(--duration-fast) var(--ease-spring), border-color var(--duration-fast) var(--ease-standard);flex-direction:column;gap:6px;padding:12px 12px 14px;display:flex;position:relative;overflow:hidden}.home__game-card:hover{border-color:color-mix(in srgb, var(--card-color,var(--color-accent)) 30%, var(--color-hairline));transform:translateY(-2px)}.home__game-card--coming-soon{cursor:default}.home__game-card--coming-soon:hover{border-color:var(--color-hairline);transform:none}.home__game-card--coming-soon .home__game-badge{display:none}.home__game-play{appearance:none;z-index:2;width:100%;min-height:40px;color:var(--color-text);border:1px solid var(--color-hairline);border-radius:var(--radius-md);font-family:var(--font-label);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--label-tracking,.08em);cursor:pointer;box-shadow:none;transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard);background:0 0;margin-top:auto;font-weight:700;position:relative}.home__game-play:hover{background:#f2ebe00d;border-color:#f2ebe02e}.home__game-lock{width:100%;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);background:var(--color-bg-elevated);border:1px solid var(--color-hairline);border-radius:var(--radius-pill);pointer-events:none;justify-content:center;align-items:center;gap:6px;margin-top:auto;padding:8px 12px;font-weight:700;display:inline-flex}.home__game-lock-icon{font-size:12px;line-height:1}.home__game-card:active{transition:transform 80ms;transform:scale(.98)}.home__game-pattern{display:none}.home__game-frame{aspect-ratio:1;border-radius:var(--radius-sm);background:linear-gradient(180deg, color-mix(in srgb, var(--card-color,var(--color-accent)) 8%, transparent) 0%, transparent 100%), var(--color-bg-elevated);border:1px solid var(--color-hairline);width:100%;color:color-mix(in srgb, var(--card-color,var(--color-accent)) 65%, var(--color-text));place-items:center;margin-bottom:8px;display:grid;position:relative}.home__game-icon{border-radius:var(--radius-sm);background:color-mix(in srgb, var(--card-color,var(--color-accent)) 22%, var(--color-surface-elevated));border:1px solid color-mix(in srgb, var(--card-color,var(--color-accent)) 32%, transparent);width:44px;height:44px;color:var(--color-text);place-items:center;margin-bottom:10px;display:grid;position:relative}.home__game-name{font-family:var(--font-display);color:var(--color-text);font-weight:600;font-size:var(--font-sm);letter-spacing:var(--ls-tight,-.01em);margin-bottom:2px;position:relative}.home__game-desc{font-size:var(--font-xs);color:var(--color-text-secondary);line-height:1.3;position:relative}.home__game-tag,.home__game-badge{font-family:var(--font-label);border-radius:var(--radius-pill);background:color-mix(in srgb, var(--color-bg) 65%, transparent);border:1px solid var(--color-hairline);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--label-tracking,.08em);padding:3px 7px;font-size:10px;font-weight:600;position:absolute;top:8px;left:8px}.home__game-badge{background:var(--tone-gold-soft);border-color:color-mix(in srgb, var(--color-gold) 22%, var(--color-hairline));color:var(--color-gold)}.home__join-card{margin:0 var(--content-padding-mobile,20px);background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);flex-direction:column;gap:12px;padding:20px;display:flex}.home__join-card-label{font-family:var(--font-label);font-size:var(--font-xs);letter-spacing:var(--label-tracking,.08em);text-transform:uppercase;color:var(--color-text-secondary);font-weight:700}.home__join{cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring);background:0 0;border:0;border-radius:0;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:0;display:grid;position:relative;overflow:hidden}.home__join:hover{transform:translateY(-1px)}.home__join:focus-visible{box-shadow:var(--ring-focus);border-radius:var(--radius-sm);outline:none}.home__join-glow{display:none}.home__join-icon{border-radius:var(--radius-sm);background:var(--tone-accent-soft);width:40px;height:40px;color:var(--color-accent);place-items:center;display:grid;position:relative}.home__join-text{position:relative}.home__join-title{font-family:var(--font-display);color:var(--color-text);font-weight:600;font-size:var(--font-md)}.home__join-sub{font-size:var(--font-xs);color:var(--color-text-secondary);margin-top:2px}.home__join-arrow{color:var(--color-accent);font-size:var(--font-xl);font-weight:600;position:relative}@media (width>=768px){.home__games-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=1024px){.home{padding-bottom:24px}.home__hero{padding:0 0 24px}.home__hero-body{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:32px;display:flex}.home__headline{flex:auto;max-width:none;margin-bottom:0;font-size:clamp(40px,5vw,56px)}.home__presence{flex:0 auto;min-width:280px;max-width:none;margin-bottom:0}.home__featured,.home__join{max-width:none;margin-left:0;margin-right:0}.home__featured{min-height:200px;margin-top:24px;padding:32px 36px}.home__featured-pattern{background:radial-gradient(circle at 78% 40%, var(--card-color,var(--color-accent)) 0%, transparent 55%), radial-gradient(circle at 95% 90%, var(--card-color,var(--color-accent)) 0%, transparent 60%);opacity:.18}.home__featured:after{content:"";background:repeating-linear-gradient(45deg, color-mix(in srgb, var(--card-color,var(--color-accent)) 28%, transparent) 0 2px, transparent 2px 36px), repeating-linear-gradient(-45deg, color-mix(in srgb, var(--card-color,var(--color-accent)) 22%, transparent) 0 2px, transparent 2px 36px);opacity:.55;pointer-events:none;z-index:0;width:420px;height:420px;position:absolute;top:-40px;right:-60px;transform:rotate(8deg);-webkit-mask-image:linear-gradient(270deg,#000000d9 10%,#0000 70%);mask-image:linear-gradient(270deg,#000000d9 10%,#0000 70%)}.home__featured-content{z-index:1;grid-template-columns:auto 1fr auto;align-items:center;gap:28px}.home__featured-icon{width:88px;height:88px}.home__featured-name{font-size:var(--font-2xl)}.home__featured-play{font-size:var(--font-md);align-self:end;padding:14px 28px}.home__section-bar{padding:0}.home__games-grid{grid-template-columns:repeat(4,1fr);gap:14px;padding:0}.home__game-card{min-height:200px;padding:14px}.home__game-icon{width:52px;height:52px}.home__game-name{font-size:var(--font-md)}.home__join{margin-bottom:0}}@media (width>=1440px){.home__games-grid{grid-template-columns:repeat(5,1fr)}}@media (width>=1800px){.home__games-grid{grid-template-columns:repeat(6,1fr)}}.card{background:var(--glass-card-bg);-webkit-backdrop-filter:var(--blur-glass);border:1px solid var(--color-hairline);border-radius:var(--radius-card);box-shadow:var(--shadow-card);transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-spring), box-shadow var(--duration-fast) var(--ease-standard);padding:18px}.card--interactive{cursor:pointer}.card--interactive:hover{background:var(--glass-card-bg-hover);border-color:var(--color-hairline-strong);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.card--elevated{background:var(--glass-pop-bg);-webkit-backdrop-filter:var(--blur-glass);box-shadow:var(--shadow-light-leak)}.card--flush{padding:0}.card--tone-accent{background:var(--tone-accent-soft);border-color:#e8785e2e}.card--tone-gold{background:var(--tone-gold-soft);border-color:#ffd3692e}.card--tone-teal{background:var(--tone-teal-soft);border-color:#4ecdc42e}.card--tone-green{background:var(--tone-green-soft);border-color:#5ee09c2e}.card--tone-purple{background:var(--tone-purple-soft);border-color:#a78bfa2e}.badge{font-size:var(--font-xs);letter-spacing:.04em;border-radius:var(--radius-pill);color:var(--color-white);white-space:nowrap;background:#ffffff0f;align-items:center;gap:4px;padding:3px 8px;font-weight:600;line-height:1;display:inline-flex}.badge--accent{background:var(--tone-accent-soft);color:var(--color-accent-light)}.badge--gold{background:var(--tone-gold-soft);color:var(--color-gold)}.badge--teal{background:var(--tone-teal-soft);color:var(--color-teal)}.badge--green{background:var(--tone-green-soft);color:var(--color-green)}.badge--purple{background:var(--tone-purple-soft);color:var(--color-purple)}.badge--coral{color:var(--color-coral);background:#ff6b6b1f}.badge--parent{background:var(--color-accent);color:var(--color-text)}.badge--child{color:var(--color-text);background:0 0;border:1px solid #f2ebe02e}.badge--online:before{content:"";background:var(--color-green);width:6px;height:6px;box-shadow:0 0 6px var(--color-green);border-radius:50%;display:inline-block}.badge--dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px;display:inline-block}.leaderboard{padding:20px var(--content-padding-mobile,20px) 24px;flex-direction:column;gap:16px;display:flex}.leaderboard__header{margin-bottom:4px}.leaderboard__title{font-family:var(--font-display);font-size:var(--font-display-sm);letter-spacing:var(--ls-display);color:var(--color-white);font-weight:700}.leaderboard__subtitle{font-size:var(--font-sm);color:var(--color-muted);margin-top:4px}.leaderboard__metric-strip{scrollbar-width:none;margin:0 calc(-1 * var(--content-padding-mobile,20px));padding:0 var(--content-padding-mobile,20px);gap:12px;display:flex;overflow-x:auto}.leaderboard__metric-strip::-webkit-scrollbar{display:none}.leaderboard__metric-card{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);flex:none;min-width:200px;padding:16px 20px}.leaderboard__metric-label{font-family:var(--font-label);font-size:var(--font-xs);letter-spacing:var(--label-tracking,.08em);text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:6px;font-weight:600}.leaderboard__metric-val{font-family:var(--font-display);font-size:var(--font-2xl);color:var(--color-text);font-feature-settings:var(--font-feature-tabular);font-weight:700;line-height:1}.leaderboard__tabs{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.leaderboard__tab{appearance:none;border:1px solid var(--color-hairline);color:var(--color-text-secondary);font-family:inherit;font-size:var(--font-sm);border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;text-transform:capitalize;min-height:44px;transition:background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard);background:0 0;padding:10px 16px;font-weight:600}.leaderboard__tab:hover{color:var(--color-text);border-color:#f2ebe02e}.leaderboard__tab--active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-text)}.leaderboard__tab:focus-visible{box-shadow:var(--ring-focus);outline:none}.leaderboard__podium{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);flex-direction:column;gap:16px;padding:20px;display:flex}.leaderboard__podium-first{border-bottom:1px solid color-mix(in srgb, var(--color-gold) 22%, transparent);grid-template-columns:auto 1fr auto;align-items:center;gap:16px;padding-bottom:16px;display:grid}.leaderboard__podium-first--me{border-left:2px solid var(--color-gold);margin-left:-14px;padding-left:12px}.leaderboard__podium-first-avatar-wrap{place-items:center;display:inline-grid;position:relative}.leaderboard__podium-first-avatar-wrap>:first-child{box-shadow:0 0 0 2px var(--color-gold);border-radius:50%}.leaderboard__podium-first-info{flex-direction:column;gap:4px;min-width:0;display:flex}.leaderboard__podium-first-name{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:8px;font-weight:700;display:flex;overflow:hidden}.leaderboard__podium-first-pts{color:var(--color-gold);align-items:baseline;gap:4px;display:inline-flex}.leaderboard__podium-first-pts-num{font-family:var(--font-display);font-size:var(--font-xl);font-feature-settings:var(--font-feature-tabular);font-weight:700}.leaderboard__podium-first-pts-unit{font-family:var(--font-body);font-size:var(--font-xs);color:var(--color-text-secondary);letter-spacing:.04em;font-weight:600}.leaderboard__podium-first-trophy{width:36px;height:36px;color:var(--color-gold);background:color-mix(in srgb, var(--color-gold) 12%, transparent);border-radius:50%;place-items:center;display:grid}.leaderboard__podium-rest{flex-direction:column;gap:12px;display:flex}.leaderboard__podium-row{grid-template-columns:36px 40px minmax(0,1fr) auto;align-items:center;gap:12px;display:grid}.leaderboard__podium-row--me{border-left:2px solid var(--color-gold);margin-left:-12px;padding-left:10px}.leaderboard__podium-row-name{font-weight:600;font-size:var(--font-base);color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:8px;display:flex;overflow:hidden}.leaderboard__podium-row-pts{font-family:var(--font-display);font-size:var(--font-md);color:var(--color-text);font-feature-settings:var(--font-feature-tabular);font-weight:700}.leaderboard__rank-pill{min-width:28px;height:22px;font-family:var(--font-display);font-size:var(--font-xs);letter-spacing:.04em;font-feature-settings:var(--font-feature-tabular);background:var(--color-bg-elevated);color:var(--color-text-secondary);border-radius:var(--radius-pill);place-items:center;padding:0 6px;font-weight:700;display:inline-grid}.leaderboard__rank-pill--gold{background:var(--color-gold);color:var(--color-surface);box-shadow:0 0 0 2px var(--color-bg-card);position:absolute;bottom:-6px;right:-6px}.leaderboard__child-badge{margin-top:2px}.leaderboard__rank-header{font-family:var(--font-label);letter-spacing:var(--label-tracking,.08em);text-transform:uppercase;color:var(--color-text-tertiary);grid-template-columns:28px 36px minmax(0,1fr) auto;gap:12px;margin-top:8px;padding:0 14px;font-size:10px;font-weight:700;display:grid}.leaderboard__rank-header-cell{line-height:1}.leaderboard__rank-header-cell:nth-child(2){visibility:hidden}.leaderboard__rank-header-cell--right{text-align:right}.leaderboard__rankings{flex-direction:column;gap:6px;display:flex}.leaderboard__rank-item{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-spring);animation:rank-item-in .24s var(--ease-spring) both;flex-wrap:nowrap;grid-template-columns:28px 36px minmax(0,1fr) auto;align-items:center;gap:12px;padding:12px 14px;display:grid}.leaderboard__rank-item--me{border-left:2px solid var(--color-gold)}.leaderboard__rank-item:hover{background:var(--color-bg-card-hover);border-color:var(--color-hairline-strong,var(--color-hairline));transform:translateY(-1px)}.leaderboard__rank-item--me:hover{border-left-color:var(--color-gold)}@keyframes rank-item-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.leaderboard__rank-num{font-family:var(--font-display);font-size:var(--font-base);text-align:center;font-feature-settings:var(--font-feature-tabular);font-weight:700;line-height:1}.leaderboard__rank-num--top{color:var(--color-gold)}.leaderboard__rank-num--rest{color:var(--color-text-secondary)}.leaderboard__rank-info-col{flex-direction:column;gap:2px;min-width:0;display:flex}.leaderboard__rank-name{color:var(--color-white);font-weight:600;font-size:var(--font-base);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;line-height:1.2;display:flex;overflow:hidden}.leaderboard__rank-meta{font-size:var(--font-xs);color:var(--color-muted);line-height:1.2}@media (width<=1023px){.leaderboard__rank-meta{display:none}}.leaderboard__rank-pts{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-text);font-feature-settings:var(--font-feature-tabular);margin-left:8px;font-weight:700}.leaderboard__empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;max-width:520px;margin:80px auto;padding:0 20px;display:flex}.leaderboard__empty-icon{margin-bottom:8px;font-size:64px;line-height:1}.leaderboard__empty-heading{font-family:var(--font-display);font-size:var(--font-display-sm);letter-spacing:var(--ls-display);color:var(--color-white);margin:0;font-weight:700}.leaderboard__empty-sub{font-size:var(--font-base);color:var(--color-muted);margin:0 0 12px}.leaderboard__empty-cta{background:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:var(--font-base);cursor:pointer;min-height:44px;transition:background var(--duration-fast) var(--ease-standard), transform var(--duration-fast) var(--ease-spring);align-items:center;gap:6px;padding:12px 24px;font-weight:600;display:inline-flex}.leaderboard__empty-cta:hover{background:var(--color-accent-light,#f08a70);transform:translateY(-2px)}@media (width>=1024px){.leaderboard{max-width:820px;margin:0 auto;padding:0}.leaderboard__title{font-size:var(--font-display-md)}.leaderboard__metric-strip{gap:16px;margin:0;padding:0;overflow:visible}.leaderboard__metric-card{flex:1 1 0;min-width:0}.leaderboard__rank-item{padding:14px 20px}.leaderboard__rank-num{font-size:var(--font-lg)}.leaderboard__rank-pts{font-size:var(--font-xl)}.leaderboard__podium{max-width:640px;margin-left:auto;margin-right:auto}}.settings{padding:var(--space-xl) var(--content-padding-mobile,20px) var(--space-2xl)}.settings__header{margin-bottom:var(--space-2xl)}.settings__title{font-family:var(--font-display);font-size:var(--font-display-sm);letter-spacing:var(--ls-display);color:var(--color-text);font-weight:700}.settings__profile{align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-card);margin-bottom:var(--space-2xl);cursor:pointer;transition:background var(--duration-fast) var(--ease-standard);display:flex}.settings__profile:hover,.settings__profile:focus-visible{background:var(--color-bg-card-hover);outline:none}.settings__profile-avatar{border-radius:var(--radius-pill);width:56px;height:56px;color:var(--color-text);font-weight:700;font-size:var(--font-xl);background:0 0;place-items:center;padding:0;display:grid}.settings__profile-avatar img,.settings__profile-avatar svg{border-radius:var(--radius-pill)}.settings__profile-body{flex:1}.settings__profile-name{color:var(--color-text);font-weight:700;font-size:var(--font-lg)}.settings__profile-email{font-size:var(--font-sm);color:var(--color-muted);margin-top:var(--space-xs)}.settings__profile-arrow{color:var(--color-muted)}.settings__group{margin-bottom:var(--space-2xl)}.settings__group-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin:0 var(--space-xs) var(--space-sm)}.settings__list{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-card);flex-direction:column;gap:2px;display:flex;overflow:hidden}.settings__row{gap:var(--space-md);padding:var(--space-md) var(--space-lg);color:var(--color-text);font-family:inherit;font-size:var(--font-base);text-align:left;cursor:pointer;border:none;border-bottom:1px solid var(--color-hairline);min-height:56px;transition:background var(--duration-fast) var(--ease-standard);background:0 0;grid-template-columns:32px 1fr auto;align-items:center;display:grid}.settings__row:last-child{border-bottom:none}.settings__row:hover,.settings__row:focus-visible{background:var(--color-bg-card-hover);outline:none}.settings__row-icon{border-radius:var(--radius-sm);background:var(--color-hairline);width:32px;height:32px;color:var(--color-muted);place-items:center;display:grid}.settings__row-icon--accent{color:var(--color-gold);background:var(--tone-gold-soft)}.settings__row-label{font-weight:500}.settings__row-label--accent{color:var(--color-gold);font-weight:600}.settings__row-meta{font-size:var(--font-sm);color:var(--color-muted);margin-top:var(--space-xs)}.settings__row-arrow{color:var(--color-muted)}.settings__signout{width:100%;margin-top:var(--space-2xl);padding:var(--space-md);color:var(--color-danger,var(--color-coral));font-family:inherit;font-size:var(--font-base);border-radius:var(--radius-2xl);cursor:pointer;min-height:48px;transition:background var(--duration-fast) var(--ease-standard);background:0 0;border:1px solid #ff6b6b40;font-weight:600}.settings__signout:hover,.settings__signout:focus-visible{background:#ff6b6b14;outline:none}.settings__signout-error{color:var(--color-danger,var(--color-coral));font-size:var(--font-sm);text-align:center;margin-top:var(--space-md)}.settings__version{font-size:var(--font-xs);color:var(--color-muted);text-align:center;margin-top:var(--space-2xl);letter-spacing:.04em}@media (width>=1024px){.settings{gap:var(--space-3xl);grid-template-columns:320px 1fr;align-items:start;padding:0;display:grid}.settings__header{grid-column:1/-1}.settings__title{font-size:var(--font-display-md)}.settings__profile{text-align:center;padding:var(--space-2xl);flex-direction:column;grid-column:1/2;margin-bottom:0}.settings__profile-avatar{width:80px;height:80px;font-size:var(--font-2xl)}.settings__profile-arrow{display:none}.settings__groups{grid-column:2/3}.settings__signout{max-width:320px}}.spm-overlay{z-index:var(--z-modal);opacity:0;transition:opacity var(--duration-normal) ease;background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.spm-overlay--visible{opacity:1}.spm-sheet{width:100%;max-width:var(--max-width);background:var(--color-bg-card);border-radius:var(--radius-round) var(--radius-round) 0 0;padding:0 var(--space-2xl) var(--space-4xl);transition:transform var(--duration-slow) var(--ease-spring);flex-direction:column;display:flex;transform:translateY(100%)}.spm-overlay--visible .spm-sheet,.spm-sheet--visible{transform:translateY(0)}.spm-sheet__header{margin:0 calc(var(--space-2xl) * -1) var(--space-sm);padding-inline:var(--space-md)}.spm-sheet__title{font-size:var(--font-lg);margin:0;font-weight:700}.spm-sheet__desc{font-size:var(--font-sm);color:var(--color-muted);text-align:center;margin:0 0 var(--space-2xl);line-height:1.5}.spm-sheet__error{color:var(--color-coral);font-size:var(--font-sm);text-align:center;margin:var(--space-md) 0 0}.spm-sheet__actions{gap:var(--space-md);margin-top:var(--space-2xl);justify-content:center;display:flex}.avatar-picker__grid{gap:var(--space-md);padding:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.avatar-picker__item{aspect-ratio:1;border:2px solid var(--color-border);background:var(--avatar-color);cursor:pointer;transition:all .2s var(--ease-standard);border-radius:50%;outline:none;justify-content:center;align-items:center;padding:0;display:flex}.avatar-picker__item:hover:not(:disabled){border-color:#ffffff4d;transform:scale(1.08)}.avatar-picker__item:active:not(:disabled){transform:scale(.95)}.avatar-picker__item--selected{border-color:var(--color-accent);box-shadow:0 0 0 3px #e8785e66}.avatar-picker__item:disabled{opacity:.5;cursor:not-allowed}.avatar-picker__emoji{font-size:28px;line-height:1}@media (width<=360px){.avatar-picker__grid{grid-template-columns:repeat(3,1fr)}}@media (width>=768px){.avatar-picker__grid{gap:var(--space-lg);grid-template-columns:repeat(6,1fr)}.avatar-picker__emoji{font-size:32px}}@media (width>=1024px){.avatar-picker__grid{grid-template-columns:repeat(6,1fr)}}.acd-overlay{z-index:var(--z-modal);padding:var(--space-xl);transition:background var(--duration-normal) var(--ease-standard);background:0 0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.acd-overlay--visible{background:#00000080}.acd-sheet{background:var(--color-bg-card);border:1px solid var(--color-hairline,var(--color-border));border-radius:var(--radius-card);width:100%;max-width:480px;max-height:min(90vh,640px);padding:0 var(--space-xl) var(--space-xl);box-shadow:var(--shadow-lg);opacity:0;transition:transform var(--duration-normal) var(--ease-spring), opacity var(--duration-normal) var(--ease-standard);flex-direction:column;display:flex;transform:scale(.96)}.acd-sheet--visible{opacity:1;transform:scale(1)}.acd-sheet__header{margin:0 calc(var(--space-xl) * -1);padding-inline:var(--space-md)}.acd-sheet__title{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-text);margin:0;font-weight:800}.acd-body{gap:var(--space-md);padding-top:var(--space-md);flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.acd-input{width:100%;padding:var(--space-md) var(--space-lg);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);font-size:var(--font-md);transition:border-color var(--duration-fast) ease;box-sizing:border-box;outline:none}.acd-input:focus{border-color:var(--color-teal)}.acd-avatar-label{font-size:var(--font-sm);color:var(--color-muted)}.acd-error{color:var(--color-coral);font-size:var(--font-sm);margin:0}.acd-actions{gap:var(--space-sm);padding-top:var(--space-lg);justify-content:flex-end;display:flex}.family{padding:20px var(--content-padding-mobile,20px) calc(var(--nav-height) + 24px);flex-direction:column;gap:16px;display:flex}.family__header{flex-direction:column;gap:4px;margin-bottom:4px;display:flex}.family__title{font-family:var(--font-display);font-size:var(--font-display-md);letter-spacing:var(--ls-display);color:var(--color-text);margin:0;font-weight:700}.family__meta{font-size:var(--font-sm);color:var(--color-muted);flex-wrap:wrap;align-items:center;gap:6px;margin:0;display:flex}.family__meta-name{color:var(--color-text);font-weight:600}.family__meta-sep{color:var(--color-text-tertiary)}.family__meta-edit{appearance:none;color:var(--color-accent);font-family:inherit;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:2px 6px;font-weight:600}.family__meta-edit:hover{background:var(--tone-accent-soft)}.family__meta-edit:focus-visible{box-shadow:var(--ring-focus);outline:none}.family__info{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:22px 20px;display:flex}.family__info-emoji{margin-bottom:4px;font-size:40px;line-height:1}.family__info-title{font-family:var(--font-display);font-size:var(--font-display-sm);letter-spacing:var(--ls-display);color:var(--color-text);font-weight:700}.family__info-title--editable{cursor:pointer;flex-direction:column;align-items:center;gap:2px;display:inline-flex}.family__edit-hint{font-family:var(--font-display,inherit);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);font-size:11px;font-weight:500}.family__info-detail{font-size:var(--font-sm);color:var(--color-muted)}.family__rename-form{flex-direction:column;align-items:stretch;gap:8px;width:100%;display:flex}.family__rename-actions{justify-content:center;gap:8px;display:flex}.family__create-input{background:var(--color-bg-input,var(--color-bg-card));border:1px solid var(--color-hairline);border-radius:var(--radius-md);width:100%;color:var(--color-text);font-family:inherit;font-size:var(--font-base);min-height:44px;padding:12px 14px}.family__create-input:focus{border-color:var(--color-accent);box-shadow:var(--ring-focus);outline:none}.family__create-error{color:var(--color-coral,var(--color-accent));font-size:var(--font-sm);margin:8px 0 0}.family__invite-section{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:18px;display:flex}.family__invite-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted)}.family__invite-code{font-family:var(--font-display);font-size:var(--font-2xl);letter-spacing:.18em;color:var(--color-gold);font-feature-settings:var(--font-feature-tabular);font-weight:700}.family__invite-actions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.family__invite-btn{min-height:36px!important;font-size:var(--font-sm)!important;border-radius:var(--radius-pill)!important;padding:6px 14px!important}.family__invite-btn--copied{background:var(--color-teal)!important;color:var(--color-text)!important}.family__invite-cta,.family__add-child-btn{width:100%}.family__section-label{font-family:var(--font-label);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:var(--label-tracking,.08em);color:var(--color-text-secondary);margin:8px 0 0}.family__section-label--danger{color:var(--color-coral,var(--color-accent))}@media (width<=1023px){.family__section-label:not(.family__section-label--danger),.family__invite-section{display:none}}.family__members{flex-direction:column;gap:16px;display:flex}.family__member{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);grid-template-columns:64px minmax(0,1fr) auto auto;align-items:center;gap:16px;padding:16px;display:grid;position:relative}.family__member-name{color:var(--color-text);font-weight:600;font-size:var(--font-base);white-space:nowrap;text-overflow:ellipsis;line-height:1.2;overflow:hidden}.family__role-toggle{cursor:pointer;font:inherit;background:0 0;border:none;padding:0}.family__role-toggle--loading{opacity:.5;cursor:wait}.family__member-remove{border-radius:var(--radius-pill);border:1px solid var(--color-hairline);width:36px;height:36px;color:var(--color-muted);cursor:pointer;transition:color var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard);background:0 0;place-items:center;display:grid}.family__member-remove:hover{color:var(--color-coral,var(--color-accent));border-color:var(--color-coral,var(--color-accent));background:var(--tone-accent-soft)}.family__menu-wrap{display:inline-flex;position:relative}.family__menu-trigger{border-radius:var(--radius-pill);border:1px solid var(--color-hairline);width:44px;height:44px;color:var(--color-text);cursor:pointer;transition:background var(--duration-fast) var(--ease-standard), border-color var(--duration-fast) var(--ease-standard);background:0 0;place-items:center;display:grid}.family__menu-trigger:hover{background:var(--color-bg-card-hover);border-color:var(--color-hairline-strong,var(--color-hairline))}.family__menu-trigger:focus-visible{box-shadow:var(--ring-focus);outline:none}.family__menu-trigger[aria-expanded=true]{background:var(--color-bg-card-hover);border-color:var(--color-accent);color:var(--color-accent)}.family__menu{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);min-width:180px;box-shadow:var(--shadow-md);z-index:calc(var(--z-card) + 5);animation:family-menu-in .12s var(--ease-spring);transform-origin:100% 0;flex-direction:column;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);right:0}@keyframes family-menu-in{0%{opacity:0;transform:translateY(-4px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.family__menu-item{appearance:none;color:var(--color-text);font-family:inherit;font-size:var(--font-sm);text-align:left;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;min-height:40px;transition:background var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard);background:0 0;border:none;padding:10px 12px;font-weight:500}.family__menu-item:hover:not(:disabled){background:var(--color-bg-card-hover)}.family__menu-item:focus-visible{background:var(--color-bg-card-hover);box-shadow:var(--ring-focus);outline:none}.family__menu-item:disabled{opacity:.5;cursor:not-allowed}.family__menu-item--danger{color:var(--color-coral,var(--color-accent))}.family__menu-item--danger:hover:not(:disabled){background:var(--tone-accent-soft)}.family__menu-divider{background:var(--color-hairline);height:1px;margin:4px 6px}.family__confirm-overlay{text-align:center;flex-direction:column;grid-column:1/-1;align-items:center;gap:10px;width:100%;padding:12px 4px;display:flex}.family__confirm-text,.family__delete-warning{font-size:var(--font-sm);color:var(--color-text);max-width:28ch;margin:0;line-height:1.4}.family__delete-warning{color:var(--color-coral,var(--color-accent))}.family__confirm-actions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.family__danger-row{cursor:pointer;grid-template-columns:24px 1fr 16px;align-items:center;gap:12px;padding:12px 4px;display:grid}.family__danger-row+.family__danger-row{border-top:1px solid var(--color-hairline)}.family__danger-icon{color:var(--color-coral,var(--color-accent));place-items:center;display:grid}.family__danger-label{font-size:var(--font-base);color:var(--color-text);font-weight:500}.family__danger-label--red{color:var(--color-coral,var(--color-accent))}.family__danger-chevron{color:var(--color-muted);place-items:center;display:grid}.family__link-overlay{background:var(--color-bg-overlay,#0009);z-index:var(--z-modal);place-items:center;padding:20px;display:grid;position:fixed;inset:0}.family__link-sheet{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-card);width:100%;max-width:420px;box-shadow:var(--shadow-md);flex-direction:column;gap:10px;padding:0 20px 20px;display:flex}.family__link-header{padding-inline:var(--space-md);margin:0 -20px}.family__link-title{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-text);margin:0;font-weight:700}.family__link-desc{font-size:var(--font-sm);color:var(--color-muted);margin:0}.family__link-url{background:var(--color-bg);border:1px dashed var(--color-hairline);border-radius:var(--radius-md);color:var(--color-text);word-break:break-all;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.family__link-actions{flex-wrap:wrap;justify-content:flex-start;gap:8px;display:flex}@media (width>=1024px){.family{gap:18px;max-width:720px;margin:0 auto;padding:0}.family__info-title{font-size:var(--font-display-md)}.family__menu{min-width:220px}}.subscription{padding:0 var(--content-padding-mobile,20px) calc(var(--nav-height) + var(--space-2xl))}.subscription__header{text-align:center;padding:var(--space-2xl) 0 var(--space-3xl)}.subscription__hero-emoji{font-size:var(--font-4xl);color:var(--color-gold);margin-bottom:var(--space-sm)}.subscription__eyebrow{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.12em;color:var(--color-gold);margin-bottom:var(--space-sm)}.subscription__title{font-family:var(--font-display);font-size:var(--font-display-md);letter-spacing:var(--ls-display);color:var(--color-white);font-weight:700;line-height:var(--lh-tight);margin-bottom:var(--space-md)}.subscription__sub{font-size:var(--font-base);color:var(--color-muted);max-width:460px;line-height:var(--lh-normal);margin:0 auto}.subscription__plan{gap:var(--space-md);padding:var(--space-2xl) var(--space-xl);background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-card);cursor:pointer;transition:transform var(--duration-fast) var(--ease-spring), border-color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard);grid-template-columns:28px 1fr auto;align-items:center;display:grid;position:relative}.subscription__plan:hover,.subscription__plan:focus-visible{background:var(--color-bg-card-hover);outline:none}.subscription__plan--current{border-color:var(--color-accent);background:var(--tone-accent-soft);box-shadow:var(--shadow-sm)}.subscription__plan-price{font-family:var(--font-display);font-size:var(--font-display-md);color:var(--color-white);margin:var(--space-sm) 0 var(--space-xs);letter-spacing:var(--ls-display);font-weight:700}.subscription__radio{border-radius:var(--radius-pill);border:2px solid var(--color-hairline);width:22px;height:22px;transition:border-color var(--duration-fast) var(--ease-standard);place-items:center;display:grid}.subscription__radio--selected{border-color:var(--color-accent)}.subscription__radio-dot{border-radius:var(--radius-pill);background:var(--color-accent);width:10px;height:10px}.subscription__plan-label{font-family:var(--font-display);color:var(--color-white);font-weight:700}.subscription__plan-sub{font-size:var(--font-sm);color:var(--color-muted);margin-top:var(--space-xs)}.subscription__best-value{margin-left:var(--space-sm)}.subscription__feature{gap:var(--space-sm);font-size:var(--font-sm);color:var(--color-white);line-height:var(--lh-normal);padding:var(--space-xs) 0;display:flex}.subscription__feature-icon{color:var(--color-green);font-weight:700}.subscription__feature-text{flex:1}.subscription__cta{width:100%;margin-top:var(--space-xl)}.subscription__cancel-text{text-align:center;font-size:var(--font-xs);color:var(--color-muted);margin-top:var(--space-sm)}.subscription__current{margin-top:var(--space-3xl)}.subscription__current-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin:0 var(--space-xs) var(--space-sm)}.subscription__current-row{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.subscription__current-name{color:var(--color-white);font-weight:600}.subscription__current-info{font-size:var(--font-sm);color:var(--color-muted);margin-top:var(--space-xs)}@media (width>=1024px){.subscription{padding:0}.subscription__title{font-size:var(--font-display-lg)}}@media (width>=1024px){.legal{padding:0}.legal__title{font-size:var(--font-display-md)}.legal__content{font-size:var(--font-md)}.legal__contact-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.legal{padding:0}.legal__title{font-size:var(--font-display-md)}.legal__content{font-size:var(--font-md)}.legal__contact-grid{grid-template-columns:repeat(2,1fr)}}.legal{padding:0 var(--content-padding-mobile,20px) 40px;max-width:720px;margin:0 auto}.legal__header{border-bottom:1px solid var(--color-hairline);margin-bottom:24px;padding:24px 0 20px}.legal__title{font-family:var(--font-display);font-size:var(--font-display-sm);letter-spacing:var(--ls-display);color:var(--color-white);font-weight:700;line-height:var(--lh-tight)}.legal__updated{font-size:var(--font-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:8px}.legal__content{font-size:var(--font-base);line-height:var(--lh-relaxed);color:#ffffffc7}.legal__content h2{font-family:var(--font-display);font-size:var(--font-xl);color:var(--color-white);letter-spacing:var(--ls-tight);margin:28px 0 12px;font-weight:700}.legal__content h3{font-size:var(--font-md);color:var(--color-white);margin:20px 0 8px;font-weight:600}.legal__content p{margin-bottom:14px}.legal__content ul,.legal__content ol{margin:0 0 14px 20px;padding-left:4px}.legal__content li{line-height:var(--lh-relaxed);margin-bottom:6px}.legal__content a{color:var(--color-accent-light);text-decoration:none}.legal__content a:hover{text-decoration:underline}.legal__content strong{color:var(--color-white);font-weight:600}.legal__content code{background:#ffffff0f;border-radius:4px;padding:2px 6px;font-family:SF Mono,Menlo,monospace;font-size:.9em}.legal__contact-grid{gap:12px;margin-bottom:24px;display:grid}.legal__contact-card{background:var(--color-bg-card);border:1px solid var(--color-hairline);border-radius:var(--radius-md);padding:16px 18px}.legal__contact-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin-bottom:4px}.legal__contact-value{font-size:var(--font-base);color:var(--color-white);font-weight:600}@media (width>=1024px){.legal{padding:0}.legal__title{font-size:var(--font-display-md)}.legal__content{font-size:var(--font-md)}.legal__contact-grid{grid-template-columns:repeat(2,1fr)}}.legal__date{font-size:var(--font-xs);color:var(--color-muted);text-transform:uppercase;letter-spacing:.08em;margin:12px 0 8px}.legal__intro{font-size:var(--font-base);color:var(--color-muted);line-height:var(--lh-relaxed);margin-bottom:24px}.legal__section{margin-bottom:28px}.legal__section-title{font-family:var(--font-display);font-size:var(--font-lg);color:var(--color-white);letter-spacing:var(--ls-tight);margin:24px 0 10px;font-weight:700}.legal__section-body{font-size:var(--font-base);color:#ffffffc7;line-height:var(--lh-relaxed)}.legal__highlight{background:var(--tone-teal-soft,#4ecdc414);border-left:3px solid var(--color-teal);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:#ffffffd9;margin:14px 0;padding:12px 16px}.legal__contact{border-top:1px solid var(--color-hairline);color:#ffffffc7;line-height:var(--lh-relaxed);margin-top:32px;padding-top:24px}.legal__contact a{color:var(--color-accent-light,var(--color-teal));text-decoration:none}.legal__contact a:hover{text-decoration:underline}.profile{padding:0 var(--content-padding-mobile,20px) calc(var(--nav-height) + var(--space-2xl))}.profile__hero{align-items:center;gap:var(--space-md);padding:var(--space-3xl) 0;text-align:center;flex-direction:column;display:flex}.profile__avatar{border-radius:var(--radius-pill);background:var(--color-accent-gradient);width:96px;height:96px;color:var(--color-white);font-family:var(--font-display);font-weight:700;font-size:var(--font-3xl);box-shadow:var(--shadow-md);place-items:center;display:grid}.profile__name{font-family:var(--font-display);font-size:var(--font-2xl);color:var(--color-white);letter-spacing:var(--ls-tight);font-weight:700}.profile__email{font-size:var(--font-sm);color:var(--color-muted)}.profile__section-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-muted);margin:var(--space-sm) var(--space-xs) 0}.profile__loading{padding:var(--space-4xl) 0;place-items:center;display:grid}.profile__spinner{border:2px solid var(--color-hairline);border-top-color:var(--color-accent);border-radius:var(--radius-pill);width:28px;height:28px;animation:.8s linear infinite app-spin}.profile__spinner--small{width:16px;height:16px}.profile__error-card{border-color:#ff6b6b4d}.profile__error{color:var(--color-coral);font-size:var(--font-sm);text-align:center;padding:var(--space-md)}.profile__avatar-card{padding:var(--space-lg)}.profile__avatar-status{align-items:center;gap:var(--space-sm);margin-top:var(--space-md);font-size:var(--font-sm);color:var(--color-muted);display:flex}.profile__avatar-status--success{color:var(--color-green)}.profile__avatar-status--error{color:var(--color-coral)}.profile__row{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--color-hairline);display:flex}.profile__row:last-child{border-bottom:none}.profile__row--editing{flex-direction:column;align-items:stretch}.profile__row-label{font-size:var(--font-sm);color:var(--color-muted)}.profile__row-value{font-size:var(--font-base);color:var(--color-white);align-items:center;gap:var(--space-xs);display:inline-flex}.profile__row-value--editable{cursor:pointer;border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);margin:calc(var(--space-xs) * -1) calc(var(--space-sm) * -1);transition:background var(--duration-fast) var(--ease-standard)}.profile__row-value--editable:hover,.profile__row-value--editable:focus-visible{background:var(--color-bg-card-hover);outline:none}.profile__edit-icon{font-size:var(--font-sm);color:var(--color-muted)}.profile__edit-group{gap:var(--space-sm);flex-direction:column;width:100%;display:flex}.profile__edit-actions{gap:var(--space-sm);display:flex}.profile__save-error{color:var(--color-coral);font-size:var(--font-sm)}@media (width>=1024px){.profile{max-width:720px;margin:0 auto;padding:0}.profile__hero{padding:var(--space-4xl) 0}}.join-family{min-height:100vh;padding:0 20px 100px;animation:.3s fadeIn}.join-family__prompt{text-align:center;color:var(--color-muted);margin-bottom:16px;font-size:14px}.join-family__form{flex-direction:column;gap:12px;padding:4px 0;display:flex}.join-family__error{color:var(--color-coral);text-align:center;margin:0;font-size:13px}.join-family__preview{text-align:center;padding:8px 0}.join-family__preview-emoji{margin-bottom:8px;font-size:42px}.join-family__preview-name{margin-bottom:4px;font-size:20px;font-weight:700}.join-family__preview-count{color:var(--color-muted);margin-bottom:20px;font-size:13px}.join-family__actions{flex-direction:column;gap:10px;display:flex}.join-family__cancel{color:var(--color-muted);cursor:pointer;font-size:14px;font-family:var(--font-family);background:0 0;border:none;padding:10px}.join-family__cancel:hover{color:var(--color-white)}.join-family__success{text-align:center;padding:8px 0}.join-family__success-emoji{margin-bottom:12px;font-size:48px}.join-family__success-title{color:var(--color-green);margin-bottom:4px;font-size:20px;font-weight:700}.join-family__success-detail{color:var(--color-muted);margin-bottom:20px;font-size:14px}.status-screen{background-color:var(--color-bg);color:var(--color-text);min-height:100vh;font-family:var(--font-body);flex-direction:column;display:flex}.status-screen__header{justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-lg);border-bottom:1px solid var(--color-border);display:flex}.status-screen__brand{align-items:center;gap:var(--space-sm);color:var(--color-text);text-decoration:none;display:inline-flex}.status-screen__logo{width:28px;height:28px}.status-screen__wordmark{font-family:var(--font-display);font-size:var(--font-lg);letter-spacing:-.01em;font-weight:600}.status-screen__back-link{color:var(--color-muted);font-size:var(--font-sm);transition:color var(--duration-fast) var(--ease-standard);text-decoration:none}.status-screen__back-link:hover,.status-screen__back-link:focus-visible{color:var(--color-text)}.status-screen__body{width:100%;max-width:720px;padding:var(--space-3xl) var(--space-lg) var(--space-4xl);margin:0 auto}.status-screen__title{font-family:var(--font-display);font-size:var(--font-3xl);margin:0 0 var(--space-sm);letter-spacing:-.01em;font-weight:600}.status-screen__lede{margin:0 0 var(--space-xl);color:var(--color-text-secondary);font-size:var(--font-base)}.status-screen__banner{border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);font-weight:600;font-size:var(--font-base);border:1px solid var(--color-border);background-color:var(--color-bg-card)}.status-screen__banner--ok{background-color:color-mix(in srgb, var(--color-green) 12%, transparent);border-color:var(--color-green);color:var(--color-green)}.status-screen__banner--partial{background-color:color-mix(in srgb, var(--color-gold) 12%, transparent);border-color:var(--color-gold);color:var(--color-gold)}.status-screen__banner--major{background-color:color-mix(in srgb, var(--color-coral) 12%, transparent);border-color:var(--color-coral);color:var(--color-coral)}.status-screen__banner--unknown{background-color:var(--color-bg-card);border-color:var(--color-border);color:var(--color-text-secondary)}.status-screen__section-heading{font-family:var(--font-label);text-transform:uppercase;letter-spacing:var(--label-tracking);font-size:var(--font-xs);color:var(--color-text-tertiary);margin:var(--space-3xl) 0 var(--space-md);font-weight:600}.status-screen__components{border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-card);margin:0;padding:0;list-style:none;overflow:hidden}.status-screen__row{padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.status-screen__row:last-child{border-bottom:0}.status-screen__row-head{justify-content:space-between;align-items:baseline;gap:var(--space-md);display:flex}.status-screen__row-label{font-size:var(--font-base);color:var(--color-text);font-weight:500}.status-screen__pill{font-family:var(--font-label);text-transform:uppercase;letter-spacing:var(--label-tracking);font-size:var(--font-xs);font-weight:600}.status-screen__pill--ok{color:var(--color-green)}.status-screen__pill--fail{color:var(--color-coral)}.status-screen__pill--unknown{color:var(--color-text-tertiary)}.status-screen__histogram{margin-top:var(--space-md);align-items:flex-end;gap:1px;padding-bottom:2px;display:flex;overflow-x:auto}.status-screen__cell{border-radius:1px;flex:none;width:6px;height:24px;display:block}@media (width>=640px){.status-screen__cell{width:7px;height:28px}}.status-screen__cell--ok{background-color:var(--color-green)}.status-screen__cell--warn{background-color:var(--color-gold)}.status-screen__cell--fail{background-color:var(--color-coral)}.status-screen__cell--none{background-color:var(--color-dimmed)}.status-screen__row-foot{margin:var(--space-sm) 0 0;color:var(--color-text-tertiary);font-size:var(--font-xs)}.status-screen__incidents{padding:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-card);color:var(--color-text-secondary);font-size:var(--font-base);margin:0}.status-screen__footer{margin-top:var(--space-4xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border);align-items:center;gap:var(--space-lg);display:flex}.status-screen__footer-link{color:var(--color-text-secondary);font-size:var(--font-sm);text-decoration:none}.status-screen__footer-link:hover,.status-screen__footer-link:focus-visible{color:var(--color-text);text-decoration:underline}.child-login-link{padding:var(--space-4xl) var(--space-2xl);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;animation:.4s fadeIn;display:flex;position:relative;overflow:hidden}.child-login-link__back{top:calc(env(safe-area-inset-top,0px) + var(--space-md));left:var(--space-md);width:44px;height:44px;color:var(--color-muted);cursor:pointer;border-radius:var(--radius-pill);transition:color var(--duration-fast) var(--ease-standard), background var(--duration-fast) var(--ease-standard);z-index:1;background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.child-login-link__back:hover{color:var(--color-white);background:color-mix(in srgb, var(--color-white) 6%, transparent)}.child-login-link__back:active{transform:scale(.92)}.child-login-link__glow{background:radial-gradient(circle, color-mix(in srgb, var(--color-purple) 18%, transparent) 0%, transparent 65%);pointer-events:none;filter:blur(20px);border-radius:50%;width:360px;height:360px;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.child-login-link__loading{justify-content:center;align-items:center;min-height:200px;display:flex}.child-login-link__welcome{text-align:center;animation:scaleIn .7s var(--ease-spring) both;flex-direction:column;align-items:center;display:flex;position:relative}.child-login-link__name{font-family:var(--font-display);font-size:var(--font-2xl);margin:var(--space-xl) 0 var(--space-sm);font-weight:800}.child-login-link__hint{color:var(--color-muted);font-size:var(--font-md);margin:0 0 var(--space-3xl)}.child-login-link__error{color:var(--color-coral);font-size:var(--font-sm);text-align:center;margin:var(--space-lg) 0 0}.child-login-link__attempts{color:var(--color-muted)}.child-login-link__countdown{color:var(--color-gold);font-size:var(--font-md);margin:var(--space-md) 0 0;font-weight:600}.child-login-link__verifying{margin-top:var(--space-lg)}.child-login-link__expired{text-align:center;flex-direction:column;align-items:center;display:flex;position:relative}.child-login-link__logo{margin-bottom:var(--space-xl)}.child-login-link__expired-title{font-family:var(--font-display);font-size:var(--font-xl);margin:0 0 var(--space-md);font-weight:700}.child-login-link__expired-text{color:var(--color-muted);font-size:var(--font-md);margin:0 0 var(--space-2xl);max-width:280px;line-height:1.5}.child-login-link__alt{color:var(--color-muted);font-size:var(--font-sm);cursor:pointer;margin-top:var(--space-4xl);font-family:var(--font-family);transition:color var(--duration-fast) ease;background:0 0;border:none}.child-login-link__alt:hover{color:var(--color-accent)}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.invite-notification__container{width:100%;max-width:var(--max-width);z-index:calc(var(--z-modal) + 10);gap:var(--space-sm);padding:var(--space-md) var(--space-lg);pointer-events:none;flex-direction:column;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%)}.invite-notification{background:var(--color-bg-card);border:1px solid color-mix(in srgb, var(--color-teal) 25%, transparent);border-left:3px solid var(--notif-game-color,var(--color-teal));border-radius:var(--radius-round);box-shadow:var(--shadow-lg), 0 0 20px #4ecdc426;padding:var(--space-md) var(--space-lg);pointer-events:auto;animation:slideDown .4s var(--ease-spring) both;animation-delay:calc(var(--notif-index,0) * 80ms);position:relative;overflow:hidden}.invite-notification--declining{animation:slideUp .3s var(--ease-standard) forwards}.invite-notification--cancelled{border-color:color-mix(in srgb, var(--color-coral) 25%, transparent);border-left-color:var(--color-coral);box-shadow:var(--shadow-lg), 0 0 20px #ff6b6b1a}.invite-notification__content{align-items:center;gap:var(--space-md);display:flex}.invite-notification__avatar{flex-shrink:0}.invite-notification__text{flex:1;min-width:0}.invite-notification__message{font-size:var(--font-sm);color:var(--color-white);line-height:1.4}.invite-notification__message strong{font-weight:700}.invite-notification__message--cancelled{color:var(--color-coral);font-style:italic}.invite-notification__actions{gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.invite-notification__btn{font-family:var(--font-display);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px;min-height:48px;padding:var(--space-sm) var(--space-xl);border-radius:var(--radius-pill);cursor:pointer;transition:transform var(--duration-fast) ease, opacity var(--duration-fast) ease;border:none;font-weight:700}.invite-notification__btn:hover{transform:scale(1.05)}.invite-notification__btn:active{transform:scale(.97)}.invite-notification__btn--join{background:var(--color-teal);color:var(--color-bg)}.invite-notification__btn--decline{border:1px solid var(--color-border);color:var(--color-muted);background:0 0}.invite-notification__btn--decline:hover{color:var(--color-white);border-color:var(--color-dimmed)}.invite-notification__timer-bar{background:var(--color-green);height:2px;animation:countdownBar var(--timer-duration,300s) linear forwards;position:absolute;bottom:0;left:0}.invite-notification__timer-bar--urgent{background:var(--color-coral)}@keyframes countdownBar{0%{width:100%}to{width:0%}}@media (width<=479px){.invite-notification__actions{flex-direction:column}.invite-notification__btn{width:100%}}.early-preview{z-index:100;background:color-mix(in srgb, var(--color-gold) 12%, var(--color-surface-container-high));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;min-height:32px;max-height:36px;font-size:var(--font-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--color-gold);-webkit-user-select:none;user-select:none;border-bottom:1px solid #ffffff0f;justify-content:center;align-items:center;gap:.5rem;padding:0 1rem;display:flex;position:sticky;top:0;left:0;right:0}.early-preview__icon{opacity:.9;align-items:center;font-size:.85em;display:inline-flex}.early-preview__text{white-space:nowrap;text-overflow:ellipsis;align-items:center;font-weight:500;display:inline-flex;overflow:hidden}.early-preview__cta{color:var(--color-gold);font:inherit;letter-spacing:inherit;text-underline-offset:3px;white-space:nowrap;background:0 0;border:none;align-items:center;margin-left:.5rem;padding:0;font-weight:600;line-height:1;text-decoration:underline;transition:color .15s;display:inline-flex}.early-preview__cta:hover,.early-preview__cta:focus-visible{color:var(--color-white,#fff);outline:none}.early-preview__dismiss{width:24px;height:24px;color:var(--color-gold);cursor:pointer;opacity:.55;letter-spacing:0;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:18px;line-height:1;transition:opacity .15s,background-color .15s;display:inline-flex;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.early-preview__dismiss:hover,.early-preview__dismiss:focus-visible{opacity:1;background-color:#ffffff0f;outline:none}.early-preview__dismiss:focus-visible{box-shadow:0 0 0 2px color-mix(in srgb, var(--color-gold) 40%, transparent)}@media (width<=480px){.early-preview{letter-spacing:.05em;padding:0 .75rem}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{touch-action:manipulation;-webkit-tap-highlight-color:transparent}body{color:#fafafa;background:#0d0b14;min-height:100dvh;font-family:Outfit,-apple-system,sans-serif}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes pulseGlow{0%,to{opacity:.15;transform:translate(-50%)scale(1)}50%{opacity:.25;transform:translate(-50%)scale(1.15)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.screen-enter{animation:fadeIn .3s var(--ease-spring) both}input::placeholder,textarea::placeholder{color:#ffffff40}::-webkit-scrollbar{display:none}select option{color:#fafafa;background:#1a1528}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:4px}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}button,[role=button],a,input,select,textarea{min-height:44px}.app-shell{color:#fafafa;background:#0d0b14;min-height:100dvh;margin:0 auto;font-family:Outfit,-apple-system,sans-serif;position:relative;overflow-x:hidden}.app-shell:after{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 25% 0,#e8785e12 0%,#0000 50%),radial-gradient(at 75% 5%,#4ecdc40d 0%,#0000 45%),radial-gradient(at 50% 95%,#a78bfa0d 0%,#0000 40%);width:100%;max-width:430px;height:100%;position:fixed;top:0;left:50%;transform:translate(-50%)}.app-shell>*{z-index:1;position:relative}@media (width>=768px){.app-shell,.app-shell:after{max-width:720px}}@media (width>=1024px){.app-shell,.app-shell:after{max-width:960px}}@media (width>=1280px){.app-shell,.app-shell:after{max-width:1100px}}.app-loading{justify-content:center;align-items:center;display:flex}.app-loading__content{align-items:center;gap:var(--space-xl);flex-direction:column;display:flex}.app-loading__logo{opacity:.9;width:64px;height:64px}.app-loading__logo--spin{animation:1.2s linear infinite app-spin}.app-loading__spinner{border:2px solid var(--color-dimmed);border-top-color:var(--color-accent);border-radius:50%;width:24px;height:24px;animation:.8s linear infinite app-spin}@keyframes app-spin{to{transform:rotate(360deg)}}
