/* ===========================================================================
   Rent & Exit — v1 frontend
   Shared application styles, built strictly on the Rent & Exit design system
   tokens (assets/ds/styles.css). Header & footer are injected by app.js and
   styled here so every page shares one chrome.
   =========================================================================== */

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

html, body { margin: 0; }

body {
  font-family: var(--font-body);
  font-weight: var(--fw-book);
  color: var(--text-body);
  background: var(--surface-page);
  line-height: var(--leading-normal);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

a { color: inherit; text-decoration: none; }

img { display: block; max-width: 100%; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* --- Layout primitives --------------------------------------------------- */
.container {
  width: 100%;
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--space-8);
}

.section { padding: var(--space-20) 0; }
.section--sunken { background: var(--surface-sunken); }
.section--ink { background: var(--surface-ink); color: var(--text-inverse); }

/* --- Type roles ---------------------------------------------------------- */
.eyebrow {
  font-family: var(--font-sans);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  font-size: var(--text-xs);
  color: var(--re-teal);
  margin: 0 0 var(--space-3);
}
.section--ink .eyebrow { color: var(--re-amber); }

.display {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  text-transform: uppercase;
  letter-spacing: var(--tracking-display);
  line-height: var(--leading-tight);
  color: var(--text-strong);
  margin: 0;
}
.section--ink .display { color: var(--text-inverse); }

h1.display { font-size: var(--text-4xl); }
h2.display { font-size: var(--text-2xl); }
h3.display { font-size: var(--text-xl); }

.lead {
  font-size: var(--text-md);
  line-height: var(--leading-relaxed);
  color: var(--text-muted);
  margin: var(--space-4) 0 0;
}
.section--ink .lead { color: rgba(255,255,255,.72); }

.section-head { margin-bottom: var(--space-10); }

/* --- Buttons ------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: var(--control-h-md);
  padding: 0 var(--space-6);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-standard),
              transform var(--dur-fast) var(--ease-standard);
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn .lucide { width: 18px; height: 18px; }

.btn--sm { height: var(--control-h-sm); padding: 0 var(--space-4); font-size: var(--text-xs); }
.btn--lg { height: var(--control-h-lg); padding: 0 var(--space-8); font-size: var(--text-base); }
.btn--block { width: 100%; }

.btn--primary {
  background: var(--action-primary);
  color: var(--text-on-amber);
  box-shadow: var(--shadow-amber);
}
.btn--primary:hover { background: var(--action-primary-hover); }
.btn--primary:active { background: var(--action-primary-press); }

.btn--secondary { background: var(--action-secondary); color: var(--text-inverse); }
.btn--secondary:hover { background: var(--action-secondary-hover); }
.btn--secondary:active { background: var(--action-secondary-press); }

.btn--ghost {
  background: transparent;
  color: var(--text-link);
  border: 1px solid var(--border-default);
}
.btn--ghost:hover { background: var(--teal-100); border-color: var(--border-focus); }

.btn:disabled,
.btn.is-disabled { opacity: .45; cursor: not-allowed; box-shadow: none; transform: none; pointer-events: auto; }

.linklike {
  color: var(--text-link);
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: var(--text-sm);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
}
.linklike:hover { color: var(--teal-700); }
.linklike .lucide { width: 16px; height: 16px; }

/* --- Cards --------------------------------------------------------------- */
.card {
  background: var(--surface-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.card--pad { padding: var(--space-6); }
.card--interactive { transition: box-shadow var(--dur-base) var(--ease-standard), transform var(--dur-base) var(--ease-standard); }
.card--interactive:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

/* Media frame. Holds either a placeholder icon or a real <img>.
   Photos are internet placeholders (Unsplash / loremflickr) until the
   PHP/CMS pipeline supplies brand photography. */
.media {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  background: var(--grad-teal);
  color: rgba(255,255,255,.85);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}
.media .lucide { width: 22px; height: 22px; }
.media__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* --- Forms / inputs ------------------------------------------------------ */
.field { display: flex; flex-direction: column; gap: var(--space-2); min-width: 0; }
.field > label {
  font-family: var(--font-sans);
  font-weight: var(--fw-bold);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.field > label .lucide { width: 15px; height: 15px; color: var(--re-teal); }

.input, .select {
  width: 100%;
  height: var(--control-h-md);
  padding: 0 var(--space-4);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--surface-card);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-strong);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.input:focus, .select:focus {
  outline: none;
  border-color: var(--border-focus);
  border-width: 2px;
  box-shadow: var(--focus-ring);
}
.input::placeholder { color: var(--text-muted); }

.check {
  display: inline-flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-body);
  cursor: pointer;
  line-height: var(--leading-snug);
}
.check input { width: 18px; height: 18px; margin: 1px 0 0; accent-color: var(--re-teal); flex-shrink: 0; }

/* --- Badge / pill -------------------------------------------------------- */
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: var(--text-2xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  background: var(--teal-100);
  color: var(--teal-700);
}
.pill--amber { background: var(--re-amber); color: var(--text-on-amber); }

.stars { color: var(--re-amber); font-size: var(--text-sm); letter-spacing: 2px; }

/* =========================================================================
   HEADER (injected by app.js)
   ========================================================================= */
.site-header {
  position: sticky; top: 0; z-index: var(--z-sticky);
  background: var(--re-ink);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.site-header__bar {
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--space-8);
  height: 76px;
  display: flex;
  align-items: center;
  gap: var(--space-8);
}
.site-header__logo { height: 26px; cursor: pointer; flex-shrink: 0; }
.site-nav { display: flex; gap: var(--space-6); flex-wrap: nowrap; }
.site-nav a { white-space: nowrap; }
.site-nav a {
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.62);
  border-bottom: 2px solid transparent;
  padding-bottom: 4px;
  transition: color var(--dur-fast);
}
.site-nav a:hover { color: #fff; }
.site-nav a.is-active { color: #fff; border-bottom-color: var(--re-amber); }
.site-header__actions { margin-left: auto; display: flex; align-items: center; gap: var(--space-4); flex-shrink: 0; }
.site-header__phone {
  display: flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-sans); font-weight: var(--fw-medium); font-size: var(--text-sm);
  color: rgba(255,255,255,.82);
}
.site-header__phone .lucide { width: 16px; height: 16px; color: var(--re-amber); }
.site-header__lang { font-family: var(--font-sans); font-size: var(--text-sm); color: rgba(255,255,255,.62); }
.site-header__lang strong { color: #fff; font-weight: var(--fw-medium); }

/* Hamburger — hidden on desktop, shown under 760px */
.nav-toggle {
  display: none;
  align-items: center; justify-content: center;
  width: 44px; height: 44px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--radius-md);
  background: transparent; color: #fff; cursor: pointer;
}
.nav-toggle .lucide { width: 22px; height: 22px; }
.nav-toggle .lucide-x { display: none; }
.site-header.is-open .nav-toggle .lucide-menu { display: none; }
.site-header.is-open .nav-toggle .lucide-x { display: block; }

/* Mobile menu panel */
.mobile-menu {
  display: none;
  border-top: 1px solid rgba(255,255,255,.08);
  background: var(--re-ink);
  padding: var(--space-4) var(--space-6) var(--space-6);
}
.site-header.is-open .mobile-menu { display: block; }
.mobile-menu a.mobile-link {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-sans); font-weight: var(--fw-medium); font-size: var(--text-md);
  text-transform: uppercase; letter-spacing: .04em;
  color: rgba(255,255,255,.78);
  padding: var(--space-4) 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.mobile-menu a.mobile-link.is-active { color: #fff; }
.mobile-menu a.mobile-link .lucide { width: 18px; height: 18px; color: var(--re-amber); }
.mobile-menu__foot { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-5); }
.mobile-menu__phone {
  display: flex; align-items: center; gap: var(--space-2);
  font-family: var(--font-sans); font-weight: var(--fw-medium); font-size: var(--text-base);
  color: rgba(255,255,255,.82);
}
.mobile-menu__phone .lucide { width: 18px; height: 18px; color: var(--re-amber); }

/* =========================================================================
   FOOTER (injected by app.js)
   ========================================================================= */
.site-footer { background: var(--re-ink); color: rgba(255,255,255,.7); padding: var(--space-16) 0 var(--space-8); }
.site-footer__grid {
  max-width: var(--container-wide); margin: 0 auto; padding: 0 var(--space-8);
  display: grid; grid-template-columns: 1.6fr repeat(3, 1fr); gap: var(--space-10);
}
.site-footer__logo { height: 28px; margin-bottom: var(--space-5); }
.site-footer__about { font-size: var(--text-sm); line-height: var(--leading-relaxed); max-width: 280px; margin: 0; color: rgba(255,255,255,.7); }
.site-footer__social { display: flex; gap: var(--space-3); margin-top: var(--space-5); }
.site-footer__social span {
  width: 38px; height: 38px; border-radius: var(--radius-pill);
  background: rgba(255,255,255,.08); display: flex; align-items: center; justify-content: center;
}
.site-footer__social .lucide { width: 17px; height: 17px; color: rgba(255,255,255,.8); }
.site-footer__col h4 {
  font-family: var(--font-sans); font-weight: var(--fw-bold);
  font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase;
  color: #fff; margin: 0 0 var(--space-4);
}
.site-footer__col a { display: block; font-size: var(--text-sm); color: rgba(255,255,255,.66); margin-bottom: var(--space-3); }
.site-footer__col a:hover { color: #fff; }
.site-footer__bottom {
  max-width: var(--container-wide); margin: var(--space-10) auto 0; padding: var(--space-6) var(--space-8) 0;
  border-top: 1px solid rgba(255,255,255,.1);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-3);
  font-size: var(--text-xs); color: rgba(255,255,255,.5);
}

/* =========================================================================
   HOME — hero & search
   ========================================================================= */
.hero {
  position: relative;
  color: var(--text-inverse);
  padding: var(--space-16) 0 var(--space-20);
  background:
    var(--grad-ink),
    linear-gradient(180deg, rgba(21,41,43,.55) 0%, rgba(21,41,43,.55) 100%),
    var(--surface-ink);
  background-size: cover;
  background-position: center;
}
/* Full-bleed photography behind the protection gradient. */
.hero--photo {
  background-image:
    var(--grad-ink),
    linear-gradient(180deg, rgba(21,41,43,.45) 0%, rgba(21,41,43,.55) 100%),
    url("https://images.unsplash.com/photo-1469854523086-cc02fe5d8800?w=1920&q=80");
}
.hero .container { position: relative; z-index: 1; }
.hero .eyebrow { color: var(--re-amber); }
.hero h1.display { font-size: var(--text-5xl); max-width: 14ch; color: var(--text-inverse); }
.hero .lead { max-width: 48ch; color: rgba(255,255,255,.82); }

.searchbar {
  margin-top: var(--space-10);
  background: var(--surface-card);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--space-5);
}
.searchbar__grid { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: var(--space-5); }
.searchbar__dates { display: flex; gap: var(--space-2); }
.searchbar__dates .input:first-child { flex: 2; }
.searchbar__dates .input:last-child { flex: 1; }
.searchbar__foot {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: var(--space-5); flex-wrap: wrap; gap: var(--space-4);
}

/* Trust stats */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-6); text-align: center; }
.stats__num { font-family: var(--font-display); font-weight: var(--fw-black); font-size: var(--text-3xl); color: var(--text-strong); }
.stats__label { font-size: var(--text-sm); color: var(--text-muted); margin-top: var(--space-1); }

