/* ==========================================================
   MERCHANT DASHBOARD: additions on top of design-system.css

   Loaded AFTER design-system.css so cascade order is:
     1. design-system.css (tokens, resets, typography, .btn, .field, .eyebrow, .prose)
     2. dashboard.css     (dashboard-only: app shell, sidebar, tables, modals,
                            progress bars, badges, toast, meter cards)

   Everything here uses the design-system tokens: no new colors or fonts.
========================================================== */

/* ==========================================================
   DASHBOARD-LOCAL TOKENS
   Additions to design-system.css's :root. Kept here so the
   design-system stays upstream-pure and dashboard-specific
   needs live alongside the dashboard-specific rules.
========================================================== */
:root {
  /* Extends the existing --t-*xs cadence (design-system ends at
     --t-2xs: 0.6875rem). One step smaller for dense pills/badges. */
  --t-3xs: 0.625rem;
  /* Badge typography tokens. Tuned for the uppercase mono pill used
     across tables, summary cells, and row meta: tight enough to feel
     like metadata, not UI chrome. */
  --badge-font-size:      var(--t-3xs);
  --badge-padding:        0.15em 0.55em;
  --badge-letter-spacing: 0.08em;
}

/* ==========================================================
   APP SHELL: header + sidebar + main
========================================================== */
.app {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr;
}

.app__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-4) var(--gutter);
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  position: sticky;
  top: 0;
  z-index: 10;
}
.app__mark {
  display: inline-flex;
  align-items: baseline;
  gap: 0.4em;
  font-family: var(--font-display);
  font-size: var(--t-xl);
  font-variation-settings: "opsz" 72, "SOFT" 100;
  letter-spacing: -0.015em;
}
.app__mark-sigil { color: var(--accent); font-size: 1.25em; position: relative; top: 0.05em; }
.app__user {
  display: inline-flex;
  align-items: center;
  gap: var(--s-4);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.app__user a { color: inherit; transition: color var(--dur-1); }
.app__user a:hover { color: var(--accent); }

.app__body {
  display: grid;
  grid-template-columns: 15rem 1fr;
  gap: 0;
}
@media (max-width: 51.25em) {
  .app__body { grid-template-columns: 1fr; }
  .app__sidebar { display: none; }
}

.app__sidebar {
  border-right: 1px solid var(--rule);
  padding: var(--s-6) var(--s-5);
  /* background: var(--paper-deep); */
}
.app__sidebar ul { display: flex; flex-direction: column; gap: var(--s-1); }
.app__sidebar a {
  display: flex;
  align-items: center;
  padding: var(--s-2) var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mid);
  border-left: 2px solid transparent;
  transition: color var(--dur-1), border-color var(--dur-1), background var(--dur-1);
}
.app__sidebar a:hover { color: var(--ink); background: rgba(23,20,14,0.04); }
.app__sidebar a.is-active {
  color: var(--ink);
  border-left-color: var(--accent);
  background: rgba(178,71,24,0.05);
}

.app__main {
  padding: var(--s-6) var(--gutter);
  max-width: 68.75rem;
  width: 100%;
  margin-inline: auto;
}

/* ==========================================================
   PAGE HEADERS
========================================================== */
.page__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
  padding-bottom: var(--s-4);
  border-bottom: 1px solid var(--rule);
}
.page__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, var(--t-2xl));
  font-weight: 420;
  font-variation-settings: "opsz" 72, "SOFT" 80;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.page__lede {
  font-size: var(--t-sm);
  color: var(--ink-mid);
  max-width: 60ch;
  margin-top: var(--s-2);
}
.page__actions { display: inline-flex; gap: var(--s-3); flex-wrap: wrap; }

/* Interior section heading used between `.page__head` and a block of content
   (a table, a panel, a chart). Gives consistent breathing room above and
   below so the heading doesn't slam into the next element. Use whenever a
   page has more than one logical section under its title. */
.section-title {
  font-family: var(--font-display);
  font-size: var(--t-lg);
  font-weight: 440;
  font-variation-settings: "opsz" 36;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: var(--s-5) 0 var(--s-3);
}
.section-title:first-child { margin-top: 0; }

/* ==========================================================
   PANELS / CARDS
========================================================== */
.panel {
  background: var(--paper-deep);
  border: 1px solid var(--rule);
  padding: var(--s-5) var(--s-5);
  margin-bottom: var(--s-5);
}
.panel--compact { padding: var(--s-3) var(--s-4); }
.panel--accent {
  border-color: var(--accent);
  background: var(--accent-tint);
}
.panel--accent .panel__head { border-color: var(--accent); }
.panel--accent .panel__title { color: var(--accent-deep); }
.panel__body { font-size: var(--t-sm); color: var(--ink); }
.panel--dash-catalog { margin-bottom: var(--s-6); }
.panel__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--rule);
}
.panel__title {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mid);
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  gap: var(--s-4);
}
.card-grid--tiers {
  grid-template-columns: repeat(auto-fit, minmax(17.5rem, 1fr));
}
.card {
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  padding: var(--s-4);
}
.card--current {
  border-color: var(--accent);
  border-width: 2px;
}
.card--disabled { opacity: 0.6; }
.card__value--md { font-size: var(--t-xl); }
.card__label {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
  display: block;
  margin-bottom: var(--s-2);
}
.card__value {
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  font-variation-settings: "opsz" 72, "SOFT" 80;
  font-weight: 420;
  color: var(--ink);
  letter-spacing: -0.015em;
}
.card__sub {
  font-size: var(--t-sm);
  color: var(--ink-mid);
  margin-top: var(--s-1);
}

