/* ============ STOCK EMPIRE — STYLES ============ */
:root{
  --bg:#0a0e14; --bg2:#111824; --panel:#141d2b; --panel2:#1b2738;
  --line:#243348; --text:#e6edf6; --muted:#8aa0b8; --dim:#5d7390;
  --accent:#3b82f6; --accent2:#2563eb;
  --up:#22c55e; --down:#ef4444; --gold:#f5c542;
  --radius:14px; --shadow:0 10px 40px rgba(0,0,0,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Inter',system-ui,sans-serif;
  background:radial-gradient(1200px 600px at 80% -10%,#16233a 0%,transparent 60%),
    radial-gradient(900px 500px at -10% 10%,#1a1430 0%,transparent 55%),var(--bg);
  color:var(--text);min-height:100vh;overflow-x:hidden}
.hidden{display:none !important}
.muted{color:var(--muted)} .small{font-size:.78rem}
.num{text-align:right;font-family:'JetBrains Mono',monospace}
.up{color:var(--up)} .down{color:var(--down)}

/* buttons */
.btn{font:inherit;font-weight:600;border:1px solid var(--line);background:var(--panel2);
  color:var(--text);padding:.5rem .9rem;border-radius:10px;cursor:pointer;transition:.15s}
.btn:hover{border-color:var(--accent);transform:translateY(-1px)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:transparent}
.btn-gold{background:linear-gradient(135deg,#eab308,#f5c542);border-color:transparent;color:#1a1400}
.btn-ghost{background:transparent}
.btn-ghost.danger:hover{border-color:var(--down);color:var(--down)}
.btn-sm{padding:.32rem .7rem;font-size:.82rem;border-radius:8px}
.btn-lg{width:100%;padding:.85rem;font-size:1.05rem;margin-top:.4rem}
.btn-trade{background:linear-gradient(135deg,#1e2c44,#23344f)}
.btn-buy{flex:1;background:linear-gradient(135deg,#16a34a,#22c55e);border-color:transparent}
.btn-sell{flex:1;background:linear-gradient(135deg,#dc2626,#ef4444);border-color:transparent}

/* modal / onboarding */
.modal-overlay{position:fixed;inset:0;background:rgba(6,9,15,.82);backdrop-filter:blur(7px);
  display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}
.modal{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);
  border-radius:18px;box-shadow:var(--shadow);width:100%;max-width:420px;padding:2rem;position:relative}
.onboard-card{text-align:center}
.onboard-logo{font-size:3.4rem;line-height:1}
.onboard-card h1{font-size:2rem;font-weight:900;margin:.3rem 0;letter-spacing:-.02em;
  background:linear-gradient(135deg,#60a5fa,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}
.onboard-tag{color:var(--muted);margin-bottom:1.4rem}
.field-label{display:block;text-align:left;font-size:.8rem;color:var(--muted);margin:.7rem 0 .3rem;font-weight:600}
.onboard-card input{width:100%;padding:.7rem .85rem;border-radius:10px;border:1px solid var(--line);
  background:var(--bg);color:var(--text);font:inherit}
.onboard-card input:focus{outline:none;border-color:var(--accent)}
.onboard-fine{font-size:.74rem;color:var(--dim);margin-top:.9rem}

/* topbar */
.topbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.7rem 1.1rem;
  background:rgba(17,24,36,.7);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:30}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-logo{font-size:1.7rem}
.brand-text strong{display:block;font-weight:800;line-height:1.1}
.brand-text small{color:var(--muted);font-size:.72rem}
.stats-strip{display:flex;gap:.4rem;flex:1;flex-wrap:wrap;justify-content:center}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:.35rem .7rem;min-width:80px;text-align:center}
.stat-k{display:block;font-size:.64rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.stat-v{font-weight:700;font-family:'JetBrains Mono',monospace;font-size:.92rem}
.stat-net{border-color:var(--accent);box-shadow:0 0 0 1px rgba(59,130,246,.25)}
.stat-net .stat-v{color:#7dd3fc}
.topbar-controls{display:flex;gap:.4rem;flex-wrap:wrap}
#notifyBtn{position:relative}
.notify-dot{position:absolute;top:-6px;right:-6px;background:var(--down);color:#fff;font-size:.6rem;
  font-weight:800;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 3px}
.agency-box{margin-top:.6rem;border-top:1px solid var(--line);padding-top:.6rem}
.agency-box .found-btn{margin-top:.3rem;width:100%}

/* tabs */
.tabs{display:flex;gap:.3rem;padding:.6rem 1rem 0;overflow-x:auto}
.tab{background:transparent;border:none;color:var(--muted);font:inherit;font-weight:600;
  padding:.6rem .85rem;border-radius:10px 10px 0 0;cursor:pointer;white-space:nowrap}
.tab:hover{color:var(--text)}
.tab.active{color:var(--text);background:var(--panel);border-bottom:2px solid var(--accent)}

/* layout */
.layout{max-width:1080px;margin:0 auto;padding:1rem}
.tabview{display:none} .tabview.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow)}
.panel-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem;margin-bottom:1rem}
.panel-head h2{font-size:1.25rem;font-weight:800;display:flex;align-items:center;gap:.5rem}
.panel-sub{color:var(--muted);font-size:.85rem;flex-basis:100%}

/* live badge */
.live-badge{font-size:.62rem;font-weight:700;padding:.2rem .5rem;border-radius:20px;letter-spacing:.03em}
.live-badge.on{color:var(--up);background:rgba(34,197,94,.12)}
.live-badge.off{color:var(--muted);background:rgba(138,160,184,.1)}
.live-dot{color:var(--up);font-size:.6rem;vertical-align:middle}

/* filters */
.market-filters{display:flex;gap:.4rem;flex-wrap:wrap}
.market-filters input,.market-filters select{background:var(--bg);border:1px solid var(--line);
  color:var(--text);border-radius:9px;padding:.45rem .6rem;font:inherit;font-size:.85rem}
.market-filters input:focus,.market-filters select:focus{outline:none;border-color:var(--accent)}

/* tables */
.table-wrap{overflow-x:auto;border-radius:10px}
.stock-table{width:100%;border-collapse:collapse;font-size:.9rem}
.stock-table thead th{text-align:left;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);padding:.5rem .6rem;border-bottom:1px solid var(--line)}
.stock-table th.num{text-align:right}
.stock-table tbody td{padding:.55rem .6rem;border-bottom:1px solid rgba(36,51,72,.5)}
.stock-table tbody tr:hover{background:var(--panel2)}
.stock-table .sym{font-weight:800;font-family:'JetBrains Mono',monospace;color:#93c5fd}
.empty-state{color:var(--muted);text-align:center;padding:2rem 1rem;font-size:.95rem}

/* net chart */
.netchart-card{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem;margin-bottom:1rem}
.netchart-head{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--muted);font-weight:600;margin-bottom:.4rem}
.net-change{font-family:'JetBrains Mono',monospace;font-weight:700}
#netChart{width:100%;display:block}

/* business */
.income-banner{flex-basis:100%;background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(34,197,94,.02));
  border:1px solid rgba(34,197,94,.3);border-radius:10px;padding:.6rem .9rem;font-size:.95rem}
.income-banner b{color:var(--up);font-family:'JetBrains Mono',monospace}
.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.8rem}
.asset-card{display:flex;align-items:center;gap:.8rem;background:var(--bg2);border:1px solid var(--line);
  border-radius:12px;padding:.8rem}
.asset-icon{font-size:2rem;line-height:1}
.asset-body{flex:1;display:flex;flex-direction:column;gap:.1rem}
.asset-body small{font-size:.74rem}
.buy-asset{font-family:'JetBrains Mono',monospace;white-space:nowrap}

/* bank */
.bank-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem}
.bank-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:1.2rem}
.bank-card h3{margin-bottom:.6rem}
.bank-fig{font-size:1.05rem;margin-bottom:.2rem}
.bank-fig b{font-family:'JetBrains Mono',monospace;color:#7dd3fc}
.bank-card input{width:100%;margin:.8rem 0 .6rem;padding:.6rem .7rem;border-radius:9px;
  border:1px solid var(--line);background:var(--bg);color:var(--text);font:inherit;font-family:'JetBrains Mono',monospace}
.bank-card input:focus{outline:none;border-color:var(--accent)}
.bank-actions{display:flex;gap:.5rem}

/* leaderboard tags */
.ai-tag{font-size:.6rem;font-weight:700;background:rgba(167,139,250,.18);color:#c4b5fd;
  padding:.1rem .35rem;border-radius:6px;vertical-align:middle}
.you-tag{font-size:.6rem;font-weight:700;background:rgba(59,130,246,.2);color:#93c5fd;
  padding:.1rem .35rem;border-radius:6px;vertical-align:middle}
.lb-you{background:rgba(59,130,246,.08)}
.lb-you td{border-color:rgba(59,130,246,.3)}

/* settings */
.set-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:1.1rem;margin-bottom:1rem}
.set-card h3{margin-bottom:.5rem}
.set-card select{background:var(--bg);border:1px solid var(--line);color:var(--text);
  border-radius:9px;padding:.55rem .7rem;font:inherit;width:100%;max-width:340px}
.set-card select:focus{outline:none;border-color:var(--accent)}
.set-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}
.set-stat{display:flex;justify-content:space-between;background:var(--panel);border:1px solid var(--line);
  border-radius:9px;padding:.5rem .7rem;font-size:.85rem}
.set-stat span{color:var(--muted)} .set-stat b{font-family:'JetBrains Mono',monospace}

/* underworld */
.sub-h{margin:1.3rem 0 .6rem;font-size:1rem;font-weight:800}
.hack-grid,.bank-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}
.hack-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:1.1rem}
.hack-card h3{margin-bottom:.5rem}
.rival-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.7rem}
.rival-card{background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:.8rem}
.rival-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem}
.rival-card .hack-btn{width:100%;margin-top:.5rem}
.ally-create{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.8rem}
.ally-create input{flex:1;min-width:140px;background:var(--bg);border:1px solid var(--line);color:var(--text);
  border-radius:9px;padding:.5rem .7rem;font:inherit}
