/* =========================================================
   GageLog — unified design system
   Sky-azure palette: light-blue primary, deep-azure accents,
   cool neutrals.
   ========================================================= */

:root {
  --bg:          #F5F9FC;
  --surface:     #FFFFFF;
  --border:      #D4DCE5;
  --text:        #1B2A38;
  --muted:       #5A6A78;
  --brand:       #3FA9D6;
  --brand-dark:  #1F6FA1;
  --teal:        #5EC3E8;
  --teal-dark:   #2E8FBF;
  --teal-wash:   #E8F4FB;
  --earth:       #8B7355;
  --success:     #4A7C59;
  --danger:      #8B3A3A;
  --danger-bg:   #FDF2F2;
  --info-bg:     #E8F4FB;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
[hidden] { display: none !important; }

html { font-size: 15px; }

body {
  font-family: system-ui, -apple-system, 'Segoe UI', sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.55;
}

a { color: var(--teal); text-decoration: none; }
a:hover { color: var(--teal-dark); text-decoration: underline; }

h1, h2, h3, h4, h5 { font-weight: 600; color: var(--brand-dark); line-height: 1.25; }
h4 { font-size: 1.2rem; }

/* ── Nav ───────────────────────────────────────────────── */

.site-nav {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 0 1.5rem;
  height: 52px;
  background: var(--brand);
  color: #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.15);
}

.site-nav__brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: -.2px;
  color: #fff;
  margin-right: auto;
  text-decoration: none;
}

.site-nav__brand img {
  height: 24px;
  width: auto;
  border-radius: 4px;
}

.site-nav__link {
  color: rgba(255,255,255,.85);
  font-size: 0.875rem;
  text-decoration: none;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  transition: background .15s;
}
.site-nav__link:hover { color: #fff; background: rgba(255,255,255,.12); text-decoration: none; }

.site-nav__user {
  font-size: 0.8125rem;
  opacity: .75;
}

.site-nav__logout {
  display: flex;
}
.site-nav__logout button {
  background: transparent;
  border: 1px solid rgba(255,255,255,.4);
  color: rgba(255,255,255,.9);
  padding: 0.2rem 0.7rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.8125rem;
  transition: background .15s, border-color .15s;
}
.site-nav__logout button:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.65);
}

/* ── Layout ─────────────────────────────────────────────── */

.site-main {
  padding: 1.75rem 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
}

/* Onboarding / form pages — centered card */
.rw-card {
  max-width: 600px;
  margin: 2.5rem auto;
  background: var(--surface);
  border-radius: 10px;
  box-shadow: 0 2px 16px rgba(31,111,161,.08);
  padding: 2.25rem 2.5rem;
}

.rw-logo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--brand);
  margin-bottom: 0.25rem;
  letter-spacing: -.2px;
}
.rw-logo img { height: 30px; width: auto; }

/* Step indicator */
.rw-step {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8125rem;
  color: var(--muted);
  margin-bottom: 1.75rem;
  flex-wrap: wrap;
}

.step-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  font-size: 0.75rem;
  font-weight: 700;
  margin-right: 0.2rem;
  flex-shrink: 0;
}
.step-dot.active   { background: var(--teal);    color: #fff; }
.step-dot.done     { background: var(--success);  color: #fff; }
.step-dot.upcoming { background: var(--border);   color: var(--muted); }

.rw-step__sep { color: var(--border); margin: 0 0.15rem; }

/* ── Buttons ─────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  padding: 0.5rem 1.1rem;
  border-radius: 5px;
  border: 1.5px solid transparent;
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s, border-color .15s, color .15s, box-shadow .15s;
  white-space: nowrap;
}

.btn--primary {
  background: var(--teal);
  color: #fff;
  border-color: var(--teal);
}
.btn--primary:hover {
  background: var(--teal-dark);
  border-color: var(--teal-dark);
  color: #fff;
  text-decoration: none;
}

.btn--secondary {
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
}
.btn--secondary:hover {
  background: var(--brand-dark);
  border-color: var(--brand-dark);
  color: #fff;
  text-decoration: none;
}

.btn--outline {
  background: transparent;
  color: var(--brand);
  border-color: var(--border);
}
.btn--outline:hover {
  background: var(--bg);
  border-color: var(--brand);
  color: var(--brand);
  text-decoration: none;
}

.btn--ghost {
  background: transparent;
  color: var(--muted);
  border-color: transparent;
}
.btn--ghost:hover { color: var(--text); background: var(--bg); text-decoration: none; }

.btn--sm { padding: 0.3rem 0.8rem; font-size: 0.8125rem; }
.btn--full { width: 100%; }

/* ── Forms ────────────────────────────────────────────────── */

.field { margin-bottom: 1rem; }
.field label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--brand-dark);
  margin-bottom: 0.3rem;
}
.field input,
.field select,
.field textarea {
  width: 100%;
  padding: 0.45rem 0.75rem;
  border: 1.5px solid var(--border);
  border-radius: 5px;
  font-size: 0.875rem;
  color: var(--text);
  background: var(--surface);
  transition: border-color .15s, box-shadow .15s;
}
.field input:focus,
.field select:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(94,195,232,.15);
}
.field input.error { border-color: var(--danger); }
.field-error {
  font-size: 0.8rem;
  color: var(--danger);
  margin-top: 0.25rem;
}
.field-help {
  font-size: 0.8rem;
  color: var(--muted);
  margin-top: 0.2rem;
}

