/* ═══════════════════════════════════════════════
   CERBERUS — Design System
   Dark terminal default · Light mode toggle
   ═══════════════════════════════════════════════ */

/* ── Full-screen template styles ────────────────
   When using the Cerberus Full Screen template,
   the theme chrome is gone entirely. These rules
   are a fallback for standard page template use.  */

body.cerberus-full-page #page,
body.cerberus-full-page .widget-area,
body.cerberus-full-page .entry-header,
body.cerberus-full-page .entry-title,
body.cerberus-full-page .entry-footer,
body.cerberus-full-page #masthead,
body.cerberus-full-page #colophon {
  display: none !important;
}

body.cerberus-full-page #content,
body.cerberus-full-page #primary,
body.cerberus-full-page #main,
body.cerberus-full-page .site-main,
body.cerberus-full-page .entry-content,
body.cerberus-full-page article.page,
body.cerberus-full-page .default-max-width {
  max-width: 100% !important;
  width:     100% !important;
  padding:   0    !important;
  margin:    0    !important;
  float:     none !important;
}

.cerberus-page-wrap {
  width:      100%;
  max-width:  none;
  box-sizing: border-box;
}

/* ── Tokens: Dark (default) ── */
:root,
.cerberus[data-theme="dark"] {
  --cb-bg:        #0F1117;
  --cb-surface:   #161B26;
  --cb-surface2:  #1C2333;
  --cb-surface3:  #232B3E;
  --cb-border:    #2D3748;
  --cb-border2:   #3D4A5C;
  --cb-text:      #E2E8F0;
  --cb-text2:     #CBD5E0;
  --cb-muted:     #718096;
  --cb-faint:     #4A5568;
  --cb-gold:      #C9A84C;
  --cb-gold2:     #E8C46A;
  --cb-gold-bg:   rgba(201,168,76,0.10);
  --cb-gold-text: #1A1200;
  --cb-pos:       #4ADE80;
  --cb-pos-bg:    rgba(74,222,128,0.10);
  --cb-neg:       #F87171;
  --cb-neg-bg:    rgba(248,113,113,0.10);
  --cb-warn:      #FBBF24;
  --cb-warn-bg:   rgba(251,191,36,0.10);
  --cb-info:      #60A5FA;
  --cb-info-bg:   rgba(96,165,250,0.10);
  --cb-mono:      'SF Mono','Fira Code','Cascadia Code','Consolas',monospace;
  --cb-radius:    8px;
  --cb-radius-lg: 12px;
}

/* ── Tokens: Light ── */
.cerberus[data-theme="light"] {
  --cb-bg:        #F8F9FA;
  --cb-surface:   #FFFFFF;
  --cb-surface2:  #F1F3F5;
  --cb-surface3:  #E9ECEF;
  --cb-border:    #DEE2E6;
  --cb-border2:   #CED4DA;
  --cb-text:      #1A1D23;
  --cb-text2:     #343A40;
  --cb-muted:     #6C757D;
  --cb-faint:     #ADB5BD;
  --cb-gold:      #996B1A;
  --cb-gold2:     #7A5214;
  --cb-gold-bg:   rgba(153,107,26,0.08);
  --cb-gold-text: #FFFFFF;
  --cb-pos:       #1A7A3A;
  --cb-pos-bg:    rgba(26,122,58,0.08);
  --cb-neg:       #C0392B;
  --cb-neg-bg:    rgba(192,57,43,0.08);
  --cb-warn:      #9A6B00;
  --cb-warn-bg:   rgba(154,107,0,0.08);
  --cb-info:      #1565C0;
  --cb-info-bg:   rgba(21,101,192,0.08);
}

/* ── Reset ── */
.cerberus * { box-sizing: border-box; margin: 0; padding: 0; }
.cerberus { font-family: var(--font-sans, system-ui, sans-serif); font-size: 13px; color: var(--cb-text); background: var(--cb-bg); border: 0.5px solid var(--cb-border); border-radius: var(--cb-radius-lg); overflow: hidden; width: 100%; min-height: 100vh; line-height: 1.5; }

/* ── Scrollbars ── */
.cerberus ::-webkit-scrollbar { width: 4px; height: 4px; }
.cerberus ::-webkit-scrollbar-track { background: transparent; }
.cerberus ::-webkit-scrollbar-thumb { background: var(--cb-border2); border-radius: 2px; }

