:root{--font-heading: "Russo One", sans-serif;--font-body: "Inter", "Segoe UI", system-ui, sans-serif;--color-ice: #e8f4f8;--color-track: #c8dce4;--color-p1: #e74c3c;--color-p2: #3498db;--color-text: #2d3436;--color-text-light: #9ba8b0;--color-bg: #0a1628;--color-panel: rgba(20, 35, 60, .75);--color-panel-solid: #14233c;--color-accent: #f39c12;--color-accent-hover: #e67e22;--glow-p1: rgba(231, 76, 60, .4);--glow-p2: rgba(52, 152, 219, .4);--glow-accent: rgba(243, 156, 18, .35);--glow-gold: rgba(255, 215, 0, .5);--frost-border: rgba(255, 255, 255, .08);--frost-bg: rgba(255, 255, 255, .04);--color-gold: #ffd700;--color-silver: #c0c0c0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:radial-gradient(ellipse at 50% 30%,#132744,#0a1628 60%,#060e1a);color:#fff;min-height:100vh;overflow-x:hidden}#root{min-height:100vh;display:flex;flex-direction:column;align-items:center}h1,h2,h3,h4{font-family:var(--font-heading);text-transform:uppercase;letter-spacing:3px}.frost-panel{background:var(--color-panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--frost-border);border-radius:12px}.btn{padding:12px 28px;font-size:1rem;font-weight:600;font-family:var(--font-body);border:none;border-radius:8px;cursor:pointer;transition:all .2s;letter-spacing:.5px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-accent) 0%,var(--color-accent-hover) 100%);color:var(--color-text);box-shadow:0 2px 10px var(--glow-accent)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-hover) 0%,#d35400 100%);transform:scale(1.02);box-shadow:0 4px 16px var(--glow-accent)}.btn-secondary{background:#334155cc;color:#fff;border:1px solid var(--frost-border)}.btn-secondary:hover:not(:disabled){background:#475569cc}.btn-accent{background:linear-gradient(135deg,#8e44ad,#6c3483);color:#fff;box-shadow:0 2px 10px #8e44ad4d}.btn-accent:hover:not(:disabled){background:linear-gradient(135deg,#7d3c98,#5b2c6f);transform:scale(1.02)}.btn-large{font-size:1.3rem;padding:16px 40px}.btn-small{font-size:.9rem;padding:8px 20px}.mode-toggle{width:100%;text-align:center;margin-bottom:12px}.mode-toggle label{display:block;font-size:.85rem;color:var(--color-text-light);margin-bottom:8px}.mode-buttons{display:flex;gap:8px;justify-content:center}.btn-pulse{animation:btnPulse 2s ease-in-out infinite}@keyframes btnPulse{0%,to{box-shadow:0 2px 10px var(--glow-accent)}50%{box-shadow:0 4px 24px var(--glow-accent),0 0 40px #f39c1233}}.lobby{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:24px;padding:32px}.title{font-family:var(--font-heading);font-size:3.2rem;letter-spacing:4px;text-transform:uppercase;background:linear-gradient(135deg,#fff,#a8d8ea,#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none;filter:drop-shadow(0 2px 8px rgba(168,216,234,.3))}.subtitle{font-size:1.1rem;color:var(--color-text-light);margin-top:-16px;letter-spacing:1px}.player-inputs{display:flex;gap:32px;margin-top:16px}.player-input{display:flex;flex-direction:column;gap:8px}.player-input label{font-size:.9rem;color:var(--color-text-light)}.player-input input{padding:12px 16px;font-size:1.1rem;font-family:var(--font-body);border:1px solid var(--frost-border);border-radius:8px;background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;width:200px;outline:none;transition:border-color .2s,box-shadow .2s}.player-input input:focus{border-color:var(--color-accent);box-shadow:0 0 12px var(--glow-accent)}.qr-section{display:flex;flex-direction:column;align-items:center;gap:8px;margin:8px 0}.qr-label{font-size:1rem;color:var(--color-text-light)}.qr-code{width:200px;height:200px;border-radius:12px;background:#fff;padding:8px;box-shadow:0 4px 20px #0000004d}.qr-url{font-size:.8rem;color:var(--color-text-light);font-family:Consolas,Courier New,monospace}.room-code-display{text-align:center;margin:4px 0}.room-code-label{font-size:.9rem;color:var(--color-text-light);margin-bottom:4px}.room-code-value{font-family:var(--font-heading);font-size:3.5rem;letter-spacing:12px;color:var(--color-accent);text-shadow:0 0 20px var(--glow-accent)}.lobby-players{display:flex;gap:24px;margin:8px 0}.lobby-player-slot{background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frost-border);border-radius:12px;padding:16px 28px;min-width:180px;text-align:center;transition:all .3s}.lobby-player-slot.filled{border-color:var(--color-accent);box-shadow:0 0 16px var(--glow-accent)}.lobby-player-name{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--color-accent);letter-spacing:1px}.lobby-player-waiting{font-size:.9rem;color:var(--color-text-light)}.character-select{display:flex;flex-direction:column;align-items:center;padding:40px 32px;gap:24px}.selecting-label{font-size:1.2rem;color:var(--color-accent);letter-spacing:1px}.type-grid{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.type-card{background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frost-border);border-radius:12px;padding:20px 24px;width:220px;cursor:pointer;text-align:left;color:#fff;transition:all .3s;position:relative}.type-card:hover:not(:disabled){border-color:#fff3;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.type-card.selected-p1{border-color:var(--color-p1);box-shadow:0 0 20px var(--glow-p1)}.type-card.selected-p2{border-color:var(--color-p2);box-shadow:0 0 20px var(--glow-p2)}.type-card h3{margin-bottom:12px;font-size:1.1rem;letter-spacing:2px}.type-stats{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--color-text-light)}.badge{position:absolute;top:-10px;right:-10px;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:700;color:#fff;letter-spacing:.5px}.badge-p1{background:var(--color-p1);box-shadow:0 2px 8px var(--glow-p1)}.badge-p2{background:var(--color-p2);box-shadow:0 2px 8px var(--glow-p2)}.race-view{display:flex;flex-direction:column;align-items:center;padding:16px;gap:16px;width:100%;max-width:1400px}.track-svg{width:100%;max-width:1200px;border-radius:16px;box-shadow:0 4px 30px #0006,inset 0 0 60px #a8d8ea0d}.track-3d-container{width:100%;max-width:950px;aspect-ratio:16 / 9;border-radius:16px;overflow:hidden;box-shadow:0 4px 30px #0006}.track-3d-container canvas{border-radius:16px}.scoreboard{display:flex;gap:16px;width:100%}.score-row{flex:1;background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:12px 16px;border-left:4px solid #666;transition:box-shadow .3s;border-top:1px solid var(--frost-border);border-right:1px solid var(--frost-border);border-bottom:1px solid var(--frost-border)}.score-row.active{box-shadow:0 0 20px var(--glow-accent);animation:activeGlow 2s ease-in-out infinite}@keyframes activeGlow{0%,to{box-shadow:0 0 15px var(--glow-accent)}50%{box-shadow:0 0 25px var(--glow-accent),0 0 40px #f39c1226}}.score-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.score-name{font-family:var(--font-heading);font-weight:700;font-size:1.1rem;letter-spacing:1px}.score-type{font-size:.8rem;color:var(--color-text-light)}.score-lane{font-size:.75rem;color:var(--color-text-light);background:#33415599;padding:2px 8px;border-radius:4px}.score-stats{display:flex;gap:16px;font-size:.85rem;color:var(--color-text-light);margin-bottom:8px}.stamina-bar{display:flex;gap:3px;align-items:center}.stamina-segment{width:10px;height:14px;border-radius:2px;transition:background-color .3s,opacity .3s}.stamina-segment.filled{background:#2ecc71}.stamina-segment.filled.low{background:#e67e22}.stamina-segment.filled.critical{background:#e74c3c}.stamina-segment.empty{background:#ffffff1a}.progress-bar{height:6px;background:#33415599;border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;transition:width .5s ease}.action-panel{background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frost-border);border-radius:12px;padding:20px 24px;text-align:center;width:100%}.turn-indicator{margin-bottom:12px;color:var(--color-accent)}.round-status{display:flex;justify-content:center;gap:24px;margin-top:8px;font-size:1.1rem}.round-status-player{display:flex;align-items:center;gap:6px;opacity:.9}.warning{color:#e74c3c;font-weight:700;margin-bottom:8px}.crossing-alert{color:#f39c12;font-weight:700;font-size:.95rem;margin-top:8px}.start-overlay{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:100;pointer-events:none}.start-text{font-family:var(--font-heading);font-size:5rem;text-transform:uppercase;letter-spacing:8px;color:#fff;text-shadow:0 0 40px rgba(255,255,255,.6),0 0 80px rgba(243,156,18,.4);animation:startFlash .6s ease-out forwards}@keyframes startFlash{0%{transform:scale(2);opacity:0}40%{opacity:1}to{transform:scale(1);opacity:0}}.dice-choice{display:flex;flex-direction:column;align-items:center;gap:12px}.dice-display{display:flex;gap:12px;align-items:center;justify-content:center}.die{width:60px;height:60px;background:linear-gradient(145deg,#fff,#e8e8e8);color:var(--color-text);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;box-shadow:0 4px 12px #0000004d,inset 0 -2px 4px #0000001a}.die.rolling{animation:diceShake .08s infinite alternate}@keyframes diceShake{0%{transform:translate(-1px,-1px) rotate(-2deg)}to{transform:translate(1px,1px) rotate(2deg)}}.dice-label{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--color-gold);text-transform:uppercase;letter-spacing:2px}.dice-label.double-flash{animation:doubleFlash .4s ease-out}@keyframes doubleFlash{0%{transform:scale(1.5);opacity:0}50%{opacity:1}to{transform:scale(1);opacity:1}}.move-buttons{display:flex;gap:12px}.reroll-option{margin-top:8px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.roll-option h5{color:var(--color-text-light)}.finish-view{display:flex;flex-direction:column;align-items:center;padding:16px;gap:20px;width:100%;max-width:900px}.finish-panel{background:var(--color-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--frost-border);border-radius:12px;padding:28px 32px;text-align:center;width:100%}.winner-text{font-family:var(--font-heading);font-size:2.8rem;margin-bottom:4px;letter-spacing:4px;text-transform:uppercase;filter:drop-shadow(0 2px 12px currentColor)}.finish-subtitle{color:var(--color-text-light);margin-bottom:20px;letter-spacing:1px}.finish-stats{display:flex;gap:24px;justify-content:center;margin-bottom:24px}.finish-stat{display:flex;flex-direction:column;gap:4px;text-align:left;background:#0a162899;border:1px solid var(--frost-border);padding:16px 20px;border-radius:8px;min-width:180px}.finish-stat strong{font-family:var(--font-heading);font-size:1.1rem;margin-bottom:4px;letter-spacing:1px}.finish-stat span{font-size:.85rem;color:var(--color-text-light)}.game-log{width:100%;background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frost-border);border-radius:10px;padding:12px 16px;max-height:140px;overflow:hidden}.log-entry{font-size:.85rem;padding:3px 0;color:var(--color-text-light);font-family:Consolas,Courier New,monospace}.controller{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:24px 16px;gap:16px;max-width:400px;margin:0 auto}.controller h2{font-size:1.4rem;text-align:center}.controller-input{display:flex;flex-direction:column;gap:8px;width:100%}.controller-input label{font-size:.9rem;color:var(--color-text-light)}.controller-input input,input.controller-input{padding:14px 16px;font-size:1.2rem;font-family:var(--font-body);border:1px solid var(--frost-border);border-radius:8px;background:var(--color-panel);color:#fff;width:100%;outline:none;transition:border-color .2s,box-shadow .2s}.controller-input input:focus,input.controller-input:focus{border-color:var(--color-accent);box-shadow:0 0 12px var(--glow-accent)}.controller .type-grid{flex-direction:column;width:100%}.controller .type-card{width:100%}.controller-wait{text-align:center;color:var(--color-text-light);font-size:1rem;padding:20px}.controller-actions{display:flex;flex-direction:column;gap:12px;width:100%;align-items:center}.sprint-controls{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;background:var(--color-panel);border:1px solid var(--frost-border);border-radius:10px;padding:12px}.sprint-controls label{font-size:.9rem;color:var(--color-text-light)}.sprint-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.sprint-btn{padding:8px 16px;font-size:.9rem;font-weight:600;font-family:var(--font-body);border:1px solid var(--frost-border);border-radius:8px;background:var(--color-panel);color:#fff;cursor:pointer;transition:all .2s}.sprint-btn:hover{border-color:var(--color-accent)}.sprint-btn.active{border-color:var(--color-accent);background:#f39c1233;box-shadow:0 0 8px var(--glow-accent)}.rhythm-tapper{width:100%;display:flex;flex-direction:column;align-items:center;gap:10px;padding:4px 0}.rhythm-countdown{font-family:var(--font-heading);font-size:3.5rem;color:var(--color-accent);text-shadow:0 0 20px var(--glow-accent)}.rhythm-instruction{font-size:1rem;color:#fffc;text-align:center;min-height:1.4em}.rhythm-section-label{font-size:.85rem;color:var(--color-text-light);margin-top:4px}.rhythm-track-preview{display:flex;align-items:center;gap:10px;width:90%;margin-top:12px;opacity:.5}.rhythm-track-preview .rhythm-track-rail{flex:1;height:6px;background:#ffffff1a;border-radius:3px;position:relative}.rhythm-ball-preview{width:14px;height:14px;border-radius:50%;background:var(--color-accent);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:previewSwing 1.5s ease-in-out infinite}@keyframes previewSwing{0%,to{left:8%}50%{left:92%}}.rhythm-progress-bar{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.rhythm-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));border-radius:3px;transition:width .05s linear}.rhythm-feedback-container{min-height:2rem;display:flex;align-items:center;justify-content:center}.rhythm-feedback{font-family:var(--font-heading);font-size:1.3rem;text-align:center}.rhythm-feedback-perfect{color:#2ecc71;text-shadow:0 0 12px rgba(46,204,113,.6)}.rhythm-feedback-good{color:var(--color-accent);text-shadow:0 0 12px var(--glow-accent)}.rhythm-feedback-miss{color:#e74c3c;text-shadow:0 0 12px rgba(231,76,60,.6)}.rhythm-track-visual{display:flex;align-items:center;gap:8px;width:100%;padding:8px 0}.rhythm-track-end{font-family:var(--font-heading);font-size:1.3rem;color:#ffffff4d;width:28px;text-align:center;transition:color .15s,text-shadow .15s}.rhythm-track-end-L.rhythm-track-end-active{color:var(--color-p1);text-shadow:0 0 12px var(--glow-p1)}.rhythm-track-end-R.rhythm-track-end-active{color:var(--color-p2);text-shadow:0 0 12px var(--glow-p2)}.rhythm-track-rail{flex:1;height:10px;background:#ffffff14;border-radius:5px;position:relative;overflow:visible}.rhythm-target-zone{position:absolute;top:-4px;bottom:-4px;width:18%;border-radius:8px;transition:background .15s,box-shadow .15s}.rhythm-target-left{left:0}.rhythm-target-right{right:0}.rhythm-target-left.rhythm-target-active{background:#e74c3c26;box-shadow:0 0 16px #e74c3c40}.rhythm-target-right.rhythm-target-active{background:#3498db26;box-shadow:0 0 16px #3498db40}.rhythm-ball{width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#ffd700,var(--color-accent));position:absolute;top:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px var(--glow-accent),0 2px 6px #0006;z-index:2}.rhythm-tap-zones{display:flex;gap:16px;width:100%}.rhythm-tap-btn{flex:1;min-height:120px;border:2px solid var(--frost-border);border-radius:16px;background:#ffffff0a;color:#ffffff80;font-family:var(--font-heading);font-size:2.2rem;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;transition:border-color .15s,background .15s,color .15s,box-shadow .15s}.rhythm-tap-left{border-color:#e74c3c33}.rhythm-tap-right{border-color:#3498db33}.rhythm-tap-left.rhythm-tap-active{border-color:var(--color-p1);background:#e74c3c1f;color:var(--color-p1);box-shadow:0 0 20px var(--glow-p1)}.rhythm-tap-right.rhythm-tap-active{border-color:var(--color-p2);background:#3498db1f;color:var(--color-p2);box-shadow:0 0 20px var(--glow-p2)}.rhythm-beats{display:flex;gap:5px;justify-content:center;flex-wrap:wrap}.rhythm-beat-dot{width:10px;height:10px;border-radius:50%;background:#ffffff1f;transition:background .15s,box-shadow .15s}.rhythm-beat-L{border:1px solid rgba(231,76,60,.2)}.rhythm-beat-R{border:1px solid rgba(52,152,219,.2)}.rhythm-beat-perfect{background:#2ecc71;box-shadow:0 0 4px #2ecc7180}.rhythm-beat-good{background:var(--color-accent);box-shadow:0 0 4px var(--glow-accent)}.rhythm-beat-miss{background:#e74c3c;box-shadow:0 0 4px #e74c3c80}.rhythm-done-label{font-size:1.2rem;color:var(--color-text-light)}.rhythm-result-summary{text-align:center;padding:12px;background:var(--frost-bg);border:1px solid var(--frost-border);border-radius:12px;width:100%}.rhythm-result-summary p{margin:4px 0}.rhythm-result-detail{font-size:.85rem;color:var(--color-text-light)}.rhythm-overlay{display:flex;gap:24px;justify-content:center;width:100%;margin-top:8px}.rhythm-player-status{flex:1;max-width:300px;padding:12px 16px;background:var(--frost-bg);border:1px solid var(--frost-border);border-radius:12px;text-align:center}.rhythm-player-name{font-family:var(--font-heading);font-size:1rem;margin-bottom:6px}.rhythm-player-score{font-size:1.4rem;font-family:var(--font-heading)}.rhythm-player-waiting{color:var(--color-text-light);font-size:.9rem}.rhythm-beat-vis{display:flex;gap:4px;justify-content:center;margin-top:6px}.rhythm-beat-vis-dot{width:10px;height:10px;border-radius:50%;background:#ffffff26}.rhythm-beat-vis-dot.active{background:var(--color-accent);box-shadow:0 0 6px var(--glow-accent)}.mute-btn{position:fixed;top:12px;right:12px;z-index:200;background:var(--color-panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--frost-border);border-radius:8px;padding:8px 10px;color:#fff;cursor:pointer;font-size:1.2rem;transition:opacity .2s;line-height:1}.mute-btn:hover{opacity:.8}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner-ring{width:48px;height:48px;border:3px solid var(--frost-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-form{background:var(--color-panel);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--frost-border);border-radius:16px;padding:32px 28px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:16px}.login-title{text-align:center;font-size:1.2rem;letter-spacing:2px;color:var(--color-ice);margin-bottom:4px}.login-error{background:#e74c3c26;border:1px solid rgba(231,76,60,.3);border-radius:8px;padding:10px 14px;color:#e74c3c;font-size:.9rem;text-align:center}.reconnect-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0a1628d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:500}.reconnect-panel{background:var(--color-panel);border:1px solid var(--frost-border);border-radius:16px;padding:40px 32px;text-align:center;max-width:340px;width:90%}.reconnect-text{font-family:var(--font-heading);font-size:1.3rem;color:var(--color-ice);letter-spacing:2px;margin-bottom:8px}.reconnect-subtext{font-size:.95rem;color:var(--color-text-light)}.tutorial-vote{width:100%;max-width:600px;margin-top:2rem;text-align:center}.tutorial-vote-question{background:linear-gradient(135deg,#1a237e,#283593);border:1px solid var(--frost-border);border-radius:16px;padding:2rem;margin-bottom:1.5rem}.tutorial-vote-question h2{font-size:1.6rem;margin-bottom:.5rem}.tutorial-vote-status{display:flex;justify-content:center;gap:2rem}.tutorial-vote-player{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--frost-bg);border:1px solid var(--frost-border);border-radius:10px;font-size:1rem;opacity:.6;transition:opacity .3s,border-color .3s}.tutorial-vote-player.voted{opacity:1;border-color:#2ecc71}.tutorial-vote-icon{font-size:1.2rem}.tutorial-overlay{width:100%;max-width:800px;min-height:60vh;display:flex;flex-direction:column;align-items:center;padding:1.5rem}.tutorial-header{width:100%;display:flex;justify-content:center;margin-bottom:1rem}.tutorial-progress{background:linear-gradient(135deg,#1a237e,#283593);padding:.5rem 1.5rem;border-radius:20px;font-size:.9rem;letter-spacing:2px;border:1px solid var(--frost-border)}.tutorial-slide{width:100%;background:var(--color-panel);border:1px solid var(--frost-border);border-radius:16px;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tutorial-slide-title{font-size:1.5rem;margin-bottom:1.5rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem}.tutorial-slide-icon{font-size:1.8rem}.tutorial-slide-content{display:flex;flex-direction:column;gap:1.25rem}.tutorial-visual{display:flex;justify-content:center;padding:1rem 0}.tutorial-start-sequence{display:flex;align-items:center;gap:.75rem}.tutorial-start-step{padding:.75rem 1.25rem;border-radius:10px;font-weight:700;font-size:1rem;min-width:80px;text-align:center}.tutorial-start-arrow{font-size:1.5rem;color:var(--color-text-light)}.tutorial-dice-example{display:flex;justify-content:center}.tutorial-dice-pair{display:flex;gap:.75rem}.tutorial-die{width:56px;height:56px;background:var(--color-panel-solid);border:2px solid var(--frost-border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700}.tutorial-dice-double .tutorial-die{border-color:var(--color-accent);box-shadow:0 0 12px var(--glow-accent)}.tutorial-skater-cards{display:flex;gap:.75rem;justify-content:center}.tutorial-skater-card{flex:1;max-width:180px;padding:1rem;border-radius:12px;text-align:center;border:1px solid var(--frost-border);background:var(--frost-bg)}.tutorial-skater-card h4{font-size:.95rem;margin-bottom:.5rem}.tutorial-skater-card p{font-size:.85rem;margin:.25rem 0}.tutorial-skater-dice{color:var(--color-accent);font-weight:700}.tutorial-skater-bonus{color:#2ecc71;font-size:.8rem;font-style:italic}.tutorial-skater-sprinter{border-color:var(--color-p1)}.tutorial-skater-allround{border-color:var(--color-p2)}.tutorial-skater-distance{border-color:#2ecc71}.tutorial-track-zone{display:flex;align-items:center;gap:1rem;background:var(--frost-bg);padding:1rem 2rem;border-radius:10px;border:1px solid var(--color-accent)}.tutorial-zone-label{font-weight:700;font-size:1rem}.tutorial-zone-arrow{font-size:1.5rem;color:var(--color-accent)}.tutorial-stamina-bar{position:relative;width:250px;height:28px;background:#ffffff1a;border-radius:14px;overflow:hidden;border:1px solid var(--frost-border)}.tutorial-stamina-fill{height:100%;background:linear-gradient(90deg,#2ecc71,#27ae60);border-radius:14px;transition:width .3s}.tutorial-stamina-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.85rem;font-weight:700;text-shadow:0 1px 3px rgba(0,0,0,.5)}.tutorial-sprint-zone{display:flex;align-items:center;gap:1rem;background:linear-gradient(135deg,#2ecc7126,#27ae6026);padding:1rem 2rem;border-radius:10px;border:1px solid #2ecc71}.tutorial-sprint-label{font-weight:700}.tutorial-sprint-icon{font-size:1.5rem}.tutorial-photo-finish{background:linear-gradient(135deg,#f39c1226,#f1c40f26);padding:1rem 2rem;border-radius:10px;border:1px solid var(--color-accent);text-align:center}.tutorial-photo-label{font-weight:700}.tutorial-rhythm-demo{display:flex;gap:1.5rem;justify-content:center}.tutorial-rhythm-beat{font-size:2rem;animation:tutorial-beat-pulse .8s ease-in-out infinite alternate}.tutorial-rhythm-beat:nth-child(2){animation-delay:.2s}.tutorial-rhythm-beat:nth-child(3){animation-delay:.4s}.tutorial-rhythm-beat:nth-child(4){animation-delay:.6s}@keyframes tutorial-beat-pulse{0%{opacity:.4;transform:scale(.9)}to{opacity:1;transform:scale(1.1)}}.tutorial-rules{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.tutorial-badge{display:inline-block;padding:.5rem 1rem;border-radius:8px;font-size:.85rem;font-weight:500;text-align:center}.tutorial-badge-green{background:#2ecc7126;border:1px solid rgba(46,204,113,.4);color:#2ecc71}.tutorial-badge-yellow{background:#f39c1226;border:1px solid rgba(243,156,18,.4);color:#f39c12}.tutorial-badge-red{background:#e74c3c26;border:1px solid rgba(231,76,60,.4);color:#e74c3c}.tutorial-tip{background:#f39c1214;border-left:3px solid var(--color-accent);padding:.75rem 1rem;border-radius:0 8px 8px 0;font-size:.9rem;line-height:1.4}.tutorial-tip strong{color:var(--color-accent)}.tutorial-skip-link{background:none;border:none;color:var(--color-text-light);font-size:.85rem;cursor:pointer;padding:.5rem;text-decoration:underline;text-underline-offset:3px;width:100%;text-align:center}.tutorial-skip-link:active{color:#fff}@media (max-width: 600px){.tutorial-skater-cards{flex-direction:column;align-items:center}.tutorial-skater-card{max-width:100%;width:100%}.tutorial-start-sequence{flex-wrap:wrap;justify-content:center}.tutorial-vote-status{flex-direction:column;align-items:center;gap:.75rem}}.hint-banner{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:100;max-width:700px;width:calc(100% - 2rem);display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-radius:12px;background:linear-gradient(135deg,#1a234ef2,#283593f2);border:1px solid var(--frost-border);border-left:4px solid var(--color-p2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000004d}.hint-banner-icon{font-size:1.5rem;flex-shrink:0}.hint-banner-content{flex:1}.hint-banner-title{font-family:var(--font-heading);font-size:.85rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:.15rem}.hint-banner-text{font-size:.85rem;color:#fffc;line-height:1.3}.hint-card{width:100%;padding:.75rem 1rem;border-radius:10px;margin-bottom:.75rem;display:flex;align-items:flex-start;gap:.6rem;border:1px solid var(--frost-border);background:var(--frost-bg)}.hint-card-icon{font-size:1.3rem;flex-shrink:0;margin-top:.1rem}.hint-card-content{flex:1}.hint-card-title{font-weight:700;font-size:.85rem;margin-bottom:.2rem}.hint-card-text{font-size:.8rem;color:#fffc;line-height:1.3}.hint-info{border-left:4px solid var(--color-p2)}.hint-info .hint-banner-title,.hint-info .hint-card-title{color:var(--color-p2)}.hint-warning{border-left:4px solid var(--color-accent)}.hint-warning .hint-banner-title,.hint-warning .hint-card-title{color:var(--color-accent)}.hint-danger{border-left:4px solid var(--color-p1)}.hint-danger .hint-banner-title,.hint-danger .hint-card-title{color:var(--color-p1)}.hint-success{border-left:4px solid #2ecc71}.hint-success .hint-banner-title,.hint-success .hint-card-title{color:#2ecc71}.hint-special{border-left:4px solid var(--color-gold)}.hint-special .hint-banner-title,.hint-special .hint-card-title{color:var(--color-gold)}.hint-purple{border-left:4px solid #9b59b6}.hint-purple .hint-banner-title,.hint-purple .hint-card-title{color:#9b59b6}@media (min-width: 1200px){.race-view{max-width:1400px}.track-svg{max-width:1200px}.winner-text{font-size:3.5rem}}@media (max-width: 600px){.scoreboard,.finish-stats,.lobby-players{flex-direction:column}.title{font-size:2rem}.room-code-value{font-size:2.5rem;letter-spacing:8px}}@media (max-width: 360px){.controller{padding:16px 10px;gap:12px}.btn-large{font-size:1.1rem;padding:14px 24px}.die{width:48px;height:48px;font-size:1.5rem}}