/* ── Alerts ───────────────────────────────────────────────── */

.alert {
  padding: 0.7rem 1rem;
  border-radius: 5px;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  border-left: 3px solid;
}
.alert--error   { background: var(--danger-bg); color: var(--danger);  border-color: var(--danger);  }
.alert--info    { background: var(--info-bg);   color: var(--teal-dark); border-color: var(--teal); }
.alert--success { background: #EFF7F1; color: var(--success); border-color: var(--success); }

/* ── Badges ───────────────────────────────────────────────── */

.badge {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 600;
}
.badge--free    { background: #EFF7F1; color: var(--success); }
.badge--plan    { background: var(--teal-wash); color: var(--teal-dark); }
.badge--current { background: var(--brand); color: #fff; }

/* ── Plan cards ───────────────────────────────────────────── */

.plan-cards { display: flex; flex-direction: column; gap: 0.75rem; margin-bottom: 1.25rem; }

.plan-card {
  display: block;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  padding: 1rem 1.15rem;
  cursor: pointer;
  transition: border-color .15s, background .15s, box-shadow .15s;
  user-select: none;
}
.plan-card:hover { border-color: var(--teal); background: var(--teal-wash); }
.plan-card.selected {
  border-color: var(--teal);
  background: var(--teal-wash);
  box-shadow: 0 0 0 2px rgba(94,195,232,.25);
}
.plan-card.current-plan { border-color: var(--brand); }

.plan-card__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
}
.plan-card__name { font-weight: 600; font-size: 0.9375rem; color: var(--brand-dark); }
.plan-card__meta { font-size: 0.8rem; color: var(--muted); margin-top: 0.15rem; }
.plan-card__price { text-align: right; font-weight: 600; font-size: 0.9375rem; flex-shrink: 0; }
.plan-card__interval { font-size: 0.75rem; color: var(--muted); font-weight: 400; }

/* ── Sensor cards ─────────────────────────────────────────── */

.sensor-cards { display: flex; flex-direction: column; gap: 0.6rem; margin-bottom: 1.25rem; }

.sensor-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  padding: 0.85rem 1.1rem;
  cursor: pointer;
  transition: border-color .15s, background .15s, box-shadow .15s;
  user-select: none;
}
.sensor-card:hover { border-color: var(--teal); background: var(--teal-wash); }
.sensor-card.selected {
  border-color: var(--teal);
  background: var(--teal-wash);
  box-shadow: 0 0 0 2px rgba(94,195,232,.2);
}
.sensor-card__name  { font-weight: 600; font-size: 0.875rem; }
.sensor-card__meta  { font-size: 0.8rem; color: var(--muted); margin-top: 0.1rem; }
.sensor-card__actions { display: flex; gap: 0.5rem; align-items: center; flex-shrink: 0; }
.sensor-card__check { display: none; }

/* ── Login card ───────────────────────────────────────────── */

.login-card {
  max-width: 360px;
  margin: 5rem auto;
  background: var(--surface);
  border-radius: 10px;
  padding: 2.25rem;
  box-shadow: 0 2px 16px rgba(31,111,161,.1);
}
.login-card__logo {
  display: flex;
  justify-content: center;
  margin-bottom: 1.75rem;
}
.login-card__logo img { height: 64px; width: auto; }
.login-card h1 { font-size: 1.2rem; margin-bottom: 1.25rem; }

/* ── Controls (gauge page) ────────────────────────────────── */

.controls {
  display: flex;
  gap: 1rem;
  align-items: flex-end;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}
.controls__field { display: flex; flex-direction: column; gap: 0.25rem; }
.controls__field span {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.controls__field input,
.controls__field select {
  padding: 0.4rem 0.65rem;
  border: 1.5px solid var(--border);
  border-radius: 5px;
  background: var(--surface);
  font-size: 0.875rem;
  color: var(--text);
}
.controls__field input:focus,
.controls__field select:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(94,195,232,.15);
}

/* ── Sensor tabs ──────────────────────────────────────────── */

.sensor-tabs {
  display: flex;
  gap: 0.2rem;
  flex-wrap: wrap;
  border-bottom: 2px solid var(--border);
  margin-bottom: 0;
}

.sensor-tab {
  padding: 0.5rem 1rem;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 0.875rem;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  color: var(--muted);
  border-radius: 4px 4px 0 0;
  transition: color .15s, background .15s;
}
.sensor-tab:hover { background: var(--bg); color: var(--brand); }
.sensor-tab.active {
  border-bottom-color: var(--teal);
  color: var(--teal-dark);
  font-weight: 600;
  background: var(--surface);
}

/* ── View tabs ────────────────────────────────────────────── */

.view-tabs {
  display: flex;
  gap: 0.25rem;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-top: none;
  padding: 0.45rem 0.75rem;
  border-bottom: none;
}

.view-tab {
  padding: 0.3rem 0.85rem;
  border: 1.5px solid transparent;
  background: transparent;
  cursor: pointer;
  font-size: 0.8125rem;
  border-radius: 4px;
  color: var(--muted);
  transition: background .15s, color .15s;
}
.view-tab:hover { background: var(--bg); color: var(--text); }
.view-tab.active {
  background: var(--teal);
  color: #fff;
  border-color: var(--teal);
}

/* ── Gauge table ──────────────────────────────────────────── */

.table-meta {
  padding: 0.55rem 1rem;
  background: var(--bg);
  border: 1.5px solid var(--border);
  border-bottom: none;
  font-size: 0.8rem;
  color: var(--muted);
}

.table-header {
  display: flex;
  gap: 1rem;
  margin-bottom: 0.75rem;
  align-items: flex-start;
}
.table-header__meta { flex: 1; min-width: 0; }
.table-header__label {
  font-weight: 600;
  font-size: 1rem;
  color: var(--brand-dark);
  margin-bottom: 0.4rem;
}
.table-header__dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.15rem 0.6rem;
  font-size: 0.8rem;
  color: var(--muted);
  margin: 0;
}
.table-header__dl dt { font-weight: 600; color: var(--text); }
.table-header__map {
  flex-shrink: 0;
  width: 220px;
  height: 140px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
}
.table-header__map iframe {
  width: 100%;
  height: 100%;
  border: none;
}
@media (max-width: 600px) {
  .table-header { flex-direction: column; }
  .table-header__map { width: 100%; height: 120px; }
}