/* ═══════════════════════════════════════════════
   TOP BAR
   ═══════════════════════════════════════════════ */
.cb-topbar {
  background: var(--cb-surface);
  border-bottom: 0.5px solid var(--cb-border);
  height: 48px;
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 0;
  flex-shrink: 0;
}

/* Logo */
.cb-logo {
  display: flex;
  align-items: center;
  gap: 9px;
  padding-right: 18px;
  border-right: 0.5px solid var(--cb-border);
  margin-right: 4px;
  flex-shrink: 0;
}
.cb-logo-icon {
  width: 26px;
  height: 26px;
  background: var(--cb-gold);
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.cb-logo-icon svg { display: block; }
.cb-logo-name { font-size: 13px; font-weight: 500; color: var(--cb-text); letter-spacing: 0.02em; }
.cb-logo-ver  { font-size: 9px;  color: var(--cb-muted); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 1px; }

/* Nav tabs */
.cb-tabs { display: flex; height: 48px; }
.cb-tab {
  height: 48px;
  padding: 0 15px;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--cb-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
  white-space: nowrap;
  user-select: none;
}
.cb-tab:hover { color: var(--cb-text2); }
.cb-tab.cb-active { color: var(--cb-gold); border-bottom-color: var(--cb-gold); }
.cb-tab-badge {
  font-size: 9px;
  background: var(--cb-surface3);
  color: var(--cb-muted);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: var(--cb-mono);
}
.cb-tab.cb-active .cb-tab-badge { background: var(--cb-gold-bg); color: var(--cb-gold); }

/* Top bar right */
.cb-topbar-right { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.cb-last-updated { font-size: 10px; color: var(--cb-faint); font-family: var(--cb-mono); letter-spacing: 0.02em; padding-right: 8px; border-right: 0.5px solid var(--cb-border); margin-right: 2px; }

/* ── Buttons ── */
.cb-btn {
  background: transparent;
  border: 0.5px solid var(--cb-border);
  color: var(--cb-muted);
  font-size: 11px;
  padding: 5px 11px;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  letter-spacing: 0.02em;
  transition: color 0.15s, border-color 0.15s;
  font-family: inherit;
  white-space: nowrap;
}
.cb-btn:hover { border-color: var(--cb-border2); color: var(--cb-text2); }
.cb-btn.cb-btn-gold { background: var(--cb-gold); border-color: var(--cb-gold); color: var(--cb-gold-text); font-weight: 500; }
.cb-btn.cb-btn-gold:hover { background: var(--cb-gold2); border-color: var(--cb-gold2); }
.cb-btn.cb-btn-ghost { border-color: transparent; }
.cb-btn.cb-btn-ghost:hover { border-color: var(--cb-border); background: var(--cb-surface2); }
.cb-btn svg { width: 11px; height: 11px; flex-shrink: 0; }

/* Theme toggle */
.cb-theme-toggle {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 0.5px solid var(--cb-border);
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cb-muted);
  transition: color 0.15s, border-color 0.15s;
  flex-shrink: 0;
}
.cb-theme-toggle:hover { color: var(--cb-gold); border-color: var(--cb-gold); }
.cb-theme-toggle svg { width: 13px; height: 13px; display: block; }

/* ═══════════════════════════════════════════════
   VIEWS
   ═══════════════════════════════════════════════ */
.cb-view { padding: 14px 16px; display: none; }
.cb-view.cb-active { display: block; }

/* ── Stat cards row ── */
.cb-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 14px; }
@media (max-width: 640px) { .cb-stats { grid-template-columns: repeat(2, 1fr); } }
.cb-stat {
  background: var(--cb-surface);
  border: 0.5px solid var(--cb-border);
  border-radius: var(--cb-radius);
  padding: 11px 13px;
}
.cb-stat-label { font-size: 9px; color: var(--cb-muted); letter-spacing: 0.07em; text-transform: uppercase; margin-bottom: 5px; }
.cb-stat-value { font-size: 19px; font-weight: 500; font-family: var(--cb-mono); color: var(--cb-text); }
.cb-stat-value.cb-pos  { color: var(--cb-pos); }
.cb-stat-value.cb-neg  { color: var(--cb-neg); }
.cb-stat-value.cb-gold { color: var(--cb-gold); }
.cb-stat-value.cb-info { color: var(--cb-info); }
.cb-stat-sub { font-size: 10px; color: var(--cb-muted); margin-top: 2px; }

