:root {
  --black: #070807;
  --black-2: #0e0f0d;
  --charcoal: #181816;
  --charcoal-2: #24231f;
  --gold: #c9a45a;
  --gold-2: #edcf87;
  --ivory: #f8f3e9;
  --cream: #efe6d7;
  --paper: #fffaf1;
  --ink: #171511;
  --muted: #746d62;
  --soft: rgba(255, 255, 255, .68);
  --line: rgba(201, 164, 90, .28);
  --dark-line: rgba(255, 255, 255, .12);
  --shadow: 0 22px 70px rgba(0, 0, 0, .2);
  --dark-shadow: 0 28px 90px rgba(0, 0, 0, .48);
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: Inter, Arial, Helvetica, sans-serif;
  --page-bg: var(--ivory);
  --section-bg: var(--ivory);
  --surface: #ffffff;
  --surface-2: #fffaf1;
  --text: #171511;
  --text-muted: #746d62;
  --header-bg: rgba(5, 7, 8, .82);
  --header-text: #ffffff;
  --hero-overlay: linear-gradient(90deg, rgba(0,0,0,.93) 0%, rgba(0,0,0,.34) 48%, rgba(0,0,0,.82) 100%);
  --hero-text: #ffffff;
  --field-bg: #ffffff;
  --field-text: #171511;
}

:root[data-theme="light"] {
  --black: #11100e;
  --black-2: #f0e7d8;
  --charcoal: #f7f0e5;
  --gold: #a97824;
  --gold-2: #c79234;
  --ivory: #fffaf1;
  --cream: #f2eadc;
  --paper: #ffffff;
  --ink: #181611;
  --muted: #655f55;
  --line: rgba(169, 120, 36, .28);
  --page-bg: #fffaf1;
  --section-bg: #fffaf1;
  --surface: #ffffff;
  --surface-2: #f7efe2;
  --text: #181611;
  --text-muted: #655f55;
  --header-bg: rgba(255, 250, 241, .94);
  --header-text: #15130f;
  --hero-overlay: linear-gradient(90deg, rgba(255,250,241,.92) 0%, rgba(255,250,241,.62) 46%, rgba(20,20,18,.5) 100%);
  --hero-text: #16130f;
  --field-bg: #ffffff;
  --field-text: #181611;
}

:root[data-theme="blue"] {
  --black: #0f2434;
  --black-2: #17364d;
  --charcoal: #203e55;
  --gold: #d2aa5e;
  --gold-2: #f0d28c;
  --ivory: #eef6fb;
  --cream: #dfeef7;
  --paper: #f8fcff;
  --ink: #10202c;
  --muted: #546b7b;
  --line: rgba(55, 111, 150, .24);
  --page-bg: #eef6fb;
  --section-bg: #eef6fb;
  --surface: #ffffff;
  --surface-2: #e5f1f8;
  --text: #10202c;
  --text-muted: #546b7b;
  --header-bg: rgba(12, 31, 46, .92);
  --header-text: #ffffff;
  --hero-overlay: linear-gradient(90deg, rgba(4,20,34,.9) 0%, rgba(8,40,65,.48) 48%, rgba(5,20,34,.8) 100%);
  --hero-text: #ffffff;
  --field-bg: #ffffff;
  --field-text: #10202c;
}

:root[data-theme="dark-blue"] {
  --black: #050b14;
  --black-2: #071423;
  --charcoal: #101f31;
  --gold: #cda75e;
  --gold-2: #efd184;
  --ivory: #eaf0f6;
  --cream: #dfe7ef;
  --paper: #f7fbff;
  --ink: #0d1722;
  --muted: #6b7885;
  --line: rgba(205, 167, 94, .28);
  --page-bg: #071423;
  --section-bg: #0c1a2b;
  --surface: #102236;
  --surface-2: #0b1929;
  --text: #f5f8fb;
  --text-muted: #bfd0df;
  --header-bg: rgba(5, 11, 20, .94);
  --header-text: #ffffff;
  --hero-overlay: linear-gradient(90deg, rgba(2,8,16,.94) 0%, rgba(9,32,52,.5) 48%, rgba(2,8,16,.84) 100%);
  --hero-text: #ffffff;
  --field-bg: #102236;
  --field-text: #f5f8fb;
}

:root[data-theme="mixed"] {
  --black: #090908;
  --black-2: #10181d;
  --charcoal: #18232a;
  --gold: #caa45a;
  --gold-2: #f0d493;
  --ivory: #f8f3ea;
  --cream: #e9edf0;
  --paper: #fffaf1;
  --ink: #171511;
  --muted: #687174;
  --line: rgba(202, 164, 90, .3);
  --page-bg: #f8f3ea;
  --section-bg: #f8f3ea;
  --surface: #ffffff;
  --surface-2: #edf2f4;
  --text: #171511;
  --text-muted: #687174;
  --header-bg: rgba(8, 12, 14, .9);
  --header-text: #ffffff;
  --hero-overlay: linear-gradient(90deg, rgba(0,0,0,.9) 0%, rgba(25,39,45,.42) 48%, rgba(0,0,0,.8) 100%);
  --hero-text: #ffffff;
  --field-bg: #ffffff;
  --field-text: #171511;
}

:root[data-theme="dark"] {
  --black:    #070807;
  --black-2:  #0e0f0d;
  --charcoal: #181816;
  --gold:     #c9a45a;
  --gold-2:   #edcf87;
  --btn-text: #0b0b09;
  --ivory:    #f8f3e9;
  --page-bg:  #0e0f0d;
  --section-bg: #181816;
  --surface:  #1c1c1a;
  --surface-2:#24231f;
  --text:     #f0ebe1;
  --text-muted: rgba(240,235,225,.58);
  --line:     rgba(201,164,90,.28);
  --dark-line:rgba(255,255,255,.12);
  --header-bg:rgba(5,7,8,.88);
  --header-text:#ffffff;
  --hero-overlay: linear-gradient(90deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.38) 48%,rgba(0,0,0,.84) 100%);
  --hero-text:#ffffff;
  --field-bg: #24231f;
  --field-text:#f0ebe1;
}

:root[data-theme="red"] {
  --black:      #0D0808;
  --black-2:    #150B0B;
  --charcoal:   #1E1010;
  --gold:       #C41E3A;
  --gold-2:     #E8475F;
  --ivory:      #FAF0F0;
  --cream:      #F5E8E8;
  --paper:      #FFF8F8;
  --ink:        #1A0808;
  --muted:      #7A5560;
  --page-bg:    #0D0808;
  --section-bg: #160B0B;
  --surface:    #1E1010;
  --surface-2:  #281414;
  --text:       #F0E8E8;
  --text-muted: rgba(240,232,232,.58);
  --line:       rgba(196,30,58,.30);
  --dark-line:  rgba(255,255,255,.12);
  --header-bg:  rgba(13,8,8,.90);
  --header-text:#ffffff;
  --hero-overlay: linear-gradient(90deg,rgba(0,0,0,.92) 0%,rgba(0,0,0,.38) 48%,rgba(0,0,0,.84) 100%);
  --hero-text:  #ffffff;
  --field-bg:   #281414;
  --field-text: #F0E8E8;
  --btn-text:   #ffffff;
}