.live-frame {
  margin-top: 1rem;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.live-frame__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.6rem 1rem;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  font-size: 0.85rem;
  color: var(--muted);
}
.live-frame__embed {
  display: block;
  width: 100%;
  height: 600px;
  border: none;
}
.live-frame__note {
  padding: 0.5rem 1rem;
  font-size: 0.75rem;
  color: var(--muted);
  background: var(--surface);
  border-top: 1px solid var(--border);
  margin: 0;
}

.table-wrap { overflow-x: auto; }

.gauge-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--surface);
  border: 1.5px solid var(--border);
  font-size: 0.875rem;
}
.gauge-table th {
  padding: 0.55rem 1rem;
  text-align: left;
  background: var(--bg);
  font-weight: 600;
  color: var(--brand-dark);
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
  user-select: none;
  font-size: 0.8125rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.gauge-table th.sortable { cursor: pointer; }
.gauge-table th.sortable:hover { background: #E2EAF1; }
.gauge-table th.sort-asc  .sort-indicator::after { content: " ↑"; color: var(--teal); }
.gauge-table th.sort-desc .sort-indicator::after { content: " ↓"; color: var(--teal); }
.gauge-table td {
  padding: 0.45rem 1rem;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.gauge-table tr:last-child td { border-bottom: none; }
.gauge-table tr:hover td { background: #F6F9FB; }
.gauge-table .flagged-yes { color: var(--danger);  font-weight: 600; }
.gauge-table .flagged-no  { color: var(--success); }

.table-loading { text-align: center; padding: 2.5rem; color: var(--muted); font-style: italic; }
.table-empty   { text-align: center; padding: 2.5rem; color: var(--muted); }

/* ── Pagination ───────────────────────────────────────────── */

.pagination {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.65rem 1rem;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-top: none;
  font-size: 0.8125rem;
  color: var(--muted);
}
.pagination button {
  padding: 0.28rem 0.7rem;
  border: 1.5px solid var(--border);
  background: var(--surface);
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.8125rem;
  color: var(--text);
  transition: background .15s, border-color .15s;
}
.pagination button:hover:not(:disabled) {
  background: var(--bg);
  border-color: var(--teal);
  color: var(--teal-dark);
}
.pagination button:disabled { opacity: .4; cursor: default; }

/* ── Analytics view ───────────────────────────────────────── */

.analytics-toolbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.55rem 1rem;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-top: none;
}

.rolling-ctrl {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8125rem;
  color: var(--muted);
}
.rolling-ctrl span:first-child {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--muted);
}
.rolling-ctrl input {
  width: 52px;
  padding: 0.2rem 0.4rem;
  border: 1.5px solid var(--border);
  border-radius: 4px;
  font-size: 0.8125rem;
  text-align: center;
  background: var(--surface);
  color: var(--text);
}
.rolling-ctrl input:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 2px rgba(94,195,232,.15);
}

/* Stats cards */
.stats-cards {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border: 1.5px solid var(--border);
  border-top: none;
}
@media (max-width: 640px) {
  .stats-cards { grid-template-columns: repeat(3, 1fr); }
}

.stat-card {
  padding: 0.7rem 1rem;
  background: var(--surface);
  border-right: 1.5px solid var(--border);
  border-bottom: 1.5px solid var(--border);
}
.stat-card:last-child { border-right: none; }

.stat-card__label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--muted);
  margin-bottom: 0.15rem;
}
.stat-card__value {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--brand-dark);
  line-height: 1.1;
}
.stat-card--danger .stat-card__label { color: var(--danger); }
.stat-card--danger .stat-card__value { color: var(--danger); }

