@font-face{font-family:Cinzel;src:url(/fonts/cinzel-700.woff2) format("woff2");font-weight:400 900;font-style:normal;font-display:swap}:root{--felt: #0a4331;--felt-2: #12583f;--felt-edge: #04231a;--wood: #5a3a22;--rail: #2e1c10;--brass: #c9a24b;--gold: #e0b44a;--gold-soft: #f2d78a;--gold-hi: #fdeec0;--gold-deep: #b8862f;--gold-metal: linear-gradient(180deg, #fdeec0 0%, #ecc768 40%, #c9962f 100%);--gold-metal-sheen: linear-gradient(180deg, #fff6d8 0%, #e9c15e 46%, #b98a2d 100%);--paper: #fbf7ec;--ink: #1c1c1c;--text: #f4f1e8;--text-dim: #d3c9b0;--accent: #d9822b;--danger: #c0392b;--success: #2e9e5b;--info: #2c6fb0;--radius: 14px;--shadow: 0 8px 24px rgba(0, 0, 0, .35);--table-free: calc(100dvh - 302px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) ;--card-xl: min(clamp(110px, 18vw, 300px), calc(var(--table-free) * .23));--card-lg: min(clamp(104px, 16vw, 240px), calc(var(--table-free) * .185));--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;--font-display: "Cinzel", "Trajan Pro", Georgia, "Times New Roman", serif;--tracking-caps: .14em;--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;--sp-1: .25rem;--sp-2: .5rem;--sp-3: .75rem;--sp-4: 1rem;--sp-6: 1.5rem;--shadow-1: 0 1px 2px rgba(0, 0, 0, .25);--shadow-2: 0 4px 12px rgba(0, 0, 0, .3);--shadow-3: 0 12px 36px rgba(0, 0, 0, .5);--hairline-gold: 1px solid rgba(242, 215, 138, .32);--ring-gold: 0 0 0 1.5px rgba(242, 215, 138, .55);--surface-1: rgba(7, 28, 20, .5);--surface-2: rgba(6, 24, 17, .62);--panel: linear-gradient(180deg, rgba(16, 63, 46, .66), rgba(9, 38, 28, .72));--panel-radius: 16px;--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--dur-press: .12s;--dur-ui: .22s;--dur-card: .38s;--us: #3d72b4;--them-c: #d9694f}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font);color:var(--text);background:radial-gradient(72% 52% at 50% 34%,rgba(255,238,200,.14),transparent 58%),radial-gradient(128% 108% at 50% 42%,transparent 38%,rgba(0,0,0,.72) 100%),radial-gradient(circle at 50% 24%,var(--felt-2),var(--felt) 52%,var(--felt-edge) 100%);background-attachment:fixed;min-height:100dvh}.app{position:relative;z-index:1;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)}.error-boundary{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:grid;place-items:center;padding:2rem}.error-boundary__card{max-width:440px;text-align:center;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:2rem 1.6rem;box-shadow:var(--shadow-3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.error-boundary__emoji{font-size:2.6rem;margin-bottom:.4rem}.error-boundary__card h1{font-size:1.35rem}.error-boundary__card p{color:var(--text-dim);margin:.6rem 0 1.4rem;line-height:1.5}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:#3a2a05;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{filter:grayscale(.4) brightness(.72);opacity:.72;cursor:not-allowed}.btn--primary{position:relative;overflow:hidden;color:#3a2a05;font-weight:800;background:linear-gradient(180deg,#f6dd95,#e0b44a);box-shadow:0 4px #9a6f24,0 8px 18px #00000059,inset 0 1px #fff6,0 0 0 1px #f2d78a80}.btn--primary:active:not(:disabled){transform:translateY(3px);box-shadow:0 1px #9a6f24,0 3px 8px #0000004d}.btn--primary:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.5) 50%,transparent 60%);transform:translate(-120%);pointer-events:none}.btn--primary:hover:not(:disabled):after{animation:sheen .7s var(--ease-out)}@keyframes sheen{to{transform:translate(120%)}}.btn--secondary{background:linear-gradient(180deg,#1a6048,#124436);border:1px solid rgba(242,215,138,.35);color:#fff}.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));color:#fff}.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-family:var(--font-display);font-weight:700;font-size:clamp(2.4rem,6.5vw,3.6rem);line-height:1.04;letter-spacing:.02em;background:var(--gold-metal-sheen);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;text-shadow:none;filter:drop-shadow(0 2px 1px rgba(0,0,0,.5)) drop-shadow(0 0 18px rgba(224,180,74,.22))}.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}.home__coach{margin-bottom:1.1rem;padding:1rem;border:1px solid rgba(224,180,74,.28);border-radius:14px;background:linear-gradient(135deg,#e0b44a24,#185c422e),#0000002e}.home__coach-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.8rem}.home__coach-kicker{margin:0 0 .25rem;color:var(--gold-soft);font-size:.82rem;font-weight:800}.home__coach-title{margin:0;font-size:1.05rem;line-height:1.2}.home__coach-body{margin:.65rem 0 0;color:var(--text-dim);line-height:1.45}.home__coach-progress{display:flex;gap:.45rem;margin-top:.85rem}.home__coach-dot{position:relative;width:44px;height:44px;border:0;background:transparent;cursor:pointer}.home__coach-dot:before{content:"";position:absolute;left:6px;right:6px;top:50%;height:.42rem;transform:translateY(-50%);border-radius:999px;background:#ffffff38}.home__coach-dot--active:before{background:var(--gold-metal)}.home__coach-dot:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.home__coach-actions{display:flex;align-items:center;flex-wrap:wrap;gap:.55rem;margin-top:.9rem}.home__coach-link{min-height:40px;padding:.45rem 0;border:0;background:transparent;color:var(--gold-soft);font:inherit;font-weight:800;cursor:pointer}.home__coach-link:disabled{color:#ffffff52;cursor:default}.home__coach-actions .home__welcome-btn{margin-left:auto}.home__daily-tip{display:grid;gap:.25rem;margin:.75rem 0 0;padding:.75rem .85rem;border-radius:10px;background:#e0b44a1a;border:1px solid rgba(224,180,74,.2);color:var(--text);line-height:1.35}.home__daily-tip-label{color:var(--gold-soft);font-size:.78rem;font-weight:900;text-transform:uppercase}.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 1px 1px rgba(0,0,0,.5)) drop-shadow(0 8px 14px rgba(0,0,0,.42)) drop-shadow(0 20px 28px rgba(6,26,18,.3));border-radius:8px}.card--playable{cursor:pointer;transform-style:preserve-3d;transition:transform var(--dur-ui) var(--ease-spring),filter var(--dur-ui) var(--ease-out)}.card--playable:hover,.card--playable:focus-visible{transform:translateY(-22px) scale(1.07) rotateX(7deg);outline:none;z-index:5}.card--playable:hover .card__img,.card--playable:focus-visible .card__img{filter:drop-shadow(0 26px 34px rgba(0,0,0,.55)) drop-shadow(0 1px 0 rgba(224,180,74,.95))}.card--playable:focus-visible .card__img{outline:4px solid #fff;outline-offset:2px;box-shadow:0 0 0 6px #e0b44ab3}.card--playable:active{transform:translateY(-8px) scale(1.02);transition-duration:.06s}.card--static{opacity:.98}.card__points{position:absolute;bottom:-9px;left:50%;transform:translate(-50%);background:radial-gradient(120% 120% at 50% 25%,#ffe9a8,#e8ba45 70%,#d09e2e);color:#3a2c07;font-size:.7rem;font-weight:800;border-radius:999px;min-width:22px;height:20px;display:grid;place-items:center;padding:0 6px;border:1px solid rgba(90,60,10,.65);box-shadow:0 2px 6px #00000080,inset 0 1px #ffffff8c;text-shadow:0 1px 0 rgba(255,255,255,.35);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:nowrap;padding:.4rem .7rem;width:fit-content;max-width:100%;margin-inline:auto}@media (max-width: 560px){.hand{gap:0}.hand .card+.card{margin-left:calc(var(--card-xl) * -.14)}}.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__opponent__inner{display:inline-block;padding:.25rem .7rem;border-radius:14px}.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:row;align-items:center;justify-content:center;gap:clamp(.8rem,4vw,3rem);flex:1;min-width:0;align-self:stretch;padding:.5rem clamp(.5rem,1.5vw,.9rem)}.table__center>.trump-pile{align-self:center;margin:0;flex:0 0 auto}.table__center .trick-area{width:var(--trick-w, calc(var(--card-lg) * 2.15));flex:none}.table--2v2{--trick-w: calc(var(--card-lg) * 2.8)}.trump-pile{display:flex;flex-direction:row;align-items:center;gap:.6rem}.trump-pile__stack{position:relative;width:calc(var(--card-lg) * 1.85);height:calc(var(--card-lg) * 1.55)}.trump-pile__trump{position:absolute;left:30%;top:12%;transform:rotate(90deg);transform-origin:center;z-index:1}.trump-pile__deck{position:absolute;left:0;top:0;z-index:2;pointer-events:none}.trump-pile__trump-btn{display:block;padding:0;border:0;background:transparent;color:inherit;cursor:zoom-in;transform-origin:center;transition:transform .22s var(--ease-spring),filter .22s var(--ease-out)}.trump-pile__trump:hover,.trump-pile__trump:focus-within,.trump-pile__trump[data-peeking=true]{z-index:4;animation-play-state:paused}.trump-pile__trump:hover .trump-pile__trump-btn,.trump-pile__trump:focus-within .trump-pile__trump-btn,.trump-pile__trump[data-peeking=true] .trump-pile__trump-btn{transform:translate(-24px) translateY(-4px) scale(1.2);filter:drop-shadow(0 0 12px rgba(242,215,138,.42))}.trump-pile__trump-btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:5px;border-radius:12px}.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: min(108px, calc(var(--table-free) * .3));--card-lg: min(96px, calc(var(--table-free) * .21));--card-md: 68px;--card-sm: 46px}.table__center{gap:.5rem}.side-player{width:auto;min-width:0;flex:0 1 clamp(52px,14vw,84px);padding:.3rem .35rem}.side-player__fan{width:calc(var(--card-sm) * 1.7)}.score-panel{min-width:0;max-width:44vw;font-size:.82rem}.table__statusrow{height:42px}.table__hint,.table__seven{padding:.3rem .6rem;font-size:.8rem}.home__join{flex-direction:column}.lobby__code-value code{font-size:1.6rem}}@media (max-width: 380px){:root{--card-xl: min(92px, calc(var(--table-free) * .3));--card-lg: min(80px, calc(var(--table-free) * .21));--card-md: 58px}}.home__topbar{display:flex;justify-content:center;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.4rem}.fs-btn{background:var(--surface-1);border:var(--hairline-gold);color:var(--gold-soft);border-radius:10px;width:40px;height:40px;font-size:1.15rem;line-height:1;cursor:pointer}.fs-btn:hover{background:var(--surface-2)}.fs-hint{font-size:.76rem;color:var(--text-dim);background:var(--surface-1);border:var(--hairline-gold);border-radius:10px;padding:.35rem .6rem}.lang-combo{position:relative}.lang-combo__trigger{display:flex;align-items:center;gap:.4rem;background:var(--surface-1);border:var(--hairline-gold);border-radius:10px;padding:.3rem .6rem;color:var(--text);cursor:pointer;min-height:40px}.lang-combo__trigger:hover{background:var(--surface-2)}.lang-combo__code{font-weight:700;font-size:.85rem}.lang-combo__caret{color:var(--gold-soft);font-size:.7rem}.lang-combo__list{position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);margin:0;padding:.3rem;list-style:none;background:var(--panel);border:var(--hairline-gold);border-radius:12px;box-shadow:var(--shadow-3);z-index:50;min-width:165px}@supports (backdrop-filter: blur(2px)){.lang-combo__list{-webkit-backdrop-filter:blur(12px) saturate(1.2);backdrop-filter:blur(12px) saturate(1.2)}}.lang-combo__opt{display:flex;align-items:center;gap:.55rem;width:100%;background:transparent;border:none;color:var(--text);padding:.5rem .6rem;border-radius:8px;cursor:pointer;font-size:.9rem}.lang-combo__opt:hover{background:var(--surface-2)}.lang-combo__opt--active{background:#e0b44a29;font-weight:700}.lang-combo .flag{width:24px;height:16px;border-radius:2px;flex:none}.table__quit{min-width:44px;padding:.35rem .55rem;font-size:1.3rem;line-height:1}.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:#2a1e05}.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:#e0b44a1f;animation:turn-glow 1.6s ease-in-out infinite}.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-anchor{position:fixed;z-index:65;display:flex;flex-direction:column;gap:.35rem;max-width:min(42vw,320px);pointer-events:none}.chat-anchor--self{left:50%;transform:translate(-50%);bottom:calc(var(--card-xl) * 1.5 + 76px + env(safe-area-inset-bottom,0px));align-items:center}.chat-anchor--top{left:50%;transform:translate(-50%);top:calc(16vh + env(safe-area-inset-top,0px));align-items:center}.chat-anchor--left{left:2%;top:40vh;align-items:flex-start}.chat-anchor--right{right:2%;top:40vh;align-items:flex-end}.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(.55,0,1,.45) forwards}.trick-area--collect-up .trick-area__slot{animation:fly-up .38s cubic-bezier(.55,0,1,.45) forwards}.trick-area--collect-left .trick-area__slot{animation:fly-left .38s cubic-bezier(.55,0,1,.45) forwards}.trick-area--collect-right .trick-area__slot{animation:fly-right .38s cubic-bezier(.55,0,1,.45) forwards}@keyframes fly-down{60%{opacity:1}to{transform:translateY(46vh) rotate(8deg) scale(.32);opacity:0}}@keyframes fly-up{60%{opacity:1}to{transform:translateY(-44vh) rotate(-8deg) scale(.32);opacity:0}}@keyframes fly-left{60%{opacity:1}to{transform:translate(-46vw,6vh) rotate(-10deg) scale(.32);opacity:0}}@keyframes fly-right{60%{opacity:1}to{transform:translate(46vw,6vh) rotate(10deg) scale(.32);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(100dvh - 284px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) }.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(--text-dim);font-style:italic;font-size:.85rem;white-space:nowrap}.quickchat{position:relative}.quickchat__toggle{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.14);background:#00000040;font-size:1.1rem;cursor:pointer;line-height:1}.quickchat__toggle:focus-visible,.quickchat__btn:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px}.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}.home__rules-link{margin-top:.5rem;padding:.4rem 1rem;border-radius:999px;border:1px solid rgba(224,180,74,.45);background:#e0b44a1a;color:var(--gold-soft, #e0b44a);font-size:.95rem;font-weight:600;cursor:pointer}.home__rules-link:hover{background:#e0b44a33}.rules{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#07160f;overflow-y:auto;-webkit-overflow-scrolling:touch}.rules__inner{max-width:780px;margin:0 auto;padding:1.2rem 1.2rem 2.5rem}.rules__header{position:sticky;top:0;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0;background:#07160f;z-index:2}.rules__title{margin:0;color:var(--gold, #ffd76a);font-size:1.35rem}.rules__close{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#fff;font-size:1rem;cursor:pointer}.rules__close:hover{background:#ffffff24}.rules__section{margin-top:1.4rem}.rules__section h3{color:var(--gold-soft, #e0b44a);margin:0 0 .5rem;font-size:1.08rem}.rules__section p{margin:.4rem 0;line-height:1.55}.rules__cards-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.7rem 0;align-items:flex-end}.rules__cards-row--ladder{gap:.3rem}.rules__note{color:var(--text-dim, #9aa3b2);font-size:.92rem}.rules__warn{border-left:3px solid var(--gold, #ffd76a);padding:.45rem .7rem;background:#e0b44a14;border-radius:0 10px 10px 0;margin-top:.6rem}.rules__trump{display:flex;gap:.5rem;margin:.6rem 0}.rules__examples{display:flex;flex-wrap:wrap;gap:1.1rem}.rules__ex{flex:1 1 200px;max-width:240px}.rules__ex-cards{display:flex;gap:.55rem;align-items:flex-start}.rules__ex-slot{position:relative;padding:4px;border-radius:12px}.rules__ex-slot--win{outline:2px solid var(--gold, #ffd76a);outline-offset:2px}.rules__ex-win{position:absolute;left:50%;transform:translate(-50%);bottom:-30px;background:#071610f2;padding:0 6px;border-radius:6px;color:var(--gold, #ffd76a);font-size:.78rem;font-weight:700;white-space:nowrap}.rules__section p.rules__ex-caption{margin-top:2.6rem;color:var(--text-dim, #9aa3b2);font-size:.9rem;line-height:1.45}.rules__list{margin:.4rem 0 0;padding-left:1.2rem;line-height:1.65}.rules__footer{margin-top:2rem;text-align:center}.rules__footer .rules__note{margin-top:.5rem}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E")}.app--game{height:100dvh;max-height:100dvh;overflow:hidden}.table{overflow:hidden;min-height:0}.table__middle{min-height:0;overflow:hidden}.trick-area{max-width:100%}.btn{box-shadow:var(--shadow-2),inset 0 1px #ffffff38}.btn--primary{background:linear-gradient(180deg,#f0c260,#dca23a);color:#3a2c07;text-shadow:0 1px 0 rgba(255,255,255,.25)}.btn--primary:hover:not(:disabled){box-shadow:var(--shadow-2),0 0 0 1px #e0b44a80,inset 0 1px #ffffff4d}.btn:active:not(:disabled){box-shadow:var(--shadow-1),inset 0 1px 3px #0000004d}.btn:focus-visible{outline:2px solid var(--gold-soft);outline-offset:2px;box-shadow:0 0 0 4px #e0b44a40}.hand--active{animation:your-turn-glow 1.8s ease-in-out infinite;border-radius:18px}@keyframes your-turn-glow{0%,to{box-shadow:0 0 #e0b44a00}50%{box-shadow:0 0 22px 2px #e0b44a47}}.trick-area__slot{animation:lay-in .28s cubic-bezier(.2,.85,.3,1.15) both}@keyframes lay-in{0%{transform:translateY(26px) scale(.86) rotate(-2deg);opacity:0}70%{transform:translateY(-3px) scale(1.02);opacity:1}to{transform:translateY(0) scale(1) rotate(0);opacity:1}}.trick-area__who{font-size:.74rem;font-weight:700;color:var(--text);letter-spacing:.02em;background:#00000052;padding:.05rem .5rem;border-radius:999px;line-height:1.3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.trick-area__slot--mine .trick-area__who{color:#a9edc2}.trick-area__slot--winner .trick-area__who{color:var(--gold-soft);font-weight:800}.trick-area__win-tag{color:var(--gold);font-weight:900}.trick-area__slot--winner .card__img{outline:3px solid var(--gold);outline-offset:2px;border-radius:8px;box-shadow:0 0 22px #e0b44ab3,0 0 0 1px #e0b44a80;animation:winner-pop .42s cubic-bezier(.34,1.56,.64,1) both}@keyframes winner-pop{0%{transform:scale(1);box-shadow:0 0 6px #e0b44a59}45%{transform:scale(1.13);box-shadow:0 0 26px #e0b44af2}to{transform:scale(1.06);box-shadow:0 0 16px #e0b44aa6}}.trick-area--collect .trick-area__slot--winner .card__img{animation:none}.score-panel{border:var(--hairline-gold);box-shadow:var(--shadow-2),inset 0 1px #ffffff0f;border-radius:14px}.score-panel__row{transition:background .18s ease}.score-panel__row--active{background:linear-gradient(90deg,#e0b44a38,#e0b44a0f);box-shadow:inset 3px 0 0 var(--gold)}.score-panel__row--active .score-panel__name{font-weight:800}.score-panel__row--us{box-shadow:inset 3px 0 0 var(--us)}.score-panel__row--us.score-panel__row--active{background:linear-gradient(90deg,#4a86c842,#4a86c80f)}.score-panel__row--them{box-shadow:inset 3px 0 0 var(--them-c)}.score-panel__row--them.score-panel__row--active{background:linear-gradient(90deg,#d9694f42,#d9694f0f)}.score-panel__turn{display:inline-block;width:.6em;color:var(--gold);text-shadow:0 0 8px rgba(224,180,74,.9)}.score-panel__name{display:flex;align-items:baseline;gap:.25rem;min-width:0}.score-panel__tag{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:14ch}.table__player-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.side-player--they{box-shadow:inset 0 0 0 2px #d9694f73;border-radius:12px}.countdown{filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}.countdown__prog{filter:drop-shadow(0 0 5px rgba(224,180,74,.75));transition:stroke .25s ease}.countdown--urgent .countdown__prog{stroke:var(--danger)}.countdown--urgent .countdown__num{color:#ffb3ab}.countdown--urgent{animation:cd-urgent .5s ease-in-out infinite}@keyframes cd-urgent{0%,to{transform:scale(1)}50%{transform:scale(1.12)}}.table__statusrow{height:46px;min-height:46px;flex-wrap:nowrap;overflow:hidden}.table__waiting{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:40vw}.chat-bubble{animation:bubble-in .22s cubic-bezier(.34,1.56,.64,1),bubble-out .4s ease 3.1s forwards}@keyframes bubble-out{to{opacity:0;transform:translateY(-6px) scale(.96)}}.table__quit{min-height:44px;padding:.4rem .9rem}.quickchat__toggle{width:44px;height:44px}.lang-btn,.seg__btn{min-height:44px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}@media (prefers-contrast: more){.status-bar--them,.trick-area__who,.table__player-label{color:#fff}.score-panel__row--active{box-shadow:inset 4px 0 #fff}:focus-visible{outline:3px solid #fff!important;outline-offset:2px}}.round-end__crest{font-size:2.6rem;line-height:1;margin-bottom:.2rem;animation:crest-pop .45s cubic-bezier(.2,.9,.3,1.4) both}@keyframes crest-pop{0%{transform:scale(.3);opacity:0}}.round-end--win{border-color:#e0b44a99;box-shadow:var(--shadow-3),0 0 60px #e0b44a40}.round-end--win .round-end__title{color:var(--gold)}.round-end__actions-row{display:flex;gap:.6rem}.round-end__actions-row .btn{flex:1;white-space:nowrap}.lobby__code-btn{display:inline-flex;align-items:center;gap:.6rem;background:#0000004d;border:1px solid rgba(224,180,74,.25);border-radius:12px;padding:.25rem .7rem .25rem 1rem;cursor:pointer;transition:border-color .15s ease,background .15s ease;min-height:44px}.lobby__code-btn:hover{border-color:#e0b44a99}.lobby__code-btn code{font-size:2.2rem;font-weight:800;letter-spacing:.3em;color:var(--gold-soft)}.lobby__code-copy{font-size:1.1rem;color:var(--text-dim)}.home__adv{margin:.2rem 0 .7rem}.home__adv>summary{cursor:pointer;list-style:none;color:var(--text-dim);font-size:.85rem;font-weight:600;padding:.5rem 0;-webkit-user-select:none;user-select:none;min-height:44px;display:flex;align-items:center}.home__adv>summary::-webkit-details-marker{display:none}.home__adv>summary:after{content:" ▾";opacity:.6}.home__adv[open]>summary:after{content:" ▴"}.home__adv[open]>summary{color:var(--gold-soft)}.home__vsbot-link{align-self:center;margin-top:.15rem;background:none;border:none;cursor:pointer;font:inherit;color:var(--text-dim);font-size:.9rem;text-decoration:underline;text-underline-offset:3px;min-height:44px;padding:.3rem .8rem}.home__vsbot-link:hover:not(:disabled){color:var(--gold-soft)}.home__vsbot-link:disabled{opacity:.4;cursor:not-allowed}.table__senas{white-space:nowrap}.flash-reveal{position:fixed;z-index:60;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.35rem .5rem;border-radius:12px;background:#0b2018f5;border:2px solid var(--gold);box-shadow:var(--shadow-2),0 0 16px #e0b44a4d;animation:flash-pop .18s cubic-bezier(.34,1.56,.64,1) both;pointer-events:none;max-width:min(70vw,300px)}@keyframes flash-pop{0%{opacity:0;transform:scale(.82) translate(var(--fx, 0),var(--fy, 0))}}.flash-reveal--top{top:calc(6.5rem + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%)}.flash-reveal--left{left:1.5%;top:40%}.flash-reveal--right{right:1.5%;top:40%}.flash-reveal__caption{font-size:.74rem;font-weight:800;color:var(--gold-soft);white-space:nowrap}.flash-reveal__cards{display:flex;gap:.4rem}.table__opponent--active .table__opponent__inner{animation:turn-glow 1.6s ease-in-out infinite}@keyframes turn-glow{0%,to{box-shadow:0 0 0 2px #e0b44a8c,0 0 #e0b44a00}50%{box-shadow:0 0 0 2px #e0b44abf,0 0 18px 3px #e0b44a66}}.table__opponent--active .table__player-label,.side-player--active .side-player__name{color:var(--gold-soft);font-weight:800}.table__opponent--active .table__player-label:after{content:" ▸"}@media (max-aspect-ratio: 5/6){.table__center{flex-direction:row;align-items:center;justify-content:center;gap:clamp(.4rem,3vw,1rem)}.table__center .trick-area{width:calc(var(--card-lg) * 2.3);flex:none}}@media (max-aspect-ratio: 5/6){.table--2v2{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:repeat(6,auto);grid-template-areas:"info    quit" "opp     opp" "railL   railR" "play    play" "status  status" "hand    hand";row-gap:clamp(.2rem,1vh,.7rem);column-gap:.5rem;min-height:100dvh;align-content:space-between;--card-sm: min(clamp(32px, 7.5vw, 56px), 6.5vh);--card-lg: min(clamp(52px, 13vw, 100px), 12vh);--card-xl: min(clamp(66px, 19vw, 118px), 15.5vh)}.table--2v2 .table__topbar,.table--2v2 .table__middle{display:contents}.table--2v2 .score-panel{grid-area:info;justify-self:start}.table--2v2 .table__quit{grid-area:quit;justify-self:end;align-self:start}.table--2v2 .table__opponent{grid-area:opp;justify-self:center}.table--2v2 .side-player--left{grid-area:railL;justify-self:center}.table--2v2 .side-player--right{grid-area:railR;justify-self:center}.table--2v2 .table__center{grid-area:play;justify-self:center;align-self:center;flex-direction:row;align-items:center;gap:clamp(.3rem,2vw,.9rem)}.table--2v2 .table__center .trick-area{width:calc(var(--card-lg) * 2.5);flex:none}.table--2v2 .table__statusrow{grid-area:status;justify-self:center}.table--2v2 .table__hand{grid-area:hand}.table--2v2 .table__footer{grid-column:1 / -1}}.table__hint,.table__seven,.table__senas,.quickchat__btn,.seg--small .seg__btn{min-height:44px}.lobby__swap{min-width:44px;min-height:44px}.open-games__join{min-height:44px}@media (orientation: landscape){.table{max-width:min(96%,1200px);display:grid;--deck-w: calc(var(--card-lg) * 1.85);--trick-w: calc(var(--card-lg) * 2.15);--play-w: calc(var(--deck-w) + var(--trick-w) + 2rem);grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto auto auto auto;grid-template-areas:"info    opp      quit" ".       play     ." ".       status   ." "hand    hand     hand" "footer  footer   footer";row-gap:clamp(.25rem,1.6vh,1.2rem);column-gap:clamp(.6rem,2vw,2rem);align-content:center;position:relative}.table:before{content:"";position:absolute;top:2.5%;right:2%;bottom:2.5%;left:2%;border-radius:46%/42%;background:radial-gradient(66% 54% at 50% 40%,rgba(255,240,205,.12),rgba(255,240,205,.03) 46%,transparent 72%),radial-gradient(120% 100% at 50% 50%,var(--felt-2),var(--felt) 60%,var(--felt-edge) 100%);box-shadow:inset 0 0 0 2px #0000008c,inset 0 0 0 3px #c9a24b66,inset 0 26px 80px #00000080,inset 0 -34px 90px #00000080;pointer-events:none;z-index:0}.table:after{content:"";position:absolute;top:6%;right:4%;bottom:6%;left:4%;border-radius:48%/44%;border:1.5px dashed rgba(242,215,138,.26);pointer-events:none;z-index:0}.table>*{position:relative;z-index:1}.table__center{gap:clamp(.75rem,2vw,2rem)}.table__topbar{display:contents}.score-panel{grid-area:info;align-self:start;justify-self:stretch;max-width:none}.table__opponent{grid-area:opp;align-self:start;justify-self:center}.table__quit{grid-area:quit;align-self:start;justify-self:end}.table__middle{grid-area:play;align-self:center;justify-content:center}.table__statusrow{grid-area:status;justify-content:center}.table__statusrow .status-bar{position:static;transform:none}.table__hand{grid-area:hand}.table__footer{grid-area:footer;flex-direction:row;align-items:center;justify-content:center;gap:.9rem;width:100%}.table__footer .quickchat{flex:none;justify-content:flex-start}}@media (orientation: landscape) and (min-width: 1024px){.table__footer{background:#04160f80;border:1px solid rgba(224,180,74,.16);border-radius:14px;padding:.4rem .9rem;gap:.9rem;box-shadow:inset 0 1px #ffffff0a;max-width:fit-content;margin-inline:auto}.score-panel{font-size:1.03rem}.table__statusrow .status-bar{font-size:1.15rem}.table--1v1 .table__opponent__inner{background:#04160f66;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:.4rem .9rem .6rem}}.seg__btn{white-space:nowrap}@media (orientation: landscape) and (min-height: 600px){:root{--card-xl: min(clamp(116px, 18vw, 280px), 17vh);--card-lg: min(clamp(100px, 15vw, 240px), 14.5vh);--card-sm: min(clamp(48px, 7vw, 112px), 8.5vh)}}@media (orientation: landscape) and (min-height: 850px){:root{--card-xl: min(clamp(132px, 20vw, 320px), 18vh);--card-lg: min(clamp(108px, 16vw, 260px), 14vh);--card-sm: min(clamp(54px, 8vw, 124px), 9.5vh)}}@media (orientation: landscape){.table--2v2{--card-sm: min(clamp(40px, 5vw, 84px), 7vh);--card-lg: min(clamp(84px, 11vw, 175px), 11vh);grid-template-columns:minmax(140px,.72fr) minmax(var(--play-w),2.9fr) minmax(140px,.72fr);grid-template-areas:"info    opp     quit" "railL   play    railR" "railL   status  railR" "hand    hand    hand"}.table--2v2 .table__middle{display:contents}.table--2v2 .table__center{grid-area:play;align-self:center;justify-self:center}.table--2v2 .side-player--left{grid-area:railL;align-self:center;justify-self:center;width:100%;max-width:210px}.table--2v2 .side-player--right{grid-area:railR;align-self:center;justify-self:center;width:100%;max-width:210px}.table--2v2 .table__footer{display:none}}@media (orientation: landscape) and (max-height: 599px){:root{--card-xl: min(clamp(76px, 13vw, 170px), 26vh);--card-lg: min(clamp(70px, 12vw, 150px), 24vh);--card-sm: min(clamp(40px, 6vw, 84px), 13vh)}.table{grid-template-columns:minmax(112px,.85fr) minmax(0,2.7fr) auto;grid-template-rows:auto minmax(0,1fr) auto auto;grid-template-areas:"info   play    quit" "opp    play    ." "opp    status  ." "hand   hand    hand";gap:.15rem .5rem}.table__opponent{grid-area:opp;align-self:start;justify-self:center}.table__footer{display:none}.table__statusrow{height:32px;min-height:32px}.score-panel{font-size:.72rem}}@media (orientation: landscape) and (max-height: 599px){.table--2v2{--card-sm: min(clamp(32px, 4vw, 56px), 11vh);--card-lg: min(clamp(56px, 9vw, 112px), 21vh);--card-xl: min(clamp(60px, 10vw, 120px), 22vh);grid-template-columns:minmax(88px,.9fr) minmax(0,1.9fr) minmax(88px,.9fr);grid-template-rows:auto minmax(0,1fr) auto auto;grid-template-areas:"info   opp     quit" "railL  play    railR" "railL  status  railR" "hand   hand    hand";gap:.12rem .35rem}.table--2v2 .table__opponent{grid-area:opp;align-self:start;justify-self:center}.table--2v2 .side-player--left{grid-area:railL;align-self:center;justify-self:center;max-width:120px}.table--2v2 .side-player--right{grid-area:railR;align-self:center;justify-self:center;max-width:120px}}.community-stats{display:flex;gap:.5rem;justify-content:center;align-items:center;flex-wrap:wrap;color:var(--text-dim);font-size:.85rem;margin:.1rem 0 .6rem}.community-stats strong{color:var(--gold-soft);font-variant-numeric:tabular-nums}.community-stats__sep{opacity:.5}.home__motd{text-align:center;background:#e0b44a24;border:var(--hairline-gold);color:var(--gold-soft);border-radius:12px;padding:.5rem .8rem;margin:0 auto .6rem;max-width:560px;font-size:.9rem}.account-panel{display:grid;gap:.65rem;margin:0 0 .75rem;padding:.75rem;border:1px solid rgba(224,180,74,.2);border-radius:10px;background:#00000029}.account-panel--connected{grid-template-columns:minmax(0,1fr) auto;align-items:center}.account-panel__kicker,.account-panel__meta{display:block;color:var(--text-dim);font-size:.78rem}.account-panel__tabs{display:flex;gap:.4rem;flex-wrap:wrap}.account-panel__tab{border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff0f;color:var(--text);padding:.42rem .72rem;font-weight:700;cursor:pointer}.account-panel__tab--active{border-color:#e0b44a8c;color:var(--gold-soft);background:#e0b44a1f}.account-panel__form{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) auto;gap:.55rem;align-items:end}.account-panel__field{display:grid;gap:.25rem}.account-panel__field span{color:var(--text-dim);font-size:.78rem}.account-panel__submit,.account-panel__logout{min-height:42px}.account-panel__error{margin:0;color:#ffb1b1;font-weight:700;font-size:.86rem}.contact-panel{width:min(560px,calc(100% - 2rem));margin:.65rem auto 0;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;box-shadow:var(--shadow-2);overflow:hidden}.contact-panel>summary{cursor:pointer;padding:.75rem 1rem;font-weight:800;color:var(--gold-soft);list-style:none}.contact-panel>summary::-webkit-details-marker{display:none}.contact-panel>summary:after{content:" ▾";opacity:.65}.contact-panel[open]>summary:after{content:" ▴"}.contact-panel__form{display:grid;gap:.65rem;padding:0 1rem 1rem}.contact-panel__row{display:flex;gap:.6rem}.contact-panel__field{display:grid;gap:.25rem}.contact-panel__field--grow{flex:1}.contact-panel__field span{color:var(--text-dim);font-size:.78rem}.contact-panel__textarea{min-height:110px;resize:vertical}.contact-panel__actions{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap}.contact-panel__status{color:var(--gold-soft);font-size:.85rem}.lb__row--me{background:#e0b44a29}.lb__row--me td{font-weight:700}.lb__you{color:var(--gold-soft);font-size:.82em}.lb__rate{color:var(--text-dim);font-variant-numeric:tabular-nums}.maintenance{flex:1;display:grid;place-items:center;align-content:center;text-align:center;padding:2rem;gap:.4rem}.maintenance__emoji{font-size:3rem}.maintenance p{color:var(--text-dim);max-width:420px}.admin{min-height:100dvh;display:grid;place-items:start center;padding:clamp(1rem,4vw,3rem)}.admin__card{width:100%;max-width:1040px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:var(--shadow-3);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:clamp(1rem,3vw,1.8rem);display:flex;flex-direction:column;gap:.7rem}.admin__head{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.admin__title{font-size:1.3rem;margin:0}.admin__hint{color:var(--text-dim);font-size:.88rem;margin:0}.admin__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:.6rem;margin:.3rem 0}.admin__stat{background:var(--surface-2);border-radius:12px;padding:.7rem;text-align:center}.admin__stat b{display:block;font-size:1.5rem;color:var(--gold-soft);font-variant-numeric:tabular-nums}.admin__stat span{font-size:.76rem;color:var(--text-dim)}.admin__h2{font-size:1rem;margin:.6rem 0 .1rem;color:var(--gold-soft)}.admin__flags{display:flex;flex-direction:column;gap:.45rem}.admin__flag{display:flex;align-items:center;gap:.6rem;cursor:pointer}.admin__flag input{width:20px;height:20px;accent-color:var(--accent);flex:none}.admin__field{display:flex;flex-direction:column;gap:.3rem}.admin__field>span{font-size:.85rem;color:var(--text-dim)}.admin__pw{display:flex;gap:.5rem}.admin__pw .field__input{flex:1}.admin__saved{color:var(--success);font-weight:600}.admin__err{color:#ff9b9b;font-weight:600}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:60}.confetti__piece{position:absolute;top:-18px;border-radius:2px;opacity:0;animation-name:confetti-fall;animation-timing-function:cubic-bezier(.2,.65,.4,1);animation-fill-mode:forwards}@keyframes confetti-fall{0%{opacity:0;transform:translateY(-24px) rotate(0)}8%{opacity:1}to{opacity:.9;transform:translateY(104vh) rotate(var(--rot, 540deg))}}.card--trump .card__img{box-shadow:0 0 0 3px var(--gold),0 0 16px #e0b44a99,0 4px 12px #0006;border-radius:8px}@media (prefers-reduced-motion: reduce){.confetti{display:none}}@media (orientation: portrait) and (min-height: 780px){:root{--card-xl: min(clamp(94px, 22vw, 240px), 17dvh);--card-lg: min(clamp(78px, 18vw, 200px), 13dvh)}.table__middle{align-items:flex-end}}@media (orientation: portrait) and (min-height: 1040px){:root{--card-xl: min(clamp(120px, 25vw, 280px), 16dvh);--card-lg: min(clamp(102px, 20vw, 240px), 12dvh)}}.avatar{border-radius:50%;display:grid;place-items:center;background:linear-gradient(160deg,hsl(var(--avatar-hue, 200) 55% 42%),hsl(var(--avatar-hue, 200) 60% 26%));border:2px solid rgba(255,255,255,.18);box-shadow:0 2px 6px #00000059,inset 0 1px #fff3;color:#fff;font-weight:800;flex:none;line-height:1}.avatar--active{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold),0 0 12px #e0b44a99}.avatar{position:relative}.avatar__bot{position:absolute;right:-3px;bottom:-3px;font-size:.62em;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.55))}.community-stats__item--online strong{color:#6ee7a8}.progress-card{background:#00000038;border:1px solid rgba(224,180,74,.22);border-radius:12px;padding:.6rem .8rem;margin-bottom:.8rem}.progress-card__head{display:flex;align-items:center;gap:.6rem;font-size:.85rem;margin-bottom:.4rem}.progress-card__level{font-weight:800;color:var(--gold)}.progress-card__streak{color:#ffb27a;font-weight:700}.progress-card__elo{color:#d9c6a0;font-weight:700}.progress-card__xp{margin-left:auto;color:var(--text-dim)}.lb__elo{font-weight:700;color:#d9c6a0}.progress-card__bar{height:8px;border-radius:5px;background:#ffffff1a;overflow:hidden}.progress-card__fill{height:100%;border-radius:5px;background:linear-gradient(90deg,var(--gold-soft),var(--gold));transition:width .5s ease}.progress-card__trophies{display:flex;gap:.35rem;margin-top:.5rem;font-size:1.1rem}:root[data-felt=ocean]{--felt: #0c2a3a;--felt-2: #143e54;--felt-edge: #061722}:root[data-felt=burgundy]{--felt: #3a0f1a;--felt-2: #531826;--felt-edge: #1e0710}:root[data-felt=night]{--felt: #14161c;--felt-2: #242833;--felt-edge: #07080d}.seg--themes{gap:.35rem}.felt-swatch{padding:.3rem .45rem!important}.felt-swatch__dot{display:inline-block;width:18px;height:18px;border-radius:50%;border:1px solid rgba(255,255,255,.35);vertical-align:middle}.felt-swatch__dot--green{background:#123f30}.felt-swatch__dot--ocean{background:#143e54}.felt-swatch__dot--burgundy{background:#531826}.felt-swatch__dot--night{background:#242833}.admin__maint-banner{background:#7a1f1f;color:#fff;font-weight:800;text-align:center;padding:.6rem;border-radius:10px;margin-bottom:.9rem;letter-spacing:.02em}.admin__rooms{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.6rem}.admin__room{display:flex;align-items:center;gap:.6rem;background:#00000038;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.5rem .7rem}.admin__room-info{flex:1 1 auto;min-width:0;font-size:.85rem}.admin__room-code{font-weight:800;color:var(--gold);letter-spacing:.05em}.admin__room-players{color:var(--text-dim);font-size:.78rem;margin-top:.15rem;overflow:hidden;text-overflow:ellipsis}.admin__room-close{flex:none}.admin__empty{color:var(--text-dim);font-size:.85rem;font-style:italic}.admin__user-create{display:grid;grid-template-columns:minmax(120px,1fr) minmax(130px,1fr) minmax(130px,1fr) 110px auto;gap:.5rem;align-items:center}.admin__users,.admin__mailbox{display:grid;gap:.6rem}.admin__user{display:grid;grid-template-columns:minmax(220px,1.3fr) minmax(250px,1fr);gap:.55rem;padding:.65rem;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:#0003}.admin__user--off{opacity:.65}.admin__user-main,.admin__user-controls,.admin__user-password{display:flex;align-items:center;gap:.5rem}.admin__user-main strong{width:96px;color:var(--gold-soft);overflow:hidden;text-overflow:ellipsis}.admin__user-main .field__input,.admin__user-password .field__input{min-width:0;flex:1}.admin__check{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap;color:var(--text-dim);font-size:.85rem}.admin__check input{width:18px;height:18px;accent-color:var(--accent)}.admin__message{display:grid;gap:.55rem;padding:.75rem;border:1px solid rgba(255,255,255,.08);border-left:4px solid rgba(224,180,74,.45);border-radius:10px;background:#0003}.admin__message--new{border-left-color:var(--gold)}.admin__message--done,.admin__message--archived{opacity:.72}.admin__message-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem}.admin__message-head strong,.admin__message-head span{display:block}.admin__message-head span,.admin__message-mail{color:var(--text-dim);font-size:.8rem}.admin__message-body{white-space:pre-wrap;margin:0;color:var(--text)}.admin__note{min-height:74px;resize:vertical}@media (max-width: 760px){.account-panel__form,.admin__user-create,.admin__user{grid-template-columns:1fr}.account-panel--connected,.admin__message-head{display:grid;grid-template-columns:1fr}.contact-panel__row,.admin__user-main,.admin__user-controls,.admin__user-password{flex-wrap:wrap}}.home__section-title,.admin__title,.admin__h2,.lobby__title,.rules__title,.round-end__title,.status-bar{font-family:var(--font-display);letter-spacing:.05em}.score-panel__points,.round-end__title{background:var(--gold-metal-sheen);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;text-shadow:0 1px 0 rgba(0,0,0,.4),0 -1px 0 rgba(255,246,214,.25)}.hand{perspective:1100px}.trump-pile .card__img{filter:drop-shadow(0 1px 1px rgba(0,0,0,.55)) drop-shadow(0 6px 10px rgba(0,0,0,.45))}.trick-area .card__img{filter:drop-shadow(0 1px 2px rgba(0,0,0,.5)) drop-shadow(0 10px 16px rgba(0,0,0,.4))}.hand--active .card--playable:not(:hover):not(:focus-visible) .card__img{filter:drop-shadow(0 2px 2px rgba(0,0,0,.5)) drop-shadow(0 16px 24px rgba(0,0,0,.45)) drop-shadow(0 4px 9px rgba(224,180,74,.2))}@media (hover: hover){.card--playable:has(~.card--playable:hover){transform:translate(-10px)}.card--playable:hover~.card--playable{transform:translate(10px)}}.home__card,.score-panel,.admin__stat,.admin__room{background:var(--panel);border:var(--hairline-gold);border-radius:var(--panel-radius);box-shadow:var(--shadow-2),inset 0 1px #fff6d614}@supports (backdrop-filter: blur(2px)){.home__card{-webkit-backdrop-filter:blur(16px) saturate(1.2);backdrop-filter:blur(16px) saturate(1.2)}}input[type=checkbox]{accent-color:var(--gold)}.avatar{border:none;box-shadow:0 0 0 2px #6e5115,0 0 0 3px var(--gold-soft),0 0 0 5px #6e5115,0 3px 8px #00000080,inset 0 2px 4px #ffffff40}.avatar--active{box-shadow:0 0 0 2px var(--gold),0 0 14px #e0b44ab3,0 3px 8px #00000080;animation:turn-ping 2s var(--ease-in-out) infinite}@keyframes turn-ping{0%,to{box-shadow:0 0 0 2px var(--gold),0 0 12px #e0b44a99,0 3px 8px #00000080}50%{box-shadow:0 0 0 2px var(--gold),0 0 24px #e0b44afa,0 3px 8px #00000080}}@media (prefers-reduced-motion: reduce){.avatar--active{animation:none}}.trump-pile__deck .card__img{box-shadow:2px 3px 0 -1px #e9dfc4,4px 6px 0 -1px #ded2b2,6px 9px 0 -1px #d3c5a0,8px 12px 0 -1px #c8b78f,10px 14px 20px #00000073}.trump-pile__count{box-shadow:var(--shadow-1)}.score-panel__points{display:inline-block}.score-panel__points--bump{animation:score-bump .6s var(--ease-spring)}@keyframes score-bump{0%{transform:scale(1)}35%{transform:scale(1.4)}to{transform:scale(1)}}.home__hero-fan{display:flex;justify-content:center;align-items:flex-end;margin-bottom:-.3rem;perspective:800px}.home__hero-card{width:clamp(56px,9vw,88px);aspect-ratio:2 / 3;object-fit:cover;border-radius:6px;margin:0 -13px;box-shadow:0 12px 22px #00000080,0 0 0 1px #0000004d;transition:transform var(--dur-ui) var(--ease-spring)}.home__hero-card:nth-child(1){transform:rotate(-13deg) translateY(9px);z-index:1}.home__hero-card:nth-child(2){transform:translateY(-4px);z-index:2}.home__hero-card:nth-child(3){transform:rotate(13deg) translateY(9px);z-index:1}.home__hero-fan:hover .home__hero-card:nth-child(1){transform:rotate(-18deg) translateY(3px)}.home__hero-fan:hover .home__hero-card:nth-child(3){transform:rotate(18deg) translateY(3px)}.home__header{position:relative}.home__header:before{content:"";position:absolute;left:50%;top:42%;width:min(92%,540px);height:240px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(224,180,74,.16),transparent 62%);pointer-events:none;z-index:-1}@keyframes lay-in-down{0%{transform:translateY(-30px) scale(1.16);opacity:.35}60%{transform:translateY(0) scale(.97);opacity:1}to{transform:none}}@keyframes lay-in-up{0%{transform:translateY(30px) scale(1.16);opacity:.35}60%{transform:translateY(0) scale(.97);opacity:1}to{transform:none}}.trick-area__slot--theirs .card{animation:lay-in-down var(--dur-card) var(--ease-spring) both}.trick-area__slot--mine .card{animation:lay-in-up var(--dur-card) var(--ease-spring) both}@media (prefers-reduced-motion: reduce){.trick-area__slot .card{animation:none}}.card--trump:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;background:linear-gradient(115deg,transparent 34%,rgba(255,255,255,.4) 48%,rgba(224,180,74,.3) 52%,transparent 64%);background-size:250% 250%;mix-blend-mode:overlay;pointer-events:none;animation:foil 3.4s linear infinite}@keyframes foil{0%{background-position:180% 0}to{background-position:-80% 0}}@media (prefers-reduced-motion: reduce){.card--trump:after{animation:none;opacity:0}}.table__seat-head,.side-player__head{display:flex;align-items:center;justify-content:center;gap:.4rem;min-width:0}.table__seat-head .table__player-label,.side-player__head .side-player__name{margin-bottom:0}.home__pseudo-hint{color:var(--gold-soft);font-size:.82rem;margin:-.15rem 0 .5rem}.home__welcome{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;background:linear-gradient(135deg,#e0b44a29,#e0b44a0f);border:1px solid rgba(224,180,74,.3);border-radius:12px;padding:.6rem .8rem;margin-bottom:.9rem}.home__welcome-text{flex:1 1 auto;font-size:.9rem}.home__welcome-btn{flex:none;background:var(--gold);color:#2a1e05;font-weight:700;border:none;border-radius:8px;padding:.45rem .8rem;cursor:pointer;min-height:40px}.home__welcome-close{flex:none;background:transparent;border:none;color:var(--text-dim);font-size:1rem;cursor:pointer;min-width:34px;min-height:34px}.table__center{position:relative}.points-fly{position:absolute;left:50%;top:42%;font-size:clamp(1.5rem,4vw,2.6rem);font-weight:900;color:var(--gold-soft);text-shadow:0 2px 8px rgba(0,0,0,.6),0 0 14px rgba(224,180,74,.55);pointer-events:none;z-index:5;animation:points-pop .95s cubic-bezier(.2,.7,.3,1) forwards}@keyframes points-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}22%{opacity:1;transform:translate(-50%,-90%) scale(1.12)}to{opacity:0;transform:translate(-50%,-180%) scale(.9)}}@media (prefers-reduced-motion: reduce){.points-fly{display:none}}@media (orientation: landscape){.table{--center-gap: clamp(1rem, 2.6vw, 3rem);--deck-w: calc(var(--card-lg) * 2.08);--trick-gap: clamp(.45rem, .9vw, .85rem);--trick-w: calc(var(--card-lg) * 2 + var(--trick-gap));--play-w: calc(var(--deck-w) + var(--center-gap) + var(--trick-w))}.table__center{display:grid;grid-template-columns:var(--deck-w) var(--trick-w);column-gap:var(--center-gap);align-items:center;justify-content:center;justify-self:center;width:min(100%,var(--play-w));max-width:var(--play-w);padding-inline:0}.table__center>.trump-pile{grid-column:1;width:var(--deck-w);justify-content:center}.table__center .trick-area{grid-column:2;width:var(--trick-w);max-width:none}.trump-pile__stack{width:min(calc(var(--card-lg) * 2.05),var(--deck-w))}.trick-area{gap:var(--trick-gap)}.trick-area__slot{flex:0 0 var(--card-lg);min-width:var(--card-lg)}.trick-area--4 .trick-area__slot+.trick-area__slot{margin-left:0}}@media (orientation: landscape){.table--2v2{max-width:min(96vw,1640px);--card-sm: min(clamp(38px, 4.4vw, 74px), 7.5vh);--card-lg: min(clamp(78px, 7vw, 142px), 12.5vh);--deck-w: calc(var(--card-lg) * 2.06);--trick-gap: clamp(.3rem, .7vw, .7rem);--trick-w: calc(var(--card-lg) * 4 + var(--trick-gap) * 3);--play-w: calc(var(--deck-w) + var(--center-gap) + var(--trick-w));grid-template-columns:minmax(128px,.56fr) minmax(min(var(--play-w),100%),auto) minmax(128px,.56fr)}.table--2v2 .trick-area--4{display:grid;grid-template-columns:repeat(4,var(--card-lg));column-gap:var(--trick-gap);justify-content:center}}@media (orientation: landscape) and (max-width: 1180px){.table{--center-gap: clamp(.65rem, 1.5vw, 1.2rem)}.table--2v2{--card-sm: min(clamp(32px, 4.2vw, 62px), 10vh);--card-lg: min(clamp(60px, 7vw, 108px), 18vh);--trick-gap: clamp(.2rem, .45vw, .42rem);grid-template-columns:minmax(92px,.52fr) minmax(min(var(--play-w),100%),auto) minmax(92px,.52fr)}}@media (orientation: landscape){.table{max-width:min(96vw,1760px);--center-gap: clamp(2.2rem, 4.6vw, 5.5rem);--trick-gap: clamp(.8rem, 1.25vw, 1.35rem);--deck-w: calc(var(--card-lg) * 1.74);--trick-w: calc(var(--card-lg) * 2 + var(--trick-gap));--play-w: calc(var(--deck-w) + var(--center-gap) + var(--trick-w))}.table__center{overflow:visible}.trump-pile__stack{width:var(--deck-w);height:calc(var(--card-lg) * 1.43)}.trump-pile__trump{left:22%;top:10%}.trick-area__who{max-width:calc(var(--card-lg) * .92);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}@media (orientation: landscape) and (min-width: 1181px){.table--2v2{--card-sm: min(clamp(34px, 3.7vw, 64px), 6.6vh);--card-lg: min(clamp(68px, 5.4vw, 112px), 9.8vh);--card-xl: min(clamp(112px, 9vw, 178px), 15vh);--deck-w: calc(var(--card-lg) * 1.74);--trick-gap: clamp(.9rem, 1.25vw, 1.35rem);--trick-w: calc(var(--card-lg) * 4 + var(--trick-gap) * 3);--play-w: calc(var(--deck-w) + var(--center-gap) + var(--trick-w));grid-template-columns:minmax(150px,.62fr) minmax(var(--play-w),auto) minmax(150px,.62fr);column-gap:clamp(1rem,2.8vw,3rem)}.table--2v2 .table__hand{height:calc(var(--card-xl) * 1.5 + 10px)}.table--2v2 .hand{gap:clamp(.9rem,1.6vw,1.8rem)}.table--2v2 .side-player{max-width:170px}}@media (orientation: landscape) and (min-width: 1181px) and (max-height: 820px){.table--2v2{--card-lg: min(clamp(62px, 5vw, 96px), 9.6vh);--card-xl: min(clamp(94px, 8.4vw, 148px), 14.5vh);--center-gap: clamp(1.6rem, 3.4vw, 3.8rem);--trick-gap: clamp(.65rem, .95vw, 1rem)}}.app--game{background:radial-gradient(72% 52% at 50% 34%,rgba(255,238,200,.14),transparent 58%),radial-gradient(128% 108% at 50% 42%,transparent 38%,rgba(0,0,0,.72) 100%),radial-gradient(circle at 50% 24%,var(--felt-2),var(--felt) 52%,var(--felt-edge) 100%)}.app--game .table{padding-top:calc(.78rem + env(safe-area-inset-top,0px));padding-bottom:calc(.55rem + env(safe-area-inset-bottom,0px))}.table__opponent,.table__opponent__inner,.table__seat-head,.side-player,.side-player__head,.table__player-label,.side-player__name{min-width:0}.table__opponent__inner,.side-player{overflow:visible}.table__player-label,.side-player__name,.score-panel__name,.score-panel__tag{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table__opponent--active .table__opponent__inner,.side-player--active{animation:none;background:#051c1475;box-shadow:inset 0 0 0 2px #f2d78a94,0 0 0 1px #0000004d}.avatar--active{animation:none;box-shadow:0 0 0 2px var(--gold),0 0 0 4px #2f2108e6,0 3px 8px #00000080,inset 0 2px 4px #ffffff40}.table__opponent--active .table__player-label:after{content:""}.hand--active{animation:none;box-shadow:inset 0 0 0 2px #f2d78a47}@media (orientation: landscape){.app--game .table{padding-top:calc(.95rem + env(safe-area-inset-top,0px))}.table__opponent{padding-top:.1rem}.table__middle{overflow:visible}}@media (orientation: landscape) and (max-height: 599px){.app--game .table{padding-top:calc(.45rem + env(safe-area-inset-top,0px));padding-bottom:calc(.35rem + env(safe-area-inset-bottom,0px))}.table__opponent__inner{padding:.24rem .5rem .38rem}.table__seat-head{gap:.28rem}.table__player-label,.side-player__name,.trick-area__who{font-size:.68rem}.opp-fan,.side-player__fan{height:calc(var(--card-sm) * 1.48)}.table__statusrow{overflow:visible}}@media (max-aspect-ratio: 5/6){.app--game .table{padding-inline:calc(.5rem + env(safe-area-inset-left,0px)) calc(.5rem + env(safe-area-inset-right,0px));overflow:hidden}.table__opponent__inner{padding:.28rem .55rem .45rem}.table__center{max-width:100%}.table__statusrow{max-width:100%;overflow:visible}}.app--game .table__footer,.app--game .quickchat{overflow:visible}.app--game .quickchat__palette{position:fixed;right:max(1rem,env(safe-area-inset-right,0px));left:auto;bottom:calc(5.7rem + env(safe-area-inset-bottom,0px));transform:none;width:min(400px,calc(100vw - 2rem));max-width:calc(100vw - 2rem);grid-template-columns:repeat(3,minmax(0,1fr));z-index:90}.app--game .quickchat__palette .quickchat__btn{min-width:0;white-space:normal;line-height:1.15;padding-inline:.7rem}@media (orientation: portrait),(max-width: 760px){.app--game .quickchat__palette{left:50%;right:auto;bottom:calc(4.9rem + env(safe-area-inset-bottom,0px));width:min(420px,calc(100vw - 1rem));transform:translate(-50%);grid-template-columns:repeat(2,minmax(0,1fr))}}@media (orientation: landscape) and (max-height: 599px){.app--game .quickchat__palette{right:max(.6rem,env(safe-area-inset-right,0px));bottom:calc(3.4rem + env(safe-area-inset-bottom,0px));width:min(500px,calc(100vw - 1.2rem))}.app--game .quickchat__palette .quickchat__btn{min-height:38px;padding:.35rem .5rem;font-size:.78rem}}@media (orientation: landscape) and (min-width: 1181px) and (min-height: 821px){.table{max-width:min(98vw,1900px);--center-gap: clamp(2.8rem, 4vw, 5.4rem)}.table--2v2{--card-sm: min(clamp(54px, 4.4vw, 88px), 8.8vh);--card-lg: min(clamp(96px, 6.2vw, 148px), 13.2vh);--card-xl: min(clamp(136px, 9.2vw, 220px), 19vh);--trick-gap: clamp(.95rem, 1.25vw, 1.45rem);--deck-w: calc(var(--card-lg) * 1.82);--trick-w: calc(var(--card-lg) * 4 + var(--trick-gap) * 3);--play-w: calc(var(--deck-w) + var(--center-gap) + var(--trick-w));grid-template-columns:minmax(210px,.72fr) minmax(var(--play-w),auto) minmax(210px,.72fr);column-gap:clamp(1.2rem,3vw,3.8rem)}.table--2v2 .table__center{transform:translateY(.4rem)}.table--2v2 .side-player{max-width:240px}.table--2v2 .side-player__fan{width:calc(var(--card-sm) * 2.05);height:calc(var(--card-sm) * 1.62)}.table--2v2 .table__hand{height:calc(var(--card-xl) * 1.5 + 18px)}.table--2v2 .hand{gap:clamp(1.1rem,2vw,2.2rem)}}@media (orientation: landscape) and (min-width: 1720px) and (min-height: 900px){.table--2v2{--card-sm: min(clamp(64px, 4.4vw, 96px), 9.2vh);--card-lg: min(clamp(112px, 6vw, 166px), 13.8vh);--card-xl: min(clamp(158px, 9vw, 244px), 19.5vh);grid-template-columns:minmax(240px,.78fr) minmax(var(--play-w),auto) minmax(240px,.78fr)}}@media (orientation: landscape) and (min-width: 1181px) and (max-height: 820px){.table--2v2{--card-sm: min(clamp(42px, 4vw, 72px), 8.2vh);--card-lg: min(clamp(76px, 5.8vw, 120px), 11.8vh);--card-xl: min(clamp(112px, 8.4vw, 172px), 17vh)}}@media (orientation: landscape){.table__statusrow{grid-area:quit;align-self:end;justify-self:end;justify-content:flex-end;width:min(360px,28vw);max-width:100%;height:auto;min-height:0;overflow:visible;margin-top:3.2rem;pointer-events:none}.table__statusrow .status-bar,.table__waiting{display:block;width:max-content;max-width:min(360px,28vw);padding:.42rem .78rem;border-radius:999px;background:#04160fad;border:1px solid rgba(242,215,138,.24);box-shadow:var(--shadow-1),inset 0 1px #ffffff0f;font-size:clamp(.82rem,1vw,1rem);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:auto}.table__statusrow .countdown,.table__hint,.table__seven,.table__senas,.table__continue{pointer-events:auto}}@media (orientation: landscape) and (min-width: 1181px){.table--2v2 .table__statusrow{width:min(390px,23vw)}.table--2v2 .table__statusrow .status-bar,.table--2v2 .table__waiting{max-width:min(390px,23vw)}}@media (orientation: landscape) and (max-height: 599px){.table__statusrow{margin-top:2.4rem;width:min(240px,28vw)}.table__statusrow .status-bar,.table__waiting{max-width:min(240px,28vw);padding:.32rem .58rem;font-size:.74rem}}@media (orientation: portrait){.table__statusrow .status-bar,.table__waiting{background:#04160f9e;border:1px solid rgba(242,215,138,.22);border-radius:999px;padding:.38rem .7rem;max-width:calc(100vw - 1rem);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}@media (orientation: landscape){.table:before{animation:felt-breathe 9s ease-in-out infinite}.table:after{animation:stitch-breathe 11s ease-in-out infinite}}@keyframes felt-breathe{0%,to{filter:saturate(1) brightness(1)}50%{filter:saturate(1.12) brightness(1.06)}}@keyframes stitch-breathe{0%,to{opacity:.78}50%{opacity:.98}}.score-panel,.table__opponent__inner,.side-player,.table__center,.table__hand,.table__footer{animation:table-piece-in .46s var(--ease-out);animation-fill-mode:none}.table__center{animation-delay:80ms}.table__hand{animation-delay:.15s}.app--game .table__footer{animation-name:footer-fade-in;transform:none}@keyframes footer-fade-in{0%{opacity:0}to{opacity:1}}@keyframes table-piece-in{0%{opacity:0;transform:translateY(12px) scale(.985)}to{opacity:1;transform:none}}.card,.card__img{will-change:transform,filter}.hand__slot{animation:deal-in-aaa .52s var(--ease-spring) both}.hand__slot:nth-child(1){animation-delay:40ms}.hand__slot:nth-child(2){animation-delay:.11s}.hand__slot:nth-child(3){animation-delay:.18s}@keyframes deal-in-aaa{0%{opacity:0;transform:translateY(54px) rotate(5deg) scale(.86);filter:blur(2px)}62%{opacity:1;transform:translateY(-9px) rotate(-1deg) scale(1.035);filter:blur(0)}to{opacity:1;transform:none;filter:none}}.hand--active .card--playable{animation:playable-breathe 2.25s ease-in-out infinite}.hand--active .hand__slot:nth-child(2) .card--playable{animation-delay:.12s}.hand--active .hand__slot:nth-child(3) .card--playable{animation-delay:.24s}@keyframes playable-breathe{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.card--playable:hover,.card--playable:focus-visible{animation:none;transform:translateY(-30px) scale(1.09) rotateX(9deg)}.card--playable:before{content:"";position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:12px;background:radial-gradient(circle at 50% 50%,rgba(242,215,138,.32),transparent 68%);opacity:0;transform:scale(.92);transition:opacity .18s var(--ease-out),transform .18s var(--ease-out);pointer-events:none;z-index:-1}.card--playable:hover:before,.card--playable:focus-visible:before{opacity:1;transform:scale(1)}.trump-pile__deck{animation:deck-weight 3.8s ease-in-out infinite}.trump-pile__trump{animation:trump-peek 4.4s ease-in-out infinite}@keyframes deck-weight{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes trump-peek{0%,to{transform:rotate(90deg) translate(0)}50%{transform:rotate(90deg) translate(-4px)}}.trick-area__slot .card{animation-duration:.48s}.trick-area__slot--theirs .card{animation-name:lay-in-down-aaa}.trick-area__slot--mine .card{animation-name:lay-in-up-aaa}@keyframes lay-in-down-aaa{0%{transform:translateY(-42px) translate(10px) rotate(3deg) scale(1.14);opacity:0;filter:blur(2px)}64%{transform:translateY(4px) rotate(-1deg) scale(.985);opacity:1;filter:blur(0)}to{transform:none;opacity:1;filter:none}}@keyframes lay-in-up-aaa{0%{transform:translateY(52px) translate(-8px) rotate(-3deg) scale(1.14);opacity:0;filter:blur(2px)}64%{transform:translateY(-4px) rotate(1deg) scale(.985);opacity:1;filter:blur(0)}to{transform:none;opacity:1;filter:none}}.trick-area--collect-down .trick-area__slot{animation:fly-down-aaa .52s cubic-bezier(.2,.7,.2,1) forwards}.trick-area--collect-up .trick-area__slot{animation:fly-up-aaa .52s cubic-bezier(.2,.7,.2,1) forwards}.trick-area--collect-left .trick-area__slot{animation:fly-left-aaa .52s cubic-bezier(.2,.7,.2,1) forwards}.trick-area--collect-right .trick-area__slot{animation:fly-right-aaa .52s cubic-bezier(.2,.7,.2,1) forwards}@keyframes fly-down-aaa{0%{transform:none;opacity:1}45%{transform:translateY(-8px) scale(1.04);opacity:1}to{transform:translateY(48vh) rotate(11deg) scale(.28);opacity:0}}@keyframes fly-up-aaa{0%{transform:none;opacity:1}45%{transform:translateY(8px) scale(1.04);opacity:1}to{transform:translateY(-46vh) rotate(-11deg) scale(.28);opacity:0}}@keyframes fly-left-aaa{0%{transform:none;opacity:1}45%{transform:translate(10px) scale(1.04);opacity:1}to{transform:translate(-48vw,5vh) rotate(-12deg) scale(.28);opacity:0}}@keyframes fly-right-aaa{0%{transform:none;opacity:1}45%{transform:translate(-10px) scale(1.04);opacity:1}to{transform:translate(48vw,5vh) rotate(12deg) scale(.28);opacity:0}}.table__opponent--active .table__opponent__inner,.side-player--active{animation:active-seat-aaa 1.85s ease-in-out infinite}@keyframes active-seat-aaa{0%,to{box-shadow:inset 0 0 0 2px #f2d78a94,0 0 0 1px #0000004d,0 6px 18px #00000038}50%{box-shadow:inset 0 0 0 2px #f2d78adb,0 0 18px #e0b44a61,0 8px 22px #00000047}}.table__statusrow .status-bar,.table__waiting{animation:hud-pop .36s var(--ease-spring) both}@keyframes hud-pop{0%{opacity:0;transform:translateY(8px) scale(.94)}to{opacity:1;transform:none}}.points-fly{animation:points-pop-aaa 1.1s cubic-bezier(.18,.88,.22,1) forwards}@keyframes points-pop-aaa{0%{opacity:0;transform:translate(-50%,-40%) scale(.45);filter:blur(2px)}18%{opacity:1;transform:translate(-50%,-92%) scale(1.22);filter:blur(0)}62%{opacity:1;transform:translate(-50%,-126%) scale(1)}to{opacity:0;transform:translate(-50%,-188%) scale(.84)}}.quickchat__palette{animation:palette-in-aaa .22s var(--ease-spring) both;transform-origin:bottom right}@keyframes palette-in-aaa{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:none}}@media (orientation: portrait),(max-width: 760px){.app--game .quickchat__palette{transform-origin:bottom center}.quickchat__palette{animation-name:palette-in-mobile-aaa}}@keyframes palette-in-mobile-aaa{0%{opacity:0;transform:translate(-50%) translateY(12px) scale(.96)}to{opacity:1;transform:translate(-50%)}}@media (prefers-reduced-motion: reduce){.table:before,.table:after,.score-panel,.table__opponent__inner,.side-player,.table__center,.table__hand,.table__footer,.hand__slot,.hand--active .card--playable,.trump-pile__deck,.trump-pile__trump,.table__opponent--active .table__opponent__inner,.side-player--active,.table__statusrow .status-bar,.table__waiting,.quickchat__palette{animation:none!important}}
