/* ═══════════════════════════════════════════════════════════════
   FRETSCOUT — verbatim GTAI design language
   DM Mono everywhere · Syne only for the wordmark · Dark-first
   Zero blobs · Zero gradients · Zero glow effects
═══════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ─── GTAI Tokens — exact from index.html ──────────────────── */
:root {
  --sf:   'Syne', sans-serif;
  --mono: 'DM Mono', monospace;

  --spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease:   cubic-bezier(0.4, 0, 0.2, 1);

  --bg:          #1a1a1a;
  --text:        #d9d5cc;
  --text-muted:  #7e7e7e;
  --text-faint:  #4e4e4e;
  --border-hard: #2c2c2c;
  --panel:       #202020;
  --accent:      #d9d5cc;    /* GTAI accent = warm off-white, not a color */
  --accent-on:   #1a1a1a;
  --hover:       #272727;
  --pill-border: #383838;

  --s0: #1a1a1a;
  --s1: #222222;
  --s2: #2a2a2a;
  --s3: #333333;

  --b:   rgba(217,213,204,0.08);
  --bhi: rgba(217,213,204,0.16);
  --blo: rgba(217,213,204,0.04);

  --green:      #30d158;
  --green-dim:  rgba(48,209,88,0.09);
  --orange:     #ff9500;
  --orange-dim: rgba(255,149,0,0.09);
  --red:        #ff453a;
  --red-dim:    rgba(255,69,58,0.09);

  --r-xl: 20px;
  --r-lg: 14px;
  --r-md: 10px;
  --r-sm: 6px;
  --r-xs: 4px;

  /* Aliases app.js may reference */
  --radius-xs: var(--r-xs);
  --radius-sm: var(--r-sm);
  --radius-md: var(--r-md);
  --radius-lg: var(--r-lg);
  --radius-xl: var(--r-xl);
  --primary:      var(--green);
  --primary-light: #57e07a;
  --border-color: var(--border-hard);
  --border-hi:    var(--bhi);
  --border:       var(--b);
  --surface-0: var(--s0);
  --surface-1: var(--s1);
  --surface-2: var(--s2);
  --surface-3: var(--s3);
  --text-primary:   var(--text);
  --text-secondary: var(--text-muted);
  --text-tertiary:  var(--text-faint);
  --transition: 150ms var(--ease);
  --transition-slow: 300ms var(--ease);
}

/* ─── Light Mode ─────────────────────────────────────────────── */
body.light-mode {
  --bg:          #f4f3f0;
  --text:        #1a1a1a;
  --text-muted:  #5a5a5a;
  --text-faint:  #9c9c9c;
  --border-hard: #e0deda;
  --panel:       #ffffff;
  --accent:      #1a1a1a;
  --accent-on:   #ffffff;
  --hover:       #ebebea;
  --pill-border: #d4d3d0;

  --s0: #ffffff;
  --s1: #f8f7f5;
  --s2: #f0efec;
  --s3: #e4e3e0;

  --b:   rgba(0,0,0,0.07);
  --bhi: rgba(0,0,0,0.13);
  --blo: rgba(0,0,0,0.04);
}

/* ─── Base ───────────────────────────────────────────────────── */
html { -webkit-font-smoothing: antialiased; }

body {
  font-family: var(--mono);
  font-size: 13px;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
}

/* Noise — GTAI .app-wrap::before */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: 0.025;
  pointer-events: none;
  z-index: 0;
}

/* ─── Keyframes ──────────────────────────────────────────────── */
@keyframes fadeIn  { from { opacity:0 } to { opacity:1 } }
@keyframes slideUp { from { opacity:0; transform:translateY(10px) } to { opacity:1; transform:none } }
@keyframes slideIn { from { opacity:0; transform:translateX(-10px) } to { opacity:1; transform:none } }
@keyframes dropIn  { from { opacity:0; transform:translateY(-4px) scale(0.98) } to { opacity:1; transform:none } }
@keyframes spin    { to { transform:rotate(360deg) } }
@keyframes pulse   { 0%,100%{opacity:.25} 50%{opacity:.55} }
@keyframes rec-pulse {
  0%, 100% {
    opacity: 1;
    box-shadow: 0 0 0 0 rgba(255,59,48,0.55), 0 0 7px rgba(255,59,48,0.45);
  }
  45% {
    opacity: 0.18;
    box-shadow: 0 0 0 6px rgba(255,59,48,0), 0 0 2px rgba(255,59,48,0.1);
  }
}