/* Loading + empty */
.analytics-loading {
  padding: 2.5rem;
  text-align: center;
  color: var(--muted);
  font-style: italic;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-top: none;
}

.analytics-empty {
  padding: 2.5rem;
  text-align: center;
  color: var(--muted);
  font-style: italic;
}

/* Chart layout */
#analytics-charts {
  border: 1.5px solid var(--border);
  border-top: none;
  background: var(--surface);
}

.chart-wrap {
  padding: 0.9rem 1rem 0.75rem;
}
.chart-wrap canvas { height: 200px !important; }
.chart-wrap--tall canvas { height: 280px !important; }

.chart-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1.5px solid var(--border);
}
.chart-row .chart-wrap:first-child { border-right: 1.5px solid var(--border); }

@media (max-width: 640px) {
  .chart-row { grid-template-columns: 1fr; }
  .chart-row .chart-wrap:first-child { border-right: none; border-bottom: 1.5px solid var(--border); }
}

.chart-title {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
  margin-bottom: 0.5rem;
}

/* Reading detail dialog */
dialog#reading-dialog {
  border: none;
  padding: 0;
  border-radius: 9px;
  box-shadow: 0 8px 40px rgba(27,42,56,.22);
  max-width: 420px;
  width: calc(100% - 2rem);
}
dialog#reading-dialog::backdrop { background: rgba(27,42,56,.45); }

.reading-dl { width: 100%; }
.reading-dl__row {
  display: flex;
  gap: 0.75rem;
  padding: 0.45rem 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.875rem;
  align-items: baseline;
}
.reading-dl__row--last { border-bottom: none; }
.reading-dl__divider {
  margin-top: 0.5rem;
  padding-top: 0.75rem;
  border-top: 2px solid var(--border);
}
.reading-dl__row dt {
  width: 80px;
  flex-shrink: 0;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--muted);
}
.reading-dl__row dd { color: var(--text); }

/* ── Gauge page wrapper ───────────────────────────────────── */

.gauge-page { display: flex; flex-direction: column; }

/* ── Period quick-picks + custom-dates disclosure ─────────── */

.period-picks {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}
.period-pick {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: .03em;
  padding: 0.4rem 0.85rem;
  border: 1.5px solid var(--border);
  background: var(--surface);
  color: var(--muted);
  border-radius: 6px;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.period-pick:hover { background: var(--bg); color: var(--text); }
.period-pick.active {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

.controls__custom {
  margin-top: 0.6rem;
  font-size: 0.85rem;
}
.controls__custom > summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 0.78rem;
  padding: 0.25rem 0;
  user-select: none;
}
.controls__custom > summary:hover { color: var(--text); }
.controls__custom-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.5rem;
}

/* ── Hero card (latest reading) ───────────────────────────── */

.hero-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-bottom: none;
  padding: 0.85rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.hero-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
}
.hero-card__label {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--muted);
}
.hero-card__updated { font-size: 0.72rem; color: var(--muted); }
.hero-card__body {
  display: flex;
  align-items: baseline;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.hero-card__primary { display: flex; align-items: baseline; gap: 0.5rem; }
.hero-card__value {
  font-size: 2.1rem;
  font-weight: 700;
  color: var(--brand-dark);
  line-height: 1;
}
.hero-card__unit { font-size: 0.95rem; color: var(--muted); font-weight: 600; }
.hero-card__delta {
  font-size: 0.85rem;
  font-weight: 600;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  margin-left: 0.4rem;
}
.hero-card__delta--up   { color: var(--teal-dark);  background: var(--teal-wash); }
.hero-card__delta--down { color: var(--earth);      background: #FAF4EB; }
.hero-card__delta--flat { color: var(--muted);      background: var(--bg); }

.hero-card__stage {
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
  padding-left: 1rem;
  border-left: 1.5px solid var(--border);
}
.hero-card__stage-label {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--muted);
  font-weight: 700;
}
.hero-card__stage-value { font-size: 1.15rem; font-weight: 700; color: var(--teal-dark); }
.hero-card__stage-unit  { font-size: 0.78rem; color: var(--muted); }

.hero-card__status {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  color: var(--text);
}
.hero-card__dot {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 50%;
  background: var(--muted);
  display: inline-block;
}
.hero-card__dot--low    { background: var(--earth); }
.hero-card__dot--normal { background: var(--success); }
.hero-card__dot--high   { background: var(--teal-dark); }

/* ── Insight cards strip ──────────────────────────────────── */

.insight-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.5rem;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-top: none;
  padding: 0.6rem;
}
.insight-card {
  padding: 0.55rem 0.75rem;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 0.85rem;
  color: var(--text);
  cursor: pointer;
  transition: background .12s, border-color .12s;
  /* Reset browser defaults so <button> variants match <div> visually */
  font-family: inherit;
  font-weight: 400;
  text-align: left;
  line-height: 1.45;
  appearance: none;
  width: 100%;
}
.insight-card:hover { background: var(--teal-wash); border-color: var(--teal); }
.insight-card:focus-visible {
  outline: 2px solid var(--teal);
  outline-offset: 2px;
}
.insight-card[data-no-target] { cursor: default; }
.insight-card[data-no-target]:hover { background: var(--bg); border-color: var(--border); }
.insight-card__strong { color: var(--brand-dark); font-weight: 700; }
.insight-card--warn { border-color: var(--danger); background: var(--danger-bg); }

