@font-face{font-family:Bowlby One;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/bowlby-one-400-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Manrope;font-style:normal;font-weight:200 800;font-display:swap;src:url(/fonts/manrope-variable-latin.woff2) format("woff2-variations"),url(/fonts/manrope-variable-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{color-scheme:dark;--space-2xs: .25rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--font-display: "Bowlby One", "Bowlby One SC", system-ui, sans-serif;--font-body: "Manrope", system-ui, -apple-system, sans-serif;--bg: oklch(.16 .025 280);--bg-deeper: oklch(.12 .02 280);--surface: oklch(.22 .04 280);--surface-2: oklch(.27 .05 280);--line: oklch(.34 .04 280 / .6);--text: oklch(.96 .015 80);--text-muted: oklch(.72 .02 280);--text-faint: oklch(.55 .02 280);--accent: oklch(.74 .2 8);--accent-strong: oklch(.66 .24 8);--accent-soft: oklch(.74 .2 8 / .18);--accent-glow: oklch(.74 .2 8 / .45);--lime: oklch(.85 .18 130);--amber: oklch(.82 .16 80);--danger: oklch(.7 .21 25);--felt: oklch(.5 .13 145);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--ease-out: cubic-bezier(.22, .61, .36, 1);--ease-quint: cubic-bezier(.22, 1, .36, 1);--shadow-card: 0 1px 0 oklch(1 0 0 / .05) inset, 0 8px 24px -12px oklch(0 0 0 / .6);--shadow-glow: 0 0 0 1.5px var(--accent), 0 0 24px -2px var(--accent-glow);--shadow-overlay: 0 30px 80px -20px oklch(0 0 0 / .85), 0 0 0 1px var(--line) inset}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background:radial-gradient(ellipse at top,oklch(.22 .06 290 / .6),transparent 60%),radial-gradient(ellipse at bottom,oklch(.18 .05 5 / .4),transparent 65%),var(--bg);background-attachment:fixed;min-height:100vh}kbd{display:inline-block;font-family:var(--font-body);font-size:.75rem;font-weight:700;padding:.05rem .45rem;border-radius:4px;background:var(--surface);border:1px solid var(--line);color:var(--text);letter-spacing:.02em}button{font-family:inherit;cursor:pointer}.app{display:grid;grid-template-rows:auto auto 1fr auto auto;gap:var(--space-md);padding:clamp(var(--space-md),2vw,var(--space-xl));max-width:1320px;margin:0 auto;min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding-block:var(--space-xs)}.brand{display:flex;align-items:center;gap:var(--space-sm)}.brand-mark{width:clamp(36px,4vw,48px);height:clamp(36px,4vw,48px);flex-shrink:0;transform:rotate(-12deg);filter:drop-shadow(0 4px 8px oklch(0 0 0 / .5));transition:transform .24s var(--ease-quint)}.topbar:hover .brand-mark{transform:rotate(-4deg) scale(1.04)}.brand-title{font-family:var(--font-display);font-weight:400;font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.01em;margin:0;line-height:.95;color:var(--text);text-shadow:0 2px 0 oklch(0 0 0 / .5)}.brand-eight{color:var(--accent);display:inline-block;transform:translateY(.04em)}.version-tag{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);padding:.2rem .6rem;border:1px solid var(--line);border-radius:999px;background:#ffffff05}.players{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--space-md)}.player-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:border-color .18s var(--ease-out),box-shadow .18s var(--ease-out),background .18s var(--ease-out),opacity .22s var(--ease-out),transform .22s var(--ease-quint);opacity:.55}.player-card[data-player=p2]{flex-direction:row-reverse;text-align:right}.player-card[data-active=true]{opacity:1;background:linear-gradient(180deg,#1f2040,#131428);border-color:var(--accent);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.player-meta{display:flex;flex-direction:column;gap:2px;min-width:0}.player-name-row{display:inline-flex;align-items:baseline;gap:var(--space-xs);flex-wrap:nowrap}.player-card[data-player=p2] .player-name-row{flex-direction:row-reverse}.player-name{font-weight:700;font-size:1rem;letter-spacing:-.01em;color:var(--text)}.player-card[data-active=false] .player-name,.player-card:not([data-active=true]) .player-name{color:var(--text-muted)}.player-target{font-size:.78rem;font-weight:500;letter-spacing:.04em;color:var(--text-faint);text-transform:lowercase;font-variant-numeric:tabular-nums}.player-card[data-active=true] .player-target{color:var(--text-muted)}.player-icon{--icon-size: 36px;width:var(--icon-size);height:var(--icon-size);flex-shrink:0;display:grid;place-items:center;filter:drop-shadow(0 2px 4px oklch(0 0 0 / .4))}.player-icon svg{display:block;width:100%;height:100%}.icon-placeholder{display:block;width:100%;height:100%;border-radius:50%;border:1.5px dashed var(--line);background:#ffffff05}.player-pocketed{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px;min-height:18px}.player-pocketed svg{display:block;filter:drop-shadow(0 1px 1px oklch(0 0 0 / .4))}.player-card[data-player=p2] .player-pocketed{justify-content:flex-end}.versus{font-family:var(--font-display);font-weight:400;font-size:1.1rem;color:var(--text-faint);letter-spacing:.05em;text-transform:lowercase;padding-inline:var(--space-md)}.table-frame{position:relative;display:grid;place-items:center;padding:var(--space-md);background:radial-gradient(ellipse at center,oklch(.2 .04 280) 0%,transparent 70%);border-radius:var(--radius-xl)}#game{display:block;width:100%;max-width:1180px;height:auto;aspect-ratio:1116 / 608;border-radius:var(--radius-md);cursor:crosshair;box-shadow:0 1px #ffffff0f inset,0 30px 60px -20px #000000b3,0 0 0 1px #2c63304d}.app[data-bih=true] #game{cursor:copy}.english-frame{display:grid;place-items:center;padding:var(--space-sm) 0 0 0}#english{display:block;width:108px;height:108px;cursor:crosshair;touch-action:none;filter:drop-shadow(0 4px 10px oklch(0 0 0 / .45))}.status-bar{min-height:2.5rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:var(--space-sm)}.status{display:inline-flex;align-items:center;gap:.55rem;margin:0;padding:.45rem .95rem;font-size:.92rem;font-weight:600;letter-spacing:.005em;border-radius:999px;background:var(--surface);border:1px solid var(--line);transform:translateY(8px);opacity:0;pointer-events:none;transition:opacity .22s var(--ease-out),transform .32s var(--ease-quint)}.status[data-shown=true]{opacity:1;transform:translateY(0)}.status-icon{display:inline-grid;place-items:center;width:1.3em;height:1.3em;border-radius:50%;font-size:.85em}.status-label{text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;font-weight:800;padding-right:.25rem;border-right:1px solid currentColor;margin-right:.15rem;opacity:.7}.status-text{color:var(--text);font-weight:500}.status-foul{background:color-mix(in oklch,var(--danger) 22%,var(--surface));border-color:color-mix(in oklch,var(--danger) 60%,transparent);color:var(--danger)}.status-foul .status-icon{background:color-mix(in oklch,var(--danger) 30%,transparent)}.status-bih{background:color-mix(in oklch,var(--amber) 22%,var(--surface));border-color:color-mix(in oklch,var(--amber) 60%,transparent);color:var(--amber)}.status-bih .status-icon{background:color-mix(in oklch,var(--amber) 28%,transparent)}.footer{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding-block:var(--space-xs);font-size:.85rem;color:var(--text-faint)}.footer-dot{color:var(--text-faint);opacity:.5}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#010003b3;backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);z-index:100;opacity:0;pointer-events:none;transition:opacity .28s var(--ease-out)}.overlay[data-shown=true]{opacity:1;pointer-events:auto}.overlay-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-2xl) var(--space-3xl);background:linear-gradient(180deg,#1b1c36,#0e0f23);border-radius:var(--radius-xl);box-shadow:var(--shadow-overlay);transform:translateY(16px) scale(.96);transition:transform .36s var(--ease-quint)}.overlay[data-shown=true] .overlay-card{transform:translateY(0) scale(1)}.winner-eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}.winner-name{font-family:var(--font-display);font-weight:400;font-size:clamp(2.4rem,6vw,3.6rem);letter-spacing:-.02em;margin:0;color:var(--text);text-shadow:0 4px 0 oklch(0 0 0 / .5)}.btn-primary{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:.85rem 2rem;font-family:var(--font-body);font-weight:700;font-size:.95rem;letter-spacing:.02em;color:#050303;background:var(--accent);border-radius:999px;box-shadow:0 1px #ffffff73 inset,0 -1px #00000040 inset,0 8px 24px -8px var(--accent-glow);transition:transform .16s var(--ease-out),box-shadow .22s var(--ease-out),background .22s var(--ease-out)}.btn-primary:hover{background:var(--accent-strong);transform:translateY(-1px);box-shadow:0 1px #ffffff8c inset,0 -1px #00000040 inset,0 12px 30px -6px var(--accent-glow)}.btn-primary:active{transform:translateY(0)}.btn-primary:focus-visible{outline:none;box-shadow:0 0 0 3px var(--bg),0 0 0 5.5px var(--accent),0 8px 24px -8px var(--accent-glow)}.lobby-card{min-width:320px;max-width:400px}.lobby-title{font-family:var(--font-display);font-weight:400;font-size:2rem;letter-spacing:-.02em;margin:0;color:var(--text)}.lobby-field{display:flex;flex-direction:column;gap:.35rem;width:100%}.lobby-field label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}.lobby-field input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid oklch(.35 .03 280);padding:.7rem 1rem;font-family:var(--font-body);font-size:.95rem;font-weight:500;color:var(--text);background:#080811;border-radius:var(--radius-md);outline:none;transition:border-color .18s var(--ease-out)}.lobby-field input:focus{border-color:var(--accent)}.lobby-field input::placeholder{color:var(--text-faint);opacity:.6}.lobby-status{margin:0;font-size:.9rem;color:var(--text-faint);text-align:center}.lobby-code-row{display:flex;align-items:center;gap:var(--space-sm)}.lobby-code{font-family:var(--font-display);font-size:1.8rem;letter-spacing:.15em;color:var(--accent)}.btn-secondary{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1.5px solid oklch(.4 .03 280);padding:.85rem 2rem;font-family:var(--font-body);font-weight:700;font-size:.95rem;letter-spacing:.02em;color:var(--text);background:transparent;border-radius:999px;transition:border-color .18s var(--ease-out),background .18s var(--ease-out);cursor:pointer}.btn-secondary:hover{border-color:#6e7083;background:#14151f}.btn-small{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid oklch(.4 .03 280);padding:.4rem .8rem;font-family:var(--font-body);font-weight:600;font-size:.78rem;color:var(--text);background:#10111a;border-radius:var(--radius-md);cursor:pointer;transition:background .15s var(--ease-out)}.btn-small:hover{background:#1c1e2d}.lobby-error{margin:0;font-size:.85rem;font-weight:600;color:var(--danger);text-align:center;display:none}.lobby-error[data-shown=true]{display:block}#lobby-menu,#lobby-waiting,#lobby-join,#lobby-reconnecting{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}#lobby-waiting[data-shown=false],#lobby-join[data-shown=false],#lobby-reconnecting[data-shown=false]{display:none}.turn-timer{font-variant-numeric:tabular-nums;font-feature-settings:"tnum";font-weight:700;font-size:.78rem;letter-spacing:.04em;color:var(--accent);background:color-mix(in oklch,var(--accent) 14%,transparent);border:1px solid color-mix(in oklch,var(--accent) 40%,transparent);border-radius:999px;padding:.1rem .55rem;line-height:1.4;min-width:3ch;text-align:center;display:none;opacity:.85;transition:color .2s var(--ease-out),background .2s var(--ease-out),border-color .2s var(--ease-out),opacity .2s var(--ease-out)}.turn-timer[data-shown=true]{display:inline-block}.turn-timer[data-urgent=true]{color:#f7f1e7;background:color-mix(in oklch,var(--danger) 35%,transparent);border-color:color-mix(in oklch,var(--danger) 70%,transparent);opacity:1;animation:turn-timer-pulse .9s var(--ease-out) infinite}@keyframes turn-timer-pulse{0%,to{box-shadow:0 0 color-mix(in oklch,var(--danger) 0%,transparent)}50%{box-shadow:0 0 0 4px color-mix(in oklch,var(--danger) 30%,transparent)}}.player-card[data-connected=false]{opacity:.45;border-color:color-mix(in oklch,var(--text-faint) 55%,transparent);box-shadow:var(--shadow-card);animation:card-disconnect-pulse 1.6s var(--ease-out) infinite}.player-card[data-connected=false][data-active=true]{background:var(--surface);transform:none}@keyframes card-disconnect-pulse{0%,to{box-shadow:0 0 #6f717d00}50%{box-shadow:0 0 0 4px #6f717d59}}.connection-status{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--danger);margin-right:.3rem;vertical-align:middle}.connection-status[data-state=connected]{background:#4cc157}.status-grace{background:color-mix(in oklch,var(--amber) 22%,var(--surface));border-color:color-mix(in oklch,var(--amber) 60%,transparent);color:var(--amber)}.status-grace .status-icon{background:color-mix(in oklch,var(--amber) 30%,transparent)}.status-grace .status-grace-time{font-family:var(--font-display);font-weight:400;font-size:.95rem;letter-spacing:.04em;color:var(--text);margin-left:.4rem;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.status-grace[data-urgent=true]{background:color-mix(in oklch,var(--danger) 28%,var(--surface));border-color:color-mix(in oklch,var(--danger) 65%,transparent);color:var(--danger)}.status-grace[data-urgent=true] .status-icon{background:color-mix(in oklch,var(--danger) 32%,transparent)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}@media(max-width:720px){.app{gap:var(--space-sm);padding:var(--space-sm)}.player-card{padding:var(--space-xs) var(--space-sm)}.player-icon{--icon-size: 28px}.player-name{font-size:.92rem}.versus{font-size:.95rem;padding-inline:var(--space-xs)}.footer{font-size:.78rem;flex-wrap:wrap}}