.ally-create input:focus{outline:none;border-color:var(--accent)}
.ally-grid{display:flex;flex-direction:column;gap:.5rem}
.ally-card{display:flex;justify-content:space-between;align-items:center;gap:.6rem;background:var(--bg2);
  border:1px solid var(--line);border-radius:10px;padding:.7rem .85rem}
.ally-card.mine{border-color:rgba(34,197,94,.45);background:linear-gradient(180deg,rgba(34,197,94,.06),var(--bg2))}
.ally-info{min-width:0}
.tier-pill{font-size:.62rem;font-weight:700;background:var(--panel);border:1px solid var(--line);
  padding:.1rem .4rem;border-radius:20px;vertical-align:middle;margin-left:.3rem}

/* my clan banner */
.my-clan{margin-bottom:1rem}
.no-clan{background:var(--bg2);border:1px dashed var(--line);border-radius:12px;padding:1.2rem;text-align:center;color:var(--muted)}
.clan-banner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem;
  background:linear-gradient(135deg,rgba(167,139,250,.12),var(--bg2));border:1px solid rgba(167,139,250,.35);
  border-radius:14px 14px 0 0;padding:1.1rem}
.clan-banner h3{font-size:1.2rem}
.clan-perks{display:flex;gap:.4rem;flex-wrap:wrap}
.perk{font-size:.78rem;font-weight:700;background:var(--panel);border:1px solid var(--line);padding:.3rem .6rem;border-radius:8px}
.perk.up{color:var(--up);border-color:rgba(34,197,94,.4)}
.clan-next{background:var(--bg2);border:1px solid var(--line);border-top:none;padding:.6rem 1.1rem}
.clan-members{background:var(--bg2);border:1px solid var(--line);border-top:none;padding:.5rem 1.1rem .7rem}
.clan-member{display:flex;justify-content:space-between;align-items:center;gap:.6rem;padding:.4rem 0;border-bottom:1px solid rgba(36,51,72,.5)}
.clan-member:last-child{border-bottom:none}
.clan-member.you{font-weight:700}
.clan-member-right{display:flex;align-items:center;gap:.5rem}
.clan-ctrl{display:flex;gap:.25rem}
.mini-btn{background:var(--panel2);border:1px solid var(--line);color:var(--text);border-radius:6px;
  width:24px;height:24px;cursor:pointer;font-size:.72rem;line-height:1;padding:0}
