@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--tile-w: 42px;--tile-h: 58px;--tile-gap: 6px;--hand-row-gap: 12px;--tile-red: #d32f2f;--tile-black: #1a1a1a;--tile-blue: #1565c0;--tile-yellow: #f9a825;--tile-bg: #fefcf5;--tile-border: #c8c4b8;--tile-selected: #00bcd4;--table-felt: #0d7347;--table-edge: #0a5c38;--table-grid: rgba(255,255,255,.06);--rack-wood: linear-gradient(180deg, #c4a265 0%, #a0793b 50%, #8b6730 100%);--rack-shadow: 0 -4px 16px rgba(0,0,0,.4)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;font-family:Inter,system-ui,sans-serif}body{background:linear-gradient(135deg,#004d40,#00695c 40%,#00796b);color:#e0e0e0}.join-screen{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:linear-gradient(135deg,#004d40,#00695c)}.join-card,.lobby-card{background:#00000073;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:40px 36px;text-align:center;min-width:340px;box-shadow:0 8px 32px #0006}.join-card h1,.lobby-card h2{margin-bottom:24px;font-weight:700}.join-card input,.lobby-card input{display:block;width:100%;padding:10px 14px;margin-bottom:12px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;color:#fff;font-size:1rem;outline:none}.join-card input::placeholder{color:#ffffff80}.join-card button,.lobby-actions button{padding:10px 24px;border-radius:8px;border:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.join-card button{width:100%;background:#00bcd4;color:#000;margin-top:4px}.join-card button:hover{background:#00acc1}.join-seats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;width:100%;margin-top:4px}.join-seats button{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#fff;font-weight:600}.join-seats button:hover{background:#ffffff24}.join-seats button:disabled{opacity:.6;cursor:not-allowed}.join-hint{margin-top:8px;font-size:.85rem;opacity:.8}.lobby-toggle{display:flex;align-items:center;gap:8px;justify-content:center;margin:10px 0 4px;font-size:.85rem;color:#ffffffd9}.lobby-toggle input{width:16px;height:16px}.hand-end-summary{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;font-size:.9rem}.round-scores{display:grid;gap:6px;margin:12px 0 18px;text-align:left}.score-row{display:grid;grid-template-columns:70px repeat(4,minmax(60px,1fr));gap:6px;align-items:center;padding:6px 8px;border-radius:8px;background:#ffffff0f}.round-scores.team-mode .score-row{grid-template-columns:70px repeat(2,minmax(60px,1fr))}.score-row.score-header{font-weight:700;background:#00000059}.score-row.score-total{font-weight:700;background:#00000073}.join-card button:disabled{opacity:.4;cursor:default}.lobby-players{display:flex;gap:10px;justify-content:center;margin-bottom:20px;flex-wrap:wrap}.lobby-player{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;border-radius:10px;background:#ffffff14;min-width:80px;font-size:.85rem}.lobby-player.you{background:#00bcd426;border:1px solid rgba(0,188,212,.3)}.lobby-player.empty{opacity:.3}.lobby-seats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:20px}.lobby-seat{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:12px;background:#ffffff14;border:1px solid rgba(255,255,255,.08);font-size:.85rem}.lobby-seat.empty{opacity:.5}.lobby-seat.you{background:#00bcd426;border:1px solid rgba(0,188,212,.3)}.lobby-teams{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:20px}.team-column{display:flex;flex-direction:column;gap:10px}.team-title{font-weight:700;text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;opacity:.8}.avatar-placeholder{width:40px;height:40px;border-radius:50%;background:#ffffff26}.ready-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:.75rem;background:#ffffff1a}.ready-badge.on{background:#4caf50;color:#fff}.lobby-actions{display:flex;gap:8px;justify-content:center}.lobby-actions button{background:#ffffff1f;color:#e0e0e0}.lobby-actions button.primary{background:#00bcd4;color:#000}.lobby-actions button.secondary{background:#ffffff14}.lobby-actions button:hover{filter:brightness(1.1)}.game-table{position:relative;width:100vw;height:100vh;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:auto 1fr auto;grid-template-areas:".     top    ." "left  center right" "bottom bottom bottom"}.seat-panel{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px;z-index:2}.seat-top{grid-area:top;flex-direction:row;gap:12px;justify-content:center;padding:8px 20px}.seat-left{grid-area:left;justify-content:center;padding:10px 6px}.seat-right{grid-area:right;justify-content:center;padding:10px 6px}.seat-avatar{position:relative}.avatar-img{width:44px;height:44px;border-radius:50%;background:#ffffff1f;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff;border:2px solid transparent}.seat-panel.active .avatar-img{border-color:#fdd835;box-shadow:0 0 12px #fdd83580}.turn-indicator{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;background:#fdd835;border:2px solid var(--table-felt)}.seat-name{font-size:.8rem;font-weight:600;text-align:center;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-team{font-size:.7rem;opacity:.7}.seat-count{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#00000080;font-size:.75rem;font-weight:700}.seat-tiles{display:flex;gap:2px;flex-wrap:wrap;justify-content:center;max-width:80px}.seat-left .seat-tiles,.seat-right .seat-tiles{max-width:50px;flex-direction:column}.seat-top .seat-tiles{max-width:200px;flex-direction:row}.more-tiles{font-size:.7rem;opacity:.6}.seat-discard{margin-top:4px}.center-area{grid-area:center;background:repeating-linear-gradient(0deg,var(--table-grid) 0px,var(--table-grid) 1px,transparent 1px,transparent 60px),repeating-linear-gradient(90deg,var(--table-grid) 0px,var(--table-grid) 1px,transparent 1px,transparent 60px),radial-gradient(ellipse at center,#0d8050 0%,var(--table-felt) 70%,var(--table-edge) 100%);border-radius:20px;margin:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:16px;box-shadow:inset 0 2px 20px #0000004d;position:relative;overflow:auto}.center-badge{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#00000080;color:#fdd835;font-weight:700;font-size:.8rem;padding:3px 12px;border-radius:12px;letter-spacing:1px}.center-info{display:flex;gap:24px;align-items:center}.indicator-area,.deck-area,.open-limit{display:flex;flex-direction:column;align-items:center;gap:4px}.indicator-area .label,.deck-area .label,.open-limit .label{font-size:.7rem;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.open-limit .limit-value{font-weight:700;font-size:.85rem}.deck-stack{position:relative}.deck-count{font-size:.75rem;font-weight:700;opacity:.8}.discard-ring{position:absolute;inset:0;pointer-events:none;z-index:3}.discard-pile{position:absolute;width:60px;height:84px;display:flex;align-items:center;justify-content:center;pointer-events:auto}.discard-pile.active-drop{box-shadow:0 0 14px #00bcd4b3;border-radius:10px}.discard-bottom-left{left:20%;bottom:26%}.discard-top-left{left:28%;top:22%}.discard-top-right{right:28%;top:22%}.discard-bottom-right{right:20%;bottom:26%}.discard-empty{width:42px;height:58px;border-radius:8px;border:2px dashed rgba(255,255,255,.25);color:#ffffff80;font-size:.6rem;display:flex;align-items:center;justify-content:center;text-transform:uppercase;letter-spacing:.5px}.return-tile-btn{width:48px;height:66px;border-radius:8px;border:1px solid rgba(255,255,255,.3);background:#ffffff14;color:#fff;font-size:.55rem;text-transform:uppercase;letter-spacing:.5px;cursor:pointer}.return-tile-btn:hover{background:#ffffff24}.table-melds{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:100%}.meld-group{display:inline-flex;flex-direction:column;align-items:center;gap:4px;padding:4px 6px;background:#00000040;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:border-color .15s}.meld-group:hover{border-color:#ffffff4d}.meld-group.selected{border-color:var(--tile-selected);box-shadow:0 0 8px #00bcd466}.meld-group.legal{border-color:#4caf5099;box-shadow:0 0 8px #4caf5040}.meld-owner{font-size:.6rem;text-transform:uppercase;letter-spacing:.4px;opacity:.7}.meld-tiles{display:inline-flex;gap:2px}.meld-group .tile{width:30px;height:42px;font-size:.85rem;cursor:default}.meld-group .tile:hover{transform:none}.tile{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;width:var(--tile-w);height:var(--tile-h);border-radius:8px;background:var(--tile-bg);border:2px solid var(--tile-border);cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;transition:transform .12s,border-color .12s,box-shadow .12s;box-shadow:0 2px 4px #00000026;gap:2px}.tile.draggable{cursor:grab}.tile.dragging{cursor:grabbing;transform:translateY(-10px) scale(1.04);box-shadow:0 10px 18px #00000059}.tile:hover:not(.disabled):not(.face-down){transform:translateY(-4px);box-shadow:0 6px 12px #00000040}.tile.selected{border-color:var(--tile-selected);box-shadow:0 0 10px var(--tile-selected),0 4px 8px #0003;transform:translateY(-8px)}.tile.disabled{cursor:default}.tile.disabled:hover{transform:none;box-shadow:0 2px 4px #00000026}.tile.hint{border-color:#4caf50bf;box-shadow:0 0 8px #4caf5066}.tile-value{font-size:1.2rem;font-weight:700;line-height:1}.tile-dot{display:block;width:6px;height:6px;border-radius:50%;border:1.5px solid currentColor;opacity:.5}.tile.color-red{color:var(--tile-red)}.tile.color-red .tile-dot{border-color:var(--tile-red)}.tile.color-black{color:var(--tile-black)}.tile.color-black .tile-dot{border-color:var(--tile-black)}.tile.color-blue{color:var(--tile-blue)}.tile.color-blue .tile-dot{border-color:var(--tile-blue)}.tile.color-yellow{color:var(--tile-yellow)}.tile.color-yellow .tile-dot{border-color:var(--tile-yellow)}.tile.fake-joker{background:linear-gradient(135deg,#fff8e1,#ffe082);color:#ff6f00}.tile.okey-tile{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.okey-star{position:absolute;top:1px;right:1px;font-size:.55rem}.tile.face-down{background:linear-gradient(135deg,#1a237e,#283593);border-color:#0d1642;width:32px;height:44px;cursor:default}.tile.face-down:after{content:"";display:block;width:16px;height:20px;border-radius:4px;border:2px solid rgba(255,255,255,.15)}.tile.face-down.mini{width:18px;height:26px}.tile.face-down.mini:after{width:8px;height:10px;border-width:1px}.local-player{grid-area:bottom;display:flex;flex-direction:column;align-items:center;gap:6px;padding:4px 12px 8px;position:relative}.action-bar{display:flex;align-items:center;gap:8px;width:100%;max-width:860px;padding:4px 8px;flex-wrap:wrap}.turn-label{font-size:.85rem;font-weight:600;opacity:.9;margin-right:auto;padding:4px 12px;background:#0000004d;border-radius:6px}.action-buttons{display:flex;gap:6px;flex-wrap:wrap}.action-buttons button{padding:6px 14px;border-radius:6px;border:none;font-size:.82rem;font-weight:600;cursor:pointer;background:#ffffff1f;color:#e0e0e0;transition:all .12s}.action-buttons button:hover{background:#fff3}.action-buttons button:disabled{opacity:.3;cursor:default}.action-buttons button.primary{background:#00bcd4;color:#000}.action-buttons button.primary:hover{background:#00acc1}.action-buttons button.secondary{background:#00bcd433;color:#00e5ff}.action-buttons button.danger{background:#f443364d;color:#ef9a9a}.action-buttons button.danger:hover{background:#f4433680}.taken-tile-panel{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:#00000059;border-radius:6px}.taken-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;opacity:.8}.meld-preview{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.meld-total{font-size:.7rem;font-weight:700;padding:4px 8px;background:#0006;border-radius:6px;align-self:center}.meld-preview-group{display:flex;gap:2px;align-items:center;background:#0000004d;border-radius:6px;padding:3px 6px;cursor:pointer}.meld-preview-group:hover{background:#00000073}.meld-label{font-size:.65rem;opacity:.5;margin-right:4px;text-transform:uppercase;letter-spacing:.5px}.meld-preview-group .tile{width:30px;height:42px;font-size:.85rem}.hand-area{width:100%;max-width:calc(var(--tile-w) * 18 + var(--tile-gap) * 17);height:calc(var(--tile-h) * 2 + var(--hand-row-gap) + 24px);background:linear-gradient(#ffffff14,#ffffff14) 0 0 / 100% var(--tile-h) no-repeat,linear-gradient(#ffffff14,#ffffff14) 0 calc(var(--tile-h) + var(--hand-row-gap)) / 100% var(--tile-h) no-repeat,var(--rack-wood);border-radius:12px 12px 4px 4px;padding:8px 10px 10px;box-shadow:var(--rack-shadow),inset 0 1px #fff3;position:relative;overflow:hidden}.hand-area.dragging{box-shadow:var(--rack-shadow),0 0 0 2px #00bcd459,inset 0 1px #fff3}.hand-area:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#ffffff26;border-radius:12px 12px 0 0}.hand-tile{position:absolute;width:var(--tile-w);height:var(--tile-h);transition:left .16s ease,top .16s ease}.hand-tile.dragging{opacity:.4;transition:none}.hand-ghost{position:absolute;width:var(--tile-w);height:var(--tile-h);pointer-events:none;opacity:.7;filter:drop-shadow(0 6px 12px rgba(0,0,0,.25))}.action-buttons button.discard-btn{background:#e53935;color:#fff;font-weight:700}.action-buttons button.discard-btn:hover{background:#c62828}.penalty-toast{position:fixed;top:12px;right:12px;z-index:100;display:flex;flex-direction:column;gap:4px}.penalty-item{background:#c62828e6;color:#fff;padding:6px 14px;border-radius:8px;font-size:.8rem;font-weight:600;box-shadow:0 4px 12px #0000004d;animation:slideIn .3s ease-out}.notice-toast{position:fixed;top:12px;left:12px;z-index:100;background:#000000a6;color:#fff;padding:8px 14px;border-radius:8px;font-size:.8rem;font-weight:600;box-shadow:0 4px 12px #0000004d;animation:slideInLeft .3s ease-out}@keyframes slideInLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.scores-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:150}.scores-modal{background:#000000a6;border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:16px 18px;min-width:360px;max-width:80vw;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.scores-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.scores-header h3{margin:0}.scores-empty{padding:8px 0;opacity:.75}.settings-grid{display:grid;gap:10px;margin-top:8px}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.85rem}.settings-row input[type=number]{width:90px;padding:6px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#fff}.settings-row input[type=checkbox]{width:16px;height:16px}.settings-actions{display:flex;justify-content:flex-end;margin-top:12px}.scores-button{position:absolute;top:12px;right:12px;z-index:6;padding:8px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#00000059;color:#fff;font-weight:600;cursor:pointer}.scores-button:hover{background:#00000080}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}
