﻿*{box-sizing:border-box;margin:0;padding:0}

/* ── Root font size ─────────────────────────────────────────────────────────
   Default: scales with viewport AND respects the user's browser/OS font
   preference (set in browser settings for accessibility).
   JS setFont() overrides this explicitly when the user picks S/M/L/XL.
   No picker choice = smart default for their device.
   87.5% → 14px on a 16px browser | 112.5% → 18px on a 16px browser      */
html {
  font-size: clamp(87.5%, 1.2vw + 0.5%, 112.5%);
  -webkit-text-size-adjust: none;
  text-size-adjust: none; /* prevent mobile browsers auto-inflating text on rotation */
}

:root{
  --bg:#0f0f13;--bg2:#16161d;--bg3:#1e1e28;--bg4:#252532;
  --border:#2a2a3a;--border2:#3a3a50;
  --text:#e8e8f0;--text2:#9898b0;--text3:#5a5a72;
  --orange:#e87c3e;--orange2:#d06a2e;--orange-bg:rgba(232,124,62,0.12);
  --green:#4ade80;--green-bg:rgba(74,222,128,0.1);
  --red:#f87171;--red-bg:rgba(248,113,113,0.1);
  --amber:#fbbf24;--amber-bg:rgba(251,191,36,0.1);
  --blue:#60a5fa;--blue-bg:rgba(96,165,250,0.1);
  --purple:#a78bfa;--purple-bg:rgba(167,139,250,0.1);
  --radius:8px;--radius-lg:12px;
  --font:'Inter',system-ui,sans-serif;

  /* ── Type scale — Major Third ratio (×1.25), base 0.75rem ─────────────── */
  /* All values in rem so they scale automatically when html font-size changes */
  --fs-2xs:  0.6875rem; /* ~11px — tiny badges, officer labels (readability floor) */
  --fs-xs:   0.75rem;   /* 12px — captions, footnotes, icon labels            */
  --fs-sm:   0.8125rem; /* 13px — body text, table rows, tooltips             */
  --fs-base: 0.9375rem; /* 15px — nav buttons, inputs, card text              */
  --fs-md:   1rem;      /* 16px — section headings, modal body                */
  --fs-lg:   1.125rem;  /* 18px — card titles, panel headers                  */
  --fs-xl:   1.25rem;   /* 20px — page section titles                         */
  --fs-2xl:  1.5rem;    /* 24px — modal headers                               */
  --fs-3xl:  1.875rem;  /* 30px — stat numbers, fleet counts                  */
  --fs-4xl:  2.5rem;    /* 40px — hero values, big org stats                  */
}
/* Background removed — using org palette */

body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:var(--fs-base);min-height:100vh}
input,select,textarea,button{font-family:var(--font);font-size:var(--fs-base);color:var(--text)}
input,select,textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:8px 12px;color:var(--text);outline:none;transition:border-color .15s}
input:focus,select:focus,textarea:focus{border-color:var(--orange)}
input::placeholder,textarea::placeholder{color:var(--text3)}
select option{background:var(--bg3)}
button{cursor:pointer;border:none;border-radius:var(--radius);padding:8px 16px;transition:all .15s}
.btn{background:var(--bg3);border:1px solid var(--border2);color:var(--text);padding:7px 14px;border-radius:var(--radius)}
.btn:hover{border-color:var(--orange);color:var(--orange)}
.btn-orange{background:var(--orange);color:#fff;border:none}
.btn-orange:hover{background:var(--orange2)}
.btn-sm{padding:4px 10px;font-size:0.75rem}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--border2);color:var(--text)}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid transparent}
.btn-danger:hover{border-color:var(--red)}