/* ── Per-chart explainers ─────────────────────────────────── */

.chart-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  margin-bottom: 0.5rem;
}
.chart-explain {
  font-size: 0.74rem;
  color: var(--muted);
  max-width: 70%;
}
.chart-explain > summary {
  cursor: pointer;
  color: var(--teal-dark);
  font-weight: 600;
  list-style: none;
  user-select: none;
}
.chart-explain > summary::-webkit-details-marker { display: none; }
.chart-explain > summary::before {
  content: "ⓘ ";
  font-style: normal;
}
.chart-explain[open] > summary { color: var(--text); }
.chart-explain[open] {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 0.5rem 0.7rem;
  margin-top: 0.25rem;
  line-height: 1.45;
}

.chart-empty {
  padding: 1.25rem;
  text-align: center;
  color: var(--muted);
  font-style: italic;
  font-size: 0.85rem;
  background: var(--surface);
  border-top: 1.5px solid var(--border);
}

/* ── Empty state ──────────────────────────────────────────── */

.empty-state {
  padding: 3rem;
  text-align: center;
  color: var(--muted);
  background: var(--surface);
  border: 1.5px dashed var(--border);
  border-radius: 8px;
  font-size: 0.9375rem;
}

/* ── Modal (vanilla lightbox) ─────────────────────────────── */

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(27,42,56,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: 1rem;
}

.modal-box {
  background: var(--surface);
  border-radius: 9px;
  box-shadow: 0 8px 40px rgba(27,42,56,.2);
  width: 100%;
  max-width: 700px;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1.5px solid var(--border);
  flex-shrink: 0;
}
.modal-header h5 {
  font-size: 1rem;
  color: var(--brand-dark);
}

.modal-close {
  background: transparent;
  border: none;
  font-size: 1.3rem;
  line-height: 1;
  cursor: pointer;
  color: var(--muted);
  padding: 0.1rem 0.3rem;
  border-radius: 4px;
}
.modal-close:hover { background: var(--bg); color: var(--text); }

.modal-body {
  padding: 1.25rem;
  overflow-y: auto;
}

.modal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
}
.modal-table th {
  padding: 0.4rem 0.75rem;
  text-align: left;
  background: var(--bg);
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--brand-dark);
  border-bottom: 2px solid var(--border);
}
.modal-table td {
  padding: 0.35rem 0.75rem;
  border-bottom: 1px solid var(--border);
}
.modal-table tr:last-child td { border-bottom: none; }
.modal-table tr:hover td { background: #F6F9FB; }
.modal-spinner {
  text-align: center;
  padding: 2rem;
  color: var(--muted);
  font-style: italic;
}
.modal-error {
  padding: 0.7rem 1rem;
  background: var(--danger-bg);
  color: var(--danger);
  border-left: 3px solid var(--danger);
  border-radius: 4px;
  font-size: 0.875rem;
  margin-bottom: 0.75rem;
}

/* ── Sensor explorer (sensor_index) ───────────────────────── */

.explore-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.7rem 1rem;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.explore-summary__line {
  font-size: 0.9rem;
  color: var(--text);
}
.explore-summary__line strong { color: var(--brand-dark); }
.explore-summary__swap {
  color: var(--muted);
  margin-left: 0.35rem;
}
.explore-summary__swap strong { color: var(--teal-dark); }

.explore-card--selected {
  border-color: var(--teal);
  box-shadow: 0 0 0 1px var(--teal-wash) inset;
  background: linear-gradient(180deg, var(--teal-wash) 0%, var(--surface) 22%);
}
.explore-card__pill {
  display: inline-block;
  margin-left: 0.45rem;
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
  background: var(--teal-wash);
  color: var(--teal-dark);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: .02em;
  vertical-align: middle;
}
.explore-card__actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0.85rem;
  flex-wrap: wrap;
}
.explore-card__btn { font-size: 0.78rem; }

