:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}body{margin:0;padding:0;width:100vw;height:100vh;overflow:hidden;background-color:#2c3e50}*,*:before,*:after{box-sizing:border-box}.card{width:60px;height:84px;margin:0;-webkit-user-select:none;user-select:none;position:relative;perspective:600px;z-index:60;flex-shrink:0;will-change:transform}.card-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .6s;transform-style:preserve-3d;box-shadow:0 2px 4px #0003;border-radius:8px}.card.face-up .card-inner{transform:rotateY(0)}.card.face-down .card-inner{transform:rotateY(180deg)}.card-front,.card-back-visual{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:8px;border:1px solid #ccc;background-color:#fff;display:flex;justify-content:center;align-items:center}.card-front{transform:rotateY(0)}.card-back-visual{transform:rotateY(180deg);background:repeating-linear-gradient(45deg,#606dbc,#606dbc 10px,#465298 10px 20px)}.card.hearts,.card.diamonds{color:red}.card.clubs,.card.spades{color:#000}.card-content{display:flex;flex-direction:column;align-items:flex-start;font-weight:700;position:absolute;top:3px;left:3px}.card-compact{width:40px;height:56px;margin:0}.player-hand-container{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.player-hand{display:flex;justify-content:center;align-items:flex-end;gap:10px}.card-slot{width:60px;height:84px;border:2px dashed rgba(255,255,255,.2);border-radius:8px;position:relative;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.card-selection{transition:transform .2s ease;transform-origin:center center}.player-name{margin-top:10px;font-size:.9rem;color:#fff;text-shadow:1px 1px 1px black}.opponent{display:flex;flex-direction:column;align-items:center;position:absolute;transform:translate(-50%,-50%)}.opponent-avatar{width:40px;height:40px;background-color:#ddd;border-radius:50%;display:flex;justify-content:center;align-items:center;font-weight:700;border:2px solid #555;margin-bottom:5px}.opponent-waiting{font-size:18px;margin-bottom:4px}.opponent-remove{position:absolute;top:0;right:0;width:20px;height:20px;background-color:#ff3232e6;border:2px solid white;border-radius:50%;color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;line-height:1;transition:background-color .2s,transform .1s;z-index:10}.opponent-remove:hover{background-color:#ff1414;transform:scale(1.1)}.opponent-remove:active{transform:scale(.95)}.opponent-cards{display:flex;justify-content:center;height:56px}.opponent-card-slot{width:16px;height:56px;position:relative;display:flex;justify-content:flex-start}.opponent-card-slot:last-child{width:32px}.opponent-name{font-size:.8rem;color:#fff;text-shadow:1px 1px 1px black;margin-top:2px}.opponent-tricks-badge{position:absolute;top:50%;left:-20px;transform:translateY(-50%);background:#2ecc71e6;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;box-shadow:0 2px 4px #0000004d}.turn-indicator{display:inline-block;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.deck-container{position:absolute;top:56%;left:calc(12% + 5px);transform:translate(-50%,-50%);width:60px;height:84px;cursor:pointer;z-index:50}.deck-container.disabled{cursor:default}.deck-container.shuffling .deck-card{animation:shuffle .8s ease-in-out infinite}.deck-container.shuffling .deck-card:nth-child(odd){animation-delay:.1s}.deck-container.shuffling .deck-card:nth-child(2n){animation-delay:0s}@keyframes shuffle{0%,to{transform:translateY(0) rotate(calc(var(--stack-index) * -.6deg))}25%{transform:translateY(-15px) rotate(calc(var(--stack-index) * -.6deg + 5deg))}50%{transform:translateY(0) rotate(calc(var(--stack-index) * -.6deg))}75%{transform:translateY(15px) rotate(calc(var(--stack-index) * -.6deg - 5deg))}}.deal-button{position:absolute;top:calc(56% + 68px);left:calc(12% + 5px);transform:translate(-50%);background:#3b8c67;color:#fff;border:none;border-radius:14px;padding:6px 12px;font-weight:600;cursor:pointer;z-index:60;box-shadow:0 4px 10px #00000040}.deal-button:disabled{opacity:.6;cursor:not-allowed}.deck-card{width:60px;height:84px;background:repeating-linear-gradient(45deg,#606dbc,#606dbc 10px,#465298 10px 20px);border-radius:8px;border:1px solid #ccc;position:absolute;box-shadow:0 2px 5px #0000004d;top:calc(var(--stack-index) * -1px);left:calc(var(--stack-index) * -.5px);transform:rotate(calc(var(--stack-index) * -.6deg));z-index:calc(1 + var(--stack-index));transition:top .15s ease-out,left .15s ease-out,transform .15s ease-out}.deck-card-top{box-shadow:0 3px 8px #00000073}.deck-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:.8rem;pointer-events:none;text-shadow:1px 1px 2px black;z-index:2}.deck-empty{width:60px;height:84px;border:2px dashed rgba(255,255,255,.3);border-radius:8px;display:flex;justify-content:center;align-items:center;color:#ffffff80;font-size:.8rem}.throw-pile-area{position:absolute;right:9%;top:56%;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle at center,#78aa8c59,#78aa8c26);border:2px dashed rgba(255,255,255,.2);transform:translateY(-50%);display:flex;justify-content:center;align-items:center;pointer-events:none}.throw-pile-cards{position:relative;width:100%;height:100%}.throw-card{position:absolute;left:50%;top:50%;transform-origin:center center}.game-table{width:100vw;height:100vh;background-color:#2c3e50;overflow:hidden;position:relative}.table-surface{width:100%;height:100%;background:radial-gradient(ellipse at center,#35654d,#1e3b2e);position:relative;display:flex;flex-direction:column;justify-content:space-between}.opponents-container{position:absolute;top:0;left:0;width:100%;height:60%;pointer-events:auto}.main-player-container{position:absolute;bottom:10px;width:100%;display:flex;justify-content:center;padding-bottom:20px;align-items:flex-end}.controls{position:absolute;top:10px;right:10px;z-index:100;display:flex;gap:8px}.flying-layer{position:fixed;inset:0;pointer-events:none;z-index:200}.flying-card{position:fixed;transform-origin:center center}.throw-card-back{width:100%;height:100%;border-radius:8px;border:1px solid #ccc;background:repeating-linear-gradient(45deg,#606dbc,#606dbc 10px,#465298 10px 20px);box-shadow:0 2px 5px #0000004d}.add-btn{background:#fff3;border:1px solid white;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:20px;display:flex;justify-content:center;align-items:center}.add-btn.disabled,.add-btn:disabled{opacity:.5;cursor:not-allowed}.reset-btn,.ghost-btn{font-size:16px}.throw-btn{font-size:.85rem;padding:6px 12px;height:30px;border-radius:16px;background:#e67e22;border-color:transparent}.throw-btn:hover{background:#d35400}.throw-button-inline{position:absolute;right:26%;bottom:170px;background:#e67e22;color:#fff;border:none;border-radius:16px;padding:8px 14px;cursor:pointer;font-weight:600;box-shadow:0 4px 10px #00000040}.keep-button-inline{position:absolute;left:50%;transform:translate(-50%);bottom:0;background:#2ecc71;color:#fff;border:none;border-radius:16px;padding:8px 14px;cursor:pointer;font-weight:600;box-shadow:0 4px 10px #00000040}.keep-button-inline:hover{background:#27ae60}.phase-indicator{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);padding:6px 16px;background:transparent;border:1px dotted rgba(150,220,170,.6);border-radius:12px;color:#96dcaaf2;font-size:.9rem;z-index:100}.throw-button-inline:hover{background:#d35400}.selection-pile{position:absolute;left:50%;bottom:170px;transform:translate(-50%);width:170px;height:90px;pointer-events:auto}.selection-card{position:absolute;left:0;bottom:0;cursor:pointer}.selection-card .card-content{align-items:flex-start;justify-content:flex-start;padding:6px}.add-btn:hover{background:#fff6}.trick-card{position:absolute;pointer-events:none;z-index:150}.main-trick-card{position:absolute;bottom:160px;left:50%;transform:translate(-50%);z-index:150}.won-tricks-pile{position:absolute;pointer-events:none;z-index:120}.main-won-tricks-pile{position:absolute;left:20px;bottom:100px;z-index:120}.tricks-count{position:absolute;top:-8px;right:-8px;background:#e74c3c;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;border:2px solid white;z-index:200}.game-over-modal{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.game-over-content{background:#fff;padding:40px;border-radius:16px;box-shadow:0 8px 32px #0000004d;text-align:center;max-width:900px;width:90vw}.game-over-content h2{margin:0 0 20px;color:#2c3e50;font-size:28px}.modal-body{display:flex;gap:30px;align-items:flex-start}.main-content{flex:1;min-width:300px}.hands-sidebar{flex-shrink:0;width:350px;background:#f8f9fa;padding:16px;border-radius:8px;text-align:left}.hands-sidebar h3{margin:0 0 12px;font-size:16px;color:#2c3e50;text-align:center}.hands-table{width:100%;border-collapse:collapse;font-size:13px}.hands-table th{background:#e0e0e0;padding:8px;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #bbb}.hands-table td{padding:8px;border-bottom:1px solid #ddd;vertical-align:top}.player-name-cell{font-weight:600;color:#2c3e50;white-space:nowrap}.hand-cell{width:100%}.hand-cards-compact{display:flex;gap:4px;margin-bottom:4px;flex-wrap:wrap}.hand-card-small{background:#fff;border:1px solid #ccc;border-radius:3px;padding:2px 4px;font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:1px}.hand-type-small{font-size:11px;color:#7f8c8d;font-style:italic}.winner-announcement{font-size:24px;font-weight:700;color:#27ae60;margin-bottom:24px}.tricks-summary{margin:20px 0;padding:16px;background:#f8f9fa;border-radius:8px}.player-tricks{padding:8px;font-size:16px;color:#2c3e50}.ok-button{background:#3498db;color:#fff;border:none;border-radius:24px;padding:12px 40px;font-size:18px;font-weight:700;cursor:pointer;margin-top:20px;transition:background .2s}.ok-button:hover{background:#2980b9}.winner-section{margin:24px 0;padding:16px;background:#f8f9fa;border-radius:8px}.winner-section h3{margin:0 0 12px;font-size:18px;color:#7f8c8d}.hand-type{font-size:18px;color:#3498db;font-weight:600;margin:8px 0}.points-awarded{font-size:20px;color:#27ae60;font-weight:700;margin-top:8px}.scores-summary{margin:24px 0;padding:16px;background:#ecf0f1;border-radius:8px}.scores-summary h3{margin:0 0 16px;font-size:18px;color:#2c3e50}.player-score{display:flex;justify-content:space-between;padding:8px 12px;margin:4px 0;background:#fff;border-radius:6px;font-size:16px}.player-score .player-name{color:#2c3e50;font-weight:600}.score{color:#27ae60;font-weight:700}.suit-symbol{font-size:14px}.suit-hearts,.suit-diamonds{color:#e74c3c}.suit-clubs,.suit-spades{color:#2c3e50}.hand-eval-notification{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:500;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-60%)}to{opacity:1;transform:translate(-50%,-50%)}}.hand-eval-content{background:linear-gradient(135deg,#667eea,#764ba2);padding:24px 40px;border-radius:16px;box-shadow:0 8px 32px #0000004d;text-align:center;color:#fff}.eval-title{font-size:14px;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:12px}.eval-player{font-size:28px;font-weight:700;margin:8px 0}.eval-hand{font-size:20px;margin:8px 0;opacity:.95}.eval-points{font-size:32px;font-weight:700;margin-top:12px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.lobby-container{width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;background:radial-gradient(circle at top,#2f5b46,#1b2c23 60%);color:#f5f5f5}.lobby-panel{width:min(720px,92vw);background:#0a140fcc;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:32px;box-shadow:0 20px 40px #00000059;display:flex;flex-direction:column;gap:24px}.lobby-title{margin:0;font-size:2rem}.lobby-subtitle{margin:0 0 12px;font-size:1.2rem}.lobby-section{display:flex;flex-direction:column;gap:12px}.lobby-label{display:flex;flex-direction:column;gap:6px;font-size:.9rem}.lobby-input{padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff}.lobby-inline{display:flex;gap:12px}.lobby-button{padding:10px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff;cursor:pointer;transition:background .2s ease,border-color .2s ease}.lobby-button.primary{background:#3b8c67;border-color:transparent}.lobby-button:hover:not(.disabled){background:#fff3}.lobby-button.primary:hover:not(.disabled){background:#2e7052}.lobby-button.disabled,.lobby-button:disabled{opacity:.5;cursor:not-allowed}.lobby-game-list,.lobby-player-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.lobby-game-row{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:12px;background:#ffffff0d}.lobby-game-title{font-weight:600}.lobby-game-meta{font-size:.85rem;color:#ffffffb3}.lobby-game-name{font-size:1.1rem;font-weight:600}.lobby-actions{display:flex;gap:12px}.lobby-muted{color:#fff9}.lobby-error{padding:10px 12px;border-radius:10px;background:#ff505033;border:1px solid rgba(255,80,80,.5)}.app-container{width:100vw;height:100vh;margin:0;padding:0}