/* Layout */
.app{display:flex;flex-direction:column;min-height:100vh}
.topbar{background:linear-gradient(135deg,#0c0c10 0%,#130707 100%);border-bottom:1px solid rgba(214,48,49,.25);padding:0 24px;display:flex;align-items:center;gap:16px;height:56px;position:sticky;top:0;z-index:50}
.topbar-logo{display:flex;align-items:center;gap:10px}
.logo-flame{font-size:1.375rem}
.topbar-logo-img{width:34px;height:34px;object-fit:contain;filter:drop-shadow(0 0 6px rgba(232,124,62,.35))}
.logo-text{font-size:1.1875rem;font-weight:600;color:var(--text)}
.logo-sub{font-size:0.75rem;color:var(--text3);margin-left:2px}
.topbar-nav{display:flex;gap:2px;margin-left:24px;flex:1}
.nav-btn{background:transparent;border:none;color:var(--text2);padding:7px 16px;border-radius:var(--radius);font-size:0.875rem;font-weight:500;transition:all .15s;display:flex;align-items:center;gap:6px}
.nav-btn:hover{background:var(--bg3);color:var(--text)}
.nav-btn.active{background:rgba(214,48,49,.15);color:#d63031}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.officer-badge{background:var(--orange-bg);color:var(--orange);border:1px solid rgba(232,124,62,.3);border-radius:99px;padding:3px 10px;font-size:0.75rem;font-weight:600;display:flex;align-items:center;gap:4px;cursor:default}
.member-badge{background:var(--bg3);color:var(--text2);border:1px solid var(--border);border-radius:99px;padding:3px 10px;font-size:0.75rem;display:flex;align-items:center;gap:4px}

.main{flex:1;max-width:1920px;margin:0 auto;width:100%;padding:20px 28px}
.view{display:none}.view:not(.active){display:none!important}
.views-wrap,.main-wrap{max-width:1800px!important}
.view.active{display:block;min-height:50vh}

/* Cards & grids */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 20px;margin-bottom:12px}
.card-sm{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:16px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.stat-label{font-size:0.75rem;color:var(--text3);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}
.stat-val{font-size:1.75rem;font-weight:600;color:var(--text)}
.stat-val.orange{color:var(--cb-red)}
.prog-bar{height:4px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-bottom:16px}
.prog-fill{height:100%;background:linear-gradient(90deg,#d63031,#e17055);border-radius:2px;transition:width .4s}

/* Filters */
.filter-bar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.filter-bar input{flex:1;min-width:160px;height:auto;padding:7px 12px}
.filter-bar select{height:auto;min-width:140px;padding:7px 10px}
.cat-pills{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}
.cpill{background:transparent;border:1px solid var(--border);color:var(--text2);padding:5px 14px;border-radius:99px;font-size:0.8125rem}
.cpill:hover{border-color:var(--border2);color:var(--text)}
.cpill.active{background:var(--orange);border-color:var(--orange);color:#fff}

/* Blueprint grid */
.bp-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;width:100%}
.bp-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;cursor:pointer;transition:all .15s;position:relative;min-height:150px}
.bp-card:hover{border-color:var(--border2);background:var(--bg3)}
.bp-card.owned{border-color:var(--orange);background:var(--orange-bg)}
.bp-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);position:absolute;top:10px;right:10px;transition:background .15s}
.bp-card.owned .bp-dot{background:var(--orange)}
.bp-name{font-size:0.9375rem;font-weight:500;color:var(--text);margin-bottom:3px;padding-right:14px;line-height:1.35}
.bp-faction{font-size:0.75rem;color:var(--text3);margin-bottom:4px}
.bp-pills{display:flex;gap:3px;flex-wrap:wrap}
.tag{font-size:0.6875rem;padding:2px 6px;border-radius:99px;font-weight:600}
.tag-weapon{background:rgba(248,113,113,.15);color:#fca5a5}
.tag-armor{background:rgba(96,165,250,.15);color:#93c5fd}
.tag-ammo{background:rgba(74,222,128,.15);color:#86efac}
.tag-ship{background:rgba(251,191,36,.15);color:#fde68a}
.tag-component{background:rgba(167,139,250,.15);color:#c4b5fd}
.tag-lawful{background:rgba(74,222,128,.1);color:#86efac}
.tag-unlawful{background:rgba(248,113,113,.1);color:#fca5a5}

/* Modal */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:24px;max-width:480px;width:100%;max-height:85vh;overflow-y:auto}
.modal h2{font-size:1.25rem;font-weight:600;margin-bottom:6px}
.modal-close{float:right;background:none;border:none;color:var(--text2);font-size:1.125rem;cursor:pointer;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-sect{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}
.modal-sect h3{font-size:0.6875rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}
.faction-badge{display:inline-block;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:3px 10px;font-size:0.75rem;color:var(--text2);margin:2px}
.ext-link{font-size:0.75rem;color:var(--orange);text-decoration:none;display:inline-flex;align-items:center;gap:4px;margin-top:6px}
.ext-link:hover{text-decoration:underline}

/* Section headers */
.section-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.section-title{font-size:1.25rem;font-weight:600;color:var(--text)}
.section-sub{font-size:0.875rem;color:var(--text3);margin-top:2px}
.section-label{font-size:0.75rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin:16px 0 8px}
/* Bank section headers */
.bank-section-hdr{display:flex;align-items:center;gap:10px;margin:24px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.bank-section-title{font-size:0.9375rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.06em}
.bank-section-count{font-size:0.6875rem;font-weight:700;color:var(--text3);background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:2px 8px;letter-spacing:.04em}
/* Bank item stats modal */
#bank-item-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:500;align-items:center;justify-content:center;padding:20px}
#bank-item-modal.open{display:flex}
.bank-item-modal-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);max-width:480px;width:100%;max-height:85vh;overflow-y:auto}
.bank-item-modal-banner{height:5px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.bank-item-modal-body{padding:20px}
.bank-item-modal-name{font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:4px}
.bank-item-modal-meta{font-size:0.8125rem;color:var(--text3);margin-bottom:14px}
.bank-item-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.bank-item-stat{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}
.bank-item-stat-val{font-size:1.25rem;font-weight:700;color:var(--orange);line-height:1}
.bank-item-stat-lbl{font-size:0.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-top:3px}
/* Clickable bank tiles */
.comp-card{cursor:pointer;transition:border-color .15s,background .15s}
.comp-card:hover{border-color:var(--border2);background:var(--bg3)}

/* Component bank */
.comp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-bottom:4px}
.comp-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.comp-name{font-size:0.875rem;font-weight:500;color:var(--text);flex:1}
.qty-row{display:flex;align-items:center;gap:6px}
.qty-btn{width:26px;height:26px;border-radius:50%;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:0.9375rem;display:flex;align-items:center;justify-content:center;line-height:1}
.qty-btn:hover{border-color:var(--orange);color:var(--orange)}
.qty-val{font-size:0.9375rem;font-weight:600;color:var(--text3);min-width:30px;text-align:center}
.qty-val.has-stock{color:var(--orange)}

/* Resources */
.res-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px}
.res-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}
.res-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.res-name{font-size:0.9375rem;font-weight:500;color:var(--text)}
.res-meta{font-size:0.6875rem;color:var(--text3);margin-bottom:4px;line-height:1.4}
.res-note{font-size:0.6875rem;color:var(--amber);margin-bottom:6px}
.res-qty-row{display:flex;align-items:center;gap:8px}
.res-label{font-size:0.6875rem;color:var(--text3);flex:1}
.res-input{width:80px;text-align:center;height:30px;font-size:0.8125rem}
.res-unit{font-size:0.6875rem;color:var(--text3)}
.tag-ore{background:rgba(251,191,36,.12);color:#fde68a}
.tag-gem{background:rgba(167,139,250,.12);color:#c4b5fd}
.tag-gas{background:rgba(96,165,250,.12);color:#93c5fd}
.tag-refined{background:rgba(74,222,128,.12);color:#86efac}
.tag-other{background:rgba(156,163,175,.12);color:#9ca3af}

/* Raffles */
.raffle-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;margin-bottom:10px}
.raffle-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.raffle-name{font-size:1.125rem;font-weight:600;color:var(--text)}
.raffle-meta{font-size:0.75rem;color:var(--text3);margin-top:3px}
.status-pill{font-size:0.6875rem;padding:3px 10px;border-radius:99px;font-weight:600}
.status-open{background:var(--green-bg);color:var(--green)}
.status-closed{background:var(--bg4);color:var(--text3)}
.status-drawn{background:var(--amber-bg);color:var(--amber)}
.entrants-wrap{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}
.entrant-chip{font-size:0.75rem;padding:3px 10px;border-radius:99px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);display:flex;align-items:center;gap:4px}
.entrant-chip.winner{background:var(--amber-bg);border-color:var(--amber);color:var(--amber)}
.chip-x{cursor:pointer;color:var(--text3);font-size:0.6875rem;line-height:1}
.chip-x:hover{color:var(--red)}
.enter-row{display:flex;gap:6px;margin-top:6px}
.enter-row input{flex:1;height:32px}
.raffle-actions{display:flex;gap:6px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);flex-wrap:wrap}
.winner-banner{background:var(--amber-bg);border:1px solid rgba(251,191,36,.3);border-radius:var(--radius);padding:8px 12px;font-size:0.875rem;font-weight:600;color:var(--amber);margin-top:8px}

/* Donations */
.donation-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;margin-bottom:8px}
.donation-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.donation-item{font-size:0.875rem;font-weight:500;color:var(--text)}
.donation-meta{font-size:0.75rem;color:var(--text3)}
.donation-actions{display:flex;gap:6px;margin-top:8px}
.pending-badge{background:var(--blue-bg);color:var(--blue);border-radius:99px;padding:2px 8px;font-size:0.6875rem;font-weight:600}

/* Craft timers */
.timer-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;margin-bottom:10px}
.timer-display{font-size:2.5rem;font-weight:700;color:var(--orange);font-variant-numeric:tabular-nums;letter-spacing:.02em}
.timer-label{font-size:0.8125rem;color:var(--text3);margin-top:4px}
.timer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin-bottom:16px}
.timer-ref-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px}
.timer-ref-name{font-size:0.8125rem;font-weight:500;color:var(--text);margin-bottom:4px}
.timer-ref-meta{font-size:0.6875rem;color:var(--text3)}

/* Log */
.log-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:0.75rem}
.log-row:last-child{border-bottom:none}
.log-action{color:var(--text);flex:1}
.log-actor{color:var(--text3)}
.log-time{color:var(--text3);font-size:0.6875rem;white-space:nowrap}
.log-qty{color:var(--orange);font-weight:600;min-width:50px}

/* PIN overlay */
.pin-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;display:flex;align-items:center;justify-content:center}
.pin-box{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:32px;max-width:320px;width:90%;text-align:center}
.pin-box h2{font-size:1.125rem;font-weight:600;margin-bottom:6px}
.pin-box p{font-size:0.8125rem;color:var(--text3);margin-bottom:20px}
.pin-input{width:100%;text-align:center;font-size:1.25rem;letter-spacing:.2em;height:48px;margin-bottom:12px}
.pin-error{color:var(--red);font-size:0.75rem;margin-bottom:10px;min-height:16px}

/* Toast */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:500;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius);padding:10px 16px;font-size:0.8125rem;color:var(--text);animation:slideIn .2s ease;max-width:300px}
.toast.success{border-color:rgba(74,222,128,.4);color:var(--green)}
.toast.error{border-color:rgba(248,113,113,.4);color:var(--red)}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}

/* Forms */
.form-row{display:flex;gap:8px;margin-bottom:8px}
.form-row input,.form-row select,.form-row textarea{flex:1}
.form-label{font-size:0.75rem;color:var(--text3);margin-bottom:4px}
textarea{resize:vertical;min-height:60px}

/* Divider */
.divider{height:1px;background:var(--border);margin:20px 0}

/* Vault sidebar in raffles */
.raffles-layout{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}
.vault-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;position:sticky;top:70px}
.vault-panel-hdr{font-size:0.8125rem;font-weight:600;color:var(--text);margin-bottom:4px;display:flex;align-items:center;justify-content:space-between}
.vault-panel-sub{font-size:0.75rem;color:var(--text3);margin-bottom:12px}
.vault-section-lbl{font-size:0.6875rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;margin:10px 0 5px}
.vault-item{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border)}
.vault-item:last-child{border-bottom:none}

.vault-empty{font-size:0.6875rem;color:var(--text3);font-style:italic;padding:4px 0}
.vault-raffle-btn{font-size:0.6875rem;padding:2px 7px;background:rgba(251,191,36,.1);color:var(--amber);border:1px solid rgba(251,191,36,.25);border-radius:99px;cursor:pointer}
.vault-raffle-btn:hover{background:rgba(251,191,36,.2)}
@media(max-width:900px){.raffles-layout{grid-template-columns:1fr}}

/* Font size control */
.font-picker{display:flex;align-items:center;gap:5px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:3px 8px}
.font-picker-label{font-size:0.6875rem;color:var(--text3);white-space:nowrap}
.font-btn{background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text2);padding:2px 7px;font-size:0.6875rem;cursor:pointer;transition:all .15s;line-height:1.4}
.font-btn:hover{border-color:var(--border2);color:var(--text)}
.font-btn.factive{background:var(--orange-bg);border-color:var(--orange);color:var(--orange)}
/* Scaled text classes applied to body */
/* Font scale — single root font-size cascades everywhere */
html{font-size:1.0625rem}
body,button,input,select,textarea{font-size:1rem}
.section-title{font-size:1.25rem}
.section-sub{font-size:0.875rem}
.bp-name{font-size:1rem}
.comp-name{font-size:0.9375rem}
.res-name{font-size:1rem}
.modal h2{font-size:1.375rem}
.nav-btn{font-size:0.8125rem}
.tag{font-size:0.75rem}
.font-picker-label{font-size:0.75rem}
.stat-val{font-size:1.75rem}
.raffle-name{font-size:1.1rem}
.modal-sect h3{font-size:1rem}
.timer-ref-name{font-size:0.9375rem}
.fab-note{font-size:0.875rem}
th,td{font-size:0.875rem}