/* ==========================================================
   PREVIEW / DEFINITION LIST: label <-> value rows
========================================================== */
.preview {
  display: flex;
  flex-direction: column;
}
.preview__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-2) 0;
  border-bottom: 1px dashed var(--rule-soft);
  font-size: var(--t-sm);
}
.preview__row:last-child { border-bottom: 0; }
.preview__k {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.preview__v {
  color: var(--ink);
  text-align: right;
}

/* ==========================================================
   PROGRESS / METER BARS (for usage)
========================================================== */
.meter {
  margin-bottom: var(--s-5);
}
.meter__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
  margin-bottom: var(--s-2);
}
.meter__label {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.meter__value {
  font-family: var(--font-display);
  font-variation-settings: "opsz" 36, "SOFT" 50;
  font-size: var(--t-md);
  color: var(--ink);
}
.meter__bar {
  height: var(--s-2);
  background: var(--paper-darker);
  border-radius: 2px;
  overflow: hidden;
  position: relative;
}
.meter__fill {
  height: 100%;
  background: var(--accent);
  transition: width var(--dur-2) var(--ease-out);
}
.meter__fill--safe    { background: var(--forest); }
.meter__fill--warning { background: var(--accent); }
.meter__fill--danger  { background: var(--accent-deep); }
.meter__foot {
  display: flex;
  justify-content: space-between;
  margin-top: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-ghost);
}
.meter--na {
  opacity: 0.55;
  font-style: italic;
  color: var(--ink-mid);
  font-family: var(--font-display);
  padding: var(--s-2) 0;
}
.meter--na__label { color: var(--ink-ghost); }
.meter--na__note  { margin-left: var(--s-3); }

/* ==========================================================
   TABLES: ledger-like, editorial
========================================================== */
.tbl {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--t-sm);
}
.tbl thead th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
  padding: var(--s-2) var(--s-3);
  border-bottom: 1px solid var(--ink);
}
.tbl tbody td {
  padding: var(--s-3);
  border-bottom: 1px solid var(--rule-soft);
  vertical-align: top;
  color: var(--ink);
}
.tbl tbody tr:hover td { background: rgba(178,71,24,0.03); }
.tbl tbody tr:last-child td { border-bottom: 0; }
.tbl td.num, .tbl th.num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
.tbl td.mono, .tbl th.mono { font-family: var(--font-mono); font-size: var(--t-xs); color: var(--ink-soft); }

/* ==========================================================
   BADGES / STATUS CHIPS
========================================================== */
.badge {
  display: inline-flex;
  align-items: center;
  padding: var(--badge-padding);
  font-family: var(--font-mono);
  font-size: var(--badge-font-size);
  line-height: 1.5;
  letter-spacing: var(--badge-letter-spacing);
  text-transform: uppercase;
  border: 1px solid var(--rule);
  color: var(--ink-mid);
  background: var(--paper);
}
.badge--success { border-color: var(--forest); color: var(--forest); }
.badge--warning { border-color: var(--accent); color: var(--accent); }
.badge--danger  { border-color: var(--accent-deep); color: var(--accent-deep); background: var(--accent-tint); }
.badge--info    { border-color: var(--ink-mid); color: var(--ink); }

/* Modality pills: the three independent hadText/hadImage/hadAudio
   flags shown alongside search-query rows. Each pill shows up only
   when its flag is true; a row can have any combination. */
.mod-pills {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.25rem;
}
.mod-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.15rem 0.45rem 0.15rem 0.4rem;
  font-family: var(--font-mono);
  font-size: var(--t-3xs, 0.65rem);
  line-height: 1.5;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border: 1px solid var(--rule);
  border-radius: 999px;
  color: var(--ink-mid);
  background: var(--paper);
}
.mod-pill svg { display: block; flex: 0 0 auto; }
.mod-pill--text  { color: var(--ink-mid); }
.mod-pill--image { color: var(--ink); border-color: var(--ink-mid); }
.mod-pill--audio { color: var(--accent-deep); border-color: var(--accent); background: var(--accent-tint); }

/* ==========================================================
   BUTTONS: dashboard additions to design-system's .btn*
========================================================== */
.btn--small {
  padding: 0.5em 0.85em;
  font-size: var(--t-2xs);
  letter-spacing: 0.12em;
}
.btn--danger {
  background: transparent;
  color: var(--accent-deep);
  border-color: var(--accent-deep);
}
.btn--danger:hover { background: var(--accent-deep); color: var(--paper); }
.btn[disabled], .btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* ==========================================================
   MODALS: editorial sheet pulled over the page
========================================================== */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(23, 20, 14, 0.55);
  backdrop-filter: blur(2px);
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--s-4);
  animation: fadeIn var(--dur-1) var(--ease-out);
}
.modal {
  background: var(--paper);
  border: 1px solid var(--ink);
  max-width: 35rem;
  width: 100%;
  max-height: 85vh;
  overflow-y: auto;
  padding: var(--s-6);
  box-shadow: 0 1.5rem 3rem rgba(23,20,14,0.18);
}
.modal__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-4);
  margin-bottom: var(--s-5);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--rule);
}
.modal__title {
  font-family: var(--font-display);
  font-size: var(--t-xl);
  font-variation-settings: "opsz" 72, "SOFT" 80;
  font-weight: 420;
  color: var(--ink);
}
.modal__close {
  background: none;
  border: 0;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--t-md);
  color: var(--ink-mid);
  width: var(--s-7);
  height: var(--s-7);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 2px;
  flex-shrink: 0;
  transition: color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out);
}
.modal__close:hover {
  color: var(--accent);
  background: var(--paper-darker);
}
.modal__close:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.modal__body { margin-bottom: var(--s-5); }
.modal__body .field + .field { margin-top: var(--s-4); }
.modal__foot {
  display: flex;
  gap: var(--s-3);
  justify-content: flex-end;
  flex-wrap: wrap;
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule);
}

