:root{--bg-base:#0e1117;--bg-surface:#141926;--bg-elevated:#1c2338;--bg-hover:#232c45;--gold-dim:#8a6c2a;--gold:#c9a84c;--gold-bright:#e8c96a;--gold-glow:#c9a84c38;--text-primary:#f0ece0;--text-secondary:#7c839e;--text-muted:#4a5068;--border:#ffffff12;--border-focus:#c9a84c99;--red:#e05a5a;--green:#4caf82;--radius-sm:10px;--radius:16px;--radius-lg:24px;--shadow-card:0 24px 60px #0000008c;--shadow-gold:0 0 32px #c9a84c33;--font:"Plus Jakarta Sans", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%;font-family:var(--font);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:var(--font);cursor:pointer}input:-webkit-autofill{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:inset 0 0 0 1000px #1a2040}input:-webkit-autofill:focus{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:inset 0 0 0 1000px #1a2040}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}@keyframes drift{0%{transform:var(--drift-start)}50%{transform:var(--drift-mid)}to{transform:var(--drift-start)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes glow{0%,to{opacity:.6}50%{opacity:1}}@keyframes checkmark{0%{stroke-dashoffset:20px}to{stroke-dashoffset:0}}@keyframes pop{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.anim-fadein{animation:.5s both fadeUp}.anim-fadein-2{animation:.5s 80ms both fadeUp}.anim-fadein-3{animation:.5s .16s both fadeUp}.anim-fadein-4{animation:.5s .24s both fadeUp}.anim-fadein-5{animation:.5s .32s both fadeUp}.anim-fadein-6{animation:.5s .4s both fadeUp}.anim-fadein-7{animation:.5s .48s both fadeUp}.fu{animation:.6s both fadeUp}.fu2{animation:.6s .1s both fadeUp}.fu3{animation:.6s .2s both fadeUp}.fu4{animation:.6s .3s both fadeUp}.fu5{animation:.6s .4s both fadeUp}.lobby-page,.lobby-waiting{flex-direction:column;align-items:center;gap:32px;padding:48px 24px;display:flex}.lobby-page h1,.lobby-waiting h1{color:var(--gold);letter-spacing:.04em;font-size:1.6rem;font-weight:700}.tabs{background:var(--bg-surface);border-radius:var(--radius);border:1px solid var(--border);gap:4px;padding:4px;display:flex}.tab{color:var(--text-secondary);border-radius:calc(var(--radius) - 4px);background:0 0;border:none;flex:1;padding:10px 28px;font-size:.9rem;font-weight:600;transition:background .15s,color .15s}.tab:hover{color:var(--text-primary);background:var(--bg-hover)}.tab.active{background:var(--bg-elevated);color:var(--gold);box-shadow:0 1px 4px #0000004d}.create-form,.join-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-card);flex-direction:column;gap:24px;padding:32px;display:flex}.field-group{flex-direction:column;gap:10px;display:flex}.field-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:600}.toggle-row{flex-direction:row;justify-content:space-between;align-items:center}.toggle-row input[type=checkbox]{display:none}.toggle{cursor:pointer;flex-shrink:0;width:44px;height:24px;display:inline-flex;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--bg-hover);border:1px solid var(--border);border-radius:12px;transition:background .2s,border-color .2s;position:absolute;inset:0}.toggle-track:after{content:"";background:var(--text-muted);border-radius:50%;width:16px;height:16px;transition:transform .2s,background .2s;position:absolute;top:3px;left:3px}.toggle input:checked+.toggle-track{border-color:var(--gold);background:#c9a84c26}.toggle input:checked+.toggle-track:after{background:var(--gold);transform:translate(20px)}.mode-cards{gap:10px;display:flex}.mode-card{text-align:center;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;flex-direction:column;flex:1;gap:3px;padding:14px 10px;font-size:.9rem;font-weight:600;transition:border-color .15s,color .15s,background .15s;display:flex}.mode-title{font-size:.9rem;font-weight:700}.mode-sub{opacity:.7;font-size:.72rem;font-weight:500}.mode-card:hover{background:var(--bg-hover);color:var(--text-primary)}.mode-card.selected{border-color:var(--gold);color:var(--gold);background:#c9a84c14}.trump-pills{flex-wrap:wrap;gap:8px;display:flex}.pill{border:1px solid var(--border);background:var(--bg-elevated);color:var(--text-secondary);border-radius:20px;padding:8px 18px;font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s,background .15s}.pill:hover{color:var(--text-primary);background:var(--bg-hover)}.pill.active{border-color:var(--gold);color:var(--gold);background:#c9a84c14}.code-input{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);letter-spacing:.25em;text-align:center;text-transform:uppercase;outline:none;width:100%;padding:14px 18px;font-size:1.4rem;font-weight:700;transition:border-color .15s}.code-input:focus{border-color:var(--border-focus)}.btn-primary{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 100%);border-radius:var(--radius-sm);color:#0e1117;letter-spacing:.03em;cursor:pointer;border:none;padding:14px 24px;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .1s}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-ghost{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:10px 20px;font-size:.875rem;font-weight:600;transition:color .15s,border-color .15s}.btn-ghost:hover{color:var(--text-primary);border-color:#ffffff2e}.btn-copy-link{border:1px solid var(--gold);border-radius:var(--radius-sm);color:var(--gold);cursor:pointer;background:0 0;padding:10px 20px;font-size:.875rem;font-weight:600;transition:color .15s,border-color .15s,background .15s}.btn-copy-link:hover{background:#c9a84c1a}.btn-copy-link.copied{color:var(--green);border-color:var(--green)}.error-message{border-radius:var(--radius-sm);color:var(--red);text-align:center;background:#e05a5a1a;border:1px solid #e05a5a4d;padding:12px 16px;font-size:.875rem}.lobby-code{color:var(--text-secondary);font-size:1rem}.lobby-code strong{color:var(--gold-bright);letter-spacing:.2em;margin-left:10px;font-size:2rem;font-weight:800}.lobby-players{grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:480px;display:grid}.seat{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:6px;min-height:80px;padding:20px;transition:border-color .2s;display:flex}.seat.occupied{background:#c9a84c0a;border-color:#c9a84c4d}.seat-index{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:600}.player-name{color:var(--text-primary);font-size:1rem;font-weight:600}.empty-seat{color:var(--text-muted);font-size:.875rem;font-style:italic}.game-page{background:var(--bg-base);flex-direction:column;height:100vh;display:flex;overflow:hidden}.game-navbar{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex}.game-navbar-logo{color:var(--gold);font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700;text-decoration:none}.game-navbar-scores{color:var(--gold-bright);letter-spacing:.03em;font-size:.9rem;font-weight:700}.game-navbar-menu{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:6px 12px;font-size:.8rem}.game-table{background:radial-gradient(#1e3a1e 0%,#162816 60%,#0f1f0f 100%);flex:1;position:relative;overflow:hidden}.badge-trump{z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-secondary);background:#0000008c;border:1px solid #c9a84c66;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;display:flex;position:absolute;top:12px;right:12px}.badge-trump .trump-symbol{font-size:1.1rem;font-weight:700}.badge-trump .suit-hearts .trump-symbol,.badge-trump .suit-diamonds .trump-symbol,.badge-trump .suit-hearts,.badge-trump .suit-diamonds{color:#e05a5a}.badge-round{z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-secondary);white-space:nowrap;background:#0000008c;border:1px solid #c9a84c66;border-radius:8px;padding:6px 12px;font-size:.8rem;position:absolute;top:12px;left:12px}.player-slot{z-index:4;flex-direction:column;align-items:center;gap:6px;display:flex;position:absolute}.player-slot-inner{align-items:center;gap:8px;display:flex}.player-slot.player-north{top:12px;left:50%;transform:translate(-50%)}.player-slot.player-west{top:50%;left:12px;transform:translateY(-50%)}.player-slot.player-east{top:50%;right:12px;transform:translateY(-50%)}.player-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:700;display:flex;position:relative}.player-active .player-avatar{box-shadow:0 0 0 2px var(--gold-bright), 0 0 12px #e8c96a66}.player-active-ring{border:2px solid var(--gold-bright);border-radius:50%;animation:1.5s ease-in-out infinite ring-pulse;position:absolute;inset:-4px}@keyframes ring-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.08)}}.player-info{flex-direction:column;gap:2px;display:flex}.player-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:.75rem;font-weight:600;overflow:hidden}.player-turn-badge{color:var(--gold-bright);background:#c9a84c26;border-radius:4px;padding:1px 5px;font-size:.65rem;font-weight:700}.player-dc-badge{color:#e05a5a;font-size:.65rem}.player-ac-badge{color:var(--text-muted);font-size:.7rem}.player-disconnected .player-avatar{opacity:.4}.player-disconnected .player-name{color:var(--text-muted)}.player-card-backs{margin-top:4px;display:flex}.card-backs-horizontal{flex-direction:row}.card-backs-vertical{flex-direction:column}.card-back-mini{background:linear-gradient(145deg,#1e2840,#141926);border:1.5px solid #c9a84c4d;border-radius:4px;flex-shrink:0;width:28px;height:39px}.card-backs-horizontal .card-back-mini+.card-back-mini{margin-left:-18px}.card-backs-vertical .card-back-mini+.card-back-mini{margin-top:-26px}.trick-zone{z-index:3;border-radius:12px;width:200px;height:180px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.trick-zone-dragover{background:#c9a84c08;outline:2px dashed #c9a84c80}.trick-zone-empty{border:1px dashed #ffffff0f;border-radius:12px;width:100%;height:100%}.trick-card-visual{background:#fafaf8;border:1px solid #0000001a;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;gap:2px;width:52px;height:73px;padding:4px;display:flex;position:absolute;box-shadow:0 3px 10px #0006}.trick-card-south{position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.trick-card-north{position:absolute;top:4px;left:50%;transform:translate(-50%)}.trick-card-west{position:absolute;top:50%;left:4px;transform:translateY(-50%)}.trick-card-east{position:absolute;top:50%;right:4px;transform:translateY(-50%)}.trick-card-slot{position:absolute}.trick-card-slot.trick-card-south{bottom:4px;left:50%;transform:translate(-50%)}.trick-card-slot.trick-card-north{top:4px;left:50%;transform:translate(-50%)}.trick-card-slot.trick-card-west{top:50%;left:4px;transform:translateY(-50%)}.trick-card-slot.trick-card-east{top:50%;right:4px;transform:translateY(-50%)}.trick-card-visual .tc-rank{color:#1a1a2e;font-size:.85rem;font-weight:800;line-height:1}.trick-card-visual .tc-suit{font-size:1.1rem;line-height:1}.trick-card-visual.suit-hearts .tc-rank,.trick-card-visual.suit-hearts .tc-suit,.trick-card-visual.suit-diamonds .tc-rank,.trick-card-visual.suit-diamonds .tc-suit{color:#c33}.trick-card-visual.suit-spades .tc-rank,.trick-card-visual.suit-spades .tc-suit,.trick-card-visual.suit-clubs .tc-rank,.trick-card-visual.suit-clubs .tc-suit{color:#1a1a2e}.hand-zone{z-index:4;background:linear-gradient(#0000 0%,#000000b3 100%);flex-direction:column;align-items:center;gap:8px;padding:16px 20px 20px;display:flex;position:absolute;bottom:0;left:0;right:0}.hand-zone-player{align-items:center;gap:8px;margin-bottom:4px;display:flex}.hand-cards{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;justify-content:center;gap:6px;max-width:100%;padding-bottom:4px;display:flex;overflow-x:auto}.hand-cards::-webkit-scrollbar{display:none}.phase-overlay{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.phase-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:20px;width:90%;max-width:420px;padding:32px 40px;display:flex;box-shadow:0 20px 60px #0009}.phase-panel h3{color:var(--text-primary);font-size:1.1rem;font-weight:700}.announcement-panel-slide{z-index:20;background:var(--bg-surface);border-top:1px solid #c9a84c4d;border-radius:16px 16px 0 0;flex-direction:column;gap:16px;padding:20px 24px;display:flex;position:absolute;bottom:0;left:0;right:0}.game-loading,.game-error{min-height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:1rem;display:flex}.game-error button{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 20px}.disconnect-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.disconnect-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:40px 48px;display:flex}.disconnect-modal h2{color:var(--text-primary);font-size:1.3rem;font-weight:700}.disconnect-modal p{color:var(--text-secondary);font-size:.9rem}.spinner{border:3px solid var(--bg-elevated);border-top-color:var(--gold);border-radius:50%;width:36px;height:36px;margin:8px auto 0;animation:.8s linear infinite spin}.scores{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:12px;padding:16px 24px;display:flex}.team-score{text-align:center;flex-direction:column;flex:1;gap:4px;display:flex}.team-score span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem}.team-score strong{color:var(--gold-bright);font-size:1.8rem;font-weight:800}.round-info{text-align:center;color:var(--text-secondary);flex:2;font-size:.875rem;font-weight:500}.players-row{justify-content:center;gap:8px;display:flex}.player-badge{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:8px 16px;font-size:.85rem;font-weight:600;transition:border-color .15s,color .15s}.player-badge.active{border-color:var(--gold);color:var(--gold);background:#c9a84c14}.player-badge.disconnected{opacity:.4;text-decoration:line-through}.current-trick{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);justify-content:center;gap:12px;min-height:120px;padding:20px;display:flex}.trick-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:72px;height:100px;font-weight:700;display:flex}.trick-card .rank{font-size:1.2rem}.trick-card .suit{font-size:1.4rem}.trick-card small{color:var(--text-muted);font-size:.65rem}.trick-card.suit-hearts .suit,.trick-card.suit-diamonds .suit{color:#e05a5a}.trick-card.suit-spades .suit,.trick-card.suit-clubs .suit{color:var(--text-primary)}.trump-selection{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:20px;padding:28px;display:flex}.trump-selection h3{color:var(--text-primary);font-size:1.1rem;font-weight:700}.trump-selection>p{color:var(--text-secondary);font-size:.9rem}.trump-buttons{gap:12px;display:flex}.trump-btn{border:1px solid var(--border);background:var(--bg-elevated);border-radius:var(--radius-sm);width:64px;height:64px;font-size:1.8rem;transition:transform .1s,border-color .15s}.trump-btn:hover{border-color:var(--gold);transform:scale(1.1)}.trump-btn.suit-hearts,.trump-btn.suit-diamonds{color:#e05a5a}.trump-btn.suit-spades,.trump-btn.suit-clubs{color:var(--text-primary)}.chibre-btn{border:1px solid var(--gold-dim);border-radius:var(--radius-sm);color:var(--gold);background:0 0;padding:10px 24px;font-size:.875rem;font-weight:600;transition:background .15s}.chibre-btn:hover{background:#c9a84c1a}.round-end,.game-over{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:16px;padding:32px;display:flex}.round-end h3,.game-over h2{color:var(--gold-bright);font-size:1.2rem;font-weight:700}.round-end p,.game-over p{color:var(--text-secondary);font-size:.9rem}.hand{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:center;gap:8px;margin-top:auto;padding:20px;display:flex}.card{background:var(--bg-elevated);border:1px solid var(--border);cursor:default;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:64px;height:92px;font-weight:700;transition:transform .12s,border-color .12s,box-shadow .12s;display:flex}.card .rank{font-size:1rem}.card .suit{font-size:1.3rem}.card.playable{cursor:pointer;border-color:#c9a84c4d}.card.playable:hover{border-color:var(--gold);transform:translateY(-8px);box-shadow:0 8px 24px #c9a84c33}.card.suit-hearts .suit,.card.suit-diamonds .suit{color:#e05a5a}.card.suit-spades .suit,.card.suit-clubs .suit{color:var(--text-primary)}.connection-banner{text-align:center;border:1px solid var(--gold-dim);border-radius:var(--radius-sm);color:var(--gold);background:#c9a84c14;padding:10px;font-size:.85rem;font-weight:500;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.game-page .btn-primary{background:linear-gradient(135deg, var(--gold) 0%, var(--gold-bright) 100%);border-radius:var(--radius-sm);color:#0e1117;cursor:pointer;border:none;padding:12px 28px;font-size:.9rem;font-weight:700;transition:opacity .15s,transform .1s}.game-page .btn-primary:hover{opacity:.9;transform:translateY(-1px)}.trump-badge{background:#c9a84c26;border:1px solid #c9a84c4d;border-radius:6px;justify-content:center;align-items:center;margin-left:6px;padding:2px 8px;font-size:1.1rem;font-weight:700;display:inline-flex}.trump-badge.suit-hearts,.trump-badge.suit-diamonds{color:#e05a5a}.trump-badge.suit-spades,.trump-badge.suit-clubs{color:var(--text-primary)}.imposed-sequence{gap:4px;margin-left:10px;display:inline-flex}.imposed-suit{opacity:.35;font-size:1rem;transition:opacity .15s}.imposed-suit.active{opacity:1;font-weight:700}.imposed-suit.suit-hearts,.imposed-suit.suit-diamonds{color:#e05a5a}.imposed-suit.suit-spades,.imposed-suit.suit-clubs{color:var(--text-primary)}.announcement-panel{background:var(--bg-surface);border:1px solid var(--gold-dim);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:16px;padding:28px;display:flex}.announcement-panel h3{color:var(--gold-bright);font-size:1.1rem;font-weight:700}.announcement-list{flex-direction:column;gap:8px;width:100%;max-width:320px;margin:0;padding:0;list-style:none;display:flex}.announcement-list li{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 16px;font-size:.9rem}.announcement-list li.is-trump{background:#c9a84c0f;border-color:#c9a84c66}.announcement-actions{align-items:center;gap:12px;display:flex}.game-page .btn-ghost{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;padding:10px 24px;font-size:.875rem;font-weight:600;transition:color .15s,border-color .15s}.game-page .btn-ghost:hover{color:var(--text-primary);border-color:#ffffff2e}.playing-card{-webkit-user-select:none;user-select:none;border-radius:8px;flex-shrink:0;transition:transform .12s,box-shadow .12s,outline .12s;position:relative}.card-face{background:#fafaf8;border:1px solid #0000001f;flex-direction:column;justify-content:center;align-items:center;width:68px;height:95px;padding:4px;display:flex;box-shadow:0 2px 8px #00000059}.card-corner{flex-direction:column;align-items:center;line-height:1;display:flex;position:absolute}.card-corner-tl{top:5px;left:6px}.card-corner-br{bottom:5px;right:6px;transform:rotate(180deg)}.card-rank{font-size:.85rem;font-weight:800;line-height:1}.card-symbol{font-size:.75rem;line-height:1}.card-center-symbol{font-size:2rem;line-height:1}.suit-red{color:#c33}.suit-dark{color:#1a1a2e}.card-back{background:linear-gradient(145deg,#1e2840,#141926);border:1.5px solid #c9a84c66;width:40px;height:56px;overflow:hidden;box-shadow:0 2px 6px #0006}.card-back-pattern{width:100%;height:100%}.card-playable{cursor:pointer;outline:2px solid #e8c96ab3;transform:translateY(-8px)}.card-playable:hover,.card-playable.card-hovered{outline-color:#e8c96a;transform:translateY(-16px)scale(1.04);box-shadow:0 0 20px #e8c96a4d,0 6px 18px #0006}.card-selected{outline:2px solid #e8c96a;transform:translateY(-20px)scale(1.06);box-shadow:0 0 28px #e8c96a80,0 8px 24px #00000080}.card-play-badge{background:var(--gold);color:#0e1117;white-space:nowrap;pointer-events:none;border-radius:4px;padding:3px 7px;font-size:.65rem;font-weight:700;position:absolute;top:-28px;left:50%;transform:translate(-50%)}.card-play-badge:after{content:"";border:4px solid #0000;border-top-color:var(--gold);position:absolute;top:100%;left:50%;transform:translate(-50%)}.card-unplayable{opacity:.38;filter:grayscale(30%);cursor:not-allowed}.card-unplayable:hover{transform:none}.card-trick{cursor:default;width:58px;height:81px}@media (width<=480px){.card-face{width:52px;height:73px}.card-center-symbol{font-size:1.5rem}.card-rank{font-size:.75rem}.card-symbol{font-size:.65rem}.card-back{width:28px;height:39px}.card-trick{width:48px;height:67px}}.trump-selection-overlay{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.trump-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:20px;width:90%;max-width:380px;padding:28px 36px;display:flex;box-shadow:0 20px 60px #000000b3}.trump-panel-title{color:var(--text-primary);font-size:1.1rem;font-weight:700}.trump-suit-grid{gap:12px;display:flex}.trump-suit-btn{background:var(--bg-elevated);border:1.5px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:72px;height:80px;transition:transform .1s,border-color .15s,background .15s;display:flex}.trump-suit-btn:hover{border-color:var(--gold);background:#c9a84c14;transform:translateY(-2px)}.trump-suit-symbol{font-size:1.75rem;line-height:1}.trump-suit-label{color:var(--text-secondary);font-size:.7rem;font-weight:600}.trump-suit-btn.suit-hearts .trump-suit-symbol,.trump-suit-btn.suit-diamonds .trump-suit-symbol{color:#c33}.trump-suit-btn.suit-spades .trump-suit-symbol,.trump-suit-btn.suit-clubs .trump-suit-symbol{color:var(--text-primary)}.trump-suit-btn.suit-hearts .trump-suit-label,.trump-suit-btn.suit-diamonds .trump-suit-label{color:#c33}.trump-wait-badge{z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text-secondary);white-space:nowrap;background:#0009;border:1px solid #c9a84c4d;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:.8rem;display:flex;position:absolute;bottom:160px;left:50%;transform:translate(-50%)}.spinner-sm{border:2px solid #c9a84c33;border-top-color:var(--gold);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin}.announcement-panel-title{color:var(--gold-bright);font-size:1rem;font-weight:700}.announcement-cards-row{-webkit-overflow-scrolling:touch;gap:10px;padding-bottom:4px;display:flex;overflow-x:auto}.announcement-cards-row::-webkit-scrollbar{display:none}.announcement-card{background:var(--bg-elevated);border:1px solid var(--border);cursor:default;border-radius:10px;flex-direction:column;flex-shrink:0;gap:4px;min-width:140px;padding:12px 14px;display:flex;position:relative}.announcement-card-trump{background:#c9a84c0f;border-color:#c9a84c66}.announcement-card-type{color:var(--text-primary);font-size:.85rem;font-weight:600}.announcement-card-points{color:var(--gold-bright);font-size:1rem;font-weight:800}.announcement-trump-star{font-size:.9rem;position:absolute;top:8px;right:8px}.score-pill{flex-direction:column;gap:4px;display:flex}.score-pill-bar{background:#ffffff14;border-radius:2px;min-width:80px;height:3px;overflow:hidden}.score-pill-fill{background:var(--gold);border-radius:2px;height:100%;transition:width .4s}.score-pill-label{color:var(--text-secondary);white-space:nowrap;font-size:.7rem}.round-end-panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:20px;width:90%;max-width:380px;padding:32px 36px;display:flex;box-shadow:0 20px 60px #0009}.round-end-title{color:var(--gold-bright);font-size:1.1rem;font-weight:700}.round-end-teams{align-items:center;gap:12px;width:100%;display:flex}.round-end-team{background:var(--bg-elevated);border:1px solid var(--border);text-align:center;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:12px 8px;display:flex}.round-end-team-winner{background:#c9a84c12;border-color:#c9a84c80}.round-end-team-name{color:var(--text-muted);font-size:.7rem;font-weight:600}.round-end-team-delta{color:var(--gold-bright);font-size:1.3rem;font-weight:800}.round-end-team-total{color:var(--text-secondary);font-size:.7rem}.round-end-separator{color:var(--text-muted);font-size:1.2rem}.round-end-waiting{color:var(--text-secondary);align-items:center;gap:8px;font-size:.85rem;display:flex}.game-over-backdrop{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000e0;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.game-over-modal{background:var(--bg-surface);border:1px solid var(--border);text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:480px;padding:36px 40px;display:flex;box-shadow:0 30px 80px #000c}.game-over-title{margin:0;font-family:Playfair Display,serif}.game-over-victory{background:linear-gradient(135deg,#f0d47a,#c9a84c);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem}.game-over-defeat{color:var(--text-secondary);font-size:2rem}.game-over-abandoned{color:var(--text-muted);font-size:1.8rem}.game-over-subtitle{color:var(--text-secondary);margin:4px 0 0;font-size:.9rem}.game-over-teams{flex-direction:column;gap:12px;width:100%;display:flex}.team-panel{border-radius:14px;align-items:center;gap:16px;padding:16px 20px;display:flex}.team-panel-winner{background:#c9a84c14;border:1.5px solid #c9a84c66}.team-panel-loser{border:1px solid var(--border);background:var(--bg-elevated);opacity:.55}.team-panel-players{flex-wrap:wrap;flex:1;gap:12px;display:flex}.team-panel-player{align-items:center;gap:6px;display:flex}.team-panel-username{color:var(--text-primary);font-size:.85rem;font-weight:600}.team-panel-score{color:var(--gold-bright);text-align:right;min-width:60px;font-size:2rem;font-weight:800}.team-panel-badge{color:var(--gold);background:#c9a84c33;border-radius:8px;margin-left:auto;padding:2px 8px;font-size:.65rem;font-weight:700}.game-over-actions{flex-direction:column;gap:10px;width:100%;max-width:280px;display:flex}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;padding:12px 28px;font-size:.9rem;font-weight:600;transition:background .15s,border-color .15s}.btn-secondary:hover{background:#ffffff0f;border-color:#ffffff2e}.hint-tooltip{z-index:30;cursor:pointer;background:#0e1117eb;border:1px solid #c9a84c40;border-radius:10px;align-items:flex-start;gap:10px;max-width:280px;padding:12px 16px;display:flex;position:absolute;box-shadow:0 4px 20px #00000080}.hint-tooltip-bottom{bottom:200px;left:50%;transform:translate(-50%)}.hint-tooltip-top{top:60px;left:50%;transform:translate(-50%)}.hint-tooltip-center{margin-top:-80px;top:50%;left:50%;transform:translate(-50%,-50%)}.hint-tooltip-message{color:var(--text-secondary);flex:1;font-size:.82rem;line-height:1.4}.hint-tooltip-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0;font-size:.8rem;line-height:1}@media (width<=480px){.hint-tooltip{bottom:calc(env(safe-area-inset-bottom) + 90px);max-width:100%;position:fixed;top:auto;left:16px;right:16px;transform:none}.hint-tooltip-bottom,.hint-tooltip-top,.hint-tooltip-center{bottom:calc(env(safe-area-inset-bottom) + 90px);top:auto;left:16px;right:16px;transform:none}.trump-suit-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}}