/* BP size and class color tags */
.tag-s0{background:rgba(156,163,175,.15);color:#9ca3af;border:1px solid rgba(156,163,175,.25)}
.tag-s1{background:rgba(74,222,128,.12);color:#86efac;border:1px solid rgba(74,222,128,.2)}
.tag-s2{background:rgba(96,165,250,.12);color:#93c5fd;border:1px solid rgba(96,165,250,.2)}
.tag-s3{background:rgba(251,191,36,.12);color:#fde68a;border:1px solid rgba(251,191,36,.2)}
.tag-s4{background:rgba(251,146,60,.15);color:#fdba74;border:1px solid rgba(251,146,60,.25)}
.tag-s5{background:rgba(248,113,113,.12);color:#fca5a5;border:1px solid rgba(248,113,113,.2)}
.tag-s6{background:rgba(232,121,249,.12);color:#f0abfc;border:1px solid rgba(232,121,249,.2)}
.tag-s7,.tag-s8{background:rgba(167,139,250,.12);color:#c4b5fd;border:1px solid rgba(167,139,250,.2)}
.tag-class{background:rgba(45,212,191,.1);color:#5eead4;border:1px solid rgba(45,212,191,.2);font-size:0.6875rem}

/* ── Mission cards ─────────────────────────────────────────────────────────── */
.mc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px}
.mc{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:border-color .15s,transform .1s}
.mc:hover{border-color:var(--border2);transform:translateY(-1px)}
.mc-hdr{padding:12px 14px 10px;display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.mc-icon{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mc-faction{font-size:0.75rem;font-weight:600}
.mc-title{font-size:0.9375rem;font-weight:600;color:var(--text);margin-top:2px;line-height:1.3}
.mc-badge{font-size:0.6875rem;padding:3px 8px;border-radius:99px;font-weight:700;white-space:nowrap;flex-shrink:0;letter-spacing:.04em}
.mc-lawful{background:rgba(74,222,128,.15);color:#86efac;border:1px solid rgba(74,222,128,.25)}
.mc-unlawful{background:rgba(248,113,113,.15);color:#fca5a5;border:1px solid rgba(248,113,113,.25)}
.mc-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.mc-meta-cell{padding:7px 10px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border)}
.mc-meta-cell:last-child{border-right:none}
.mc-meta-lbl{font-size:0.6875rem;font-weight:700;letter-spacing:.08em;color:var(--text3);text-transform:uppercase}
.mc-meta-val{font-size:0.75rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-pool-preview{padding:8px 14px 10px}
.mc-pool-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.mc-pool-bar-wrap{flex:1;height:3px;background:var(--bg4);border-radius:2px;overflow:hidden}
.mc-pool-bar{height:100%;background:linear-gradient(90deg,var(--orange),#f59e0b);border-radius:2px}
.mc-pool-pct{font-size:0.6875rem;font-weight:700;color:var(--orange);min-width:32px;text-align:right}
.mc-bp-chips{display:flex;flex-wrap:wrap;gap:3px;margin-top:4px}
.mc-bp-chip{font-size:0.6875rem;padding:2px 7px;border-radius:99px;background:var(--bg3);border:1px solid var(--border);color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.mc-more{font-size:0.6875rem;color:var(--text3);padding:2px 7px}

/* ── Mission detail modal ──────────────────────────────────────────────────── */
#mc-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .2s}
#mc-modal.open{opacity:1;pointer-events:all}
.mc-modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:540px;max-height:85vh;overflow-y:auto}
.mc-modal-hdr{padding:20px 18px 14px;display:flex;align-items:flex-start;justify-content:space-between;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1}
.mc-modal-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mc-modal-faction{font-size:0.8125rem;font-weight:600}
.mc-modal-title{font-size:1.125rem;font-weight:700;color:var(--text);margin-top:3px}
.mc-modal-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid var(--border)}
.mc-modal-cell{padding:10px 14px;display:flex;flex-direction:column;gap:2px;border-right:1px solid var(--border)}
.mc-modal-cell:last-child{border-right:none}
.mc-modal-pool{padding:14px 18px;border-bottom:1px solid var(--border)}
.mc-modal-pool:last-child{border-bottom:none}
.mc-modal-pool-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.mc-modal-pool-title{font-size:0.6875rem;font-weight:700;letter-spacing:.06em;color:var(--text3);text-transform:uppercase}
.mc-modal-pool-count{font-size:0.6875rem;color:var(--text3)}
.mc-modal-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.mc-modal-bar-wrap{flex:1;height:4px;background:var(--bg4);border-radius:2px;overflow:hidden}
.mc-modal-bar{height:100%;border-radius:2px}
.mc-modal-bp-row{display:flex;align-items:center;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.mc-modal-bp-row:last-child{border-bottom:none}
.mc-modal-bp-left{display:flex;align-items:center;gap:6px;min-width:0}
.mc-modal-bp-name{font-size:0.8125rem;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:230px}
.mc-modal-bp-mfr{font-size:0.6875rem;color:var(--text3);flex-shrink:0}
.mc-modal-bp-pct{font-size:0.8125rem;font-weight:700;color:var(--orange);flex-shrink:0}

/* Donate pane */
.donate-pane{position:fixed;right:0;top:0;height:100%;width:360px;background:var(--bg2);border-left:1px solid var(--border);z-index:500;transform:translateX(100%);transition:transform .25s ease;display:flex;flex-direction:column;box-shadow:-4px 0 20px rgba(0,0,0,.4)}
.donate-pane.open{transform:translateX(0)}
.donate-pane-hdr{padding:20px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.donate-pane-title{font-size:1rem;font-weight:600;color:var(--text)}
.donate-pane-body{flex:1;overflow-y:auto;padding:20px}
.donate-pane-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:499;display:none}
.donate-pane-overlay.open{display:block}
/* Item search dropdown */
.item-search-wrap{position:relative}
.item-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);z-index:100;max-height:200px;overflow-y:auto;display:none}
.item-dropdown.open{display:block}
.item-dropdown-row{padding:7px 10px;cursor:pointer;font-size:0.875rem;color:var(--text);border-bottom:1px solid var(--border)}
.item-dropdown-row:last-child{border-bottom:none}
.item-dropdown-row:hover{background:var(--bg3);color:var(--orange)}

.tag-component{background:rgba(96,165,250,.12);color:#93c5fd;border:1px solid rgba(96,165,250,.2)}
.tag-shipweapon{background:rgba(251,146,60,.12);color:#fdba74;border:1px solid rgba(251,146,60,.2)}

/* Ore detail modal */
#ore-modal,#gear-modal{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s}
#ore-modal.open,#gear-modal.open{opacity:1;pointer-events:all}
/* Centered, wider detail panel — gives the dense loadout/stats content room to breathe */
.ore-modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:660px;height:auto;max-height:96vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.5);transform:scale(.97);transition:transform .2s ease}
#ore-modal.open .ore-modal-box,#gear-modal.open .ore-modal-box{transform:scale(1)}
/* Two-column variant: ore info on the left, loadout/tester on the right */
.ore-modal-box.two-col{max-width:940px}
.ore-cols{display:flex;align-items:stretch}
.ore-cols>.ore-col-left{flex:1 1 0;min-width:0;border-right:1px solid var(--border)}
.ore-cols>.ore-col-right{flex:1 1 0;min-width:0}
.ore-cols>.ore-col-right .ore-sect{border-bottom:none}
.ore-modal-hdr{padding:20px 18px 12px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg2);z-index:1;display:flex;justify-content:space-between;align-items:flex-start}
.ore-modal-name{font-size:1.25rem;font-weight:700;color:var(--text)}
.ore-modal-rarity{font-size:0.6875rem;padding:3px 10px;border-radius:99px;font-weight:700;margin-top:4px;display:inline-block}
.ore-sect{padding:12px 18px;border-bottom:1px solid var(--border)}
.ore-sect:last-child{border-bottom:none}
.ore-sect-title{font-size:0.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:8px}
.ore-stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px}
.ore-stat{background:var(--bg3);border-radius:var(--radius);padding:8px 10px;text-align:center}
.ore-stat-val{font-size:1rem;font-weight:700;color:var(--text)}
.ore-stat-lbl{font-size:0.6875rem;color:var(--text3);margin-top:2px}
.ore-instab-bar{height:6px;border-radius:3px;margin:6px 0 2px}
.ore-loc-chip{display:inline-block;font-size:0.75rem;padding:3px 10px;border-radius:99px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);margin:2px}
.ore-sys-chip{display:inline-block;font-size:0.75rem;padding:3px 10px;border-radius:99px;margin:2px;font-weight:600}
.ore-sys-stanton{background:rgba(96,165,250,.15);color:#93c5fd;border:1px solid rgba(96,165,250,.25)}
.ore-sys-pyro{background:rgba(251,146,60,.15);color:#fdba74;border:1px solid rgba(251,146,60,.25)}
.ore-sys-nyx{background:rgba(45,212,191,.15);color:#5eead4;border:1px solid rgba(45,212,191,.25)}
.ore-danger-pip{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:3px}
.ore-craft-chip{display:inline-block;font-size:0.75rem;padding:3px 10px;border-radius:99px;background:var(--orange-bg);border:1px solid rgba(232,124,62,.3);color:var(--orange);margin:2px}
/* Clickable res cards */
.res-card{cursor:pointer;transition:border-color .15s,transform .1s}
.res-card:hover{border-color:var(--border2);transform:translateY(-1px)}

/* Raffle timers */
.raffle-timer{display:flex;align-items:center;gap:6px;margin-top:6px;padding:6px 10px;background:var(--bg3);border-radius:var(--radius);border:1px solid var(--border)}
.raffle-timer-digits{font-family:monospace;font-size:1rem;font-weight:700;color:var(--orange);letter-spacing:.04em}
.raffle-timer-digits.ending{color:#f87171;animation:pulse-red 1s infinite}
.raffle-timer-label{font-size:0.6875rem;color:var(--text3)}
.raffle-set-timer{font-size:0.6875rem;color:var(--text3);cursor:pointer;text-decoration:underline;margin-left:auto}
@keyframes pulse-red{0%,100%{opacity:1}50%{opacity:.5}}

/* Floating raffle panel */
#raffle-float{position:fixed;bottom:20px;right:20px;width:300px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(0,0,0,.5);z-index:400;transform:translateY(calc(100% + 24px));transition:transform .3s ease;overflow:hidden}
#raffle-float.visible{transform:translateY(0)}

.bpm-own-btn{display:block;width:100%;padding:10px 8px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg3);cursor:pointer;text-align:center;transition:all .15s;font-size:0.875rem;font-weight:500;color:var(--text)}
.bpm-own-btn:hover{background:var(--bg4);border-color:var(--border2)}
.bpm-own-btn.active{background:rgba(232,124,62,.18);border-color:var(--orange);color:var(--orange);font-weight:600}
.bpm-own-btn.active-green{background:rgba(74,222,128,.12);border-color:rgba(74,222,128,.35);color:#86efac;font-weight:600}

select,input,textarea,button{font-size:inherit}
select option{font-size:inherit;background:var(--bg2);color:var(--text)}
.filter-bar select,.filter-bar input{font-size:0.875rem}
body.fs-l .filter-bar select,body.fs-l .filter-bar input{font-size:1rem}
body.fs-xl .filter-bar select,body.fs-xl .filter-bar input{font-size:1.0625rem}

@media(max-width:767px){.officer-grid{grid-template-columns:1fr}}

.officer-log-row:last-child{border-bottom:none}

.request-card:last-child{border-bottom:none}

.vault-summary-row:last-child{border-bottom:none}

/* Org member HUD */
.org-hud{position:fixed;top:64px;right:16px;width:240px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:100;box-shadow:0 4px 20px rgba(0,0,0,.4);transform:translateX(calc(100% + 20px));transition:transform .25s ease}
.org-hud.open{transform:translateX(0)}
.org-hud-toggle{position:fixed;top:68px;right:0;background:var(--bg3);border:1px solid rgba(74,222,128,.2);border-left:none;border-radius:var(--radius) 0 0 var(--radius);padding:10px 7px;cursor:pointer;z-index:101;writing-mode:vertical-rl;display:flex;flex-direction:column;align-items:center;gap:5px;transition:background .15s,border-color .15s}
.org-hud-toggle:hover{background:rgba(34,197,94,.08);border-color:rgba(74,222,128,.45)}
.org-hud-toggle-lbl{font-size:0.6875rem;font-weight:700;letter-spacing:.07em;color:#5a8068;text-transform:uppercase;transition:color .15s}
.org-hud-toggle:hover .org-hud-toggle-lbl{color:#4ade80}
#discord-online-count{font-size:0.8125rem;font-weight:800;color:#4ade80;line-height:1}
#sc-patch-version{font-size:0.6875rem;font-weight:800;color:var(--orange);line-height:1}
.online-dot-pulse{width:7px;height:7px;background:#4ade80;border-radius:50%;display:block;position:relative}
.online-dot-pulse::after{content:'';position:absolute;inset:-3px;border-radius:50%;background:rgba(74,222,128,.35);animation:pulse-ring 2.2s ease-out infinite}
@keyframes pulse-ring{0%{transform:scale(.7);opacity:.9}70%{transform:scale(1.7);opacity:0}100%{transform:scale(1.7);opacity:0}}
.online-dot-sm{display:inline-block;width:7px;height:7px;background:#4ade80;border-radius:50%;margin-right:5px;vertical-align:middle}
.fab-roster-list{display:flex;flex-wrap:wrap;gap:4px;overflow:hidden;transition:max-height .3s ease}
.fab-roster-list.collapsed{max-height:68px}
.fab-roster-list.expanded{max-height:360px;overflow-y:auto}
.fab-member-chip{font-size:0.6875rem;color:var(--text2);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.07);border-radius:3px;padding:2px 6px;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;cursor:default;transition:background .1s}
.fab-member-chip:hover{background:rgba(255,255,255,.11)}
.fab-member-chip img{width:13px;height:13px;border-radius:50%;object-fit:cover}
.fab-member-chip .fmc-init{width:13px;height:13px;border-radius:50%;background:var(--orange-bg);color:var(--orange);font-size:0.4375rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
@media(max-width:767px){.org-hud,.org-hud-toggle{display:none}}
.org-hud-hdr{padding:10px 12px 8px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.org-hud-title{font-size:0.75rem;font-weight:700;color:var(--orange);letter-spacing:.04em}
.org-hud-body{padding:8px 0;max-height:400px;overflow-y:auto}
.org-member-row{display:flex;align-items:center;gap:8px;padding:5px 12px;transition:background .1s}
.org-member-row:hover{background:var(--bg3)}
.org-member-avatar{width:24px;height:24px;border-radius:50%;background:var(--bg4);flex-shrink:0;overflow:hidden}
.org-member-avatar img{width:100%;height:100%;object-fit:cover}
.org-member-name{font-size:0.75rem;color:var(--text);font-weight:500}
.org-member-rank{font-size:0.6875rem;color:var(--text3)}
.org-hud-footer{padding:8px 12px;border-top:1px solid var(--border);font-size:0.6875rem;color:var(--text3);text-align:center}
.org-hud-loading{padding:16px;text-align:center;color:var(--text3);font-size:0.75rem}
.org-hud-stats{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 12px 8px;border-bottom:1px solid var(--border);margin-bottom:4px}
.org-hud-stat-main{display:flex;flex-direction:column;align-items:center;gap:1px}
.org-hud-stat-sub{display:flex;flex-direction:column;align-items:center;gap:1px}
.org-hud-stat-num{font-size:1.25rem;font-weight:800;color:var(--orange);line-height:1}
.org-hud-stat-num-sm{font-size:0.9rem;font-weight:700;color:var(--text2);line-height:1}
.org-hud-stat-lbl{font-size:0.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);font-weight:600}
.org-hud-stat-divider{width:1px;height:28px;background:var(--border)}

.bp-card-banner{height:4px;width:100%}
.bp-card-body{padding:10px 12px;flex:1;display:flex;flex-direction:column;gap:4px}
.bp-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:6px}
.bp-owned-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);flex-shrink:0;margin-top:4px}
.bp-card.owned .bp-owned-dot{background:var(--orange)}
.bp-mfr-line{font-size:0.6875rem;font-weight:600;letter-spacing:.05em;color:var(--text3);text-transform:uppercase}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border2)}

/* System & legality colored tags */
.tag-stanton{background:rgba(96,165,250,.18);color:#93c5fd;border:1px solid rgba(96,165,250,.25)}
.tag-pyro{background:rgba(251,146,60,.18);color:#fdba74;border:1px solid rgba(251,146,60,.25)}
.tag-nyx{background:rgba(167,139,250,.18);color:#c4b5fd;border:1px solid rgba(167,139,250,.25)}
.tag-stanton-pyro{background:rgba(96,165,250,.12);color:#93c5fd;border:1px solid rgba(96,165,250,.2)}
.tag-illegal{background:rgba(248,113,113,.18);color:#fca5a5;border:1px solid rgba(248,113,113,.3)}
.tag-legal{background:rgba(74,222,128,.12);color:#86efac;border:1px solid rgba(74,222,128,.2)}
.tag-multi{background:rgba(251,191,36,.12);color:#fde68a;border:1px solid rgba(251,191,36,.2)}

/* View toggle */
.view-toggle{display:flex;gap:4px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:3px}
.vt-btn{background:transparent;border:none;color:var(--text3);padding:5px 12px;border-radius:6px;font-size:0.8125rem;display:flex;align-items:center;gap:5px;transition:all .15s}
.vt-btn.active{background:var(--bg2);color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.3)}
.vt-btn svg{flex-shrink:0}

/* Table view */
.bp-table{width:100%;border-collapse:collapse;font-size:0.875rem}
.bp-table th{text-align:left;padding:9px 12px;font-size:0.6875rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);background:var(--bg3);white-space:nowrap}
.bp-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}
.bp-table tr:hover td{background:var(--bg3);cursor:pointer}
.bp-table tr.owned-row td{background:var(--orange-bg)}
.bp-table tr.owned-row:hover td{background:rgba(232,124,62,.18)}
.bp-owned-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);display:inline-block}
.bp-owned-dot.on{background:var(--orange)}
.bp-org-dot{width:8px;height:8px;border-radius:50%;background:var(--border2);display:inline-block;margin-left:4px}
.bp-org-dot.on{background:var(--green)}
.tags-cell{display:flex;gap:3px;flex-wrap:wrap}

/* Tile size slider */
.slider-wrap{display:flex;align-items:center;gap:10px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:6px 12px}
.slider-wrap label{font-size:0.75rem;color:var(--text3);white-space:nowrap}
.slider-wrap input[type=range]{-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;background:var(--border2);outline:none;cursor:pointer;flex:1;min-width:80px}
.slider-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--orange);cursor:pointer}
.slider-val{font-size:0.75rem;color:var(--orange);font-weight:600;min-width:24px;text-align:right}

/* Responsive */
@media(max-width:640px){
  .topbar-nav .nav-btn span{display:none}
    .bp-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}
}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE / MOBILE STYLES
   Base: desktop (1024px+)
   Tablet: 768–1023px
   Mobile: <768px
   Small mobile: <480px
═══════════════════════════════════════════════════════ */

/* Tablet */
@media(max-width:1023px) {
  .main{padding:0 16px 16px}
  .bp-grid{grid-template-columns:repeat(4,1fr)}
  .topbar{padding:0 16px;gap:10px}
  .font-picker{display:none}
  .section-hdr{flex-wrap:wrap;gap:8px}
  .bpm-stat-row{grid-template-columns:repeat(3,1fr)}
  .mc-modal-meta{grid-template-columns:repeat(3,1fr)}
}

/* Mobile */
@media(max-width:767px) {
  /* Layout */
  html{font-size:1.0rem}
  .main{padding:0 10px 80px}
  .topbar{padding:0 12px;height:50px;gap:8px}
  .topbar-title{font-size:1rem}
  .font-picker{display:none}

  /* Nav — scrollable bottom bar on mobile */
  .topbar-nav{
    position:fixed;bottom:0;left:0;right:0;
    background:var(--bg2);border-top:1px solid var(--border);
    display:flex;align-items:center;
    height:58px;z-index:200;padding:0 4px;
    box-shadow:0 -4px 16px rgba(0,0,0,.3);
    overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;gap:0
  }
  .topbar-nav::-webkit-scrollbar{display:none}
  .nav-btn{
    flex-direction:column;gap:1px;padding:5px 10px;
    font-size:0.6875rem;border-radius:8px;
    min-width:54px;flex-shrink:0;
    justify-content:center;align-items:center;border:none;
    background:none;color:var(--text3)
  }
  .nav-btn svg{width:18px;height:18px}
  .nav-btn span{display:block!important;font-size:0.6875rem;line-height:1.3;text-align:center;white-space:nowrap}
  .nav-btn.active{background:rgba(214,48,49,.15);color:#d63031}

  /* BP grid — 2 cols on mobile */
  .bp-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .bp-card{min-height:120px}
  .bp-card-body{padding:8px 10px 8px}
  .bp-name{font-size:0.8125rem}

  /* Filter bar — horizontal scroll */
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-bar input,.filter-bar select,.filter-bar button{flex-shrink:0;font-size:0.8125rem;height:auto}
  .filter-bar input{min-width:160px}

  /* BP category pills — horizontal scroll */
  .bp-cats{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}
  .bp-cats::-webkit-scrollbar{display:none}
  .bp-cats button{flex-shrink:0}

  /* Modals — full screen bottom sheet */
  .modal-overlay{align-items:flex-end;padding:0}
  .modal{max-width:100%;width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:90vh;padding:0}
  #wikelo-modal{align-items:flex-end;padding:0}
  #wikelo-modal .modal{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .bp-modal-content{border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .bpm-hdr{padding:14px 16px 10px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .bpm-stat-row{grid-template-columns:repeat(3,1fr);gap:6px}
  .bpm-stat{padding:6px 8px}
  .bpm-stat-val{font-size:0.875rem}
  .bpm-own-row{grid-template-columns:1fr}
  .bpm-own-row button+button{margin-top:6px}

  /* Section headers */
  .section-hdr{flex-direction:column;align-items:flex-start;gap:8px}
  .section-hdr>div:last-child{width:100%;display:flex;gap:6px;flex-wrap:wrap}

  /* Org bank */
  .comp-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px}
  .comp-card{padding:8px 10px}
  .comp-name{font-size:0.8125rem}

  /* Resources */
  .res-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:6px}
  .res-card{padding:10px}
  .res-name{font-size:0.875rem}
  
  /* Ore modal — full-width bottom sheet on phones (overrides the desktop right-dock) */
  .ore-modal-box{border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:auto;max-height:90vh;max-width:none;box-shadow:0 -8px 40px rgba(0,0,0,.4);transform:translateY(16px)}
  #ore-modal.open .ore-modal-box,#gear-modal.open .ore-modal-box{transform:translateY(0)}
  #ore-modal,#gear-modal{align-items:flex-end;justify-content:center;padding:0}
  .ore-modal-box.two-col{max-width:none}
  .ore-cols{flex-direction:column}
  .ore-cols>.ore-col-left{border-right:none;border-bottom:1px solid var(--border)}
  .ore-stat-grid{grid-template-columns:repeat(3,1fr);gap:6px}

  /* Fabricator */
  .timer-grid{grid-template-columns:1fr}
  .timer-ref-grid{grid-template-columns:repeat(2,1fr)!important}

  /* Raffles */
  .raffles-layout{grid-template-columns:1fr}
  .raffle-card{padding:12px}
  
  /* Floating raffle FAB — above bottom nav */
  #raffle-float{
    position:fixed!important;bottom:0!important;left:0!important;right:0!important;
    width:100%!important;max-width:100%!important;border-radius:16px 16px 0 0!important;
    max-height:70vh!important;overflow-y:auto!important;
    transform:translateY(100%)!important;transition:transform .3s ease!important;
    z-index:300!important;
  }
  #raffle-float.visible{transform:translateY(0)!important}

  /* Donate pane — full screen on mobile */
  .donate-pane{width:100%;border-left:none;border-top:1px solid var(--border);
    border-radius:var(--radius-lg) var(--radius-lg) 0 0;top:auto;bottom:0;height:85vh;
    transform:translateY(100%)}
  .donate-pane.open{transform:translateY(0)}

  /* Mission cards modal */
  #mc-modal{align-items:flex-end;padding:0}
  .mc-modal-box{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:90vh;max-width:100%}
  .mc-meta{grid-template-columns:repeat(2,1fr)}
  .mc-modal-meta{grid-template-columns:repeat(2,1fr)}

  /* Topbar right — hide non-essential */
  .topbar-right .btn{font-size:0.75rem;padding:4px 8px}
  

  /* Table view — horizontal scroll */
  .bp-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .bp-table{min-width:600px}

  /* Forms */
  .form-row{flex-direction:column}
  input,select,textarea{font-size:1.0rem!important} /* prevent iOS zoom */
}

/* Small mobile (iPhone SE etc) */
@media(max-width:390px) {
  .bp-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .topbar-title{font-size:0.9rem}
  .nav-btn{min-width:36px}
  .topbar{gap:4px}
  
}

/* Landscape mobile */
@media(max-width:767px) and (orientation:landscape) {
  .main{padding-bottom:70px}
  .topbar-nav{height:52px}
  #raffle-float{bottom:60px}
}

/* Touch targets — ensure 44px minimum */
@media(hover:none) {
  .nav-btn,.btn,.qty-btn,.font-btn,.tag,.comp-cat-btn{min-height:36px}
  .bp-card{cursor:pointer}
  select,input[type=range]{height:auto}
}

#bp-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;align-items:center;justify-content:center;padding:20px}
#bp-modal.open{display:flex}
#bp-modal .modal{max-width:560px;width:100%;padding:0;max-height:90vh;overflow:hidden}

/* New raffle modal */
#new-raffle-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;padding:20px}
#new-raffle-modal.open{display:flex}
#new-raffle-modal .modal{padding:24px}
/* Wikelo contract modal */
#wikelo-modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;align-items:center;justify-content:center;padding:20px}
#wikelo-modal.open{display:flex}
#wikelo-modal .modal{max-width:540px;width:100%;padding:0;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}

/* Wikelo clickable tiles */
.wikelo-tile{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform .15s,border-color .15s,box-shadow .15s}
.wikelo-tile:hover{transform:translateY(-2px);border-color:var(--border2);box-shadow:0 6px 20px rgba(0,0,0,.3)}

/* Wikelo tracker tabs */
.wt-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:0}
.wt-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-size:0.875rem;font-weight:600;color:var(--text3);cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}
.wt-tab:hover{color:var(--text)}
.wt-tab.active{color:var(--orange);border-bottom-color:var(--orange)}

/* ── LOOT RUN TRACKER ──────────────────────────────────────────────────────── */
.lr-preset{background:var(--bg3);border:1px solid var(--border2);color:var(--text2);padding:4px 10px;border-radius:99px;font-size:0.75rem;cursor:pointer;transition:all .15s;white-space:nowrap}
.lr-preset:hover{border-color:var(--orange);color:var(--orange)}
.loot-run-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:10px;overflow:hidden}
.loot-run-hdr{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;transition:background .15s}
.loot-run-hdr:hover{background:rgba(255,255,255,.03)}
.loot-run-body{padding:0 16px 14px;border-top:1px solid var(--border)}
.loot-run-body table{color:var(--text)}
.loot-run-body tbody tr{border-bottom:1px solid rgba(255,255,255,.04);transition:background .1s}
.loot-run-body tbody tr:hover{background:rgba(255,255,255,.02)}
.li-result-row{display:flex;align-items:center;padding:8px 12px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.05);transition:background .1s}
.li-result-row:hover{background:rgba(255,255,255,.06)}
.li-result-row:last-child{border-bottom:none}

/* Old float FABs hidden — merged into Cinderborn FAB */

/* FAB removed — code kept in app.js for future use */

/* ── CINDERBORN BRAND BUTTON (bottom-right) ─────────────────────────────────── */

/* ── FLEET VIEWER ────────────────────────────────────────────────────────────── */
/* Fleet counter row */
.fleet-counter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.fleet-counter-total{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 20px;display:flex;flex-direction:column;align-items:center;min-width:90px}
.fleet-counter-total .fc-num{font-size:2.25rem;font-weight:800;color:var(--text);line-height:1}
.fleet-counter-total .fc-label{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);margin-top:3px}
.fleet-counter{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 16px;display:flex;flex-direction:column;align-items:center;min-width:80px;border-top:3px solid var(--fc-color);transition:border-color .15s}
.fleet-counter .fc-icon{font-size:1.25rem;margin-bottom:2px}
.fleet-counter .fc-num{font-size:1.875rem;font-weight:800;color:var(--fc-color,var(--text));line-height:1}
.fleet-counter .fc-label{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-top:2px}
.fleet-counter .fc-sub{font-size:0.6875rem;color:var(--text3);margin-top:1px;opacity:.7}
.fleet-role-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
@media(max-width:640px){.fleet-counter-row{gap:6px}.fleet-counter{min-width:60px;padding:10px 10px}.fleet-counter .fc-num{font-size:1.5rem}.fleet-counter-total .fc-num{font-size:1.875rem}}
.fleet-stat-total{display:flex;flex-direction:column;align-items:center;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 16px;min-width:60px}
.fleet-stat-total span:first-child{font-size:1.5rem;font-weight:800;color:var(--text);line-height:1}
.fleet-stat-total span:last-child{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3)}
.fleet-stat-chip{font-size:0.75rem;font-weight:600;padding:5px 12px;border-radius:99px;border:1px solid;white-space:nowrap}
.fleet-filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.fleet-filter-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text3);padding:5px 12px;border-radius:99px;font-size:0.8125rem;cursor:pointer;transition:all .15s;white-space:nowrap}
.fleet-filter-btn:hover{border-color:var(--border2);color:var(--text)}
.fleet-filter-btn.active{font-weight:600}

.fleet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,240px));gap:12px;justify-content:start}
.fleet-empty{padding:60px;text-align:center;color:var(--text3);grid-column:1/-1}