/* ==========================================================
   TOASTS (ephemeral status messages)
========================================================== */
.toast-stack {
  position: fixed;
  top: var(--s-4);
  right: var(--s-4);
  z-index: 200;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  pointer-events: none;
}
.toast {
  min-width: 16.25rem;
  max-width: 26.25rem;
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: var(--s-3) var(--s-4);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  color: var(--ink);
  box-shadow: 0 0.5rem 1.5rem rgba(23,20,14,0.16);
  pointer-events: auto;
  animation: toastIn var(--dur-1) var(--ease-out);
}
.toast--success { border-color: var(--forest); }
.toast--warning { border-color: var(--accent); }
.toast--error   { border-color: var(--accent-deep); background: var(--accent-tint); }
.toast__action {
  display: inline-block;
  margin-left: var(--s-2);
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 0.15em;
  font-weight: 600;
}
.toast__action:hover { color: var(--accent-deep); }

/* ==========================================================
   LOADING
========================================================== */
.loading-overlay {
  position: fixed; inset: 0;
  background: rgba(238, 229, 206, 0.72);
  backdrop-filter: blur(2px);
  z-index: 150;
  display: none;
  align-items: center;
  justify-content: center;
}
.loading-overlay.is-shown { display: flex; }
.spinner {
  width: var(--s-6); height: var(--s-6);
  border: 2px solid var(--rule);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
}

/* ==========================================================
   FORM GROUPS & LABELS (for modals / auth forms)
========================================================== */
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4);
}
@media (max-width: 40em) {
  .form-grid { grid-template-columns: 1fr; }
}

.checkbox {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  color: var(--ink);
}
.checkbox input {
  width: 1rem;
  height: 1rem;
  accent-color: var(--accent);
}

/* ==========================================================
   AUTH LANDING: login / signup centering
========================================================== */
.auth {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--s-6);
}
.auth__card {
  max-width: 27.5rem;
  width: 100%;
  background: var(--paper);
  border: 1px solid var(--ink);
  padding: var(--s-7);
  box-shadow: 0 1.5rem 3rem rgba(23,20,14,0.12);
}
.auth__brand {
  display: flex;
  align-items: baseline;
  gap: 0.4em;
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  font-variation-settings: "opsz" 72, "SOFT" 100;
  letter-spacing: -0.015em;
  margin-bottom: var(--s-2);
}
.auth__brand-sigil { color: var(--accent); font-size: 1.15em; position: relative; top: 0.05em; }
.auth__sub {
  font-size: var(--t-sm);
  color: var(--ink-mid);
  margin-bottom: var(--s-6);
}
.auth__form { display: flex; flex-direction: column; gap: var(--s-4); }
.auth__form--narrow { max-width: 27.5rem; }
.auth__submit { justify-self: start; margin-top: var(--s-3); }
.auth__alt {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  color: var(--ink-mid);
  text-align: center;
}
.auth__alt a {
  color: var(--accent);
  transition: color var(--dur-1);
}
.auth__alt a:hover { color: var(--accent-deep); }

.auth__error {
  margin-top: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  color: var(--accent-deep);
  min-height: 1em;
}

/* ==========================================================
   UTILITIES
========================================================== */
.mono { font-family: var(--font-mono); }
.muted { color: var(--ink-mid); }
.text-right { text-align: right; }
.text-success { color: var(--forest); }
.text-danger  { color: var(--accent-deep); }
.text-accent  { color: var(--accent); }
.hidden { display: none !important; }

.text-2xs { font-size: var(--t-2xs); }
.text-xs  { font-size: var(--t-xs); }
.text-sm  { font-size: var(--t-sm); }
.text-md  { font-size: var(--t-md); }
.text-lg  { font-size: var(--t-lg); }
.text-xl  { font-size: var(--t-xl); }

.nums-right { text-align: right; font-variant-numeric: tabular-nums; }

.mt-1 { margin-top: var(--s-1); }
.mt-2 { margin-top: var(--s-2); }
.mt-3 { margin-top: var(--s-3); }
.mt-4 { margin-top: var(--s-4); }
.mt-5 { margin-top: var(--s-5); }
.mt-6 { margin-top: var(--s-6); }
.mb-2 { margin-bottom: var(--s-2); }
.mb-3 { margin-bottom: var(--s-3); }
.mb-4 { margin-bottom: var(--s-4); }
.mb-5 { margin-bottom: var(--s-5); }
.mb-6 { margin-bottom: var(--s-6); }

/* Muted mono micro-caption (letter-spaced "ticker" text) */
.hint {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: 0.08em;
  color: var(--ink-mid);
}
.hint--tight { letter-spacing: 0.05em; }

.inline-code {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  background: var(--paper-darker);
  padding: 0.1em 0.4em;
  letter-spacing: 0.02em;
  color: var(--ink);
}

