@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700;800&family=Cinzel+Decorative:wght@400;700;900&family=UnifrakturMaguntia&display=swap";@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700;800&family=Uncial+Antiqua&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow-y:auto;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#1a202c,#2d3748,#4a5568);color:#e2e8f0;touch-action:manipulation;user-select:text;-webkit-user-select:text;-webkit-touch-callout:default;-webkit-tap-highlight-color:rgba(0,0,0,.1)}#root{width:100vw;height:100vh;overflow:hidden}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:#cbd5e0}:root{--color-primary: #2d3748;--color-primary-dark: #1a202c;--color-primary-light: #4a5568;--color-secondary: #38a169;--color-accent: #d69e2e;--color-danger: #e53e3e;--color-warning: #dd6b20;--color-text: #e2e8f0;--color-text-muted: #a0aec0;--color-text-dark: #2d3748;--color-bg-overlay: rgba(26, 32, 44, .95);--color-border: #4a5568;--color-surface: #2d3748;--color-surface-elevated: #4a5568;--color-friendly: #38a169;--color-enemy: #e53e3e;--color-neutral: #a0aec0;--color-selected: #d69e2e;--color-movement: #4299e1;--color-attack: #f56565}.screen{width:100%;height:100%;position:relative;display:flex;flex-direction:column;overflow:visible;backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0);will-change:transform}.screen-content{flex:1;padding:1rem;overflow-y:auto;overflow-x:hidden}.header{background:var(--color-bg-overlay);padding:1rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--color-border);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.app,.battle-selection-screen,.game-mode-selection-screen,.settings-screen,.game-screen{backface-visibility:hidden;-webkit-backface-visibility:hidden;transform:translateZ(0);will-change:transform}.header-title{font-size:1.5rem;font-weight:700;color:var(--color-text);text-shadow:0 1px 2px rgba(0,0,0,.5)}.header-subtitle{font-size:.875rem;color:var(--color-text-muted);margin-top:.25rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;font-size:1rem;min-height:48px;position:relative;overflow:hidden}.btn-primary{background:linear-gradient(135deg,var(--color-secondary) 0%,#2f855a 100%);color:#fff;box-shadow:0 4px 6px -1px #0006}.btn-primary:hover,.btn-primary:active{background:linear-gradient(135deg,#2f855a 0%,var(--color-secondary) 100%);transform:translateY(-1px)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover,.btn-secondary:active{background:var(--color-surface-elevated);border-color:var(--color-accent);transform:translateY(-1px)}.btn-icon{width:48px;height:48px;padding:0;border-radius:50%;display:flex;align-items:center;justify-content:center}.card{background:var(--color-surface);border-radius:.75rem;padding:1.5rem;box-shadow:0 4px 6px -1px #0006;border:1px solid var(--color-border);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-secondary) 100%)}.card-title{font-size:1.25rem;font-weight:700;margin-bottom:.5rem;color:var(--color-text)}.card-subtitle{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1rem}@media (max-width: 768px){.header{padding:.75rem 1rem}.header-title{font-size:1.25rem}.screen-content{padding:.75rem}.btn{padding:.5rem 1rem;font-size:.875rem}.card{padding:1rem}}@media (max-width: 480px){.header{padding:.5rem}.header-title{font-size:1.125rem}.screen-content{padding:.5rem}}.pi-icon{display:inline-flex;width:1.4rem;height:1.4rem;align-items:center;justify-content:center;font-size:1.05rem;border-radius:6px;background:var(--pi-bg, #f5f5f5);color:var(--pi-fg, #222);box-shadow:0 0 0 1px #0000000f}.pi-serious .pi-icon,.pi-serious-wrapper .pi-icon{background:#1d2430!important;color:#e2e6eb!important;box-shadow:0 0 0 1px #2e3642;border-radius:2px}.pi-serious .pi-icon:hover,.pi-serious-wrapper .pi-icon:hover{box-shadow:0 0 0 1px #3a4656}.pi-icon:hover{box-shadow:0 0 0 2px #00000026}.high-contrast .pi-icon{box-shadow:0 0 0 2px #000;background:#fff!important;color:#000!important}.pi-default{--pi-bg: #ececec;--pi-fg: #444}.pi-archery{--pi-bg: #ffeadd;--pi-fg: #9b4614}.pi-shield{--pi-bg: #e0f0ff;--pi-fg: #1d5a97}.pi-elephant{--pi-bg: #ede7f6;--pi-fg: #56367f}.pi-cavalry{--pi-bg: #fff4d6;--pi-fg: #8d6400}.pi-snow{--pi-bg: #eef7ff;--pi-fg: #2a6f9b}.pi-temple{--pi-bg: #f2efe6;--pi-fg: #5d5140}.pi-naval{--pi-bg: #e1f5fe;--pi-fg: #006b8f}.pi-sword{--pi-bg: #fde4ef;--pi-fg: #a81755}.pi-crown{--pi-bg: #fff2cc;--pi-fg: #9a7100}.pi-trophy{--pi-bg: #ffeccc;--pi-fg: #a65d00}.pi-desert{--pi-bg: #f9ecd7;--pi-fg: #8a4e15}.pi-car{--pi-bg: #e8f5e9;--pi-fg: #2e7d32}.pi-eagle{--pi-bg: #edeff9;--pi-fg: #2f4596}.pi-camp{--pi-bg: #fff0e0;--pi-fg: #8a451d}.pi-forest{--pi-bg: #e3f3e8;--pi-fg: #1f6234}.pi-storm{--pi-bg: #ebeef5;--pi-fg: #3a506e}.pi-wave{--pi-bg: #e0f3ff;--pi-fg: #0a5d8f}.legacy-icon{font-size:1.4rem}.pi-unit{border-radius:4px;background:var(--pi-unit-bg, #f4f4f4);padding:2px 4px;box-shadow:0 0 0 1px #00000014}.high-contrast .pi-unit{background:#fff!important;box-shadow:0 0 0 2px #000}.rs-icon{display:inline-block;width:1em;height:1em;line-height:1;vertical-align:middle}.rs-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}.high-contrast .rs-icon svg{stroke-width:2}.rs-icon.rs-loading,.rs-icon.rs-fallback{opacity:.6}.anc-icon{display:inline-block;width:1em;height:1em;line-height:1;vertical-align:middle}.anc-icon svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.5}.anc-icon.anc-loading,.anc-icon.anc-fallback{opacity:.55}.anc-theme-mono .anc-icon svg{stroke-width:1.7}:root{--gaming-bg-primary: #0f172a;--gaming-bg-secondary: #1e293b;--gaming-bg-tertiary: #334155;--gaming-bg-elevated: #475569;--gaming-accent-primary: #3b82f6;--gaming-accent-secondary: #2563eb;--gaming-accent-tertiary: #1d4ed8;--gaming-accent-bright: #60a5fa;--gaming-text-primary: #f8fafc;--gaming-text-secondary: #e2e8f0;--gaming-text-tertiary: #cbd5e1;--gaming-text-muted: #94a3b8;--gaming-success: #10b981;--gaming-success-dark: #059669;--gaming-warning: #f59e0b;--gaming-warning-dark: #d97706;--gaming-danger: #ef4444;--gaming-danger-dark: #dc2626;--gaming-info: #06b6d4;--gaming-info-dark: #0891b2;--gaming-border: #374151;--gaming-border-light: #4b5563;--gaming-border-dark: #1f2937;--gaming-shadow: 0 10px 25px rgba(0, 0, 0, .5);--gaming-shadow-light: 0 4px 15px rgba(0, 0, 0, .3);--gaming-shadow-strong: 0 20px 40px rgba(0, 0, 0, .7);--gaming-glow: 0 0 20px rgba(59, 130, 246, .3);--gaming-glow-strong: 0 0 30px rgba(59, 130, 246, .5);--gaming-font-family: "Inter", "Roboto", -apple-system, BlinkMacSystemFont, sans-serif;--gaming-font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--gaming-font-size-xs: .75rem;--gaming-font-size-sm: .875rem;--gaming-font-size-base: 1rem;--gaming-font-size-lg: 1.125rem;--gaming-font-size-xl: 1.25rem;--gaming-font-size-2xl: 1.5rem;--gaming-font-size-3xl: 1.875rem;--gaming-font-size-4xl: 2.25rem;--gaming-font-size-5xl: 3rem;--gaming-space-1: .25rem;--gaming-space-2: .5rem;--gaming-space-3: .75rem;--gaming-space-4: 1rem;--gaming-space-5: 1.25rem;--gaming-space-6: 1.5rem;--gaming-space-8: 2rem;--gaming-space-10: 2.5rem;--gaming-space-12: 3rem;--gaming-space-16: 4rem;--gaming-radius-sm: .25rem;--gaming-radius-md: .375rem;--gaming-radius-lg: .5rem;--gaming-radius-xl: .75rem;--gaming-transition-fast: .1s ease-out;--gaming-transition-normal: .2s ease-out;--gaming-transition-slow: .3s ease-out}.gaming-app{font-family:var(--gaming-font-family);background:linear-gradient(135deg,var(--gaming-bg-primary) 0%,var(--gaming-bg-secondary) 100%);color:var(--gaming-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}.gaming-heading-1{font-size:var(--gaming-font-size-5xl);font-weight:800;line-height:1.1;color:var(--gaming-text-primary);margin-bottom:var(--gaming-space-6);text-shadow:0 2px 4px rgba(0,0,0,.5)}.gaming-heading-2{font-size:var(--gaming-font-size-4xl);font-weight:700;line-height:1.2;color:var(--gaming-text-primary);margin-bottom:var(--gaming-space-5);text-shadow:0 1px 3px rgba(0,0,0,.4)}.gaming-heading-3{font-size:var(--gaming-font-size-3xl);font-weight:600;line-height:1.3;color:var(--gaming-text-primary);margin-bottom:var(--gaming-space-4)}.gaming-heading-4{font-size:var(--gaming-font-size-2xl);font-weight:600;line-height:1.4;color:var(--gaming-text-secondary);margin-bottom:var(--gaming-space-3)}.gaming-body-large{font-size:var(--gaming-font-size-lg);line-height:1.6;color:var(--gaming-text-secondary)}.gaming-body{font-size:var(--gaming-font-size-base);line-height:1.5;color:var(--gaming-text-secondary)}.gaming-body-small{font-size:var(--gaming-font-size-sm);line-height:1.4;color:var(--gaming-text-tertiary)}.gaming-caption{font-size:var(--gaming-font-size-xs);line-height:1.3;color:var(--gaming-text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.gaming-mono{font-family:var(--gaming-font-mono);font-size:var(--gaming-font-size-sm);color:var(--gaming-accent-bright);background-color:#3b82f61a;padding:var(--gaming-space-1) var(--gaming-space-2);border-radius:var(--gaming-radius-sm)}.gaming-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--gaming-space-3) var(--gaming-space-6);font-size:var(--gaming-font-size-base);font-weight:600;border-radius:var(--gaming-radius-lg);border:1px solid transparent;cursor:pointer;transition:all var(--gaming-transition-normal);text-decoration:none;text-transform:uppercase;letter-spacing:.025em;min-height:44px;gap:var(--gaming-space-2);position:relative;overflow:visible}.gaming-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left var(--gaming-transition-slow)}.gaming-btn:hover:before{left:100%}.gaming-btn-primary{background:linear-gradient(135deg,var(--gaming-accent-primary),var(--gaming-accent-secondary));color:#fff;box-shadow:var(--gaming-shadow-light),var(--gaming-glow);border-color:var(--gaming-accent-tertiary)}.gaming-btn-primary:hover{background:linear-gradient(135deg,var(--gaming-accent-secondary),var(--gaming-accent-tertiary));box-shadow:var(--gaming-shadow),var(--gaming-glow-strong);transform:translateY(-2px)}.gaming-btn-secondary{background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));color:var(--gaming-text-primary);border-color:var(--gaming-border);box-shadow:var(--gaming-shadow-light)}.gaming-btn-secondary:hover{background:linear-gradient(135deg,var(--gaming-bg-tertiary),var(--gaming-bg-elevated));border-color:var(--gaming-accent-primary);box-shadow:var(--gaming-shadow);transform:translateY(-1px)}.gaming-btn-danger{background:linear-gradient(135deg,var(--gaming-danger),var(--gaming-danger-dark));color:#fff;box-shadow:var(--gaming-shadow-light)}.gaming-btn-danger:hover{background:linear-gradient(135deg,var(--gaming-danger-dark),#b91c1c);box-shadow:var(--gaming-shadow);transform:translateY(-2px)}.gaming-btn-large{padding:var(--gaming-space-4) var(--gaming-space-8);font-size:var(--gaming-font-size-lg);min-height:56px}.gaming-btn-small{padding:var(--gaming-space-2) var(--gaming-space-4);font-size:var(--gaming-font-size-sm);min-height:36px}.gaming-card{background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));border:1px solid var(--gaming-border);border-radius:var(--gaming-radius-xl);padding:var(--gaming-space-6);box-shadow:var(--gaming-shadow-light);transition:all var(--gaming-transition-normal);position:relative;overflow:hidden}.gaming-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gaming-accent-primary),var(--gaming-accent-bright));opacity:0;transition:opacity var(--gaming-transition-normal)}.gaming-card:hover{box-shadow:var(--gaming-shadow),var(--gaming-glow);transform:translateY(-4px);border-color:var(--gaming-accent-primary)}.gaming-card:hover:before{opacity:1}.gaming-card-header{margin-bottom:var(--gaming-space-4);padding-bottom:var(--gaming-space-4);border-bottom:1px solid var(--gaming-border)}.gaming-card-title{font-size:var(--gaming-font-size-xl);font-weight:700;color:var(--gaming-text-primary);margin-bottom:var(--gaming-space-2)}.gaming-card-subtitle{font-size:var(--gaming-font-size-sm);color:var(--gaming-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.gaming-card-content{margin-bottom:var(--gaming-space-4)}.gaming-card-footer{margin-top:var(--gaming-space-4);padding-top:var(--gaming-space-4);border-top:1px solid var(--gaming-border);display:flex;justify-content:space-between;align-items:center}.gaming-nav{background:linear-gradient(135deg,var(--gaming-bg-primary),var(--gaming-bg-secondary));border-bottom:1px solid var(--gaming-border);padding:var(--gaming-space-4) 0;box-shadow:var(--gaming-shadow-light);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gaming-nav-brand{font-size:var(--gaming-font-size-2xl);font-weight:800;color:var(--gaming-accent-bright);text-decoration:none;text-shadow:var(--gaming-glow)}.gaming-nav-links{display:flex;gap:var(--gaming-space-6);align-items:center}.gaming-nav-link{font-size:var(--gaming-font-size-base);font-weight:500;color:var(--gaming-text-secondary);text-decoration:none;padding:var(--gaming-space-2) var(--gaming-space-4);border-radius:var(--gaming-radius-md);transition:all var(--gaming-transition-fast);text-transform:uppercase;letter-spacing:.025em}.gaming-nav-link:hover,.gaming-nav-link.active{color:var(--gaming-accent-bright);background:linear-gradient(135deg,var(--gaming-bg-tertiary),var(--gaming-bg-elevated));box-shadow:var(--gaming-glow)}.gaming-hud{position:fixed;background:#0f172ae6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--gaming-border);border-radius:var(--gaming-radius-lg);padding:var(--gaming-space-4);box-shadow:var(--gaming-shadow)}.gaming-stat-display{display:flex;align-items:center;gap:var(--gaming-space-2);padding:var(--gaming-space-2) var(--gaming-space-3);background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));border-radius:var(--gaming-radius-md);border:1px solid var(--gaming-border)}.gaming-stat-label{font-size:var(--gaming-font-size-xs);color:var(--gaming-text-muted);text-transform:uppercase;letter-spacing:.05em}.gaming-stat-value{font-family:var(--gaming-font-mono);font-size:var(--gaming-font-size-lg);font-weight:700;color:var(--gaming-accent-bright)}.gaming-progress{width:100%;height:12px;background:linear-gradient(135deg,var(--gaming-bg-tertiary),var(--gaming-bg-secondary));border-radius:var(--gaming-radius-md);overflow:hidden;border:1px solid var(--gaming-border);box-shadow:inset 0 2px 4px #0000004d}.gaming-progress-bar{height:100%;background:linear-gradient(135deg,var(--gaming-accent-primary),var(--gaming-accent-bright));transition:width var(--gaming-transition-normal);border-radius:var(--gaming-radius-md);box-shadow:var(--gaming-glow);position:relative}.gaming-progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.2),transparent);border-radius:var(--gaming-radius-md)}.gaming-control-panel{display:flex;gap:var(--gaming-space-3);align-items:center;justify-content:center;padding:var(--gaming-space-4);background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));border-radius:var(--gaming-radius-xl);border:1px solid var(--gaming-border);box-shadow:var(--gaming-shadow-light)}.gaming-alert{padding:var(--gaming-space-4);border-radius:var(--gaming-radius-lg);margin-bottom:var(--gaming-space-4);border:1px solid;box-shadow:var(--gaming-shadow-light);position:relative;overflow:hidden}.gaming-alert:before{content:"";position:absolute;top:0;left:0;bottom:0;width:4px}.gaming-alert-info{background:linear-gradient(135deg,#06b6d41a,#0ea5e91a);border-color:var(--gaming-info);color:var(--gaming-info)}.gaming-alert-info:before{background:var(--gaming-info)}.gaming-alert-success{background:linear-gradient(135deg,#10b9811a,#0596691a);border-color:var(--gaming-success);color:var(--gaming-success)}.gaming-alert-success:before{background:var(--gaming-success)}.gaming-alert-warning{background:linear-gradient(135deg,#f59e0b1a,#d977061a);border-color:var(--gaming-warning);color:var(--gaming-warning)}.gaming-alert-warning:before{background:var(--gaming-warning)}.gaming-alert-danger{background:linear-gradient(135deg,#ef44441a,#dc26261a);border-color:var(--gaming-danger);color:var(--gaming-danger)}.gaming-alert-danger:before{background:var(--gaming-danger)}.gaming-container{max-width:1400px;margin:0 auto;padding:0 var(--gaming-space-4)}.gaming-grid{display:grid;gap:var(--gaming-space-6)}.gaming-grid-2{grid-template-columns:repeat(2,1fr)}.gaming-grid-3{grid-template-columns:repeat(3,1fr)}.gaming-grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.gaming-grid-3,.gaming-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.gaming-grid-2,.gaming-grid-3,.gaming-grid-4{grid-template-columns:1fr}.gaming-heading-1{font-size:var(--gaming-font-size-4xl)}.gaming-heading-2{font-size:var(--gaming-font-size-3xl)}.gaming-container{padding:0 var(--gaming-space-3)}}@keyframes gaming-glow-pulse{0%,to{box-shadow:var(--gaming-glow)}50%{box-shadow:var(--gaming-glow-strong)}}@keyframes gaming-slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes gaming-fade-in{0%{opacity:0}to{opacity:1}}.gaming-animate-glow{animation:gaming-glow-pulse 2s ease-in-out infinite}.gaming-animate-slide-up{animation:gaming-slide-up .6s ease-out}.gaming-animate-fade-in{animation:gaming-fade-in .4s ease-out}.gaming-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.gaming-focus-visible{outline:2px solid var(--gaming-accent-bright);outline-offset:2px;box-shadow:var(--gaming-glow)}@media (prefers-contrast: high){:root{--gaming-border: #ffffff;--gaming-text-secondary: #ffffff}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.home-secondary-menu{margin-top:var(--gaming-space-8);padding-top:var(--gaming-space-6);border-top:1px solid var(--gaming-border)}.secondary-menu-title{font-size:var(--gaming-font-size-lg);font-weight:600;color:var(--gaming-text-secondary);text-align:center;margin-bottom:var(--gaming-space-6);text-transform:uppercase;letter-spacing:.05em}.secondary-menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--gaming-space-4);max-width:800px;margin:0 auto}.gaming-btn-tertiary{background:linear-gradient(135deg,var(--gaming-bg-tertiary),var(--gaming-bg-elevated));color:var(--gaming-text-tertiary);border-color:var(--gaming-border-light);box-shadow:var(--gaming-shadow-light);font-size:var(--gaming-font-size-sm);padding:var(--gaming-space-2) var(--gaming-space-4);min-height:40px}.gaming-btn-tertiary:hover{background:linear-gradient(135deg,var(--gaming-bg-elevated),var(--gaming-accent-primary));color:var(--gaming-text-primary);border-color:var(--gaming-accent-primary);box-shadow:var(--gaming-shadow);transform:translateY(-1px)}.gaming-btn-tertiary:disabled{opacity:.6;cursor:not-allowed;background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));color:var(--gaming-text-muted)}.gaming-btn-tertiary:disabled:hover{transform:none;box-shadow:var(--gaming-shadow-light);border-color:var(--gaming-border)}.home-screen{padding:var(--gaming-space-8);text-align:center;max-width:1200px;margin:0 auto}.home-header{margin-bottom:var(--gaming-space-8)}.home-header h1{font-size:var(--gaming-font-size-5xl);font-weight:800;color:var(--gaming-text-primary);margin-bottom:var(--gaming-space-4);text-shadow:var(--gaming-glow)}.home-header .subtitle{font-size:var(--gaming-font-size-xl);color:var(--gaming-text-secondary);margin-bottom:var(--gaming-space-2)}.home-header .version{font-size:var(--gaming-font-size-sm);color:#fbbf24;font-family:var(--gaming-font-mono);text-shadow:0 0 8px rgba(251,191,36,.3)}.home-menu{display:flex;flex-direction:column;gap:var(--gaming-space-4);max-width:400px;margin:0 auto var(--gaming-space-8)}.home-footer{margin-top:var(--gaming-space-8);padding-top:var(--gaming-space-6);border-top:1px solid var(--gaming-border);color:var(--gaming-text-tertiary)}.home-footer p{margin:var(--gaming-space-2) 0}.gaming-note{font-size:var(--gaming-font-size-sm);color:var(--gaming-text-muted);font-style:italic}@media (max-width: 768px){.secondary-menu-grid{grid-template-columns:repeat(2,1fr);gap:var(--gaming-space-3)}.home-header h1{font-size:var(--gaming-font-size-4xl)}.home-screen{padding:var(--gaming-space-6)}}@media (max-width: 480px){.secondary-menu-grid{grid-template-columns:1fr}.home-menu{max-width:100%}}:root{--medieval-parchment-light: #f4f1e8;--medieval-parchment: #e8dcc0;--medieval-parchment-dark: #d4c4a0;--medieval-parchment-aged: #c4b088;--medieval-gold-light: #ffd700;--medieval-gold: #daa520;--medieval-gold-dark: #b8860b;--medieval-gold-antique: #996515;--medieval-bronze-light: #cd7f32;--medieval-bronze: #a0522d;--medieval-bronze-dark: #8b4513;--medieval-bronze-patina: #6b4423;--medieval-silver-light: #e6e6fa;--medieval-silver: #c0c0c0;--medieval-silver-dark: #a9a9a9;--medieval-silver-tarnished: #8c8c8c;--medieval-iron-light: #708090;--medieval-iron: #556b2f;--medieval-iron-dark: #2f4f4f;--medieval-iron-rust: #8b4513;--medieval-crimson: #dc143c;--medieval-royal-blue: #4169e1;--medieval-forest-green: #228b22;--medieval-deep-purple: #663399;--medieval-parchment-texture: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" viewBox="0 0 100 100"><defs><filter id="noise"><feTurbulence baseFrequency="0.9" numOctaves="4" stitchTiles="stitch"/><feColorMatrix values="0 0 0 0 0.9 0 0 0 0 0.8 0 0 0 0 0.6 0 0 0 0.1 0"/></filter></defs><rect width="100%" height="100%" filter="url(%23noise)" opacity="0.1"/></svg>');--medieval-metal-texture: linear-gradient( 45deg, rgba(255, 255, 255, .1) 25%, transparent 25%, transparent 75%, rgba(255, 255, 255, .1) 75% ), linear-gradient( -45deg, rgba(255, 255, 255, .1) 25%, transparent 25%, transparent 75%, rgba(255, 255, 255, .1) 75% );--medieval-gold-glow: 0 0 20px rgba(218, 165, 32, .6);--medieval-gold-glow-strong: 0 0 30px rgba(218, 165, 32, .8);--medieval-bronze-glow: 0 0 15px rgba(205, 127, 50, .5);--medieval-silver-glow: 0 0 15px rgba(192, 192, 192, .5);--medieval-crimson-glow: 0 0 20px rgba(220, 20, 60, .6);--medieval-embossed-shadow: inset 0 1px 0 rgba(255, 255, 255, .2), inset 0 -1px 0 rgba(0, 0, 0, .2), 0 2px 4px rgba(0, 0, 0, .3);--medieval-engraved-shadow: inset 0 2px 4px rgba(0, 0, 0, .3), inset 0 -1px 0 rgba(255, 255, 255, .1);--medieval-font-serif: "Cinzel", "Trajan Pro", "Times New Roman", serif;--medieval-font-decorative: "Cinzel Decorative", "Uncial Antiqua", serif;--medieval-font-manuscript: "UnifrakturMaguntia", "Old English Text MT", serif}.medieval-title{font-family:var(--medieval-font-decorative);background:linear-gradient(135deg,var(--medieval-gold-light),var(--medieval-gold),var(--medieval-gold-dark));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:2px 2px 4px rgba(0,0,0,.5);letter-spacing:.05em;position:relative}.medieval-title:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent,var(--medieval-gold),transparent);box-shadow:var(--medieval-gold-glow)}.medieval-heading{font-family:var(--medieval-font-serif);color:var(--medieval-gold);text-shadow:1px 1px 2px rgba(0,0,0,.7);letter-spacing:.02em}.medieval-manuscript{font-family:var(--medieval-font-manuscript);color:var(--medieval-parchment);text-shadow:1px 1px 2px rgba(0,0,0,.8);line-height:1.6}.medieval-illuminated-capital{font-family:var(--medieval-font-decorative);font-size:4em;line-height:.8;float:left;margin:.1em .1em 0 0;background:linear-gradient(135deg,var(--medieval-gold-light),var(--medieval-crimson));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:2px 2px 4px rgba(0,0,0,.5);filter:drop-shadow(0 0 8px rgba(218,165,32,.5))}.medieval-battle-card{background:linear-gradient(135deg,var(--gaming-bg-secondary) 0%,var(--gaming-bg-tertiary) 50%,var(--gaming-bg-secondary) 100%);border:2px solid var(--medieval-bronze);border-radius:16px;padding:1.5rem;position:relative;overflow:hidden;transition:all .4s ease;box-shadow:var(--gaming-shadow-light),inset 0 1px #ffffff1a}.medieval-battle-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--medieval-gold-dark),var(--medieval-gold-light),var(--medieval-gold-dark));box-shadow:var(--medieval-gold-glow)}.medieval-battle-card:after{content:"";position:absolute;inset:8px;border:1px solid rgba(218,165,32,.2);border-radius:12px;pointer-events:none;opacity:0;transition:opacity .3s ease}.medieval-battle-card:hover{transform:translateY(-6px) scale(1.02);border-color:var(--medieval-gold);box-shadow:var(--gaming-shadow),var(--medieval-gold-glow),inset 0 1px #fff3}.medieval-battle-card:hover:after{opacity:1}.medieval-battle-icon{font-size:3rem;text-align:center;margin-bottom:1rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5));transition:all .3s ease}.medieval-battle-card:hover .medieval-battle-icon{transform:scale(1.1);filter:drop-shadow(0 6px 12px rgba(218,165,32,.4))}.medieval-battle-name{font-family:var(--medieval-font-serif);font-size:1.4rem;font-weight:700;color:var(--medieval-gold);text-align:center;margin-bottom:.5rem;text-shadow:1px 1px 2px rgba(0,0,0,.7);letter-spacing:.02em}.medieval-battle-date{font-family:var(--medieval-font-serif);color:var(--medieval-bronze-light);font-size:1rem;text-align:center;margin-bottom:1rem;font-style:italic;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.medieval-battle-description{color:var(--gaming-text-secondary);font-size:.9rem;line-height:1.5;text-align:center;margin-bottom:1rem}.medieval-era-badge{display:inline-block;background:linear-gradient(135deg,var(--medieval-bronze),var(--medieval-bronze-dark));color:var(--medieval-parchment-light);padding:.3rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;box-shadow:var(--medieval-embossed-shadow);border:1px solid var(--medieval-bronze-light);position:relative;overflow:hidden}.medieval-era-badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.medieval-battle-card:hover .medieval-era-badge:before{left:100%}.medieval-era-badge.ancient{background:linear-gradient(135deg,var(--medieval-bronze),var(--medieval-bronze-dark))}.medieval-era-badge.medieval{background:linear-gradient(135deg,var(--medieval-gold-dark),var(--medieval-gold));color:var(--gaming-bg-primary)}.medieval-era-badge.renaissance{background:linear-gradient(135deg,var(--medieval-silver),var(--medieval-silver-dark));color:var(--gaming-bg-primary)}.medieval-era-badge.napoleonic{background:linear-gradient(135deg,var(--medieval-royal-blue),var(--medieval-deep-purple))}.medieval-era-badge.modern{background:linear-gradient(135deg,var(--medieval-iron),var(--medieval-iron-dark))}.medieval-btn{font-family:var(--medieval-font-serif);background:linear-gradient(135deg,var(--medieval-gold-dark),var(--medieval-gold),var(--medieval-gold-light));color:var(--gaming-bg-primary);border:2px solid var(--medieval-gold);border-radius:8px;padding:.8rem 2rem;font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow);text-shadow:1px 1px 2px rgba(0,0,0,.3)}.medieval-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.medieval-btn:hover{transform:translateY(-2px);box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow-strong),0 8px 16px #0000004d;border-color:var(--medieval-gold-light)}.medieval-btn:hover:before{left:100%}.medieval-btn:active{transform:translateY(0);box-shadow:var(--medieval-engraved-shadow)}.medieval-btn-secondary{background:linear-gradient(135deg,var(--medieval-bronze-dark),var(--medieval-bronze),var(--medieval-bronze-light));border-color:var(--medieval-bronze);box-shadow:var(--medieval-embossed-shadow),var(--medieval-bronze-glow);color:var(--medieval-parchment-light)}.medieval-btn-secondary:hover{border-color:var(--medieval-bronze-light);box-shadow:var(--medieval-embossed-shadow),0 0 20px #cd7f32b3,0 8px 16px #0000004d}.medieval-btn-danger{background:linear-gradient(135deg,#8b0000,var(--medieval-crimson),#ff4500);border-color:var(--medieval-crimson);box-shadow:var(--medieval-embossed-shadow),var(--medieval-crimson-glow);color:var(--medieval-parchment-light)}.medieval-progress{width:100%;height:16px;background:linear-gradient(135deg,var(--gaming-bg-tertiary),var(--gaming-bg-secondary));border:2px solid var(--medieval-bronze-dark);border-radius:8px;overflow:hidden;position:relative;box-shadow:var(--medieval-engraved-shadow)}.medieval-progress:before{content:"";position:absolute;inset:0;background:var(--medieval-parchment-texture);opacity:.1;pointer-events:none}.medieval-progress-bar{height:100%;background:linear-gradient(135deg,var(--medieval-gold-dark),var(--medieval-gold-light),var(--medieval-gold),var(--medieval-gold-dark));background-size:20px 20px;transition:width .5s ease;position:relative;box-shadow:var(--medieval-gold-glow)}.medieval-progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.3),transparent);border-radius:4px 4px 0 0}.medieval-heraldic-border{border:3px solid var(--medieval-gold);border-image:linear-gradient(45deg,var(--medieval-gold-dark),var(--medieval-gold-light),var(--medieval-gold),var(--medieval-gold-dark)) 1;position:relative}.medieval-heraldic-border:before,.medieval-heraldic-border:after{content:"⚜";position:absolute;font-size:1.5rem;color:var(--medieval-gold);text-shadow:var(--medieval-gold-glow)}.medieval-heraldic-border:before{top:-12px;left:-12px}.medieval-heraldic-border:after{bottom:-12px;right:-12px}.medieval-coat-of-arms{width:60px;height:60px;background:linear-gradient(135deg,var(--medieval-crimson),var(--medieval-royal-blue));border:3px solid var(--medieval-gold);border-radius:50%/60% 60% 40% 40%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--medieval-gold);text-shadow:1px 1px 2px rgba(0,0,0,.8);box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow);position:relative;overflow:hidden}.medieval-coat-of-arms:before{content:"";position:absolute;inset:10%;border:1px solid rgba(255,255,255,.3);border-radius:50%/60% 60% 40% 40%}@keyframes medieval-banner-wave{0%,to{transform:rotate(0)}25%{transform:rotate(1deg)}75%{transform:rotate(-1deg)}}@keyframes medieval-emblem-shine{0%{background-position:-100% 0}to{background-position:100% 0}}.medieval-animate-banner{animation:medieval-banner-wave 4s ease-in-out infinite;transform-origin:top center}.medieval-animate-shine{background-image:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);background-size:200% 100%;animation:medieval-emblem-shine 3s ease-in-out infinite}@media (max-width: 768px){.medieval-title{font-size:var(--gaming-font-size-3xl)}.medieval-battle-card{padding:1rem}.medieval-battle-icon{font-size:2.5rem}.medieval-battle-name{font-size:1.2rem}.medieval-illuminated-capital{font-size:3em}}.medieval-theme .gaming-card{border-color:var(--medieval-bronze);background:linear-gradient(135deg,var(--gaming-bg-secondary) 0%,var(--gaming-bg-tertiary) 100%)}.medieval-theme .gaming-btn-primary{background:linear-gradient(135deg,var(--medieval-gold-dark),var(--medieval-gold-light));border-color:var(--medieval-gold);color:var(--gaming-bg-primary);box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow)}.medieval-theme .gaming-nav{border-bottom-color:var(--medieval-bronze)}.medieval-theme .gaming-nav-brand{color:var(--medieval-gold);text-shadow:var(--medieval-gold-glow)}.medieval-theme .gaming-progress-bar{background:linear-gradient(135deg,var(--medieval-gold-dark),var(--medieval-gold-light));box-shadow:var(--medieval-gold-glow)}.battle-theme-ancient{--theme-primary: var(--medieval-bronze);--theme-secondary: var(--medieval-bronze-light);--theme-accent: var(--medieval-gold)}.battle-theme-medieval{--theme-primary: var(--medieval-gold);--theme-secondary: var(--medieval-gold-light);--theme-accent: var(--medieval-crimson)}.battle-theme-renaissance{--theme-primary: var(--medieval-silver);--theme-secondary: var(--medieval-silver-light);--theme-accent: var(--medieval-royal-blue)}.battle-theme-napoleonic{--theme-primary: var(--medieval-royal-blue);--theme-secondary: var(--medieval-gold);--theme-accent: var(--medieval-crimson)}.battle-theme-modern{--theme-primary: var(--medieval-iron);--theme-secondary: var(--medieval-iron-light);--theme-accent: var(--gaming-accent-primary)}.unit-icon>span,.unit-icon>svg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;margin:auto;text-align:center;box-sizing:border-box;background:transparent!important;overflow:visible}.battle-replay-screen{background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;min-height:100vh;padding:20px}.replay-header{text-align:center;margin-bottom:20px}.replay-header h2{color:#e53e3e;margin:0 0 10px;font-size:28px}.replay-header p{color:#a0aec0;margin:0 0 20px}.back-button{background:#718096;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .3s}.back-button:hover{background:#4a5568}.replay-content{display:grid;grid-template-columns:1fr 400px;gap:20px;max-width:1400px;margin:0 auto}.battlefield-container{background:#0000004d;border-radius:10px;padding:20px;display:flex;justify-content:center;align-items:flex-start;overflow:auto;flex:1;min-height:0}.replay-battlefield{border:2px solid #4a5568;border-radius:8px;background:#2d3748;padding:10px}.replay-unit{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;font-size:16px}.replay-unit.england{color:#3182ce}.replay-unit.france,.replay-unit.french{color:#e53e3e}.replay-unit.russian{color:#38a169}.replay-unit.greeks{color:#3182ce}.replay-unit.persians{color:#d69e2e}.replay-controls-panel{background:#0000004d;border-radius:10px;padding:20px;height:fit-content}.replay-controls{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.control-button{padding:10px 15px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:700;transition:all .3s;flex:1;min-width:80px}.control-button:disabled{opacity:.5;cursor:not-allowed}.play-button{background:#48bb78;color:#fff}.play-button:hover:not(:disabled){background:#38a169}.pause-button{background:#ed8936;color:#fff}.pause-button:hover:not(:disabled){background:#dd6b20}.stop-button{background:#e53e3e;color:#fff}.stop-button:hover:not(:disabled){background:#c53030}.next-button{background:#4299e1;color:#fff}.next-button:hover:not(:disabled){background:#3182ce}.replay-progress{margin-bottom:20px}.progress-bar{width:100%;height:8px;background:#4a5568;border-radius:4px;overflow:hidden;margin-bottom:10px}.progress-fill{height:100%;background:linear-gradient(90deg,#4299e1,#3182ce);transition:width .3s ease}.replay-info{background:#4299e11a;border:1px solid #4299e1;border-radius:6px;padding:15px;margin-bottom:20px}.replay-info h3{color:#4299e1;margin:0 0 10px;font-size:18px}.replay-info p{margin:5px 0;color:#e2e8f0}.educational-commentary{background:#48bb781a;border:1px solid #48bb78;border-radius:6px;padding:15px}.educational-commentary h3{color:#48bb78;margin:0 0 15px;font-size:18px}.commentary-panel{background:#0000004d;border-radius:6px;padding:15px}.current-phase h4{color:#fbd38d;margin:0 0 10px;font-size:16px}.current-phase p{margin:8px 0;color:#e2e8f0;line-height:1.4}.current-phase p strong{color:#fbd38d}@media (max-width: 768px){.replay-content{grid-template-columns:1fr;gap:15px}.battlefield-container{padding:15px}.replay-battlefield{padding:5px}.replay-controls{flex-direction:column}.control-button{min-width:100%}}.battle-selection-screen{height:100vh;padding:2rem;background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;overflow-y:auto;display:flex;flex-direction:column}.battle-selection-content{max-width:1200px;margin:0 auto;flex:1;overflow-y:auto}.battle-search-controls{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center}.search-input{flex:1;min-width:300px;padding:.75rem 1rem;border:2px solid #4a5568;border-radius:8px;background:#2d3748cc;color:#fff;font-size:1rem}.search-input::placeholder{color:#a0aec0}.search-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e14d}.era-filter{padding:.75rem 1rem;border:2px solid #4a5568;border-radius:8px;background:#2d3748cc;color:#fff;font-size:1rem;min-width:150px}.era-filter:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e14d}.battles-grid{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:1.5rem!important;margin-top:2rem;margin-bottom:2rem;width:100%;max-width:1200px;margin-left:auto;margin-right:auto}@media (max-width: 1200px){.battles-grid{grid-template-columns:repeat(2,1fr)!important}}@media (max-width: 768px){.battles-grid{grid-template-columns:1fr!important}}.battle-card{background:#2d3748e6;border:2px solid #4a5568;border-radius:12px;padding:1.2rem;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.battle-card:hover{transform:translateY(-4px);border-color:#4299e1;box-shadow:0 8px 25px #4299e14d;background:#4299e11a}.battle-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(135deg,#4299e1,gold)}.battle-icon{font-size:2rem;text-align:center;margin-bottom:.8rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.battle-name{font-size:1.04rem;font-weight:700;margin-bottom:.4rem;color:gold;text-align:center}.battle-date{color:#4299e1;font-size:.72rem;margin-bottom:.8rem;text-align:center}.battle-description{color:#e2e8f0;font-size:.72rem;line-height:1.4;margin-bottom:.8rem;text-align:center}.battle-era{display:inline-block;background:#4299e133;color:#4299e1;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:700;margin-bottom:1rem}.battle-status{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:700;margin-left:.5rem}.battle-status.available{background:#48bb7833;color:#48bb78}.battle-status.premium{background:#ffd70033;color:gold}.battle-status.coming_soon{background:#a0aec033;color:#a0aec0}.home-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;padding:2rem;overflow-y:auto}.home-title{font-size:3.5rem;margin-bottom:1rem;background:linear-gradient(45deg,gold,#4299e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.home-subtitle{font-size:1.5rem;margin-bottom:3rem;color:#e2e8f0;max-width:600px}.home-navigation{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:400px}.home-navigation button{width:100%;padding:1rem 2rem;font-size:1.2rem;font-weight:700;border:2px solid #4a5568;border-radius:12px;background:#2d3748cc;color:#fff;cursor:pointer;transition:all .3s ease;min-height:60px}.home-navigation button:hover{transform:translateY(-2px);border-color:#4299e1;box-shadow:0 8px 25px #4299e14d;background:#4299e11a}.home-navigation button.primary{background:linear-gradient(135deg,#4299e1,#3182ce);border-color:#3182ce}.home-navigation button.primary:hover{background:linear-gradient(135deg,#3182ce,#2c5282);transform:translateY(-2px);box-shadow:0 8px 25px #3182ce66}.home-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid #4a5568;color:#a0aec0;font-size:.9rem}.game-mode-selection-screen{min-height:100vh;padding:2rem;background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;overflow-y:auto;overflow-x:hidden;display:block;box-sizing:border-box}body:has(.game-mode-selection-screen){overflow-y:auto!important}#root:has(.game-mode-selection-screen){overflow:visible!important}.mode-selection-content{max-width:800px;margin:0 auto;display:block}.mode-section,.faction-section,.difficulty-section{margin-bottom:2rem}.mode-section h3,.faction-section h3,.difficulty-section h3{color:gold;font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.mode-options,.faction-options,.difficulty-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.mode-option,.faction-option,.difficulty-option{background:#2d3748cc;border:2px solid #4a5568;border-radius:12px;padding:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.8rem}.mode-option:hover,.faction-option:hover,.difficulty-option:hover{transform:translateY(-2px);border-color:#4299e1;box-shadow:0 8px 25px #4299e14d;background:#4299e11a}.mode-option.selected,.faction-option.selected,.difficulty-option.selected{border-color:gold;background:#ffd7001a;box-shadow:0 0 20px #ffd7004d}.mode-icon,.faction-icon,.difficulty-icon{font-size:2.5rem;min-width:60px;text-align:center}.mode-text{display:flex;flex-direction:column;flex:1;min-width:0}.mode-text h4{margin:0 0 .25rem;font-size:1rem;font-weight:600;word-wrap:break-word;overflow-wrap:break-word}.mode-text p{margin:0;font-size:.85rem;color:#a0aec0;word-wrap:break-word;overflow-wrap:break-word}.mode-info,.faction-info,.difficulty-info{flex:1;text-align:left}.mode-info h4,.faction-info h4,.difficulty-info h4{color:#fff;margin:0 0 .5rem;font-size:1.2rem}.mode-info p,.faction-info p,.difficulty-info p{color:#a0aec0;margin:0;line-height:1.4}.battle-config-actions{display:flex;gap:1rem;justify-content:center;margin-top:3rem}.battle-config-actions button{padding:1rem 2rem;font-size:1.1rem;font-weight:700;border:2px solid #4a5568;border-radius:12px;background:#2d3748cc;color:#fff;cursor:pointer;transition:all .3s ease;min-width:150px;min-height:50px}.battle-config-actions button:hover{transform:translateY(-2px);border-color:#4299e1;box-shadow:0 8px 25px #4299e14d;background:#4299e11a}.battle-config-actions button.primary{background:linear-gradient(135deg,#48bb78,#38a169);border-color:#38a169}.battle-config-actions button.primary:hover{background:linear-gradient(135deg,#38a169,#2f855a);transform:translateY(-2px);box-shadow:0 8px 25px #38a16966}.battle-config-actions button:disabled{opacity:.5;cursor:not-allowed;transform:none}.battle-config-actions button:disabled:hover{border-color:#4a5568;background:#2d3748cc;box-shadow:none;transform:none}.game-screen{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;overflow:hidden}.unit-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem;padding:1rem 1.25rem 2.5rem}.app-container{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;overflow-y:auto;will-change:contents;backface-visibility:hidden;transform:translateZ(0)}.app-container>*{min-height:100vh;width:100%}.unit-card{background:#2d3748d9;border:1px solid #4a5568;border-radius:10px;padding:.75rem .9rem;display:flex;flex-direction:column;gap:.5rem;transition:all .25s ease;cursor:pointer;font-size:.8rem}.unit-card.current{border-color:#48bb78;box-shadow:0 0 0 2px #48bb7859,0 6px 14px -4px #0009}.unit-card:hover{transform:translateY(-3px);border-color:#4299e1;box-shadow:0 6px 18px -6px #4299e166;background:#4299e126}.unit-card-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.85rem;color:gold}.unit-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.unit-faction{font-size:.65rem;background:#ffd70026;padding:2px 6px;border-radius:6px;color:#ffe88a;letter-spacing:.5px}.unit-meta{display:flex;flex-wrap:wrap;gap:.4rem .8rem;font-size:.68rem;color:#e2e8f0;line-height:1.2}.unit-meta span{background:#0003;padding:2px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.08)}.battlefield-wrapper{position:relative;width:100%;height:100%;overflow:hidden;background:#1a202c66;border-right:2px solid #2f3b4a}.game-content.list-mode .battlefield-wrapper{display:none}.game-sidebar.collapsed{width:36px;padding:.25rem;overflow:visible}.sidebar-toggle{background:#2d3748;border:1px solid #4a5568;color:#e2e8f0;padding:4px 6px;border-radius:6px;cursor:pointer;margin-bottom:4px;width:100%}.game-sidebar.collapsed .turn-info,.game-sidebar.collapsed .battle-stats-container,.game-sidebar.collapsed .casualties-by-side,.game-sidebar.collapsed .game-log-panel{display:none}.view-toggle button{background:#2d3748;border:1px solid #4a5568;color:#e2e8f0;padding:4px 8px;font-size:.75rem;cursor:pointer;border-radius:4px 0 0 4px;line-height:1.1}.view-toggle button+button{border-radius:0 4px 4px 0;margin-left:-1px}.view-toggle button.active{background:#4299e1;border-color:#3182ce;color:#fff}.zoom-display{font-size:.7rem;color:#a0aec0;min-width:38px;text-align:center}.game-controls button:not(.primary):not(.secondary){background:#2d3748;color:#e2e8f0;border:1px solid #4a5568;padding:4px 8px;border-radius:4px}.game-controls button:not(.primary):not(.secondary):hover{border-color:#4299e1}.attack-range{box-shadow:inset 0 0 0 2px #e53e3e2e;background-color:#e53e3e0f!important}.game-log-panel{margin-top:1rem}.game-log-panel h3{margin:0 0 .5rem;font-size:.9rem;color:gold}.game-log-panel ul{list-style:none;padding:0;margin:0;max-height:160px;overflow:auto;font-size:.65rem;line-height:1.2}.game-log-panel li{padding:2px 4px;border-bottom:1px solid rgba(255,255,255,.05)}.game-log-panel li:last-child{border-bottom:none}@media (max-width: 640px){.unit-list{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.unit-card{font-size:.75rem}.unit-card-header{font-size:.8rem}.unit-meta{font-size:.62rem}}.game-header{padding:1rem 2rem;background:#2d3748e6;border-bottom:2px solid #4a5568;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.game-screen .game-header{position:sticky;top:0;z-index:40}.game-header h2{color:gold;font-size:1.5rem;margin:0}.turn-info{display:flex;flex-direction:column;align-items:center;gap:.5rem}.turn-info p{margin:0;font-size:1.1rem;color:#e2e8f0}.game-controls{display:flex;gap:1rem;align-items:center}.game-content{display:flex;flex:1;min-height:0;overflow:auto}.battlefield-wrapper{overflow:auto}.battlefield-grid{max-width:unset;max-height:unset}.battlefield{flex:1;padding:1rem;overflow:auto;background:#1a202ccc}.battlefield-grid{display:grid;gap:1px;max-width:100%;max-height:100%;background:#4a5568;border:2px solid #718096;border-radius:8px;overflow:hidden}.battlefield-cell{min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:all .2s ease}.battlefield-cell:hover{opacity:.8;transform:scale(1.05)}.battlefield-cell.possible-move{box-shadow:inset 0 0 0 2px #4299e1f2,0 0 4px #4299e180;background-color:#4299e12e!important;cursor:pointer;transition:all .15s ease-in-out}.battlefield-cell.possible-move:hover{box-shadow:inset 0 0 0 3px #4299e1,0 0 8px #4299e1cc;background-color:#4299e140!important}.battlefield-cell.possible-attack{box-shadow:inset 0 0 0 2px #e53e3e80;background-color:#e53e3e1a!important}.battlefield-cell.enemy-in-range{box-shadow:inset 0 0 0 4px red;background-color:#ff00004d!important;animation:pulseEnemyTarget 1s infinite}.battlefield-cell.aircraft-range{box-shadow:inset 0 0 0 1px #64b4ffb3;background-color:#64b4ff2e!important}.battlefield-cell.aircraft-range:hover{background-color:#64b4ff59!important;cursor:crosshair}.battlefield-cell.aircraft-airfield{box-shadow:inset 0 0 0 3px #ffdc32e6,0 0 8px #ffdc3280;background-color:#ffdc3259!important;animation:pulseAirfield 1.5s ease-in-out infinite}@keyframes pulseAirfield{0%,to{box-shadow:inset 0 0 0 3px #ffdc32e6,0 0 8px #ffdc3266}50%{box-shadow:inset 0 0 0 3px #ffdc32,0 0 16px #ffdc32b3}}@keyframes pulseEnemyTarget{0%,to{box-shadow:inset 0 0 0 4px red;background-color:#ff00004d!important}50%{box-shadow:inset 0 0 0 6px red,0 0 15px #f00c;background-color:#ff000080!important}}.move-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background-color:#4299e1e6;border:2px solid rgba(255,255,255,.8);border-radius:50%;box-shadow:0 0 4px #4299e1cc;z-index:25;pointer-events:none}.attack-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background-color:#e53e3ee6;border:2px solid rgba(255,255,255,.8);border-radius:50%;box-shadow:0 0 4px #e53e3ecc;z-index:25;pointer-events:none}@keyframes bounce{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}.unit{display:flex;flex-direction:column;align-items:center;font-size:.8rem;transition:all .2s ease}.unit.selected{transform:scale(1.18);filter:brightness(1.35) drop-shadow(0 0 6px rgba(255,255,255,.25));animation:pulse-selected 1.5s ease-in-out infinite}@keyframes pulse-selected{0%,to{filter:brightness(1.35) drop-shadow(0 0 6px rgba(255,255,255,.25))}50%{filter:brightness(1.5) drop-shadow(0 0 12px rgba(255,255,255,.5))}}.unit.current-player{filter:drop-shadow(0 0 4px currentColor)}.unit.current-player:hover{cursor:pointer;filter:brightness(1.2) drop-shadow(0 0 8px currentColor)}.unit:not(.current-player){opacity:.85}.enemy-in-range .unit{opacity:1;cursor:crosshair;filter:brightness(1.1) drop-shadow(0 0 6px rgba(255,0,0,.5))}.unit.has-acted{opacity:.6;border:2px dashed #ff9800!important;filter:grayscale(.4) brightness(.8);cursor:not-allowed!important}.unit.has-acted.selected{animation:none;filter:grayscale(.4) brightness(.9)}.unit-icon{font-size:var(--icon-size, 16px);font-weight:700;text-shadow:0 0 2px rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;min-height:20px;background:transparent!important;border:none!important}.nato-symbol{font-family:Courier New,monospace;font-weight:700;letter-spacing:-1px;text-shadow:0 0 3px rgba(0,0,0,.8);background:#0000001a;border-radius:2px;padding:1px 2px;display:inline-block;border:1px solid rgba(255,255,255,.3)}.professional-nato{font-family:Courier New,monospace;font-weight:700;font-size:var(--icon-size, 18px);text-align:center;background:#0003;border:2px solid;border-radius:3px;padding:2px 4px;min-width:20px;min-height:20px;display:inline-flex;align-items:center;justify-content:center}.nato-friendly{color:#4299e1;border-color:#4299e1}.nato-hostile{color:#e53e3e;border-color:#e53e3e}.nato-unknown{color:#d69e2e;border-color:#d69e2e}.nato-neutral{color:#48bb78;border-color:#48bb78}.music-controls{background:#4299e11a;padding:15px;border-radius:8px;margin-top:10px}.music-toggle{display:flex;align-items:center;font-size:16px}.music-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#4299e1}.song-selection{border-top:1px solid rgba(255,255,255,.1);padding-top:10px}.song-selection select{width:100%;padding:8px;background:#2d3748e6;border:1px solid #4a5568;border-radius:4px;color:#e2e8f0;font-size:14px}.song-selection select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 2px #4299e133}.unit-health-bar{width:30px;height:4px;background:#ffffff4d;border-radius:2px;overflow:hidden}.health-bar-fill{height:100%;transition:width .3s ease}.health-bar-fill.high{background:#48bb78}.health-bar-fill.medium{background:#ed8936}.health-bar-fill.low{background:#f56565}.unit-men-bar{width:30px;height:3px;margin-top:2px;background:#add8e640;border-radius:2px;overflow:hidden}.men-bar-fill{height:100%;background:#63b3ed;opacity:.85;transition:width .3s ease}.game-sidebar{width:300px;background:#2d3748e6;border-left:2px solid #4a5568;padding:1rem;overflow-y:auto}.ai-processing{background:#4299e133;padding:.5rem 1rem;border-radius:4px;border:1px solid #4299e1}.ai-indicator{color:#4299e1;font-size:.9rem}.settings-screen{min-height:100vh;max-height:100vh;overflow-y:auto;background:linear-gradient(135deg,#1a202c,#2d3748);color:#fff;padding:2rem}.settings-content{max-width:800px;margin:0 auto;padding-bottom:2rem}.screen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #4a5568}.screen-header h2{color:gold;font-size:2rem;margin:0}.screen-header p{color:#a0aec0;margin:.5rem 0 0}.settings-section{background:#2d3748cc;border:2px solid #4a5568;border-radius:12px;padding:2rem;margin-bottom:2rem}.settings-section h3{color:gold;font-size:1.3rem;margin:0 0 1rem}.settings-section p{color:#e2e8f0;margin:0 0 1rem;line-height:1.5}button{font-family:inherit;font-size:1rem;font-weight:700;padding:.75rem 1.5rem;border:2px solid #4a5568;border-radius:8px;background:#2d3748cc;color:#fff;cursor:pointer;transition:all .3s ease;min-height:44px;min-width:120px}button:hover{transform:translateY(-2px);border-color:#4299e1;box-shadow:0 4px 12px #4299e14d;background:#4299e11a}button.primary{background:linear-gradient(135deg,#4299e1,#3182ce);border-color:#3182ce}button.primary:hover{background:linear-gradient(135deg,#3182ce,#2c5282);transform:translateY(-2px);box-shadow:0 4px 12px #3182ce66}button.secondary{background:#4a5568cc;border-color:#4a5568}button.secondary:hover{background:#4a5568;border-color:#718096}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button:disabled:hover{border-color:#4a5568;background:#2d3748cc;box-shadow:none;transform:none}@media (max-width: 768px){.home-title{font-size:2.5rem}.home-subtitle{font-size:1.2rem}.mode-options,.faction-options,.difficulty-options{grid-template-columns:1fr}.battle-config-actions{flex-direction:column;align-items:stretch}.battle-config-actions button{width:100%}}.battle-stats-container{background:#000c;border:2px solid #4a5568;border-radius:8px;padding:15px;margin:10px 0;box-shadow:0 4px 6px #0000004d}.battle-stats-header{text-align:center;margin-bottom:15px;border-bottom:2px solid #4a5568;padding-bottom:10px}.battle-stats-header h4{color:gold;font-size:1.2em;font-weight:700;margin:0}.battle-stats-overview{margin-bottom:15px;padding:10px;background:#ffffff0d;border-radius:5px}.stat-item{display:flex;justify-content:space-between;align-items:center;margin:5px 0;padding:3px 0}.stat-label{color:#a0aec0;font-size:.9em;flex:1}.stat-value{color:#fff;font-weight:700;font-size:1em}.casualties-by-faction{margin-bottom:15px;padding:10px;background:#ff00001a;border:1px solid rgba(255,0,0,.3);border-radius:5px}.casualties-by-faction h5{color:#ff6b6b;margin:0 0 10px;font-size:1em;text-align:center;border-bottom:1px solid rgba(255,0,0,.3);padding-bottom:5px}.faction-casualties{margin-bottom:10px;padding:8px;background:#0000004d;border-radius:4px;border-left:4px solid #ffd700}.faction-name{color:gold;font-weight:700;font-size:1em;margin-bottom:5px;text-align:center}.faction-stats{display:flex;flex-direction:column;gap:3px}.faction-stat{display:flex;justify-content:space-between;align-items:center;font-size:.85em}.faction-stat .stat-label{color:#cbd5e0}.faction-stat .stat-value{color:#fff;font-weight:700}.battle-performance{padding:10px;background:#00ff000d;border:1px solid rgba(0,255,0,.2);border-radius:5px}.battle-performance h5{color:#68d391;margin:0 0 10px;font-size:1em;text-align:center;border-bottom:1px solid rgba(0,255,0,.2);padding-bottom:5px}.performance-stats{display:flex;flex-direction:column;gap:5px}.stats-log-separator{height:3px;background:linear-gradient(90deg,#4a5568,gold,#4a5568);margin:20px 0;border-radius:2px;box-shadow:0 2px 4px #0000004d}.game-log{background:#0009;border:2px solid #2d3748;border-radius:8px;padding:15px;margin-top:10px}.game-log h4{color:#90cdf4;font-size:1.1em;margin:0 0 10px;text-align:center;border-bottom:2px solid #2d3748;padding-bottom:8px}.log-entries{max-height:200px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#4a5568 #2d3748}.log-entry{padding:4px 8px;margin:2px 0;background:#ffffff0d;border-radius:3px;border-left:3px solid #4a5568;font-size:.9em;color:#e2e8f0;line-height:1.3}.log-entry:hover{background:#ffffff1a;border-left-color:#90cdf4}@media (max-width: 768px){.battle-stats-container{padding:10px;margin:5px 0}.stat-item,.faction-stat{font-size:.8em}.faction-casualties{padding:6px}}.audio-controls-compact{position:fixed;top:20px;right:20px;z-index:1000;display:flex;gap:.5rem;align-items:center}.audio-toggle-btn,.audio-settings-btn{width:44px;height:44px;border:2px solid var(--medieval-bronze);border-radius:50%;background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));color:var(--medieval-gold);font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:var(--gaming-shadow-light)}.audio-toggle-btn:hover,.audio-settings-btn:hover{transform:scale(1.1);border-color:var(--medieval-gold);box-shadow:var(--medieval-gold-glow)}.audio-toggle-btn.muted{background:linear-gradient(135deg,var(--medieval-crimson),#8b0000);border-color:var(--medieval-crimson)}.audio-settings-btn.active{background:linear-gradient(135deg,var(--medieval-gold-dark),var(--medieval-gold));color:var(--gaming-bg-primary);border-color:var(--medieval-gold-light)}.audio-settings-panel{position:absolute;top:50px;right:0;background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));border:2px solid var(--medieval-bronze);border-radius:12px;padding:1rem;min-width:280px;box-shadow:var(--gaming-shadow),var(--medieval-bronze-glow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.audio-setting{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.9rem}.audio-setting:last-child{margin-bottom:0}.audio-setting label{min-width:60px;color:var(--gaming-text-secondary);font-weight:500}.audio-slider{flex:1;height:6px;background:var(--gaming-bg-tertiary);border-radius:3px;outline:none;border:1px solid var(--medieval-bronze-dark)}.audio-slider::-webkit-slider-thumb{appearance:none;width:16px;height:16px;background:linear-gradient(135deg,var(--medieval-gold),var(--medieval-gold-light));border-radius:50%;cursor:pointer;border:2px solid var(--medieval-gold-dark);box-shadow:var(--medieval-gold-glow)}.audio-slider::-moz-range-thumb{width:16px;height:16px;background:linear-gradient(135deg,var(--medieval-gold),var(--medieval-gold-light));border-radius:50%;cursor:pointer;border:2px solid var(--medieval-gold-dark);box-shadow:var(--medieval-gold-glow)}.volume-value{min-width:35px;text-align:right;color:var(--medieval-gold);font-weight:600;font-size:.8rem}.audio-controls-full{background:linear-gradient(135deg,var(--gaming-bg-secondary),var(--gaming-bg-tertiary));border:2px solid var(--medieval-bronze);border-radius:16px;padding:1.5rem;margin:1rem 0;box-shadow:var(--gaming-shadow-light)}.audio-controls-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--medieval-bronze-dark)}.audio-controls-header h3{margin:0;color:var(--medieval-gold);font-size:1.3rem}.mute-button{padding:.5rem 1rem;font-size:.9rem;min-height:40px}.mute-button.muted{background:linear-gradient(135deg,var(--medieval-crimson),#8b0000);border-color:var(--medieval-crimson);color:#fff}.audio-controls-grid{display:grid;gap:1.5rem}.audio-control-group{display:flex;flex-direction:column;gap:.5rem}.audio-label{display:flex;align-items:center;gap:.5rem;color:var(--gaming-text-secondary);font-weight:600;font-size:1rem}.label-icon{font-size:1.2rem;min-width:24px}.audio-checkbox{width:18px;height:18px;accent-color:var(--medieval-gold)}.volume-control{display:flex;align-items:center;gap:1rem}.volume-control input[type=range]{flex:1;height:8px;background:linear-gradient(135deg,var(--gaming-bg-tertiary),var(--gaming-bg-secondary));border:1px solid var(--medieval-bronze-dark);border-radius:4px;outline:none;cursor:pointer}.volume-control input[type=range]::-webkit-slider-thumb{appearance:none;width:20px;height:20px;background:linear-gradient(135deg,var(--medieval-gold),var(--medieval-gold-light));border-radius:50%;cursor:pointer;border:2px solid var(--medieval-gold-dark);box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow);transition:all .2s ease}.volume-control input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow-strong)}.volume-control input[type=range]::-moz-range-thumb{width:20px;height:20px;background:linear-gradient(135deg,var(--medieval-gold),var(--medieval-gold-light));border-radius:50%;cursor:pointer;border:2px solid var(--medieval-gold-dark);box-shadow:var(--medieval-embossed-shadow),var(--medieval-gold-glow)}.volume-control input[type=range]:disabled{opacity:.5;cursor:not-allowed}.volume-display{min-width:45px;text-align:right;color:var(--medieval-gold);font-weight:700;font-family:var(--gaming-font-mono);font-size:.9rem;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.audio-status{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--medieval-bronze-dark);display:flex;flex-direction:column;gap:.5rem}.status-indicator{display:flex;align-items:center;gap:.5rem;color:var(--gaming-text-tertiary);font-size:.9rem}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--gaming-text-muted)}.status-dot.active{background:var(--gaming-success);box-shadow:0 0 8px #10b98180;animation:pulse 2s infinite}.status-dot.inactive{background:var(--gaming-danger)}.audio-warning{display:flex;align-items:center;gap:.5rem;color:var(--gaming-warning);font-size:.9rem;font-weight:600}.warning-icon{font-size:1rem}@media (max-width: 768px){.audio-controls-compact{top:10px;right:10px}.audio-settings-panel{right:-20px;min-width:260px}.audio-controls-full{padding:1rem}.audio-controls-header{flex-direction:column;gap:1rem;align-items:stretch}.audio-controls-header h3{text-align:center}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.audio-controls-full{animation:gaming-slide-up .5s ease-out}.audio-settings-panel{animation:gaming-slide-up .3s ease-out}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow-x:hidden}.app{position:relative;min-height:100vh;background:linear-gradient(135deg,#0f1419,#1a202c,#2d3748,#1a202c,#0f1419);background-size:400% 400%;animation:gradientShift 30s ease infinite;will-change:background-position}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.app:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20px 30px,rgba(255,215,0,.3),transparent),radial-gradient(2px 2px at 40px 70px,rgba(66,153,225,.3),transparent),radial-gradient(1px 1px at 90px 40px,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 130px 80px,rgba(255,215,0,.3),transparent),radial-gradient(2px 2px at 160px 30px,rgba(66,153,225,.3),transparent);background-repeat:repeat;background-size:200px 100px;animation:sparkle 20s linear infinite;pointer-events:none;z-index:1}@keyframes sparkle{0%{transform:translateY(0)}to{transform:translateY(-100px)}}.home-screen{position:relative;z-index:2;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home-header{margin-bottom:3rem;animation:fadeInUp 1s ease-out}.home-header h1{font-size:4rem;margin-bottom:1rem;background:linear-gradient(45deg,gold,#4299e1,#e53e3e,gold);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientText 3s ease infinite,glow 2s ease-in-out infinite alternate;text-shadow:0 0 30px rgba(255,215,0,.5);font-weight:700;letter-spacing:2px}@keyframes gradientText{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes glow{0%{text-shadow:0 0 20px rgba(255,215,0,.5),0 0 30px rgba(66,153,225,.3)}to{text-shadow:0 0 30px rgba(255,215,0,.8),0 0 40px rgba(66,153,225,.6)}}.subtitle{font-size:1.5rem;color:#e2e8f0;margin-bottom:1rem;animation:fadeIn 1.5s ease-out;text-shadow:0 2px 4px rgba(0,0,0,.5)}.version{font-size:1.1rem;color:#a0aec0;margin-bottom:2rem;animation:fadeIn 2s ease-out;background:#ffffff1a;padding:.5rem 1rem;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.home-menu{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;width:100%;max-width:800px;animation:fadeInUp 1s ease-out .5s both}.home-menu button{position:relative;padding:1.5rem 2rem;font-size:1.2rem;font-weight:700;border:none;border-radius:15px;background:linear-gradient(135deg,#4299e133,#2d3748cc);color:#fff;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);min-height:80px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0000004d}.home-menu button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.home-menu button:hover:before{left:100%}.home-menu button:hover{transform:translateY(-8px) scale(1.05);box-shadow:0 20px 40px #4299e166;background:linear-gradient(135deg,#4299e166,#2d3748e6);border-color:#4299e180}.home-menu button:active{transform:translateY(-4px) scale(1.02)}.battle-selection-screen{position:relative;z-index:2;min-height:100vh;padding:2rem;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.screen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;animation:slideInDown .8s ease-out}.screen-header h2{font-size:2.5rem;background:linear-gradient(45deg,gold,#4299e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;text-shadow:0 2px 4px rgba(0,0,0,.5)}.battle-filters{display:flex;gap:1.5rem;margin-bottom:2rem;flex-wrap:wrap;align-items:center;animation:slideInLeft .8s ease-out .2s both}.search-container{flex:1;min-width:300px;position:relative}.search-input{width:100%;padding:1rem 1.5rem;border:2px solid rgba(66,153,225,.3);border-radius:12px;background:#2d3748cc;color:#fff;font-size:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.search-input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 4px #4299e133,0 0 20px #4299e14d;transform:translateY(-2px)}.era-filter{display:flex;align-items:center;gap:.5rem}.era-select{padding:1rem 1.5rem;border:2px solid rgba(66,153,225,.3);border-radius:12px;background:#2d3748cc;color:#fff;font-size:1rem;min-width:180px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.era-select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 4px #4299e133}.battles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:2rem;animation:fadeInUp .8s ease-out .4s both}.battle-card{position:relative;background:linear-gradient(135deg,#2d3748e6,#1a202ce6);border-radius:20px;padding:2rem;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);border:2px solid rgba(66,153,225,.2);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);overflow:hidden;box-shadow:0 10px 30px #0000004d}.battle-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,gold,#4299e1,#e53e3e);transform:scaleX(0);transition:transform .3s ease}.battle-card:hover{transform:translateY(-10px) scale(1.02);border-color:#4299e180;box-shadow:0 20px 50px #4299e14d;background:linear-gradient(135deg,#4299e133,#2d3748e6)}.battle-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.battle-header h3{font-size:1.5rem;margin:0;color:gold;text-shadow:0 2px 4px rgba(0,0,0,.5)}.battle-date{font-size:.9rem;color:#a0aec0;background:#ffffff1a;padding:.3rem .8rem;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.battle-description{color:#e2e8f0;margin-bottom:1.5rem;line-height:1.6;font-style:italic}.battle-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.3rem}.detail-item .label{font-size:.8rem;color:#a0aec0;text-transform:uppercase;letter-spacing:1px}.detail-item .value{font-weight:700;color:#4299e1}.battle-actions button{width:100%;padding:1rem 2rem;font-size:1.1rem;font-weight:700;border:none;border-radius:12px;background:linear-gradient(135deg,#4299e1,#3182ce);color:#fff;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.battle-actions button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#ffffff4d;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease}.battle-actions button:hover:before{width:300px;height:300px}.battle-actions button:hover{transform:translateY(-2px);box-shadow:0 10px 25px #4299e166}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.home-header h1{font-size:2.5rem}.battles-grid{grid-template-columns:1fr}.battle-filters{flex-direction:column;align-items:stretch}.search-container{min-width:auto}}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid rgba(66,153,225,.3);border-radius:50%;border-top-color:#4299e1;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}:root{--gothic-black: #0a0a0a;--gothic-dark: #1a1a1a;--gothic-charcoal: #2a2a2a;--gothic-stone: #3a3a3a;--gothic-blood: #8b0000;--gothic-blood-dark: #660000;--gothic-gold: #d4af37;--gothic-gold-dark: #b8941f;--gothic-purple: #4b0082;--gothic-purple-dark: #350058;--gothic-silver: #c0c0c0;--gothic-bone: #f5f5dc;--gothic-shadow: 0 8px 32px rgba(0, 0, 0, .8);--gothic-shadow-heavy: 0 16px 48px rgba(0, 0, 0, .9);--gothic-glow-blood: 0 0 20px rgba(139, 0, 0, .5);--gothic-glow-gold: 0 0 20px rgba(212, 175, 55, .4);--gothic-font-title: "Cinzel", serif;--gothic-font-decorative: "Uncial Antiqua", cursive}.gothic-theme{background:linear-gradient(135deg,var(--gothic-black) 0%,var(--gothic-dark) 50%,var(--gothic-charcoal) 100%);color:var(--gothic-bone);font-family:var(--gothic-font-title);min-height:100vh}.gothic-theme:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 20% 80%,rgba(139,0,0,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(75,0,130,.1) 0%,transparent 50%);pointer-events:none;z-index:-1}.loading-screen{position:fixed;inset:0;background:linear-gradient(135deg,var(--gothic-black),var(--gothic-dark));display:flex;align-items:center;justify-content:center;z-index:9999}.loading-content{text-align:center;color:var(--gothic-bone)}.gothic-loader{font-size:4rem;animation:gothic-pulse 2s ease-in-out infinite;margin-bottom:1rem;color:var(--gothic-blood);text-shadow:var(--gothic-glow-blood)}@keyframes gothic-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.2);opacity:1}}.gothic-title{font-family:var(--gothic-font-decorative);font-size:3.5rem;color:var(--gothic-gold);text-shadow:var(--gothic-glow-gold);margin-bottom:1rem;text-align:center}.gothic-subtitle{font-family:var(--gothic-font-title);font-size:1.5rem;color:var(--gothic-silver);text-align:center;margin-bottom:2rem;font-weight:500}.gothic-btn{background:linear-gradient(135deg,var(--gothic-charcoal),var(--gothic-stone));border:2px solid var(--gothic-gold);color:var(--gothic-bone);padding:12px 24px;font-family:var(--gothic-font-title);font-weight:600;text-transform:uppercase;letter-spacing:1px;border-radius:4px;cursor:pointer;transition:all .3s ease;box-shadow:var(--gothic-shadow);position:relative;overflow:hidden}.gothic-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(212,175,55,.2),transparent);transition:left .5s}.gothic-btn:hover:before{left:100%}.gothic-btn:hover{background:linear-gradient(135deg,var(--gothic-stone),var(--gothic-gold-dark));box-shadow:var(--gothic-shadow-heavy),var(--gothic-glow-gold);transform:translateY(-2px);border-color:var(--gothic-gold)}.gothic-btn-blood{border-color:var(--gothic-blood);background:linear-gradient(135deg,var(--gothic-charcoal),var(--gothic-blood-dark))}.gothic-btn-blood:hover{background:linear-gradient(135deg,var(--gothic-blood-dark),var(--gothic-blood));box-shadow:var(--gothic-shadow-heavy),var(--gothic-glow-blood);border-color:var(--gothic-blood)}.gothic-card{background:linear-gradient(135deg,var(--gothic-dark),var(--gothic-charcoal));border:1px solid var(--gothic-stone);border-radius:8px;padding:1.5rem;box-shadow:var(--gothic-shadow);transition:all .3s ease;position:relative}.gothic-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gothic-gold),var(--gothic-blood));opacity:0;transition:opacity .3s}.gothic-card:hover{transform:translateY(-4px);box-shadow:var(--gothic-shadow-heavy);border-color:var(--gothic-gold)}.gothic-card:hover:before{opacity:1}.home-screen{background:transparent;padding:2rem;text-align:center}.home-header h1{font-family:var(--gothic-font-decorative);font-size:4rem;color:var(--gothic-gold);text-shadow:var(--gothic-glow-gold);margin-bottom:1rem}.home-header .subtitle{font-family:var(--gothic-font-title);font-size:1.5rem;color:var(--gothic-silver);margin-bottom:.5rem}.home-header .version{font-size:1rem;color:var(--gothic-stone);font-family:var(--gothic-font-title)}.battle-selection-screen{background:transparent;padding:2rem;min-height:100vh}.screen-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--gothic-gold)}.screen-header h2{font-family:var(--gothic-font-decorative);font-size:2.5rem;color:var(--gothic-gold);text-shadow:var(--gothic-glow-gold)}.battle-filters{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center}.search-input,.era-select{background:linear-gradient(135deg,var(--gothic-dark),var(--gothic-charcoal));border:2px solid var(--gothic-stone);color:var(--gothic-bone);padding:12px 16px;border-radius:4px;font-family:var(--gothic-font-title);font-size:1rem}.search-input:focus,.era-select:focus{outline:none;border-color:var(--gothic-gold);box-shadow:var(--gothic-glow-gold)}.battles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.battle-card{background:linear-gradient(135deg,var(--gothic-dark),var(--gothic-charcoal));border:2px solid var(--gothic-stone);border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .3s ease;box-shadow:var(--gothic-shadow);position:relative;overflow:hidden}.battle-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gothic-blood),var(--gothic-gold));transform:scaleX(0);transition:transform .3s}.battle-card:hover:before{transform:scaleX(1)}.battle-card:hover{transform:translateY(-6px);border-color:var(--gothic-gold);box-shadow:var(--gothic-shadow-heavy),var(--gothic-glow-gold)}.battle-icon{font-size:2.5rem;margin-bottom:1rem;text-align:center}.battle-name{font-family:var(--gothic-font-title);font-size:1.3rem;color:var(--gothic-gold);margin-bottom:.5rem;font-weight:700}.battle-era,.battle-difficulty,.battle-continent{font-size:.9rem;color:var(--gothic-silver);margin-bottom:.3rem}.premium-badge{position:absolute;top:10px;right:10px;background:var(--gothic-blood);color:var(--gothic-bone);padding:4px 8px;border-radius:4px;font-size:.8rem;font-weight:600}@media (max-width: 768px){.gothic-title{font-size:2.5rem}.home-header h1{font-size:3rem}.battles-grid{grid-template-columns:1fr}.battle-filters{flex-direction:column;align-items:center}}.replay-narrative-panel{background:linen;border:2px solid #8B4513;border-radius:8px;padding:20px;font-family:Georgia,Times New Roman,serif;color:#2f2f2f;max-height:600px;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.narrative-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #8B4513;gap:10px}.narrative-header h2{margin:0;font-size:1.8em;color:#8b4513;flex:1 1 auto}.turn-indicator{background:#8b4513;color:#fff;padding:5px 15px;border-radius:15px;font-weight:700;font-size:.9em}.tts-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.tts-button{padding:6px 12px;border:2px solid #8B4513;border-radius:4px;background:#fff8dc;cursor:pointer;font-size:.85em;font-weight:700;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.tts-button:hover{background:#ffe4b5;transform:translateY(-1px);box-shadow:0 3px 6px #00000026}.tts-button.enabled{background:#90ee90;border-color:#228b22;color:#006400}.tts-button.disabled{background:#ffb6c1;border-color:#dc143c;color:#8b0000}.tts-button.play{background:#87ceeb;border-color:#4682b4;color:#00008b}.tts-button.stop{background:#ffa07a;border-color:tomato;color:#8b0000}.tts-button:active{transform:translateY(1px);box-shadow:0 1px 2px #0000001a}.narrative-section{display:flex;gap:12px;margin-bottom:20px;padding:15px;background:#fff;border-left:4px solid #8B4513;border-radius:4px;box-shadow:0 2px 4px #0000000d}.section-icon{font-size:2em;flex-shrink:0}.section-content{flex:1}.section-title{margin:0 0 10px;font-size:1.3em;color:#8b0000;font-weight:700}.section-text{margin:8px 0;line-height:1.6;font-size:1.05em}.section-impact{margin-top:12px;padding:10px;background:#fff8dc;border-left:3px solid #DAA520;border-radius:4px;font-size:1em}.narrative-section.key-moment{border-left-color:#dc143c;background:linear-gradient(to right,#fff5f5,#fff)}.key-moment .section-title{color:#dc143c}.narrative-section.historical-context{border-left-color:#8b4513}.narrative-section.educational-note{border-left-color:#4169e1;background:linear-gradient(to right,#f0f8ff,#fff)}.educational-note .section-title{color:#4169e1}.commander-notes{margin-top:12px;padding:12px;background:beige;border:1px solid #D2B48C;border-radius:4px;font-style:italic}.commander-notes strong{display:block;margin-bottom:6px;font-style:normal;color:#8b4513;font-family:Arial,sans-serif;font-size:.95em;text-transform:uppercase;letter-spacing:.5px}.notes-text{margin:0;font-size:1.05em;color:#4a4a4a;line-height:1.5}.move-entry{margin-bottom:15px}.move-entry:last-child{margin-bottom:0}.narrative-section.empty-state{border-left-color:#999;background:#f9f9f9;justify-content:center}.empty-text{margin:0;color:#666;font-style:italic;text-align:center;font-size:1em}.replay-narrative-panel::-webkit-scrollbar{width:10px}.replay-narrative-panel::-webkit-scrollbar-track{background:#f0e6d6;border-radius:4px}.replay-narrative-panel::-webkit-scrollbar-thumb{background:#8b4513;border-radius:4px}.replay-narrative-panel::-webkit-scrollbar-thumb:hover{background:sienna}@media (max-width: 768px){.replay-narrative-panel{padding:15px}.narrative-header{flex-direction:column;align-items:flex-start;gap:10px}.narrative-header h2{font-size:1.5em}.turn-indicator{align-self:flex-end}.section-title{font-size:1.1em}.section-text{font-size:1em}.narrative-section{padding:12px}}@media print{.replay-narrative-panel{box-shadow:none;border:1px solid #000000}.turn-indicator{background:#fff;color:#000;border:1px solid #000000}.narrative-section{page-break-inside:avoid;box-shadow:none}}.replay-controls{background:#2f2f2f;border:2px solid #1A1A1A;border-radius:6px;padding:5px 10px;color:#fff;box-shadow:0 2px 4px #0000004d;overflow:hidden;min-width:0}.controls-main{display:flex;align-items:center;gap:8px;margin-bottom:4px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;min-width:0}.controls-main::-webkit-scrollbar{display:none}.controls-buttons{display:flex;gap:10px}.control-btn{background:#4169e1;color:#fff;border:none;padding:5px 10px;border-radius:5px;font-size:.88em;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0003;min-width:80px;white-space:nowrap}.control-btn:hover{background:#5a7feb;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.control-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0003}.play-btn{background:#28a745}.play-btn:hover{background:#34c759}.pause-btn{background:orange}.pause-btn:hover{background:#ffb833}.stop-btn{background:#dc143c}.stop-btn:hover{background:#f52549}.controls-speed{display:flex;align-items:center;gap:6px;background:#3a3a3a;padding:4px 10px;border-radius:5px}.controls-speed label{font-weight:700;font-size:.88em}.speed-select{background:#fff;color:#2f2f2f;border:2px solid #4169E1;border-radius:4px;padding:3px 8px;font-size:.88em;font-weight:700;cursor:pointer;transition:border-color .2s ease}.speed-select:hover{border-color:#5a7feb}.speed-select:focus{outline:none;border-color:gold;box-shadow:0 0 4px #ffd70080}.controls-turn-counter{display:flex;align-items:baseline;gap:4px;background:#3a3a3a;padding:4px 10px;border-radius:5px;font-size:1em;font-weight:700;margin-left:auto}.turn-label{color:#ccc;font-size:.9em}.turn-value{color:gold;font-size:1.3em}.turn-separator{color:#888}.turn-total{color:#ccc}.controls-timeline{position:relative;margin-bottom:4px;margin-top:6px}.timeline-slider{width:100%;height:8px;background:#3a3a3a;border-radius:4px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:#4169e1;border:2px solid #FFFFFF;border-radius:50%;cursor:pointer;transition:all .2s ease}.timeline-slider::-webkit-slider-thumb:hover{background:#5a7feb;transform:scale(1.2)}.timeline-slider::-moz-range-thumb{width:20px;height:20px;background:#4169e1;border:2px solid #FFFFFF;border-radius:50%;cursor:pointer;transition:all .2s ease}.timeline-slider::-moz-range-thumb:hover{background:#5a7feb;transform:scale(1.2)}.timeline-markers{position:absolute;top:0;left:0;width:100%;height:8px;pointer-events:none}.timeline-marker{position:absolute;top:-6px;transform:translate(-50%);font-size:1.2em;cursor:pointer;pointer-events:auto;transition:transform .2s ease;filter:drop-shadow(0 2px 2px rgba(0,0,0,.5))}.timeline-marker:hover{transform:translate(-50%) scale(1.3)}.controls-key-moments{display:flex;align-items:center;gap:6px;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:#4169E1 #1A1A1A;padding:2px 0;min-width:0;max-width:100%}.controls-key-moments::-webkit-scrollbar{height:4px}.controls-key-moments::-webkit-scrollbar-track{background:#1a1a1a}.controls-key-moments::-webkit-scrollbar-thumb{background:#4169e1;border-radius:2px}.key-moments-label{font-weight:700;font-size:.78em;color:#ccc;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}.key-moments-buttons{display:flex;gap:4px;flex-wrap:nowrap}.key-moment-btn{background:#3a3a3a;color:#fff;border:1px solid #4169E1;padding:3px 7px;border-radius:3px;font-size:.75em;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap}.key-moment-btn:hover{background:#4169e1;transform:translateY(-2px);box-shadow:0 2px 4px #0000004d}.key-moment-btn.active{background:gold;color:#2f2f2f;border-color:gold}.key-moment-btn.active:hover{background:#ffc700}@media (max-width: 768px){.replay-controls{padding:15px}.controls-main{flex-direction:column;align-items:stretch}.controls-buttons{flex-direction:column}.control-btn{width:100%}.controls-speed{justify-content:space-between}.controls-turn-counter{margin-left:0;justify-content:center}.key-moments-buttons{flex-direction:column}.key-moment-btn{width:100%}}.control-btn:focus,.key-moment-btn:focus{outline:3px solid #FFD700;outline-offset:2px}.timeline-slider:focus{box-shadow:0 0 0 3px #4169e180}@media (prefers-contrast: high){.replay-controls{border:3px solid #FFFFFF}.control-btn,.key-moment-btn{border:2px solid #FFFFFF}}@media (prefers-reduced-motion: reduce){.control-btn,.timeline-marker,.key-moment-btn{transition:none}}.historical-replay-engine{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:linear-gradient(135deg,#1a1a1a,#2f2f2f);color:#fff;font-family:Arial,sans-serif}.replay-engine.loading,.replay-engine.error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:#2f2f2f;color:#fff;text-align:center;padding:40px}.replay-engine.error h2{margin:10px 0;color:#f44}.retry-button{margin-top:20px;background:#4169e1;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:1.1em;font-weight:700;cursor:pointer;transition:background .2s ease}.replay-header{background:linear-gradient(to right,#8b0000,#dc143c);padding:4px 16px;text-align:center;border-bottom:2px solid #FFD700;box-shadow:0 2px 4px #0000004d}.replay-header h1{margin:0;font-size:1.15em;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.battle-date{margin:0;font-size:.78em;color:gold;font-weight:700}.replay-content{display:grid;grid-template-columns:1fr 300px;gap:8px;padding:6px 10px;flex:1;overflow:hidden;min-height:0}.replay-map-container{position:relative;display:flex;flex-direction:column;background:#3a3a3a;border-radius:8px;padding:5px;box-shadow:0 4px 6px #0000004d;overflow:hidden;width:100%;height:100%}.replay-map-viewport{flex:1;min-height:280px;overflow:auto;display:flex}.replay-narrative-container{display:flex;flex-direction:column;overflow:hidden;min-width:300px}.replay-controls-container{padding:5px 15px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}@media (max-width: 1200px){.replay-content{grid-template-columns:1fr;grid-template-rows:auto 1fr}.replay-map-container{height:50vh}.replay-header h1{font-size:2em}}@media (max-width: 768px){.historical-replay-engine{height:auto;min-height:100vh}.replay-header{padding:15px 20px}.replay-header h1{font-size:1.5em}.battle-date{font-size:1em}.replay-content{padding:10px;gap:10px}.replay-map-container{padding:10px}.replay-controls-container{padding:0 10px 10px}}@media print{.historical-replay-engine{background:#fff;color:#000}.replay-header{background:#fff;color:#000;border-bottom:2px solid #000000;box-shadow:none}.replay-header h1{color:#000;text-shadow:none}.battle-date{color:#000}.replay-controls-container{display:none}.replay-content{grid-template-columns:1fr;gap:20px}.replay-map-container,.replay-narrative-container{page-break-inside:avoid}}.battle-replay-list{min-height:100vh;background:linear-gradient(135deg,#1a1a1a,#2f2f2f);color:#fff;padding:20px}.battle-replay-list.loading,.battle-replay-list.error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh}.loading-spinner{font-size:4em;margin-bottom:20px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-icon{font-size:4em;margin-bottom:20px}.replay-list-header{display:flex;align-items:center;gap:20px;margin-bottom:40px}.back-button{background:#4169e1;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:1.1em;font-weight:700;cursor:pointer}.back-button:hover{background:#5a7feb}.header-content h1{margin:0 0 10px;font-size:2.5em}.subtitle{margin:0;color:#ccc;font-size:1.1em}.battle-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:30px;margin-bottom:40px}.battle-card{background:#3a3a3a;border:2px solid #4169E1;border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000004d;transition:transform .2s ease}.battle-card:hover{transform:translateY(-4px);box-shadow:0 6px 12px #00000080}.battle-card-header{background:linear-gradient(to right,#8b0000,#dc143c);padding:15px 20px}.battle-card-header h2{margin:0 0 8px;font-size:1.5em;color:#fff}.battle-date{color:gold;font-weight:700}.battle-card-content{padding:20px}.battle-description{margin:0 0 15px;line-height:1.6;color:#ccc}.battle-stats{display:flex;justify-content:space-between;background:#2f2f2f;padding:12px;border-radius:4px}.stat{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-icon{font-size:1.5em}.stat-label{font-size:.9em;color:#999}.stat-value{font-size:1.2em;font-weight:700;color:gold}.battle-card-footer{padding:20px;background:#2f2f2f}.watch-replay-button{width:100%;background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:1.1em;font-weight:700;cursor:pointer;transition:background .2s ease}.watch-replay-button:hover{background:#34c759}.educational-info{background:linen;color:#2f2f2f;padding:30px;border-radius:8px;border:2px solid #8B4513}.educational-info h3{margin:0 0 20px;color:#8b0000;font-size:2em}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.info-item strong{display:block;margin-bottom:8px;color:#8b0000;font-size:1.1em}.info-item p{margin:0;line-height:1.6;color:#4a4a4a}@media (max-width: 768px){.battle-cards-grid{grid-template-columns:1fr}.replay-list-header{flex-direction:column;align-items:flex-start}}.retry-button{background:#4169e1;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:1.1em;font-weight:700;cursor:pointer}.retry-button:hover{background:#5a7feb}