/* ── RED THEME: component overrides ─────────────────────────── */
[data-theme="red"] body {
  background: #0D0808 !important;
  color: #F0E8E8 !important;
}
[data-theme="red"] .section                { background-color: #160B0B !important; color: #F0E8E8 !important; }
[data-theme="red"] .section.cream          { background-color: #1E1010 !important; }
[data-theme="red"] .home-intro,
[data-theme="red"] .why-us,
[data-theme="red"] .home-services,
[data-theme="red"] .home-fleet-section     { background-color: #160B0B !important; color: #F0E8E8 !important; }
[data-theme="red"] h1,
[data-theme="red"] h2,
[data-theme="red"] h3                      { color: #F0E8E8; }
[data-theme="red"] p                       { color: rgba(240,232,232,.78); }
[data-theme="red"] .text-muted,
[data-theme="red"] .section-head > p       { color: rgba(240,232,232,.62) !important; }
[data-theme="red"] .card                   { background: #1E1010 !important; border-color: rgba(196,30,58,.2) !important; color: #F0E8E8 !important; }
[data-theme="red"] .card-body              { background: #1E1010 !important; color: #F0E8E8 !important; }
[data-theme="red"] .card-body h2           { color: #F0E8E8 !important; }
[data-theme="red"] .card-body p            { color: rgba(240,232,232,.7) !important; }
[data-theme="red"] .benefit-card           { background: #281414 !important; color: #F0E8E8 !important; border-color: rgba(196,30,58,.25) !important; }
[data-theme="red"] .benefit-card p         { color: rgba(240,232,232,.65) !important; }
[data-theme="red"] .service-list span      { background: #1E1010 !important; color: #F0E8E8 !important; border-left-color: var(--gold) !important; border-color: rgba(196,30,58,.2) !important; }
[data-theme="red"] .price-table            { background: #1E1010 !important; color: #F0E8E8 !important; }
[data-theme="red"] .price-table thead th  { color: #E8475F !important; background: #110808 !important; }
[data-theme="red"] .price-table td        { border-color: rgba(255,255,255,.08) !important; color: #F0E8E8 !important; }
[data-theme="red"] .why-row,
[data-theme="red"] .why-content           { color: #F0E8E8 !important; }
[data-theme="red"] input,
[data-theme="red"] select,
[data-theme="red"] textarea               { background: #281414 !important; color: #F0E8E8 !important; border-color: rgba(255,255,255,.16) !important; }
[data-theme="red"] .form-panel,
[data-theme="red"] .booking-sidebar       { background: #1E1010 !important; color: #F0E8E8 !important; }
/* Tailwind gold → crimson for fleet & services pages */
[data-theme="red"] .text-\[\#D4AF37\]     { color: #E8475F !important; }
[data-theme="red"] .text-metallic-gold    { color: #E8475F !important; }
[data-theme="red"] .border-\[\#D4AF37\]   { border-color: #C41E3A !important; }
[data-theme="red"] .border-metallic-gold  { border-color: #C41E3A !important; }
[data-theme="red"] .hover\:bg-\[\#D4AF37\]:hover,
[data-theme="red"] .hover\:bg-metallic-gold:hover { background-color: #C41E3A !important; color: #fff !important; }
[data-theme="red"] .border-\[\#D4AF37\]\/30 { border-color: rgba(196,30,58,.3) !important; }
[data-theme="red"] .bg-\[\#D4AF37\]\/5   { background-color: rgba(196,30,58,.05) !important; }
/* Fleet & services dark section backgrounds */
[data-theme="red"] [style*="background:#1a1c1c"],
[data-theme="red"] [style*="background:#1e2020"] { background-color: #1E1010 !important; }
[data-theme="red"] [style*="background:#0e0f0d"],
[data-theme="red"] [style*="background:#0a0a09"] { background-color: #0D0808 !important; }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  background: var(--page-bg);
  color: var(--text);
  line-height: 1.6;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
p { margin: 0 0 16px; }

.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 90;
  display: flex;
  align-items: center;
  gap: clamp(12px, 2vw, 32px);
  min-height: 88px;
  padding: 0 clamp(18px, 4vw, 60px);
  background: linear-gradient(180deg, rgba(5,7,8,.88) 0%, rgba(5,7,8,.32) 68%, rgba(5,7,8,0));
  color: var(--header-text);
  transition: background .3s ease, min-height .3s ease, box-shadow .3s ease;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  min-width: max-content;
  color: var(--header-text);
  text-transform: uppercase;
}
.brand-mark {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border: 1px solid var(--gold);
  color: var(--gold-2);
  font-weight: 800;
  font-size: 17px;
  box-shadow: inset 0 0 0 3px rgba(201, 164, 90, .16);
}
.brand-text {
  display: grid;
  gap: 2px;
  font-size: 17px;
  font-weight: 800;
  letter-spacing: .2em;
  line-height: 1.1;
}
.brand-text small {
  font-size: 11px;
  color: color-mix(in srgb, var(--header-text) 82%, transparent);
  letter-spacing: .3em;
}
.site-nav {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  gap: clamp(12px, 1.6vw, 30px);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

/* ── HEADER RIGHT: phone + Book Now ────────────────────────── */
.header-right {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-shrink: 0;
}
.header-phone {
  display: flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.76);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .03em;
  text-decoration: none;
  white-space: nowrap;
  transition: color .18s;
}
.header-phone i { color: var(--gold); font-size: 12px; }
.header-phone:hover { color: var(--gold-2); }
.theme-menu {
  position: relative;
}
.theme-menu-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px 12px;
  border: 1px solid color-mix(in srgb, var(--gold) 36%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--black) 58%, transparent);
  color: color-mix(in srgb, var(--header-text) 88%, transparent);
  font: inherit;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
}
.theme-menu-btn:hover,
.theme-menu.is-open .theme-menu-btn {
  color: var(--gold-2);
  border-color: color-mix(in srgb, var(--gold-2) 62%, transparent);
}
.theme-menu-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  display: grid;
  gap: 6px;
  min-width: 190px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 96%, var(--black) 4%);
  color: var(--text);
  box-shadow: var(--dark-shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s;
}
.theme-menu:hover .theme-menu-dropdown,
.theme-menu.is-open .theme-menu-dropdown,
.theme-menu:focus-within .theme-menu-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.theme-menu-dropdown button,
.mobile-theme-options button {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: inherit;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
  text-align: left;
  cursor: pointer;
}
.theme-menu-dropdown button:hover,
.theme-menu-dropdown button.is-active,
.mobile-theme-options button:hover,
.mobile-theme-options button.is-active {
  border-color: color-mix(in srgb, var(--gold) 32%, transparent);
  background: color-mix(in srgb, var(--gold) 12%, transparent);
}
.theme-dot {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.42);
  flex-shrink: 0;
}
.theme-dot-dark { background: linear-gradient(135deg, #070807 45%, #c9a45a 45%); }
.theme-dot-red { background: linear-gradient(135deg, #0D0808 45%, #C41E3A 45%); }
.theme-dot-light { background: linear-gradient(135deg, #fffaf1 45%, #a97824 45%); border-color: rgba(0,0,0,.18); }
.mobile-theme-panel {
  display: none;
}

/* hide phone text on mid-size screens, keep icon */
@media (max-width: 1150px) and (min-width: 901px) {
  .header-phone-num { display: none; }
}

/* Mobile nav extras (phone + Book Now inside dropdown) */
.mobile-nav-footer {
  display: none;
}

/* Keep the .site-nav
.nav-item {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.submenu {
  position: absolute;
  top: 100%;
  left: 50%;
  display: none;
  min-width: 150px;
  padding: 10px;
  background: rgba(8, 8, 7, .96);
  border: 1px solid var(--line);
  transform: translateX(-50%);
  box-shadow: var(--dark-shadow);
}
.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu {
  display: grid;
}
.submenu a {
  padding: 10px 12px;
  color: rgba(255, 255, 255, .82);
}
.submenu a::after {
  display: none;
}
.site-nav a {
  position: relative;
  color: color-mix(in srgb, var(--header-text) 86%, transparent);
  padding: 18px 0 12px;
  line-height: 1;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color .2s ease, border-color .2s ease;
}
/* theme-picker removed */
.site-nav a:hover { color: var(--gold-2); }
.site-nav a::after { display: none !important; }
.site-nav a:hover,
.site-nav a.is-active {
  color: var(--gold-2);
  border-bottom-color: var(--gold-2);
}
.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  place-items: center;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--gold-2);
}

.btn,
.nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  padding: 13px 24px;
  background: linear-gradient(135deg, var(--gold-2), var(--gold));
  color: var(--btn-text, #0b0b09) !important;
  border: 1px solid color-mix(in srgb, var(--gold-2) 70%, transparent);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .09em;
  text-transform: uppercase;
  box-shadow: 0 14px 32px color-mix(in srgb, var(--gold) 18%, transparent);
  transition: filter .2s, transform .15s;
}
.btn:hover, .nav-cta:hover { filter: brightness(1.12); }
.site-nav .nav-cta { display: none; } /* Book Now lives in .header-right on desktop */
.header-right .nav-cta {
  align-self: center;
  min-height: 46px;
  padding: 0 22px;
  font-size: 11px;
  letter-spacing: .12em;
  border: 1px solid color-mix(in srgb, var(--gold-2) 88%, transparent);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .24);
}
.btn.secondary {
  background: rgba(255, 255, 255, .03);
  color: #fff !important;
  border-color: color-mix(in srgb, var(--gold-2) 52%, transparent);
  box-shadow: none;
}
.btn.dark {
  background: var(--black);
  color: #fff !important;
  border-color: var(--black);
}
.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 30px;
}

h1, h2, h3 {
  margin: 0 0 16px;
  font-family: var(--serif);
  font-weight: 700;
  line-height: .98;
}
h1 { font-size: clamp(42px, 5.4vw, 76px); }
h2 { font-size: clamp(30px, 3.6vw, 50px); }
h3 { font-size: clamp(21px, 2vw, 26px); }
.eyebrow {
  margin-bottom: 14px;
  color: var(--gold);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.lead {
  max-width: 650px;
  color: rgba(255, 255, 255, .82);
  font-size: clamp(17px, 1.6vw, 21px);
}

.home-hero {
  position: relative;
  min-height: 760px;
  overflow: hidden;
  color: #fff;
  background: var(--black);
}
.mock-hero {
  min-height: 760px;
}
.mock-hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.93) 0%, rgba(0,0,0,.34) 48%, rgba(0,0,0,.82) 100%),
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.58)),
    url("../images/hero-chauffeur.jpg");
  background-size: cover;
  background-position: center left;
  filter: saturate(.78) contrast(1.08);
}
.home-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(0, 0, 0, .9) 0%, rgba(0, 0, 0, .5) 52%, rgba(0, 0, 0, .82) 100%);
}
.mock-hero::before {
  background:
    radial-gradient(circle at 38% 50%, rgba(201, 164, 90, .06), transparent 24%),
    linear-gradient(90deg, rgba(0,0,0,.94) 0%, rgba(0,0,0,.28) 50%, rgba(0,0,0,.84) 100%);
}
.home-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  z-index: 1;
  height: 190px;
  background: linear-gradient(180deg, transparent, var(--black));
}
.home-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(.86) contrast(1.04);
}
.home-hero-inner {
  position: relative;
  z-index: 2;
  width: min(1320px, 100%);
  min-height: 690px;
  margin: 0 auto;
  padding: clamp(130px, 11vw, 168px) clamp(18px, 4vw, 58px) 56px;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, 470px);
  align-items: center;
  gap: clamp(34px, 5vw, 90px);
}
.mock-hero .home-hero-inner {
  padding-top: 118px;
  padding-bottom: 34px;
}
.home-hero-copy h1 {
  max-width: 900px;
  text-shadow: 0 8px 34px rgba(0, 0, 0, .55);
}
.mock-hero h1 {
  max-width: 650px;
  font-size: clamp(50px, 6.2vw, 84px);
}
.mock-hero h1 em {
  color: var(--gold-2);
  font-style: italic;
  font-weight: 600;
}
.mock-hero .lead {
  max-width: 560px;
}
.mock-proof {
  display: flex;
  align-items: center;
  gap: 14px;
  max-width: 300px;
  margin-top: 32px;
  color: rgba(255, 255, 255, .78);
}
.mock-proof span {
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  color: var(--gold-2);
}
.mock-proof p {
  margin: 0;
  font-size: 13px;
  line-height: 1.35;
}
.home-quote-panel {
  width: 100%;
  padding: 34px 30px;
  background: linear-gradient(145deg, rgba(17, 17, 15, .95), rgba(34, 31, 27, .88));
  border: 1px solid rgba(237, 207, 135, .34);
  box-shadow: var(--dark-shadow);
}
.home-quote-panel h2 {
  margin-bottom: 24px;
  color: rgba(255, 255, 255, .72);
  font-family: var(--sans);
  font-size: 15px;
  font-weight: 500;
  line-height: 1.5;
}
.quote-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: end;
}
/* Pickup, destination, name, phone are full-width rows */
.quote-grid label:nth-child(1),
.quote-grid label:nth-child(2),
.quote-grid label:nth-child(7),
.quote-grid label:nth-child(8) {
  grid-column: 1 / -1;
}
.quote-grid label {
  color: var(--gold-2);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.home-quote-panel input,
.home-quote-panel select {
  margin-top: 8px;
  background: rgba(255, 255, 255, .035);
  border-color: rgba(255, 255, 255, .16);
  color: #fff;
}
.home-quote-panel label span {
  display: grid;
  grid-template-columns: 26px 1fr;
  align-items: center;
  margin-top: 8px;
  border: 1px solid rgba(255, 255, 255, .16);
  background: rgba(255, 255, 255, .035);
}
.home-quote-panel label span i {
  color: var(--gold-2);
  text-align: center;
}
.home-quote-panel label span input {
  margin-top: 0;
  border: 0;
  background: transparent;
}
.home-quote-panel input::placeholder { color: rgba(255, 255, 255, .48); }
.home-quote-panel select option { color: #111; }

/* Date & time inputs — proper pickers, gold calendar icon */
.home-quote-panel input[type="date"],
.home-quote-panel input[type="time"] {
  color-scheme: dark;
  cursor: pointer;
}
.home-quote-panel input[type="date"]::-webkit-calendar-picker-indicator,
.home-quote-panel input[type="time"]::-webkit-calendar-picker-indicator {
  cursor: pointer;
  opacity: .7;
  filter: invert(75%) sepia(45%) saturate(500%) hue-rotate(4deg) brightness(95%);
}
.home-quote-panel input[type="date"]:hover::-webkit-calendar-picker-indicator,
.home-quote-panel input[type="time"]:hover::-webkit-calendar-picker-indicator {
  opacity: 1;
}
.quote-submit {
  width: 100%;
  margin-top: 18px;
}
.quote-small {
  margin: 14px 0 0;
  color: rgba(255, 255, 255, .68);
  font-size: 12px;
}
.quote-small i {
  color: var(--gold-2);
}

.home-trust-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  background: var(--black-2);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  color: #fff;
}
.home-trust-strip div {
  min-height: 94px;
  padding: 22px clamp(18px, 4vw, 54px);
  display: grid;
  grid-template-columns: 40px 1fr;
  column-gap: 16px;
  align-content: center;
  border-right: 1px solid var(--dark-line);
}
.home-trust-strip i {
  grid-row: span 2;
  color: var(--gold-2);
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  font-size: 22px;
}
.home-trust-strip strong {
  color: var(--gold-2);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.home-trust-strip span {
  color: rgba(255, 255, 255, .72);
  font-size: 13px;
}

.home-intro {
  background: var(--section-bg);
  color: var(--text);
}
.home-intro-copy {
  width: min(900px, 100%);
  margin: 0 auto 34px;
  text-align: center;
}
.home-intro-copy p:last-child {
  color: var(--text-muted);
  font-size: 17px;
}
.benefit-grid {
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.benefit-card {
  padding: 28px 24px 28px 26px;
  background: var(--surface);
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  border-left: 3px solid var(--gold);
  box-shadow: 0 8px 32px rgba(38, 30, 19, .07);
  transition: box-shadow .2s, transform .2s;
}
.benefit-card:hover {
  box-shadow: 0 16px 48px rgba(38, 30, 19, .13);
  transform: translateY(-3px);
}
.benefit-card i {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-bottom: 16px;
  background: color-mix(in srgb, var(--gold) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--gold) 40%, transparent);
  color: var(--gold);
  font-size: 17px;
}
.benefit-card h3 {
  font-size: 20px;
  margin-bottom: 8px;
}
.benefit-card p {
  color: var(--text-muted);
  font-size: 14px;
  margin: 0;
  line-height: 1.6;
}

.home-services {
  background: var(--surface-2);
  color: var(--text);
}
.split-head {
  display: grid;
  grid-template-columns: 1fr minmax(260px, 420px);
  gap: 28px;
  align-items: end;
  width: min(1220px, 100%);
  margin-left: auto;
  margin-right: auto;
}
.split-head > p {
  color: var(--text-muted);
}
.home-service-grid {
  width: min(1220px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 20px;
}
.home-service-card {
  overflow: hidden;
  background: var(--surface);
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  box-shadow: 0 8px 32px rgba(38, 30, 19, .08);
  transition: box-shadow .25s, transform .25s;
}
.home-service-card:hover {
  box-shadow: 0 20px 56px rgba(38, 30, 19, .14);
  transform: translateY(-4px);
}
.home-service-card img {
  width: 100%;
  height: 256px;
  object-fit: cover;
  transition: transform .4s ease;
}
.home-service-card:hover img {
  transform: scale(1.04);
}
.home-service-card > div {
  padding: 26px;
}
.home-service-card span {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-top: -48px;
  margin-bottom: 18px;
  position: relative;
  background: var(--black);
  border: 1px solid var(--gold);
  color: var(--gold-2);
}
.home-service-card p {
  color: var(--text-muted);
  font-size: 14px;
}

.home-final-cta {
  position: relative;
  overflow: hidden;
  min-height: 420px;
  display: grid;
  grid-template-columns: 1fr minmax(auto, 580px);
  align-items: center;
  gap: 0;
  padding: 88px clamp(24px, 5vw, 80px);
  color: #fff;
  background: var(--black);
}
.home-final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, .06) 0%,
    rgba(0, 0, 0, .30) 32%,
    rgba(0, 0, 0, .88) 54%,
    rgba(0, 0, 0, .97) 100%
  );
}
.home-final-cta img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center left;
  opacity: .78;
}
.home-final-cta > div {
  position: relative;
  z-index: 2;
  grid-column: 2;
  width: 100%;
  padding-left: clamp(24px, 3vw, 56px);
  border-left: 2px solid rgba(201, 164, 90, .38);
}
.home-final-cta p {
  max-width: 500px;
  color: rgba(255, 255, 255, .82);
}

.section {
  padding: clamp(64px, 8vw, 120px) clamp(18px, 4vw, 64px);
}
.section-row {
  width: min(1280px, 100%);
  margin: 0 auto 40px;
  display: grid;
  grid-template-columns: 1.15fr minmax(260px, .85fr) auto;
  align-items: end;
  gap: 28px;
}
.section-row > p {
  max-width: 560px;
  color: var(--text-muted);
}
.luxury-services {
  background:
    linear-gradient(120deg, color-mix(in srgb, var(--surface) 90%, transparent), color-mix(in srgb, var(--section-bg) 88%, transparent)),
    var(--section-bg);
  color: var(--text);
}
.service-grid {
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 20px;
}
.service-card,
.route-card,
.review-card,
.card {
  position: relative;
  overflow: hidden;
  background: var(--surface);
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  box-shadow: 0 16px 44px rgba(38, 30, 19, .08);
}
.service-card img {
  width: 100%;
  height: 176px;
  object-fit: cover;
}
.service-badge {
  position: absolute;
  top: 150px;
  left: 22px;
  display: grid;
  place-items: center;
  width: 48px;
  height: 48px;
  background: var(--black);
  border: 1px solid var(--gold);
  color: var(--gold-2);
}
.card-body { padding: 30px 24px 26px; }
.service-card p,
.card p {
  color: var(--text-muted);
  font-size: 14px;
}
.text-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #9f7630;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.fleet-showcase {
  background:
    linear-gradient(135deg, rgba(255,255,255,.04), transparent),
    var(--black);
  color: #fff;
}
.fleet-showcase .section-row > p { color: rgba(255, 255, 255, .72); }
.fleet-grid {
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
.fleet-card {
  position: relative;
  padding: 30px;
  background: linear-gradient(145deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .015));
  border: 1px solid rgba(255, 255, 255, .14);
  box-shadow: var(--dark-shadow);
}
.fleet-card.is-featured {
  border-color: rgba(237, 207, 135, .78);
}
.popular-tag {
  position: absolute;
  top: 0;
  left: 24px;
  transform: translateY(-50%);
  padding: 8px 14px;
  background: var(--gold-2);
  color: #171511;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.fleet-card h3 {
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: .24em;
  text-align: center;
  text-transform: uppercase;
}
.fleet-card img {
  width: 100%;
  height: 230px;
  object-fit: contain;
  padding: 14px 0;
}
.fleet-card p {
  color: rgba(255, 255, 255, .7);
  font-size: 14px;
}
.fleet-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
  padding-top: 22px;
  border-top: 1px solid var(--dark-line);
}
.fleet-meta span {
  color: rgba(255, 255, 255, .72);
  font-size: 13px;
}
.fleet-meta i {
  margin-right: 8px;
  color: var(--gold-2);
}
.fleet-meta strong { color: #fff; }

.route-section {
  background: var(--section-bg);
  color: var(--text);
}
.route-grid {
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
}
.route-card img {
  width: 100%;
  height: 145px;
  object-fit: cover;
}
.route-card div { padding: 18px; }
.route-card h3 {
  margin-bottom: 4px;
  font-size: 22px;
}
.route-card p {
  margin-bottom: 6px;
  color: var(--text-muted);
  font-size: 13px;
}
.route-card a {
  color: var(--text);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.review-section {
  background:
    linear-gradient(rgba(8, 8, 7, .94), rgba(8, 8, 7, .96)),
    var(--black);
  color: #fff;
}
.review-section .section-row > p { color: rgba(255, 255, 255, .76); }
.rating-line span,
.stars {
  color: var(--gold-2);
  letter-spacing: .12em;
}
.review-grid {
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
.review-card {
  padding: 30px;
  background: linear-gradient(145deg, rgba(255, 255, 255, .07), rgba(255, 255, 255, .025));
  border-color: rgba(255, 255, 255, .14);
}
.review-card p {
  color: rgba(255, 255, 255, .82);
  font-size: 16px;
}
.review-card small {
  display: block;
  color: var(--gold-2);
}
.review-logos {
  width: min(900px, 100%);
  margin: 34px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 26px;
  color: rgba(255, 255, 255, .42);
  font-size: 20px;
  font-weight: 800;
}

.final-cta {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr minmax(280px, 420px) auto;
  gap: 28px;
  align-items: center;
  min-height: 260px;
  padding: 56px clamp(18px, 4vw, 64px);
  color: #fff;
  background: var(--black);
}
.final-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(0,0,0,.94), rgba(0,0,0,.62), rgba(0,0,0,.92));
}
.final-cta img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .62;
}
.final-cta > *:not(img) {
  position: relative;
  z-index: 2;
}
.final-cta p {
  max-width: 430px;
  color: rgba(255, 255, 255, .78);
}

.hero,
.section.dark,
.section.cream {
  color: inherit;
}
.hero {
  min-height: 620px;
  display: grid;
  align-items: end;
  position: relative;
  overflow: hidden;
  color: #fff;
  background: #0a0a09;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.32), rgba(0,0,0,.72));
}
.hero img.bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-inner {
  position: relative;
  z-index: 2;
  width: min(1180px, 100%);
  padding: 90px clamp(18px, 4vw, 64px);
}
.grid { display: grid; gap: 24px; }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.section.dark { background: var(--black); color: #fff; }
.section.cream { background: var(--cream); }
.section-head {
  width: min(900px, 100%);
  margin-bottom: 34px;
}
.card img {
  width: 100%;
  height: 240px;
  object-fit: cover;
}
.vehicle-card img {
  height: 220px;
  object-fit: contain;
  background: linear-gradient(140deg, #111, #282828);
  padding: 18px;
}
.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  margin-top: -46px;
  position: relative;
  z-index: 3;
}
.trust-strip div {
  background: #111;
  color: #fff;
  padding: 22px;
}
.trust-strip strong {
  color: var(--gold-2);
  display: block;
  font-size: 22px;
}

.price-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  box-shadow: var(--shadow);
}
.price-table th,
.price-table td {
  padding: 16px;
  border-bottom: 1px solid #ece7dd;
  text-align: left;
}
.price-table th {
  background: #111;
  color: var(--gold-2);
}
.section-note {
  max-width: 980px;
  margin-top: 24px;
  padding: 22px;
  background: rgba(255, 255, 255, .72);
  border: 1px solid rgba(20, 18, 14, .08);
}
.service-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.service-list span,
.booking-guidance {
  background: #fff;
  border: 1px solid rgba(20, 18, 14, .08);
  padding: 14px 16px;
}
.booking-guidance {
  margin-bottom: 24px;
}
.booking-guidance h2 {
  font-size: 30px;
}
.booking-guidance ul {
  columns: 2;
  padding-left: 20px;
  margin: 0;
}
.form-panel {
  background: #fff;
  box-shadow: var(--shadow);
  padding: 28px;
  border: 1px solid rgba(0,0,0,.06);
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.form-grid .full { grid-column: 1 / -1; }
label {
  display: block;
  font-weight: 700;
  margin-bottom: 6px;
}
input,
select,
textarea {
  width: 100%;
  min-height: 46px;
  border: 1px solid #d7cfbf;
  padding: 11px 12px;
  font: inherit;
  background: #fff;
  color: var(--ink);
  border-radius: 0;
}
textarea {
  min-height: 130px;
  resize: vertical;
}
.alert {
  padding: 14px 16px;
  margin-bottom: 18px;
}
.alert.success { background: #eaf7ee; color: #155724; }
.alert.error { background: #fff0f0; color: #8a1f1f; }
.hidden-field {
  position: absolute;
  left: -10000px;
}
.contact-list {
  display: grid;
  gap: 14px;
  margin-top: 18px;
}
.contact-list a,
.contact-list div {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px;
  background: #fff;
  border: 1px solid #eadfca;
}
.contact-list i {
  color: var(--gold);
  margin-top: 4px;
}
#contact-map {
  width: 100%;
  min-height: 420px;
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid rgba(0,0,0,.08);
}
.gallery-grid {
  columns: 3 260px;
  column-gap: 18px;
}
.gallery-grid img {
  width: 100%;
  margin: 0 0 18px;
  box-shadow: var(--shadow);
}

/* Site-wide polish for the public pages */
main > .section:first-child {
  padding-top: clamp(132px, 13vw, 178px);
}
.hero {
  min-height: 520px;
  border-bottom: 1px solid var(--line);
}
.hero::before {
  background:
    linear-gradient(90deg, rgba(0,0,0,.86), rgba(0,0,0,.44), rgba(0,0,0,.68)),
    radial-gradient(circle at 28% 38%, rgba(237, 207, 135, .12), transparent 24%);
}
.hero-inner {
  max-width: 1180px;
  padding-top: clamp(138px, 13vw, 180px);
  padding-bottom: clamp(68px, 8vw, 104px);
}
.hero-inner h1 {
  max-width: 780px;
}
.hero .lead {
  max-width: 760px;
}
.section {
  background: var(--section-bg);
  color: var(--text);
}
.section.cream {
  background: var(--surface-2);
}
.section.dark {
  background:
    linear-gradient(135deg, rgba(255,255,255,.035), transparent),
    var(--black);
  color: #fff;
}
.section.dark .section-head p,
.section.dark p {
  color: rgba(255, 255, 255, .78);
}
.section-head {
  max-width: 980px;
}
.grid.three {
  align-items: stretch;
}
.card,
.form-panel,
.price-table,
.service-list span,
.booking-guidance,
.section-note {
  background: var(--surface);
  color: var(--text);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  box-shadow: 0 18px 44px rgba(16, 12, 8, .1);
}
.card {
  display: flex;
  flex-direction: column;
}
.card img {
  height: 220px;
}
.card-body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 10px;
  padding: 28px;
}
.card-body h2,
.card-body h3 {
  margin-bottom: 4px;
}
.card p,
.card-body p,
.section-head p,
.section-row > p {
  color: var(--text-muted);
}
.card .btn {
  margin-top: auto;
}
.vehicle-card {
  border-color: color-mix(in srgb, var(--gold) 34%, transparent);
}
.vehicle-card img {
  height: 240px;
  background:
    radial-gradient(circle at 50% 50%, rgba(237,207,135,.08), transparent 48%),
    linear-gradient(145deg, #070807, #1f211f);
}
.vehicle-card .card-body p:last-of-type {
  padding: 16px;
  background: color-mix(in srgb, var(--surface-2) 78%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}
.price-table {
  overflow: hidden;
}
.price-table th {
  background: var(--black);
  color: var(--gold-2);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.price-table td {
  color: var(--text);
}
.section-note {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  max-width: none;
}
.prices-copy {
  grid-template-columns: 1fr;
  max-width: 1080px;
  padding: clamp(24px, 4vw, 42px);
  font-size: clamp(17px, 1.5vw, 21px);
}
.prices-copy p:last-child {
  margin-bottom: 0;
}
.service-list span {
  display: flex;
  align-items: center;
  min-height: 58px;
  font-weight: 700;
}
.service-list span::before {
  content: "";
  width: 7px;
  height: 7px;
  margin-right: 10px;
  background: var(--gold);
}
.gallery-grid {
  width: min(1180px, 100%);
  margin: 0 auto;
  columns: 3 300px;
  column-gap: 22px;
}
.gallery-grid img {
  margin-bottom: 22px;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
}
.form-panel {
  width: min(980px, 100%);
}
.grid.two .form-panel {
  width: 100%;
}
label {
  color: var(--text);
}
input,
select,
textarea {
  background: var(--field-bg);
  color: var(--field-text);
  border-color: color-mix(in srgb, var(--line) 72%, #bdb4a6);
}
input:focus,
select:focus,
textarea:focus {
  outline: 2px solid color-mix(in srgb, var(--gold) 55%, transparent);
  outline-offset: 2px;
}
.contact-list a,
.contact-list div {
  background: var(--surface);
  color: var(--text);
  border-color: color-mix(in srgb, var(--line) 70%, transparent);
}
.booking-guidance h2 {
  font-size: clamp(26px, 3vw, 36px);
}
.booking-guidance li {
  margin-bottom: 6px;
}
.site-footer {
  background:
    linear-gradient(135deg, rgba(255,255,255,.035), transparent 36%),
    #050505;
}
.footer-grid {
  grid-template-columns: minmax(250px, 1.35fr) repeat(3, minmax(170px, .75fr));
  max-width: 1360px;
  margin: 0 auto;
}
.footer-bottom {
  text-align: center;
}

.site-footer {
  background: #050505;
  color: rgba(255, 255, 255, .78);
  border-top: 1px solid var(--line);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 36px;
  padding: 54px clamp(18px, 4vw, 64px);
}
.site-footer h3 {
  font-family: var(--sans);
  color: var(--gold-2);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.site-footer p,
.site-footer a {
  color: rgba(255, 255, 255, .72);
  font-size: 14px;
}
.footer-brand p { max-width: 330px; margin-top: 18px; }
.social-links {
  display: flex;
  gap: 10px;
  margin-top: 18px;
}
.social-links a {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--dark-line);
  color: #fff;
}
.footer-bottom {
  padding: 18px clamp(18px, 4vw, 64px);
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255, 255, 255, .46);
  text-align: center;
  font-size: 13px;
}
.mobile-actions { display: none; }

@media (max-width: 1160px) {
  .service-grid,
  .route-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .quote-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .final-cta {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .site-header {
    min-height: 66px;
    padding: 0 16px;
    gap: 12px;
  }
  .nav-toggle { display: grid; }
  .header-right .header-phone-num { display: none; }
  .header-right .nav-cta { display: none; } /* appears inside mobile nav */
  .theme-menu { display: none; }
  .site-nav {
    display: none;
    position: fixed;
    left: 0; right: 0;
    top: 66px;
    padding: 18px 20px 24px;
    background: rgba(5,7,8,.99);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(201,164,90,.18);
    flex-direction: column;
    align-items: stretch;
    z-index: 95;
    max-height: calc(100dvh - 66px);
    overflow-y: auto;
    overflow-x: hidden;
    overscroll-behavior: contain;
  }
  .site-nav.is-open { display: flex; }
  .site-nav a { padding: 13px 0; border-bottom: 1px solid rgba(255,255,255,.07) !important; font-size: 14px; }
  .site-nav a::after { display: none !important; }
  .site-nav a.is-active, .site-nav a:hover { border-bottom-color: var(--gold-2) !important; }
  .mobile-nav-footer {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid rgba(255,255,255,.1);
  }
  .mobile-nav-phone {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--gold-2) !important;
    font-size: 16px;
    font-weight: 700;
    text-decoration: none;
    padding: 10px 0;
  }
  .mobile-nav-phone i { color: var(--gold); }
  .mobile-nav-footer .nav-cta {
    display: flex;
    width: 100%;
    justify-content: center;
    min-height: 50px;
  }
  .mobile-theme-panel {
    display: grid;
    gap: 10px;
    padding: 12px 0 4px;
    color: color-mix(in srgb, var(--header-text) 76%, transparent);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
  }
  .mobile-theme-options {
    display: grid;
    grid-template-columns: 1fr;
    gap: 7px;
  }
  .mobile-theme-options button {
    color: var(--header-text);
    border-color: rgba(255,255,255,.08);
    background: rgba(255,255,255,.035);
  }

  .home-hero { min-height: auto; }
  .home-hero-inner { min-height: auto; }
  .home-hero-inner {
    grid-template-columns: 1fr;
    align-items: start;
    padding: 98px 18px 42px;
    gap: 34px;
  }
  .mock-hero .home-hero-inner { padding-top: 98px; }
  .home-hero-copy h1 { font-size: clamp(40px, 12vw, 64px); }
  .mock-hero h1 { font-size: clamp(42px, 12vw, 66px); }
  .home-quote-panel {
    max-width: 560px;
    padding: 26px 22px;
  }
  .trust-band,
  .home-trust-strip,
  .section-row,
  .fleet-grid,
  .review-grid,
  .benefit-grid,
  .home-service-grid,
  .split-head,
  .grid.three,
  .grid.two,
  .footer-grid,
  .trust-strip,
  .form-grid,
  .service-list {
    grid-template-columns: 1fr;
  }
  .section-row { align-items: start; }
  .service-grid,
  .route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .quote-grid {
    grid-template-columns: 1fr;
  }
  .quote-grid label:nth-child(1),
  .quote-grid label:nth-child(2) {
    grid-column: auto;
  }
  .quote-submit {
    width: 100%;
  }
  .fleet-card img { height: 190px; }
  .hero { min-height: 560px; }
  .mobile-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 70;
  }
  .mobile-actions a {
    background: var(--gold);
    color: #111;
    text-align: center;
    padding: 13px;
    font-weight: 900;
    border-right: 1px solid rgba(0,0,0,.2);
  }
  body { padding-bottom: 50px; }
  .theme-picker {
    right: 18px;
    bottom: 62px;
  }
  .price-table {
    display: block;
    overflow-x: auto;
  }
}

@media (max-width: 620px) {
  .brand-text { font-size: 11px; }
  .brand-text small { font-size: 8px; }
  .brand-mark {
    width: 38px;
    height: 38px;
  }
  .form-split,
  .service-grid,
  .route-grid,
  .home-service-grid {
    grid-template-columns: 1fr;
  }
  .booking-guidance ul { columns: 1; }
  .home-service-card img { height: 210px; }
  .home-trust-strip div { padding: 20px 18px; }
  .quote-panel,
  .home-quote-panel { padding: 22px; }
  .home-hero-inner {
    padding-left: 18px;
    padding-right: 18px;
  }
  .mock-proof {
    max-width: 220px;
  }
  .service-card img,
  .route-card img { height: 210px; }
  .section { padding: 58px 18px; }
  .footer-grid { padding: 42px 18px; }
}

/* ─────────────────────────────────────────────────────────────
   STICKY HEADER — becomes solid when scrolled
   ──────────────────────────────────────────────────────────── */
.site-header.is-scrolled {
  background: rgba(5, 7, 8, .97);
  backdrop-filter: blur(14px);
  box-shadow: 0 2px 28px rgba(0,0,0,.42);
  min-height: 68px;
  border-bottom: 1px solid rgba(201,164,90,.14);
}

/* ─────────────────────────────────────────────────────────────
   HOMEPAGE FLEET PREVIEW SECTION
   ──────────────────────────────────────────────────────────── */
.home-fleet {
  background:
    linear-gradient(135deg, rgba(255,255,255,.032), transparent 40%),
    var(--black);
  color: #fff;
  border-top: 1px solid rgba(201,164,90,.22);
}
.home-fleet-inner {
  width: min(1220px, 100%);
  margin: 0 auto;
}
.home-fleet-head {
  text-align: center;
  margin-bottom: 52px;
}
.home-fleet-head > p:not(.eyebrow) {
  color: rgba(255,255,255,.68);
  max-width: 540px;
  margin: 0 auto;
  font-size: 17px;
}
.home-fleet-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px;
  margin-bottom: 44px;
}
.home-fleet-card {
  background: linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.018));
  border: 1px solid rgba(255,255,255,.13);
  overflow: hidden;
  transition: border-color .22s, box-shadow .22s;
}
.home-fleet-card:hover {
  border-color: rgba(201,164,90,.55);
  box-shadow: 0 20px 56px rgba(0,0,0,.38);
}
.home-fleet-card-img {
  width: 100%;
  height: 220px;
  object-fit: contain;
  background: linear-gradient(150deg, #0c0d0b, #1e211e);
  padding: 20px;
  display: block;
}
.home-fleet-body {
  padding: 22px 24px 28px;
  border-top: 1px solid rgba(255,255,255,.09);
}
.home-fleet-name {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold-2);
  margin: 0 0 12px;
}
.home-fleet-meta {
  display: flex;
  gap: 22px;
  margin-bottom: 14px;
  color: rgba(255,255,255,.58);
  font-size: 13px;
}
.home-fleet-meta i {
  color: var(--gold-2);
  margin-right: 5px;
}
.home-fleet-desc {
  color: rgba(255,255,255,.65);
  font-size: 14px;
  line-height: 1.6;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.home-fleet-actions {
  display: flex;
  justify-content: center;
  gap: 16px;
}
@media (max-width: 900px) {
  .home-fleet-grid { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
  .home-fleet-actions { flex-direction: column; align-items: center; }
  .home-fleet-actions .btn { width: 100%; max-width: 320px; justify-content: center; }
}

/* ─────────────────────────────────────────────────────────────
   HOME PAGE SECTION REFINEMENTS
   ──────────────────────────────────────────────────────────── */

/* Give the intro section a clean top boundary */
.home-intro {
  border-top: 1px solid color-mix(in srgb, var(--line) 55%, transparent);
}

/* Differentiate services section from intro */
.home-services {
  background: var(--surface-2);
  border-top: 1px solid color-mix(in srgb, var(--line) 45%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 45%, transparent);
}

/* Service card icon badge overlay */
.home-service-card span {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-top: -48px;
  margin-bottom: 16px;
  position: relative;
  background: var(--black);
  border: 1px solid var(--gold);
  color: var(--gold-2);
  box-shadow: 0 4px 18px rgba(0,0,0,.35);
}

/* Stronger text-link on service cards */
.text-link {
  color: var(--gold);
  transition: color .18s, gap .18s;
}
.text-link:hover {
  color: var(--gold-2);
  gap: 12px;
}

/* Hero: add gold radial glow for polish */
.home-hero.mock-hero::after {
  background: linear-gradient(180deg, transparent 60%, rgba(5,7,8,.88));
}

/* Trust strip: stronger dividers */
.home-trust-strip {
  border-top: 1px solid rgba(201,164,90,.28);
  border-bottom: 1px solid rgba(201,164,90,.18);
}
.home-trust-strip div:last-child {
  border-right: none;
}

/* Final CTA: right-aligned — responsive collapse */
.home-final-cta h2 {
  font-size: clamp(30px, 3.6vw, 52px);
  line-height: 1.05;
}
@media (max-width: 900px) {
  .home-final-cta {
    grid-template-columns: 1fr;
    padding: 64px clamp(18px, 4vw, 40px);
    min-height: auto;
  }
  .home-final-cta > div {
    grid-column: 1;
    padding-left: 0;
    border-left: none;
    border-top: 2px solid rgba(201, 164, 90, .38);
    padding-top: 28px;
  }
  .home-final-cta::before {
    background: linear-gradient(
      180deg,
      rgba(0,0,0,.22) 0%,
      rgba(0,0,0,.82) 52%,
      rgba(0,0,0,.96) 100%
    );
  }
}

/* Intro heading improvement */
.home-intro-copy h2 {
  line-height: 1.06;
}

/* ─────────────────────────────────────────────────────────────
   CARD GLOBAL HOVER (services, fleet, gallery)
   ──────────────────────────────────────────────────────────── */
.card {
  transition: box-shadow .25s, transform .25s;
}
.card:hover {
  box-shadow: 0 24px 60px rgba(16, 12, 8, .16);
  transform: translateY(-4px);
}

/* ─────────────────────────────────────────────────────────────
   GALLERY PAGE
   ──────────────────────────────────────────────────────────── */
.gallery-item {
  overflow: hidden;
  break-inside: avoid;
  margin-bottom: 22px;
}
.gallery-item img {
  width: 100%;
  display: block;
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  box-shadow: 0 8px 28px rgba(16,12,8,.10);
  transition: transform .4s ease, box-shadow .4s ease;
}
.gallery-item:hover img {
  transform: scale(1.03);
  box-shadow: 0 16px 48px rgba(16,12,8,.18);
}

/* ─────────────────────────────────────────────────────────────
   BOOKING PAGE — TWO COLUMN LAYOUT
   ──────────────────────────────────────────────────────────── */
.booking-layout {
  display: grid;
  grid-template-columns: minmax(260px, 340px) 1fr;
  gap: 36px;
  width: min(1120px, 100%);
  margin: 0 auto;
  align-items: start;
}
.booking-sidebar {
  position: sticky;
  top: 100px;
}
.booking-guidance {
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  box-shadow: 0 8px 28px rgba(16,12,8,.07);
  padding: 26px 28px;
  margin-bottom: 18px;
}
.booking-guidance h2 {
  font-size: clamp(20px, 2.2vw, 26px);
  margin-bottom: 16px;
  line-height: 1.15;
}
.booking-guidance ul {
  margin: 0;
  padding-left: 0;
  list-style: none;
}
.booking-guidance li {
  padding: 8px 0 8px 18px;
  position: relative;
  font-size: 14px;
  color: var(--text-muted);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 50%, transparent);
}
.booking-guidance li:last-child { border-bottom: none; }
.booking-guidance li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  background: var(--gold);
  border-radius: 50%;
}
.booking-trust {
  display: grid;
  gap: 10px;
}
.booking-trust div {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}
.booking-trust i { color: var(--gold); font-size: 16px; }
.booking-main .form-panel {
  width: 100%;
}
@media (max-width: 900px) {
  .booking-layout {
    grid-template-columns: 1fr;
  }
  .booking-sidebar {
    position: static;
  }
  .booking-guidance ul { columns: 1; }
}

/* ─────────────────────────────────────────────────────────────
   LEGAL PAGES (Privacy, Terms)
   ──────────────────────────────────────────────────────────── */
.legal-content {
  max-width: 840px;
  margin: 0 auto;
  font-size: clamp(15px, 1.4vw, 17px);
  line-height: 1.8;
}
.legal-content p {
  margin-bottom: 22px;
  color: var(--text);
}
.legal-content a {
  color: var(--gold);
  text-decoration: underline;
}
.legal-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 38px;
  padding-top: 30px;
  border-top: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}

/* ─────────────────────────────────────────────────────────────
   PRICE TABLE PAGE
   ──────────────────────────────────────────────────────────── */
.price-table-wrap {
  overflow-x: auto;
  box-shadow: var(--shadow);
}
.price-table td:last-child {
  font-size: 13px;
  color: var(--text-muted);
  max-width: 280px;
}
.price-table tr:last-child td {
  border-bottom: none;
}

/* ─────────────────────────────────────────────────────────────
   HEADER: SCROLLED STATE (sticky)
   ──────────────────────────────────────────────────────────── */
.site-header.is-scrolled .brand-mark,
.site-header.is-scrolled .brand-text {
  color: #fff;
}

/* ─────────────────────────────────────────────────────────────
   ADDITIONAL RESPONSIVE RULES
   ──────────────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .legal-cta { flex-direction: column; }
  .legal-cta .btn { width: 100%; justify-content: center; }
}
@media (max-width: 620px) {
  .home-service-card img { height: 210px; }
}

/* ═══════════════════════════════════════════════════════════════
   PREMIUM REDESIGN — Complete visual overhaul
   ═══════════════════════════════════════════════════════════ */

/* ── TRUST STRIP: Premium redesign ─────────────────────────── */
.home-trust-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: #080807;
  border-top: 2px solid var(--gold);
  border-bottom: 1px solid rgba(201, 164, 90, .12);
}
.home-trust-strip div {
  min-height: 152px;
  padding: 36px clamp(18px, 3vw, 52px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-right: 1px solid rgba(255, 255, 255, .06);
  position: relative;
  transition: background .28s;
}
.home-trust-strip div:hover { background: rgba(201, 164, 90, .04); }
.home-trust-strip div:last-child { border-right: none; }
.home-trust-strip i {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  flex-shrink: 0;
  border: 1px solid rgba(201, 164, 90, .30);
  border-radius: 50%;
  color: var(--gold);
  font-size: 18px;
  margin-bottom: 16px;
  transition: border-color .28s, background .28s;
}
.home-trust-strip div:hover i {
  border-color: var(--gold);
  background: rgba(201, 164, 90, .08);
}
.home-trust-strip strong {
  display: block;
  font-family: var(--serif);
  font-size: clamp(22px, 2.4vw, 36px);
  font-weight: 600;
  font-style: italic;
  color: #ffffff;
  line-height: 1.05;
  letter-spacing: .01em;
  margin-bottom: 9px;
  text-transform: none;
}
.home-trust-strip span {
  display: block;
  color: var(--gold);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  line-height: 1.4;
}

/* ── HOMEPAGE: INTRO SECTION ────────────────────────────────── */
.home-intro {
  background: var(--ivory);
  border-top: 1px solid color-mix(in srgb, var(--line) 50%, transparent);
}
.home-intro-copy {
  max-width: 860px;
  margin: 0 auto 52px;
  text-align: center;
}
.home-intro-copy h2 {
  font-size: clamp(34px, 4.4vw, 60px);
  line-height: 1.04;
  margin-bottom: 22px;
}
.home-intro-copy p {
  font-size: clamp(16px, 1.4vw, 19px);
  color: var(--text-muted);
  line-height: 1.72;
  margin: 0;
}

/* ── HOMEPAGE: SERVICES SECTION ─────────────────────────────── */
.home-services {
  background: var(--surface-2);
  border-top: 1px solid color-mix(in srgb, var(--line) 42%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 42%, transparent);
}
.home-service-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
.home-service-card {
  overflow: hidden;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  box-shadow: 0 6px 24px rgba(16, 12, 8, .07);
  transition: transform .26s, box-shadow .26s;
  display: flex;
  flex-direction: column;
}
.home-service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 22px 56px rgba(16, 12, 8, .14);
}
.home-service-card img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  transition: transform .45s cubic-bezier(.4, 0, .2, 1);
}
.home-service-card:hover img { transform: scale(1.06); }
.home-service-card > div {
  padding: 22px 24px 28px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.home-service-card span {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-top: -48px;
  margin-bottom: 18px;
  position: relative;
  background: var(--black);
  border: 1px solid var(--gold);
  color: var(--gold-2);
  box-shadow: 0 4px 16px rgba(0, 0, 0, .34);
  flex-shrink: 0;
}
.home-service-card h3 {
  font-size: clamp(17px, 1.6vw, 22px);
  margin-bottom: 10px;
  line-height: 1.2;
}
.home-service-card p {
  color: var(--text-muted);
  font-size: 14px;
  line-height: 1.68;
  margin-bottom: 18px;
  flex: 1;
}
.home-service-card .text-link {
  margin-top: auto;
  font-size: 11px;
  letter-spacing: .14em;
}

/* ── INNER PAGE HERO ─────────────────────────────────────────── */
.hero {
  min-height: 580px;
  display: flex;
  align-items: flex-end;
  border-bottom: 1px solid rgba(201, 164, 90, .18);
}
.hero::before {
  background:
    linear-gradient(100deg, rgba(0,0,0,.90) 0%, rgba(0,0,0,.46) 46%, rgba(0,0,0,.72) 100%),
    radial-gradient(circle at 28% 40%, rgba(201,164,90,.1), transparent 30%);
}
.hero-inner {
  max-width: 1180px;
  padding-top: clamp(140px, 14vw, 200px);
  padding-bottom: clamp(64px, 7vw, 110px);
}
.hero-inner h1 {
  font-size: clamp(38px, 5.4vw, 72px);
  line-height: 1.03;
  max-width: 820px;
  margin-bottom: 22px;
}
.hero .lead {
  font-size: clamp(16px, 1.5vw, 20px);
  max-width: 680px;
  line-height: 1.66;
  margin-bottom: 32px;
}

/* ── SECTION TYPOGRAPHY ─────────────────────────────────────── */
.section-head h2 {
  font-size: clamp(28px, 3.5vw, 50px);
  line-height: 1.08;
  margin-bottom: 16px;
}
.section-head > p,
.split-head > p {
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.7;
  color: var(--text-muted);
}

/* ── FLEET CARDS (inner fleet page) ────────────────────────── */
.vehicle-card img {
  height: 260px;
  background:
    radial-gradient(circle at 50% 60%, rgba(201, 164, 90, .07), transparent 52%),
    linear-gradient(150deg, #060806, #1d201c);
}

/* ── CARD GLOBAL ─────────────────────────────────────────────── */
.card .card-body h2 {
  font-size: clamp(20px, 2vw, 28px);
  margin-bottom: 12px;
}
.card .card-body p {
  font-size: 14px;
  line-height: 1.68;
}

/* ── SERVICES PAGE: ADDITIONAL SERVICES LIST ────────────────── */
.service-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.service-list span {
  display: flex;
  align-items: center;
  min-height: 56px;
  padding: 14px 18px;
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  border-left: 3px solid var(--gold);
}
.service-list span::before { display: none; }

/* ── PRICES PAGE ─────────────────────────────────────────────── */
.price-table {
  font-size: 14px;
  box-shadow: 0 4px 28px rgba(16, 12, 8, .1);
}
.price-table thead th {
  padding: 16px 20px;
  font-size: 11px;
  letter-spacing: .14em;
}
.price-table td {
  padding: 15px 20px;
}
.price-table tbody tr:nth-child(even) td {
  background: color-mix(in srgb, var(--cream) 45%, transparent);
}
.price-table td:first-child { font-weight: 700; }
.price-table td:last-child {
  font-size: 13px;
  color: var(--text-muted);
  max-width: 260px;
}

/* ── GALLERY: NEW GRID + LIGHTBOX ───────────────────────────── */
.gallery-grid-new {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  width: min(1400px, 100%);
  margin: 0 auto;
}
.gallery-tile {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4 / 3;
  cursor: pointer;
  background: #0a0a08;
  border: none;
  padding: 0;
  display: block;
  outline: none;
}
.gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s cubic-bezier(.4, 0, .2, 1);
}
.gallery-tile:hover img { transform: scale(1.09); }
.gallery-tile-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(0, 0, 0, .82) 0%,
    rgba(0, 0, 0, .18) 55%,
    transparent 100%
  );
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding: 14px 16px;
  opacity: 0;
  transition: opacity .3s;
}
.gallery-tile:hover .gallery-tile-overlay,
.gallery-tile:focus .gallery-tile-overlay { opacity: 1; }
.gallery-tile-label {
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.gallery-tile-icon {
  color: var(--gold-2);
  font-size: 16px;
}
@media (max-width: 1100px) {
  .gallery-grid-new { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .gallery-grid-new { grid-template-columns: repeat(2, 1fr); gap: 4px; }
}
@media (max-width: 420px) {
  .gallery-grid-new { grid-template-columns: 1fr; gap: 3px; }
}

/* Lightbox */
.lb-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(3, 3, 2, .97);
  align-items: center;
  justify-content: center;
}
.lb-overlay.open { display: flex; }
.lb-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: min(1200px, 94vw);
  width: 100%;
  padding: 0 70px;
}
.lb-wrap img {
  max-height: 82vh;
  max-width: 100%;
  object-fit: contain;
  display: block;
  box-shadow: 0 32px 90px rgba(0, 0, 0, .7);
}
.lb-caption {
  margin-top: 16px;
  color: rgba(255, 255, 255, .5);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-align: center;
}
.lb-counter {
  color: rgba(255, 255, 255, .28);
  font-size: 11px;
  margin-top: 6px;
  letter-spacing: .08em;
}
.lb-close {
  position: fixed;
  top: 18px; right: 22px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .18);
  color: #fff;
  width: 46px; height: 46px;
  font-size: 26px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .18s;
  z-index: 9001;
  line-height: 1;
}
.lb-close:hover { background: rgba(201, 164, 90, .22); }
.lb-prev, .lb-next {
  position: fixed;
  top: 50%; transform: translateY(-50%);
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .12);
  color: #fff;
  width: 52px; height: 90px;
  font-size: 30px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .18s, border-color .18s;
  z-index: 9001;
}
.lb-prev:hover, .lb-next:hover {
  background: rgba(201, 164, 90, .18);
  border-color: rgba(201, 164, 90, .4);
}
.lb-prev { left: 12px; }
.lb-next { right: 12px; }
@media (max-width: 620px) {
  .lb-wrap { padding: 0 44px; }
  .lb-prev { left: 4px; width: 40px; }
  .lb-next { right: 4px; width: 40px; }
}

/* ── CONTACT PAGE ─────────────────────────────────────────────── */
.contact-map-wrap {
  width: 100%;
  overflow: hidden;
  position: relative;
  line-height: 0; /* remove inline-block gap under iframe */
}
.contact-map-wrap iframe,
.contact-map-wrap #contact-map {
  width: 100%;
  min-height: 480px;
  display: block;
  border: none;
  border: none;
}

/* ── BOOKING PAGE ────────────────────────────────────────────── */
.form-panel {
  background: var(--surface);
  border: 1px solid color-mix(in srgb, var(--line) 62%, transparent);
  box-shadow: 0 8px 36px rgba(16, 12, 8, .09);
  padding: 32px;
  border-radius: 0;
}

/* ── FOOTER POLISH ───────────────────────────────────────────── */
.site-footer h3 {
  font-size: 10px;
  letter-spacing: .22em;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  color: var(--gold-2);
}
.footer-brand .brand-text {
  color: #fff;
}
.footer-brand .brand-mark {
  border-color: var(--gold);
  color: var(--gold-2);
}

/* ── NAV: MOBILE FIX ─────────────────────────────────────────── */
@media (max-width: 900px) {
  .site-nav {
    font-size: 14px;
    gap: 0;
  }
  .site-nav a {
    padding: 14px 0;
    font-size: 14px;
    letter-spacing: .1em;
  }
  .site-nav .nav-cta {
    font-size: 13px;
    margin-left: 0;
    padding: 0 24px;
  }
}

/* ── RESPONSIVE: TRUST STRIP ─────────────────────────────────── */
@media (max-width: 900px) {
  .home-trust-strip {
    grid-template-columns: repeat(2, 1fr);
  }
  .home-trust-strip div:nth-child(2) { border-right: none; }
  .home-trust-strip div:nth-child(odd) { border-right: 1px solid rgba(255,255,255,.06); }
  .home-trust-strip div:nth-child(3),
  .home-trust-strip div:nth-child(4) {
    border-top: 1px solid rgba(255,255,255,.06);
  }
  .home-service-grid {
    grid-template-columns: 1fr;
  }
  .service-list {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 560px) {
  .home-trust-strip {
    grid-template-columns: 1fr 1fr;
  }
  .home-trust-strip div {
    min-height: 128px;
    padding: 24px 14px;
  }
  .home-trust-strip i { width: 42px; height: 42px; font-size: 15px; margin-bottom: 12px; }
  .home-service-card img { height: 220px; }
}

/* ═══════════════════════════════════════════════════════════════
   PHASE 2 — PREMIUM FEATURES
   ═══════════════════════════════════════════════════════════ */

/* ── HERO ENTRANCE ANIMATION ────────────────────────────────── */
@keyframes heroFadeUp {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: none; }
}
.home-hero-copy {
  animation: heroFadeUp .7s cubic-bezier(.16,1,.3,1) .05s both;
}
.home-quote-panel {
  animation: heroFadeUp .7s cubic-bezier(.16,1,.3,1) .2s both;
}

/* ── SCROLL REVEAL ──────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .52s cubic-bezier(.4,0,.2,1), transform .52s cubic-bezier(.4,0,.2,1);
}
.reveal.is-visible { opacity: 1; transform: none; }
.reveal-d1 { transition-delay: .06s; }
.reveal-d2 { transition-delay: .12s; }
.reveal-d3 { transition-delay: .18s; }
.reveal-d4 { transition-delay: .24s; }

/* sticky-bar removed — header itself is permanently fixed */

/* ── WHATSAPP FLOATING BUTTON ───────────────────────────────── */
.whatsapp-float {
  position: fixed;
  bottom: 88px; right: 20px;
  z-index: 70;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  box-shadow: 0 6px 24px rgba(37,211,102,.45);
  text-decoration: none;
  transition: transform .22s, box-shadow .22s;
}
.whatsapp-float:hover {
  transform: scale(1.12);
  box-shadow: 0 10px 36px rgba(37,211,102,.6);
}
.whatsapp-float-tooltip {
  position: absolute;
  right: 64px;
  background: rgba(5,7,8,.94);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
  padding: 7px 12px;
  border: 1px solid rgba(255,255,255,.1);
  opacity: 0;
  pointer-events: none;
  transform: translateX(8px);
  transition: opacity .2s, transform .2s;
}
.whatsapp-float:hover .whatsapp-float-tooltip {
  opacity: 1;
  transform: none;
}
@media (max-width: 900px) {
  .whatsapp-float { bottom: 72px; right: 12px; width: 50px; height: 50px; font-size: 24px; }
  .whatsapp-float-tooltip { display: none; }
}

/* ── FOOTER CTA BAND ────────────────────────────────────────── */
.footer-cta {
  padding: clamp(56px,7vw,100px) clamp(18px,4vw,64px);
  background:
    linear-gradient(135deg, rgba(201,164,90,.07), rgba(201,164,90,.02) 60%, transparent),
    #080806;
  border-top: 1px solid rgba(201,164,90,.22);
  border-bottom: 1px solid rgba(201,164,90,.1);
  text-align: center;
  color: #fff;
}
.footer-cta h2 {
  font-size: clamp(28px,3.8vw,54px);
  line-height: 1.06;
  margin-bottom: 16px;
}
.footer-cta > p {
  color: rgba(255,255,255,.58);
  font-size: clamp(15px,1.4vw,17px);
  max-width: 520px;
  margin: 0 auto 34px;
  line-height: 1.65;
}
.footer-cta .actions { justify-content: center; }

/* ── WHY CHOOSE US SPLIT SECTION ────────────────────────────── */
.why-us { background: var(--ivory); }
.why-us-inner {
  max-width: 1180px;
  margin: 0 auto;
}
.why-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(36px,5vw,88px);
  align-items: center;
  margin-bottom: clamp(60px,8vw,110px);
}
.why-row:last-child { margin-bottom: 0; }
.why-row.reverse .why-img   { order: 2; }
.why-row.reverse .why-content { order: 1; }
.why-img {
  position: relative;
  overflow: hidden;
  aspect-ratio: 4/3;
  box-shadow: 0 24px 64px rgba(16,12,8,.16);
}
.why-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s ease;
}
.why-img::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid rgba(201,164,90,.24);
  pointer-events: none;
}
.why-row:hover .why-img img { transform: scale(1.05); }
.why-content h2 {
  font-size: clamp(26px,3.2vw,44px);
  line-height: 1.08;
  margin-bottom: 16px;
}
.why-content > p {
  color: var(--text-muted);
  font-size: clamp(15px,1.3vw,17px);
  line-height: 1.72;
  margin-bottom: 24px;
}
.why-list {
  list-style: none;
  margin: 0 0 32px;
  padding: 0;
  display: grid;
  gap: 0;
}
.why-list li {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  padding: 12px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 44%, transparent);
}
.why-list li:last-child { border-bottom: none; }
.why-list li::before {
  content: '';
  width: 22px; height: 22px;
  flex-shrink: 0;
  border-radius: 50%;
  background: color-mix(in srgb, var(--gold) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--gold) 42%, transparent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23c9a45a' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 12px;
  background-repeat: no-repeat;
  background-position: center;
}
@media (max-width: 900px) {
  .why-row, .why-row.reverse {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .why-row.reverse .why-img, .why-row.reverse .why-content { order: unset; }
}

/* ── FLEET TAB SWITCHER (homepage) ──────────────────────────── */
.fleet-tabs {
  display: inline-flex;
  border: 1px solid rgba(255,255,255,.14);
  padding: 4px;
  gap: 3px;
  margin-bottom: 44px;
}
.fleet-tab {
  background: transparent;
  border: none;
  color: rgba(255,255,255,.48);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 12px 30px;
  cursor: pointer;
  transition: background .2s, color .2s;
  white-space: nowrap;
}
.fleet-tab:hover:not(.active) { background: rgba(255,255,255,.06); color: rgba(255,255,255,.76); }
.fleet-tab.active { background: var(--gold); color: #111; }
.fleet-panel {
  display: none;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px,4vw,64px);
  align-items: center;
  background: linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.016));
  border: 1px solid rgba(255,255,255,.12);
  padding: clamp(28px,4vw,56px);
  animation: panelIn .42s cubic-bezier(.4,0,.2,1);
}
.fleet-panel.active { display: grid; }
@keyframes panelIn {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: none; }
}
.fleet-panel-img img {
  width: 100%;
  object-fit: contain;
  background: linear-gradient(150deg, #06080, #1a1d1a);
  padding: 24px;
  display: block;
  background: linear-gradient(150deg, #060806, #1c1e1a);
}
.fleet-panel-badge {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
  border: 1px solid rgba(201,164,90,.32);
  display: inline-block;
  padding: 4px 10px;
  margin-bottom: 16px;
}
.fleet-panel-name {
  font-size: clamp(22px,2.8vw,34px);
  font-family: var(--serif);
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  margin-bottom: 16px;
}
.fleet-panel-desc {
  color: rgba(255,255,255,.68);
  font-size: 15px;
  line-height: 1.68;
  margin-bottom: 24px;
}
.fleet-panel-specs {
  display: flex;
  gap: 24px;
  margin-bottom: 28px;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,.1);
  flex-wrap: wrap;
}
.fleet-panel-specs span {
  color: rgba(255,255,255,.58);
  font-size: 13px;
  font-weight: 600;
}
.fleet-panel-specs i { color: var(--gold-2); margin-right: 6px; }
@media (max-width: 900px) {
  .fleet-panel { grid-template-columns: 1fr; gap: 24px; }
  .fleet-tabs { display: flex; width: 100%; }
  .fleet-tab { flex: 1; padding: 10px 12px; font-size: 10px; }
}

/* ── MULTI-STEP BOOKING FORM ────────────────────────────────── */
.booking-steps {
  display: flex;
  align-items: center;
  margin-bottom: 32px;
  padding-bottom: 24px;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
  gap: 0;
}
.booking-step-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}
.booking-step-item.active { color: var(--text); }
.booking-step-item.done   { color: var(--gold); }
.booking-step-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 2px solid currentColor;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
  flex-shrink: 0;
}
.booking-step-item.active .booking-step-num,
.booking-step-item.done   .booking-step-num {
  background: var(--gold);
  border-color: var(--gold);
  color: #111;
}
.booking-step-line {
  flex: 1;
  height: 1px;
  background: color-mix(in srgb, var(--line) 64%, transparent);
  margin: 0 10px;
}
.booking-step-line.done { background: var(--gold); }
.booking-form-step { display: none; }
.booking-form-step.active { display: block; }
.booking-form-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}
.booking-step-back {
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  color: var(--text-muted);
}
.booking-step-back:hover { color: var(--text); }
@media (max-width: 540px) {
  .booking-step-item span:not(.booking-step-num) { display: none; }
  .booking-step-line { margin: 0 6px; }
}

