/* ============================================================
   HOCHZEITSPLANER — Styles
   Editorial romantic, warm cream + wine accent
   ============================================================ */

:root {
  --bg:           #f4ede0;
  --bg-deep:      #ebe1cf;
  --paper:        #fbf6ec;
  --paper-warm:   #f7efe0;
  --ink:          #1c1612;
  --ink-soft:     #5a4d40;
  --ink-mute:     #8a7c6d;
  --rule:         #e0d3bc;
  --rule-soft:    #ece2ce;

  --wine:         #7a2929;
  --wine-deep:    #5a1d1d;
  --wine-soft:    #a85656;
  --gold:         #b8924d;
  --gold-deep:    #8c6b30;
  --gold-soft:    #e8d9b6;
  --sage:         #5f7a64;
  --sage-soft:    #c5d2c4;
  --terra:        #c87454;
  --rose:         #e6cfca;

  --font-display: "Instrument Serif", "Cormorant Garamond", Georgia, serif;
  --font-body:    "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  font-feature-settings: "ss01", "cv11";
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  line-height: 1.45;
  min-height: 100vh;
}

/* ---------- TOP BAR ---------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244, 237, 224, 0.92);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule);
}
.topbar-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 14px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.brand {
  font-family: var(--font-display);
  font-size: 24px;
  letter-spacing: 0.01em;
  display: flex; align-items: baseline; gap: 10px;
  white-space: nowrap;
}
.brand .heart { color: var(--wine); font-size: 18px; transform: translateY(-1px); }
.brand-sub { font-family: var(--font-body); font-size: 11px; text-transform: uppercase; letter-spacing: 0.18em; color: var(--ink-mute); margin-left: 8px; }
@media (max-width: 800px) { .brand-sub { display: none; } }
.countdown-chip {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-soft);
  background: var(--paper-warm);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 8px 16px;
  white-space: nowrap;
}
.countdown-chip strong { color: var(--wine); font-weight: 600; }

/* ---------- TABS ---------- */
.tabs {
  display: flex; justify-content: center;
  gap: 4px;
  border-bottom: 1px solid var(--rule);
  background: var(--bg);
}
.tab {
  font-family: var(--font-body);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink-mute);
  padding: 18px 22px;
  cursor: pointer;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  transition: color 0.15s, border-color 0.15s;
  position: relative;
}
.tab:hover { color: var(--ink); }
.tab.active { color: var(--wine); border-bottom-color: var(--wine); }
.tab .count {
  display: inline-block;
  margin-left: 8px;
  font-size: 10px;
  background: var(--gold-soft);
  color: var(--gold-deep);
  padding: 2px 6px;
  border-radius: 999px;
  font-family: var(--font-mono);
  letter-spacing: 0;
  text-transform: none;
}

/* ---------- LAYOUT ---------- */
.page {
  max-width: 1320px;
  margin: 0 auto;
  padding: 48px 32px 96px;
}

/* ---------- HERO ---------- */
.hero {
  text-align: center;
  padding: 56px 0 64px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 48px;
}
.hero-eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--ink-mute);
  margin-bottom: 28px;
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(64px, 9vw, 132px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin: 0;
  font-weight: 400;
}
.hero-title em { font-style: italic; color: var(--wine); }
.hero-date {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.2em;
  color: var(--ink-soft);
  margin-top: 28px;
  display: flex; justify-content: center; gap: 18px; align-items: center;
}
.hero-date .dot { width: 4px; height: 4px; background: var(--wine); border-radius: 50%; }

.hero-countdown {
  margin-top: 48px;
  display: inline-grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--rule);
  background: var(--paper);
  border-radius: 4px;
  overflow: hidden;
}
.hero-countdown > div {
  padding: 22px 36px;
  border-right: 1px solid var(--rule);
  text-align: center;
}
.hero-countdown > div:last-child { border-right: none; }
.hero-countdown .num {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 1;
  color: var(--wine);
  font-weight: 400;
}
.hero-countdown .lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  margin-top: 8px;
}

