/* ==========================================================
   Eorzéan-inspired Market Tracker — original aesthetic
   Deep midnight + antique gold + crystal cyan
   ========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Spectral:ital,wght@0,400;0,600;1,400;1,600&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
  --bg-void:     #07090f;
  --bg-deep:     #0c1018;
  --bg-panel:    #131825;
  --bg-panel-2:  #181d2c;
  --bg-panel-3:  #1f2538;
  --border-soft: #232a3e;
  --border-mid:  #2e3650;
  --border-strong:#3d466a;
  --gold:        #c9a557;
  --gold-bright: #f0c674;
  --gold-dim:    #8a7740;
  --gold-glow:   rgba(240,198,116,.22);
  --crystal:     #6fd4d8;
  --crystal-bright:#a4ecef;
  --crystal-glow:rgba(111,212,216,.22);
  --violet:      #b08cd9;
  --rose:        #e07a8a;
  --emerald:     #5fd49a;
  --emerald-bright:#7fe8b0;
  --ruby:        #e25c6b;
  --txt-bright:  #f4eedf;
  --txt-main:    #d8d2c2;
  --txt-mute:    #8e8a7f;
  --txt-dim:     #5a5a64;
  --font-display:"Cinzel","Trajan Pro",serif;
  --font-serif:  "Spectral","EB Garamond",Georgia,serif;
  --font-sans:   "Inter",-apple-system,BlinkMacSystemFont,sans-serif;
  --font-mono:   "JetBrains Mono","SF Mono",Menlo,monospace;
}

*,*::before,*::after { box-sizing:border-box; }
html,body {
  margin:0; padding:0;
  background:var(--bg-void);
  color:var(--txt-main);
  font-family:var(--font-sans);
  font-size:14px;
  line-height:1.4;
  height:100vh;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
body {
  background:
    radial-gradient(ellipse 1200px 600px at 20% -10%,rgba(176,124,217,.08),transparent 60%),
    radial-gradient(ellipse 900px 500px at 90% 0%,rgba(201,165,87,.06),transparent 60%),
    radial-gradient(ellipse 700px 400px at 50% 110%,rgba(111,212,216,.05),transparent 60%),
    var(--bg-void);
  background-attachment:fixed;
}
/* Starfield overlay */
body::before {
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 20% 30%,rgba(240,198,116,.5),transparent),
    radial-gradient(1px 1px at 80% 70%,rgba(255,255,255,.35),transparent),
    radial-gradient(1px 1px at 60% 40%,rgba(111,212,216,.4),transparent),
    radial-gradient(1px 1px at 30% 80%,rgba(255,255,255,.3),transparent),
    radial-gradient(1px 1px at 90% 20%,rgba(240,198,116,.4),transparent),
    radial-gradient(1px 1px at 10% 60%,rgba(255,255,255,.25),transparent);
  background-size:800px 800px;
  opacity:.55;
  z-index:0;
}

/* ===================== App shell ===================== */
.app {
  height:100vh;
  display:flex;
  flex-direction:column;
  position:relative;
  z-index:1;
}

/* ===================== Topbar ===================== */
.topbar {
  display:grid;
  grid-template-columns:minmax(240px,auto) minmax(280px,1fr) auto;
  gap:18px;
  align-items:center;
  padding:12px 24px;
  background:linear-gradient(180deg,rgba(19,24,37,.95),rgba(19,24,37,.85));
  border-bottom:1px solid var(--border-soft);
  position:relative;
  backdrop-filter:blur(8px);
  flex-shrink:0;
  z-index:100;
}
.topbar::after {
  content:"";
  position:absolute;
  left:0;right:0;bottom:-1px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-dim) 30%,var(--gold) 50%,var(--gold-dim) 70%,transparent);
  opacity:.4;
}

/* ===================== Brand ===================== */
.brand {
  display:flex;
  align-items:center;
  gap:14px;
}
.brand-mark {
  width:36px;height:36px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--gold);
}
.brand-mark svg {
  width:100%;height:100%;
  filter:drop-shadow(0 0 8px var(--gold-glow));
}
.brand-text {
  display:flex;
  flex-direction:column;
  gap:2px;
}
.brand-title {
  font-family:var(--font-display);
  font-size:15px;
  font-weight:600;
  letter-spacing:.14em;
  color:var(--txt-bright);
  text-transform:uppercase;
  line-height:1;
  white-space:nowrap;
}
.brand-subtitle {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:11px;
  color:var(--gold);
  letter-spacing:.06em;
  white-space:nowrap;
}

/* ===================== World Pill (custom dropdown) ===================== */
.world-pill-wrap {
  position:relative;
}
.world-pill {
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 14px 8px 12px;
  background:linear-gradient(180deg,var(--bg-panel-2),var(--bg-panel));
  border:1px solid var(--border-mid);
  border-radius:999px;
  font-family:var(--font-sans);
  font-size:13px;
  font-weight:500;
  color:var(--txt-bright);
  cursor:pointer;
  transition:border-color .15s;
  white-space:nowrap;
  outline:none;
}
.world-pill:hover { border-color:var(--gold-dim); }
.world-dot {
  width:9px;height:9px;
  border-radius:999px;
  background:var(--gold);
  box-shadow:0 0 8px var(--gold);
  flex-shrink:0;
  transition:background .2s,box-shadow .2s;
}
.world-dot.dc { background:var(--gold); box-shadow:0 0 8px var(--gold); }
.world-dot.srv { background:var(--crystal); box-shadow:0 0 8px var(--crystal); }
.world-pill .chev { color:var(--txt-mute); font-size:10px; margin-left:2px; }

.world-dropdown {
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  min-width:210px;
  background:var(--bg-panel-2);
  border:1px solid var(--border-mid);
  border-radius:4px;
  box-shadow:0 16px 48px rgba(0,0,0,.75);
  z-index:400;
  overflow:hidden;
  max-height:340px;
  overflow-y:auto;
}
.world-dropdown::-webkit-scrollbar { width:3px; }
.world-dropdown::-webkit-scrollbar-thumb { background:var(--border-mid); border-radius:2px; }

.wd-group-label {
  font-family:var(--font-display);
  font-size:9px;
  letter-spacing:.22em;
  color:var(--txt-dim);
  text-transform:uppercase;
  padding:10px 16px 4px;
}
.wd-item {
  padding:9px 18px;
  font-size:13px;
  color:var(--txt-main);
  cursor:pointer;
  transition:background .1s,color .1s;
}
.wd-item:hover { background:var(--bg-panel-3); color:var(--gold-bright); }
.wd-item.active { color:var(--gold-bright); background:rgba(201,165,87,.08); }