.mini-btn:hover{border-color:var(--accent)}
.mini-btn.danger:hover{border-color:var(--down);color:var(--down)}
.founder-tag{font-size:.58rem;font-weight:700;background:rgba(245,197,66,.2);color:var(--gold);padding:.08rem .3rem;border-radius:6px;margin-left:.3rem}
.clan-invite{display:flex;gap:.4rem;background:var(--bg2);border:1px solid var(--line);border-top:none;padding:.6rem 1.1rem}
.clan-invite input{flex:1;background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:.45rem .6rem;font:inherit}
.clan-invite input:focus{outline:none;border-color:var(--accent)}
/* clan chat */
.clan-chat{background:var(--bg2);border:1px solid var(--line);border-top:none;border-radius:0 0 14px 14px;padding:.7rem 1.1rem 1rem}
.chat-head{font-size:.78rem;font-weight:700;color:var(--muted);margin-bottom:.5rem}
.chat-messages{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:.35rem;margin-bottom:.6rem}
.chat-msg{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:.4rem .6rem;font-size:.86rem;align-self:flex-start;max-width:85%}
.chat-msg.you{align-self:flex-end;background:linear-gradient(135deg,#1e2c44,#23344f);border-color:var(--accent)}
.chat-msg b{color:#93c5fd;margin-right:.3rem}
.chat-input-row{display:flex;gap:.4rem}
.chat-input-row input{flex:1;background:var(--bg);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:.5rem .7rem;font:inherit}
.chat-input-row input:focus{outline:none;border-color:var(--accent)}

/* world */
.region-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.9rem}
.region-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:1.2rem 1rem;text-align:center;transition:.2s}
.region-card.unlocked{border-color:rgba(34,197,94,.4);background:linear-gradient(180deg,rgba(34,197,94,.06),var(--bg2))}
.region-card:hover{transform:translateY(-3px)}
.region-flag{font-size:2.6rem;line-height:1}
.region-card h3{margin:.4rem 0 .15rem;font-size:1.05rem}
.region-badge{color:var(--up);font-weight:700;font-size:.85rem}

/* badges */
.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.8rem}
.badge-card{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:1.1rem .8rem;
  text-align:center;opacity:.55;filter:grayscale(.6);transition:.2s}