/* ---------- SECTIONS ---------- */
.section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 32px;
  gap: 24px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--rule);
}
.section-title {
  font-family: var(--font-display);
  font-size: 44px;
  line-height: 1.05;
  margin: 0;
  font-weight: 400;
  letter-spacing: -0.01em;
}
.section-title em { font-style: italic; color: var(--wine); }
.section-sub {
  font-size: 13px;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.eyebrow {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  color: var(--ink-mute);
  font-weight: 600;
}

/* ---------- STAT GRID (overview) ---------- */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--rule);
  background: var(--paper);
  margin-bottom: 56px;
}
.stat {
  padding: 28px 28px 32px;
  border-right: 1px solid var(--rule);
  position: relative;
}
.stat:last-child { border-right: none; }
.stat .stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--ink-mute);
  margin-bottom: 18px;
}
.stat .stat-value {
  font-family: var(--font-display);
  font-size: 40px;
  line-height: 1;
  color: var(--ink);
  font-weight: 400;
  letter-spacing: -0.01em;
}
.stat .stat-value.wine { color: var(--wine); }
.stat .stat-value.sage { color: var(--sage); }
.stat .stat-value.gold { color: var(--gold-deep); }
.stat .stat-value.terra { color: var(--terra); }
.stat .stat-meta {
  margin-top: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-mute);
}
.stat .stat-progress {
  margin-top: 18px;
  height: 3px;
  background: var(--rule-soft);
  position: relative;
  overflow: hidden;
}
.stat .stat-progress > i {
  display: block;
  height: 100%;
  background: var(--wine);
}

/* ---------- TWO-COLUMN ---------- */
.two-col {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 48px;
  margin-bottom: 64px;
}
@media (max-width: 1000px) { .two-col { grid-template-columns: 1fr; } }

/* ---------- BUDGET BARS ---------- */
.cat-list {
  display: flex; flex-direction: column;
  gap: 0;
}
.cat-row {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  align-items: center;
  gap: 20px;
  padding: 18px 0;
  border-bottom: 1px solid var(--rule-soft);
}
.cat-row:last-child { border-bottom: none; }
.cat-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
}
.cat-bar {
  position: relative;
  height: 28px;
  background: var(--rule-soft);
  border-radius: 2px;
  overflow: hidden;
}
.cat-bar .fill-budget {
  position: absolute; inset: 0; right: auto;
  background: var(--rule);
}
.cat-bar .fill-paid {
  position: absolute; inset: 0; right: auto;
  background: linear-gradient(90deg, var(--wine), var(--wine-soft));
}
.cat-bar.over .fill-paid { background: linear-gradient(90deg, var(--terra), var(--terra)); }
.cat-bar.done .fill-paid { background: var(--sage); }
.cat-bar-label {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--paper);
  padding-left: 10px;
  letter-spacing: 0.04em;
  pointer-events: none;
  mix-blend-mode: difference;
  filter: invert(1);
}
.cat-amounts {
  text-align: right;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-soft);
  min-width: 220px;
}
.cat-amounts .num { color: var(--ink); font-weight: 500; }
.cat-amounts .sep { color: var(--ink-mute); padding: 0 6px; }

/* ---------- DONUT ---------- */
.donut-wrap {
  position: relative;
  display: flex; flex-direction: column;
  align-items: center;
  padding: 12px 0 24px;
}
.donut-svg { max-width: 100%; }
.donut-center {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -65%);
  text-align: center;
  pointer-events: none;
}
.donut-center .big {
  font-family: var(--font-display);
  font-size: 40px;
  line-height: 1;
  color: var(--ink);
}
.donut-center .sub {
  margin-top: 6px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
}
.donut-legend {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 18px;
  font-size: 12px;
  width: 100%;
  max-width: 360px;
}
.donut-legend-row {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
}
.donut-legend-row > .sw {
  width: 10px; height: 10px; border-radius: 2px;
}
.donut-legend-row > .nm {
  font-family: var(--font-body);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ---------- ROW TOTALS ---------- */
.totals {
  margin-top: 16px;
  padding-top: 18px;
  border-top: 2px solid var(--ink);
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: 20px;
  align-items: center;
}
.totals .lbl {
  font-family: var(--font-display);
  font-size: 22px;
}
.totals .nm {
  font-family: var(--font-mono);
  font-size: 13px;
  text-align: right;
  font-weight: 600;
}
.totals .delta-warn { color: var(--terra); }

/* ---------- ITINERARY ---------- */
.trip-overview {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 28px 32px;
  margin-bottom: 32px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.trip-stat .v {
  font-family: var(--font-display);
  font-size: 32px;
  line-height: 1;
}
.trip-stat .l {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  margin-top: 6px;
}

.region-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  color: var(--paper);
}
.region-tag.aus { background: var(--terra); }
.region-tag.nz  { background: var(--sage); }
.region-tag.transit { background: var(--ink-mute); }

.itin-list {
  display: flex; flex-direction: column;
  gap: 0;
}
.itin-row {
  display: grid;
  grid-template-columns: 90px 90px 1fr 1fr 200px;
  gap: 24px;
  padding: 20px 0;
  border-bottom: 1px solid var(--rule-soft);
  align-items: start;
}
.itin-row .day {
  font-family: var(--font-display);
  font-size: 32px;
  line-height: 1;
  color: var(--wine);
}
.itin-row .day-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  margin-top: 4px;
}
.itin-row .date {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-soft);
  letter-spacing: 0.06em;
  padding-top: 6px;
}
.itin-row .route {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.itin-row .activities {
  font-size: 13px;
  color: var(--ink-soft);
  padding-top: 4px;
}
.itin-row .meta {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-mute);
  display: flex; flex-direction: column;
  gap: 4px;
  text-align: right;
}
.itin-row .meta .stay {
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
}