/* ===================== Search ===================== */
.search-block {
  position:relative;
  display:flex;
  align-items:center;
}
.search-input-wrap {
  position:relative;
  flex:1;
  min-width:200px;
  max-width:560px;
}
.search-input {
  width:100%;
  background:var(--bg-deep);
  border:1px solid var(--border-mid);
  border-radius:4px;
  padding:10px 16px 10px 40px;
  color:var(--txt-bright);
  font-family:var(--font-sans);
  font-size:13.5px;
  outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.search-input::placeholder { color:var(--txt-dim); }
.search-input:focus {
  border-color:var(--gold-dim);
  box-shadow:0 0 0 3px var(--gold-glow);
}
.search-icon {
  position:absolute;
  left:13px;top:50%;
  transform:translateY(-50%);
  color:var(--gold);
  pointer-events:none;
  opacity:.7;
}
.search-dropdown {
  position:absolute;
  top:calc(100% + 6px);
  left:0;right:0;
  background:var(--bg-panel-2);
  border:1px solid var(--border-mid);
  border-radius:4px;
  box-shadow:0 16px 48px rgba(0,0,0,.75);
  z-index:300;
  max-height:340px;
  overflow-y:auto;
}
.search-dropdown.hidden { display:none; }
.search-dropdown::-webkit-scrollbar { width:3px; }
.search-dropdown::-webkit-scrollbar-thumb { background:var(--border-mid); border-radius:2px; }

.sd-item {
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  cursor:pointer;
  transition:background .1s;
}
.sd-item:hover { background:var(--bg-panel-3); }
.sd-icon {
  width:28px;height:28px;
  border-radius:5px;
  object-fit:contain;
  background:var(--bg-panel-3);
  border:1px solid var(--border-soft);
  flex-shrink:0;
}
.sd-icon-ph,.sd-icon-placeholder { font-size:18px;width:28px;text-align:center;flex-shrink:0;opacity:.6; }
.sd-name { flex:1;font-size:13px;color:var(--txt-main); }
.sd-id { font-family:var(--font-mono);font-size:10.5px;color:var(--txt-mute); }
.sd-status { padding:12px 14px;color:var(--txt-mute);font-style:italic;font-size:13px; }
.sd-error { color:var(--ruby); }

.sd-hist-header {
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 14px 5px;
  font-family:var(--font-display);
  font-size:9px;letter-spacing:.2em;
  color:var(--txt-dim);
  border-bottom:1px solid var(--border-soft);
  text-transform:uppercase;
}
.sd-hist-clear { background:none;border:none;color:var(--txt-mute);font-size:10px;cursor:pointer;padding:2px 4px;border-radius:3px; }
.sd-hist-clear:hover { color:var(--ruby); }
.sd-hist-item { padding-right:6px; }
.sd-hist-main { display:flex;align-items:center;gap:10px;flex:1;min-width:0; }
.sd-hist-del { background:none;border:none;color:transparent;font-size:11px;cursor:pointer;padding:4px 6px;border-radius:3px;transition:color .15s; }
.sd-hist-item:hover .sd-hist-del { color:var(--txt-mute); }
.sd-hist-del:hover { color:var(--ruby)!important;background:rgba(226,92,107,.1); }

/* ===================== Topbar actions ===================== */
.topbar-actions {
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  flex-shrink:0;
}
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 16px;
  background:linear-gradient(180deg,var(--bg-panel-2),var(--bg-panel));
  border:1px solid var(--border-mid);
  border-radius:6px;
  color:var(--txt-main);
  font-family:var(--font-sans);
  font-size:13px;
  cursor:pointer;
  transition:all .15s;
  outline:none;
}
.btn:hover {
  border-color:var(--gold-dim);
  color:var(--txt-bright);
  transform:translateY(-1px);
}
.btn:disabled { opacity:.4;cursor:default;transform:none; }
.btn-primary {
  background:linear-gradient(180deg,#2a2540,#1d1a2e);
  border-color:var(--gold-dim);
  color:var(--gold-bright);
}
.btn-primary:hover {
  border-color:var(--gold);
  box-shadow:0 0 16px var(--gold-glow);
}
.auto-select {
  background:var(--bg-deep);
  border:1px solid var(--border-soft);
  border-radius:6px;
  color:var(--txt-main);
  padding:8px 12px;
  font-family:var(--font-sans);
  font-size:12.5px;
  cursor:pointer;
  outline:none;
  transition:border-color .2s;
}
.auto-select:hover,.auto-select:focus { border-color:var(--gold-dim);color:var(--txt-bright); }
.refresh-meta {
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--txt-mute);
  display:flex;
  align-items:center;
  gap:6px;
  white-space:nowrap;
}
.live-dot {
  width:7px;height:7px;
  border-radius:999px;
  background:var(--emerald);
  box-shadow:0 0 6px var(--emerald);
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%,100%{opacity:.5;transform:scale(.85);}
  50%{opacity:1;transform:scale(1.1);}
}

/* ===================== Main layout ===================== */
.main {
  display:grid;
  grid-template-columns:350px 1fr;
  gap:0;
  flex:1;
  min-height:0;
  overflow:hidden;
}

/* ===================== Sidebar ===================== */
.sidebar {
  border-right:1px solid var(--border-soft);
  padding:20px 14px;
  background:linear-gradient(180deg,rgba(12,16,24,.4),rgba(7,9,15,.6));
  display:flex;
  flex-direction:column;
  gap:16px;
  overflow-y:auto;
  height:100%;
}
.sidebar::-webkit-scrollbar { width:3px; }
.sidebar::-webkit-scrollbar-thumb { background:var(--border-soft);border-radius:2px; }

.section-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 4px;
}
.section-title {
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-display);
  font-size:10px;
  font-weight:600;
  letter-spacing:.22em;
  color:var(--gold);
  text-transform:uppercase;
}
.count-badge {
  font-family:var(--font-mono);
  font-size:11px;
  padding:2px 8px;
  background:var(--bg-panel-2);
  border:1px solid var(--border-mid);
  border-radius:999px;
  color:var(--gold-bright);
  font-weight:600;
}

/* ===================== Watch list items ===================== */
.watch-list {
  display:flex;
  flex-direction:column;
  gap:4px;
}
.empty-pinned {
  padding:28px 8px;
  text-align:center;
  color:var(--txt-mute);
  font-size:12px;
  line-height:1.7;
}
.empty-pinned span { font-size:20px;display:block;margin-bottom:8px;opacity:.3; }

.watch-item {
  display:grid;
  grid-template-columns:14px 28px minmax(0,1fr) auto;
  gap:6px;
  align-items:center;
  padding:7px 8px;
  background:var(--bg-panel);
  border:1px solid var(--border-soft);
  border-radius:6px;
  cursor:pointer;
  transition:all .18s;
  position:relative;
  overflow:hidden;
}
.watch-item.dragging {
  opacity:.55;
  border-color:var(--gold-dim);
}
.watch-item.drag-over {
  border-color:var(--gold-bright);
  box-shadow:0 0 0 1px rgba(201,165,87,.28), inset 0 0 0 1px rgba(201,165,87,.18);
}
.watch-item .alert-form { grid-column:1 / -1; grid-row:2; }
.watch-item::before {
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:2px;
  background:transparent;
  transition:background .18s;
}
.watch-item:hover {
  border-color:var(--border-strong);
  background:var(--bg-panel-2);
}
.watch-item.active {
  border-color:var(--gold-dim);
  background:linear-gradient(90deg,rgba(201,165,87,.08),var(--bg-panel-2));
}
.watch-item.active::before {
  background:linear-gradient(180deg,var(--gold-bright),var(--gold));
  box-shadow:0 0 8px var(--gold-glow);
}
.watch-item.alert-triggered {
  border-color:rgba(95,212,154,.4)!important;
  background:rgba(95,212,154,.04);
}
.watch-icon {
  width:28px;height:28px;
  border-radius:5px;
  background:linear-gradient(135deg,var(--bg-panel-3),var(--bg-deep));
  border:1px solid var(--border-mid);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  overflow:hidden;
}
.watch-icon img { width:100%;height:100%;object-fit:contain; }
.watch-icon .icon-ph { font-size:13px;opacity:.4; }
.watch-drag-handle {
  width:14px;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  background:transparent;
  color:var(--txt-dim);
  cursor:grab;
  font-size:10px;
  line-height:1;
  opacity:.45;
  padding:0;
  flex-shrink:0;
}
.watch-item:hover .watch-drag-handle { opacity:.9; }
.watch-drag-handle:active { cursor:grabbing; }
.watch-info {
  display:flex;
  flex-direction:column;
  gap:1px;
  min-width:0;
}
.watch-name-row {
  display:flex;
  align-items:center;
  gap:4px;
  min-width:0;
}
.watch-alert-inline {
  flex-shrink:0;
  font-size:10px;
  color:var(--gold-bright);
}
.watch-name {
  font-size:11px;
  font-weight:500;
  color:var(--txt-bright);
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  line-height:1.2;
}
.watch-price {
  font-family:var(--font-mono);
  font-size:10px;
  color:var(--txt-mute);
  display:flex;
  align-items:center;
  gap:4px;
  white-space:nowrap;
  line-height:1.1;
}
.delta-chip {
  display:inline-flex;
  align-items:center;
  gap:2px;
  font-family:var(--font-mono);
  font-size:8px;
  font-weight:600;
  padding:1px 4px;
  border-radius:3px;
}
.delta-up { background:rgba(95,212,154,.12);color:var(--emerald-bright); }
.delta-down { background:rgba(226,92,107,.12);color:var(--ruby); }
.watch-actions {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  justify-content:center;
  gap:2px;
  flex-shrink:0;
  min-width:44px;
}
.profit-chip {
  font-family:var(--font-mono);
  font-size:8.5px;
  font-weight:700;
  padding:1px 5px;
  border-radius:3px;
  line-height:1.1;
  min-width:42px;
  text-align:center;
}
.profit-chip-pos { background:rgba(95,212,154,.12);color:var(--emerald-bright); }
.profit-chip-neg { background:rgba(226,92,107,.12);color:var(--ruby); }
.watch-action-row {
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:3px;
}
.icon-btn {
  width:18px;height:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.02);border:1px solid rgba(46,54,80,.4);border-radius:4px;
  color:var(--txt-dim);cursor:pointer;transition:all .15s;
  font-size:11px;padding:0;
}
.icon-btn:hover { color:var(--gold-bright);background:var(--bg-panel-3);border-color:rgba(201,165,87,.25); }
.icon-btn.alert-on { color:var(--gold-bright); }
.icon-btn.unpin:hover { color:var(--ruby); }
@keyframes pulse-alert { 0%,100%{opacity:1;transform:scale(1);}50%{opacity:.6;transform:scale(1.25);} }