.empty {
  padding: var(--s-6);
  text-align: center;
  color: var(--ink-mid);
  font-style: italic;
  background: var(--paper-deep);
  border: 1px dashed var(--rule);
}
.empty--error { color: var(--accent-deep); }
.empty a {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 0.15em;
  font-weight: 600;
}
.empty a:hover { color: var(--accent-deep); }
.empty--inline {
  padding: var(--s-3);
  background: transparent;
  border: 0;
  text-align: left;
  font-style: normal;
}

.key-flash {
  background: var(--accent-tint);
  border: 1px solid var(--accent);
  padding: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  word-break: break-all;
  color: var(--ink);
  letter-spacing: 0.02em;
  text-transform: none;
  margin: var(--s-3) 0;
}

/* ==========================================================
   DASH: sub-section headers inside a panel (splits a panel
   into labelled zones without a full second panel).
========================================================== */
.dash-subhead {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
  margin-bottom: var(--s-2);
}
.dash-subhead + .dash-subhead-group,
.dash-subhead--spaced { margin-top: var(--s-5); }
.dash-subhead__note {
  font-size: var(--t-xs);
  color: var(--ink-mid);
  margin-bottom: var(--s-2);
  font-family: var(--font-sans, inherit);
  letter-spacing: 0;
  text-transform: none;
}

/* ==========================================================
   SUMMARY ROW: catalog-health counter cells used on the
   dashboard, items, and queries pages.
========================================================== */
.summary-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: var(--s-3);
  margin-bottom: var(--s-5);
}
.summary-cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--s-2);
  padding: var(--s-4) var(--s-5);
  background: var(--paper);
  border: 1px solid var(--rule);
  color: inherit;
  text-align: left;
  font: inherit;
  text-decoration: none;
}
/* Clickable variants: buttons and anchors get pointer + hover. Plain
   <div> summary-cells (preview + completion readouts in the import flow)
   stay presentational. */
button.summary-cell,
a.summary-cell {
  cursor: pointer;
  text-decoration: none;
  transition: border-color var(--dur-1) var(--ease-out),
              background var(--dur-1) var(--ease-out);
}
button.summary-cell:hover,
a.summary-cell:hover {
  border-color: var(--ink);
  background: var(--paper-deep);
}
.summary-cell--active {
  border-color: var(--accent);
  background: var(--accent-tint);
}
.summary-cell__count {
  font-family: var(--font-display);
  font-size: var(--t-2xl);
  line-height: 1;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.summary-cell__label {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.summary-cell__badge {
  margin-top: auto;
}

/* ==========================================================
   FILTER ROW: inline chip row under the summary row
========================================================== */
.filter-row {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
  margin-bottom: var(--s-4);
}
.filter-row__label {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
  margin-right: var(--s-2);
}
.chip {
  display: inline-flex;
  align-items: center;
  padding: 0.35em 0.9em;
  font-family: inherit;
  font-size: var(--t-xs);
  background: var(--paper);
  border: 1px solid var(--rule);
  color: var(--ink-mid);
  cursor: pointer;
  transition: border-color var(--dur-1) var(--ease-out),
              background var(--dur-1) var(--ease-out),
              color var(--dur-1) var(--ease-out);
}
.chip:hover { border-color: var(--ink); color: var(--ink); }
.chip--active {
  border-color: var(--accent);
  background: var(--accent-tint);
  color: var(--accent-deep);
}

/* ==========================================================
   LIST ROWS: item + query row micro-layout + load-more
========================================================== */
.item-title, .query-text {
  font-size: var(--t-sm);
  color: var(--ink);
  line-height: 1.4;
}
.item-sub, .query-sub {
  font-size: var(--t-xs);
  color: var(--ink-soft);
  margin-top: 0.15em;
  line-height: 1.4;
}
.query-sub.muted { color: var(--ink-mid); }

.item-error-row td {
  background: var(--paper-deep);
  padding-top: 0;
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--rule);
}

.load-more {
  display: flex;
  justify-content: center;
  margin-top: var(--s-5);
}

/* ==========================================================
   IMPORT PAGE: side-by-side input + live preview/progress
   ==========================================================
   Layout: two equal columns on desktop. Left = input (textarea +
   file upload + collapsed format help). Right = live preview that
   cycles through empty / preview / importing / done states without
   displacing the layout. The right column is sticky so the summary
   + Import button stay in view while the textarea grows.
*/
.import-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--s-5);
  align-items: start;
}
@media (max-width: 56.25em) {
  .import-grid { grid-template-columns: 1fr; }
}

.import-input { margin-bottom: 0; }
.import-input textarea {
  width: 100%;
  min-height: 28rem;
  resize: vertical;
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  line-height: 1.5;
}
.import-input__tools {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-top: var(--s-3);
  flex-wrap: wrap;
}
.import-input__file {
  display: none;
}
.import-input__file-label {
  cursor: pointer;
}

/* Right-side pane. Sticky so the Import button + preview stay visible
   when the textarea grows tall. min-height keeps it from collapsing
   to nothing in the empty state. */
.import-side {
  position: sticky;
  top: var(--s-4);
  min-height: 28rem;
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
}
@media (max-width: 56.25em) {
  .import-side { position: static; }
}
.import-side__empty {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-mid);
  font-style: italic;
  text-align: center;
  padding: var(--s-5);
}
.import-side > * + * { margin-top: var(--s-4); }
.import-side .page__actions { margin-top: auto; padding-top: var(--s-4); }

/* Full-width collapsed disclosure below the input/preview grid. Help is
   valuable but consumed once: keep it out of the way until asked for,
   and let the examples table breathe at full page width when open. */