.badge-card.earned{opacity:1;filter:none;border-color:rgba(245,197,66,.45);
  background:linear-gradient(180deg,rgba(245,197,66,.08),var(--bg2));box-shadow:0 0 0 1px rgba(245,197,66,.15)}
.badge-icon{font-size:2.2rem;line-height:1;margin-bottom:.35rem}
.badge-card strong{display:block;font-size:.92rem;margin-bottom:.25rem}
.badge-card small{color:var(--muted);font-size:.74rem;line-height:1.3;display:block}

/* news */
.news-feed{display:flex;flex-direction:column;gap:.55rem}
.news-item{display:flex;gap:.7rem;align-items:flex-start;background:var(--bg2);border:1px solid var(--line);
  border-left-width:3px;border-radius:10px;padding:.7rem .85rem}
.news-item.up{border-left-color:var(--up)} .news-item.down{border-left-color:var(--down)}
.news-item.crash{border-left-color:var(--down);background:rgba(239,68,68,.08)}
.news-icon{font-size:1.2rem}
.news-item p{font-size:.9rem;font-weight:500} .news-item small{color:var(--muted);font-size:.72rem}
.news-section{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  color:var(--muted);margin:.4rem 0 .1rem}
.news-item.real{text-decoration:none;color:inherit;border-left-color:var(--accent);transition:.15s}
.news-item.real:hover{border-color:var(--accent);background:var(--panel2)}

/* trade modal */
.trade-card{max-width:460px}
.modal-close{position:absolute;top:.7rem;right:.8rem;background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer}
.modal-close:hover{color:var(--text)}
.trade-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.6rem}
.trade-head strong{font-family:'JetBrains Mono',monospace;font-size:1.4rem;color:#93c5fd}
.trade-head .muted{display:block;font-size:.8rem}
.trade-price{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:1.25rem}
.chart-ranges{display:flex;gap:.25rem;margin:.5rem 0 .3rem}
.rbtn{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--muted);
  border-radius:7px;padding:.3rem;cursor:pointer;font-size:.72rem;font-weight:700}