/* ===================== Alert form ===================== */
.alert-form {
  display:flex;align-items:center;gap:6px;
  padding:8px 6px 4px;
  border-top:1px solid var(--border-soft);
  margin-top:4px;
  flex-wrap:wrap;
}
.alert-form.hidden { display:none; }
.alert-form-label { font-size:11px;color:var(--txt-mute);white-space:nowrap; }
.alert-input {
  flex:1;min-width:80px;
  background:var(--bg-panel-3);border:1px solid var(--border-mid);border-radius:5px;
  color:var(--txt-bright);padding:4px 8px;
  font-family:var(--font-mono);font-size:12px;outline:none;
}
.alert-input:focus { border-color:var(--gold-dim); }
.btn-alert-save,.btn-alert-clear {
  border:none;border-radius:5px;cursor:pointer;
  font-size:12px;font-weight:700;padding:3px 9px;
}
.btn-alert-save  { background:rgba(95,212,154,.12);color:var(--emerald-bright); }
.btn-alert-clear { background:rgba(226,92,107,.1);color:var(--ruby); }
.btn-alert-save:hover  { background:rgba(95,212,154,.22); }
.btn-alert-clear:hover { background:rgba(226,92,107,.2); }

/* ===================== Content area + tabs ===================== */
.content-area {
  flex:1;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  min-height:0;
}
.tabs {
  display:flex;
  gap:4px;
  border-bottom:1px solid rgba(201,165,87,.12);
  padding:0 28px;
  position:relative;
  flex-shrink:0;
  background:linear-gradient(180deg, rgba(9,12,20,.92), rgba(11,14,22,.85));
  box-shadow: 0 1px 0 rgba(201,165,87,.06), 0 4px 20px rgba(0,0,0,.25);
}
.tab {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 18px;
  background:transparent;
  border:none;
  color:var(--txt-dim);
  font-family:var(--font-display);
  font-size:9.5px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:600;
  cursor:pointer;
  border-bottom:2px solid transparent;
  transition:all .18s;
  position:relative;
  top:1px;
  outline:none;
}
.tab:hover { color:var(--txt-main); }
.tab.active {
  color:var(--gold-bright);
  border-bottom-color:var(--gold);
  text-shadow: 0 0 16px rgba(240,198,116,.30);
}
.tab.active::after {
  content:"";
  position:absolute;
  left:50%;bottom:-2px;
  width:36px;height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  box-shadow:0 0 14px var(--gold-glow);
  transform:translateX(-50%);
}
.tab-pane {
  flex:1;
  overflow-y:auto;
  padding:26px 32px 60px;
  min-height:0;
}
.tab-pane::-webkit-scrollbar { width:5px; }
.tab-pane::-webkit-scrollbar-track { background:transparent; }
.tab-pane::-webkit-scrollbar-thumb { background:var(--border-mid);border-radius:3px; }

/* ===================== Empty / Loading / Error states ===================== */
.empty-state {
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:55vh;color:var(--txt-mute);text-align:center;gap:14px;
}
.empty-icon { font-size:40px;opacity:.2; }
.empty-state p { font-family:var(--font-serif);font-style:italic;font-size:15px; }
.empty-state small { font-size:12px; }
.loading-state {
  display:flex;align-items:center;gap:12px;
  padding:40px;color:var(--txt-mute);font-size:14px;
}
.spinner { display:inline-block;animation:spin 1s linear infinite;font-size:20px; }
@keyframes spin { to { transform:rotate(360deg); } }
.error-state { padding:40px;color:var(--ruby);font-size:14px; }
.no-data {
  background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:4px;
  padding:13px 18px;color:var(--txt-mute);font-size:13px;margin-bottom:14px;font-style:italic;
}
.hidden { display:none!important; }

/* ===================== Item header ===================== */
.item-header {
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:20px;
  align-items:center;
  margin-bottom:26px;
  padding-bottom:20px;
  border-bottom:1px solid var(--border-soft);
}
.item-portrait {
  width:72px;height:72px;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.item-portrait-frame {
  position:absolute;inset:0;
  border:1px solid var(--gold-dim);
  border-radius:4px;
  background:linear-gradient(135deg,var(--bg-panel-3),var(--bg-deep));
  box-shadow:inset 0 0 0 1px rgba(201,165,87,.15),0 0 18px rgba(201,165,87,.12);
}
.item-portrait-frame::before,.item-portrait-frame::after {
  content:"";
  position:absolute;
  width:9px;height:9px;
  border:1px solid var(--gold);
}
.item-portrait-frame::before { top:-2px;left:-2px;border-right:none;border-bottom:none; }
.item-portrait-frame::after  { bottom:-2px;right:-2px;border-left:none;border-top:none; }
.item-portrait-img {
  width:100%;height:100%;object-fit:contain;
  padding:6px;position:relative;z-index:1;
}
.item-portrait-ph {
  font-size:30px;opacity:.3;position:relative;z-index:1;
}
.item-info { display:flex;flex-direction:column;gap:5px; }
.item-name {
  font-family:var(--font-display);
  font-size:24px;
  font-weight:600;
  color:var(--txt-bright);
  letter-spacing:.04em;
  margin:0;
  line-height:1.1;
}
.item-meta {
  display:flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  color:var(--txt-mute);
  font-family:var(--font-mono);
  flex-wrap:wrap;
}
.item-meta-sep {
  width:3px;height:3px;
  border-radius:999px;
  background:var(--txt-dim);
  display:inline-block;
  flex-shrink:0;
}
.item-meta .tag {
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;
  background:var(--bg-panel-2);
  border:1px solid var(--border-mid);
  border-radius:3px;
  font-family:var(--font-sans);
  font-size:11px;
  letter-spacing:.05em;
}
.tag-reactif { color:var(--emerald-bright);border-color:rgba(95,212,154,.25);background:rgba(95,212,154,.08); }
.tag-stable  { color:var(--gold-bright);border-color:rgba(201,165,87,.25);background:rgba(201,165,87,.08); }
.tag-lent    { color:var(--txt-mute);border-color:var(--border-soft); }
.tag-dot {
  width:5px;height:5px;
  border-radius:50%;
  display:inline-block;
}
.tag-reactif .tag-dot { background:var(--emerald-bright);box-shadow:0 0 5px var(--emerald); }
.tag-stable  .tag-dot { background:var(--gold-bright); }
.tag-lent    .tag-dot { background:var(--txt-mute); }

.pin-btn {
  padding:9px 18px;
  background:linear-gradient(180deg,rgba(240,198,116,.14),rgba(240,198,116,.06));
  border:1px solid var(--gold-dim);
  border-radius:6px;
  color:var(--gold-bright);
  font-family:var(--font-sans);
  font-size:13px;
  font-weight:500;
  cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .15s;
  white-space:nowrap;
  outline:none;
}
.pin-btn:hover {
  box-shadow:0 0 14px var(--gold-glow);
  background:linear-gradient(180deg,rgba(240,198,116,.22),rgba(240,198,116,.1));
}
.pin-btn.unpinned {
  color:var(--txt-mute);
  border-color:var(--border-mid);
  background:var(--bg-panel-2);
}
.pin-btn.unpinned:hover { border-color:var(--gold-dim);color:var(--gold-bright); }

/* ===================== Panels ===================== */
.panel {
  /* background: gilded top line + ambient glows + base gradient */
  background:
    linear-gradient(90deg,
      transparent 0%, rgba(201,165,87,.10) 15%,
      rgba(201,165,87,.52) 35%, rgba(240,198,116,.80) 50%,
      rgba(201,165,87,.52) 65%, rgba(201,165,87,.10) 85%,
      transparent 100%) top / 100% 2px no-repeat,
    radial-gradient(ellipse 320px 180px at 0% 0%, rgba(201,165,87,.04), transparent 60%),
    radial-gradient(ellipse 200px 150px at 100% 100%, rgba(111,212,216,.025), transparent 60%),
    linear-gradient(180deg, rgba(14,18,28,.98) 0%, rgba(9,12,20,.99) 100%);
  border: 1px solid rgba(201,165,87,.20);
  border-radius: 4px;
  padding: 20px 22px;
  position: relative;
  margin-bottom: 20px;
  box-shadow:
    0 22px 54px rgba(0,0,0,.35),
    inset 0 1px 0 rgba(255,255,255,.03),
    0 0 0 1px rgba(201,165,87,.04);
}
/* Corner ornaments */
.panel-corners::before,.panel-corners::after,
.panel-corners > .corner-tr,.panel-corners > .corner-bl {
  content:"";
  position:absolute;
  width:14px;height:14px;
  pointer-events:none;
  border:1px solid rgba(201,165,87,.55);
  opacity:.8;
}
.panel-corners::before { top:-1px;left:-1px;border-right:none;border-bottom:none; }
.panel-corners::after  { bottom:-1px;right:-1px;border-left:none;border-top:none; }
.panel-corners > .corner-tr { top:-1px;right:-1px;border-left:none;border-bottom:none; }
.panel-corners > .corner-bl { bottom:-1px;left:-1px;border-right:none;border-top:none; }

.panel-title {
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-display);
  font-size:9.5px;
  letter-spacing:.28em;
  color:var(--gold);
  text-transform:uppercase;
  margin:0 0 16px;
  font-weight:600;
  text-shadow: 0 0 18px rgba(201,165,87,.25);
}
.panel-title-sub {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:12px;
  color:var(--txt-mute);
  letter-spacing:.02em;
  text-transform:none;
  font-weight:400;
  margin-left:4px;
  text-shadow: none;
}
.panel-title-icon { width:16px;height:16px;color:var(--gold);flex-shrink:0; }
.section-subtitle {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:12px;
  color:var(--txt-mute);
  display:block;
  margin:-10px 0 14px;
}

