:root{--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #e8e8e8;--bg-hover: #f0f0f0;--bg-modal: rgba(0, 0, 0, .7);--text-primary: #1a1a1a;--text-secondary: #4a4a4a;--text-muted: #6a6a6a;--text-inverse: #ffffff;--border-color: #d0d0d0;--border-light: #e5e5e5;--border-dark: #a0a0a0;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .2);--rarity-common: #6b7280;--rarity-uncommon: #10b981;--rarity-rare: #3b82f6;--rarity-epic: #a855f7;--rarity-legendary: #f59e0b;--rarity-mythic: #ef4444;--primary-color: #3b82f6;--primary-hover: #2563eb;--success-color: #10b981;--success-hover: #059669;--danger-color: #ef4444;--danger-hover: #dc2626;--warning-color: #f59e0b;--info-color: #3b82f6;--slot-empty: #e5e7eb;--slot-filled: #dbeafe;--slot-border: #cbd5e1;--stat-attack: #ef4444;--stat-defense: #3b82f6;--stat-health: #10b981;--stat-mana: #8b5cf6;--input-bg: #ffffff;--input-border: #d1d5db;--input-focus: #3b82f6;--input-text: #1f2937;--toast-success-bg: #d1fae5;--toast-success-text: #065f46;--toast-error-bg: #fee2e2;--toast-error-text: #991b1b}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2a2a2a;--bg-tertiary: #333333;--bg-hover: #3a3a3a;--bg-modal: rgba(0, 0, 0, .85);--text-primary: #e5e5e5;--text-secondary: #b5b5b5;--text-muted: #8a8a8a;--text-inverse: #1a1a1a;--border-color: #404040;--border-light: #353535;--border-dark: #505050;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .5);--rarity-common: #9ca3af;--rarity-uncommon: #34d399;--rarity-rare: #60a5fa;--rarity-epic: #c084fc;--rarity-legendary: #fbbf24;--rarity-mythic: #f87171;--primary-color: #60a5fa;--primary-hover: #3b82f6;--success-color: #34d399;--success-hover: #10b981;--danger-color: #f87171;--danger-hover: #ef4444;--warning-color: #fbbf24;--info-color: #60a5fa;--slot-empty: #374151;--slot-filled: #1e3a8a;--slot-border: #4b5563;--stat-attack: #f87171;--stat-defense: #60a5fa;--stat-health: #34d399;--stat-mana: #a78bfa;--input-bg: #374151;--input-border: #4b5563;--input-focus: #60a5fa;--input-text: #e5e7eb;--toast-success-bg: #064e3b;--toast-success-text: #d1fae5;--toast-error-bg: #7f1d1d;--toast-error-text: #fecaca}body{background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.theme-toggle{position:fixed;top:1rem;right:1rem;z-index:1000;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:50%;width:50px;height:50px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.5rem;transition:all .3s ease;box-shadow:var(--shadow-md)}.theme-toggle:hover{transform:scale(1.1);background:var(--bg-hover);box-shadow:var(--shadow-lg)}.theme-toggle:active{transform:scale(.95)}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}#root{width:100%;max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.rpg-container{max-width:1600px;margin:0 auto;padding:2rem;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;text-align:center}.loading-screen p{font-size:1.5rem;color:var(--text-secondary);margin-top:2rem}.error-banner{display:flex;justify-content:space-between;align-items:center;background:#ef44441a;border:2px solid var(--danger-color);border-radius:8px;padding:1rem 1.5rem;margin-bottom:2rem;color:var(--danger-color);font-weight:600}.error-banner button{background:none;border:none;color:var(--danger-color);font-size:1.5rem;cursor:pointer;padding:0 .5rem}.title-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;text-align:center}.game-title{font-size:4rem;margin-bottom:1rem;background:linear-gradient(135deg,gold,orange,tomato);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(255,215,0,.3);letter-spacing:4px;animation:glow 2s ease-in-out infinite alternate}@keyframes glow{0%{filter:drop-shadow(0 0 10px rgba(255,215,0,.5))}to{filter:drop-shadow(0 0 20px rgba(255,215,0,.8))}}.game-subtitle{font-size:1.5rem;color:var(--text-secondary);margin-bottom:3rem;letter-spacing:2px}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 2rem;background:var(--bg-secondary);border-radius:12px;border:2px solid var(--border-color);box-shadow:var(--shadow-md)}.game-header .game-title{font-size:2rem;margin:0;animation:none}.player-info{display:flex;gap:2rem;align-items:center}.username{font-size:1.2rem;font-weight:700;color:var(--warning-color)}.points{font-size:1.1rem;padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;color:var(--text-primary)}.login-prompt{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:3rem 2rem;margin:2rem 0;box-shadow:var(--shadow-lg)}.login-prompt p{font-size:1.2rem;margin-bottom:1.5rem;color:var(--text-secondary)}.btn{display:inline-block;padding:.75rem 1.5rem;background:var(--primary-color);color:var(--text-inverse);text-decoration:none;border-radius:8px;font-weight:600;transition:transform .2s,box-shadow .2s,background .2s;border:none;cursor:pointer;font-size:1rem}.btn:hover{transform:translateY(-2px);background:var(--primary-hover);box-shadow:var(--shadow-md)}.btn-primary{background:linear-gradient(135deg,gold,orange);box-shadow:0 4px 12px #ffd7004d}.btn-primary:hover{box-shadow:0 8px 20px #ffd70080}@media(max-width:768px){.game-title{font-size:2.5rem}.game-header{flex-direction:column;gap:1rem}.player-info{flex-direction:column;gap:.5rem}}.hero-creation{max-width:1200px;margin:0 auto;padding:2rem}.creation-title{font-size:3rem;text-align:center;margin-bottom:.5rem;background:linear-gradient(135deg,gold,orange);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.creation-subtitle{text-align:center;color:#ffffffb3;margin-bottom:3rem;font-size:1.2rem}.creation-section{margin-bottom:3rem}.section-label{display:block;font-size:1.5rem;font-weight:700;margin-bottom:1rem;color:gold}.hero-name-input{width:100%;max-width:500px;padding:1rem;font-size:1.2rem;background:#ffffff0d;border:2px solid rgba(255,215,0,.3);border-radius:8px;color:#fff;outline:none;transition:all .3s ease}.hero-name-input:focus{border-color:gold;box-shadow:0 0 12px #ffd7004d}.hero-name-input::placeholder{color:#fff6}.input-hint{margin-top:.5rem;font-size:.9rem;color:#ffffff80}.factions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.faction-card{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease}.faction-card:hover{transform:translateY(-5px);border-color:#ffd70080;box-shadow:0 8px 24px #ffd70033}.faction-card.selected{border-color:gold;background:#ffd7001a;box-shadow:0 0 20px #ffd7004d}.faction-icon{font-size:3rem;text-align:center;margin-bottom:1rem}.faction-name{font-size:1.5rem;text-align:center;color:gold;margin-bottom:.5rem}.faction-description{text-align:center;color:#ffffffb3;margin-bottom:1rem;font-size:.95rem;min-height:2.5rem}.faction-traits{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.trait-badge{background:#ffd70026;border:1px solid rgba(255,215,0,.3);padding:.25rem .75rem;border-radius:12px;font-size:.85rem;color:gold}.error-message{background:#ff00001a;border:2px solid rgba(255,0,0,.3);border-radius:8px;padding:1rem;margin:2rem auto;max-width:500px;text-align:center;color:#ff6b6b;font-weight:600}.btn-large{display:block;margin:2rem auto 0;padding:1rem 3rem;font-size:1.3rem}.btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.factions-grid{grid-template-columns:1fr}.creation-title{font-size:2rem}}.game-hub{max-width:1400px;margin:0 auto;padding:2rem}.hero-banner{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:2rem;margin-bottom:2rem;text-align:center;box-shadow:var(--shadow-md)}.hero-display-name{font-size:2.5rem;color:var(--warning-color);margin-bottom:.5rem}.hero-faction{font-size:1.3rem;color:var(--text-secondary);margin-bottom:1rem}.fame-level-badge{display:flex;align-items:center;justify-content:center;gap:.75rem;background:linear-gradient(135deg,#ffd7004d,#ff8c004d);border:2px solid rgba(255,215,0,.6);border-radius:12px;padding:.75rem 1.5rem;margin:.75rem auto 1rem;max-width:fit-content;box-shadow:0 0 20px #ffd70066;animation:famePulse 2s ease-in-out infinite}@keyframes famePulse{0%,to{box-shadow:0 0 20px #ffd70066}50%{box-shadow:0 0 30px #ffd70099}}.fame-icon{font-size:1.5rem;text-shadow:0 0 10px rgba(255,215,0,.8)}.fame-text{font-size:1.1rem;font-weight:700;color:gold;text-transform:uppercase;letter-spacing:1px;text-shadow:0 2px 4px rgba(0,0,0,.5)}.rebirth-count{font-size:.85rem;color:#ffd700cc;font-style:italic}.hero-stats-mini{display:flex;justify-content:center;gap:1rem;font-size:1.1rem;color:#ffffffb3}.resources-bar{display:flex;justify-content:center;gap:3rem;background:#0000004d;padding:1.5rem;border-radius:12px;margin-bottom:2rem;border:2px solid rgba(255,215,0,.2)}.resource{display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all .3s ease}.resource-maxed{animation:capWarning 2s ease-in-out infinite}@keyframes capWarning{0%,to{opacity:1}50%{opacity:.6}}.resource-maxed .resource-amount{color:#ff6b6b;font-weight:900}.resource-maxed .resource-icon{animation:shake .5s ease-in-out infinite}.resource-icon{font-size:2rem}.resource-amount{font-size:1.5rem;font-weight:700;color:gold}.resource-label{font-size:.9rem;color:#fff9;text-transform:uppercase;letter-spacing:1px}.debuffs-bar{background:linear-gradient(135deg,#8b000033,#dc143c33);border:2px solid rgba(220,20,60,.4);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.debuffs-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid rgba(220,20,60,.3)}.debuffs-icon{font-size:1.5rem}.debuffs-title{font-size:1.2rem;font-weight:700;color:#ff6b6b;text-transform:uppercase;letter-spacing:1px}.debuffs-list{display:flex;flex-wrap:wrap;gap:1rem}.debuff-item{display:flex;align-items:center;gap:.75rem;background:#0006;border:2px solid rgba(220,20,60,.5);border-radius:8px;padding:.75rem 1rem;cursor:help;transition:all .2s;min-width:200px}.debuff-item:hover{background:#dc143c1a;border-color:#dc143cb3;transform:translateY(-2px);box-shadow:0 4px 8px #dc143c4d}.debuff-emoji{font-size:1.8rem;flex-shrink:0}.debuff-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.debuff-name{font-weight:700;color:#ff6b6b;font-size:.95rem}.debuff-effect{font-size:.85rem;color:#ff6b6bcc;text-transform:capitalize}.debuff-duration{font-size:.85rem;color:#ffffffb3;background:#dc143c4d;padding:.25rem .5rem;border-radius:4px;white-space:nowrap}.navigation{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem}.nav-btn{padding:1rem 2rem;font-size:1.1rem;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-weight:600}.nav-btn:hover{background:#ffd7001a;border-color:#ffd70080;transform:translateY(-2px)}.nav-btn.active{background:linear-gradient(135deg,#ffd70033,#ffa50033);border-color:gold;box-shadow:0 4px 12px #ffd7004d;color:var(--text-primary)}.nav-btn.admin-btn{background:linear-gradient(135deg,#dc262626,#b91c1c26);border-color:#dc262666}.nav-btn.admin-btn:hover{background:linear-gradient(135deg,#dc262640,#b91c1c40);border-color:#dc262699}.nav-btn.admin-btn.active{background:linear-gradient(135deg,#dc262659,#b91c1c59);border-color:#dc2626;box-shadow:0 4px 12px #dc262666}.content-area{background:#ffffff08;border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;min-height:500px}.content-area h2{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,gold,orange);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.view-description{color:#ffffffb3;margin-bottom:2rem;font-size:1.1rem}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;min-height:300px}.coming-soon h3{font-size:2.5rem;margin-bottom:1rem;color:#fffc}.coming-soon p{font-size:1.2rem;color:#fff9;margin-bottom:1rem}.coming-soon .hint{font-size:1rem;color:#ffd700b3;font-style:italic;max-width:500px}@media(max-width:768px){.resources-bar{flex-direction:column;gap:1rem}.navigation{flex-direction:column}.nav-btn{width:100%}}.barracks{padding:1rem}.army-capacity-warning{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;margin-bottom:1.5rem;border-radius:8px;font-size:1rem;animation:warningPulse 2s ease-in-out infinite}.capacity-near{background:linear-gradient(135deg,#ffa50033,#ff8c0033);border:2px solid rgba(255,165,0,.5)}.capacity-full{background:linear-gradient(135deg,#dc143c33,#8b000033);border:2px solid rgba(220,20,60,.5)}.warning-icon{font-size:1.5rem;animation:shake .5s ease-in-out infinite}@keyframes warningPulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.barracks-loading{text-align:center;padding:4rem;font-size:1.2rem;color:#ffffffb3}.barracks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.army-summary h3{font-size:1.5rem;color:gold;margin-bottom:.5rem}.army-stats{display:flex;gap:2rem}.army-stats .stat{display:flex;flex-direction:column}.stat-label{font-size:.9rem;color:#fff9}.stat-value{font-size:1.5rem;font-weight:700;color:gold;transition:color .3s ease}.stat-value.maxed{color:#ff6b6b;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.tier-filter{display:flex;gap:.5rem}.filter-btn{padding:.5rem 1rem;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;cursor:pointer;transition:all .3s ease;font-weight:600}.filter-btn:hover{border-color:#ffd70080}.filter-btn.active{background:#ffd70033;border-color:gold}.units-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.unit-card{background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;transition:all .3s ease}.unit-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000004d}.unit-card.tier-1{border-color:#c0c0c04d}.unit-card.tier-2{border-color:#ffd7004d}.unit-card.tier-3{border-color:#8a2be266}.unit-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.unit-icon{font-size:2.5rem}.unit-title h4{margin:0;font-size:1.2rem;color:gold}.unit-tier{font-size:.8rem;color:var(--text-secondary)}.unit-description{font-size:.9rem;color:var(--text-primary);margin-bottom:1rem;min-height:2.5rem}.unit-stats{display:flex;justify-content:space-around;padding:.75rem;background:#0003;border-radius:8px;margin-bottom:1rem}.stat-item{display:flex;align-items:center;gap:.25rem;font-weight:600;color:#ffffffe6}.unit-cost{display:flex;justify-content:center;gap:1rem;margin-bottom:.75rem;padding:.5rem;background:#ffd7001a;border-radius:6px}.cost-item{font-weight:700;color:gold}.current-count{text-align:center;padding:.5rem;background:#00ff001a;border-radius:6px;margin-bottom:.75rem;color:#90ee90}.recruit-actions{display:flex;gap:.5rem}.recruit-btn{flex:1;padding:.75rem;background:linear-gradient(135deg,gold,orange);border:none;border-radius:6px;color:#000;font-weight:700;cursor:pointer;transition:all .3s ease}.recruit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ffd70066}.recruit-btn:disabled{opacity:.4;cursor:not-allowed}.recruit-btn.small{flex:.5}.disband-section{margin-top:1rem;padding-top:1rem;border-top:2px solid rgba(255,255,255,.1)}.disband-info{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:#6495ed1a;border-radius:6px;margin-bottom:.5rem}.disband-label{font-size:.85rem;color:#ffffffb3}.mana-refund{font-weight:700;color:#6495ed;font-size:.9rem}.disband-actions{display:flex;gap:.5rem}.disband-btn{flex:1;padding:.75rem;background:linear-gradient(135deg,#dc143c,#8b0000);border:none;border-radius:6px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s ease}.disband-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #dc143c66}.disband-btn:disabled{opacity:.4;cursor:not-allowed}.disband-btn.small{flex:.5}.error-message{display:flex;justify-content:space-between;align-items:center;background:#ff00001a;border:2px solid rgba(255,0,0,.3);border-radius:8px;padding:1rem 1.5rem;margin-bottom:1.5rem;color:#ff6b6b;font-weight:600}.error-message button{background:none;border:none;color:#ff6b6b;font-size:1.5rem;cursor:pointer;padding:0 .5rem}@media(max-width:768px){.barracks-header{flex-direction:column;align-items:flex-start}.tier-filter{width:100%;flex-wrap:wrap}.filter-btn{flex:1;min-width:80px}.units-grid{grid-template-columns:1fr}}.toast{position:fixed;top:80px;right:20px;display:flex;align-items:center;gap:10px;padding:16px 20px;border-radius:12px;box-shadow:var(--shadow-lg);z-index:9999;animation:slideIn .3s ease-out;max-width:400px;min-width:300px}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.toast-error{background:var(--toast-error-bg);color:var(--toast-error-text);border:2px solid var(--danger-color)}.toast-success{background:var(--toast-success-bg);color:var(--toast-success-text);border:2px solid var(--success-color)}.toast-info{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--info-color)}.toast-icon{font-size:1.5em;flex-shrink:0}.toast-message{flex:1;font-weight:600;font-size:1em}.toast-close{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.2em;transition:all .2s;flex-shrink:0}.toast-close:hover{background:#ffffff4d;transform:scale(1.1)}body.dark-mode .toast{box-shadow:0 8px 24px #0009}@media(max-width:600px){.toast{top:10px;right:10px;left:10px;max-width:none;min-width:auto}}.campaign-container{padding:20px;max-width:1400px;margin:0 auto}.campaign-header{text-align:center;margin-bottom:30px}.campaign-header h2{font-size:2em;margin:0 0 10px;color:var(--text-primary)}.campaign-description{color:var(--text-secondary);font-size:1.1em;margin:0}.campaign-loading{text-align:center;padding:40px;font-size:1.2em;color:var(--text-secondary)}.campaign-error{background:#fee;color:#c33;padding:15px;border-radius:8px;margin-bottom:20px;text-align:center}.difficulty-filters{display:flex;justify-content:center;gap:10px;margin-bottom:30px;flex-wrap:wrap}.filter-btn{padding:10px 20px;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;cursor:pointer;font-size:1em;transition:all .2s}.filter-btn:hover{background:var(--bg-hover);transform:translateY(-2px)}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea}body.dark-mode .filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}body.dark-mode .enemy-cost{background:linear-gradient(135deg,#1e3a8a,#1e40af);border-color:#3b82f6}body.dark-mode .cost-label{color:#93c5fd}body.dark-mode .cost-value{color:#dbeafe}body.dark-mode .cost-value.insufficient{color:#fca5a5}.enemies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:20px}.enemy-card{background:var(--bg-secondary);border:3px solid var(--border-color);border-radius:12px;padding:20px;transition:all .3s;display:flex;flex-direction:column;gap:15px}.enemy-card:not(.locked):hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}.enemy-card.locked{opacity:.6;filter:grayscale(50%)}.enemy-emoji{font-size:4em;text-align:center}.enemy-name{font-size:1.4em;margin:0;text-align:center;color:var(--text-primary)}.enemy-description{text-align:center;color:#666;font-size:.95em;margin:0;min-height:40px}.enemy-stats{display:flex;flex-direction:column;gap:8px;padding:15px;background:var(--bg-tertiary);border-radius:8px}.stat{display:flex;justify-content:space-between;align-items:center}.stat-label{color:var(--text-secondary);font-size:.9em}.stat-value{font-weight:700;color:var(--text-primary)}.difficulty-badge{padding:4px 12px;border-radius:12px;color:#fff;font-size:.85em;font-weight:700}.enemy-rewards{display:flex;justify-content:space-around;padding:10px;background:#fffbea;border-radius:8px;border:2px solid #ffd700;margin-bottom:10px}.reward{font-weight:700;color:var(--text-primary)}.enemy-cost{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:linear-gradient(135deg,#e0f2fe,#bae6fd);border-radius:8px;border:2px solid #0ea5e9;margin-bottom:10px}.cost-label{font-size:.9em;color:#0369a1;font-weight:600}.cost-value{font-size:1.1em;font-weight:700;color:#0c4a6e}.cost-value.insufficient{color:#dc2626;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.enemy-debuff-warning{background:#dc143c26;border:2px solid rgba(220,20,60,.4);border-radius:6px;padding:8px 12px;display:flex;flex-direction:column;gap:4px;cursor:help;transition:all .2s}.enemy-debuff-warning:hover{background:#dc143c40;border-color:#dc143c99}.debuff-warning-label{font-size:.75em;text-transform:uppercase;color:#ff6b6bcc;letter-spacing:.5px;font-weight:700}.debuff-warning-info{color:#ff6b6b;font-weight:700;font-size:.9em;display:flex;align-items:center;gap:6px}.level-requirement{text-align:center;color:#c33;font-weight:700;padding:8px;background:#fee;border-radius:6px}.battle-btn{padding:12px 24px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .2s}.battle-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #f5576c66}.battle-btn:disabled{opacity:.5;cursor:not-allowed}.no-enemies{text-align:center;padding:40px;color:#999;font-size:1.1em}.battle-result-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s}.battle-result-modal{background:#fff;border-radius:16px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.result-header{padding:30px;text-align:center;border-radius:16px 16px 0 0}.result-header.victory{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.result-header.defeat{background:linear-gradient(135deg,#eb3349,#f45c43);color:#fff}.result-header h2{margin:0;font-size:2em}.battle-summary{padding:30px}.power-comparison{display:flex;align-items:center;justify-content:space-around;margin-bottom:30px;padding:20px;background:#f9f9f9;border-radius:12px}.power-stat{display:flex;flex-direction:column;align-items:center;gap:8px}.power-label{font-size:.9em;color:#666}.power-value{font-size:1.4em;font-weight:700;color:#333}.vs{font-size:1.2em;font-weight:700;color:#999}.rewards-section,.penalties-section,.casualties-section{margin-top:20px}.rewards-section h3,.penalties-section h3,.casualties-section h3{margin:0 0 15px;color:#333;font-size:1.2em}.rewards,.penalties{display:flex;flex-direction:column;gap:10px}.reward-item,.penalty-item{display:flex;align-items:center;gap:10px;padding:12px;background:#f0f9ff;border-radius:8px;font-size:1.1em}.penalty-item{background:#fee}.reward-icon,.penalty-icon{font-size:1.5em}.reward-text{font-weight:700;color:#059669}.penalty-text{font-weight:700;color:#dc2626}.casualties{display:flex;flex-direction:column;gap:8px}.casualty-item{padding:10px;background:#fef2f2;border-left:3px solid #dc2626;border-radius:4px;color:#991b1b}.loot-section{margin-top:20px}.loot-section h3{margin:0 0 15px;color:#333;font-size:1.2em}.loot-items{display:flex;flex-direction:column;gap:10px}.loot-item{display:flex;align-items:center;gap:12px;padding:12px;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:8px;border:2px solid #fbbf24;animation:lootDrop .5s ease-out}@keyframes lootDrop{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.loot-item.rarity-uncommon{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981}.loot-item.rarity-rare{background:linear-gradient(135deg,#dbeafe,#93c5fd);border-color:#3b82f6}.loot-item.rarity-epic{background:linear-gradient(135deg,#e9d5ff,#c084fc);border-color:#a855f7}.loot-item.rarity-legendary{background:linear-gradient(135deg,#fce7f3,#fbcfe8);border-color:#ec4899;box-shadow:0 0 20px #ec489980}.loot-emoji{font-size:2em;display:flex;align-items:center;justify-content:center}.loot-emoji .item-image{max-width:48px;max-height:48px;object-fit:contain}.loot-name{flex:1;font-weight:700;color:#333}.loot-rarity{font-size:.85em;text-transform:uppercase;padding:4px 8px;background:#0000001a;border-radius:4px;font-weight:700}.levelup-section{margin-top:30px;display:flex;flex-direction:column;gap:20px}.levelup-banner{background:linear-gradient(135deg,#fbbf24,#f59e0b,#d97706);border:3px solid #b45309;border-radius:12px;padding:20px;box-shadow:0 8px 30px #fbbf2466;animation:levelUpPulse .8s ease-out}@keyframes levelUpPulse{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.levelup-header{text-align:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid rgba(255,255,255,.3)}.levelup-header h2{margin:0 0 10px;font-size:2em;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3);animation:levelUpText .5s ease-out}@keyframes levelUpText{0%,50%,to{transform:translateY(0)}25%{transform:translateY(-5px)}75%{transform:translateY(-3px)}}.new-level{margin:0;font-size:1.5em;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.levelup-rewards{background:#ffffffe6;border-radius:8px;padding:15px}.levelup-rewards h3{margin:0 0 15px;color:#78350f;font-size:1.2em}.levelup-reward-item{display:flex;align-items:center;gap:12px;padding:12px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fbbf24;border-radius:8px;margin-bottom:15px}.reward-icon{font-size:2em}.reward-text{font-size:1.2em;font-weight:700;color:#78350f}.levelup-items h4{margin:0 0 10px;color:#78350f;font-size:1em}.levelup-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;border:2px solid;margin-bottom:8px;animation:lootDrop .5s ease-out}.levelup-item.rarity-common{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-color:#9ca3af}.levelup-item.rarity-uncommon{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#10b981}.levelup-item.rarity-rare{background:linear-gradient(135deg,#dbeafe,#93c5fd);border-color:#3b82f6}.levelup-item.rarity-epic{background:linear-gradient(135deg,#e9d5ff,#c084fc);border-color:#a855f7}.levelup-item.rarity-legendary{background:linear-gradient(135deg,#fce7f3,#fbcfe8);border-color:#ec4899;box-shadow:0 0 15px #ec489966}.item-emoji{font-size:1.8em;display:flex;align-items:center;justify-content:center}.item-emoji .item-image{max-width:44px;max-height:44px;object-fit:contain}.item-name{flex:1;font-weight:700;color:#333;font-size:1.05em}.item-tier{font-size:.85em;padding:3px 8px;background:#0000001a;border-radius:4px;font-weight:700;color:#555}.item-rarity{font-size:.85em;text-transform:uppercase;padding:4px 8px;background:#00000026;border-radius:4px;font-weight:700;color:#333}.debuff-notification{margin-top:25px;background:linear-gradient(135deg,#dc143c33,#8b000033);border:3px solid rgba(220,20,60,.6);border-radius:12px;padding:20px;animation:debuffPulse .6s ease-out}@keyframes debuffPulse{0%{transform:scale(.9);opacity:0}50%{transform:scale(1.03)}to{transform:scale(1);opacity:1}}.debuff-notification-header{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:15px;padding-bottom:12px;border-bottom:2px solid rgba(220,20,60,.4)}.debuff-warning-icon{font-size:1.8em;animation:warningBlink 1.5s infinite}@keyframes warningBlink{0%,to{opacity:1}50%{opacity:.5}}.debuff-notification-header h3{margin:0;color:#ff6b6b;font-size:1.4em;text-transform:uppercase;letter-spacing:1px}.debuff-notification-content{background:#0000004d;border-radius:8px;padding:15px}.debuff-notification-main{display:flex;align-items:center;gap:15px}.debuff-notification-emoji{font-size:3em;flex-shrink:0}.debuff-notification-info{flex:1}.debuff-notification-info h4{margin:0 0 8px;color:#ff6b6b;font-size:1.2em}.debuff-notification-info p{margin:0 0 12px;color:#fffc;font-size:.95em;line-height:1.4}.debuff-notification-details{display:flex;gap:12px;flex-wrap:wrap}.debuff-effect{background:#dc143c4d;color:#ff6b6b;padding:6px 12px;border-radius:6px;font-weight:700;font-size:.9em;text-transform:capitalize;border:1px solid rgba(220,20,60,.5)}.debuff-duration-badge{background:#0006;color:#ffffffe6;padding:6px 12px;border-radius:6px;font-weight:700;font-size:.9em;border:1px solid rgba(255,255,255,.2)}.close-btn{width:calc(100% - 60px);margin:0 30px 30px;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .2s}.close-btn:hover{transform:scale(1.02);box-shadow:0 4px 12px #667eea66}@media(max-width:768px){.campaign-header h2{font-size:1.5em}.enemies-grid{grid-template-columns:1fr;gap:15px}.difficulty-filters{gap:5px}.filter-btn{padding:8px 15px;font-size:.9em}.power-comparison{flex-direction:column;gap:15px}.vs{transform:rotate(90deg)}}.equipment-container{padding:20px;max-width:1400px;margin:0 auto}.equipment-header{text-align:center;margin-bottom:30px}.equipment-header h2{font-size:2em;margin:0 0 10px;color:var(--text-primary)}.hero-stats-summary{display:flex;justify-content:center;gap:30px;margin-top:15px}.stat-item{font-size:1.2em;font-weight:700;color:var(--text-secondary)}.flag-designer-btn{padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.flag-designer-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.equipment-loading{text-align:center;padding:40px;font-size:1.2em;color:var(--text-secondary)}.equipment-error{background:#fee;color:#c33;padding:15px;border-radius:8px;margin-bottom:20px;text-align:center}.equipment-layout{position:relative;display:grid;grid-template-columns:400px 1fr;gap:30px;margin-top:20px}.equipment-panel{background:var(--bg-tertiary);padding:20px;border-radius:16px;box-shadow:var(--shadow-md);border:2px solid var(--border-color)}.equipment-panel h3{color:var(--text-primary);text-align:center;margin:0 0 20px;font-size:1.4em}.equipment-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.equipment-row{display:grid;gap:10px;justify-items:center}.head-row,.gloves-row,.legs-row,.boots-row{grid-template-columns:1fr 100px 1fr}.hands-row{grid-template-columns:100px 100px 100px}.equipment-slot{width:100px;height:100px;background:var(--slot-empty);border:3px solid var(--slot-border);border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.equipment-slot:hover{background:var(--bg-hover);border-color:var(--border-dark);transform:scale(1.05)}.slot-label{position:absolute;top:4px;left:0;right:0;text-align:center;font-size:.7em;color:var(--text-secondary);font-weight:700;text-transform:uppercase}.empty-slot{font-size:2.5em;opacity:.3;margin-top:15px}.equipped-item{margin-top:15px}.item-emoji{font-size:3em;display:block}.hero-name-display{text-align:center;color:var(--text-primary);font-size:1.3em;font-weight:700;margin-top:20px;padding:10px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-light)}.inventory-panel{background:var(--bg-secondary);padding:20px;border-radius:16px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;border:1px solid var(--border-color)}.inventory-panel h3{margin:0 0 20px;color:var(--text-primary);font-size:1.4em}.empty-inventory{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-inventory p{margin:10px 0;font-size:1.1em}.hint{font-size:.9em!important;color:var(--text-muted)!important}.inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;height:100%;overflow-y:auto;padding:10px;background:var(--bg-tertiary);border-radius:8px}.inventory-item{background:var(--bg-secondary);border:3px solid var(--border-color);border-radius:12px;padding:12px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}.inventory-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--border-dark)}.inventory-item.selected{border-width:4px;border-color:var(--primary-color);box-shadow:0 0 20px var(--primary-color)}.item-emoji-large{font-size:2.5em;display:flex;align-items:center;justify-content:center;width:100%;height:60px}.item-emoji-large .item-image{max-width:60px;max-height:60px;object-fit:contain}.item-name{font-size:.85em;font-weight:700;color:var(--text-primary);text-align:center;line-height:1.2;min-height:30px}.item-stats-mini{display:flex;gap:8px;font-size:.8em;color:var(--text-secondary)}.item-quantity{position:absolute;top:4px;right:4px;background:var(--bg-tertiary);color:var(--text-primary);font-size:.75em;padding:2px 6px;border-radius:10px;font-weight:700;border:1px solid var(--border-color)}.item-details-overlay{position:absolute;width:380px;max-height:500px;z-index:100;pointer-events:none}.item-details-over-equipment{left:20px}.item-details-over-inventory{right:20px}.item-details{padding:20px;background:var(--bg-secondary);border-radius:12px;border:2px solid var(--primary-color);position:relative;pointer-events:all;box-shadow:var(--shadow-lg)}.item-details-close{position:absolute;top:10px;right:10px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:50%;width:30px;height:30px;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.item-details-close:hover{background:var(--primary-hover);transform:scale(1.1)}.item-details-header{display:flex;align-items:center;gap:15px;margin-bottom:15px}.item-emoji-huge{font-size:3.5em;display:flex;align-items:center;justify-content:center;min-width:80px}.item-emoji-huge .item-image-large{max-width:80px;max-height:80px;object-fit:contain}.item-title-group{flex:1}.item-title-group h4{margin:0 0 8px;font-size:1.4em;color:var(--text-primary)}.item-rarity-badge{display:inline-block;color:#fff;padding:4px 12px;border-radius:12px;font-size:.85em;font-weight:700;text-transform:uppercase}.item-description{color:var(--text-secondary);font-size:.95em;margin:0 0 20px;font-style:italic}.item-stats{background:var(--bg-tertiary);padding:15px;border-radius:8px;margin-bottom:15px;border:1px solid var(--border-light)}.stat-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-light);color:var(--text-primary)}.stat-row:last-child{border-bottom:none}.stat-value{font-weight:700;color:var(--success-color)}.item-requirements{background:var(--bg-tertiary);padding:15px;border-radius:8px;margin-bottom:15px;border:1px solid var(--border-light)}.req-row{display:flex;justify-content:space-between;font-size:.95em}.req-met{color:#059669;font-weight:700}.req-not-met{color:#dc2626;font-weight:700}.equip-button{width:100%;padding:15px;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .2s}.equip-button:hover:not(:disabled){transform:scale(1.02);box-shadow:0 4px 12px #f5576c66}.equip-button:disabled{opacity:.5;cursor:not-allowed;background:var(--text-muted)}.unequip-button{width:100%;padding:15px;background:var(--primary-color);color:var(--text-inverse);border:none;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .2s}.unequip-button:hover{transform:scale(1.02);box-shadow:0 4px 12px #667eea66}@media(max-width:768px){.equipment-layout{grid-template-columns:1fr;gap:20px}.equipment-panel{padding:15px}.equipment-slot{width:80px;height:80px}.hands-row{grid-template-columns:80px 80px 80px}.head-row,.gloves-row,.legs-row,.boots-row{grid-template-columns:1fr 80px 1fr}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px}.item-emoji-large{font-size:2em}.item-name{font-size:.75em}}.active-buffs-section{margin-top:20px;padding:15px;background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:12px;border:2px solid #667eea}.active-buffs-section h4{margin:0 0 12px;font-size:1.1em;color:var(--primary-color);text-align:center}.active-buffs-list{display:flex;flex-direction:column;gap:8px}.active-buff-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:8px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.buff-emoji{font-size:1.8em}.buff-info{flex:1;display:flex;flex-direction:column;gap:2px}.buff-name{font-weight:600;font-size:.9em;color:var(--text-primary)}.buff-remaining{font-size:.8em;color:var(--primary-color);font-weight:500}.use-button{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:600;cursor:pointer;transition:all .2s;margin-top:15px}.use-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.use-button:disabled{background:var(--border-color);cursor:not-allowed;opacity:.6}.sell-button{width:100%;padding:10px;background:var(--warning-color);color:var(--text-inverse);border:none;border-radius:8px;font-size:.95em;font-weight:600;cursor:pointer;transition:all .2s;margin-top:10px}.sell-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66;background:linear-gradient(135deg,#fbbf24,#f59e0b)}.sell-button:active{transform:translateY(0)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-modal);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.hand-selector-modal{background:var(--bg-secondary);border-radius:12px;padding:30px;max-width:500px;width:90%;box-shadow:var(--shadow-lg);border:2px solid var(--border-color);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.hand-selector-modal h3{margin:0 0 15px;color:var(--text-primary);font-size:1.5em;text-align:center}.hand-selector-modal p{margin:0 0 25px;color:var(--text-secondary);text-align:center;font-size:1.1em}.hand-selector-modal p strong{color:var(--primary-color)}.hand-buttons{display:flex;gap:15px;margin-bottom:20px}.hand-button{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:25px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.hand-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #667eea80}.hand-button:active{transform:translateY(-1px)}.hand-icon{font-size:3em;line-height:1}.hand-label{font-size:1.2em}.current-item{font-size:.85em;font-weight:400;opacity:.9;margin-top:5px;background:#fff3;padding:5px 10px;border-radius:5px;text-align:center}.cancel-button{width:100%;padding:12px;background:var(--text-muted);border:none;border-radius:8px;color:var(--text-inverse);font-size:1em;font-weight:600;cursor:pointer;transition:all .3s ease}.cancel-button:hover{background:var(--border-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.sell-modal{background:var(--bg-secondary);border-radius:12px;padding:30px;max-width:450px;width:90%;box-shadow:var(--shadow-lg);border:2px solid var(--border-color);animation:slideUp .3s ease-out}.sell-modal h3{margin:0 0 15px;color:var(--text-primary);font-size:1.5em;text-align:center}.sell-modal p{margin:0 0 25px;color:var(--text-secondary);text-align:center;font-size:1.05em}.sell-modal p strong{color:var(--warning-color)}.quantity-selector{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:25px}.qty-button{width:45px;height:45px;background:var(--primary-color);border:none;border-radius:8px;color:var(--text-inverse);font-size:1.5em;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.qty-button:hover:not(:disabled){transform:scale(1.1);background:var(--primary-hover);box-shadow:var(--shadow-md)}.qty-button:disabled{opacity:.3;cursor:not-allowed}.quantity-display{display:flex;align-items:center;gap:8px}.quantity-input{width:70px;padding:10px;font-size:1.3em;font-weight:600;text-align:center;border:2px solid var(--input-border);border-radius:8px;background:var(--input-bg);color:var(--input-text)}.quantity-input:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px #3b82f633}.quantity-max{font-size:1.1em;color:var(--text-secondary);font-weight:600}.sell-info{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:15px;border-radius:8px;margin-bottom:20px}.sell-price-info,.sell-total-info{margin:8px 0;color:#92400e;font-size:1em;display:flex;justify-content:space-between;align-items:center}.sell-total-info{font-size:1.2em;font-weight:700;border-top:2px solid #fbbf24;padding-top:10px;margin-top:10px}.gold-amount,.gold-amount-total{color:#b45309;font-weight:700}.gold-amount-total{font-size:1.3em}.modal-buttons{display:flex;gap:10px}.confirm-sell-button{flex:1;padding:12px;background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:8px;color:#fff;font-size:1.1em;font-weight:600;cursor:pointer;transition:all .3s ease}.confirm-sell-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b80}.modal-buttons .cancel-button{flex:1}.flag-designer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;overflow:auto}.flag-designer-modal{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000004d;max-width:1200px;width:90%;max-height:90vh;display:flex;flex-direction:column;margin:20px}.flag-designer-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:2px solid #e0e0e0;background:#f8f9fa}.flag-designer-header h2{margin:0;font-size:24px;color:#333}.close-btn{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#f0f0f0;color:#333}.flag-designer-content{display:grid;grid-template-columns:1fr 400px;gap:30px;padding:30px;flex:1;overflow:hidden}.flag-canvas-container{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#2a2a2a;border-radius:12px;padding:20px;position:relative;overflow:auto;min-height:0}.flag-canvas{border:2px solid #666;box-shadow:0 4px 12px #0000004d;cursor:crosshair;background:#fff;max-width:100%;max-height:500px;width:auto;height:auto}.canvas-footer{display:flex;gap:15px;margin-top:10px;align-items:center;flex-wrap:wrap}.canvas-info{font-size:14px;color:#fff;font-weight:600;white-space:nowrap}.elements-list{display:flex;gap:6px;flex-wrap:wrap;flex:1}.element-item{width:32px;height:32px;border:2px solid #666;background:#1a1a1a;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#fff}.element-item:hover{border-color:#667eea;transform:scale(1.1)}.element-item.active{border-color:#667eea;background:#667eea;box-shadow:0 0 8px #667eea99}.flag-controls{overflow-y:auto;padding-right:10px}.control-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.control-section:last-child{border-bottom:none}.control-section h3{margin:0 0 15px;font-size:16px;color:#333;font-weight:600}.aspect-ratio-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.aspect-btn{padding:10px;border:2px solid #ddd;background:#fff;border-radius:8px;cursor:pointer;font-size:12px;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px;color:#333;font-weight:500}.aspect-btn:hover{border-color:#667eea;transform:translateY(-1px)}.aspect-btn.active{border-color:#667eea;background:#667eea;color:#fff;font-weight:600}.shape-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.shape-btn{padding:12px;border:2px solid #667eea;background:#fff;border-radius:8px;cursor:pointer;font-size:24px;display:flex;flex-direction:column;align-items:center;gap:5px;transition:all .2s;color:#333}.shape-btn span{font-size:10px;text-transform:capitalize;color:#333}.shape-btn:hover:not(:disabled){background:#667eea;color:#fff;transform:translateY(-2px)}.shape-btn:hover:not(:disabled) span{color:#fff}.shape-btn span{color:inherit}.shape-btn:disabled{opacity:.3;cursor:not-allowed}.color-picker{width:100%;height:50px;border:2px solid #ddd;border-radius:8px;cursor:pointer;padding:5px}.control-section label{display:block;margin-bottom:15px;font-size:14px;color:#333}.control-section input[type=range]{width:100%;margin-top:8px;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none}.control-section input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer}.control-section input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.layer-controls{display:flex;gap:10px;margin-top:15px}.layer-controls button{flex:1;padding:8px;border:2px solid #667eea;background:#fff;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s;color:#333;font-weight:600}.layer-controls button:hover{background:#667eea;color:#fff}.layer-controls .delete-btn{border-color:#e74c3c;color:#e74c3c}.layer-controls .delete-btn:hover{background:#e74c3c;color:#fff}.flag-designer-footer{display:flex;justify-content:flex-end;gap:15px;padding:20px 30px;border-top:2px solid #e0e0e0}.flag-designer-footer button{padding:12px 30px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn{background:#e0e0e0;color:#333}.cancel-btn:hover{background:#d0d0d0}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.save-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media(max-width:1024px){.flag-designer-content{grid-template-columns:1fr}.flag-canvas{max-width:100%;height:auto}}.leaderboard-container{padding:20px;max-width:1600px;margin:0 auto}.leaderboard-header{text-align:center;margin-bottom:30px}.leaderboard-header h2{font-size:2.5em;margin:0 0 10px;color:var(--text-primary);background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.leaderboard-description{color:var(--text-secondary);font-size:1.1em;margin:0}.leaderboard-loading,.leaderboard-error,.leaderboard-empty{text-align:center;padding:40px;font-size:1.2em}.leaderboard-loading{color:var(--text-secondary)}.leaderboard-error{background:#fee;color:#c33;border-radius:8px}.leaderboard-empty{color:var(--text-muted);font-style:italic}.leaderboard-table-container{overflow-x:auto;overflow-y:visible;background:var(--bg-secondary);border-radius:12px;box-shadow:var(--shadow-md);max-width:100%;-webkit-overflow-scrolling:touch;position:relative}.leaderboard-table-container:after{content:"← Scroll →";position:absolute;bottom:0;left:50%;transform:translate(-50%);background:#667eeae6;color:#fff;padding:4px 12px;border-radius:4px 4px 0 0;font-size:.75em;opacity:0;transition:opacity .3s;pointer-events:none}@media(max-width:800px){.leaderboard-table-container:after{opacity:1}}.leaderboard-table{width:100%;min-width:750px;border-collapse:collapse;display:table}.leaderboard-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:sticky;top:0;z-index:10}.leaderboard-table th{padding:15px 12px;text-align:left;font-weight:600;font-size:.9em;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(135deg,#667eea,#764ba2)}.leaderboard-table tbody tr{border-bottom:1px solid var(--border-light);transition:background-color .2s;background:var(--bg-secondary)}.leaderboard-table tbody tr:hover{background-color:var(--bg-hover)}.leaderboard-table tbody tr.top-three{background-color:var(--bg-tertiary)}.leaderboard-table tbody tr.top-three:hover{background-color:var(--bg-hover)}.leaderboard-table td{padding:15px 12px;color:var(--text-primary)}.rank-cell{text-align:center;font-weight:700;width:80px}.rank-badge{font-size:1.3em}.hero-cell{min-width:200px}.hero-info{display:flex;flex-direction:row;gap:12px;align-items:center}.hero-flag{flex-shrink:0;display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);border-radius:4px;overflow:hidden;background:var(--bg-primary);box-shadow:var(--shadow-sm)}.hero-text{display:flex;flex-direction:column;gap:4px}.hero-name{font-weight:600;font-size:1.05em;color:var(--text-primary)}.player-name{font-size:.85em;color:var(--text-secondary)}.faction-cell{min-width:150px}.faction-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg-tertiary);border-radius:12px;font-size:.9em;color:var(--text-primary)}.fame-cell{text-align:center;width:100px}.fame-display{display:flex;flex-direction:column;align-items:center;gap:4px}.fame-stars{font-size:1.2em;text-shadow:0 0 10px rgba(255,215,0,.8);animation:fameTwinkle 2s ease-in-out infinite}@keyframes fameTwinkle{0%,to{text-shadow:0 0 10px rgba(255,215,0,.8)}50%{text-shadow:0 0 20px rgba(255,215,0,1)}}.fame-number{font-size:.85em;font-weight:700;color:gold;background:#ffd70033;padding:2px 8px;border-radius:8px;border:1px solid rgba(255,215,0,.4)}.no-fame{color:#999;font-size:.9em}.leaderboard-row.has-fame{background:linear-gradient(135deg,#ffd7000d,#ff8c000d);border-left:3px solid #FFD700}.leaderboard-row.has-fame:hover{background:linear-gradient(135deg,#ffd7001a,#ff8c001a)}.level-cell{text-align:center;width:80px}.level-badge{display:inline-block;padding:4px 12px;background:linear-gradient(135deg,gold,#ffed4e);border-radius:12px;font-weight:600;color:#333;font-size:.95em}.exp-cell{text-align:right;font-family:Courier New,monospace;color:#666;width:120px}.record-cell{text-align:center;width:150px}.record-display{display:flex;flex-direction:column;gap:4px;align-items:center}.record-text{font-family:Courier New,monospace;font-size:.9em;font-weight:600;color:#666}.winrate-cell{width:150px}.winrate-bar-container{position:relative;height:20px;width:100%;background:#e0e0e0;border-radius:12px;overflow:hidden}.winrate-bar{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease;border-radius:12px}.winrate-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-size:.85em;font-weight:600;color:#333;text-shadow:0 1px 2px rgba(255,255,255,.8)}.created-cell{color:#999;font-size:.9em;white-space:nowrap;width:100px;text-align:center}body.dark-mode .leaderboard-header h2{color:#e0e0e0}@media(max-width:1200px){.leaderboard-table{font-size:.9em}}@media(max-width:850px){.created-cell{display:none}.leaderboard-table{min-width:600px}}@media(max-width:600px){.leaderboard-table th,.leaderboard-table td{padding:10px 8px}.faction-cell{min-width:auto}.faction-badge{font-size:.8em;padding:3px 8px}}.admin-item-editor{padding:20px;max-width:1400px;margin:0 auto}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:20px;flex-wrap:wrap}.editor-header h2{margin:0;color:#333;font-size:2em;flex-shrink:0}body.dark-mode .editor-header h2{color:#fff}.header-controls{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.filter-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:6px;background:#f3f4f6;border:2px solid #e5e7eb;transition:all .2s;-webkit-user-select:none;user-select:none}.filter-checkbox:hover{background:#e5e7eb;border-color:#d1d5db}body.dark-mode .filter-checkbox{background:#2a2a2a;border-color:#444;color:#fff}body.dark-mode .filter-checkbox:hover{background:#333;border-color:#555}.filter-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.filter-checkbox span{font-size:.95em;font-weight:500;color:#333}body.dark-mode .filter-checkbox span{color:#fff}.search-input{padding:10px 15px;font-size:1em;border:2px solid #ddd;border-radius:8px;width:300px}body.dark-mode .search-input{background:#2a2a2a;border-color:#444;color:#fff}.loading,.error{text-align:center;padding:40px;font-size:1.2em}.error{color:#dc2626}.error-message{background:#fee;color:#c33;padding:12px 20px;border-radius:8px;margin-bottom:20px;border:1px solid #fcc}.editor-layout{display:grid;grid-template-columns:350px 1fr;gap:20px;min-height:600px}@media(max-width:900px){.editor-layout{grid-template-columns:1fr}}.items-list{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;overflow-y:auto;max-height:800px}body.dark-mode .items-list{background:#1a1a1a}.items-list h3{margin:0 0 15px;color:#333;font-size:1.2em}body.dark-mode .items-list h3{color:#fff}.item-row{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:8px;border:2px solid transparent}.item-row:hover{background:#f3f4f6}body.dark-mode .item-row:hover{background:#2a2a2a}.item-row.selected{background:#e0e7ff;border-color:#667eea}body.dark-mode .item-row.selected{background:#2d3748;border-color:#667eea}.item-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#f9fafb;border:2px solid #e5e7eb;flex-shrink:0}body.dark-mode .item-icon{background:#2a2a2a;border-color:#444}.item-icon img{width:40px;height:40px;object-fit:contain}.item-emoji{font-size:24px}.item-info{flex:1;min-width:0}.item-name{font-weight:600;color:#333;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}body.dark-mode .item-name{color:#fff}.item-meta{display:flex;gap:8px;font-size:.85em}.item-rarity{font-weight:600}.item-type,.item-tier{color:#6b7280}body.dark-mode .item-type,body.dark-mode .item-tier{color:#9ca3af}.item-editor{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 8px #0000001a}body.dark-mode .item-editor{background:#1a1a1a}.item-editor h3{margin:0 0 20px;color:#333;font-size:1.5em}body.dark-mode .item-editor h3{color:#fff}.item-editor h4{margin:0 0 12px;color:#555;font-size:1.1em}body.dark-mode .item-editor h4{color:#ccc}.current-image{margin-bottom:30px}.image-preview{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:20px;display:flex;align-items:center;justify-content:center;min-height:200px}body.dark-mode .image-preview{background:#2a2a2a;border-color:#444}.image-preview img{max-width:100%;max-height:300px;object-fit:contain}.no-image{background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;padding:40px;text-align:center}body.dark-mode .no-image{background:#2a2a2a;border-color:#444}.emoji-large{font-size:80px;display:block;margin-bottom:10px}.no-image p{color:#6b7280;margin:0}body.dark-mode .no-image p{color:#9ca3af}.item-details{background:#f9fafb;border-radius:8px;padding:20px;margin-bottom:30px}body.dark-mode .item-details{background:#2a2a2a}.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e5e7eb}body.dark-mode .detail-row{border-bottom-color:#444}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:600;color:#6b7280}body.dark-mode .detail-row .label{color:#9ca3af}.detail-row .value{color:#333;font-weight:500}body.dark-mode .detail-row .value{color:#fff}.upload-area{background:linear-gradient(135deg,#e0e7ff,#fef3c7);border:3px dashed #667eea;border-radius:12px;padding:30px;text-align:center;outline:none;cursor:pointer;transition:all .3s}.upload-area:hover,.upload-area:focus{border-color:#764ba2;background:linear-gradient(135deg,#ddd6fe,#fde68a);transform:scale(1.02)}.upload-instructions{color:#6b7280;margin:10px 0 20px;font-size:1.1em}.file-input{display:none}.upload-button{display:inline-block;padding:12px 30px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-weight:600;font-size:1.1em;cursor:pointer;transition:all .3s;border:none}.upload-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.upload-button:active{transform:translateY(0)}.no-selection{text-align:center;padding:60px 20px;color:#9ca3af;font-size:1.2em}body.dark-mode .no-selection{color:#6b7280}