/* Motto transitions — each pair is intentionally distinct */
@keyframes motto-fade-in      { from{opacity:0}                                     to{opacity:1} }
@keyframes motto-fade-out     { from{opacity:1}                                     to{opacity:0} }

@keyframes motto-slide-up-in  { from{opacity:0;transform:translateY(20px)}          to{opacity:1;transform:none} }
@keyframes motto-slide-up-out { from{opacity:1;transform:none}                      to{opacity:0;transform:translateY(-20px)} }

@keyframes motto-scale-in     { from{opacity:0;transform:scale(0.86)}               to{opacity:1;transform:scale(1)} }
@keyframes motto-scale-out    { from{opacity:1;transform:scale(1)}                  to{opacity:0;transform:scale(1.12)} }

@keyframes motto-blur-in      { from{opacity:0;filter:blur(16px)}                   to{opacity:1;filter:blur(0)} }
@keyframes motto-blur-out     { from{opacity:1;filter:blur(0)}                      to{opacity:0;filter:blur(16px)} }

@keyframes motto-wipe-in      { from{clip-path:inset(0 100% 0 0);opacity:1}         to{clip-path:inset(0 0% 0 0);opacity:1} }
@keyframes motto-wipe-out     { from{clip-path:inset(0 0% 0 0);opacity:1}           to{clip-path:inset(0 0% 0 100%);opacity:1} }

/* ─── Utilities ──────────────────────────────────────────────── */
.hidden { display: none !important; }

.spinner {
  width:11px; height:11px;
  border:1.5px solid var(--bhi);
  border-top-color: var(--green);
  border-radius:50%;
  animation: spin .75s linear infinite;
  flex-shrink:0;
}

/* ═══════════════════════════════════════════════════════════════
   NAV — exact GTAI nav from index.html
═══════════════════════════════════════════════════════════════ */
.nav {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 56px;
  height: 64px;
  border-bottom: 1px solid var(--border-hard);
  background: var(--bg);
  position: relative;
  z-index: 100;
  flex-shrink: 0;
}

.nav--results {
  position: sticky;
  top: 0;
  background: rgba(26,26,26,0.92);
  backdrop-filter: blur(15px) saturate(180%);
  -webkit-backdrop-filter: blur(15px) saturate(180%);
  border-bottom: 1px solid var(--b);
}

body.light-mode .nav--results {
  background: rgba(244,243,240,0.94);
}

/* GTAI logo — Syne 700, exact same spec */
.logo {
  font-family: var(--sf);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--text);
  text-decoration: none;
  transition: opacity .2s, letter-spacing .25s;
  padding-right: 2px;
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: default;
}

.logo--btn {
  cursor: pointer;
}
.logo--btn:hover {
  opacity: 0.6;
  letter-spacing: 0.28em;
}

/* Center tags — GTAI .nav-links style */
.nav-center {
  display: flex;
  align-items: center;
  gap: 10px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

.nav-tag {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .05em;
  color: var(--text-faint);
}

.nav-dot {
  width: 2px;
  height: 2px;
  border-radius: 50%;
  background: var(--text-faint);
}

/* Right side icon button */
.nav-icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  background: transparent;
  border: 1px solid var(--border-hard);
  color: var(--text-muted);
  cursor: pointer;
  transition: all .15s var(--ease);
  flex-shrink: 0;
  margin-left: auto;
}

.nav-icon-btn:hover {
  background: var(--hover);
  color: var(--text);
  border-color: var(--bhi);
}

.nav-icon-btn--label {
  width: auto;
  padding: 0 10px;
  gap: 5px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
}

/* Results nav — inline search */
.nav-search-wrap {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 5px 9px;
  background: var(--s2);
  border: 1px solid var(--b);
  flex: 1;
  max-width: 340px;
  transition: border-color .15s;
}

.nav-search-wrap:focus-within {
  border-color: rgba(48,209,88,0.35);
}

.nav-search-wrap > svg { color: var(--text-faint); flex-shrink:0; }

.nav-search-input {
  flex: 1;
  border: none;
  background: transparent;
  color: var(--text);
  font-family: var(--mono);
  font-size: 12px;
  outline: none;
}

.nav-search-input::placeholder { color: var(--text-faint); }

