:root{--color-bg: #0b0d17;--color-bg-deep: #07091a;--color-surface-1: rgba(20, 26, 48, .88);--color-surface-2: rgba(30, 37, 61, .94);--color-surface-3: rgba(42, 50, 78, .96);--color-surface-raised:rgba(30, 41, 59, .95);--color-border-subtle: rgba(255, 255, 255, .08);--color-border: rgba(255, 255, 255, .15);--color-border-strong: rgba(255, 255, 255, .25);--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-text-dim: rgba(226, 232, 240, .55);--color-text-inverse: #0f172a;--color-primary: #22d3ee;--color-primary-hover: #67e8f9;--color-primary-deep: #0891b2;--color-primary-ring: rgba(34, 211, 238, .4);--color-gold: #fbbf24;--color-gold-hover: #fcd34d;--color-gold-deep: #d97706;--color-gold-ring: rgba(251, 191, 36, .35);--color-success: #34d399;--color-success-soft: rgba(52, 211, 153, .15);--color-danger: #f87171;--color-danger-soft: rgba(248, 113, 113, .15);--color-warn: #fbbf24;--color-info: #22d3ee;--color-food: #fbbf24;--color-wood: #a16207;--color-stone: #9ca3af;--color-metal: #f97316;--color-reps: #fbbf24;--font-body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;--font-display: "Space Grotesk", "Inter", system-ui, sans-serif;--font-mono: ui-monospace, "JetBrains Mono", SFMono-Regular, Menlo, monospace;--text-xs: 11px;--text-sm: 12px;--text-base:13px;--text-md: 14px;--text-lg: 16px;--text-xl: 20px;--text-2xl: 28px;--text-3xl: 40px;--line-tight: 1.2;--line-normal: 1.45;--line-loose: 1.6;--tracking-tight: -.01em;--tracking-normal: 0;--tracking-wide: .06em;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-2xl: 16px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .22);--shadow-md: 0 4px 12px rgba(0, 0, 0, .32);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .48);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .55);--shadow-glow-primary: 0 0 20px rgba(34, 211, 238, .32);--shadow-glow-gold: 0 0 24px rgba(251, 191, 36, .28);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .12s;--dur-base: .18s;--dur-slow: .32s;--z-map: 1;--z-hud: 10;--z-hud-raised: 11;--z-banner: 20;--z-modal: 50;--z-toast: 60;--z-overlay: 100;--z-coach: 110;--blur-panel: blur(10px)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-base);line-height:var(--line-normal);overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#game{width:100vw;height:100vh}.hidden{display:none!important}.dim{opacity:.5}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.num{font-variant-numeric:tabular-nums}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-base);font-weight:500;line-height:1;white-space:nowrap;background:transparent;color:var(--color-text);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),opacity var(--dur-fast) var(--ease-out),filter var(--dur-fast) var(--ease-out)}.btn:hover:not(:disabled):not(.btn--loading){transform:translateY(-1px)}.btn:active:not(:disabled):not(.btn--loading){transform:translateY(0)}.btn:focus-visible{outline:2px solid var(--color-primary-ring);outline-offset:2px}.btn:disabled{opacity:.5;cursor:default}.btn--sm{padding:var(--space-1) var(--space-2);font-size:var(--text-sm)}.btn--lg{padding:var(--space-3) var(--space-5);font-size:var(--text-md)}.btn--xl{padding:var(--space-4) var(--space-6);font-size:var(--text-lg);font-weight:600;letter-spacing:var(--tracking-tight)}.btn--primary{background:var(--color-primary);color:var(--color-text-inverse);font-weight:600}.btn--primary:hover:not(:disabled):not(.btn--loading){background:var(--color-primary-hover);box-shadow:var(--shadow-glow-primary)}.btn--gold{background:var(--color-gold);color:var(--color-text-inverse);font-weight:600}.btn--gold:hover:not(:disabled):not(.btn--loading){background:var(--color-gold-hover);box-shadow:var(--shadow-glow-gold)}.btn--secondary{background:transparent;border-color:var(--color-border);color:var(--color-text)}.btn--secondary:hover:not(:disabled):not(.btn--loading){background:#ffffff0f;border-color:var(--color-border-strong)}.btn--ghost{background:transparent;color:var(--color-text-muted)}.btn--ghost:hover:not(:disabled):not(.btn--loading){background:#ffffff0f;color:var(--color-text)}.btn--danger{background:var(--color-danger);color:#fff;font-weight:600}.btn--danger:hover:not(:disabled):not(.btn--loading){filter:brightness(1.08)}.btn--loading{pointer-events:none;opacity:.85}.btn--loading:after{content:"";width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite}.btn--loading .btn-label{opacity:.55}@keyframes btn-spin{to{transform:rotate(360deg)}}.card{background:var(--color-surface-1);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel)}.card--raised{background:var(--color-surface-2);box-shadow:var(--shadow-lg)}.card--gold-edge{border-color:var(--color-gold-ring)}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-pill);background:#ffffff0f;border:1px solid var(--color-border-subtle);font-size:var(--text-xs);font-weight:500;line-height:1.4;white-space:nowrap}.chip--success{background:var(--color-success-soft);color:var(--color-success);border-color:transparent}.chip--danger{background:var(--color-danger-soft);color:var(--color-danger);border-color:transparent}.chip--gold{background:#fbbf241f;color:var(--color-gold);border-color:transparent}.chip--primary{background:#22d3ee1f;color:var(--color-primary);border-color:transparent}.chip--muted{background:#ffffff0d;color:var(--color-text-dim);border-color:transparent}.chip--sm{padding:1px var(--space-1);font-size:10px}.stack{display:flex;flex-direction:column;gap:var(--space-2)}.stack--sm{gap:var(--space-1)}.stack--lg{gap:var(--space-4)}.cluster{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.cluster--sm{gap:var(--space-1)}.cluster--lg{gap:var(--space-4)}.divider{height:1px;background:var(--color-border-subtle);margin:var(--space-2) 0;border:0}.icon-12{width:12px;height:12px}.icon-16{width:16px;height:16px}.icon-20{width:20px;height:20px}.icon-24{width:24px;height:24px}.icon-32{width:32px;height:32px}#top-hud{position:fixed;top:var(--space-3);left:50%;transform:translate(-50%);z-index:var(--z-hud);display:flex;align-items:stretch;gap:var(--space-2);pointer-events:none}#top-hud>*{pointer-events:auto}#reps-badge-slot{display:flex}#resources{background:var(--color-surface-1);border:1px solid var(--color-border-subtle);padding:var(--space-2) var(--space-3);border-radius:var(--radius-pill);box-shadow:var(--shadow-md);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-base)}.res-switcher-btn{display:inline-flex;align-items:center;gap:var(--space-2);background:transparent;border:0;padding:var(--space-1) var(--space-2);border-radius:var(--radius-md);color:var(--color-text);font:inherit;font-weight:500;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.res-switcher-btn:hover:not(:disabled){background:#ffffff0f}.res-switcher-btn:disabled{cursor:default}.res-switcher-label{font-size:var(--text-sm);letter-spacing:var(--tracking-tight);white-space:nowrap;max-width:220px;overflow:hidden;text-overflow:ellipsis}.res-switcher-caret{width:14px;height:14px;flex-shrink:0;opacity:.7;transition:transform var(--dur-fast) var(--ease-out)}.res-switcher-btn[aria-expanded=true] .res-switcher-caret{transform:rotate(180deg)}.res-switcher-btn--static .res-switcher-caret{display:none}.res-switcher-menu{position:absolute;top:calc(100% + var(--space-2));left:var(--space-3);min-width:220px;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);padding:var(--space-1);display:flex;flex-direction:column;gap:2px;animation:res-menu-in var(--dur-base) var(--ease-out)}.res-switcher-menu.hidden{display:none}@keyframes res-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.res-switcher-item{text-align:left;background:transparent;color:var(--color-text);border:0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font:inherit;font-size:var(--text-sm);cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.res-switcher-item:hover,.res-switcher-item:focus-visible{background:#ffffff14;outline:none}.res-switcher-item--active{background:var(--color-surface-3);color:var(--color-primary);font-weight:600}.res-divider{width:1px;height:18px;background:var(--color-border-subtle);flex-shrink:0}#resources .res{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-pill);font-variant-numeric:tabular-nums;line-height:1;transition:background var(--dur-base) var(--ease-out)}.res-icon{display:inline-flex;width:16px;height:16px;flex-shrink:0}.res-icon svg{width:100%;height:100%}.res-val{font-weight:600;font-size:var(--text-base)}.res--food .res-icon{color:var(--color-food)}.res--wood .res-icon{color:var(--color-wood)}.res--stone .res-icon{color:var(--color-stone)}.res--metal .res-icon{color:var(--color-metal)}.res--reps .res-icon,.res--reps .res-val{color:var(--color-reps)}.res--flash{animation:res-flash .7s var(--ease-out)}@keyframes res-flash{0%{background:transparent}25%{background:#ffffff1a}to{background:transparent}}#hud,#army-hud{position:fixed;top:70px;right:var(--space-3);width:300px;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);font-size:var(--text-base);color:var(--color-text);transition:transform var(--dur-base) var(--ease-out),opacity var(--dur-base) var(--ease-out)}#hud{z-index:var(--z-hud)}#army-hud{z-index:var(--z-hud-raised)}#hud.hidden,#army-hud.hidden{transform:translate(16px);opacity:0;pointer-events:none;display:flex!important}.hud-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.hud-header strong{font-family:var(--font-display);font-size:var(--text-md);letter-spacing:var(--tracking-tight)}.hud-close{background:transparent;color:var(--color-text);border:0;font-size:18px;line-height:1;cursor:pointer;padding:0 var(--space-1);border-radius:var(--radius-sm);transition:background var(--dur-fast) var(--ease-out)}.hud-close:hover{background:#ffffff14}.hud-body{padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.hud-row{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.hud-row .label{opacity:.55;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:600;padding-top:2px;flex-shrink:0}.hud-row .value{text-align:right}.hud-row .value.dim{opacity:.5;font-style:italic;font-weight:400}.hud-chip-row{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:var(--space-2)}.hud-chip-main{font-weight:600}.hud-chip-sub{font-size:var(--text-xs);opacity:.6}.terrain-swatch{display:inline-block;width:14px;height:14px;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.5);box-shadow:inset 0 0 0 1px #ffffff1f}.level-badge{display:inline-flex;align-items:center;justify-content:center;min-width:26px;padding:2px 6px;border-radius:var(--radius-sm);background:var(--color-primary-deep);color:var(--color-text);font-size:var(--text-xs);font-weight:700;letter-spacing:var(--tracking-tight);font-variant-numeric:tabular-nums}.hud-building-icon{color:var(--color-primary)}.hud-section-title{margin-top:var(--space-1);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);opacity:.55;font-weight:600}.hud-section-line{font-size:var(--text-sm);opacity:.8}#hud-actions-section,#army-actions-section{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);max-width:min(720px,calc(100vw - var(--space-4) * 2));background:none;border:0;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;padding:0;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);color:var(--color-text);z-index:var(--z-hud);pointer-events:none;transition:transform var(--dur-base) var(--ease-out),opacity var(--dur-base) var(--ease-out)}#hud-actions-section.hidden,#army-actions-section.hidden{transform:translate(-50%,16px);opacity:0;pointer-events:none;display:flex!important}.hud-actions-title{text-align:center;font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;letter-spacing:var(--tracking-tight);color:var(--color-text);text-shadow:0 2px 6px rgba(0,0,0,.7),0 0 2px rgba(0,0,0,.9);pointer-events:none}.hud-actions{display:flex;flex-direction:column;gap:var(--space-2)}.hud-actions .empty{opacity:.55;font-style:italic;font-size:var(--text-sm);text-align:center;padding:var(--space-2)}#hud-actions-section .hud-actions,#army-actions-section .hud-actions{flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:stretch;pointer-events:auto}#hud-actions-section .hud-actions .empty,#hud-actions-section .hud-actions .hud-section-line,#hud-actions-section .hud-actions .hud-queue{flex-basis:100%}#hud-actions-section .hud-action,#army-actions-section .hud-action{width:88px;height:88px;min-width:88px;padding:var(--space-2);flex-direction:column;align-items:center;justify-content:space-between;text-align:center;gap:4px;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}#hud-actions-section .hud-action--collect{flex-direction:column;justify-content:space-between;align-items:center}#hud-actions-section .hud-action-header,#army-actions-section .hud-action-header{flex-direction:column;gap:4px;align-items:center;width:100%}#hud-actions-section .hud-action-icon,#army-actions-section .hud-action-icon{width:28px;height:28px}#hud-actions-section .hud-action-title,#army-actions-section .hud-action-title{font-size:var(--text-xs);line-height:1.15;font-weight:700;letter-spacing:var(--tracking-tight);word-break:break-word;white-space:normal}#hud-actions-section .cost-pills{gap:2px;justify-content:center;width:100%}#hud-actions-section .cost-pill{padding:1px 5px}#hud-actions-section .collect-chip{padding:2px 8px}#hud-actions-section .hud-action-preview{display:none}.hud-action{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-1);min-width:140px;background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-deep) 100%);color:var(--color-text-inverse);border:0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:var(--text-base);font-weight:600;text-align:left;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),opacity var(--dur-fast) var(--ease-out),filter var(--dur-fast) var(--ease-out)}.hud-action:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-glow-primary);filter:brightness(1.08)}.hud-action:active:not(:disabled){transform:translateY(0)}.hud-action:disabled{opacity:.55;cursor:default;filter:saturate(.6)}.hud-action-header{display:inline-flex;align-items:center;gap:var(--space-2)}.hud-action-icon{color:currentColor}.hud-action-title{font-weight:700;letter-spacing:var(--tracking-tight)}.hud-action-preview{font-size:var(--text-xs);font-weight:500;opacity:.75;letter-spacing:var(--tracking-tight)}.hud-action--secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.hud-action--secondary:hover:not(:disabled){background:#ffffff0f;border-color:var(--color-border-strong);box-shadow:none;filter:none}.hud-action--danger{background:linear-gradient(180deg,#ef4444,#b91c1c);color:#fff;border:1px solid rgba(185,28,28,.8)}.hud-action--danger:hover:not(:disabled){box-shadow:0 0 24px #ef444473;filter:brightness(1.05)}.hud-action--danger:active:not(:disabled){filter:brightness(.95)}.hud-action--collect{flex-direction:row;justify-content:space-between;align-items:center;background:linear-gradient(180deg,var(--color-gold) 0%,var(--color-gold-deep) 100%);color:var(--color-text-inverse)}.hud-action--collect:hover:not(:disabled){box-shadow:var(--shadow-glow-gold)}.collect-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;background:#00000040;border-radius:var(--radius-pill);font-variant-numeric:tabular-nums;font-weight:700}.collect-chip svg{color:currentColor}.cost-pills{display:inline-flex;gap:var(--space-1);flex-wrap:wrap}.cost-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 6px;border-radius:var(--radius-pill);background:#0003;font-size:var(--text-xs);font-weight:600;font-variant-numeric:tabular-nums;line-height:1;color:var(--color-text-inverse)}.cost-pill svg{width:12px;height:12px}.cost-pill--food svg{color:var(--color-food)}.cost-pill--wood svg{color:#f59e0b}.cost-pill--stone svg{color:var(--color-stone)}.cost-pill--metal svg{color:var(--color-metal)}.cost-pill--short{color:#fee2e2;background:#7f1d1d8c;outline:1px solid rgba(248,113,113,.5)}.cost-pill--short svg{opacity:.8}.hud-nft-section{display:flex;flex-direction:column;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:#facc150a;overflow:hidden}.hud-nft-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:0;color:inherit;font:inherit;cursor:pointer;text-align:left;transition:background var(--dur-fast) var(--ease-out)}.hud-nft-header:hover{background:#facc1514}.hud-nft-header:focus-visible{outline:2px solid var(--color-gold);outline-offset:-2px}.hud-nft-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:700;color:var(--color-gold);flex:1}.hud-nft-chip{display:inline-flex;align-items:center;padding:1px 8px;font-size:var(--text-xs);font-weight:700;letter-spacing:var(--tracking-wide);border-radius:var(--radius-pill);background:#facc151f;color:var(--color-gold);border:1px solid rgba(250,204,21,.28)}.hud-nft-caret{width:12px;height:12px;color:var(--color-gold);transition:transform var(--dur-base) var(--ease-out);flex-shrink:0}.hud-nft-section.is-open .hud-nft-caret{transform:rotate(180deg)}.hud-nft-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows var(--dur-base) var(--ease-out)}.hud-nft-inner{min-height:0;overflow:hidden;display:flex;flex-direction:column;gap:4px}.hud-nft-section.is-open .hud-nft-body{grid-template-rows:1fr}.hud-nft-section.is-open .hud-nft-inner{padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border-subtle)}.hud-nft-row{display:flex;justify-content:space-between;align-items:baseline;gap:var(--space-2);font-size:var(--text-sm)}.hud-nft-label{opacity:.55;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:600;flex-shrink:0}.hud-nft-value{text-align:right;font-variant-numeric:tabular-nums;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hud-nft-value .monospace{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:var(--text-xs)}.hud-nft-link{color:var(--color-text);text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.25);transition:color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.hud-nft-link:hover{color:var(--color-gold);border-bottom-color:var(--color-gold)}.hud-nft-placeholder{font-size:var(--text-sm);opacity:.65;font-style:italic;padding:var(--space-1) 0}.hud-nft-placeholder--err{color:var(--color-danger, #fca5a5);opacity:.85;font-style:normal}.hud-queue{display:flex;flex-direction:column;gap:2px;background:#ffffff0a;padding:var(--space-2) var(--space-2);border-radius:var(--radius-sm)}.hud-queue-row{font-size:var(--text-sm);font-variant-numeric:tabular-nums;opacity:.85}.hud-queue-row.dim{opacity:.55;font-style:italic}#army-hud .hud-status.active{color:#fde68a;font-weight:600}.hud-army-soldiers{display:inline-flex;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:var(--space-2)}.hud-army-total{font-family:var(--font-display);font-size:var(--text-md);font-weight:700;font-variant-numeric:tabular-nums}.hud-army-type{font-variant-numeric:tabular-nums}.hud-army-type--infantry{background:#94a3b829;color:#e2e8f0;border:1px solid rgba(148,163,184,.3)}.hud-army-type--cavalry{background:#3b82f62e;color:#bfdbfe;border:1px solid rgba(59,130,246,.35)}.hud-army-type--knight{background:#fbbf2429;color:#fde68a;border:1px solid rgba(251,191,36,.35)}#army-list{position:fixed;top:70px;left:var(--space-3);width:240px;max-height:calc(100vh - 90px);display:flex;flex-direction:column;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);font-size:var(--text-base);color:var(--color-text);z-index:var(--z-hud);transition:transform var(--dur-base) var(--ease-out),opacity var(--dur-base) var(--ease-out)}#army-list.hidden{transform:translate(-16px);opacity:0;pointer-events:none;display:flex!important}.army-list-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.army-list-header strong{font-family:var(--font-display);font-size:var(--text-md);letter-spacing:var(--tracking-tight)}.army-list-count{min-width:22px;padding:1px 8px;background:var(--color-primary-deep);color:var(--color-text);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;font-variant-numeric:tabular-nums;text-align:center}.army-list-body{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2);overflow-y:auto}.army-list-row{display:flex;flex-direction:column;border-radius:var(--radius-md);background:#ffffff08;border:1px solid transparent;overflow:hidden;transition:border-color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.army-list-row:hover{background:#ffffff0f}.army-list-row.is-selected{border-color:var(--color-primary);background:#22d3ee14}.army-list-head{display:flex;align-items:stretch}.army-list-summary{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2) var(--space-2) var(--space-3);background:transparent;color:inherit;border:0;font:inherit;cursor:pointer;text-align:left;flex:1;min-width:0}.army-list-summary:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.army-list-locate{display:inline-flex;align-items:center;justify-content:center;width:28px;flex-shrink:0;background:transparent;color:var(--color-text-muted);border:0;border-left:1px solid var(--color-border-subtle);cursor:pointer;padding:0;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.army-list-locate:hover{background:#22d3ee1f;color:var(--color-primary)}.army-list-locate:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.army-list-caret{width:10px;flex-shrink:0;opacity:.7;font-size:10px}.army-list-title-wrap{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.army-list-title{font-weight:600;letter-spacing:var(--tracking-tight)}.army-list-status{font-size:var(--text-xs);font-weight:500;letter-spacing:var(--tracking-tight);color:var(--color-text-muted)}.army-list-row.is-traveling{border-left:2px solid var(--color-warning, #f59e0b)}.army-list-row.is-traveling .army-list-status{color:var(--color-warning, #f59e0b)}.army-list-row.is-raiding{border-left:2px solid var(--color-reps, #a78bfa)}.army-list-row.is-raiding .army-list-status,.army-list-status--raiding{color:var(--color-reps, #a78bfa);font-weight:600;animation:army-list-raid-pulse 2.2s ease-in-out infinite}@keyframes army-list-raid-pulse{0%,to{opacity:1}50%{opacity:.55}}.hud-status.hud-status--raiding{color:var(--color-reps, #a78bfa);font-weight:600}.army-list-food{display:inline-flex;align-items:center;gap:4px;font-size:var(--text-xs);font-variant-numeric:tabular-nums;color:var(--color-warning, #f59e0b);margin-top:2px}.army-list-food-icon{display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px}.army-list-food.is-empty{color:var(--color-danger, #ef4444)}.army-list-breakdown{display:flex;flex-direction:column;gap:2px;padding:var(--space-1) var(--space-3) var(--space-2) 28px;border-top:1px solid var(--color-border-subtle)}.army-list-type-row{display:flex;justify-content:space-between;align-items:baseline;font-size:var(--text-xs);padding:2px 0}.army-list-type-label{opacity:.7;text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:600}.army-list-type-val{font-variant-numeric:tabular-nums;font-weight:600}.army-list-type-row--infantry .army-list-type-val{color:#e2e8f0}.army-list-type-row--cavalry .army-list-type-val{color:#bfdbfe}.army-list-type-row--knight .army-list-type-val{color:#fde68a}body.army-move-mode{cursor:crosshair}body.army-move-mode #game canvas{cursor:crosshair}.upgrade-modal{max-width:380px;padding:var(--space-5) var(--space-4) var(--space-4);gap:var(--space-3);position:relative;text-align:center}.upgrade-modal .modal-title{text-align:center}.upgrade-modal-close{position:absolute;top:var(--space-2);right:var(--space-2);width:28px;height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:var(--color-danger);color:#fff;border:0;border-radius:var(--radius-pill);font-size:18px;line-height:1;font-weight:700;cursor:pointer;transition:background var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.upgrade-modal-close:hover{filter:brightness(1.1);box-shadow:0 0 0 4px var(--color-danger-soft)}.upgrade-modal-close:focus-visible{outline:2px solid var(--color-danger);outline-offset:2px}.upgrade-modal-level{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);margin:0 auto}.upgrade-modal-level-chip{min-width:40px;padding:4px 10px;border-radius:var(--radius-pill);background:#ffffff0f;border:1px solid var(--color-border-subtle);font-family:var(--font-display);font-size:var(--text-md);font-weight:700;letter-spacing:var(--tracking-tight);font-variant-numeric:tabular-nums}.upgrade-modal-level-chip--next{background:#22d3ee24;border-color:var(--color-primary-ring);color:var(--color-primary);box-shadow:0 0 12px #22d3ee40}.upgrade-modal-level-arrow{font-size:var(--text-lg);color:var(--color-text-muted)}.upgrade-modal-preview{font-size:var(--text-md);font-weight:600;color:var(--color-primary-hover);letter-spacing:var(--tracking-tight)}.upgrade-modal-cost-label{margin-top:0;text-align:center;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted)}.upgrade-modal-costs{justify-content:center;gap:var(--space-2)}.upgrade-modal-costs .cost-pill{padding:4px 10px;font-size:var(--text-sm)}.upgrade-modal-costs .cost-pill svg{width:14px;height:14px}.upgrade-modal-actions{justify-content:center;margin-top:var(--space-3)}.upgrade-modal-actions .btn{min-width:200px}.training-modal{max-width:480px;padding:var(--space-5) var(--space-4) var(--space-4);gap:var(--space-3);position:relative;text-align:left}.training-modal .modal-title{text-align:center;margin-bottom:var(--space-1)}.training-modal-stats{display:flex;justify-content:space-around;gap:var(--space-2);padding:var(--space-3) var(--space-2);background:#ffffff08;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md)}.training-modal-stat{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:70px}.training-modal-stat-value{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;letter-spacing:var(--tracking-tight);font-variant-numeric:tabular-nums;color:var(--color-text)}.training-modal-stat--primary .training-modal-stat-value{color:var(--color-primary)}.training-modal-stat-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:600;color:var(--color-text-muted)}.training-modal-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);font-weight:700;color:var(--color-text-muted);margin-top:var(--space-1)}.training-modal-queue{display:flex;flex-direction:column;gap:var(--space-2)}.training-modal-queue-empty{font-size:var(--text-sm);font-style:italic;opacity:.6;padding:var(--space-2) 0;text-align:center}.training-modal-queue-row{display:grid;grid-template-columns:1fr 2fr auto;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:#ffffff08;border:1px solid var(--color-border-subtle)}.training-modal-queue-row--active{background:#22d3ee14;border-color:var(--color-primary-ring)}.training-modal-queue-label{font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.training-modal-queue-bar{position:relative;height:8px;border-radius:var(--radius-pill);background:#ffffff14;overflow:hidden}.training-modal-queue-row:not(.training-modal-queue-row--active) .training-modal-queue-bar{display:none}.training-modal-queue-row:not(.training-modal-queue-row--active){grid-template-columns:1fr auto}.training-modal-queue-progress{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);border-radius:inherit;transition:width .5s linear}.training-modal-queue-time{font-family:var(--font-display);font-size:var(--text-sm);font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text);letter-spacing:var(--tracking-tight);min-width:48px;text-align:right}.training-modal-queue-time--dim{color:var(--color-text-muted);font-weight:500}.training-modal-options{display:flex;flex-direction:column;gap:var(--space-2)}.training-modal-option-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.training-modal-warn{font-size:var(--text-sm);color:var(--color-warn);background:#fbbf2414;border:1px solid rgba(251,191,36,.25);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);text-align:center}.training-option{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);background:#ffffff08;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-family:inherit;text-align:center;transition:transform var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.training-option:hover:not(:disabled){transform:translateY(-1px);background:#22d3ee14;border-color:var(--color-primary-ring);box-shadow:var(--shadow-glow-primary)}.training-option:disabled{cursor:default;opacity:.75}.training-option-name{font-family:var(--font-display);font-size:var(--text-md);font-weight:700;letter-spacing:var(--tracking-tight)}.training-option-meta{display:inline-flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;justify-content:center}.training-option-meta .cost-pills{display:inline-flex}.training-option-time{font-size:var(--text-xs);font-variant-numeric:tabular-nums;color:var(--color-text-muted);font-weight:600}.training-option-cta{margin-top:var(--space-1);padding:4px 12px;border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:700;letter-spacing:var(--tracking-wide);text-transform:uppercase}.training-option-cta--active{background:var(--color-primary);color:var(--color-text-inverse)}.training-option:hover:not(:disabled) .training-option-cta--active{background:var(--color-primary-hover)}.training-option-cta--locked{background:#ffffff0f;color:var(--color-text-muted)}.training-option-cta--short{background:#f8717126;color:#fca5a5}.training-option--infantry{border-top:2px solid #94a3b8}.training-option--cavalry{border-top:2px solid #60a5fa}.training-option--knight{border-top:2px solid #fbbf24}.hud-action-army-chip{font-variant-numeric:tabular-nums;font-weight:700}.food-modal{width:min(480px,calc(100vw - 32px));padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.food-modal .modal-title{margin:0;padding-right:32px}.food-modal-sub{margin:0;font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.4}.food-modal-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}.food-modal-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2);background:#ffffff08;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md)}.food-modal-stat-value{font-family:var(--font-display);font-size:var(--text-md);font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-text)}.food-modal-stat-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted)}.food-modal-amount-label{margin-top:var(--space-2)}.food-modal-amount-row{display:flex;align-items:center;gap:var(--space-3)}.food-modal-slider{flex:1;accent-color:#fbbf24}.food-modal-amount-val{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;font-variant-numeric:tabular-nums;color:#fde68a;min-width:3ch;text-align:right}.food-modal-quick{display:flex;gap:var(--space-2);flex-wrap:wrap}.food-modal-quick-btn{padding:4px 12px;background:#ffffff0a;border:1px solid var(--color-border-subtle);border-radius:var(--radius-pill);color:var(--color-text);font-family:inherit;font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.food-modal-quick-btn:hover{background:#fbbf241a;border-color:#fbbf2466}.food-modal-outcome{display:flex;flex-direction:column;gap:4px;padding:var(--space-3);background:#ffffff08;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);font-size:var(--text-sm)}.food-modal-outcome-line{color:var(--color-text)}.food-modal-warn{color:#fca5a5;font-weight:600}.food-modal-actions{display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-2)}.food-modal-actions .btn{min-width:140px}#hud-actions-section .hud-actions:has(>.castle-panel-header){flex-direction:column;align-items:stretch;max-width:520px;width:min(520px,calc(100vw - var(--space-4) * 2));padding:var(--space-3) var(--space-4);background:#121024eb;border:1px solid rgba(139,92,246,.45);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);gap:var(--space-2);pointer-events:auto}.castle-panel-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3)}.castle-panel-pool{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-variant-numeric:tabular-nums}.castle-panel-pool-icon{color:var(--color-reps, #fbbf24)}.castle-panel-pool-n{font-size:var(--text-lg)}.castle-panel-pool-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);opacity:.7}.castle-panel-timer{font-family:var(--font-display, inherit);font-size:var(--text-lg);font-weight:700;font-variant-numeric:tabular-nums;color:#a78bfa;padding:2px 10px;border-radius:var(--radius-sm);background:#8b5cf61f;border:1px solid rgba(139,92,246,.35)}.castle-panel-timer--done{color:#fca5a5;background:#f871711f;border-color:#f8717166}.castle-panel-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);opacity:.7;font-weight:600;margin-top:var(--space-1)}.castle-panel-occupants{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}.castle-panel-occupant{display:flex;flex-direction:column;gap:4px;padding:6px 8px;background:#ffffff0a;border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm)}.castle-panel-occupant-main{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.castle-panel-occupant-owner{font-family:var(--font-mono, monospace);font-size:var(--text-xs);opacity:.85;margin-right:auto}.castle-panel-occupant-counts{display:flex;flex-wrap:wrap;gap:4px}.castle-panel-admin{display:flex;justify-content:flex-end;margin-top:var(--space-1)}.hud-castle-icon{color:#a78bfa}.castle-optin-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3);margin-bottom:var(--space-2);border:1px solid rgba(167,139,250,.55);border-radius:var(--radius-md);background:linear-gradient(135deg,#8b5cf62e,#60a5fa2e)}.castle-optin-card-title{font-weight:700;font-size:var(--text-sm);color:var(--color-text)}.castle-optin-card-copy{margin:0;font-size:var(--text-xs);line-height:var(--line-normal);color:var(--color-text-dim)}.castle-optin-card .btn{align-self:flex-start}#city-hall-banner{position:fixed;bottom:var(--space-4);left:50%;transform:translate(-50%);z-index:var(--z-banner);display:flex;align-items:center;gap:var(--space-4);width:min(540px,calc(100vw - var(--space-6)));padding:var(--space-4);background:linear-gradient(180deg,#1e253df2,#141a30f7);border:1px solid var(--color-gold-ring);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);color:var(--color-text);transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}#city-hall-banner.hidden{opacity:0;transform:translate(-50%,12px);pointer-events:none;display:flex!important;visibility:hidden}#city-hall-banner.banner--mint,#city-hall-banner.banner--place,#city-hall-banner.banner--minting{box-shadow:var(--shadow-xl),0 0 0 1px #fbbf2433,0 0 48px #fbbf241f}.banner-visual{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);width:56px;height:56px;background:#fbbf241f;color:var(--color-gold)}.banner-visual svg{width:28px;height:28px;display:block}.banner-visual img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}#city-hall-banner.banner--mint .banner-visual,#city-hall-banner.banner--place .banner-visual,#city-hall-banner.banner--minting .banner-visual{width:96px;height:96px;padding:var(--space-1);background:radial-gradient(circle at 50% 40%,#fbbf2438,#fbbf240a 70%);border:1px solid rgba(251,191,36,.32);box-shadow:inset 0 0 0 1px #ffffff0a,0 0 22px #fbbf242e;position:relative;overflow:hidden}#city-hall-banner.banner--minting .banner-visual:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 35%,rgba(251,191,36,.28) 50%,transparent 65%);animation:banner-shimmer 1.8s ease-in-out infinite;pointer-events:none}@keyframes banner-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (prefers-reduced-motion: reduce){#city-hall-banner.banner--minting .banner-visual:after{animation:none;opacity:.35}}#city-hall-banner.banner--apply .banner-visual{background:#fbbf2424;color:var(--color-gold)}#city-hall-banner.banner--pending .banner-visual{background:#22d3ee24;color:var(--color-info)}#city-hall-banner.banner--rejected .banner-visual,#city-hall-banner.banner--delivery-pending .banner-visual{background:var(--color-danger-soft);color:var(--color-danger)}#city-hall-banner.banner--rejected,#city-hall-banner.banner--delivery-pending{border-color:#f8717159}.banner-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-2)}.banner-head{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.banner-title{margin:0;font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;letter-spacing:var(--tracking-tight);color:#f8fafc;line-height:var(--line-tight)}.banner-step{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:var(--radius-pill);font-size:10px;font-weight:700;line-height:1.4;letter-spacing:var(--tracking-wide);text-transform:uppercase;background:#22d3ee24;color:var(--color-info)}.banner-copy{margin:0;font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--line-normal)}.banner-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-1)}.banner-steps.hidden{display:none}.banner-step-item{display:flex;align-items:center;gap:var(--space-2);padding:6px var(--space-2);border-radius:var(--radius-md);background:#ffffff08;font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--line-tight);transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.banner-step-item--active{color:var(--color-text);background:#fbbf2414}.banner-step-item--done{color:var(--color-success);background:#22c55e14}.banner-step-item--error{color:var(--color-warn);background:#fb923c1a}.banner-step-badge{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;font-family:var(--font-display);background:#ffffff14;color:var(--color-text-dim)}.banner-step-item--active .banner-step-badge{background:var(--color-gold);color:#0b0b0b;box-shadow:0 0 0 3px #fbbf2433}.banner-step-item--done .banner-step-badge{background:var(--color-success);color:#0b0b0b}.banner-step-item--error .banner-step-badge{background:var(--color-warn);color:#0b0b0b}.banner-step-badge svg{width:12px;height:12px;display:block}.banner-step-text{flex:1;min-width:0}.banner-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-1)}.banner-actions:empty{display:none}#city-hall-banner.banner--mint .banner-actions .btn,#city-hall-banner.banner--apply .banner-actions .btn,#city-hall-banner.banner--place .banner-actions .btn{width:100%;justify-content:center;padding:var(--space-3) var(--space-4);font-size:var(--text-base);font-weight:600}.banner-issuances{display:flex;flex-direction:column;gap:var(--space-1)}.banner-issuances:empty{display:none}.banner-issuance{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:#ffffff08}.banner-issuance-label{flex:1;min-width:0;font-size:var(--text-sm);color:var(--color-text-muted)}.banner-issuance-id{font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--color-text);font-weight:500}@media (max-width: 520px){#city-hall-banner{width:auto;left:var(--space-3);right:var(--space-3);transform:none;gap:var(--space-3);padding:var(--space-3)}#city-hall-banner.hidden{transform:translateY(12px)}.banner-title{font-size:var(--text-base)}#city-hall-banner.banner--mint .banner-visual,#city-hall-banner.banner--place .banner-visual,#city-hall-banner.banner--minting .banner-visual{width:72px;height:72px}}#admin-panel{position:fixed;top:150px;left:var(--space-3);z-index:var(--z-hud);width:360px;max-height:calc(100vh - 180px);overflow:hidden;display:flex;flex-direction:column;background:var(--color-surface-2);color:var(--color-text);border:1px solid var(--color-gold-ring);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);font-size:var(--text-base)}.admin-header{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:center;gap:var(--space-2)}.admin-header strong{flex:1;font-family:var(--font-display);font-size:var(--text-base);color:var(--color-gold);letter-spacing:var(--tracking-tight)}.admin-refresh{background:transparent;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px var(--space-2);cursor:pointer;font-size:var(--text-md);transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.admin-refresh:hover{background:#ffffff0f;border-color:var(--color-border-strong)}.admin-tabs{display:flex;gap:var(--space-1);padding:var(--space-2) var(--space-3) 0}.admin-tab{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border-subtle);padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:500;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.admin-tab:hover{color:var(--color-text);border-color:var(--color-border)}.admin-tab.active{background:#fbbf2426;color:var(--color-gold);border-color:var(--color-gold-ring)}.admin-status{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);opacity:.85;border-bottom:1px solid var(--color-border-subtle);min-height:18px}.admin-status:empty{padding:0;min-height:0;border-bottom:0}.admin-status.err{color:var(--color-danger)}.admin-status.ok{color:var(--color-success)}.admin-list{overflow-y:auto;padding:var(--space-1) 0}.admin-item{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border-subtle);display:flex;flex-direction:column;gap:var(--space-2)}.admin-item:last-child{border-bottom:0}.admin-item-head{display:flex;align-items:center;gap:var(--space-2)}.admin-blockie{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,hsl(var(--blockie-hue, 200),80%,50%),hsl(var(--blockie-hue-2, 220),70%,35%));box-shadow:inset 0 0 0 1px #ffffff1f}.admin-ident{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.admin-addr{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-meta{font-size:var(--text-xs);color:var(--color-text-dim)}.admin-actions{display:flex;gap:var(--space-2)}.admin-empty{padding:var(--space-4) var(--space-3);color:var(--color-text-dim);font-style:italic;font-size:var(--text-sm);text-align:center}.admin-notes{font-size:var(--text-xs);color:var(--color-text-muted);font-style:italic;padding:var(--space-1) var(--space-2);background:#ffffff0a;border-radius:var(--radius-sm)}.admin-subhead{padding:var(--space-2) var(--space-3) 0;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-muted);font-weight:600}.admin-castles{display:flex;flex-direction:column;gap:var(--space-2);padding:0 var(--space-3) var(--space-2);border-bottom:1px solid var(--color-border-subtle)}.admin-castle-spawn{display:flex}.admin-castle-spawn .btn{flex:1}.admin-castles-empty{font-size:var(--text-xs);font-style:italic;color:var(--color-text-dim);padding:var(--space-1) 0}.admin-castle-list{display:flex;flex-direction:column;gap:var(--space-1);max-height:180px;overflow-y:auto}.admin-castle-row{display:flex;align-items:center;gap:var(--space-2);padding:4px 6px;background:#8b5cf612;border:1px solid rgba(139,92,246,.28);border-radius:var(--radius-sm)}.admin-castle-text{flex:1;display:flex;align-items:center;gap:6px;font-size:var(--text-xs)}.admin-castle-coord{font-family:var(--font-mono, monospace)}.modal-backdrop{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-5);background:#07091aa6;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:0;transition:opacity var(--dur-base) var(--ease-out)}.modal-backdrop.modal-backdrop--in{opacity:1}.modal-backdrop.modal-backdrop--leaving{opacity:0}.modal{width:100%;max-width:420px;padding:var(--space-4) var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);transform:translateY(8px) scale(.98);transition:transform var(--dur-base) var(--ease-out)}.modal-backdrop--in .modal{transform:translateY(0) scale(1)}.modal-title{margin:0;font-family:var(--font-display);font-size:var(--text-lg);font-weight:600;color:#f8fafc;letter-spacing:var(--tracking-tight)}.modal-addr{font-size:var(--text-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}.modal-copy{margin:0;font-size:var(--text-sm);line-height:var(--line-normal);color:var(--color-text-muted)}.modal-textarea{width:100%;resize:vertical;min-height:72px;padding:var(--space-2);background:#07091a8c;border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text);line-height:var(--line-normal);transition:border-color var(--dur-fast) var(--ease-out)}.modal-textarea::placeholder{color:var(--color-text-dim)}.modal-textarea:focus{outline:none;border-color:var(--color-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-2)}#landing{position:fixed;inset:0;z-index:var(--z-overlay);display:flex;align-items:center;justify-content:center;padding:var(--space-5);overflow-y:auto;-webkit-overflow-scrolling:touch;background:radial-gradient(ellipse at center,#0b0d17a6,#0b0d17e0 60%,#07091af2);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:opacity var(--dur-slow) var(--ease-out),visibility var(--dur-slow) var(--ease-out)}#landing.landing--hiding{opacity:0;visibility:hidden;pointer-events:none}.landing-card{width:100%;max-width:480px;background:linear-gradient(180deg,#1e253df0,#141a30f5);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl);padding:var(--space-6) var(--space-6);box-shadow:var(--shadow-xl);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);display:flex;flex-direction:column;align-items:center;gap:var(--space-4);text-align:center;animation:landing-enter var(--dur-slow) var(--ease-out)}@keyframes landing-enter{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.landing-logo{width:56px;height:56px;border-radius:var(--radius-xl);display:grid;place-items:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-gold) 100%);color:var(--color-text-inverse);font-family:var(--font-display);font-weight:700;font-size:var(--text-xl);letter-spacing:-.02em;box-shadow:var(--shadow-glow-primary)}.landing-title{margin:0;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:700;letter-spacing:var(--tracking-tight);line-height:1.1;background:linear-gradient(180deg,#f8fafc,#cbd5e1);-webkit-background-clip:text;background-clip:text;color:transparent}.landing-tag{margin:0;font-size:var(--text-md);color:var(--color-text-muted);max-width:360px;line-height:var(--line-normal)}.landing-features{display:flex;gap:var(--space-3);margin:var(--space-2) 0;width:100%;justify-content:center;flex-wrap:wrap}.landing-feature{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-4);min-width:88px;background:#ffffff0a;border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.landing-feature:hover{background:#ffffff12;border-color:var(--color-border);transform:translateY(-1px)}.landing-feature-icon{font-size:22px;line-height:1}.landing-feature-label{font-size:var(--text-sm);color:var(--color-text);font-weight:500}#landing-connect{width:100%;max-width:320px;margin-top:var(--space-2);position:relative;animation:landing-cta-pulse 2.4s ease-in-out infinite}@keyframes landing-cta-pulse{0%,to{box-shadow:0 0 #fbbf2400}50%{box-shadow:var(--shadow-glow-gold)}}#landing-connect.btn--loading{animation:none;box-shadow:var(--shadow-glow-gold)}#landing-connect.btn--error{animation:none;background:var(--color-danger);color:#fff}#landing-connect.btn--error:hover{filter:brightness(1.08)}.landing-status{min-height:20px;font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--dur-base) var(--ease-out);text-align:center;padding:0 var(--space-2);line-height:var(--line-normal)}.landing-status.landing-status--info{color:var(--color-primary)}.landing-status.landing-status--success{color:var(--color-success)}.landing-status.landing-status--error{color:var(--color-danger)}.landing-browse{background:transparent;border:0;color:var(--color-text-muted);font:inherit;font-size:var(--text-sm);padding:var(--space-2) var(--space-3);margin-top:calc(-1 * var(--space-1));cursor:pointer;border-radius:var(--radius-md);transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.landing-browse:hover{color:var(--color-text);background:#ffffff0d}.landing-browse:focus-visible{outline:2px solid var(--color-primary-ring);outline-offset:2px}#guest-connect{position:fixed;top:var(--space-3);right:var(--space-3);z-index:var(--z-hud-raised);box-shadow:var(--shadow-glow-gold);animation:landing-cta-pulse 2.4s ease-in-out infinite}#guest-connect.hidden{display:none}.landing-trust{margin:0;font-size:var(--text-xs);color:var(--color-text-dim);max-width:340px;line-height:var(--line-normal)}@media (max-width: 520px){.landing-card{padding:var(--space-5) var(--space-4);gap:var(--space-3)}.landing-title{font-size:var(--text-xl)}.landing-feature{min-width:72px;padding:var(--space-2) var(--space-3)}}@media (max-height: 520px){#landing{padding:max(var(--space-3),env(safe-area-inset-top)) var(--space-3) max(var(--space-3),env(safe-area-inset-bottom))}.landing-card{padding:var(--space-4) var(--space-5);gap:var(--space-3);max-width:460px;animation:none}.landing-logo{width:44px;height:44px;font-size:var(--text-lg)}.landing-title{font-size:var(--text-lg);margin:0}.landing-tag{display:none}.landing-features{margin:0;gap:var(--space-2)}.landing-feature{min-width:68px;padding:var(--space-2) var(--space-3);gap:2px}.landing-feature-icon{font-size:18px}.landing-feature-label{font-size:var(--text-xs)}#landing-connect{margin-top:0}.landing-status:empty{min-height:0;padding:0}.landing-browse{margin-top:0;padding:var(--space-1) var(--space-3)}.landing-trust{display:none}}#wallet-pill{position:fixed;top:var(--space-3);right:var(--space-3);z-index:var(--z-hud-raised)}.wallet-pill-button{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-1);background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-pill);box-shadow:var(--shadow-md);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);cursor:pointer;font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-text);transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.wallet-pill-button:hover{background:var(--color-surface-3);border-color:var(--color-border);transform:translateY(-1px)}.wallet-pill-button:focus-visible{outline:2px solid var(--color-primary-ring);outline-offset:2px}.wallet-pill-button[aria-expanded=true]{background:var(--color-surface-3);border-color:var(--color-border)}.wallet-pill-blockie{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,hsl(var(--blockie-hue, 200),80%,50%),hsl(var(--blockie-hue-2, 220),70%,35%));flex-shrink:0;box-shadow:inset 0 0 0 1px #ffffff1f}.wallet-pill-addr{font-family:var(--font-mono);font-size:var(--text-sm);font-weight:500;letter-spacing:.02em;line-height:1}.wallet-pill-caret{width:12px;height:12px;opacity:.6;transition:transform var(--dur-fast) var(--ease-out),opacity var(--dur-fast) var(--ease-out);margin-left:2px}.wallet-pill-button[aria-expanded=true] .wallet-pill-caret{transform:rotate(180deg);opacity:1}.wallet-pill-menu{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:220px;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);padding:var(--space-1);display:flex;flex-direction:column;gap:2px;transform-origin:top right;animation:wallet-menu-enter var(--dur-fast) var(--ease-out)}@keyframes wallet-menu-enter{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.wallet-pill-menu-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border:0;background:transparent;color:var(--color-text);font-family:var(--font-body);font-size:var(--text-sm);font-weight:500;text-align:left;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.wallet-pill-menu-item:hover:not(:disabled){background:#ffffff0f}.wallet-pill-menu-item:focus-visible{outline:2px solid var(--color-primary-ring);outline-offset:-2px}.wallet-pill-menu-item:disabled{opacity:.5;cursor:default}.wallet-pill-menu-item.wallet-pill-menu-item--danger{color:var(--color-danger)}.wallet-pill-menu-item.wallet-pill-menu-item--danger:hover:not(:disabled){background:var(--color-danger-soft)}.wallet-pill-menu-hint{padding:var(--space-1) var(--space-3);font-size:var(--text-xs);color:var(--color-text-dim);font-family:var(--font-mono);word-break:break-all;line-height:var(--line-normal)}.wallet-pill-menu-divider{height:1px;background:var(--color-border-subtle);margin:var(--space-1) 0}.wallet-pill-menu-item .spinner{width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:btn-spin .6s linear infinite;flex-shrink:0;margin-left:auto}@media (max-width: 520px){.wallet-pill-addr{font-size:var(--text-xs)}.wallet-pill-menu{min-width:200px}}#toasts{position:fixed;bottom:var(--space-3);right:var(--space-3);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none;width:min(360px,calc(100vw - var(--space-6)))}.toast{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-surface-2);border:1px solid var(--color-border);border-left-width:3px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);color:var(--color-text);font-size:var(--text-sm);line-height:var(--line-normal);pointer-events:auto;opacity:0;transform:translate(24px);transition:opacity var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}.toast.toast--in{opacity:1;transform:translate(0)}.toast.toast--leaving{opacity:0;transform:translate(24px)}.toast--info{border-left-color:var(--color-info)}.toast--success{border-left-color:var(--color-success)}.toast--warn{border-left-color:var(--color-warn)}.toast--error{border-left-color:var(--color-danger)}.toast--info .toast-icon{color:var(--color-info)}.toast--success .toast-icon{color:var(--color-success)}.toast--warn .toast-icon{color:var(--color-warn)}.toast--error .toast-icon{color:var(--color-danger)}.toast-icon{flex-shrink:0;width:18px;height:18px;margin-top:1px}.toast-icon svg{width:100%;height:100%;display:block}.toast-msg{flex:1;min-width:0;overflow-wrap:anywhere}.toast-close{flex-shrink:0;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:var(--radius-sm);color:var(--color-text-dim);cursor:pointer;padding:0;margin:-2px -4px 0 0;transition:color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out)}.toast-close:hover{color:var(--color-text);background:#ffffff14}.toast-close:focus-visible{outline:2px solid var(--color-primary-ring);outline-offset:1px}.toast-close svg{width:12px;height:12px;display:block}@media (max-width: 520px){#toasts{left:var(--space-3);right:var(--space-3);width:auto}}.reps-badge{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:radial-gradient(120% 180% at 0% 50%,#fbbf2438,#fbbf2400 55%),linear-gradient(135deg,#1e1708f5,#111827f5);border:1px solid rgba(251,191,36,.55);border-radius:var(--radius-pill);box-shadow:0 4px 14px #00000061,0 0 0 1px #fbbf2414,inset 0 1px #ffe6b438,inset 0 -6px 12px #fbbf2414;backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out)}.reps-badge:hover{transform:translateY(-1px);box-shadow:0 6px 18px #00000073,0 0 0 1px #fbbf242e,inset 0 1px #ffe6b44d,inset 0 -6px 14px #fbbf241f,var(--shadow-glow-gold)}.reps-badge.hidden{display:none}.reps-badge-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:#fde68a;filter:drop-shadow(0 1px 1px rgba(0,0,0,.55))}.reps-badge-icon svg{width:100%;height:100%}.reps-badge-val{font-weight:700;font-variant-numeric:tabular-nums;font-size:var(--text-lg);line-height:1;color:#fde68a;min-width:1ch;text-shadow:0 0 12px rgba(251,191,36,.3)}.reps-badge-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fde68ab3}.reps-badge-opt-in{display:none;align-items:center;justify-content:center;width:22px;height:22px;margin-left:var(--space-1);padding:0;background:linear-gradient(135deg,#fbbf24eb,#d97706eb);border:1px solid rgba(253,224,71,.8);border-radius:50%;color:#1a1003;cursor:pointer;box-shadow:0 2px 6px #00000059,inset 0 1px #ffffff59;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out),filter var(--dur-fast) var(--ease-out)}.reps-badge-opt-in:hover{transform:scale(1.08);filter:brightness(1.08);box-shadow:0 4px 10px #00000073,inset 0 1px #ffffff73,0 0 12px #fbbf248c}.reps-badge-opt-in:focus-visible{outline:2px solid var(--color-gold-ring);outline-offset:2px}.reps-badge-opt-in:active{transform:scale(.96)}.reps-badge--opt-in{animation:reps-badge-attract 2.8s ease-in-out infinite}.reps-badge--opt-in .reps-badge-val{color:var(--color-text-dim);text-shadow:none;font-size:var(--text-md)}.reps-badge--opt-in .reps-badge-opt-in{display:inline-flex}@keyframes reps-badge-attract{0%,to{border-color:#fbbf248c;box-shadow:0 4px 14px #00000061,0 0 0 1px #fbbf2414,inset 0 1px #ffe6b438,inset 0 -6px 12px #fbbf2414}50%{border-color:#fde047d9;box-shadow:0 4px 14px #00000061,0 0 0 1px #fbbf242e,inset 0 1px #ffe6b447,inset 0 -6px 14px #fbbf2429,0 0 18px #fbbf2459}}@keyframes reps-badge-flash{0%{box-shadow:0 0 #fbbf2499,0 4px 14px #00000061,inset 0 1px #ffe6b438,inset 0 -6px 12px #fbbf2414;transform:scale(1)}40%{box-shadow:0 0 0 10px #fbbf2400,0 4px 14px #00000061,inset 0 1px #ffe6b44d,inset 0 -6px 14px #fbbf242e;transform:scale(1.04)}to{box-shadow:0 0 #fbbf2400,0 4px 14px #00000061,inset 0 1px #ffe6b438,inset 0 -6px 12px #fbbf2414;transform:scale(1)}}.reps-badge--flash{animation:reps-badge-flash .6s var(--ease-out)}@media (max-width: 640px){.reps-badge-label{display:none}.reps-badge-val{font-size:var(--text-md)}}.castle-reward-modal{max-width:360px;align-items:center;text-align:center;gap:var(--space-3)}.castle-reward-modal .modal-title{font-size:var(--text-xl)}.castle-reward-hero{position:relative;width:100%;padding:var(--space-4) var(--space-3) var(--space-3);display:flex;flex-direction:column;align-items:center;gap:var(--space-1);background:radial-gradient(circle at 50% 35%,#fbbf2440,#fbbf2400 65%);border-radius:var(--radius-lg);overflow:hidden}.castle-reward-hero:before{content:"";position:absolute;top:50%;left:50%;width:140px;height:140px;margin-top:-70px;margin-left:-70px;border-radius:50%;background:radial-gradient(circle,#fbbf248c,#fbbf2400 70%);animation:castleRewardPulse 1.6s var(--ease-out) both;pointer-events:none}@keyframes castleRewardPulse{0%{transform:scale(.4);opacity:0}40%{opacity:.9}to{transform:scale(1.4);opacity:0}}.castle-reward-amount{position:relative;display:flex;align-items:baseline;gap:var(--space-2);font-family:var(--font-display);font-size:48px;font-weight:700;color:#fde68a;letter-spacing:var(--tracking-tight);text-shadow:0 2px 16px rgba(251,191,36,.5);line-height:1}.castle-reward-amount .reps-unit{font-size:var(--text-md);font-weight:600;color:#fbbf24;letter-spacing:var(--tracking-wide)}.castle-reward-subline{position:relative;font-size:var(--text-sm);color:var(--color-text-muted)}.castle-reward-lucky{position:relative;display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:999px;background:linear-gradient(135deg,#a855f740,#ec489933);border:1px solid rgba(236,72,153,.55);color:#fbcfe8;font-size:var(--text-xs);font-weight:600;letter-spacing:var(--tracking-wide);text-transform:uppercase}.castle-reward-explorer{font-size:var(--text-xs);color:var(--color-text-muted);text-decoration:underline;text-decoration-color:#fbbf2480;text-underline-offset:3px;transition:color var(--dur-fast) var(--ease-out)}.castle-reward-explorer:hover{color:#fde68a}.castle-reward-actions{width:100%;display:flex;justify-content:center;margin-top:var(--space-2)}.castle-reward-queue{font-size:var(--text-xs);color:var(--color-text-dim);letter-spacing:var(--tracking-wide)}#game,#game canvas{touch-action:none;-webkit-user-select:none;user-select:none}html,body,#game{height:100vh;height:100dvh}#top-hud{top:max(var(--space-3),env(safe-area-inset-top))}#wallet-pill,#guest-connect{top:max(var(--space-3),env(safe-area-inset-top));right:max(var(--space-3),env(safe-area-inset-right))}#hud,#army-hud{right:max(var(--space-3),env(safe-area-inset-right))}#army-list{left:max(var(--space-3),env(safe-area-inset-left))}#admin-panel{right:max(var(--space-3),env(safe-area-inset-right))}#toasts{bottom:max(var(--space-3),env(safe-area-inset-bottom));right:max(var(--space-3),env(safe-area-inset-right))}#city-hall-banner,#hud-actions-section,#army-actions-section{bottom:max(var(--space-4),env(safe-area-inset-bottom))}@media (max-width: 768px){#hud,#army-hud{width:min(260px,calc(100vw - var(--space-6)));top:calc(56px + env(safe-area-inset-top))}#army-list{width:min(200px,55vw);top:calc(56px + env(safe-area-inset-top));max-height:calc(100dvh - 72px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}#resources{padding:var(--space-1) var(--space-2);gap:var(--space-2);font-size:var(--text-sm)}.res-switcher-label{max-width:120px}#resources .res{padding:2px 6px}.res-icon{width:14px;height:14px}#hud-actions-section .hud-action,#army-actions-section .hud-action{width:72px;height:72px;min-width:72px;padding:6px}#hud-actions-section .hud-action-icon,#army-actions-section .hud-action-icon{width:22px;height:22px}#hud-actions-section .hud-action-title,#army-actions-section .hud-action-title{font-size:10px;line-height:1.1}#hud-actions-section .cost-pill{padding:1px 3px;font-size:9px}#hud-actions-section .cost-pill svg{width:10px;height:10px}.hud-actions-title{font-size:var(--text-base)}.btn,.wallet-pill-button,.hud-close,.res-switcher-btn,.wallet-pill-menu-item,.res-switcher-item{min-height:40px}}@media (max-width: 520px){#admin-panel{display:none!important}#hud,#army-hud{width:min(240px,calc(100vw - var(--space-5)))}#army-list{width:min(180px,50vw)}.wallet-pill-button{padding:6px var(--space-2) 6px var(--space-1)}}@media (max-height: 500px){#hud,#army-hud,#army-list{top:calc(52px + env(safe-area-inset-top));max-height:calc(100dvh - 64px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow-y:auto}#city-hall-banner{padding:var(--space-2) var(--space-3);gap:var(--space-2)}#city-hall-banner.banner--mint .banner-visual,#city-hall-banner.banner--place .banner-visual,#city-hall-banner.banner--minting .banner-visual{width:56px;height:56px}}#fullscreen-toggle{position:fixed;top:max(var(--space-3),env(safe-area-inset-top));left:max(var(--space-3),env(safe-area-inset-left));z-index:var(--z-hud-raised);display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-pill);box-shadow:var(--shadow-md);backdrop-filter:var(--blur-panel);-webkit-backdrop-filter:var(--blur-panel);cursor:pointer;color:var(--color-text);transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}#fullscreen-toggle:hover{background:var(--color-surface-3);border-color:var(--color-border);transform:translateY(-1px)}#fullscreen-toggle:focus-visible{outline:2px solid var(--color-primary-ring);outline-offset:2px}#fullscreen-toggle.hidden{display:none}.fullscreen-icon{display:block}.fullscreen-icon--exit,#fullscreen-toggle[aria-pressed=true] .fullscreen-icon--enter{display:none}#fullscreen-toggle[aria-pressed=true] .fullscreen-icon--exit{display:block}.ios-install-steps{margin:0;padding:0 0 0 var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text);line-height:var(--line-normal)}.ios-install-steps li strong{font-weight:600;color:#f8fafc}.ios-install-steps li span{color:var(--color-text-muted);font-size:var(--text-xs)}#orientation-hint{display:none}@media (max-width: 900px) and (orientation: portrait){#landing.landing--hiding~#orientation-hint{display:flex;position:fixed;inset:0;z-index:200;align-items:center;justify-content:center;padding:var(--space-5);background:linear-gradient(180deg,#07091af5,#0b0d17fa);color:var(--color-text);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}}.orientation-hint-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);text-align:center;padding:var(--space-6) var(--space-5);max-width:340px;background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl)}.orientation-hint-icon{color:var(--color-primary);animation:orient-rotate 2.4s ease-in-out infinite}@keyframes orient-rotate{0%,to{transform:rotate(0)}35%{transform:rotate(-90deg)}65%{transform:rotate(-90deg)}}@media (prefers-reduced-motion: reduce){.orientation-hint-icon{animation:none;transform:rotate(-90deg)}}.orientation-hint-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;letter-spacing:var(--tracking-tight);color:#f8fafc}.orientation-hint-copy{font-size:var(--text-sm);color:var(--color-text-muted);line-height:var(--line-normal)}