/* ── Toolbar ── */
.cb-toolbar { display: flex; align-items: center; gap: 6px; margin-bottom: 10px; flex-wrap: wrap; }
.cb-section-label { font-size: 10px; color: var(--cb-muted); letter-spacing: 0.08em; text-transform: uppercase; }
.cb-spacer { flex: 1; }
.cb-pill {
  font-size: 10px;
  padding: 3px 9px;
  border-radius: 4px;
  border: 0.5px solid var(--cb-border);
  color: var(--cb-muted);
  cursor: pointer;
  transition: all 0.12s;
  user-select: none;
  background: transparent;
}
.cb-pill:hover { border-color: var(--cb-border2); color: var(--cb-text2); }
.cb-pill.cb-active { background: var(--cb-gold-bg); border-color: var(--cb-gold); color: var(--cb-gold); }
.cb-search {
  background: var(--cb-surface);
  border: 0.5px solid var(--cb-border);
  border-radius: 5px;
  color: var(--cb-text);
  padding: 4px 10px;
  font-size: 11px;
  width: 150px;
  font-family: inherit;
}
.cb-search:focus { outline: none; border-color: var(--cb-gold); }
.cb-search::placeholder { color: var(--cb-faint); }

/* ── Divider ── */
.cb-divider { height: 0.5px; background: var(--cb-border); margin: 14px 0; }

/* ═══════════════════════════════════════════════
   PORTFOLIO TABLE
   ═══════════════════════════════════════════════ */
.cb-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.cb-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 800px;
}
.cb-table th {
  font-size: 9px;
  color: var(--cb-muted);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-bottom: 0.5px solid var(--cb-border);
  text-align: left;
  font-weight: 400;
  white-space: nowrap;
  background: var(--cb-surface);
  position: sticky;
  top: 0;
  z-index: 2;
}
.cb-table th.cb-r { text-align: right; }
.cb-table td { padding: 0; border-bottom: 0.5px solid var(--cb-surface2); }
.cb-table tr.cb-coin-row { cursor: pointer; }
.cb-table tr.cb-coin-row:hover td { background: var(--cb-surface2); }

/* Row inner (flex wrapper for consistent padding) */
.cb-ri { display: flex; align-items: center; padding: 9px 10px; }

/* Coin badge */
.cb-coin-badge {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 500;
  flex-shrink: 0;
  margin-right: 9px;
  font-family: var(--cb-mono);
  text-transform: uppercase;
}
.cb-coin-name  { font-size: 12px; font-weight: 500; color: var(--cb-text); }
.cb-coin-exch  { font-size: 9px;  color: var(--cb-muted); margin-top: 1px; }

/* Mono cells */
.cb-mono-cell { font-family: var(--cb-mono); font-size: 12px; text-align: right; color: var(--cb-text2); padding: 9px 10px; white-space: nowrap; }
.cb-mono-cell .cb-sub { font-size: 9px; color: var(--cb-muted); margin-top: 1px; }
.cb-mono-cell.cb-pos { color: var(--cb-pos); }
.cb-mono-cell.cb-neg { color: var(--cb-neg); }
.cb-mono-cell.cb-gold { color: var(--cb-gold); }
.cb-mono-cell.cb-warn { color: var(--cb-warn); }

