.lobby{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.lobby-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:64px;width:100%;max-width:800px}.lobby-logo{display:block;margin:0 auto 16px;max-width:180px;height:auto}.lobby-card h1{text-align:center;font-size:72px;margin-bottom:4px;background:linear-gradient(135deg,var(--gold),#e67e22);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{text-align:center;color:var(--text-dim);margin-bottom:24px;font-size:28px}.room-info{text-align:center;margin-bottom:20px}.room-info .label{display:block;font-size:24px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.room-code{font-size:96px;font-weight:700;letter-spacing:8px;color:var(--gold)}.room-input{text-align:center;font-size:48px!important;letter-spacing:6px;text-transform:uppercase}.players-list{margin-bottom:20px}.players-list h3{font-size:28px;color:var(--text-dim);margin-bottom:8px}.player-item{padding:16px 24px;background:var(--surface2);border-radius:6px;margin-bottom:4px;display:flex;align-items:center;gap:8px;font-size:30px}.player-item.disconnected{opacity:.5}.host-badge{background:var(--gold);color:#000;font-size:22px;padding:2px 12px;border-radius:4px;font-weight:600}.dc-badge{background:var(--danger);color:#fff;font-size:22px;padding:2px 12px;border-radius:4px;margin-left:auto}.timer-settings{margin-bottom:16px}.toggle-label{display:flex;align-items:center;gap:8px;font-size:28px;cursor:pointer;margin-bottom:8px}.toggle-label input{cursor:pointer}.timer-settings select{display:block;width:100%;padding:16px;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:6px;font-size:28px}.waiting-text{text-align:center;color:var(--text-dim);font-size:28px;margin-top:12px}.host-actions{margin-left:auto;display:flex;gap:6px}.btn-kick,.btn-ban{padding:4px 12px;border-radius:4px;border:none;font-size:18px;font-weight:600;cursor:pointer;color:#fff}.btn-kick{background:var(--danger)}.btn-kick:hover{opacity:.85}.btn-ban{background:#8e44ad}.btn-ban:hover{opacity:.85}.card{width:160px;height:224px;border-radius:12px;overflow:hidden;flex-shrink:0;transition:transform .15s,box-shadow .15s;cursor:default;position:relative}.card img{width:100%;height:100%;object-fit:cover;pointer-events:none}.card.playable{cursor:pointer;box-shadow:0 0 0 2px var(--primary)}.card.playable:hover{transform:translateY(-24px) scale(1.05)!important;box-shadow:0 0 12px var(--primary),0 0 0 2px var(--primary);z-index:100!important}.card.highlighted{box-shadow:0 0 8px var(--gold)}.card.small{width:112px;height:156px;border-radius:8px}.player-hand{display:flex;justify-content:center;align-items:flex-end;padding:8px 40px 32px;gap:0;min-height:260px;position:relative}.player-hand .card{margin-left:-96px;transform-origin:bottom center}.player-hand .card:first-child{margin-left:0}@media (max-width: 1200px){.card{width:120px;height:168px}.card.small{width:84px;height:117px}.player-hand{padding:8px 16px 24px;overflow-x:auto;justify-content:flex-start}.player-hand .card{margin-left:-96px}}.scoreboard{overflow-x:auto;margin:12px 0}.scoreboard table{width:100%;border-collapse:collapse;font-size:26px}.scoreboard th,.scoreboard td{padding:12px 20px;border:1px solid var(--border);text-align:center}.scoreboard th{background:var(--surface2);font-weight:600;font-size:24px;white-space:nowrap}.scoreboard tr.latest td{background:#4a90d91a}.scoreboard .bid-ok{color:var(--success)}.scoreboard .bid-fail{color:var(--danger)}.scoreboard .round-detail{display:inline;font-size:22px;color:var(--text-dim)}.scoreboard .round-score{display:inline;font-weight:700}.game-board{display:flex;flex-direction:column;min-height:100vh}.game-header{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:var(--surface);border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap;position:relative}.round-info{font-size:28px;font-weight:600;white-space:nowrap}.trump-display{display:flex;align-items:center;gap:12px}.trump-label{font-size:24px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.trump-suit{font-size:56px}.trump-none{font-size:26px;color:var(--text-dim)}.game-controls{display:flex;align-items:center;gap:8px}.timer{font-size:26px;font-weight:700;font-variant-numeric:tabular-nums;padding:8px 24px;background:var(--surface2);border-radius:6px}.timer-low{color:var(--danger);animation:pulse .5s ease-in-out infinite alternate}@keyframes pulse{0%{opacity:1}to{opacity:.5}}.play-area{flex:1;position:relative;min-height:680px}.seat-position{position:absolute}.seat-bottom{bottom:20px;left:50%;transform:translate(-50%)}.player-seat{background:var(--surface);border:3px solid var(--border);border-radius:10px;padding:16px 28px;text-align:center;min-width:220px;transition:border-color .2s,box-shadow .2s}.player-seat.current{border-color:#e53e3e;box-shadow:0 0 12px #e53e3e99,0 0 24px #e53e3e4d}.player-seat.me{padding:8px 28px;min-width:340px}.player-seat.me.current{border-color:#e53e3e;box-shadow:0 0 12px #e53e3e99,0 0 24px #e53e3e4d}.seat-info{display:flex;flex-direction:column;gap:4px}.seat-stats-row{display:flex;justify-content:center;gap:32px}.seat-name{font-weight:600;font-size:28px;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.seat-score{font-size:22px;color:var(--text-dim);font-weight:700}.dealer-chip{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--gold);color:#000;font-size:22px;font-weight:700}.seat-bid,.seat-cards{font-size:24px;color:var(--text-dim)}.played-card{position:absolute;z-index:10;display:flex;align-items:center;justify-content:center}.played-card.trick-winner{border:3px solid var(--gold);border-radius:12px;padding:6px;box-shadow:0 0 16px #f1c40f80}.played-card.fly-to-winner{transition:left .6s ease-in,top .6s ease-in,opacity .6s ease-in;opacity:0}.trump-badge{display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;border-radius:50%;background:#fff;border:2px solid;font-size:33px;font-weight:700}.status-bar{position:absolute;left:50%;transform:translate(-50%);text-align:center;font-size:22px;color:#fff;font-weight:700;white-space:nowrap;pointer-events:none}.status-bar.my-turn{color:#e53e3e}.bid-selector{position:fixed;top:24%;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;z-index:50;text-align:center}.bid-selector h3{font-size:28px;margin-bottom:10px;color:var(--text-dim)}.bid-buttons{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}.bid-btn{width:88px;height:88px;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:36px;font-weight:600;cursor:pointer;transition:background .15s}.bid-btn:hover{background:var(--primary)}.suit-buttons{display:flex;gap:12px;justify-content:center;margin-top:16px}.suit-btn{width:120px;height:120px;border-radius:10px;border:2px solid var(--border);background:#fff;cursor:pointer;transition:transform .15s}.suit-btn:hover{transform:scale(1.1)}.suit-icon{font-size:64px}.trump-picker-inline{position:fixed;top:24%;left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:32px;z-index:50;text-align:center}.trump-picker-inline h3{font-size:28px;margin-bottom:10px}.trump-picker-inline p{font-size:22px;color:var(--text-dim);margin-bottom:16px}.round-results .result-row{display:flex;justify-content:space-between;padding:8px 12px;border-radius:6px;margin-bottom:4px;font-size:28px}.result-row.success{background:#27ae6026}.result-row.fail{background:#e74c3c26}.result-name{font-weight:600;min-width:80px;max-width:140px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.round-results .result-row span:nth-child(2){flex:1;text-align:center}.result-score{font-weight:700;min-width:50px;text-align:right;flex-shrink:0}.game-over{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.game-over-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;max-width:95vw;width:100%;text-align:center}.game-over-card h1{margin-bottom:16px}.winner-announce h2{color:var(--gold);font-size:24px;margin-bottom:20px}.final-rankings{margin-bottom:24px}.ranking-row{display:flex;align-items:center;gap:12px;padding:20px 32px;border-radius:8px;margin-bottom:4px;background:var(--surface2);font-size:28px}.ranking-row.first{background:linear-gradient(135deg,#f1c40f33,#e67e2233);border:1px solid rgba(241,196,15,.3)}.ranking-row .rank{font-weight:700;font-size:36px;min-width:36px}.ranking-row .name{flex:1;text-align:left}.ranking-row .score{font-weight:700}.ranking-row.first .rank{color:var(--gold)}.game-over-actions{display:flex;gap:12px;margin-top:20px}.game-over-actions .btn-primary,.game-over-actions .btn-secondary{flex:1;margin-top:0}@media (max-width: 1200px){.play-area{min-height:400px}.player-seat{min-width:160px;padding:12px 16px}.player-seat.me{min-width:280px;padding:6px 16px}.seat-name{font-size:22px}}.tournament-page{min-height:100vh;background:var(--bg);color:var(--text);padding:20px;max-width:1200px;margin:0 auto}.t-header{margin-bottom:24px}.t-header-top{display:flex;justify-content:space-between;align-items:center}.t-theme-toggle{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;font-size:18px;cursor:pointer;transition:background .2s;line-height:1}.t-theme-toggle:hover{background:var(--border)}.t-header h1{font-size:28px;margin-top:8px}.t-back-link,.t-admin-link{color:var(--primary);text-decoration:none;font-size:14px}.t-back-link:hover,.t-admin-link:hover{color:var(--primary-hover)}.t-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.t-tab{padding:10px 20px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-dim);font-size:16px;cursor:pointer;transition:all .2s}.t-tab:hover{color:var(--text)}.t-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.t-subtabs{display:flex;gap:4px;margin-bottom:16px}.t-subtab{padding:6px 16px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text-dim);font-size:14px;cursor:pointer;transition:all .2s}.t-subtab:hover{background:var(--surface2)}.t-subtab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.t-section{margin-bottom:32px}.t-section h2{font-size:20px;margin-bottom:12px}.t-subtitle{color:var(--text-dim);font-size:13px;margin-bottom:12px}.t-badge{display:inline-block;background:var(--primary);color:#fff;font-size:11px;padding:2px 8px;border-radius:10px;margin-left:8px;vertical-align:middle}.t-table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.t-table{width:100%;border-collapse:collapse;font-size:14px}.t-table th,.t-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}.t-table th{background:var(--surface);color:var(--text-dim);font-weight:600;font-size:12px;text-transform:uppercase;position:sticky;top:0}.t-table tbody tr:hover{background:var(--surface)}.t-rank{font-weight:700;width:40px}.t-player-name{font-weight:600}.t-score-main{font-weight:700;color:var(--primary)}.medal-gold{background:#f1c40f1a!important}.medal-gold .t-rank{color:#f1c40f}.medal-silver{background:#bdc3c714!important}.medal-silver .t-rank{color:#bdc3c7}.medal-bronze{background:#cd7f3214!important}.medal-bronze .t-rank{color:#cd7f32}.t-scores-cell{white-space:normal!important}.t-score-item{display:inline-block;margin:2px 6px 2px 0;padding:2px 6px;background:var(--surface2);border-radius:4px;font-size:12px}.t-score-item.t-winner{background:#27ae6033;color:var(--success);font-weight:600}.t-winner-name{color:var(--success);font-weight:600}.t-footer{text-align:center;padding:32px 0;border-top:1px solid var(--border);margin-top:32px}.t-admin-add{display:flex;gap:8px;margin-bottom:16px;align-items:center}.t-player-list{display:flex;flex-wrap:wrap;gap:8px}.t-player-item{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:14px}.t-btn-danger{background:none;border:1px solid var(--danger);color:var(--danger);padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer}.t-btn-danger:hover{background:var(--danger);color:#fff}.t-settings-form{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end}.t-settings-form label{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--text-dim)}.t-settings-form input{padding:8px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:16px;width:120px}.t-settings-form input:focus{border-color:var(--primary);outline:none}.t-message{padding:10px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.t-message.success{background:#27ae6026;color:var(--success);border:1px solid var(--success)}.t-message.error{background:#e74c3c26;color:var(--danger);border:1px solid var(--danger)}.t-error{color:var(--danger)}.tournament-mapper h2{font-size:22px;margin-bottom:4px}.mapper-table{margin:16px 0}.mapper-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.mapper-game-name{font-weight:600;min-width:120px;font-size:16px}.mapper-arrow{color:var(--text-dim);font-size:18px}.mapper-select{flex:1;padding:8px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:16px}.mapper-select:focus{border-color:var(--primary);outline:none}.mapper-error{color:var(--danger);font-size:14px;margin:8px 0}.mapper-actions{margin-top:16px}@media (max-width: 768px){.tournament-page{padding:12px}.t-header h1{font-size:22px}.t-table{font-size:12px}.t-table th,.t-table td{padding:6px 8px}.t-tabs{overflow-x:auto}.t-settings-form{flex-direction:column}.t-settings-form input{width:100%}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0f1c;--surface: #141b2d;--surface2: #1e2a42;--border: #2a3a5c;--text: #e8eaf0;--text-dim: #8892a8;--primary: #4a90d9;--primary-hover: #5fa0e9;--success: #27ae60;--danger: #e74c3c;--gold: #f1c40f}[data-theme=light]{--bg: #f5f6fa;--surface: #ffffff;--surface2: #e8eaf0;--border: #d1d5de;--text: #1a1a2e;--text-dim: #6b7280;--primary: #3b7dd8;--primary-hover: #2b6bc0;--success: #1e8449;--danger: #c0392b;--gold: #d4a017}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}#root{min-height:100vh}.app{min-height:100vh;position:relative}.connection-bar{position:fixed;top:0;left:0;right:0;background:var(--danger);color:#fff;text-align:center;padding:6px;font-size:13px;z-index:1000}.error-bar{position:fixed;top:0;left:0;right:0;background:#c0392b;color:#fff;text-align:center;padding:8px 16px;font-size:14px;z-index:999;cursor:pointer}.error-bar .dismiss{margin-left:12px;opacity:.7}.btn-primary{display:block;width:100%;padding:24px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:32px;font-weight:600;cursor:pointer;transition:background .2s}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{display:block;width:100%;padding:20px;background:transparent;color:var(--text-dim);border:1px solid var(--border);border-radius:8px;font-size:28px;cursor:pointer;margin-top:8px;transition:border-color .2s}.btn-secondary:hover{border-color:var(--text-dim)}.btn-small{padding:8px 24px;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:6px;font-size:26px;cursor:pointer}.btn-small:hover{background:var(--border)}.input{display:block;width:100%;padding:24px;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:32px;margin-bottom:12px;outline:none;text-align:center}.input:focus{border-color:var(--primary)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.overlay-content{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:48px;max-width:1000px;width:90%;max-height:80vh;overflow-y:auto}
