/* HYPERION terminal — design system */
:root {
  --font-mono: 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --font-sans: 'Inter Tight', 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-display: 'Inter Tight', 'Inter', system-ui, sans-serif;

  /* Dark — terminal */
  --bg:        #07090b;
  --bg-elev:   #0c1014;
  --bg-card:   #0e1217;
  --bg-soft:   #131820;
  --bd:        #1c232c;
  --bd-strong: #2a323d;
  --fg:        #e7eef5;
  --fg-mid:    #7c8896;
  --fg-dim:    #4a5562;
  --accent:    #4cd9ff;   /* cyan */
  --accent-dim:#1f7a96;
  --green:     #6cf2a8;
  --green-dim: #2d8758;
  --amber:     #f6c95c;
  --red:       #ff5d6e;
  --violet:    #b794ff;
  --grid:      rgba(76, 217, 255, 0.04);
}
:root[data-theme="light"] {
  --bg:        #f6f5f0;
  --bg-elev:   #ffffff;
  --bg-card:   #ffffff;
  --bg-soft:   #efece4;
  --bd:        #d9d4c5;
  --bd-strong: #b9b3a1;
  --fg:        #1a1d1c;
  --fg-mid:    #6b7066;
  --fg-dim:    #99988b;
  --accent:    #0a84a8;
  --accent-dim:#7fc4d8;
  --green:     #1a7f4f;
  --green-dim: #4ba87b;
  --amber:     #b8851b;
  --red:       #c63548;
  --violet:    #6a3fb1;
  --grid:      rgba(10, 132, 168, 0.05);
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: 13px;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'ss01', 'cv11';
}

/* Density */
:root[data-density="compact"] { --pad: 12px; --row-h: 30px; --gap: 12px; --card-pad: 16px; }
:root[data-density="comfy"]   { --pad: 22px; --row-h: 44px; --gap: 24px; --card-pad: 28px; }
:root { --pad: 16px; --row-h: 36px; --gap: 18px; --card-pad: 22px; }

