.room-browser{background:#ffffff1a;border-radius:16px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.room-browser-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(255,255,255,.2)}.room-browser-header h2{margin:0;font-size:1.8rem}.room-count{background:#fff3;padding:.5rem 1rem;border-radius:20px;font-size:.9rem}.no-rooms{text-align:center;padding:4rem 2rem;color:#ffffffb3}.no-rooms p{margin:.5rem 0;font-size:1.2rem}.no-rooms-hint{font-size:1rem;opacity:.8}.room-list{display:grid;gap:1rem}.room-card{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;background:#ffffff26;border-radius:12px;transition:all .2s;border:2px solid transparent}.room-card:hover{background:#fff3;border-color:#ffffff4d}.room-card.in-progress{opacity:.6}.room-info{display:flex;gap:2rem;align-items:center;flex:1}.room-host{display:flex;flex-direction:column;gap:.25rem}.host-label{font-size:.8rem;opacity:.8}.host-name{font-size:1.1rem;font-weight:600}.room-players{display:flex;align-items:center}.player-count{padding:.5rem 1rem;background:#3b82f64d;border-radius:20px;font-weight:500}.player-count.full{background:#ef44444d;color:#fca5a5}.room-status{display:flex;align-items:center}.status-badge{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.status-badge.waiting{background:#10b9814d;color:#6ee7b7}.status-badge.in-progress{background:#f59e0b4d;color:#fcd34d}.join-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s;min-width:100px}.join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.join-btn:disabled{opacity:.5;cursor:not-allowed;background:#64646480}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.join-prompt{background:linear-gradient(135deg,#1e3a5f,#2d5a7b);padding:2rem;border-radius:16px;min-width:400px;box-shadow:0 8px 32px #00000080;border:2px solid rgba(255,255,255,.2)}.join-prompt h3{margin:0 0 1.5rem;font-size:1.5rem;text-align:center}.join-prompt input{width:100%;padding:.75rem;font-size:1rem;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;margin-bottom:1.5rem}.join-prompt input::placeholder{color:#ffffff80}.join-prompt input:focus{outline:none;border-color:#3b82f6}.join-prompt-actions{display:flex;gap:1rem;justify-content:flex-end}.join-prompt-actions button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.confirm-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.confirm-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.room-browser{padding:1rem}.room-info{flex-direction:column;align-items:flex-start;gap:.75rem}.room-card{flex-direction:column;gap:1rem}.join-btn{width:100%}.join-prompt{min-width:90%;margin:1rem}}.create-game-modal{position:relative;background:linear-gradient(135deg,#1e3a5f,#2d5a7b);padding:2.5rem;border-radius:16px;min-width:500px;max-width:90vw;box-shadow:0 8px 32px #00000080;border:2px solid rgba(255,255,255,.2);color:#fff}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:#ffffffb3;font-size:1.5rem;cursor:pointer;padding:.5rem;line-height:1}.modal-close:hover{color:#fff}.create-game-modal h2{margin:0 0 .5rem;font-size:2rem;text-align:center}.modal-description{text-align:center;color:#fffc;margin:0 0 2rem;line-height:1.5}.form-group{margin-bottom:2rem;position:relative}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.95rem}.form-group input{width:100%;padding:.875rem;font-size:1rem;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;transition:all .2s}.form-group input::placeholder{color:#ffffff80}.form-group input:focus{outline:none;border-color:#3b82f6;background:#ffffff26}.character-count{position:absolute;bottom:-1.5rem;right:0;font-size:.85rem;color:#fff9}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2.5rem}.modal-actions button{padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s;min-width:120px}.cancel-btn{background:#fff3;color:#fff}.cancel-btn:hover{background:#ffffff4d}.create-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.create-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.create-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.create-game-modal{min-width:90%;margin:1rem;padding:2rem 1.5rem}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.player-list{display:flex;flex-direction:column;gap:1rem}.player-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#ffffff1a;border-radius:12px;border:2px solid rgba(255,255,255,.2);transition:all .2s}.player-item.current-player{border-color:#3b82f6;background:#3b82f626}.player-item.disconnected{opacity:.6}.player-item.empty{opacity:.5;border-style:dashed}.player-number{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;flex-shrink:0}.player-item.empty .player-number{background:#6464644d}.player-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.player-name{font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.player-name.empty-slot{color:#ffffff80;font-weight:400;font-style:italic}.add-ai-slot-btn{background:transparent;border:none;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;padding:.5rem 0;transition:all .2s;text-align:left}.add-ai-slot-btn:hover{color:#fffc;text-decoration:underline}.host-badge,.you-badge,.ai-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.host-badge{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.you-badge{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.ai-badge{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.player-status{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#ffffffb3}.status-indicator{width:8px;height:8px;border-radius:50%}.status-indicator.connected{background:#10b981;box-shadow:0 0 8px #10b981}.status-indicator.disconnected{background:#ef4444}@media (max-width: 768px){.player-item{padding:.875rem}.player-number{width:36px;height:36px;font-size:1rem}.player-name{font-size:1rem;flex-wrap:wrap}}.waiting-room{max-width:600px;margin:0 auto;background:#ffffff1a;border-radius:16px;padding:1.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.waiting-room-header{text-align:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid rgba(255,255,255,.2)}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.waiting-room-header h2{margin:0;font-size:1.5rem}.leave-link{background:transparent;border:none;color:#fff9;font-size:.9rem;cursor:pointer;padding:.25rem .5rem;transition:color .2s}.leave-link:hover{color:#ef4444}.room-id{font-size:.8rem;color:#ffffff80;font-family:monospace;margin-bottom:.75rem}.mode-selector{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.75rem}.mode-label{font-size:.95rem;color:#fffc;font-weight:500}.mode-select{padding:.5rem 2rem .5rem .75rem;font-size:.95rem;font-weight:500;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25em 1.25em}.mode-select:hover{border-color:#ffffff80;background-color:#ffffff26}.mode-select:focus{outline:none;border-color:#3b82f6}.mode-select option{background:#1e293b;color:#fff}.style-selector{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.75rem}.style-label{font-size:.95rem;color:#fffc;font-weight:500}.style-loading{font-size:.9rem;color:#ffffff80;font-style:italic}.style-select{padding:.5rem 2rem .5rem .75rem;font-size:.95rem;font-weight:500;border:2px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:#fff;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25em 1.25em;min-width:160px}.style-select:hover{border-color:#ffffff80;background-color:#ffffff26}.style-select:focus{outline:none;border-color:#3b82f6}.style-select option{background:#1e293b;color:#fff}.settings-hint{font-size:.8rem;color:#ffffff80;margin-top:.5rem;text-align:center;font-style:italic}.waiting-room-content{display:flex;flex-direction:column;gap:1.25rem}.fill-ai-btn{width:100%;padding:1rem 2rem;font-size:1.15rem;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f666;letter-spacing:.5px}.fill-ai-btn:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);transform:translateY(-2px);box-shadow:0 6px 16px #3b82f680}.start-game-btn{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 12px #10b9814d}.start-game-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.start-game-btn:disabled{opacity:.6;cursor:not-allowed;background:#64646466;box-shadow:none;transform:none}@media (max-width: 768px){.waiting-room{padding:1rem;margin:0 .5rem}.waiting-room-header h2{font-size:1.25rem}.mode-selector{flex-direction:column;gap:.5rem}.mode-select{width:100%}.style-selector{flex-direction:column;gap:.5rem}.style-select{width:100%;min-width:unset}.settings-hint{font-size:.75rem}.fill-ai-btn{padding:.875rem 1.25rem;font-size:1rem}.start-game-btn{padding:.875rem 1.5rem;font-size:1rem}}.toast{position:fixed;top:20px;right:20px;display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #00000080;color:#fff;font-size:.95rem;z-index:9999;min-width:300px;max-width:500px;animation:toast-slide-in .3s ease}@keyframes toast-slide-in{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{font-size:1.5rem;font-weight:700;flex-shrink:0}.toast-message{flex:1}.toast-close{background:none;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s;flex-shrink:0}.toast-close:hover{background:#fff3}.toast-success{background:linear-gradient(135deg,#10b981,#059669)}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626)}.toast-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.toast-info{background:linear-gradient(135deg,#3b82f6,#2563eb)}@media (max-width: 768px){.toast{right:10px;left:10px;min-width:auto;max-width:none}}.tile-style-selector{padding:var(--spacing-md)}.tile-style-selector h3{margin-top:0;margin-bottom:var(--spacing-sm);color:#fff;font-size:var(--font-xl)}.style-description{color:#ffffffb3;margin-bottom:var(--spacing-lg);font-size:var(--font-sm)}.loading-message{color:#fff9;padding:var(--spacing-lg);text-align:center}.style-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md)}.style-option{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:8px;padding:var(--spacing-md);cursor:pointer;transition:all .2s ease;text-align:left;position:relative}.style-option:hover{background:#ffffff26;border-color:#3b82f680;transform:translateY(-2px)}.style-option.active{background:#3b82f633;border-color:#3b82f6cc;box-shadow:0 4px 12px #3b82f64d}.style-content h4{margin:0 0 var(--spacing-xs) 0;color:#fff;font-size:var(--font-lg)}.style-content p{margin:0;color:#ffffffb3;font-size:var(--font-sm);line-height:1.4}.active-badge{display:inline-block;margin-top:var(--spacing-sm);padding:4px 12px;background:#22c55e33;color:#22c55e;border-radius:12px;font-size:var(--font-xs);font-weight:700}@media (max-width: 768px){.style-grid{grid-template-columns:1fr}}.settings-modal{max-width:800px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{margin:0;font-size:var(--font-xl);color:#fff}.close-button{background:none;border:none;color:#fff9;font-size:24px;cursor:pointer;padding:var(--spacing-xs);line-height:1;transition:color .2s ease}.close-button:hover{color:#fff}.modal-content{flex:1;overflow-y:auto}.settings-section{margin-bottom:var(--spacing-xl)}.settings-section h3{color:#fff;font-size:var(--font-lg);margin:0 0 var(--spacing-md) 0;font-weight:600}.setting-item{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-md);background:#ffffff0d;border-radius:8px;margin-bottom:var(--spacing-sm)}.setting-info{flex:1}.setting-label{display:block;color:#fff;font-size:var(--font-md);font-weight:500;margin-bottom:var(--spacing-xs);cursor:pointer}.setting-description{color:#fff9;font-size:var(--font-sm);margin:0;line-height:1.4}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#fff3;transition:.3s;border-radius:28px;border:2px solid rgba(255,255,255,.3)}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:2px;bottom:2px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#4caf50;border-color:#4caf50}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 4px #4caf5080}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding-top:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1);margin-top:var(--spacing-lg)}@media (max-width: 768px){.settings-modal{max-width:95vw;max-height:95vh}}.lobby{min-height:100vh;background:linear-gradient(135deg,#1e3a5f,#2d5a7b);color:#fff;padding:2rem}.lobby-header{text-align:center;margin-bottom:3rem}.lobby-header h1{font-size:3rem;margin:0 0 1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.header-actions{display:flex;justify-content:center;align-items:center;gap:1rem}.settings-button{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#fff;font-size:.95rem;padding:.5rem 1rem;border-radius:20px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.4rem;white-space:nowrap}.connection-status{display:flex;justify-content:center;gap:.5rem;align-items:center}.status{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500;display:inline-flex;align-items:center;gap:.5rem}.status:before{content:"";width:8px;height:8px;border-radius:50%;display:inline-block}.status.connected{background:#10b98133;color:#10b981}.status.connected:before{background:#10b981;box-shadow:0 0 8px #10b981}.status.connecting{background:#f59e0b33;color:#f59e0b}.status.connecting:before{background:#f59e0b;animation:pulse 1.5s infinite}.status.disconnected{background:#ef444433;color:#ef4444}.status.disconnected:before{background:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.lobby-content{max-width:1200px;margin:0 auto}.lobby-actions{display:flex;justify-content:center;margin-bottom:2rem}.create-game-btn{padding:1rem 2rem;font-size:1.2rem;font-weight:600;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #10b9814d}.create-game-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.create-game-btn:active:not(:disabled){transform:translateY(0)}.create-game-btn:disabled{opacity:.5;cursor:not-allowed}.rejoin-modal{text-align:center;max-width:500px}.rejoin-modal h2{margin:0 0 1rem;color:#1e3a5f}.rejoin-modal p{margin:.5rem 0;color:#4b5563}.rejoin-message{font-size:1.1rem;margin:1.5rem 0 2rem;color:#1f2937}.rejoin-actions{display:flex;gap:1rem;justify-content:center}.rejoin-actions button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b9814d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;box-shadow:0 2px 8px #4b55634d}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4b556366}@media (max-width: 768px){.lobby{padding:1rem}.lobby-header h1{font-size:2rem}.create-game-btn{width:100%;max-width:400px}.rejoin-actions{flex-direction:column}.rejoin-actions button{width:100%}}.tile{position:relative;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.tile:hover{transform:translateY(-8px)}.tile:active{transform:translateY(-4px)}.tile-selected{filter:brightness(1.2);box-shadow:0 0 12px #ffd700cc,0 0 4px #ffd70099}.tile-selected:hover{transform:translateY(-8px)}.tile-disabled{cursor:not-allowed;opacity:.5}.tile-disabled:hover{transform:none}.tile-highlighted{box-shadow:0 0 15px #10b981cc;animation:pulse-highlight 1.5s infinite}@keyframes pulse-highlight{0%,to{box-shadow:0 0 15px #10b981cc}50%{box-shadow:0 0 25px #10b981}}.tile-received{animation:received-glow 3s ease-out forwards;box-shadow:0 0 20px #ffd700cc}@keyframes received-glow{0%{box-shadow:0 0 25px gold,0 0 40px #ffd70099;filter:brightness(1.15)}70%{box-shadow:0 0 20px #ffd700cc,0 0 30px #ffd70066;filter:brightness(1.1)}to{box-shadow:none;filter:brightness(1)}}.tile-image{width:var(--tile-width);height:var(--tile-height);display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.tile-tooltip{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background:#000000f2;color:#fff;padding:.75rem;border-radius:8px;font-size:.875rem;white-space:nowrap;z-index:1000;pointer-events:none;box-shadow:0 4px 12px #0006;border:1px solid rgba(255,255,255,.2);animation:tooltip-fade-in .2s ease;min-width:200px;white-space:normal}.tile-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#000000f2}.tooltip-title{font-weight:600;font-size:1rem;margin-bottom:.25rem;color:#4caf50}.tooltip-info{font-size:.8125rem;line-height:1.4;color:#ffffffe6}@keyframes tooltip-fade-in{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.player-hand{border-radius:clamp(8px,1.5vw,12px);padding:var(--spacing-lg);color:#fff;width:100%;max-width:100%;margin-bottom:8px;transition:background-color .3s ease,box-shadow .3s ease}.player-hand.is-turn{background:#0006;box-shadow:0 4px 16px #0000004d}.tip-banner{background:#3b82f626;border-left:3px solid rgba(59,130,246,.6);padding:var(--spacing-xs) var(--spacing-sm);margin-bottom:var(--spacing-sm);margin-left:220px;margin-right:220px;font-size:var(--font-sm);color:#ffffffe6;text-align:center;animation:fade-in .3s ease;pointer-events:none;-webkit-user-select:none;user-select:none;border-radius:4px}@keyframes fade-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.player-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);padding-left:60px;padding-right:60px}.player-hand.is-turn .player-info{border-bottom:1px solid rgba(255,255,255,.2)}.player-name-score{display:flex;gap:var(--spacing-md);align-items:center}.player-name{font-size:var(--font-lg);font-weight:600}.player-score{font-size:var(--font-sm);opacity:.8}.tile-count{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-sm);opacity:.8}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:var(--font-xs);font-weight:600;animation:pulse-glow 2s infinite}.status-badge.draw{background:#10b981;color:#fff}.status-badge.discard{background:#f59e0b;color:#fff}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.7}}.section-label{font-size:var(--font-sm);opacity:.7;margin-bottom:var(--spacing-sm);display:block}.flowers-section,.exposed-melds-section{margin-bottom:var(--spacing-sm)}.flowers-container{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;padding:var(--spacing-sm);border-radius:8px}.player-hand.is-turn .flowers-container{background:#ffffff0d}.exposed-melds-container{display:flex;gap:var(--spacing-md);flex-wrap:wrap;padding:var(--spacing-sm);border-radius:8px}.player-hand.is-turn .exposed-melds-container{background:#ffffff0d}.meld{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm);background:#0003;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.concealed-hand-section{margin-top:var(--spacing-md)}.tile-rack{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center;align-items:flex-end;padding:var(--spacing-md);border-radius:8px;min-height:auto}.player-hand.is-turn .tile-rack{background:#ffffff0d}.received-tiles-group{display:flex;flex-direction:column;align-items:center;margin-left:var(--spacing-md);padding-left:var(--spacing-md);border-left:2px solid rgba(255,215,0,.3)}.received-label{font-size:10px;color:#ffd700cc;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.received-tiles-container{display:flex;gap:var(--spacing-xs);padding:8px 12px;background:#ffd7001a;border-radius:20px;border:1px solid rgba(255,215,0,.25);animation:received-group-pulse 2s ease-in-out infinite}@keyframes received-group-pulse{0%,to{box-shadow:0 0 10px #ffd70033}50%{box-shadow:0 0 20px #ffd70066}}.received-tiles-container.single-tile{padding:6px 8px;border-radius:12px}@media (max-width: 768px){.player-hand{padding:var(--spacing-md)}.tip-banner{margin-left:120px;margin-right:120px}.player-info{padding-left:40px;padding-right:40px}.player-name-score{gap:var(--spacing-sm)}.tile-rack{padding:var(--spacing-sm);gap:var(--spacing-xs)}}@media (max-width: 480px){.player-hand{padding:var(--spacing-sm)}.tip-banner{margin-left:60px;margin-right:60px;font-size:13px}.player-info{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs);padding-left:20px;padding-right:20px}.player-name-score{flex-direction:column;gap:var(--spacing-xs);align-items:flex-start}.section-label{font-size:var(--font-xs)}}@media (max-width: 400px){.player-hand{padding:var(--spacing-xs);border-radius:6px}.tip-banner{margin-left:30px;margin-right:30px;font-size:12px}.player-info{padding-left:10px;padding-right:10px}.tile-rack,.flowers-container,.exposed-melds-container{padding:var(--spacing-xs)}}.opponent-hand{background:transparent;border-radius:clamp(6px,1.2vw,10px);padding:var(--spacing-sm);color:#fff;transition:all .3s;min-width:120px}.opponent-hand.current-turn{background:#0000004d;box-shadow:0 0 20px #10b98199;animation:pulse-turn 2s infinite}@keyframes pulse-turn{0%,to{box-shadow:0 0 20px #10b98199}50%{box-shadow:0 0 30px #10b981e6}}.opponent-info{margin-bottom:var(--spacing-xs)}.opponent-header{display:flex;align-items:flex-start;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.connection-indicator{width:8px;height:8px;border-radius:50%;background:#6b7280;transition:all .3s;margin-top:3px;flex-shrink:0}.connection-indicator.active{background:#10b981;box-shadow:0 0 8px #10b981}.opponent-name-container{display:flex;flex-direction:column;gap:1px}.opponent-name{font-size:var(--font-sm);font-weight:600;line-height:1.2}.opponent-computer-label{font-size:10px;opacity:.5;font-weight:400;line-height:1}.opponent-score{font-size:var(--font-xs);opacity:.6}.opponent-exposures{margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px solid rgba(255,255,255,.1)}.opponent-flowers{display:flex;gap:2px;flex-wrap:wrap;margin-bottom:var(--spacing-xs)}.opponent-exposed-melds{display:flex;flex-direction:column;gap:var(--spacing-xs)}.opponent-meld{display:flex;gap:2px}.opponent-tile-small .tile-image{width:var(--tile-width-opponent)!important;height:var(--tile-height-opponent)!important}.opponent-no-melds{font-size:11px;opacity:.4;font-style:italic;margin-top:var(--spacing-xs)}.opponent-north{max-width:100%;text-align:center}.opponent-north .opponent-info{display:flex;flex-direction:column;align-items:center}.opponent-north .opponent-header{justify-content:center}.opponent-north .opponent-exposures{display:flex;flex-direction:column;align-items:center}.opponent-north .opponent-flowers{justify-content:center}.opponent-north .opponent-exposed-melds{align-items:center}.opponent-west,.opponent-east{max-width:100%}@media (max-width: 768px){.opponent-hand{padding:var(--spacing-xs);min-width:100px}}@media (max-width: 480px){.opponent-hand{padding:var(--spacing-xs);min-width:80px}.opponent-name{font-size:var(--font-xs)}.opponent-no-melds{font-size:10px}}.discard-pile{background:#0000004d;border-radius:clamp(6px,1.2vw,10px);padding:var(--spacing-md);color:#fff;width:100%;max-width:100%}.discard-pile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid rgba(255,255,255,.2)}.discard-pile-header h3{margin:0;font-size:var(--font-lg);font-weight:600}.discard-count{font-size:var(--font-sm);opacity:.7}.discard-pile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--tile-width-small),1fr));gap:var(--spacing-xs);min-height:auto;padding:var(--spacing-sm);background:#ffffff0d;border-radius:8px}.discard-pile-empty{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;opacity:.5;font-size:var(--font-sm);padding:var(--spacing-sm);min-height:40px}.discard-tile{position:relative;transition:all .3s}.discard-tile.most-recent{animation:discard-drop .4s ease}@keyframes discard-drop{0%{transform:translateY(-50px) rotate(-10deg);opacity:0}to{transform:translateY(0) rotate(0);opacity:1}}.discard-tile.most-recent:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border:2px solid #f59e0b;border-radius:6px;pointer-events:none;animation:pulse-border 2s infinite}@keyframes pulse-border{0%,to{border-color:#f59e0b;opacity:1}50%{border-color:#fbbf24;opacity:.7}}.discard-tile-small .tile-image{width:var(--tile-width-small)!important;height:var(--tile-height-small)!important}.discard-tile-recent .tile-image{width:calc(var(--tile-width-small) * 1.2)!important;height:calc(var(--tile-height-small) * 1.2)!important}.discard-tile-recent{transform:scale(1);z-index:10}@media (max-width: 900px){.discard-pile{padding:var(--spacing-sm)}.discard-pile-header{margin-bottom:var(--spacing-xs);padding-bottom:var(--spacing-xs)}.discard-pile-grid{padding:var(--spacing-xs);min-height:0}.discard-pile-empty{padding:var(--spacing-sm)}}@media (max-width: 768px){.discard-pile{padding:var(--spacing-xs)}.discard-pile-header h3{font-size:var(--font-md)}.discard-pile-grid{padding:4px;gap:2px}.discard-pile-empty{padding:var(--spacing-xs);font-size:var(--font-xs)}}@media (max-width: 480px){.discard-pile{padding:4px}.discard-pile-header{margin-bottom:2px;padding-bottom:2px}.discard-pile-header h3{font-size:var(--font-sm)}.discard-count{font-size:var(--font-xs)}.discard-pile-empty{padding:4px}}@media (max-width: 400px){.discard-pile-empty{padding:2px;font-size:10px}}.tile-wall{background:#0000004d;border-radius:8px;padding:6px 12px;color:#fff;display:flex;flex-direction:row;align-items:center;gap:8px;transition:all .3s}.tile-wall-header h3{margin:0;font-size:var(--font-sm);font-weight:600;white-space:nowrap}.tile-wall-stack{display:flex;align-items:center}.tile-back-stack{position:relative;width:24px;height:32px;flex-shrink:0}.tile-back-stack .tile-back{position:absolute;width:20px;height:28px;background:linear-gradient(135deg,#1e3a8a,#3b82f6);border:1px solid #1e3a8a;border-radius:3px;box-shadow:0 1px 2px #0000004d}.tile-back-stack .tile-back:nth-child(1){top:0;left:0;z-index:3}.tile-back-stack .tile-back:nth-child(2){top:2px;left:2px;z-index:2;opacity:.8}.tile-back-stack .tile-back:nth-child(3){top:4px;left:4px;z-index:1;opacity:.6}.tile-wall-count{display:flex;flex-direction:row;align-items:baseline;gap:4px}.count-number{font-size:1.25rem;font-weight:700;line-height:1}.count-label{font-size:var(--font-xs);opacity:.7;white-space:nowrap}.tile-wall-progress{width:60px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;flex-shrink:0}.progress-bar{height:100%;transition:width .5s ease,background-color .3s;border-radius:3px}.tile-wall-good .count-number{color:#10b981}.tile-wall-good .progress-bar{background:linear-gradient(90deg,#10b981,#34d399)}.tile-wall-warning .count-number{color:#f59e0b}.tile-wall-warning .progress-bar{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.tile-wall-danger .count-number{color:#ef4444;animation:pulse-danger 1s infinite}.tile-wall-danger .progress-bar{background:linear-gradient(90deg,#ef4444,#f87171)}@keyframes pulse-danger{0%,to{opacity:1}50%{opacity:.7}}.btn-view-card-small{background:#6366f1cc;border:none;color:#fff;font-size:var(--font-xs);font-weight:600;padding:4px 10px;border-radius:4px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-view-card-small:hover{background:#6366f1;transform:scale(1.05)}@media (max-width: 900px){.tile-wall{padding:4px 8px;gap:6px}.tile-wall-header h3{font-size:var(--font-xs)}.tile-back-stack{width:20px;height:26px}.tile-back-stack .tile-back{width:16px;height:22px}.count-number{font-size:1rem}.tile-wall-progress{width:50px;height:5px}.btn-view-card-small{font-size:10px;padding:3px 8px}}@media (max-width: 768px){.tile-wall{padding:3px 6px;gap:4px}.tile-wall-header h3{font-size:10px}.tile-back-stack{width:16px;height:22px}.tile-back-stack .tile-back{width:14px;height:18px}.count-number{font-size:.9rem}.count-label{font-size:9px}.tile-wall-progress{width:40px;height:4px}.btn-view-card-small{font-size:9px;padding:2px 6px}}@media (max-width: 480px){.tile-wall{padding:2px 4px;gap:3px}.tile-wall-header h3{font-size:9px}.tile-back-stack{display:none}.count-number{font-size:.85rem}.count-label{display:none}.tile-wall-progress{width:30px;height:3px}.btn-view-card-small{font-size:8px;padding:2px 4px}}.game-controls{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background:#0000004d;border-radius:clamp(6px,1.2vw,10px);min-width:auto;max-width:100%}.btn-control{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:clamp(6px,1vw,8px);font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all .3s;color:#fff;box-shadow:0 2px 8px #0000004d}.btn-control:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0006}.btn-control:active:not(:disabled){transform:translateY(0)}.btn-control:disabled{opacity:.5;cursor:not-allowed}.btn-icon{font-size:var(--font-lg)}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.btn-draw{background:linear-gradient(135deg,#10b981,#059669);font-size:var(--font-lg);padding:var(--spacing-md) var(--spacing-lg)}.btn-draw:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857)}.btn-claim{background:linear-gradient(135deg,#8b5cf6,#7c3aed);font-size:var(--font-lg);padding:var(--spacing-md) var(--spacing-lg)}.btn-claim:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9)}.btn-charleston{background:linear-gradient(135deg,#d4a373,#b8956e);font-size:var(--font-lg);padding:var(--spacing-md) var(--spacing-lg)}.btn-charleston:hover:not(:disabled){background:linear-gradient(135deg,#b8956e,#9a7b5a)}.btn-discard{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-discard:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)}.btn-expose{background:linear-gradient(135deg,#3b82f6,#2563eb);font-size:var(--font-sm)}.btn-expose:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8)}.btn-view-card{background:linear-gradient(135deg,#6366f1,#4f46e5);font-size:var(--font-sm)}.btn-view-card:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#4338ca)}.btn-win{background:linear-gradient(135deg,#ef4444,#dc2626);font-size:var(--font-xl);padding:var(--spacing-md) var(--spacing-lg);animation:pulse-win 2s infinite}.btn-win:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);animation:none}@keyframes pulse-win{0%,to{box-shadow:0 0 10px #ef444480}50%{box-shadow:0 0 20px #ef4444cc}}.btn-win-ready{background:linear-gradient(135deg,#22c55e,#16a34a)!important;animation:pulse-win-ready 1.5s infinite!important}.btn-win-ready:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d)!important}@keyframes pulse-win-ready{0%,to{box-shadow:0 0 20px #22c55ecc,0 0 40px #22c55e66;transform:scale(1)}50%{box-shadow:0 0 30px #22c55e,0 0 60px #22c55e99;transform:scale(1.05)}}.controls-waiting{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-md);color:#fff9;font-size:var(--font-sm);text-align:center}.waiting-icon{font-size:var(--font-xl);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@media (max-width: 768px){.game-controls{gap:var(--spacing-xs);padding:var(--spacing-sm)}.btn-draw,.btn-claim,.btn-win{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-md)}}@media (max-width: 480px){.game-controls{padding:var(--spacing-xs);gap:4px}.btn-control{padding:var(--spacing-xs) var(--spacing-sm)}.btn-draw,.btn-claim,.btn-win{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-sm)}}@media (max-width: 400px){.btn-control{font-size:var(--font-sm)}.btn-icon{font-size:var(--font-md)}.waiting-icon{font-size:var(--font-lg)}}.charleston-staging{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 14px;background:#0006;border:3px solid #d4a373;border-radius:12px;box-shadow:0 0 20px #d4a3734d;transition:border-color .2s,box-shadow .2s}.charleston-staging.drop-active{border-color:#22c55e;box-shadow:0 0 30px #22c55e80}.charleston-staging.drop-active .empty-slot{border-color:#22c55e;background:#22c55e33}.staging-header{display:flex;flex-direction:column;align-items:center;gap:4px}.staging-title{font-size:var(--font-lg);font-weight:700;color:#d4a373;text-transform:uppercase;letter-spacing:1px}.staging-phase{font-size:var(--font-md);color:#fffc;background:#d4a37333;padding:4px 12px;border-radius:4px}.staging-direction{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);border-radius:20px;font-weight:600}.direction-arrow{font-size:var(--font-xl)}.direction-label{font-size:var(--font-sm);text-transform:uppercase;letter-spacing:1px}.direction-right{background:linear-gradient(135deg,#fb923c4d,#f9731633);color:#fb923c}.direction-across{background:linear-gradient(135deg,#60a5fa4d,#3b82f633);color:#60a5fa}.direction-left{background:linear-gradient(135deg,#a78bfa4d,#8b5cf633);color:#a78bfa}.staging-slots{display:flex;gap:8px;padding:8px 12px;background:#0000004d;border-radius:8px;transition:transform .4s ease-out,opacity .4s ease-out}.staging-slots.departing-right{animation:fly-right .4s ease-in forwards}.staging-slots.departing-left{animation:fly-left .4s ease-in forwards}.staging-slots.departing-across{animation:fly-across .4s ease-in forwards}@keyframes fly-right{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(100px) scale(.8);opacity:0}}@keyframes fly-left{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(-100px) scale(.8);opacity:0}}@keyframes fly-across{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(-80px) scale(.8);opacity:0}}.staging-slot{width:calc(var(--tile-width) + 4px);height:calc(var(--tile-height) + 4px);display:flex;align-items:center;justify-content:center}.empty-slot{width:var(--tile-width);height:var(--tile-height);border:2px dashed rgba(212,163,115,.5);border-radius:6px;display:flex;align-items:center;justify-content:center;background:#0003}.slot-number{font-size:var(--font-xl);color:#d4a37366;font-weight:700}.staged-tile{position:relative;cursor:pointer;transition:transform .2s}.staged-tile:hover{transform:scale(1.05)}.remove-badge{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#ef4444;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 2px 4px #0000004d;opacity:0;transition:opacity .2s}.staged-tile:hover .remove-badge{opacity:1}.staging-instructions{font-size:var(--font-sm);color:#fff9;text-align:center}.btn-staging-pass{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:8px 16px;border:none;border-radius:8px;font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all .3s;color:#fff;background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 8px #0000004d;min-width:120px}.btn-staging-pass:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0006}.btn-staging-pass:disabled{opacity:.5;cursor:not-allowed}.btn-staging-pass.ready{background:linear-gradient(135deg,#d4a373,#b8956e);animation:pulse-ready 2s infinite}.btn-staging-pass.ready:hover:not(:disabled){background:linear-gradient(135deg,#b8956e,#9a7b5a);animation:none}@keyframes pulse-ready{0%,to{box-shadow:0 0 10px #d4a37380}50%{box-shadow:0 0 20px #d4a373cc}}.btn-staging-pass .btn-icon{font-size:var(--font-lg)}.btn-staging-pass .btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 1024px){.charleston-staging{padding:var(--spacing-xs);gap:var(--spacing-xs)}.staging-header{gap:2px}.staging-slots{gap:var(--spacing-xs);padding:var(--spacing-xs)}.staging-slot{width:calc(var(--tile-width) * .9);height:calc(var(--tile-height) * .9)}.staging-title{font-size:var(--font-md)}.staging-phase{font-size:var(--font-sm);padding:2px 8px}.staging-direction{padding:4px 10px}}@media (max-width: 900px){.charleston-staging{padding:6px;gap:4px;border-width:2px}.staging-header{gap:2px}.staging-slots{gap:2px;padding:4px}.staging-slot{width:calc(var(--tile-width) * .75);height:calc(var(--tile-height) * .75)}.empty-slot{width:calc(var(--tile-width) * .7);height:calc(var(--tile-height) * .7)}.slot-number{font-size:var(--font-md)}.staging-title{font-size:var(--font-sm)}.staging-phase{font-size:var(--font-xs);padding:2px 6px}.staging-direction{padding:2px 8px}.direction-arrow{font-size:var(--font-md)}.direction-label,.staging-instructions{font-size:var(--font-xs)}.btn-staging-pass{padding:4px 10px;font-size:var(--font-sm);min-width:100px}}@media (max-width: 768px){.charleston-staging{padding:4px;gap:2px;border-width:2px}.staging-slots{gap:2px;padding:2px}.staging-slot{width:calc(var(--tile-width) * .65);height:calc(var(--tile-height) * .65)}.empty-slot{width:calc(var(--tile-width) * .6);height:calc(var(--tile-height) * .6)}.slot-number{font-size:var(--font-sm)}.staging-title{font-size:var(--font-xs)}.staging-phase{font-size:10px;padding:2px 4px}.staging-direction{padding:2px 6px}.direction-arrow{font-size:var(--font-sm)}.direction-label,.staging-instructions{font-size:10px}.btn-staging-pass{padding:4px 8px;font-size:var(--font-xs);min-width:80px}}@media (max-width: 480px){.charleston-staging{padding:2px;gap:2px}.staging-header{gap:1px}.staging-slot{width:calc(var(--tile-width) * .5);height:calc(var(--tile-height) * .5)}.empty-slot{width:calc(var(--tile-width) * .45);height:calc(var(--tile-height) * .45)}.slot-number{font-size:var(--font-xs)}.staging-title{font-size:10px}.staging-direction{padding:2px 4px}.direction-arrow{font-size:var(--font-xs)}.direction-label{font-size:9px}.btn-staging-pass{padding:2px 6px;font-size:10px;min-width:60px}}.discard-staging{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#000000d9;border:3px solid #ef4444;border-radius:12px;box-shadow:0 0 20px #ef44444d;position:relative;z-index:500;pointer-events:auto;transition:border-color .2s,box-shadow .2s,transform .2s}.discard-staging.drop-active{border-color:#22c55e;box-shadow:0 0 30px #22c55e80;transform:scale(1.02)}.discard-staging.drop-active .empty-discard-slot{border-color:#22c55e;background:#22c55e33}.discard-staging-header{display:flex;flex-direction:column;align-items:center;gap:4px}.discard-staging-title{font-size:var(--font-lg);font-weight:700;color:#ef4444;text-transform:uppercase;letter-spacing:1px}.discard-staging-slot{display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:#0000004d;border-radius:8px;transition:transform .3s ease-out,opacity .3s ease-out}.discard-staging-slot.departing{animation:fly-to-discard .3s ease-in forwards}@keyframes fly-to-discard{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(50px) scale(.8);opacity:0}}.empty-discard-slot{width:var(--tile-width);height:var(--tile-height);border:2px dashed rgba(239,68,68,.5);border-radius:6px;display:flex;align-items:center;justify-content:center;background:#0003}.slot-placeholder{font-size:var(--font-xl);color:#ef444466;font-weight:700}.staged-discard-tile{position:relative;cursor:pointer;transition:transform .2s}.staged-discard-tile:hover{transform:scale(1.05)}.discard-staging .remove-badge{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:#6b7280;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:0 2px 4px #0000004d;opacity:0;transition:opacity .2s}.staged-discard-tile:hover .remove-badge{opacity:1}.discard-staging-instructions{font-size:var(--font-sm);color:#fff9;text-align:center}.btn-discard-confirm{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:8px;font-size:var(--font-md);font-weight:600;cursor:pointer;transition:all .3s;color:#fff;background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 8px #0000004d;min-width:120px}.btn-discard-confirm:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0006}.btn-discard-confirm:disabled{opacity:.5;cursor:not-allowed}.btn-discard-confirm.ready{background:linear-gradient(135deg,#ef4444,#dc2626);animation:pulse-discard-ready 2s infinite}.btn-discard-confirm.ready:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);animation:none}@keyframes pulse-discard-ready{0%,to{box-shadow:0 0 10px #ef444480}50%{box-shadow:0 0 20px #ef4444cc}}.btn-discard-confirm .btn-icon{font-size:var(--font-lg)}.btn-discard-confirm .btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 900px){.discard-staging{padding:var(--spacing-xs);gap:var(--spacing-xs)}.discard-staging-slot{padding:var(--spacing-xs)}.discard-staging-title{font-size:var(--font-md)}.empty-discard-slot{width:calc(var(--tile-width) * .85);height:calc(var(--tile-height) * .85)}}@media (max-width: 768px){.discard-staging{padding:6px;gap:4px;border-width:2px}.discard-staging-slot{padding:4px}.discard-staging-title{font-size:var(--font-sm)}.discard-staging-instructions{font-size:var(--font-xs)}.empty-discard-slot{width:calc(var(--tile-width) * .75);height:calc(var(--tile-height) * .75)}.btn-discard-confirm{padding:4px 10px;font-size:var(--font-sm);min-width:90px}}@media (max-width: 480px){.discard-staging{padding:4px;gap:2px}.discard-staging-slot{padding:2px}.discard-staging-title{font-size:var(--font-xs)}.empty-discard-slot{width:calc(var(--tile-width) * .6);height:calc(var(--tile-height) * .6)}.slot-placeholder{font-size:var(--font-md)}.btn-discard-confirm{padding:2px 6px;font-size:var(--font-xs);min-width:70px}}.claim-window-timer{position:fixed;top:calc(var(--header-height) + var(--spacing-sm));left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:var(--spacing-sm);background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:var(--spacing-sm) var(--spacing-lg);border-radius:clamp(8px,1.5vw,12px);box-shadow:0 8px 24px #8b5cf666;font-weight:600;font-size:var(--font-lg);animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.timer-icon{font-size:var(--font-xl);animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.timer-text{display:flex;align-items:center;gap:var(--spacing-xs)}.timer-label{opacity:.9}.timer-seconds{font-size:var(--font-xl);font-weight:700;min-width:2.5rem;text-align:center;background:#fff3;padding:var(--spacing-xs) var(--spacing-sm);border-radius:6px}.timer-seconds.urgent{animation:urgentPulse .5s ease-in-out infinite;background:#ef44444d;color:#fef2f2}@keyframes urgentPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@media (max-width: 480px){.claim-window-timer{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-md);gap:var(--spacing-xs)}.timer-icon{font-size:var(--font-lg)}.timer-seconds{font-size:var(--font-lg);min-width:2rem}}@media (max-width: 400px){.claim-window-timer{top:var(--spacing-xs)}.timer-label{display:none}}.game-results-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fade-in .3s ease}.game-results-modal{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-radius:16px;padding:var(--spacing-xl);max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:slide-up .4s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.results-header{text-align:center;padding:var(--spacing-xl) var(--spacing-lg);background:#ffffff1a;border-radius:12px;margin-bottom:var(--spacing-lg)}.results-header.winner{background:linear-gradient(135deg,#10b98133,#05966933);border:2px solid rgba(16,185,129,.4)}.results-header.not-winner{background:#ffffff0d}.trophy-icon{font-size:4rem;margin-bottom:var(--spacing-md);animation:bounce .6s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.results-header h1{margin:0 0 var(--spacing-md) 0;font-size:var(--font-2xl);color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.winning-hand{display:flex;flex-direction:column;gap:var(--spacing-xs);margin:var(--spacing-md) 0}.hand-label{font-size:var(--font-sm);color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.hand-pattern{font-size:var(--font-lg);font-weight:600;color:#fbbf24;text-shadow:0 2px 8px rgba(251,191,36,.3)}.winning-points{font-size:var(--font-xl);font-weight:700;color:#10b981;margin-top:var(--spacing-sm)}.game-over-reason{font-size:var(--font-base);color:#ffffffb3;margin:var(--spacing-md) 0 0 0}.scores-section{margin-bottom:var(--spacing-lg)}.scores-section h2{margin:0 0 var(--spacing-md) 0;font-size:var(--font-xl);color:#fff;text-align:center}.scores-table{background:#0000004d;border-radius:8px;overflow:hidden}.scores-header,.score-row{display:grid;grid-template-columns:60px 1fr 80px;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);align-items:center}.scores-header{background:#0006;font-weight:600;font-size:var(--font-sm);color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.score-row{background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);transition:background .2s;color:#fff}.score-row:hover{background:#ffffff1a}.score-row:last-child{border-bottom:none}.score-row.current-player{background:#3b82f633;font-weight:600;border:1px solid rgba(59,130,246,.4)}.score-row.first-place{background:linear-gradient(90deg,#fbbf2426,#f59e0b26)}.score-row.first-place.current-player{background:linear-gradient(90deg,#fbbf2440,#f59e0b40);border-color:#fbbf2480}.rank-col{text-align:center;font-size:var(--font-lg)}.player-col{font-size:var(--font-base)}.score-col{text-align:right;font-size:var(--font-lg);font-weight:600;color:#10b981}.stats-section{margin-bottom:var(--spacing-lg)}.stats-section h3{margin:0 0 var(--spacing-md) 0;font-size:var(--font-lg);color:#fff;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.stat-item{background:#0000004d;padding:var(--spacing-md);border-radius:8px;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.stat-label{font-size:var(--font-sm);color:#fff9;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:var(--font-xl);font-weight:700;color:#fff}.results-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl)}.results-actions button{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:none;border-radius:8px;font-size:var(--font-base);font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#10b981;color:#fff}.btn-primary:hover{background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:#fff3;transform:translateY(-2px)}@media (max-width: 768px){.game-results-modal{padding:var(--spacing-lg)}.results-header h1{font-size:var(--font-xl)}.trophy-icon{font-size:3rem}.scores-header,.score-row{grid-template-columns:50px 1fr 70px;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm)}.stats-grid{grid-template-columns:1fr}}@media (max-width: 480px){.game-results-modal{padding:var(--spacing-md);width:95%}.results-header{padding:var(--spacing-md)}.results-header h1{font-size:var(--font-lg)}.trophy-icon{font-size:2.5rem}.results-actions{flex-direction:column}}.signup-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2100;animation:fade-in .3s ease}.signup-prompt-modal{background:linear-gradient(135deg,#1e3a8a,#3b82f6);border-radius:16px;padding:var(--spacing-xl);max-width:420px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;animation:slide-up .4s ease}.signup-header{text-align:center;margin-bottom:var(--spacing-lg)}.mahjong-icon{font-size:4rem;margin-bottom:var(--spacing-md);animation:bounce .6s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.signup-header h1{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-xl);color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.3)}.signup-subtitle{margin:0;font-size:var(--font-base);color:#fffc;line-height:1.5}.signup-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:var(--font-sm);color:#fffc;font-weight:500}.form-group input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;color:#fff;font-size:var(--font-base);transition:all .2s}.form-group input::placeholder{color:#fff6}.form-group input:focus{outline:none;border-color:#ffffff80;background:#ffffff26}.signup-error{padding:var(--spacing-sm) var(--spacing-md);background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:8px;color:#fca5a5;font-size:var(--font-sm);text-align:center}.signup-form .btn-primary{padding:var(--spacing-md) var(--spacing-lg);background:#10b981;border:none;border-radius:8px;color:#fff;font-size:var(--font-base);font-weight:600;cursor:pointer;transition:all .2s;margin-top:var(--spacing-sm)}.signup-form .btn-primary:hover:not(:disabled){background:#059669;transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.signup-form .btn-primary:disabled{opacity:.7;cursor:not-allowed}.signup-divider{display:flex;align-items:center;gap:var(--spacing-md);margin:var(--spacing-lg) 0}.signup-divider:before,.signup-divider:after{content:"";flex:1;height:1px;background:#fff3}.signup-divider span{color:#ffffff80;font-size:var(--font-sm);text-transform:uppercase;letter-spacing:1px}.btn-google{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:#fff;border:none;border-radius:8px;color:#374151;font-size:var(--font-base);font-weight:500;cursor:pointer;transition:all .2s}.btn-google:hover:not(:disabled){background:#f9fafb;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-google:disabled{opacity:.7;cursor:not-allowed}.google-icon{width:20px;height:20px}.signup-switch{text-align:center;margin-top:var(--spacing-lg);color:#ffffffb3;font-size:var(--font-sm)}.link-button{background:none;border:none;color:#60a5fa;font-size:var(--font-sm);cursor:pointer;text-decoration:underline;padding:0;font-weight:500}.link-button:hover{color:#93c5fd}.btn-skip{display:block;width:100%;margin-top:var(--spacing-md);padding:var(--spacing-sm);background:none;border:none;color:#ffffff80;font-size:var(--font-sm);cursor:pointer;transition:color .2s}.btn-skip:hover{color:#fffc}@media (max-width: 480px){.signup-prompt-modal{padding:var(--spacing-lg);width:95%}.mahjong-icon{font-size:3rem}.signup-header h1{font-size:var(--font-lg)}}.nmjl-card-viewer{max-width:900px;max-height:90vh;overflow-y:auto}.card-loading,.card-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-md);color:#fff}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.card-info{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:#ffffff0d;border-radius:8px;border-left:4px solid #3b82f6}.card-version{color:#ffffffb3;font-size:var(--font-sm);margin:0 0 var(--spacing-xs) 0}.card-notice{color:#fff;font-size:var(--font-md);margin:0;font-weight:500}.patterns-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.pattern-card{background:#ffffff14;border-radius:12px;padding:var(--spacing-md);border:1px solid rgba(255,255,255,.15);transition:all .2s ease}.pattern-card:hover{background:#ffffff1f;border-color:#ffffff40;transform:translate(4px)}.pattern-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.pattern-name{color:#fff;font-size:var(--font-lg);font-weight:600;margin:0}.pattern-points{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1a1a;padding:var(--spacing-xs) var(--spacing-sm);border-radius:20px;font-size:var(--font-sm);font-weight:700;white-space:nowrap}.pattern-description{color:#fffc;font-size:var(--font-sm);line-height:1.5;margin:0 0 var(--spacing-sm) 0}.pattern-example{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-sm);background:#0000004d;border-radius:6px;margin-top:var(--spacing-sm)}.example-label{color:#fff9;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.5px}.example-tiles{color:#4ade80;font-family:Courier New,monospace;font-size:var(--font-md);font-weight:600;letter-spacing:1px}.pattern-requirement{margin-top:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:#3b82f633;border-left:3px solid #3b82f6;border-radius:4px;color:#93c5fd;font-size:var(--font-sm)}.stub-notice{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:#fbbf2426;border:1px solid rgba(251,191,36,.3);border-radius:8px}.stub-notice p{color:#fbbf24;font-size:var(--font-sm);margin:0;line-height:1.5}.stub-notice strong{color:#fcd34d}@media (max-width: 768px){.nmjl-card-viewer{max-width:95vw;max-height:95vh}.pattern-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.pattern-name{font-size:var(--font-md)}.pattern-points{align-self:flex-start}}@media (max-width: 480px){.pattern-card{padding:var(--spacing-sm)}.example-tiles{font-size:var(--font-sm);word-break:break-word}}:root{--felt-green: #1a5f3f;--felt-dark: #0f3d28;--wood-brown: #5c3d2e;--wood-light: #8b5a3c;--player-turn: #10b981}.game-table{position:relative;height:100vh;overflow:auto;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;flex-direction:column}.game-header{background:#0006;padding:var(--spacing-md) var(--spacing-xl);display:flex;justify-content:space-between;align-items:center;color:#fff;box-shadow:0 2px 10px #0000004d;height:var(--header-height);flex-shrink:0}.game-info{display:flex;align-items:center;gap:1.5rem}.game-info h1{font-size:var(--font-xl);margin:0}.game-id{font-size:var(--font-sm);opacity:.7;font-family:monospace}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.settings-button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:.95rem;padding:.5rem 1rem;border-radius:20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.4rem;white-space:nowrap}.settings-button:hover{background:#ffffff40;border-color:#ffffff80;transform:scale(1.05);box-shadow:0 0 10px #ffffff4d}.btn-leave{background-color:#dc2626;color:#fff;padding:.5rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;transition:all .3s}.btn-leave:hover{background-color:#b91c1c;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.tip-header-banner{position:absolute;top:var(--header-height);left:0;right:0;background:linear-gradient(90deg,#3b82f640,#3b82f666,#3b82f640);border-bottom:1px solid rgba(59,130,246,.4);padding:8px 20px;font-size:1.1rem;font-weight:500;color:#fffffff2;text-align:center;animation:tip-slide-in .3s ease;z-index:100;pointer-events:none}@keyframes tip-slide-in{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.toast{position:fixed;top:100px;right:20px;background:#000000e6;color:#fff;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #00000080;z-index:1000;animation:slide-in .3s ease}@keyframes slide-in{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.table-container{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);min-height:0;overflow:visible}.table-felt{width:100%;height:100%;min-height:700px;max-width:1400px;background:radial-gradient(ellipse at center,var(--felt-green) 0%,var(--felt-dark) 100%);border:clamp(10px,2vw,20px) solid var(--wood-brown);border-radius:clamp(10px,2vw,20px);box-shadow:0 10px 40px #00000080,inset 0 0 50px #0000004d;position:relative;display:grid;grid-template-areas:"north north north" "west center east" "south south south";grid-template-rows:minmax(80px,auto) 1fr minmax(140px,auto);grid-template-columns:minmax(150px,250px) 1fr minmax(150px,250px);gap:var(--spacing-md);padding:var(--spacing-lg)}.table-felt:before{content:"";position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:20px;background:repeating-linear-gradient(90deg,var(--wood-brown) 0px,var(--wood-light) 2px,var(--wood-brown) 4px);z-index:-1}.opponent-north{grid-area:north;display:flex;justify-content:center;align-items:flex-start}.opponent-west{grid-area:west;display:flex;justify-content:flex-start;align-items:center}.center-area{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:var(--spacing-xs);min-height:0;overflow:visible;padding:var(--spacing-xs) 0}.opponent-east{grid-area:east;display:flex;justify-content:flex-end;align-items:center}.player-south{grid-area:south;display:flex;justify-content:center;align-items:flex-end}.game-table-loading,.game-table-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a8a,#3b82f6);color:#fff;gap:1rem}.loading-spinner{width:50px;height:50px;border:5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.game-table-error button{background:#3b82f6;color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s}.game-table-error button:hover{background:#2563eb;transform:translateY(-2px)}@media (max-width: 1024px){.table-container{padding:var(--spacing-md)}.table-felt{grid-template-columns:minmax(120px,200px) 1fr minmax(120px,200px);grid-template-rows:minmax(70px,auto) 1fr minmax(120px,auto);gap:var(--spacing-sm)}}@media (max-width: 900px){.table-container{padding:var(--spacing-sm)}.table-felt{grid-template-columns:minmax(90px,140px) 1fr minmax(90px,140px);grid-template-rows:minmax(65px,auto) 1fr minmax(115px,auto);gap:var(--spacing-xs);padding:var(--spacing-md)}.center-area{gap:2px;padding:2px 0}}@media (max-width: 768px){.table-container{padding:var(--spacing-xs)}.table-felt{grid-template-columns:minmax(80px,120px) 1fr minmax(80px,120px);grid-template-rows:minmax(60px,auto) 1fr minmax(100px,auto);padding:var(--spacing-sm);gap:var(--spacing-xs)}.game-header{padding:var(--spacing-sm) var(--spacing-md)}.game-info{gap:var(--spacing-md)}.game-id{display:none}.center-area{gap:2px;padding:2px 0}}@media (max-width: 480px){.table-container{padding:var(--spacing-xs)}.table-felt{grid-template-columns:minmax(80px,120px) 1fr minmax(80px,120px);grid-template-rows:minmax(30px,auto) 1fr minmax(100px,auto);padding:var(--spacing-sm);gap:var(--spacing-xs);border-width:8px}.game-header{padding:var(--spacing-xs) var(--spacing-sm)}.game-info{gap:var(--spacing-sm)}.game-info h1{font-size:var(--font-lg)}.center-area{padding:0}}@media (max-width: 400px){.table-felt{grid-template-columns:70px 1fr 70px;grid-template-rows:minmax(25px,auto) 1fr minmax(90px,auto);border-width:6px}}.reconnect-modal{text-align:center;max-width:500px}.reconnect-modal h2{margin:0 0 1rem;color:#1e3a5f}.reconnect-modal p{margin:.5rem 0;color:#4b5563}.reconnect-message{font-size:1.1rem;margin:1.5rem 0 2rem;color:#1f2937}.reconnect-actions{display:flex;gap:1rem;justify-content:center}.reconnect-actions button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}@media (max-width: 768px){.reconnect-actions{flex-direction:column}.reconnect-actions button{width:100%}}.game{min-height:100vh;background:linear-gradient(135deg,#1e3a8a,#3b82f6);display:flex;flex-direction:column}.game-header{background:#0000004d;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;color:#fff}.game-header h1{font-size:1.8rem;margin:0}.btn-leave{background-color:#dc2626;color:#fff;padding:.5rem 1.5rem;border:none;border-radius:6px;cursor:pointer;transition:all .3s}.btn-leave:hover{background-color:#b91c1c}.game-board{flex:1;display:flex;flex-direction:column;padding:2rem}.center-area{flex:1;display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.wall{background:#ffffff1a;border:2px dashed rgba(255,255,255,.3);border-radius:12px;padding:3rem;min-width:500px;min-height:300px;display:flex;align-items:center;justify-content:center}.placeholder{color:#ffffff80;font-size:1.2rem}.player-hand{background:#0000004d;border-radius:12px;padding:1.5rem;color:#fff}.player-hand h3{margin:0 0 1rem;font-size:1.2rem}.tile-rack{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center;padding:1rem;background:#ffffff0d;border-radius:8px}@media (max-width: 768px){.game-header h1{font-size:1.3rem}.wall{min-width:300px;min-height:200px}.tile-rack{gap:.3rem}}.app{min-height:100vh;display:flex;flex-direction:column}:root{font-family:Inter,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;--tile-width: clamp(28px, 4.5vw, 60px);--tile-height: calc(var(--tile-width) * 1.33);--tile-width-small: clamp(22px, 3.5vw, 45px);--tile-height-small: calc(var(--tile-width-small) * 1.33);--tile-width-opponent: clamp(20px, 3vw, 40px);--tile-height-opponent: calc(var(--tile-width-opponent) * 1.33);--spacing-xs: clamp(.1rem, .3vw, .25rem);--spacing-sm: clamp(.25rem, .5vw, .5rem);--spacing-md: clamp(.5rem, 1vw, 1rem);--spacing-lg: clamp(.75rem, 1.5vw, 1.5rem);--spacing-xl: clamp(1rem, 2vw, 2rem);--font-xs: clamp(.7rem, 1.3vw, .85rem);--font-sm: clamp(.75rem, 1.5vw, .9rem);--font-md: clamp(.85rem, 1.7vw, 1rem);--font-lg: clamp(.95rem, 1.9vw, 1.1rem);--font-xl: clamp(1.1rem, 2.2vw, 1.5rem);--header-height: clamp(50px, 8vh, 70px)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}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}button{background-color:#f9f9f9}}