.format-help {
  margin-top: var(--s-4);
}
.format-help > summary {
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
  list-style: none;
  padding: var(--s-1) 0;
  user-select: none;
}
.format-help > summary::-webkit-details-marker { display: none; }
.format-help > summary::before {
  content: '▸';
  color: var(--accent);
  display: inline-block;
  width: 1.1em;
  transition: transform var(--dur-1) var(--ease-out);
}
.format-help[open] > summary::before { transform: rotate(90deg); }
.format-help > summary:hover { color: var(--ink); }
.format-help__body {
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--s-6);
  align-items: start;
}
@media (max-width: 56.25em) {
  .format-help__body { grid-template-columns: 1fr; gap: var(--s-4); }
}

.help-list {
  font-size: var(--t-sm);
  line-height: 1.6;
  padding-left: var(--s-4);
  margin: 0;
}
.help-list li + li { margin-top: var(--s-1); }

.example-table {
  font-size: var(--t-xs);
  border-collapse: collapse;
  width: 100%;
}
.example-table td {
  padding: var(--s-2) 0;
  vertical-align: top;
}
.example-table td:first-child {
  font-family: var(--font-mono);
  padding-right: var(--s-4);
  white-space: nowrap;
}

.field__hint {
  font-size: var(--t-2xs);
  color: var(--ink-mid);
  margin-top: var(--s-1);
}

.stack-sm > * + * { margin-top: var(--s-4); }
.stack-md > * + * { margin-top: var(--s-5); }

.import-note {
  font-size: var(--t-xs);
  color: var(--ink-mid);
  padding: var(--s-3);
  background: var(--paper-deep);
  border-left: 2px solid var(--rule);
}

/* Clickable table rows (items list row → edit form) */
.tbl tr.tbl-row-clickable { cursor: pointer; }

/* Row-action cluster: right-aligned group of ghost buttons. Lives inside
   a `<td>` so the cell remains display: table-cell (its vertical-align
   governs the buttons within the row). Using flex directly on the `<td>`
   breaks table-row height sharing: when an adjacent cell's content
   wraps, the row grows but a flex-cell doesn't stretch with it. */
.tbl .tbl-actions {
  display: inline-flex;
  gap: 0.375rem;
  justify-content: flex-end;
  flex-wrap: nowrap;
  white-space: nowrap;
}

/* ==========================================================
   ITEM FORM: create / edit surface
========================================================== */
.item-form { display: flex; flex-direction: column; gap: var(--s-5); }
.item-form .field + .field,
.item-form .field + .item-form__row,
.item-form__row + .field,
.item-form__row + .item-form__row { margin-top: 0; }

.item-form__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--s-5);
}
@media (max-width: 43.75em) {
  .item-form__row { grid-template-columns: 1fr; }
}

.item-form textarea { resize: vertical; }
.item-form textarea.description { min-height: 10rem; }

.field__error {
  font-size: var(--t-2xs);
  color: var(--accent-deep);
  margin-top: var(--s-1);
  min-height: 1em;
}

/* In-stock tri-state chip toggle */
.instock-group {
  display: inline-flex;
  gap: var(--s-2);
  padding: var(--s-2) 0;
}

/* Image list */
.image-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  margin-top: var(--s-2);
}
.image-row {
  display: grid;
  grid-template-columns: var(--s-7) minmax(0, 1fr) auto;
  gap: var(--s-3);
  align-items: center;
}
.image-thumb {
  width: var(--s-7);
  height: var(--s-7);
  border: 1px solid var(--rule);
  background: var(--paper-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  color: var(--ink-mid);
  text-align: center;
}
.image-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.image-thumb--error { color: var(--accent-deep); }
.image-row__remove {
  background: none;
  border: 0;
  color: var(--ink-mid);
  cursor: pointer;
  font-size: var(--t-md);
  padding: var(--s-2);
  line-height: 1;
}
.image-row__remove:hover { color: var(--accent-deep); }
.image-row input { width: 100%; }
.image-add { align-self: flex-start; margin-top: var(--s-2); }

/* JSON metadata disclosure */
.metadata-details {
  border-top: 1px solid var(--rule);
  padding-top: var(--s-3);
}
.metadata-details > summary {
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mid);
  list-style: none;
  padding: var(--s-1) 0;
  user-select: none;
}
.metadata-details > summary::-webkit-details-marker { display: none; }
.metadata-details > summary::before {
  content: '▸';
  color: var(--accent);
  display: inline-block;
  width: 1.1em;
  transition: transform var(--dur-1) var(--ease-out);
}
.metadata-details[open] > summary::before { transform: rotate(90deg); }
.metadata-details textarea {
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  min-height: 8rem;
  margin-top: var(--s-3);
}

/* Billing note: reuses import-note base */
.billing-note {
  font-size: var(--t-xs);
  color: var(--ink-mid);
  padding: var(--s-3);
  background: var(--paper-deep);
  border-left: 2px solid var(--rule);
}
.billing-note--charged { border-left-color: var(--accent); color: var(--ink); }
.billing-note--free    { border-left-color: var(--forest); }

/* Form actions: primary on right, secondary/delete on left */
.item-form__actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--s-3);
  flex-wrap: wrap;
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule);
}
.item-form__actions-left  { display: inline-flex; gap: var(--s-3); }
.item-form__actions-right { display: inline-flex; gap: var(--s-3); }
.import-note--danger {
  color: var(--ink);
  background: var(--accent-tint);
  border-left-color: var(--accent-deep);
}
.import-note + .import-note { margin-top: var(--s-3); }