/* ── MOBILE ACTIONS — Gold style ────────────────────────────── */
.mobile-actions a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.mobile-actions a:last-child {
  background: #25D366;
  border-right: none;
}

/* ── FORM FIELD ERROR STATE ─────────────────────────────────── */
input.field-error,
select.field-error,
textarea.field-error {
  border-color: #dc2626 !important;
  box-shadow: 0 0 0 3px rgba(220,38,38,.14) !important;
}

/* ── BRAND LOGO SVG ─────────────────────────────────────────── */
.brand-logo {
  flex-shrink: 0;
}
.brand:not(.footer-brand .brand) .brand-logo rect:first-child,
.brand:not(.footer-brand .brand) .brand-logo text,
.brand:not(.footer-brand .brand) .brand-logo line {
  /* inherits gold color — no override needed */
}

/* ── DARK THEME: global overrides ───────────────────────────── */
/* Light theme component overrides */
[data-theme="light"] body {
  background: #fffaf1 !important;
  color: #181611 !important;
}
[data-theme="light"] .site-header {
  background: linear-gradient(180deg, rgba(255,250,241,.96) 0%, rgba(255,250,241,.76) 68%, rgba(255,250,241,0));
  color: #15130f;
}
[data-theme="light"] .site-header.is-scrolled,
[data-theme="light"] .site-nav.is-open {
  background: rgba(255,250,241,.98) !important;
  color: #15130f !important;
}
[data-theme="light"] .section,
[data-theme="light"] .home-intro,
[data-theme="light"] .why-us,
[data-theme="light"] .home-services,
[data-theme="light"] .home-fleet-section,
[data-theme="light"] .prices-copy,
[data-theme="light"] .legal-content {
  background-color: #fffaf1 !important;
  color: #181611 !important;
}
[data-theme="light"] .section.cream {
  background-color: #f2eadc !important;
}
[data-theme="light"] .section.dark,
[data-theme="light"] [style*="background:#121414"],
[data-theme="light"] [style*="background:#111111"],
[data-theme="light"] [style*="background:#1a1c1c"],
[data-theme="light"] [style*="background:#1e2020"],
[data-theme="light"] [style*="background:#0e0f0d"],
[data-theme="light"] [style*="background:#0a0a09"] {
  background-color: #f7efe2 !important;
  color: #181611 !important;
}
[data-theme="light"] h1,
[data-theme="light"] h2,
[data-theme="light"] h3 {
  color: #181611;
}
[data-theme="light"] p,
[data-theme="light"] li,
[data-theme="light"] .section-head > p {
  color: rgba(24,22,17,.72) !important;
}
[data-theme="light"] .hero h1,
[data-theme="light"] .hero h2,
[data-theme="light"] .hero p,
[data-theme="light"] .home-hero h1,
[data-theme="light"] .home-hero p {
  color: var(--hero-text) !important;
}
[data-theme="light"] .card,
[data-theme="light"] .card-body,
[data-theme="light"] .benefit-card,
[data-theme="light"] .form-panel,
[data-theme="light"] .booking-sidebar,
[data-theme="light"] .price-table,
[data-theme="light"] .service-list span {
  background: #ffffff !important;
  color: #181611 !important;
  border-color: rgba(169,120,36,.22) !important;
}
[data-theme="light"] .card-body h2,
[data-theme="light"] .card-body h3,
[data-theme="light"] .card-body p,
[data-theme="light"] .benefit-card p,
[data-theme="light"] .price-table td,
[data-theme="light"] .price-table th {
  color: #181611 !important;
}
[data-theme="light"] input,
[data-theme="light"] select,
[data-theme="light"] textarea {
  background: #ffffff !important;
  color: #181611 !important;
  border-color: rgba(169,120,36,.24) !important;
}
[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder {
  color: rgba(24,22,17,.42) !important;
}
[data-theme="light"] .text-\[\#e2e2e2\],
[data-theme="light"] .text-\[\#cfc4c5\],
[data-theme="light"] .text-\[\#988e90\],
[data-theme="light"] .text-body-md,
[data-theme="light"] .font-body-md,
[data-theme="light"] .font-title-lg,
[data-theme="light"] .font-headline-sm {
  color: #181611 !important;
}
[data-theme="light"] .site-footer,
[data-theme="light"] .footer-cta {
  background: #11100e !important;
  color: rgba(255,255,255,.78) !important;
}
[data-theme="light"] .brand,
[data-theme="light"] .brand-text,
[data-theme="light"] .site-header.is-scrolled .brand-text,
[data-theme="light"] .site-nav a,
[data-theme="light"] .nav-dropdown-btn,
[data-theme="light"] .header-phone,
[data-theme="light"] .theme-menu-btn,
[data-theme="light"] .nav-toggle {
  color: #15130f !important;
}
[data-theme="light"] .brand-text small {
  color: rgba(21,19,15,.72) !important;
}
[data-theme="light"] .site-nav a:hover,
[data-theme="light"] .site-nav a.is-active,
[data-theme="light"] .nav-has-dropdown:hover .nav-dropdown-btn,
[data-theme="light"] .nav-has-dropdown.is-open .nav-dropdown-btn,
[data-theme="light"] .nav-has-dropdown.current-section .nav-dropdown-btn {
  color: #a97824 !important;
  border-bottom-color: #a97824 !important;
}
[data-theme="light"] .theme-menu-btn,
[data-theme="light"] .nav-toggle {
  background: rgba(255,250,241,.72) !important;
  border-color: rgba(169,120,36,.36) !important;
}
[data-theme="light"] .site-header.is-scrolled {
  background: rgba(255,250,241,.98) !important;
  box-shadow: 0 2px 28px rgba(62,45,18,.14) !important;
}
[data-theme="light"] .site-nav {
  color: #15130f !important;
}

[data-theme="dark"] body {
  background: #0e0f0d !important;
  color: #f0ebe1 !important;
}

/* Sections */
[data-theme="dark"] .section {
  background-color: #181816 !important;
  color: #f0ebe1 !important;
}
[data-theme="dark"] .section.cream {
  background-color: #1e1e1c !important;
}
[data-theme="dark"] .home-intro,
[data-theme="dark"] .why-us,
[data-theme="dark"] .home-services,
[data-theme="dark"] .home-fleet-section,
[data-theme="dark"] .prices-copy,
[data-theme="dark"] .legal-content {
  background-color: #181816 !important;
  color: #f0ebe1 !important;
}

/* Typography */
[data-theme="dark"] h1,
[data-theme="dark"] h2,
[data-theme="dark"] h3 { color: #f0ebe1; }
[data-theme="dark"] p  { color: rgba(240,235,225,.78); }
[data-theme="dark"] .section p,
[data-theme="dark"] .section h2,
[data-theme="dark"] .section h3 { color: inherit; }
[data-theme="dark"] .text-muted,
[data-theme="dark"] .home-intro-copy p:last-child,
[data-theme="dark"] .section-head > p { color: rgba(240,235,225,.62) !important; }

/* Service / generic cards */
[data-theme="dark"] .card {
  background: #1e1e1c !important;
  border-color: rgba(201,164,90,.18) !important;
  color: #f0ebe1 !important;
}
[data-theme="dark"] .card-body { background: #1e1e1c !important; color: #f0ebe1 !important; }
[data-theme="dark"] .card-body h2 { color: #f0ebe1 !important; }
[data-theme="dark"] .card-body p  { color: rgba(240,235,225,.7) !important; }

/* Benefit cards */
[data-theme="dark"] .benefit-card {
  background: #24231f !important;
  color: #f0ebe1 !important;
  border-color: rgba(201,164,90,.22) !important;
}
[data-theme="dark"] .benefit-card p { color: rgba(240,235,225,.65) !important; }

/* Service list (additional services) */
[data-theme="dark"] .service-list span {
  background: #1e1e1c !important;
  color: #f0ebe1 !important;
  border-left-color: var(--gold) !important;
  border-color: rgba(201,164,90,.2) !important;
}

/* Price table */
[data-theme="dark"] .price-table { background: #1e1e1c !important; color: #f0ebe1 !important; }
[data-theme="dark"] .price-table thead { background: #111 !important; }
[data-theme="dark"] .price-table thead th { color: #edcf87 !important; }
[data-theme="dark"] .price-table td,
[data-theme="dark"] .price-table th { border-color: rgba(255,255,255,.08) !important; color: #f0ebe1 !important; }
[data-theme="dark"] .price-table tbody tr:nth-child(even) td { background: rgba(255,255,255,.04) !important; }

/* Why-us rows */
[data-theme="dark"] .why-row,
[data-theme="dark"] .why-content { color: #f0ebe1 !important; }
[data-theme="dark"] .why-list li { color: rgba(240,235,225,.78); }
[data-theme="dark"] .why-list li::before { color: var(--gold) !important; }

/* Forms */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
  background: #24231f !important;
  color: #f0ebe1 !important;
  border-color: rgba(255,255,255,.16) !important;
}
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder { color: rgba(240,235,225,.42) !important; }

/* Contact list, booking panels */
[data-theme="dark"] .form-panel,
[data-theme="dark"] .booking-sidebar { background: #1e1e1c !important; color: #f0ebe1 !important; }
[data-theme="dark"] .contact-list    { color: rgba(240,235,225,.82); }

/* ── HERO SLIDESHOW ─────────────────────────────────────────── */
.hero-slides {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.8s ease-in-out;
  will-change: opacity;
}
.hero-slide.is-active {
  opacity: 1;
}
.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 50%;  /* default; overridden per-slide via inline style */
  filter: saturate(0.78) contrast(1.04) brightness(0.86);
  display: block;
  transform: scale(1.04);
  transition: transform 7s ease-out;
}
.hero-slide.is-active img {
  transform: scale(1);
}

/* ═══════════════════════════════════════════════════════════════
   NAV SERVICES DROPDOWN
   ══════════════════════════════════════════════════════════════ */
.nav-has-dropdown {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.nav-dropdown-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--header-text) 86%, transparent);
  padding: 18px 0 12px;
  line-height: 1;
  white-space: nowrap;
  transition: color .2s, border-color .2s;
}
.nav-dropdown-btn i {
  font-size: 9px;
  transition: transform .22s;
}
.nav-has-dropdown:hover .nav-dropdown-btn,
.nav-has-dropdown.is-open .nav-dropdown-btn,
.nav-has-dropdown.current-section .nav-dropdown-btn {
  color: var(--gold-2);
  border-bottom-color: var(--gold-2);
}
.nav-has-dropdown:hover .nav-dropdown-btn i,
.nav-has-dropdown.is-open .nav-dropdown-btn i {
  transform: rotate(180deg);
}
.nav-dropdown-menu {
  position: absolute;
  top: calc(100% + 2px);
  left: 50%;
  transform: translateX(-50%) translateY(-10px);
  min-width: 580px;
  background: rgba(6, 7, 6, .98);
  border: 1px solid rgba(201, 164, 90, .24);
  box-shadow: 0 32px 90px rgba(0, 0, 0, .75);
  opacity: 0;
  visibility: hidden;
  transition: opacity .2s, visibility .2s, transform .2s;
  z-index: 200;
}
.nav-has-dropdown:hover .nav-dropdown-menu,
.nav-has-dropdown.is-open .nav-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.nav-dropdown-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 10px;
}
.nav-dropdown-grid a {
  display: flex !important;
  align-items: center !important;
  gap: 10px;
  padding: 9px 12px !important;
  color: rgba(255, 255, 255, .76) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .03em !important;
  text-transform: none !important;
  border-bottom: none !important;
  border-radius: 3px;
  transition: background .18s, color .18s !important;
}
.nav-dropdown-grid a:hover {
  background: rgba(201, 164, 90, .1);
  color: var(--gold-2) !important;
}
.nav-dropdown-grid a i {
  width: 16px;
  text-align: center;
  color: var(--gold);
  font-size: 11px;
  flex-shrink: 0;
}
.nav-dropdown-footer {
  border-top: 1px solid rgba(255, 255, 255, .07);
  padding: 10px 16px;
  text-align: center;
}
.nav-dropdown-footer a {
  color: var(--gold) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  border-bottom: none !important;
  transition: color .18s !important;
}
.nav-dropdown-footer a:hover {
  color: var(--gold-2) !important;
}

@media (max-width: 900px) {
  .nav-has-dropdown {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
  }
  .nav-dropdown-btn {
    width: 100%;
    justify-content: space-between;
    padding: 13px 0;
    border-bottom: 1px solid rgba(255, 255, 255, .07) !important;
    font-size: 14px;
    border-radius: 0;
  }
  .nav-dropdown-menu {
    position: static;
    transform: none !important;
    min-width: 100%;
    opacity: 1;
    visibility: hidden;
    max-height: 0;
    overflow: hidden;
    transition: max-height .32s ease, visibility .32s;
    box-shadow: none;
    border: none;
    border-top: 1px solid rgba(255, 255, 255, .05);
    background: rgba(0, 0, 0, .28);
  }
  .nav-has-dropdown.is-open .nav-dropdown-menu {
    visibility: visible;
    max-height: 800px;
  }
  .nav-dropdown-grid {
    grid-template-columns: 1fr;
    padding: 6px 0;
  }
  .nav-dropdown-grid a {
    padding: 10px 4px !important;
    border-bottom: 1px solid rgba(255, 255, 255, .06) !important;
    border-radius: 0;
  }
  .nav-dropdown-footer {
    padding: 12px 4px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   SERVICE DETAIL PAGE
   ══════════════════════════════════════════════════════════════ */
.svc-hero {
  position: relative;
  min-height: 460px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: #070807;
}
.svc-hero-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  filter: saturate(.72) contrast(1.05) brightness(.82);
}
.svc-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.28) 0%, rgba(7,8,7,.9) 100%);
  z-index: 1;
}
.svc-hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1220px;
  margin: 0 auto;
  padding: 120px clamp(18px, 4vw, 60px) 60px;
}
.svc-hero-label {
  display: inline-block;
  margin-bottom: 16px;
  padding: 5px 14px;
  background: rgba(201, 164, 90, .16);
  border: 1px solid rgba(201, 164, 90, .36);
  color: var(--gold-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.svc-hero h1 {
  color: #fff;
  font-size: clamp(38px, 5vw, 72px);
  margin: 0 0 20px;
  max-width: 760px;
}
.svc-hero-tagline {
  color: rgba(255, 255, 255, .72);
  font-size: clamp(16px, 1.5vw, 20px);
  max-width: 640px;
  margin: 0 0 28px;
  line-height: 1.5;
}
.svc-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  color: rgba(255, 255, 255, .46);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.svc-breadcrumb a { color: var(--gold); transition: color .18s; }
.svc-breadcrumb a:hover { color: var(--gold-2); }
.svc-breadcrumb i { font-size: 9px; }

.svc-body {
  background: #0e0f0d;
  padding: 72px 0 100px;
}
.svc-body-inner {
  max-width: 1220px;
  margin: 0 auto;
  padding: 0 clamp(18px, 4vw, 60px);
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 60px;
  align-items: start;
}
.svc-main-col { min-width: 0; }
.svc-main-col p {
  color: rgba(240, 235, 225, .74);
  font-size: 17px;
  line-height: 1.72;
  margin-bottom: 22px;
}

/* Sidebar */
.svc-sidebar {
  position: sticky;
  top: 104px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.svc-card {
  background: #181816;
  border: 1px solid rgba(201, 164, 90, .18);
  padding: 28px 26px;
}
.svc-card h3 {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 18px;
}
.svc-includes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.svc-includes-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: rgba(240, 235, 225, .78);
  font-size: 14px;
  line-height: 1.45;
}
.svc-includes-list li::before {
  content: '';
  display: block;
  width: 16px;
  height: 16px;
  min-width: 16px;
  margin-top: 1px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='7' stroke='%23c9a45a' stroke-width='1.2' fill='none'/%3E%3Cpath d='M5 8l2 2 4-4' stroke='%23c9a45a' stroke-width='1.4' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.svc-vehicle-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}
.svc-vehicle-tag {
  padding: 6px 12px;
  background: rgba(201, 164, 90, .08);
  border: 1px solid rgba(201, 164, 90, .22);
  color: var(--gold-2);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
}
.svc-cta-card {
  background: linear-gradient(135deg, #181816, #0e0f0d);
  border: 1px solid rgba(201, 164, 90, .28);
  padding: 30px 26px;
  text-align: center;
}
.svc-cta-card h3 {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 10px;
}
.svc-cta-card p {
  color: rgba(240, 235, 225, .62);
  font-size: 14px;
  margin: 0 0 22px;
  line-height: 1.5;
}
.svc-cta-card .actions { margin-top: 0; flex-direction: column; }
.svc-cta-card .btn { width: 100%; justify-content: center; }

/* FAQ accordion */
.svc-faq { margin-top: 52px; }
.svc-faq-title {
  font-size: clamp(22px, 2.2vw, 30px);
  color: var(--gold-2);
  margin: 0 0 24px;
}
.svc-faq details {
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}
.svc-faq details:first-of-type { border-top: 1px solid rgba(255, 255, 255, .08); }
.svc-faq summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 18px 0;
  cursor: pointer;
  list-style: none;
  color: rgba(240, 235, 225, .9);
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
  transition: color .18s;
}
.svc-faq summary::-webkit-details-marker { display: none; }
.svc-faq summary::after {
  content: '+';
  flex-shrink: 0;
  color: var(--gold);
  font-size: 20px;
  font-weight: 300;
  transition: transform .22s;
}
.svc-faq details[open] summary { color: var(--gold-2); }
.svc-faq details[open] summary::after { transform: rotate(45deg); }
.svc-faq details p {
  margin: 0 0 20px;
  padding-left: 2px;
  color: rgba(240, 235, 225, .64);
  font-size: 15px;
  line-height: 1.65;
}

/* Related services row */
.svc-related {
  background: #181816;
  padding: 72px 0 80px;
}
.svc-related-inner {
  max-width: 1220px;
  margin: 0 auto;
  padding: 0 clamp(18px, 4vw, 60px);
}
.svc-related-head {
  margin-bottom: 36px;
}
.svc-related-head p {
  margin: 0 0 6px;
  color: var(--gold);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.svc-related-head h2 {
  margin: 0;
  font-size: clamp(26px, 3vw, 38px);
}
.svc-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.svc-related-card {
  position: relative;
  overflow: hidden;
  background: #0e0f0d;
  border: 1px solid rgba(255, 255, 255, .08);
  height: 260px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  transition: border-color .2s;
}
.svc-related-card:hover { border-color: rgba(201, 164, 90, .36); }
.svc-related-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .52;
  transition: transform .6s, opacity .3s;
}
.svc-related-card:hover img { transform: scale(1.04); opacity: .62; }
.svc-related-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,.88) 100%);
}
.svc-related-card-body {
  position: relative;
  z-index: 2;
  padding: 20px;
}
.svc-related-card-body h3 {
  color: #fff;
  font-size: 18px;
  margin: 0 0 8px;
}
.svc-related-card-body a {
  color: var(--gold);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: color .18s;
}
.svc-related-card-body a:hover { color: var(--gold-2); }

@media (max-width: 1024px) {
  .svc-body-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .svc-sidebar {
    position: static;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
  }
  .svc-cta-card { grid-column: 1 / -1; }
}
@media (max-width: 700px) {
  .svc-sidebar { grid-template-columns: 1fr; }
  .svc-related-grid { grid-template-columns: 1fr; }
  .svc-related-card { height: 220px; }
}

/* ═══════════════════════════════════════════════════════════════
   HOME FEATURES — Premium interactive dark grid
   Replaces old benefit-card section. Stays on-brand (dark) but
   adds interactive hover behaviour: gold slide-in top bar,
   large serif number glow, icon lift.
   ══════════════════════════════════════════════════════════════ */
.home-features {
  background: #0c0d0c;
  padding: 96px 0 108px;
  position: relative;
}
.home-features::before {
  content: '';
  position: absolute;
  top: 0;
  left: 8%; right: 8%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,164,90,.55) 50%, transparent);
}
.home-features-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 clamp(18px, 4vw, 60px);
}
.home-features-intro {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 68px;
}
.home-features-intro h2 {
  font-size: clamp(30px, 3.8vw, 54px);
  color: #fff;
  margin-bottom: 18px;
  line-height: 1.06;
}
.home-features-intro > p {
  color: rgba(255,255,255,.52);
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.7;
  margin: 0;
}

/* Grid */
.home-features-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(201,164,90,.16);
}
.hf-item {
  padding: 44px 30px 40px;
  border-right: 1px solid rgba(201,164,90,.12);
  position: relative;
  overflow: hidden;
  transition: background .32s ease;
  cursor: default;
}
.hf-item:last-child { border-right: none; }

