:root{color-scheme:dark;--bg-void:#060a10;--bg-outer:#091018;--bg-inner:#0f1620;--surface:rgba(14,20,30,0.88);--surface-strong:rgba(20,28,40,0.94);--surface-soft:rgba(255,255,255,0.035);--surface-glass:rgba(12,18,28,0.72);--line:rgba(255,255,255,0.08);--line-strong:rgba(214,179,106,0.22);--line-glow:rgba(214,179,106,0.45);--text-main:#f0eadc;--text-muted:#8e99a9;--text-dim:#5a6476;--gold:#d6b36a;--gold-bright:#f4d89a;--gold-soft:rgba(214,179,106,0.15);--gold-glow:rgba(214,179,106,0.35);--teal:#68aba4;--teal-bright:#9cd4ce;--teal-soft:rgba(104,171,164,0.14);--ruby:#c86970;--ruby-soft:rgba(200,105,112,0.14);--violet:#9b7ec8;--violet-soft:rgba(155,126,200,0.14);--shadow-float:0 8px 32px rgba(0,0,0,0.5),0 2px 8px rgba(0,0,0,0.3);--shadow-panel:0 4px 20px rgba(0,0,0,0.4);--shadow-glow-gold:0 0 20px rgba(214,179,106,0.15);--shadow-glow-teal:0 0 20px rgba(104,171,164,0.12);--r-xs:6px;--r-sm:10px;--r-md:14px;--r-lg:18px;--r-xl:24px;--r-full:999px;--rail-width:64px;--hud-height:52px;--topbar-height:48px;--font-ui:"Trebuchet MS","Lucida Sans Unicode",sans-serif;--font-display:Garamond,Baskerville,"Times New Roman",serif;--ease-out:cubic-bezier(0.16,1,0.3,1);--dur:180ms}*{box-sizing:border-box}body,html{margin:0;min-height:100%}body{background:var(--bg-void);color:var(--text-main);font-family:var(--font-ui);font-size:.9rem;letter-spacing:.01em;overflow-x:hidden}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.shell{display:grid;grid-template-columns:var(--rail-width) minmax(0,1fr);grid-template-rows:var(--topbar-height) minmax(0,1fr);min-height:100vh;background:radial-gradient(ellipse at 20% 0,rgba(214,179,106,.06) 0,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(104,171,164,.05) 0,transparent 50%),var(--bg-void)}.shell-no-rail{grid-template-columns:minmax(0,1fr)}.shell-no-rail .main-viewport-full,.shell-no-rail .topbar-full{grid-column:1}.rail{grid-row:1/-1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;background:linear-gradient(180deg,rgba(10,16,24,.98),rgba(6,10,16,.99));border-right:1px solid var(--line);z-index:30}.rail-brand{display:grid;place-items:center;width:44px;height:44px;margin-bottom:8px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--gold-soft),rgba(104,171,164,.08));border:1px solid var(--line-strong);color:var(--gold);font-family:var(--font-display);font-size:1.1rem;font-weight:700;cursor:default;transition:box-shadow var(--dur) var(--ease-out)}.rail-brand:hover{box-shadow:var(--shadow-glow-gold)}.rail-nav{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1 1;width:100%;padding:0 6px}.rail-link{position:relative;display:grid;place-items:center;width:48px;height:44px;border-radius:var(--r-sm);color:var(--text-dim);transition:all var(--dur) var(--ease-out);cursor:pointer;border:1px solid transparent}.rail-link:hover{color:var(--text-main);background:rgba(255,255,255,.06);border-color:var(--line)}.rail-link.active{color:var(--gold);background:var(--gold-soft);border-color:var(--line-strong);box-shadow:var(--shadow-glow-gold)}.rail-link.active:before{content:"";position:absolute;left:-7px;top:50%;transform:translateY(-50%);width:3px;height:24px;border-radius:0 3px 3px 0;background:var(--gold)}.rail-link.disabled{opacity:.3;pointer-events:none}.rail-tooltip{display:none;position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);padding:6px 12px;border-radius:var(--r-xs);background:rgba(10,14,22,.96);border:1px solid var(--line);color:var(--text-main);font-size:.78rem;white-space:nowrap;pointer-events:none;z-index:100;box-shadow:var(--shadow-float)}.rail-link:hover .rail-tooltip{display:block}.rail-sep{width:32px;height:1px;margin:6px 0;background:var(--line)}.rail-footer{display:flex;flex-direction:column;align-items:center;gap:4px;padding:0 6px;margin-top:auto}.rail-avatar{display:grid;place-items:center;width:38px;height:38px;border-radius:var(--r-sm);background:linear-gradient(135deg,var(--gold-soft),var(--teal-soft));border:1px solid var(--line-strong);color:var(--gold-bright);font-family:var(--font-display);font-size:.85rem;font-weight:700}.rail-level{font-size:.62rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase}.topbar{grid-column:2;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 1.25rem;background:linear-gradient(180deg,rgba(8,13,20,.96),rgba(8,13,20,.88));border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:20}.topbar-commander,.topbar-section{display:flex;align-items:center;gap:.5rem}.topbar-avatar{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--gold-soft);border:1px solid var(--gold);color:var(--gold);font-size:.65rem;font-weight:700;font-family:var(--font-display);flex-shrink:0}.topbar-title{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase}.topbar-title strong{color:var(--text-main);font-family:var(--font-display);font-size:.95rem;letter-spacing:.02em;text-transform:none}.topbar-logout{display:grid;place-items:center;width:32px;height:32px;border-radius:var(--r-sm);background:transparent;border:1px solid transparent;color:var(--text-dim);cursor:pointer;transition:all var(--dur) var(--ease-out)}.topbar-logout:hover{color:var(--text-main);background:rgba(255,255,255,.06);border-color:var(--line)}.hud-resources{gap:3px}.hud-res,.hud-resources{display:flex;align-items:center}.hud-res{gap:6px;padding:6px 12px;border-radius:var(--r-full);background:rgba(255,255,255,.04);border:1px solid transparent;font-size:.82rem;color:var(--text-muted);transition:all var(--dur) var(--ease-out);cursor:default;position:relative}.hud-res:hover{background:rgba(255,255,255,.08);border-color:var(--line)}.hud-res-icon{display:flex;align-items:center;color:var(--gold)}.hud-res-icon.wood{color:#8bc47a}.hud-res-icon.stone{color:#a0a8b8}.hud-res-icon.mana{color:var(--violet)}.hud-res-value{color:var(--text-main);font-weight:600;font-size:.85rem}.hud-res-rate{font-size:.7rem;color:var(--text-dim)}.hud-res-bar{position:absolute;bottom:0;left:10%;width:80%;height:2px;border-radius:var(--r-full);background:rgba(255,255,255,.06);overflow:hidden}.hud-res-bar span{display:block;height:100%;border-radius:inherit;background:var(--gold);transition:width .4s var(--ease-out)}.hud-res-bar.wood span{background:#8bc47a}.hud-res-bar.stone span{background:#a0a8b8}.hud-res-bar.mana span{background:var(--violet)}.topbar-meta{display:flex;align-items:center;gap:.75rem}.topbar-meta span{color:var(--text-dim);font-size:.76rem}.topbar-actions{display:flex;align-items:center;gap:.5rem}.main-viewport{grid-column:2;position:relative;overflow:hidden;padding:0}.canvas-overlay{pointer-events:none}.canvas-overlay>*{pointer-events:auto}.canvas-overlay>.page-stack{position:absolute;top:46px;left:0;right:0;bottom:0;overflow-y:auto;padding:.75rem 1.25rem 1.25rem}.canvas-overlay>.page-stack.map-page{padding:0;overflow:hidden}.scene-panel{pointer-events:auto}.canvas-overlay>.hud-layout{position:absolute;inset:0;pointer-events:none;overflow:hidden}.hud-layout>*{pointer-events:auto}.hud-sidebar{position:absolute;top:3.5rem;right:.75rem;bottom:.75rem;width:360px;display:flex;flex-direction:column;gap:.75rem;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.12) transparent}.hud-sidebar .panel{flex-shrink:0}.hud-top-bar{position:absolute;top:3.5rem;left:.75rem;right:calc(360px + 1.5rem);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.hud-top-bar .stat-chip{padding:.35rem .75rem;font-size:.8rem;white-space:nowrap}.hud-action-row{position:absolute;bottom:.75rem;left:.75rem;display:flex;gap:.5rem}@media (max-width:900px){.hud-sidebar{width:100%;right:0;left:0;top:auto;bottom:0;height:55%;border-radius:var(--r-lg) var(--r-lg) 0 0;padding:0 .5rem}.hud-top-bar{right:.75rem;top:3.5rem}.hud-action-row{bottom:calc(55% + .5rem)}}@media (max-width:480px){.hud-sidebar{height:65%}.hud-action-row{bottom:calc(65% + .5rem)}}.content-inner{max-width:1440px;margin:0 auto}.page-stack{display:flex;flex-direction:column;gap:1rem}.panel{border-radius:var(--r-lg);border:1px solid var(--line);background:linear-gradient(180deg,rgba(14,20,30,.55),rgba(10,16,24,.45));box-shadow:var(--shadow-panel);padding:1rem;-webkit-backdrop-filter:blur(16px) saturate(1.2);backdrop-filter:blur(16px) saturate(1.2)}.panel-header{justify-content:space-between;gap:.75rem;margin-bottom:.85rem}.panel-header,.panel-title{display:flex;align-items:center}.panel-title{gap:.5rem}.panel-title-icon{display:grid;place-items:center;width:32px;height:32px;border-radius:var(--r-sm);background:var(--gold-soft);color:var(--gold);flex-shrink:0}.panel-title-icon.teal{background:var(--teal-soft);color:var(--teal)}.panel-title-icon.ruby{background:var(--ruby-soft);color:var(--ruby)}.panel-title-icon.violet{background:var(--violet-soft);color:var(--violet)}.panel-title h2,.panel-title h3,.panel-title h4{margin:0;font-family:var(--font-display);font-size:1.05rem;letter-spacing:.02em}.panel-badges{display:flex;align-items:center;gap:6px}.panel-accent{border-color:var(--line-strong);background:linear-gradient(180deg,rgba(214,179,106,.06),var(--surface)),linear-gradient(180deg,var(--surface-strong),var(--surface))}.panel-accent:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--line-glow),transparent 60%)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-full);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;line-height:1}.badge-gold{background:var(--gold-soft);color:var(--gold-bright);border:1px solid rgba(214,179,106,.25)}.badge-teal{background:var(--teal-soft);color:var(--teal-bright);border:1px solid rgba(104,171,164,.2)}.badge-ruby{background:var(--ruby-soft);color:#ffc8cc;border:1px solid rgba(200,105,112,.2)}.badge-dim{background:rgba(255,255,255,.04);color:var(--text-muted);border:1px solid var(--line)}.badge-violet{background:var(--violet-soft);color:#c8b4e8;border:1px solid rgba(155,126,200,.2)}.pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--r-full);font-size:.76rem;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text-muted)}.stat-tile{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.03);transition:border-color var(--dur) var(--ease-out)}.stat-tile:hover{border-color:rgba(255,255,255,.12)}.stat-tile-label{font-size:.68rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.stat-tile-value{font-family:var(--font-display);font-size:1.15rem;color:var(--text-main)}.stat-tile-value.gold{color:var(--gold)}.stat-tile-value.teal{color:var(--teal)}.stat-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:.85rem}.stat-row:last-child{border-bottom:0}.stat-row-key{color:var(--text-muted)}.stat-row-val{color:var(--text-main);font-weight:600}.icon-tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px 10px;border-radius:var(--r-md);border:1px solid var(--line);background:rgba(255,255,255,.025);cursor:pointer;transition:all var(--dur) var(--ease-out);text-align:center;min-width:0}.icon-tile:hover{transform:translateY(-2px);border-color:var(--line-strong);background:rgba(255,255,255,.05);box-shadow:var(--shadow-glow-gold)}.icon-tile.active{border-color:var(--line-strong);background:linear-gradient(180deg,var(--gold-soft),rgba(255,255,255,.03))}.icon-tile.locked{opacity:.4;pointer-events:none}.icon-tile.upgrading{border-color:rgba(214,179,106,.3)}.icon-tile-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(214,179,106,.15),rgba(255,255,255,.04));color:var(--gold-bright);transition:all var(--dur) var(--ease-out)}.icon-tile:hover .icon-tile-icon{box-shadow:0 0 12px rgba(214,179,106,.2)}.icon-tile-icon.economy,.icon-tile-icon.resource{background:linear-gradient(180deg,var(--teal-soft),rgba(255,255,255,.04));color:var(--teal-bright)}.icon-tile-icon.affinity,.icon-tile-icon.hero,.icon-tile-icon.research{background:linear-gradient(180deg,var(--violet-soft),rgba(255,255,255,.04));color:#c8b4e8}.icon-tile-icon.defense,.icon-tile-icon.gear{background:linear-gradient(180deg,var(--ruby-soft),rgba(255,255,255,.04));color:#ffc8cc}.icon-tile-name{font-size:.72rem;color:var(--text-muted);line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-tile-level{font-size:.65rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.icon-tile-indicator{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold-glow)}.icon-tile-indicator.upgrading{background:var(--teal);box-shadow:0 0 8px rgba(104,171,164,.4);animation:pulse-dot 2s ease-in-out infinite}.icon-tile-indicator.locked{background:var(--ruby);box-shadow:0 0 8px rgba(200,105,112,.3)}.icon-tile-progress{width:100%;height:3px;border-radius:var(--r-full);background:rgba(255,255,255,.06);overflow:hidden}.icon-tile-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--teal),var(--teal-bright))}.icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));grid-gap:8px;gap:8px}.icon-grid.wide{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.section-collapse{border-radius:var(--r-lg);border:1px solid var(--line);background:var(--surface);overflow:hidden}.section-collapse-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:10px 14px;cursor:pointer;list-style:none;transition:background var(--dur) var(--ease-out)}.section-collapse-header:hover{background:rgba(255,255,255,.03)}.section-collapse-header::-webkit-details-marker{display:none}.section-collapse-title{display:flex;align-items:center;gap:8px}.section-collapse-title h3{margin:0;font-family:var(--font-display);font-size:.95rem}.section-collapse-meta{display:flex;align-items:center;gap:6px}.section-collapse-toggle{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.06);color:var(--gold);font-size:.9rem;transition:transform var(--dur) var(--ease-out)}details[open]>.section-collapse-header .section-collapse-toggle{transform:rotate(180deg)}.section-collapse-body{padding:0 14px 14px}.progress-bar{height:6px;border-radius:var(--r-full);background:rgba(255,255,255,.06);overflow:hidden}.progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--gold),var(--gold-bright));transition:width .4s var(--ease-out)}.progress-bar.teal span{background:linear-gradient(90deg,var(--teal),var(--teal-bright))}.progress-bar.thin{height:4px}.progress-bar.thick{height:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:7px 16px;border-radius:var(--r-sm);border:1px solid transparent;font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--dur) var(--ease-out)}.btn:disabled{cursor:not-allowed;opacity:.45;transform:none!important}.btn-primary{background:linear-gradient(135deg,var(--gold),#b8823a);color:#1a1208;border-color:rgba(214,179,106,.4)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-glow-gold)}.btn-secondary{background:rgba(104,171,164,.12);border-color:rgba(104,171,164,.2);color:var(--teal-bright)}.btn-secondary:hover:not(:disabled){background:rgba(104,171,164,.18);transform:translateY(-1px)}.btn-ghost{background:transparent;border-color:var(--line);color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.06);color:var(--text-main);border-color:rgba(255,255,255,.15)}.btn-danger{background:rgba(200,105,112,.12);border-color:rgba(200,105,112,.2);color:#ffc8cc}.btn-icon{padding:7px;min-height:auto}.btn-sm{min-height:30px;padding:4px 12px;font-size:.76rem}.primary-button{composes:btn btn-primary}.secondary-button{composes:btn btn-secondary}.ghost-button{composes:btn btn-ghost}.button-link{text-decoration:none}.ghost-button,.primary-button,.secondary-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:7px 16px;border-radius:var(--r-sm);border:1px solid transparent;font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--dur) var(--ease-out)}.primary-button{background:linear-gradient(135deg,var(--gold),#b8823a);color:#1a1208;border-color:rgba(214,179,106,.4)}.primary-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-glow-gold)}.secondary-button{background:rgba(104,171,164,.12);border-color:rgba(104,171,164,.2);color:var(--teal-bright)}.secondary-button:hover:not(:disabled){background:rgba(104,171,164,.18);transform:translateY(-1px)}.ghost-button{background:transparent;border-color:var(--line);color:var(--text-muted)}.ghost-button:hover:not(:disabled){background:rgba(255,255,255,.06);color:var(--text-main)}.ghost-button:disabled,.primary-button:disabled,.secondary-button:disabled{cursor:not-allowed;opacity:.45}.compact-button{min-height:30px;padding:4px 10px;font-size:.76rem}.text-input{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:var(--r-sm);background:rgba(6,10,16,.6);color:var(--text-main);font-size:.88rem;transition:border-color var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out)}.text-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(214,179,106,.12)}.text-input::placeholder{color:var(--text-dim)}textarea.text-input{resize:vertical;min-height:100px}.field-label{gap:5px;font-size:.78rem;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase}.field-label,.form-stack{display:flex;flex-direction:column}.form-stack{gap:.7rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:.75rem;gap:.75rem}.form-grid.wide{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.field-span-full{grid-column:1/-1}.checkbox-field{flex-direction:row;align-items:center;gap:.6rem}.checkbox-field input{width:auto;accent-color:var(--gold)}.auth-shell{min-height:100vh;display:grid;place-items:center;padding:2rem;background:transparent}.auth-gate{width:min(440px,100%);gap:1.25rem}.auth-gate,.auth-gate-brand{display:flex;flex-direction:column;align-items:center}.auth-gate-brand{gap:.6rem}.auth-gate-sigil{display:grid;place-items:center;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 40% 35%,rgba(214,179,106,.2),transparent 60%),linear-gradient(135deg,rgba(10,16,26,.9),rgba(6,10,16,.95));border:1.5px solid rgba(214,179,106,.3);color:var(--gold-bright);font-family:var(--font-display);font-size:2rem;font-weight:700;box-shadow:0 0 20px rgba(214,179,106,.15),0 0 40px rgba(214,179,106,.06),inset 0 0 20px rgba(214,179,106,.05);animation:sigil-pulse 4s ease-in-out infinite;position:relative}.auth-gate-sigil:after{content:"";position:absolute;inset:-6px;border-radius:50%;border:1px solid rgba(214,179,106,.1);animation:sigil-ring-pulse 4s ease-in-out .5s infinite}@keyframes sigil-pulse{0%,to{box-shadow:0 0 20px rgba(214,179,106,.15),0 0 40px rgba(214,179,106,.06),inset 0 0 20px rgba(214,179,106,.05)}50%{box-shadow:0 0 30px rgba(214,179,106,.3),0 0 60px rgba(214,179,106,.12),inset 0 0 30px rgba(214,179,106,.08)}}@keyframes sigil-ring-pulse{0%,to{border-color:rgba(214,179,106,.1);transform:scale(1)}50%{border-color:rgba(214,179,106,.2);transform:scale(1.05)}}.auth-gate-title{margin:0;font-family:var(--font-display);font-size:2rem;letter-spacing:.06em;background:linear-gradient(135deg,var(--gold-bright) 20%,var(--gold) 50%,var(--teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:none}.auth-card{width:100%;border-radius:var(--r-lg);border:1px solid rgba(214,179,106,.12);background:linear-gradient(180deg,rgba(214,179,106,.04),transparent 30%),linear-gradient(180deg,rgba(10,16,26,.85),rgba(6,12,20,.92));padding:2rem 1.75rem;box-shadow:0 10px 40px rgba(0,0,0,.55),0 0 80px rgba(214,179,106,.03),inset 0 1px 0 rgba(214,179,106,.12);backdrop-filter:blur(28px) saturate(1.3);-webkit-backdrop-filter:blur(28px) saturate(1.3);position:relative;overflow:hidden}.auth-card:before{top:0;left:5%;right:5%;background:linear-gradient(90deg,transparent,rgba(214,179,106,.5),transparent)}.auth-card:after,.auth-card:before{content:"";position:absolute;height:1px}.auth-card:after{bottom:0;left:15%;right:15%;background:linear-gradient(90deg,transparent,rgba(104,171,164,.2),transparent)}.auth-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:.75rem;position:relative}.auth-card-header:after{content:"◆";position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);font-size:.45rem;color:rgba(214,179,106,.3);background:linear-gradient(90deg,transparent,rgba(214,179,106,.1) 20%,transparent 50%,rgba(214,179,106,.1) 80%,transparent);background-size:100% 1px;background-position:50%;background-repeat:no-repeat;padding:0 2rem;width:100%;text-align:center;line-height:0}.auth-card-header h2{margin:0;font-family:var(--font-display);font-size:1.15rem;letter-spacing:.03em;color:var(--gold-bright)}.auth-form{display:flex;flex-direction:column;gap:.9rem}.auth-form .field-label{gap:6px;font-size:.72rem;color:var(--gold);letter-spacing:.06em;opacity:.7}.auth-form .text-input{background:rgba(4,8,14,.65);border:1px solid rgba(214,179,106,.1);border-radius:var(--r-sm);padding:12px 14px;font-size:.9rem;letter-spacing:.01em;color:var(--text-main);transition:border-color .25s ease,box-shadow .25s ease,background .25s ease}.auth-form .text-input:focus{border-color:rgba(214,179,106,.35);background:rgba(4,8,14,.8);box-shadow:0 0 0 3px rgba(214,179,106,.06),0 0 20px rgba(214,179,106,.04),inset 0 0 12px rgba(214,179,106,.02);outline:none}.auth-form .text-input::placeholder{color:rgba(90,100,118,.7);font-style:italic;font-size:.85rem}.auth-form .primary-button{margin-top:.6rem;min-height:44px;font-size:.88rem;letter-spacing:.06em;font-weight:700;text-transform:uppercase;font-family:var(--font-display);border-radius:var(--r-sm);background:linear-gradient(135deg,var(--gold) 0,#c8923a 100%);border:1px solid rgba(214,179,106,.4);box-shadow:0 2px 12px rgba(214,179,106,.25),inset 0 1px 0 rgba(255,255,255,.12);position:relative}.auth-form .primary-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 24px rgba(214,179,106,.4),inset 0 1px 0 rgba(255,255,255,.15)}.auth-form .primary-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 6px rgba(214,179,106,.2)}.auth-footer{display:flex;flex-direction:column;align-items:center;gap:.5rem}.auth-footer-link{color:var(--text-muted);font-size:.82rem;font-family:var(--font-display);letter-spacing:.02em;transition:color var(--dur) var(--ease-out),text-shadow var(--dur) var(--ease-out);padding:4px 12px;border-bottom:1px solid rgba(214,179,106,.1)}.auth-footer-link:hover{color:var(--gold);text-shadow:0 0 12px rgba(214,179,106,.2);border-bottom-color:rgba(214,179,106,.3)}.inline-alert{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--r-sm);font-size:.85rem}.inline-alert p,.inline-alert strong{margin:0}.inline-alert.error{background:var(--ruby-soft);border:1px solid rgba(200,105,112,.25);color:#ffc8cc}.inline-alert.success{background:var(--teal-soft);border:1px solid rgba(104,171,164,.25);color:var(--teal-bright)}.inline-alert.neutral{background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--text-muted)}.flash{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--r-md);border:1px solid var(--line)}.flash p,.flash strong{margin:0}.flash.success{border-color:rgba(104,171,164,.3);background:var(--teal-soft)}.flash.error{border-color:rgba(200,105,112,.3);background:var(--ruby-soft)}.hero-stage{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem;border-radius:var(--r-xl);border:1px solid var(--line);overflow:hidden;background:linear-gradient(135deg,rgba(20,28,40,.96),rgba(10,16,24,.94)),radial-gradient(circle at top right,var(--gold-soft),transparent 40%)}.hero-stage:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--line-glow),transparent 50%)}.hero-stage-info{display:flex;flex-direction:column;gap:.5rem;flex:1 1}.hero-stage-info h2{margin:0;font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,1.9rem);line-height:1.1}.hero-stage-stats{display:flex;flex-wrap:wrap;gap:6px}.hero-stage-actions{display:flex;flex-wrap:wrap;gap:8px}.spotlight-card{position:relative;overflow:hidden;border-radius:var(--r-xl);border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(18,26,36,.9),rgba(10,14,22,.95));min-height:300px}.spotlight-card-media{position:absolute;inset:0}.spotlight-card-art{width:100%;height:100%;object-fit:cover;opacity:.85;animation:float-slow 18s ease-in-out infinite}.spotlight-card-wash{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,13,20,.15),rgba(8,13,20,.9)),linear-gradient(135deg,rgba(8,13,20,.2),rgba(8,13,20,.5))}.spotlight-card-content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px;padding:1.25rem;gap:.75rem}.spotlight-card-content h3{margin:0;font-family:var(--font-display);font-size:1.3rem}.roster-card{position:relative;overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--line);background:linear-gradient(180deg,rgba(20,28,40,.96),rgba(12,18,28,.94));transition:transform var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.roster-card:hover{transform:translateY(-2px);border-color:var(--line-strong)}.roster-card-media{position:relative;min-height:180px;overflow:hidden}.roster-card-art{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.88}.roster-card-overlay{position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;min-height:180px;padding:12px;background:linear-gradient(180deg,transparent 30%,rgba(8,13,20,.9))}.roster-card-body{display:flex;flex-direction:column;gap:8px;padding:12px}.roster-card-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:6px;gap:6px}.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:10px;gap:10px}.building-icon{display:grid;place-items:center;width:40px;height:40px;flex-shrink:0;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,var(--gold-soft),rgba(255,255,255,.04));color:var(--gold-bright)}.building-icon svg{width:20px;height:20px}.building-icon.economy,.building-icon.resource{background:linear-gradient(180deg,var(--teal-soft),rgba(255,255,255,.04));color:var(--teal-bright)}.building-icon.core,.building-icon.quest,.building-icon.roster,.building-icon.strategy{background:linear-gradient(180deg,var(--gold-soft),rgba(255,255,255,.04));color:var(--gold-bright)}.building-icon.affinity,.building-icon.hero,.building-icon.research{background:linear-gradient(180deg,var(--violet-soft),rgba(255,255,255,.04));color:#c8b4e8}.building-icon.defense,.building-icon.gear{background:linear-gradient(180deg,var(--ruby-soft),rgba(255,255,255,.04));color:#ffc8cc}.building-visual-badge{width:40px;height:40px;flex-shrink:0;border-radius:var(--r-sm);overflow:hidden;border:1px solid rgba(255,255,255,.1)}.building-visual-badge img{width:100%;height:100%;object-fit:cover}.building-identity{display:flex;align-items:center;gap:10px;min-width:0}.building-identity h4{margin:0;font-family:var(--font-display);font-size:.95rem}.building-identity-text{display:flex;flex-direction:column;gap:1px;min-width:0}.building-identity-label{font-size:.68rem;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase}.detail-panel{display:flex;flex-direction:column;gap:10px;padding:14px;border-radius:var(--r-lg);border:1px solid var(--line);background:linear-gradient(180deg,rgba(20,28,40,.92),rgba(14,20,30,.9))}.detail-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.detail-panel-body{gap:8px}.detail-panel-body,.timer-block{display:flex;flex-direction:column}.timer-block{gap:6px}.timer-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.timer-label{color:var(--text-dim);font-size:.78rem}.cost-row{display:flex;flex-wrap:wrap;gap:6px}.cost-row span{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-full);font-size:.72rem;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text-muted)}.upgrade-preview{display:flex;flex-direction:column;gap:6px;padding:10px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.06);background:rgba(255,255,255,.025);font-size:.82rem}.upgrade-preview p{margin:0;color:var(--text-muted)}.level-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.88rem}.level-row strong{font-family:var(--font-display);font-size:1rem}.level-row span{color:var(--text-dim)}.hero-sigil,.portrait-disc{display:grid;place-items:center;flex-shrink:0;border-radius:var(--r-md);border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,var(--gold-soft),rgba(127,85,34,.2));font-family:var(--font-display);font-weight:700;color:var(--gold-bright)}.hero-sigil{width:54px;height:54px;font-size:1.2rem}.portrait-disc{width:96px;height:96px;font-size:2rem}.hero-sigil.felina,.portrait-disc.felina{background:linear-gradient(135deg,var(--ruby-soft),rgba(101,40,48,.2));color:#ffc8cc}.hero-sigil.kitsune,.portrait-disc.kitsune{background:linear-gradient(135deg,var(--teal-soft),rgba(45,79,87,.2));color:var(--teal-bright)}.queue-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:center;padding:10px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.queue-row strong{display:block;font-size:.88rem}.queue-row span{font-size:.76rem;color:var(--text-muted)}.recruit-form{display:flex;flex-direction:column;gap:.7rem}.admin-table-shell{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);background:rgba(255,255,255,.015)}.admin-data-table{width:100%;min-width:900px;border-collapse:collapse}.admin-data-table td,.admin-data-table th{padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.04);text-align:left;vertical-align:middle}.admin-data-table th{position:-webkit-sticky;position:sticky;top:0;z-index:1;background:rgba(8,14,22,.98);color:var(--text-dim);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}.admin-data-table tbody tr:hover{background:rgba(255,255,255,.025)}.admin-sort-button{padding:0;border:0;background:transparent;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.admin-table-primary{display:flex;flex-direction:column;gap:2px}.admin-table-primary small{color:var(--text-dim)}.admin-table-toolbar{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center}.admin-table-toolbar .text-input{flex:1 1 220px}.admin-shell .rail{background:linear-gradient(180deg,rgba(8,14,18,.98),rgba(6,10,14,.99))}.admin-shell .rail-brand{background:linear-gradient(135deg,var(--teal-soft),rgba(255,255,255,.04));color:var(--teal);border-color:rgba(104,171,164,.2)}.admin-shell .rail-link.active{color:var(--teal);background:var(--teal-soft);border-color:rgba(104,171,164,.2);box-shadow:var(--shadow-glow-teal)}.admin-shell .rail-link.active:before{background:var(--teal)}.admin-page-actions{display:flex;justify-content:flex-start}.admin-users-workspace{display:flex;flex-direction:column;gap:.85rem}.admin-quick-actions{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.5rem}.admin-quick-actions form{flex:1 1 160px}.admin-quick-actions .ghost-button,.admin-quick-actions .secondary-button{width:100%}.user-detail-grid{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);grid-gap:1rem;gap:1rem;align-items:start}.admin-asset-workspace{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(340px,.85fr);grid-gap:1rem;gap:1rem}.admin-slot-preview-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:.85rem;gap:.85rem}.admin-slot-preview-card{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:rgba(255,255,255,.025)}.admin-collapsible,.admin-slot-preview-card{border:1px solid var(--line);border-radius:var(--r-lg)}.admin-collapsible{background:rgba(255,255,255,.02)}.admin-collapsible-summary{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:12px 14px;cursor:pointer;list-style:none}.admin-collapsible-summary::-webkit-details-marker{display:none}.admin-collapsible-body{display:flex;flex-direction:column;gap:.85rem;padding:0 14px 14px}.admin-select,.admin-select-field{position:relative}.admin-select{display:flex;flex-direction:column;gap:.5rem}.admin-select-control{position:relative}.admin-select-input{padding-right:2rem}.admin-select-clear,.admin-tag-remove{border:0;background:transparent;color:var(--text-muted);cursor:pointer}.admin-select-clear{position:absolute;top:50%;right:.7rem;transform:translateY(-50%)}.admin-select-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:30;max-height:260px;overflow:auto;border:1px solid var(--line);border-radius:var(--r-sm);background:rgba(8,12,20,.98);box-shadow:var(--shadow-float)}.admin-select-empty,.admin-select-option{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem;width:100%;padding:8px 10px;border:0;border-bottom:1px solid rgba(255,255,255,.04);background:transparent;color:var(--text-main);text-align:left}.admin-select-option:last-child{border-bottom:0}.admin-select-option.selected,.admin-select-option:hover{background:rgba(104,171,164,.1)}.admin-select-empty,.admin-select-option small,.admin-select-option span{color:var(--text-muted)}.admin-select-tags{display:flex;flex-wrap:wrap;gap:.4rem}.admin-select-tag{display:inline-flex;align-items:center;gap:.3rem}.admin-collapsible-panel{padding:.85rem}.danger-panel{border-color:rgba(200,105,112,.25);background:linear-gradient(180deg,var(--ruby-soft),var(--surface))}.search-form{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:.85rem}.search-form .text-input{flex:1 1 280px}.asset-manager{display:flex;flex-direction:column;gap:1rem}.asset-filter-bar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.asset-type-tabs{display:flex;gap:.25rem}.asset-type-tab{padding:.35rem .85rem;border:1px solid var(--line);border-radius:var(--r-full);background:transparent;color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:background .15s,color .15s}.asset-type-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.asset-workspace{display:grid;grid-template-columns:1fr;grid-gap:1rem;gap:1rem}.asset-workspace.has-panel{grid-template-columns:1fr 340px}@media (max-width:1100px){.asset-workspace.has-panel{grid-template-columns:1fr}}.asset-coverage-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg)}.asset-coverage-table{width:100%;border-collapse:collapse;font-size:.83rem}.asset-coverage-table td,.asset-coverage-table th{padding:.5rem .75rem;border-bottom:1px solid var(--line);white-space:nowrap}.asset-coverage-table tr:last-child td{border-bottom:0}.asset-coverage-table thead th{background:rgba(255,255,255,.03);color:var(--text-muted);font-weight:500;text-transform:uppercase;font-size:.72rem;letter-spacing:.05em;text-align:center}.asset-coverage-table thead th:first-child{text-align:left}.asset-entity-cell{min-width:180px;max-width:260px}.asset-entity-name{font-weight:500;color:var(--text-main);overflow:hidden;text-overflow:ellipsis;max-width:220px;display:block}.asset-entity-type-badge{font-size:.7rem;color:var(--text-muted);margin-top:1px;display:block}.asset-slot-cell{text-align:center;cursor:pointer;transition:background .1s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.asset-slot-cell:hover{background:rgba(104,171,164,.08)}.asset-slot-cell.active{background:rgba(104,171,164,.18);outline:2px solid var(--accent);outline-offset:-2px}.asset-slot-cell.na{color:var(--line);cursor:default;pointer-events:none}.asset-slot-ok{color:var(--status-active,#4caf8a);font-weight:600}.asset-slot-empty{color:var(--text-muted)}.asset-edit-panel{position:-webkit-sticky;position:sticky;top:1rem;border:1px solid var(--line);border-radius:var(--r-lg);background:rgba(14,20,30,.8);padding:1rem;display:flex;flex-direction:column;gap:1rem;max-height:calc(100vh - 4rem);overflow-y:auto}.asset-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.asset-panel-title{font-size:.9rem;font-weight:600;color:var(--text-main)}.asset-panel-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:2px}.asset-thumb-preview{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r-sm);background:rgba(255,255,255,.04);display:block;margin-bottom:.4rem}.asset-current-path{font-size:.72rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;display:block}.locale-toggle{display:flex;align-items:center;gap:2px}.locale-toggle-label{display:none}.locale-toggle-actions{display:inline-flex;gap:2px;padding:2px;border-radius:var(--r-full);border:1px solid var(--line);background:rgba(255,255,255,.03)}.locale-pill{min-width:40px;border:0;border-radius:var(--r-full);padding:4px 8px;background:transparent;color:var(--text-dim);font-size:.72rem;cursor:pointer;transition:all var(--dur) var(--ease-out)}.locale-pill.active{background:var(--gold-soft);color:var(--gold)}.visual-slot{position:relative;overflow:hidden;isolation:isolate;border:1px solid var(--line);border-radius:var(--r-lg);min-height:160px;padding:1rem;background:linear-gradient(180deg,rgba(16,22,32,.96),rgba(10,14,20,.94))}.visual-slot:after{content:"";position:absolute;inset:auto 0 0;height:50%;background:linear-gradient(180deg,transparent,rgba(7,10,16,.86));z-index:0}.visual-slot.landscape{min-height:200px}.visual-slot.portrait{min-height:280px}.visual-slot.compact{min-height:140px}.visual-slot.gold{background:linear-gradient(180deg,rgba(36,28,18,.92),rgba(14,16,22,.95))}.visual-slot.teal{background:linear-gradient(180deg,rgba(14,30,32,.92),rgba(14,16,22,.95))}.visual-slot.ruby{background:linear-gradient(180deg,rgba(32,16,20,.92),rgba(14,16,22,.95))}.visual-slot-glow,.visual-slot-grid,.visual-slot-media{position:absolute;inset:0}.visual-slot-media{z-index:-2}.visual-slot-art{width:100%;height:100%;display:block;object-fit:cover;object-position:center;opacity:.85;animation:float-slow 18s ease-in-out infinite}.visual-slot-glow{inset:auto -30px -50px auto;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.06);filter:blur(10px)}.visual-slot-grid{background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 0),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 0);background-size:30px 30px;opacity:.18;-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.8),transparent);mask-image:linear-gradient(180deg,rgba(0,0,0,.8),transparent)}.visual-slot-copy{position:relative;z-index:1;display:flex;flex-direction:column;gap:.4rem;max-width:65%}.visual-slot-copy span{color:var(--gold);font-size:.68rem;text-transform:uppercase;letter-spacing:.14em}.visual-slot-copy strong{font-family:var(--font-display);font-size:clamp(1.1rem,2vw,1.5rem);line-height:1.15}.visual-slot-copy p{margin:0;color:var(--text-muted);font-size:.82rem;line-height:1.55}.refresh-hint{margin:0;padding:0;color:var(--text-dim);font-size:.7rem;text-align:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:120px;padding:1rem;border-radius:var(--r-md);border:1px dashed var(--line);background:rgba(255,255,255,.015);text-align:center}.empty-state h4{margin:0;font-family:var(--font-display);font-size:.95rem}.empty-state p{margin:0;color:var(--text-muted);font-size:.82rem}.empty-state.compact{min-height:auto}.countdown-pill{gap:4px;padding:4px 10px;border-radius:var(--r-full);border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--text-main);font-size:.78rem}.countdown-pill,.status-badge{display:inline-flex;align-items:center}.status-badge{padding:3px 8px;border-radius:var(--r-full);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.status-badge.active{background:var(--teal-soft);color:var(--teal-bright)}.status-badge.upgrading{background:var(--gold-soft);color:var(--gold-bright)}.status-badge.locked{background:var(--ruby-soft);color:#ffc8cc}.muted{color:var(--text-muted);font-size:.85rem;line-height:1.6}.eyebrow{color:var(--gold);letter-spacing:.16em}.card-label,.eyebrow{margin:0;font-size:.68rem;text-transform:uppercase}.card-label{color:var(--text-dim);letter-spacing:.08em}.lead-copy{margin:0;max-width:55ch;color:var(--text-muted);line-height:1.65;font-size:.92rem}.blocked-copy{color:#ffd3d7;max-width:28ch;line-height:1.4;font-size:.82rem}.summary-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:var(--r-full);font-size:.72rem;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text-muted)}.chip-row{display:flex;flex-wrap:wrap;gap:4px}.chip-row.vertical{flex-direction:column;align-items:flex-start}.bonus-stack{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:6px;gap:6px}.bonus-stack div,.trait-chip{display:flex;flex-direction:column;gap:3px}.bonus-stack span,.trait-chip span{color:var(--text-muted);font-size:.8rem}.trait-chip{padding:10px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.trait-chip.featured{background:linear-gradient(180deg,var(--teal-soft),rgba(255,255,255,.02))}.trait-list{display:flex;flex-direction:column;gap:6px}.skill-row{align-items:flex-start;justify-content:space-between;gap:.75rem;padding:10px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.skill-meta{display:flex;flex-wrap:wrap;gap:4px}.skill-meta span{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--r-full);font-size:.72rem;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text-muted)}.skill-priority-form{flex-wrap:wrap;align-items:flex-end;gap:.6rem}.skill-priority-form .field-label.inline{flex:0 0 130px}.skill-priority-form .text-input{max-width:110px}.world-command-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;grid-gap:12px;gap:12px;align-items:start}.map-stage-panel,.map-stage-scroll{position:relative;overflow:hidden}.map-stage-scroll{border-radius:var(--r-md);border:1px solid rgba(214,179,106,.12);box-shadow:0 4px 32px rgba(0,0,0,.6),inset 0 0 60px rgba(0,0,0,.3)}.map-stage-grid{position:relative;width:100%;aspect-ratio:5/3;min-height:420px;overflow:visible;background-color:#152012;background-image:repeating-linear-gradient(60deg,rgba(255,255,255,.018),rgba(255,255,255,.018) 1px,transparent 0,transparent 28px),repeating-linear-gradient(-60deg,rgba(255,255,255,.018),rgba(255,255,255,.018) 1px,transparent 0,transparent 28px),radial-gradient(ellipse at 50% 50%,transparent 40%,rgba(0,0,0,.55) 100%),radial-gradient(ellipse at 25% 30%,rgba(60,100,40,.25) 0,transparent 45%),radial-gradient(ellipse at 75% 60%,rgba(30,70,25,.2) 0,transparent 40%);background-size:32px 32px,32px 32px,100% 100%,100% 100%,100% 100%}.map-terrain-layer{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:hidden;border-radius:var(--r-md)}.terrain-water{fill:rgba(22,70,130,.38);stroke:rgba(80,160,220,.3);stroke-width:1;animation:water-shimmer 5s ease-in-out infinite}.terrain-water-inner{fill:rgba(30,90,160,.22);stroke:none;animation:water-shimmer 5s ease-in-out 1.5s infinite}.terrain-mountain-shadow{fill:rgba(0,0,0,.28)}.terrain-mountain{fill:rgba(75,65,55,.72);stroke:rgba(130,115,95,.35);stroke-width:.5;stroke-linejoin:round}.terrain-mountain-peak{fill:rgba(160,150,135,.55);stroke:none}.terrain-mountain-snow{fill:rgba(220,225,235,.45)}.terrain-forest{fill:rgba(18,58,18,.6);stroke:rgba(40,90,30,.3);stroke-width:.5}.terrain-forest-dark{fill:rgba(10,40,12,.5)}.terrain-road{fill:none;stroke:rgba(160,135,90,.22);stroke-width:1;stroke-dasharray:4 3}@keyframes water-shimmer{0%,to{fill-opacity:1}50%{fill-opacity:.75}}.map-stage-routes{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;overflow:visible}.route-line{fill:none;stroke:var(--gold);stroke-width:.55;stroke-dasharray:2.5 1.8;stroke-linecap:round;opacity:.55;animation:route-march 1.6s linear infinite}.route-line.focused{stroke-width:.85;opacity:.9;filter:drop-shadow(0 0 2.5px var(--gold-glow))}.route-line.attack{stroke:var(--ruby);filter:drop-shadow(0 0 2px rgba(200,105,112,.5))}.route-line.attack.focused{filter:drop-shadow(0 0 3px rgba(200,105,112,.8))}.route-line.scout{stroke:var(--teal);stroke-dasharray:1.5 2.5}.route-line.scout.focused{filter:drop-shadow(0 0 2px rgba(104,171,164,.6))}.route-line.gather{stroke:var(--violet)}.route-line.reinforce{stroke:var(--teal-bright);stroke-dasharray:3 1}.route-target{fill:none;stroke:var(--gold);stroke-width:.45;opacity:.8}.route-target.attack{stroke:var(--ruby)}.route-target.scout{stroke:var(--teal)}.route-target.gather{stroke:var(--violet)}.route-target.reinforce{stroke:var(--teal-bright)}.march-troop-dot{filter:drop-shadow(0 0 3px currentColor)}.march-troop-dot.pve{fill:var(--gold-bright)}.march-troop-dot.attack{fill:#ff9fa5}.march-troop-dot.scout{fill:var(--teal-bright)}.march-troop-dot.gather{fill:#c8a6ff}.march-troop-dot.reinforce{fill:var(--teal-bright)}.march-troop-dot.returning{opacity:.65}@keyframes route-march{to{stroke-dashoffset:-18}}.world-origin-marker{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;z-index:10}.world-origin-ring{position:absolute;width:40px;height:40px;border-radius:50%;border:1.5px solid var(--gold);opacity:0;animation:origin-pulse 2.8s ease-out infinite}.world-origin-ring:after{content:"";position:absolute;inset:-10px;border-radius:50%;border:1px solid var(--gold);opacity:0;animation:origin-pulse 2.8s ease-out .9s infinite}.world-origin-core{position:relative;display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--r-sm);background:radial-gradient(circle at 40% 35%,rgba(214,179,106,.35),transparent 60%),linear-gradient(135deg,rgba(214,179,106,.22),rgba(214,179,106,.08));border:1.5px solid var(--gold);color:var(--gold-bright);font-size:.55rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 0 18px rgba(214,179,106,.25),0 0 6px rgba(214,179,106,.15),inset 0 1px 0 rgba(255,255,255,.12);z-index:2}@keyframes origin-pulse{0%{transform:scale(.85);opacity:.75}to{transform:scale(2.4);opacity:0}}.world-node{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;z-index:5;cursor:pointer;text-decoration:none}.world-node.selected,.world-node:hover{z-index:20}.world-node.sm .world-node-core{width:20px;height:20px;font-size:9px}.world-node.md .world-node-core{width:28px;height:28px;font-size:12px}.world-node.lg .world-node-core{width:38px;height:38px;font-size:15px;border-radius:var(--r-sm)}.world-node.gold .world-node-core{background:radial-gradient(circle at 40% 35%,rgba(214,179,106,.45),rgba(214,179,106,.1));border-color:var(--gold);color:var(--gold-bright);box-shadow:0 0 10px rgba(214,179,106,.25),0 2px 8px rgba(0,0,0,.5)}.world-node.teal .world-node-core{background:radial-gradient(circle at 40% 35%,rgba(104,171,164,.45),rgba(104,171,164,.1));border-color:var(--teal);color:var(--teal-bright);box-shadow:0 0 10px rgba(104,171,164,.25),0 2px 8px rgba(0,0,0,.5)}.world-node.ruby .world-node-core{background:radial-gradient(circle at 40% 35%,rgba(200,105,112,.5),rgba(200,105,112,.12));border-color:var(--ruby);color:#ff9fa5;box-shadow:0 0 14px rgba(200,105,112,.35),0 2px 8px rgba(0,0,0,.5)}.world-node.engaged .world-node-core{border-style:dashed;animation:node-engaged-pulse 1.5s ease-in-out infinite}.world-node.locked .world-node-core{opacity:.45;filter:grayscale(.6)}.world-node.ruby.lg .world-node-core:after{content:"";position:absolute;inset:-5px;border-radius:calc(var(--r-sm) + 5px);border:1px solid rgba(200,105,112,.5);animation:boss-rotate 5s linear infinite}.world-node.ruby.lg .world-node-core:before{content:"";position:absolute;inset:-10px;border-radius:calc(var(--r-sm) + 10px);border:1px solid rgba(200,105,112,.2);animation:boss-rotate 8s linear infinite reverse}.world-node-core{position:relative;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1.5px solid;transition:transform var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out);background-clip:padding-box}.world-node.selected .world-node-core,.world-node:hover .world-node-core{transform:scale(1.28)}.world-node-ping{position:absolute;border-radius:50%;pointer-events:none;inset:-8px}.world-node.active.gold .world-node-ping{border:1px solid var(--gold);animation:node-ping 2.8s ease-out infinite}.world-node.active.teal .world-node-ping{border:1px solid var(--teal);animation:node-ping 2.8s ease-out .5s infinite}.world-node.active.ruby .world-node-ping{border:1px solid var(--ruby);animation:node-ping 2.2s ease-out infinite}.world-node.engaged .world-node-ping{border:1px solid var(--gold);animation:node-ping-fast 1.1s ease-out infinite}.world-node-card{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(6px) scale(.93);min-width:144px;max-width:196px;padding:10px 12px;border-radius:var(--r-md);background:linear-gradient(180deg,rgba(18,26,38,.99),rgba(8,13,20,.99));border:1px solid rgba(214,179,106,.2);box-shadow:0 12px 40px rgba(0,0,0,.7),0 2px 8px rgba(0,0,0,.5),inset 0 1px 0 rgba(214,179,106,.12);opacity:0;pointer-events:none;transition:opacity .14s var(--ease-out),transform .14s var(--ease-out);display:flex;flex-direction:column;gap:3px;white-space:nowrap;z-index:40}.world-node-card:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,transparent,var(--line-glow) 40%,transparent);border-radius:var(--r-md) var(--r-md) 0 0}.world-node-card:after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:rgba(214,179,106,.2)}.world-node.selected .world-node-card,.world-node:hover .world-node-card{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}.world-node-card .card-label{font-size:.62rem;letter-spacing:.09em;text-transform:uppercase;color:var(--text-dim);margin:0}.world-node-card strong{display:block;font-size:.8rem;color:var(--text-main);font-family:var(--font-display)}.world-node-card small{display:block;font-size:.68rem;color:var(--text-muted)}.world-node-card .summary-pill{margin-top:5px;font-size:.62rem;align-self:flex-start}.world-node-card-art{display:block;width:100%;aspect-ratio:2.4/1;overflow:hidden;border-radius:var(--r-xs);margin-bottom:5px;border:1px solid var(--line)}.world-node-card-art img{width:100%;height:100%;object-fit:cover}.map-stage-footer{padding:10px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:6px}@keyframes node-ping{0%{transform:scale(.7);opacity:.8}to{transform:scale(2.8);opacity:0}}@keyframes node-ping-fast{0%{transform:scale(.7);opacity:.9}to{transform:scale(2.2);opacity:0}}@keyframes node-engaged-pulse{0%,to{box-shadow:0 0 8px rgba(214,179,106,.3)}50%{box-shadow:0 0 18px rgba(214,179,106,.7)}}@keyframes boss-rotate{to{transform:rotate(1turn)}}@media (max-width:960px){.world-command-grid{grid-template-columns:1fr}}.inspector-entity-head{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r-md);background:rgba(255,255,255,.03);border:1px solid var(--line)}.inspector-entity-icon-lg{display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex-shrink:0;border-radius:var(--r-sm);font-size:22px;line-height:1;border:1.5px solid transparent}.inspector-entity-icon-lg.gold{background:radial-gradient(circle at 40% 35%,rgba(214,179,106,.3),rgba(214,179,106,.08));border-color:rgba(214,179,106,.3);box-shadow:0 0 14px rgba(214,179,106,.15)}.inspector-entity-icon-lg.teal{background:radial-gradient(circle at 40% 35%,rgba(104,171,164,.3),rgba(104,171,164,.08));border-color:rgba(104,171,164,.3);box-shadow:0 0 14px rgba(104,171,164,.12)}.inspector-entity-icon-lg.ruby{background:radial-gradient(circle at 40% 35%,rgba(200,105,112,.35),rgba(200,105,112,.08));border-color:rgba(200,105,112,.35);box-shadow:0 0 16px rgba(200,105,112,.2)}.inspector-entity-meta{display:flex;flex-direction:column;gap:5px;min-width:0}.inspector-entity-meta .card-label{margin:0}.entity-stat-row{display:flex;border-radius:var(--r-sm);border:1px solid var(--line);overflow:hidden}.entity-stat-item{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:9px 6px;background:rgba(255,255,255,.025);border-right:1px solid var(--line);text-align:center}.entity-stat-item:last-child{border-right:none}.entity-stat-item span{font-size:.6rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-dim)}.entity-stat-item strong{font-family:var(--font-display);font-size:1rem;color:var(--text-main)}.world-entity-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:10px}.squad-slot-grid,.world-entity-grid{display:grid;gap:10px;align-items:stretch}.squad-slot-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:10px}.battle-summary-card,.march-card,.squad-slot-card,.world-entity-card{position:relative;display:flex;flex-direction:column;gap:10px;min-height:100%;overflow:hidden;padding:1rem;border-radius:var(--r-lg);border:1px solid var(--line);background:linear-gradient(180deg,rgba(22,30,42,.92),rgba(12,18,28,.9))}.battle-summary-card:before,.march-card:before,.squad-slot-card:before,.world-entity-card:before{content:"";position:absolute;inset:0 0 auto;height:1px;background:linear-gradient(90deg,var(--line-glow),transparent 60%)}.world-form-stack{display:flex;flex-direction:column;gap:.85rem}.squad-hero-inline{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.battle-log-row strong,.squad-hero-inline strong{display:block}.squad-selector-row{margin-bottom:.2rem}.active-pill{border-color:var(--line-strong);background:linear-gradient(135deg,var(--gold-soft),var(--teal-soft));color:var(--text-main)}.battle-log-row{gap:1rem}.hero-card-cover{position:relative;min-height:120px;overflow:hidden;border-radius:var(--r-md);border:1px solid var(--line);background:radial-gradient(circle at top right,var(--gold-soft),transparent 30%),linear-gradient(180deg,rgba(14,20,30,.85),rgba(8,12,18,.94))}.hero-card-cover:after{content:"";position:absolute;inset:auto 0 0;height:50%;background:linear-gradient(180deg,transparent,rgba(8,12,18,.88))}.class-thumb,.hero-card-cover-art{display:block;object-fit:cover}.hero-card-cover-art{width:100%;height:120px;opacity:.88;animation:float-slow 14s ease-in-out infinite}.class-thumb{width:44px;height:44px;border-radius:var(--r-sm);border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04)}.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.section-heading.compact{margin-bottom:.5rem}.section-heading h2,.section-heading h3{margin:0;font-family:var(--font-display)}.mini-list{flex-direction:column;gap:4px;margin:0;padding-left:1rem;color:var(--text-muted)}.inline-stat,.mini-list{display:flex;font-size:.82rem}.inline-stat{align-items:center;justify-content:space-between;gap:.5rem;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04)}.inline-stat:last-child{border-bottom:0}.inline-stat span{color:var(--text-muted)}.inline-stat strong{font-size:.88rem}.stack-list{display:flex;flex-direction:column}.stack-list.compact .inline-stat:last-child{padding-bottom:0;border-bottom:0}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:10px;gap:10px}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));grid-gap:8px;gap:8px}.summary-grid.compact{grid-template-columns:repeat(auto-fit,minmax(110px,1fr))}.inspector-metric-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:8px;gap:8px}@media (max-width:768px){.inspector-metric-grid{grid-template-columns:repeat(2,1fr)}}.stat-card,.stat-chip{border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.04);padding:10px 12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.stat-card span,.stat-chip span{display:block;margin-bottom:3px;color:var(--text-dim);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.stat-card strong,.stat-chip strong{font-size:1.1rem;font-family:var(--font-display)}.resource-card{border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.03);padding:10px 12px}.resource-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.resource-card strong{font-family:var(--font-display);font-size:1.1rem}.resource-card span{color:var(--text-muted);font-size:.82rem}.resource-card small{color:var(--text-dim);font-size:.78rem}.resource-card.warning{border-color:rgba(214,179,106,.25);background:linear-gradient(180deg,var(--gold-soft),rgba(255,255,255,.025))}.feature-card{display:flex;flex-direction:column;gap:8px;padding:14px;border-radius:var(--r-lg);border:1px solid var(--line);background:rgba(255,255,255,.025)}.feature-card.locked{opacity:.45}.feature-card h4{margin:0;font-family:var(--font-display)}.feature-card-head{align-items:flex-start;gap:.5rem}.feature-card-actions,.feature-card-head{display:flex;justify-content:space-between}.feature-card-actions{align-items:center;flex-wrap:wrap;gap:6px;margin-top:auto}.feature-card-actions.split{justify-content:flex-start}.feature-card-actions form{margin:0}.priority-card{display:flex;flex-direction:column;gap:8px;padding:14px;border-radius:var(--r-lg);border:1px solid var(--line-strong);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));transition:transform var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.priority-card:hover{transform:translateY(-2px);border-color:var(--gold)}.priority-card h4{margin:0;font-family:var(--font-display)}.priority-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:10px;gap:10px}.progress-track{height:6px;border-radius:var(--r-full);background:rgba(255,255,255,.06);overflow:hidden}.progress-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--gold),var(--gold-bright))}.progress-track.subtle span{background:linear-gradient(90deg,var(--teal),var(--teal-bright))}.timer-track{height:5px}.timer-track span{background:linear-gradient(90deg,var(--gold),#f09c76)}.fortress-page{gap:1rem}.fortress-command-bar{display:flex;flex-direction:column;gap:.85rem;position:relative;background:linear-gradient(135deg,rgba(20,28,40,.96),rgba(10,16,24,.94)),radial-gradient(circle at top right,var(--gold-soft),transparent 30%)}.fortress-command-bar:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--line-glow),transparent 50%)}.fortress-command-main{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.fortress-command-main h2{margin:0;font-family:var(--font-display);font-size:clamp(1.3rem,2.2vw,1.8rem);line-height:1.1}.fortress-command-actions{display:flex;flex-wrap:wrap;gap:6px}.fortress-command-stats{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:6px;gap:6px}.fortress-panel{padding:0;overflow:hidden}.fortress-panel-summary{position:relative;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:12px 14px;cursor:pointer;list-style:none}.fortress-panel-summary::-webkit-details-marker{display:none}.fortress-panel-summary:after{content:"";display:grid;place-items:center;width:24px;height:24px;flex-shrink:0;border-radius:50%;background:rgba(255,255,255,.06);color:var(--gold);font-size:.9rem;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23d6b36a' stroke-width='2'%3E%3Cpolyline points='6,9 12,15 18,9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:50%;transition:transform var(--dur) var(--ease-out)}details[open]>.fortress-panel-summary:after{transform:rotate(180deg)}.fortress-panel-body{gap:.85rem;padding:0 14px 14px}.fortress-operations-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}.fortress-operations-grid,.fortress-section-stack{display:grid;grid-gap:10px;gap:10px}.fortress-resource-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px}.fortress-priority-grid .empty-state{grid-column:1/-1}.fortress-focus-card{gap:8px;min-height:100%}.fortress-focus-card,.signal-card{display:flex;flex-direction:column;padding:12px;border-radius:var(--r-md);border:1px solid var(--line);background:rgba(255,255,255,.025)}.signal-card{gap:6px}.signal-card.accent{background:linear-gradient(180deg,var(--gold-soft),rgba(255,255,255,.02));border-color:var(--line-strong)}.fortress-card-section{display:flex;flex-direction:column;gap:4px}.fortress-building-identity{display:flex;align-items:center;gap:10px;min-width:0}.fortress-building-title{display:flex;flex-direction:column;gap:1px;min-width:0}.fortress-building-title h4{margin:0;font-family:var(--font-display);font-size:.92rem}.fortress-timer-block{display:flex;flex-direction:column;gap:5px}.fortress-timer-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}.fortress-data-points{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:6px;gap:6px}.fortress-data-pill{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.fortress-data-pill span{color:var(--text-dim);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase}.fortress-data-pill strong{font-family:var(--font-display);font-size:.95rem}.district-review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:10px;gap:10px}.district-review-card{border-radius:var(--r-md);border:1px solid var(--line);background:rgba(255,255,255,.025);overflow:hidden}.district-review-card[open]{border-color:var(--line-strong)}.district-review-summary{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:10px 12px;cursor:pointer;list-style:none}.district-review-summary::-webkit-details-marker{display:none}.district-review-summary:after{content:"";display:grid;place-items:center;width:22px;height:22px;flex-shrink:0;border-radius:50%;background:rgba(255,255,255,.06);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23d6b36a' stroke-width='2'%3E%3Cpolyline points='6,9 12,15 18,9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:50%;transition:transform var(--dur) var(--ease-out)}.district-review-card[open]>.district-review-summary:after{transform:rotate(180deg)}.district-review-meta{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.district-review-body{display:flex;flex-direction:column;gap:8px;padding:0 12px 12px}.fortress-architecture-stack{display:flex;flex-direction:column;gap:10px}.fortress-category-panel{background:linear-gradient(180deg,rgba(20,28,40,.92),rgba(12,18,28,.9))}.fortress-category-summary{align-items:center}.fortress-category-heading{display:flex;flex-direction:column;gap:3px;min-width:0}.fortress-category-heading h3{margin:0;font-family:var(--font-display);font-size:.95rem}.fortress-mini-progress{width:min(280px,100%)}.category-summary{position:relative;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:10px 14px;cursor:pointer;list-style:none}.category-summary::-webkit-details-marker{display:none}.category-summary:after{content:"";display:grid;place-items:center;width:24px;height:24px;flex-shrink:0;border-radius:50%;background:rgba(255,255,255,.06);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23d6b36a' stroke-width='2'%3E%3Cpolyline points='6,9 12,15 18,9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:50%;transition:transform var(--dur) var(--ease-out)}details[open]>.category-summary:after{transform:rotate(180deg)}.category-content{padding:0 14px 14px}.category-stats{display:flex;flex-wrap:wrap;gap:4px;max-width:340px;justify-content:flex-end}.category-panel{padding:0;overflow:hidden}.heroes-page{gap:1rem}.heroes-command-stage{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(0,1.15fr);grid-gap:1rem;gap:1rem;align-items:stretch;background:linear-gradient(135deg,rgba(14,28,32,.96),rgba(10,16,24,.94)),radial-gradient(circle at top right,var(--teal-soft),transparent 30%)}.heroes-command-overview{display:flex;flex-direction:column;justify-content:space-between;gap:.85rem}.heroes-command-overview h2{margin:0;font-family:var(--font-display);font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.05;max-width:12ch}.heroes-command-actions{display:flex;flex-wrap:wrap;gap:6px}.heroes-command-stats{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:6px;gap:6px}.heroes-spotlight-card{position:relative;overflow:hidden;min-height:340px;border-radius:var(--r-xl);border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(16,24,34,.9),rgba(10,14,22,.95))}.heroes-spotlight-media{position:absolute;inset:0}.heroes-spotlight-art{width:100%;height:100%;object-fit:cover;opacity:.88;animation:float-slow 16s ease-in-out infinite}.heroes-spotlight-wash{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,13,20,.12),rgba(8,13,20,.88)),linear-gradient(135deg,rgba(8,13,20,.18),rgba(8,13,20,.5))}.heroes-spotlight-content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;min-height:340px;padding:1.25rem;gap:.75rem}.heroes-spotlight-content h3{margin:0;font-family:var(--font-display);font-size:1.2rem}.heroes-spotlight-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.heroes-spotlight-stats{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px}.heroes-spotlight-progress{display:flex;flex-direction:column;gap:4px}.heroes-spotlight-empty{min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:1rem}.heroes-roster-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:10px;gap:10px}.hero-roster-card{display:flex;flex-direction:column;overflow:hidden;padding:0;border-radius:var(--r-lg);border:1px solid var(--line);background:linear-gradient(180deg,rgba(20,28,40,.96),rgba(12,18,28,.94));transition:transform var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.hero-roster-card:hover{transform:translateY(-2px);border-color:var(--line-strong)}.hero-roster-media{position:relative;min-height:200px}.hero-roster-art{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.88}.hero-roster-wash{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,13,20,.12),rgba(8,13,20,.88)),linear-gradient(135deg,rgba(8,13,20,.18),rgba(8,13,20,.5))}.hero-roster-overlay{position:relative;z-index:1;display:flex;align-items:flex-end;justify-content:space-between;min-height:200px;padding:12px}.hero-roster-name h4{margin:.15rem 0 0;font-family:var(--font-display)}.hero-roster-body{display:flex;flex-direction:column;gap:8px;padding:12px}.heroes-roster-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px}.hero-roster-progress{display:flex;flex-direction:column;gap:4px}.heroes-stat-line{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px}.hero-stat-tile{display:flex;flex-direction:column;gap:2px;padding:8px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.hero-stat-tile span{color:var(--text-dim);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}.hero-stat-tile strong{font-family:var(--font-display);font-size:.95rem}.hero-loadout-disclosure{margin-top:-.1rem}.heroes-support-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:10px;gap:10px}.heroes-support-panel{display:flex;flex-direction:column;gap:10px;min-height:100%}.heroes-support-list{display:flex;flex-direction:column;gap:8px}.heroes-queue-row{display:grid;grid-template-columns:44px minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:center;padding:10px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.heroes-queue-copy{display:flex;flex-direction:column;gap:2px}.heroes-queue-copy strong{display:block;font-size:.88rem}.heroes-queue-copy span{font-size:.76rem;color:var(--text-muted)}.heroes-recruit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:10px;gap:10px}.hero-recruit-card{gap:10px}.hero-recruit-cover{min-height:160px}.hero-card-banner{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:8px}.hero-card-identity{display:flex;align-items:flex-start;gap:10px;flex:1 1 220px}.hero-card-badges{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.hero-meta{display:flex;flex-wrap:wrap;gap:4px}.hero-meta span{display:inline-flex;align-items:center;padding:3px 8px;border-radius:var(--r-full);font-size:.72rem;border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--text-muted)}.profile-identity{display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--r-md);border:1px solid var(--line);background:rgba(255,255,255,.025)}.profile-visual-stage{gap:10px}.recruitment-head{display:flex;align-items:center;gap:10px}.queue-box{flex-direction:column;gap:6px}.queue-box,.queue-item{display:flex;padding:10px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.025)}.queue-item{align-items:flex-start;justify-content:space-between;gap:.75rem}.dashboard-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;grid-gap:10px;gap:10px;align-items:start}.hero-panel{position:relative;display:flex;align-items:center;justify-content:space-between;gap:1rem;overflow:hidden}.hero-panel h2{margin:0;font-family:var(--font-display)}.hero-panel-stats{display:flex;flex-wrap:wrap;gap:6px}.admin-hero{background:linear-gradient(135deg,rgba(14,34,38,.94),rgba(16,20,26,.94)),radial-gradient(circle at top right,var(--teal-soft),transparent 40%)}.admin-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,rgba(104,171,164,.45),transparent 50%)}@keyframes float-slow{0%,to{transform:translateY(0) scale(1.03)}50%{transform:translateY(-6px) scale(1.05)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@keyframes glow-pulse{0%,to{box-shadow:0 0 8px rgba(214,179,106,.2)}50%{box-shadow:0 0 16px rgba(214,179,106,.35)}}.fortress-fullscreen{position:absolute;inset:0;z-index:2;overflow:hidden;pointer-events:none}.fortress-fullscreen>*{pointer-events:auto}.fortress-canvas-wrap{position:absolute;inset:0;z-index:0}.fortress-canvas-wrap canvas{display:block!important;width:100%!important;height:100%!important}.fortress-canvas-loading{width:100%;height:100%;background:#0a120a}.fortress-panel{position:absolute;top:.75rem;right:.75rem;bottom:.75rem;width:320px;z-index:20;background:rgba(10,18,10,.68);border:1px solid rgba(214,179,106,.15);border-radius:var(--r-md);-webkit-backdrop-filter:blur(20px) saturate(1.3);backdrop-filter:blur(20px) saturate(1.3);display:flex;flex-direction:column;overflow-y:auto;animation:fortress-panel-in .2s ease-out;scrollbar-width:thin;scrollbar-color:rgba(214,179,106,.2) transparent}@keyframes fortress-panel-in{0%{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}.fortress-panel--hint{top:auto;bottom:.75rem;height:auto}.fortress-panel-head{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.fortress-panel-head h3{font-size:1rem;margin:0;color:var(--gold,#d6b36a);font-family:var(--font-display,inherit)}.fortress-panel-close{background:none;border:none;color:rgba(255,255,255,.35);cursor:pointer;font-size:1.2rem;padding:.2rem .4rem;border-radius:4px;transition:color .15s,background .15s}.fortress-panel-close:hover{color:#fff;background:rgba(255,255,255,.08)}.fortress-panel-body{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.75rem;flex:1 1}.fp-stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:.5rem;gap:.5rem}.fp-stat{display:flex;flex-direction:column;gap:.1rem}.fp-stat span{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;opacity:.45}.fp-stat strong{font-size:.85rem}.fp-stat .fp-active{color:#3db879}.fp-stat .fp-upgrade{color:var(--gold,#d6b36a)}.fp-stat .fp-locked{color:rgba(255,255,255,.3)}.fp-progress{height:4px;border-radius:2px;background:rgba(255,255,255,.06);overflow:hidden}.fp-progress-fill{height:100%;border-radius:2px;background:var(--gold,#d6b36a);transition:width .4s ease-out}.fp-section-title{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;opacity:.45;margin:0}.fp-bonus-row{display:flex;justify-content:space-between;font-size:.8rem;padding:.15rem 0}.fp-bonus-row strong{color:var(--teal,#68aba4)}.fp-costs{display:flex;flex-wrap:wrap;gap:.35rem}.fp-cost{font-size:.72rem;padding:.15rem .45rem;border-radius:4px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06)}.fp-cost--gold{color:#d6b36a}.fp-cost--wood{color:#8bc47a}.fp-cost--stone{color:#a0a8b8}.fp-cost--mana{color:#9b7ec8}.fp-time{font-size:.75rem;opacity:.55}.fp-blocked{font-size:.75rem;color:var(--ruby,#c86970);opacity:.85}.fp-upgrade-btn{width:100%;padding:.55rem;border:none;border-radius:6px;background:linear-gradient(135deg,rgba(214,179,106,.25),rgba(214,179,106,.15));border:1px solid rgba(214,179,106,.3);color:var(--gold,#d6b36a);font-weight:600;font-size:.82rem;cursor:pointer;transition:background .2s,transform .1s}.fp-upgrade-btn:hover{background:linear-gradient(135deg,rgba(214,179,106,.35),rgba(214,179,106,.2))}.fp-upgrade-btn:active{transform:scale(.98)}.fp-detail-link{display:block;text-align:center;font-size:.72rem;opacity:.45;padding:.3rem;border-radius:4px;transition:opacity .15s}.fp-detail-link:hover{opacity:.8}.fp-queue-info{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}.fp-hint{font-size:.82rem;opacity:.5;text-align:center;line-height:1.5;margin:0}.fp-quick-stats{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:.4rem;gap:.4rem;margin-top:.25rem}.fortress-timer{position:absolute;bottom:.75rem;left:50%;transform:translateX(-50%);z-index:15;display:flex;align-items:center;gap:.6rem;padding:.45rem 1rem;background:rgba(10,18,10,.92);border:1px solid rgba(214,179,106,.2);border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:.8rem;pointer-events:none}.fortress-timer-label{color:var(--gold,#d6b36a);font-weight:600}.fortress-flash{position:absolute;top:.75rem;left:50%;transform:translateX(-50%);z-index:30;padding:.4rem 1.2rem;border-radius:6px;background:rgba(61,184,121,.12);border:1px solid rgba(61,184,121,.25);color:#3db879;font-size:.8rem;animation:fortress-flash-fade 4s ease-out forwards;pointer-events:none}.fortress-flash--error{background:rgba(200,105,112,.12);border-color:rgba(200,105,112,.25);color:var(--ruby,#c86970)}@keyframes fortress-flash-fade{0%,60%{opacity:1}to{opacity:0}}@media (max-width:920px){.fortress-panel{width:280px}}@media (max-width:640px){.fortress-panel{width:100%;right:0;bottom:0;top:auto;height:50%;border-radius:12px 12px 0 0}}@media (max-width:1320px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid>:first-child{grid-column:1/-1}}@media (max-width:1180px){.heroes-command-stage{grid-template-columns:1fr}.fortress-command-stats,.heroes-spotlight-stats{grid-template-columns:repeat(3,1fr)}.admin-asset-workspace,.fortress-operations-grid{grid-template-columns:1fr}}@media (max-width:920px){.shell{grid-template-columns:52px minmax(0,1fr)}:root{--rail-width:52px}.rail-link{width:40px;height:38px}.rail-brand{width:38px;height:38px;font-size:.95rem}.district-review-summary,.fortress-category-summary,.fortress-panel-summary,.hero-roster-overlay,.hero-stage,.heroes-spotlight-top{flex-direction:column;align-items:flex-start}.district-review-summary:after,.fortress-panel-summary:after{display:none}.fortress-command-stats,.fortress-data-points,.fortress-resource-grid,.heroes-command-stats,.heroes-roster-summary-grid,.heroes-stat-line,.heroes-support-grid{grid-template-columns:repeat(2,1fr)}.district-review-meta{align-items:flex-start}.user-detail-grid{grid-template-columns:1fr}.category-summary{flex-direction:column}.category-summary:after{display:none}.category-stats{justify-content:flex-start;max-width:none}.queue-item,.skill-row{flex-direction:column}}@media (max-width:720px){.dashboard-grid{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start;padding:8px 12px;gap:6px}.hud-resources{width:100%;overflow-x:auto}}@media (max-width:640px){.shell{grid-template-columns:1fr;grid-template-rows:auto auto minmax(0,1fr)}.rail{grid-row:auto;justify-content:center;padding:6px 10px;border-right:0;border-bottom:1px solid var(--line);overflow-x:auto}.rail,.rail-nav{flex-direction:row}.rail-nav{width:auto;padding:0}.rail-sep{width:1px;height:24px;margin:0 4px}.rail-footer{flex-direction:row;margin-top:0;margin-left:auto}.rail-link.active:before{display:none}.rail-tooltip{display:none!important}.topbar{grid-column:1}.main-viewport{grid-column:1;padding:0}.fortress-command-stats,.fortress-data-points,.fortress-resource-grid,.heroes-command-stats,.heroes-roster-summary-grid,.heroes-spotlight-stats,.heroes-stat-line,.heroes-support-grid{grid-template-columns:1fr}.feature-card-actions,.feature-card-actions.split,.fortress-command-actions,.hero-stage-actions,.heroes-command-actions,.search-form{flex-direction:column;align-items:stretch}.button-link,.ghost-button,.primary-button,.secondary-button{width:100%}.bonus-stack,.form-grid,.form-grid.wide,.summary-grid,.summary-grid.compact{grid-template-columns:1fr}.hero-card-badges{align-items:flex-start}.visual-slot-copy{max-width:100%}.heroes-queue-row{grid-template-columns:44px minmax(0,1fr)}.heroes-queue-row .countdown-pill{grid-column:1/-1}}@media (max-width:1080px){.spotlight-grid{grid-template-columns:1fr}}.page-stack.map-page{gap:0}.page-stack.map-page .world-command-grid{height:calc(100dvh - var(--topbar-height) - 2.5rem);align-items:stretch}.pixi-map-panel{display:flex;flex-direction:column;overflow:hidden}.pixi-map-container{flex:1 1;min-height:400px;border-radius:6px;overflow:hidden;background:#0d1a0b;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}.pixi-map-container canvas{display:block!important;position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.pixi-map-container>div{position:relative;width:100%;height:100%}.pixi-map-loading{width:100%;height:100%;min-height:400px;background:#0d1a0b;border-radius:6px;animation:pixi-shimmer 1.8s ease-in-out infinite}@keyframes pixi-shimmer{0%,to{opacity:.5}50%{opacity:1}}@media (max-width:960px){.page-stack.map-page .world-command-grid{height:auto}.pixi-map-container{height:55vw;min-height:320px}}.map-fullscreen{position:absolute;inset:0;overflow:hidden;z-index:2;pointer-events:none}.map-fullscreen>*{pointer-events:auto}.map-canvas-wrap{position:absolute;inset:0;background:#0d1a0b}.map-canvas-wrap>div{width:100%;height:100%}.map-canvas-wrap canvas{display:block!important;position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.map-loading-shimmer{width:100%;height:100%;background:#0d1a0b;animation:pixi-shimmer 1.8s ease-in-out infinite}.map-coord-hud{position:absolute;bottom:16px;left:16px;display:flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.08);border-radius:6px;font-size:.75rem;color:rgba(255,255,255,.7);pointer-events:none;z-index:10;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.map-coord-sector{font-weight:700;color:rgba(255,255,255,.9)}.map-coord-local,.map-coord-sector{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.map-coord-local{opacity:.6}.map-coord-terrain{display:flex;align-items:center;gap:6px;padding:2px 8px;border-radius:4px;font-weight:600;font-size:.7rem}.map-terrain--river{background:rgba(26,74,128,.5);color:#6ab8e0}.map-terrain--mountain{background:rgba(74,62,50,.5);color:#d8dce8}.map-terrain--forest{background:rgba(18,42,12,.5);color:#50a040}.map-terrain--road{background:rgba(160,138,90,.3);color:#c0a870}.map-terrain--plains{background:rgba(21,32,18,.3);color:#8a9a7a}.map-terrain-speed{font-weight:400;font-size:.65rem;opacity:.8}.map-quick-stats{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:12px;padding:6px 16px;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.08);border-radius:6px;font-size:.75rem;color:rgba(255,255,255,.6);pointer-events:none;z-index:10;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.map-stat strong{color:rgba(255,255,255,.9);margin-right:3px}.map-stat--active strong{color:#50e090}.map-home-btn{position:absolute;bottom:16px;right:360px;width:36px;height:36px;border-radius:6px;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.08);color:#70b8ff;font-size:1.2rem;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:background .15s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.map-home-btn:hover{background:rgba(74,144,217,.3)}.map-panel{position:absolute;top:16px;right:16px;width:320px;max-height:calc(100% - 32px);overflow-y:auto;background:rgba(10,18,10,.92);border:1px solid rgba(255,255,255,.08);border-radius:10px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:10;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.map-panel--hint{top:auto;bottom:16px;max-height:none}.map-panel-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid rgba(255,255,255,.06)}.map-panel-head>div{display:flex;align-items:center;gap:8px;min-width:0}.map-panel-head h3{font-size:.95rem;font-weight:700;color:#fff;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-panel-icon{font-size:1.2rem;flex-shrink:0}.map-panel-close{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:1rem;padding:4px;border-radius:4px;transition:color .15s,background .15s}.map-panel-close:hover{color:#fff;background:rgba(255,255,255,.08)}.map-panel-body{padding:12px 16px 16px;display:flex;flex-direction:column;gap:12px}.map-panel-type{display:flex;align-items:center;justify-content:space-between;font-size:.8rem;color:rgba(255,255,255,.5)}.mp-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.mp-badge--active{background:rgba(80,224,144,.15);color:#50e090}.mp-badge--march{background:rgba(240,160,48,.15);color:#f0a030}.mp-badge--locked{background:rgba(255,255,255,.06);color:rgba(255,255,255,.35)}.mp-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px}.mp-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:rgba(255,255,255,.03);border-radius:6px;border:1px solid rgba(255,255,255,.04)}.mp-stat span{font-size:.65rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.03em}.mp-stat strong{font-size:.85rem;color:#fff}.mp-detail{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.04)}.mp-detail span{color:rgba(255,255,255,.4)}.mp-detail strong{color:rgba(255,255,255,.8);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.mp-section-title{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:rgba(255,255,255,.35);margin:0 0 4px}.mp-march-card{padding:10px 12px;background:rgba(240,160,48,.06);border:1px solid rgba(240,160,48,.15);border-radius:6px}.mp-march-card strong{display:block;font-size:.85rem;color:#f0a030;margin-bottom:2px}.mp-muted{font-size:.75rem;color:rgba(255,255,255,.35);margin:2px 0}.mp-respawn{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:rgba(255,255,255,.03);border-radius:6px;font-size:.8rem}.mp-respawn span{color:rgba(255,255,255,.4)}.mp-actions{display:flex;flex-direction:column;gap:6px}.mp-action-btn{display:block;text-align:center;padding:8px 14px;border-radius:6px;font-size:.8rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s}.mp-action-primary{background:rgba(74,144,217,.2);color:#70b8ff;border:1px solid rgba(74,144,217,.3)}.mp-action-primary:hover{background:rgba(74,144,217,.35)}.mp-action-ghost{background:transparent;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.08)}.mp-action-ghost:hover{background:rgba(255,255,255,.04);color:rgba(255,255,255,.7)}.mp-history-card{padding:10px 12px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:6px}.mp-history-card strong{display:block;font-size:.85rem;color:rgba(255,255,255,.8);margin-bottom:2px}.mp-hint{font-size:.85rem;color:rgba(255,255,255,.4);text-align:center;margin:0 0 10px}.mp-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 14px;font-size:.72rem;color:rgba(255,255,255,.35)}@media (max-width:920px){.map-panel{width:280px}.map-home-btn{right:300px}}@media (max-width:640px){.map-panel{top:auto;bottom:60px;left:8px;right:8px;width:auto;max-height:50%}.map-coord-hud{bottom:auto;top:8px;left:8px}.map-quick-stats{bottom:8px}.map-home-btn{right:8px;bottom:50px}}.fortress-scene-stage{display:flex;flex-direction:column;gap:12px;padding:16px 20px;border-radius:var(--r-md);background:linear-gradient(135deg,rgba(21,32,18,.95),rgba(10,18,10,.98));border:1px solid var(--line)}.fortress-scene-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:8px}.pixi-fortress-wrap{position:relative;width:100%;height:320px;border-radius:6px;overflow:hidden;background:#0a120a;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}.pixi-fortress-wrap canvas{display:block!important;position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.pixi-fortress-wrap>div{position:relative;width:100%;height:100%}.pixi-fortress-loading{width:100%;height:320px;background:#0a120a;border-radius:6px;animation:pixi-shimmer 1.8s ease-in-out infinite}@media (max-width:640px){.pixi-fortress-loading,.pixi-fortress-wrap{height:240px}}.pixi-battle-wrap{position:relative;width:100%;height:280px;border-radius:6px;overflow:hidden;background:#0e0a14;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}.pixi-battle-wrap canvas{display:block!important;position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.pixi-battle-wrap>div{position:relative;width:100%;height:100%}.pixi-battle-loading{width:100%;height:280px;background:#0e0a14;border-radius:6px;animation:pixi-shimmer 1.8s ease-in-out infinite}.pixi-hud-resource-wrap{position:relative;height:32px;flex:1 1;min-width:0}.pixi-hud-resource-wrap canvas{display:block!important;position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.pixi-hud-resource-wrap>div{position:relative;width:100%;height:100%}.pixi-timeline-wrap{position:relative;width:100%;height:48px;border-radius:4px;overflow:hidden;background:rgba(14,20,30,.5)}.pixi-timeline-wrap canvas{display:block!important;position:absolute!important;inset:0!important;width:100%!important;height:100%!important}.pixi-timeline-wrap>div{position:relative;width:100%;height:100%}.report-strip-list{display:flex;flex-direction:column;gap:.5rem}.report-strip{display:flex;align-items:flex-start;gap:.6rem;padding:.6rem;border-radius:var(--r-md,8px);background:rgba(255,255,255,.03);border-left:3px solid rgba(255,255,255,.08);overflow:hidden}.report-strip.victory{border-left-color:var(--gold,#d6b36a)}.report-strip.defeat{border-left-color:var(--ruby,#c84a4a)}.report-strip.draw{border-left-color:rgba(255,255,255,.15)}.report-strip-mark{flex-shrink:0;width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.06);font-size:.7rem;color:rgba(255,255,255,.5)}.report-strip-body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.report-strip-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.report-strip-head h4{margin:0;font-size:.85rem}.report-strip-actions{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.25rem}.timeline-list{gap:.6rem}.timeline-card,.timeline-list{display:flex;flex-direction:column}.timeline-card{padding:.65rem;border-radius:var(--r-md,8px);background:rgba(255,255,255,.03);border-left:3px solid rgba(255,255,255,.08);gap:.4rem;overflow:hidden}.timeline-card.traveling{border-left-color:var(--gold,#d6b36a)}.timeline-card.returning{border-left-color:var(--teal,#4ac0c0)}.timeline-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.4rem}.timeline-card-head h4{margin:0;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.timeline-lane{display:flex;gap:.25rem;align-items:flex-start}.timeline-step{flex:1 1;display:flex;flex-direction:column;align-items:center;gap:.15rem;font-size:.65rem;text-align:center;color:rgba(255,255,255,.4)}.timeline-step.complete{color:rgba(255,255,255,.7)}.timeline-step.current{color:var(--gold,#d6b36a)}.timeline-step strong{font-size:.6rem;text-transform:uppercase;letter-spacing:.04em}.timeline-step small{font-size:.6rem;opacity:.7}.timeline-dot{display:block;width:6px;height:6px;border-radius:50%;background:currentColor}.timeline-members{display:flex;gap:.35rem;flex-wrap:wrap;overflow:hidden}.timeline-members.compact{gap:.25rem}.hud-sidebar .portrait-frame,.hud-sidebar .portrait-wrap{max-width:100%;overflow:hidden}.hud-sidebar .summary-grid{grid-template-columns:repeat(2,1fr)}.hero-sheet{position:absolute;inset:0;z-index:2;overflow:hidden;pointer-events:none}.hero-sheet>*{pointer-events:auto}.hero-sheet-flash{position:absolute;top:.75rem;left:50%;transform:translateX(-50%);z-index:10;max-width:420px;width:90%}.hero-sheet-left{position:absolute;left:0;bottom:0;width:42%;height:100%;display:flex;align-items:flex-end;justify-content:center;pointer-events:none}.hero-sheet-art{max-height:85vh;max-width:90%;object-fit:contain;object-position:bottom center;-webkit-mask-image:linear-gradient(0deg,black 60%,transparent);mask-image:linear-gradient(0deg,black 60%,transparent);-webkit-user-select:none;-moz-user-select:none;user-select:none;filter:drop-shadow(0 0 24px rgba(0,0,0,.5))}.hero-sheet-tabs{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.35rem;z-index:5}.hero-sheet-tab-btn{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.5rem .45rem;border:1px solid rgba(255,255,255,.08);border-radius:var(--r-md,8px);background:rgba(14,20,30,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:rgba(255,255,255,.45);cursor:pointer;transition:all .2s ease;min-width:46px}.hero-sheet-tab-btn:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.7)}.hero-sheet-tab-btn.active{border-color:rgba(255,255,255,.15);color:rgba(255,255,255,.95)}.hero-sheet-tab-btn.active.accent-gold{border-color:var(--gold,#d6b36a);box-shadow:0 0 8px rgba(214,179,106,.2)}.hero-sheet-tab-btn.active.accent-teal{border-color:var(--teal,#4ac0c0);box-shadow:0 0 8px rgba(74,192,192,.2)}.hero-sheet-tab-btn.active.accent-ruby{border-color:var(--ruby,#c84a4a);box-shadow:0 0 8px rgba(200,74,74,.2)}.hero-sheet-tab-icon{font-size:1.1rem;line-height:1}.hero-sheet-tab-label{font-size:.55rem;text-transform:uppercase;letter-spacing:.06em;line-height:1}.hero-sheet-panel{position:absolute;right:.75rem;top:.75rem;bottom:.75rem;width:380px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}.hero-sheet-panel>.panel{min-height:100%;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:rgba(14,20,30,.85)}.hero-sheet-nameplate{position:absolute;left:4.5rem;bottom:1.25rem;display:flex;flex-direction:column;gap:.35rem;max-width:35%}.hero-sheet-nameplate h2{margin:0;font-size:1.6rem;letter-spacing:-.01em;text-shadow:0 2px 12px rgba(0,0,0,.6)}.hero-sheet-nameplate p{margin:0;font-size:.8rem;color:rgba(255,255,255,.5);text-shadow:0 1px 6px rgba(0,0,0,.5)}.gear-slot-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:.5rem;gap:.5rem}.gear-slot-card{padding:.6rem;border-radius:var(--r-md,8px);background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.35rem}.gear-slot-card .feature-card-head h4{font-size:.8rem}.inventory-drawer-grid{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.inventory-item-card{padding:.5rem;border-radius:var(--r-md,8px);background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.04);display:flex;flex-direction:column;gap:.3rem}.inventory-item-card .feature-card-head h4{font-size:.8rem}.skill-row{padding:.6rem;border-radius:var(--r-md,8px);background:rgba(255,255,255,.02);display:flex;flex-direction:column;gap:.35rem}.skill-row strong{font-size:.85rem}.skill-priority-form{display:flex;align-items:center;gap:.5rem}.skill-priority-form .text-input{width:60px}.mini-disclosure{border-radius:var(--r-md,8px);background:rgba(255,255,255,.02);overflow:hidden}.mini-disclosure>summary{padding:.5rem .6rem;cursor:pointer;font-size:.8rem;font-weight:500;color:rgba(255,255,255,.6);-webkit-user-select:none;-moz-user-select:none;user-select:none}.mini-disclosure>summary:hover{color:rgba(255,255,255,.85)}.mini-disclosure[open]>summary{border-bottom:1px solid rgba(255,255,255,.05)}.mini-disclosure>:not(summary){padding:.5rem}@media (max-width:900px){.hero-sheet-left{position:relative;width:100%;height:35vh;justify-content:center}.hero-sheet-art{max-height:100%}.hero-sheet-tabs{position:relative;left:auto;top:auto;transform:none;flex-direction:row;justify-content:center;padding:.5rem}.hero-sheet-tab-btn{flex-direction:row;gap:.3rem;padding:.4rem .65rem;min-width:auto}.hero-sheet-tab-icon{font-size:.9rem}.hero-sheet-tab-label{font-size:.6rem}.hero-sheet-panel{position:relative;right:auto;top:auto;bottom:auto;width:100%;max-height:none;overflow:visible}.hero-sheet-nameplate{position:relative;left:auto;bottom:auto;max-width:100%;padding:.75rem}.hero-sheet{position:relative;overflow-y:auto;display:flex;flex-direction:column}.gear-slot-grid{grid-template-columns:1fr}}@media (max-width:480px){.hero-sheet-panel{padding:0 .25rem}}.heroes-hud-spotlight{position:absolute;left:4rem;bottom:0;width:38%;max-width:480px;height:100%;display:flex;align-items:flex-end;pointer-events:none}.heroes-hud-spotlight-art{position:absolute;bottom:0;left:0;max-height:88vh;max-width:80%;object-fit:contain;object-position:bottom left;-webkit-mask-image:linear-gradient(0deg,black 55%,transparent 95%);mask-image:linear-gradient(0deg,black 55%,transparent 95%);-webkit-user-select:none;-moz-user-select:none;user-select:none;filter:drop-shadow(0 0 32px rgba(0,0,0,.5))}.heroes-hud-spotlight-nameplate{position:absolute;bottom:1.5rem;left:48%;display:flex;flex-direction:column;gap:.5rem;pointer-events:auto;max-width:220px}.heroes-hud-spotlight-nameplate h2{margin:0;font-size:1.8rem;text-shadow:0 2px 12px rgba(0,0,0,.7)}.heroes-hud-spotlight-nameplate .eyebrow{font-size:.7rem;text-shadow:0 1px 6px rgba(0,0,0,.5)}.heroes-roster-row{display:flex;align-items:center;gap:.6rem;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.heroes-roster-row:last-child{border-bottom:none}.heroes-roster-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;background:rgba(255,255,255,.05)}.heroes-roster-info{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.heroes-roster-info strong{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.heroes-roster-info .muted{font-size:.7rem}.heroes-roster-xp{height:3px;margin-top:.15rem}.heroes-roster-meta{align-items:flex-end;gap:.2rem}.heroes-roster-actions,.heroes-roster-meta{display:flex;flex-direction:column;flex-shrink:0}.heroes-roster-actions{gap:.25rem}.heroes-recruit-row{display:flex;align-items:flex-start;gap:.6rem;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.04)}.heroes-recruit-row:last-child{border-bottom:none}.heroes-recruit-thumb{width:40px;height:40px;border-radius:var(--r-md,8px);object-fit:cover;flex-shrink:0;background:rgba(255,255,255,.05)}.heroes-recruit-info{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.heroes-recruit-info strong{font-size:.85rem}.heroes-recruit-form{display:flex;flex-direction:column;gap:.35rem;flex-shrink:0;width:130px}.heroes-recruit-form .text-input{font-size:.75rem;padding:.3rem .5rem}@media (max-width:900px){.heroes-hud-spotlight{display:none}.heroes-recruit-form{width:100%}.heroes-recruit-row{flex-wrap:wrap}}.operations-layout,.report-archive-layout{display:grid;grid-template-columns:1fr 320px;grid-gap:1rem;gap:1rem;align-items:start}@media (max-width:900px){.operations-layout,.report-archive-layout{grid-template-columns:1fr}}.notif-bell-btn,.notif-bell-wrap{position:relative}.notif-bell-btn{background:none;border:1px solid var(--line);border-radius:6px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;width:32px;height:32px;transition:color .15s,border-color .15s}.notif-bell-btn:hover{color:var(--text);border-color:var(--gold-soft)}.notif-bell-count{position:absolute;top:-4px;right:-4px;background:#d64a4a;color:#fff;font-size:.6rem;font-weight:700;border-radius:50%;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;line-height:1;padding:0 3px}.notif-dropdown{position:absolute;top:calc(100% + 6px);right:0;width:300px;max-height:360px;background:var(--panel-bg,#111);border:1px solid var(--line);border-radius:8px;z-index:100;display:flex;flex-direction:column;box-shadow:0 8px 24px rgba(0,0,0,.5);pointer-events:auto}.notif-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .75rem;border-bottom:1px solid var(--line);font-size:.8rem}.notif-dropdown-list{overflow-y:auto;flex:1 1;max-height:260px}.notif-item{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;border-bottom:1px solid rgba(255,255,255,.04);font-size:.78rem}.notif-item.read{opacity:.5}.notif-icon{font-size:1rem;flex-shrink:0;margin-top:2px}.notif-content{flex:1 1;min-width:0}.notif-content strong{display:block;font-size:.78rem}.notif-content p{margin:2px 0 0;font-size:.72rem;color:var(--text-muted)}.notif-time{font-size:.68rem;flex-shrink:0;white-space:nowrap}.notif-empty{text-align:center;padding:1.5rem .75rem;font-size:.78rem}.notif-dropdown-footer{border-top:1px solid var(--line);padding:.5rem .75rem}.notif-mark-read{background:none;border:1px solid var(--line);border-radius:4px;color:var(--text-muted);cursor:pointer;font-size:.72rem;padding:.3rem .6rem;width:100%;transition:color .15s}.notif-mark-read:hover{color:var(--text)}.world-events-banner{display:flex;gap:.5rem;padding:.3rem .75rem;background:rgba(26,42,74,.25);border-bottom:1px solid rgba(74,155,106,.15);overflow-x:auto;flex-shrink:0}.world-event-chip{display:flex;align-items:center;gap:.35rem;font-size:.72rem;padding:.2rem .5rem;background:rgba(255,255,255,.04);border:1px solid rgba(74,155,106,.2);border-radius:4px;white-space:nowrap;color:var(--text-muted)}.world-event-icon{font-size:.85rem}.world-event-name{font-weight:600;color:var(--text)}.world-event-bonus{color:var(--gold-bright);font-weight:600}.daily-bonus-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:linear-gradient(90deg,rgba(214,179,106,.1),rgba(214,179,106,.02));border:1px solid rgba(214,179,106,.2);border-radius:6px;margin:.5rem;pointer-events:auto;position:relative;z-index:2}.daily-bonus-icon{font-size:1.2rem;color:var(--gold-bright)}.daily-bonus-text{font-size:.82rem;font-weight:600;color:var(--gold-bright);flex:1 1}.daily-bonus-btn{background:var(--gold-soft);color:#111;border:none;border-radius:4px;padding:.3rem .8rem;font-size:.78rem;font-weight:700;cursor:pointer;transition:background .15s}.daily-bonus-btn:hover{background:var(--gold-bright)}