:root{--bg:#0a0e17;--p:rgba(20,26,40,.62);--p2:rgba(31,40,60,.72);--line:rgba(255,255,255,.09);
  --gold:#f0b90b;--cream:#e7ecf5;--muted:#8493b0;--green:#16e1a3;--mint:#16e1a3;--red:#ff4d6d;--violet:#7b61ff}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:linear-gradient(160deg,#0d1320,#0a0e17 60%);color:var(--cream);
  font:500 15px/1.45 'Space Grotesk',ui-sans-serif,system-ui,Segoe UI,Roboto,Arial;overflow:hidden;-webkit-user-select:none;user-select:none;
  font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased}
/* numbers in Orbitron */
.pcard b,.res b,#rTrophy,#tickerPrice,.raidhud b,.tcard .n,#raidPct,#raidTime,.warresult .big{font-family:'Orbitron',ui-sans-serif;font-variant-numeric:tabular-nums}
/* inline SVG icons */
.ic{width:17px;height:17px;flex:0 0 auto;vertical-align:-3px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.res.gold .ic{color:var(--gold)} .res.hype .ic{color:#ff7a3c} .res.liq .ic{color:#4fc3f7}
.res.scrap .ic{color:#b9a98c} .res.tro .ic{color:var(--mint)}
.brand .ic{color:var(--mint);width:20px;height:20px}
.res span{display:flex;align-items:center;gap:7px}
.nav-b .ic,.wbtn .ic{width:16px;height:16px}
.hidden{display:none!important} .muted{color:var(--muted);font-size:12px}
.btn{background:linear-gradient(180deg,#ffd02e,#f0b90b);color:#1a1400;border:0;font-weight:700;
  padding:10px 16px;border-radius:10px;cursor:pointer;letter-spacing:.2px;
  box-shadow:0 4px 16px rgba(240,185,11,.32),inset 0 1px 0 rgba(255,255,255,.45);transition:transform .08s,box-shadow .15s,filter .15s}
.btn:hover{filter:brightness(1.08);box-shadow:0 6px 22px rgba(240,185,11,.5),inset 0 1px 0 rgba(255,255,255,.5)}
.btn:active{transform:scale(.97)} .btn[disabled]{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}
.btn.big{font-size:17px;padding:13px 26px;width:100%;margin-top:8px}
.btn.ghost{background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--cream);box-shadow:none}
.btn.ghost:hover{border-color:var(--green);box-shadow:0 0 0 1px rgba(22,199,132,.4)}
.btn.sm{padding:7px 11px;font-size:13px}
.hint{color:var(--muted);font-size:12px;margin-top:10px}

/* login */
.login{position:fixed;inset:0;display:grid;place-items:center;padding:20px;background:radial-gradient(800px 460px at 50% -8%,#173728,#0a120d 65%)}
.loginbox{background:var(--p);border:1px solid var(--line);border-radius:16px;padding:30px;max-width:360px;width:100%;text-align:center}
.crest{font-size:46px;filter:drop-shadow(0 0 10px var(--gold))}
h1{font-size:30px;letter-spacing:3px;color:var(--gold);margin:6px 0}.sub{color:var(--muted);margin-bottom:16px}
input{width:100%;background:var(--p2);border:1px solid var(--line);color:var(--cream);padding:11px;border-radius:10px;text-align:center;font-size:15px;margin-bottom:8px}
.gate{background:rgba(224,88,79,.12);border:1px solid var(--red);color:#ffc0bb;padding:10px;border-radius:10px;margin-bottom:12px;font-size:13px}
.gate.ok{background:rgba(95,194,106,.12);border-color:var(--green);color:#bff0c4}

/* app shell */
.app{position:fixed;inset:0;display:flex}
.sidebar{width:262px;flex:0 0 262px;background:linear-gradient(180deg,rgba(20,38,28,.82),rgba(10,18,13,.82));
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid rgba(61,240,160,.18);
  box-shadow:2px 0 30px rgba(0,0,0,.4);display:flex;flex-direction:column;padding:14px;gap:10px;overflow-y:auto}
.brand{font-size:19px;letter-spacing:1px;color:var(--mint);font-weight:700;display:flex;gap:8px;align-items:center;text-shadow:0 0 12px rgba(61,240,160,.4)}
.pcard{display:flex;justify-content:space-between;align-items:center;background:var(--p2);border:1px solid var(--line);border-radius:10px;padding:9px 12px}
.pcard b{font-size:15px}.pw{color:var(--gold);font-size:12px}
.resbar{display:flex;flex-direction:column;gap:6px}
.res{display:flex;align-items:center;gap:6px;background:var(--p);border:1px solid var(--line);border-radius:9px;padding:7px 10px;font-size:13px}
.res span{flex:1;color:var(--muted)}.res b{font-weight:800;font-variant-numeric:tabular-nums}
.res i{font-style:normal;color:var(--green);font-size:11px;min-width:42px;text-align:right}
.res.tro b{color:var(--gold)}
.qtitle{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-top:4px}
.qbox{display:flex;flex-direction:column;gap:6px;min-height:8px}
.q{background:var(--p2);border:1px solid var(--line);border-radius:10px;padding:8px 10px;font-size:12px}
.q .qr{display:flex;justify-content:space-between;align-items:center;gap:6px}
.q .bar{height:5px;background:var(--line);border-radius:4px;margin-top:5px;overflow:hidden}
.q .fill{height:100%;background:linear-gradient(90deg,var(--gold),#fff2c8)}
.q .spd{padding:4px 8px;font-size:11px;white-space:nowrap}
.nav{display:flex;flex-direction:column;gap:5px;margin-top:6px}
.nav-b{text-align:left;background:var(--p);border:1px solid var(--line);color:var(--cream);padding:10px 12px;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer}
.nav-b.active{background:rgba(240,185,11,.12);color:var(--gold);border-color:rgba(240,185,11,.5);box-shadow:0 0 16px rgba(240,185,11,.25),inset 0 0 0 1px rgba(240,185,11,.2)}
.nav-b.active .ic{color:var(--gold)}
.nav-b{transition:border-color .15s,background .15s,color .15s}.nav-b:hover{border-color:var(--green);color:#fff}
.res i{color:var(--green)} .res b{font-weight:700}
.card,.ecard,.bpop-card,.tickerbox{ -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px) }
.wbtn{margin-top:auto}

/* stage */
.stage{flex:1;position:relative;overflow:hidden;background:#0d1a2e}
.view{position:absolute;inset:0;overflow-y:auto;padding:0}
.view:not(#view-kingdom):not(#view-army){padding:16px}
.stagewrap{position:absolute;inset:0}
.stagewrap.sm{position:relative;height:42%;inset:auto}
#view-army{padding:0;display:flex;flex-direction:column}
#view-army .panel{flex:1;overflow-y:auto;padding:16px}
canvas{display:block;width:100%;height:100%}
.hinttip{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:#000a;border:1px solid var(--line);
  color:var(--muted);font-size:12px;padding:6px 12px;border-radius:20px;pointer-events:none}
.editbtn{position:absolute;left:12px;bottom:12px;z-index:3;box-shadow:0 4px 16px #0007}
.editbtn.saving{background:linear-gradient(180deg,#5fc26a,#3a9a48);color:#06210d}
.zoomctl{position:absolute;right:12px;bottom:48px;z-index:3;display:flex;flex-direction:column;gap:6px}
.zoomctl button{width:40px;height:40px;border:1px solid var(--line);background:#000a;color:var(--cream);border-radius:10px;font-size:20px;font-weight:800;cursor:pointer;line-height:1}
.sec{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin:6px 4px 10px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.card{background:var(--p);border:1px solid var(--line);border-radius:12px;padding:12px}
.card .top{display:flex;justify-content:space-between;align-items:center}
.card h4{font-size:15px}.lvl{background:var(--p2);border:1px solid var(--line);border-radius:7px;padding:2px 8px;font-size:12px;color:var(--gold)}
.card .d{color:var(--muted);font-size:12px;margin:6px 0}.cost{font-size:12px;margin:4px 0}
.train .row,.panel .row{display:flex;gap:8px;align-items:center;background:var(--p);border:1px solid var(--line);border-radius:12px;padding:11px;margin-bottom:8px}
.panel .row .info{flex:1}.panel input{width:74px;margin:0}
.formrow{display:flex;gap:10px;align-items:center;background:var(--p);border:1px solid var(--line);border-radius:12px;padding:11px;margin-bottom:8px;flex-wrap:wrap}
.frole{flex:1 1 130px}.fchips{display:flex;gap:5px;flex-wrap:wrap}
.chip{background:var(--p2);border:1px solid var(--line);color:var(--muted);padding:6px 9px;border-radius:8px;font-size:12px;cursor:pointer}
.chip.on{background:var(--gold);color:#2a1c06;border-color:var(--gold);font-weight:700}
.targets{display:flex;flex-direction:column;gap:8px;max-width:620px}
.tg{background:var(--p);border:1px solid var(--line);border-radius:12px;padding:11px;display:flex;justify-content:space-between;align-items:center}
.tg .meta{font-size:12px;color:var(--muted)}
.lb{list-style:none;counter-reset:r;max-width:620px}
.lb li{counter-increment:r;display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.lb li:before{content:counter(r);width:24px;height:24px;display:grid;place-items:center;border-radius:7px;background:var(--p2);color:var(--muted);font-size:12px;font-weight:700}
.lb li:nth-child(1):before{background:var(--gold);color:#2a1c06}.lb li:nth-child(2):before{background:#cdd6e6;color:#222}.lb li:nth-child(3):before{background:#cd7f32}
.lb .nm{flex:1}.lb .tp{color:var(--gold);font-weight:800}.lb .pw{color:var(--muted);font-size:12px}
.tokencard{background:var(--p);border:1px solid var(--gold);border-radius:12px;padding:12px;margin-bottom:12px;max-width:620px}
.tickerbox{background:#10160f;border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:14px;max-width:620px}
.tickerhead{font-size:1.05rem;margin-bottom:6px}.tickerhead b{color:var(--gold)}#tickerPrice{font-weight:800}
.tickerbox canvas{width:100%;height:90px;display:block}
.up{color:var(--green)}.down{color:var(--red)}
#econPanel{display:flex;flex-direction:column;gap:12px;margin-bottom:18px;max-width:620px}
.ecard{background:var(--p);border:1px solid var(--line);border-radius:12px;padding:14px}
.ecard h4{font-family:var(--sans);font-weight:800;margin-bottom:8px}
.ecard .row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ecard input{width:120px;margin:0}
.pumpbtn{background:linear-gradient(180deg,#5fc26a,#3a9a48);color:#06210d}
.pumpbtn[disabled]{background:var(--p2);color:var(--muted)}

/* building popup */
.bpop{position:fixed;inset:0;background:rgba(8,6,4,.6);z-index:25;display:flex;align-items:center;justify-content:center;padding:18px}
.bpop-card{background:var(--p);border:1px solid var(--gold);border-radius:14px;padding:18px;max-width:340px;width:100%;box-shadow:0 18px 60px #000a}
.bpop-card h3{font-size:20px;color:var(--gold)}.bpop-card .lv{color:var(--muted);font-size:13px;margin:2px 0 8px}
.bpop-card .d{color:var(--cream);font-size:13px;margin-bottom:10px}
.bpop-card .ln{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-bottom:1px dashed var(--line)}
.bpop-card .ln b{color:var(--cream)} .bad{color:var(--red)} .ok{color:var(--green)}
.bpop-card .actions{display:flex;gap:8px;margin-top:14px}.bpop-card .actions .btn{flex:1}

/* battle */
.waroverlay{position:fixed;inset:0;background:rgba(8,6,4,.93);z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:16px}
.waroverlay canvas{width:100%;max-width:760px;height:auto;border:1px solid var(--line);border-radius:12px}
.warresult{text-align:center}.warresult h2{font-size:30px;letter-spacing:2px}
.warresult h2.win{color:var(--gold)}.warresult h2.lose{color:var(--red)}.warresult .det{color:var(--muted);margin-top:6px}
.warclose{min-width:170px}
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:#000d;border:1px solid var(--line);color:var(--cream);padding:11px 18px;border-radius:12px;font-size:14px;z-index:40;max-width:90%}

/* right-side building stats panel */
.statspanel{position:fixed;top:0;right:0;height:100%;width:312px;max-width:86%;background:linear-gradient(180deg,rgba(20,38,28,.9),rgba(10,18,13,.92));
  -webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border-left:1px solid rgba(61,240,160,.18);z-index:38;transform:translateX(100%);transition:transform .28s ease;overflow-y:auto;padding:14px;box-shadow:-12px 0 40px #0008}
.statspanel.open{transform:none}
.sphead{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.sphead b{font-family:var(--serif);font-size:1.3rem;color:var(--gold)}
.sphead button{background:none;border:1px solid var(--line);color:var(--cream);border-radius:8px;width:30px;height:30px;cursor:pointer}
.srow{background:var(--p);border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px}
.srow .sh{display:flex;justify-content:space-between;align-items:center;gap:8px}
.srow .sh b{font-size:.98rem}
.srow .lock{color:var(--red);font-size:.8rem;font-weight:700}
.srow .ok{color:var(--green);font-size:.8rem;font-weight:700}
.srow .muted{font-size:.82rem}

/* raid overlay */
.raidoverlay{position:fixed;inset:0;z-index:35;background:#0d1a12;display:flex;flex-direction:column}
.raidhud{display:flex;align-items:center;gap:16px;padding:10px 16px;background:#1a130c;border-bottom:1px solid var(--line);font-weight:700;flex-wrap:wrap}
.raidhud #raidName{flex:1;color:var(--gold);font-family:var(--serif);font-size:1.2rem}
.raidhud #raidStars{color:var(--gold);font-size:1.1rem;letter-spacing:2px}
.raidstage{flex:1;position:relative;overflow:hidden}
.raidstage canvas{width:100%;height:100%;display:block;touch-action:none}
.raidtray{display:flex;gap:8px;padding:10px;background:#1a130c;border-top:1px solid var(--line);overflow-x:auto}
.troopbtn{background:var(--p2);border:2px solid var(--line);border-radius:12px;padding:8px 12px;min-width:64px;text-align:center;cursor:pointer;flex:0 0 auto}
.troopbtn.sel{border-color:var(--gold);background:#3a2c14}
.troopbtn .em{font-size:22px;line-height:1}.troopbtn .ct{font-weight:800;font-size:.9rem}
.troopbtn .tav{width:40px;height:40px;display:block;margin:0 auto}
.tav{width:44px;height:44px;flex:0 0 auto;vertical-align:middle;image-rendering:auto}
.panel .row{align-items:center}
.troopbtn[disabled]{opacity:.4}
.raidresult{position:absolute;inset:0;background:rgba(8,6,4,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:20px}
.raidresult h2{font-size:2rem;color:var(--gold)} .raidresult .stars{font-size:2.4rem;color:var(--gold);letter-spacing:6px}
.raidresult .det{color:var(--cream)}

/* nav badge */
.nav-b{position:relative}
.navbadge{position:absolute;top:6px;right:8px;background:var(--red);color:#fff;font-size:10px;font-weight:800;
  min-width:17px;height:17px;line-height:17px;text-align:center;border-radius:9px;padding:0 4px;box-shadow:0 0 8px rgba(255,77,109,.6)}

/* mail */
.mailhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.maillist{display:flex;flex-direction:column;gap:8px;max-width:660px}
.mailrow{display:flex;gap:12px;align-items:flex-start;background:var(--p);border:1px solid var(--line);border-radius:12px;padding:12px 14px;cursor:pointer;transition:border-color .15s,background .15s}
.mailrow:hover{border-color:rgba(61,240,160,.4)}
.mailrow.unread{background:rgba(240,185,11,.06);border-color:rgba(240,185,11,.35)}
.mailrow.unread .mailtitle{color:var(--gold)}
.mailrow.unread:before{content:"";position:absolute}
.mailic{width:22px;height:22px;flex:0 0 auto;color:var(--mint);margin-top:2px}
.mailrow.unread .mailic{color:var(--gold)}
.mailbody{flex:1;min-width:0}
.mailtitle{font-weight:700;font-size:14px;margin-bottom:3px}
.maildesc{color:var(--cream);font-size:12.5px;line-height:1.4;opacity:.85}
.maildate{margin-top:5px}

/* events */
.evcard{position:relative;overflow:hidden}
.evcard:before{content:"";position:absolute;inset:0;background:radial-gradient(120px 60px at 100% 0,rgba(123,97,255,.16),transparent);pointer-events:none}
.evtimer{background:var(--p2);border:1px solid var(--line);border-radius:7px;padding:2px 8px;font-size:11px;color:var(--violet);font-family:'Orbitron',ui-sans-serif;white-space:nowrap}

/* bazaar splash */
.bazaar{position:relative;max-width:520px;margin:18px auto;text-align:center;background:linear-gradient(180deg,rgba(31,40,60,.6),rgba(10,14,23,.7));
  border:1px solid rgba(123,97,255,.35);border-radius:18px;padding:34px 26px;overflow:hidden;
  box-shadow:0 0 50px rgba(123,97,255,.18),inset 0 1px 0 rgba(255,255,255,.06)}
.bazaar-glow{position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:300px;height:300px;
  background:radial-gradient(circle,rgba(34,211,238,.22),transparent 60%);pointer-events:none}
.bazaar-ic{width:58px;height:58px;color:var(--gold);fill:none;stroke:currentColor;stroke-width:1.6;
  filter:drop-shadow(0 0 14px rgba(240,185,11,.5));position:relative}
.bazaar h2{font-size:30px;letter-spacing:2px;color:var(--cream);margin:10px 0 6px;position:relative}
.bazaar-badge{display:inline-block;background:linear-gradient(90deg,var(--violet),var(--mint));color:#06121f;
  font-weight:800;letter-spacing:2px;font-size:12px;padding:5px 14px;border-radius:20px;margin-bottom:16px;position:relative}
.bazaar p{color:var(--muted);font-size:13.5px;margin:8px 0;position:relative}
.bazaar-list{list-style:none;text-align:left;max-width:340px;margin:14px auto;display:flex;flex-direction:column;gap:10px;position:relative}
.bazaar-list li{display:flex;align-items:center;gap:10px;background:var(--p);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13px}
.bazaar-list .ic{color:var(--mint);width:18px;height:18px}

/* mobile */
@media(max-width:760px){
  .app{flex-direction:column}
  .sidebar{width:100%;flex:0 0 auto;max-height:46vh;border-right:0;border-bottom:1px solid var(--line)}
  .nav{flex-direction:row;flex-wrap:wrap}.nav-b{flex:1 1 28%;text-align:center;padding:9px 6px;font-size:12px}
  .wbtn{margin-top:6px}.resbar{flex-direction:row;flex-wrap:wrap}.res{flex:1 1 45%}
  .stage{flex:1}
}