/* ---------- SAVINGS CHART ---------- */
.savings-chart {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 32px;
  margin-bottom: 32px;
}
.savings-svg {
  width: 100%;
  height: 360px;
  display: block;
}

.savings-summary {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--rule);
  background: var(--paper);
}
.savings-summary .item {
  padding: 24px 28px;
  border-right: 1px solid var(--rule);
}
.savings-summary .item:last-child { border-right: none; }
.savings-summary .v {
  font-family: var(--font-display);
  font-size: 32px;
}
.savings-summary .l {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  margin-top: 4px;
}

/* ---------- DECO ---------- */
.deco-group {
  margin-bottom: 32px;
  border: 1px solid var(--rule);
  background: var(--paper);
}
.deco-group-head {
  padding: 18px 24px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  cursor: pointer;
  user-select: none;
  border-bottom: 1px solid transparent;
}
.deco-group.open .deco-group-head { border-bottom-color: var(--rule); }
.deco-group-head .name {
  font-family: var(--font-display);
  font-size: 28px;
}
.deco-group-head .totals-mini {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-soft);
}
.deco-group-head .totals-mini strong { color: var(--ink); font-weight: 600; }
.deco-rows {
  display: none;
  padding: 0 24px 16px;
}
.deco-group.open .deco-rows { display: block; }
.deco-row {
  display: grid;
  grid-template-columns: 1fr 110px 110px 18px;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid var(--rule-soft);
  font-size: 13px;
  align-items: center;
}
.deco-row:last-child { border-bottom: none; }
.deco-row .num {
  font-family: var(--font-mono);
  font-size: 12px;
  text-align: right;
  color: var(--ink-soft);
}
.deco-row .check {
  text-align: right;
  color: var(--sage);
  font-family: var(--font-mono);
}
.deco-row.done .item { color: var(--ink-mute); text-decoration: line-through; text-decoration-color: var(--rule); }

/* ---------- TIMELINE SPINE (overview cards) ---------- */
.cards-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 56px;
}
@media (max-width: 900px) { .cards-grid { grid-template-columns: 1fr; } }
.summary-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 32px;
}
.summary-card .ttl {
  font-family: var(--font-display);
  font-size: 28px;
  margin: 0 0 4px;
  letter-spacing: -0.01em;
}
.summary-card .sub {
  font-size: 12px;
  color: var(--ink-mute);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.summary-card .big {
  font-family: var(--font-display);
  font-size: 60px;
  line-height: 1;
  color: var(--wine);
  letter-spacing: -0.02em;
}
.summary-card .big small {
  font-size: 22px; color: var(--ink-mute);
  font-family: var(--font-body);
  margin-left: 6px;
}
.summary-card .barline {
  margin-top: 22px;
  height: 6px;
  background: var(--rule-soft);
  position: relative;
}
.summary-card .barline > i {
  position: absolute; inset: 0; right: auto;
  background: linear-gradient(90deg, var(--wine), var(--gold));
}
.summary-card .legend {
  margin-top: 16px;
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-mute);
}