.card-map {
  margin: 0.75rem 0 0;
  border-radius: 5px;
  overflow: hidden;
  height: 90px;
  border: 1px solid var(--border);
  background: #EEF3F6;
}

/* Swap dialog */
.swap-dialog {
  border: none;
  border-radius: 10px;
  padding: 0;
  width: 100%;
  max-width: 460px;
  box-shadow: 0 12px 48px rgba(27,42,56,.28);
}
.swap-dialog::backdrop { background: rgba(27,42,56,.45); }
.swap-dialog form { margin: 0; }
.swap-dialog__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  border-bottom: 1.5px solid var(--border);
}
.swap-dialog__head h3 { font-size: 1rem; color: var(--brand-dark); }
.swap-dialog__close {
  background: transparent;
  border: none;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
  color: var(--muted);
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
}
.swap-dialog__close:hover { background: var(--bg); color: var(--text); }
.swap-dialog__body { padding: 1rem 1.25rem; }
.swap-dialog__lede {
  font-size: 0.875rem;
  color: var(--muted);
  margin-bottom: 0.85rem;
  line-height: 1.45;
}
.swap-dialog__lede strong { color: var(--text); }
.swap-dialog__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  max-height: 260px;
  overflow-y: auto;
}
.swap-dialog__list li { margin: 0; }
.swap-dialog__list label {
  display: block;
  padding: 0.55rem 0.75rem 0.55rem 2.1rem;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  font-size: 0.875rem;
  transition: border-color .15s, background .15s;
}
.swap-dialog__list label:hover { border-color: var(--teal); background: var(--teal-wash); }
.swap-dialog__list label strong { display: block; color: var(--brand-dark); }
.swap-dialog__list label span {
  display: block;
  font-size: 0.75rem;
  color: var(--muted);
  margin-top: 0.1rem;
}
.swap-dialog__list input[type="radio"] {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  accent-color: var(--teal);
}
/* The markup is `<input>` followed by `<label>`, so the sibling selector
   covers all browsers. The `:has()` rule below is a progressive enhancement
   for callers that wrap `<input>` inside `<label>`; it's split into its own
   rule so unsupporting browsers don't drop the sibling rule along with it. */
.swap-dialog__list input[type="radio"]:checked + label {
  border-color: var(--teal);
  background: var(--teal-wash);
  box-shadow: 0 0 0 2px rgba(94,195,232,.18);
}
.swap-dialog__list label:has(input:checked) {
  border-color: var(--teal);
  background: var(--teal-wash);
  box-shadow: 0 0 0 2px rgba(94,195,232,.18);
}
.swap-dialog__error {
  margin-top: 0.6rem;
  padding: 0.55rem 0.75rem;
  background: var(--danger-bg);
  color: var(--danger);
  border-left: 3px solid var(--danger);
  border-radius: 4px;
  font-size: 0.85rem;
}
.swap-dialog__foot {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 0.85rem 1.25rem;
  border-top: 1.5px solid var(--border);
  background: var(--bg);
}

.explore-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.explore-controls__input {
  flex: 1;
  padding: 0.55rem 0.85rem;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
  font-size: 0.9rem;
  font-family: inherit;
}
.explore-controls__input:focus {
  outline: none;
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(94,195,232,.15);
}
.explore-controls__count {
  font-size: 0.85rem;
  color: var(--muted);
  white-space: nowrap;
}

.explore-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

.explore-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 1rem 1.1rem;
  transition: border-color .15s, box-shadow .15s, transform .15s;
}
.explore-card:hover {
  border-color: var(--teal);
  box-shadow: 0 3px 14px rgba(31,111,161,.08);
  transform: translateY(-1px);
}
.explore-card__main {
  display: block;
  text-decoration: none;
  color: inherit;
}
.explore-card__main:hover { text-decoration: none; color: inherit; }
.explore-card__label {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--brand-dark);
  margin-bottom: 0.25rem;
  line-height: 1.3;
}
.explore-card__meta {
  font-size: 0.8rem;
  color: var(--muted);
  margin-bottom: 0.4rem;
}
.explore-card__org {
  font-size: 0.75rem;
  color: #7A8896;
}
.explore-card__cta {
  font-size: 0.78rem;
}

.explore-empty {
  padding: 2.5rem;
  text-align: center;
  color: var(--muted);
}

/* ── Home dashboard ───────────────────────────────────────── */