/* Ship card — GPU-accelerated hover (no box-shadow transition = no repaint per frame) */
.fleet-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
  transition:transform .15s,border-color .15s;position:relative;
  will-change:transform} /* pre-promote to compositor layer */
/* Shadow lives on a pseudo-element so it composites independently — no repaint */
.fleet-card::after{content:'';position:absolute;inset:0;border-radius:var(--radius-lg);
  box-shadow:0 8px 24px rgba(0,0,0,.4);opacity:0;transition:opacity .15s;pointer-events:none}
.fleet-card:hover{transform:translateY(-3px);border-color:var(--role-color,var(--border2))}
.fleet-card:hover::after{opacity:1}
.fleet-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--role-color,#94a3b8);z-index:1}
/* Quick-add button — CSS hover only, no inline JS handlers */
.fleet-card-add{width:100%;margin-top:8px;padding:5px 0;border-radius:6px;font-size:var(--fs-xs);font-weight:700;cursor:pointer;letter-spacing:.04em;transition:opacity .15s}
.fleet-card-add:hover{opacity:.75}
.fleet-card-img{height:140px;background:var(--bg3);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.fleet-card-img-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2.5rem;opacity:.2}
.fleet-card-body{padding:12px 14px}
.fleet-card-role{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.fleet-card-name{font-size:0.9375rem;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:2px}
.fleet-card-mfr{font-size:0.6875rem;color:var(--text3);margin-bottom:8px}
.fleet-card-owner{display:flex;align-items:center;gap:7px;padding-top:8px;border-top:1px solid var(--border)}
.fleet-card-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#d63031,#7b0000);display:flex;align-items:center;justify-content:center;font-size:0.6875rem;font-weight:700;color:#fff;flex-shrink:0}
.fleet-card-owner span{font-size:0.75rem;color:var(--text2);font-weight:600}
.fleet-card-notes{font-size:0.6875rem;color:var(--text3);margin-top:6px;font-style:italic}

/* Ship search autocomplete */
.fr-result{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,.04);transition:background .1s}
.fr-result:hover{background:rgba(255,255,255,.06)}
.fr-result:last-child{border-bottom:none}