/* App shell — inside browser frame */
.app {
  width: 100%;
  min-height: 100%;
  background:
    linear-gradient(var(--grid) 1px, transparent 1px) 0 0 / 28px 28px,
    linear-gradient(90deg, var(--grid) 1px, transparent 1px) 0 0 / 28px 28px,
    var(--bg);
  font-family: var(--font-sans);
}
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 28px;
  padding: 14px 32px;
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--bd);
}
.brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-weight: 700; font-size: 13px;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.brand-mark {
  width: 22px; height: 22px;
  background: var(--accent);
  position: relative;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.brand-mark::after {
  content: ''; position: absolute; inset: 4px;
  background: var(--bg);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.brand-mark::before {
  content: ''; position: absolute; inset: 8px;
  background: var(--accent);
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
}
.brand-vsep { width: 1px; height: 18px; background: var(--bd-strong); margin: 0 4px; }
.brand-tag { font-family: var(--font-mono); color: var(--fg-mid); font-size: 11px; letter-spacing: 0.06em; }

.nav { display: flex; gap: 0; flex: 1; }
.nav-item {
  padding: 8px 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-mid);
  background: transparent; border: 0;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -15px;
  position: relative;
}
.nav-item:hover { color: var(--fg); }
.nav-item.on {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.nav-item.on::before {
  content: ''; position: absolute; left: 6px; top: 10px;
  width: 4px; height: 4px; background: var(--accent);
  border-radius: 999px;
  box-shadow: 0 0 8px var(--accent);
}
.nav-item.on { padding-left: 18px; }

.tb-status {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 11px; color: var(--fg-mid);
  letter-spacing: 0.04em;
}
.tb-status .live-dot { width: 6px; height: 6px; }

.btn {
  appearance: none; border: 1px solid var(--bd-strong);
  background: var(--bg-elev); color: var(--fg);
  padding: 8px 14px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; cursor: pointer;
  transition: all 0.15s;
}
.btn:hover { border-color: var(--accent); color: var(--accent); }
.btn-primary {
  background: var(--accent); color: var(--bg);
  border-color: var(--accent);
  font-weight: 700;
}
.btn-primary:hover { background: var(--fg); border-color: var(--fg); color: var(--bg); }
.btn-wide { width: 100%; padding: 12px; margin-top: 10px; }

/* Live blinking dot */
.live-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 999px;
  animation: livePulse 1.4s ease-in-out infinite;
  vertical-align: middle;
}
@keyframes livePulse { 0%,100% { opacity: 1; } 50% { opacity: 0.3; } }

/* Section header */
.section-hd {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 0 0 16px;
  border-bottom: 1px solid var(--bd);
  margin-bottom: 16px;
  gap: 16px;
}
.section-hd h2 {
  margin: 4px 0 0;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.kicker {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-mid);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.section-hd-right { display: flex; align-items: center; gap: 8px; }
.section-hd-link {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.section-hd-link:hover { color: var(--fg); }

/* Hero */
.hero { padding: 60px 32px 40px; max-width: 1200px; }
.hero-sub-screen { padding: 48px 32px 24px; }
.hero-compact { padding: 28px 32px 20px; max-width: 1400px; }
.hero-h1-sm { font-size: 38px !important; margin: 8px 0 0 !important; }

.hero-context {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 48px;
  align-items: center;
  padding: 48px 0 8px;
  margin-top: 24px;
  border-top: 1px solid var(--bd);
}
.hero-context-text p {
  margin: 12px 0 0;
  font-size: 17px;
  line-height: 1.5;
  color: var(--fg);
  text-wrap: pretty;
  font-family: var(--font-display);
  letter-spacing: -0.005em;
}
.hero-context .hero-stats {
  margin-top: 0;
  border-top: 0;
  border-bottom: 0;
}
@media (max-width: 1100px) {
  .hero-context { grid-template-columns: 1fr; gap: 24px; }
}
.hero-h1 {
  margin: 14px 0 18px;
  font-family: var(--font-display);
  font-size: 64px;
  line-height: 1;
  letter-spacing: -0.035em;
  font-weight: 600;
  text-wrap: balance;
}
.hero-sub {
  max-width: 640px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--fg-mid);
  text-wrap: pretty;
}

/* Hero stats */
.hero-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 36px;
  border-top: 1px solid var(--bd);
  border-bottom: 1px solid var(--bd);
}
.stat {
  padding: 18px 22px 18px 0;
  border-right: 1px solid var(--bd);
}
.stat:last-child { border-right: 0; }
.stat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--fg-mid);
  text-transform: uppercase;
}
.stat-value {
  margin-top: 6px;
  font-family: var(--font-display);
  font-size: 32px;
  letter-spacing: -0.02em;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.stat-sub {
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
}

/* Cards & screen */
.screen {
  padding: 0 32px 60px;
  max-width: 1400px;
  margin: 0 auto;
}
.card {
  background: var(--bg-card);
  border: 1px solid var(--bd);
  padding: var(--card-pad);
}

/* Ticker strip */
.ticker {
  display: flex; align-items: center;
  background: var(--bg-elev);
  border-bottom: 1px solid var(--bd);
  font-family: var(--font-mono);
  font-size: 12px;
  height: 36px;
  overflow: hidden;
  position: sticky; top: 51px; z-index: 40;
}
.ticker-label {
  flex-shrink: 0;
  padding: 0 14px;
  color: var(--green);
  letter-spacing: 0.14em;
  font-weight: 700;
  border-right: 1px solid var(--bd);
  height: 100%;
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-soft);
}
.ticker-track { flex: 1; overflow: hidden; height: 100%; position: relative; }
.ticker-inner {
  display: inline-flex; gap: 0;
  white-space: nowrap;
  animation: tickerScroll 60s linear infinite;
  height: 100%; align-items: center;
}
@keyframes tickerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.ticker-item {
  display: inline-flex; gap: 8px; align-items: center;
  padding: 0 16px;
}
.ticker-item strong { font-variant-numeric: tabular-nums; }

/* Timeline grid */
.grid-tl {
  display: grid; grid-template-columns: 1fr 360px;
  gap: var(--gap);
  margin-top: 24px;
}
.card-tl { padding: 0; }
.card-tl > .section-hd { padding: var(--card-pad); margin-bottom: 0; }
.card-side { padding: var(--card-pad); }