.preview-meta { font-size: var(--t-xs); }
.preview-section__title {
  margin: 0 0 var(--s-2) 0;
  font-size: var(--t-sm);
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mid);
}
.preview-section__title--danger { color: var(--accent-deep); }
.preview-list {
  font-size: var(--t-sm);
  line-height: 1.7;
  list-style: none;
  padding: 0;
  margin: 0;
  max-height: 14rem;
  overflow-y: auto;
}
.preview-list--tight { font-size: var(--t-xs); line-height: 1.5; max-height: 10rem; }

/* Progress bar used during import */
.progress {
  margin-top: var(--s-3);
  height: 0.625rem;
  background: var(--ink-paper);
  border-radius: 4px;
  overflow: hidden;
}
.progress__fill {
  height: 100%;
  width: 0%;
  background: var(--accent);
  transition: width 120ms;
}
.progress__text {
  margin-top: var(--s-2);
  font-size: var(--t-xs);
}
.progress__errors {
  font-size: var(--t-xs);
  margin-top: var(--s-2);
  color: var(--ink-mid);
}

/* ==========================================================
   SUBSCRIBE: tier picker row + annual/monthly toggle
========================================================== */
.tier-interval {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-4);
}
.tier-interval__toggle {
  display: inline-flex;
  gap: var(--s-2);
}

/* ==========================================================
   API KEYS: masked key preview
========================================================== */
.api-key-mask {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-mid);
}

/* ==========================================================
   SETTINGS: narrow forms + destructive-zone lede
========================================================== */
.settings-lede {
  font-size: var(--t-sm);
  color: var(--ink-mid);
}

/* ==========================================================
   VOLUME CHART: search-queries page glance.
   Driven off the same window + source filters as the tables;
   compact, always-on, no chart library.
========================================================== */
.volume-chart {
  margin: 0 0 var(--s-5) 0;
  position: relative;
}
.volume-chart:empty { display: none; }
.volume-chart__skeleton {
  height: 8.5rem;
  background: var(--paper-deep);
  border: 1px solid var(--rule-soft);
  border-radius: 0.5rem;
}
.volume-chart__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  margin-bottom: var(--s-2);
}
.volume-chart__title {
  font-size: var(--t-sm);
  color: var(--ink);
  font-weight: 500;
}
.volume-chart__meta {
  font-size: var(--t-xs);
  color: var(--ink-mid);
}
.volume-chart__bars {
  display: grid;
  grid-template-columns: repeat(var(--bar-count, 7), minmax(0, 1fr));
  gap: 0.125rem;
  height: 7rem;
  padding: 0.5rem 0 0;
  border-top: 1px dashed var(--rule-soft);
  border-bottom: 1px solid var(--rule-soft);
  align-items: end;
}
/* Dense series (hourly over a week) get a tighter gap so the bars read as
   a continuous curve rather than isolated ticks. */
.volume-chart__bars:has(> :nth-child(80)) { gap: 0.0625rem; }
.volume-chart__col {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100%;
  min-width: 0;
  /* Let tick labels center over the column and spill outside it; the
     grid track is much narrower than the label text on dense series. */
  overflow: visible;
}
.volume-chart__bar-wrap {
  flex: 1 1 auto;
  display: flex;
  align-items: flex-end;
  min-height: 0;
  padding: 0 0.0625rem;
}
.volume-chart__bar {
  width: 100%;
  min-height: 0.125rem;
  background: var(--accent);
  border-radius: 0.125rem 0.125rem 0 0;
}
.volume-chart__col.is-empty .volume-chart__bar {
  min-height: 0.0625rem;
  background: var(--rule);
}
.volume-chart__col:hover .volume-chart__bar,
.volume-chart__col.is-active .volume-chart__bar {
  background: var(--accent-deep, var(--accent));
}
.volume-chart__col.is-active.is-empty .volume-chart__bar { background: var(--ink-mid); }

.volume-chart__tooltip {
  position: absolute;
  transform: translateX(-50%);
  background: var(--ink);
  color: var(--paper);
  padding: 0.375rem 0.625rem;
  border-radius: 0.25rem;
  font-size: 0.75rem;
  line-height: 1.2;
  pointer-events: none;
  white-space: nowrap;
  box-shadow: 0 0.25rem 0.75rem rgba(23, 20, 14, 0.18);
  z-index: 5;
}
.volume-chart__tooltip[hidden] { display: none; }
.volume-chart__tooltip::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: -0.3125rem;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 0.3125rem solid transparent;
  border-right: 0.3125rem solid transparent;
  border-top: 0.3125rem solid var(--ink);
}
.volume-chart__tooltip-count {
  font-weight: 500;
  font-size: 0.8125rem;
}
.volume-chart__tooltip-when {
  color: rgba(238, 229, 206, 0.7);
  margin-top: 0.125rem;
}
.volume-chart__tick {
  font-size: 0.6875rem;
  color: var(--ink-mid);
  margin-top: 0.375rem;
  min-height: 1rem;
  position: relative;
  line-height: 1;
}
.volume-chart__tick > span {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  white-space: nowrap;
}