/* Gold bar slides in from left on hover */
.hf-item::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold), var(--gold-2));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .48s cubic-bezier(.16,1,.3,1);
}
.hf-item:hover { background: rgba(201,164,90,.05); }
.hf-item:hover::after { transform: scaleX(1); }

/* Large italic serif number — decorative */
.hf-num {
  display: block;
  font-family: var(--serif);
  font-size: 56px;
  font-style: italic;
  font-weight: 600;
  color: rgba(201,164,90,.15);
  line-height: 1;
  margin-bottom: 24px;
  transition: color .32s;
  user-select: none;
}
.hf-item:hover .hf-num { color: rgba(201,164,90,.42); }

/* Icon */
.hf-item > i {
  color: var(--gold);
  font-size: 22px;
  margin-bottom: 18px;
  display: block;
  transition: transform .32s ease;
}
.hf-item:hover > i { transform: translateY(-3px); }

/* Title */
.hf-item h3 {
  color: #fff;
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .01em;
  line-height: 1.35;
  margin: 0 0 12px;
}

/* Body */
.hf-item p {
  color: rgba(240,235,225,.44);
  font-size: 14px;
  line-height: 1.72;
  margin: 0;
  transition: color .32s;
}
.hf-item:hover p { color: rgba(240,235,225,.62); }