/* Generic responsive grids */
.grid { display: grid; gap: var(--space-6); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }

/* Fleet group card */
.fleet-card__body { padding: var(--space-4); }
.fleet-card__name { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-md); color: var(--text-strong); }
.fleet-meta { display: flex; gap: var(--space-3); align-items: center; color: var(--text-muted); font-size: var(--text-xs); margin: var(--space-2) 0 var(--space-4); flex-wrap: wrap; }
.fleet-meta span { display: inline-flex; align-items: center; gap: 5px; }
.fleet-meta .lucide { width: 14px; height: 14px; }
.fleet-card__foot { display: flex; align-items: center; justify-content: space-between; }
.price { font-size: var(--text-sm); color: var(--text-body); }
.price strong { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-lg); color: var(--text-strong); }

/* How it works */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); }
.step-item { text-align: center; }
.step-item__icon {
  width: 56px; height: 56px; border-radius: var(--radius-lg);
  background: var(--teal-100); color: var(--re-teal);
  display: flex; align-items: center; justify-content: center; margin: 0 auto var(--space-4);
}
.step-item__icon .lucide { width: 26px; height: 26px; }
.step-item__title { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-base); color: var(--text-strong); }
.step-item__desc { font-size: var(--text-sm); color: var(--text-muted); margin-top: var(--space-1); }