.nav-search-go {
  padding: 3px 8px;
  background: var(--s3);
  border: 1px solid var(--b);
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: background .12s, color .12s;
}

.nav-search-go:hover { background: var(--green); color: #1a1a1a; border-color: transparent; }

/* ═══════════════════════════════════════════════════════════════
   LANDING STAGE — the hero equivalent but without hero decorations
═══════════════════════════════════════════════════════════════ */
#heroSection {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.stage {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 56px 24px 80px;
  position: relative;
  overflow: hidden;
}

/* GTAI grid — verbatim */
.stage-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(217,213,204,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217,213,204,0.03) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

body.light-mode .stage-grid {
  background-image:
    linear-gradient(rgba(0,0,0,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,0.03) 1px, transparent 1px);
}

.stage-inner {
  position: relative;
  z-index: 10;
  width: 100%;
  max-width: 540px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  animation: slideUp .28s var(--ease);
}

/* Eyebrow — mono caps, faint dots */
.eyebrow {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.eyebrow-dot {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--text-faint);
  flex-shrink: 0;
}

/* REC indicator — first dot only */
.eyebrow .eyebrow-dot:first-child {
  width: 7px; height: 7px;
  background: #ff3b30;
  animation: rec-pulse 1.6s ease-in-out infinite;
}

/* Motto span must be block so clip-path and transforms work across line breaks */
#mottoDisplay { display: block; }

/* Headline — Syne, tight */
.headline {
  font-family: var(--sf);
  font-size: clamp(28px, 5vw, 44px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -.04em;
  color: var(--text);
  /* Always reserve exactly 2 lines so motto swaps never shift the layout */
  min-height: calc(2.1 * clamp(28px, 5vw, 44px));
  min-height: 2lh; /* modern browsers: exact 2 × line-height, overrides above */
}

/* ─── Search ─────────────────────────────────────────────────── */
.search-wrap {
  position: relative;
}

.search-field {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 0 5px 0 13px;
  background: var(--s2);
  border: 1px solid var(--bhi);
  transition: border-color .15s, box-shadow .15s;
  box-shadow: 0 2px 12px rgba(0,0,0,0.28);
}

.search-field:focus-within {
  border-color: rgba(48,209,88,0.40);
  box-shadow: 0 0 0 3px rgba(48,209,88,0.07), 0 2px 12px rgba(0,0,0,0.3);
}

.search-ico { color: var(--text-faint); flex-shrink:0; }

.search-input {
  flex: 1;
  border: none;
  background: transparent;
  color: var(--text);
  font-family: var(--mono);
  font-size: 13px;
  outline: none;
  padding: 13px 0;
}

.search-input::placeholder { color: var(--text-faint); }

/* CTA button — uses --accent which in dark = off-white, in light = black */
.search-go {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--accent);
  color: var(--accent-on);
  border: none;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: opacity .15s;
  white-space: nowrap;
  flex-shrink: 0;
  margin: 5px 0;
}

.search-go:hover { opacity: .75; }
.search-go:active { opacity: .6; }

/* History dropdown */
.search-history {
  position: absolute;
  top: calc(100% + 5px);
  left: 0; right: 0;
  background: var(--s0);
  border: 1px solid var(--bhi);
  z-index: 100;
  animation: dropIn .18s var(--spring);
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6);
}

.history-head {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 11px;
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--text-faint);
  border-bottom: 1px solid var(--b);
}

.history-list { max-height: 220px; overflow-y: auto; }

.history-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 11px;
  color: var(--text);
  cursor: pointer;
  border-bottom: 1px solid var(--blo);
  transition: background .1s;
  font-size: 12px;
  font-family: var(--mono);
}

.history-item:hover { background: var(--hover); }
.history-item-icon { width: 11px; height: 11px; color: var(--text-faint); flex-shrink: 0; }
.history-item-text { flex: 1; }

/* ─── Pills ──────────────────────────────────────────────────── */
.pills {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}

.pills-label {
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .14em;
  color: var(--text-faint);
  flex-shrink: 0;
}

/* GTAI .nav-cta / .cpill style — no radius in GTAI, just border */
.pill {
  padding: 5px 11px;
  background: transparent;
  border: 1px solid var(--pill-border);
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
  transition: color .15s, border-color .15s;
  letter-spacing: .01em;
}

.pill:hover {
  color: var(--text);
  border-color: var(--text-muted);
}

