:root{--bg: #0b0e17;--bg2: #111827;--surface: rgba(15, 18, 30, .75);--surface2: rgba(25, 30, 45, .7);--surface-solid: #1a1f2e;--border: rgba(255, 255, 255, .08);--text: #e2e8f0;--text-muted: #64748b;--accent: #8b5cf6;--accent2: #a78bfa;--green: #22c55e;--red: #ef4444;--gold: #f59e0b;--felt: #0c2818;--felt-light: #143d24;--felt-border: #1e5c38;--card-w: 76px;--card-h: 112px;--card-w-sm: 56px;--card-h-sm: 82px;--radius: 12px;--hand-h: 210px;--bid-h: 72px;--max-card-scale: 1.45;--trick-card-w: 94px;--trick-card-h: 138px;--trick-overlap: 4px}@media (min-width: 1024px){:root{--card-w: 92px;--card-h: 134px;--card-w-sm: 64px;--card-h-sm: 94px;--hand-h: 250px;--max-card-scale: 1.22;--trick-card-w: 124px;--trick-card-h: 182px;--trick-overlap: 4px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Cinzel,Inter,Segoe UI,-apple-system,BlinkMacSystemFont,serif;background:var(--bg) url(/taverne-loop-poster.webp) center/cover no-repeat fixed;min-height:100dvh;color:var(--text);overflow:hidden}#root{min-height:100dvh;position:relative}.stage-viewport{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.stage{flex:0 0 auto;position:relative;transform-origin:center center}.stage[data-scaled=true]{will-change:transform}@media (min-width: 501px){.stage-viewport[data-orientation=portrait] .table-felt{max-width:520px}.stage-viewport[data-orientation=portrait] .table-wrapper{padding:20px 70px 90px}}.bg-video{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:-1;pointer-events:none;-webkit-user-select:none;user-select:none}.loading{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;color:var(--text-muted);font-size:1.1rem}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.btn{padding:12px 24px;font-size:.95rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s;font-family:inherit}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 14px #8b5cf659}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #8b5cf673}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.ready-prompt{text-align:center;font-size:.82rem;color:#fff2b0;margin-bottom:4px;letter-spacing:.3px;opacity:.85;animation:readyPromptFade 2.2s ease-in-out infinite}@keyframes readyPromptFade{0%,to{opacity:.7}50%{opacity:1}}.btn-ready-cta{width:100%;padding:16px 24px;font-size:1.12rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase;border:none;border-radius:14px;cursor:pointer;color:#0c1a0c;background:linear-gradient(135deg,#7ee787,#2ea043 55%,#1a7a31);box-shadow:0 0 0 2px #7ee78759,0 6px 20px #2ea0438c,0 0 28px #7ee78773,inset 0 1px #ffffff59;display:flex;align-items:center;justify-content:center;gap:10px;transition:transform .15s ease,box-shadow .2s ease;animation:readyCtaPulse 1.6s ease-in-out infinite;font-family:inherit;position:relative}.btn-ready-cta:hover{transform:translateY(-2px)}.btn-ready-cta:active{transform:translateY(0)}@keyframes readyCtaPulse{0%,to{box-shadow:0 0 0 2px #7ee78759,0 6px 20px #2ea0438c,0 0 28px #7ee78773,inset 0 1px #ffffff59}50%{box-shadow:0 0 0 4px #7ee7878c,0 8px 26px #2ea043bf,0 0 48px #7ee787bf,inset 0 1px #ffffff73}}.ready-pulse-dot{width:10px;height:10px;border-radius:50%;background:#fff;box-shadow:0 0 10px #fffffff2;animation:readyDot 1s ease-in-out infinite;display:inline-block;flex-shrink:0}@keyframes readyDot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(.6);opacity:.6}}.btn-ready-set{width:100%;padding:14px 20px;font-size:.95rem;font-weight:600;border:1px solid rgba(126,231,135,.45);border-radius:12px;cursor:pointer;background:#2ea04324;color:#9ff1a8;display:flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;transition:background .15s ease,border-color .15s ease}.btn-ready-set:hover{background:#2ea04338;border-color:#7ee787b3}.ready-check{font-weight:900;color:#7ee787;font-size:1.05rem}.ready-sub{font-size:.72rem;color:var(--text-muted);font-weight:500;margin-left:4px;opacity:.75}.btn-ghost{background:none;color:var(--text-muted);padding:8px 16px}.btn-ghost:hover{color:var(--text)}.btn-icon{position:relative;background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-icon:hover{color:var(--text);background:var(--border)}.audio-menu-wrap{position:relative;display:inline-flex}.audio-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #00000073;padding:6px;z-index:50;display:flex;flex-direction:column;gap:2px}.audio-menu-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border-radius:6px}.audio-menu-row:hover{background:var(--border)}.audio-menu-label{color:var(--text);font-size:.88rem;font-family:Cinzel,serif;letter-spacing:.3px}.audio-toggle{position:relative;width:38px;height:22px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);padding:0;cursor:pointer;transition:background .18s,border-color .18s;flex:0 0 auto}.audio-toggle.on{background:var(--gold, #c9a86a);border-color:var(--gold, #c9a86a)}.audio-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0006;transition:left .18s}.audio-toggle.on .audio-toggle-knob{left:18px}.lobby-screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:safe center;justify-content:safe center;padding:20px;background:transparent;overflow-y:auto}.lobby-card{background:var(--surface);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:20px;padding:40px 32px;width:100%;max-width:380px;text-align:center}.lobby-card.wide{max-width:460px}.logo{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}.logo-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:14px;font-size:1.8rem;font-weight:900;color:#fff;font-family:Georgia,serif}.logo-icon.sm{width:36px;height:36px;font-size:1.1rem;border-radius:10px}.logo-text{font-size:2.2rem;font-weight:400;font-family:MedievalSharp,cursive;background:linear-gradient(135deg,var(--gold),#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:3px}.logo-sm{display:flex;align-items:center;gap:8px;justify-content:center;margin-bottom:16px;font-size:1.3rem;font-weight:700;color:var(--accent2)}.subtitle{color:var(--text-muted);margin-bottom:28px;font-size:.95rem;font-family:MedievalSharp,cursive}.character-picker{margin-bottom:16px;padding:14px;background:var(--bg2);border-radius:12px;border:1px solid var(--border)}.character-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.character-grid{display:grid;grid-template-columns:repeat(4,56px);gap:12px;justify-content:center}.character-btn{display:block;padding:0;background:transparent;border:none;cursor:pointer;line-height:0}.character-img{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--border);transition:border-color .2s,box-shadow .2s}.character-btn.selected .character-img{border-color:var(--accent);box-shadow:0 0 12px #8b5cf680}.character-name{font-size:.7rem;font-weight:600;color:var(--text-muted)}.character-btn.selected .character-name{color:var(--accent2)}.difficulty-picker{margin-bottom:16px;padding:14px;background:var(--bg2);border-radius:12px;border:1px solid var(--border)}.difficulty-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.difficulty-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.diff-btn{padding:10px 6px;background:transparent;border:2px solid var(--border);border-radius:10px;color:var(--text-muted);font-family:inherit;font-size:.9rem;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:border-color .15s,color .15s,background .15s,box-shadow .2s}.diff-btn:hover{border-color:var(--accent);color:var(--text)}.diff-btn.selected{border-color:var(--accent);color:var(--accent2);background:#8b5cf61a;box-shadow:0 0 12px #8b5cf64d}.form-group{margin-bottom:12px}.form-group input,.lobby-card input{width:100%;padding:14px 16px;font-size:1rem;font-family:inherit;border:2px solid var(--border);border-radius:10px;background:var(--bg2);color:var(--text);text-align:center;transition:border-color .2s}.form-group input:focus,.lobby-card input:focus{outline:none;border-color:var(--accent)}.form-group.needs-name input{border-color:var(--red);animation:shakeName .35s ease}@keyframes shakeName{0%,to{transform:translate(0)}25%{transform:translate(-6px)}50%{transform:translate(6px)}75%{transform:translate(-3px)}}.name-warning{color:var(--red);font-size:.85rem;text-align:center;margin-top:6px}.lobby-card .btn{width:100%}.lobby-mp-btn{margin-top:10px}.error-msg{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--red);padding:10px 16px;border-radius:10px;margin-bottom:16px;font-size:.9rem}.error-bar{background:#ef44441f;color:var(--red);padding:8px 16px;border-radius:8px;text-align:center;font-size:.85rem;margin-bottom:8px}.you-label{background:#8b5cf61f;padding:8px 20px;border-radius:20px;margin-bottom:20px;font-size:.95rem}.room-code-display{background:var(--bg2);border:1px solid var(--border);border-radius:14px;padding:18px 16px;margin-bottom:20px;text-align:center}.rcd-label{font-size:.72rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}.rcd-code-big{display:block;width:100%;background:#8b5cf614;border:1px dashed rgba(139,92,246,.4);color:var(--text);font-family:Courier New,monospace;font-size:2.4rem;font-weight:700;letter-spacing:10px;padding:14px 4px 14px 14px;border-radius:10px;cursor:pointer;transition:background .15s,transform .1s;user-select:all;-webkit-user-select:all}.rcd-code-big:hover{background:#8b5cf624}.rcd-code-big:active{transform:scale(.99)}.rcd-share-btn{width:100%;margin-top:12px;font-size:.95rem;padding:10px 16px}.rcd-count{color:var(--text-muted);font-size:.85rem;margin-top:10px}.mp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:20px;animation:mpFade .2s ease}@keyframes mpFade{0%{opacity:0}to{opacity:1}}.mp-modal{position:relative;width:100%;max-width:380px;background:var(--bg2);border:1px solid var(--border);border-radius:16px;padding:28px 24px 24px;box-shadow:0 20px 60px #0009;animation:mpSlide .25s cubic-bezier(.4,0,.2,1)}@keyframes mpSlide{0%{transform:translateY(12px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.mp-close{position:absolute;top:10px;right:12px;background:transparent;border:none;color:var(--text-muted);font-size:1.6rem;line-height:1;cursor:pointer;padding:4px 10px;transition:color .15s,transform .15s}.mp-close:hover{color:var(--text);transform:scale(1.15)}.mp-title{font-family:MedievalSharp,Cinzel,serif;font-size:1.5rem;color:var(--text);text-align:center;margin-bottom:18px;letter-spacing:1px}.mp-hint{text-align:center;color:var(--text-muted);font-size:.85rem;margin-bottom:12px}.mp-create-btn{width:100%;font-size:1rem;padding:14px 16px}.mp-divider{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:.72rem;margin:18px 0 14px;text-transform:uppercase;letter-spacing:2px}.mp-divider:before,.mp-divider:after{content:"";flex:1;height:1px;background:var(--border)}.mp-join-row{display:flex;gap:8px;align-items:stretch}.mp-code-input{flex:1 1 auto;min-width:0;text-align:center;text-transform:uppercase;font-family:Courier New,monospace;font-size:1.2rem;letter-spacing:8px;padding-left:16px}.mp-join-btn{flex:0 0 auto;width:auto!important;padding:0 22px}.player-list{margin-bottom:20px}.pl-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;margin-bottom:4px;transition:background .2s}.pl-row:hover{background:#ffffff08}.pl-row.is-me{background:#8b5cf61a}.pl-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;color:var(--accent2)}img.pl-avatar{display:block}.pl-name{flex:1;font-weight:500}.pl-badges{display:flex;gap:6px}.badge{padding:3px 10px;border-radius:8px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.badge-host{background:var(--accent);color:#fff}.badge-ready{background:var(--green);color:#fff}.badge-dealer{background:var(--gold);color:#000;font-size:.65rem;padding:2px 6px}.game-rules{margin-bottom:16px}.rule-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;padding:10px 14px;border-radius:10px;background:var(--bg2);border:1px solid var(--border);transition:background .15s}.rule-toggle:hover{background:var(--surface2)}.rule-switch{width:36px;height:20px;border-radius:10px;background:var(--border);position:relative;transition:background .2s;flex-shrink:0}.rule-switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--text-muted);transition:transform .2s,background .2s}.rule-switch.on{background:var(--accent)}.rule-switch.on:after{transform:translate(16px);background:#fff}.rule-label{font-weight:600;font-size:.9rem;color:var(--text)}.rule-hint{font-size:.75rem;color:var(--text-muted);margin-left:auto}.lobby-buttons{display:flex;flex-direction:column;gap:8px}.game-screen{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;grid-template-rows:auto 1fr auto auto;grid-template-areas:"topbar" "table" "bid" "hand";padding-top:max(12px,env(safe-area-inset-top,0px));padding-right:max(12px,env(safe-area-inset-right,0px));padding-bottom:max(12px,env(safe-area-inset-bottom,0px));padding-left:max(12px,env(safe-area-inset-left,0px));gap:10px;overflow:hidden;background:transparent}.game-screen>.topbar{grid-area:topbar}.game-screen>.table-wrapper{grid-area:table;min-height:0}.game-screen>.bid-slot{grid-area:bid}.game-screen>.hand-area{grid-area:hand}.stage-viewport[data-profile=landscape-16-10],.stage-viewport[data-profile=landscape-4-3]{--arc-pivot: 1700;--arc-max-angle: 22;--max-card-scale: 1.5;--hand-h: 260px}.stage-viewport[data-profile=landscape-16-10] .hand-area,.stage-viewport[data-profile=landscape-4-3] .hand-area{max-width:1000px}.stage-viewport[data-profile=portrait-tablet-tall]{--hand-h: 240px;--bid-h: 76px}.stage-viewport[data-profile=portrait-tablet-wide]{--hand-h: 220px}.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:10px 16px;background:var(--surface);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);gap:12px;flex-wrap:wrap;position:relative;isolation:isolate}.tb-left{display:flex;align-items:center;gap:10px}.tb-logo{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.95rem;color:#fff;font-family:Georgia,serif}.tb-room{color:var(--text-muted);font-size:.85rem;font-family:monospace;letter-spacing:2px}.btn-leave-sm{background:none;border:1px solid var(--border);color:var(--text-muted);width:28px;height:28px;border-radius:6px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-left:4px}.btn-leave-sm:hover{color:var(--red);border-color:var(--red)}.tb-center{text-align:center}.tb-round{font-size:1.1rem;font-weight:700;color:var(--accent2);font-family:MedievalSharp,cursive}.tb-dealer{font-size:.8rem;color:var(--text-muted)}.tb-right{display:flex;align-items:center;gap:10px;justify-self:end}.music-player{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.music-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;flex-shrink:0}.music-btn:hover{color:var(--text);background:var(--border)}.music-track-name{font-size:.72rem;font-weight:700;color:var(--accent2);letter-spacing:1px;text-transform:uppercase;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.music-volume{width:60px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none;cursor:pointer;flex-shrink:0}.music-volume::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}.music-volume::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--accent);border:none;cursor:pointer}@media (max-width: 600px){.music-player{padding:4px 8px;gap:6px}.music-volume{width:45px}.music-track-name{font-size:.65rem}}.trump-section{display:flex;align-items:center;gap:10px}.trump-display{display:flex;flex-direction:column;align-items:center;padding:6px 16px;border-radius:12px;background:var(--surface2);border:2px solid var(--border);gap:2px;min-width:64px;transition:border-color .3s,background .3s,color .3s}.trump-display-icon,.trump-display-label{transition:color .3s}.trump-display-icon{font-size:2rem;line-height:1}.trump-display-icon--sm{font-size:1.2rem;color:var(--text-muted)}.trump-display-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);white-space:nowrap}.trump-flip-container{perspective:600px;width:var(--card-w-sm);height:var(--card-h-sm)}.trump-flip-container.peekable{cursor:zoom-in;-webkit-tap-highlight-color:transparent}.trump-flip-container.peekable:hover{filter:brightness(1.08)}.trump-peek-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#05060cd1;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:300;animation:trumpPeekFadeIn .18s ease-out both;cursor:zoom-out;-webkit-tap-highlight-color:transparent}.trump-peek-card{transform-origin:center;animation:trumpPeekPop .26s cubic-bezier(.25,.9,.35,1.25) both;filter:drop-shadow(0 16px 48px rgba(0,0,0,.8)) drop-shadow(0 0 32px rgba(255,200,80,.35))}.trump-peek-card .game-card{width:min(68vw,320px);height:auto;aspect-ratio:53 / 72;pointer-events:none}.trump-peek-card .game-card .gc-img{width:100%;height:100%;object-fit:cover}@keyframes trumpPeekFadeIn{0%{opacity:0}to{opacity:1}}@keyframes trumpPeekPop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.trump-flip-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transform:rotateY(180deg)}.trump-flip-container.flipping .trump-flip-inner{animation:trumpFlip .8s ease forwards}@keyframes trumpFlip{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}.trump-flip-front,.trump-flip-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden}.trump-flip-front{transform:rotateY(180deg)}.trump-flip-back{transform:rotateY(0)}.trump-display.none{border-color:var(--border)}.trump-display.choosing{border-color:var(--gold);animation:pulse 1.5s ease-in-out infinite}.trump-display.choosing .trump-display-icon{color:var(--gold);font-size:1.4rem}.trump-display.choosing .trump-display-label{color:var(--gold)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.table-wrapper{flex:1;display:flex;align-items:center;justify-content:center;min-height:200px}.table-felt{position:relative;isolation:isolate;width:100%;max-width:828px;aspect-ratio:923 / 532;height:auto}.table-felt:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url(/TISCH.png?v=3) center/100% 100% no-repeat;filter:brightness(.8) drop-shadow(0 8px 24px rgba(0,0,0,.55));pointer-events:none;z-index:-1}.seat{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:2px;z-index:10;transition:transform .3s;pointer-events:none}.seat-score{position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);font-family:Inter,system-ui,sans-serif;font-size:.72rem;font-weight:600;color:var(--gold);text-shadow:0 1px 2px rgba(0,0,0,.7);line-height:1;letter-spacing:.3px;animation:seatScoreIn .35s ease-out both;white-space:nowrap}@keyframes seatScoreIn{0%{opacity:0;transform:translate(-50%,-4px)}to{opacity:1;transform:translate(-50%)}}.seat-score.negative{color:var(--red)}@media (max-width: 600px){.seat-score{font-size:.62rem}}.seat-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);transition:border-color .3s,box-shadow .3s;object-fit:cover;flex-shrink:0}.seat-avatar-letter{background:var(--surface);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:var(--accent2)}.seat.active{transform:translate(-50%,-50%) scale(1.2);z-index:20}.seat.active .seat-avatar{border-color:var(--gold);border-width:3px;animation:activeGlow 1.4s ease-in-out infinite}@keyframes activeGlow{0%,to{box-shadow:0 0 0 3px #f59e0b59,0 0 14px 2px #f59e0b8c,0 0 28px 6px #f59e0b4d}50%{box-shadow:0 0 0 5px #f59e0b8c,0 0 22px 4px #f59e0bd9,0 0 44px 10px #f59e0b73}}.seat.active .seat-name{color:var(--gold);text-shadow:0 1px 4px rgba(0,0,0,.9),0 0 8px rgba(245,158,11,.6)}.seat-me .seat-avatar{border-color:var(--accent);box-shadow:0 0 8px #8b5cf666}.seat-name{font-size:.6rem;font-weight:600;color:var(--text);white-space:nowrap;max-width:62px;overflow:hidden;text-overflow:ellipsis;font-family:MedievalSharp,cursive;text-shadow:0 1px 4px rgba(0,0,0,.8);line-height:1}.seat-info{display:flex;align-items:center;justify-content:center;gap:3px}.seat-avatar-wrap{position:relative;display:inline-flex;line-height:0}.seat-dealer-chip{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 30% 25%,#ffe58a 0%,var(--gold, #e6b84a) 55%,#8a6a1f 100%);color:#2b1d00;font-family:Inter,system-ui,sans-serif;font-size:.62rem;font-weight:900;letter-spacing:.2px;display:inline-flex;align-items:center;justify-content:center;border:1.5px solid #4a3612;box-shadow:0 1px 3px #0000008c,0 0 10px #e6b84a8c,inset 0 0 2px #ffffff8c;z-index:3;pointer-events:none;animation:dealerChipPulse 2.2s ease-in-out infinite}@keyframes dealerChipPulse{0%,to{box-shadow:0 1px 3px #0000008c,0 0 8px #e6b84a66,inset 0 0 2px #ffffff8c}50%{box-shadow:0 1px 3px #0000008c,0 0 14px #e6b84ae6,inset 0 0 2px #ffffffb3}}@media (max-width: 600px){.seat-dealer-chip{width:15px;height:15px;font-size:.55rem;top:-4px;right:-4px}}.seat-bid-tricks{display:flex;align-items:center;justify-content:center;gap:2px;background:#0009;border-radius:6px;padding:2px 6px;font-size:.65rem;min-width:54px}.sbt-bid{font-size:1.1rem;font-weight:700;color:var(--text-muted);min-width:1ch;text-align:center;font-variant-numeric:tabular-nums}.sbt-sep{font-size:.8rem;color:var(--text-muted);opacity:.5}.sbt-tricks{font-size:1.1rem;font-weight:800;min-width:1ch;text-align:center;font-variant-numeric:tabular-nums}.seat-bid-tricks.bid-flash{animation:bidFlash 1.8s ease-out both;z-index:30;position:relative}.seat-bid-tricks.bid-flash .sbt-bid{color:var(--gold);text-shadow:0 0 8px rgba(245,158,11,.9)}@keyframes bidFlash{0%{transform:scale(1);background:#0009;box-shadow:0 0 #f59e0b00}12%{transform:scale(2);background:#f59e0b40;box-shadow:0 0 20px 6px #f59e0bcc,0 0 40px 12px #f59e0b4d}35%{transform:scale(1.7);background:#f59e0b26;box-shadow:0 0 14px 4px #f59e0b80,0 0 28px 8px #f59e0b33}to{transform:scale(1);background:#0009;box-shadow:0 0 #f59e0b00}}.seat-cards-back{display:flex;justify-content:center;margin-top:4px}.mini-card-back{width:18px;height:26px;border-radius:3px;background:linear-gradient(135deg,var(--accent),var(--accent2));border:1px solid rgba(255,255,255,.15);box-shadow:0 1px 3px #0000004d}.table-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:3;width:80%;max-width:360px;border-radius:16px;transition:background .2s,box-shadow .2s}.table-center.priority{z-index:50}.table-center.priority .center-panel{background:#000000d9;box-shadow:0 8px 32px #0009,0 0 0 1px #f59e0b40}.table-center.drag-over{background:#22c55e1f;box-shadow:0 0 20px #22c55e4d}.center-panel{background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;padding:20px;border:1px solid rgba(255,255,255,.1)}.cp-title{font-size:1.1rem;font-weight:700;color:var(--gold);margin-bottom:4px;font-family:MedievalSharp,cursive}.cp-subtitle{font-size:.85rem;color:var(--text-muted);margin-bottom:12px}.cp-waiting{color:var(--text-muted);font-style:italic;padding:16px}.trump-choices{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}@media (max-width: 480px){.trump-choices{gap:6px}.trump-btn{width:52px;height:64px}}.trump-btn{width:60px;height:72px;border-radius:10px;border:2px solid rgba(255,255,255,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all .2s;color:#fff}.trump-btn:hover{transform:scale(1.08);border-color:#ffffff80;box-shadow:0 4px 20px #0006}.trump-btn--none{background:linear-gradient(135deg,var(--surface-solid),#0f1320);color:var(--text-muted)}.trump-btn-sym{font-size:1.5rem}.trump-btn-name{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.trick-display{display:flex;justify-content:center;align-items:flex-end;gap:0;flex-wrap:nowrap;transition:all .5s ease;max-width:70%;margin:0 auto}.trick-display .game-card{width:var(--trick-card-w);height:var(--trick-card-h)}.trick-display.completed{animation:trickComplete .3s ease}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes trickComplete{0%{transform:scale(1)}50%{transform:scale(1.03)}to{transform:scale(1)}}.trick-entry{text-align:center;transition:all .2s;margin:0 calc(-1 * var(--trick-overlap));animation:cardSlideIn .3s ease both;min-width:0}@keyframes cardSlideIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.trick-entry.winner .game-card{box-shadow:0 0 22px #ffd550,0 0 48px #ffb428a6,0 0 84px #ffa01e59;border-color:#f4c851;animation:winnerPulse .9s cubic-bezier(.2,.8,.3,1) forwards;z-index:5}@keyframes winnerPulse{0%{transform:scale(1)}40%{transform:scale(1.18);box-shadow:0 0 44px #ffd550,0 0 88px #ffb428e6}to{transform:scale(1.1)}}.winner-burst{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible;z-index:18}.wb-spark{position:absolute;top:50%;left:50%;width:6px;height:6px;border-radius:50%;background:radial-gradient(circle,#fff7cf,#ffd75a 45%,#ffb42800 70%);transform:translate(-50%,-50%);animation:wbSpark .85s cubic-bezier(.2,.7,.3,1) forwards}@keyframes wbSpark{0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}15%{opacity:1}to{opacity:0;transform:translate(calc(-50% + var(--wb-dx)),calc(-50% + var(--wb-dy))) scale(.6)}}.te-name{font-size:.55rem;letter-spacing:.02em;color:#ffffff8c;margin-bottom:3px;white-space:nowrap;max-width:calc(var(--trick-card-w) + 4px);overflow:hidden;text-overflow:ellipsis;text-align:center}.trick-winner-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;padding:6px 18px;border-radius:12px;font-size:1rem;font-weight:700;font-family:MedievalSharp,cursive;white-space:nowrap;z-index:20;animation:winnerFade .3s ease}@keyframes winnerFade{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.turn-info{padding:16px}.ti-phase{color:#fef3c7;font-size:1.15rem;font-weight:400;letter-spacing:.5px;text-shadow:0 2px 4px rgba(0,0,0,.9),0 0 12px rgba(0,0,0,.7)}.ti-you{color:#4ade80;font-size:1.3rem;font-weight:400;animation:pulse 1.5s ease-in-out infinite;font-family:MedievalSharp,cursive;text-shadow:0 2px 6px rgba(0,0,0,.95),0 0 14px rgba(34,197,94,.5)}.ti-wait{color:#f3f4f6;font-size:1.05rem;font-weight:400;text-shadow:0 2px 4px rgba(0,0,0,.9),0 0 10px rgba(0,0,0,.6)}.turn-label{margin-top:8px;font-size:.8rem;color:var(--text-muted)}.my-seat-bar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:var(--surface);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius)}.msb-identity{display:flex;align-items:center;gap:8px;flex-shrink:0}.msb-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid var(--accent);flex-shrink:0}.msb-name{font-weight:600;font-size:.85rem;display:flex;align-items:center}.my-stats-row{display:flex;align-items:stretch;background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin:0 auto}.my-stat{padding:8px 20px;text-align:center;min-width:76px}.my-stat-label{font-size:.58rem;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:2px}.my-stat-value{font-size:2rem;font-weight:900;color:var(--text);line-height:1;font-family:Georgia,serif;transition:color .3s}.my-stat-divider{width:1px;background:var(--border);align-self:stretch}.bid-slot{width:100%;max-width:640px;margin:0 auto;min-height:var(--bid-h);display:flex;align-items:stretch;flex-direction:column;justify-content:center;z-index:5;pointer-events:none}.bid-slot>*{pointer-events:auto}.bid-bar{background:var(--surface);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:10px 16px;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}.bid-controls{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:nowrap;min-width:0;max-width:100%}.bid-label{font-weight:600;font-size:.9rem;font-family:MedievalSharp,cursive}.bid-spinner{display:flex;align-items:center;gap:0;background:var(--bg2);border-radius:10px;border:1px solid var(--border);overflow:hidden}.btn-spin{width:44px;height:44px;background:var(--surface2);border:none;color:var(--text);font-size:1.3rem;font-weight:700;cursor:pointer;transition:background .15s;font-family:inherit}.btn-spin:hover{background:var(--border)}.bid-value{width:60px;text-align:center;font-size:1.6rem;font-weight:800;color:var(--accent)}.btn-bid{padding:10px 28px}.bid-value.forbidden{color:var(--red);text-decoration:line-through}.forbidden-hint{color:var(--red);font-size:.75rem;font-weight:700;background:#ef44441f;padding:4px 8px;border-radius:6px;white-space:nowrap;flex:0 0 auto;line-height:1}.bid-waiting{color:var(--text-muted);font-style:italic}.bid-done-bar{text-align:center;padding:0 16px;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius);font-size:.9rem;height:100%;display:flex;align-items:center;justify-content:center}.hand-area{background:var(--surface);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;max-width:640px;margin:0 auto;width:100%;height:var(--hand-h);flex-shrink:0}.hand-cards{display:flex;justify-content:center;flex-wrap:wrap;padding:4px 0;gap:6px;min-height:var(--card-h)}.hand-cards.fan{position:relative;display:block;height:100%;padding:4px 0;min-height:0}.hand-cards.fan .card-slot{position:absolute;left:50%;bottom:max(calc(8px + var(--actual-dip, 0px)),calc((100% - var(--card-h) + var(--actual-dip, 0px)) / 2));margin-left:calc(var(--card-w) / -2);width:var(--card-w);height:var(--card-h);transform-origin:center calc(100% + var(--pivot, 500px));transform:rotate(var(--angle, 0deg));transition:transform .35s cubic-bezier(.22,.61,.36,1),width .4s ease,height .4s ease,margin-left .4s ease}.card-slot{cursor:not-allowed;flex-shrink:0}.card-inner{width:100%;height:100%;transition:transform .28s cubic-bezier(.34,1.46,.64,1),filter .22s ease;transform-origin:center bottom}.card-slot.disabled .card-inner{opacity:.75;filter:saturate(.7) brightness(.8)}.card-slot.playable{cursor:pointer}@media (hover: hover){.card-slot.playable:hover{z-index:50}.card-slot.playable:hover .card-inner{transform:translateY(-22px) rotate(calc(-1 * var(--angle, 0deg))) scale(1.12);filter:drop-shadow(0 8px 20px rgba(0,0,0,.5))}}.card-slot.selected{z-index:60}.card-slot.selected .card-inner{transform:translateY(-32px) rotate(calc(-1 * var(--angle, 0deg))) scale(1.15);filter:drop-shadow(0 0 12px rgba(255,215,0,.9)) drop-shadow(0 8px 20px rgba(0,0,0,.5))}.card-slot.trump-highlight:after{content:"";position:absolute;bottom:4px;left:4px;width:7px;height:7px;background:radial-gradient(circle at 30% 30%,#fff0a8 0%,var(--gold) 60%,#a67c15 100%);border-radius:50%;z-index:10;box-shadow:0 0 4px #f5c850d9,0 1px 2px #0006;pointer-events:none}.card-slot.trump-highlight .game-card{box-shadow:0 0 8px #f59e0b66}.card-slot.deal-in{animation:dealIn .5s cubic-bezier(.34,1.46,.64,1) both}@keyframes dealIn{0%{opacity:0;transform:rotate(var(--angle, 0deg)) translateY(80px) scale(.55)}to{opacity:1;transform:rotate(var(--angle, 0deg)) translateY(0) scale(1)}}.hand-empty{color:var(--text-muted);display:flex;align-items:center;font-size:.85rem}.game-card{width:var(--card-w);height:var(--card-h);border-radius:8px;position:relative;-webkit-user-select:none;user-select:none;transition:box-shadow .2s,border-color .2s,width .4s ease,height .4s ease;box-shadow:0 2px 6px #00000040;border:2px solid transparent;overflow:hidden}.game-card.sm{width:var(--card-w-sm);height:var(--card-h-sm)}.game-card.normal{background:transparent;border-color:transparent;box-shadow:none;overflow:hidden}.gc-img{width:100%;height:100%;object-fit:cover;border-radius:6px;display:block}.gc-badge{position:absolute;top:3px;left:3px;min-width:18px;height:18px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6);line-height:1;padding:0 3px;z-index:1}.gc-corner{position:absolute;font-size:.65rem;font-weight:800;line-height:1.1}.game-card.sm .gc-corner{font-size:.55rem}.gc-corner.tl{top:4px;left:5px}.gc-corner.br{bottom:4px;right:5px;transform:rotate(180deg)}.gc-pips{position:absolute;top:14px;right:8px;bottom:14px;left:8px}.gc-pip{position:absolute;transform:translate(-50%,-50%);line-height:1}.gc-pip.flipped{transform:translate(-50%,-50%) rotate(180deg)}.game-card.sm .gc-pips{top:12px;right:6px;bottom:12px;left:6px}.game-card.sm .gc-pip{font-size:.5rem!important}.gc-face-letter{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);font-size:1.8rem;font-weight:900;font-family:Georgia,serif;line-height:1}.gc-face-suit{position:absolute;top:62%;left:50%;transform:translate(-50%,-50%);font-size:1.2rem}.game-card.sm .gc-face-letter{font-size:1.3rem}.game-card.sm .gc-face-suit{font-size:.9rem}.game-card.card-back,.game-card.mage,.game-card.fool{background:transparent;border-color:transparent;box-shadow:none;overflow:hidden}.ambient-particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.ambient-particle{position:absolute;border-radius:50%;background:radial-gradient(circle,#c4b5fdcc,#8b5cf64d);animation:ambientFloat linear infinite;box-shadow:0 0 4px #c4b5fd4d}@keyframes ambientFloat{0%{transform:translateY(0) translate(0) scale(1);opacity:0}10%{opacity:var(--particle-opacity, .2)}50%{transform:translateY(-40px) translate(15px) scale(1.3)}90%{opacity:var(--particle-opacity, .2)}to{transform:translateY(-80px) translate(-10px) scale(.8);opacity:0}}.confetti-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:200;overflow:hidden}.confetti-piece{position:absolute;top:-10px;border-radius:2px;animation:confettiFall linear forwards}@keyframes confettiFall{0%{opacity:1;transform:translateY(0) translate(0) rotate(0)}to{opacity:0;transform:translateY(100vh) translate(var(--drift, 0px)) rotate(calc(var(--rotation, 0deg) + 720deg))}}.sparkle-container{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5;overflow:hidden}.sparkle-center{z-index:150}.sparkle{position:absolute;border-radius:50%;background:radial-gradient(circle,#fde68a,#f59e0b);box-shadow:0 0 6px #fde68a,0 0 12px #fde88a80;animation:sparkleAnim ease-out forwards}@keyframes sparkleAnim{0%{opacity:0;transform:scale(0) translateY(0)}30%{opacity:1;transform:scale(1.2) translateY(-10px)}to{opacity:0;transform:scale(0) translateY(-30px)}}.smoke-puff{position:absolute;border-radius:50%;background:radial-gradient(circle,#a08cb499,#503c6433);filter:blur(6px);animation:smokePuff ease-out forwards}@keyframes smokePuff{0%{opacity:0;transform:scale(.3) translate(0)}25%{opacity:.7;transform:scale(1) translate(calc(var(--dx) * .3),calc(var(--dy) * .3))}to{opacity:0;transform:scale(1.8) translate(var(--dx),var(--dy))}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:overlayFade .18s ease-out}.overlay-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px;max-width:480px;width:100%;text-align:center;max-height:85vh;overflow-y:auto;animation:overlayCardIn .22s cubic-bezier(.2,.9,.3,1.2);transform-origin:center}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}@keyframes overlayCardIn{0%{opacity:0;transform:scale(.94) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.overlay-card.wide{max-width:700px}.overlay-card h2{font-size:1.3rem;margin-bottom:16px;color:var(--accent2)}.overlay-hint{margin-top:16px;color:var(--text-muted);font-size:.85rem;font-style:italic}.summary-table{width:100%;border-collapse:collapse;font-size:.9rem}.summary-table th{padding:8px 12px;color:var(--text-muted);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.summary-table td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.04)}.summary-table tr.is-me{background:#8b5cf614}.summary-table tr.hit td:nth-child(4){color:var(--green)}.summary-table tr.miss td:nth-child(4){color:var(--red)}.positive{color:var(--green)}.negative{color:var(--red)}@keyframes winner-glow{0%,to{box-shadow:inset 0 0 0 1px #fac83c4d,inset 0 0 18px #fac83c14}50%{box-shadow:inset 0 0 0 1px #fac83cb3,inset 0 0 28px #fac83c38}}@keyframes banner-in{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.round-winner-banner{display:flex;align-items:center;justify-content:center;gap:10px;margin:8px 0 16px;padding:9px 18px;background:linear-gradient(135deg,#fac83c1f,#faa01412);border:1px solid rgba(250,200,60,.35);border-radius:8px;color:#f5c842;font-weight:700;font-size:.95rem;letter-spacing:.3px;animation:banner-in .4s ease both}.round-winner-banner.is-me{background:linear-gradient(135deg,#8b5cf62e,#fac83c1a);border-color:#8b5cf680;color:#c4a7f5}.round-winner-banner.is-tie{background:linear-gradient(135deg,#64b4ff1a,#64dcc812);border-color:#64c8ff59;color:#7ecfee}.round-winner-star{font-size:.85rem;opacity:.8}.summary-table tr.round-winner-row{animation:winner-glow 1.8s ease-in-out infinite;background:#fac83c0f!important}.winner-crown{color:#f5c842;margin-right:5px;font-size:.85rem}.sb-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sb-header h2{margin-bottom:0}.btn-close{background:var(--surface2);border:1px solid var(--border);color:var(--text);width:32px;height:32px;border-radius:8px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.btn-close:hover{background:var(--border)}.sb-empty{color:var(--text-muted);padding:20px}.sb-scroll{overflow-x:auto}.score-table{width:100%;border-collapse:collapse;font-size:.8rem;white-space:nowrap}.score-table th,.score-table td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.05);text-align:center}.score-table th{color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;position:sticky;top:0;background:var(--surface)}.score-table th.is-me,.score-table td.is-me{background:#8b5cf614}.sb-bid{color:var(--text-muted);margin-right:4px}.sb-pts{font-weight:600;margin-right:4px}.sb-total{color:var(--text-muted);font-size:.7rem}.score-table tfoot td{border-top:2px solid var(--border);font-size:.9rem;padding:10px}.end-screen{position:relative;overflow:hidden}.end-card{position:relative;z-index:2}.end-hero{position:relative;width:128px;height:128px;margin:8px auto 14px;display:flex;align-items:center;justify-content:center;animation:endHeroIn .6s cubic-bezier(.2,.7,.3,1.3) both}.end-hero-avatar{width:128px;height:128px;border-radius:50%;object-fit:cover;border:3px solid #f4c851;box-shadow:0 6px 22px #0000008c,0 0 36px #f4c8518c,inset 0 0 12px #ffdc7840;position:relative;z-index:2;background:var(--surface2)}.end-hero-avatar-letter{display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:800;color:var(--accent2)}.end-hero-crown{position:absolute;top:-22px;left:50%;transform:translate(-50%);font-size:2.4rem;color:#ffd75a;text-shadow:0 2px 6px rgba(0,0,0,.55),0 0 16px rgba(255,215,90,.9);z-index:3;animation:endCrownBob 2.4s ease-in-out infinite}.end-hero-glow{position:absolute;top:-28px;right:-28px;bottom:-28px;left:-28px;border-radius:50%;background:radial-gradient(circle,#ffd75a59,#ffb42826 45%,#0000 70%);animation:endHeroGlow 2.8s ease-in-out infinite;z-index:1}@keyframes endHeroIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes endCrownBob{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-4px)}}@keyframes endHeroGlow{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.end-title{font-size:2.1rem;font-weight:400;font-family:MedievalSharp,cursive;margin-bottom:6px;background:linear-gradient(135deg,#fff2b0,#f4c851 45%,#d59923);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-align:center;letter-spacing:.5px;animation:endTitleIn .7s ease both .2s}.end-subtitle{text-align:center;color:var(--text-muted);font-size:.92rem;margin-bottom:22px;animation:endTitleIn .7s ease both .35s}@keyframes endTitleIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.podium{margin-bottom:24px}.podium-entry{display:flex;align-items:center;gap:12px;padding:14px 16px;margin-bottom:6px;border-radius:12px;background:#ffffff08;transition:background .2s;opacity:0;animation:podiumEntryIn .45s cubic-bezier(.2,.7,.3,1.1) both}@keyframes podiumEntryIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.podium-entry.is-me{background:#8b5cf61f;border:1px solid rgba(139,92,246,.3)}.podium-entry.rank-0{background:linear-gradient(135deg,#f5c85038,#f59e0b1f);border:1px solid rgba(245,200,80,.45);box-shadow:0 0 18px #f5c85033}.pe-rank{font-size:1.5rem;width:40px;text-align:center}.pe-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--accent2);border:2px solid var(--border)}img.pe-avatar{display:block}.pe-name{flex:1;font-weight:600;text-align:left}.pe-score{font-weight:700;color:var(--accent);font-size:1.1rem}.end-buttons{display:flex;flex-direction:column;gap:8px}@media (max-width: 600px){.topbar{padding:6px max(8px,env(safe-area-inset-right,0px)) 6px max(8px,env(safe-area-inset-left,0px));gap:4px;grid-template-columns:1fr auto;backdrop-filter:none;-webkit-backdrop-filter:none}.seat.active .seat-avatar{animation:activeGlowMobile 1.4s ease-in-out infinite}@keyframes activeGlowMobile{0%,to{box-shadow:0 0 0 2px #f59e0b73,0 0 8px 1px #f59e0b73}50%{box-shadow:0 0 0 3px #f59e0ba6,0 0 12px 2px #f59e0ba6}}.tb-left{display:none}.tb-left{gap:6px}.tb-round{font-size:.8rem}.tb-dealer{font-size:.7rem}.tb-right{gap:4px}.btn-icon{width:30px;height:30px;border-radius:7px}.music-player{padding:3px 8px;gap:5px}.music-btn{width:24px;height:24px;border-radius:6px}.music-track-name{font-size:.6rem}.music-volume{width:40px}.trump-display{padding:3px 8px;min-width:42px}.trump-display-icon{font-size:1.2rem}.trump-display-label{font-size:.45rem}.trump-section{gap:6px}.trump-flip-container{width:var(--card-w-sm);height:var(--card-h-sm)}.table-felt{max-width:552px}.table-center{top:50%}.turn-label{display:none}.seat-avatar{width:32px;height:32px;font-size:.75rem}.seat-name{font-size:.5rem;max-width:48px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sbt-bid,.sbt-tricks{font-size:.8rem}.seat-bid-tricks{padding:2px 6px}:root{--card-w: 56px;--card-h: 82px;--card-w-sm: 40px;--card-h-sm: 58px;--hand-h: 180px;--bid-h: 64px;--max-card-scale: 1.55;--trick-card-w: 72px;--trick-card-h: 106px;--trick-overlap: 3px}.gc-corner{font-size:.5rem}.gc-pips{top:12px;right:6px;bottom:12px;left:6px}.gc-pip{font-size:.55rem!important}.gc-face-letter{font-size:1.3rem}.gc-face-suit{font-size:.9rem}.hand-area{padding:8px 10px;max-width:none}.hand-cards{gap:4px}.bid-controls{gap:8px}.bid-value{font-size:1.25rem;width:44px}.bid-bar{padding:6px 10px}.bid-label{font-size:.8rem}.btn-spin{width:38px;height:38px;font-size:1.15rem}.btn-bid{padding:7px 18px;font-size:.85rem}.forbidden-hint{font-size:.7rem;padding:3px 6px}.my-seat-bar{padding:6px 10px;gap:6px}.msb-identity{gap:6px}.msb-avatar{width:28px;height:28px}.msb-name{font-size:.72rem}.my-stat{padding:4px 10px;min-width:52px}.my-stat-value{font-size:1.3rem}.my-stat-label{font-size:.48rem}.game-screen{padding:4px;padding-top:calc(4px + env(safe-area-inset-top,0px));padding-bottom:calc(4px + env(safe-area-inset-bottom,0px));gap:4px}.lobby-card{padding:28px 20px}.rcd-code-big{font-size:2rem;letter-spacing:8px;padding-left:10px}@media (max-height: 820px){.lobby-screen{padding:10px}.lobby-card{padding:18px;border-radius:16px}.logo{margin-bottom:2px}.logo-text{font-size:1.9rem;letter-spacing:2px}.subtitle{font-size:.82rem;margin-bottom:14px}.form-group{margin-bottom:10px}.form-group input,.lobby-card input{padding:10px 14px;font-size:.95rem}.character-picker{padding:10px 12px;margin-bottom:10px}.character-label{margin-bottom:6px;font-size:.72rem}.character-grid{grid-template-columns:repeat(4,48px);gap:10px}.character-img{width:48px;height:48px}.difficulty-picker{padding:10px 12px;margin-bottom:10px}.difficulty-label{margin-bottom:6px;font-size:.72rem}.diff-btn{padding:8px 4px;font-size:.82rem}.lobby-card .btn{padding:11px 14px;font-size:.95rem}.lobby-mp-btn{margin-top:6px}.btn-rules-link{margin-top:6px;font-size:.78rem;padding:4px 6px}.legal-links{margin-top:4px;font-size:.7rem}}.overlay-card{padding:14px 10px;max-height:90vh;border-radius:14px}.overlay-card h2{font-size:1rem;margin-bottom:8px}.round-winner-banner{margin:4px 0 8px;padding:6px 10px;font-size:.8rem;gap:6px}.round-winner-star{font-size:.7rem}.summary-table{font-size:.78rem}.summary-table th{padding:5px 6px;font-size:.68rem}.summary-table td{padding:6px}.winner-crown{font-size:.7rem;margin-right:3px}.overlay-hint{margin-top:8px;font-size:.75rem}.sb-header{margin-bottom:8px}.sb-header h2{font-size:1rem}.btn-close{width:28px;height:28px;font-size:1rem}.score-table{font-size:.65rem}.score-table th,.score-table td{padding:4px 5px}.score-table th{font-size:.6rem}.score-table tfoot td{font-size:.75rem;padding:6px 5px}.sb-bid,.sb-pts{margin-right:2px}.sb-total{font-size:.58rem}.overlay-card.wide{max-width:95vw}}@media (max-width: 400px){.table-felt{max-width:414px}:root{--card-w: 52px;--card-h: 76px;--card-w-sm: 36px;--card-h-sm: 52px;--hand-h: 168px;--bid-h: 60px;--max-card-scale: 1.5;--trick-card-w: 58px;--trick-card-h: 84px;--trick-overlap: 3px}.hand-cards{gap:3px}.music-player,.bid-label{display:none}.seat-name{font-size:.45rem;max-width:44px}.te-name{font-size:.45rem}.sbt-bid,.sbt-tricks{font-size:.72rem}.seat-avatar{width:28px;height:28px}}.chat-panel{position:fixed;bottom:0;right:0;width:320px;max-height:420px;background:var(--surface);border:1px solid var(--border);border-radius:12px 12px 0 0;display:flex;flex-direction:column;z-index:60;box-shadow:0 -4px 24px #0006}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border);flex-shrink:0}.chat-header-title{font-weight:700;font-size:.9rem;color:var(--accent2)}.btn-close-chat{background:none;border:none;color:var(--text-muted);font-size:1.3rem;cursor:pointer;padding:0 4px;line-height:1}.btn-close-chat:hover{color:var(--text)}.chat-messages{flex:1;overflow-y:auto;padding:8px 12px;min-height:120px;max-height:280px;display:flex;flex-direction:column;gap:4px}.chat-empty{color:var(--text-muted);font-size:.8rem;font-style:italic;text-align:center;padding:20px 0}.chat-msg{display:flex;flex-wrap:wrap;gap:6px;font-size:.82rem;line-height:1.35;word-break:break-word;position:relative}.chat-name{font-weight:700;color:var(--accent2);flex-shrink:0}.chat-name:after{content:":"}.chat-text{color:var(--text)}.chat-msg-menu{position:absolute;top:100%;left:0;z-index:20;display:flex;gap:4px;margin-top:4px;padding:4px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0006}.chat-msg-menu button{background:transparent;border:1px solid var(--border);color:var(--text);padding:4px 10px;font-size:.78rem;border-radius:6px;cursor:pointer;font-family:inherit}.chat-msg-menu button:hover{background:var(--surface2);border-color:var(--accent)}.report-modal{max-width:380px}.report-help{color:var(--text-muted);font-size:.9rem;margin:0 0 12px}.report-reasons{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;text-align:left}.report-reason{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-size:.88rem}.report-reason:hover{border-color:var(--accent);background:var(--surface2)}.report-reason input[type=radio]{accent-color:var(--accent)}.report-actions{display:flex;gap:8px;justify-content:flex-end}.report-thanks{color:var(--accent2);font-size:.95rem;text-align:center;padding:12px 0}.chat-input-row{display:flex;gap:0;border-top:1px solid var(--border);flex-shrink:0}.chat-input-row input{flex:1;min-width:0;padding:10px 12px;background:var(--bg2);border:none;color:var(--text);font-size:16px;font-family:inherit;border-radius:0 0 0 12px;outline:none}.chat-input-row input::placeholder{color:var(--text-muted)}.chat-send{background:var(--accent);border:none;color:#fff;padding:10px 16px;font-size:1rem;cursor:pointer;border-radius:0 0 12px;transition:background .15s}.chat-send:hover{background:var(--accent)}.btn-chat-toggle{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);padding:8px 16px;border-radius:10px;font-size:.85rem;font-weight:600;cursor:pointer;font-family:inherit;display:flex;align-items:center;gap:6px;transition:all .2s}.btn-chat-toggle:hover{color:var(--text);background:var(--border)}.lobby-bottom-row{display:flex;justify-content:center;gap:12px;align-items:center}.chat-badge{background:var(--red);color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px}.chat-badge-sm{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:.55rem;font-weight:800;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px}.btn-icon-rules{font-family:MedievalSharp,Cinzel,serif;font-size:1.1rem;font-weight:700;line-height:1}.btn-rules-link{margin-top:12px;background:transparent;border:none;color:var(--text-muted);font-family:Cinzel,serif;font-size:.82rem;letter-spacing:1px;cursor:pointer;padding:6px;transition:color .2s}.btn-rules-link:hover{color:var(--gold)}.legal-links{margin-top:4px;display:flex;justify-content:center;align-items:center;gap:8px;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.5px}.legal-link{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px 6px;opacity:.7;transition:color .2s,opacity .2s}.legal-link:hover{color:var(--gold);opacity:1}.legal-sep{color:var(--text-muted);opacity:.5}.lang-switch{display:inline-flex;align-items:center;gap:4px;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.5px}.lang-switch-icon{display:inline-flex;color:var(--text-muted);opacity:.7;margin-right:2px}.lang-switch-sep{color:var(--text-muted);opacity:.4}.lang-option{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;opacity:.5;font-family:inherit;font-size:inherit;letter-spacing:inherit;transition:color .2s,opacity .2s}.lang-option:hover{opacity:.85}.lang-option.is-active{color:var(--gold);opacity:1;font-weight:600;cursor:default}.connection-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99998;padding:20px;animation:rulesFade .25s ease}.connection-card{background:linear-gradient(180deg,#2a2115,#1a1510);border:2px solid var(--gold, #c9a961);border-radius:14px;padding:36px 28px;text-align:center;max-width:340px;box-shadow:0 20px 50px #0009}.connection-spinner{width:48px;height:48px;margin:0 auto 18px;border:3px solid rgba(201,169,97,.2);border-top-color:var(--gold, #c9a961);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.connection-title{font-family:Cinzel,serif;font-size:1.3rem;color:var(--gold, #c9a961);margin:0 0 10px;letter-spacing:1px}.connection-sub{color:#c9b896;font-size:.95rem;line-height:1.45;margin:0 0 22px}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:99997;padding:20px;animation:rulesFade .3s ease}.tutorial-card{position:relative;background:linear-gradient(180deg,#2a2115,#1a1510);border:2px solid var(--gold, #c9a961);border-radius:16px;padding:32px 28px 24px;text-align:center;max-width:380px;width:100%;box-shadow:0 24px 60px #000000a6}.tutorial-skip{position:absolute;top:10px;right:14px;background:transparent;border:none;color:var(--text-muted);font-family:Cinzel,serif;font-size:.78rem;letter-spacing:1px;cursor:pointer;padding:6px 8px;opacity:.7;transition:color .2s,opacity .2s}.tutorial-skip:hover{color:var(--gold, #c9a961);opacity:1}.tutorial-icon{font-size:2.8rem;color:var(--gold, #c9a961);margin:8px 0 14px;line-height:1}.tutorial-title{font-family:Cinzel,serif;font-size:1.35rem;color:var(--gold, #c9a961);margin:0 0 12px;letter-spacing:1px}.tutorial-text{color:#d6c4a3;font-size:1rem;line-height:1.55;margin:0 0 20px;min-height:7em}.tutorial-dots{display:flex;justify-content:center;gap:8px;margin:0 0 20px}.tutorial-dot{width:8px;height:8px;border-radius:50%;background:#c9a96140;transition:background .25s,transform .25s}.tutorial-dot.active{background:var(--gold, #c9a961);transform:scale(1.25)}.tutorial-actions{display:flex;gap:10px;justify-content:space-between}.tutorial-actions .btn{flex:1;padding:12px 18px;font-size:.95rem}.rules-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:99999;padding:20px;animation:rulesFade .25s ease}@keyframes rulesFade{0%{opacity:0}to{opacity:1}}.rules-scroll{position:relative;max-width:640px;width:100%;max-height:90vh;overflow-y:auto;background:url(/paper.webp) center / 100% 100% no-repeat,#e8d9b0;color:#3d2817;padding:48px 56px;border-radius:6px;box-shadow:0 0 0 1px #3d281733,0 20px 60px #0009,inset 0 0 60px #65432126;animation:rulesSlide .35s cubic-bezier(.4,0,.2,1)}@keyframes rulesSlide{0%{transform:translateY(20px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.rules-close{position:absolute;top:12px;right:14px;background:transparent;border:none;color:#5a3d20;font-size:1.8rem;line-height:1;cursor:pointer;padding:4px 10px;font-family:MedievalSharp,cursive;transition:transform .15s;z-index:2}.rules-close:hover{transform:scale(1.2);color:#8b1a1a}.rules-content{font-family:IM Fell English,MedievalSharp,Georgia,serif;font-size:1.05rem;line-height:1.7}.rules-title{font-family:MedievalSharp,Cinzel,serif;font-size:2.2rem;text-align:center;color:#4a2a10;margin-bottom:6px;letter-spacing:2px}.rules-divider{text-align:center;color:#8b5a2b;font-size:.9rem;letter-spacing:8px;margin:16px 0 24px}.rules-content h2{font-family:MedievalSharp,Cinzel,serif;font-size:1.35rem;color:#5a2e0c;margin:20px 0 6px;letter-spacing:1px}.rules-content p{margin-bottom:10px}.rules-content ul{margin:6px 0 10px 22px}.rules-content li{margin-bottom:4px}.rules-content strong{color:#4a2a10}.rn{font-family:Cinzel,Inter,sans-serif;font-weight:600;color:#4a2a10;letter-spacing:.5px;padding:0 2px}.rules-footer{text-align:center;color:#6b4423;margin-top:16px;font-size:.95rem}@media (max-width: 600px){.rules-scroll{padding:36px 28px}.rules-title{font-size:1.7rem}.rules-content{font-size:.98rem}.rules-content h2{font-size:1.15rem}}@media (max-width: 600px){.chat-panel{width:100%;max-height:50vh;border-radius:12px 12px 0 0}}@media (orientation: landscape) and (max-height: 480px){body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#1a0f0a;z-index:99998}body:after{content:"↻  Please rotate your device";position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px;color:#e8d7b5;font-family:Cinzel,Georgia,serif;font-size:1.35rem;letter-spacing:1px;background:#1a0f0a;z-index:99999;pointer-events:none;white-space:pre-wrap}}