/* Locations */
.locations { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--space-6); }
.loc-list { display: flex; flex-direction: column; gap: var(--space-3); }
.loc-card__name { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-base); color: var(--text-strong); display: flex; align-items: center; gap: var(--space-2); }
.loc-card__name .lucide { width: 16px; height: 16px; color: var(--re-teal); }
.loc-card__meta { font-size: var(--text-sm); color: var(--text-muted); margin-top: var(--space-1); }

/* Reviews */
.review p { font-size: var(--text-sm); color: var(--text-body); margin: var(--space-2) 0 var(--space-4); line-height: var(--leading-relaxed); }
.review__author { display: flex; align-items: center; gap: var(--space-2); }
.avatar { width: 32px; height: 32px; border-radius: var(--radius-pill); background: var(--teal-100); color: var(--teal-700); display: flex; align-items: center; justify-content: center; font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-xs); }

/* About */
.about { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-10); align-items: center; }

/* =========================================================================
   RESULTS
   ========================================================================= */
.search-summary {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
  padding: var(--space-4) var(--space-5); margin-bottom: var(--space-6); flex-wrap: wrap;
}
.search-summary__trip { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); flex-wrap: wrap; }
.search-summary__trip .lucide { width: 16px; height: 16px; color: var(--re-teal); }
.search-summary__trip strong { font-family: var(--font-sans); font-weight: var(--fw-bold); }