/* ═══════════════════════════════════════════════════════════════
   RESULTS PAGE
═══════════════════════════════════════════════════════════════ */
#resultsSection { animation: fadeIn .18s var(--ease); }

/* ─── Layout ─────────────────────────────────────────────────── */
.layout {
  display: grid;
  grid-template-columns: 244px 1fr;
  gap: 16px;
  max-width: 1360px;
  margin: 0 auto;
  padding: 16px;
}

/* ─── Sidebar ────────────────────────────────────────────────── */
.sidebar {
  position: sticky;
  top: 64px;
  height: fit-content;
  max-height: calc(100vh - 80px);
  overflow-y: auto;
  background: var(--s1);
  border: 1px solid var(--bhi);
  padding: 14px;
  animation: slideIn .24s var(--ease);
  scrollbar-width: thin;
  scrollbar-color: var(--s3) transparent;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.sidebar-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 11px;
  border-bottom: 1px solid var(--b);
  margin-bottom: 12px;
}

.section-label {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-faint);
}

.section-label-row {
  display: flex;
  align-items: center;
  gap: 6px;
  position: relative;
}

.hint-wrap {
  display: flex;
  align-items: center;
}

.hint-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  background: transparent;
  border: 1px solid var(--text-faint);
  color: var(--text-faint);
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  border-radius: 50%;
  cursor: pointer;
  transition: border-color .15s, color .15s;
  padding: 0;
  line-height: 1;
}

.hint-btn:hover,
.hint-btn.open {
  border-color: var(--text-muted);
  color: var(--text-muted);
}

.hint-bubble {
  display: none;
  position: absolute;
  bottom: calc(100% + 5px);
  top: auto;
  left: 0;
  right: 0;
  width: auto;
  background: var(--s0);
  border: 1px solid var(--bhi);
  padding: 9px 10px;
  font-family: var(--mono);
  font-size: 10px;
  line-height: 1.55;
  color: var(--text-muted);
  z-index: 200;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
  animation: dropIn .15s var(--spring);
}

.hint-bubble.open { display: block; }

.hint-bubble strong {
  color: var(--text);
  font-weight: 500;
}

.text-btn {
  background: none;
  border: none;
  color: var(--text-faint);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color .12s;
  padding: 0;
}

.text-btn:hover { color: var(--green); }

/* Filter blocks */
.filter-block {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 12px 0;
  border-bottom: 1px solid var(--blo);
}

.filter-block:last-child { border-bottom: none; padding-bottom: 0; }

.filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  cursor: pointer;
  transition: background .12s;
}

.filter-row:hover { background: var(--hover); }

.filter-row input {
  width: 13px; height: 13px;
  accent-color: var(--green);
  cursor: pointer;
  flex-shrink: 0;
}

.filter-row span {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-muted);
  transition: color .12s;
}

.filter-row:has(input:checked) span { color: var(--text); }

/* Histogram view toggle */
.toggle-row {
  display: flex;
  gap: 1px;
  padding: 2px;
  background: var(--s2);
  border: 1px solid var(--b);
  width: fit-content;
}

.toggle-btn {
  appearance: none;
  border: none;
  background: transparent;
  color: var(--text-faint);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .04em;
  padding: 3px 8px;
  cursor: pointer;
  transition: background .12s, color .12s;
}

.toggle-btn:hover { color: var(--text-muted); }
.toggle-btn.active { background: var(--s3); color: var(--green); }

/* Histogram */
.histogram {
  height: 44px;
  display: flex;
  align-items: flex-end;
  gap: 2px;
  border-bottom: 1px solid var(--b);
  padding-bottom: 1px;
}

.histogram-bar {
  flex: 1;
  min-width: 2px;
  background: var(--green);
  opacity: 0.4;
  transition: opacity .12s;
  min-height: 4%;
  cursor: pointer;
}

.histogram-bar:hover { opacity: 0.9; }
.histogram-bar--dim { opacity: 0.08; }
.histogram-bar--in-range { opacity: 0.75; }
.histogram-bar--empty { cursor: default; }
.histogram-bar--empty:hover { opacity: 0.4; }

/* Price inputs */
.price-inputs {
  display: flex;
  align-items: center;
  gap: 5px;
}

.price-field {
  display: flex;
  align-items: center;
  flex: 1;
  min-width: 0;
  background: var(--s2);
  border: 1px solid var(--b);
  padding: 5px 6px;
  transition: border-color .12s;
}

