:root{-webkit-font-smoothing:antialiased;font:16px/1.5 system-ui,Segoe UI,Roboto,sans-serif}body{background:#1a472a;margin:0}#root{min-height:100vh}h1,h2,h3,h4{margin:0}button,input,select{font-family:inherit}.lobby{background:linear-gradient(135deg,#1a472a 0%,#2d6a4f 100%);flex-direction:column;align-items:center;gap:1.5rem;min-height:100vh;padding:2rem 1rem;display:flex}.lobby-header{text-align:center;color:#fff}.lobby-header h1{text-shadow:2px 2px 8px #00000080;letter-spacing:.05em;margin:0;font-family:Georgia,serif;font-size:3rem}.lobby-subtitle{color:#ffffffbf;margin:.25rem 0 0;font-size:1rem}.lobby-card{background:#fff;border-radius:12px;width:100%;max-width:420px;overflow:hidden;box-shadow:0 8px 32px #0000004d}.lobby-tabs{border-bottom:2px solid #e0e0e0;display:flex}.lobby-tabs button{cursor:pointer;color:#555;background:#f5f5f5;border:none;flex:1;padding:.75rem;font-size:.95rem;font-weight:500;transition:background .2s,color .2s}.lobby-tabs button.active{color:#1a472a;background:#fff;border-bottom:3px solid #1a472a;margin-bottom:-2px;font-weight:700}.lobby-form{flex-direction:column;gap:.5rem;padding:1.5rem;display:flex}.lobby-form label{color:#444;margin-top:.25rem;font-size:.85rem;font-weight:600}.lobby-form input,.lobby-form select{border:2px solid #e0e0e0;border-radius:6px;outline:none;padding:.6rem .75rem;font-size:1rem;transition:border-color .2s}.lobby-form input:focus,.lobby-form select:focus{border-color:#1a472a}.variant-info{color:#2e7d32;background:#f0f7f0;border:1px solid #c8e6c9;border-radius:6px;margin:.25rem 0;padding:.6rem .75rem;font-size:.85rem}.btn-primary{color:#fff;cursor:pointer;background:#1a472a;border:none;border-radius:8px;margin-top:.5rem;padding:.75rem;font-size:1rem;font-weight:700;transition:background .2s}.btn-primary:hover:not(:disabled){background:#2d6a4f}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.lobby-error{color:#c62828;background:#ffebee;border-radius:6px;margin:0;padding:.5rem .75rem;font-size:.9rem}.lobby-rules{color:#ffffffe6;background:#ffffff1f;border-radius:10px;width:100%;max-width:420px;padding:1rem 1.25rem}.lobby-rules h3{text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem;font-size:.95rem}.lobby-rules ul{margin:0;padding-left:1.2rem;font-size:.85rem;line-height:1.6}.waiting-room{background:#fff;border-radius:12px;width:100%;max-width:480px;padding:2rem;box-shadow:0 8px 32px #0003}.waiting-room h2{color:#1a472a;text-align:center;margin:0 0 1.5rem;font-size:1.5rem}.game-code-display{text-align:center;background:#1a472a;border-radius:10px;flex-direction:column;gap:.25rem;margin-bottom:1.25rem;padding:1.25rem;display:flex}.code-label{color:#ffffffb3;text-transform:uppercase;letter-spacing:.1em;font-size:.8rem}.code-value{color:#fff;letter-spacing:.25em;font-family:monospace;font-size:2.5rem;font-weight:700}.code-hint{color:#fff9;font-size:.8rem}.waiting-settings{background:#f5f5f5;border-radius:8px;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;padding:.75rem 1rem;display:flex}.setting-row{justify-content:space-between;align-items:center;font-size:.9rem;display:flex}.setting-label{color:#444;font-weight:600}.setting-row select{border:1px solid #ccc;border-radius:4px;padding:.25rem .5rem;font-size:.9rem}.players-list h3{color:#555;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem;font-size:.95rem}.player-row{border-bottom:1px solid #f0f0f0;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.player-row:last-child{border-bottom:none}.player-seat{color:#999;width:24px;font-size:.85rem}.player-name{flex:1;font-weight:500}.player-empty .player-name{color:#aaa;font-style:italic;font-weight:400}.player-you{color:#1a472a;font-size:.8rem;font-weight:600}.player-host{color:#fff;background:#1a472a;border-radius:4px;padding:1px 6px;font-size:.75rem}.btn-start{color:#fff;cursor:pointer;background:#1a472a;border:none;border-radius:8px;width:100%;margin-top:1.5rem;padding:.85rem;font-size:1.05rem;font-weight:700;transition:background .2s}.btn-start:hover:not(:disabled){background:#2d6a4f}.btn-start:disabled{cursor:not-allowed;background:#aaa}.waiting-hint{text-align:center;color:#777;margin-top:1.5rem;font-style:italic}.card{-webkit-user-select:none;user-select:none;background:#fff;border:2px solid #ccc;border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:105px;height:150px;font-family:Georgia,serif;font-size:1.65rem;font-weight:700;transition:transform .15s,box-shadow .15s;display:inline-flex;position:relative;box-shadow:1px 2px 4px #0000004d}.card-small{width:75px;height:108px;font-size:1.275rem}.card-rank-top{font-size:.8em;line-height:1;position:absolute;top:6px;left:9px}.card-suit-top{font-size:.65em;line-height:1;position:absolute;top:24px;left:9px}.card-suit-center{font-size:1.6em}.card-rank-bottom{font-size:.8em;line-height:1;position:absolute;bottom:6px;right:9px;transform:rotate(180deg)}.card-suit-bottom{font-size:.65em;line-height:1;position:absolute;bottom:24px;right:9px;transform:rotate(180deg)}.card-trump-badge{color:#333;background:gold;border-radius:3px;padding:0 2px;font-size:.5em;line-height:1.3;position:absolute;top:5px;right:6px}.card-back{cursor:default;background:linear-gradient(135deg,#1a3a6b,#2a5ab8);border-color:#1a3a6b}.card-back-pattern{background:repeating-linear-gradient(45deg,#ffffff0d 0 4px,#0000 4px 8px);border:5px solid #ffffff4d;border-radius:6px;width:81px;height:126px}.card-trump{background:linear-gradient(160deg,#fff 80%,#fffbe6 100%);border-color:#c8a400}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-6px);box-shadow:2px 6px 12px #0006}.card-selected{transform:translateY(-12px);box-shadow:0 0 0 3px #4caf50,2px 8px 16px #0006}.card-unplayable{opacity:.4;cursor:not-allowed}.card-unplayable:hover{transform:none;box-shadow:1px 2px 4px #0000004d}.game-table{color:#fff;background:radial-gradient(#2d6a4f 0%,#1a472a 100%);flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}.status-bar{background:#0006;border-bottom:1px solid #ffffff26;flex-shrink:0;align-items:center;gap:1rem;padding:.6rem 1.25rem;font-size:.95rem;display:flex}.status-text{flex:1}.called-ace{color:gold;background:#ffd70040;border:1px solid gold;border-radius:6px;padding:2px 10px;font-size:.85rem}.leasters-badge{letter-spacing:.1em;background:#c62828;border-radius:6px;padding:2px 10px;font-size:.8rem;font-weight:700}.table-layout{flex:1;grid-template-rows:auto 1fr;grid-template-columns:1fr auto 260px;gap:.75rem;min-height:0;padding:.75rem;display:grid}.opponents-area{flex-wrap:wrap;grid-column:1/3;justify-content:center;align-items:flex-start;gap:.75rem;padding-bottom:.5rem;display:flex}.opponent-area{background:#00000040;border:2px solid #0000;border-radius:10px;min-width:140px;padding:.6rem .75rem;transition:border-color .3s}.opponent-area.current-player{border-color:gold;box-shadow:0 0 12px #ffd70066}.opponent-info{justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.85rem;display:flex}.opponent-name{align-items:center;gap:4px;font-weight:600;display:flex}.opponent-tricks{color:#fff9;font-size:.75rem}.opponent-cards{flex-wrap:wrap;gap:2px;display:flex}.badge{border-radius:4px;justify-content:center;align-items:center;padding:1px 4px;font-size:.65rem;font-weight:700;line-height:1.4;display:inline-flex}.dealer-badge{color:#fff;background:#555}.picker-badge{color:#fff;background:#1565c0}.partner-badge{color:#fff;background:#c62828}.center-area{flex-direction:column;grid-area:2/1;justify-content:center;align-items:center;gap:1rem;display:flex}.trick-area{text-align:center;background:#00000040;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;max-width:500px;min-height:140px;padding:1rem 1.5rem;display:flex}.trick-area-empty{border:2px dashed #fff3}.trick-label{color:#fff9;margin-bottom:.25rem;font-size:.8rem}.trick-empty-text{color:#ffffff59;font-style:italic}.trick-cards{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.trick-card-slot{flex-direction:column;align-items:center;gap:4px;display:flex}.trick-player-name{color:#ffffffb3;font-size:.72rem}.scoring-overlay{text-align:center;background:#00000080;border:2px solid gold;border-radius:12px;width:100%;max-width:500px;padding:1rem 1.5rem}.scoring-overlay h3{color:gold;margin:0 0 .75rem;font-size:1.1rem}.buried-reveal{flex-direction:column;align-items:center;gap:.5rem;display:flex}.buried-label{color:#ffffffb3;font-size:.85rem}.buried-cards{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}.sidebar{flex-direction:column;grid-area:1/3/3;gap:.75rem;min-width:0;display:flex}.score-panel,.game-log{background:#00000059;border-radius:10px;padding:.75rem}.score-panel h3,.game-log h3{text-transform:uppercase;letter-spacing:.1em;color:#fff9;margin:0 0 .5rem;font-size:.8rem}.score-table{border-collapse:collapse;width:100%;font-size:.85rem}.score-table th{text-align:left;color:#ffffff80;border-bottom:1px solid #ffffff26;padding:2px 4px;font-weight:500}.score-table td{padding:3px 4px}.score-me{background:#ffffff14;border-radius:4px}.score-total{font-weight:700}.score-pos{color:#69f0ae}.score-neg{color:#ff5252}.game-log{flex-direction:column;flex:1;display:flex;overflow:hidden}.log-entries{flex:1;max-height:280px;overflow-y:auto}.log-entry{color:#ffffffbf;border-bottom:1px solid #ffffff14;padding:3px 0;font-size:.78rem;line-height:1.3}.action-panel{background:#00000073;border-top:2px solid #ffd70080;flex-shrink:0;padding:1rem 1.25rem}.action-panel-waiting{text-align:center;color:#fff9;padding:.75rem;font-style:italic}.action-prompt{margin:0 0 .75rem;font-size:.95rem}.action-note{color:#fff9;margin:-.5rem 0 .75rem;font-size:.8rem}.action-buttons{flex-wrap:wrap;gap:.75rem;display:flex}.btn-action{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.25rem;font-size:.95rem;font-weight:700;transition:opacity .2s,transform .1s}.btn-action:hover:not(:disabled){opacity:.85;transform:translateY(-1px)}.btn-action:disabled{opacity:.4;cursor:not-allowed}.btn-pick{color:#fff;background:#1565c0}.btn-pass{color:#fff;background:#555}.btn-bury{color:#fff;background:#c62828}.btn-call{color:#fff;background:#4a148c;font-size:1rem}.btn-next{color:#fff;background:#1a472a;border:2px solid gold}.bury-hand{flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:.75rem;display:flex}.my-hand-area{background:#0000004d;border-top:1px solid #ffffff1a;flex-shrink:0;padding:.75rem 1.25rem}.my-hand-label{color:#fff9;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.8rem;display:flex}.my-hand{flex-wrap:wrap;justify-content:center;gap:.5rem;display:flex}@media (width<=768px){.table-layout{grid-template-rows:auto auto 1fr;grid-template-columns:1fr}.opponents-area{grid-column:1}.center-area{grid-area:2/1}.sidebar{flex-direction:row;grid-area:3/1;overflow-x:auto}.score-panel,.game-log{min-width:200px}}*,:before,:after{box-sizing:border-box}.connecting-screen{color:#fffc;background:#1a472a;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;font-size:1.1rem;display:flex}.connecting-spinner{border:4px solid #fff3;border-top-color:#fff;border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.waiting-screen{background:linear-gradient(135deg,#1a472a,#2d6a4f);flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;padding:2rem 1rem;display:flex}.btn-leave{color:#ffffffb3;cursor:pointer;background:0 0;border:1px solid #fff6;border-radius:6px;padding:.4rem 1rem;font-size:.85rem;transition:all .2s}.btn-leave:hover{color:#fff;background:#ffffff1a}.screen-error{color:#ff5252;background:#c6282833;border-radius:6px;padding:.5rem 1rem;font-size:.9rem}.game-screen{min-height:100vh;position:relative}.game-error-banner{color:#fff;z-index:999;background:#c62828;border-radius:8px;align-items:center;gap:1rem;padding:.6rem 1rem;font-size:.9rem;display:flex;position:fixed;top:1rem;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0006}.game-error-banner button{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;padding:0;font-size:1.2rem;line-height:1}.game-error-banner button:hover{opacity:1}.btn-leave-game{color:#fff9;cursor:pointer;z-index:100;background:#0006;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.85rem;transition:all .2s;display:flex;position:fixed;top:.5rem;right:.75rem}.btn-leave-game:hover{color:#fff;background:#c6282899;border-color:#0000}