/* ===================== Profit / Stats ===================== */
.profit-banner {
  display:flex;align-items:center;gap:12px;
  padding:11px 16px;
  background:linear-gradient(90deg,rgba(201,165,87,.08),rgba(201,165,87,.02));
  border:1px solid rgba(201,165,87,.18);
  border-radius:7px;
  margin-bottom:16px;
  font-size:13px;
  flex-wrap:wrap;
}
.profit-banner .label { color:var(--txt-mute); }
.profit-banner .city-badge {
  font-family:var(--font-display);
  font-size:11px;font-weight:600;letter-spacing:.16em;
  color:var(--gold-bright);
  padding:4px 10px;
  background:rgba(201,165,87,.12);
  border-radius:4px;
}
.profit-banner .tax-saving { color:var(--emerald-bright);font-weight:600; }
/* Alias for old tax-banner code */
.tax-banner { display:flex;align-items:center;gap:12px;padding:11px 16px;background:linear-gradient(90deg,rgba(201,165,87,.08),rgba(201,165,87,.02));border:1px solid rgba(201,165,87,.18);border-radius:7px;margin-bottom:16px;font-size:13px;flex-wrap:wrap; }
.tax-best { color:var(--txt-main); }
.tax-best strong { color:var(--gold-bright); }
.tax-saving { color:var(--emerald-bright);font-weight:600; }

.stat-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.stat-card {
  background:
    linear-gradient(90deg,
      transparent 0%, var(--accent-line, rgba(201,165,87,.08)) 30%,
      var(--accent-line, rgba(201,165,87,.32)) 50%,
      var(--accent-line, rgba(201,165,87,.08)) 70%, transparent 100%) top / 100% 1px no-repeat,
    linear-gradient(180deg, rgba(12,15,24,.97), rgba(8,11,19,.99));
  border:1px solid var(--accent-border, rgba(201,165,87,.14));
  border-radius:4px;
  padding:16px 18px;
  position:relative;
  overflow:hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.stat-card::after {
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at top right,var(--accent-glow,transparent),transparent 60%);
  pointer-events:none;
  opacity:.5;
}
.stat-card.accent-cyan  { --accent-border: rgba(111,212,216,.22); --accent-line: rgba(111,212,216,.28); }
.stat-card.accent-gold  { --accent-border: rgba(201,165,87,.22);  --accent-line: rgba(201,165,87,.42); }
.stat-card.accent-emerald { --accent-border: rgba(95,212,154,.20); --accent-line: rgba(95,212,154,.32); }
.stat-card.accent-ruby  { --accent-border: rgba(226,92,107,.20);  --accent-line: rgba(226,92,107,.30); }
.stat-label {
  font-family:var(--font-display);
  font-size:9.5px;
  letter-spacing:.2em;
  color:var(--txt-mute);
  text-transform:uppercase;
  margin-bottom:4px;
  display:block;
}
.stat-label-sub {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:11px;
  color:var(--txt-dim);
  margin-bottom:6px;
  display:block;
}
.stat-value {
  font-family:var(--font-mono);
  font-size:22px;
  font-weight:600;
  letter-spacing:-.01em;
  display:flex;
  align-items:baseline;
  gap:5px;
  margin-top:6px;
}
.stat-unit { font-size:12px;color:var(--txt-mute);font-weight:400; }
.stat-card.accent-cyan  { --accent-glow:rgba(111,212,216,.10); }
.stat-card.accent-cyan  .stat-value { color:var(--crystal-bright); }
.stat-card.accent-gold  { --accent-glow:rgba(240,198,116,.10); }
.stat-card.accent-gold  .stat-value { color:var(--gold-bright); }
.stat-card.accent-ruby  { --accent-glow:rgba(226,92,107,.10); }
.stat-card.accent-ruby  .stat-value { color:var(--ruby); }
.stat-card.accent-emerald { --accent-glow:rgba(95,212,154,.12); }
.stat-card.accent-emerald .stat-value { color:var(--emerald-bright); }
.stat-card.accent-violet  { --accent-glow:rgba(176,140,217,.10); }
.stat-card.accent-violet  .stat-value { color:var(--violet); }
.stat-card.accent-neutral .stat-value { color:var(--txt-bright); }
.stat-spark {
  position:absolute;right:12px;bottom:10px;
  font-family:var(--font-mono);font-size:10.5px;color:var(--txt-mute);
}

/* ===================== Chart ===================== */
.chart-wrap {
  position:relative;
  height:240px;
  width:100%;
}
.chart-wrap canvas { display:block;width:100%;height:100%; }

/* ===================== Tables ===================== */
.tables-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin-bottom:20px;
}
.market-table,
.scanner-table { width:100%;border-collapse:collapse;font-size:12.5px; }
.market-table thead th,
.scanner-table thead th {
  text-align:left;
  font-family:var(--font-display);
  font-size:8.5px;
  letter-spacing:.24em;
  color:rgba(200,182,145,.55);
  font-weight:600;
  text-transform:uppercase;
  padding:13px 14px;
  background:rgba(7,10,18,.75);
  border-bottom:1px solid rgba(201,165,87,.09);
  white-space:nowrap;
}
.market-table tbody td,
.scanner-table tbody td {
  padding:12px 14px;
  border-bottom:1px solid rgba(35,42,62,.5);
  background:rgba(12,15,24,.62);
  color:var(--txt-main);
  vertical-align:middle;
}
.market-table tbody tr,
.scanner-table tbody tr { transition:background .14s; }
.market-table tbody tr:nth-child(even) td,
.scanner-table tbody tr:nth-child(even) td { background:rgba(9,12,21,.72); }
.market-table tbody tr:hover td,
.scanner-table tbody tr:hover td { background:rgba(201,165,87,.05) !important; }
.market-table tbody tr:last-child td,
.scanner-table tbody tr:last-child td { border-bottom:none; }
.market-table .price-cell {
  font-family:var(--font-mono);
  font-size:14px;
  font-weight:700;
  color:var(--gold-bright);
  text-shadow:0 0 14px rgba(240,198,116,.18);
}
.market-table .qty-cell   { font-family:var(--font-mono); font-size:13px; color:var(--txt-main); }
.market-table .server-cell {
  font-family:var(--font-display);
  font-size:9px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--crystal-bright);
}
.market-table .date-cell  { font-family:var(--font-mono);font-size:11px;color:var(--txt-dim); }
.market-table th:nth-child(1),
.market-table td:nth-child(1) { width:24%; }
.market-table th:nth-child(2),
.market-table td:nth-child(2) { width:14%; }
.market-table th:nth-child(3),
.market-table td:nth-child(3) { width:18%; }
.market-table th:nth-child(4),
.market-table td:nth-child(4) { width:18%; }
.market-table th:nth-child(5),
.market-table td:nth-child(5) { width:26%; }
.hq-chip,.nq-chip {
  display:inline-block;
  font-family:var(--font-display);
  font-size:9px;font-weight:600;letter-spacing:.16em;
  padding:2px 7px;border-radius:3px;
}
.nq-chip { background:var(--bg-panel-3);color:var(--txt-mute);border:1px solid var(--border-mid); }
.hq-chip { background:rgba(111,212,216,.12);color:var(--crystal-bright);border:1px solid rgba(111,212,216,.3); }

.positive { color:var(--emerald-bright); }
.negative { color:var(--ruby); }
.muted    { color:var(--txt-mute); }
.center   { text-align:center; }
.gil-label { font-size:10px;color:var(--txt-mute); }

.trend-arrow { font-size:10px;font-weight:700;margin-left:4px; }
.trend-up   { color:var(--emerald-bright); }
.trend-down { color:var(--ruby); }
.trend-flat { color:var(--txt-mute); }

