:root{--bg-dark: #0a0a12;--bg-gradient: radial-gradient(ellipse at top center, #1a0a0a 0%, #0a0a12 60%, #0a0a12 100%);--primary: #ff3a3a;--primary-hover: #e02020;--primary-glow: rgba(255, 58, 58, .4);--secondary: #ff8c00;--secondary-glow: rgba(255, 140, 0, .4);--accent: #ffd700;--danger: #ff1744;--glass-bg: rgba(255, 255, 255, .03);--glass-border: rgba(255, 255, 255, .08);--glass-blur: blur(12px);--text-main: #f8fafc;--text-dim: #94a3b8;--text-muted: #64748b;--radius-lg: 4px;--radius-xl: 4px;--radius-md: 4px;--radius-sm: 2px;--shadow-neon: 0 0 20px var(--primary-glow);--space-xs: 8px;--space-sm: 16px;--space-md: 24px;--space-lg: 40px;--space-xl: 48px;--font-heading: "Rajdhani", sans-serif;--font-body: "Inter", sans-serif;--font-accent: "Orbitron", sans-serif}[data-theme=light]{--bg-dark: #f0f0f8;--bg-gradient: radial-gradient(ellipse at top center, #fff0f0 0%, #f0f0f8 60%, #f0f0f8 100%);--glass-bg: rgba(255, 255, 255, .75);--glass-border: rgba(0, 0, 0, .1);--glass-blur: blur(12px);--text-main: #1a1a2e;--text-dim: #4a5568;--text-muted: #718096}[data-theme=light] body{background:var(--bg-dark);background-image:var(--bg-gradient);color:var(--text-main)}[data-theme=light] .form-input{color:var(--text-main);background:#00000008;border-bottom-color:#00000026}[data-theme=light] .form-input::placeholder{color:var(--text-muted)}[data-theme=light] .btn-secondary{background:#0000000f;color:var(--text-main);border-color:#0000001f}[data-theme=light] .btn-secondary:hover{background:#ff3a3a14;color:var(--text-main)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--bg-dark);background-image:var(--bg-gradient);background-attachment:fixed;color:var(--text-main);min-height:100vh;line-height:1.6;overflow-x:hidden}.app-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:var(--space-md)}.content-box{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 8px 32px #000c;text-align:center;max-width:450px;width:100%;position:relative;clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px))}.content-box:after{content:"";position:absolute;top:0;right:0;width:24px;height:2px;background:var(--primary);transform:rotate(-45deg);transform-origin:top right}.wide-content-box{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 8px 32px #000c;max-width:1000px;width:100%;margin:var(--space-md) auto;position:relative;clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px))}.btn{border:none;padding:12px 28px;font-size:1rem;font-weight:700;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-family:var(--font-heading);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;letter-spacing:1.5px;text-transform:uppercase;position:relative;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;box-shadow:0 0 15px var(--primary-glow)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-hover),#e07000);transform:translateY(-2px) scale(1.03);box-shadow:0 0 30px var(--primary-glow),0 0 60px #ff8c0033}.btn-secondary{background:#ffffff0d;color:#fff;border:1px solid rgba(255,255,255,.1)}.btn-secondary:hover{background:#ff3a3a1a;transform:translateY(-2px);border-color:var(--primary);box-shadow:0 0 20px var(--primary-glow)}.btn-large{padding:16px 40px;font-size:1.1rem}.btn-medium{padding:12px 24px}.btn-small{padding:8px 16px;font-size:.875rem}.form-group{margin-bottom:var(--space-md);text-align:left}.form-input{width:100%;padding:15px 20px;font-size:1rem;border:none;border-bottom:3px solid rgba(255,255,255,.1);border-radius:0;background:#ffffff08;color:var(--text-main);transition:all .3s ease;font-family:var(--font-body)}.form-input:focus{outline:none;border-bottom-color:var(--primary);box-shadow:0 4px 12px var(--primary-glow);background:#ff3a3a08}.form-input::placeholder{color:var(--text-muted)}.page-title{color:var(--text-main);font-size:2.5rem;font-weight:700;font-family:var(--font-heading);margin-bottom:var(--space-md);text-transform:uppercase;letter-spacing:2px;-webkit-text-stroke:1px rgba(255,58,58,.3)}.section-title{color:var(--text-main);font-size:1.8rem;font-weight:700;font-family:var(--font-heading);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:1px}.subtitle{color:var(--text-dim);font-size:1.1rem;margin-bottom:var(--space-lg);line-height:1.6}.text-muted{color:var(--text-muted);font-size:.875rem}.text-center{text-align:center}.link{color:var(--primary);text-decoration:none;font-weight:700;transition:color .3s ease}.link:hover{color:var(--secondary);text-decoration:underline}.error-message{background:linear-gradient(135deg,var(--danger),#c82333);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-weight:500;text-align:center;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}.success-message{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-weight:500;text-align:center;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}.icon-bounce{font-size:4rem;margin-bottom:var(--space-md);animation:energy-pulse 2s infinite}@keyframes energy-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 8px var(--primary-glow))}50%{transform:scale(1.1);filter:drop-shadow(0 0 25px var(--primary-glow)) drop-shadow(0 0 50px var(--secondary-glow))}}@keyframes slash-in{0%{clip-path:polygon(0 0,0 0,0 100%,0 100%);opacity:0}50%{opacity:1}to{clip-path:polygon(0 0,100% 0,100% 100%,0 100%);opacity:1}}@keyframes impact-shake{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)}90%{transform:translate(0)}}@keyframes speed-lines{0%{background-position:0% 0%}to{background-position:0% 100%}}.fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width: 768px){.content-box,.wide-content-box{padding:var(--space-lg) var(--space-md);margin:var(--space-md);width:calc(100% - var(--space-lg))}.page-title{font-size:1.8rem}.section-title{font-size:1.4rem}.btn{padding:12px 25px;font-size:1rem;min-width:120px}.btn-large{padding:15px 30px;font-size:1.05rem;min-width:160px}}@media (max-width: 480px){.content-box,.wide-content-box{padding:var(--space-md) var(--space-sm);margin:var(--space-sm);width:calc(100% - var(--space-md))}.form-input{padding:12px 16px}}.navbar{background:var(--surface-primary);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);padding:var(--spacing-xs) 0;position:fixed;top:0;width:100%;z-index:1000;box-shadow:var(--shadow-light)}.game-container{background:var(--wide-content-box);min-height:calc(100vh - 120px);padding:var(--spacing-lg)}.game-board{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-md);padding:var(--spacing-md);gap:var(--spacing-lg)}.player-section{flex:1;text-align:center;padding:var(--spacing-md);border-radius:var(--border-radius-sm);background:var(--surface-secondary);border:1px solid rgba(108,117,125,.2)}.dice{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;justify-content:center;margin-top:var(--spacing-sm)}.actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-top:var(--spacing-lg);flex-wrap:wrap}@media (max-width: 768px){.lobby-layout{grid-template-columns:1fr;gap:var(--spacing-md)}.lobby-title{font-size:var(--font-size-3xl)}.game-board{flex-direction:column;gap:var(--spacing-md)}.actions{gap:var(--spacing-sm)}.dice{gap:var(--spacing-xs)}.dice button{min-width:45px;min-height:45px;padding:var(--spacing-xs)}}@media (max-width: 480px){.lobby-container,.history-panel,.matchmaking-panel{padding:var(--spacing-sm)}.dice button{min-width:40px;min-height:40px}}.notification-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.notification-toast{background:#0a0a12f2;color:#fff;padding:12px 20px;border-radius:var(--radius-sm, 2px);box-shadow:0 4px 20px #00000080;border:1px solid rgba(255,58,58,.1);font-size:.95rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:toast-slash-in .3s ease-out;cursor:pointer;min-width:250px;max-width:400px;pointer-events:auto;display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--font-heading, "Rajdhani", sans-serif);clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}.notification-toast.success{border-left:3px solid var(--accent, #ffd700);box-shadow:0 4px 20px #00000080,0 0 15px #ffd7001a}.notification-toast.error{border-left:3px solid var(--danger, #ff1744);box-shadow:0 4px 20px #00000080,0 0 15px #ff17441a}.notification-toast.warning{border-left:3px solid var(--secondary, #ff8c00);box-shadow:0 4px 20px #00000080,0 0 15px #ff8c001a}.notification-toast.info{border-left:3px solid var(--primary, #ff3a3a);box-shadow:0 4px 20px #00000080,0 0 15px #ff3a3a1a}@keyframes toast-slash-in{0%{transform:translate(100%);opacity:0;clip-path:polygon(100% 0,100% 0,100% 100%,100% 100%)}to{transform:translate(0);opacity:1;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}}.die-container-svg{position:relative;width:85px;height:85px;display:flex;align-items:center;justify-content:center;border:none!important;background:transparent!important;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);padding:0;margin:var(--space-sm);overflow:visible;filter:drop-shadow(0 10px 15px rgba(0,0,0,.3));color:#fff}.die-visual-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.die-svg{width:100%;height:100%;display:block;transition:all .3s ease}.die-content-svg{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5;pointer-events:none;transition:transform .3s ease}.die-value-svg{font-size:1.8rem;font-weight:900;line-height:1;color:#1a202c;letter-spacing:-1px;text-shadow:0 1px 0 rgba(255,255,255,.5)}.die-size-svg{font-size:.7rem;font-weight:800;opacity:.6;text-transform:uppercase;color:#4a5568;letter-spacing:.5px}.die-container-svg:hover:not(:disabled){transform:translateY(-10px) scale(1.15);filter:drop-shadow(0 20px 30px rgba(255,58,58,.3));animation:die-shake .3s ease-in-out}@keyframes die-shake{0%,to{transform:translateY(-10px) scale(1.15) rotate(0)}25%{transform:translateY(-10px) scale(1.15) rotate(3deg)}75%{transform:translateY(-10px) scale(1.15) rotate(-3deg)}}.die-container-svg:active:not(:disabled){transform:translateY(-2px) scale(1.05)}.die-container-svg.selected{color:var(--primary);filter:drop-shadow(0 0 25px var(--primary-glow)) drop-shadow(0 0 50px rgba(255,58,58,.3));animation:selected-energy 2s ease-in-out infinite;z-index:10}.die-container-svg.selected .die-value-svg{color:#fff;text-shadow:0 0 15px var(--primary-glow)}.die-container-svg.selected .die-size-svg{color:#fff;opacity:.8}.die-container-svg.target{color:var(--secondary);filter:drop-shadow(0 0 25px var(--secondary-glow)) drop-shadow(0 0 50px rgba(255,140,0,.3));animation:target-energy 2s ease-in-out infinite;z-index:10}.die-container-svg.target .die-value-svg{color:#fff;text-shadow:0 0 15px var(--secondary-glow)}.die-container-svg.target .die-size-svg{color:#fff;opacity:.8}.die-container-svg.disabled{cursor:default;opacity:.4;filter:grayscale(.8) opacity(.5);pointer-events:none}@keyframes selected-energy{0%,to{transform:translateY(-6px) scale(1.08);filter:drop-shadow(0 0 20px var(--primary-glow))}50%{transform:translateY(-14px) scale(1.12);filter:drop-shadow(0 0 35px var(--primary-glow)) drop-shadow(0 0 60px rgba(255,140,0,.2))}}@keyframes target-energy{0%,to{transform:translateY(0) scale(1);filter:drop-shadow(0 0 15px var(--secondary-glow))}50%{transform:translateY(-8px) scale(1.05);filter:drop-shadow(0 0 30px var(--secondary-glow)) drop-shadow(0 0 50px rgba(255,58,58,.2))}}.die-container-svg.rolling{animation:die-roll-spin .8s cubic-bezier(.2,.6,.4,1) infinite;z-index:15;color:var(--primary, #ff3a3a);filter:drop-shadow(0 0 20px rgba(255,58,58,.5)) drop-shadow(0 0 40px rgba(255,140,0,.3));pointer-events:none}.die-container-svg.rolling .die-value-svg{color:#fff;text-shadow:0 0 10px rgba(255,58,58,.8);font-family:var(--font-accent, "Orbitron", sans-serif)}.die-container-svg.rolling .die-size-svg{opacity:0}@keyframes die-roll-spin{0%{transform:translateY(0) scale(1) rotate(0)}15%{transform:translateY(-30px) scale(1.2) rotate(40deg)}30%{transform:translateY(-20px) scale(1.1) rotate(-30deg)}50%{transform:translateY(-35px) scale(1.25) rotate(20deg)}70%{transform:translateY(-15px) scale(1.1) rotate(-15deg)}85%{transform:translateY(-25px) scale(1.15) rotate(10deg)}to{transform:translateY(0) scale(1) rotate(0)}}.die-container-svg.roll-landing{animation:die-land-impact .4s ease-out forwards}@keyframes die-land-impact{0%{transform:translateY(-20px) scale(1.3);filter:drop-shadow(0 0 40px rgba(255,215,0,.8)) drop-shadow(0 0 80px rgba(255,58,58,.5))}40%{transform:translateY(4px) scale(.95)}70%{transform:translateY(-2px) scale(1.02)}to{transform:translateY(0) scale(1);filter:drop-shadow(0 10px 15px rgba(0,0,0,.3))}}.die-container-svg.captured{animation:die-captured-shatter .6s ease-in forwards;pointer-events:none;z-index:20}.die-container-svg.captured .die-value-svg{color:#fff;text-shadow:0 0 20px rgba(255,23,68,1)}@keyframes die-captured-shatter{0%{transform:scale(1);opacity:1;filter:drop-shadow(0 0 10px rgba(255,23,68,.3))}20%{transform:scale(1.3);filter:drop-shadow(0 0 30px rgba(255,23,68,.8)) drop-shadow(0 0 60px rgba(255,140,0,.5))}40%{transform:scale(1.4) rotate(5deg);opacity:.9;filter:drop-shadow(0 0 50px rgba(255,215,0,.8)) drop-shadow(0 0 80px rgba(255,58,58,.6))}to{transform:scale(0) rotate(30deg);opacity:0;filter:drop-shadow(0 0 0px transparent)}}.game-container{width:100%;max-width:1400px;margin:0 auto;padding:120px 20px 40px;min-height:100vh;box-sizing:border-box}.battle-board{display:grid;grid-template-columns:1fr 340px 1fr;gap:var(--space-lg);align-items:center;margin-bottom:var(--space-xl)}.player-zone{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-xl);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);min-height:480px;transition:all .3s ease;position:relative;overflow:hidden;clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,20px 100%,0 calc(100% - 20px))}.player-zone:before{content:"";position:absolute;top:0;left:0;width:60px;height:2px;background:linear-gradient(90deg,var(--primary),transparent);z-index:2}.player-zone:after{content:"";position:absolute;bottom:0;right:0;width:60px;height:2px;background:linear-gradient(270deg,var(--secondary),transparent);z-index:2}.player-zone.active-turn{border-color:var(--primary);background:#ff3a3a0d;box-shadow:0 0 40px #ff3a3a26,inset 0 0 30px #ff3a3a0d;animation:energy-aura 2s ease-in-out infinite}@keyframes energy-aura{0%,to{box-shadow:0 0 30px #ff3a3a1a,inset 0 0 20px #ff3a3a08}50%{box-shadow:0 0 50px #ff3a3a40,inset 0 0 40px #ff3a3a14,0 0 80px #ff8c001a}}.player-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:2px solid rgba(255,58,58,.1)}.player-avatar-small{width:60px;height:60px;border-radius:var(--radius-sm);border:2px solid var(--glass-border);object-fit:cover;background:var(--bg-dark)}.player-info h3{font-family:var(--font-heading);font-size:1.5rem;color:#fff;margin:0;text-transform:uppercase;letter-spacing:1px}.player-info span{font-size:.8rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px}.dice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:var(--space-md);justify-items:center}.battle-hud{display:flex;flex-direction:column;gap:var(--space-lg);align-items:center;justify-content:center;padding:var(--space-md)}.vs-badge{font-family:var(--font-accent);font-size:3.5rem;font-weight:900;color:var(--primary);opacity:1;margin:var(--space-md) 0;text-align:center;width:100%;-webkit-text-stroke:2px var(--primary);text-shadow:0 0 20px var(--primary-glow),0 0 40px var(--primary-glow),0 0 80px rgba(255,140,0,.3);animation:vs-impact 3s ease-in-out infinite;letter-spacing:4px}@keyframes vs-impact{0%,to{transform:scale(1);text-shadow:0 0 20px var(--primary-glow),0 0 40px var(--primary-glow)}50%{transform:scale(1.1);text-shadow:0 0 30px var(--primary-glow),0 0 60px var(--primary-glow),0 0 100px rgba(255,140,0,.4)}}.turn-indicator{width:100%;text-align:center}.turn-badge{display:inline-block;padding:10px 28px;border-radius:var(--radius-sm);font-family:var(--font-accent);font-size:.8rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:var(--space-md);box-shadow:0 5px 15px #0000004d;clip-path:polygon(0 0,calc(100% - 6px) 0,100% 6px,100% 100%,6px 100%,0 calc(100% - 6px))}.turn-badge.your-turn{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;animation:turn-pulse-energy 2s infinite}.turn-badge.opp-turn{background:#ffffff1a;color:var(--text-dim);border:1px solid var(--glass-border)}@keyframes turn-pulse-energy{0%{box-shadow:0 0 0 0 var(--primary-glow)}70%{box-shadow:0 0 0 20px #ff3a3a00}to{box-shadow:0 0 #ff3a3a00}}.battle-log-card{background:#0006;border:1px solid var(--glass-border);border-left:3px solid var(--primary);border-radius:var(--radius-sm);width:100%;max-width:800px;margin:0 auto;overflow:hidden;clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px))}.log-header{padding:12px 20px;background:#ff3a3a0d;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:10px}.log-header h4{font-size:.75rem;color:var(--primary);text-transform:uppercase;letter-spacing:2px;margin:0;font-family:var(--font-accent)}.log-content{height:120px;overflow-y:auto;padding:var(--space-sm);display:flex;flex-direction:column;gap:4px}.log-entry{font-size:.9rem;color:var(--text-dim);padding:6px 12px;border-left:2px solid transparent;background:#ffffff03;transition:all .2s ease}.log-entry:hover{background:#ffffff08}.log-entry.new{animation:entry-in .3s ease-out;border-left-color:var(--primary);color:#fff}@keyframes entry-in{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.battle-controls{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:#0a0a12e6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:12px 30px;border-radius:var(--radius-sm);border:1px solid rgba(255,58,58,.2);display:flex;gap:var(--space-md);box-shadow:0 10px 40px #00000080,0 0 20px #ff3a3a1a;z-index:100;clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))}.btn-battle{padding:12px 28px!important;font-size:1rem!important;border-radius:var(--radius-sm)!important;font-weight:700!important;text-transform:uppercase;letter-spacing:1px}@media (max-width: 1200px){.battle-board{grid-template-columns:1fr;gap:var(--space-xl)}.battle-hud{order:-1;flex-direction:row;justify-content:space-between;width:100%;background:var(--glass-bg);border-radius:var(--radius-lg)}.vs-badge{display:none}.player-zone{min-height:auto}}@media (max-width: 768px){.battle-hud{flex-direction:column;gap:var(--space-sm)}.battle-controls{bottom:10px;padding:10px;width:90%;justify-content:center}.btn-battle{padding:10px 16px!important;font-size:.85rem!important}}.auth-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--bg-dark);font-family:var(--font-body);padding:var(--space-md);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(255,58,58,.015) 40px,rgba(255,58,58,.015) 42px);z-index:0;animation:lines-drift 20s linear infinite}@keyframes lines-drift{0%{transform:translate(0)}to{transform:translate(42px,42px)}}.auth-box{background:#0f0f19e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,58,58,.15);padding:var(--space-xl);text-align:center;max-width:420px;width:100%;animation:slash-in .5s ease-out;position:relative;z-index:1;clip-path:polygon(0 0,calc(100% - 24px) 0,100% 24px,100% 100%,24px 100%,0 calc(100% - 24px))}.auth-box:before{content:"";position:absolute;top:0;left:0;width:80px;height:3px;background:linear-gradient(90deg,var(--primary),transparent);z-index:2}.auth-box:after{content:"";position:absolute;bottom:0;right:0;width:80px;height:3px;background:linear-gradient(270deg,var(--secondary),transparent);z-index:2}@keyframes slash-in{0%{clip-path:polygon(0 0,0 0,0 100%,0 100%);opacity:0}to{clip-path:polygon(0 0,calc(100% - 24px) 0,100% 24px,100% 100%,24px 100%,0 calc(100% - 24px));opacity:1}}.auth-title{color:var(--text-main);font-size:2.2rem;font-weight:700;font-family:var(--font-heading);margin-bottom:var(--space-lg);text-transform:uppercase;letter-spacing:2px;-webkit-text-stroke:.5px rgba(255,58,58,.3)}.auth-form{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.auth-input{width:100%;padding:16px 20px;font-size:1rem;border:none;border-bottom:3px solid rgba(255,255,255,.1);border-radius:0;background:#ffffff08;color:var(--text-main);transition:all .3s ease;font-family:var(--font-body);box-sizing:border-box}.auth-input:focus{outline:none;border-bottom-color:var(--primary);box-shadow:0 4px 15px var(--primary-glow);background:#ff3a3a08;transform:translateY(-1px)}.auth-input::placeholder{color:var(--text-muted);font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.auth-button{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border:none;padding:16px 30px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px var(--primary-glow);text-transform:uppercase;letter-spacing:2px;font-family:var(--font-heading);margin-top:var(--space-sm);clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px))}.auth-button:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 30px var(--primary-glow),0 0 60px #ff8c0033}.auth-button:active{transform:translateY(0);box-shadow:0 3px 15px var(--primary-glow)}.auth-error{background:#ff174426;color:var(--danger);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);font-weight:500;font-size:.9rem;border-left:3px solid var(--danger);animation:impact-shake .5s ease-in-out}.auth-footer{border-top:1px solid rgba(255,255,255,.05);padding-top:var(--space-md);color:var(--text-muted);font-size:.875rem;line-height:1.5}.auth-footer .link{color:var(--primary);text-decoration:none;font-weight:700;transition:color .3s ease;font-size:.875rem}.auth-footer .link:hover{color:var(--secondary);text-decoration:underline}.auth-divider{margin:var(--space-lg) 0;text-align:center;position:relative;color:var(--text-muted);font-size:.875rem}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#ffffff0d;z-index:0}.auth-divider span{background:#0f0f19e6;padding:0 var(--space-md);position:relative;z-index:1}.auth-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-button.loading{position:relative;color:transparent}.auth-button.loading:after{content:"";position:absolute;top:50%;left:50%;margin-left:-10px;margin-top:-10px;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:buttonSpin 1s linear infinite}@keyframes buttonSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 480px){.auth-container{padding:var(--space-sm)}.auth-box{padding:var(--space-lg) var(--space-md);margin:var(--space-sm)}.auth-title{font-size:1.8rem}.auth-input{padding:14px 16px;font-size:.95rem}.auth-button{padding:14px 25px;font-size:.95rem}}@media (max-width: 360px){.auth-box{padding:var(--space-md) var(--space-sm)}.auth-input{padding:12px 14px}}.lobby-container{width:100%;max-width:1300px;margin:0 auto;padding:140px 20px 60px;min-height:100vh;box-sizing:border-box}.lobby-title{font-family:var(--font-heading);text-align:center;color:#fff;font-size:3.5rem;margin-bottom:var(--space-xl);letter-spacing:4px;text-transform:uppercase;-webkit-text-stroke:1px rgba(255,58,58,.4);text-shadow:0 0 20px var(--primary-glow),0 0 40px rgba(255,140,0,.2)}.lobby-layout{display:grid;grid-template-columns:320px 1fr 320px;gap:var(--space-lg);align-items:start}.history-panel,.character-panel,.matchmaking-panel{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:0 15px 45px #00000080;transition:all .3s ease;position:relative;clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px))}.history-panel:before,.character-panel:before,.matchmaking-panel:before{content:"";position:absolute;top:0;left:0;width:50px;height:2px;background:linear-gradient(90deg,var(--primary),transparent);z-index:2}.history-panel:after,.character-panel:after,.matchmaking-panel:after{content:"";position:absolute;bottom:0;right:0;width:50px;height:2px;background:linear-gradient(270deg,var(--secondary),transparent);z-index:2}.history-panel:hover,.matchmaking-panel:hover,.character-panel:hover{border-color:#ff3a3a33;box-shadow:0 20px 60px #0009,0 0 30px #ff3a3a1a}.panel-title{font-family:var(--font-heading);color:var(--primary);font-size:1.1rem;margin-bottom:var(--space-lg);display:flex;align-items:center;gap:12px;letter-spacing:2px;text-transform:uppercase;opacity:1;font-weight:700}.history-list{display:flex;flex-direction:column;gap:14px;max-height:550px;overflow-y:auto;padding-right:10px}.history-list::-webkit-scrollbar{width:3px}.history-list::-webkit-scrollbar-thumb{background:#ff3a3a33;border-radius:10px}.history-card{background:#ffffff05;border:1px solid rgba(255,255,255,.03);border-radius:var(--radius-sm);padding:14px;position:relative;overflow:hidden;transition:all .3s ease}.history-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%}.history-card.win:before{background:var(--accent)}.history-card.lose:before{background:var(--danger)}.history-card.draw:before{background:var(--text-dim)}.history-card:hover{background:#ffffff0d;transform:translate(8px);border-color:#ff3a3a1a}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.history-header h3{font-size:.75rem;color:var(--text-dim);font-weight:500;margin:0}.status-badge{font-size:.65rem;font-weight:800;padding:2px 8px;border-radius:2px;letter-spacing:1px;font-family:var(--font-accent)}.badge-win{color:var(--accent);border:1px solid rgba(255,215,0,.3);background:#ffd7001a}.badge-lose{color:var(--danger);border:1px solid rgba(255,23,68,.3);background:#ff17441a}.badge-draw{color:var(--text-dim);border:1px solid rgba(148,163,184,.3);background:#94a3b81a}.opponent-name{color:#fff;font-weight:600;font-size:1rem;margin:0}.character-panel{min-height:550px;display:flex;flex-direction:column;background:radial-gradient(circle at center,rgba(255,58,58,.08),transparent),var(--glass-bg);border-color:#ff3a3a26}.character-display{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);width:100%}.character-card-premium{width:100%;max-width:360px;position:relative;text-align:center;padding:var(--space-xl) var(--space-lg);border-radius:var(--radius-sm);background:#ffffff05;border:1px solid rgba(255,255,255,.05);overflow:hidden}.character-card-premium:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;background:radial-gradient(circle,rgba(255,58,58,.1),transparent 70%);z-index:0;animation:power-aura 3s ease-in-out infinite}@keyframes power-aura{0%,to{opacity:.5;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.3)}}.character-avatar-ring{width:160px;height:160px;border-radius:var(--radius-sm);margin:0 auto var(--space-xl) auto;position:relative;padding:4px;background:linear-gradient(135deg,var(--primary),var(--secondary));box-shadow:0 0 40px var(--primary-glow);z-index:1}.character-avatar-inner{width:100%;height:100%;background:var(--bg-dark);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:4.5rem;font-family:var(--font-heading)}.character-name-large{font-family:var(--font-heading);font-size:3rem;color:#fff;margin-bottom:var(--space-md);letter-spacing:2px;text-transform:uppercase;-webkit-text-stroke:.5px rgba(255,58,58,.3);position:relative;z-index:1}.premium-divider{width:60px;height:3px;background:linear-gradient(90deg,var(--primary),var(--secondary));margin:0 auto var(--space-lg);border-radius:0;box-shadow:0 0 15px var(--primary-glow)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;width:100%;position:relative;z-index:1}.stat-item{background:#0000004d;padding:16px;border-radius:var(--radius-sm);border:1px solid rgba(255,58,58,.05);border-left:3px solid var(--primary)}.stat-label{display:block;font-size:.65rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;font-family:var(--font-accent)}.stat-value{color:#fff;font-weight:800;font-size:1.25rem;font-family:var(--font-heading)}.matchmaking-panel{border-color:#ff8c0026;background:radial-gradient(circle at top left,rgba(255,140,0,.05),transparent),var(--glass-bg)}.searching-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-md) 0}.searching-radar{position:relative;width:140px;height:140px;margin-bottom:var(--space-xl)}.radar-circle{position:absolute;top:0;left:0;right:0;bottom:0;border:1.5px solid var(--primary);border-radius:50%;opacity:0;animation:radar-pulse 3s cubic-bezier(.25,.46,.45,.94) infinite}.radar-circle:nth-child(2){animation-delay:1s;border-color:var(--secondary)}.radar-circle:nth-child(3){animation-delay:2s;border-color:var(--accent)}@keyframes radar-pulse{0%{transform:scale(.3);opacity:0}10%{opacity:.8}to{transform:scale(1.6);opacity:0}}.searching-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2.5rem;z-index:2;filter:drop-shadow(0 0 15px var(--primary-glow))}.search-timer{font-family:var(--font-accent);color:var(--primary);font-size:1.2rem;margin-bottom:var(--space-md);opacity:.8}.status-info{width:100%;text-align:center}.status-tag{display:inline-block;padding:6px 16px;background:#ff3a3a1a;border:1px solid rgba(255,58,58,.2);border-radius:var(--radius-sm);font-size:.75rem;color:var(--primary);font-weight:700;letter-spacing:2px;margin-bottom:var(--space-md);font-family:var(--font-accent);animation:status-pulse 2s infinite}@keyframes status-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.03);opacity:.8}to{transform:scale(1);opacity:1}}.match-actions{display:flex;flex-direction:column;gap:16px;width:100%}.match-status-box{padding:16px;background:#ffffff05;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.05);border-left:3px solid var(--secondary);margin-bottom:var(--space-sm)}.match-status-box p{color:var(--text-dim);font-size:.9rem;margin:0;line-height:1.4}.practice-btn{background:#ff8c000d;color:var(--secondary);border:1px solid rgba(255,140,0,.2);padding:16px;border-radius:var(--radius-sm);font-weight:700;cursor:pointer;transition:all .3s ease;font-size:1rem;text-transform:uppercase;letter-spacing:1px;font-family:var(--font-heading);clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px))}.practice-btn:hover:not(:disabled){background:#ff8c001a;border-color:var(--secondary);box-shadow:0 0 25px var(--secondary-glow);transform:translateY(-2px)}.practice-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1100px){.lobby-layout{grid-template-columns:1fr;gap:var(--space-xl)}.character-panel{order:-1}.lobby-container{padding-top:120px}.history-panel,.matchmaking-panel{max-width:600px;margin:0 auto;width:100%}.character-panel{max-width:800px;margin:0 auto;width:100%}}@media (max-width: 768px){.lobby-title{font-size:2.5rem}.character-name-large{font-size:2.2rem}}.dice-showcase-container{max-width:1000px;margin:100px auto 40px;padding:var(--space-xl, 48px);background:var(--glass-bg, rgba(255, 255, 255, .03));border:1px solid var(--glass-border, rgba(255, 255, 255, .08));border-radius:var(--radius-lg, 4px);color:var(--text-main, #f8fafc);position:relative;clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,20px 100%,0 calc(100% - 20px))}.showcase-header{text-align:center;margin-bottom:var(--space-xl, 48px)}.showcase-header h1{font-size:2.5rem;margin-bottom:var(--space-sm, 16px);font-family:var(--font-heading, "Rajdhani", sans-serif);text-transform:uppercase;letter-spacing:3px;-webkit-text-stroke:.5px rgba(255,58,58,.3)}.showcase-header p{color:var(--text-dim, #94a3b8)}.showcase-section{margin-bottom:var(--space-xl, 48px)}.showcase-section h2{font-size:1.5rem;margin-bottom:var(--space-lg, 40px);border-bottom:3px solid var(--primary, #ff3a3a);padding-bottom:var(--space-xs, 8px);display:inline-block;font-family:var(--font-heading, "Rajdhani", sans-serif);text-transform:uppercase;letter-spacing:2px;color:var(--primary, #ff3a3a)}.showcase-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-lg, 40px)}.showcase-card{background:#ffffff05;padding:var(--space-md, 24px);border-radius:var(--radius-sm, 2px);border:1px solid rgba(255,255,255,.05);text-align:center;border-left:3px solid var(--primary, #ff3a3a)}.showcase-card.full-width{grid-column:1 / -1}.showcase-card h3{margin-bottom:var(--space-md, 24px);color:var(--secondary, #ff8c00);font-family:var(--font-heading, "Rajdhani", sans-serif);text-transform:uppercase;letter-spacing:1px}.showcase-variants{display:flex;justify-content:center;gap:var(--space-md, 24px);padding:var(--space-sm, 16px);flex-wrap:wrap}.variant{display:flex;flex-direction:column;align-items:center;gap:8px}.variant span{font-size:.7rem;color:var(--text-muted, #64748b);font-weight:700;text-transform:uppercase;font-family:var(--font-accent, "Orbitron", sans-serif);letter-spacing:1px}.dice-row{display:flex;justify-content:center;gap:var(--space-lg, 40px);flex-wrap:wrap;padding:var(--space-md, 24px)}.hint{margin-top:var(--space-md, 24px);font-size:.875rem;color:var(--text-muted, #64748b);font-style:italic}.showcase-footer{margin-top:var(--space-xl, 48px);text-align:center}.admin-container{max-width:1100px;margin:0 auto;padding:40px 24px 80px}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}.admin-title{font-family:var(--font-heading);font-size:2rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-main);margin:0 0 4px}.admin-subtitle{color:var(--text-dim);font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.admin-loading,.admin-empty{color:var(--text-dim);text-align:center;padding:48px;font-size:1rem}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.char-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .2s ease;clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px))}.char-card:hover{border-color:#ff3a3a4d}.char-card-img{width:100%;height:140px;background:#0000004d;display:flex;align-items:center;justify-content:center;overflow:hidden}.char-card-img img{width:100%;height:100%;object-fit:cover}.char-card-no-img{font-size:3rem;color:var(--text-muted)}.char-card-body{padding:16px}.char-card-body h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-main);margin:0 0 10px}.char-dice-list{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}.die-badge{display:inline-block;padding:2px 8px;border-radius:2px;font-size:.75rem;font-weight:700;font-family:var(--font-accent);color:#fff;letter-spacing:.5px}.char-card-actions{display:flex;gap:8px}.admin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500;padding:24px}.admin-modal{background:var(--bg-dark);border:1px solid rgba(255,58,58,.2);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px))}.admin-modal-sm{max-width:360px}.modal-title{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-main);margin:0 0 24px}.modal-form{display:flex;flex-direction:column;gap:4px;margin-bottom:24px}.form-label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin-bottom:8px;font-family:var(--font-accent)}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.dice-selector{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.die-add-btn{background:transparent;border:1px solid;border-radius:2px;padding:6px 14px;font-size:.8rem;font-weight:700;font-family:var(--font-accent);cursor:pointer;transition:all .15s ease;letter-spacing:.5px}.die-add-btn:hover{opacity:.8;transform:translateY(-1px)}.dice-selected{display:flex;flex-wrap:wrap;gap:6px;min-height:32px;align-items:center}.die-badge-rm{cursor:pointer;transition:opacity .15s}.die-badge-rm:hover{opacity:.7}.img-upload-area{border:2px dashed var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .2s ease;overflow:hidden;min-height:120px;display:flex;align-items:center;justify-content:center}.img-upload-area:hover{border-color:var(--primary)}.img-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-dim);font-size:.875rem;padding:24px;text-align:center}.img-preview{width:100%;max-height:200px;object-fit:contain}@media (max-width: 600px){.admin-header{flex-direction:column}.char-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.admin-modal{padding:24px 16px}}
