:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#2a1644;--muted:#7b5b86;--paper:#fff9ed;--cream:#fff0c7;--mango:#ffcf4a;--mango-dark:#c27a1d;--strawberry:#ff5d8f;--strawberry-dark:#b62f64;--taro:#8756d9;--taro-dark:#4d2a83;--matcha:#22bf85;--matcha-dark:#117854;--tea:#a95f35;--sky:#2fc8ef;--peach:#ffa58a;--white:#fffefa;--rim:#2a164424;--shadow:0 18px 45px #2a164433;--toy-shadow:0 7px 0 #2a16442e, 0 14px 24px #2a164424;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.name-gate{color:var(--strawberry-dark);text-align:center;background:linear-gradient(#fff,#fff0c9);border:2px solid #ff5d8f52;border-radius:8px;padding:10px 12px;font-weight:950;box-shadow:0 5px #2a16441f}.invite-gate{min-height:54px;color:var(--ink);background:linear-gradient(#fffefaf0,#ffe7f5e6),linear-gradient(90deg,#ff5d8f29,#2fc8ef24);border:2px solid #ff5d8f61;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex;box-shadow:0 6px #2a16441f}.invite-gate svg{color:var(--strawberry-dark);flex:none}.invite-gate span{gap:1px;min-width:0;display:grid}.invite-gate strong{font-weight:950}.invite-gate em{color:var(--muted);text-transform:uppercase;font-size:.72rem;font-style:normal;font-weight:900}.invite-recovery{color:var(--ink);background:linear-gradient(#fffefaf7,#fff2d6f0),linear-gradient(135deg,#ff5d8f26,#2fc8ef24);border:2px solid #ff5d8f57;border-radius:8px;grid-template-columns:auto minmax(0,1fr);gap:10px;padding:12px;display:grid;box-shadow:0 7px #2a164424,0 14px 24px #2a16441f}.invite-recovery>svg{color:var(--strawberry-dark);margin-top:2px}.invite-recovery.is-joining{background:linear-gradient(#fffefafa,#ebf9fff2),linear-gradient(135deg,#ff5d8f1f,#2fc8ef33);border-color:#2fc8ef70}.invite-recovery.is-joining>svg{color:var(--sky);animation:1.1s ease-in-out infinite active-pulse}.invite-recovery span{gap:3px;min-width:0;display:grid}.invite-recovery strong{font-weight:950}.invite-recovery em{color:var(--muted);font-size:.78rem;font-style:normal;font-weight:850}.invite-recovery-actions{grid-column:1/-1;grid-template-columns:1.4fr 1fr 1fr;gap:8px;display:grid}.throw-panel{z-index:11;background:linear-gradient(#fffefaf5,#fff0c7eb),linear-gradient(90deg,#ff5d8f14,#2fc8ef1a);border:2px solid #2a16441f;border-radius:8px;gap:6px;width:min(236px,100% - 92px);padding:8px;display:grid;position:absolute;bottom:12px;left:14px;box-shadow:0 7px #2a164424,0 12px 22px #2a164429}.status-lobby .throw-panel{display:none}.throw-target,.throw-actions button{min-width:0;min-height:34px;color:var(--ink);cursor:pointer;background:linear-gradient(#fff,#fff1cd);border:2px solid #2a16441f;border-radius:8px;justify-content:center;align-items:center;font-weight:950;display:flex;box-shadow:0 4px #2a16441f}.throw-target{text-transform:uppercase;gap:5px;padding:0 8px;font-size:.62rem}.throw-target strong{text-overflow:ellipsis;white-space:nowrap;color:var(--taro-dark);font-size:.7rem;overflow:hidden}.throw-target em{color:#fff;background:linear-gradient(135deg, var(--strawberry), var(--taro));border-radius:999px;place-items:center;min-width:28px;height:20px;margin-left:auto;font-style:normal;font-weight:950;display:grid;box-shadow:0 3px #2a164429}.throw-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:5px;display:grid}.throw-actions button{text-transform:uppercase;flex-direction:column;gap:2px;min-height:48px;padding:4px;font-size:.56rem;position:relative}.throw-actions button:disabled{opacity:.42;transform:none}.throw-count{color:#fff;background:linear-gradient(180deg, var(--taro), var(--taro-dark));border:1px solid #ffffffb8;border-radius:999px;place-items:center;min-width:17px;height:17px;padding:0 4px;font-size:.58rem;line-height:1;display:grid;position:absolute;top:4px;right:5px;box-shadow:0 2px #2a164429}.throw-total{display:none}.throw-icon{width:23px;height:23px;display:block;position:relative}.throw-icon:before,.throw-icon:after{content:"";display:block;position:absolute}.throw-icon.is-water:before{background:linear-gradient(#9beeff,#2fc8ef);border-radius:50% 50% 56% 56%;inset:3px 6px 2px;transform:rotate(18deg);box-shadow:-6px 7px 0 -2px #83e5ff,7px 8px 0 -3px #1aa8d8}.throw-icon.is-tomato:before{background:radial-gradient(circle at 34% 28%,#ff9faf 0 16%,#ff415f 18% 68%,#b91834 70%);border-radius:50%;inset:4px}.throw-icon.is-tomato:after{background:var(--matcha);border-radius:8px 0;width:8px;height:8px;top:0;left:9px;transform:rotate(-28deg)}.throw-icon.is-boba:before{background:radial-gradient(circle at 35% 72%, var(--ink) 0 2px, transparent 2px), radial-gradient(circle at 65% 76%, var(--ink) 0 2px, transparent 2px), linear-gradient(180deg, #fff 0 24%, #ff8fbd 25% 100%);border:2px solid #2a16443d;border-radius:5px 5px 8px 8px;width:12px;height:18px;top:2px;left:6px}.throw-icon.is-boba:after{background:var(--ink);border-radius:4px;width:4px;height:17px;top:0;left:15px;transform:rotate(-9deg)}.reaction-burst{z-index:12;pointer-events:none;justify-items:center;gap:2px;animation:.98s cubic-bezier(.2,.9,.2,1) both reaction-hit;display:grid;position:absolute}.reaction-burst.is-left{top:53%;left:16%}.reaction-burst.is-top{top:22%;left:50%}.reaction-burst.is-right{top:53%;right:16%}.reaction-burst.is-self{bottom:13%;left:50%}.reaction-burst.is-center{top:48%;left:50%}.reaction-object{filter:drop-shadow(0 8px #2a16442e);width:52px;height:52px;display:block;position:relative}.reaction-burst strong{color:#fff;background:linear-gradient(135deg, var(--strawberry), var(--taro));text-transform:uppercase;border:2px solid #ffffff80;border-radius:999px;padding:2px 7px;font-size:.68rem;font-weight:950;box-shadow:0 4px #2a164429}.reaction-object:before,.reaction-object:after{content:"";display:block;position:absolute}.reaction-burst.is-water .reaction-object:before{background:radial-gradient(circle at 20% 30%,#fff 0 5px,#0000 6px),radial-gradient(circle at 72% 64%,#bdf6ff 0 6px,#0000 7px),radial-gradient(circle,#2fc8ef 0 44%,#0000 46%);border-radius:42% 58% 50% 50%;inset:7px}.reaction-burst.is-water .reaction-object:after{border:5px dotted #2fc8efb8;border-radius:50%;inset:5px}.reaction-burst.is-tomato .reaction-object:before{background:radial-gradient(circle at 34% 28%,#ff9faf 0 14%,#ff415f 16% 68%,#b91834 70%);border-radius:50%;inset:8px}.reaction-burst.is-tomato .reaction-object:after{background:var(--matcha);border-radius:12px 0;width:15px;height:12px;top:4px;left:22px;transform:rotate(-28deg)}.reaction-burst.is-boba .reaction-object:before{background:radial-gradient(circle at 30% 76%, var(--ink) 0 3px, transparent 4px), radial-gradient(circle at 54% 84%, var(--ink) 0 3px, transparent 4px), radial-gradient(circle at 72% 76%, var(--ink) 0 3px, transparent 4px), linear-gradient(180deg, #fff 0 24%, #ff8fbd 25% 100%);border:4px solid #2a164440;border-top-width:7px;border-radius:8px 8px 14px 14px;width:25px;height:36px;top:6px;left:15px}.reaction-burst.is-boba .reaction-object:after{background:var(--ink);border-radius:6px;width:6px;height:31px;top:0;left:34px;transform:rotate(-10deg)}.rematch-action{z-index:2;position:sticky;bottom:0}@keyframes reaction-hit{0%{opacity:0;transform:translate(-50%,34px)scale(.55)rotate(-18deg)}22%{opacity:1;transform:translate(-50%,-10px)scale(1.15)rotate(7deg)}52%{opacity:1;transform:translate(-50%)scale(1)rotate(-3deg)}to{opacity:0;transform:translate(-50%,-26px)scale(.88)rotate(8deg)}}@keyframes active-pulse{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@media (width<=900px){.table-seat .player-meta em{align-items:center;gap:2px;font-size:.54rem;line-height:1;display:inline-flex}.table-seat .player-meta em svg{width:10px;height:10px}.table-seat .player-meta em b{font-size:.5rem}.round-over .score-list{-webkit-overflow-scrolling:touch;scrollbar-width:none;max-height:min(36svh,220px);overflow-y:auto}.round-over .score-list::-webkit-scrollbar{display:none}.hand-dock.status-roundOver .action-row{display:none}}@media (width<=560px){.throw-panel{gap:4px;width:72px;padding:6px;bottom:8px;left:8px}.throw-panel.is-open{grid-template-columns:1fr;align-items:stretch}.throw-panel:not(.is-open){width:auto;box-shadow:none;background:0 0;border:0;padding:0}.throw-target{min-height:36px;font-size:.54rem}.throw-panel.is-open .throw-target{flex-direction:column;gap:1px;min-height:54px;padding:3px 5px}.throw-panel.is-open .throw-target span{font-size:.46rem}.throw-panel.is-open .throw-target strong{text-overflow:clip;white-space:normal;max-width:100%;font-size:.56rem;line-height:1.05;overflow:visible}.throw-panel:not(.is-open) .throw-target{color:#fff;background:linear-gradient(135deg, var(--taro), var(--sky));border-color:#ffffff8f;flex-direction:column;gap:0;min-width:54px;min-height:48px;padding:3px 8px}.throw-panel:not(.is-open) .throw-target span{font-size:.48rem;line-height:1}.throw-panel:not(.is-open) .throw-target strong{display:none}.throw-panel:not(.is-open) .throw-total{min-width:20px;height:20px;color:var(--ink);background:var(--mango);border-radius:999px;place-items:center;margin-top:2px;font-size:.7rem;font-weight:950;display:grid}.throw-panel:not(.is-open) .throw-target em{min-width:22px;height:18px;margin:0;font-size:.58rem;position:absolute;top:-7px;right:-7px}.throw-target strong{font-size:.62rem}.throw-actions{grid-template-columns:1fr;gap:4px}.throw-actions button{min-height:42px;padding:3px 2px;font-size:.44rem}.throw-actions button.is-empty,.throw-panel:not(.is-open) .throw-actions{display:none}.throw-icon{width:19px;height:19px}.table-zone.status-playing.is-chat-open .throw-panel{display:none}.hand-dock.status-playing .hand-scroll{min-height:112px;padding:10px 14px 7px}.hand-dock.status-playing .card-view{flex-basis:64px;width:64px;height:94px}.hand-dock.status-playing .hand-scroll .card-view+.card-view,.hand-scroll .card-view+.card-view,.hand-scroll.is-short-hand .card-view+.card-view,.hand-dock.status-playing .hand-scroll.is-short-hand .card-view+.card-view{margin-left:7px}.reaction-object{width:42px;height:42px}.reaction-burst strong{font-size:.58rem}}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;color:var(--ink);background:linear-gradient(#fff9edfa,#ffe799eb 52%,#ffa58ab8),repeating-linear-gradient(135deg,#ff5d8f21 0 14px,#2fc8ef21 14px 28px,#22bf851f 28px 42px);margin:0}button,input{font:inherit}button{border:0}button:disabled{cursor:not-allowed;filter:grayscale(.25);opacity:.62}.app-shell{min-height:100svh;overflow:hidden}.home-shell{place-items:center;padding:18px;display:grid;overflow:auto}.home-panel{width:min(100%,520px);box-shadow:var(--shadow);background:linear-gradient(#fffefad1,#fff0c7c7),repeating-linear-gradient(90deg,#2a16440b 0 1px,#0000 1px 22px);border:3px solid #2a16441f;border-radius:8px;gap:18px;padding:18px;display:grid}.home-brand,.top-bar,.room-chip,.brand-chip,.status-line,.self-row,.action-row,.solo-strip,.lobby-actions,.winner-burst{align-items:center;display:flex}.home-brand{justify-content:space-between;gap:12px}.home-brand img{filter:drop-shadow(0 12px #ffcf4a8c)drop-shadow(0 16px 18px #2a16442e);width:82px;height:92px}.home-brand p{color:var(--strawberry-dark);text-transform:uppercase;margin:0 0 4px;font-size:.72rem;font-weight:800}.home-brand h1{color:var(--ink);text-shadow:0 3px #fff,0 7px #ffcf4ae6,0 11px 20px #8756d938;margin:0 0 12px;font-size:clamp(2.8rem,18vw,5.4rem);line-height:.94}.home-brand h1 span{display:block}.home-subtitle{max-width:30rem;color:var(--muted);margin-top:0;font-size:.9rem;font-weight:850;line-height:1.28;display:block}.campaign-badge{width:fit-content;min-height:28px;color:var(--ink);text-transform:uppercase;background:linear-gradient(#fffdf8,#fff0c9);border:2px solid #ff5d8f47;border-radius:999px;align-items:center;margin-top:10px;padding:5px 10px;font-size:.7rem;font-weight:950;display:inline-flex;box-shadow:0 4px #2a16441a}.tutorial-card{background:linear-gradient(#fffefaeb,#fff0c7d6),repeating-linear-gradient(90deg,#ff5d8f0f 0 16px,#2fc8ef0f 16px 32px);border:2px solid #2a16441f;border-radius:8px;gap:10px;padding:10px;display:grid;box-shadow:0 6px #2a16441a}.tutorial-card summary{min-height:38px;color:var(--taro-dark);cursor:pointer;text-transform:uppercase;align-items:center;gap:8px;font-weight:950;list-style:none;display:flex}.tutorial-card summary::-webkit-details-marker{display:none}.tutorial-card summary:after{content:"+";color:#fff;background:linear-gradient(135deg, var(--strawberry), var(--taro));border-radius:8px;place-items:center;width:26px;height:26px;margin-left:auto;display:grid;box-shadow:0 4px #2a164429}.tutorial-card[open] summary:after{content:"-"}.tutorial-intro{color:var(--muted);background:linear-gradient(#ffffffb8,#fff5dcbd);border:1px solid #2a16441a;border-radius:8px;margin:0;padding:9px 10px;font-size:.78rem;font-weight:850;line-height:1.28}.tutorial-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.tutorial-grid div{background:linear-gradient(#fffefa,#fff5dc);border:1px solid #2a16441a;border-radius:8px;gap:3px;min-height:72px;padding:9px;display:grid;box-shadow:0 3px #2a164414}.tutorial-grid strong{color:var(--strawberry-dark);text-transform:uppercase;font-size:.72rem;font-weight:950}.tutorial-grid span{color:var(--ink);font-size:.76rem;font-weight:800;line-height:1.22}.profile-editor{background:linear-gradient(180deg, var(--white), #fff2d6);border:2px solid var(--rim);box-shadow:var(--toy-shadow);border-radius:8px;gap:10px;padding:14px;display:grid}.profile-editor.is-compact{box-shadow:none;grid-template-columns:minmax(120px,1fr);gap:6px;padding:8px}.avatar-picker{grid-template-columns:repeat(4,minmax(64px,1fr));gap:8px;display:grid}.avatar-picker button,.icon-button{min-width:40px;min-height:40px;color:var(--ink);border:2px solid var(--rim);cursor:pointer;background:linear-gradient(#fff,#fff0c9);border-radius:8px;place-items:center;display:grid;box-shadow:0 5px #2a164429}.avatar-picker button{background:linear-gradient(#fffefa,#fff1ce),radial-gradient(circle at 50% 18%,#ffffffdb,#0000 44%);align-content:center;gap:3px;min-height:96px;padding:9px 6px 7px}.avatar-picker button.is-active{border-color:var(--strawberry);background:linear-gradient(#fff8fb,#ffd6e5),radial-gradient(circle at 50% 18%,#ffffffe6,#0000 44%);transform:translateY(2px);box-shadow:0 3px #2a164429}.avatar-picker-name{color:var(--ink);text-transform:uppercase;font-size:.7rem;font-weight:950;line-height:1}.avatar-picker-flavor{max-width:100%;color:var(--muted);text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap;font-size:.52rem;font-weight:900;line-height:1.05;overflow:hidden}.boba-avatar{--avatar-primary:var(--strawberry);--avatar-secondary:var(--cream);--avatar-accent:var(--ink);width:34px;height:40px;color:var(--avatar-accent);filter:drop-shadow(0 4px #2a164421);flex:none;display:inline-block;position:relative}.boba-avatar-picker{width:54px;height:60px}.boba-avatar-pill{width:34px;height:38px}.boba-avatar-chat,.boba-avatar-callout{filter:drop-shadow(0 2px #2a16441f);width:24px;height:28px}.boba-avatar-straw{z-index:1;background:linear-gradient(180deg, #fffefa, var(--avatar-secondary));border-radius:999px;width:5px;height:28px;position:absolute;top:-2px;left:58%;transform:rotate(-10deg);box-shadow:inset -1px 0 #2a16441f}.boba-avatar-cup{z-index:2;background:radial-gradient(circle at 36% 82%, var(--avatar-accent) 0 2px, transparent 3px), radial-gradient(circle at 62% 79%, var(--avatar-accent) 0 2px, transparent 3px), linear-gradient(180deg, #fffefa70 0 22%, var(--avatar-secondary) 23% 38%, var(--avatar-primary) 39% 100%);border:2px solid #fffefadb;border-top-width:5px;border-radius:9px 9px 15px 15px;height:76%;position:absolute;bottom:0;left:16%;right:16%;overflow:hidden;box-shadow:inset 0 -4px #2a164426,0 3px #2a16441f}.boba-avatar-shine{background:#fffefab3;border-radius:999px;height:4px;position:absolute;top:8px;left:21%;right:21%}.boba-avatar-eye{background:var(--avatar-accent);border-radius:999px;width:4px;height:5px;position:absolute;top:43%;box-shadow:inset 1px 1px #fffefa80}.boba-avatar-eye.left{left:28%}.boba-avatar-eye.right{right:28%}.boba-avatar-mouth{border-bottom:2px solid var(--avatar-accent);border-radius:0 0 999px 999px;width:8px;height:5px;position:absolute;top:57%;left:50%;transform:translate(-50%)}.boba-avatar-blush{background:#ffcf4abd;border-radius:999px;width:5px;height:3px;position:absolute;top:56%}.boba-avatar-blush.left{left:14%}.boba-avatar-blush.right{right:14%}.boba-avatar-pearls{justify-content:space-between;display:flex;position:absolute;bottom:4px;left:18%;right:18%}.boba-avatar-pearls i{background:var(--avatar-accent);opacity:.84;border-radius:999px;width:4px;height:4px;display:block}.boba-avatar-accessory{z-index:3;width:15px;height:13px;position:absolute;top:0;left:50%;transform:translate(-50%,-18%)}.boba-avatar-accessory.is-cap{background:var(--avatar-accent);width:22px;height:7px;box-shadow:0 -4px 0 -1px var(--avatar-secondary);border-radius:999px 999px 5px 5px}.boba-avatar-accessory.is-crown{background:linear-gradient(180deg, #fff2a0, var(--mango));clip-path:polygon(0 100%,0 36%,23% 58%,50% 0,77% 58%,100% 36%,100% 100%);filter:drop-shadow(0 1px #2a164433);width:20px;height:13px}.boba-avatar-accessory.is-leaf{background:linear-gradient(135deg,#c8ffb5,#2dcf87);border-radius:999px 0;width:17px;height:11px;transform:translate(-50%,-14%)rotate(-18deg)}.boba-avatar-accessory.is-spark{background:linear-gradient(180deg, #fff, var(--mango));clip-path:polygon(50% 0,62% 34%,100% 50%,62% 66%,50% 100%,38% 66%,0 50%,38% 34%);width:16px;height:16px}.boba-avatar-accessory.is-moon{background:var(--mango);border-radius:50%;width:16px;height:16px}.boba-avatar-accessory.is-moon:after{content:"";background:var(--avatar-secondary);border-radius:50%;position:absolute;inset:0 0 0 5px}.boba-avatar-accessory.is-flower{background:radial-gradient(circle at 50% 50%, var(--mango) 0 3px, transparent 4px), radial-gradient(circle at 50% 13%, #fff 0 4px, transparent 5px), radial-gradient(circle at 87% 50%, #fff 0 4px, transparent 5px), radial-gradient(circle at 50% 87%, #fff 0 4px, transparent 5px), radial-gradient(circle at 13% 50%, #fff 0 4px, transparent 5px);width:16px;height:16px}.boba-avatar-accessory.is-bolt{background:linear-gradient(180deg, #fff583, var(--mango));clip-path:polygon(52% 0,100% 0,69% 42%,100% 42%,31% 100%,46% 54%,10% 54%);width:13px;height:18px}.boba-avatar-accessory.is-ice{width:17px;height:13px}.boba-avatar-accessory.is-ice:before,.boba-avatar-accessory.is-ice:after{content:"";background:linear-gradient(135deg,#fff,#bff4ff);border:1px solid #2a164424;border-radius:3px;width:9px;height:9px;position:absolute;transform:rotate(15deg)}.boba-avatar-accessory.is-ice:after{top:3px;left:8px;transform:rotate(-13deg)}.profile-editor label{color:var(--muted);text-transform:uppercase;gap:4px;font-size:.74rem;font-weight:800;display:grid}.profile-editor input{border:2px solid var(--rim);width:100%;min-height:42px;color:var(--ink);background:#fff;border-radius:8px;padding:0 12px;font-weight:850}.quick-actions{gap:10px;display:grid}.hero-action,.primary-action,.secondary-action{cursor:pointer;letter-spacing:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:0 16px;font-weight:950;transition:transform .13s,filter .13s,box-shadow .13s;display:inline-flex}.hero-action:not(:disabled):active,.primary-action:not(:disabled):active,.secondary-action:not(:disabled):active,.icon-button:not(:disabled):active,.brand-chip:not(:disabled):active,.avatar-picker button:not(:disabled):active{filter:saturate(1.08);transform:translateY(3px)}.hero-action{color:#fff;background:radial-gradient(circle at 24% 0%, #ffffff8f, transparent 28%), linear-gradient(135deg, var(--strawberry), var(--taro) 56%, var(--sky));box-shadow:0 8px 0 var(--taro-dark), 0 16px 28px #8756d94d;border:2px solid #ffffff6b}.home-start-action{min-height:86px;box-shadow:0 11px 0 var(--taro-dark), 0 22px 34px #8756d957, 0 0 0 7px #ffcf4a2e;isolation:isolate;border-width:3px;justify-self:stretch;gap:12px;padding:0 20px;position:relative;overflow:hidden}.home-start-action:before{content:"";z-index:-1;border:1px solid #ffffff6b;border-radius:6px;position:absolute;inset:7px}.home-start-action:after{content:"";z-index:-1;background:linear-gradient(90deg,#0000,#ffffff75,#0000);width:34%;animation:3.2s ease-in-out infinite start-shine;position:absolute;top:-55%;bottom:-55%;left:-26%;transform:rotate(18deg)}.home-start-action svg{filter:drop-shadow(0 3px #2a16442e);flex:none}.home-start-action span{text-align:left;gap:3px;min-width:0;display:grid}.home-start-action strong{font-size:clamp(1.35rem,6vw,2rem);line-height:1}.home-start-action em{color:#ffffffdb;letter-spacing:0;text-transform:uppercase;font-size:.76rem;font-style:normal;font-weight:900}.hero-action.compact{min-height:44px}.primary-action{color:var(--ink);background:linear-gradient(180deg, #ffe57d, var(--mango));box-shadow:0 6px 0 var(--mango-dark), 0 12px 20px #c27a1d33;border:2px solid #ffffffb8}.primary-action.is-ready{background:linear-gradient(180deg, #fff2a0, var(--mango) 42%, #ffb23c);animation:.9s ease-in-out infinite action-ready}.primary-action.is-suggesting{background:linear-gradient(#fff,#e8fbff 48%,#bff2ff);box-shadow:0 6px #2fc8ef6b,0 12px 20px #2fc8ef33}.secondary-action{color:var(--ink);border:2px solid var(--rim);background:linear-gradient(#fff,#edfaff);box-shadow:0 6px #2a164426}.solo-strip{flex-wrap:wrap;gap:8px}.difficulty-tabs{background:#2a16441a;border:1px solid #ffffff8c;border-radius:8px;grid-template-columns:repeat(3,1fr);min-height:40px;padding:4px;display:inline-grid}.difficulty-tabs button{min-width:72px;color:var(--muted);cursor:pointer;text-transform:capitalize;background:0 0;border-radius:6px;font-size:.78rem;font-weight:900}.difficulty-tabs button.is-active{color:var(--ink);background:linear-gradient(#fff,#fff1cd);box-shadow:0 3px 8px #2a16441f}.status-line{min-height:38px;color:var(--muted);justify-content:center;gap:8px;font-weight:800}.online-dot,.offline-dot{border-radius:50%;width:10px;height:10px}.online-dot{background:var(--matcha);box-shadow:0 0 0 5px #30b77c2e}.offline-dot{background:var(--strawberry);box-shadow:0 0 0 5px #ff5d862e}.game-shell{grid-template-rows:auto minmax(0,1fr) auto;height:100svh;display:grid}.top-bar{padding:max(9px, env(safe-area-inset-top)) 10px 9px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:5;background:linear-gradient(#fffefaf5,#ffecb6e6),repeating-linear-gradient(90deg,#ff5d8f14 0 18px,#2fc8ef14 18px 36px);border-bottom:3px solid #ff5d8f40;gap:8px;box-shadow:0 8px 22px #2a16441a}.brand-chip{min-height:42px;color:var(--ink);cursor:pointer;background:linear-gradient(#fff,#ffe8a8);border:2px solid #2a16441a;border-radius:8px;gap:6px;padding:0 10px 0 7px;font-weight:950;box-shadow:0 5px #2a164421}.brand-chip img{width:28px;height:34px}.room-chip{min-height:38px;color:var(--ink);background:linear-gradient(#fff,#eaf9ff);border:2px solid #2fc8ef3d;border-radius:8px;gap:6px;margin-left:auto;padding:0 10px;font-size:.82rem;font-weight:900;box-shadow:0 4px #2a16441c}.room-chip span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.toast{z-index:20;color:#fff;background:linear-gradient(135deg, var(--ink), var(--taro-dark));max-width:min(92vw,420px);box-shadow:var(--shadow);border-radius:8px;padding:10px 14px;font-weight:850;position:fixed;top:62px;left:50%;transform:translate(-50%)}.toast.in-flow{text-align:center;justify-self:stretch;position:static;transform:none}.table-zone{background:linear-gradient(#fff9ed38,#ffcf4a33),repeating-linear-gradient(0deg,#ffffff2e 0 2px,#0000 2px 24px);grid-template-rows:minmax(0,1fr);min-height:0;padding:10px;display:grid;position:relative}.game-shell.is-table-impact .table-zone{animation:.42s cubic-bezier(.2,1.2,.2,1) table-impact}.opponent-rail{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;min-height:66px;display:grid}.seat-map{z-index:2;pointer-events:none;position:absolute;inset:0}.table-seat{pointer-events:none;justify-items:center;gap:4px;width:min(230px,27vw);display:grid;position:absolute}.seat-left{top:51%;left:clamp(14px,2.4vw,34px);transform:translateY(-50%)}.seat-top{top:clamp(10px,2vw,18px);left:50%;transform:translate(-50%)}@media (width>=901px){.seat-top{grid-template-columns:auto minmax(0,1fr);place-items:center stretch;gap:8px;width:min(320px,32vw);top:8px}.seat-top .player-person{justify-self:center}.seat-top .player-pill{justify-self:stretch;min-height:48px}}.seat-right{top:51%;right:clamp(14px,2.4vw,34px);transform:translateY(-50%)}.seat-self{z-index:2;opacity:.92;width:82px;bottom:6px;left:50%;transform:translate(-50%)}.table-seat .player-pill{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(#fffefaf0,#ffedc5e0),linear-gradient(90deg,#ff5d8f29,#2fc8ef24);border-color:#fffefa8f;width:100%;min-height:50px;padding:7px;box-shadow:0 6px #2a164424,0 10px 20px #2a164429}.table-seat .player-avatar{width:28px;height:28px;font-size:1rem}.table-seat .player-meta strong{font-size:.78rem}.table-seat .player-meta em{font-size:.66rem}.player-person{filter:drop-shadow(0 9px 10px #2a16442e);width:68px;height:72px;animation:3.2s ease-in-out infinite person-idle;position:relative}.person-shadow,.person-body,.person-head,.person-arm,.person-straw,.person-cards{position:absolute}.person-shadow{filter:blur(1px);background:#2a164433;border-radius:999px;width:52px;height:11px;bottom:1px;left:8px}.person-straw{z-index:1;background:linear-gradient(180deg, #fffefa, var(--avatar-secondary));border-radius:999px;width:7px;height:37px;top:2px;left:42px;transform:rotate(-12deg);box-shadow:inset -2px 0 #cf31593d,0 2px #2a164414}.person-body{z-index:2;background:radial-gradient(circle at 70% 82%, #fffefa57 0 2px, transparent 3px), linear-gradient(180deg, #fffefa6b 0 17%, var(--avatar-secondary) 18% 38%, var(--avatar-primary) 39% 100%);border:3px solid #fffefac7;border-radius:15px 15px 21px 21px;width:46px;height:49px;bottom:6px;left:11px;overflow:hidden;box-shadow:inset 0 7px #fffefa40,inset 0 -7px #2a164424,0 5px #2a16441f}.person-body:before{content:"";background:#fffefa94;border-radius:999px;height:6px;position:absolute;top:10px;left:8px;right:8px}.person-face{position:absolute;inset:18px 7px 10px}.person-face i{display:block;position:absolute}.eye{background:var(--avatar-accent);border-radius:50%;width:6px;height:8px;top:1px;box-shadow:inset 1px 1px #fffefa80}.eye-left{left:7px}.eye-right{right:7px}.mouth{border-bottom:3px solid var(--avatar-accent);border-radius:0 0 999px 999px;width:11px;height:7px;top:12px;left:50%;transform:translate(-50%)}.blush{background:#ffcf4ab8;border-radius:999px;width:8px;height:5px;top:10px}.blush-left{left:0;transform:rotate(7deg)}.blush-right{right:0;transform:rotate(-7deg)}.person-pearls{justify-content:space-between;display:flex;position:absolute;bottom:4px;left:10px;right:10px}.person-pearls i{background:var(--avatar-accent);opacity:.86;border-radius:50%;width:6px;height:6px;display:block;box-shadow:0 -1px #fffefa38}.person-head{z-index:3;background:radial-gradient(circle at 35% 25%, #fffefaf5, transparent 18%), linear-gradient(180deg, #fff7df, var(--avatar-secondary));border:3px solid #fffefad1;border-radius:999px;place-items:center;width:52px;height:34px;display:grid;top:0;left:8px;box-shadow:inset 0 -4px #2a164414,0 4px #2a16441a}.person-head .boba-avatar-accessory{top:8px;transform:translate(-50%,-50%)scale(.78)}.person-arm{z-index:2;transform-origin:top;background:linear-gradient(#ffe2c3,#ffba94);border:2px solid #fffefa94;border-radius:999px;width:14px;height:25px;bottom:23px}.arm-left{left:3px;transform:rotate(31deg)}.arm-right{right:1px;transform:rotate(-31deg)}.person-cards{z-index:4;display:flex;bottom:25px;right:-10px}.person-cards i{background:linear-gradient(#fff,#ffeabc);border:1px solid #2a164438;border-radius:4px;width:15px;height:21px;margin-left:-8px;display:block;box-shadow:0 2px #2a164426}.person-cards i:first-child{transform:rotate(-13deg)}.person-cards i:nth-child(2){transform:translateY(-2px)rotate(1deg)}.person-cards i:nth-child(3){transform:rotate(12deg)}.table-seat.is-active .player-person{animation:.9s ease-in-out infinite person-active}.table-seat.is-active .person-cards{animation:.52s ease-in-out infinite cards-wiggle}.table-seat.is-winner .person-body{background:radial-gradient(circle at 70% 82%, #fffefa6b 0 2px, transparent 3px), linear-gradient(180deg, #fffefa7a 0 17%, var(--avatar-secondary) 18% 40%, var(--matcha) 41% 100%)}.player-pill{min-height:58px;color:var(--ink);border:2px solid var(--rim);box-shadow:var(--toy-shadow);background:linear-gradient(#fffffff5,#fff2d3eb),linear-gradient(90deg,#ff5d8f29,#2fc8ef1f);border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;padding:8px;display:grid;position:relative;overflow:hidden}.player-pill:before{content:"";background:linear-gradient(180deg, var(--strawberry), var(--mango), var(--matcha));width:7px;position:absolute;inset:0 auto 0 0}.player-pill.is-active{border-color:var(--mango);box-shadow:0 0 0 4px #ffcf4a6b, var(--toy-shadow);animation:1.2s ease-in-out infinite active-pulse}.player-pill.is-winner{border-color:var(--matcha)}.player-pill.is-offline{opacity:.68;filter:saturate(.75)}.player-pill.is-low .hand-count{background:linear-gradient(180deg, var(--strawberry), var(--taro-dark));animation:.92s ease-in-out infinite danger-pop}.player-avatar{background:linear-gradient(#fff6dc,#ffd6e5);border:2px solid #ffffffb3;border-radius:8px;place-items:center;width:34px;height:34px;font-size:1.2rem;display:grid;box-shadow:inset 0 -3px #2a16441a}.player-avatar.boba-avatar{box-shadow:none;background:0 0;border:0}.player-meta{min-width:0;display:grid}.player-meta strong{text-overflow:ellipsis;white-space:nowrap;font-size:.88rem;overflow:hidden}.player-meta em{color:var(--muted);align-items:center;gap:3px;font-size:.72rem;font-style:normal;font-weight:900;display:flex}.hand-count{color:#fff;background:linear-gradient(180deg, var(--taro), var(--ink));border-radius:8px;justify-content:center;align-items:center;gap:5px;min-width:46px;min-height:32px;padding:3px 6px;font-weight:950;display:inline-flex;box-shadow:inset 0 2px #ffffff40}.hand-stack{flex:0 0 20px;width:20px;height:23px;position:relative}.hand-stack i{background:linear-gradient(#fffefa,#ffe8a8);border:1px solid #2a164438;border-radius:4px;width:14px;height:19px;display:block;position:absolute;top:3px;left:4px;box-shadow:0 2px #2a16442e}.hand-stack i:first-child{top:5px;left:0;transform:rotate(-12deg)}.hand-stack i:nth-child(2){top:3px;left:4px}.hand-stack i:nth-child(3){top:5px;left:8px;transform:rotate(12deg)}.hand-count-copy{place-items:center start;line-height:1;display:grid}.hand-count-copy b{font-size:.86rem;line-height:1}.hand-count-copy small{text-transform:uppercase;white-space:nowrap;opacity:.88;margin-top:1px;font-size:.48rem;font-weight:950;line-height:1}.hand-count.is-self{min-width:94px}.bot-tag,.passed-tag,.offline-tag{color:#fff;background:linear-gradient(90deg, var(--taro), var(--strawberry));text-transform:uppercase;border-radius:6px;padding:1px 5px;font-size:.58rem;font-weight:950;position:absolute;bottom:3px;right:6px}.passed-tag{background:linear-gradient(90deg, #7f728a, var(--muted))}.offline-tag{background:linear-gradient(90deg,#82738d,#4f4358);left:10px;right:auto}.positive{color:var(--matcha)}.negative{color:var(--strawberry)}.table-felt{isolation:isolate;height:100%;min-height:340px;box-shadow:inset 0 0 0 7px #ffdf9b75, inset 0 0 0 18px #2a164421, inset 0 -34px 64px #2a16442e, 0 17px 0 #5d34276b, 0 25px 34px #2a16442e, var(--shadow);background:radial-gradient(at 50% 48%,#fffefa52 0 13%,#0000 42%),radial-gradient(circle at 18% 22%,#ffcf4a38,#0000 19%),radial-gradient(circle at 78% 78%,#ff5d8f2e,#0000 21%),repeating-linear-gradient(45deg,#fffefa12 0 9px,#fffefa00 9px 18px),linear-gradient(135deg,#20bd91 0%,#29c9d7 48%,#6b78de 100%);border:10px solid #7b4a31;border-radius:34px;position:relative;overflow:hidden}.table-zone.is-my-turn .table-felt{box-shadow:0 0 0 5px #ffcf4a47, inset 0 0 0 7px #ffdf9b80, inset 0 0 0 18px #2a164421, inset 0 -34px 64px #2a16442e, 0 17px 0 #5d34276b, 0 25px 34px #2a16442e, var(--shadow)}.table-felt:before,.table-felt:after{content:"";pointer-events:none;opacity:.56;position:absolute}.table-felt:before{border:2px solid #fffefa94;border-radius:26px;inset:22px;box-shadow:inset 0 0 0 8px #ffcf4a14,inset 0 0 42px #fffefa14,0 0 0 1px #2a164414}.table-felt:after{background:radial-gradient(circle,#fff9ed33,#0000 56%),repeating-radial-gradient(#fffefa3d 0 2px,#0000 2px 19px);border:2px dashed #fffefa57;border-radius:999px;width:min(50vw,460px);height:min(30vw,260px);top:50%;left:50%;transform:translate(-50%,-50%)}.table-pattern{background:radial-gradient(circle,#fffefa14,#0000 58%),repeating-linear-gradient(45deg,#fffefa0f 0 8px,#0000 8px 16px);border:2px dashed #fff9ed5c;border-radius:25px;position:absolute;inset:25px}.table-decor{z-index:1;pointer-events:none;opacity:.9;position:absolute;inset:0}.table-cup{background:radial-gradient(circle at 38% 78%,#2a1644 0 3px,#0000 4px),radial-gradient(circle at 62% 72%,#2a1644 0 3px,#0000 4px),linear-gradient(#ffffff6b 0 24%,#ff5d8fd1 25% 100%);border:3px solid #fffefac2;border-top-width:7px;border-radius:7px 7px 13px 13px;width:30px;height:38px;position:absolute;box-shadow:0 7px #2a164424,inset 0 -5px #2a16441f}.table-cup:before{content:"";background:#fffefae6;border-radius:999px;width:5px;height:30px;position:absolute;top:-25px;left:17px;transform:rotate(-14deg);box-shadow:2px 0 #cf315952}.cup-left{bottom:18%;left:13%;transform:rotate(-9deg)}.cup-right{top:17%;right:13%;transform:rotate(10deg)}.table-chip-stack{background:radial-gradient(ellipse at 50% 20%, #fff6da 0 30%, transparent 31%), repeating-linear-gradient(0deg, var(--mango) 0 5px, var(--strawberry) 5px 10px, var(--sky) 10px 15px);border:2px solid #fffefaad;border-radius:50%/35%;width:42px;height:25px;position:absolute;box-shadow:0 6px #2a164429}.chips-left{top:21%;left:27%;transform:rotate(8deg)}.chips-right{bottom:19%;right:25%;transform:rotate(-10deg)}.table-card-tray{background:linear-gradient(90deg,#2a164433,#2a16440d),repeating-linear-gradient(90deg,#fffefa7a 0 8px,#0000 8px 16px);border:2px solid #fffefa3d;border-radius:8px;width:88px;height:42px;position:absolute;bottom:22px;right:22px;transform:rotate(-7deg);box-shadow:0 7px #2a164424}.table-light-ring{background:radial-gradient(#fffefa29,#0000 68%);border-radius:999px;width:min(58vw,520px);height:min(34vw,300px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.center-stack{z-index:5;pointer-events:none;grid-auto-rows:max-content;align-content:center;place-items:center;gap:8px;padding:20px;display:grid;position:absolute;inset:0}.play-pile{z-index:4;min-width:min(78vw,360px);min-height:142px;color:var(--ink);background:linear-gradient(#fffefafa,#ffefcaf0),repeating-linear-gradient(135deg,#ff5d8f14 0 10px,#2fc8ef14 10px 20px);border:3px solid #2a164426;border-radius:8px;justify-items:center;gap:8px;padding:14px;animation:.22s ease-out pile-pop;display:grid;position:relative;box-shadow:0 12px #2a164429,0 20px 36px #2a16442e}.play-pile.is-covered{animation:.42s cubic-bezier(.2,1.4,.4,1) cover-pop}.pile-owner{color:var(--strawberry-dark);text-transform:uppercase;font-size:.76rem;font-weight:950}.pile-cards{justify-content:center;min-height:78px;display:flex}.pile-cards .card-view+.card-view{margin-left:-24px}.open-table{min-height:112px;color:var(--muted);text-align:center;place-items:center;gap:8px;display:grid}.timer-badge{--timer-progress:1;z-index:6;color:#fff;background:conic-gradient(var(--strawberry) calc(var(--timer-progress) * 360deg), #2a164433 0);border:2px solid #ffffff85;border-radius:8px;align-items:center;gap:5px;min-height:34px;padding:0 10px;font-weight:950;display:inline-flex;position:relative;box-shadow:0 5px #2a16442e}.timer-badge span{text-align:center;font-variant-numeric:tabular-nums;min-width:26px}.turn-callout{z-index:6;color:#fff;text-align:center;background:linear-gradient(135deg,#2a1644eb,#8756d9db);border:2px solid #ffffff57;border-radius:8px;justify-items:center;gap:2px;max-width:min(84vw,430px);min-height:42px;padding:6px 12px;animation:.36s ease-out badge-bounce;display:grid;position:relative;box-shadow:0 6px #2a164433,0 12px 22px #2a164429}.turn-callout.is-self{background:linear-gradient(135deg, var(--strawberry), var(--taro) 58%, var(--sky))}.turn-callout strong,.turn-callout span{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.turn-callout strong{justify-content:center;align-items:center;gap:6px;font-size:.88rem;font-weight:950;display:inline-flex}.turn-callout span{opacity:.86;font-size:.72rem;font-weight:800}.effect-badge{z-index:6;color:#fff;background:linear-gradient(135deg, var(--taro), var(--sky));text-transform:uppercase;border:2px solid #ffffff6b;border-radius:8px;padding:8px 12px;font-weight:950;animation:.6s ease-out badge-bounce;position:relative;box-shadow:0 6px #2a164438}.effect-badge.is-hot{background:linear-gradient(135deg, var(--strawberry), var(--mango))}.effect-badge.is-win{background:linear-gradient(135deg, var(--matcha), var(--sky))}.chat-panel{z-index:7;background:linear-gradient(#fffefaf5,#fff1d3eb),repeating-linear-gradient(90deg,#ff5d8f12 0 14px,#2fc8ef12 14px 28px);border:3px solid #2a164421;border-radius:8px;grid-template-rows:auto minmax(0,1fr) auto;gap:8px;width:min(300px,100% - 48px);max-height:min(30vh,240px);padding:10px;display:grid;position:absolute;bottom:22px;right:24px;box-shadow:0 9px #2a164421,0 16px 28px #2a16442e}.chat-toggle{display:none}.chat-body{display:contents}.chat-header{color:var(--taro-dark);text-transform:uppercase;align-items:center;gap:6px;font-size:.72rem;font-weight:950;display:flex}.chat-log{align-content:end;gap:6px;min-height:64px;padding-right:2px;display:grid;overflow-y:auto}.chat-empty{color:var(--muted);margin:0;font-size:.8rem;font-weight:850}.chat-bubble{background:linear-gradient(#fff,#fff6df);border:1px solid #2a16441a;border-radius:8px;gap:2px;padding:7px 8px;display:grid;box-shadow:0 3px #2a164414}.chat-bubble strong{min-width:0;color:var(--strawberry-dark);align-items:center;gap:4px;font-size:.7rem;font-weight:950;display:flex}.score-row .boba-avatar-chat,.chat-bubble .boba-avatar-chat{margin-right:2px}.chat-bubble p{overflow-wrap:anywhere;color:var(--ink);margin:0;font-size:.82rem;font-weight:800;line-height:1.24}.chat-form{grid-template-columns:minmax(0,1fr) 40px;gap:6px;display:grid}.chat-form input{width:100%;min-height:40px;color:var(--ink);background:#fff;border:2px solid #2a164424;border-radius:8px;padding:0 10px;font-weight:850}.chat-form button{color:#fff;background:linear-gradient(135deg, var(--strawberry), var(--taro));cursor:pointer;border:2px solid #ffffff73;border-radius:8px;place-items:center;min-height:40px;display:grid;box-shadow:0 5px #2a16442e}.lobby-panel,.round-over{z-index:8;width:min(100% - 28px,560px);box-shadow:var(--shadow);background:linear-gradient(#fffefafa,#ffefcaf5),repeating-linear-gradient(90deg,#ff5d8f12 0 14px,#2fc8ef12 14px 28px);border:3px solid #2a164421;border-radius:8px;padding:12px;position:absolute;bottom:18px;left:50%;transform:translate(-50%)}.lobby-panel{gap:10px;display:grid}.lobby-actions{justify-content:center;gap:10px;display:grid}.invite-actions,.bot-setup-row,.start-actions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.invite-actions>button{flex:190px}.sms-action{background:linear-gradient(#fff,#eefbff);border-color:#2fc8ef57}.bot-setup-row{align-items:stretch}.bot-fill-action{flex:0 170px}.bot-difficulty-control{background:linear-gradient(#fffefaf0,#fff0c7c2),linear-gradient(90deg,#ff5d8f14,#2fc8ef14);border:2px solid #2a16441a;border-radius:8px;flex:320px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;min-width:min(100%,320px);padding:6px;display:grid;box-shadow:0 5px #2a16441a}.bot-difficulty-label{color:var(--taro-dark);text-transform:uppercase;white-space:nowrap;align-items:center;gap:5px;font-size:.68rem;font-weight:950;display:inline-flex}.bot-difficulty-control .difficulty-tabs{width:100%;min-height:40px}.bot-difficulty-control .difficulty-tabs button{min-width:0;padding:0 8px}.lobby-bot-count{min-width:96px;color:var(--muted);text-transform:uppercase;gap:4px;font-size:.68rem;font-weight:950;display:grid}.lobby-bot-count select{min-height:44px;color:var(--ink);font:inherit;background:linear-gradient(#fff,#fff7df);border:2px solid #2a164424;border-radius:8px;padding:0 10px;font-size:.86rem}.start-actions .hero-action{flex:220px}.invite-link-input{width:100%;min-height:38px;color:var(--muted);text-overflow:ellipsis;background:#ffffffb8;border:2px dashed #2a164429;border-radius:8px;padding:0 10px;font-size:.78rem;font-weight:850}.round-over{gap:12px;display:grid}.winner-burst{justify-content:center;gap:8px}.winner-burst h2{margin:0;font-size:1.1rem}.winning-play-strip{color:var(--ink);text-align:center;background:linear-gradient(#fff,#fff7df);border:2px dashed #2a16441f;border-radius:8px;justify-items:center;gap:2px;padding:7px 10px;display:grid}.winning-play-strip span{color:var(--strawberry-dark);text-transform:uppercase;font-size:.62rem;font-weight:950}.winning-play-strip strong{font-size:.82rem;line-height:1.1}.score-list{gap:6px;display:grid}.score-row{background:linear-gradient(#fff,#fff6df);border:1px solid #2a164414;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto auto auto;align-items:center;gap:8px;min-height:38px;padding:0 8px;font-size:.86rem;display:grid}.score-row strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.score-row em{font-style:normal;font-weight:950}.score-detail{color:var(--muted);overflow-wrap:anywhere;grid-column:1/-1;font-size:.68rem;font-weight:850;line-height:1.2}.rematch-status{color:var(--taro-dark);text-transform:uppercase;background:linear-gradient(#fff,#fff0c9);border:2px solid #2a16441f;border-radius:8px;justify-self:center;padding:5px 10px;font-size:.78rem;font-weight:950}.final-play-review{color:var(--ink);background:linear-gradient(#fffefafa,#fff4d5f0),radial-gradient(circle at 18% 12%,#ff5d8f29,#0000 34%),radial-gradient(circle at 82% 0,#2fc8ef26,#0000 34%);border:2px dashed #2a164429;border-radius:8px;justify-items:center;gap:7px;padding:10px 10px 12px;display:grid}.final-play-kicker{color:var(--strawberry-dark);letter-spacing:0;text-transform:uppercase;font-size:.64rem;font-weight:950}.final-play-review strong{text-align:center;font-size:.9rem;line-height:1.15}.final-play-cards{justify-content:center;min-height:78px;display:flex}.final-play-cards .card-view+.card-view{margin-left:-22px}.ready-tag{color:#fff;background:linear-gradient(90deg, #8a7b95, var(--muted));text-transform:uppercase;border-radius:6px;justify-self:end;padding:2px 6px;font-size:.58rem;font-weight:950}.ready-tag.is-ready{background:linear-gradient(90deg, var(--matcha), var(--sky))}.hand-dock{padding:8px 10px max(10px, env(safe-area-inset-bottom));z-index:5;background:linear-gradient(#fffefaf5,#ffe6a4f5),repeating-linear-gradient(90deg,#2a16440a 0 1px,#0000 1px 22px);border-top:3px solid #2a16441f;gap:8px;display:grid;box-shadow:0 -10px 24px #2a16441f}.self-row{justify-content:space-between;gap:8px}.self-row .player-pill{flex:1}.self-row .profile-editor{width:min(46vw,220px)}.self-row .avatar-picker{display:none}.hand-scroll{scroll-snap-type:x proximity;background:linear-gradient(#ffffff61,#ffffff1f),linear-gradient(90deg,#ff5d8f17,#22bf8514,#2fc8ef17);border-radius:8px;min-height:122px;padding:15px 4px 8px;display:flex;overflow:auto hidden;box-shadow:inset 0 0 0 2px #ffffff47}.hand-scroll .card-view{scroll-snap-align:center;flex:none}.hand-scroll .card-view+.card-view{margin-left:-34px}.action-row{gap:8px}.action-row .primary-action{flex:1;min-width:0}.action-row .primary-action span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.hint-text{color:var(--strawberry);text-align:center;text-shadow:0 1px #fff;margin:-2px 0 0;font-size:.82rem;font-weight:850}.card-view{width:74px;height:108px;color:var(--ink);cursor:pointer;background:linear-gradient(#fffefa,#fff4db 72%,#ffe8b4),repeating-linear-gradient(135deg,#ff5d8f14 0 8px,#0000 8px 16px);border:2px solid #2a164438;border-radius:8px;padding:7px;transition:transform .14s,box-shadow .14s,border-color .14s;display:grid;position:relative;transform:translateY(0);box-shadow:0 8px #2a164433,0 12px 18px #2a16442e}.card-view:before{content:"";pointer-events:none;background:linear-gradient(#ffffff94,#0000 48%),linear-gradient(90deg,#ff5d8f14,#2fc8ef14);border:1px solid #2a16441f;border-radius:6px;position:absolute;inset:5px}.card-view:disabled{cursor:default;opacity:1;filter:none}.card-view.is-selected{border-color:var(--mango);z-index:2;transform:translateY(-20px)rotate(-1deg);box-shadow:0 0 0 4px #ffcf4a6b,0 12px #2a164433,0 20px 22px #ff5d8f38}.card-view.is-compact{width:52px;height:76px;padding:5px;box-shadow:0 5px #2a16442e}.card-view.is-red{color:#cf3159}.card-corner{z-index:1;text-shadow:0 1px #fff;justify-items:center;font-size:.7rem;line-height:1;display:grid;position:absolute;top:5px;left:6px}.card-corner strong{font-size:.95rem}.card-corner.bottom{inset:auto 6px 5px auto;transform:rotate(180deg)}.card-art{z-index:1;background:linear-gradient(#ffffff8c,#ffcf4a2e),#ffcb4d2e;border:1px solid #2a164414;border-radius:8px;place-items:center;display:grid;position:absolute;inset:22px 12px;overflow:visible}.tea-matcha .card-art{background:linear-gradient(#ffffff80,#22bf8533)}.tea-mango .card-art{background:linear-gradient(#ffffff85,#ffcf4a47)}.tea-strawberry .card-art{background:linear-gradient(#ffffff80,#ff5d8f38)}.tea-taro .card-art{background:linear-gradient(#ffffff80,#8756d938)}.tea-cup-shape{opacity:.82;filter:drop-shadow(0 3px #2a164414);background:linear-gradient(#ffffff80 0 26%,#0000 27%),linear-gradient(#ffffff42,currentColor);border:3px solid;border-top-width:6px;border-radius:6px 6px 11px 11px;width:30px;height:36px;position:relative;overflow:visible}.tea-cup-shape:before{content:"";transform-origin:bottom;background:currentColor;border-radius:5px;width:5px;height:24px;position:absolute;top:-19px;left:16px;transform:rotate(-12deg);box-shadow:inset 2px 0 #ffffff57}.tea-cup-shape:after{content:"";background:#ffffff9e;border-radius:999px;height:4px;position:absolute;top:9px;left:5px;right:5px}.boba-dot{opacity:.82;z-index:2;background:#2a1644;border-radius:50%;width:5px;height:5px;position:absolute;box-shadow:0 1px #ffffff73}.dot-a{bottom:6px;left:7px}.dot-b{bottom:8px;right:7px}.dot-c{bottom:3px;left:13px}@keyframes pile-pop{0%{transform:translateY(12px)scale(.96)}to{transform:translateY(0)scale(1)}}@keyframes cover-pop{0%{transform:rotate(-2deg)scale(.92)}55%{transform:rotate(1deg)scale(1.08)}to{transform:rotate(0)scale(1)}}@keyframes badge-bounce{0%{opacity:0;transform:translateY(10px)scale(.82)}45%{opacity:1;transform:translateY(-4px)scale(1.06)}to{transform:translateY(0)scale(1)}}@keyframes action-ready{0%,to{filter:saturate();transform:translateY(0)}50%{filter:saturate(1.18);transform:translateY(-1px)}}@keyframes start-shine{0%,46%{opacity:0;transform:translate(0)rotate(18deg)}58%{opacity:.85}78%,to{opacity:0;transform:translate(420%)rotate(18deg)}}@keyframes danger-pop{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes table-impact{0%{transform:translate(0,0)rotate(0)}15%{transform:translate(-5px,2px)rotate(-.35deg)}30%{transform:translate(5px,-3px)rotate(.35deg)}45%{transform:translate(-4px,3px)rotate(-.25deg)}60%{transform:translate(3px,-2px)rotate(.2deg)}to{transform:translate(0,0)rotate(0)}}@keyframes person-idle{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-3px)rotate(-1deg)}}@keyframes person-active{0%,to{transform:translateY(0)scale(1)}45%{transform:translateY(-6px)scale(1.04)}}@keyframes cards-wiggle{0%,to{transform:rotate(0)}35%{transform:rotate(-8deg)translateY(-2px)}70%{transform:rotate(7deg)translateY(1px)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}@keyframes table-shimmer{0%{background-position:0 0,0 0,0 0}to{background-position:0 0,42px 42px,0 0}}@media (width>=760px){.game-shell{grid-template-rows:auto minmax(0,1fr) auto}.table-zone{grid-template-columns:minmax(0,1fr);padding:14px 18px}.table-felt{min-height:420px;animation:12s linear infinite table-shimmer}.hand-scroll .card-view+.card-view{margin-left:-20px}.card-view{width:88px;height:128px}.card-view.is-compact{width:60px;height:88px}}@media (width>=1100px){.hand-scroll{justify-content:center}}@media (width<=900px){.table-zone{padding:8px 10px}.table-felt{min-height:380px}.table-seat{width:132px}.seat-left{top:40%;left:8px}.seat-right{top:40%;right:8px}.seat-top{width:min(170px,48vw);top:7px}.table-seat .player-pill{grid-template-columns:minmax(0,1fr) auto;min-height:42px;padding:5px 7px}.table-seat .player-pill:before,.table-seat .player-avatar,.table-seat .player-meta em{display:none}.table-seat .player-meta strong{font-size:.72rem}.table-seat .hand-count{min-width:24px;height:27px;font-size:.76rem}.center-stack{padding:72px 40px 52px}.play-pile{min-width:min(54vw,300px)}.chat-panel{width:min(280px,100% - 24px);max-height:108px}}@media (width<=560px){.home-shell{align-items:start;padding:10px}.home-panel{gap:12px;padding:12px}.home-brand{gap:8px}.home-brand img{width:64px;height:74px}.home-brand p{font-size:.62rem}.home-brand h1{margin-bottom:10px;font-size:clamp(2.7rem,16.5vw,5rem);line-height:.96}.home-subtitle{font-size:.78rem}.home-start-action{min-height:78px;padding-inline:14px}.home-start-action strong{font-size:1.22rem}.home-start-action em{font-size:.66rem}.avatar-picker{grid-template-columns:repeat(2,minmax(0,1fr))}.avatar-picker button{min-height:108px}.avatar-picker-flavor{white-space:normal}.tutorial-card{padding:8px}.tutorial-card summary{min-height:34px;font-size:.82rem}.tutorial-grid{grid-template-columns:minmax(0,1fr);gap:6px}.tutorial-grid div{min-height:auto;padding:8px}.tutorial-grid span{font-size:.72rem}.table-seat{width:112px}.seat-left{top:28%;left:5px}.seat-right{top:28%;right:5px}.seat-top{width:min(140px,46vw);top:5px}.table-seat .player-pill{min-height:38px;padding:5px 6px}.table-seat .player-meta strong{font-size:.66rem}.table-seat .hand-count{min-width:22px;height:24px;font-size:.7rem}.player-person{width:54px;height:58px}.person-straw{width:5px;height:30px;top:1px;left:34px}.person-head{width:42px;height:28px;left:6px}.person-head .boba-avatar-accessory{transform:translate(-50%,-50%)scale(.66)}.person-body{border-width:2px;width:36px;height:40px;bottom:5px;left:9px}.person-body:before{height:5px;top:8px;left:6px;right:6px}.person-face{inset:15px 6px 8px}.eye{width:5px;height:7px}.mouth{border-bottom-width:2px;width:9px;height:6px;top:10px}.blush{width:6px;height:4px;top:9px}.person-pearls{bottom:3px;left:8px;right:8px}.person-pearls i{width:5px;height:5px}.person-arm{width:10px;height:23px;bottom:19px}.person-cards{bottom:19px;right:-6px}.person-cards i{width:12px;height:17px;margin-left:-7px}.center-stack{padding:108px 46px 118px}.play-pile{min-width:min(50vw,240px)}.chat-panel{width:min(240px,100% - 16px);max-height:82px;padding:7px;bottom:8px;right:8px}.chat-header{display:none}.chat-log{min-height:24px;max-height:28px}.chat-form{grid-template-columns:minmax(0,1fr) 34px}.chat-form input,.chat-form button{min-height:34px}.lobby-panel{padding:10px;bottom:10px}.invite-actions>button,.start-actions .hero-action,.bot-fill-action{flex:100%;min-height:42px}.bot-setup-row{grid-template-columns:minmax(0,1fr);display:grid}.bot-difficulty-control{grid-template-columns:minmax(0,1fr);min-width:0}.bot-difficulty-control .difficulty-tabs button{padding:0 6px;font-size:.7rem}}@media (width<=430px){.brand-chip span{display:none}.room-chip{max-width:86px;overflow:hidden}.opponent-rail .player-pill{min-height:50px;padding:6px}.opponent-rail .player-meta em{display:none}.opponent-rail .player-meta strong{font-size:.72rem}.player-pill{gap:6px;min-height:52px}.opponent-rail .player-avatar{width:26px;height:26px;font-size:1rem}.opponent-rail .hand-count{min-width:24px;height:28px}.player-avatar{width:30px;height:30px}.table-zone{padding:6px 8px}.table-felt{border-width:6px;border-radius:22px;min-height:322px}.table-felt:before{border-radius:16px;inset:16px}.table-pattern{border-radius:16px;inset:17px}.table-seat{gap:0;width:118px}.seat-left{top:43%;left:6px}.seat-right{top:43%;right:6px}.seat-top{width:min(150px,48vw);top:5px}.seat-self{width:62px;bottom:0}.player-person{width:54px;height:58px;transform:scale(.86)}.person-straw{width:5px;height:30px;top:1px;left:34px}.person-head{width:42px;height:28px;left:6px}.person-head .boba-avatar-accessory{transform:translate(-50%,-50%)scale(.66)}.person-body{border-width:2px;width:36px;height:40px;bottom:5px;left:9px}.person-body:before{height:5px;top:8px;left:6px;right:6px}.person-face{inset:15px 6px 8px}.eye{width:5px;height:7px}.mouth{border-bottom-width:2px;width:9px;height:6px;top:10px}.blush{width:6px;height:4px;top:9px}.person-pearls{bottom:3px;left:8px;right:8px}.person-pearls i{width:5px;height:5px}.person-arm{width:10px;height:23px;bottom:19px}.person-cards{bottom:19px;right:-6px}.person-cards i{width:12px;height:17px;margin-left:-7px}.table-seat .player-pill{grid-template-columns:minmax(0,1fr) auto;min-height:38px;padding:5px 6px}.table-seat .player-pill:before,.table-seat .player-avatar,.table-seat .player-meta em{display:none}.table-seat .player-meta strong{font-size:.68rem}.table-seat .hand-count{min-width:23px;height:25px;font-size:.72rem}.table-seat .bot-tag,.table-seat .passed-tag,.table-seat .offline-tag{font-size:.5rem}.table-cup,.table-chip-stack,.table-card-tray{transform:scale(.78)}.cup-left{bottom:18%;left:8%}.cup-right{top:18%;right:8%}.chips-left{top:27%;left:22%}.chips-right{bottom:23%;right:18%}.table-card-tray{bottom:12px;right:7px}.center-stack{padding:72px 42px 120px}.play-pile{min-width:min(66vw,280px);min-height:128px;padding:12px}.chat-panel{width:min(260px,100% - 16px);max-height:86px;padding:8px;top:auto;bottom:8px;right:8px}.status-lobby .chat-panel,.status-roundOver .chat-panel{top:auto;bottom:8px}.chat-header{display:none}.chat-log{min-height:24px;max-height:30px}.chat-bubble{padding:5px 7px}.chat-bubble p{font-size:.76rem}.score-row{grid-template-columns:auto minmax(0,1fr) auto auto;font-size:.78rem}.score-row span:last-of-type{display:none}.ready-tag{font-size:.5rem}.hand-scroll{min-height:116px;padding-top:16px}.card-view{width:66px;height:98px}.hand-scroll .card-view+.card-view{margin-left:-38px}.self-row .profile-editor{display:none}.action-row{align-items:stretch}}@media (width<=900px){.game-shell{grid-template-rows:auto minmax(0,1fr) auto}.top-bar{gap:6px;padding-inline:8px}.brand-chip{min-height:38px;padding-right:8px}.brand-chip img{width:24px;height:30px}.room-chip{min-width:0;max-width:132px;min-height:36px;padding:0 8px}.room-chip span{text-overflow:ellipsis;overflow:hidden}.icon-button{min-width:38px;min-height:38px}.table-zone{padding:6px 8px}.table-felt{border-width:7px;border-radius:24px;min-height:342px}.table-felt:before{border-radius:17px;inset:16px}.table-pattern{border-radius:17px;inset:17px}.seat-left{top:42%;left:6px}.seat-right{top:42%;right:6px}.seat-top{grid-template-columns:auto minmax(0,1fr);place-items:center stretch;gap:4px;width:min(194px,64vw);top:3px}.seat-top .player-person{transform-origin:50%;justify-self:center;transform:scale(.8)}.seat-top .player-pill{min-height:34px;padding:4px 6px}.seat-top .hand-count{min-width:22px;height:24px;font-size:.7rem}.table-seat .bot-tag,.table-seat .passed-tag,.table-seat .offline-tag{font-size:.5rem}.center-stack{gap:6px;padding:102px 40px 78px;transition:transform .18s}.timer-badge{min-height:30px;padding:0 8px}.turn-callout{max-width:min(72vw,290px);min-height:36px;padding:5px 10px}.turn-callout strong{font-size:.78rem}.turn-callout span{font-size:.64rem}.play-pile{min-width:min(68vw,280px);min-height:122px;padding:10px}.round-over{-webkit-overflow-scrolling:touch;gap:8px;width:min(100% - 22px,540px);max-height:calc(100% - 22px);padding:10px;overflow-y:auto}.winner-burst h2{font-size:.98rem}.final-play-review{gap:5px;padding:8px}.final-play-review strong{font-size:.82rem}.final-play-cards{min-height:68px}.final-play-cards .card-view.is-compact{width:48px;height:70px;padding:4px}.final-play-cards .card-view+.card-view{margin-left:-18px}.pile-cards{min-height:70px}.pile-cards .card-view+.card-view{margin-left:-28px}.chat-panel{z-index:10;width:auto;max-height:none;box-shadow:none;background:0 0;border:0;padding:0;display:block;inset:auto 10px 10px auto}.chat-toggle{color:#fff;background:linear-gradient(135deg, var(--taro), var(--sky));border:2px solid #ffffff8f;border-radius:8px;justify-content:center;align-items:center;gap:5px;min-height:38px;padding:0 10px;font-size:.72rem;font-weight:950;display:inline-flex;box-shadow:0 6px #2a164433,0 12px 18px #2a164429}.chat-toggle b{min-width:17px;height:17px;color:var(--ink);background:var(--mango);border-radius:999px;place-items:center;padding:0 4px;font-size:.62rem;display:grid}.chat-body{display:none}.chat-panel.is-open{left:10px;right:10px;bottom:max(10px, env(safe-area-inset-bottom));background:linear-gradient(#fffefafa,#fff1d3f2),repeating-linear-gradient(90deg,#ff5d8f12 0 14px,#2fc8ef12 14px 28px);border:3px solid #2a164421;border-radius:8px;grid-template-rows:auto minmax(0,1fr);gap:6px;width:auto;max-height:174px;padding:8px;display:grid;box-shadow:0 9px #2a164421,0 16px 28px #2a16442e}.chat-panel.is-open .chat-toggle{min-height:30px;box-shadow:none;justify-self:start;padding:0 8px}.chat-panel.is-open .chat-body{grid-template-rows:minmax(0,1fr) auto;gap:7px;min-height:0;display:grid}.chat-panel.is-open .chat-header{display:none}.chat-panel.is-open .chat-log{min-height:34px;max-height:62px}.chat-panel.is-open .chat-form{grid-template-columns:minmax(0,1fr) 36px}.chat-panel.is-open .chat-form input,.chat-panel.is-open .chat-form button{min-height:36px}.status-lobby .chat-panel,.status-roundOver .chat-panel{display:none}.game-shell.is-chat-open{grid-template-rows:auto minmax(0,1fr)}.game-shell.is-chat-open .hand-dock{display:none}.game-shell.is-chat-open .chat-panel.is-open{left:10px;right:10px;bottom:max(10px, env(safe-area-inset-bottom));z-index:30;position:fixed}.table-zone.status-playing.is-chat-open .center-stack{transform:translateY(-70px)scale(.97)}.table-zone.status-playing.is-chat-open .chat-panel.is-open{max-height:128px}.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-log{min-height:24px;max-height:38px}.hand-scroll.is-short-hand{justify-content:center}.hand-scroll.is-short-hand .card-view+.card-view{margin-left:-12px}.self-row .profile-editor{display:none}.hand-dock.status-lobby{gap:0;padding-block:7px}.hand-dock.status-lobby .hand-scroll,.hand-dock.status-lobby .action-row,.hand-dock.status-lobby .hint-text{display:none}.self-row .player-pill{min-height:50px}.hand-dock{padding:7px 8px max(8px, env(safe-area-inset-bottom));gap:7px}.hand-scroll{min-height:128px;padding:13px 12px 9px;scroll-padding-inline:14px}.card-view{touch-action:manipulation;width:72px;height:106px}.hand-scroll .card-view+.card-view{margin-left:-20px}.card-view.is-selected{transform:translateY(-14px)rotate(-1deg)}.action-row{align-items:stretch}.action-row .primary-action,.action-row .secondary-action{min-height:48px}}@media (width<=430px),(height<=740px){.table-zone.status-playing.is-chat-open .center-stack{transform:translateY(-72px)scale(.94)}.table-zone.status-playing.is-chat-open .chat-panel.is-open{max-height:122px}.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-log{max-height:30px}.hand-scroll.is-short-hand{padding-inline:16px}.hand-scroll.is-short-hand .card-view+.card-view{margin-left:-10px}}@media (width<=430px) and (height<=680px){.table-zone.status-playing.is-chat-open .center-stack{transform:translateY(-60px)scale(.94)}.table-zone.status-playing.is-chat-open .chat-panel.is-open{gap:4px;max-height:136px;padding:6px}.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-toggle{min-height:40px}.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-body{gap:5px}.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-log{min-height:18px;max-height:26px}.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-form input,.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-form button{min-height:40px}.table-felt{min-height:310px}.center-stack{padding:86px 34px 70px}.play-pile{min-height:112px}.hand-dock{padding:6px 8px max(6px, env(safe-area-inset-bottom));gap:6px}.self-row .player-pill{min-height:46px}.hand-scroll{min-height:116px;padding:11px 12px 7px}.card-view{width:68px;height:100px}.hand-scroll .card-view+.card-view{margin-left:-22px}.card-view.is-selected{transform:translateY(-12px)rotate(-1deg)}.action-row .primary-action,.action-row .secondary-action{min-height:44px}}@media (width<=560px){.table-zone.status-playing .table-felt{min-height:356px}.table-zone.status-playing .table-seat{gap:0;width:76px}.table-zone.status-playing .seat-left{top:48%;left:10px}.table-zone.status-playing .seat-right{top:48%;right:10px}.table-zone.status-playing .seat-top{gap:2px;width:min(178px,62vw);top:5px}.table-zone.status-playing .seat-left .player-person,.table-zone.status-playing .seat-right .player-person{transform-origin:bottom;margin-bottom:-8px;transform:scale(.74)}.table-zone.status-playing .seat-top .player-person{transform:scale(.72)}.table-zone.status-playing .seat-left .player-pill,.table-zone.status-playing .seat-right .player-pill{grid-template-columns:minmax(0,1fr) auto;width:76px;min-height:31px;padding:3px 4px}.table-zone.status-playing .seat-top .player-pill{min-height:32px;padding:3px 5px}.table-zone.status-playing .table-seat .player-meta strong{font-size:.6rem;line-height:1}.table-zone.status-playing .table-seat .hand-count{border-radius:7px;gap:2px;min-width:30px;min-height:22px;padding:1px 3px;font-size:.64rem}.table-zone.status-playing .table-seat .hand-stack{flex-basis:14px;width:14px;height:16px}.table-zone.status-playing .table-seat .hand-stack i{border-radius:3px;width:10px;height:14px}.table-zone.status-playing .table-seat .hand-stack i:first-child{top:3px;left:0}.table-zone.status-playing .table-seat .hand-stack i:nth-child(2){top:1px;left:2px}.table-zone.status-playing .table-seat .hand-stack i:nth-child(3){top:3px;left:5px}.table-zone.status-playing .table-seat .hand-count-copy b{font-size:.66rem}.table-zone.status-playing .table-seat .hand-count-copy small,.table-zone.status-playing .seat-left .bot-tag,.table-zone.status-playing .seat-right .bot-tag{display:none}.table-zone.status-playing .seat-top .bot-tag{text-overflow:clip;white-space:nowrap;max-width:42px;padding:0 4px;font-size:.44rem;line-height:1.35;bottom:-8px;right:4px;overflow:hidden}.table-zone.status-playing .center-stack{gap:5px;padding:100px 94px 62px}.table-zone.status-playing .timer-badge{min-height:28px;padding:0 8px;font-size:.78rem}.table-zone.status-playing .timer-badge span{min-width:22px}.table-zone.status-playing .turn-callout{max-width:min(54vw,232px);min-height:34px;padding:5px 8px}.table-zone.status-playing .turn-callout strong{font-size:.76rem}.table-zone.status-playing .turn-callout span{font-size:.6rem}.table-zone.status-playing .play-pile{width:min(52vw,238px);min-width:0;min-height:116px;padding:9px}.table-zone.status-playing .pile-owner{font-size:.64rem}.table-zone.status-playing .pile-cards{min-height:62px}.table-zone.status-playing .pile-cards .card-view.is-compact{width:44px;height:64px;padding:4px}.table-zone.status-playing .pile-cards .card-view+.card-view{margin-left:-16px}.table-zone.status-playing .play-pile>strong{font-size:.76rem;line-height:1.1}.table-zone.status-playing .chat-panel:not(.is-open){bottom:12px;right:12px}.table-zone.status-playing .chat-panel:not(.is-open) .chat-toggle{gap:0;width:46px;min-width:46px;min-height:42px;padding:0}.table-zone.status-playing .chat-panel:not(.is-open) .chat-toggle span{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}.table-zone.status-playing .chat-panel:not(.is-open) .chat-toggle b{position:absolute;top:-7px;right:-7px}}@media (width<=380px){.table-zone.status-playing .center-stack{padding-inline:82px}.table-zone.status-playing .play-pile{width:min(50vw,210px)}}@media (width<=560px) and (height<=740px){.table-zone.status-playing{padding-block:4px}.table-zone.status-playing .table-felt{border-width:6px;border-radius:22px;min-height:292px}.table-zone.status-playing .table-felt:before{inset:15px}.table-zone.status-playing .table-pattern{inset:16px}.table-zone.status-playing .table-seat{width:70px}.table-zone.status-playing .seat-left{top:47%;left:8px}.table-zone.status-playing .seat-right{top:47%;right:8px}.table-zone.status-playing .seat-top{width:min(168px,61vw);top:3px}.table-zone.status-playing .seat-left .player-person,.table-zone.status-playing .seat-right .player-person{margin-bottom:-13px;transform:scale(.64)}.table-zone.status-playing .seat-top .player-person{transform:scale(.64)}.table-zone.status-playing .seat-left .player-pill,.table-zone.status-playing .seat-right .player-pill{width:70px;min-height:29px;padding:3px 4px}.table-zone.status-playing .table-seat .player-meta strong{font-size:.56rem}.table-zone.status-playing .table-seat .hand-count{gap:2px;min-width:28px;min-height:21px;padding:1px 3px;font-size:.6rem}.table-zone.status-playing .table-seat .hand-stack{flex-basis:13px;width:13px;height:15px}.table-zone.status-playing .table-seat .hand-stack i{border-radius:3px;width:9px;height:13px}.table-zone.status-playing .table-seat .hand-stack i:first-child{top:3px;left:0}.table-zone.status-playing .table-seat .hand-stack i:nth-child(2){top:1px;left:2px}.table-zone.status-playing .table-seat .hand-stack i:nth-child(3){top:3px;left:4px}.table-zone.status-playing .table-seat .hand-count-copy b{font-size:.62rem}.table-zone.status-playing .table-seat .hand-count-copy small{display:none}.table-zone.status-playing .center-stack{gap:4px;padding:78px 88px 38px}.table-zone.status-playing .timer-badge{min-height:26px;padding:0 7px;font-size:.72rem}.table-zone.status-playing .turn-callout{max-width:min(50vw,218px);min-height:31px;padding:4px 7px}.table-zone.status-playing .turn-callout strong{font-size:.7rem}.table-zone.status-playing .turn-callout span{font-size:.56rem}.table-zone.status-playing .play-pile{gap:5px;width:min(50vw,220px);min-height:92px;padding:7px}.table-zone.status-playing .pile-cards{min-height:54px}.table-zone.status-playing .pile-cards .card-view.is-compact{width:39px;height:58px}.table-zone.status-playing .pile-cards .card-view+.card-view{margin-left:-14px}.table-zone.status-playing .chat-panel:not(.is-open){bottom:0;right:10px}.hand-dock.status-playing{padding:5px 8px max(5px, env(safe-area-inset-bottom));gap:5px}.hand-dock.status-playing .self-row .player-pill{min-height:42px;padding:5px 7px}.hand-dock.status-playing .self-row .player-avatar{width:26px;height:26px}.hand-dock.status-playing .self-row .player-meta strong{font-size:.78rem}.hand-dock.status-playing .self-row .player-meta em{font-size:.64rem}.hand-dock.status-playing .self-row .hand-count{min-width:92px;min-height:32px;padding:3px 7px}.hand-dock.status-playing .hand-scroll{min-height:96px;padding:9px 10px 6px}.hand-dock.status-playing .card-view{width:62px;height:92px}.hand-dock.status-playing .hand-scroll .card-view+.card-view{margin-left:-30px}.hand-dock.status-playing .card-view.is-selected{transform:translateY(-11px)rotate(-1deg)}.hand-dock.status-playing .action-row .primary-action,.hand-dock.status-playing .action-row .secondary-action{min-height:42px}}@media (width<=900px){.table-seat .player-meta em{align-items:center;gap:2px;font-size:.54rem;line-height:1;display:inline-flex}.table-seat .player-meta em svg{width:10px;height:10px}.table-seat .player-meta em b{font-size:.5rem}.round-over .score-list{-webkit-overflow-scrolling:touch;max-height:min(36svh,220px);overflow-y:auto}}@media (width<=560px){.hand-dock.status-playing .hand-scroll{min-height:112px;padding:10px 14px 7px}.hand-dock.status-playing .card-view{flex-basis:64px;width:64px;height:94px}.hand-dock.status-playing .hand-scroll .card-view+.card-view,.hand-scroll .card-view+.card-view,.hand-scroll.is-short-hand .card-view+.card-view,.hand-dock.status-playing .hand-scroll.is-short-hand .card-view+.card-view{margin-left:7px}.table-zone.status-playing.is-chat-open .throw-panel{display:none}}.card-view.is-required{border-color:var(--matcha);animation:.98s ease-in-out infinite required-card-pulse;box-shadow:0 0 0 4px #24b87d47,0 12px #2a164433,0 18px 22px #24b87d3d}.card-view.is-required:after{content:"OPEN";z-index:3;color:#fff;background:linear-gradient(180deg, var(--matcha), var(--ink));border:2px solid #fffefae6;border-radius:999px;padding:2px 7px;font-size:.54rem;font-weight:950;position:absolute;bottom:-9px;left:50%;transform:translate(-50%);box-shadow:0 3px #2a16442e}.hint-text.is-opening-note,.hint-text.is-pass-note{width:min(100%,560px);color:var(--ink);text-shadow:none;background:linear-gradient(#fffefaf5,#fff1cceb);border:2px solid #2a16441a;border-radius:8px;justify-self:center;margin-top:0;padding:7px 10px}.hint-text.is-pass-note{border-color:#ff5d8f52}.secondary-action.is-pass-suggested{border-color:var(--strawberry);box-shadow:0 0 0 4px #ff5d8f2e,0 6px #2a164429}.table-seat.is-active{z-index:6}.table-seat.is-active .player-pill{border-color:var(--mango);box-shadow:0 0 0 4px #ffcf4a6b,0 0 0 8px #2fc8ef33,0 8px #2a164429,0 14px 24px #2a164433}.table-seat.is-active:after{content:"PLAYING";z-index:8;color:#fff;background:linear-gradient(180deg, var(--strawberry), var(--taro-dark));border:2px solid #fffefad1;border-radius:999px;padding:1px 8px;font-size:.54rem;font-weight:950;position:absolute;top:-12px;left:50%;transform:translate(-50%);box-shadow:0 3px #2a16442e}.player-meta strong,.score-row strong{white-space:normal;text-overflow:clip;line-height:1.05;overflow:visible}.player-meta em{flex-wrap:wrap;min-width:0}.player-person.is-damaged{filter:drop-shadow(0 9px 10px #2a16442e)saturate(1.35)contrast(1.08);animation:.68s cubic-bezier(.2,1.4,.22,1) both damage-shake}.player-person.is-damaged .person-body{box-shadow:inset 0 7px #fffefa40,inset 0 -7px #2a164424,0 0 0 4px #ff5d8f52,0 5px #2a16441f}.player-person.is-damaged .mouth{background:var(--avatar-accent);border:0;border-radius:999px;width:10px;height:9px;top:11px}.table-seat.is-damaged:before{content:"OOF!";z-index:9;color:#fff;background:linear-gradient(180deg, var(--strawberry), var(--ink));border:2px solid #fffefae6;border-radius:999px;padding:2px 7px;font-size:.58rem;font-weight:950;position:absolute;top:26px;right:-6px;transform:rotate(7deg);box-shadow:0 4px #2a164433}.reaction-burst{z-index:12;animation-duration:1.06s}.reaction-burst strong{letter-spacing:0;font-size:.72rem}.score-row span{white-space:nowrap;font-weight:900}@keyframes required-card-pulse{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes damage-shake{0%{transform:translate(0)rotate(0)scale(1)}16%{transform:translate(-8px,2px)rotate(-9deg)scale(1.06)}32%{transform:translate(7px,-3px)rotate(8deg)scale(.98)}48%{transform:translate(-5px,1px)rotate(-6deg)scale(1.04)}66%{transform:translate(4px,-1px)rotate(4deg)scale(1)}to{transform:translate(0)rotate(0)scale(1)}}@media (width<=900px){.score-row{grid-template-columns:minmax(0,1fr) auto;row-gap:2px;min-height:48px;padding-block:5px}.score-row .boba-avatar-chat{display:none}.score-row strong{grid-area:1/1;font-size:.78rem}.score-row em{grid-area:2/1;font-size:.72rem}.score-row span{grid-area:2/2;justify-self:end;font-size:.72rem}.score-row .ready-tag{grid-area:1/2;justify-self:end}.score-detail{grid-area:3/1/auto/-1;font-size:.64rem}}@media (width<=560px){.table-zone.status-playing .seat-self{display:none}.table-zone.status-playing .table-seat{width:98px}.table-zone.status-playing .seat-left{top:47%;left:6px}.table-zone.status-playing .seat-right{top:47%;right:6px}.table-zone.status-playing .seat-top{width:min(232px,68vw)}.table-zone.status-playing .seat-left .player-pill,.table-zone.status-playing .seat-right .player-pill{width:98px;min-height:42px;padding:5px 6px}.table-zone.status-playing .table-seat .player-meta strong{-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:2.15em;font-size:.64rem;display:-webkit-box;overflow:hidden}.table-zone.status-playing .table-seat .player-meta em{font-size:.52rem}.table-zone.status-playing .center-stack{padding-inline:106px}.table-zone.status-playing .play-pile{width:min(48vw,224px)}.table-seat.is-active:after{font-size:.48rem;top:-9px}.hand-dock.status-playing .self-row .player-meta strong{white-space:normal;line-height:1.05}.hand-dock.status-playing .self-row .player-meta em{font-size:.58rem}}@media (width<=380px){.table-zone.status-playing .table-seat,.table-zone.status-playing .seat-left .player-pill,.table-zone.status-playing .seat-right .player-pill{width:88px}.table-zone.status-playing .center-stack{padding-inline:92px}.table-zone.status-playing .play-pile{width:min(45vw,176px)}}@media (width<=560px){.table-zone.status-playing .table-seat{width:82px}.table-zone.status-playing .seat-left{top:46%;left:5px}.table-zone.status-playing .seat-right{top:46%;right:5px}.table-zone.status-playing .seat-left .player-pill,.table-zone.status-playing .seat-right .player-pill{grid-template-columns:minmax(0,1fr) auto;width:82px;min-height:36px;padding:4px 5px}.table-zone.status-playing .seat-left .player-meta strong,.table-zone.status-playing .seat-right .player-meta strong{white-space:normal;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:2.1em;font-size:.58rem;line-height:1.05;display:-webkit-box;overflow:hidden}.table-zone.status-playing .seat-left .player-meta em,.table-zone.status-playing .seat-right .player-meta em,.table-zone.status-playing .seat-left .bot-tag,.table-zone.status-playing .seat-right .bot-tag{display:none}.table-zone.status-playing .seat-top{width:min(214px,66vw)}.table-zone.status-playing .center-stack{padding-inline:88px}.table-zone.status-playing .play-pile{width:min(46vw,184px);min-width:0}}@media (width<=380px){.table-zone.status-playing .table-seat,.table-zone.status-playing .seat-left .player-pill,.table-zone.status-playing .seat-right .player-pill{width:76px}.table-zone.status-playing .seat-left .player-meta strong,.table-zone.status-playing .seat-right .player-meta strong{font-size:.54rem}.table-zone.status-playing .center-stack{padding-inline:80px}.table-zone.status-playing .play-pile{width:min(44vw,168px)}}.profile-editor.is-simple{gap:8px;padding:10px}.profile-editor.is-simple .avatar-picker{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.profile-editor.is-simple .avatar-picker button{min-height:70px;padding:6px 4px}.profile-editor.is-simple .boba-avatar-picker{width:38px;height:44px}.profile-editor.is-simple .avatar-picker-flavor{display:none}.home-choice{width:100%;min-height:76px;color:var(--ink);text-align:left;cursor:pointer;background:linear-gradient(#fffefafa,#fff0c7f0),linear-gradient(90deg,#ff5d8f24,#2fc8ef24);border:3px solid #2a16441f;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;padding:0 16px;display:grid;box-shadow:0 8px #2a164424,0 14px 24px #2a16441f}.home-choice.is-active{color:#fff;background:radial-gradient(circle at 20% 0%, #ffffff8c, transparent 28%), linear-gradient(135deg, var(--strawberry), var(--taro) 56%, var(--sky));box-shadow:0 8px 0 var(--taro-dark), 0 16px 28px #8756d947;border-color:#ffffff8c}.home-choice strong,.home-choice em{display:block}.home-choice strong{font-size:clamp(1.05rem,4.4vw,1.42rem);line-height:1.05}.home-choice em{color:currentColor;opacity:.72;text-transform:uppercase;margin-top:4px;font-size:.72rem;font-style:normal;font-weight:900}.mode-panel{border:2px solid var(--rim);box-shadow:var(--toy-shadow);background:linear-gradient(#fffefa,#fff2d6),repeating-linear-gradient(90deg,#ff5d8f0f 0 14px,#2fc8ef0f 14px 28px);border-radius:8px;gap:10px;padding:12px;display:grid}.mode-panel-heading{justify-content:space-between;align-items:center;gap:8px;display:flex}.mode-panel-heading strong{color:var(--taro-dark);text-transform:uppercase;font-size:.84rem;font-weight:950}.mode-panel-heading button{min-height:30px;color:var(--muted);cursor:pointer;background:#fff;border:2px solid #2a16441f;border-radius:8px;padding:0 10px;font-size:.72rem;font-weight:900}.mode-helper{color:var(--muted);background:#ffffffb8;border:2px dashed #2a164429;border-radius:8px;margin:0;padding:9px 10px;font-size:.74rem;font-weight:850;line-height:1.25}.mode-helper.is-offline{color:var(--strawberry-dark);background:linear-gradient(#fff9fb,#fff0d7);border-color:#ff5d8652}.mode-helper.is-name-required{color:var(--taro-dark);background:linear-gradient(#fffefa,#fff1cc);border-color:#ffcf4a75}.offline-solo-action{justify-self:stretch}.session-presets{gap:7px;display:grid}.session-presets button{min-height:58px;color:var(--ink);text-align:left;cursor:pointer;background:linear-gradient(#fff,#fff6df);border:2px solid #2a16441f;border-radius:8px;gap:3px;padding:8px 10px;display:grid;box-shadow:0 5px #2a16441a}.session-presets button.is-active{border-color:var(--strawberry);background:linear-gradient(#fff8fb,#ffd9e8);box-shadow:0 3px #2a16441f,0 0 0 4px #ff5d8f24}.session-presets strong{font-size:.86rem;font-weight:950}.session-presets span{color:var(--muted);font-size:.7rem;font-weight:850}.setting-field{color:var(--muted);text-transform:uppercase;gap:6px;font-size:.74rem;font-weight:900;display:grid}.setting-field select{min-height:42px;color:var(--ink);font:inherit;text-transform:none;background:linear-gradient(#fff,#fff7df);border:2px solid #2a164424;border-radius:8px;padding:0 10px;font-size:.86rem}.session-status{min-height:34px;color:var(--ink);background:linear-gradient(#fff,#fff4d7);border:2px solid #2a16441a;border-radius:8px;flex-wrap:wrap;justify-content:center;align-items:center;gap:8px;padding:6px 10px;font-size:.76rem;display:flex;box-shadow:0 4px #2a164414}.session-status strong{color:var(--strawberry-dark);text-transform:uppercase;font-weight:950}.session-status span{color:var(--muted);font-weight:850}.session-status.is-complete{background:linear-gradient(#fff,#dcffe8);border-color:#22bf856b}.cashout-card{background:linear-gradient(#fff,#fff5dc),radial-gradient(circle at 15% 0,#ffcf4a38,#0000 34%);border:2px solid #22bf854d;border-radius:8px;gap:6px;padding:10px;display:grid;box-shadow:0 5px #2a16441a}.cashout-card>span{color:var(--matcha-dark);text-align:center;text-transform:uppercase;font-size:.72rem;font-weight:950}.cashout-card div{background:#ffffffbd;border:1px solid #2a164414;border-radius:8px;grid-template-columns:32px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:30px;padding:0 8px;display:grid}.cashout-card b{color:var(--strawberry-dark)}.cashout-card strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cashout-card em{color:var(--ink);font-style:normal;font-weight:950}@media (width<=560px){.home-panel{gap:10px}.home-choice{min-height:66px;padding:0 12px}.profile-editor.is-simple{padding:8px}.profile-editor.is-simple .avatar-picker button{min-height:58px}.profile-editor.is-simple .boba-avatar-picker{width:32px;height:38px}.profile-editor.is-simple .avatar-picker-name{font-size:.56rem}.mode-panel{padding:10px}.invite-recovery-actions{grid-template-columns:1fr}}@media (width<=900px){.icon-button,.brand-chip,.primary-action,.secondary-action,.hero-action.compact,.chat-toggle,.throw-target,.throw-actions button,.difficulty-tabs button,.mode-panel-heading button,.profile-editor input,.invite-link-input,.tutorial-card summary{min-height:44px}.icon-button,.brand-chip{min-width:44px}.room-chip{min-height:44px}.difficulty-tabs,.bot-difficulty-control .difficulty-tabs{min-height:52px}.invite-actions>button,.start-actions .hero-action,.bot-fill-action,.hand-dock.status-playing .action-row .primary-action,.hand-dock.status-playing .action-row .secondary-action,.chat-panel.is-open .chat-toggle,.chat-panel.is-open .chat-form input,.chat-panel.is-open .chat-form button,.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-form input,.table-zone.status-playing.is-chat-open .chat-panel.is-open .chat-form button{min-height:44px}.chat-panel.is-open .chat-form{grid-template-columns:minmax(0,1fr) 44px}.table-zone.status-playing .chat-panel:not(.is-open) .chat-toggle{min-width:48px;min-height:48px}.throw-target{padding-inline:10px}}@media (width<=560px){.hand-dock.status-playing .hand-scroll{min-height:124px;padding:12px 14px 8px;scroll-padding-inline:14px}.hand-dock.status-playing .card-view{flex:0 0 70px;width:70px;height:104px}.hand-dock.status-playing .hand-scroll .card-view+.card-view,.hand-scroll .card-view+.card-view,.hand-scroll.is-short-hand .card-view+.card-view,.hand-dock.status-playing .hand-scroll.is-short-hand .card-view+.card-view{margin-left:10px}.hand-dock.status-playing .card-view.is-selected{transform:translateY(-14px)rotate(-1deg)}}