.rbtn:hover{color:var(--text)}
.rbtn.active{background:var(--accent);border-color:transparent;color:#fff}
.chart-meta{text-align:center;margin:.1rem 0 .6rem;min-height:1rem}
#miniChart{width:100%;display:block;margin:.2rem 0}
.trade-info{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);margin-bottom:.7rem}
.qty-row{display:flex;gap:.35rem;align-items:center;margin-bottom:.5rem}
.qty-btn{flex:0 0 auto;background:var(--panel2);border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:.45rem .55rem;cursor:pointer;font-weight:700;font-size:.8rem}
.qty-btn:hover{border-color:var(--accent)}
#tradeQty{flex:1;text-align:center;background:var(--bg);border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:.5rem;font:inherit;font-family:'JetBrains Mono',monospace}
.qty-shortcuts{display:flex;gap:.35rem;margin-bottom:.7rem}
.chip{flex:1;background:var(--panel2);border:1px solid var(--line);color:var(--muted);
  border-radius:8px;padding:.35rem;cursor:pointer;font-size:.8rem;font-weight:600}
.chip:hover{border-color:var(--accent);color:var(--text)}
.trade-total{text-align:center;font-size:.9rem;color:var(--muted);margin-bottom:.8rem}
.trade-total b{color:var(--text);font-family:'JetBrains Mono',monospace}
.trade-actions{display:flex;gap:.6rem}

/* toast */
.toast{position:fixed;left:50%;bottom:1.4rem;transform:translate(-50%,140%);background:var(--panel2);
  border:1px solid var(--line);color:var(--text);padding:.7rem 1.1rem;border-radius:12px;box-shadow:var(--shadow);
  font-weight:600;font-size:.9rem;z-index:200;transition:transform .3s;max-width:90vw;text-align:center}
.toast.show{transform:translate(-50%,0)}
.toast.up{border-color:var(--up)} .toast.down{border-color:var(--down)} .toast.info{border-color:var(--accent)}