.results-layout { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--space-6); align-items: start; }
.results-list { display: flex; flex-direction: column; gap: var(--space-4); }

.result-card {
  display: flex; gap: var(--space-4); align-items: center;
  padding: var(--space-4); cursor: pointer;
  border: 1px solid var(--border-subtle);
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.result-card.is-selected { border: 2px solid var(--re-teal); box-shadow: var(--shadow-md); }
.result-card__media { width: 92px; height: 64px; flex-shrink: 0; border-radius: var(--radius-md); }
.result-card__info { flex: 1; min-width: 0; }
.result-card__name { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-base); color: var(--text-strong); }
.result-card__price { font-size: var(--text-sm); margin-top: var(--space-1); }
.result-card__price strong { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-md); color: var(--text-strong); }

/* Booking panel (sticky) */
.booking-panel {
  position: sticky; top: 96px;
  background: var(--surface-card); border: 1px solid var(--border-default);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: var(--space-6);
}
.booking-panel__head { display: flex; gap: var(--space-3); align-items: center; padding-bottom: var(--space-4); margin-bottom: var(--space-4); border-bottom: 1px solid var(--border-subtle); }
.booking-panel__head .media { width: 56px; height: 40px; flex-shrink: 0; border-radius: var(--radius-md); }
.booking-panel__car { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-md); color: var(--text-strong); }

.opt-label { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-2xs); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-muted); margin-bottom: var(--space-2); }
.opt-row { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); padding: var(--space-3) 0; border-bottom: 1px solid var(--border-subtle); font-size: var(--text-sm); }
.opt-row .muted { color: var(--text-muted); }
.opt-row .select { width: auto; height: var(--control-h-sm); }

.stepper { display: flex; align-items: center; gap: var(--space-2); }
.stepper button {
  width: 30px; height: 30px; border-radius: var(--radius-md);
  border: 1px solid var(--border-default); background: var(--surface-card);
  color: var(--text-strong); font-size: var(--text-md); line-height: 1; cursor: pointer;
  transition: border-color var(--dur-fast), background var(--dur-fast);
}
.stepper button:hover { border-color: var(--re-teal); background: var(--teal-100); }
.stepper span { min-width: 16px; text-align: center; font-size: var(--text-base); }