/* ===================== Scanner ===================== */
.scanner-header {
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:20px;gap:16px;
}
.scanner-header h2 {
  font-family:var(--font-display);
  font-size:18px;font-weight:600;
  color:var(--txt-bright);
  letter-spacing:.06em;text-transform:uppercase;
}
#scannerMeta,#collectMeta {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:11.5px;
  color:var(--txt-mute);
  display:block;
  margin-top:3px;
}
.btn-scan {
  background:linear-gradient(180deg,rgba(176,124,217,.2),rgba(176,124,217,.1));
  border:1px solid rgba(176,124,217,.4);
  color:var(--violet);
  padding:9px 20px;border-radius:6px;cursor:pointer;
  font-family:var(--font-sans);font-size:13px;font-weight:600;white-space:nowrap;
  transition:all .2s;flex-shrink:0;outline:none;
}
.btn-scan:hover { border-color:var(--violet);box-shadow:0 0 16px rgba(176,124,217,.2); }
.btn-scan:disabled { opacity:.4;cursor:default; }
.scan-name {
  font-weight:500;max-width:200px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.scanner-table-shell {
  background:
    linear-gradient(90deg,
      transparent 0%, rgba(201,165,87,.10) 15%,
      rgba(201,165,87,.52) 35%, rgba(240,198,116,.80) 50%,
      rgba(201,165,87,.52) 65%, rgba(201,165,87,.10) 85%,
      transparent 100%) top / 100% 2px no-repeat,
    radial-gradient(ellipse 360px 200px at 0% 0%, rgba(201,165,87,.04), transparent 60%),
    radial-gradient(ellipse 220px 160px at 100% 100%, rgba(111,212,216,.025), transparent 60%),
    linear-gradient(180deg, rgba(14,18,28,.98), rgba(9,12,20,.99));
  border:1px solid rgba(201,165,87,.22);
  border-radius:4px;
  overflow:hidden;
  box-shadow:
    0 28px 64px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.04),
    0 0 0 1px rgba(201,165,87,.05);
}
.scanner-table-head {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:18px;
  padding:20px 22px 18px;
  border-bottom:1px solid rgba(201,165,87,.10);
  background:linear-gradient(180deg, rgba(10,13,23,.94), rgba(14,18,29,.80));
}
.scanner-table-kicker {
  font-family:var(--font-display);
  font-size:9px;
  letter-spacing:.30em;
  text-transform:uppercase;
  color:var(--gold-dim);
  margin-bottom:8px;
  text-shadow: 0 0 14px rgba(201,165,87,.2);
}
.scanner-table-note {
  color:var(--txt-main);
  font-size:12px;
  max-width:540px;
  line-height:1.5;
}
.scanner-table-legend {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.scanner-legend-pill {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid var(--border-mid);
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.scanner-legend-pill.is-good { background:rgba(95,212,154,.12); color:var(--emerald-bright); border-color:rgba(95,212,154,.24); }
.scanner-legend-pill.is-mid { background:rgba(201,165,87,.10); color:var(--gold-bright); border-color:rgba(201,165,87,.24); }
.scanner-legend-pill.is-bad { background:rgba(226,92,107,.12); color:var(--ruby); border-color:rgba(226,92,107,.22); }
.scanner-table-wrap { overflow-x:auto; }
.scanner-table-premium { min-width:860px; }
.scanner-table-premium thead th {
  padding:13px 16px;
  background:rgba(7,10,18,.78);
  color:rgba(200,182,145,.55);
  font-size:8.5px;
  letter-spacing:.24em;
  border-bottom:1px solid rgba(201,165,87,.09);
}
.scanner-table-premium tbody td {
  padding:15px 16px;
  border-bottom:1px solid rgba(35,42,62,.5);
  background:rgba(12,15,24,.62);
}
.scanner-table-premium tbody tr:nth-child(even) td { background:rgba(9,12,21,.72); }
.scanner-table-premium tbody tr:hover td { background:rgba(201,165,87,.06) !important; }
.scan-item-cell { min-width:250px; }
.scan-item-name {
  display:block;
  font-size:14px;
  font-weight:600;
  color:var(--txt-bright);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.scan-price-cell,
.scan-profit-cell,
.scan-roi-cell,
.scan-velocity-cell,
.scan-type-cell {
  white-space:nowrap;
  font-family:var(--font-mono);
}
.scan-price-cell { color:var(--gold-bright); }
.scan-action-cell { width:58px; text-align:right; }
.roi-pill {
  display:inline-block;padding:2px 8px;border-radius:20px;
  font-family:var(--font-mono);font-size:11.5px;font-weight:700;
}
.roi-great { background:rgba(95,212,154,.12);color:var(--emerald-bright);border:1px solid rgba(95,212,154,.2); }
.roi-ok    { background:rgba(90,90,100,.12);color:var(--txt-main); }
.roi-bad   { background:rgba(226,92,107,.12);color:var(--ruby); }
.btn-scan-detail {
  background:rgba(11,14,21,.88);border:1px solid rgba(201,165,87,.16);color:var(--txt-mute);
  padding:5px 10px;border-radius:7px;cursor:pointer;font-size:12px;
  opacity:.45;transition:opacity .15s,border-color .15s,color .15s,transform .15s;
}
.scanner-row { cursor:pointer; }
.scanner-row:hover td { background:rgba(201,165,87,.03); }
.scanner-row:hover .btn-scan-detail { opacity:1; transform:translateX(1px); }
.btn-scan-detail:hover { color:var(--gold-bright);border-color:var(--gold-dim); }
.craft-mode-toggle {
  display:flex;align-items:center;gap:6px;
  font-size:12.5px;color:var(--txt-mute);cursor:pointer;user-select:none;white-space:nowrap;
}
.craft-mode-toggle input { cursor:pointer;accent-color:var(--gold); }
.type-badge {
  display:inline-block;font-size:10px;font-weight:700;
  padding:2px 7px;border-radius:4px;letter-spacing:.3px;white-space:nowrap;
}
.type-craft { background:rgba(176,124,217,.15);color:var(--violet); }
.type-flip  { background:rgba(111,212,216,.12);color:var(--crystal-bright); }

/* ===================== Craft calculator ===================== */
.btn-craft {
  background:linear-gradient(180deg,rgba(176,124,217,.2),rgba(176,124,217,.1));
  border:1px solid rgba(176,124,217,.35);color:var(--violet);
  padding:8px 18px;border-radius:6px;cursor:pointer;
  font-family:var(--font-sans);font-size:13px;font-weight:600;
  transition:all .2s;letter-spacing:.3px;outline:none;
}
.btn-craft:hover { border-color:var(--violet);box-shadow:0 0 14px rgba(176,124,217,.2); }
.btn-craft-reload {
  background:var(--bg-panel-2);color:var(--txt-mute);border-color:var(--border-mid);
}
.btn-craft-reload:hover { color:var(--gold-bright);border-color:var(--gold-dim);box-shadow:none; }
.craft-table { width:100%;border-collapse:collapse;font-size:12.5px;margin-bottom:14px; }
.craft-table thead th {
  font-family:var(--font-display);
  font-size:8.5px;
  letter-spacing:.24em;
  color:rgba(200,182,145,.55);
  text-transform:uppercase;
  padding:13px 14px;
  background:rgba(7,10,18,.75);
  border-bottom:1px solid rgba(201,165,87,.09);
  text-align:left;
  white-space:nowrap;
}
.craft-table td {
  padding:12px 14px;
  border-bottom:1px solid rgba(35,42,62,.5);
  background:rgba(12,15,24,.62);
  vertical-align:middle;
}
.craft-table tbody tr:nth-child(even) td { background:rgba(9,12,21,.72); }
.craft-table tbody tr:last-child td { border-bottom:none; }
.craft-table tbody tr:hover td { background:rgba(201,165,87,.05) !important; }
.ingredient-link {
  color:var(--txt-main);cursor:pointer;text-decoration:none;
  border-bottom:1px dashed var(--border-mid);transition:color .15s;
}
.ingredient-link:hover { color:var(--gold-bright);border-color:var(--gold-dim); }
.craft-summary {
  background:
    linear-gradient(90deg,
      transparent 0%, rgba(201,165,87,.07) 20%,
      rgba(201,165,87,.30) 50%,
      rgba(201,165,87,.07) 80%, transparent 100%) top / 100% 1px no-repeat,
    linear-gradient(180deg, rgba(12,15,24,.97), rgba(8,11,19,.99));
  border:1px solid rgba(201,165,87,.15);
  border-radius:4px;
  padding:16px 18px;
  display:flex;
  flex-direction:column;
  gap:8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.craft-row {
  display:flex;justify-content:space-between;align-items:center;
  font-size:13px;padding:4px 0;border-bottom:1px solid rgba(35,42,62,.5);
}
.craft-row:last-of-type { border-bottom:none; }
.craft-row span { color:var(--txt-mute); }
.craft-profit {
  margin-top:4px;padding-top:10px;
  border-top:1px solid var(--border-soft)!important;
  font-weight:700;font-size:14px;
}
.craft-profit span { color:var(--txt-main);font-weight:600; }
.craft-profit.positive strong { color:var(--emerald-bright); }
.craft-profit.negative strong { color:var(--ruby); }
.roi-badge {
  font-family:var(--font-mono);font-size:10.5px;font-weight:700;
  padding:2px 7px;border-radius:4px;margin-left:8px;vertical-align:middle;
}
.roi-badge.positive { background:rgba(95,212,154,.12);color:var(--emerald-bright); }
.roi-badge.negative { background:rgba(226,92,107,.12);color:var(--ruby); }
.craft-hint { font-size:11.5px;color:var(--txt-mute);margin-top:6px;font-style:italic; }

/* ===================== Gather badges ===================== */
.gather-badge { display:inline-block;font-size:10px;font-weight:700;padding:2px 7px;border-radius:4px;white-space:nowrap;letter-spacing:.3px; }
.badge-min { background:rgba(251,191,36,.12);color:#fbbf24; }
.badge-btn { background:rgba(134,239,172,.12);color:#86efac; }
.badge-fsh { background:rgba(103,232,249,.12);color:#67e8f9; }

/* ===================== Shopping list ===================== */
.shopping-list-bar { display:flex;align-items:center;gap:8px;margin-top:14px;padding:10px 0 0;border-top:1px solid var(--border-soft);flex-wrap:wrap; }
.shop-label { font-size:13px;color:var(--txt-mute); }
.shop-qty-input { width:64px;background:var(--bg-panel-3);border:1px solid var(--border-mid);border-radius:6px;color:var(--txt-bright);padding:5px 8px;font-family:var(--font-mono);font-size:13px;text-align:center;outline:none; }
.shop-qty-input:focus { border-color:var(--gold-dim); }
.btn-shopping { background:var(--bg-panel-2);border:1px solid var(--border-mid);color:var(--txt-main);padding:5px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:border-color .2s,color .2s; }
.btn-shopping:hover { border-color:var(--gold-dim);color:var(--gold-bright); }
.shopping-list-card { background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:4px;padding:14px 16px;margin-top:10px; }
.shop-header { display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;color:var(--txt-bright); }
.btn-shop-copy { background:transparent;border:1px solid var(--border-mid);color:var(--txt-mute);padding:3px 10px;border-radius:5px;cursor:pointer;font-size:11px;transition:color .15s; }
.btn-shop-copy:hover { color:var(--gold-bright);border-color:var(--gold-dim); }
.shop-group { margin-bottom:10px; }
.shop-group-title { font-family:var(--font-display);font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.2em;margin-bottom:6px; }
.shop-item { display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid rgba(35,42,62,.5);font-size:12.5px; }
.shop-item:last-child { border-bottom:none; }
.shop-item-name { color:var(--txt-main); }
.shop-item-qty { color:var(--gold-bright);font-family:var(--font-mono);font-weight:700; }

/* ===================== Money Maker — Arbitrage redesign ===================== */

/* Shell container */
.money-shell {
  background: linear-gradient(180deg, rgba(14,18,28,.98) 0%, rgba(9,12,20,.99) 100%);
  border: 1px solid rgba(201,165,87,.22);
  border-radius: 4px;
  overflow: hidden;
  box-shadow:
    0 28px 64px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.04),
    0 0 0 1px rgba(201,165,87,.05);
  position: relative;
}
/* top gilded line */
.money-shell::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg,
    transparent 0%, rgba(201,165,87,.15) 15%,
    rgba(201,165,87,.65) 35%, rgba(240,198,116,.95) 50%,
    rgba(201,165,87,.65) 65%, rgba(201,165,87,.15) 85%,
    transparent 100%);
  pointer-events: none;
  z-index: 2;
}
/* ambient corner glows */
.money-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 4px;
  background:
    radial-gradient(ellipse 360px 220px at 0% 0%, rgba(201,165,87,.05), transparent 60%),
    radial-gradient(ellipse 220px 180px at 100% 100%, rgba(111,212,216,.03), transparent 60%);
  pointer-events: none;
}

/* Header */
.money-shell-hd {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding: 22px 26px 20px;
  border-bottom: 1px solid rgba(201,165,87,.1);
  background: linear-gradient(180deg, rgba(10,13,23,.94), rgba(14,18,29,.80));
  position: relative;
  z-index: 1;
  flex-wrap: wrap;
}
.money-shell-hd-left { flex: 1; min-width: 0; }

.money-shell-kicker {
  font-family: var(--font-display);
  font-size: 9px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold-dim);
  margin-bottom: 10px;
}

/* Route indicator: Light DC ——→ Shiva */
.money-shell-route {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 9px;
}
.money-route-from {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: .1em;
  color: var(--crystal-bright);
  text-shadow: 0 0 18px rgba(111,212,216,.25);
}
.money-route-to {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: .1em;
  color: var(--gold-bright);
  text-shadow: 0 0 18px rgba(240,198,116,.22);
}
.money-route-arrow {
  width: 40px;
  height: 10px;
  color: var(--gold-dim);
  flex-shrink: 0;
}

.money-shell-note {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 12px;
  color: var(--txt-mute);
  line-height: 1.5;
}

/* Stats block */
.money-shell-hd-stats {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-shrink: 0;
}
.money-shell-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-align: center;
  min-width: 64px;
}
.money-shell-stat-val {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--txt-bright);
  line-height: 1;
}
.money-shell-stat-val.mssv-gold    { color: var(--gold-bright);    text-shadow: 0 0 14px rgba(240,198,116,.2); }
.money-shell-stat-val.mssv-emerald { color: var(--emerald-bright); text-shadow: 0 0 14px rgba(95,212,154,.18); }
.money-shell-stat-lbl {
  font-family: var(--font-display);
  font-size: 8px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--txt-dim);
  white-space: nowrap;
}
.money-shell-sep {
  color: var(--gold);
  opacity: .4;
  display: flex;
  align-items: center;
}
.money-orn {
  width: 64px;
  height: 12px;
  color: currentColor;
}

