body{margin:0;min-width:320px}:root{--bg: #0f0f13;--surface: #1a1a24;--surface-2: #232336;--border: #2a2a40;--text: #e8e8f0;--text-dim: #8888a0;--accent: #6c5ce7;--accent-glow: #7c6cf7;--green: #00b894;--green-glow: #00d4aa;--red: #e74c3c;--orange: #f39c12;--gold: #ffd700;--die-bg: #f0ece4;--die-dot: #1a1a24;--die-scored-bg: #6c5ce7;--die-scored-dot: #fff;--die-locked-bg: #2d2d44;--die-locked-dot: #6c5ce7}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100dvh;overflow-x:hidden}.app{max-width:540px;margin:0 auto;padding:1.5rem 1rem;min-height:100dvh;display:flex;flex-direction:column}.app-header{text-align:center;margin-bottom:1.25rem;position:relative}.app-header h1{font-size:2.5rem;font-weight:900;letter-spacing:.15em;background:linear-gradient(135deg,var(--accent) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-dim);font-size:.85rem;margin-top:.2rem;letter-spacing:.05em}.mute-btn{position:absolute;top:.5rem;right:0;background:none;border:1px solid var(--border);border-radius:8px;color:var(--text-dim);font-size:1.2rem;padding:.3rem .5rem;cursor:pointer;transition:all .15s}.mute-btn:hover{border-color:var(--text-dim);color:var(--text)}.game-board{position:relative;flex:1;display:flex;flex-direction:column}.screen-flash:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;animation:screenFlash .4s ease-out forwards;pointer-events:none;z-index:100}.screen-shake{animation:screenShake .4s ease-in-out}.setup{display:flex;align-items:center;justify-content:center;min-height:60vh}.setup-card{background:var(--surface);border:1px solid var(--border);border-radius:1.25rem;padding:2rem 1.5rem;width:100%;max-width:400px;display:flex;flex-direction:column;gap:.75rem}.setup-title{font-size:1.5rem;font-weight:800;text-align:center;color:var(--text)}.setup-subtitle{text-align:center;color:var(--text-dim);font-size:.8rem;margin-bottom:.5rem}.setup-players{display:flex;flex-direction:column;gap:.5rem}.setup-row{display:flex;align-items:center;gap:.6rem}.setup-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.setup-input{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:.6rem;padding:.6rem .8rem;color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border-color .15s}.setup-input:focus{border-color:var(--accent)}.setup-input::placeholder{color:var(--text-dim)}.setup-remove{background:none;border:none;color:var(--text-dim);font-size:1.2rem;cursor:pointer;padding:.2rem .4rem;line-height:1}.setup-remove:hover{color:var(--red)}.setup-error{color:var(--red);font-size:.8rem;text-align:center}.setup-start{margin-top:.5rem;align-self:center}.btn-ghost{background:none;border:1px dashed var(--border);color:var(--text-dim);border-radius:.6rem;padding:.5rem;cursor:pointer;font-size:.85rem;transition:all .15s}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.mp-scoreboard{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:.75rem;margin-bottom:.75rem}.final-round-banner{text-align:center;font-size:.7rem;font-weight:800;letter-spacing:.15em;color:var(--gold);padding:.3rem;margin-bottom:.5rem;border:1px solid rgba(255,215,0,.3);border-radius:.5rem;background:#ffd7000f;animation:pulse 1.5s ease-in-out infinite}.mp-players{display:flex;flex-direction:column;gap:.35rem}.mp-player{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:.6rem;border:1px solid transparent;transition:all .2s}.mp-player-active{background:#ffffff0a;border-color:var(--player-color, var(--accent));box-shadow:0 0 12px #6c5ce726}.mp-player-rank{font-size:.7rem;font-weight:700;color:var(--text-dim);width:18px;text-align:center}.mp-player-info{flex:1;min-width:0}.mp-player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem}.mp-player-name{font-size:.8rem;font-weight:600;display:flex;align-items:center;gap:.4rem}.mp-active-dot{width:6px;height:6px;border-radius:50%;background:var(--player-color, var(--accent));animation:pulse 1s ease-in-out infinite}.mp-player-score{font-size:.85rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--player-color, var(--text))}.mp-bar-track{width:100%;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden}.mp-bar-fill{height:100%;border-radius:2px;transition:width .5s ease}.mp-not-on-board{font-size:.6rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;opacity:.7}.mp-turn-info{margin-top:.5rem;padding:.5rem .6rem;background:var(--surface-2);border-radius:.6rem;display:flex;flex-direction:column;gap:.15rem}.mp-turn-row{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-dim)}.mp-turn-value{font-weight:700;color:var(--orange);font-variant-numeric:tabular-nums}.mp-turn-selected{color:var(--accent-glow)}.mp-turn-total{padding-top:.2rem;border-top:1px solid var(--border);margin-top:.1rem}.mp-turn-bank{color:var(--gold);font-size:.85rem}.message-bar{text-align:center;padding:.5rem;margin-bottom:.5rem;min-height:2.5rem;display:flex;align-items:center;justify-content:center}.message{font-size:.85rem;color:var(--text);line-height:1.4}.message-farkle{color:var(--red);font-weight:700;font-size:1.1rem;animation:shake .5s ease-in-out}.message-hot{color:var(--gold);font-weight:700;animation:pulse .6s ease-in-out 2}.combo-display{margin-bottom:.5rem;text-align:center}.combo-list{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem}.combo-tag{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .6rem;border-radius:2rem;font-size:.75rem;font-weight:600;animation:comboPopIn .3s ease-out backwards}.combo-name{opacity:.9}.combo-pts{font-weight:800}.combo-low{background:#ffffff14;color:var(--text)}.combo-medium{background:#6c5ce726;color:var(--accent-glow);border:1px solid rgba(108,92,231,.3)}.combo-high{background:#ffd7001f;color:var(--gold);border:1px solid rgba(255,215,0,.3);text-shadow:0 0 8px rgba(255,215,0,.3)}.combo-extreme{background:linear-gradient(135deg,#ffd70033,#e74c3c33);color:var(--gold);border:1px solid rgba(255,215,0,.4);text-shadow:0 0 12px rgba(255,215,0,.5);animation:comboPopIn .3s ease-out backwards,comboPulse 1s ease-in-out infinite}.combo-total{font-size:.7rem;color:var(--text-dim);margin-top:.3rem}.dice-tray{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:320px;margin:0 auto 1.25rem;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:1rem;position:relative}.die{width:80px;height:80px;margin:0 auto;border:3px solid transparent;border-radius:14px;background:var(--die-bg);cursor:pointer;padding:12px;transition:all .15s ease;box-shadow:0 3px 8px #0000004d;position:relative;flex-shrink:0}.die:hover:not(:disabled):not(.die-locked):not(.die-hidden){transform:translateY(-3px);box-shadow:0 6px 16px #0006}.die:active:not(:disabled):not(.die-locked):not(.die-hidden){transform:translateY(0)}.die-hidden{background:var(--surface-2);border-color:var(--border);cursor:default}.die-hidden .die-face{visibility:hidden}.die-scored{background:var(--die-scored-bg);border-color:var(--accent-glow);box-shadow:0 0 20px #6c5ce766}.die-scored .die-dot{background:var(--die-scored-dot)}.die-highlight{border-color:var(--gold);box-shadow:0 0 16px #ffd70040;animation:highlightPulse 1.2s ease-in-out infinite}.die-locked{background:var(--die-locked-bg);border-color:var(--border);cursor:default;opacity:.6}.die-locked .die-dot{background:var(--die-locked-dot)}.die-disabled{cursor:default}.die-rolling{animation:dieRoll .3s ease-in-out infinite;background:var(--surface-2);border-color:var(--border)}.die-rolling .die-face{visibility:hidden}.die-face{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:6%}.die-dot{width:100%;height:100%;border-radius:50%;background:var(--die-dot);justify-self:center;align-self:center;max-width:14px;max-height:14px}.revealing-indicator{text-align:center;color:var(--text-dim);font-size:.85rem;font-weight:600;padding:.9rem;animation:pulse .8s ease-in-out infinite}.controls{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.25rem}.btn{border:none;border-radius:.75rem;font-weight:700;font-size:.9rem;cursor:pointer;transition:all .15s ease;text-transform:uppercase;letter-spacing:.05em}.btn-large{padding:.9rem 1.5rem;font-size:.95rem}.btn:disabled{opacity:.4;cursor:default}.btn-primary{background:linear-gradient(135deg,var(--accent),#8b7cf7);color:#fff;box-shadow:0 4px 12px #6c5ce74d}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #6c5ce780;transform:translateY(-1px)}.btn-accent{background:linear-gradient(135deg,var(--orange),#e67e22);color:#fff;box-shadow:0 4px 12px #f39c124d}.btn-accent:hover:not(:disabled){box-shadow:0 6px 20px #f39c1280;transform:translateY(-1px)}.btn-bank{background:linear-gradient(135deg,var(--green),#00a382);color:#fff;box-shadow:0 4px 12px #00b8944d}.btn-bank:hover:not(:disabled){box-shadow:0 6px 20px #00b89480;transform:translateY(-1px)}.btn-bank-blocked{background:var(--surface-2);color:var(--text-dim);border:1px dashed var(--border);cursor:not-allowed}.score-popups{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:90}.score-popup{position:absolute;font-weight:900;font-size:1.4rem;transform:translate(-50%,-50%);animation:scoreFloat 1.2s ease-out forwards;text-shadow:0 2px 8px rgba(0,0,0,.5);white-space:nowrap}.popup-medium{color:var(--accent-glow);font-size:1.2rem}.popup-high{color:var(--gold);font-size:1.6rem}.popup-bank{color:var(--green-glow);font-size:1.5rem}.popup-onboard{color:var(--gold);font-size:1.8rem;text-shadow:0 0 20px rgba(255,215,0,.6)}.popup-hotdice{color:#ff6b6b;font-size:2rem;font-weight:700;text-shadow:0 0 25px rgba(255,107,107,.8),0 0 50px rgba(255,107,107,.4);letter-spacing:.05em}.particle-layer{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:80;overflow:hidden}.particle-burst{position:absolute;transform:translate(-50%,-50%)}.particle{position:absolute;font-size:1rem;animation:particleFly 1s ease-out forwards;opacity:0}.scoring-guide{background:var(--surface);border:1px solid var(--border);border-radius:1rem;overflow:hidden;margin-top:auto}.scoring-guide summary{padding:.75rem 1.25rem;cursor:pointer;font-weight:600;font-size:.85rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}.scoring-guide summary:hover{color:var(--text)}.guide-content{padding:0 1.25rem 1rem;display:flex;flex-direction:column;gap:.75rem}.guide-section h4{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.35rem}.guide-row{display:flex;justify-content:space-between;font-size:.8rem;padding:.15rem 0;color:var(--text)}.guide-row.dim{color:var(--text-dim)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes dieRoll{0%{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(.85)}50%{transform:rotate(180deg) scale(1.05)}75%{transform:rotate(270deg) scale(.95)}to{transform:rotate(360deg) scale(1)}}@keyframes highlightPulse{0%,to{box-shadow:0 0 12px #ffd70033}50%{box-shadow:0 0 24px #ffd70066}}@keyframes comboPopIn{0%{transform:scale(.5) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@keyframes comboPulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.3)}}@keyframes scoreFloat{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}15%{transform:translate(-50%,-60%) scale(1.2);opacity:1}to{transform:translate(-50%,-180%) scale(.8);opacity:0}}@keyframes particleFly{0%{transform:translate(0) rotate(0) scale(1);opacity:1}to{transform:translate(calc(cos(var(--angle)) * var(--velocity)),calc(sin(var(--angle)) * var(--velocity) - 30px)) rotate(var(--spin)) scale(.3);opacity:0}}@keyframes screenFlash{0%{opacity:.25}to{opacity:0}}@keyframes screenShake{0%,to{transform:translate(0)}10%{transform:translate(-4px,-2px)}20%{transform:translate(4px,2px)}30%{transform:translate(-3px,1px)}40%{transform:translate(3px,-1px)}50%{transform:translate(-2px,2px)}60%{transform:translate(2px,-2px)}70%{transform:translate(-1px,1px)}80%{transform:translate(1px,-1px)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.main-menu{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem 1rem}.menu-dice{display:flex;gap:.5rem;font-size:2.5rem}.menu-die{animation:menuFloat 2s ease-in-out infinite}@keyframes menuFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.menu-buttons{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:300px}.menu-buttons .btn{width:100%;text-align:center;font-size:1.1rem}.online-lobby{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem;max-width:400px;margin:0 auto}.lobby-form{display:flex;flex-direction:column;gap:1rem;width:100%}.lobby-label{font-size:.85rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}.lobby-input{padding:.75rem 1rem;border:2px solid var(--border);border-radius:.75rem;background:var(--surface);color:var(--text);font-size:1rem;outline:none;transition:border-color .2s}.lobby-input:focus{border-color:var(--accent)}.lobby-code-input{width:7rem;text-align:center;font-size:1.3rem;font-weight:700;letter-spacing:.2em;flex-shrink:0}.lobby-actions{display:flex;flex-direction:column;gap:1rem}.lobby-divider{text-align:center;color:var(--text-dim);font-size:.85rem}.lobby-join-row{display:flex;gap:.75rem;align-items:center}.lobby-join-row .btn{flex:0 0 auto}.lobby-error{color:#e74c3c;font-size:.9rem;text-align:center}.lobby-back{background:transparent;border:1px solid var(--border);color:var(--text-dim)}.lobby-room{display:flex;flex-direction:column;gap:1.5rem;width:100%;background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:1.5rem}.lobby-code-display{display:flex;flex-direction:column;align-items:center;gap:.25rem}.lobby-code-label{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em}.lobby-code-value{font-size:2.5rem;font-weight:700;letter-spacing:.3em;color:var(--accent)}.lobby-players{display:flex;flex-direction:column;gap:.5rem}.lobby-player{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:.5rem;background:#ffffff08}.lobby-player-me{background:#ffffff14;border:1px solid var(--border)}.lobby-player-waiting{opacity:.4}.lobby-player-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.lobby-player-name{flex:1;font-weight:500}.lobby-host-badge{font-size:.65rem;background:var(--accent);color:#000;padding:.1rem .4rem;border-radius:.25rem;margin-left:.5rem;font-weight:700;text-transform:uppercase}.lobby-kick-btn{padding:.25rem .6rem;font-size:.75rem;background:#e74c3c33;color:#e74c3c;border:1px solid rgba(231,76,60,.4);border-radius:.3rem;cursor:pointer}.lobby-kick-btn:hover{background:#e74c3c59}.lobby-waiting-msg{text-align:center;color:var(--text-dim);font-style:italic}.lobby-connecting{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message-waiting{color:var(--text-dim);font-size:.85rem;font-style:italic;margin-top:.25rem}.game-back-btn{margin-top:1rem;margin-bottom:1.25rem;font-size:.8rem;padding:.4rem 1rem;background:transparent;border:1px solid var(--border);color:var(--text-dim)}@media (max-width: 400px){.app{padding:1rem .75rem}.dice-tray{gap:.5rem;padding:1rem}.die{border-radius:10px;width:68px;height:68px;padding:10px}.controls{gap:.5rem}.btn-large{padding:.75rem 1rem;font-size:.85rem}.mp-player{padding:.3rem .4rem}.lobby-code-value{font-size:2rem}}