@media (max-width: 900px) {
  .home-features-grid { grid-template-columns: repeat(2, 1fr); }
  .hf-item:nth-child(2) { border-right: none; }
  .hf-item:nth-child(3),
  .hf-item:nth-child(4) { border-top: 1px solid rgba(201,164,90,.12); }
}
@media (max-width: 540px) {
  .home-features-grid { grid-template-columns: 1fr; }
  .hf-item { border-right: none !important; border-top: 1px solid rgba(201,164,90,.12); }
  .hf-item:first-child { border-top: none; }
  .hf-num { font-size: 44px; }
}

/* Mobile overflow guard
   Keeps fixed headers, dropdowns, Tailwind utility sections and long labels from
   creating a page-level horizontal scrollbar on phones. Local scroll areas such
   as pricing tables still keep their own horizontal scroll. */
@media (max-width: 900px) {
  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
  }

  body {
    position: relative;
  }

  main,
  section,
  footer,
  .site-header,
  .site-nav,
  .home-hero,
  .hero,
  .svc-hero,
  .bk {
    max-width: 100%;
    overflow-x: clip;
  }

  .site-header {
    max-width: 100vw;
  }

  .brand {
    min-width: 0;
    max-width: calc(100vw - 86px);
    gap: 10px;
  }

  .brand-logo,
  .brand-mark {
    flex: 0 0 auto;
  }

  .brand-text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    letter-spacing: .08em;
  }

  .brand-text small {
    letter-spacing: .12em;
  }

  .site-nav {
    max-width: 100vw;
    top: 66px;
    bottom: 0;
    height: calc(100dvh - 66px);
    max-height: none;
    overflow-x: hidden;
    overflow-y: auto;
    padding-top: 22px;
    justify-content: flex-start;
    scroll-padding-top: 22px;
  }

  .nav-toggle {
    position: relative;
    z-index: 120;
  }

  .site-nav > a:first-child {
    margin-top: 0;
  }

  .nav-dropdown-menu,
  .theme-menu-dropdown {
    width: 100%;
    min-width: 0 !important;
    max-width: 100%;
  }

  .home-hero-inner,
  .hero-inner,
  .section,
  .section-row,
  .footer-grid,
  .svc-hero-inner,
  .svc-body-inner,
  .home-features-inner,
  .home-fleet-inner,
  .bk > div {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .actions,
  .legal-cta,
  .mobile-actions,
  .quote-grid,
  .grid,
  .home-trust-strip,
  .home-service-grid,
  .home-features-grid,
  .fleet-grid,
  .gallery-grid-new,
  .svc-related-grid {
    min-width: 0;
  }

  .btn,
  .nav-cta,
  .quote-submit,
  .mobile-actions a {
    max-width: 100%;
    white-space: normal;
  }

  input,
  select,
  textarea,
  button {
    max-width: 100%;
  }

  h1,
  h2,
  h3,
  p,
  a,
  span,
  label {
    overflow-wrap: anywhere;
  }
}