/* Table */
.money-tbl-scroll {
  overflow-x: auto;
  position: relative;
  z-index: 1;
}
.money-tbl-scroll::-webkit-scrollbar { height: 4px; }
.money-tbl-scroll::-webkit-scrollbar-thumb { background: var(--border-mid); border-radius: 2px; }

.money-tbl {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}
.money-tbl thead th {
  font-family: var(--font-display);
  font-size: 8.5px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(200,182,145,.55);
  padding: 13px 16px;
  text-align: left;
  background: rgba(7,10,18,.75);
  border-bottom: 1px solid rgba(201,165,87,.09);
  white-space: nowrap;
}
.money-th-item { padding-left: 22px !important; }

/* Rows */
.money-tr {
  cursor: pointer;
  border-bottom: 1px solid rgba(35,42,62,.5);
  transition: background .14s;
}
.money-tr td {
  padding: 14px 16px;
  vertical-align: middle;
  background: rgba(12,15,24,.62);
}
.money-tr:nth-child(even) td { background: rgba(9,12,21,.72); }
.money-tr:last-child { border-bottom: none; }

/* Left tier border on first cell */
.money-tr td:first-child { padding-left: 22px; border-left: 3px solid transparent; }
.money-tr.mtier-elite  td:first-child { border-left-color: var(--gold); }
.money-tr.mtier-strong td:first-child { border-left-color: var(--emerald); }
.money-tr.mtier-good   td:first-child { border-left-color: var(--crystal); }
.money-tr.mtier-entry  td:first-child { border-left-color: var(--border-mid); }

/* Row hover — tier-tinted */
.money-tr:hover td                   { background: rgba(201,165,87,.05) !important; }
.money-tr.mtier-elite:hover  td      { background: rgba(201,165,87,.08) !important; }
.money-tr.mtier-strong:hover td      { background: rgba(95,212,154,.05) !important; }
.money-tr.mtier-good:hover   td      { background: rgba(111,212,216,.05) !important; }

/* Item cell */
.money-td-item { min-width: 230px; }
.money-item-inner  { display: flex; align-items: center; gap: 12px; }
.money-item-ico {
  width: 38px; height: 38px;
  border-radius: 7px;
  background: linear-gradient(135deg, var(--bg-panel-3), var(--bg-deep));
  border: 1px solid var(--border-mid);
  overflow: hidden;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.money-item-ico img { width: 100%; height: 100%; object-fit: contain; }
.money-ico-ph { color: var(--txt-dim); }
.money-item-text { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.money-item-name {
  font-family: var(--font-display);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--txt-bright);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.money-item-cat {
  font-size: 10.5px;
  color: var(--txt-dim);
  white-space: nowrap;
}

/* Buy cell */
.money-td-buy { white-space: nowrap; }
.money-buy-price {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--txt-main);
  display: block;
  margin-bottom: 5px;
}
.money-buy-world {
  font-family: var(--font-display);
  font-size: 8.5px;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 3px;
  background: rgba(111,212,216,.09);
  color: var(--crystal-bright);
  border: 1px solid rgba(111,212,216,.16);
  white-space: nowrap;
}

/* Target cell */
.money-td-target { white-space: nowrap; }
.money-target-price {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--gold-bright);
  font-weight: 600;
  display: block;
  margin-bottom: 3px;
}
.money-avg {
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--txt-dim);
}