.tl-head, .tl-row {
  display: grid;
  grid-template-columns: 80px 110px 110px 120px 130px 1fr 110px 130px;
  gap: 12px;
  align-items: center;
  padding: 0 var(--card-pad);
  font-family: var(--font-mono);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  height: var(--row-h);
  border-bottom: 1px solid var(--bd);
}
.tl-head {
  font-size: 10px; color: var(--fg-mid);
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--bg-soft);
  border-top: 1px solid var(--bd);
}
.tl-body { max-height: 1100px; overflow-y: auto; }
.tl-time { color: var(--fg-mid); }
.tl-ev { display: flex; gap: 6px; align-items: center; }
.tl-asset { display: flex; gap: 8px; align-items: center; }
.tl-amount { font-weight: 600; }
.tl-tx .link { color: var(--accent); cursor: pointer; }
.tl-row:hover { background: var(--bg-soft); }
.tl-new { animation: rowIn 0.7s ease-out; }
@keyframes rowIn {
  from { background: color-mix(in oklab, var(--accent) 18%, var(--bg-card)); transform: translateX(-2px); }
  to { background: var(--bg-card); }
}

.filter-row { display: flex; gap: 4px; flex-wrap: wrap; }
.chip {
  appearance: none; border: 1px solid var(--bd);
  background: transparent;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; padding: 5px 9px;
  color: var(--fg-mid); cursor: pointer;
}
.chip:hover { color: var(--fg); border-color: var(--bd-strong); }
.chip.chip-on { color: var(--accent); border-color: var(--accent); background: color-mix(in oklab, var(--accent) 8%, transparent); }

/* Side card content */
.signals-mini { display: flex; flex-direction: column; gap: 1px; background: var(--bd); }
.signal-mini {
  padding: 12px;
  background: var(--bg-card);
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: 'hd hd' 'lab lab' 'stat val';
  gap: 4px;
}
.signal-mini-hd { grid-area: hd; display: flex; justify-content: space-between; }
.signal-mini-label { grid-area: lab; font-size: 13px; font-weight: 500; }
.signal-mini-stat { grid-area: stat; font-family: var(--font-mono); font-size: 11px; color: var(--fg-mid); }
.signal-mini-val { grid-area: val; font-family: var(--font-mono); font-weight: 700; font-size: 13px; }

.sev {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.1em; padding: 2px 5px;
  border: 1px solid currentColor;
}
.sev-high { color: var(--red); }
.sev-mid  { color: var(--amber); }
.sev-low  { color: var(--accent); }
.signal-window { font-family: var(--font-mono); font-size: 10px; color: var(--fg-mid); }

/* Mini bars */
.minibars-row {
  display: grid; grid-template-columns: 60px 1fr 70px;
  gap: 10px; align-items: center;
  padding: 5px 0;
  font-family: var(--font-mono); font-size: 12px;
}
.minibars-asset { font-weight: 600; }
.minibars-bar {
  height: 8px; background: var(--bg-soft);
  position: relative; display: block;
}
.minibars-bar > span {
  position: absolute; left: 0; top: 0; height: 100%;
  background: linear-gradient(90deg, var(--accent), color-mix(in oklab, var(--accent) 40%, transparent));
}
.minibars-val { text-align: right; font-variant-numeric: tabular-nums; color: var(--fg-mid); }

/* Markets */
.markets-tabs {
  display: flex; gap: 0; margin: 24px 0 16px;
  border-bottom: 1px solid var(--bd);
}
.mk-tab {
  appearance: none; background: transparent; border: 0;
  padding: 12px 20px;
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.1em; color: var(--fg-mid);
  cursor: pointer; border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  display: flex; gap: 8px; align-items: center;
}
.mk-tab:hover { color: var(--fg); }
.mk-tab.on { color: var(--accent); border-bottom-color: var(--accent); }
.mk-tab .count {
  font-size: 10px; color: var(--fg-mid);
  background: var(--bg-soft); padding: 2px 6px;
}

.market-filter {
  display: flex; gap: 10px; align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--bd);
  margin-bottom: 4px;
}
.search {
  display: flex; align-items: center; gap: 8px;
  border: 1px solid var(--bd);
  padding: 0 10px; height: 34px;
  background: var(--bg-elev);
  flex: 1; max-width: 320px;
}
.search input {
  border: 0; outline: 0; background: transparent;
  color: var(--fg); font-family: var(--font-mono); font-size: 12px;
  flex: 1;
}
.select {
  appearance: none;
  border: 1px solid var(--bd);
  background: var(--bg-elev);
  color: var(--fg);
  padding: 0 28px 0 10px;
  height: 34px;
  font-family: var(--font-mono); font-size: 12px;
  cursor: pointer;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%237c8896' d='M0 0h10L5 6z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
}
.select.wide { width: 100%; }
.result-count { font-family: var(--font-mono); font-size: 11px; color: var(--fg-mid); }