/* Hero */
.home-hero {
  position: relative;
  margin: -1.75rem -1.5rem 2rem;
  padding: 3.5rem 1.5rem 3rem;
  background:
    radial-gradient(ellipse at 12% 20%, rgba(94,195,232,.22), transparent 55%),
    radial-gradient(ellipse at 95% 90%, rgba(63,169,214,.35), transparent 55%),
    linear-gradient(135deg, var(--brand-dark) 0%, #2F88BC 60%, var(--brand) 100%);
  color: #fff;
  overflow: hidden;
}
.home-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0 0;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(255,255,255,.25), transparent);
}
.home-hero__inner {
  max-width: 880px;
  margin: 0 auto;
}
.home-hero__eyebrow {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-bottom: 0.85rem;
}
.home-hero__title {
  color: #fff;
  font-size: clamp(1.85rem, 3.5vw, 2.65rem);
  line-height: 1.1;
  letter-spacing: -.5px;
  margin-bottom: 0.6rem;
}
.home-hero__lede {
  color: rgba(255,255,255,.82);
  font-size: 1.05rem;
  margin-bottom: 1.6rem;
  max-width: 560px;
}
.home-hero__search {
  display: flex;
  gap: 0.5rem;
  background: rgba(255,255,255,.08);
  padding: 0.4rem;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  max-width: 640px;
  box-shadow: 0 6px 24px rgba(0,0,0,.18);
}
.home-hero__search-input {
  flex: 1;
  border: none;
  background: rgba(255,255,255,.95);
  color: var(--text);
  padding: 0.75rem 1rem;
  border-radius: 7px;
  font-size: 0.95rem;
  font-family: inherit;
}
.home-hero__search-input:focus {
  outline: none;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(94,195,232,.45);
}
.home-hero__search-btn { padding: 0.75rem 1.5rem; font-size: 0.9rem; }
.home-hero__meta {
  margin-top: 1.1rem;
  font-size: 0.85rem;
  color: rgba(255,255,255,.75);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.home-hero__link { color: #fff; font-weight: 600; }
.home-hero__link:hover { color: #fff; text-decoration: underline; }
.home-hero__dot { opacity: .5; }

/* Section frame */
.home-section { margin-bottom: 2.5rem; }
.home-section__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
.home-section__title {
  font-size: 1.1rem;
  letter-spacing: -.2px;
  color: var(--brand-dark);
}
.home-section__sub {
  font-size: 0.85rem;
  color: var(--muted);
  margin-top: 0.15rem;
}

/* Plan utilization meter */
.plan-meter {
  height: 6px;
  background: var(--border);
  border-radius: 3px;
  overflow: hidden;
  margin: 0 0 1rem;
  max-width: 320px;
}
.plan-meter__fill {
  height: 100%;
  background: linear-gradient(to right, var(--teal), var(--brand));
  border-radius: 3px;
  transition: width .3s ease;
}

/* My-sensor grid (overrides the legacy .sensor-card flex layout for this page) */
.home-sensor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 0.85rem;
}
.home-sensor-tile {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 1rem 1.1rem;
  text-decoration: none;
  color: inherit;
  transition: border-color .15s, box-shadow .15s, transform .15s;
}
.home-sensor-tile:hover {
  border-color: var(--teal);
  box-shadow: 0 4px 18px rgba(31,111,161,.08);
  transform: translateY(-1px);
  text-decoration: none;
  color: inherit;
}
.home-sensor-tile__label {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--brand-dark);
  margin-bottom: 0.3rem;
  line-height: 1.3;
}
.home-sensor-tile__meta {
  font-size: 0.8rem;
  color: var(--muted);
  margin-bottom: 0.15rem;
}
.home-sensor-tile__org {
  font-size: 0.75rem;
  color: #7A8896;
  margin-bottom: 0.85rem;
}
.home-sensor-tile__cta {
  margin-top: auto;
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}
.home-sensor-tile__chip {
  font-size: 0.72rem;
  font-weight: 600;
  padding: 0.22rem 0.55rem;
  border-radius: 999px;
  background: var(--bg);
  color: var(--muted);
  letter-spacing: .02em;
}
.home-sensor-tile__chip--accent {
  background: var(--teal-wash);
  color: var(--teal-dark);
}

/* Region / river groups */
.home-region-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1rem;
}
.home-region-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  padding: 1.1rem 1.25rem 0.9rem;
}
.home-region-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.6rem;
  padding-bottom: 0.55rem;
  border-bottom: 1px solid var(--border);
}
.home-region-card__title {
  font-size: 1rem;
  color: var(--brand-dark);
}
.home-region-card__count {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--teal-dark);
}
.home-river-list { list-style: none; padding: 0; margin: 0; }
.home-river-list li + li { margin-top: 0.15rem; }
.home-river-tile {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 0.65rem;
  border-radius: 6px;
  text-decoration: none;
  color: var(--text);
  font-size: 0.875rem;
  transition: background .12s, color .12s;
}
.home-river-tile:hover {
  background: var(--teal-wash);
  color: var(--teal-dark);
  text-decoration: none;
}
.home-river-tile__name { font-weight: 500; }
.home-river-tile__count {
  font-size: 0.78rem;
  color: var(--muted);
  background: var(--bg);
  padding: 0.1rem 0.5rem;
  border-radius: 999px;
}
.home-river-tile:hover .home-river-tile__count {
  background: #fff;
  color: var(--teal-dark);
}
.home-region-card__more {
  display: inline-block;
  margin-top: 0.55rem;
  font-size: 0.8rem;
  color: var(--muted);
}
.home-region-card__more:hover { color: var(--teal-dark); }