.price-field:focus-within { border-color: rgba(48,209,88,0.35); }

.price-prefix {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-faint);
  margin-right: 2px;
}

.price-num {
  width: 100%;
  min-width: 0;
  border: none;
  background: transparent;
  outline: none;
  color: var(--text);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
  -moz-appearance: textfield;
  appearance: textfield;
}

.price-num::-webkit-outer-spin-button,
.price-num::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.price-sep { color: var(--text-faint); font-family: var(--mono); font-size: 11px; flex-shrink: 0; }

.filter-hint {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-faint);
  line-height: 1.5;
}

.link-btn {
  background: none;
  border: none;
  color: var(--green);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: underline;
  text-decoration-color: rgba(48,209,88,0.25);
  transition: color .12s;
  padding: 0;
}

.link-btn:hover { color: var(--primary-light); }

/* Suppliers */
.supplier-list { display: flex; flex-direction: column; gap: 1px; }

.supplier-name {
  flex: 1;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.supplier-count {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--green);
  background: var(--green-dim);
  border: 1px solid rgba(48,209,88,0.22);
  padding: 1px 5px;
  flex-shrink: 0;
}

.filter-option {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  cursor: pointer;
  transition: background .12s;
}

.filter-option:hover { background: var(--hover); }

.filter-option input {
  width: 13px; height: 13px;
  accent-color: var(--green);
  cursor: pointer;
  flex-shrink: 0;
}

.supplier-option { gap: 8px; }

.supplier-untrusted {
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 6px;
  cursor: pointer;
  transition: background .12s;
  opacity: 0.5;
}

.supplier-untrusted:hover { background: var(--hover); opacity: .7; }
.supplier-untrusted .supplier-name { text-decoration: line-through; }
.supplier-warning { font-size: 10px; flex-shrink: 0; }

.supplier-disable-x {
  flex-shrink: 0;
  width: 11px; height: 11px;
  display: flex; align-items: center; justify-content: center;
  background: var(--green-dim);
  color: var(--green);
  font-size: 8px;
}

.supplier-disclaimer {
  position: absolute;
  left: 6px; right: 6px;
  bottom: calc(100% + 4px);
  z-index: 20;
  padding: 6px 8px;
  background: var(--s0);
  border: 1px solid var(--bhi);
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 10px;
  line-height: 1.5;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  opacity: 0; visibility: hidden;
  transform: translateY(3px);
  transition: opacity .12s, transform .12s, visibility .12s;
  pointer-events: none;
}

.supplier-untrusted:hover .supplier-disclaimer { opacity: 1; visibility: visible; transform: translateY(0); }
.supplier-untrusted.revealed { opacity: 1; }
.supplier-untrusted.revealed .supplier-name { text-decoration: none; color: var(--orange); }

/* ═══════════════════════════════════════════════════════════════
   RESULTS MAIN
═══════════════════════════════════════════════════════════════ */
.results-main {
  display: flex;
  flex-direction: column;
  gap: 10px;
  animation: slideUp .24s var(--ease);
}

/* Status bar */
.status-bar {
  padding: 9px 12px;
  background: var(--s2);
  border: 1px solid var(--b);
}

.status-inner {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .02em;
}

/* Sort strip — GTAI .nav-links tab style */
.sort-strip {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--b);
  overflow-x: auto;
}

.sort-btn {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 7px 11px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  color: var(--text-faint);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: color .12s, border-color .12s;
  white-space: nowrap;
  margin-bottom: -1px;
}

.sort-btn:hover { color: var(--text-muted); }
.sort-btn.active { color: var(--green); border-bottom-color: var(--green); }

/* Source toggle */
.source-toggle {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  width: fit-content;
  padding: 4px 9px;
  background: var(--s2);
  border: 1px solid var(--b);
  color: var(--text-faint);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}

.source-toggle:hover { background: var(--s3); color: var(--text-muted); border-color: var(--bhi); }
.source-toggle.open { color: var(--green); border-color: rgba(48,209,88,0.28); }

.source-status {
  padding: 10px;
  background: var(--s1);
  border: 1px solid var(--b);
  display: flex;
  flex-direction: column;
  gap: 7px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.22);
}

.source-status-head {
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--text-faint);
}

.source-list { display: flex; flex-wrap: wrap; gap: 4px; }