/* ── FLEET SHIP PICKER ────────────────────────────────────────────────────── */
#fleet-picker-panel{animation:slideInRight .2s ease-out}
@keyframes slideInRight{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}

/* Grid = single-column list for alphabetical browsing */
#fr-ship-grid{grid-template-columns:1fr !important;align-content:start}

/* Row style for ship list items */
.fpc-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius);cursor:pointer;transition:background .1s,border-left-color .1s;border-left:3px solid transparent}
.fpc-row:hover{background:rgba(255,255,255,.04);border-left-color:var(--rc,var(--border2))}
.fpc-row.selected{background:rgba(255,255,255,.07);border-left-color:var(--rc,var(--orange))}
.fpc-row-img{width:48px;height:32px;border-radius:4px;background:var(--bg3);overflow:hidden;flex-shrink:0;display:none} /* hidden — only show on hover in future */
.fpc-name{font-size:0.8125rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fpc-meta{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}

/* ── CINDERBORN FAB ────────────────────────────────────────────────────────── */
#cb-fab{position:fixed;bottom:20px;left:20px;width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,#1a1d2e,#252840);border:1px solid rgba(251,149,36,.4);cursor:pointer;z-index:9500;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.5);transition:transform .2s,box-shadow .2s;animation:cb-pulse 3s ease-in-out infinite}
#cb-fab:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(0,0,0,.6),0 0 0 6px rgba(251,149,36,.12)}
#cb-fab-logo{width:46px;height:46px;object-fit:contain;border-radius:50%;pointer-events:none}
#cb-fab-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(251,149,36,.25);animation:cb-ring 3s ease-in-out infinite;pointer-events:none}
@keyframes cb-pulse{0%,100%{box-shadow:0 4px 20px rgba(0,0,0,.5),0 0 0 0 rgba(251,149,36,.2)}50%{box-shadow:0 4px 20px rgba(0,0,0,.5),0 0 0 5px rgba(251,149,36,.06)}}
@keyframes cb-ring{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:0;transform:scale(1.15)}}