.mk-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-mono); font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.mk-table th, .mk-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--bd);
  text-align: left;
}
.mk-table th {
  font-size: 10px; font-weight: 500;
  color: var(--fg-mid); letter-spacing: 0.1em;
  text-transform: uppercase;
}
.mk-table th.sortable { cursor: pointer; user-select: none; }
.mk-table th.sortable:hover { color: var(--fg); }
.mk-table td.num { text-align: right; }
.mk-table th:nth-child(2), .mk-table th:nth-child(3),
.mk-table th:nth-child(4), .mk-table th:nth-child(5),
.mk-table th:nth-child(6) { text-align: right; }
.mk-table tbody tr:hover { background: var(--bg-soft); }
.pair { display: flex; gap: 8px; align-items: center; }
.pair > span:nth-child(2) { margin-left: -8px; }
.row-btn {
  appearance: none; background: transparent;
  border: 1px solid var(--bd-strong);
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.1em; padding: 5px 9px;
  color: var(--fg); cursor: pointer;
}
.row-btn:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }

/* Signals page */
.sig-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: var(--bd); border: 1px solid var(--bd);
  margin-top: 8px;
}
.sig-grid--3 { grid-template-columns: repeat(3, 1fr); }
.sig-card { padding: 18px; background: var(--bg-card); display: flex; flex-direction: column; gap: 8px; }

/* Protocol-state signal table cards. Each card replaces what would
   otherwise be a single-value sig-card — these signals fire on N pools
   at once, so a table is the right primitive. Reuses .mk-table styling
   but resets the default per-column right-alignment (mk-table assumes
   the 2nd-onward columns are numeric; state tables mix text + numbers
   per column so we set alignment inline at the cell level). */
.sig-table-card .section-hd { margin-bottom: 8px; }
.sig-table-card .section-hd h2 { font-size: 18px; }
.state-table { table-layout: auto; }
.state-table th:nth-child(n) { text-align: left; }
.state-table tbody tr:hover { background: var(--bg-soft); }
.state-table-wrap { overflow-x: auto; }

.state-count {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid var(--bd);
  color: var(--fg-mid);
  white-space: nowrap;
}
.state-count--hot {
  color: var(--accent);
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 10%, transparent);
}
.state-empty {
  text-align: center !important;
  color: var(--fg-dim);
  padding: 22px 12px !important;
  font-style: normal;
}
.sev-bg-high { background: linear-gradient(180deg, color-mix(in oklab, var(--red) 6%, var(--bg-card)), var(--bg-card)); }
.sev-bg-mid  { background: linear-gradient(180deg, color-mix(in oklab, var(--amber) 5%, var(--bg-card)), var(--bg-card)); }
.sev-bg-low  { background: var(--bg-card); }
.sig-hd { display: flex; justify-content: space-between; }
.sig-code { font-family: var(--font-mono); color: var(--fg-mid); font-size: 11px; letter-spacing: 0.04em; }
.sig-label { font-size: 14px; font-weight: 500; line-height: 1.3; }
.sig-divider { height: 1px; background: var(--bd); }
.sig-foot { display: flex; justify-content: space-between; align-items: flex-end; }
.sig-stat { font-family: var(--font-mono); font-size: 11px; color: var(--fg); margin-top: 4px; }
.sig-val { font-family: var(--font-display); font-size: 24px; font-weight: 600; font-variant-numeric: tabular-nums; }

.sub-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap); margin-top: 8px; }
.sub-grid--2 { grid-template-columns: repeat(2, 1fr); }
.sub-card { border: 1px solid var(--bd); padding: 22px; display: flex; flex-direction: column; }
.sub-card h3 { margin: 14px 0 6px; font-size: 18px; font-weight: 600; letter-spacing: -0.01em; }
.sub-card p { margin: 0 0 16px; color: var(--fg-mid); font-size: 13px; line-height: 1.5; flex: 1; }
/* Primary variant — highlighted call-to-action (Custom subscriptions) */
.sub-card--primary {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 4%, var(--bg-card));
}
.sub-card--primary .sub-icon { background: var(--accent); }
.sub-icon {
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-weight: 700;
  background: var(--accent); color: var(--bg);
  font-size: 12px;
}

