:root{--bg-primary:#0d0a14;--bg-secondary:#1a0e2e;--bg-tertiary:#241545;--bg-card:#1a0e2ed9;--bg-glass:#24154599;--bg-glass-hover:#241545cc;--text-primary:#f0e6d3;--text-secondary:#b8a88a;--text-muted:#7a6b55;--text-accent:gold;--gold:gold;--gold-dark:#c5a200;--gold-glow:#ffd7004d;--ruby:#e63946;--ruby-glow:#e639464d;--emerald:#2ec4b6;--emerald-glow:#2ec4b64d;--sapphire:#4895ef;--sapphire-glow:#4895ef4d;--amethyst:#9b5de5;--amethyst-glow:#9b5de54d;--arcane:#c77dff;--arcane-glow:#c77dff4d;--color-gold:gold;--color-wood:#8b6914;--color-stone:#7d8491;--color-food:#5fa55a;--color-iron:#a0aab4;--color-arcane:#c77dff;--color-gems:#00d4ff;--color-decree:#fa0;--gradient-royal:linear-gradient(135deg, #1a0e2e 0%, #2d1b69 50%, #1a0e2e 100%);--gradient-gold:linear-gradient(135deg, gold, #fa0, gold);--gradient-mythic:linear-gradient(135deg, #c77dff, #9b5de5, #7b2ff7);--gradient-danger:linear-gradient(135deg, #e63946, #d62828);--gradient-success:linear-gradient(135deg, #2ec4b6, #1ea896);--gradient-card:linear-gradient(160deg, #241545e6 0%, #1a0e2eb3 100%);--gradient-panel:linear-gradient(180deg, #1a0e2ef2 0%, #0d0a14fa 100%);--border-subtle:1px solid #ffd7001a;--border-gold:1px solid #ffd7004d;--border-glow:1px solid #ffd70080;--border-radius-sm:6px;--border-radius-md:10px;--border-radius-lg:16px;--border-radius-xl:24px;--shadow-sm:0 2px 8px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-gold:0 0 20px #ffd70026;--shadow-glow:0 0 30px #9b5de533;--font-display:"Cinzel Decorative", "Cinzel", serif;--font-heading:"Cinzel", serif;--font-body:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-xs:.65rem;--font-size-sm:.75rem;--font-size-base:.875rem;--font-size-md:1rem;--font-size-lg:1.25rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-size-3xl:2.5rem;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:24px;--space-2xl:32px;--space-3xl:48px;--hud-height:88px;--bottom-nav-height:64px;--safe-area-top:env(safe-area-inset-top,0px);--safe-area-bottom:env(safe-area-inset-bottom,0px);--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-spring:.4s cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-size:16px;overflow:hidden}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100vw;height:100dvh;line-height:1.5;position:fixed;top:0;left:0;overflow:hidden}#app{background:var(--gradient-royal);width:100%;height:100%;position:relative;overflow:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffd70033;border-radius:2px}.loading-screen{background:var(--bg-primary);z-index:9999;background-image:radial-gradient(at 50% 30%,#9b5de526 0%,#0000 60%),radial-gradient(at 20% 80%,#ffd70014 0%,#0000 50%);justify-content:center;align-items:center;transition:opacity .6s,visibility .6s;display:flex;position:fixed;inset:0}.loading-screen.fade-out{opacity:0;visibility:hidden}.loading-content{text-align:center;animation:2s ease-in-out infinite loadingPulse}.loading-crown{margin-bottom:var(--space-lg);filter:drop-shadow(0 0 20px #ffd70080);font-size:4rem;animation:3s ease-in-out infinite crownFloat}.loading-title{font-family:var(--font-display);font-size:var(--font-size-3xl);background:var(--gradient-gold);-webkit-text-fill-color:transparent;letter-spacing:6px;margin-bottom:var(--space-sm);text-shadow:none;-webkit-background-clip:text;background-clip:text;font-weight:900}.loading-subtitle{font-family:var(--font-heading);font-size:var(--font-size-base);color:var(--text-secondary);letter-spacing:4px;text-transform:uppercase;margin-bottom:var(--space-2xl)}.loading-bar-container{width:200px;height:4px;margin:0 auto var(--space-lg);background:#ffd7001a;border-radius:2px;overflow:hidden}.loading-bar{background:var(--gradient-gold);border-radius:2px;width:0%;height:100%;transition:width .3s;box-shadow:0 0 10px #ffd70080}.loading-text{font-size:var(--font-size-xs);color:var(--text-muted);letter-spacing:1px}.hidden{display:none!important}.fade-in{animation:.4s forwards fadeIn}.slide-up{animation:slideUp .4s var(--transition-spring) forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes crownFloat{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-8px)rotate(-2deg)}75%{transform:translateY(-4px)rotate(2deg)}}@keyframes loadingPulse{0%,to{opacity:1}50%{opacity:.85}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes pulseGlow{0%,to{box-shadow:0 0 5px #ffd70033}50%{box-shadow:0 0 20px #ffd70066}}@keyframes tickUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-12px)}}@keyframes popIn{0%{opacity:0;transform:scale(.8)}60%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)rotate(0)}50%{opacity:1;transform:scale(1)rotate(180deg)}}@keyframes borderGlow{0%,to{border-color:#ffd70033}50%{border-color:#ffd70080}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-radius:var(--border-radius-md);font-family:var(--font-heading);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;touch-action:manipulation;border:none;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(135deg,#ffffff1a 0%,#0000 50%);position:absolute;inset:0}.btn:active:after{opacity:1}.btn-gold{background:var(--gradient-gold);color:#1a0e2e;box-shadow:0 2px 12px #ffd7004d}.btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 20px #ffd70080}.btn-gold:active{transform:translateY(0)}.btn-primary{background:var(--gradient-mythic);color:var(--text-primary);box-shadow:0 2px 12px #9b5de54d}.btn-danger{background:var(--gradient-danger);color:var(--text-primary)}.btn-ghost{background:var(--bg-glass);color:var(--text-primary);border:var(--border-subtle);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-md)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.card{background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-gold);border-color:#ffd70040}.progress-bar{background:#ffffff14;border-radius:3px;width:100%;height:6px;position:relative;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .5s;position:relative}.progress-fill:after{content:"";background:linear-gradient(90deg,#0000 0%,#fff3 50%,#0000 100%) 0 0/200% 100%;animation:2s linear infinite shimmer;position:absolute;inset:0}.progress-gold .progress-fill{background:var(--gradient-gold)}.progress-ruby .progress-fill{background:var(--gradient-danger)}.progress-emerald .progress-fill{background:var(--gradient-success)}.progress-amethyst .progress-fill{background:var(--gradient-mythic)}.divider{width:100%;height:1px;margin:var(--space-lg) 0;background:linear-gradient(90deg,#0000,#ffd70033,#0000)}.badge{font-size:var(--font-size-xs);letter-spacing:.5px;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.badge-gold{color:var(--gold);background:#ffd70026}.badge-ruby{color:var(--ruby);background:#e6394626}.badge-emerald{color:var(--emerald);background:#2ec4b626}.badge-amethyst{color:var(--amethyst);background:#9b5de526}[data-tooltip]{position:relative}[data-tooltip]:before{content:attr(data-tooltip);border:var(--border-subtle);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);color:var(--text-secondary);white-space:nowrap;opacity:0;visibility:hidden;transition:all var(--transition-fast);pointer-events:none;z-index:1000;background:#0d0a14f2;padding:4px 10px;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:before{opacity:1;visibility:visible}.hud{z-index:100;padding-top:var(--safe-area-top);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(#0d0a14f2 0%,#0d0a14b3 80%,#0000 100%);position:fixed;top:0;left:0;right:0}.hud-top{padding:4px var(--space-sm) 2px;justify-content:space-between;align-items:center;gap:4px;display:flex}.hud-resources{flex:1;grid-template-columns:repeat(6,auto);gap:2px;display:grid}.hud-resource{border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff0d;align-items:center;gap:2px;padding:2px 6px;display:flex;position:relative}.hud-resource:hover{background:#ffffff14;border-color:#ffd70026}.hud-resource-icon{flex-shrink:0;align-items:center;font-size:.75rem;display:flex}.hud-resource-icon img{object-fit:contain;width:14px;height:14px}.hud-resource-value{color:var(--text-primary);white-space:nowrap;transition:color var(--transition-fast);font-size:.65rem;font-weight:600;line-height:1}.hud-resource-value.increasing{color:var(--emerald)}.hud-resource-value.decreasing{color:var(--ruby)}.hud-gems{border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-base);background:linear-gradient(135deg,#00d4ff1a,#00d4ff0d);border:1px solid #00d4ff33;flex-shrink:0;align-items:center;gap:3px;padding:3px 10px;display:flex}.hud-gems:hover{border-color:#00d4ff66;box-shadow:0 0 15px #00d4ff26}.hud-gems-icon{align-items:center;font-size:.8rem;display:flex}.hud-gems-icon img{object-fit:contain;width:16px;height:16px}.hud-gems-value{font-family:var(--font-heading);color:var(--color-gems);font-size:.7rem;font-weight:700}.hud-gems-plus{width:16px;height:16px;color:var(--color-gems);background:#00d4ff33;border-radius:50%;justify-content:center;align-items:center;font-size:.6rem;font-weight:700;display:flex}.hud-bottom-bar{padding:0 var(--space-sm) 4px;justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.hud-score{cursor:help;flex:1;align-items:center;gap:6px;display:flex}.hud-score-crown{filter:drop-shadow(0 0 4px #ffd70066);align-items:center;font-size:.9rem;display:flex}.hud-score-crown img{object-fit:contain;width:18px;height:18px}.hud-score-bar{flex:1}.hud-score-label{justify-content:space-between;align-items:baseline;margin-bottom:1px;display:flex}.hud-score-title{font-family:var(--font-heading);color:var(--text-secondary);letter-spacing:1px;font-size:.6rem}.hud-score-value{font-family:var(--font-heading);color:var(--gold);font-size:.6rem;font-weight:700}.hud-decree{cursor:help;flex-shrink:0;align-items:center;gap:6px;display:flex}.hud-decree-icon{align-items:center;font-size:.85rem;display:flex}.hud-decree-icon img{object-fit:contain;width:16px;height:16px}.hud-decree-bar-container{width:75px}.hud-decree-label{justify-content:space-between;margin-bottom:1px;display:flex}.hud-decree-text{color:var(--text-secondary);font-size:.55rem}.hud-decree-value{color:var(--color-decree);font-size:.55rem;font-weight:700}.hud-decree-refill{width:20px;height:20px;color:var(--color-decree);cursor:pointer;transition:all var(--transition-fast);background:#ffaa0026;border:1px solid #ffaa004d;border-radius:50%;justify-content:center;align-items:center;font-size:.6rem;display:flex}.hud-decree-refill:hover{background:#ffaa0040;border-color:#ffaa0080}@media (width>=480px){.hud-resource-icon img{width:16px;height:16px}.hud-resource-value{font-size:var(--font-size-xs)}.hud-resource{gap:3px;padding:3px 8px}.hud-gems-value{font-size:var(--font-size-sm)}.hud-score-title,.hud-score-value,.hud-decree-text,.hud-decree-value{font-size:var(--font-size-xs)}.hud-decree-bar-container{width:80px}}@media (width>=1024px){.hud-top{padding:var(--space-sm) var(--space-lg)}.hud-bottom-bar{padding:0 var(--space-lg) var(--space-sm)}.hud-resource{gap:4px;padding:4px 10px}.hud-resource-icon img{width:18px;height:18px}.hud-resource-value{font-size:var(--font-size-sm)}.hud-gems-icon img{width:20px;height:20px}.hud-gems-value{font-size:var(--font-size-base)}}@media (width<=380px){.hud-resources{grid-template-columns:repeat(3,1fr)}}.kingdom-view{top:var(--hud-height);left:0;right:0;bottom:var(--bottom-nav-height);padding:var(--space-md);padding-bottom:var(--space-xl);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;position:fixed;overflow:hidden auto}.kingdom-header{text-align:center;margin-bottom:var(--space-xl);animation:.6s fadeIn}.kingdom-name{font-family:var(--font-display);font-size:var(--font-size-xl);color:var(--gold);letter-spacing:3px;text-shadow:0 0 20px #ffd7004d;margin-bottom:4px;font-weight:900}.kingdom-rank{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}.kingdom-stats-grid{gap:var(--space-sm);margin-bottom:var(--space-xl);grid-template-columns:repeat(3,1fr);display:grid}.kingdom-stat{background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);padding:var(--space-md);text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.kingdom-stat-value{font-family:var(--font-heading);font-size:var(--font-size-lg);color:var(--text-primary);font-weight:700}.kingdom-stat-label{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.score-breakdown{background:var(--gradient-card);border:var(--border-gold);border-radius:var(--border-radius-lg);padding:var(--space-lg);margin-bottom:var(--space-xl);animation:.4s popIn}.score-breakdown-title{font-family:var(--font-heading);font-size:var(--font-size-base);color:var(--gold);text-align:center;margin-bottom:var(--space-md);letter-spacing:2px}.score-category{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.score-cat-icon{text-align:center;width:20px;font-size:.9rem}.score-cat-name{font-size:var(--font-size-xs);color:var(--text-secondary);flex:1}.score-cat-bar{width:80px}.score-cat-value{font-size:var(--font-size-xs);color:var(--text-primary);text-align:right;width:35px;font-weight:700}.buildings-section-title{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-secondary);letter-spacing:2px;text-transform:uppercase;margin-bottom:var(--space-md);padding-left:var(--space-xs)}.buildings-grid{gap:var(--space-sm);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.building-card{background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);padding:var(--space-md);cursor:pointer;transition:all var(--transition-base);text-align:center;flex-direction:column;align-items:center;min-height:140px;display:flex;position:relative;overflow:hidden}.building-card:hover{box-shadow:var(--shadow-gold);border-color:#ffd7004d;transform:translateY(-2px)}.building-card.upgrading{animation:2s ease-in-out infinite borderGlow}.building-card-img{width:56px;height:56px;margin-bottom:var(--space-sm);background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:1.8rem;display:flex;overflow:hidden}.building-card-img img{object-fit:cover;border-radius:50%;width:100%;height:100%;-webkit-mask-image:radial-gradient(circle,#000 55%,#0000 72%);mask-image:radial-gradient(circle,#000 55%,#0000 72%)}.building-card-name{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--text-primary);margin-bottom:4px;font-weight:600}.building-card-level{font-size:var(--font-size-xs);color:var(--text-muted)}.building-card-timer{font-size:var(--font-size-xs);color:var(--color-decree);padding-top:var(--space-sm);margin-top:auto}.building-card-beauty{border-radius:8px;padding:1px 5px;font-size:.6rem;font-weight:700;position:absolute;top:4px;right:4px}.beauty-painted{color:var(--sapphire);background:#4895ef33}.beauty-ornate{color:var(--gold);background:#ffd70033}.beauty-royal{color:var(--ruby);background:#e6394633}.beauty-legendary{color:var(--amethyst);background:#9b5de533}.beauty-mythic{color:#fff;background:linear-gradient(135deg,#c77dff4d,#ffd7004d) 0 0/200% 100%;animation:3s linear infinite shimmer}.building-slot-empty{opacity:.6;min-height:140px;transition:all var(--transition-base);border-style:dashed;border-color:#ffd70026;flex-direction:column;justify-content:center;align-items:center;display:flex}.building-slot-empty:hover{opacity:1;border-color:#ffd7004d}.building-slot-plus{color:var(--text-muted);margin-bottom:4px;font-size:1.5rem}.building-slot-text{font-size:var(--font-size-xs);color:var(--text-muted)}.combat-panel{padding:var(--space-lg)}.combat-title{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--ruby);text-align:center;margin-bottom:var(--space-xl);letter-spacing:2px}.troop-grid{gap:var(--space-sm);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(120px,1fr));display:grid}.troop-card{background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);padding:var(--space-md);text-align:center;cursor:pointer;transition:all var(--transition-base)}.troop-card:hover{border-color:#e639464d;box-shadow:0 0 15px #e6394626}.troop-card.selected{border-color:var(--ruby);box-shadow:0 0 20px var(--ruby-glow)}.troop-icon{margin-bottom:var(--space-sm);font-size:2rem}.troop-name{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--text-primary);margin-bottom:4px}.troop-count{font-size:var(--font-size-sm);color:var(--gold);font-weight:700}.troop-stats{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:4px}.troop-train-btn{margin-top:var(--space-sm);width:100%}.enemy-section-title{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-secondary);letter-spacing:2px;margin-bottom:var(--space-md)}.enemy-list{gap:var(--space-sm);flex-direction:column;display:flex}.enemy-card{background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);padding:var(--space-md);align-items:center;gap:var(--space-md);cursor:pointer;transition:all var(--transition-base);display:flex}.enemy-card:hover{border-color:#e639464d;transform:translate(4px)}.enemy-icon{font-size:1.8rem}.enemy-info{flex:1}.enemy-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary)}.enemy-power{font-size:var(--font-size-xs);color:var(--text-muted)}.enemy-loot{font-size:var(--font-size-xs);color:var(--gold)}.enemy-actions{gap:var(--space-xs);display:flex}.battle-log{border-radius:var(--border-radius-md);padding:var(--space-md);max-height:200px;font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:var(--space-lg);background:#0000004d;overflow-y:auto}.battle-log-entry{border-bottom:1px solid #ffffff08;padding:4px 0}.battle-log-entry.victory{color:var(--emerald)}.battle-log-entry.defeat{color:var(--ruby)}.battle-report-overlay{z-index:9999;opacity:0;pointer-events:none;background:#000000d9;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.battle-report-overlay.visible{opacity:1;pointer-events:all}.battle-report{background:var(--gradient-card);border:var(--border-gold);border-radius:var(--border-radius-xl,16px);padding:var(--space-xl) var(--space-lg);text-align:center;width:90%;max-width:380px;transition:transform .4s;transform:scale(.8);box-shadow:0 20px 60px #0009,0 0 40px #ffd7001a}.battle-report-overlay.visible .battle-report{transform:scale(1)}.battle-report.victory{border-color:#2db75d80;box-shadow:0 20px 60px #0009,0 0 40px #2db75d33}.battle-report.defeat{border-color:#e6394680;box-shadow:0 20px 60px #0009,0 0 40px #e6394633}.br-icon{margin-bottom:var(--space-md);font-size:4rem;animation:1s ease-in-out infinite brPulse}@keyframes brPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.br-title{font-family:var(--font-display,var(--font-heading));color:var(--gold);letter-spacing:3px;margin-bottom:var(--space-xs);font-size:1.8rem}.br-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-lg)}.br-stats{gap:var(--space-md);margin-bottom:var(--space-md);justify-content:center;display:flex}.br-stat{border-radius:var(--border-radius-md);padding:var(--space-sm) var(--space-md);text-align:center;background:#0000004d}.br-stat-label{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:2px;display:block}.br-stat-value{font-size:var(--font-size-lg);color:var(--text-primary);font-weight:700}.br-loot{border-radius:var(--border-radius-md);padding:var(--space-md);margin-bottom:var(--space-md);background:#ffd70014}.br-loot-title{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--gold);letter-spacing:1px;margin-bottom:var(--space-xs)}.br-loot-item{border-radius:var(--border-radius-sm,4px);font-size:var(--font-size-sm);color:var(--emerald);background:#ffd7001f;margin:2px;padding:2px 8px;display:inline-block}.floating-gain{color:var(--emerald);pointer-events:none;font-size:.6rem;font-weight:700;animation:1.2s ease-out forwards floatUp;position:absolute;top:-8px;right:-4px}@keyframes floatUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.bd-production{gap:var(--space-xs);border-radius:var(--border-radius-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);background:#0003;flex-wrap:wrap;align-items:center;display:flex}.bd-prod-label{font-size:var(--font-size-xs);color:var(--text-muted);margin-right:var(--space-xs)}.bd-prod-item{font-size:var(--font-size-sm);color:var(--emerald);background:#2db75d1a;border-radius:4px;padding:2px 8px;font-weight:600}.scene-kingdom-name:hover{text-underline-offset:3px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.equip-slot{transition:all var(--transition-fast)}.equip-slot:hover{transform:scale(1.15);box-shadow:0 0 8px #ffd7004d}.equip-popup{z-index:9999;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.equip-popup-inner{background:var(--bg-secondary);border:var(--border-subtle);border-radius:var(--border-radius-lg);padding:var(--space-lg);min-width:220px;max-width:320px;box-shadow:0 20px 60px #00000080}.equip-option{padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius-sm);cursor:pointer;transition:background var(--transition-fast);align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);display:flex}.equip-option:hover{background:#ffffff14}.panel-overlay{z-index:200;flex-direction:column;justify-content:flex-end;display:flex;position:fixed;inset:0}.panel-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;position:absolute;inset:0}.panel-container{z-index:1;-webkit-overflow-scrolling:touch;background:var(--gradient-panel);border-top:var(--border-gold);border-radius:var(--border-radius-xl) var(--border-radius-xl) 0 0;max-height:80vh;animation:.35s cubic-bezier(.34,1.56,.64,1) slideUp;position:relative;overflow-y:auto}.panel-handle{width:40px;height:4px;margin:var(--space-md) auto var(--space-sm);background:#fff3;border-radius:2px}.panel-header{padding:0 var(--space-lg) var(--space-md);justify-content:space-between;align-items:center;display:flex}.panel-title{font-family:var(--font-display);font-size:var(--font-size-lg);color:var(--gold);letter-spacing:2px}.panel-close{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.panel-close:hover{color:var(--text-primary);background:#ffffff1a}.panel-body{padding:0 var(--space-lg) var(--space-xl)}.build-tabs{gap:var(--space-xs);padding-bottom:var(--space-md);scrollbar-width:none;display:flex;overflow-x:auto}.build-tabs::-webkit-scrollbar{display:none}.build-tab{padding:var(--space-xs) var(--space-md);border-radius:var(--border-radius-md);font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--text-muted);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff0f}.build-tab.active{color:var(--gold);background:#ffd7001a;border-color:#ffd7004d}.build-tab:hover{color:var(--text-secondary);border-color:#ffd70033}.build-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);margin-bottom:var(--space-sm);transition:all var(--transition-base);display:flex}.build-item:hover{border-color:#ffd70033}.build-item-icon{flex-shrink:0;font-size:2rem}.build-item-info{flex:1;min-width:0}.build-item-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary)}.build-item-desc{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:2px}.build-item-cost{gap:var(--space-xs);flex-wrap:wrap;margin-top:4px;display:flex}.cost-tag{font-size:var(--font-size-xs);background:#ffffff0a;border-radius:4px;align-items:center;gap:2px;padding:1px 6px;display:inline-flex}.cost-tag.affordable{color:var(--emerald)}.cost-tag.expensive{color:var(--ruby)}.build-item-actions{gap:var(--space-xs);flex-direction:column;flex-shrink:0;display:flex}.shop-grid{gap:var(--space-sm);grid-template-columns:repeat(2,1fr);display:grid}.shop-item{background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-base)}.shop-item:hover{border-color:#00d4ff4d;box-shadow:0 0 20px #00d4ff1a}.shop-item-icon{margin-bottom:var(--space-sm);font-size:2rem}.shop-item-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary);margin-bottom:4px}.shop-item-desc{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--space-sm)}.shop-item-price{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--color-gems);font-weight:700}.research-tree{gap:var(--space-md);flex-direction:column;display:flex}.research-branch-title{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-secondary);letter-spacing:2px;margin-bottom:var(--space-sm)}.research-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);transition:all var(--transition-base);cursor:pointer;display:flex}.research-item:hover{border-color:#4895ef4d}.research-item.completed{border-color:#2ec4b64d}.research-item.locked{opacity:.4;cursor:not-allowed}.research-item-icon{font-size:1.5rem}.research-item-info{flex:1}.research-item-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary)}.research-item-desc{font-size:var(--font-size-xs);color:var(--text-muted)}.research-item-status{font-size:var(--font-size-xs);font-weight:600}.research-item-status.done{color:var(--emerald)}.research-item-status.in-progress{color:var(--color-decree)}.bottom-nav{height:var(--bottom-nav-height);padding-bottom:var(--safe-area-bottom);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:100;background:#0d0a14f2;border-top:1px solid #ffd70014;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-btn{padding:var(--space-sm);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;display:flex;position:relative}.nav-icon{transition:transform var(--transition-spring);justify-content:center;align-items:center;font-size:1.3rem;display:flex}.nav-icon img{object-fit:contain;filter:brightness(.8);width:26px;height:26px;transition:filter var(--transition-fast);border-radius:50%}.nav-label{font-size:var(--font-size-xs);color:var(--text-muted);transition:color var(--transition-fast);font-weight:500}.nav-btn.active .nav-icon{transform:scale(1.15)}.nav-btn.active .nav-icon img{filter:brightness(1.1)drop-shadow(0 0 4px #ffd70080)}.nav-btn.active .nav-label{color:var(--gold)}.nav-btn.active:after{content:"";background:var(--gold);border-radius:1px;width:20px;height:2px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.notifications{top:calc(var(--hud-height) + var(--space-sm));right:var(--space-md);z-index:300;gap:var(--space-sm);pointer-events:none;flex-direction:column;max-width:280px;display:flex;position:fixed}.notification{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:var(--border-subtle);border-radius:var(--border-radius-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto;box-shadow:var(--shadow-md);background:#1a0e2ef2;animation:.3s slideInRight,.3s 3s forwards fadeOut;display:flex}.notification.success{border-color:#2ec4b64d}.notification.warning{border-color:#ffaa004d}.notification.error{border-color:#e639464d}.notification.reward{box-shadow:var(--shadow-gold);border-color:#ffd70066}.notification-icon{flex-shrink:0;font-size:1.2rem}.notification-text{font-size:var(--font-size-xs);color:var(--text-primary)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{to{opacity:0;transform:translateY(-10px)}}@media (width>=768px){.buildings-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.kingdom-stats-grid{grid-template-columns:repeat(4,1fr)}.shop-grid{grid-template-columns:repeat(3,1fr)}.troop-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}@media (width>=1024px){.panel-container{border-radius:var(--border-radius-xl);max-width:600px;margin:0 auto}.bottom-nav{border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;max-width:500px;left:50%;transform:translate(-50%)}}.beauty-modal{padding:var(--space-lg)}.beauty-tier-list{gap:var(--space-sm);flex-direction:column;display:flex}.beauty-tier{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-base);display:flex}.beauty-tier:hover{border-color:#ffd7004d}.beauty-tier.current{border-color:var(--gold);box-shadow:var(--shadow-gold)}.beauty-tier-swatch{border-radius:var(--border-radius-sm);justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;display:flex}.beauty-tier-info{flex:1}.beauty-tier-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary)}.beauty-tier-cost{font-size:var(--font-size-xs);color:var(--text-muted)}.quest-list{gap:var(--space-sm);flex-direction:column;display:flex}.quest-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--gradient-card);border:var(--border-subtle);border-radius:var(--border-radius-md);display:flex}.quest-item.completed{opacity:.5}.quest-icon{font-size:1.5rem}.quest-info{flex:1}.quest-name{font-size:var(--font-size-sm);color:var(--text-primary);font-weight:600}.quest-desc{font-size:var(--font-size-xs);color:var(--text-muted)}.quest-progress{margin-top:4px}.quest-reward{font-size:var(--font-size-xs);color:var(--gold);font-weight:600}.kingdom-scene{aspect-ratio:16/10;border-radius:var(--border-radius-lg);width:100%;min-height:280px;max-height:400px;margin-bottom:var(--space-xl);border:var(--border-gold);box-shadow:var(--shadow-lg), inset 0 0 60px #0006;position:relative;overflow:hidden}.scene-bg{filter:brightness(.7)saturate(1.2);background:url(/images/backgrounds/kingdom_bg.png) 50%/cover no-repeat;position:absolute;inset:0}.scene-overlay{background:radial-gradient(at 50% 80%,#0000 30%,#0d0a1466 100%);position:absolute;inset:0}.scene-buildings{grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(6,1fr);gap:4px;padding:8px;display:grid;position:absolute;inset:0}.scene-building{cursor:pointer;z-index:2;flex-direction:column;justify-content:center;align-items:center;transition:transform .2s;display:flex;position:relative}.scene-building:hover{z-index:10;transform:scale(1.12)}.scene-building-img{aspect-ratio:1;object-fit:cover;filter:drop-shadow(0 3px 8px #00000080);border-radius:50%;width:90%;max-width:80px;transition:filter .3s;-webkit-mask-image:radial-gradient(circle,#000 50%,#0000 72%);mask-image:radial-gradient(circle,#000 50%,#0000 72%)}.scene-building:hover .scene-building-img{filter:drop-shadow(0 4px 12px #ffd70066)}.scene-building-label{font-family:var(--font-heading);color:var(--text-primary);white-space:nowrap;letter-spacing:.5px;background:#0009;border-radius:4px;margin-top:2px;padding:1px 5px;font-size:.5rem}.scene-building-level{color:var(--gold);background:#000000b3;border-radius:3px;padding:0 4px;font-size:.45rem;position:absolute;top:2px;right:2px}.scene-upgrade-timer{color:#ffd54f;white-space:nowrap;z-index:5;background:#000c;border:1px solid #ffd54f4d;border-radius:8px;padding:1px 6px;font-size:.5rem;font-weight:700;animation:2s ease-in-out infinite timerPulse;position:absolute;bottom:-2px;left:50%;transform:translate(-50%)}@keyframes timerPulse{0%,to{box-shadow:0 0 4px #ffd54f33}50%{box-shadow:0 0 10px #ffd54f66}}.scene-upgrade-particles{pointer-events:none;z-index:4;border-radius:50%;position:absolute;inset:0;overflow:hidden}.scene-upgrade-particles:before,.scene-upgrade-particles:after{content:"";background:#ffd54f;border-radius:50%;width:4px;height:4px;position:absolute}.scene-upgrade-particles:before{animation:1.5s ease-in-out infinite constructSpark;top:20%;left:30%}.scene-upgrade-particles:after{animation:1.5s ease-in-out .7s infinite constructSpark;top:40%;left:60%}@keyframes constructSpark{0%{opacity:0;transform:translateY(0)scale(0)}50%{opacity:1;transform:translateY(-8px)scale(1.2)}to{opacity:0;transform:translateY(-16px)scale(0)}}@keyframes constructPulse{0%,to{filter:drop-shadow(0 3px 8px #00000080)}50%{filter:drop-shadow(0 3px 12px #ffd54f66)brightness(1.05)}}.scene-walls{pointer-events:none;z-index:1;border-radius:var(--border-radius-lg);border:3px solid #0000;transition:border-color .5s,box-shadow .5s;position:absolute;inset:0}.scene-walls.level-1{border-color:#8b776566}.scene-walls.level-5{border-color:#8b776599;box-shadow:inset 0 0 10px #8b776533}.scene-walls.level-10{border-width:4px;border-color:#a99583b3;box-shadow:inset 0 0 15px #a995834d}.scene-walls.level-15{border-width:5px;border-color:#c8b4a0cc;box-shadow:inset 0 0 20px #c8b4a04d}.scene-walls.level-20{border-width:6px;border-color:#ffd70080;box-shadow:inset 0 0 30px #ffd70026,0 0 20px #ffd7001a}.scene-soldiers{pointer-events:none;z-index:3;height:40px;position:absolute;bottom:8px;left:0;right:0;overflow:hidden}.soldier-sprite{filter:drop-shadow(0 1px 2px #000c);width:14px;height:20px;font-size:14px;line-height:20px;animation:linear infinite soldierPatrol;position:absolute;bottom:0}@keyframes soldierPatrol{0%{transform:translate(-20px)}to{transform:translate(calc(100vw + 20px))}}.beauty-glow-painted .scene-building-img{filter:drop-shadow(0 2px 6px #4895ef4d)}.beauty-glow-ornate .scene-building-img{filter:drop-shadow(0 2px 8px #ffd7004d)}.beauty-glow-royal .scene-building-img{filter:drop-shadow(0 3px 10px #e6394666)}.beauty-glow-legendary .scene-building-img{filter:drop-shadow(0 4px 14px #9b5de580)brightness(1.1)}.beauty-glow-mythic .scene-building-img{filter:drop-shadow(0 4px 18px #c77dff99)brightness(1.2);animation:2s ease-in-out infinite mythicPulse}@keyframes mythicPulse{0%,to{filter:drop-shadow(0 4px 18px #c77dff80)brightness(1.15)}50%{filter:drop-shadow(0 6px 24px #ffd70080)brightness(1.3)}}.scene-smoke{pointer-events:none;z-index:4;position:absolute}.smoke-particle{background:#c8c8c84d;border-radius:50%;width:6px;height:6px;animation:3s ease-out infinite smokeRise;position:absolute}@keyframes smokeRise{0%{opacity:.4;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-30px)scale(2.5)}}.scene-people{pointer-events:none;z-index:3;position:absolute;inset:0;overflow:hidden}.person-sprite{font-size:8px;animation:linear infinite personWalk;position:absolute}@keyframes personWalk{0%{transform:translate(0)}25%{transform:translate(20px,-10px)}50%{transform:translate(40px)}75%{transform:translate(20px,10px)}to{transform:translate(0)}}.scene-building.upgrading .scene-building-img{animation:1s ease-in-out infinite buildingUpgrade}@keyframes buildingUpgrade{0%,to{opacity:1}50%{opacity:.5}}.scene-info-bar{z-index:5;background:linear-gradient(#0000,#000000b3);justify-content:space-between;align-items:flex-end;padding:20px 12px 8px;display:flex;position:absolute;bottom:0;left:0;right:0}.scene-kingdom-name{font-family:var(--font-display);font-size:var(--font-size-sm);color:var(--gold);letter-spacing:2px;text-shadow:0 0 10px #ffd7004d}.scene-pop-info{font-size:var(--font-size-xs);color:var(--text-secondary);align-items:center;gap:4px;display:flex}.scene-torches{pointer-events:none;z-index:3;position:absolute;inset:0}.torch-glow{background:radial-gradient(circle,#ffaa3273 0%,#ff781e26 40%,#0000 70%);width:50px;height:50px;animation:1.8s ease-in-out infinite torchFlicker;position:absolute}.torch-glow:after{content:"🔥";opacity:.8;font-size:.7rem;animation:1.2s ease-in-out infinite reverse torchFlicker;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes torchFlicker{0%,to{opacity:.6;transform:scale(1)}30%{opacity:1;transform:scale(1.2)}60%{opacity:.8;transform:scale(1.05)}}.scene-building .scene-building-torch{pointer-events:none;opacity:0;background:radial-gradient(#ffa02840 0%,#0000 70%);width:80px;height:40px;transition:opacity 2s;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)}.night-active .scene-building .scene-building-torch{opacity:1}.scene-quick-actions{z-index:5;gap:4px;display:flex;position:absolute;top:8px;right:8px}.scene-qa-btn{cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#00000080;border:1px solid #ffffff1f;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;transition:all .2s;display:flex}.scene-qa-btn:hover{background:#ffd70026;border-color:#ffd7004d;transform:scale(1.08);box-shadow:0 0 10px #ffd70026}.scene-qa-icon{object-fit:contain;filter:drop-shadow(0 1px 2px #00000080);border-radius:50%;width:18px;height:18px}.login-form{align-items:center;gap:var(--space-md);margin-top:var(--space-xl);flex-direction:column;width:100%;max-width:320px;display:flex}.login-input{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:var(--font-size-md);background:#ffffff14;border:1px solid #ffd70033;outline:none;transition:border-color .3s}.login-input:focus{border-color:var(--gold);box-shadow:0 0 10px #ffd70026}.login-input::placeholder{color:var(--text-muted)}.login-buttons{gap:var(--space-sm);width:100%;display:flex}.login-buttons .btn{flex:1}.login-error{color:var(--ruby);font-size:var(--font-size-sm);text-align:center;min-height:1.5em}.leaderboard-list{flex-direction:column;gap:2px;display:flex}.leaderboard-row{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius-sm);background:#ffffff08;transition:background .2s;display:flex}.leaderboard-row:hover{background:#ffffff0f}.leaderboard-row.me{background:#ffd70014;border:1px solid #ffd70033}.lb-rank{font-family:var(--font-heading);font-size:var(--font-size-lg);color:var(--gold);text-align:center;min-width:32px}.lb-rank.top1{color:gold;font-size:1.3rem}.lb-rank.top2{color:silver}.lb-rank.top3{color:#cd7f32}.lb-info{flex:1}.lb-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary)}.lb-title{font-size:var(--font-size-xs);color:var(--text-muted)}.lb-score{font-family:var(--font-heading);color:var(--gold);font-size:var(--font-size-sm)}.login-divider{text-align:center;width:100%;margin:var(--space-sm) 0;position:relative}.login-divider:before,.login-divider:after{content:"";background:#ffffff1a;width:35%;height:1px;position:absolute;top:50%}.login-divider:before{left:0}.login-divider:after{right:0}.login-divider span{font-size:var(--font-size-xs);color:var(--text-muted);padding:0 var(--space-sm);position:relative}.login-oauth{gap:var(--space-sm);width:100%;display:flex}.btn-oauth{justify-content:center;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-family:var(--font-body);cursor:pointer;border:1px solid #ffffff1a;flex:1;transition:background .2s,transform .1s;display:flex}.btn-oauth:hover{transform:translateY(-1px)}.btn-oauth:active{transform:translateY(0)}.btn-google{color:var(--text-primary);background:#ffffff14}.btn-google:hover{background:#ffffff24}.btn-discord{color:#8b9dff;background:#5865f233}.btn-discord:hover{background:#5865f259}.tutorial-overlay{z-index:10000;pointer-events:all;position:fixed;inset:0}.tutorial-spotlight{z-index:1;pointer-events:none;border:2px solid #ffd70059;border-radius:12px;transition:all .5s cubic-bezier(.4,0,.2,1);position:fixed;box-shadow:0 0 0 9999px #0000008c,0 0 20px 4px #ffd70040}.tutorial-card{z-index:2;background:var(--gradient-card);border:var(--border-gold);border-radius:var(--border-radius-lg,12px);padding:var(--space-lg);width:85%;max-width:320px;animation:.4s tutorialPop;position:fixed;box-shadow:0 16px 48px #0009,0 0 30px #ffd70026}@keyframes tutorialPop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.tutorial-step-counter{font-size:var(--font-size-xs);color:var(--text-muted);letter-spacing:2px;margin-bottom:var(--space-xs)}.tutorial-title{font-family:var(--font-heading);font-size:var(--font-size-md);color:var(--gold);margin-bottom:var(--space-sm)}.tutorial-text{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-md);line-height:1.5}.tutorial-actions{gap:var(--space-sm);justify-content:flex-end;display:flex}.guide-panel{flex-direction:column;gap:0;display:flex}.guide-search{border-radius:var(--border-radius-md);width:100%;color:var(--text-primary);font-size:var(--font-size-sm);margin-bottom:var(--space-md);transition:border-color var(--transition-fast);background:#0000004d;border:1px solid #ffffff14;outline:none;padding:10px 14px}.guide-search:focus{border-color:#ffd7004d}.guide-search::placeholder{color:var(--text-muted)}.guide-tabs{padding-bottom:var(--space-sm);margin-bottom:var(--space-md);scrollbar-width:none;-ms-overflow-style:none;gap:4px;display:flex;overflow-x:auto}.guide-tabs::-webkit-scrollbar{display:none}.guide-tab{border-radius:var(--border-radius-md);color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);font-size:.7rem;font-family:var(--font-heading);letter-spacing:.5px;background:#ffffff0a;border:1px solid #ffffff0f;align-items:center;gap:6px;padding:8px 14px;display:flex}.guide-tab:hover{color:var(--text-primary);background:#ffffff14}.guide-tab.active{color:var(--gold);background:#ffd7001a;border-color:#ffd7004d;font-weight:600}.guide-tab-label{pointer-events:none}.guide-tab-panel{display:none}.guide-tab-panel.active{animation:.3s fadeIn;display:block}.guide-panel-title{font-family:var(--font-heading);font-size:var(--font-size-base);color:var(--gold);margin-bottom:var(--space-md);letter-spacing:1px}.guide-qa{margin-bottom:var(--space-sm);border-radius:var(--border-radius-md);background:#ffffff05;border:1px solid #ffffff0d;overflow:hidden}.guide-q{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast);justify-content:space-between;align-items:center;font-weight:600;display:flex}.guide-q:hover{background:#ffffff0a}.guide-qa-arrow{color:var(--text-muted);flex-shrink:0;font-size:.6rem;transition:transform .3s}.guide-qa.open .guide-qa-arrow{transform:rotate(90deg)}.guide-a{padding:0 var(--space-md) var(--space-md);font-size:var(--font-size-xs);color:var(--text-secondary);line-height:1.7;display:none}.guide-qa.open .guide-a{animation:.2s fadeIn;display:block}.guide-highlight{color:var(--gold);font-weight:600}.worldmap-container{z-index:200;background:#0d0a14;position:fixed;inset:0}.worldmap-canvas{cursor:grab;display:block}.worldmap-canvas:active{cursor:grabbing}.worldmap-header{padding:var(--space-sm) var(--space-md);z-index:1;background:linear-gradient(#0d0a14e6 0%,#0000 100%);justify-content:space-between;align-items:center;display:flex;position:absolute;top:0;left:0;right:0}.worldmap-title{font-family:var(--font-display,var(--font-heading));font-size:var(--font-size-md);color:var(--gold)}.worldmap-legend{bottom:70px;left:var(--space-md);border-radius:var(--border-radius-md);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-xs);color:var(--text-secondary);z-index:1;background:#0d0a14d9;border:1px solid #ffffff14;position:absolute}.worldmap-legend-item{align-items:center;gap:6px;margin-bottom:4px;display:flex}.worldmap-legend-dot{border-radius:50%;width:10px;height:10px}.banner-designer{text-align:center}.banner-preview{margin-bottom:var(--space-lg)}.banner-section{margin-bottom:var(--space-md)}.banner-section-title{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--text-secondary);letter-spacing:1px;margin-bottom:var(--space-sm)}.banner-shapes{gap:var(--space-xs);flex-wrap:wrap;justify-content:center;display:flex}.banner-shape-option{border-radius:var(--border-radius-sm,4px);cursor:pointer;transition:all var(--transition-fast);border:2px solid #ffffff14;padding:6px}.banner-shape-option:hover{border-color:#ffd7004d}.banner-shape-option.active{border-color:var(--gold);box-shadow:0 0 10px #ffd70033}.banner-colors{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.banner-color-swatch{cursor:pointer;width:24px;height:24px;transition:all var(--transition-fast);border:2px solid #0000;border-radius:4px}.banner-color-swatch:hover{transform:scale(1.2)}.banner-color-swatch.active{border-color:#fff;box-shadow:0 0 8px #ffffff4d}.banner-symbols{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.banner-symbol-option{border-radius:var(--border-radius-sm,4px);cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);border:2px solid #ffffff14;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.banner-symbol-option:hover{background:#ffffff0d;border-color:#ffd7004d}.banner-symbol-option.active{border-color:var(--gold);background:#ffd7001a}.achievement-grid{gap:var(--space-sm);grid-template-columns:1fr;display:grid}.achievement-card{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--gradient-card);border-radius:var(--border-radius-md);transition:all var(--transition-fast);border:1px solid #ffffff0d;display:flex}.achievement-card.unlocked{background:#ffd7000a;border-color:#ffd70033}.achievement-card.locked{opacity:.5}.achievement-icon{flex-shrink:0;font-size:1.8rem}.achievement-card.locked .achievement-icon{filter:grayscale()}.achievement-info{flex:1}.achievement-name{font-family:var(--font-heading);font-size:var(--font-size-sm);color:var(--text-primary)}.achievement-desc{font-size:var(--font-size-xs);color:var(--text-muted)}.achievement-reward{font-size:var(--font-size-xs);color:var(--gold);margin-top:2px}.achievement-check{font-size:1.2rem}.achievement-cat-title{font-family:var(--font-heading);font-size:var(--font-size-sm);letter-spacing:2px;margin:var(--space-md) 0 var(--space-sm)}.scene-time-overlay{pointer-events:none;border-radius:inherit;z-index:2;transition:background 2s,opacity 2s;position:absolute;inset:0}.scene-time-night{background:#0a0f2847}.scene-time-dawn{background:#ff8c321a}.scene-time-dusk{background:#ff641e26}.scene-time-day{background:0 0}.scene-time-night~.scene-buildings .scene-building-img{filter:brightness(.85)saturate(1.1)}.scene-time-night~.scene-torches .torch-glow{width:50px;height:50px;opacity:1!important}.scene-stars{pointer-events:none;z-index:1;border-radius:inherit;position:absolute;inset:0;overflow:hidden}.scene-star{background:#fff;border-radius:50%;width:2px;height:2px;animation:2s ease-in-out infinite alternate starTwinkle;position:absolute}@keyframes starTwinkle{0%{opacity:.2}to{opacity:.9}}.scene-moon{z-index:3;pointer-events:none;background:0 0;border-radius:50%;width:22px;height:22px;position:absolute;top:8%;right:12%;box-shadow:-4px 0 #f5e6b8,0 0 15px #f5e6b84d,0 0 40px #f5e6b826}.events-banner-strip{gap:var(--space-sm);padding:0 0 var(--space-sm);scrollbar-width:none;margin-bottom:var(--space-xs);display:flex;overflow-x:auto}.events-banner-strip::-webkit-scrollbar{display:none}.event-banner-card{align-items:center;gap:var(--space-sm);border-radius:var(--border-radius-md);border-left:3px solid var(--gold);background:#0000004d;flex-shrink:0;min-width:200px;padding:8px 14px;animation:3s ease-in-out infinite eventPulse;display:flex}@keyframes eventPulse{0%,to{box-shadow:0 0 #ffd70000}50%{box-shadow:0 0 12px 2px #ffd70026}}.event-banner-icon{border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:1rem;display:flex}.event-banner-text{flex:1}.event-banner-name{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--gold)}.event-banner-desc{color:var(--text-muted);font-size:.65rem;line-height:1.3}.crownpass-mini{border-radius:var(--border-radius-md);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);transition:all var(--transition-fast);background:linear-gradient(135deg,#ffd7000f 0%,#8b451314 100%);border:1px solid #ffd7001f}.crownpass-mini:hover{border-color:#ffd7004d}.crownpass-mini-header{align-items:center;gap:var(--space-sm);margin-bottom:4px;display:flex}.crownpass-mini-icon{font-size:1rem}.crownpass-mini-title{font-family:var(--font-heading);font-size:var(--font-size-xs);color:var(--gold);flex:1}.crownpass-mini-level{font-size:var(--font-size-xs);color:var(--text-secondary)}.crownpass-mini-xp{color:var(--text-muted);text-align:right;margin-top:2px;font-size:.6rem}.crownpass-track{padding:var(--space-md) 0;scrollbar-width:thin;align-items:center;gap:0;display:flex;overflow-x:auto}.crownpass-track::-webkit-scrollbar{height:4px}.crownpass-track::-webkit-scrollbar-thumb{background:#ffd70033;border-radius:4px}.crownpass-node{text-align:center;width:80px;padding:var(--space-sm);border-radius:var(--border-radius-md);background:var(--gradient-card);transition:all var(--transition-fast);border:1px solid #ffffff0d;flex-shrink:0}.crownpass-node.unlocked{background:#2db75d0d;border-color:#2db75d4d}.crownpass-node.current{border-color:var(--gold);transform:scale(1.05);box-shadow:0 0 15px #ffd70033}.crownpass-node-level{font-family:var(--font-heading);font-size:var(--font-size-md);color:var(--text-muted);margin-bottom:4px}.crownpass-node.unlocked .crownpass-node-level{color:var(--emerald)}.crownpass-node.current .crownpass-node-level{color:var(--gold)}.crownpass-node-rewards{flex-direction:column;gap:2px;display:flex}.crownpass-reward{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.6rem;overflow:hidden}.crownpass-reward.free{color:var(--text-primary)}.crownpass-reward.premium{color:var(--amethyst,#c77dff)}.crownpass-connector{background:#ffffff1a;flex-shrink:0;width:20px;height:2px}.crownpass-connector.filled{background:var(--emerald)}.quest-reward-overlay{z-index:9000;opacity:0;pointer-events:none;background:#00000080;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}.quest-reward-overlay.visible{opacity:1;pointer-events:all}.quest-reward-popup{text-align:center;background:var(--gradient-card);border:var(--border-gold);border-radius:var(--border-radius-lg,16px);padding:var(--space-xl) var(--space-lg);min-width:280px;animation:.5s cubic-bezier(.4,0,.2,1) rewardPop;position:relative;box-shadow:0 0 60px #ffd70033,0 20px 60px #00000080}@keyframes rewardPop{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.quest-reward-title{font-family:var(--font-heading);font-size:var(--font-size-lg);color:var(--gold);margin-bottom:var(--space-sm)}.quest-reward-name{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-md)}.quest-reward-value{font-family:var(--font-heading);font-size:var(--font-size-md);color:var(--emerald);text-shadow:0 0 20px #2db75d66}.reward-particle{pointer-events:none;animation:1.5s ease-out forwards particleFloat;position:absolute}@keyframes particleFloat{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-60px)scale(.3)rotate(180deg)}}.attack-alert{z-index:8000;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--border-radius-lg,12px);background:linear-gradient(135deg,#b41e1ef2 0%,#781414f2 100%);border:2px solid #ff505080;width:90%;max-width:440px;transition:top .5s cubic-bezier(.4,0,.2,1);animation:1s ease-in-out infinite attackPulse;display:flex;position:fixed;top:-100px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #ff00004d,0 0 60px #ff000026}.attack-alert.visible{top:80px}@keyframes attackPulse{0%,to{box-shadow:0 8px 32px #ff00004d,0 0 60px #ff000026}50%{box-shadow:0 8px 32px #ff000080,0 0 80px #ff00004d}}.attack-alert-icon{font-size:2rem;animation:.5s ease-in-out infinite shakeIcon}@keyframes shakeIcon{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.attack-alert-info{flex:1}.attack-alert-title{font-family:var(--font-heading);font-size:var(--font-size-sm);color:#fff;letter-spacing:2px}.attack-alert-attacker{font-size:var(--font-size-xs);color:#ffffffb3}.attack-alert-timer{font-family:var(--font-heading);font-size:var(--font-size-sm);color:gold;margin-top:2px}.attack-alert-btn{flex-shrink:0}@media (width<=480px){.hud-top{gap:4px;padding:4px 8px}.hud-resource{gap:2px;padding:2px 5px}.hud-resource-icon{font-size:.7rem}.hud-resource-value{font-size:.65rem}.hud-gems{padding:3px 8px}.hud-bottom-bar{gap:8px;padding:0 8px 4px}.hud-decree-bar-container{width:60px}.panel-container{max-height:90vh}.nav-btn{min-height:48px;padding:6px 0}.nav-icon{font-size:1.1rem}.nav-label{font-size:.55rem}.troop-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px}.troop-card{padding:8px}.troop-icon{font-size:1.5rem}.build-item{gap:8px;padding:8px}.beauty-tier{padding:6px}.battle-report{padding:var(--space-md)}.br-icon{font-size:3rem}.br-title{font-size:1.4rem}.br-stats{gap:var(--space-xs);flex-direction:column}.attack-alert{width:95%;max-width:none;padding:var(--space-sm) var(--space-md)}.crownpass-node{width:65px;padding:6px}}@media (width<=768px){.score-category{flex-direction:column;gap:2px}.buildings-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.kingdom-stats-grid{grid-template-columns:repeat(3,1fr)}}.btn{transition:transform .1s}.btn:active{transform:scale(.95)}.panel-container{animation:.35s cubic-bezier(.4,0,.2,1) panelSlideUp}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.build-dust{pointer-events:none;width:60px;height:30px;animation:.6s ease-out forwards dustPoof;position:absolute}@keyframes dustPoof{0%{opacity:.8;transform:scale(.5)}to{opacity:0;transform:scale(2)translateY(-20px)}}.confetti-piece{pointer-events:none;z-index:9998;width:8px;height:8px;animation:1.5s ease-out forwards confettiFall;position:fixed}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}#crisis-banners{z-index:6;position:relative}.crisis-banner{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius-md);margin:var(--space-xs) var(--space-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-left:4px solid;animation:2s ease-in-out infinite crisisPulse;display:flex}.crisis-famine{background:linear-gradient(135deg,#b41e1e40,#78141426);border-left-color:#e63946}.crisis-famine.crisis-critical{background:linear-gradient(135deg,#dc1e1e59,#a0141440);border-left-color:#ff1744;animation:1s ease-in-out infinite crisisPulseHard}.crisis-low-food{background:linear-gradient(135deg,#c8961e33,#a078141a);border-left-color:#ffa726}.crisis-overcrowding{background:linear-gradient(135deg,#b4781e33,#8c5a141a);border-left-color:#ff9800}.crisis-icon{flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.4rem;display:flex}.crisis-critical .crisis-icon{animation:.5s ease-in-out infinite crisisShake}.crisis-text{flex:1;min-width:0}.crisis-title{font-family:var(--font-heading);font-size:var(--font-size-xs);color:#ff6b6b;letter-spacing:2px;font-weight:700}.crisis-low-food .crisis-title{color:#ffa726}.crisis-overcrowding .crisis-title{color:#ff9800}.crisis-desc{color:var(--text-secondary);font-size:.65rem;line-height:1.3}@keyframes crisisPulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes crisisPulseHard{0%,to{opacity:1;box-shadow:0 0 15px #ff17444d}50%{opacity:.8;box-shadow:0 0 25px #ff174480}}@keyframes crisisShake{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(-2px)rotate(-5deg)}75%{transform:translate(2px)rotate(5deg)}}