/* Profit cell — hero element */
.money-td-profit { white-space: nowrap; }
.money-profit {
  font-family: var(--font-mono);
  font-size: 19px;
  font-weight: 700;
  color: var(--emerald-bright);
  letter-spacing: -.01em;
  text-shadow: 0 0 18px rgba(95,212,154,.15);
}
.money-unit { font-size: 11px; color: var(--txt-mute); font-weight: 400; }

/* ROI pill — tier-colored */
.money-roi {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  padding: 4px 11px;
  border-radius: 20px;
  white-space: nowrap;
}
.money-roi.mtier-elite  { background: rgba(201,165,87,.14); color: var(--gold-bright);    border: 1px solid rgba(201,165,87,.30); }
.money-roi.mtier-strong { background: rgba(95,212,154,.11); color: var(--emerald-bright); border: 1px solid rgba(95,212,154,.25); }
.money-roi.mtier-good   { background: rgba(111,212,216,.09);color: var(--crystal-bright); border: 1px solid rgba(111,212,216,.20); }
.money-roi.mtier-entry  { background: rgba(80,80,95,.10);   color: var(--txt-main);       border: 1px solid var(--border-mid); }

/* Velocity */
.money-td-vel { white-space: nowrap; }
.money-vel {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 600;
  color: var(--txt-main);
}

/* ===================== Arbitrage ===================== */
.arb-summary {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-bottom:16px;
  align-items:stretch;
}
.arb-card {
  min-width:0;
  background:linear-gradient(180deg,rgba(12,16,24,.94),rgba(10,14,22,.98));
  border:1px solid var(--border-soft);
  border-radius:4px;
  padding:12px 14px;
  display:flex;
  flex-direction:column;
  gap:6px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.03);
}
.arb-buy  { border-color:rgba(111,212,216,.28); }
.arb-sell { border-color:rgba(201,165,87,.26); }
.arb-profit.positive { border-color:rgba(95,212,154,.34); }
.arb-profit.negative { border-color:rgba(226,92,107,.3); }
.arb-profit.positive strong { color:var(--emerald-bright); }
.arb-profit.negative strong { color:var(--ruby); }
.arb-lbl {
  font-family:var(--font-display);
  font-size:9px;
  color:var(--txt-mute);
  text-transform:uppercase;
  letter-spacing:.22em;
}
.arb-price { font-family:var(--font-mono);font-size:11px;color:var(--txt-mute); }
.arb-card strong { font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--txt-bright); }
.arb-arrow { display:none; }
.arb-table-shell {
  background:rgba(8,11,18,.42);
  border:1px solid rgba(46,54,80,.6);
  border-radius:4px;
  overflow:hidden;
}
.panel .arb-summary + table {
  width:100%;
  margin-top:6px;
  border-collapse:collapse;
  table-layout:fixed;
  background:rgba(8,11,18,.42);
  border:1px solid rgba(46,54,80,.6);
  border-radius:4px;
  overflow:hidden;
}
.panel .arb-summary + table thead th {
  text-align:left;
  padding:12px 14px;
  font-family:var(--font-display);
  font-size:9.5px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--txt-mute);
  background:rgba(255,255,255,.02);
  border-bottom:1px solid var(--border-soft);
}
.panel .arb-summary + table tbody td {
  padding:13px 14px;
  border-bottom:1px solid rgba(35,42,62,.45);
  vertical-align:middle;
}
.panel .arb-summary + table tbody tr:last-child td { border-bottom:none; }
.panel .arb-summary + table tbody tr:hover td { background:rgba(201,165,87,.04); }
.panel .arb-summary + table th:nth-child(1),
.panel .arb-summary + table td:nth-child(1) { width:34%; }
.panel .arb-summary + table th:nth-child(2),
.panel .arb-summary + table td:nth-child(2) { width:24%; }
.panel .arb-summary + table th:nth-child(3),
.panel .arb-summary + table td:nth-child(3) { width:14%; }
.panel .arb-summary + table th:nth-child(4),
.panel .arb-summary + table td:nth-child(4) { width:14%; }
.arb-table {
  width:100%;
  border-collapse:collapse;
  table-layout:fixed;
}
.arb-table thead th {
  text-align:left;
  padding:13px 14px;
  font-family:var(--font-display);
  font-size:8.5px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(200,182,145,.55);
  background:rgba(7,10,18,.75);
  border-bottom:1px solid rgba(201,165,87,.09);
  white-space:nowrap;
}
.arb-table tbody td {
  padding:13px 14px;
  border-bottom:1px solid rgba(35,42,62,.5);
  background:rgba(12,15,24,.62);
  vertical-align:middle;
}
.arb-table tbody tr:nth-child(even) td { background:rgba(9,12,21,.72); }
.arb-table tbody tr:last-child td { border-bottom:none; }
.arb-row:hover td { background:rgba(201,165,87,.05) !important; }
.arb-world-cell {
  font-weight:600;
  color:var(--txt-bright);
}
.panel .arb-summary + table .price-cell {
  font-family:var(--font-mono);
  color:var(--gold-bright);
  font-weight:600;
}
.panel .arb-summary + table .muted {
  font-family:var(--font-mono);
  color:var(--txt-main);
}
.panel .arb-summary + table .arb-row-buy td:first-child { color:var(--crystal-bright); font-weight:600; }
.panel .arb-summary + table .arb-row-sell td:first-child { color:var(--gold-bright); font-weight:600; }
.arb-row-buy .arb-world-cell { color:var(--crystal-bright); }
.arb-row-sell .arb-world-cell { color:var(--gold-bright); }
.arb-count-cell {
  font-family:var(--font-mono);
  color:var(--txt-main);
}
.arb-tag {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:88px;
  font-size:9px;
  font-weight:700;
  padding:3px 8px;
  border-radius:999px;
  text-transform:uppercase;
  letter-spacing:.14em;
}
.buy-tag  { background:rgba(111,212,216,.12);color:var(--crystal-bright);border:1px solid rgba(111,212,216,.18); }
.sell-tag { background:rgba(201,165,87,.12);color:var(--gold-bright);border:1px solid rgba(201,165,87,.18); }
.arb-tag-neutral { background:rgba(255,255,255,.04);color:var(--txt-mute);border:1px solid rgba(255,255,255,.05); }