/* Single CTA card */
.home-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  padding: 1.4rem 1.6rem;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--teal-wash) 0%, #F5FAFB 100%);
  border: 1.5px solid #CCE5EB;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}
.home-cta__title {
  font-size: 1.05rem;
  color: var(--brand-dark);
  margin-bottom: 0.2rem;
}
.home-cta__lede {
  font-size: 0.875rem;
  color: var(--muted);
  max-width: 540px;
}
.home-cta__actions {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

/* Quiet utility row at the bottom of home */
.home-footer-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
  font-size: 0.8rem;
  color: var(--muted);
}
.home-footer-row__link {
  color: var(--muted);
  text-decoration: none;
}
.home-footer-row__link:hover { color: var(--brand-dark); text-decoration: underline; }
.home-footer-row__sep { opacity: .5; }

@media (max-width: 640px) {
  .home-hero { padding: 2.5rem 1.25rem 2.25rem; }
  .home-hero__search { flex-direction: column; padding: 0.5rem; }
  .home-hero__search-btn { width: 100%; }
  .home-cta { flex-direction: column; align-items: flex-start; }
}

/* ── Utility ──────────────────────────────────────────────── */

.text-muted { color: var(--muted); }
.text-center { text-align: center; }
.mt-1 { margin-top: 0.35rem; }
.mt-2 { margin-top: 0.75rem; }
.mt-3 { margin-top: 1.25rem; }
.mb-1 { margin-bottom: 0.35rem; }
.mb-2 { margin-bottom: 0.75rem; }
.mb-3 { margin-bottom: 1.25rem; }

/* ── Site footer (authenticated pages) ───────────────────── */

.site-footer {
  padding: 1rem 2rem;
  text-align: center;
  font-size: 0.8rem;
  color: var(--muted);
  border-top: 1px solid var(--border);
}
.site-footer a { color: var(--muted); text-decoration: none; }
.site-footer a:hover { color: var(--brand-dark); }
.site-footer__sep { margin: 0 0.4rem; }

/* ── Registration checkbox ────────────────────────────────── */

.field--check { margin-top: 0.5rem; }
.check-label {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  font-size: 0.875rem;
  color: var(--text);
  cursor: pointer;
  line-height: 1.5;
}
.check-label input[type="checkbox"] {
  flex-shrink: 0;
  margin-top: 0.2rem;
  accent-color: var(--brand);
}
.check-label a { color: var(--teal-dark); }

/* ── Tracked Gages tab strip ─────────────────────────────────────────────── */
.tracked-tabs {
  display: flex;
  gap: 0.5rem;
  border-bottom: 1.5px solid var(--border);
  margin-bottom: 1rem;
}
.tracked-tabs__tab {
  display: inline-block;
  padding: 0.55rem 1.1rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1.5px;
  transition: color .15s, border-color .15s;
}
.tracked-tabs__tab:hover {
  color: var(--text);
}
.tracked-tabs__tab--active {
  color: var(--brand);
  border-bottom-color: var(--brand);
}

/* ── Anomalies + Compare toolbar bits ────────────────────────────────────── */
.anom-summary {
  color: var(--muted);
  font-size: 0.85rem;
  margin-left: 0.5rem;
}
.compare-toolbar {
  flex-wrap: wrap;
  gap: 0.75rem;
}

/* ── Multi-state map on the Overview tab ─────────────────────────────────── */
.tracked-map {
  margin: 1.25rem 0;
}
.tracked-map__head {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.6rem;
  flex-wrap: wrap;
}
.tracked-map__title {
  font-size: 1rem;
  margin: 0;
  color: var(--text);
}
.tracked-map__hint {
  color: var(--muted);
  font-size: 0.8rem;
}
.tracked-map__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.85rem;
}
.tracked-map__state {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 6px;
  padding: 0.6rem 0.7rem 0.4rem;
}
.tracked-map__state-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.3rem;
  font-size: 0.85rem;
}
.tracked-map__count {
  color: var(--muted);
  font-size: 0.75rem;
}
.tracked-map__svg {
  display: block;
  width: 100%;
  height: auto;
}

/* ── Cross-gage compare section on Overview ──────────────────────────────── */
.cross-compare {
  margin: 1.5rem 0;
  padding: 1rem;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
}
.cross-compare__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.cross-compare__title {
  font-size: 1rem;
  margin: 0;
  color: var(--text);
}
.cross-compare__pick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 0.4rem;
  margin-bottom: 0.75rem;
}
.cross-compare__pick {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  color: var(--text);
  cursor: pointer;
}
.cross-compare__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: end;
}
