*{margin:0;padding:0;box-sizing:border-box}:root{--red: #e74c3c;--blue: #3498db;--green: #2ecc71;--yellow: #f1c40f;--black: #2c3e50;--bg: #1a1a2e;--surface: #16213e;--text: #eee;--text-muted: #999;--accent: #e94560}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden;-webkit-tap-highlight-color:transparent}.app{min-height:100dvh;display:flex;flex-direction:column}.screen{flex:1;display:flex;flex-direction:column;padding:1rem;max-width:480px;margin:0 auto;width:100%}.error-banner{background:var(--red);color:#fff;padding:.75rem 1rem;text-align:center;cursor:pointer;font-size:.9rem}.offline-banner{background:#e67e22;color:#fff;padding:.5rem 1rem;text-align:center;font-size:.85rem;font-weight:600;animation:pulse-bg 1.5s ease-in-out infinite alternate}@keyframes pulse-bg{0%{opacity:1}to{opacity:.7}}.uno-hand.sending{opacity:.6;pointer-events:none}.countdown-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:var(--bg)}.countdown-game-name{font-size:1.8rem;font-weight:900;color:var(--accent);letter-spacing:.1em}.countdown-number{font-size:8rem;font-weight:900;color:var(--text);animation:countPop .4s ease-out}.countdown-number.go{color:var(--green);font-size:5rem}@keyframes countPop{0%{transform:scale(2);opacity:0}60%{transform:scale(.95);opacity:1}to{transform:scale(1)}}.back-btn{align-self:flex-start;background:none;border:none;color:var(--text-muted);font-size:1rem;padding:.5rem 0;cursor:pointer;transition:color .2s}.back-btn:active{color:var(--accent)}.uno-top-bar{display:flex;justify-content:flex-start}.title{text-align:center;font-size:2rem;margin:2rem 0 1.5rem;color:var(--accent)}.mode-toggle{display:flex;gap:0;margin-bottom:1.5rem;border-radius:8px;overflow:hidden}.toggle-btn{flex:1;padding:.75rem;border:none;background:var(--surface);color:var(--text-muted);font-size:1rem;cursor:pointer}.toggle-btn.active{background:var(--accent);color:#fff}.join-form{display:flex;flex-direction:column;gap:1rem}.input{padding:1rem;border:2px solid #333;border-radius:8px;background:var(--surface);color:var(--text);font-size:1.1rem;outline:none;transition:border-color .2s}.input:focus{border-color:var(--accent)}.code-input{text-align:center;letter-spacing:.5em;font-size:1.5rem;text-transform:uppercase}.btn{padding:1rem;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid #444}.lobby-header{text-align:center;margin-bottom:1.5rem}.lobby-code{font-size:3rem;font-weight:800;letter-spacing:.3em;color:var(--accent);margin-top:.5rem}.player-list{margin-bottom:1.5rem}.player-list h3{margin-bottom:.75rem;color:var(--text-muted)}.player-item{padding:.75rem 1rem;background:var(--surface);border-radius:6px;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center}.player-item.me{border-left:3px solid var(--accent)}.player-item.disconnected{opacity:.5}.status-badge{font-size:.75rem;color:var(--red)}.game-selection{margin-bottom:1.5rem}.game-selection h3{margin-bottom:.75rem;color:var(--text-muted)}.game-cards{display:flex;flex-direction:column;gap:.75rem}.game-card{width:100%;padding:1rem;background:var(--surface);border:2px solid #333;border-radius:12px;color:var(--text);text-align:left;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:border-color .2s,transform .1s}.game-card:active{transform:scale(.98)}.game-card:disabled{opacity:.4;cursor:not-allowed}.game-card-kes{border-color:var(--red)}.game-card-fourbe{border-color:#333}.game-card-icon{width:50px;height:50px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.game-icon-kes{font-size:1.3rem;font-weight:900;color:var(--red);text-shadow:0 0 8px rgba(231,76,60,.5)}.game-icon-fourbe{font-size:2rem}.game-card-info{display:flex;flex-direction:column;gap:.2rem}.game-title{font-size:1.1rem}.game-title-kes{color:var(--red)}.game-title-fourbe{color:#ccc}.game-desc{font-size:.85rem;color:var(--text-muted)}.game-players{font-size:.75rem;color:var(--accent)}.music-player{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--surface);border-bottom:1px solid #333}.music-btn{background:none;border:none;color:var(--text);font-size:1rem;cursor:pointer;padding:.25rem}.music-btn-play{font-size:1.1rem}.music-name{font-size:.75rem;color:var(--text-muted);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.volume-slider{width:50px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#444;border-radius:2px;outline:none}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}.waiting-text{text-align:center;color:var(--text-muted);padding:2rem 0}.uno-player-view{padding:.5rem;gap:.5rem}.uno-info-bar{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:var(--surface);border-radius:8px}.turn-indicator{font-weight:600;color:var(--text-muted)}.turn-indicator.my-turn{color:var(--green)}.action-error{background:var(--red);color:#fff;padding:.5rem;border-radius:6px;text-align:center;font-size:.85rem;cursor:pointer}.uno-top-card{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 0}.draw-count{color:var(--text-muted);font-size:.85rem}.uno-other-players{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.other-player{background:var(--surface);padding:.4rem .75rem;border-radius:6px;font-size:.8rem;display:flex;gap:.5rem}.other-cards{color:var(--text-muted)}.uno-hand{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;padding:.5rem 0;flex:1;align-content:flex-start}.uno-card{width:60px;height:90px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5);border:2.5px solid rgba(255,255,255,.25);transition:transform .15s,box-shadow .15s;-webkit-user-select:none;user-select:none;position:relative;box-shadow:2px 3px 6px #0000004d;overflow:hidden}.card-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0px;width:100%;height:100%}.card-logo{font-size:.6rem;font-weight:900;font-style:italic;opacity:.5;letter-spacing:1px;position:absolute;top:3px;left:5px}.card-value{font-size:1.4rem;font-weight:900;line-height:1}.card-kes{font-size:.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;opacity:.55;position:absolute;bottom:4px}.uno-card.playable{cursor:pointer;box-shadow:0 0 10px #fff6,0 0 20px #e945604d}.uno-card.playable:active{transform:scale(1.12) translateY(-6px)}.uno-card.small{width:44px;height:66px}.uno-card.small .card-value{font-size:1rem}.uno-card.small .card-logo{font-size:.45rem}.uno-card.small .card-kes{font-size:.35rem}.uno-card-red{background:linear-gradient(135deg,#e74c3c,#c0392b)}.uno-card-blue{background:linear-gradient(135deg,#3498db,#2980b9)}.uno-card-green{background:linear-gradient(135deg,#2ecc71,#27ae60)}.uno-card-yellow{background:linear-gradient(135deg,#f1c40f,#f39c12);color:#333;text-shadow:none}.uno-card-black{background:linear-gradient(135deg,#34495e,#2c3e50)}.wild-colors{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;width:32px;height:32px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.4)}.wc-red{background:#e74c3c}.wc-blue{background:#3498db}.wc-green{background:#2ecc71}.wc-yellow{background:#f1c40f}.uno-table{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:.75rem 0}.draw-pile-card{width:60px;height:90px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#8e44ad,#6c3483);color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5);border:2.5px solid rgba(255,255,255,.2);box-shadow:2px 3px 6px #0000004d;cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden}.draw-pile-card:not(:disabled):active{transform:scale(1.05);box-shadow:0 0 12px #8e44ad80}.draw-pile-card:disabled{opacity:.5;cursor:not-allowed}.draw-pile-card .card-inner{display:flex;flex-direction:column;align-items:center;justify-content:center}.draw-pile-card .card-logo{font-size:.6rem;font-weight:900;font-style:italic;opacity:.5;position:absolute;top:3px;left:5px}.draw-pile-card .card-value{font-size:1.4rem;font-weight:900}.draw-pile-card .card-kes{font-size:.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.15em;opacity:.55;position:absolute;bottom:4px}.draw-pile-count{position:absolute;top:-6px;right:-6px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:700;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000004d}.kes-title{font-size:1.1rem;font-weight:900;color:var(--red);letter-spacing:.1em}.btn-uno{background:var(--red);color:#fff;padding:.75rem 1.5rem;font-size:1.2rem;font-weight:800;border:none;border-radius:8px;cursor:pointer;animation:pulse .5s ease-in-out infinite alternate;width:100%}@keyframes pulse{0%{transform:scale(1)}to{transform:scale(1.05)}}.uno-finished{align-items:center;justify-content:center;gap:1rem}.uno-finished h2{font-size:2rem;color:var(--accent)}.color-picker-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.color-picker{background:var(--surface);padding:1.5rem;border-radius:12px;text-align:center;display:flex;flex-direction:column;gap:1rem}.color-options{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.color-btn{width:60px;height:60px;border-radius:50%;border:3px solid rgba(255,255,255,.3);cursor:pointer;transition:transform .15s}.color-btn:active{transform:scale(1.15)}.color-red{background:var(--red)}.color-blue{background:var(--blue)}.color-green{background:var(--green)}.color-yellow{background:var(--yellow)}
