:root{--felt: #0b3d2e;--felt-2: #0f4d3a;--felt-edge: #072b20;--wood: #5a3a22;--gold: #e0b44a;--gold-soft: #f2d78a;--paper: #fbf7ec;--ink: #1c1c1c;--text: #f4f1e8;--text-dim: #c9d6cd;--accent: #d9822b;--danger: #c0392b;--success: #2e9e5b;--info: #2c6fb0;--radius: 14px;--shadow: 0 8px 24px rgba(0, 0, 0, .35);--table-free: calc(100vh - 302px) ;--card-xl: min(clamp(110px, 18vw, 300px), calc(var(--table-free) * .23));--card-lg: min(clamp(96px, 15vw, 230px), calc(var(--table-free) * .16));--card-md: min(clamp(80px, 10vw, 130px), 10.5vh);--card-sm: min(clamp(54px, 6.5vw, 84px), 64px);--font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Segoe UI", system-ui, Roboto, Helvetica, Arial, sans-serif;--glass: rgba(10, 30, 22, .55);--glass-border: rgba(255, 255, 255, .12);--shadow-soft: 0 10px 30px rgba(0, 0, 0, .28), 0 1px 0 rgba(255, 255, 255, .05) inset}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);color:var(--text);background:radial-gradient(circle at 50% 20%,var(--felt-2),var(--felt) 55%,var(--felt-edge) 100%);min-height:100dvh}.app{min-height:100dvh;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}body{overscroll-behavior:none}.card,.btn,.seg__btn,.quickchat__btn,.lang-btn,.table,.lobby__swap{touch-action:manipulation}.table,.card,.trick-area,.hand{-webkit-user-select:none;user-select:none}h1,h2,h3{margin:0 0 .4em}a{color:var(--gold-soft)}.btn{font:inherit;font-weight:600;letter-spacing:.01em;border:none;border-radius:14px;padding:.75rem 1.35rem;cursor:pointer;color:#fff;background:var(--accent);transition:transform .12s cubic-bezier(.2,.8,.2,1),filter .15s ease,box-shadow .15s ease;box-shadow:0 6px 18px #00000038,0 1px #ffffff2e inset;min-height:46px}.btn:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(1px) scale(.99);filter:brightness(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:linear-gradient(180deg,#e79a3d,var(--accent))}.btn--secondary{background:linear-gradient(180deg,#2f7d5b,#1f5f43)}.btn--ghost{background:transparent;color:var(--gold-soft);border:1px solid rgba(224,180,74,.5);box-shadow:none}.btn--danger{background:linear-gradient(180deg,#d64c3c,var(--danger))}.btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.home{max-width:560px;margin:0 auto;padding:2rem 1.2rem 3rem;width:100%}.home__header{text-align:center;margin-bottom:1.5rem}.home__title{font-size:clamp(2.2rem,6vw,3rem);color:var(--gold);letter-spacing:.02em;text-shadow:0 2px 0 rgba(0,0,0,.3)}.home__subtitle{color:var(--text-dim);margin:0}.conn{display:inline-block;margin-top:.8rem;font-size:.82rem;padding:.2rem .7rem;border-radius:999px;background:#00000040}.conn--on{color:#9fe6b8}.conn--off{color:#f0c674}.home__card{background:var(--glass);-webkit-backdrop-filter:blur(22px) saturate(1.3);backdrop-filter:blur(22px) saturate(1.3);border:1px solid var(--glass-border);border-radius:20px;padding:1.5rem;box-shadow:var(--shadow-soft)}.home__section{margin-top:1rem}.home__section-title{font-size:1rem;color:var(--gold-soft)}.home__buttons{display:flex;flex-direction:column;gap:.6rem}.home__buttons .btn{width:100%}.home__divider{text-align:center;color:var(--text-dim);margin:1.2rem 0 .4rem;position:relative}.home__join{display:flex;gap:.5rem}.home__join .btn{white-space:nowrap}.home__resume{margin-top:1rem;text-align:center}.field{display:block;margin-bottom:.4rem}.field__label{display:block;font-size:.85rem;color:var(--text-dim);margin-bottom:.3rem}.field__input{width:100%;font:inherit;padding:.7rem .9rem;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#fffffff2;color:var(--ink);min-height:44px}.field__input--code{text-transform:uppercase;letter-spacing:.25em;font-weight:700;text-align:center}.field__input:focus-visible{outline:3px solid var(--gold-soft);outline-offset:1px}.home__rules{margin-top:1.4rem;background:#0003;border-radius:10px;padding:.6rem 1rem}.home__rules summary{cursor:pointer;font-weight:600;color:var(--gold-soft)}.home__rules ul{margin:.6rem 0 .2rem;padding-left:1.1rem;color:var(--text-dim);line-height:1.5}.home__footer{text-align:center;margin-top:1.4rem;font-size:.85rem}.home__version{display:block;margin-top:.4rem;color:var(--text-dim);font-size:.72rem;opacity:.65;letter-spacing:.04em;font-variant-numeric:tabular-nums}.lobby{max-width:520px;margin:0 auto;padding:2rem 1.2rem;width:100%}.lobby__title{text-align:center;color:var(--gold)}.lobby__code{background:#00000047;border-radius:var(--radius);padding:1.2rem;text-align:center;margin-bottom:1.2rem;border:1px solid rgba(224,180,74,.25)}.lobby__code-label{display:block;color:var(--text-dim);font-size:.85rem}.lobby__code-value{display:flex;align-items:center;justify-content:center;gap:.8rem;margin-top:.4rem}.lobby__code-value code{font-size:2.2rem;font-weight:800;letter-spacing:.3em;color:var(--gold-soft);background:#0000004d;padding:.2rem .6rem .2rem .9rem;border-radius:10px}.lobby__hint{color:var(--text-dim);font-size:.85rem;margin:.6rem 0 0}.lobby__players{background:#0003;border-radius:var(--radius);padding:1rem 1.2rem}.lobby__players ul{list-style:none;margin:.6rem 0 0;padding:0}.lobby__player{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.08)}.lobby__player--waiting{color:var(--text-dim);font-style:italic}.dot{width:10px;height:10px;border-radius:50%;background:#888;flex:0 0 auto}.dot--on{background:var(--success);box-shadow:0 0 8px #2e9e5bcc}.dot--off{background:var(--danger)}.dot--wait{background:var(--gold);animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.badge{font-size:.7rem;background:#ffffff26;border-radius:999px;padding:.1rem .5rem;text-transform:uppercase;letter-spacing:.04em}.badge--host{background:#e0b44a4d;color:var(--gold-soft)}.lobby__actions{display:flex;flex-direction:column;gap:.7rem;margin-top:1.2rem;align-items:stretch}.lobby__wait-host{text-align:center;color:var(--text-dim)}.card{position:relative;aspect-ratio:2 / 3;border-radius:8px;padding:0;border:none;background:transparent;flex:0 0 auto}.card--sm{width:var(--card-sm)}.card--md{width:var(--card-md)}.card--lg{width:var(--card-lg)}.card--xl{width:var(--card-xl)}.card__img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 4px 6px rgba(0,0,0,.4));border-radius:8px}.card--playable{cursor:pointer;transition:transform .12s ease}.card--playable:hover,.card--playable:focus-visible{transform:translateY(-14px) scale(1.04);outline:none}.card--playable:focus-visible .card__img{outline:3px solid var(--gold-soft);outline-offset:2px}.card--playable:active{transform:translateY(-6px) scale(.99)}.card--static{opacity:.98}.card__points{position:absolute;bottom:-9px;left:50%;transform:translate(-50%);background:linear-gradient(180deg,#f6dd9b,#dfae37);color:#3a2c07;font-size:.68rem;font-weight:800;border-radius:999px;min-width:20px;height:19px;display:grid;place-items:center;padding:0 6px;border:1px solid rgba(90,60,10,.55);box-shadow:0 2px 5px #00000073;z-index:2}.hand .card:not(.card--playable) .card__img{filter:drop-shadow(0 4px 6px rgba(0,0,0,.4)) grayscale(.25) brightness(.9)}.hand{display:flex;justify-content:center;gap:.6rem;flex-wrap:wrap;padding:.4rem}.hand--empty{color:var(--text-dim);font-style:italic}.opp-fan,.side-player__fan{position:relative;width:calc(var(--card-sm) * 2.1);height:calc(var(--card-sm) * 1.62);margin:0 auto}.opp-fan__card,.side-player__fan-card{position:absolute;left:50%;bottom:0;margin-left:calc(var(--card-sm) * -.5);transform-origin:50% 112%}.table{flex:1;display:flex;flex-direction:column;gap:.35rem;padding:.45rem clamp(.5rem,3vw,1.5rem) .5rem;max-width:1280px;margin:0 auto;width:100%}.table__topbar{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.table__topbar .table__opponent{flex:1;min-width:0;text-align:center}.table__quit{padding:.3rem .75rem;min-height:32px;font-size:.82rem;color:#e29a9a;border:1px solid rgba(226,110,110,.35);background:transparent;opacity:.85}.table__quit:hover{background:#e26e6e26;opacity:1}.table__opponent,.table__hand{text-align:center}.table__hand{height:calc(var(--card-xl) * 1.5 + 18px);overflow:visible}.table__player-label{font-size:.85rem;color:var(--text-dim);margin-bottom:.2rem}.table__middle{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.table__middle>.side-player{flex:0 0 auto}.table__center{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:clamp(.4rem,1.2vh,.8rem);flex:1;min-width:0;align-self:stretch;padding:.5rem clamp(.5rem,1.5vw,.9rem)}.table__center>.trump-pile{align-self:center}.trump-pile{display:flex;flex-direction:row;align-items:center;gap:.6rem}.trump-pile__stack{position:relative;width:calc(var(--card-xl) * 1.7);height:calc(var(--card-xl) * 1.55)}.trump-pile__trump{position:absolute;left:30%;top:12%;transform:rotate(90deg);transform-origin:center}.trump-pile__deck{position:absolute;left:0;top:0}.trump-pile__count{position:absolute;right:8px;bottom:8px;background:#0000009e;color:var(--gold-soft);font-size:.85rem;font-weight:800;font-variant-numeric:tabular-nums;border-radius:999px;padding:.1rem .5rem;pointer-events:none}.trump-pile__meta{display:none}.chip{font-size:.78rem;background:#00000059;padding:.2rem .6rem;border-radius:999px;white-space:nowrap}.chip--accent{background:#e0b44a40;color:var(--gold-soft);font-weight:600}.trick-area{display:flex;gap:clamp(.5rem,1.5vw,1rem);align-items:center;justify-content:center;width:100%;min-width:0;flex-wrap:nowrap;height:calc(var(--card-lg) * 1.5 + 30px)}.trick-area--4{gap:0}.trick-area--4 .trick-area__slot+.trick-area__slot{margin-left:calc(var(--card-lg) * -.32)}@media (max-width: 640px){.trick-area--4 .trick-area__slot+.trick-area__slot{margin-left:calc(var(--card-lg) * -.52)}}.trick-area__hint{color:var(--text-dim);font-style:italic}.trick-area__slot{display:flex;flex-direction:column;align-items:center;gap:.25rem;animation:drop-in .25s ease}.trick-area__who{font-size:.72rem;color:var(--text-dim)}.trick-area__slot--winner .card__img{outline:3px solid var(--gold);outline-offset:2px;border-radius:8px;box-shadow:0 0 16px #e0b44a99}@keyframes drop-in{0%{transform:translateY(-16px) scale(.9);opacity:0}to{transform:none;opacity:1}}.score-panel{background:#0000004d;border-radius:12px;padding:.35rem .65rem;min-width:185px;font-size:.9rem}.score-panel__row{display:flex;justify-content:space-between;gap:1rem;padding:.2rem .3rem;border-radius:8px}.score-panel__row--active{background:#e0b44a2e}.score-panel__name{font-weight:600}.score-panel__tag{font-weight:400;color:var(--text-dim);font-size:.8rem}.score-panel__tag--warn{color:#f0a24a}.score-panel__turn{color:var(--gold)}.score-panel__points{font-variant-numeric:tabular-nums;font-weight:800;color:var(--gold-soft)}.score-panel__total{font-size:.72rem;color:var(--text-dim);text-align:right;margin-top:.2rem}.status-bar{text-align:center;font-weight:700;padding:.3rem;letter-spacing:.02em}.status-bar--you{color:#a9edc2}.status-bar--them{color:#d9c9a1}.status-bar--neutral{color:var(--text-dim, #9aa3b2)}.history{position:relative;background:#00000038;border-radius:12px;padding:.45rem .9rem;font-size:.82rem}.history__pop{position:absolute;bottom:calc(100% + 10px);left:0;min-width:min(400px,84vw);width:max-content;max-width:min(560px,88vw);max-height:min(46vh,420px);overflow-y:auto;background:#0b2018;border:1px solid rgba(255,255,255,.16);border-radius:14px;box-shadow:0 12px 36px #0000008c;padding:.65rem .85rem;z-index:30}.history__title{font-size:.85rem;color:var(--gold-soft);cursor:pointer;-webkit-user-select:none;user-select:none}.history__empty{color:var(--text-dim);margin:0}.history__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem}.history__item{display:flex;gap:.5rem;align-items:baseline;color:var(--text-dim)}.history__no{color:var(--gold);font-weight:700;min-width:2rem}.history__cards{flex:0 0 auto}.history__winner{color:var(--text);font-weight:600}.toast{position:fixed;left:50%;bottom:1.4rem;transform:translate(-50%);padding:.7rem 1.2rem;border-radius:999px;font-weight:600;color:#fff;box-shadow:var(--shadow);z-index:50;animation:toast-in .2s ease;max-width:90vw;text-align:center}.toast--info{background:var(--info)}.toast--success{background:var(--success)}.toast--error{background:var(--danger)}@keyframes toast-in{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:grid;place-items:center;z-index:40;padding:1rem;animation:toast-in .2s ease}.round-end{background:linear-gradient(180deg,#123f30,#0b3226);border:1px solid rgba(224,180,74,.35);border-radius:18px;padding:2rem 1.6rem;max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow)}.round-end__title{color:var(--gold)}.round-end__result{font-size:1.3rem;font-weight:800;margin:.4rem 0 1.2rem}.round-end--win .round-end__result{color:#9fe6b8}.round-end--lose .round-end__result{color:#f0a24a}.round-end--tie .round-end__result{color:var(--gold-soft)}.round-end__scores{display:flex;align-items:center;justify-content:center;gap:1.2rem;margin-bottom:.4rem}.round-end__score{display:flex;flex-direction:column}.round-end__name{color:var(--text-dim);font-size:.85rem}.round-end__points{font-size:2rem;font-weight:800;color:var(--gold-soft)}.round-end__vs{color:var(--text-dim)}.round-end__total{color:var(--text-dim);font-size:.85rem;margin-bottom:1.4rem}.round-end__actions{display:flex;flex-direction:column;gap:.6rem}.round-end__wait{color:var(--text-dim)}@media (max-width: 640px){:root{--card-xl: 108px;--card-lg: 96px;--card-md: 68px;--card-sm: 46px}.table__center{gap:.5rem}.home__join{flex-direction:column}.lobby__code-value code{font-size:1.6rem}}@media (max-width: 380px){:root{--card-xl: 92px;--card-lg: 80px;--card-md: 58px}}.home__topbar{display:flex;justify-content:center;margin-bottom:.4rem}.lang-switch{display:inline-flex;gap:.35rem;background:#00000040;padding:.3rem;border-radius:999px}.lang-btn{display:inline-flex;align-items:center;gap:.35rem;border:1px solid transparent;background:transparent;color:var(--text-dim);border-radius:999px;padding:.25rem .6rem;cursor:pointer;font:inherit;font-size:.8rem;font-weight:700;min-height:36px;transition:background .15s ease,color .15s ease}.lang-btn:hover{color:var(--text)}.lang-btn--active{background:#e0b44a38;color:var(--gold-soft);border-color:#e0b44a80}.lang-btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.flag{width:22px;height:15px;border-radius:2px;display:block;box-shadow:0 0 0 1px #0000004d}.lang-btn__code{letter-spacing:.05em}.home__panel{margin-top:1rem;background:#0003;border-radius:10px;padding:.6rem 1rem}.home__panel summary{cursor:pointer;font-weight:600;color:var(--gold-soft)}.home__rules-list{margin:.6rem 0 .2rem;padding-left:1.1rem;color:var(--text-dim);line-height:1.5}.settings{margin-top:.8rem;display:flex;flex-direction:column;gap:.8rem}.settings__row{display:flex;flex-direction:column;gap:.4rem}.settings__label{color:var(--text-dim);font-size:.9rem}.settings__hint{color:var(--text-dim);font-size:.85rem;margin:0;font-style:italic}.settings__row--slider input[type=range]{width:100%;accent-color:var(--accent)}.seg{display:inline-flex;background:#0000004d;border-radius:999px;padding:.2rem;gap:.2rem;align-self:flex-start}.seg__btn{border:none;background:transparent;color:var(--text-dim);font:inherit;font-weight:600;padding:.4rem 1rem;border-radius:999px;cursor:pointer;min-height:38px}.seg__btn--active{background:var(--accent);color:#fff}.seg__btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.table__statusrow{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:.6rem;min-height:46px}.table__statusrow .status-bar{position:absolute;left:50%;transform:translate(-50%);width:max-content;max-width:min(72vw,600px)}@media (max-width: 640px){.table__statusrow .status-bar{position:static;transform:none;flex:1;width:auto;max-width:none}}.table__continue{white-space:nowrap;animation:pulse-btn 1.4s ease-in-out infinite}@keyframes pulse-btn{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}.deck-picker{display:flex;gap:.6rem}.deck-opt{flex:1;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.5rem;border-radius:14px;border:1.5px solid transparent;background:#ffffff0d;cursor:pointer;font:inherit;color:var(--text-dim);transition:transform .12s ease,border-color .15s ease,background .15s ease}.deck-opt:hover{transform:translateY(-2px);color:var(--text)}.deck-opt--active{border-color:var(--gold);background:#e0b44a24;color:var(--gold-soft)}.deck-opt__preview{width:52px;height:78px;border-radius:7px;box-shadow:0 4px 10px #00000059;display:block}.deck-opt__name{font-size:.8rem;font-weight:600}.deck-opt:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.settings__saved{font-size:.78rem;color:var(--text-dim);margin:.2rem 0 0;display:flex;align-items:center;gap:.3rem}.settings__saved:before{content:"✓";color:var(--success);font-weight:800}.countdown{position:relative;width:46px;height:46px;flex:0 0 auto;display:grid;place-items:center}.countdown__ring{width:46px;height:46px;transform:none}.countdown__track{fill:none;stroke:#ffffff24;stroke-width:4}.countdown__prog{fill:none;stroke:var(--gold);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .08s linear}.countdown__num{position:absolute;font-size:.72rem;font-weight:700;color:var(--gold-soft);font-variant-numeric:tabular-nums}.lobby__code,.lobby__players,.home__panel,.score-panel,.history{background:var(--glass);-webkit-backdrop-filter:blur(20px) saturate(1.25);backdrop-filter:blur(20px) saturate(1.25);border:1px solid var(--glass-border);box-shadow:var(--shadow-soft)}.round-end{-webkit-backdrop-filter:blur(24px) saturate(1.3);backdrop-filter:blur(24px) saturate(1.3)}.field__input{border-radius:14px}.home__title{letter-spacing:-.02em}.status-bar{border-radius:14px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.hand__slot{display:inline-block;animation:deal-in .38s cubic-bezier(.2,.8,.2,1) both}@keyframes deal-in{0%{opacity:0;transform:translateY(28px) rotate(2deg) scale(.92)}}.conn-banner{position:fixed;top:env(safe-area-inset-top,0);left:0;right:0;z-index:80;background:linear-gradient(180deg,#c8473b,#b3352f);color:#fff;font-weight:700;text-align:center;padding:.45rem 1rem;box-shadow:0 4px 14px #00000059;animation:toast-in .2s ease}.score-panel__match{font-size:.75rem;font-weight:700;color:var(--gold-soft);text-align:right;margin-top:.15rem}.round-end__match{color:var(--gold-soft);font-weight:700;font-size:.95rem;margin:0 0 1.1rem}.home__mode-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:.5rem}.seg--small .seg__btn{padding:.28rem .7rem;min-height:32px;font-size:.85rem}.badge--team1{background:#2f6fc059;color:#bcd6ff}.badge--team2{background:#cc383859;color:#ffb3b3}.side-player{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.5rem .6rem;border-radius:12px;width:max(clamp(74px,9vw,112px),calc(var(--card-sm) * 2.3));box-sizing:border-box}.side-player__name{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-player--active{background:#e0b44a26;box-shadow:0 0 0 1.5px #e0b44a73}.side-player__name{font-size:.75rem;color:var(--text-dim);max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table__partner-tag{color:var(--gold-soft);font-weight:700}.table__footer{display:flex;align-items:flex-start;gap:.5rem}.table__footer .history{flex:1;min-width:0}.table__footer .quickchat{flex:none}.table__bottombar{display:flex;justify-content:center}.quickchat{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;background:#00000038;border-radius:999px;padding:.3rem .5rem}.quickchat__btn{font:inherit;font-size:.82rem;font-weight:600;color:var(--text);background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:.3rem .75rem;cursor:pointer;transition:background .15s ease,transform .1s ease;min-height:34px}.quickchat__btn:hover{background:#e0b44a38;transform:translateY(-1px)}.quickchat__btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.chat-bubbles{position:fixed;top:calc(158px + env(safe-area-inset-top,0px));left:16px;z-index:70;display:flex;flex-direction:column;gap:.35rem;align-items:flex-start;max-width:min(46vw,340px);pointer-events:none}.chat-bubble{background:#0f2d23eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,180,74,.4);border-radius:999px;padding:.35rem .9rem;box-shadow:var(--shadow);animation:bubble-in .2s ease;font-size:.9rem}@keyframes bubble-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-bubble--mine{border-color:#2e9e5b99}.chat-bubble__name{color:var(--gold-soft);font-weight:700;margin-right:.45rem}.chat-bubble__name:after{content:" ·";color:var(--text-dim)}.lb{width:100%;border-collapse:collapse;margin-top:.7rem;font-size:.9rem}.lb th,.lb td{padding:.35rem .5rem;text-align:center}.lb th{color:var(--gold-soft);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(224,180,74,.3)}.lb tbody tr:nth-child(odd){background:#ffffff0a}.lb tbody tr:first-child .lb__name:after{content:" 👑"}.lb__rank{color:var(--text-dim);width:2rem}.lb__name{text-align:left!important;font-weight:600}.lb__empty{color:var(--text-dim);font-style:italic;margin:.7rem 0 .2rem}@media (max-width: 640px){.side-player{min-width:56px}.quickchat__btn{font-size:.75rem;padding:.25rem .55rem}}.home__options{display:flex;flex-direction:column;gap:.55rem;margin:.2rem 0 .7rem}.home__check{display:flex;align-items:center;gap:.5rem;color:var(--text-dim);font-size:.9rem;cursor:pointer}.home__check input{width:18px;height:18px;accent-color:var(--accent)}.home__target{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.open-games{list-style:none;margin:.7rem 0 0;padding:0;display:flex;flex-direction:column;gap:.45rem}.open-games__item{display:flex;align-items:center;gap:.55rem;background:#ffffff0d;border-radius:12px;padding:.45rem .7rem}.open-games__host{font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.open-games__seats{color:var(--gold-soft);font-weight:700;font-variant-numeric:tabular-nums}.open-games__join{padding:.35rem .9rem;min-height:36px}.my-stats{margin:-.1rem 0 .5rem;font-size:.8rem;color:var(--gold-soft);font-variant-numeric:tabular-nums}.hand__slot--hint .card__img{outline:3px solid var(--gold);outline-offset:3px;border-radius:8px;animation:hint-pulse .9s ease-in-out infinite}@keyframes hint-pulse{0%,to{box-shadow:0 0 6px #e0b44a80}50%{box-shadow:0 0 22px #e0b44af2}}.table__hint,.table__seven{padding:.4rem .85rem;min-height:38px;white-space:nowrap;font-size:.85rem}.trick-area--collect .trick-area__slot{animation:none}.trick-area--collect-down .trick-area__slot{animation:fly-down .38s cubic-bezier(.5,0,.9,.4) forwards}.trick-area--collect-up .trick-area__slot{animation:fly-up .38s cubic-bezier(.5,0,.9,.4) forwards}.trick-area--collect-left .trick-area__slot{animation:fly-left .38s cubic-bezier(.5,0,.9,.4) forwards}.trick-area--collect-right .trick-area__slot{animation:fly-right .38s cubic-bezier(.5,0,.9,.4) forwards}@keyframes fly-down{to{transform:translateY(42vh) rotate(4deg) scale(.4);opacity:0}}@keyframes fly-up{to{transform:translateY(-38vh) rotate(-4deg) scale(.4);opacity:0}}@keyframes fly-left{to{transform:translate(-42vw) rotate(-6deg) scale(.4);opacity:0}}@keyframes fly-right{to{transform:translate(42vw) rotate(6deg) scale(.4);opacity:0}}.history__mini{width:30px;border-radius:3px;margin-right:3px;vertical-align:middle;box-shadow:0 1px 3px #00000073}.history__mini--win{outline:2px solid var(--gold);outline-offset:1px}.history__item{align-items:center}.lobby__swap{margin-left:auto;font:inherit;font-size:1rem;color:var(--gold-soft);background:#e0b44a26;border:1px solid rgba(224,180,74,.4);border-radius:8px;padding:.1rem .55rem;cursor:pointer;min-height:30px}.lobby__swap:hover{background:#e0b44a4d}@media (max-height: 780px){:root{--table-free: calc(100vh - 284px) }.table__center{padding:.35rem .6rem;gap:.3rem}.table{gap:.25rem}.table__player-label{font-size:.72rem;margin-bottom:.05rem}.score-panel__total{display:none}.status-bar{padding:.32rem;font-size:.9rem}.trick-area__who{font-size:.66rem}.quickchat__btn{min-height:30px;padding:.2rem .55rem;font-size:.75rem}.history{padding:.3rem .7rem}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}.table__waiting{color:var(--muted, #9aa3b2);font-style:italic;font-size:.85rem;white-space:nowrap}.quickchat{position:relative}.quickchat__toggle{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.14);background:#00000040;font-size:1.1rem;cursor:pointer;line-height:1}.quickchat__toggle:hover{background:#0006}.quickchat__palette{position:absolute;bottom:calc(100% + 10px);right:0;display:grid;grid-template-columns:repeat(3,1fr);gap:.45rem;width:max-content;max-width:min(84vw,460px);padding:.55rem;border-radius:14px;background:#0b2018;border:1px solid rgba(255,255,255,.16);box-shadow:0 12px 36px #0000008c;z-index:30}.quickchat__palette .quickchat__btn{width:100%;white-space:nowrap;text-align:center}