/* world map */
.world-map{margin-bottom:1.1rem;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--bg2)}
.map-svg{width:100%;height:auto;display:block}
.map-land{fill:#1d2c43;stroke:#2c405c;stroke-width:1.5}
.spot{cursor:pointer;outline:none}
.spot .spot-ring{fill:rgba(138,160,184,.12);stroke:var(--dim);stroke-width:2;transition:.18s}
.spot .spot-flag{font-size:22px;text-anchor:middle;dominant-baseline:middle}
.spot .spot-name{font-size:13px;font-weight:700;text-anchor:middle;fill:var(--muted)}
.spot:hover .spot-ring,.spot:focus .spot-ring{stroke:var(--accent);fill:rgba(59,130,246,.18)}
.spot.unlocked .spot-ring{stroke:var(--up);fill:rgba(34,197,94,.16)}
.spot.unlocked .spot-name{fill:#bdf0cf}
.spot.down .spot-ring{stroke:var(--down);fill:rgba(239,68,68,.16);animation:pulse 1.4s infinite}
.spot.locked .spot-ring{stroke-dasharray:4 4}
.spot-badge circle{fill:var(--gold);stroke:#1a1400;stroke-width:1}
.spot-badge-t{font-size:12px;font-weight:800;text-anchor:middle;fill:#1a1400}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* agency type chooser */
.agency-types{display:flex;flex-direction:column;gap:.5rem;margin:.4rem 0}
.agency-type{display:flex;align-items:center;gap:.7rem;text-align:left;background:var(--bg2);
  border:1px solid var(--line);border-radius:12px;padding:.6rem .8rem;cursor:pointer;color:var(--text);font:inherit;transition:.15s}
.agency-type:hover{border-color:var(--gold);transform:translateY(-1px)}
.agency-type:disabled,.agency-type.poor{opacity:.45;cursor:not-allowed;transform:none}
.at-icon{font-size:1.7rem;line-height:1}
.at-body{display:flex;flex-direction:column;flex:1;min-width:0}
.at-body small{font-size:.74rem}
.at-stats{color:var(--up);font-weight:700;font-family:'JetBrains Mono',monospace}
.at-cost{font-family:'JetBrains Mono',monospace;font-weight:800;color:var(--gold)}
.at-cash{text-align:right;margin-top:.3rem}
.agency-sub-h{margin:.7rem 0 .35rem;font-size:.82rem;letter-spacing:.02em;color:var(--muted);text-transform:uppercase}
.agency-sub-h:first-child{margin-top:0}
.agency-list{display:flex;flex-direction:column;gap:.45rem;margin:.3rem 0}
.agency-row{display:flex;align-items:center;gap:.7rem;background:var(--bg2);
  border:1px solid var(--line);border-radius:12px;padding:.55rem .8rem}
.agency-row.offline{opacity:.6;border-color:var(--down)}
.up-ag{white-space:nowrap;text-align:center;line-height:1.2}
.up-ag.poor{opacity:.45;cursor:not-allowed}
.up-ag small{font-weight:600}

/* mod badge + global chat */
.mod-tag{font-size:.58rem;font-weight:800;background:rgba(245,197,66,.18);color:var(--gold);
  padding:.08rem .35rem;border-radius:6px;border:1px solid rgba(245,197,66,.4);box-shadow:0 0 8px rgba(245,197,66,.25)}
.mod-tag.big{font-size:.72rem;padding:.2rem .5rem}
.mod-toolbar{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;background:linear-gradient(180deg,rgba(245,197,66,.08),var(--bg2));
  border:1px solid rgba(245,197,66,.3);border-radius:12px;padding:.6rem .9rem;margin-bottom:.8rem}
.global-chat{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:.9rem}
.chat-messages.big{max-height:52vh}
.chat-msg{position:relative}
.chat-msg.announce{align-self:stretch;max-width:100%;background:linear-gradient(180deg,rgba(245,197,66,.12),var(--panel));
  border-color:rgba(245,197,66,.5)}
.ann-tag{display:block;font-size:.6rem;font-weight:800;color:var(--gold);letter-spacing:.05em;margin-bottom:.15rem}
.msg-del{margin-left:.4rem;background:none;border:none;color:var(--dim);cursor:pointer;font-size:.78rem}
.msg-del:hover{color:var(--down)}

/* admin console */
.adm-list,.adm-chips{display:flex;flex-direction:column;gap:.35rem}
.adm-chips{flex-direction:row;flex-wrap:wrap}
.adm-row{display:flex;justify-content:space-between;align-items:center;gap:.6rem;flex-wrap:wrap}
.adm-actions{display:flex;gap:.3rem}
.adm-clan{border-top:1px solid var(--line);padding:.55rem 0}
.adm-clan:first-child{border-top:none}
.adm-members,.adm-msgs{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.4rem}
.adm-chip{display:inline-flex;align-items:center;gap:.3rem;background:var(--panel2);border:1px solid var(--line);
  border-radius:20px;padding:.15rem .5rem;font-size:.8rem}
.adm-chatroom{border-top:1px solid var(--line);padding:.55rem 0}
.adm-chatroom:first-child{border-top:none}
.adm-msgs{flex-direction:column}
.adm-msg{display:flex;justify-content:space-between;align-items:center;gap:.5rem;background:var(--panel);
  border:1px solid var(--line);border-radius:8px;padding:.3rem .55rem;font-size:.82rem}
.adm-msg b{color:#93c5fd;margin-right:.3rem}

/* strategy paths */
.strategy-pick{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.55rem;margin-top:.7rem}
.strat-card{display:flex;gap:.7rem;align-items:flex-start;text-align:left;background:var(--bg);
  border:1px solid var(--line);border-radius:12px;padding:.7rem .8rem;cursor:pointer;color:var(--text);font:inherit;transition:.15s}
.strat-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.strat-card.active{border-color:var(--gold);background:linear-gradient(180deg,rgba(245,197,66,.1),var(--bg));
  box-shadow:0 0 0 1px rgba(245,197,66,.25)}
.strat-card.locked,.strat-card:disabled{opacity:.45;cursor:not-allowed;transform:none}
.strat-card.locked:hover{border-color:var(--line);transform:none}
.strat-icon{font-size:1.8rem;line-height:1}
.strat-body{display:flex;flex-direction:column;min-width:0}
.strat-body b{font-size:.92rem;margin-bottom:.15rem}
.strat-body small{font-size:.74rem;line-height:1.35}
.strat-on{font-size:.6rem;font-weight:800;color:var(--gold)}

/* sub-tabs */
.subtabs{display:flex;gap:.3rem;margin-bottom:1rem;border-bottom:1px solid var(--line)}
.subtab{background:transparent;border:none;color:var(--muted);font:inherit;font-weight:700;
  padding:.5rem .9rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.subtab:hover{color:var(--text)}
.subtab.active{color:var(--text);border-bottom-color:var(--accent)}
.subview{display:none} .subview.active{display:block;animation:fade .25s ease}

/* prestige / dynasty */
.prestige-bar{height:8px;background:var(--bg);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin:.5rem 0 .3rem}
.prestige-bar span{display:block;height:100%;background:linear-gradient(90deg,#eab308,#f5c542)}

/* responsive */
@media(max-width:640px){
  .hide-sm{display:none}
  .stats-strip{order:3;flex-basis:100%}
  .stat{min-width:0;flex:1}
  .panel-head h2{font-size:1.1rem}
}

/* ===== trading depth: fees, shorts, orders ===== */
.trade-actions-2{display:flex;gap:.6rem;margin-top:.5rem}
.trade-actions-2 .btn{flex:1}
#tradeFee{margin-left:.3rem}
.order-box{margin-top:.8rem;border:1px solid var(--line);border-radius:10px;
  background:var(--panel2);padding:.4rem .7rem}
.order-box summary{cursor:pointer;font-weight:600;font-size:.9rem;padding:.3rem 0}
.order-box[open] summary{margin-bottom:.4rem}
.order-grid{display:grid;grid-template-columns:1.3fr .7fr 1fr auto;gap:.45rem;align-items:center}
.order-grid select,.order-grid input{background:var(--bg2);border:1px solid var(--line);
  color:var(--text);border-radius:8px;padding:.45rem .5rem;font:inherit;min-width:0}
@media(max-width:560px){ .order-grid{grid-template-columns:1fr 1fr} }

/* ===== PvP vault + raids ===== */
.vault-card{max-width:none}
.vault-card input{width:100%;background:var(--bg2);border:1px solid var(--line);
  color:var(--text);border-radius:8px;padding:.5rem;font:inherit;margin:.5rem 0}
.vault-log{margin-top:.6rem;display:flex;flex-direction:column;gap:.25rem}
.vlog{font-size:.8rem;padding:.3rem .5rem;border-radius:7px;background:var(--panel2);border:1px solid var(--line)}
.vlog.hit{border-color:var(--down);color:#ffd7d7}
.vlog.block{border-color:var(--up);color:#d7ffe0}

/* ===== clan goals + wars ===== */
.clan-war{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:.8rem 0}
@media(max-width:680px){ .clan-war{grid-template-columns:1fr} }
.war-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:.9rem 1rem}
.war-card h3{font-size:1rem;margin-bottom:.3rem}
.war-card .ally-create{margin-top:.6rem}
.war-card input,.war-card select{background:var(--bg2);border:1px solid var(--line);
  color:var(--text);border-radius:8px;padding:.45rem .5rem;font:inherit;min-width:0}
.war-active{border-color:var(--gold)}
.war-bars{display:flex;height:30px;border-radius:8px;overflow:hidden;margin:.5rem 0;border:1px solid var(--line)}
.war-bar{display:flex;align-items:center;justify-content:center;min-width:0;font-size:.72rem;font-weight:700;
  white-space:nowrap;overflow:hidden;transition:flex .4s}
.war-bar.us{background:linear-gradient(135deg,#16a34a,#22c55e)}
.war-bar.them{background:linear-gradient(135deg,#dc2626,#ef4444)}

/* ===== tab claim dot (quests) ===== */
.tab{position:relative}
.tab-dot{position:absolute;top:6px;right:4px;width:8px;height:8px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 2px var(--panel),0 0 8px var(--gold);animation:pulseDot 1.6s infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.45}}

/* ===== daily quests ===== */
.quest-reset{margin-top:.5rem;font-size:.85rem}
.quest-grid{display:grid;gap:.7rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.quest-card{display:flex;align-items:center;gap:.85rem;background:var(--bg2);border:1px solid var(--line);
  border-radius:var(--radius);padding:.85rem 1rem;transition:.15s}
.quest-card.ready{border-color:var(--gold);background:linear-gradient(180deg,rgba(245,197,66,.08),var(--bg2));
  box-shadow:0 0 0 1px rgba(245,197,66,.25)}
.quest-card.claimed{opacity:.55}
.quest-icon{font-size:1.7rem;line-height:1;flex-shrink:0}
.quest-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.3rem}
.quest-body strong{font-size:.95rem}
.quest-bar{height:7px;background:var(--bg);border:1px solid var(--line);border-radius:5px;overflow:hidden}
.quest-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#60a5fa);transition:width .3s}
.quest-card.ready .quest-bar span{background:linear-gradient(90deg,#eab308,#f5c542)}

/* ===== season banner ===== */
.season-banner{display:flex;align-items:center;gap:.6rem 1rem;flex-wrap:wrap;margin-bottom:.9rem;
  padding:.7rem .95rem;border-radius:var(--radius);border:1px solid var(--line);
  background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(167,139,250,.08))}
.season-tag{font-weight:800;background:linear-gradient(135deg,#60a5fa,#a78bfa);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.season-count{color:var(--muted);font-size:.85rem}
.season-champ{color:var(--muted);font-size:.82rem;margin-left:auto}

/* ===== notifications setting ===== */
.notify-status{margin:.5rem 0 .7rem}

/* ===== tutorial ===== */
.tut-card{max-width:440px;text-align:center}
.tut-progress{height:5px;background:var(--bg);border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-bottom:1.2rem}
.tut-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#a78bfa);transition:width .3s;width:0}
.tut-icon{font-size:3rem;line-height:1;margin-bottom:.3rem}
.tut-card h2{font-size:1.35rem;font-weight:800;margin-bottom:.5rem}
.tut-body{color:var(--muted);font-size:.92rem;line-height:1.5;min-height:4.5em}
.tut-body b{color:var(--text)}
.tut-dots{display:flex;justify-content:center;gap:.4rem;margin:1.1rem 0}
.tut-dots i{width:7px;height:7px;border-radius:50%;background:var(--line);transition:.2s}
.tut-dots i.on{background:var(--accent);transform:scale(1.25)}
.tut-actions{display:flex;align-items:center;gap:.5rem}
.tut-spacer{flex:1}
@media(max-width:640px){
  .tut-body{min-height:6em}
}

/* ===== accessibility: visible keyboard focus ===== */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
.btn:focus-visible,.tab:focus-visible,.subtab:focus-visible{outline:2px solid #93c5fd;outline-offset:2px}
/* don't show the focus ring for plain mouse clicks, only keyboard */
:focus:not(:focus-visible){outline:none}

/* respect reduced-motion preference */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .tabview.active,.subview.active{animation:none}
}

/* ===== mobile / small-screen polish ===== */
@media(max-width:640px){
  .layout{padding:.7rem}
  .panel{padding:.85rem}
  /* horizontal tab strip: smooth touch scroll, hide the scrollbar */
  .tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab{padding:.55rem .65rem;font-size:.9rem}
  /* denser tables so the remaining columns fit a phone without feeling cramped */
  .stock-table{font-size:.82rem}
  .stock-table thead th{padding:.4rem .45rem;font-size:.62rem}
  .stock-table tbody td{padding:.5rem .45rem}
  .stock-table .sym{white-space:nowrap}
  /* a scroll cue on wide tables */
  .table-wrap{position:relative}
  /* prevent iOS Safari from zooming in when focusing inputs (needs >=16px) */
  input,select,textarea{font-size:16px}
  .market-filters{width:100%}
  .market-filters input,.market-filters select{flex:1;min-width:0}
  /* roomier tap targets for the small icon buttons */
  .mini-btn{width:30px;height:30px}
  .qty-btn{padding:.55rem .6rem}
  .modal{padding:1.3rem}
}
@media(max-width:380px){
  .stat-v{font-size:.82rem}
  .brand-text small{display:none}
  .stock-table{font-size:.78rem}
}