/* Agent screen */
.agent-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--gap); margin-top: 8px; }
.terminal {
  background: #06080a;
  border: 1px solid var(--bd);
  padding: 0;
  overflow: hidden;
}
.terminal-hd {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 14px;
  background: #0a0e12;
  border-bottom: 1px solid var(--bd);
}
.t-dot { width: 11px; height: 11px; border-radius: 999px; }
.t-r { background: #ff5f57; } .t-y { background: #febc2e; } .t-g { background: #28c840; }
.terminal-title { color: #6b7280; font-family: var(--font-mono); font-size: 11px; margin-left: 10px; }
.terminal-body {
  padding: 18px;
  font-family: var(--font-mono); font-size: 12.5px;
  line-height: 1.6; color: #cfdbe5;
}
.t-prompt { color: var(--accent); margin-right: 6px; }
.t-str { color: var(--green); }
.t-ok { color: var(--green); }
.t-dim { color: #6b7989; }
.t-cursor { display: inline-block; color: var(--accent); animation: blink 1s steps(2) infinite; }
@keyframes blink { 50% { opacity: 0; } }

.tools-list { display: flex; flex-direction: column; gap: 0; }
.tool-row {
  padding: 10px 0;
  border-bottom: 1px solid var(--bd);
  display: flex; gap: 12px; align-items: baseline;
}
.tool-row:last-child { border-bottom: 0; }
.tool-name {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--accent); padding: 2px 6px;
  background: color-mix(in oklab, var(--accent) 10%, transparent);
  flex-shrink: 0;
}
.tool-desc { color: var(--fg-mid); font-size: 12px; }

.erc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
.erc-card { border: 1px solid var(--bd); padding: 22px; }
.erc-id {
  font-family: var(--font-display); font-size: 56px;
  letter-spacing: -0.04em; font-weight: 600;
  color: var(--accent);
  margin: 6px 0;
}
.erc-meta { color: var(--fg-mid); font-family: var(--font-mono); font-size: 11px; margin-bottom: 18px; }
.erc-row {
  display: flex; justify-content: space-between;
  padding: 10px 0; border-bottom: 1px solid var(--bd);
  font-family: var(--font-mono); font-size: 12px;
}
.erc-row:last-child { border-bottom: 0; }
.erc-row code { color: var(--fg); }
.erc-row span:first-child { color: var(--fg-mid); }
.erc-stack { margin: 6px 0 16px; }
.erc-stack .erc-row b { font-family: var(--font-mono); }
.erc-active { color: var(--accent); }
.erc-active b { color: var(--accent); }
.erc-blurb { color: var(--fg-mid); font-size: 13px; line-height: 1.55; margin: 0; }
.link { color: var(--accent); cursor: pointer; }

/* Calculator */
.calc-grid {
  display: grid; grid-template-columns: 380px 1fr;
  gap: var(--gap);
  margin-top: 8px;
}
.calc-field { margin: 14px 0; }
.calc-field label {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 11px;
  color: var(--fg-mid); letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.num-aside { color: var(--fg); font-weight: 600; text-transform: none; letter-spacing: 0; }

.slider {
  appearance: none; -webkit-appearance: none;
  width: 100%; height: 4px;
  background: var(--bd); outline: none;
}
.slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 14px; height: 14px;
  background: var(--accent);
  border: 0; cursor: pointer;
  box-shadow: 0 0 8px var(--accent);
}
.slider::-moz-range-thumb {
  width: 14px; height: 14px; border-radius: 0;
  background: var(--accent); border: 0;
  box-shadow: 0 0 8px var(--accent);
}

.calc-rates {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 12px; margin: 16px 0 8px;
  border-top: 1px solid var(--bd);
  border-bottom: 1px solid var(--bd);
  padding: 14px 0;
}
.num-big { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.num-xl { font-family: var(--font-display); font-size: 38px; font-weight: 600; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }

.calc-summary {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--bd);
  border-bottom: 1px solid var(--bd);
  margin-bottom: 16px;
}
.calc-stat { padding: 18px 22px 18px 0; border-right: 1px solid var(--bd); }
.calc-stat:last-child { border-right: 0; }

.calc-warn {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--amber); margin: 12px 0 0;
}

.calc-table th, .calc-table td { padding: 8px 10px; }

/* Footer */
.footer {
  padding: 40px 32px 24px;
  border-top: 1px solid var(--bd);
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 32px;
  font-size: 12px;
  color: var(--fg-mid);
}
.footer h4 {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  margin: 0 0 12px; color: var(--fg);
}
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.footer a { color: var(--fg-mid); text-decoration: none; }
.footer a:hover { color: var(--accent); }

@media (max-width: 1100px) {
  .grid-tl { grid-template-columns: 1fr; }
  .agent-grid { grid-template-columns: 1fr; }
  .erc-grid { grid-template-columns: 1fr; }
  .sig-grid { grid-template-columns: repeat(2, 1fr); }
  .sub-grid { grid-template-columns: 1fr; }
  .calc-grid { grid-template-columns: 1fr; }
  .hero-h1 { font-size: 44px; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
}

/* Mobile (≤ 760px) — terminal layout collapses to single column.
   Source: designer handoff. Adapted for .site-footer__grid (we ship
   the legacy site-footer markup, not the design's bare .footer) and
   tightened paddings + section-hd stacking after on-device review. */
@media (max-width: 760px) {
  /* Density: tighten card/row paddings so feed cards aren't drowning in margin */
  :root { --pad: 12px; --card-pad: 14px; --gap: 14px; }

  /* Topbar wraps; nav drops to its own row with horizontal scroll.
     Hide the "DEFI LENDING TERMINAL" tag + separator — they eat space
     without adding info on a 360px viewport. */
  .topbar { flex-wrap: wrap; gap: 10px 14px; padding: 10px 14px; }
  .brand-tag, .brand-vsep { display: none; }
  .nav    { order: 3; flex-basis: 100%; overflow-x: auto;
            border-top: 1px solid var(--bd); padding-top: 6px; }

  /* Hero shrinks (font + padding) */
  .hero       { padding: 24px 16px 16px; }
  .hero-h1    { font-size: 32px !important; margin: 8px 0 12px; }
  .hero-h1-sm { font-size: 26px !important; }

  /* Screen + main gutters — drop the 24+32px desktop gutters; the card's
     own padding gives enough breathing room. */
  .container { padding: 0 8px; margin-top: 0; }
  .screen { padding: 0 0 32px; }

  /* Every grid → single column */
  .grid-tl, .agent-grid, .erc-grid,
  .sub-grid, .calc-grid, .sig-grid { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: 1fr 1fr; }

  /* Section header inside cards — stack title + right slot vertically.
     The horizontal flex layout was making the title compete with the
     filter chips for width, wrapping the title to 3-4 lines. */
  .section-hd { flex-direction: column; align-items: stretch; gap: 10px; padding: 0 0 12px; margin-bottom: 12px; }
  .section-hd-right { align-items: flex-start; flex-wrap: wrap; }
  .card-tl > .section-hd { padding: 12px 14px; }

  /* Live event feed → card-style rows (no header).
     Reduced row padding to match the tighter card padding above. */
  .tl-head { display: none; }
  .tl-row {
    display: grid;
    grid-template-columns: auto 1fr auto;
    grid-template-areas: "ev asset amount" "time proto chain" "addr addr tx";
    gap: 4px 10px; height: auto; padding: 10px 14px;
  }
  .tl-ev    { grid-area: ev; }
  .tl-asset { grid-area: asset; }
  .tl-amount{ grid-area: amount; text-align: right; }
  .tl-time  { grid-area: time; }
  .tl-proto { grid-area: proto; }
  .tl-chain { grid-area: chain; text-align: right; }
  .tl-addr  { grid-area: addr; }
  .tl-tx    { grid-area: tx; text-align: right; }

  /* Wide tables (Markets / Calculator rounds) → horizontal scroll */
  .mk-table, .calc-table {
    display: block; overflow-x: auto; white-space: nowrap;
  }

  /* Footer → single column */
  .site-footer__grid { grid-template-columns: 1fr; }
}