/* Badges */
.cb-badge { display: inline-block; font-size: 10px; padding: 2px 7px; border-radius: 3px; white-space: nowrap; }
.cb-badge-hodl  { background: rgba(29,158,117,0.12); color: #5DCAA5; border: 0.5px solid rgba(29,158,117,0.22); }
.cb-badge-watch { background: var(--cb-gold-bg);      color: var(--cb-gold);  border: 0.5px solid rgba(201,168,76,0.22); }
.cb-badge-sell  { background: var(--cb-neg-bg);        color: var(--cb-neg);   border: 0.5px solid rgba(248,113,113,0.22); }
.cb-badge-short { background: rgba(127,119,221,0.10);  color: #AFA9EC;         border: 0.5px solid rgba(127,119,221,0.22); }
.cb-badge-lt    { background: rgba(29,158,117,0.08);   color: #5DCAA5;         border: 0.5px solid rgba(29,158,117,0.18); }
.cb-badge-st    { background: var(--cb-warn-bg);       color: var(--cb-warn);  border: 0.5px solid rgba(251,191,36,0.22); }
.cb-badge-bull  { background: rgba(29,158,117,0.08);   color: #5DCAA5;         border: 0.5px solid rgba(29,158,117,0.18); }
.cb-badge-bear  { background: var(--cb-neg-bg);        color: var(--cb-neg);   border: 0.5px solid rgba(248,113,113,0.22); }
.cb-badge-neut  { background: var(--cb-surface3);      color: var(--cb-muted); border: 0.5px solid var(--cb-border); }

/* Score bar */
.cb-score { display: flex; align-items: center; gap: 5px; padding: 9px 10px; }
.cb-score-bar-bg  { width: 38px; height: 3px; background: var(--cb-border); border-radius: 2px; flex-shrink: 0; }
.cb-score-bar     { height: 3px; border-radius: 2px; transition: width 0.3s; }
.cb-score-num     { font-size: 10px; font-family: var(--cb-mono); color: var(--cb-muted); }
.cb-score-num.cb-pos  { color: var(--cb-pos); }
.cb-score-num.cb-warn { color: var(--cb-warn); }
.cb-score-num.cb-neg  { color: var(--cb-neg); }

/* ── Expanded panel ── */
.cb-expand-row td { padding: 0; }
.cb-expand-panel {
  background: var(--cb-surface2);
  border-bottom: 0.5px solid var(--cb-border);
}
.cb-expand-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap: 0.5px;
  background: var(--cb-border);
}
@media (max-width: 700px) { .cb-expand-grid { grid-template-columns: 1fr 1fr; } }
.cb-expand-cell {
  background: var(--cb-surface2);
  padding: 12px 14px;
}
.cb-expand-label {
  font-size: 9px;
  color: var(--cb-muted);
  letter-spacing: 0.07em;
  text-transform: uppercase;
  margin-bottom: 7px;
}
.cb-expand-label + .cb-expand-label { margin-top: 10px; }
.cb-point { font-size: 11px; padding: 2px 0; display: flex; gap: 5px; line-height: 1.4; }
.cb-point-pos { color: var(--cb-pos); }
.cb-point-neg { color: var(--cb-neg); }
.cb-point-ev  { color: var(--cb-text2); }
.cb-point-sym { flex-shrink: 0; }
.cb-expand-price { font-size: 17px; font-weight: 500; font-family: var(--cb-mono); color: var(--cb-gold); margin-bottom: 3px; }
.cb-expand-sub   { font-size: 10px; color: var(--cb-muted); }
.cb-history-range { display: flex; justify-content: space-between; font-size: 10px; color: var(--cb-muted); font-family: var(--cb-mono); margin-top: 6px; }

/* Expand form inputs */
.cb-form-field { margin-bottom: 6px; }
.cb-form-label { font-size: 9px; color: var(--cb-muted); letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 3px; }
.cb-form-input, .cb-form-select {
  width: 100%;
  background: var(--cb-surface3);
  border: 0.5px solid var(--cb-border);
  border-radius: 4px;
  padding: 5px 7px;
  font-size: 11px;
  font-family: var(--cb-mono);
  color: var(--cb-text);
}
.cb-form-select { font-family: inherit; }
.cb-form-input:focus, .cb-form-select:focus { outline: none; border-color: var(--cb-gold); }
.cb-form-save {
  margin-top: 8px;
  width: 100%;
  background: var(--cb-gold);
  border: none;
  color: var(--cb-gold-text);
  font-size: 11px;
  font-weight: 500;
  padding: 6px 10px;
  border-radius: 4px;
  cursor: pointer;
  letter-spacing: 0.03em;
  font-family: inherit;
  transition: background 0.12s;
}
.cb-form-save:hover { background: var(--cb-gold2); }

/* Chart canvas */
.cb-chart-wrap { position: relative; height: 80px; margin-top: 6px; }
.cb-chart-wrap canvas { max-height: 80px; }

/* ═══════════════════════════════════════════════
   RESEARCH TABLE
   ═══════════════════════════════════════════════ */
.cb-research-table { width: 100%; border-collapse: collapse; }
.cb-research-table th { font-size: 9px; color: var(--cb-muted); letter-spacing: 0.07em; text-transform: uppercase; padding: 6px 10px; border-bottom: 0.5px solid var(--cb-border); text-align: left; font-weight: 400; background: var(--cb-surface); }
.cb-research-table td { padding: 8px 10px; border-bottom: 0.5px solid var(--cb-surface2); font-size: 12px; color: var(--cb-text2); }
.cb-research-table tr:hover td { background: var(--cb-surface2); }
.cb-research-trigger-row { font-size: 10px; color: var(--cb-gold); border: 0.5px solid var(--cb-gold); background: var(--cb-gold-bg); padding: 3px 8px; border-radius: 4px; cursor: pointer; display: inline-flex; align-items: center; gap: 4px; }

/* ═══════════════════════════════════════════════
   NEWS VIEW
   ═══════════════════════════════════════════════ */
.cb-news-layout {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 0.5px;
  background: var(--cb-border);
  border-radius: var(--cb-radius);
  overflow: hidden;
  border: 0.5px solid var(--cb-border);
}
@media (max-width: 600px) { .cb-news-layout { grid-template-columns: 1fr; } }

.cb-news-sidebar { background: var(--cb-surface); }
.cb-news-sidebar-header { padding: 9px 12px; border-bottom: 0.5px solid var(--cb-border); font-size: 9px; color: var(--cb-muted); letter-spacing: 0.07em; text-transform: uppercase; }
.cb-news-coin {
  padding: 8px 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 0.5px solid var(--cb-surface2);
  transition: background 0.1s;
}
.cb-news-coin:hover { background: var(--cb-surface2); }
.cb-news-coin.cb-active { background: var(--cb-surface3); }
.cb-news-coin-name { font-size: 11px; color: var(--cb-text); font-weight: 500; }
.cb-news-coin-count { font-size: 9px; color: var(--cb-muted); background: var(--cb-surface3); padding: 1px 5px; border-radius: 3px; font-family: var(--cb-mono); }

.cb-news-feed { background: var(--cb-bg); }
.cb-news-article { padding: 10px 13px; border-bottom: 0.5px solid var(--cb-surface2); cursor: pointer; transition: background 0.1s; }
.cb-news-article:hover { background: var(--cb-surface); }
.cb-news-article.cb-featured { border-left: 2px solid var(--cb-gold); }
.cb-news-source { font-size: 9px; color: var(--cb-gold); letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 3px; }
.cb-news-title  { font-size: 12px; color: var(--cb-text); line-height: 1.4; margin-bottom: 3px; font-weight: 500; }
.cb-news-desc   { font-size: 10px; color: var(--cb-muted); line-height: 1.4; }
.cb-news-meta   { font-size: 9px; color: var(--cb-faint); margin-top: 4px; font-family: var(--cb-mono); }
.cb-news-empty  { padding: 24px; text-align: center; font-size: 12px; color: var(--cb-muted); }

/* ═══════════════════════════════════════════════
   REPORTS
   ═══════════════════════════════════════════════ */
.cb-reports-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
@media (max-width: 600px) { .cb-reports-grid { grid-template-columns: 1fr; } }
.cb-report-card {
  background: var(--cb-surface);
  border: 0.5px solid var(--cb-border);
  border-radius: var(--cb-radius);
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color 0.15s;
}
.cb-report-card:hover { border-color: var(--cb-border2); }
.cb-report-header { display: flex; align-items: center; gap: 10px; }
.cb-report-icon { width: 32px; height: 32px; border-radius: 6px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cb-report-title { font-size: 13px; font-weight: 500; color: var(--cb-text); }
.cb-report-meta  { font-size: 10px; color: var(--cb-muted); font-family: var(--cb-mono); margin-top: 1px; }
.cb-report-desc  { font-size: 11px; color: var(--cb-muted); line-height: 1.5; }
.cb-report-btn {
  margin-top: auto;
  background: var(--cb-surface2);
  border: 0.5px solid var(--cb-border);
  color: var(--cb-text2);
  font-size: 11px;
  padding: 7px 12px;
  border-radius: 5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  justify-content: center;
  letter-spacing: 0.02em;
  font-family: inherit;
  transition: all 0.12s;
}
.cb-report-btn:hover { border-color: var(--cb-gold); color: var(--cb-gold); }
.cb-report-btn.cb-btn-gold { background: var(--cb-gold); border-color: var(--cb-gold); color: var(--cb-gold-text); font-weight: 500; }
.cb-report-btn.cb-btn-gold:hover { background: var(--cb-gold2); }
.cb-report-btn svg { width: 11px; height: 11px; flex-shrink: 0; }
.cb-report-last { font-size: 10px; color: var(--cb-faint); font-family: var(--cb-mono); text-align: center; margin-top: 2px; }

/* ═══════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════ */
.cb-modal-backdrop {
  min-height: 300px;
  background: rgba(0,0,0,0.55);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 24px 16px;
}
.cb-modal {
  background: var(--cb-surface);
  border: 0.5px solid var(--cb-border);
  border-radius: var(--cb-radius-lg);
  width: 100%;
  max-width: 520px;
  padding: 20px;
}
.cb-modal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.cb-modal-title  { font-size: 14px; font-weight: 500; color: var(--cb-text); }
.cb-modal-close  { background: transparent; border: none; color: var(--cb-muted); cursor: pointer; font-size: 18px; line-height: 1; padding: 0 2px; }
.cb-modal-close:hover { color: var(--cb-text); }

/* ═══════════════════════════════════════════════
   MESSAGES
   ═══════════════════════════════════════════════ */
.cb-message { font-size: 12px; padding: 8px 12px; border-radius: 5px; margin-bottom: 10px; }
.cb-message-success { background: var(--cb-pos-bg);  color: var(--cb-pos);  border: 0.5px solid rgba(74,222,128,0.25); }
.cb-message-error   { background: var(--cb-neg-bg);  color: var(--cb-neg);  border: 0.5px solid rgba(248,113,113,0.25); }
.cb-message-info    { background: var(--cb-info-bg); color: var(--cb-info); border: 0.5px solid rgba(96,165,250,0.25); }

/* ═══════════════════════════════════════════════
   LOADING STATES
   ═══════════════════════════════════════════════ */
.cb-loading { display: flex; align-items: center; gap: 8px; color: var(--cb-muted); font-size: 12px; padding: 20px; }
.cb-spinner { width: 14px; height: 14px; border: 1.5px solid var(--cb-border); border-top-color: var(--cb-gold); border-radius: 50%; animation: cb-spin 0.7s linear infinite; flex-shrink: 0; }
@keyframes cb-spin { to { transform: rotate(360deg); } }
.cb-empty { padding: 32px 16px; text-align: center; color: var(--cb-muted); font-size: 12px; }

/* ═══════════════════════════════════════════════
   UTILITIES
   ═══════════════════════════════════════════════ */
.cb-sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.cb-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cb-mono { font-family: var(--cb-mono) !important; }
.cb-pos  { color: var(--cb-pos)  !important; }
.cb-neg  { color: var(--cb-neg)  !important; }
.cb-gold { color: var(--cb-gold) !important; }
.cb-muted-text { color: var(--cb-muted) !important; }
.cb-hidden { display: none !important; }

/* ═══════════════════════════════════════════════
   ALERTS — visible on all tabs, desktop + mobile
   ═══════════════════════════════════════════════ */

.cb-alert-strip {
  background: rgba(251,191,36,0.06);
  border-bottom: .5px solid rgba(251,191,36,0.18);
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.35s ease;
}
.cb-alert-strip.cb-has-alerts { max-height: 500px; }

.cb-alert-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 14px;
  border-bottom: .5px solid rgba(251,191,36,0.12);
}
.cb-alert-header-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 9px;
  color: var(--cb-warn);
  letter-spacing: .07em;
  text-transform: uppercase;
  font-weight: 500;
}
.cb-alert-pulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--cb-warn);
  animation: cb-pulse 2s infinite;
  flex-shrink: 0;
}
.cb-alert-count {
  background: var(--cb-warn);
  color: #1A1200;
  font-size: 9px;
  font-weight: 500;
  padding: 1px 5px;
  border-radius: 3px;
  font-family: var(--cb-mono);
}
.cb-alert-dismiss-all {
  font-size: 10px;
  color: var(--cb-faint);
  cursor: pointer;
  padding: 2px 8px;
  border: .5px solid var(--cb-border);
  border-radius: 4px;
  background: transparent;
  font-family: inherit;
}
.cb-alert-dismiss-all:hover { color: var(--cb-text2); border-color: var(--cb-border2); }

