.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-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}.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:16px 40px 32px;gap:0;min-height:260px;position:relative}.player-hand .card{margin-left:-32px;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:-40px}}.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:block;font-size:22px;color:var(--text-dim)}.scoreboard .round-score{display:block;font-weight:700}.scoreboard .cumulative{display:block;font-size:22px;color:var(--text-dim)}.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}.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:36px;font-weight:700;font-variant-numeric:tabular-nums;padding:4px 20px;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%)}.seat-left{left:32px;top:50%;transform:translateY(-50%)}.seat-right{right:32px;top:50%;transform:translateY(-50%)}.seat-top{top:20px;left:50%;transform:translate(-50%)}.seat-top-left{top:20px;left:20%}.seat-top-right{top:20px;right:20%}.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}.player-seat.current{border-color:var(--primary);box-shadow:0 0 8px #4a90d94d}.player-seat.me{border-color:var(--gold)}.seat-info{display:flex;flex-direction:column;gap:4px}.seat-name{font-weight:600;font-size:28px;display:flex;align-items:center;justify-content:center;gap:6px}.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)}.seat-played-card{margin-top:6px;display:flex;justify-content:center}.card-back-stack{position:relative;height:156px;min-width:112px;margin-top:8px;display:flex;justify-content:center}.card-back-stack .card{position:absolute;top:0}.trick-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;gap:16px;z-index:10}.trick-card{display:flex;flex-direction:column;align-items:center;gap:4px}.trick-card-name{font-size:22px;color:var(--text-dim);white-space:nowrap}.status-bar{text-align:center;padding:8px;font-size:28px;color:var(--text-dim);min-height:48px}.bid-selector{position:fixed;bottom:320px;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;bottom:320px;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}.result-score{font-weight:700;min-width:50px;text-align:right}.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:600px;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}.seat-name{font-size:22px}.bid-selector{bottom:240px}}*,*: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}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}.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}