/* ===================== Collection ===================== */
.collect-id-block { background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:4px;padding:18px 20px;margin-bottom:20px;max-width:520px; }
.collect-id-label { display:block;font-family:var(--font-display);font-size:9.5px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.2em;margin-bottom:10px; }
.collect-id-row { display:flex;gap:10px;align-items:center;margin-bottom:12px; }
.collect-id-input { flex:1;background:var(--bg-deep);border:1px solid var(--border-mid);border-radius:4px;color:var(--txt-bright);padding:9px 14px;font-family:var(--font-mono);font-size:16px;font-weight:600;letter-spacing:1px;outline:none;transition:border-color .2s;-moz-appearance:textfield; }
.collect-id-input::-webkit-outer-spin-button,.collect-id-input::-webkit-inner-spin-button { -webkit-appearance:none;margin:0; }
.collect-id-input:focus { border-color:var(--gold-dim); }
.collect-id-hint { font-size:11px;color:var(--txt-mute);line-height:1.7; }
.collect-id-hint code { background:var(--bg-panel-3);border-radius:3px;padding:1px 5px;font-family:var(--font-mono);font-size:11px;color:var(--gold-bright); }
.collect-link { color:var(--gold);text-decoration:none; }
.collect-link:hover { text-decoration:underline; }
.btn-collect-search { background:linear-gradient(180deg,rgba(201,165,87,.18),rgba(201,165,87,.08));border:1px solid var(--gold-dim);color:var(--gold-bright);padding:9px 20px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap;transition:all .2s; }
.btn-collect-search:hover { box-shadow:0 0 14px var(--gold-glow); }
.coll-stat-chips { display:flex;flex-wrap:wrap;gap:8px;margin:12px 0; }
.coll-stat-chip { background:var(--bg-panel);border:1px solid var(--border-soft);border-radius:20px;padding:5px 12px;font-size:12px; }
.collect-external-link { margin-top:16px;text-align:center; }
.btn-collect-ext { display:inline-block;padding:10px 24px;background:linear-gradient(135deg,var(--gold),var(--gold-bright));color:#1a1610;border-radius:6px;font-weight:800;font-family:var(--font-display);font-size:11px;letter-spacing:.12em;text-decoration:none;text-transform:uppercase;transition:opacity .15s; }
.btn-collect-ext:hover { opacity:.85; }
.char-card {
  display:flex;align-items:center;gap:18px;
  background:
    linear-gradient(90deg,
      transparent 0%, rgba(201,165,87,.08) 15%,
      rgba(201,165,87,.45) 35%, rgba(240,198,116,.72) 50%,
      rgba(201,165,87,.45) 65%, rgba(201,165,87,.08) 85%,
      transparent 100%) top / 100% 2px no-repeat,
    radial-gradient(ellipse 280px 160px at 0% 0%, rgba(201,165,87,.04), transparent 60%),
    linear-gradient(180deg, rgba(14,18,28,.98), rgba(9,12,20,.99));
  border:1px solid rgba(201,165,87,.20);
  border-radius:4px;
  padding:18px 22px;
  margin-bottom:16px;
  flex-wrap:wrap;
  box-shadow: 0 20px 50px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.03);
}
.char-avatar { width:64px;height:64px;border-radius:50%;object-fit:cover;background:var(--bg-panel-3);flex-shrink:0;border:2px solid rgba(201,165,87,.35); box-shadow: 0 0 18px rgba(201,165,87,.15); }
.char-info { flex:1;min-width:0; }
.char-info h3 { font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--txt-bright);margin-bottom:2px;letter-spacing:.08em; text-shadow: 0 0 20px rgba(240,198,116,.15); }
.char-title { font-family:var(--font-serif);font-size:11px;color:var(--gold-dim);font-style:italic;margin-bottom:3px; letter-spacing:.06em; }
.char-stats { display:flex;gap:20px;flex-shrink:0; }
.char-stat { display:flex;flex-direction:column;align-items:center;gap:2px; }
.char-stat-val { font-family:var(--font-mono);font-size:22px;font-weight:700;color:var(--gold-bright);line-height:1; text-shadow: 0 0 16px rgba(240,198,116,.22); }
.char-stat-lbl { font-family:var(--font-display);font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--txt-dim);text-align:center;line-height:1.4; }
.collect-progress-row { display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px; }
.collect-progress-block {
  background:
    linear-gradient(90deg,
      transparent 0%, rgba(201,165,87,.07) 20%,
      rgba(201,165,87,.35) 50%,
      rgba(201,165,87,.07) 80%, transparent 100%) top / 100% 1px no-repeat,
    linear-gradient(180deg, rgba(14,18,28,.96), rgba(9,12,20,.98));
  border:1px solid rgba(201,165,87,.14);
  border-radius:4px;
  padding:14px 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.cpr-label { display:flex;justify-content:space-between;font-size:12px;color:var(--txt-mute);margin-bottom:8px; }
.cpr-bar { height:5px;background:var(--bg-panel-3);border-radius:3px;overflow:hidden; }
.cpr-fill { height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-bright));border-radius:3px;transition:width .6s ease; }
.cpr-fill-minion { background:linear-gradient(90deg,var(--violet),#c4b5fd); }

/* ===================== Shards guide ===================== */
.shards-resource-grid {
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-bottom:20px;
}
.shards-resource-card {
  position:relative;
  overflow:hidden;
  padding:18px 18px 16px;
}
.shards-resource-card::after {
  content:"";
  position:absolute;
  inset:auto -20% -40% auto;
  width:180px;
  height:180px;
  border-radius:50%;
  opacity:.22;
  filter:blur(8px);
}
.shards-resource-card-cyan::after { background:radial-gradient(circle,rgba(111,212,216,.38),transparent 65%); }
.shards-resource-card-gold::after { background:radial-gradient(circle,rgba(201,165,87,.34),transparent 65%); }
.shards-resource-card-violet::after { background:radial-gradient(circle,rgba(176,140,217,.34),transparent 65%); }
.shards-resource-head {
  position:relative;
  z-index:1;
  margin-bottom:10px;
}
.shards-resource-kicker {
  display:block;
  font-family:var(--font-display);
  font-size:10px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--txt-mute);
  margin-bottom:6px;
}
.shards-resource-head h3 {
  margin:0;
  font-size:22px;
  color:var(--txt-bright);
}
.shards-resource-card p {
  position:relative;
  z-index:1;
  margin:0 0 14px;
  color:var(--txt-main);
  line-height:1.55;
}
.shards-resource-stats {
  position:relative;
  z-index:1;
  display:grid;
  gap:10px;
}
.shards-resource-stats div {
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:10px 12px;
  border:1px solid var(--border-soft);
  border-radius:4px;
  background:rgba(10,13,20,.58);
}
.shards-resource-stats span {
  color:var(--txt-mute);
  font-size:11px;
}
.shards-resource-stats strong {
  color:var(--txt-bright);
  font-size:12px;
}
.shards-guide-grid {
  display:grid;
  grid-template-columns:1.2fr .95fr;
  gap:20px;
  margin-bottom:20px;
}
.shards-decision-table {
  display:flex;
  flex-direction:column;
  gap:10px;
}
.shards-decision-row,
.shards-shortcut-card {
  background:
    linear-gradient(90deg,
      transparent 0%, rgba(201,165,87,.07) 20%,
      rgba(201,165,87,.28) 50%,
      rgba(201,165,87,.07) 80%, transparent 100%) top / 100% 1px no-repeat,
    linear-gradient(180deg, rgba(12,15,24,.97), rgba(8,11,19,.99));
  border:1px solid rgba(201,165,87,.15);
  border-radius:4px;
  padding:16px 18px;
  display:flex;
  flex-direction:column;
  gap:8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
}
.shards-shortcut-card strong {
  font-family:var(--font-display);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--txt-bright);
}
.shards-shortcut-card p {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:12px;
  color:var(--txt-mute);
  margin:0;
  line-height:1.55;
}
.shards-shortcuts-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.shards-badge {
  display:inline-block;
  font-family:var(--font-display);
  font-size:8px;
  letter-spacing:.22em;
  text-transform:uppercase;
  padding:3px 10px;
  border-radius:20px;
  font-weight:600;
  width:fit-content;
}
.shards-badge-cyan   { background:rgba(111,212,216,.12); color:var(--crystal-bright); border:1px solid rgba(111,212,216,.22); }
.shards-badge-gold   { background:rgba(201,165,87,.12);  color:var(--gold-bright);    border:1px solid rgba(201,165,87,.25); }
.shards-badge-violet { background:rgba(176,140,217,.12); color:#c4b5fd;               border:1px solid rgba(176,140,217,.22); }

.shards-decision-row {
  display:grid;
  grid-template-columns:1.4fr 1.2fr 1.4fr;
  gap:12px;
  padding:10px 12px;
  border-radius:6px;
  font-size:12.5px;
  border-bottom:1px solid rgba(35,42,62,.5);
}
.shards-decision-row:last-child { border-bottom:none; }
.shards-decision-head {
  font-family:var(--font-display);
  font-size:8.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(200,182,145,.45);
  padding-bottom:8px;
  border-bottom:1px solid rgba(201,165,87,.1);
}
.shards-decision-row strong { color:var(--gold-bright); font-weight:600; }
.shards-decision-row em     { color:var(--txt-mute); font-style:italic; font-family:var(--font-serif); }
.shards-decision-row span   { color:var(--txt-main); }
.shards-decision-row:not(.shards-decision-head):hover { background:rgba(201,165,87,.04); }

.shards-loop-list { display:flex; flex-direction:column; gap:12px; }
.shards-loop-step {
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.shards-loop-step > span {
  width:24px; height:24px;
  border-radius:50%;
  background:rgba(201,165,87,.12);
  border:1px solid rgba(201,165,87,.28);
  color:var(--gold-bright);
  font-family:var(--font-display);
  font-size:11px;
  font-weight:700;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  margin-top:1px;
}
.shards-loop-step > div strong {
  display:block;
  font-family:var(--font-display);
  font-size:11px;
  letter-spacing:.08em;
  color:var(--txt-bright);
  margin-bottom:3px;
}
.shards-loop-step > div p {
  font-family:var(--font-serif);
  font-style:italic;
  font-size:12px;
  color:var(--txt-mute);
  margin:0;
  line-height:1.5;
}

/* ===================== Responsive ===================== */
@media (max-width:1180px) {
  .money-shell-hd { flex-direction:column; align-items:flex-start; gap:18px; }
  .money-shell-hd-stats { flex-wrap:wrap; gap:14px; }
  .money-shell-sep { display:none; }
  .shards-resource-grid { grid-template-columns:1fr 1fr; }
  .shards-shortcuts-grid { grid-template-columns:1fr 1fr; }
  .shards-guide-grid { grid-template-columns:1fr; }
  .shards-decision-row { grid-template-columns:1fr 1fr; }
  .shards-decision-row em { display:none; }
}
@media (max-width:780px) {
  .shards-resource-grid { grid-template-columns:1fr; }
  .shards-shortcuts-grid { grid-template-columns:1fr; }
  .stat-grid { grid-template-columns:repeat(2,1fr); }
  .tables-grid { grid-template-columns:1fr; }
}

/* ===================== Séparateur Opportunités ===================== */
.opp-sep {
  height: 1px;
  margin: 8px 0 24px;
  background: linear-gradient(90deg,
    transparent 0%, rgba(201,165,87,.08) 15%,
    rgba(201,165,87,.35) 35%, rgba(240,198,116,.55) 50%,
    rgba(201,165,87,.35) 65%, rgba(201,165,87,.08) 85%,
    transparent 100%);
}