#cb-fab-panel{position:fixed;bottom:100px;left:20px;width:290px;z-index:9400;pointer-events:none;opacity:0;transform:translateY(10px) scale(.97);transform-origin:bottom left;transition:opacity .2s,transform .2s;filter:drop-shadow(0 8px 32px rgba(0,0,0,.6))}
#cb-fab-panel.open{pointer-events:all;opacity:1;transform:translateY(0) scale(1)}
#cb-fab-panel-inner{background:#13161f;border:1px solid rgba(82,100,180,.2);border-radius:14px;overflow:hidden}

.cb-fab-hdr{display:flex;align-items:center;gap:10px;padding:14px 14px 12px;border-bottom:1px solid rgba(255,255,255,.06)}
.cb-fab-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid rgba(255,255,255,.06)}
.cb-fab-stat{display:flex;flex-direction:column;align-items:center;padding:12px 6px;gap:2px}
.cb-fab-stat span:first-child{font-size:1.375rem;font-weight:800;color:#eaedf5}
.cb-fab-stat span:last-child{font-size:0.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#5a6480;text-align:center}
.cb-fab-discord{display:flex;align-items:center;justify-content:center;gap:8px;margin:12px 14px 6px;padding:10px;background:#5865f2;border-radius:8px;color:#fff;font-size:0.875rem;font-weight:700;text-decoration:none;transition:background .15s}
.cb-fab-discord:hover{background:#4752c4}
.cb-fab-links{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;font-size:0.6875rem}
.cb-fab-links a{color:#5a6480;text-decoration:none;transition:color .15s}
.cb-fab-links a:hover{color:#eaedf5}
.cb-fab-sep{color:#2a2e3a}
@media(max-width:400px){#cb-fab{bottom:14px;left:14px;width:58px;height:58px}#cb-fab-logo{width:38px;height:38px}#cb-fab-panel{left:14px;width:calc(100vw - 28px)}}

/* ── SC VERSION BADGE ── */
#sc-version-badge{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fb923c;background:rgba(251,146,60,.08);border:1px solid rgba(251,146,60,.35);border-radius:99px;animation:sc-badge-pulse 3s ease-in-out infinite;cursor:default;padding:3px 9px;white-space:nowrap;box-shadow:0 0 8px rgba(251,146,60,.25),0 0 0 0 rgba(251,146,60,.2);animation:sc-ver-glow 3s ease-in-out infinite}
@keyframes sc-ver-glow{0%,100%{box-shadow:0 0 6px rgba(251,146,60,.25),0 0 12px rgba(251,146,60,.08)}50%{box-shadow:0 0 12px rgba(251,146,60,.5),0 0 22px rgba(251,146,60,.2)}}

/* ── BANK LAYOUT (sidebar nav + main) ── */
.bank-layout{display:flex;gap:0;align-items:flex-start}
.bank-nav{width:150px;flex-shrink:0;position:sticky;top:72px;max-height:calc(100vh - 90px);overflow-y:auto;padding-right:10px}
.bank-main{flex:1;min-width:0}
.bank-nav-hdr{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);padding:4px 10px 8px}
.bank-nav-btn{display:block;width:100%;text-align:left;background:none;border:none;border-left:2px solid transparent;color:var(--text3);font-size:0.75rem;padding:5px 10px;cursor:pointer;border-radius:0 var(--radius) var(--radius) 0;transition:color .15s,border-color .15s,background .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bank-nav-btn:hover{background:rgba(255,255,255,.04);border-left-color:var(--orange);color:var(--text)}
.bank-nav-grp{font-size:0.45rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);padding:10px 10px 3px;margin-top:4px}
@media(max-width:680px){
  .bank-layout{flex-direction:column}
  .bank-nav{width:100%;position:static;max-height:none;padding-right:0;padding-bottom:4px}
  #bank-nav-list{display:flex;overflow-x:auto;gap:4px;padding-bottom:4px}
  .bank-nav-btn{white-space:nowrap;flex-shrink:0;border-left:none;border-bottom:2px solid transparent;border-radius:var(--radius)}
  .bank-nav-btn:hover{border-bottom-color:var(--orange);border-left-color:transparent}
}

/* ── RAFFLE TIMER REDESIGN ── */
.raffle-timer-wrap{margin-top:10px;padding:8px 12px;background:var(--bg3);border-radius:var(--radius);border:1px solid var(--border)}
.raffle-timer-active{display:flex;align-items:center;gap:8px}
.raffle-timer-set{display:flex;align-items:center;gap:5px;flex-wrap:wrap}
.raffle-timer-set-label{font-size:0.6875rem;color:var(--text3);flex-shrink:0}
.raffle-tpre{background:var(--bg2);border:1px solid var(--border2);color:var(--text2);padding:3px 9px;border-radius:var(--radius);font-size:0.75rem;cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.raffle-tpre:hover{border-color:var(--orange);color:var(--orange)}
.raffle-timer-clear{font-size:0.6875rem !important;padding:2px 7px !important;color:var(--text3) !important;border-color:var(--border) !important}

/* ── OFFICER TAB (full view) ── */
#view-officer{padding-bottom:20px}
.off-view-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:0;flex-wrap:wrap}
.off-tab-btn{padding:10px 20px;font-size:0.8125rem;font-weight:600;cursor:pointer;color:var(--text3);background:none;border:none;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}
.off-tab-btn:hover{color:var(--text)}
.off-tab-btn.active{color:var(--orange);border-bottom-color:var(--orange)}
.off-view-body{padding-top:16px}
.off-section{min-height:60px}
.off-tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:4px}

/* ── BP QUICK ADD (bottom of tile) ── */
.bp-quick-add-btn{display:block;width:100%;margin-top:8px;padding:5px 8px;font-size:0.6875rem;font-weight:700;letter-spacing:.04em;text-align:center;border-radius:4px;cursor:pointer;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--text3);opacity:0.45;transition:opacity .15s,border-color .15s,color .15s,background .15s}
.bp-card:hover .bp-quick-add-btn{opacity:1;border-color:rgba(232,124,62,.5);color:var(--orange)}
.bp-quick-add-btn.owned{opacity:0.7;border-color:rgba(232,124,62,.35);color:var(--orange);background:var(--orange-bg)}
.bp-card:hover .bp-quick-add-btn.owned{opacity:1}

/* ── VAULT PANEL ROWS ── */
.vault-panel-row{display:flex;align-items:center;gap:6px;padding:5px 0;border-bottom:1px solid var(--border);font-size:0.8125rem}
.vault-panel-row:last-child{border-bottom:none}
.vault-panel-name{flex:1;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vault-panel-qty{color:var(--orange);font-weight:700;flex-shrink:0}

/* ── BLUEPRINT BANNER ── */
.bp-banner{display:flex;align-items:flex-end;gap:20px;padding:14px 18px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:14px;flex-wrap:wrap}
.bp-banner-stat{flex:1;min-width:140px}
.bp-banner-num{font-size:2.25rem;font-weight:800;color:var(--orange);line-height:1;letter-spacing:-.01em}
.bp-banner-sub{font-size:0.75rem;color:var(--text3);margin-top:2px;font-weight:500}
.bp-banner-track{height:5px;background:var(--bg4);border-radius:3px;overflow:hidden;width:100%;margin-top:6px}
.bp-banner-label{font-size:0.6875rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}
.bp-banner-fill{height:100%;background:var(--orange);border-radius:3px;transition:width .5s ease}
.bp-banner-filters{display:flex;gap:6px;flex-shrink:0;align-self:flex-start;padding-top:2px}
.bp-src-btn{padding:6px 14px;font-size:0.75rem;font-weight:600;border-radius:6px;cursor:pointer;border:1px solid var(--border2);background:transparent;color:var(--text3);transition:all .15s;white-space:nowrap}
.bp-src-btn:hover{border-color:var(--border2);color:var(--text)}
.bp-src-btn.active{background:var(--orange);border-color:var(--orange);color:#fff}
/* hide old stat-grid/prog-bar since replaced by banner */
#bp-stats{display:none!important}
.prog-bar{display:none!important}

/* ── BANK STOCK BANNER ── */
#bank-stock-bar{align-items:center;gap:8px;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap}
.bank-stock-label{font-size:0.6875rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;flex-shrink:0}
.bank-stock-pills{display:flex;gap:5px;flex-wrap:wrap;flex:1}
.bank-stock-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:99px;background:var(--bg3);border:1px solid var(--border);cursor:pointer;transition:border-color .15s;font-size:0.6875rem;user-select:none}
.bank-stock-pill:hover{border-color:var(--orange)}
.bank-stock-name{color:var(--text);font-weight:500}
.bank-stock-qty{color:var(--orange);font-weight:700;font-size:0.75rem}

/* ── BANK INVENTORY FLOAT ── */

/* ── OFF STATS PILLS ── */
.off-stat-pill{background:rgba(214,48,49,.15);border-radius:99px;padding:2px 8px;display:flex;align-items:center;gap:4px}


.sc-updates-btn{border-color:rgba(251,149,36,.2)!important}
.sc-updates-btn:hover{background:rgba(251,149,36,.08)!important;border-color:rgba(251,149,36,.45)!important}
.sc-updates-btn .org-hud-toggle-lbl{color:var(--orange)!important}

.sc-patch-link{display:block;padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.05);text-decoration:none;transition:background .1s}
.sc-patch-link:hover{background:rgba(255,255,255,.04)}

@keyframes sc-badge-pulse{0%,100%{box-shadow:0 0 0 0 rgba(251,149,36,.0);border-color:rgba(251,149,36,.35)}50%{box-shadow:0 0 6px 2px rgba(251,149,36,.25);border-color:rgba(251,149,36,.7)}}

.discord-avatar-sm{width:18px;height:18px;border-radius:50%;object-fit:cover;flex-shrink:0}

#sc-updates-hud{top:90px !important;right:20px !important;width:280px}

/* ── Special recognition: HACKERMANS matrix theme ─────────────────────────── */
.tag-matrix{
  font-weight:500;
  color:#7dffaa;
  text-shadow:0 0 2px rgba(0,255,65,.35);
}
.special-tag{
  display:inline-block;
  margin-left:6px;
  font-size:0.6875rem;
  font-weight:600;
  letter-spacing:.18em;
  padding:2px 9px;
  border-radius:99px;
  vertical-align:middle;
  white-space:nowrap;
}
/* High-contrast readable badge: dark text on solid matrix green */
.tag-matrix-tag{
  font-family:inherit;            /* same font as the Owner badge */
  color:#4ade80;                 /* matrix green */
  background:#0a0d0a;            /* dark background */
  border:1px solid #2f6b40;
  text-shadow:none;
  box-shadow:0 0 5px rgba(74,222,128,.2);
  font-weight:600;               /* not bold */
}

/* ── Fabricator quality sliders — itemfab-style gradient track ─────────────── */
/* ── Holographic ship stage (mining ship loadout) ─────────────────────────── */
.holo-stage{position:relative;height:260px;margin:0;overflow:hidden;
  background:radial-gradient(ellipse at 50% 60%,rgba(34,211,238,.12),rgba(10,14,20,.0) 70%),linear-gradient(180deg,#070b12,#0a0f17);
  border-bottom:1px solid var(--border)}
.holo-stage model-viewer{filter:brightness(1.25) saturate(1.5) hue-rotate(150deg) drop-shadow(0 0 10px rgba(34,211,238,.5));opacity:.92}
.holo-grid{position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(34,211,238,.10) 1px,transparent 1px),linear-gradient(90deg,rgba(34,211,238,.10) 1px,transparent 1px);
  background-size:26px 26px;mask-image:radial-gradient(ellipse at 50% 70%,#000 35%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at 50% 70%,#000 35%,transparent 75%)}
.holo-scan{position:absolute;left:0;right:0;height:40px;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(34,211,238,.18),transparent);
  animation:holoScan 3.2s linear infinite}
@keyframes holoScan{0%{top:-40px}100%{top:260px}}
.holo-tag{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:0.6875rem;letter-spacing:.1em;
  text-transform:uppercase;color:#67e8f9;text-shadow:0 0 6px rgba(34,211,238,.5);pointer-events:none}
.holo-loading,.holo-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#67e8f9;text-shadow:0 0 8px rgba(34,211,238,.5)}
.holo-loading{font-size:0.8125rem;letter-spacing:.08em}
.holo-fallback{font-size:4rem;opacity:.5;filter:drop-shadow(0 0 14px rgba(34,211,238,.6))}
/* Clickable hardpoint nodes */
.holo-hotspot{position:absolute;top:48%;transform:translate(-50%,-50%);width:26px;height:26px;border-radius:50%;
  background:rgba(34,211,238,.18);border:1.5px solid #22d3ee;color:#cffafe;font-size:0.6875rem;font-weight:800;
  cursor:pointer;z-index:3;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 10px rgba(34,211,238,.6);text-shadow:0 0 4px rgba(0,0,0,.5);transition:transform .12s,background .12s}
.holo-hotspot:hover{background:rgba(34,211,238,.4);transform:translate(-50%,-50%) scale(1.18)}
.holo-hotspot.active{background:var(--orange);border-color:var(--orange);box-shadow:0 0 12px rgba(245,158,11,.8)}
/* Native model-viewer 3D hotspots (anchored to the ship, rotate with it) */
.holo-hp{display:flex;flex-direction:column;align-items:center;cursor:pointer;background:none;border:none;padding:0}
.holo-hp .holo-hp-dot{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;
  background:rgba(34,211,238,.22);border:1.5px solid #22d3ee;color:#cffafe;font-size:0.6875rem;font-weight:800;
  box-shadow:0 0 10px rgba(34,211,238,.7);transition:transform .12s,background .12s}
.holo-hp:hover .holo-hp-dot{background:rgba(34,211,238,.5);transform:scale(1.2)}
.holo-hp.active .holo-hp-dot{background:var(--orange);border-color:var(--orange);box-shadow:0 0 12px rgba(245,158,11,.9)}
.holo-hp .holo-hp-label{margin-top:2px;font-size:0.4375rem;font-weight:700;letter-spacing:.03em;color:#67e8f9;
  text-shadow:0 0 4px #000,0 0 4px #000;white-space:nowrap;pointer-events:none;max-width:90px;overflow:hidden;text-overflow:ellipsis}
/* Keep ALL hotspots visible even when behind the hull (so every turret shows) */
model-viewer{--min-hotspot-opacity:1}
/* Equipment category buttons — bigger, friendlier */
#gear-cats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.gear-cat{display:inline-flex;align-items:center;gap:8px;background:var(--bg3);border:1px solid var(--border);
  border-radius:10px;padding:10px 16px;color:var(--text2);font-size:var(--fs-base);font-weight:700;cursor:pointer;
  transition:border-color .12s,color .12s,background .12s}
.gear-cat:hover{border-color:var(--border2);color:var(--text)}
.gear-cat.active{background:var(--orange);border-color:var(--orange);color:#fff}
.gear-cat-ico{font-size:1.15rem;line-height:1}
@media(max-width:600px){ .gear-cat{flex:1;justify-content:center;padding:10px 8px;font-size:var(--fs-sm)} }
/* Holo "position hardpoints" editor buttons */
.holo-edit-btn{position:absolute;bottom:8px;right:10px;z-index:6;background:rgba(7,11,18,.85);
  border:1px solid rgba(34,211,238,.4);color:#67e8f9;border-radius:99px;padding:3px 10px;
  font-size:0.6875rem;font-weight:700;cursor:pointer}
.holo-edit-btn:hover{background:rgba(34,211,238,.2)}
.holo-edit-btn.active{background:var(--orange);border-color:var(--orange);color:#fff}
.holo-reset-btn{right:92px;padding:3px 9px}
/* Hardpoint nudge editor pad */
.holo-editpad{position:absolute;left:10px;bottom:10px;z-index:7;width:188px;background:rgba(7,11,18,.94);
  border:1px solid rgba(34,211,238,.45);border-radius:10px;padding:9px 10px;box-shadow:0 6px 24px rgba(0,0,0,.55)}
.holo-editpad .hep-title{font-size:0.6875rem;font-weight:800;color:#67e8f9;margin-bottom:6px}
.holo-editpad .hep-row{display:flex;gap:5px;margin-bottom:7px}
.holo-editpad .hep-hp{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:4px 0;font-weight:700;font-size:0.75rem;cursor:pointer}
.holo-editpad .hep-hp.active{background:var(--orange);border-color:var(--orange);color:#fff}
.holo-editpad .hep-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.holo-editpad .hep-grid button{background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:6px;padding:6px 0;font-size:0.6875rem;font-weight:600;cursor:pointer}
.holo-editpad .hep-grid button:hover{border-color:#22d3ee;color:#67e8f9}
.holo-editpad .hep-actions{display:flex;gap:5px;margin-top:8px}
.holo-editpad .hep-actions button{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text2);border-radius:6px;padding:6px 0;font-size:0.6875rem;font-weight:700;cursor:pointer}
.holo-editpad .hep-actions .hep-save{background:var(--orange);border-color:var(--orange);color:#fff}
/* In-holo hardpoint picker overlay */
.holo-picker{position:absolute;left:10px;bottom:34px;width:200px;z-index:5;
  background:rgba(7,11,18,.92);border:1px solid rgba(34,211,238,.4);border-radius:8px;padding:8px 10px;
  box-shadow:0 6px 24px rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.holo-hotspot-ring{position:absolute;inset:-6px;border-radius:50%;border:1.5px solid rgba(34,211,238,.5);animation:holoPulse 1.8s ease-out infinite}
@keyframes holoPulse{0%{transform:scale(.7);opacity:.9}100%{transform:scale(1.6);opacity:0}}
/* Panel pulse when a hardpoint is clicked */
.hp-pulse{animation:hpPulse 1s ease}
@keyframes hpPulse{0%{box-shadow:inset 0 0 0 2px rgba(34,211,238,.7)}100%{box-shadow:inset 0 0 0 2px rgba(34,211,238,0)}}

/* Fabricator quick-search chips — CSS :hover so they never stick highlighted */
.fab-chip{background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:5px 14px;color:var(--text2);font-size:var(--fs-sm);cursor:pointer;font-weight:600;transition:border-color .12s,color .12s}
.fab-chip:hover{border-color:var(--orange);color:var(--orange)}

/* ── Resource Solver — clean look ─────────────────────────────────────────── */
.solver-quick-lbl{font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-right:2px}
.solver-shuffle{padding:5px 10px}
.solver-chip{display:inline-flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid rgba(245,158,11,.35);border-radius:99px;padding:5px 6px 5px 12px;font-size:0.8125rem;color:var(--text)}
.solver-chip-x2{color:var(--orange);font-weight:800;font-size:0.75rem}
.solver-chip-rm{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(248,113,113,.12);color:#f87171;font-size:0.6875rem;font-weight:700;cursor:pointer}
.solver-chip-rm:hover{background:rgba(248,113,113,.28)}
.solver-stats{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.solver-stat{flex:1;min-width:84px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 10px;text-align:center}
.solver-stat-val{font-size:1.15rem;font-weight:800;line-height:1.1}
.solver-stat-lbl{font-size:0.6875rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-top:3px}
.fab-slider{
  -webkit-appearance:none;appearance:none;
  height:8px;border-radius:99px;outline:none;cursor:pointer;
  background:linear-gradient(to right,
    #f87171 0%,      /* low quality - red */
    #fb923c 25%,     /* orange */
    #fbbf24 50%,     /* amber - standard */
    #4ade80 75%,     /* green */
    #60a5fa 100%);   /* high quality - blue */
}
.fab-slider::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:3px solid var(--orange);
  box-shadow:0 1px 4px rgba(0,0,0,.5);cursor:pointer;transition:transform .1s;
}
.fab-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
.fab-slider::-moz-range-thumb{
  width:18px;height:18px;border-radius:50%;
  background:#fff;border:3px solid var(--orange);
  box-shadow:0 1px 4px rgba(0,0,0,.5);cursor:pointer;
}
.fab-slider::-moz-range-track{height:8px;border-radius:99px;background:transparent}

/* Projected stats — the highlight of the tab */
.fab-stat-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 14px;border-radius:8px;margin-bottom:6px;
  background:var(--bg3);border:1px solid var(--border);
}
.fab-stat-label{font-size:var(--fs-base);color:var(--text2);font-weight:600}
.fab-stat-base{font-size:var(--fs-sm);color:var(--text3)}
.fab-stat-arrow{color:var(--text3);margin:0 8px;font-size:var(--fs-md)}
.fab-stat-proj{font-size:var(--fs-xl);font-weight:800}
.fab-stat-pct{font-size:var(--fs-sm);font-weight:700;margin-left:8px}

/* Fabricator blueprint result tiles — pure-CSS hover (auto-resets, no sticky state) */
.fab-bp-card:hover{ border-color:var(--bpcol,var(--orange)) !important; }
