/*! tailwindcss v4.3.1 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-outline-style:solid}}}@layer theme{:root,:host{--radius-sm:.25rem;--radius-md:.375rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1)}}@layer base,components;@layer utilities{.fixed{position:fixed}.block{display:block}.hidden{display:none}.table{display:table}.text-center{text-align:center}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--surface:#fff;--surface-2:#f5f5f7;--hover:#f1f1f4;--border:#e6e6ea;--foreground:#18181b;--muted-foreground:#6b7280;--primary:#f5c542;--primary-foreground:#1c1917;--primary-hover:#eab308;--primary-soft:#f5c54224;--primary-soft-2:#f5c54242;--primary-border:#f5c54280;--ring:#f5c54273;--red:#e11d48;--paper:#fff;--ink:#1c1c1f;--radius:14px;--radius-md:9px;--radius-sm:7px;--shadow-sm:0 1px 2px #1018280f, 0 1px 3px #1018281a;--shadow-md:0 6px 18px #1018281f;--shadow-lg:0 20px 50px #10182838;--shadow-card:0 2px 8px #141e3238;--felt:radial-gradient(circle at 50% 16%, #1f8a52 0%, #0c3f26 72%);--felt-text:#fff;--felt-text-soft:#ffffffb8;--felt-text-faint:#ffffff80;--felt-line:#ffffff24;--glass-bg:#00000057;--glass-border:#ffffff1f;--glass-field-bg:#ffffff14;--glass-field-border:#ffffff29;--topbar-bg:#00000042;--topbar-border:#ffffff1a;--chip-btn-bg:#ffffff0f;--chip-btn-border:#ffffff26;--chip-btn-hover:#ffffff24}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{height:100%}body{font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--felt);color:var(--foreground);min-height:100dvh;font-family:Inter,Sarabun,-apple-system,Segoe UI,system-ui,sans-serif;overflow-x:hidden}.screen{flex-direction:column;min-height:100dvh;display:flex;position:relative}.hidden{display:none!important}input{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);width:100%;min-height:2.6rem;color:var(--foreground);padding:.625rem .875rem;font-family:inherit;font-size:.95rem;line-height:1.3;transition:border-color .15s,box-shadow .15s}input::placeholder{color:var(--muted-foreground)}input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring);outline:none}button{border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;background:var(--surface);min-height:2.5rem;color:var(--foreground);justify-content:center;align-items:center;gap:6px;padding:.55rem 1rem;font-family:inherit;font-size:.875rem;font-weight:600;line-height:1.2;transition:background .15s,border-color .15s,box-shadow .15s,transform 50ms;display:inline-flex}button:hover{background:var(--hover)}button:active{transform:scale(.98)}button:focus-visible{box-shadow:0 0 0 3px var(--ring);outline:none}button.primary{color:#3a2c00;text-shadow:0 1px #ffffff4d;background:linear-gradient(#fad760 0%,#f5c542 48%,#e7b01d 100%);border-color:#aa78088c;font-weight:700;box-shadow:inset 0 1px #ffffff80,0 4px 14px #eab3084d}button.primary:hover{background:linear-gradient(#fcdd6e 0%,#f8ca49 48%,#eeb924 100%)}button.primary:active{background:linear-gradient(#efbe39 0%,#e7b01d 100%);box-shadow:inset 0 1px 3px #78500047}button:disabled{opacity:.5;cursor:not-allowed}button:disabled:active{transform:none}svg.lucide{vertical-align:-.125em;stroke-width:2px;flex:none;width:1em;height:1em;display:inline-block}.progress-bar{background:var(--primary);width:0;height:3px;box-shadow:0 0 10px var(--primary), 0 0 4px var(--primary);z-index:2000;opacity:0;pointer-events:none;border-radius:0 2px 2px 0;transition:width .25s,opacity .3s;position:fixed;top:0;left:0}.progress-bar.active{opacity:1}button.loading{cursor:progress}button.loading:disabled{opacity:.92}.spin{transform-origin:50%;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}#lobby-screen{justify-content:center;align-items:center;padding:20px}.card-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-border);border-radius:var(--radius);width:100%;max-width:420px;box-shadow:var(--shadow-lg);color:var(--felt-text);flex-direction:column;gap:12px;padding:30px 26px;display:flex;position:relative}.corner-btn{width:28px;height:28px;min-height:0;color:var(--felt-text-soft);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;text-decoration:none;transition:color .15s;display:inline-flex;position:absolute;top:14px}.corner-btn:hover{color:var(--felt-text);background:0 0}.corner-btn:active{transform:none}.corner-btn:focus-visible{box-shadow:none;outline:none}.corner-tl{left:12px}.corner-tr{right:12px}.corner-install{right:44px}.lang-switch{z-index:2;align-items:center;display:inline-flex;position:absolute;top:14px;left:14px}.lang-switch button{min-height:0;color:var(--felt-text-faint);cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem;font-weight:600;line-height:1;transition:color .15s}.lang-switch button:not(:first-of-type){border-left:1px solid var(--felt-line);margin-left:7px;padding-left:7px}.lang-switch button:hover:not(.active){color:var(--felt-text-soft);background:0 0}.lang-switch button.active{color:var(--felt-text)}.lang-switch button:focus-visible{box-shadow:none;outline:none}.corner-btn svg{width:17px;height:17px}.project-logo{object-fit:cover;width:84px;height:84px;box-shadow:var(--shadow-md);border:1px solid #ffffff26;border-radius:18px;align-self:center;margin-top:14px}.card-panel h1{text-align:center;letter-spacing:-.025em;color:var(--felt-text);font-size:1.85rem;font-weight:800}.card-panel .sub{text-align:center;color:var(--felt-text-soft);margin-bottom:6px;font-size:.92rem}.card-panel input{background:var(--glass-field-bg);border-color:var(--glass-field-border);color:var(--felt-text)}.card-panel input::placeholder{color:var(--felt-text-faint)}.card-panel input:focus{border-color:var(--primary);background:var(--glass-field-bg);box-shadow:0 0 0 3px var(--ring)}.card-panel .ghost-btn{color:var(--felt-text-soft);border-color:var(--glass-field-border);margin-top:2px}.card-panel .ghost-btn:hover{background:var(--chip-btn-hover);color:var(--felt-text)}.divider{color:var(--felt-text-soft);align-items:center;gap:10px;margin:2px 0;font-size:.78rem;display:flex}.divider:before,.divider:after{content:"";background:var(--felt-line);flex:1;height:1px}.input-icon{display:flex;position:relative}.input-icon>svg.lucide{width:18px;height:18px;color:var(--felt-text-faint);pointer-events:none;z-index:1;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-icon input{flex:1;padding-left:42px;padding-right:42px}.input-group{align-items:stretch;display:flex}.input-addon{color:var(--felt-text-soft);border:1px solid var(--glass-field-border);border-radius:var(--radius-md) 0 0 var(--radius-md);background:var(--chip-btn-bg);border-right:none;flex:none;justify-content:center;align-items:center;padding:0 12px;display:inline-flex}.input-addon svg.lucide{width:17px;height:17px}.input-group #code-input{border-left:none;border-right:none;border-radius:0;flex:1;min-width:0}.input-group #join-btn{border-top-left-radius:0;border-bottom-left-radius:0;flex:none}.link-btn{min-height:0;color:var(--felt-text-soft);cursor:pointer;background:0 0;border:none;justify-content:center;align-self:center;align-items:center;gap:5px;margin-top:2px;padding:6px 4px;font-size:.875rem;font-weight:500;text-decoration:none;display:inline-flex}.link-btn:hover{color:var(--felt-text);text-decoration:underline}.install-btn{color:#ffffffe6;background:#ffffff1a;border-color:#ffffff38;align-self:center;margin-top:2px}.install-btn:hover{background:#ffffff2e}#code-input{text-transform:uppercase;text-align:center;letter-spacing:4px;font-size:1.15rem;font-weight:800}#code-input::placeholder{letter-spacing:normal;text-transform:none;font-size:.95rem;font-weight:400}.field{flex-direction:column;gap:6px;display:flex}.field-error{color:#fca5a5;align-items:center;gap:5px;padding-left:2px;font-size:.8rem;font-weight:500;display:flex}.field-error:empty{display:none}.card-panel input[aria-invalid=true]{border-color:var(--red);background:#e11d4814}.card-panel input[aria-invalid=true]:focus{border-color:var(--red);box-shadow:0 0 0 3px #e11d484d}.error{color:var(--red);text-align:center;min-height:1.2em;font-size:.9rem}#topbar{border-bottom:1px solid var(--topbar-border);background:var(--topbar-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);justify-content:space-between;align-items:center;gap:12px;padding:11px 16px;display:flex}.kick-btn{flex:none;min-height:2rem;padding:0 12px;font-size:.82rem}.topbar-actions{align-items:center;gap:8px;display:flex}.icon-btn{width:2.1rem;min-height:2.1rem;color:var(--felt-text-soft);background:var(--chip-btn-bg);border-color:var(--chip-btn-border);flex:none;padding:0}.icon-btn:hover{background:var(--chip-btn-hover);color:var(--felt-text)}.icon-btn svg.lucide{width:1.15em;height:1.15em}.share-box{text-align:center;max-width:360px}.share-sub{color:var(--muted-foreground);margin:2px 0 14px;font-size:.9rem}.share-code{color:var(--foreground);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:7px;min-height:0;margin:0 auto 12px;padding:6px 12px;font-size:1.05rem;display:inline-flex}.share-code:hover{background:var(--hover)}.share-code .lucide{width:.95rem;height:.95rem;color:var(--muted-foreground)}.share-code strong{border-radius:var(--radius-sm);letter-spacing:3px;background:var(--primary-soft);color:var(--primary-foreground);border:1px solid var(--primary-border);margin-left:4px;padding:2px 10px;font-size:1.25rem;font-weight:800;display:inline-block}.share-qr{border-radius:var(--radius-md);border:1px solid var(--border);width:max-content;box-shadow:var(--shadow-sm);background:#fff;justify-content:center;margin:0 auto 14px;padding:12px;display:flex}.share-qr img{width:220px;height:220px;image-rendering:pixelated;display:block}.share-link{border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;gap:8px;width:100%;padding:9px 12px;display:flex}.share-link:hover{background:var(--hover)}.share-url{color:var(--muted-foreground);text-overflow:ellipsis;white-space:nowrap;text-align:left;font-size:.82rem;font-weight:500;overflow:hidden}.share-link svg.lucide{width:1.05em;height:1.05em;color:var(--muted-foreground);flex:none}.modal-box.settings-box{text-align:left;max-width:450px}.settings-list{flex-direction:column;gap:4px;margin-top:6px;display:flex}.settings-group-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted-foreground);align-items:center;gap:6px;margin:12px 2px 2px;font-size:.78rem;font-weight:700;display:flex}.settings-group-label:first-child{margin-top:0}.settings-group-label svg.lucide{width:.95em;height:.95em}.settings-sub-label{color:var(--foreground);align-items:center;gap:6px;margin:8px 2px 2px;font-size:.86rem;font-weight:600;display:flex}.settings-sub-label svg.lucide{width:1em;height:1em;color:var(--muted-foreground)}.settings-tag{text-transform:none;letter-spacing:0;color:var(--primary-foreground);background:var(--primary-soft-2);border-radius:999px;margin-left:auto;padding:1px 8px;font-size:.68rem;font-weight:600}.setting-row{border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.setting-label{align-items:center;gap:8px;font-size:.92rem;font-weight:500;display:flex}.setting-label svg.lucide{width:1.05em;height:1.05em;color:var(--muted-foreground)}.setting-sub{color:var(--muted-foreground);font-size:.82rem;font-weight:400}.setting-row.is-disabled{opacity:.6}.setting-soon{color:var(--muted-foreground);background:var(--hover);border-radius:999px;padding:1px 8px;font-size:.72rem;font-weight:600}.settings-logout{width:100%;min-height:2.7rem;margin-top:16px}.color-picker{position:relative}.color-swatch-btn{border-radius:var(--radius-sm);border:1px solid var(--glass-field-border);cursor:pointer;width:46px;height:28px;min-height:0;padding:0;box-shadow:inset 0 0 0 1px #ffffff38}.color-pop{z-index:50;border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);background:#27272a;flex-direction:column;gap:10px;padding:12px;display:flex;position:absolute;top:calc(100% + 8px);right:0}.color-pop .react-colorful{width:180px;height:140px}.color-swatches{grid-template-columns:repeat(8,1fr);gap:6px;display:grid}.color-swatch{cursor:pointer;border:0;border-radius:6px;width:20px;height:20px;min-height:0;padding:0;box-shadow:inset 0 0 0 1px #ffffff2e}.color-swatch.active{box-shadow:0 0 0 2px #27272a, 0 0 0 4px var(--primary)}.color-hex-row{font-variant-numeric:tabular-nums;color:var(--felt-text);align-items:center;gap:4px;font-weight:700;display:flex}.color-hex-row input{text-transform:uppercase;background:var(--glass-field-bg);border:1px solid var(--glass-field-border);border-radius:var(--radius-sm);width:100%;min-height:0;color:var(--felt-text);font:inherit;padding:4px 6px}.color-hex-row input:focus{box-shadow:0 0 0 2px var(--ring);outline:none}.conn-banner{z-index:100;padding:7px 14px;padding-top:max(7px, env(safe-area-inset-top));color:#3a2c00;background:linear-gradient(#fad760,#f5c542);justify-content:center;align-items:center;gap:7px;font-size:.85rem;font-weight:600;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 10px #00000040}.conn-banner svg.lucide{width:1.05em;height:1.05em}.spectator-banner{text-align:center;color:#bae6fd;background:#7dd3fc29;border-bottom:1px solid #7dd3fc47;justify-content:center;align-items:center;gap:6px;margin:0;padding:8px 14px;font-size:.9rem;font-weight:600;display:flex}.spec-count{font-variant-numeric:tabular-nums;color:#bae6fd;background:#7dd3fc24;border:1px solid #7dd3fc47;border-radius:999px;flex:none;align-items:center;gap:4px;padding:3px 9px;font-size:.78rem;font-weight:700;display:inline-flex}.spec-count svg.lucide{width:.95em;height:.95em}.bot-controls{justify-content:center;gap:8px;margin-bottom:10px;display:flex}.bot-controls button{color:var(--felt-text-soft);background:var(--chip-btn-bg);border-color:var(--chip-btn-border)}.bot-controls button:hover:not(:disabled){background:var(--chip-btn-hover);color:var(--felt-text)}.bot-ico{color:#7dd3fc}.seg{border-radius:var(--radius-md);background:var(--border);flex:none;gap:2px;padding:2px;display:inline-flex}.seg button{border-radius:var(--radius-sm);font-variant-numeric:tabular-nums;min-height:0;color:var(--muted-foreground);background:0 0;border:none;padding:4px 10px;font-size:.82rem;font-weight:600}.seg button:hover:not(:disabled):not(.active){background:var(--hover);color:var(--foreground)}.seg button.active{background:var(--surface);color:var(--foreground);box-shadow:var(--shadow-sm)}.seg button:disabled{opacity:.5;cursor:not-allowed}.switch{appearance:none;cursor:pointer;background:var(--border);border:none;border-radius:999px;flex:none;width:38px;height:22px;min-height:0;transition:background .15s;position:relative}.switch:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .15s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #00000040}.switch:checked{background:var(--primary)}.switch:checked:before{transform:translate(16px)}.switch:focus-visible{box-shadow:0 0 0 3px var(--ring);outline:none}.switch:disabled{opacity:.45;cursor:not-allowed}.room-code{border-radius:var(--radius-md);cursor:pointer;color:#ffffffb8;-webkit-user-select:none;user-select:none;background:#ffffff0f;border:1px solid #ffffff26;align-items:center;gap:6px;min-height:2.1rem;padding:0 .7rem;font-size:.9rem;font-weight:600;display:inline-flex}.room-code:hover{color:#fff;background:#ffffff24}.room-code:active{transform:scale(.97)}.room-code strong{color:var(--primary);letter-spacing:2px;font-size:1rem}.room-code .lucide-hash{opacity:.55}.room-code .room-copy-ico{opacity:.5;width:.95em;height:.95em;margin-left:1px}.room-code:hover .room-copy-ico{opacity:.9}.room-code.copied{color:#4ade80;border-color:#4ade8066}.room-code.copied .room-copy-ico{color:#4ade80;opacity:1}.toast{text-align:left;background:var(--surface);width:max-content;max-width:min(360px,100vw - 32px);color:var(--foreground);border:1px solid var(--border);z-index:1000;opacity:0;pointer-events:none;border-radius:12px;align-items:center;gap:12px;padding:14px 16px;font-size:.8125rem;font-weight:500;line-height:1.4;transition:opacity .25s,transform .35s cubic-bezier(.21,1.02,.73,1);display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(12px);box-shadow:0 4px 12px #0000001f,0 1px 3px #00000014}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast.hidden{display:none}.toast.top{top:20px;bottom:auto;transform:translate(-50%)translateY(-14px)}.toast.top.show{transform:translate(-50%)translateY(0)}.toast .toast-ico{flex:none}.toast .toast-ico svg.lucide{width:18px;height:18px}.toast .toast-msg{flex-wrap:wrap;align-items:center;gap:5px;display:inline-flex}.toast.error{color:#be123c;background:#fff1f2;border-color:#e11d484d}.toast.error .toast-ico{color:var(--red)}.toast.success{color:#15803d;background:#f0fdf4;border-color:#16a34a4d}.toast.success .toast-ico{color:#16a34a}#turn-info{z-index:1;min-height:1.4em;color:var(--felt-text);text-align:center;text-shadow:0 1px 2px #0000004d;font-size:1.05rem;font-weight:700;position:relative}#turn-info.your-turn{color:var(--primary);animation:1.2s infinite pulse}@keyframes pulse{50%{opacity:.5}}.turn-timer{z-index:1;font-variant-numeric:tabular-nums;color:#ffffffd9;background:#00000047;border:1px solid #ffffff29;border-radius:999px;justify-content:center;align-items:center;gap:4px;margin:4px auto 0;padding:1px 9px;font-size:.82rem;font-weight:700;display:inline-flex;position:relative}.turn-timer svg.lucide{width:.95em;height:.95em}.turn-timer.mine{color:var(--primary);border-color:var(--primary-border)}.turn-timer.urgent{color:#fff;background:var(--red);border-color:var(--red);animation:.8s infinite pulse}.seat{z-index:1;justify-content:center;align-items:center;min-width:0;display:flex}#seat-tl{grid-area:tl}#seat-top{grid-area:top}#seat-tr{grid-area:tr}#seat-left{grid-area:left}#seat-right{grid-area:right}#seat-bl{grid-area:bl}#seat-bottom{grid-area:bottom}#seat-br{grid-area:br}.player-chip{background:var(--surface);border-radius:var(--radius-md);border:1px solid var(--border);min-width:80px;box-shadow:var(--shadow-sm);color:var(--chip-fg,var(--foreground));flex-direction:column;align-items:center;gap:1px;padding:8px 14px;transition:border-color .2s,box-shadow .2s,transform .2s;display:flex}.player-chip.turn{box-shadow:0 0 0 2px var(--primary), 0 4px 18px var(--primary-soft-2);animation:.34s cubic-bezier(.2,.8,.3,1) turnPop;transform:translateY(-2px)}@keyframes turnPop{0%{transform:translateY(-2px)scale(.95)}55%{transform:translateY(-5px)scale(1.06)}to{transform:translateY(-2px)scale(1)}}@media (prefers-reduced-motion:reduce){.player-chip.turn{animation:none}}.player-chip.finished{opacity:.55}.player-chip .pname{font-size:.9rem;font-weight:600}.player-chip .pcount{color:var(--chip-fg-soft,var(--muted-foreground));font-size:.78rem}.player-chip .badge{color:var(--primary);font-size:.7rem}.player-chip .ptitle{background:var(--primary-soft);color:#a16207;border:1px solid var(--primary-border);border-radius:999px;margin-top:4px;padding:1px 9px;font-size:.7rem;font-weight:700}.player-chip .pname .host-ico{color:#eab308;vertical-align:-.1em}.player-chip .pname .off-ico{color:var(--muted-foreground);opacity:.8;vertical-align:-.1em}#table{flex:1;grid-template-areas:"tl top tr""left center right""bl bottom br";place-content:center;place-items:center;gap:12px 18px;min-height:240px;padding:12px;display:grid;position:relative}.pile-center{z-index:1;flex-direction:column;grid-area:center;align-items:center;gap:10px;display:flex;position:relative}.dir-ring{width:clamp(150px,32vh,232px);height:clamp(150px,32vh,232px);color:var(--felt-text);pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.dir-ring svg{stroke-width:1.25px;width:100%;height:100%}.dir-ring.behind{z-index:0;opacity:.18}.dir-ring.front{z-index:5;opacity:.22}#pile-label,#pile-cards{z-index:1;position:relative}#pile-label{color:var(--felt-text-soft);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;font-weight:500}#pile-cards{align-items:center;gap:8px;min-height:92px;display:flex}@keyframes cardIn{0%{opacity:0;transform:translate(var(--from-x,0px), var(--from-y,-16px)) scale(.82)}to{opacity:1;transform:none}}#pile-cards.deal .playing-card{animation:.3s cubic-bezier(.2,.8,.3,1) backwards cardIn}#pile-cards.deal .playing-card:nth-child(2){animation-delay:50ms}#pile-cards.deal .playing-card:nth-child(3){animation-delay:.1s}#pile-cards.deal .playing-card:nth-child(4){animation-delay:.15s}#pile-cards.deal .playing-card:nth-child(n+5){animation-delay:.2s}@keyframes bombShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)rotate(-2deg)}40%{transform:translate(6px)rotate(2deg)}60%{transform:translate(-4px)rotate(-1deg)}80%{transform:translate(4px)rotate(1deg)}}#pile-cards.bomb-hit{animation:.4s bombShake}@media (prefers-reduced-motion:reduce){#pile-cards.deal .playing-card,#pile-cards.bomb-hit{animation:none}}@keyframes handDeal{0%{opacity:0;transform:translateY(46px)scale(.6)rotate(-8deg)}to{opacity:1;transform:none}}#hand.dealing .playing-card{animation:.34s cubic-bezier(.2,.8,.3,1) backwards handDeal;animation-delay:calc(var(--i,0) * 42ms)}@media (prefers-reduced-motion:reduce){#hand.dealing .playing-card{animation:none}}#log{color:#ffffffb8;white-space:nowrap;justify-content:safe center;align-items:center;gap:10px;padding:8px 16px;font-size:.8rem;display:flex;overflow:auto hidden}.log-item{flex:none;align-items:center;gap:3px;display:inline-flex}.log-name{color:#fff9;margin-right:2px;font-size:.72rem}.log-event{color:#ffffff8c;font-size:.72rem}.log-pass{opacity:.65}.mini-card{background:var(--paper);color:var(--ink);border:1px solid var(--border);border-radius:5px;justify-content:center;align-items:center;padding:2px 6px;font-size:.72rem;font-weight:800;line-height:1;display:inline-flex;box-shadow:0 1px 2px #0000002e}.mini-card.red{color:var(--red)}.playing-card{background:var(--paper);width:64px;height:90px;color:var(--ink);box-shadow:var(--shadow-card);-webkit-user-select:none;user-select:none;border:1px solid #e4e4e8;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-weight:800;display:flex;position:relative}.playing-card.red{color:var(--red)}.playing-card .corner{white-space:nowrap;font-size:.82rem;font-weight:800;line-height:1.05;position:absolute}.playing-card .tl{top:6px;left:7px}.playing-card .br{bottom:6px;right:7px;transform:rotate(180deg)}.playing-card .pip{opacity:.92;font-size:1.7rem}#hand-area{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:10px 10px max(10px, env(safe-area-inset-bottom));background:#0000004d;border-top:1px solid #ffffff1a;margin-top:auto;box-shadow:0 -6px 22px #00000038}#combo-hints{flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;padding:4px 4px 8px;display:flex;overflow-x:auto}#combo-hints.hidden{display:none}.combo-hints-label{color:#ffffffb3;white-space:nowrap;font-size:.78rem}.combo-chip{border:1px solid var(--primary-border);background:var(--primary-soft);width:auto;min-height:0;color:var(--primary);cursor:pointer;white-space:nowrap;border-radius:999px;flex:none;padding:5px 13px;font-size:.8rem;font-weight:600;transition:background .12s,color .12s}.combo-chip:hover{background:var(--primary-soft-2)}.combo-chip.active{background:var(--primary);color:var(--primary-foreground);border-color:#0000}#sort-toggle{color:#ffffffbf;background:#ffffff14;border-color:#ffffff24;border-radius:999px;flex:none;width:auto;min-height:0;margin:0 auto 6px;padding:5px 14px;font-size:.78rem;font-weight:600;display:inline-flex}#sort-toggle:hover{color:#fff;background:#ffffff24}#hand{justify-content:safe center;gap:0;min-height:134px;padding:30px 12px 12px;display:flex;overflow:auto visible}#hand .playing-card{cursor:pointer;width:60px;height:86px;margin-left:-14px;transition:transform .14s}#hand .playing-card:first-child{margin-left:0}#hand .playing-card.selected{outline:2px solid var(--primary);outline-offset:1px;transform:translateY(-18px);box-shadow:0 12px 24px #141e3252}#actions{gap:10px;padding:0 8px;display:flex}#actions button{flex:1;min-height:2.7rem;font-size:.95rem}#actions button:not(.primary){color:#fff;background:#ffffff1a;border-color:#ffffff2e}#actions button:not(.primary):hover{background:#ffffff2e}#start-btn:not(.hidden),#again-btn:not(.hidden){border-radius:var(--radius);z-index:20;flex:none;width:auto;min-width:240px;max-width:80vw;min-height:0;padding:16px 44px;font-size:1.1rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 16px 40px #0000004d}#start-btn:not(.hidden):active,#again-btn:not(.hidden):active{transform:translate(-50%,-50%)scale(.97)}.modal{z-index:50;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:0;pointer-events:none;background:#0a0f0c8c;justify-content:center;align-items:center;padding:20px;transition:opacity .18s;display:flex;position:fixed;inset:0}.modal.open{opacity:1;pointer-events:auto}.modal-box{background:var(--surface);color:var(--foreground);border:1px solid var(--border);border-radius:var(--radius);text-align:center;width:100%;max-width:360px;box-shadow:var(--shadow-lg);opacity:0;padding:26px;transition:opacity .2s,transform .2s cubic-bezier(.16,1,.3,1);position:relative;transform:translateY(8px)scale(.96)}.modal.open .modal-box{opacity:1;transform:translateY(0)scale(1)}.dialog-close{border-radius:var(--radius-sm);width:1.9rem;height:1.9rem;min-height:0;color:var(--muted-foreground);background:0 0;border:1px solid #0000;gap:0;padding:0;font-size:1rem;position:absolute;top:12px;right:12px}.dialog-close:hover{background:var(--surface-2);color:var(--foreground)}.modal-box h2{margin-bottom:18px;padding-right:1.5rem;font-size:1.4rem;font-weight:800}#result-list{text-align:left;flex-direction:column;gap:7px;list-style:none;display:flex}#result-list li{border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border);color:var(--foreground);padding:11px 14px;font-weight:700}#result-list li.rank-0{background:var(--primary);color:var(--primary-foreground);border-color:#0000}#result-list li.rank-last{background:#e11d481a;border-color:#e11d4859}#result-close,#scoreboard-close{width:100%;min-height:2.7rem;margin-top:18px}.alert-box{text-align:left;max-width:400px}.alert-box h2{margin-bottom:10px;padding-right:0;font-size:1.25rem}.alert-desc{color:var(--muted-foreground);margin-bottom:22px;font-size:.9rem;line-height:1.55}.alert-actions{justify-content:flex-end;gap:10px;display:flex}.alert-actions button{min-height:2.6rem;padding:0 1.1rem}.btn-secondary:hover{background:var(--surface-2)}.btn-destructive{background:var(--red);color:#fff;border-color:#0000;font-weight:700}.btn-destructive:hover{background:#be123c}.ghost-btn{border:1px solid var(--border);color:var(--muted-foreground);background:0 0;margin-top:2px;font-size:.875rem}.ghost-btn:hover{background:var(--surface-2);color:var(--foreground)}.lobby-foot{justify-content:center;align-items:center;gap:12px;margin-top:14px;display:flex}.github-btn{color:#fff;background:#1f2328;border:1px solid #ffffff29;border-radius:999px;justify-content:center;align-items:center;gap:8px;min-height:2.4rem;padding:.55rem 1.15rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .15s;display:inline-flex;box-shadow:0 6px 18px #00000047}.github-btn:hover{background:#2d333b}.github-btn svg{flex:none}.rules-box{text-align:left;max-width:460px}.rules-content{max-height:60vh;margin:4px -6px 0;padding:0 10px;font-size:.9rem;line-height:1.6;overflow-y:auto}.rules-content h3{color:#a16207;margin:16px 0 4px;font-size:.92rem;font-weight:700}.rules-content h3:first-child{margin-top:0}.rules-content p{color:var(--muted-foreground);margin:0}.rules-content b{color:var(--foreground);font-weight:700}#rules-close{width:100%;min-height:2.7rem;margin-top:18px}.app-version{letter-spacing:.02em;font-variant-numeric:tabular-nums;color:var(--felt-text-faint);font-size:.75rem;font-weight:600;text-decoration:none;transition:color .15s}.app-version:hover{color:var(--felt-text)}.app-version:empty{display:none}.score-empty{color:var(--muted-foreground);text-align:center;padding:22px 0}.score-table{border-collapse:collapse;width:100%;font-size:.85rem}.score-table th,.score-table td{text-align:center;font-variant-numeric:tabular-nums;padding:6px 4px}.score-table thead th{color:var(--muted-foreground);border-bottom:1px solid var(--border)}.score-table .lucide{vertical-align:middle;width:1.05rem;height:1.05rem}.score-th-name{text-align:left}.score-th-rounds{font-size:.7rem;font-weight:600}.score-name{text-align:left;text-overflow:ellipsis;white-space:nowrap;max-width:9rem;font-weight:600;overflow:hidden}.score-table tbody tr{border-bottom:1px solid var(--border)}.score-table tbody tr:last-child{border-bottom:0}.score-zero{color:var(--muted-foreground);opacity:.4}.score-rounds{color:var(--muted-foreground)}.score-table tr.is-you{background:var(--primary-soft)}.score-table tr.is-you .score-name{color:var(--primary-hover)}.score-history{flex-direction:column;gap:4px;max-height:32vh;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.score-history li{border-radius:var(--radius-sm);background:var(--surface-2);flex-wrap:wrap;align-items:center;gap:8px;padding:5px 7px;font-size:.8rem;display:flex}.score-round-n{color:var(--muted-foreground);font-variant-numeric:tabular-nums;min-width:1.6rem;font-weight:700}.score-h-entry{align-items:center;gap:3px;display:inline-flex}.score-h-entry.is-you{color:var(--primary-hover);font-weight:700}.score-h-entry .lucide{width:.95rem;height:.95rem}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}