/* ---------- FINE PRINT ---------- */
.footer-note {
  margin-top: 64px;
  padding-top: 32px;
  border-top: 1px solid var(--rule);
  font-size: 12px;
  color: var(--ink-mute);
  text-align: center;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
}
.footer-note .heart { color: var(--wine); }

/* ---------- ALERT ---------- */
.alert {
  margin: 24px 0;
  padding: 16px 20px;
  background: rgba(200, 116, 84, 0.1);
  border-left: 3px solid var(--terra);
  font-size: 13px;
  color: var(--ink);
}
.alert strong { color: var(--terra); }

/* ============================================================
   RESPONSIVE — Tablet & Mobile
   ============================================================ */

/* Tablet */
@media (max-width: 900px) {
  .topbar-inner { padding: 12px 20px; gap: 14px; }
  .brand { font-size: 22px; }
  .page { padding: 36px 24px 72px; }
  .hero-title { font-size: clamp(48px, 11vw, 96px); }
  .section-title { font-size: 36px; }
  .stat-grid { grid-template-columns: 1fr 1fr; }
  .stat { padding: 22px 22px 26px; }
  .stat:nth-child(2) { border-right: none; }
  .stat:nth-child(-n+2) { border-bottom: 1px solid var(--rule); }
  .trip-overview { grid-template-columns: 1fr 1fr; gap: 20px; padding: 24px; }
  .savings-summary { grid-template-columns: 1fr; }
  .savings-summary .item {
    border-right: none;
    border-bottom: 1px solid var(--rule);
  }
  .savings-summary .item:last-child { border-bottom: none; }

  /* TripMap: two map panels stack on tablet */
  .trip-map-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  .trip-map-head {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
  .trip-map-legend {
    flex-wrap: wrap !important;
    gap: 10px 16px !important;
  }

  /* Itinerary: 2-column layout */
  .itin-row {
    grid-template-columns: 90px 1fr;
    grid-template-areas:
      "day route"
      "date route"
      "day weather"
      "date meta";
    gap: 6px 20px;
    padding: 18px 0;
  }
  .itin-cell-day { grid-area: day; }
  .itin-cell-date { grid-area: date; padding-top: 4px; }
  .itin-cell-route { grid-area: route; }
  .itin-cell-route .route { font-size: 20px; }
  .itin-cell-weather { grid-area: weather; }
  .itin-cell-meta { grid-area: meta; text-align: left !important; }
}

/* Mobile */
@media (max-width: 640px) {
  /* Topbar */
  .topbar-inner { padding: 10px 14px; gap: 10px; }
  .brand { font-size: 18px; gap: 8px; }
  .brand .heart { font-size: 14px; }
  .countdown-chip { font-size: 10px; padding: 5px 10px; gap: 6px; }

  /* Tabs — horizontal scroll */
  .tabs {
    overflow-x: auto;
    overflow-y: hidden;
    justify-content: flex-start;
    flex-wrap: nowrap;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    padding: 0 4px;
  }
  .tabs::-webkit-scrollbar { display: none; }
  .tab {
    padding: 14px 12px;
    flex: 0 0 auto;
    font-size: 11px;
    letter-spacing: 0.1em;
    white-space: nowrap;
  }
  .tab .count { margin-left: 6px; font-size: 9px; padding: 1px 5px; }

  /* Page */
  .page { padding: 24px 14px 64px; }

  /* Hero */
  .hero { padding: 28px 0 32px; margin-bottom: 32px; }
  .hero-eyebrow { margin-bottom: 16px; font-size: 10px; letter-spacing: 0.22em; }
  .hero-title { font-size: clamp(40px, 13vw, 64px); letter-spacing: -0.01em; }
  .hero-date {
    font-size: 10px;
    gap: 10px;
    margin-top: 18px;
    flex-wrap: wrap;
  }
  .hero-countdown {
    margin-top: 24px;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    width: 100%;
  }
  .hero-countdown > div { padding: 14px 4px; }
  .hero-countdown .num { font-size: 26px; }
  .hero-countdown .lbl { font-size: 8px; letter-spacing: 0.12em; margin-top: 6px; }

  /* Sections */
  .section-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
    margin-bottom: 24px;
  }
  .section-title { font-size: 30px; }
  .section-sub { font-size: 12px; }

  /* Stat grid: 2x2 with reset borders */
  .stat-grid { grid-template-columns: 1fr 1fr; margin-bottom: 40px; }
  .stat { padding: 18px 14px 22px; }
  .stat .stat-label { font-size: 9px; margin-bottom: 12px; letter-spacing: 0.18em; }
  .stat .stat-value { font-size: 26px; }
  .stat .stat-meta { font-size: 10px; }

  /* Two-col already collapses at 1000px */
  .two-col { gap: 28px; margin-bottom: 40px; }

  /* Budget category rows — stack everything */
  .cat-row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 14px 0;
  }
  .cat-name { font-size: 13px; }
  .cat-bar { height: 22px; }
  .cat-amounts {
    text-align: left;
    min-width: 0;
    font-size: 11px;
  }

  /* Totals row */
  .totals {
    grid-template-columns: 1fr;
    gap: 8px;
    padding-top: 14px;
  }
  .totals .lbl { font-size: 18px; }
  .totals .nm { text-align: left; font-size: 12px; }

  /* Donut */
  .donut-svg { max-width: 280px; }
  .donut-center .big { font-size: 32px; }
  .donut-legend { grid-template-columns: 1fr; max-width: 100%; }

  /* Trip overview */
  .trip-overview {
    grid-template-columns: 1fr 1fr;
    padding: 18px 16px;
    gap: 18px 14px;
  }
  .trip-stat .v { font-size: 22px; }
  .trip-stat .l { font-size: 9px; letter-spacing: 0.16em; }

  /* Itinerary rows — fully stacked */
  .itin-row {
    grid-template-columns: 1fr;
    grid-template-areas:
      "day"
      "date"
      "route"
      "weather"
      "meta";
    gap: 4px;
    padding: 16px 0;
  }
  .itin-cell-day { display: flex; align-items: baseline; gap: 10px; }
  .itin-cell-day .day { font-size: 22px; }
  .itin-cell-day .day-sub { font-size: 10px; color: var(--ink-mute); }
  .itin-cell-date { padding-top: 0 !important; font-size: 10px; }
  .itin-cell-route .route { font-size: 19px; line-height: 1.2; }
  .itin-cell-route .activities { font-size: 12px; }
  .itin-cell-weather { font-size: 11px; }
  .itin-cell-meta { font-size: 10px; }

  /* TripMap mobile tightening */
  .trip-map-summary {
    font-size: 10px !important;
    padding: 12px 14px !important;
    line-height: 1.7;
    letter-spacing: 0.04em !important;
  }


  /* Savings */
  .savings-chart { padding: 18px 14px; }
  .savings-svg { height: 260px; }

  /* Deco groups */
  .deco-group-head {
    padding: 14px 16px;
    flex-wrap: wrap;
    gap: 6px;
  }
  .deco-group-head .name { font-size: 22px; }
  .deco-group-head .totals-mini { font-size: 11px; }
  .deco-rows { padding: 0 16px 12px; }
  .deco-row {
    grid-template-columns: 1fr 80px 20px;
    gap: 10px;
    font-size: 12px;
    padding: 8px 0;
  }
  .deco-row .num { font-size: 11px; }
  /* hide the second price column on very small screens to keep it readable */
  .deco-row > .num:nth-of-type(2) { display: none; }

  /* Summary cards */
  .summary-card { padding: 22px 18px; }
  .summary-card .ttl { font-size: 22px; }
  .summary-card .big { font-size: 44px; }
  .summary-card .big small { font-size: 16px; }

  /* Footer */
  .footer-note { margin-top: 40px; padding-top: 24px; font-size: 11px; }

  /* Hero countdown chip — hide subtitle to save space */
  .brand-sub { display: none !important; }
}

/* Extra-small (very narrow phones) */
@media (max-width: 380px) {
  .hero-countdown .num { font-size: 22px; }
  .hero-countdown > div { padding: 12px 2px; }
  .hero-title { font-size: clamp(36px, 13vw, 56px); }
  .section-title { font-size: 26px; }
  .countdown-chip { font-size: 9px; padding: 4px 8px; }
  .stat .stat-value { font-size: 22px; }
}