.cb-alert-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 14px;
  border-bottom: .5px solid rgba(251,191,36,0.08);
  cursor: pointer;
  transition: background 0.1s;
  text-decoration: none;
}
.cb-alert-item:last-child { border-bottom: none; }
.cb-alert-item:hover { background: rgba(251,191,36,0.05); }
.cb-alert-coin {
  font-size: 10px;
  font-weight: 500;
  color: var(--cb-warn);
  font-family: var(--cb-mono);
  flex-shrink: 0;
  min-width: 40px;
  margin-top: 1px;
}
.cb-alert-body { flex: 1; min-width: 0; }
.cb-alert-title {
  font-size: 11px;
  color: var(--cb-text2);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cb-alert-source {
  font-size: 9px;
  color: var(--cb-faint);
  font-family: var(--cb-mono);
  margin-top: 2px;
}
.cb-alert-dismiss-item {
  font-size: 14px;
  color: var(--cb-faint);
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
  flex-shrink: 0;
  background: transparent;
  border: none;
  font-family: inherit;
}
.cb-alert-dismiss-item:hover { color: var(--cb-text); }

/* News dot on coin rows */
.cb-news-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--cb-warn);
  display: inline-block;
  margin-left: 6px;
  vertical-align: middle;
  flex-shrink: 0;
  animation: cb-pulse 2s infinite;
  cursor: pointer;
}
@keyframes cb-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.35; }
}