.source-item {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px 7px;
  background: var(--s2);
  border: 1px solid var(--b);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--text-faint);
  cursor: pointer;
  transition: all .12s;
}

.source-item.success { border-color: rgba(48,209,88,0.28); color: var(--green); }
.source-item.success:hover { background: var(--green-dim); }
.source-item.failed  { border-color: rgba(255,69,58,0.28); color: var(--red); cursor: default; opacity: .7; }
.source-item.blocked { border-color: rgba(255,149,0,0.28); color: var(--orange); opacity: .7; cursor: default; }
.source-item.disabled { opacity: .3; }

.source-indicator { width: 4px; height: 4px; border-radius: 50%; background: currentColor; }

.source-group-label {
  width: 100%;
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--text-faint);
  padding: 3px 0 1px;
  margin-top: 3px;
}

.source-group-label:first-child { margin-top: 0; }
.source-group-label--blocked { color: var(--orange); }
.source-group-label--failed  { color: var(--red); }

/* Scam banner */
.scam-banner {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 10px;
  background: rgba(255,149,0,0.06);
  border: 1px solid rgba(255,149,0,0.2);
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-muted);
  line-height: 1.5;
}

.scam-banner-icon { width: 11px; height: 11px; flex-shrink: 0; margin-top: 1px; color: var(--orange); }
.scam-banner strong { color: var(--orange); }

/* ─── Results Grid ───────────────────────────────────────────── */
.results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px;
  align-items: start;
}

/* ─── Product Card ───────────────────────────────────────────── */
.product-card {
  display: flex;
  flex-direction: column;
  background: var(--s1);
  border: 1px solid var(--b);
  overflow: hidden;
  cursor: pointer;
  transition: border-color 150ms var(--ease), box-shadow 150ms var(--ease), transform 150ms var(--spring);
  box-shadow: 0 1px 4px rgba(0,0,0,0.22);
}

.product-card:hover {
  border-color: rgba(48,209,88,0.25);
  box-shadow: 0 8px 24px rgba(0,0,0,0.4), 0 0 0 1px rgba(48,209,88,0.08);
  transform: translateY(-1px);
}

.product-image {
  width: 100%;
  height: 128px;
  background: var(--s2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-faint);
  font-size: 22px;
  overflow: hidden;
  position: relative;
}

.product-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 250ms var(--ease);
}

.product-card:hover .product-image img { transform: scale(1.04); }

.product-content {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding: 9px;
  flex: 1;
}

/* Badge */
.product-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  width: fit-content;
  padding: 2px 5px;
  background: var(--s2);
  border: 1px solid var(--bhi);
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.product-badge--oos         { background: var(--red-dim);    border-color: rgba(255,69,58,0.26);  color: var(--red); }
.product-badge--unavailable { background: transparent;        border-color: var(--b);               color: var(--text-faint); }
.product-badge--new         { background: var(--green-dim);  border-color: rgba(48,209,88,0.22);  color: var(--green); }
.product-badge--used        { background: var(--orange-dim); border-color: rgba(255,149,0,0.20);  color: var(--orange); }

.product-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.4;
  letter-spacing: -.01em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.product-source {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: .02em;
}

.product-footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 7px;
  border-top: 1px solid var(--b);
}

.product-price { display: flex; flex-direction: column; gap: 1px; }

.product-price-main {
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -.02em;
  color: var(--text);
}

.product-price-original {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-faint);
  text-decoration: line-through;
}

/* View button — GTAI .nav-cta ghost style */
.product-link {
  padding: 4px 9px;
  background: transparent;
  border: 1px solid var(--border-hard);
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .04em;
  cursor: pointer;
  transition: color .12s, border-color .12s, background .12s;
  white-space: nowrap;
}