/* ==========================================================
   ANIMATIONS
========================================================== */
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes toastIn {
  from { opacity: 0; transform: translateX(0.5rem); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ==========================================================
   MOBILE SAFETY NET
   Not a mobile-first redesign. Goal: the dashboard doesn't
   break on a phone. Nav is still reachable, tables scroll
   horizontally within their card instead of bursting the
   viewport, and dense surfaces stack cleanly.

   Anything that demands more than a phone screen (admin
   console, dense forms) is still best on desktop.
========================================================== */
@media (max-width: 51.25em) {
  /* Header: email can wrap, sign-out stays usable, tighter padding. */
  .app__header {
    padding: var(--s-3) var(--s-4);
    gap: var(--s-3);
    flex-wrap: wrap;
  }
  .app__user {
    font-size: var(--t-2xs);
    gap: var(--s-3);
    letter-spacing: 0.08em;
    min-width: 0;
  }
  .app__user > span {
    max-width: 14ch;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  /* Sidebar: instead of disappearing at the mobile breakpoint (which
     stranded users without nav), reshape it into a horizontal-scroll
     strip under the header. No JS, no hamburger. Non-sticky on mobile
     since the header is already sticky and stacking them eats too
     much viewport. */
  .app__body { grid-template-columns: 1fr; }
  .app__sidebar {
    display: block;
    position: static;
    background: var(--paper);
    border-right: 0;
    border-bottom: 1px solid var(--rule);
    padding: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .app__sidebar ul {
    flex-direction: row;
    gap: 0;
    width: max-content;
    min-width: 100%;
    padding: 0 var(--s-3);
  }
  .app__sidebar a {
    border-left: 0;
    border-bottom: 2px solid transparent;
    padding: var(--s-3) var(--s-3);
    white-space: nowrap;
    font-size: var(--t-2xs);
  }
  .app__sidebar a.is-active {
    border-left: 0;
    border-bottom-color: var(--accent);
    background: transparent;
  }

  /* Main column: tighter gutter so dense tables have more room. */
  .app__main {
    padding: var(--s-5) var(--s-4);
  }

  /* Tables inside panels overflow on mobile. The panel becomes a
     horizontal scroll container so the rest of the page stays
     viewport-wide. :has() support is >95% across browsers in 2026. */
  .panel {
    padding: var(--s-4);
  }
  .panel:has(.tbl) {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Hint at scrollability with a minimum width so the table doesn't
     artificially squish. */
  .panel:has(.tbl) .tbl {
    min-width: 36rem;
  }

  /* Panel heads can have a title + action button that's too wide. */
  .panel__head {
    flex-wrap: wrap;
    row-gap: var(--s-2);
  }

  /* Two-col item form already has its own stack rule (1052). The
     import grid (888) and format-help (978) already collapse.
     meter-cards (200) and stat strip (750) auto-fit to 1 column. */
}

/* Very narrow phones: tighter still. */
@media (max-width: 30em) {
  .app__main { padding: var(--s-4) var(--s-3); }
  .app__header { padding: var(--s-2) var(--s-3); }
  .panel { padding: var(--s-3); }
  .app__user > span { max-width: 10ch; }
}

/* ==========================================================
   INTELLIGENCE: feature-card grid + drill-in surfaces
========================================================== */

.intel-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
  gap: var(--s-4);
}

.intel-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  padding: var(--s-5);
  text-decoration: none;
  color: inherit;
  transition: border-color 120ms ease, transform 120ms ease, box-shadow 120ms ease;
  min-height: 11rem;
}
.intel-card:hover {
  border-color: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.04);
}

.intel-card__title {
  font-family: var(--font-display);
  font-size: var(--t-xl);
  font-variation-settings: "opsz" 48, "SOFT" 60;
  font-weight: 420;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.intel-card__lede {
  font-size: var(--t-sm);
  color: var(--ink-mid);
  margin: 0;
  line-height: 1.45;
}
.intel-card__signal {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.intel-card__count {
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  color: var(--ink);
}
.intel-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}
.intel-chip {
  display: inline-block;
  padding: 0.2em 0.65em;
  background: var(--paper-sunk, rgba(0,0,0,0.04));
  border: 1px solid var(--rule-soft);
  font-size: var(--t-xs);
  color: var(--ink-mid);
  white-space: nowrap;
  max-width: 18rem;
  overflow: hidden;
  text-overflow: ellipsis;
}
.intel-chip--gap {
  border-color: var(--accent);
  color: var(--accent-deep);
}
.intel-card__when {
  font-size: var(--t-xs);
  color: var(--ink-mid);
}

/* Empty / standing-by state on a card's signal slot. Italic display
   font with a small accent dot reads as intentional, like an editorial
   pull quote, instead of the plain "no data" sans line. */
.intel-card__empty {
  display: flex;
  align-items: baseline;
  gap: var(--s-2);
  font-family: var(--font-display);
  font-style: italic;
  font-variation-settings: "opsz" 48, "SOFT" 60;
  font-weight: 380;
  font-size: var(--t-md);
  line-height: 1.35;
  color: var(--ink-mid);
  letter-spacing: -0.005em;
}
.intel-card__empty::before {
  content: "";
  flex-shrink: 0;
  width: 0.35rem;
  height: 0.35rem;
  border-radius: 50%;
  background: var(--accent);
  transform: translateY(-0.15em);
}
.intel-card__empty--error {
  color: var(--accent-deep);
}
.intel-card__empty--error::before { background: var(--accent-deep); }
.intel-card__arrow {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  font-size: var(--t-lg);
  color: var(--ink-mid);
}
.intel-card:hover .intel-card__arrow { color: var(--accent); }

/* Cluster list rows: shared across demand and catalog views. */
.intel-cluster {
  padding: var(--s-4);
  border-bottom: 1px solid var(--rule-soft);
}
.intel-cluster:last-child { border-bottom: 0; }
.intel-cluster__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.intel-cluster__name {
  font-family: var(--font-display);
  font-size: var(--t-lg);
  font-weight: 460;
}
.intel-cluster__meta {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-mid);
}
.intel-cluster__desc {
  margin-top: var(--s-2);
  font-size: var(--t-sm);
  color: var(--ink-mid);
  line-height: 1.5;
}
.intel-cluster__archetypes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-3);
}