/* ═══════════════════════════════════════════════
   MOBILE — iPhone Safari optimised
   Breakpoint: 768px
   ═══════════════════════════════════════════════ */

/* PWA standalone mode */
@media (display-mode: standalone) {
  .cerberus { border-radius: 0; border: none; }
  .cb-topbar { padding-top: env(safe-area-inset-top, 0px); }
  .cb-mobile-nav { padding-bottom: env(safe-area-inset-bottom, 0px); }
}

@media (max-width: 768px) {

  /* Hide desktop-only controls */
  #cb-btn-upload,
  #cb-btn-manage-uploads,
  #cb-btn-transfers,
  .cb-last-updated { display: none !important; }

  /* Sticky top bar */
  .cb-topbar {
    height: 44px;
    padding: 0 12px;
    position: sticky;
    top: 0;
    z-index: 100;
  }
  .cb-logo-ver { display: none; }
  .cb-logo { padding-right: 12px; }
  .cb-logo-name { font-size: 12px; }

  /* Hide desktop tabs — replaced by bottom nav */
  .cb-tabs { display: none !important; }

  /* Export button smaller */
  #cb-btn-export { font-size: 10px; padding: 4px 8px; }
  #cb-btn-export svg { width: 10px; height: 10px; }

  /* ── Bottom navigation bar ── */
  .cb-mobile-nav {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 56px;
    background: var(--cb-surface);
    border-top: .5px solid var(--cb-border);
    z-index: 200;
    padding-bottom: env(safe-area-inset-bottom, 0px);
  }
  .cb-mobile-nav-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    cursor: pointer;
    color: var(--cb-faint);
    font-size: 9px;
    letter-spacing: .04em;
    text-transform: uppercase;
    position: relative;
    border: none;
    background: transparent;
    -webkit-tap-highlight-color: transparent;
    transition: color 0.15s;
  }
  .cb-mobile-nav-item.cb-active { color: var(--cb-gold); }
  .cb-mobile-nav-item svg { width: 22px; height: 22px; }
  .cb-mobile-nav-badge {
    position: absolute;
    top: 5px;
    right: calc(50% - 16px);
    background: var(--cb-warn);
    color: #1A1200;
    font-size: 8px;
    font-weight: 500;
    padding: 1px 4px;
    border-radius: 3px;
    font-family: var(--cb-mono);
    min-width: 14px;
    text-align: center;
    line-height: 1.4;
  }

  /* Reserve space for bottom nav */
  .cerberus { padding-bottom: 60px; }

  /* Views fill screen */
  .cb-view { padding: 10px 12px; }

  /* Stats — 2×2 */
  .cb-stats {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
    margin-bottom: 10px;
  }
  .cb-stat { padding: 9px 10px; }
  .cb-stat-value { font-size: 16px; }
  .cb-stat-label { font-size: 9px; }
  .cb-stat-sub   { font-size: 9px; }

  /* Toolbar — horizontal scroll */
  .cb-toolbar {
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 5px;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin-bottom: 8px;
  }
  .cb-toolbar::-webkit-scrollbar { display: none; }
  .cb-section-label { display: none; }
  .cb-search { width: 110px; }

  /* ── Portfolio table: hide non-essential columns ── */
  .cb-table-wrap { overflow-x: visible; }
  .cb-table { min-width: unset; width: 100%; }

  /* Keep: coin(1), price(2), P&L(4) — hide rest */
  .cb-table th:nth-child(3),
  .cb-table td:nth-child(3),
  .cb-table th:nth-child(5),
  .cb-table td:nth-child(5),
  .cb-table th:nth-child(6),
  .cb-table td:nth-child(6),
  .cb-table th:nth-child(7),
  .cb-table td:nth-child(7),
  .cb-table th:nth-child(8),
  .cb-table td:nth-child(8),
  .cb-table th:nth-child(9),
  .cb-table td:nth-child(9) { display: none !important; }

  /* Bigger tap targets */
  .cb-ri          { padding: 13px 10px; }
  .cb-coin-badge  { width: 32px; height: 32px; font-size: 10px; }
  .cb-coin-name   { font-size: 13px; }
  .cb-coin-exch   { font-size: 10px; }
  .cb-mono-cell   { font-size: 13px; padding: 13px 10px; }
  .cb-mono-cell .cb-sub { font-size: 10px; }

  /* Expand panel: single column */
  .cb-expand-grid { grid-template-columns: 1fr !important; }

  /* ── News: horizontal coin scroll ── */
  .cb-news-layout { grid-template-columns: 1fr; }
  .cb-news-sidebar { border-bottom: .5px solid var(--cb-border); }
  .cb-news-sidebar-header { padding: 8px 12px 4px; }
  #cb-news-coin-list {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 6px 8px;
    gap: 5px;
  }
  #cb-news-coin-list::-webkit-scrollbar { display: none; }
  .cb-news-coin {
    flex-shrink: 0;
    border: .5px solid var(--cb-border);
    border-radius: 4px;
    padding: 4px 10px;
    border-bottom: none; /* override desktop */
  }
  .cb-news-coin.cb-active {
    background: var(--cb-gold-bg);
    border-color: var(--cb-gold);
  }
  /* Bigger article tap targets, hide desc to reduce scroll */
  .cb-news-article { padding: 12px 14px; }
  .cb-news-title   { font-size: 13px; line-height: 1.4; }
  .cb-news-desc    { display: none; }

  /* Alerts: slightly more compact on mobile */
  .cb-alert-title { font-size: 12px; }
  .cb-alert-item  { padding: 10px 12px; }

  /* Reports: single column */
  .cb-reports-grid { grid-template-columns: 1fr; }

  /* Modals: slide up from bottom */
  .cb-modal-backdrop {
    align-items: flex-end;
    padding: 0;
  }
  .cb-modal {
    border-radius: var(--cb-radius-lg) var(--cb-radius-lg) 0 0;
    max-width: 100% !important;
    max-height: 88vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 20px 16px;
  }

  /* Feed manager stacked */
  #cb-feed-manager > div:nth-child(3) {
    grid-template-columns: 1fr 1fr !important;
  }
  #cb-feed-url { grid-column: span 2; }
}

/* Very small (iPhone SE) */
@media (max-width: 375px) {
  .cb-stat-value { font-size: 14px; }
  .cb-coin-name  { font-size: 12px; }
  .cb-mono-cell  { font-size: 12px; }
}