.product-link:hover { background: var(--green); color: #1a1a1a; border-color: transparent; }

/* ─── Skeleton ───────────────────────────────────────────────── */
.product-card--skeleton { cursor: default; pointer-events: none; }
.product-card--skeleton:hover { border-color: var(--b); box-shadow: 0 1px 4px rgba(0,0,0,0.22); transform: none; }
.product-image--skeleton { background: var(--s2); animation: pulse 1.5s ease-in-out infinite; }

.skeleton-line {
  height: 9px;
  background: var(--s2);
  animation: pulse 1.5s ease-in-out infinite;
}

.skeleton-line--title  { width: 80%; height: 12px; }
.skeleton-line--source { width: 46%; }
.skeleton-line--price  { width: 32%; height: 14px; margin-top: auto; }

.product-card--live-in { opacity: 0; transform: scale(0.96) translateY(5px); transition: opacity 180ms var(--ease), transform 180ms var(--spring); }
.product-card--live-in-active { opacity: 1; transform: none; }

/* ─── Empty State ────────────────────────────────────────────── */
.empty-state { grid-column: 1/-1; text-align: center; padding: 48px 20px; color: var(--text-faint); }
.empty-state-icon { font-size: 36px; margin-bottom: 10px; opacity: .3; }
.empty-state-title { font-family: var(--sf); font-size: 15px; font-weight: 700; letter-spacing: -.02em; color: var(--text-muted); margin-bottom: 5px; }
.empty-state-text  { font-family: var(--mono); font-size: 11px; color: var(--text-faint); }

/* ─── Scrollbar ──────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--s3); }
::-webkit-scrollbar-thumb:hover { background: var(--text-faint); }

/* ─── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .layout { grid-template-columns: 1fr; }
  .sidebar { position: static; display: none; max-height: none; }
  .sidebar.open { display: flex; }
  .nav { padding: 0 20px; }
  .nav-center { display: none; }
}

@media (max-width: 768px) {
  .stage { padding: 32px 16px 56px; }
  .results-grid { grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); }
  .product-image { height: 110px; }
}

@media (max-width: 480px) {
  .stage { padding: 24px 14px 44px; }
  .results-grid { grid-template-columns: 1fr 1fr; }
  .layout { padding: 10px; }
  .nav-search-wrap { display: none; }
}
/* ═══════════════════════════════════════════════════════════════
   LIVE TICKER WIDGET
═══════════════════════════════════════════════════════════════ */
@keyframes ticker-pop {
  0%   { opacity:0; transform:translateY(8px) scale(0.95); }
  60%  { transform:translateY(-2px) scale(1.01); }
  100% { opacity:1; transform:none; }
}
@keyframes price-flash-up {
  0%   { background: rgba(48,209,88,0.22); color: #30d158; }
  100% { background: transparent; color: var(--text); }
}
@keyframes price-flash-down {
  0%   { background: rgba(255,69,58,0.18); color: #ff453a; }
  100% { background: transparent; color: var(--text); }
}
@keyframes live-dot-pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:0.35; transform:scale(0.7); }
}

.live-ticker {
  width: 100%;
  border: 1px solid var(--border-hard);
  background: var(--s1);
  overflow: hidden;
}

.ticker-head {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-hard);
}

.ticker-live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
  animation: live-dot-pulse 1.4s ease-in-out infinite;
}

.ticker-label {
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .14em;
  color: var(--text-faint);
  text-transform: uppercase;
}

.ticker-sub {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--text-faint);
  opacity: 0.5;
  margin-left: auto;
  letter-spacing: .04em;
}

.ticker-track {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

.ticker-card {
  padding: 9px 12px;
  border-right: 1px solid var(--border-hard);
  border-bottom: 1px solid var(--border-hard);
  cursor: pointer;
  transition: background .12s;
  box-sizing: border-box;
}

.ticker-card:nth-child(3n) { border-right: none; }
.ticker-card:nth-child(n+4) { border-bottom: none; }

.ticker-card:hover { background: var(--hover); }

.ticker-card-name {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 3px;
}

.ticker-card-source {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--text-faint);
  margin-bottom: 5px;
  letter-spacing: .02em;
}

.ticker-card-bottom {
  display: flex;
  align-items: center;
  gap: 5px;
}

.ticker-card-price {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: .02em;
  transition: color .15s;
  padding: 1px 3px;
  border-radius: 2px;
}

.ticker-card-price.flash-up {
  animation: price-flash-up .7s ease both;
}

.ticker-card-price.flash-down {
  animation: price-flash-down .7s ease both;
}

.ticker-card-delta {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .02em;
}

.ticker-card-delta.up   { color: var(--green); }
.ticker-card-delta.down { color: var(--red); }

/* ═══════════════════════════════════════════════════════════════
   SOURCES DISCLOSURE (hero)
═══════════════════════════════════════════════════════════════ */
.sources-disclosure {
  width: 100%;
  border: 1px solid var(--border-hard);
  background: var(--s1);
  overflow: hidden;
}