/* Gap narrative block. */
.intel-gap {
  padding: var(--s-4);
  border-bottom: 1px solid var(--rule-soft);
}
.intel-gap:last-child { border-bottom: 0; }
.intel-gap__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  flex-wrap: wrap;
}
.intel-gap__name {
  font-family: var(--font-display);
  font-size: var(--t-lg);
  font-weight: 460;
}
.intel-gap__score {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-mid);
}
.intel-gap__narrative {
  margin-top: var(--s-2);
  font-size: var(--t-sm);
  color: var(--ink);
  line-height: 1.55;
}
.intel-gap__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-top: var(--s-3);
  font-size: var(--t-xs);
  color: var(--ink-mid);
}

.intel-trend {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.04em;
}

/* Toggle switch, used on the billing panel for intelligence overage. */
.switch {
  position: relative;
  display: inline-block;
  width: 2.6rem;
  height: 1.4rem;
  vertical-align: middle;
  cursor: pointer;
}
.switch input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.switch__track {
  position: absolute;
  inset: 0;
  background: var(--rule-soft);
  border: 1px solid var(--rule);
  transition: background var(--dur-1);
  border-radius: 999px;
}
.switch__track::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: calc(1.4rem - 6px);
  height: calc(1.4rem - 6px);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 999px;
  transition: transform var(--dur-1);
}
.switch input:checked + .switch__track {
  background: var(--accent);
  border-color: var(--accent);
}
.switch input:checked + .switch__track::after {
  transform: translateX(1.2rem);
  border-color: var(--accent-deep);
}
.intel-trend--rising  { color: var(--accent-deep); }
.intel-trend--cooling { color: var(--ink-mid); }

/* ==========================================================
   INTELLIGENCE: Map canvas
========================================================== */

.intel-map-frame {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  overflow: hidden;
}
.intel-map-frame canvas {
  display: block;
  width: 100%;
  cursor: default;
}
.intel-map-tooltip {
  position: absolute;
  pointer-events: none;
  background: var(--paper);
  border: 1px solid var(--rule-soft);
  padding: var(--s-3);
  max-width: 20rem;
  box-shadow: 0 4px 14px rgba(0,0,0,0.08);
  z-index: 2;
}
.intel-map-tooltip__name {
  font-family: var(--font-display);
  font-size: var(--t-md);
  font-weight: 500;
  color: var(--ink);
}
.intel-map-tooltip__meta {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-mid);
  margin-top: 0.15rem;
}
.intel-map-tooltip__desc {
  margin-top: var(--s-2);
  font-size: var(--t-xs);
  color: var(--ink-mid);
  line-height: 1.45;
}

/* Positioning form/result layout. */
.intel-positioning-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--s-5);
}
@media (max-width: 56em) {
  .intel-positioning-layout { grid-template-columns: 1fr; }
}
.intel-positioning__section {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-mid);
  margin: var(--s-4) 0 var(--s-2);
}
.intel-positioning__narrative {
  font-size: var(--t-sm);
  line-height: 1.55;
  color: var(--ink);
}
.intel-density {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-2);
  font-size: var(--t-sm);
}
.intel-density__bar {
  flex: 1;
  height: 6px;
  background: var(--rule-soft);
  overflow: hidden;
}
.intel-density__fill {
  height: 100%;
  background: var(--accent);
}

/* Positioning form actions row + recent list. */
.intel-form__actions {
  margin-top: var(--s-4);
  display: flex;
  justify-content: flex-end;
}
#pos-form .field + .field { margin-top: var(--s-4); }

.intel-recent {
  display: flex;
  flex-direction: column;
}
.intel-recent__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  padding: var(--s-2) 0;
  border-bottom: 1px dashed var(--rule-soft);
  text-decoration: none;
  color: inherit;
}
.intel-recent__row:last-child { border-bottom: 0; }
.intel-recent__row:hover .intel-recent__title { color: var(--accent-deep); }
.intel-recent__row.is-active .intel-recent__title { color: var(--accent-deep); font-weight: 500; }
.intel-recent__title {
  font-size: var(--t-sm);
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.intel-recent__when {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--ink-mid);
  white-space: nowrap;
}

/* Refresh-in-progress banner on drill-in pages. */
.intel-refreshing {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: rgba(178,71,24,0.06);
  border: 1px solid var(--accent);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.05em;
  color: var(--accent-deep);
  margin-bottom: var(--s-4);
}
.intel-spinner {
  width: 0.75rem;
  height: 0.75rem;
  border: 1.5px solid var(--rule-soft);
  border-top-color: var(--accent-deep);
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
  flex-shrink: 0;
}

/* Informational callout shared across pages. */
.intel-callout {
  padding: var(--s-3) var(--s-4);
  border-left: 2px solid var(--accent);
  background: rgba(178,71,24,0.03);
  font-size: var(--t-sm);
  color: var(--ink-mid);
  margin-bottom: var(--s-4);
}