.totals { margin-top: var(--space-4); font-size: var(--text-sm); color: var(--text-muted); }
.totals__row { display: flex; justify-content: space-between; padding: 3px 0; }
.totals__grand { display: flex; justify-content: space-between; align-items: baseline; margin-top: var(--space-2); padding-top: var(--space-3); border-top: 1px solid var(--border-default); }
.totals__grand .label { font-family: var(--font-sans); font-weight: var(--fw-bold); color: var(--text-strong); }
.totals__grand .value { font-family: var(--font-display); font-weight: var(--fw-black); font-size: var(--text-2xl); color: var(--text-strong); }
.fineprint { font-size: var(--text-2xs); color: var(--text-muted); text-align: right; margin-top: var(--space-1); }
.fineprint--center { text-align: center; }

/* =========================================================================
   CONFIRMATION
   ========================================================================= */
.confirm { max-width: 640px; margin: 0 auto; padding: var(--space-16) 0; }
.confirm__head { text-align: center; margin-bottom: var(--space-8); }
.confirm__check {
  width: 64px; height: 64px; border-radius: var(--radius-pill);
  background: rgba(46,158,107,.14); color: var(--success);
  display: flex; align-items: center; justify-content: center; margin: 0 auto var(--space-5);
}
.confirm__check .lucide { width: 32px; height: 32px; }
.confirm__ref {
  display: inline-block; margin-top: var(--space-4);
  font-size: var(--text-sm); background: var(--surface-sunken);
  border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: var(--space-2) var(--space-4);
}
.confirm__ref strong { font-family: var(--font-sans); font-weight: var(--fw-bold); }

.summary-card { padding: var(--space-6); }
.summary-card__top { display: flex; gap: var(--space-4); align-items: center; margin-bottom: var(--space-4); }
.summary-card__top .media { width: 72px; height: 52px; flex-shrink: 0; border-radius: var(--radius-md); }
.summary-row { display: flex; justify-content: space-between; gap: var(--space-3); font-size: var(--text-sm); padding: var(--space-2) 0; border-bottom: 1px solid var(--border-subtle); }
.summary-row .key { color: var(--text-muted); display: flex; align-items: center; gap: var(--space-2); }
.summary-row .key .lucide { width: 16px; height: 16px; color: var(--re-teal); }
.summary-card__total { display: flex; justify-content: space-between; align-items: baseline; margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--border-default); }
.summary-card__total .value { font-family: var(--font-display); font-weight: var(--fw-black); font-size: var(--text-2xl); color: var(--text-strong); }

.next-steps { display: flex; flex-direction: column; gap: var(--space-5); margin-top: var(--space-8); }
.next-step { display: flex; gap: var(--space-4); align-items: flex-start; }
.next-step__icon { color: var(--re-teal); margin-top: 2px; }
.next-step__icon .lucide { width: 22px; height: 22px; }
.next-step__title { font-family: var(--font-sans); font-weight: var(--fw-bold); font-size: var(--text-base); color: var(--text-strong); }
.next-step__desc { font-size: var(--text-sm); color: var(--text-muted); margin-top: 2px; }

.confirm__actions { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; margin-top: var(--space-10); }

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 960px) {
  .results-layout { grid-template-columns: 1fr; }
  .booking-panel { position: static; }
  .site-footer__grid { grid-template-columns: 1fr 1fr; }
  .about, .locations { grid-template-columns: 1fr; }
  .section { padding: var(--space-16) 0; }
}