.sources-toggle {
  display: flex;
  align-items: center;
  gap: 7px;
  width: 100%;
  padding: 9px 12px;
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .05em;
  cursor: pointer;
  transition: background .12s, color .12s;
  text-align: left;
}

.sources-toggle:hover { background: var(--hover); color: var(--text); }
.sources-toggle > svg:first-child { color: var(--text-faint); flex-shrink:0; }

.sources-chevron {
  margin-left: auto;
  color: var(--text-faint);
  transition: transform .2s var(--ease);
  flex-shrink: 0;
}

.sources-toggle.open .sources-chevron { transform: rotate(180deg); }

.sources-panel {
  border-top: 1px solid var(--border-hard);
  padding: 10px 12px;
}

.sources-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.source-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border: 1px solid var(--border-hard);
  background: var(--s2);
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .03em;
  cursor: default;
  transition: background .1s, border-color .1s;
  border-radius: 2px;
}

.source-chip::before {
  content: '';
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   HERO FOOTER
═══════════════════════════════════════════════════════════════ */
.hero-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 24px;
  border-top: 1px solid var(--border-hard);
}

.hero-footer-text {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: .04em;
}

.hero-footer-link {
  color: var(--text-muted);
  text-decoration: none;
  border-bottom: 1px solid var(--border-hard);
  transition: color .12s, border-color .12s;
}

.hero-footer-link:hover {
  color: var(--text);
  border-color: var(--text-muted);
}

/* ═══════════════════════════════════════════════════════════════
   HERO FOOTER — separator & button variant
═══════════════════════════════════════════════════════════════ */
.hero-footer-sep {
  color: var(--text-faint);
  font-family: var(--mono);
  font-size: 10px;
  opacity: 0.5;
  margin: 0 2px;
}

.hero-footer-link--btn {
  background: none;
  border: none;
  border-bottom: 1px solid var(--border-hard);
  cursor: pointer;
  padding: 0;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .04em;
}

/* ═══════════════════════════════════════════════════════════════
   LEGAL / TERMS OF SERVICE PAGE
═══════════════════════════════════════════════════════════════ */
#legalSection {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.legal-wrap {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
  padding: 56px 24px 80px;
}

/* Header */
.legal-header {
  margin-bottom: 48px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--border-hard);
}

.legal-title {
  font-family: var(--sf);
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--text);
  margin-top: 14px;
  margin-bottom: 10px;
  line-height: 1.15;
}

.legal-meta {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: .06em;
}

/* Body */
.legal-intro {
  font-family: var(--mono);
  font-size: 12px;
  line-height: 1.75;
  color: var(--text-muted);
  margin-bottom: 40px;
  padding: 14px 16px;
  border-left: 2px solid var(--border-hard);
  background: var(--s1);
}

.legal-body {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.legal-section {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.legal-h2 {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text);
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border-hard);
}

.legal-num {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--text-faint);
  letter-spacing: .08em;
  flex-shrink: 0;
}

.legal-section p {
  font-family: var(--mono);
  font-size: 11.5px;
  line-height: 1.8;
  color: var(--text-muted);
}

.legal-section strong {
  color: var(--text);
  font-weight: 500;
}

.legal-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.legal-list li {
  font-family: var(--mono);
  font-size: 11.5px;
  line-height: 1.7;
  color: var(--text-muted);
  padding-left: 18px;
  position: relative;
}

.legal-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--text-faint);
  font-size: 10px;
}

.legal-code {
  font-family: var(--mono);
  font-size: 10.5px;
  background: var(--s2);
  border: 1px solid var(--border-hard);
  padding: 1px 5px;
  border-radius: 2px;
  color: var(--text);
}

.legal-link {
  color: var(--text-muted);
  text-underline-offset: 3px;
  transition: color .12s;
}

.legal-link:hover { color: var(--text); }

/* Footer */
.legal-footer {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 56px;
  padding-top: 24px;
  border-top: 1px solid var(--border-hard);
}

.legal-back-cta {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: var(--s2);
  border: 1px solid var(--border-hard);
  color: var(--text-muted);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
  flex-shrink: 0;
}

.legal-back-cta:hover {
  background: var(--hover);
  color: var(--text);
  border-color: var(--bhi);
}

.legal-footer-copy {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: .04em;
  margin-left: auto;
}

@media (max-width: 768px) {
  .legal-wrap { padding: 32px 16px 56px; }
  .legal-title { font-size: 24px; }
}