.lobby{max-width:1200px;margin:0 auto;padding:2rem;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;font-family:Arial,sans-serif}.lobby-header{text-align:center;margin-bottom:3rem;padding:2rem;background:rgba(255,255,255,.1);border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.lobby-header h1{font-size:3.5rem;margin:0 0 1rem;background:linear-gradient(45deg,#FFD700,#FFA500);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(255,215,0,.5);animation:title-glow 3s ease-in-out infinite}.lobby-subtitle{font-size:1.3rem;margin:0;color:#e0e0e0;font-weight:300}@keyframes title-glow{0%,to{filter:brightness(1) drop-shadow(0 0 20px rgba(255,215,0,.5))}50%{filter:brightness(1.2) drop-shadow(0 0 30px rgba(255,215,0,.8))}}.connection-status{text-align:center;margin-bottom:2rem}.status-connected,.status-disconnected{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:50px;font-weight:600;font-size:1.1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid;transition:all .3s ease}.status-connected{background:rgba(76,175,80,.2);border-color:#4caf5080;color:#4caf50}.status-disconnected{background:rgba(244,67,54,.2);border-color:#f4433680;color:#f44336}.status-icon{font-size:1.2rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.mode-selection{margin-bottom:3rem}.mode-selection h2{text-align:center;font-size:2.5rem;margin-bottom:2rem;color:gold;text-shadow:0 0 20px rgba(255,215,0,.6)}.mode-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem;margin-bottom:2rem}.mode-option{background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.2);border-radius:20px;padding:2rem;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.mode-option:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .3s ease}.mode-option:hover:before{opacity:1}.mode-option.selected{border-color:gold;background:rgba(255,215,0,.1);transform:translateY(-5px);box-shadow:0 10px 30px #ffd7004d}.mode-option.selected:after{content:"✅";position:absolute;top:1rem;right:1rem;font-size:1.5rem;animation:check-bounce .5s ease-out}@keyframes check-bounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.mode-icon{font-size:4rem;text-align:center;margin-bottom:1rem;animation:icon-float 3s ease-in-out infinite}@keyframes icon-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.mode-info h3{font-size:1.8rem;margin:0 0 1rem;color:gold;text-align:center}.mode-description{text-align:center;margin-bottom:1.5rem;color:#e0e0e0;line-height:1.6}.mode-stats{display:flex;justify-content:space-around;gap:1rem}.stat{background:rgba(255,255,255,.1);padding:.5rem 1rem;border-radius:15px;font-size:.9rem;border:1px solid rgba(255,255,255,.2)}.join-section{text-align:center;margin-bottom:3rem}.join-btn{background:linear-gradient(45deg,#FF6B6B,#4ECDC4);color:#fff;border:none;padding:1.5rem 3rem;font-size:1.3rem;font-weight:700;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 20px #0000004d;position:relative;overflow:hidden}.join-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.join-btn:hover:before{left:100%}.join-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0006}.join-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.join-btn.joining{background:linear-gradient(45deg,#FFA726,#FF7043);animation:joining-pulse 1.5s ease-in-out infinite}@keyframes joining-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.searching-animation{margin-top:1rem}.searching-dots{display:flex;justify-content:center;gap:.5rem}.searching-dots span{width:12px;height:12px;background:#FFD700;border-radius:50%;animation:dots-bounce 1.4s ease-in-out infinite both}.searching-dots span:nth-child(1){animation-delay:-.32s}.searching-dots span:nth-child(2){animation-delay:-.16s}@keyframes dots-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.game-info{margin-bottom:3rem}.game-info h2{text-align:center;font-size:2.5rem;margin-bottom:2rem;color:gold;text-shadow:0 0 20px rgba(255,215,0,.6)}.rules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.rule-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:15px;padding:2rem;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.rule-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000004d}.rule-icon{font-size:3rem;margin-bottom:1rem;animation:icon-float 3s ease-in-out infinite}.rule-card h4{font-size:1.3rem;margin:0 0 1rem;color:gold}.rule-card p{margin:0;color:#e0e0e0;line-height:1.5}.features-preview{text-align:center}.features-preview h2{font-size:2.5rem;margin-bottom:2rem;color:gold;text-shadow:0 0 20px rgba(255,215,0,.6)}.features-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;max-width:800px;margin:0 auto}.feature-item{display:flex;align-items:center;gap:1rem;background:rgba(255,255,255,.1);padding:1rem 1.5rem;border-radius:15px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.feature-item:hover{transform:translate(5px);background:rgba(255,255,255,.15)}.feature-icon{font-size:1.5rem;animation:icon-float 3s ease-in-out infinite}@media (max-width: 768px){.lobby{padding:1rem}.lobby-header h1{font-size:2.5rem}.mode-options,.rules-grid,.features-list{grid-template-columns:1fr}}.draft{width:100%;max-width:1400px;min-height:100vh;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);padding:2rem;color:#1e293b;position:relative;overflow-x:hidden;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.draft-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:2rem;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #ffffff0d;position:relative;overflow:hidden}.draft-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#8b5cf6,#ec4899,#f59e0b);border-radius:24px 24px 0 0}.draft-header h2{font-size:2.5rem;color:#1e293b;text-shadow:none;margin:0;font-weight:800;letter-spacing:-.025em}.draft-timer{background:linear-gradient(135deg,#fef3c7,#fde68a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;border-radius:20px;border:1px solid #fbbf24;box-shadow:0 4px 6px -1px #0000001a}.timer-label{font-weight:600;color:#92400e;margin-right:.5rem}.timer-value{font-size:1.25rem;font-weight:700;color:#92400e}.timer-value.urgent{color:#dc2626;animation:urgent-pulse 1s ease-in-out infinite}.draft-instructions{background:linear-gradient(135deg,#eff6ff,#dbeafe);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:2rem;border-radius:20px;margin-bottom:2rem;text-align:center;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #93c5fd}.draft-instructions p{font-size:1.125rem;color:#1e40af;margin-bottom:1rem;font-weight:500}.selection-counter{font-size:1.25rem;font-weight:700;color:#1d4ed8;background:rgba(255,255,255,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;border-radius:20px;display:inline-block;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 6px -1px #0000001a}.draft-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;margin-bottom:2rem}.draft-cube{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:2px solid rgba(255,255,255,.3);border-radius:24px;padding:2rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;text-align:center;position:relative;overflow:hidden;height:280px;display:flex;flex-direction:column;justify-content:space-between}.draft-cube:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#8b5cf6,#ec4899,#f59e0b);background-size:200% 100%}.draft-cube:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#ffffff80}.draft-cube.selected{border-color:#8b5cf6;background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(139,92,246,.05));transform:translateY(-8px);box-shadow:0 20px 25px -5px #8b5cf633,0 10px 10px -5px #8b5cf61a}.cube-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.cube-name{font-size:1.375rem;font-weight:700;color:#1e293b;margin:0}.timing-badge{color:#fff;padding:.5rem 1rem;border-radius:12px;font-size:.875rem;font-weight:700;text-transform:uppercase;background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 4px 6px -1px #8b5cf64d}.cube-description{color:#64748b;margin-bottom:1rem;line-height:1.6;font-size:.95rem;flex-grow:1}.cube-effect{background:rgba(139,92,246,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.25rem;border-radius:16px;font-size:.9rem;border:1px solid rgba(139,92,246,.2);margin-top:auto;color:#7c3aed}.cube-effect strong{color:#7c3aed;font-weight:600}.draft-actions{text-align:center;margin-bottom:2rem}.confirm-button{font-size:1.25rem;padding:1.25rem 3rem;border-radius:20px;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;font-weight:600;cursor:pointer;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.confirm-button.ready{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 6px -1px #10b9814d,0 2px 4px -1px #10b98133}.confirm-button.ready:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px #10b98133,0 10px 10px -5px #10b9811a}.confirm-button.disabled{background:#9ca3af;color:#6b7280;cursor:not-allowed;transform:none;box-shadow:none}.selected-cubes{background:linear-gradient(135deg,rgba(139,92,246,.1),rgba(139,92,246,.05));-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:2rem;border-radius:20px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid rgba(139,92,246,.2)}.selected-cubes h3{color:#7c3aed;margin-bottom:1.5rem;text-align:center;font-size:1.5rem;font-weight:700}.selected-cubes-list{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.selected-cube{background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 1.5rem;border-radius:16px;display:flex;align-items:center;gap:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid rgba(255,255,255,.3);transition:all .3s cubic-bezier(.4,0,.2,1)}.selected-cube:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.selected-cube .cube-name{font-size:.95rem;margin:0;color:#1e293b;font-weight:600}.selected-cube .timing-badge{font-size:.75rem;padding:.25rem .75rem}@media (max-width: 1400px){.draft{max-width:95vw;padding:1.5rem}.draft-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}}@media (max-width: 1024px){.draft{padding:1.5rem}.draft-header{flex-direction:column;gap:1.5rem;text-align:center;padding:1.5rem}.draft-header h2{font-size:2rem}.draft-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.draft-cube{height:260px;padding:1.5rem}}@media (max-width: 768px){.draft{padding:1rem}.draft-header{padding:1.5rem}.draft-header h2{font-size:1.75rem}.draft-grid{grid-template-columns:1fr;gap:1rem}.draft-cube{height:auto;min-height:240px}.confirm-button{font-size:1.125rem;padding:1rem 2.5rem}.draft-instructions{padding:1.5rem}.draft-instructions p{font-size:1rem}}@media (max-width: 480px){.draft{padding:.75rem}.draft-header{padding:1rem}.draft-header h2{font-size:1.5rem}.draft-cube,.draft-instructions{padding:1rem}.draft-instructions p{font-size:.95rem}.selection-counter{font-size:1rem;padding:.75rem 1.5rem}}.class-pick{width:100%;max-width:1400px;min-height:100vh;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);padding:2rem;color:#1e293b;position:relative;overflow-x:hidden;margin:0 auto;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.class-pick-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:2rem;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:24px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #ffffff0d;position:relative;overflow:hidden}.class-pick-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ec4899,#f59e0b,#10b981);border-radius:24px 24px 0 0}.class-pick-header h2{font-size:2.5rem;color:#1e293b;text-shadow:none;margin:0;font-weight:800;letter-spacing:-.025em}.class-timer{background:linear-gradient(135deg,#fef3c7,#fde68a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;border-radius:20px;border:1px solid #fbbf24;box-shadow:0 4px 6px -1px #0000001a}.class-timer .timer-label{font-weight:600;color:#92400e;margin-right:.5rem}.class-timer .timer-value{font-size:1.25rem;font-weight:700;color:#92400e}.class-timer .timer-value.urgent{color:#dc2626;animation:urgent-pulse 1s ease-in-out infinite}.class-pick-instructions{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);padding:2rem;border-radius:20px;margin-bottom:2rem;text-align:center;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #7dd3fc}.class-pick-instructions p{font-size:1.125rem;color:#0369a1;margin-bottom:1rem;font-weight:500}.selected-class-info{background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:16px;margin-top:1rem;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 6px -1px #0000001a}.selected-class-info h3{color:#10b981;margin-bottom:.5rem;text-shadow:none;font-weight:700}.selected-class-info p{color:#64748b;margin:0}.class-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:2rem;margin-bottom:2rem}.class-card{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:2px solid rgba(255,255,255,.3);border-radius:24px;padding:2rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;text-align:center;position:relative;overflow:hidden;height:320px;display:flex;flex-direction:column;justify-content:space-between}.class-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#ec4899,#f59e0b,#10b981);background-size:200% 100%}.class-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#ffffff80}.class-card.selected{border-color:#ec4899;background:linear-gradient(135deg,rgba(236,72,153,.1),rgba(236,72,153,.05));transform:translateY(-8px);box-shadow:0 20px 25px -5px #ec489933,0 10px 10px -5px #ec48991a}.class-icon{font-size:4rem;margin-bottom:1rem;text-shadow:none;color:#ec4899}.class-name{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:1rem;text-shadow:none}.class-description{color:#64748b;margin-bottom:1.5rem;line-height:1.6;font-size:.95rem;flex-grow:1}.class-ability{background:rgba(236,72,153,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.25rem;border-radius:16px;border:1px solid rgba(236,72,153,.2);margin-top:auto;color:#be185d}.class-ability strong{color:#be185d;display:block;margin-bottom:.5rem;font-weight:600}.class-ability p{color:#be185d;margin:0;font-size:.9rem}.class-pick-actions{text-align:center}.selection-hint{font-size:1.125rem;color:#10b981;font-weight:600;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1.5rem;border-radius:16px;border:1px solid rgba(255,255,255,.3);box-shadow:0 4px 6px -1px #0000001a}@media (max-width: 1400px){.class-pick{max-width:95vw;padding:1.5rem}.class-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}}@media (max-width: 1024px){.class-pick{padding:1.5rem}.class-pick-header{flex-direction:column;gap:1.5rem;text-align:center;padding:1.5rem}.class-pick-header h2{font-size:2rem}.class-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.class-card{height:280px;padding:1.5rem}}@media (max-width: 768px){.class-pick{padding:1rem}.class-pick-header{padding:1.5rem}.class-pick-header h2{font-size:1.75rem}.class-grid{grid-template-columns:1fr;gap:1rem}.class-card{height:auto;min-height:260px}.class-icon{font-size:3rem}.class-pick-instructions{padding:1.5rem}.class-pick-instructions p{font-size:1rem}}@media (max-width: 480px){.class-pick{padding:.75rem}.class-pick-header{padding:1rem}.class-pick-header h2{font-size:1.5rem}.class-card,.class-pick-instructions{padding:1rem}.class-pick-instructions p{font-size:.95rem}}.damage-animation{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;text-align:center;pointer-events:none;font-family:Arial,sans-serif;font-weight:700}.damage-animation.player{color:#4caf50;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.damage-animation.opponent{color:#f44336;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.damage-number{font-size:4rem;margin-bottom:.5rem;opacity:0;transform:scale(.5);transition:all .3s ease-out}.damage-label{font-size:1.2rem;opacity:0;transform:translateY(20px);transition:all .3s ease-out .2s}.damage-animation.animating .damage-number{opacity:1;transform:scale(1.2)}.damage-animation.animating .damage-label{opacity:1;transform:translateY(0)}.damage-animation:not(.animating) .damage-number{opacity:0;transform:scale(.8) translateY(-20px)}.damage-animation:not(.animating) .damage-label{opacity:0;transform:translateY(20px)}.damage-animation.player .damage-number[data-critical=true]{color:gold;animation:critical-pulse .5s ease-in-out}@keyframes critical-pulse{0%,to{transform:scale(1.2)}50%{transform:scale(1.5)}}.damage-animation.opponent .damage-number[data-protection=true]{color:#2196f3;animation:protection-shield .8s ease-in-out}@keyframes protection-shield{0%{transform:scale(1.2) rotate(0)}50%{transform:scale(1.3) rotate(180deg)}to{transform:scale(1.2) rotate(360deg)}}.ultimate-animation{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001;text-align:center;pointer-events:none;font-family:Arial,sans-serif;font-weight:700;opacity:0;transition:all .5s ease-out}.ultimate-animation.phase-1{opacity:1;transform:translate(-50%,-50%) scale(.5)}.ultimate-animation.phase-2{opacity:1;transform:translate(-50%,-50%) scale(1.2)}.ultimate-animation.phase-3{opacity:0;transform:translate(-50%,-50%) scale(1) translateY(-50px)}.ultimate-icon{font-size:5rem;margin-bottom:1rem;animation:icon-bounce .8s ease-in-out}.ultimate-text{font-size:2rem;margin-bottom:.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8);animation:text-glow .8s ease-in-out}.ultimate-class{font-size:1.5rem;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.8);animation:class-rotate .8s ease-in-out}.ultimate-animation.thief{background:linear-gradient(45deg,#9C27B0,#673AB7);padding:2rem;border-radius:20px;box-shadow:0 0 30px #9c27b0cc}.ultimate-animation.alchemist{background:linear-gradient(45deg,#4CAF50,#8BC34A);padding:2rem;border-radius:20px;box-shadow:0 0 30px #4caf50cc}.ultimate-animation.paladin{background:linear-gradient(45deg,#2196F3,#03A9F4);padding:2rem;border-radius:20px;box-shadow:0 0 30px #2196f3cc}.ultimate-animation.berserker{background:linear-gradient(45deg,#f44336,#FF5722);padding:2rem;border-radius:20px;box-shadow:0 0 30px #f44336cc}.ultimate-animation.gambler{background:linear-gradient(45deg,#FF9800,#FFC107);padding:2rem;border-radius:20px;box-shadow:0 0 30px #ff9800cc}@keyframes icon-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.3)}}@keyframes text-glow{0%,to{text-shadow:2px 2px 4px rgba(0,0,0,.8)}50%{text-shadow:0 0 20px rgba(255,255,255,.8),2px 2px 4px rgba(0,0,0,.8)}}@keyframes class-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ultimate-animation.thief .ultimate-icon{animation:thief-steal 1.2s ease-in-out}.ultimate-animation.alchemist .ultimate-icon{animation:alchemist-bubble 1.2s ease-in-out}.ultimate-animation.paladin .ultimate-icon{animation:paladin-shield 1.2s ease-in-out}.ultimate-animation.berserker .ultimate-icon{animation:berserker-rage 1.2s ease-in-out}.ultimate-animation.gambler .ultimate-icon{animation:gambler-spin 1.2s ease-in-out}@keyframes thief-steal{0%{transform:scale(1) translate(0)}25%{transform:scale(1.2) translate(-20px)}75%{transform:scale(1.2) translate(20px)}to{transform:scale(1) translate(0)}}@keyframes alchemist-bubble{0%{transform:scale(1)}50%{transform:scale(1.4) rotate(180deg)}to{transform:scale(1) rotate(360deg)}}@keyframes paladin-shield{0%{transform:scale(1) rotate(0)}50%{transform:scale(1.3) rotate(180deg)}to{transform:scale(1) rotate(360deg)}}@keyframes berserker-rage{0%{transform:scale(1)}25%{transform:scale(1.5) rotate(-10deg)}75%{transform:scale(1.5) rotate(10deg)}to{transform:scale(1) rotate(0)}}@keyframes gambler-spin{0%{transform:scale(1) rotate(0)}to{transform:scale(1.2) rotate(720deg)}}.damage-results{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:999;background:linear-gradient(135deg,#1e3c72,#2a5298);border-radius:20px;padding:2rem;box-shadow:0 0 40px #000c;color:#fff;font-family:Arial,sans-serif;min-width:400px;opacity:0;animation:results-fade-in .5s ease-out forwards}.results-header{text-align:center;margin-bottom:2rem;border-bottom:2px solid rgba(255,255,255,.3);padding-bottom:1rem}.results-header h2{margin:0;font-size:2rem;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.results-content{display:flex;flex-direction:column;gap:1.5rem}.player-result{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-radius:15px;opacity:0;transform:translate(-50px);transition:all .8s ease-out}.player-result.visible{opacity:1;transform:translate(0)}.player-result.p1{background:linear-gradient(45deg,#4CAF50,#8BC34A);border-left:5px solid #2E7D32}.player-result.p2{background:linear-gradient(45deg,#f44336,#FF5722);border-left:5px solid #C62828}.player-label{font-size:1.2rem;font-weight:700;color:#fff}.damage-value{font-size:2rem;font-weight:700;color:gold;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.ultimate-indicator{font-size:1.5rem;animation:ultimate-pulse 1s ease-in-out infinite}.total-stats{text-align:center;padding:1.5rem;background:rgba(255,255,255,.1);border-radius:15px;border:2px solid rgba(255,255,255,.3);opacity:0;transform:scale(.8);transition:all .8s ease-out}.total-stats.visible{opacity:1;transform:scale(1)}.total-damage{font-size:1.5rem;font-weight:700;color:gold;margin-bottom:1rem}.round-summary{font-size:1.3rem;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8)}@keyframes results-fade-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes ultimate-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (max-width: 600px){.damage-results{min-width:300px;padding:1.5rem}.results-header h2,.damage-value{font-size:1.5rem}.player-label{font-size:1rem}}.gambler-result{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1002;background:linear-gradient(135deg,#FF9800,#FFC107);border-radius:25px;padding:2.5rem;box-shadow:0 0 50px #ff9800cc;color:#fff;font-family:Arial,sans-serif;min-width:450px;text-align:center;opacity:0;animation:gambler-fade-in .6s ease-out forwards}.gambler-header{margin-bottom:2rem}.gambler-icon{font-size:4rem;margin-bottom:1rem;animation:gambler-bounce 1s ease-in-out infinite}.gambler-header h2{margin:0;font-size:2.2rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.gambler-content{display:flex;flex-direction:column;gap:1.5rem}.old-subtotal{font-size:1.5rem;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.old-subtotal .value{font-weight:700;color:gold;font-size:2rem}.result-arrow{font-size:3rem;color:gold;animation:arrow-bounce 1s ease-in-out infinite}.new-subtotal{font-size:2rem;font-weight:700;padding:1rem;border-radius:15px;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.new-subtotal.success{background:linear-gradient(45deg,#4CAF50,#8BC34A);color:#fff;animation:success-pulse .8s ease-in-out}.new-subtotal.fail{background:linear-gradient(45deg,#f44336,#FF5722);color:#fff;animation:fail-shake .8s ease-in-out}.final-value{font-size:2.5rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.final-value.success{color:#4caf50;animation:value-glow 1s ease-in-out infinite}.final-value.fail{color:#f44336;animation:value-fade 1s ease-in-out infinite}.result-message{font-size:1.3rem;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8);padding:1rem;background:rgba(255,255,255,.1);border-radius:15px;border:2px solid rgba(255,255,255,.3)}@keyframes gambler-fade-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.5) rotate(-10deg)}to{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0)}}@keyframes gambler-bounce{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.2) translateY(-10px)}}@keyframes arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes success-pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes fail-shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@keyframes value-glow{0%,to{text-shadow:2px 2px 4px rgba(0,0,0,.8)}50%{text-shadow:0 0 20px rgba(76,175,80,.8),2px 2px 4px rgba(0,0,0,.8)}}@keyframes value-fade{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 600px){.gambler-result{min-width:350px;padding:2rem}.gambler-header h2{font-size:1.8rem}.gambler-icon{font-size:3rem}.final-value{font-size:2rem}}.alchemist-replace{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1003;background:linear-gradient(135deg,#4CAF50,#8BC34A);border-radius:25px;padding:2.5rem;box-shadow:0 0 50px #4caf50cc;color:#fff;font-family:Arial,sans-serif;min-width:500px;text-align:center;opacity:0;animation:alchemist-fade-in .6s ease-out forwards}.replace-header{margin-bottom:2rem}.alchemist-icon{font-size:4rem;margin-bottom:1rem;animation:alchemist-bounce 1s ease-in-out infinite}.replace-header h2{margin:0 0 .5rem;font-size:2.2rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.8)}.replace-header p{margin:0;font-size:1.2rem;color:#e8f5e8;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.dice-selection{margin-bottom:2rem}.dice-selection h3{margin:0 0 1rem;font-size:1.5rem;color:gold;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.dice-container{display:flex;justify-content:center;gap:1rem;margin-bottom:1rem}.die-option{width:60px;height:60px;border:3px solid rgba(255,255,255,.5);border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;background:rgba(255,255,255,.2);cursor:pointer;transition:all .3s ease;color:#333}.die-option:hover{transform:scale(1.1);border-color:gold;background:rgba(255,255,255,.4)}.die-option.selected{border-color:gold;background:#FFD700;color:#333;transform:scale(1.1);box-shadow:0 0 20px #ffd700cc}.value-selection{margin-bottom:2rem}.value-selection h3{margin:0 0 1rem;font-size:1.5rem;color:gold;text-shadow:1px 1px 2px rgba(0,0,0,.8)}.value-buttons{display:flex;justify-content:center;gap:1rem}.value-btn{padding:1rem 1.5rem;border:none;border-radius:15px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;background:rgba(255,255,255,.2);color:#fff;border:2px solid rgba(255,255,255,.3)}.value-btn:hover{transform:scale(1.05);background:rgba(255,255,255,.3)}.value-btn.selected{background:#FFD700;color:#333;border-color:gold;box-shadow:0 0 15px #ffd70099}.replace-actions{display:flex;justify-content:center;gap:1rem}.replace-btn,.cancel-btn{padding:1rem 2rem;border:none;border-radius:15px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease}.replace-btn{background:linear-gradient(45deg,#FFD700,#FFA000);color:#333;box-shadow:0 0 20px #ffd70099}.replace-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 0 25px #ffd700cc}.replace-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.cancel-btn{background:linear-gradient(45deg,#f44336,#FF5722);color:#fff;box-shadow:0 0 20px #f4433699}.cancel-btn:hover{transform:scale(1.05);box-shadow:0 0 25px #f44336cc}@keyframes alchemist-fade-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.5) rotate(-5deg)}to{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0)}}@keyframes alchemist-bounce{0%,to{transform:scale(1) translateY(0)}50%{transform:scale(1.1) translateY(-10px)}}@media (max-width: 600px){.alchemist-replace{min-width:350px;padding:2rem}.replace-header h2{font-size:1.8rem}.alchemist-icon{font-size:3rem}.dice-container{flex-wrap:wrap}.value-buttons{flex-direction:column}}.damage-calculation{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;z-index:9999;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;animation:damage-calc-fade-in .3s ease-out}@keyframes damage-calc-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.damage-calculation-content{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-radius:32px;padding:3rem;max-width:800px;width:90%;text-align:center;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a;position:relative;overflow:hidden;color:#1e293b}.damage-calculation-content:before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:linear-gradient(90deg,#ef4444,#f59e0b,#10b981,#3b82f6);border-radius:32px 32px 0 0}.damage-calculation-header{margin-bottom:2rem}.damage-calculation-header h2{font-size:2.5rem;font-weight:800;color:#1e293b;margin:0 0 1rem;letter-spacing:-.025em}.damage-calculation-header .phase-icon{font-size:3rem;margin-bottom:1rem;display:block}.damage-numbers{display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center;margin:2rem 0}.player-damage,.opponent-damage{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #e2e8f0;border-radius:24px;padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.player-damage{border-color:#10b981}.opponent-damage{border-color:#ef4444}.player-damage:before,.opponent-damage:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#059669);border-radius:24px 24px 0 0}.opponent-damage:before{background:linear-gradient(90deg,#ef4444,#dc2626)}.player-damage:hover,.opponent-damage:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.player-label,.opponent-label{font-size:1.125rem;font-weight:600;color:#64748b;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em}.damage-number{font-size:3rem;font-weight:800;color:#1e293b;margin:.5rem 0;letter-spacing:-.025em}.player-damage .damage-number{color:#059669}.opponent-damage .damage-number{color:#dc2626}.hp-value{font-size:1rem;color:#64748b;font-weight:500;margin-top:.5rem}.vs-section{display:flex;flex-direction:column;align-items:center;gap:1rem}.vs-text{font-size:2rem;font-weight:800;color:#8b5cf6;margin:0;letter-spacing:-.025em}.vs-line{width:2px;height:60px;background:linear-gradient(180deg,#8b5cf6,#ec4899);border-radius:1px}.ultimate-usage{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24;border-radius:20px;padding:1.5rem;margin:2rem 0;color:#92400e}.ultimate-usage h3{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:#92400e}.ultimate-usage p{font-size:1rem;margin:0;color:#92400e;font-weight:500}.ultimate-usage .ultimate-icon{font-size:2rem;margin-bottom:.75rem;display:block}@media (max-width: 800px){.damage-calculation-content{padding:2rem;margin:1rem}.damage-calculation-header h2{font-size:2rem}.damage-numbers{grid-template-columns:1fr;gap:1.5rem}.vs-section{order:-1;margin-bottom:1rem}.vs-text{font-size:1.5rem}.vs-line{height:40px}.damage-number{font-size:2.5rem}}@media (max-width: 600px){.damage-calculation-content{padding:1.5rem;margin:.5rem}.damage-calculation-header h2{font-size:1.75rem}.damage-calculation-header .phase-icon{font-size:2.5rem}.player-damage,.opponent-damage{padding:1.5rem}.damage-number{font-size:2rem}.player-label,.opponent-label{font-size:1rem}.ultimate-usage{padding:1rem}.ultimate-usage h3{font-size:1.125rem}}@media (max-width: 480px){.damage-calculation-content{padding:1rem;margin:.25rem;border-radius:24px}.damage-calculation-header h2{font-size:1.5rem}.damage-calculation-header .phase-icon{font-size:2rem}.player-damage,.opponent-damage{padding:1rem}.damage-number{font-size:1.75rem}.vs-text{font-size:1.25rem}.vs-line{height:30px}}.game-board{width:100%;max-width:1400px;min-height:100vh;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem;color:#1e293b;position:relative;overflow-x:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.game-board-container{min-height:100vh;background:linear-gradient(135deg,#f1f5f9 0%,#e2e8f0 100%);padding:1rem;display:flex;align-items:flex-start;justify-content:center;position:relative}.game-header{background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);border-radius:24px;padding:2rem;text-align:center;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f,0 0 0 1px #ffffff0d;position:relative;overflow:hidden}.game-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#ec4899);border-radius:24px 24px 0 0}.game-header h2{margin:0 0 1.5rem;font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#1e40af,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.025em}.player-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}.player-hp,.opponent-hp{background:rgba(255,255,255,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:1.5rem;font-weight:600;font-size:1.1rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.player-hp{border-left:4px solid #10b981}.opponent-hp{border-left:4px solid #ef4444}.player-hp:hover,.opponent-hp:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.game-info{display:grid;grid-template-columns:repeat(6,1fr);gap:1.5rem;margin-bottom:2rem;min-height:120px}.game-info>div{background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:1.5rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.game-info>div:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.game-info strong{color:#64748b;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:block;margin-bottom:.75rem}.game-info br+*{margin-top:.5rem;font-size:1.25rem;color:#1e293b;font-weight:700}.round-timer{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:1px solid #86efac}.round-timer .timer-value{font-size:1.5rem;font-weight:800;color:#059669}.round-timer .timer-value.urgent{color:#dc2626;animation:urgent-pulse 1s ease-in-out infinite}@keyframes urgent-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.ultimate-status{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24}.ultimate-status .used{color:#059669;font-weight:700}.ultimate-status .available{color:#d97706;font-weight:700;animation:available-pulse 2s ease-in-out infinite}@keyframes available-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.farkle-message{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;border-radius:16px;padding:1.5rem;margin:1.5rem 0;font-size:1.125rem;color:#991b1b;text-align:center;box-shadow:0 4px 6px -1px #0000001a;animation:farkle-shake .8s ease-in-out;min-height:80px;display:flex;align-items:center;justify-content:center}.farkle-message strong{color:#dc2626;font-weight:700}@keyframes farkle-shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.dice-result{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-radius:24px;padding:2.5rem;text-align:center;margin:2rem 0;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;min-height:200px;display:flex;flex-direction:column;justify-content:center}.dice-result h3{margin-bottom:1.5rem;color:#1e293b;font-size:1.875rem;font-weight:700;letter-spacing:-.025em}.scoring-hint{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:16px;padding:1.5rem;margin:1.5rem 0;font-size:1rem;color:#1e40af;text-align:center;box-shadow:0 4px 6px -1px #0000001a}.scoring-hint strong{color:#1d4ed8;font-weight:700}.dice-container{display:grid;grid-template-columns:repeat(6,1fr);gap:1.5rem;margin:2rem 0;max-width:600px;margin-left:auto;margin-right:auto}.die{width:70px;height:70px;background:linear-gradient(135deg,#ffffff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;color:#475569;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.die:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#3b82f6}.die.selected{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;transform:scale(1.1);box-shadow:0 0 #10b981b3,0 0 #10b981b3;animation:selected-pulse 2s infinite}@keyframes selected-pulse{0%{box-shadow:0 0 #10b981b3,0 0 #10b981b3}70%{box-shadow:0 0 0 10px #10b98100,0 0 0 20px #10b98100}to{box-shadow:0 0 #10b98100,0 0 #10b98100}}.confirm-selection-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:1rem 2rem;border-radius:16px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin:1.5rem 0;position:relative;overflow:hidden}.confirm-selection-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.confirm-selection-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.game-controls{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.3);border-radius:24px;padding:2rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin-top:auto;min-height:120px}.control-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1rem}.roll-btn,.bank-btn,.continue-btn,.ult-btn{padding:1.25rem 1.5rem;border:none;border-radius:16px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:60px;display:flex;align-items:center;justify-content:center;gap:.75rem;position:relative;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.roll-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.bank-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.continue-btn{background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff}.ult-btn{background:linear-gradient(135deg,#ec4899,#be185d);color:#fff}.roll-btn:hover:not(:disabled),.bank-btn:hover:not(:disabled),.continue-btn:hover:not(:disabled),.ult-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.roll-btn:disabled,.bank-btn:disabled,.continue-btn:disabled,.ult-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.ult-used-info{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px solid #d1d5db;border-radius:16px;color:#374151;text-align:center;box-shadow:0 4px 6px -1px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.ult-used-info:hover{transform:scale(1.02);box-shadow:0 10px 15px -3px #0000001a}.ult-used-icon{font-size:2rem;animation:ult-used-pulse 2s ease-in-out infinite}.ult-used-text strong{font-size:1.125rem;color:#111827;font-weight:600}.ult-used-text small{font-size:.875rem;color:#6b7280;opacity:.9}@keyframes ult-used-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.debug-info,.debug-hp-info,.debug-damage-calculation{background:rgba(0,0,0,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:15px;padding:1.5rem;margin:1.5rem 0;font-family:Courier New,monospace;font-size:.9rem;color:#e0e0e0;max-height:300px;overflow-y:auto}.debug-info p,.debug-hp-info div,.debug-damage-calculation div{margin:.5rem 0;padding:.3rem 0;border-bottom:1px solid rgba(255,255,255,.1)}@media (max-width: 1400px){.game-board{max-width:95vw;padding:1.5rem}.game-info{grid-template-columns:repeat(3,1fr);gap:1rem}.control-buttons{grid-template-columns:repeat(2,1fr);gap:1rem}}@media (max-width: 1024px){.game-board{padding:1rem;gap:1.5rem}.game-header h2{font-size:2rem}.dice-container{grid-template-columns:repeat(3,1fr);gap:1rem}.die{width:60px;height:60px;font-size:1.5rem}.control-buttons{grid-template-columns:1fr;gap:1rem}}@media (max-width: 768px){.game-board{padding:1rem;gap:1rem}.game-header{padding:1.5rem}.game-header h2{font-size:1.75rem}.player-info{grid-template-columns:1fr;gap:1rem}.game-info,.dice-container{grid-template-columns:repeat(2,1fr);gap:1rem}.die{width:50px;height:50px;font-size:1.25rem}.roll-btn,.bank-btn,.continue-btn,.ult-btn{padding:1rem 1.25rem;font-size:1rem;min-height:56px}.dice-result{padding:1.5rem}.dice-result h3{font-size:1.5rem}}@media (max-width: 480px){.game-board{padding:.75rem;gap:.75rem}.game-header{padding:1rem}.game-header h2{font-size:1.5rem}.game-info{grid-template-columns:1fr}.dice-container{grid-template-columns:repeat(2,1fr);gap:.75rem}.die{width:45px;height:45px;font-size:1.125rem}.roll-btn,.bank-btn,.continue-btn,.ult-btn{padding:.875rem 1rem;font-size:.875rem;min-height:48px}}.match-end-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(0,0,0,.9) 0%,rgba(20,20,40,.95) 100%);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .5s ease-out}.match-end-modal{background:linear-gradient(145deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);border-radius:20px;padding:40px;max-width:600px;width:90%;box-shadow:0 20px 60px #00000080;border:2px solid rgba(255,255,255,.1);animation:slideUp .6s ease-out}.result-header{text-align:center;margin-bottom:30px;padding:20px;border-radius:15px;position:relative;overflow:hidden}.result-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:shimmer 2s infinite}.result-header.win{background:linear-gradient(135deg,#4ade80 0%,#22c55e 50%,#16a34a 100%);color:#fff}.result-header.lose{background:linear-gradient(135deg,#f87171 0%,#ef4444 50%,#dc2626 100%);color:#fff}.result-header.draw{background:linear-gradient(135deg,#94a3b8 0%,#64748b 50%,#475569 100%);color:#fff}.result-icon{font-size:4rem;margin-bottom:15px;animation:bounce 1s ease-in-out}.result-title{font-size:2.5rem;font-weight:700;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.match-stats{margin-bottom:30px}.stat-section h3{color:#e2e8f0;text-align:center;margin-bottom:20px;font-size:1.5rem}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:25px}.stat-item{background:rgba(255,255,255,.05);padding:15px;border-radius:10px;border:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.stat-label{color:#cbd5e1;font-size:.9rem}.stat-value{color:#f1f5f9;font-weight:700;font-size:1.1rem}.player-info{display:flex;align-items:center;justify-content:center;gap:20px;margin-bottom:30px}.player-card{background:rgba(255,255,255,.05);border-radius:15px;padding:20px;text-align:center;border:2px solid rgba(255,255,255,.1);min-width:150px;transition:transform .3s ease,box-shadow .3s ease}.player-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000004d}.player-card.opponent{border-color:#ef44444d}.player-avatar{font-size:3rem;margin-bottom:10px}.player-name{color:#f1f5f9;font-weight:700;font-size:1.1rem;margin-bottom:5px}.player-class{color:#94a3b8;font-size:.9rem;margin-bottom:8px}.player-hp{color:#22c55e;font-weight:700;font-size:1rem}.vs-separator{color:#64748b;font-weight:700;font-size:1.5rem;padding:10px;background:rgba(255,255,255,.05);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center}.match-actions{display:flex;gap:15px;justify-content:center;margin-bottom:25px}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;min-width:140px}.btn-primary{background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#2563eb 0%,#1e40af 100%);transform:translateY(-2px);box-shadow:0 8px 25px #3b82f666}.btn-secondary{background:rgba(255,255,255,.1);color:#e2e8f0;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:rgba(255,255,255,.15);transform:translateY(-2px)}.match-footer{text-align:center;color:#94a3b8;font-size:.9rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (max-width: 768px){.match-end-modal{padding:25px;margin:20px}.result-title{font-size:2rem}.stat-grid{grid-template-columns:1fr}.player-info{flex-direction:column;gap:15px}.match-actions{flex-direction:column;align-items:center}.btn-primary,.btn-secondary{width:100%;max-width:250px}}.error-display{position:fixed;top:20px;right:20px;z-index:1000;animation:slideIn .3s ease-out}.error-content{background:linear-gradient(45deg,#f44336,#d32f2f);color:#fff;padding:1rem 1.5rem;border-radius:10px;box-shadow:0 4px 15px #f4433666;display:flex;align-items:center;gap:1rem;min-width:300px;max-width:400px}.error-icon{font-size:1.5rem;flex-shrink:0}.error-message{flex:1;font-weight:500;line-height:1.4}.error-close{background:rgba(255,255,255,.2);border:none;color:#fff;padding:.5rem;border-radius:50%;cursor:pointer;transition:all .3s ease;flex-shrink:0}.error-close:hover{background:rgba(255,255,255,.3);transform:scale(1.1)}@media (max-width: 768px){.error-display{top:10px;right:10px;left:10px}.error-content{min-width:auto;max-width:none}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;color:#333}.App{text-align:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:0;margin:0}.App-header{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:20px;color:#fff;box-shadow:0 2px 20px #0000001a;position:sticky;top:0;z-index:100}.App-header h1{margin:0 0 15px;font-size:2.5rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.connection-status{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.connected,.disconnected{padding:8px 16px;border-radius:20px;font-weight:600;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.connected{background:rgba(76,175,80,.2);color:#4caf50;border:1px solid rgba(76,175,80,.3)}.disconnected{background:rgba(244,67,54,.2);color:#f44336;border:1px solid rgba(244,67,54,.3)}.App-main{flex:1;padding:20px;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}button{background:linear-gradient(45deg,#4CAF50,#45a049);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #4caf504d}button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}button.secondary{background:linear-gradient(45deg,#2196F3,#1976D2);box-shadow:0 4px 15px #2196f34d}button.secondary:hover:not(:disabled){box-shadow:0 6px 20px #2196f366}button.danger{background:linear-gradient(45deg,#f44336,#d32f2f);box-shadow:0 4px 15px #f443364d}button.danger:hover:not(:disabled){box-shadow:0 6px 20px #f4433666}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.fade-in{animation:fadeIn .5s ease-out}.slide-in{animation:slideIn .3s ease-out}.pulse{animation:pulse 2s infinite}@media (max-width: 768px){.App-header{padding:15px}.App-header h1{font-size:2rem}.connection-status{gap:15px}.connected,.disconnected{padding:6px 12px;font-size:12px}.App-main{padding:15px}}@media (max-width: 480px){.App-header{padding:10px}.App-header h1{font-size:1.5rem}.connection-status{flex-direction:column;gap:10px}.App-main{padding:10px}}: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;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