/* --- Mobile (<= 760px): hamburger menu kicks in --------------------------- */
@media (max-width: 760px) {
  .searchbar__grid { grid-template-columns: 1fr 1fr; }
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .grid--3, .steps { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
  .hero { padding: var(--space-12) 0 var(--space-16); }
  .hero h1.display { font-size: var(--text-3xl); }

  /* Header → logo + hamburger only; everything else moves into the panel */
  .site-nav, .site-header__phone, .site-header__lang { display: none; }
  .site-header__actions .btn--primary { display: none; }
  .nav-toggle { display: inline-flex; }
  .site-header__bar { gap: var(--space-4); height: 64px; }

  /* Results: stack the car card so the action never overflows */
  .result-card { flex-wrap: wrap; }
  .result-card__info { flex: 1 1 60%; }
  .result-card .js-select { flex: 1 0 100%; order: 3; }
  .search-summary { gap: var(--space-3); }
}

/* --- Small phones (<= 520px) --------------------------------------------- */
@media (max-width: 520px) {
  .searchbar__grid, .grid--4 { grid-template-columns: 1fr; }
  .container { padding: 0 var(--space-5); }
  .stats { grid-template-columns: 1fr 1fr; }
  .site-footer__grid { grid-template-columns: 1fr; gap: var(--space-8); }
  .searchbar__foot { flex-direction: column; align-items: stretch; }
  .searchbar__foot .btn { width: 100%; }
  .confirm { padding: var(--space-10) 0; }
  .confirm__actions .btn { flex: 1 1 100%; }
  .site-footer__bottom { flex-direction: column; }
}

/* =========================================================================
   v2 additions — language switcher, alerts, CMS prose
   ========================================================================= */
.lang-switch { position: relative; }
.lang-switch__btn {
  display: inline-flex; align-items: center; gap: 4px;
  background: transparent; border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.85); border-radius: var(--radius-md);
  height: 36px; padding: 0 10px; cursor: pointer;
  font-family: var(--font-sans); font-weight: var(--fw-medium); font-size: var(--text-xs);
  letter-spacing: .06em;
}
.lang-switch__btn .lucide { width: 14px; height: 14px; }
.lang-switch__menu {
  position: absolute; top: calc(100% + 8px); right: 0; min-width: 160px;
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md); box-shadow: var(--shadow-lg); padding: 6px;
  display: none; z-index: var(--z-overlay);
}
.lang-switch.is-open .lang-switch__menu { display: block; }
.lang-switch__menu a {
  display: block; padding: 8px 10px; border-radius: var(--radius-sm);
  font-size: var(--text-sm); color: var(--text-body);
}
.lang-switch__menu a:hover { background: var(--surface-sunken); }
.lang-switch__menu a.is-active { color: var(--re-teal); font-weight: var(--fw-medium); }

.mobile-menu__langs { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-4); }
.mobile-menu__langs a {
  padding: 6px 12px; border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius-pill);
  color: rgba(255,255,255,.78); font-size: var(--text-xs); font-weight: var(--fw-medium);
}
.mobile-menu__langs a.is-active { color: #fff; border-color: var(--re-amber); }

.alert {
  border-radius: var(--radius-md); padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm); border: 1px solid var(--border-subtle); margin-bottom: var(--space-4);
}
.alert--success { background: #eafaf1; border-color: #b9e6cd; color: #176844; }
.alert--error   { background: #fdecea; border-color: #f4c2bd; color: #a3271c; }
.alert--info    { background: var(--teal-100); border-color: var(--teal-200); color: var(--teal-700); }

.prose { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-body); }
.prose h1, .prose h2, .prose h3 { font-family: var(--font-sans); color: var(--text-strong); margin: 1.4em 0 .5em; }
.prose h2 { font-size: var(--text-xl); }
.prose h3 { font-size: var(--text-lg); }
.prose p, .prose ul, .prose ol { margin: 0 0 1em; }
.prose ul, .prose ol { padding-left: 1.4em; }
.prose a { color: var(--text-link); text-decoration: underline; }
.prose img { border-radius: var(--radius-md); margin: 1em 0; }

/* v2 — results grouped by sub-group */
.results-group-title {
  font-family: var(--font-sans); font-weight: var(--fw-bold);
  font-size: var(--text-xs); letter-spacing: var(--tracking-caps); text-transform: uppercase;
  color: var(--re-teal); margin: var(--space-6) 0 var(--space-2);
}
.results-group-title:first-child { margin-top: 0; }
