/* ============================================================
   Prestige Auto Spa Mobile — visual system
   Palette: ink black, charcoal, ivory, gold (warm metallic)
   ============================================================ */
:root{
  --ink:#0a0a0a;
  --black:#000000;
  --charcoal:#141414;
  --charcoal-2:#1a1a1a;
  --line:rgba(212,175,55,0.18);
  --line-strong:rgba(212,175,55,0.45);
  --line-soft:rgba(255,255,255,0.08);

  --ivory:#f6f1e7;
  --bone:#ece6d6;
  --white:#ffffff;
  --muted:rgba(246,241,231,0.62);
  --muted-2:rgba(246,241,231,0.42);

  --gold:#d4af37;
  --gold-2:#e8c971;
  --gold-3:#b9912a;
  --gold-grad: linear-gradient(180deg,#f1d683 0%, #d4af37 38%, #a47a18 100%);
  --gold-grad-flat: linear-gradient(180deg,#e8c971 0%, #b9912a 100%);

  --shadow-soft: 0 30px 80px -30px rgba(0,0,0,0.7);
  --shadow-gold: 0 20px 60px -20px rgba(212,175,55,0.25);

  --radius: 4px;
  --radius-lg: 10px;

  --container: 1280px;
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--black);
  color:var(--ivory);
  font-family:'Inter', system-ui, sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

::selection{background:var(--gold);color:var(--black);}

.serif{font-family:'Cormorant Garamond', 'Times New Roman', serif; letter-spacing:0.01em;}
.mono{font-family:'JetBrains Mono', monospace; letter-spacing:0.02em;}
.eyebrow{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:""; width:24px; height:1px; background:var(--gold);}

h1,h2,h3,h4{margin:0; font-family:'Cormorant Garamond', 'Times New Roman', serif; font-weight:600; letter-spacing:0; color:var(--white);}
h1{font-size:clamp(40px, 4.8vw, 72px); line-height:1.05; font-weight:600;}
h2{font-size:clamp(32px, 3.8vw, 54px); line-height:1.08; font-weight:500;}

.hero-title{ max-width: 560px; text-wrap: balance; }
h3{font-size:clamp(20px, 1.8vw, 26px); line-height:1.2; font-weight:500;}
p{margin:0; color:var(--bone);}

.gold-text{
  background: var(--gold-grad);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-fill-color:transparent;
}

.container{max-width:var(--container); margin:0 auto; padding:0 32px;}
.section{padding:120px 0; position:relative;}
.section-tight{padding:80px 0;}

.section-head{
  display:flex; flex-direction:column; gap:16px;
  margin-bottom:64px; max-width:760px;
}
.section-head h2{text-wrap:balance;}
.section-head p{color:var(--muted); font-size:18px; max-width:620px;}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:12px;
  padding:18px 32px;
  font-family:'Inter',sans-serif;
  font-size:13px; font-weight:600;
  letter-spacing:0.18em; text-transform:uppercase;
  border:none; border-radius:2px;
  cursor:pointer;
  transition:all .35s cubic-bezier(.2,.7,.2,1);
  text-decoration:none;
  position:relative;
  white-space:nowrap;
}
.btn-primary{
  background:var(--gold-grad);
  color:#1a1102;
  box-shadow: 0 12px 30px -10px rgba(212,175,55,0.5);
}
.btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 40px -10px rgba(212,175,55,0.7);
  filter: brightness(1.07);
}
.btn-ghost{
  background:transparent;
  color:var(--ivory);
  border:1px solid var(--line-strong);
}
.btn-ghost:hover{
  background:rgba(212,175,55,0.08);
  border-color:var(--gold);
  color:var(--gold-2);
}
.btn-dark{
  background:var(--charcoal);
  color:var(--ivory);
  border:1px solid var(--line-soft);
}
.btn-dark:hover{ border-color:var(--line-strong); color:var(--gold-2);}
.btn .arrow{transition:transform .3s ease;}
.btn:hover .arrow{transform: translateX(4px);}

.gold-rule{
  height:1px; width:100%;
  background: linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
  opacity:.4;
}
.gold-corner{
  position:absolute; width:32px; height:32px;
  border:1px solid var(--gold);
  pointer-events:none;
}
.gold-corner.tl{top:0; left:0; border-right:none; border-bottom:none;}
.gold-corner.tr{top:0; right:0; border-left:none; border-bottom:none;}
.gold-corner.bl{bottom:0; left:0; border-right:none; border-top:none;}
.gold-corner.br{bottom:0; right:0; border-left:none; border-top:none;}

.card{
  background: linear-gradient(180deg, #131313 0%, #0c0c0c 100%);
  border:1px solid var(--line-soft);
  border-radius: var(--radius);
  position:relative;
  transition: all .4s cubic-bezier(.2,.7,.2,1);
}
.card:hover{
  border-color:var(--line-strong);
  transform: translateY(-4px);
}

.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg,
      rgba(212,175,55,0.06) 0 1px, transparent 1px 14px),
    linear-gradient(180deg, #1a1a1a, #0a0a0a);
  border:1px solid var(--line-soft);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
  color:var(--muted-2);
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  text-align:center;
  padding:14px;
}
.ph::after{
  content:""; position:absolute; inset:14px;
  border:1px solid var(--line);
  pointer-events:none;
}

.input, .select, textarea.input{
  background:#0c0c0c;
  color:var(--ivory);
  border:1px solid var(--line-soft);
  border-radius:2px;
  padding:14px 16px;
  font-family:'Inter',sans-serif;
  font-size:15px;
  outline:none;
  transition: border-color .25s ease, background .25s ease;
  width:100%;
}
.input:focus, .select:focus, textarea.input:focus{
  border-color:var(--gold);
  background:#0f0f0f;
}
.field{display:flex; flex-direction:column; gap:8px;}
.field-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10px; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--muted);
}

body::before{
  content:"";
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(212,175,55,0.06), transparent 60%),
    radial-gradient(1000px 500px at -10% 50%, rgba(212,175,55,0.04), transparent 60%);
}
#root{position:relative; z-index:1;}

@media (max-width: 900px){
  .section{padding:80px 0;}
  .container{padding:0 22px;}
}

/* ============================================================
   Component styles
   ============================================================ */

/* ---- NAV ------------------------------------------------- */
.nav{
  position: fixed; top:0; left:0; right:0; z-index:50;
  transition: background .35s ease, border-color .35s ease, padding .25s ease;
  border-bottom:1px solid transparent;
}
.nav.nav-scrolled{
  background: rgba(8,8,8,0.85);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom:1px solid var(--line-soft);
}
.nav-inner{
  display:flex; align-items:center; gap:32px;
  padding:16px 32px; max-width:1440px;
}
.nav-brand{
  display:flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--ivory);
}
.nav-brand img{
  width:68px; height:68px; object-fit:cover;
  border-radius:50%;
  border:1px solid var(--line-strong);
  box-shadow: 0 4px 18px rgba(212,175,55,0.18);
  transition: transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s ease;
}
.nav-brand:hover img{
  transform: rotate(8deg) scale(1.06);
  box-shadow: 0 6px 24px rgba(212,175,55,0.35);
}
.nav-scrolled .nav-brand img{ width:54px; height:54px; }
.nav-brand-text{display:flex; flex-direction:column; line-height:1;}
.nav-brand-text .serif{font-size:24px; font-weight:700; color:var(--white);}
.nav-brand-text .mono{font-size:10px; letter-spacing:0.24em; color:var(--gold); margin-top:5px;}
.nav-links{
  display:flex; gap:28px; margin-left:32px;
}
.nav-links a{
  color:var(--bone); text-decoration:none;
  font-size:13px; font-weight:500;
  letter-spacing:0.06em;
  transition: color .2s ease;
  position:relative;
}
.nav-links a:hover{color:var(--gold-2);}
.nav-cta{margin-left:auto; display:flex; align-items:center; gap:18px;}
.nav-phone{
  color:var(--ivory); text-decoration:none;
  font-size:13px; font-weight:500;
  display:inline-flex; align-items:center; gap:8px;
}
.nav-phone:hover{color:var(--gold-2);}
.nav-book{padding:14px 22px; font-size:11px;}
.nav-toggle{
  display:none; background:transparent; border:1px solid var(--line-strong);
  color:var(--ivory); padding:10px; border-radius:2px; cursor:pointer;
}
.nav-mobile{
  display:none; flex-direction:column; gap:8px;
  background:#0a0a0a; border-top:1px solid var(--line-soft);
  padding:18px 22px;
}
.nav-mobile a{color:var(--ivory); padding:10px; text-decoration:none; border-bottom:1px solid var(--line-soft);}

@media (max-width: 1100px){
  .nav-links{display:none;}
  .nav-phone{display:none;}
}
@media (max-width: 720px){
  .nav-toggle{display:inline-flex;}
  .nav-book{display:none;}
  .nav-mobile{display:flex;}
  .nav-brand-text .mono{display:none;}
}

/* ---- HERO ----------------------------------------------- */
.hero{
  position:relative;
  padding-top:140px;
  padding-bottom:80px;
  overflow:hidden;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
}
.hero-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(circle at 60% 50%, black 30%, transparent 70%);
  opacity:.35;
}
.hero-glow{
  position:absolute; right:-200px; top:-100px; width:900px; height:900px;
  background: radial-gradient(circle, rgba(212,175,55,0.18) 0%, transparent 60%);
  filter: blur(40px);
}
.hero-inner{
  position:relative; z-index:1;
  display:grid; grid-template-columns: 1.1fr 1fr;
  gap:80px; align-items:center;
}
.hero-left{display:flex; flex-direction:column; gap:28px;}
.hero-title{
  text-wrap:balance;
}
.hero-sub{
  font-size:19px; max-width:540px; color:var(--bone);
}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap;}
.hero-trust{
  list-style:none; padding:0; margin:24px 0 0;
  display:grid; grid-template-columns: repeat(2, max-content);
  gap:14px 32px;
}
.hero-trust li{
  display:flex; align-items:center; gap:10px;
  color:var(--bone); font-size:13px;
  font-weight:500;
}
.hero-trust li svg{color:var(--gold);}

.hero-right{position:relative;}
.hero-card{
  position:relative;
  background: linear-gradient(180deg, #131313 0%, #0a0a0a 100%);
  border:1px solid var(--line-soft);
  padding:32px;
}
.hero-card-img{
  height: 360px;
  width:100%;
  margin-bottom:24px;
}
.hero-card-meta{
  display:grid; grid-template-columns: 1fr auto 1fr auto 1fr;
  gap:16px; align-items:center;
}
.hero-stat{display:flex; flex-direction:column; gap:6px; align-items:center;}
.hero-stat .serif{font-size:34px; font-weight:700; line-height:1;}
.hero-stat .mono{font-size:9px; letter-spacing:0.24em; color:var(--muted); text-transform:uppercase;}
.hero-stat-divider{width:1px; height:36px; background:var(--line-soft);}

.hero-floating{
  position:absolute;
  bottom:-30px; left:-30px;
  background:#0a0a0a; border:1px solid var(--line-strong);
  padding:14px 18px; display:flex; align-items:center; gap:14px;
  box-shadow: var(--shadow-soft);
  max-width:280px;
}
.hero-floating-dot{
  width:10px; height:10px; border-radius:50%;
  background:var(--gold);
  box-shadow: 0 0 0 4px rgba(212,175,55,0.2);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{box-shadow: 0 0 0 4px rgba(212,175,55,0.2);}
  50%{box-shadow: 0 0 0 8px rgba(212,175,55,0);}
}

.hero-marquee{
  margin-top:80px;
  padding:18px 0;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  overflow:hidden;
  position:relative;
}
.hero-marquee-track{
  display:flex; gap:48px;
  animation: marquee 50s linear infinite;
  width:max-content;
}
.hero-marquee-group{display:flex; gap:48px; padding-right:48px;}
.hero-marquee span{
  font-family:'JetBrains Mono', monospace;
  font-size:13px; letter-spacing:0.18em;
  color:var(--bone);
  text-transform:uppercase;
  white-space:nowrap;
}
@keyframes marquee{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

@media (max-width: 980px){
  .hero-inner{grid-template-columns: 1fr; gap:48px;}
  .hero-trust{grid-template-columns: repeat(2,1fr);}
  .hero-card-img{height:260px;}
  .hero-floating{left:0; bottom:-22px;}
}

/* ---- SECTION ALTERNATING BG ----------------------------- */
.how-section{background:linear-gradient(180deg, var(--black), #0a0a0a);}
.why-section{background:#000;}
.services-section{background:linear-gradient(180deg, #0a0a0a, #000);}
.about-section{background:#0a0a0a;}
.testimonials-section{background:#000;}
.faq-section{background:linear-gradient(180deg, #000, #0a0a0a);}
.final-cta-section{background:#0a0a0a;}
.gallery-section{background:#000;}
.booking-section{background:linear-gradient(180deg, #0a0a0a 0%, #000 100%); position:relative;}
.booking-section::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background: var(--gold-grad);
  opacity:.5;
}

/* Featured (highlighted) booking section */
.booking-section-feature{
  background:
    radial-gradient(800px 400px at 50% 0%, rgba(212,175,55,0.10), transparent 70%),
    linear-gradient(180deg, #0a0a0a 0%, #000 100%);
  padding-top: 100px;
  padding-bottom: 120px;
}
.booking-section-feature::before{
  height:2px;
  opacity:.85;
  box-shadow: 0 0 24px rgba(212,175,55,0.4);
}
.booking-aura{
  position:absolute;
  top:120px; left:50%; transform: translateX(-50%);
  width: min(90%, 1100px); height: 60%;
  background:
    radial-gradient(ellipse at 50% 50%, rgba(212,175,55,0.12), transparent 60%);
  filter: blur(40px);
  pointer-events:none; z-index:0;
  animation: auraPulse 6s ease-in-out infinite;
}
@keyframes auraPulse{
  0%,100% { opacity:.7; transform: translateX(-50%) scale(1); }
  50%     { opacity:1;  transform: translateX(-50%) scale(1.04); }
}
.booking-section-feature .container{ position:relative; z-index:1; }

.section-head-feature{
  align-items:center;
  text-align:center;
  margin-left:auto; margin-right:auto;
  max-width:760px;
  margin-bottom:48px;
  animation: featureHeadIn 0.7s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes featureHeadIn{
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.section-head-feature .eyebrow{
  justify-content:center;
  font-size:12px;
  padding:10px 22px;
  background: rgba(212,175,55,0.08);
  border:1px solid var(--line-strong);
  border-radius:999px;
}
.section-head-feature .eyebrow::before{ display:none; }
.section-head-feature h2{
  font-size: clamp(38px, 4.6vw, 64px);
  text-wrap:balance;
}
.section-head-feature p{
  margin: 0 auto;
  font-size: 17px;
  color: var(--bone);
}

.booking-shell-feature{
  position:relative;
  border:1px solid var(--line-strong);
  box-shadow:
    0 0 0 1px rgba(212,175,55,0.1),
    0 40px 100px -30px rgba(0,0,0,0.9),
    0 0 60px -10px rgba(212,175,55,0.18);
  background:
    linear-gradient(180deg, rgba(212,175,55,0.025) 0%, transparent 30%),
    linear-gradient(180deg, #0d0d0d 0%, #080808 100%);
}
.booking-shell-feature::before{
  content:"";
  position:absolute; inset:-1px;
  border-radius: var(--radius-lg);
  padding:1px;
  background: linear-gradient(180deg, rgba(212,175,55,0.45), rgba(212,175,55,0.05) 40%, transparent 80%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events:none;
}
.booking-shell-feature > .gold-corner{ width:24px; height:24px; }
.booking-shell-feature > .gold-corner.tl{ top:-1px; left:-1px; }
.booking-shell-feature > .gold-corner.tr{ top:-1px; right:-1px; }
.booking-shell-feature > .gold-corner.bl{ bottom:-1px; left:-1px; }
.booking-shell-feature > .gold-corner.br{ bottom:-1px; right:-1px; }

/* Booking extras — trust strip + call CTA below the form */
.booking-extras{
  margin-top: 40px;
  padding: 36px 40px;
  background:
    linear-gradient(180deg, rgba(212,175,55,0.04) 0%, transparent 100%),
    linear-gradient(180deg, #0c0c0c 0%, #060606 100%);
  border:1px solid var(--line-soft);
  border-top: 2px solid transparent;
  border-image: linear-gradient(90deg, transparent, var(--gold), transparent) 1;
  border-image-slice: 1;
  position:relative;
  display:grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items:center;
}
.booking-extras::before{
  content:""; position:absolute; top:-1px; left:10%; right:10%;
  height:2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  box-shadow: 0 0 18px rgba(212,175,55,0.5);
}
.booking-extras-row{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.booking-extra{
  display:flex; align-items:center; gap:14px;
  transition: transform .35s cubic-bezier(.2,.7,.2,1);
}
.booking-extra:hover{ transform: translateY(-2px); }
.booking-extra-icon{
  flex-shrink:0;
  width:48px; height:48px;
  border-radius: 50%;
  background: rgba(212,175,55,0.08);
  border: 1px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center;
  color: var(--gold);
  transition: background .3s ease, border-color .3s ease, color .3s ease;
}
.booking-extra:hover .booking-extra-icon{
  background: var(--gold-grad);
  border-color: var(--gold);
  color: #1a1102;
}
.booking-extra > div{ display:flex; flex-direction:column; gap:2px; }
.booking-extra strong{
  font-size: 14px; font-weight: 600; color: var(--ivory);
  letter-spacing: 0.02em;
}
.booking-extra span{
  font-size: 12px; color: var(--muted);
  font-family: 'JetBrains Mono', monospace;
  letter-spacing: 0.04em;
}

.booking-extras-cta{
  display:flex; flex-direction:column; gap:8px;
  align-items:flex-end;
  padding-left: 32px;
  border-left: 1px solid var(--line-soft);
}
.booking-extras-cta > span{
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--muted);
  text-transform: uppercase;
}
.booking-call{
  display: inline-flex; align-items: center; gap: 10px;
  font-family: 'Cormorant Garamond', 'Times New Roman', serif;
  font-size: 28px; font-weight: 600;
  color: var(--gold-2);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: color .3s ease, transform .3s ease;
}
.booking-call:hover{
  color: var(--white);
  transform: translateX(-3px);
}
.booking-call svg{ color: var(--gold); }

@media (max-width: 980px){
  .booking-extras{
    grid-template-columns: 1fr;
    padding: 28px 24px;
    gap: 24px;
  }
  .booking-extras-row{ grid-template-columns: 1fr; gap: 18px; }
  .booking-extras-cta{
    padding-left: 0; border-left: none;
    padding-top: 20px; border-top: 1px solid var(--line-soft);
    align-items: center;
  }
  .booking-call{ font-size: 24px; }
}

/* ---- BOOKING -------------------------------------------- */
.booking-shell{
  background: linear-gradient(180deg, #0d0d0d 0%, #080808 100%);
  border:1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  overflow:hidden;
}
.stepper{
  display:grid; grid-template-columns: repeat(5, 1fr);
  border-bottom:1px solid var(--line-soft);
  background:#0a0a0a;
}
.stepper-item{
  display:flex; align-items:center; gap:14px;
  padding:22px 28px;
  background:transparent; border:none;
  text-align:left; cursor:pointer;
  border-right:1px solid var(--line-soft);
  color:var(--muted);
  transition: background .2s ease, color .2s ease;
  position:relative;
}
.stepper-item:last-child{border-right:none;}
.stepper-item:hover{color:var(--ivory);}
.stepper-item.is-done{color:var(--ivory);}
.stepper-item.is-done .stepper-num{
  background:var(--gold-grad); color:#1a1102; border-color:transparent;
}
.stepper-item.is-active{
  color:var(--white);
  background: linear-gradient(180deg, rgba(212,175,55,0.08), transparent);
}
.stepper-item.is-active::after{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background: var(--gold-grad);
}
.stepper-num{
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--line-strong);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:11px; letter-spacing:0.1em;
  flex-shrink:0;
}
.stepper-label{font-size:13px; font-weight:500; letter-spacing:0.04em;}

.booking-body{
  display:grid; grid-template-columns: 1.5fr 1fr;
  gap:0;
}
.booking-main{
  padding:48px;
  border-right:1px solid var(--line-soft);
  min-height:520px;
  display:flex; flex-direction:column;
}
.step-pane{
  flex:1;
  display:flex; flex-direction:column; gap:20px;
}
.step-pane h3{font-size:24px; font-weight:500;}
.step-help{color:var(--muted); font-size:14px; max-width:520px;}

.booking-actions{
  display:flex; gap:12px; align-items:center;
  margin-top:32px; padding-top:24px;
  border-top:1px solid var(--line-soft);
}
.booking-actions-spacer{flex:1;}
.btn:disabled{opacity:.4; cursor:not-allowed; transform:none !important; box-shadow:none !important;}

/* Vehicle grid */
.vehicle-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.vehicle-card{
  background:#0a0a0a; border:1px solid var(--line-soft);
  padding:22px 18px;
  cursor:pointer;
  transition: all .25s ease;
  display:flex; flex-direction:column; gap:14px;
  text-align:left;
  color:var(--bone);
  position:relative;
}
.vehicle-card:hover{border-color:var(--line-strong); color:var(--ivory);}
.vehicle-card.is-active{
  border-color:var(--gold);
  background: linear-gradient(180deg, rgba(212,175,55,0.06), transparent);
  color:var(--white);
  box-shadow: var(--shadow-gold);
}
.vehicle-silhouette{
  width:100%; height:72px;
  display:flex; align-items:center; justify-content:center;
  color:var(--bone);
}
.vehicle-silhouette img{
  max-width:100%; max-height:100%;
  width:auto; height:100%;
  object-fit:contain;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.4));
  transition: transform .35s cubic-bezier(.2,.7,.2,1), filter .35s ease;
}
.vehicle-card:hover .vehicle-silhouette img{ transform: translateY(-2px); }
.vehicle-card.is-active .vehicle-silhouette{color:var(--gold);}
.vehicle-card.is-active .vehicle-silhouette img{
  filter: drop-shadow(0 4px 10px rgba(212,175,55,0.35));
}
.vehicle-card-meta{display:flex; flex-direction:column; gap:4px;}
.vehicle-card-label{font-weight:600; font-size:15px;}
.vehicle-card-sub{font-size:11px; color:var(--muted); font-family:'JetBrains Mono', monospace; letter-spacing:0.06em;}
.vehicle-card-mult{
  position:absolute; top:14px; right:14px;
  font-size:10px; color:var(--gold-2);
  background: rgba(212,175,55,0.08);
  padding:3px 8px; border-radius:2px;
  letter-spacing:0.1em;
}

/* Service rows */
.service-grid-form{display:flex; flex-direction:column; gap:10px;}
.service-row{
  display:grid; grid-template-columns: auto 1fr auto; align-items:center; gap:20px;
  background:#0a0a0a; border:1px solid var(--line-soft);
  padding:20px 24px; cursor:pointer; text-align:left;
  transition: all .25s ease;
  color:var(--bone);
}
.service-row:hover{border-color:var(--line-strong); color:var(--ivory);}
.service-row.is-active{
  border-color:var(--gold);
  background: linear-gradient(90deg, rgba(212,175,55,0.05), transparent 40%);
  color:var(--white);
}
.service-row-radio{
  width:22px; height:22px; border-radius:50%;
  border:1.5px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
}
.service-row.is-active .service-row-radio{
  background:var(--gold); border-color:var(--gold); color:var(--black);
}
.service-row-meta{display:flex; flex-direction:column; gap:4px;}
.service-row-label{font-weight:600; font-size:16px;}
.service-row-desc{color:var(--muted); font-size:13px;}
.service-row-meta-line{display:flex; gap:16px; font-size:11px; color:var(--muted-2); margin-top:4px;}
.service-row-meta-line span{display:inline-flex; gap:6px; align-items:center;}
.service-row-price{text-align:right;}

/* Date / time pills */
.date-row{display:flex; flex-wrap:wrap; gap:10px;}
.date-pill{
  background:#0a0a0a; border:1px solid var(--line-soft);
  padding:14px 18px; display:flex; flex-direction:column; gap:4px; align-items:center;
  cursor:pointer; min-width:74px;
  color:var(--bone);
  transition: all .2s ease;
}
.date-pill:hover{border-color:var(--line-strong); color:var(--ivory);}
.date-pill.is-active{
  border-color:var(--gold);
  background:rgba(212,175,55,0.08);
  color:var(--white);
}
.date-dow{font-size:9px; color:var(--muted); letter-spacing:0.18em;}
.date-day{font-size:24px; font-weight:600;}
.date-pill.is-active .date-day{color:var(--gold-2);}
.date-mo{font-size:9px; color:var(--muted); letter-spacing:0.18em;}

.slot-row{display:flex; flex-wrap:wrap; gap:8px;}
.slot-pill{
  background:#0a0a0a; border:1px solid var(--line-soft);
  padding:12px 18px; cursor:pointer; color:var(--bone);
  font-size:13px; font-weight:500; letter-spacing:0.04em;
  transition: all .2s ease;
}
.slot-pill:hover{border-color:var(--line-strong); color:var(--ivory);}
.slot-pill.is-active{
  border-color:var(--gold); background:rgba(212,175,55,0.08); color:var(--gold-2);
}
.slot-pill.is-taken{
  cursor:not-allowed;
  opacity:.45;
  background: repeating-linear-gradient(135deg,
    #0a0a0a 0 6px, rgba(212,175,55,0.04) 6px 12px);
  border-color: var(--line-soft);
  color: var(--muted);
  display:inline-flex; align-items:center; gap:8px;
}
.slot-pill.is-taken:hover{ border-color: var(--line-soft); color: var(--muted); }
.slot-pill-tag{
  font-size:9px; letter-spacing:0.18em; text-transform:uppercase;
  background: rgba(212,175,55,0.12); color: var(--gold);
  padding:2px 6px; border-radius:2px;
}

/* Form grid */
.form-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:20px;
}
.field-divider{
  display:flex; align-items:center; gap:14px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px; letter-spacing:0.28em; color:var(--gold);
  margin-top:8px;
}
.field-divider::before,.field-divider::after{
  content:""; flex:1; height:1px; background:var(--line-soft);
}

/* Pay grid */
.pay-grid{
  display:grid; grid-template-columns: repeat(3,1fr); gap:10px;
}
.pay-card{
  background:#0a0a0a; border:1px solid var(--line-soft);
  padding:18px; cursor:pointer; text-align:left;
  display:flex; flex-direction:column; gap:6px;
  color:var(--bone);
  transition: all .2s ease;
  position:relative;
}
.pay-card:hover{border-color:var(--line-strong); color:var(--ivory);}
.pay-card.is-active{
  border-color:var(--gold);
  background:rgba(212,175,55,0.06);
  color:var(--white);
}
.pay-card-radio{
  position:absolute; top:14px; right:14px;
  width:18px; height:18px; border-radius:50%;
  border:1.5px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
}
.pay-card.is-active .pay-card-radio{background:var(--gold); border-color:var(--gold); color:var(--black);}
.pay-card-label{font-size:15px; font-weight:600;}
.pay-card-sub{font-size:11px; color:var(--muted); font-family:'JetBrains Mono', monospace; letter-spacing:0.04em;}

.promo-row{margin-top:24px;}
.terms{
  margin-top:20px; padding:14px 16px;
  border:1px dashed var(--line-soft);
  display:flex; gap:12px; align-items:center;
  font-size:12px; color:var(--muted);
}
.terms svg{color:var(--gold); flex-shrink:0;}

/* Summary */
.booking-summary{
  padding:40px 36px;
  background:#080808;
  display:flex; flex-direction:column; gap:8px;
  position:relative;
}
.summary-head{display:flex; flex-direction:column; gap:8px; margin-bottom:8px;}
.summary-rows{display:flex; flex-direction:column; gap:14px;}
.summary-row{display:grid; grid-template-columns: 110px 1fr; gap:14px; align-items:start;}
.summary-row-label{font-size:10px; letter-spacing:0.22em; color:var(--muted-2); text-transform:uppercase; padding-top:2px;}
.summary-row-val{font-size:14px; color:var(--ivory);}
.summary-row-val .muted{color:var(--muted-2);}
.summary-row-sub{font-size:12px; color:var(--muted); margin-top:2px;}

.price-block{display:flex; flex-direction:column; gap:8px;}
.price-line{display:flex; justify-content:space-between; font-size:14px; color:var(--bone);}
.price-line.gold{color:var(--gold-2);}
.price-line.muted{color:var(--muted); font-size:12px;}
.price-total{display:flex; justify-content:space-between; align-items:baseline;}
.price-total .mono{font-size:11px; letter-spacing:0.24em; color:var(--ivory);}
.price-total .serif{font-size:36px; font-weight:700; line-height:1;}

.price-empty{
  display:flex; flex-direction:column; gap:10px; align-items:center; text-align:center;
  padding:32px 16px;
  border:1px dashed var(--line-soft);
}
.price-empty svg{color:var(--gold);}
.price-empty p{color:var(--muted); font-size:13px;}

.summary-trust{
  margin-top:24px; padding-top:20px;
  border-top:1px solid var(--line-soft);
  display:flex; justify-content:space-between; gap:12px;
  font-size:11px; font-family:'JetBrains Mono',monospace;
  letter-spacing:0.16em; color:var(--muted);
}
.summary-trust div{display:flex; gap:6px; align-items:center;}
.summary-trust svg{color:var(--gold);}

/* Confirmation */
.confirm-shell{
  position:relative;
  background: linear-gradient(180deg, #131313 0%, #0a0a0a 100%);
  border:1px solid var(--line-strong);
  padding:64px 48px;
  display:flex; flex-direction:column; gap:18px; align-items:center;
}
.confirm-icon{
  width:72px; height:72px; border-radius:50%;
  background: var(--gold-grad);
  display:flex; align-items:center; justify-content:center;
  color:var(--black);
  margin-bottom:8px;
}
.confirm-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:24px 32px;
  margin-top:32px;
  padding:24px 28px;
  background:#000; border:1px solid var(--line-soft);
  width:100%; max-width:760px;
}
.confirm-grid > div{display:flex; flex-direction:column; gap:6px;}
.confirm-grid .mono{font-size:10px; letter-spacing:0.22em; color:var(--muted-2); text-transform:uppercase;}
.confirm-grid strong{font-size:15px; color:var(--ivory); font-weight:500;}

.confirm-actions{
  display:flex; gap:12px; justify-content:center;
  margin-top:32px;
  width:100%;
  flex-wrap:wrap;
}
.confirm-actions .btn{ flex: 1 1 auto; min-width: 180px; max-width: 280px; justify-content:center; }
@media (max-width: 640px){
  .confirm-actions{ flex-direction:column; align-items:stretch; gap:10px; }
  .confirm-actions .btn{ width:100%; max-width:none; }
}

@media (max-width: 980px){
  .stepper{grid-template-columns: repeat(5, auto); overflow-x:auto;}
  .stepper-item{padding:16px 18px;}
  .stepper-label{display:none;}
  .booking-body{grid-template-columns: 1fr;}
  .booking-main{padding:28px; border-right:none; border-bottom:1px solid var(--line-soft);}
  .vehicle-grid{grid-template-columns: repeat(2,1fr);}
  .pay-grid{grid-template-columns: repeat(2,1fr);}
  .form-grid{grid-template-columns: 1fr;}
  .confirm-grid{grid-template-columns: repeat(2,1fr);}
}

/* ---- HOW IT WORKS — process flow ----------------------- */
.how-flow{
  position:relative;
  list-style:none;
  margin:0; padding:0;
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:32px;
}
.how-flow-line{
  position:absolute;
  top:54px; left:8%; right:8%;
  height:1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(212,175,55,0.18) 8%,
    rgba(212,175,55,0.55) 50%,
    rgba(212,175,55,0.18) 92%,
    transparent 100%);
  z-index:0;
}
.how-flow-line::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(90deg,
    transparent, var(--gold-2), transparent);
  background-size: 30% 100%; background-repeat:no-repeat;
  animation: flowPulse 5s linear infinite;
}
@keyframes flowPulse{
  0%   { background-position: -30% 0; }
  100% { background-position: 130% 0; }
}

.how-step{
  position:relative;
  display:flex; flex-direction:column; align-items:center;
  text-align:center;
  gap:24px;
  padding:0 12px;
  z-index:1;
}
.how-step-node{
  position:relative;
  width:108px; height:108px;
  border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%, #1c1c1c 0%, #050505 100%);
  border:1px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
  box-shadow:
    0 20px 50px -20px rgba(0,0,0,0.9),
    inset 0 1px 0 rgba(212,175,55,0.18);
  transition: transform .5s cubic-bezier(.2,.7,.2,1), border-color .35s ease, box-shadow .5s ease;
}
.how-step:hover .how-step-node{
  transform: translateY(-4px) scale(1.04);
  border-color: var(--gold);
  box-shadow:
    0 24px 60px -20px rgba(212,175,55,0.5),
    inset 0 1px 0 rgba(212,175,55,0.3);
}
.how-step-node::before{
  content:""; position:absolute; inset:-4px;
  border-radius:50%;
  border:1px dashed rgba(212,175,55,0.25);
  animation: nodeRotate 30s linear infinite;
}
@keyframes nodeRotate{ to { transform: rotate(360deg); } }

.how-step-num{
  position:absolute;
  top:-14px; right:-14px;
  width:40px; height:40px; border-radius:50%;
  background: var(--gold-grad);
  color:#1a1102;
  font-size:13px; font-weight:600; letter-spacing:0.06em;
  display:flex; align-items:center; justify-content:center;
  box-shadow: 0 6px 16px rgba(212,175,55,0.35);
  z-index:2;
}
.how-step-icon{ display:flex; }

.how-step-pulse{
  position:absolute; inset:0;
  border-radius:50%;
  border:1px solid rgba(212,175,55,0.5);
  animation: nodePulse 3s cubic-bezier(.2,.7,.2,1) infinite;
  pointer-events:none;
}
.how-step:nth-child(2) .how-step-pulse{ animation-delay: -1s; }
.how-step:nth-child(3) .how-step-pulse{ animation-delay: -2s; }
@keyframes nodePulse{
  0%   { transform: scale(1);   opacity: .6; }
  100% { transform: scale(1.6); opacity: 0; }
}

.how-step-body{
  display:flex; flex-direction:column; gap:10px;
  max-width:300px;
}
.how-step-body h3{
  font-size:24px; font-weight:500; color:var(--white);
  text-wrap:balance;
}
.how-step-body p{ color:var(--muted); font-size:15px; }

@media (max-width:900px){
  .how-flow{ grid-template-columns:1fr; gap:40px; }
  .how-flow-line{
    top:0; bottom:0; left:54px; right:auto;
    width:1px; height:auto;
    background: linear-gradient(180deg,
      transparent 0%,
      rgba(212,175,55,0.55) 10%,
      rgba(212,175,55,0.55) 90%,
      transparent 100%);
  }
  .how-flow-line::after{ display:none; }
  .how-step{
    flex-direction:row; align-items:center;
    text-align:left; gap:24px;
    padding:0;
  }
  .how-step-node{ width:88px; height:88px; flex-shrink:0; }
  .how-step-num{ width:32px; height:32px; font-size:11px; top:-10px; right:-10px; }
  .how-step-body{ max-width:none; }
}

/* ---- WHY CHOOSE ----------------------------------------- */
.why-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:1px;
  background: var(--line-soft);
  border:1px solid var(--line-soft);
}
.why-card{
  background:#000; padding:48px 36px;
  display:flex; flex-direction:column; gap:14px;
  transition: background .35s ease;
}
.why-card:hover{background:#0c0c0c;}
.why-icon{
  width:48px; height:48px;
  border:1px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
  margin-bottom:8px;
}
.why-card h3{font-size:20px; font-weight:500;}
.why-card p{color:var(--muted); font-size:14px;}

@media (max-width:900px){
  .why-grid{grid-template-columns:1fr;}
}

/* ---- SERVICES -------------------------------------------- */
.services-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:24px;
}
.service-card{
  background: linear-gradient(180deg, #0e0e0e 0%, #060606 100%);
  border:1px solid var(--line-soft);
  display:flex; flex-direction:column;
  transition: all .35s ease;
  position:relative;
}
.service-card:hover{border-color:var(--line-strong); transform:translateY(-6px);}
.service-card.is-feature{border-color:var(--line-strong);}
.service-card.is-feature::before{
  content:""; position:absolute; top:0; left:0; right:0; height:2px;
  background: var(--gold-grad);
}
.service-card-img{height:200px; width:100%;}
.service-card-body{padding:28px; display:flex; flex-direction:column; gap:14px;}
.service-card-tag{
  font-size:10px; letter-spacing:0.24em; color:var(--gold);
  text-transform:uppercase;
  display:inline-block;
}
.service-card h3{font-size:22px; font-weight:500;}
.service-card p{color:var(--muted); font-size:14px; flex:1;}
.service-card-btn{
  align-self:flex-start; margin-top:8px;
  padding:14px 22px; font-size:11px;
}

@media (max-width:900px){
  .services-grid{grid-template-columns:1fr;}
}

/* ---- GALLERY -------------------------------------------- */
.ba-slider{
  position:relative; height:480px; width:100%;
  overflow:hidden;
  border:1px solid var(--line-strong);
  user-select:none;
  cursor:ew-resize;
}
.ba-pane{position:absolute; inset:0; display:flex; align-items:center; justify-content:center;}
.ba-tag{
  position:absolute; top:24px;
  background:rgba(0,0,0,0.7); border:1px solid var(--gold);
  padding:8px 16px; font-size:11px; letter-spacing:0.24em; color:var(--gold);
  z-index:3;
}
.ba-tag-before{left:24px;}
.ba-tag-after{right:24px;}
.ba-handle{
  position:absolute; top:0; bottom:0; width:0;
  z-index:4; pointer-events:none;
  transform: translateX(-50%);
}
.ba-slider.is-hinting .ba-handle{
  transition: left 1.0s cubic-bezier(.4,.0,.2,1);
}
.ba-slider.is-hinting .ba-before{
  transition: clip-path 1.0s cubic-bezier(.4,.0,.2,1);
}
.ba-slider.is-touched .ba-before{ transition: none; }
.ba-handle-line{
  position:absolute; top:0; bottom:0; left:50%;
  width:2px; background: var(--gold-grad);
  transform:translateX(-50%);
}
.ba-handle-knob{
  position:absolute; top:50%; left:50%;
  transform:translate(-50%,-50%);
  width:56px; height:56px; border-radius:50%;
  background:var(--gold-grad); color:var(--black);
  display:flex; align-items:center; justify-content:center; gap:0;
  box-shadow: 0 0 0 6px rgba(212,175,55,0.15), 0 8px 24px rgba(0,0,0,0.6);
}
.ba-handle-knob svg:first-child{transform:rotate(180deg) translateX(-2px);}
.ba-handle-knob svg:last-child{transform:translateX(-2px);}

/* Hint state — pulse + tooltip while user hasn't touched yet */
.ba-handle-knob::before{
  content:""; position:absolute; inset:-12px;
  border-radius:50%;
  border:2px solid rgba(212,175,55,0.5);
  opacity:0;
  pointer-events:none;
}
.ba-slider.is-hinting .ba-handle-knob::before{
  animation: knobRing 1.6s cubic-bezier(.2,.7,.2,1) infinite;
}
@keyframes knobRing{
  0%   { transform: scale(1);   opacity:.7; border-width:2px; }
  100% { transform: scale(1.8); opacity:0;  border-width:1px; }
}
.ba-slider.is-hinting .ba-handle-knob{
  animation: knobBreath 1.6s ease-in-out infinite;
}
@keyframes knobBreath{
  0%,100% {
    box-shadow: 0 0 0 6px rgba(212,175,55,0.15), 0 8px 24px rgba(0,0,0,0.6);
  }
  50% {
    box-shadow: 0 0 0 10px rgba(212,175,55,0.30), 0 12px 32px rgba(212,175,55,0.4);
  }
}

/* "DRAG TO COMPARE" tooltip */
.ba-handle::after{
  content: "DRAG TO COMPARE";
  position:absolute;
  top:50%; left:50%;
  transform: translate(-50%, calc(-50% - 56px));
  background: rgba(0,0,0,0.88);
  border:1px solid var(--gold);
  padding:7px 14px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px; letter-spacing:0.22em;
  color: var(--gold);
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition: opacity .4s ease, transform .4s cubic-bezier(.2,.7,.2,1);
}
.ba-handle::before{
  content:""; position:absolute;
  top:50%; left:50%;
  transform: translate(-50%, calc(-50% - 38px)) rotate(45deg);
  width:8px; height:8px;
  background: rgba(0,0,0,0.88);
  border-right:1px solid var(--gold);
  border-bottom:1px solid var(--gold);
  opacity:0;
  pointer-events:none;
  transition: opacity .4s ease;
}
.ba-slider.is-hinting .ba-handle::after{
  opacity:1;
  animation: tooltipFloat 2s ease-in-out infinite;
}
.ba-slider.is-hinting .ba-handle::before{ opacity:1; }
@keyframes tooltipFloat{
  0%,100% { transform: translate(-50%, calc(-50% - 56px)); }
  50%     { transform: translate(-50%, calc(-50% - 64px)); }
}

/* Once touched — kill all hint animations */
.ba-slider.is-touched .ba-handle{ transition: none; }
.ba-slider.is-touched .ba-handle-knob,
.ba-slider.is-touched .ba-handle-knob::before,
.ba-slider.is-touched .ba-handle::after,
.ba-slider.is-touched .ba-handle::before{
  animation: none !important;
  opacity:0;
}
.ba-slider.is-touched .ba-handle-knob{ opacity:1; }

.gallery-filter{
  display:flex; gap:8px; flex-wrap:wrap;
  margin:48px 0 28px;
}
.gallery-chip{
  background:#0a0a0a; border:1px solid var(--line-soft);
  color:var(--bone);
  padding:10px 18px;
  font-size:12px; font-weight:500; letter-spacing:0.06em;
  cursor:pointer;
  transition:all .2s ease;
}
.gallery-chip:hover{border-color:var(--line-strong); color:var(--ivory);}
.gallery-chip.is-active{
  background:var(--gold-grad); border-color:transparent; color:#1a1102;
}

.gallery-grid{
  display:grid; grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 200px;
  gap:14px;
}
.gallery-tile{
  position:relative;
  display:flex; align-items:flex-end;
  padding:18px;
}
.gallery-tile-0{grid-column: span 2; grid-row: span 2;}
.gallery-tile-3{grid-column: span 2;}
.gallery-tile-cat{
  position:absolute; top:14px; left:14px;
  font-size:10px; letter-spacing:0.22em; color:var(--gold);
  background:rgba(0,0,0,.6); padding:4px 8px;
}

@media (max-width:900px){
  .gallery-grid{grid-template-columns:1fr 1fr; grid-auto-rows:160px;}
  .gallery-tile-0,.gallery-tile-3{grid-column: span 2;}
  .ba-slider{height:340px;}
}

/* ---- ABOUT --------------------------------------------- */
.about-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:80px; align-items:center;
}
.about-img-stack{
  position:relative; height:560px;
}
.about-img-1, .about-img-2{position:absolute;}
.about-img-1{top:0; left:0; width:75%; height:65%;}
.about-img-2{bottom:0; right:0; width:62%; height:55%; border-color:var(--gold);}
.about-copy{display:flex; flex-direction:column; gap:20px;}
.about-copy p{color:var(--bone); font-size:16px;}
.about-stats{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap:24px; margin-top:32px;
  padding-top:32px; border-top:1px solid var(--line-soft);
}
.about-stats > div{display:flex; flex-direction:column; gap:6px;}
.about-stats .serif{font-size:36px; font-weight:700; line-height:1;}
.about-stats .mono{font-size:9px; letter-spacing:0.22em; color:var(--muted); text-transform:uppercase;}

@media (max-width:980px){
  .about-grid{grid-template-columns:1fr; gap:48px;}
  .about-img-stack{height:380px;}
  .about-stats{grid-template-columns:repeat(2,1fr);}
}

/* ---- TESTIMONIALS (carousel) ---------------------------- */
.testimonial-carousel{
  position:relative;
  background: linear-gradient(180deg, #0e0e0e 0%, #060606 100%);
  border:1px solid var(--line-soft);
  padding:80px 64px 56px;
  overflow:hidden;
  border-radius: var(--radius);
}
.testimonial-carousel::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background: var(--gold-grad); opacity:.6;
}
.testimonial-quote-mark{
  position:absolute; top:8px; left:36px;
  font-size:220px; line-height:1;
  color:var(--gold);
  opacity:.15;
  pointer-events:none;
  font-weight:600;
}
.testimonial-track{
  position:relative;
  min-height:240px;
  display:flex; align-items:center; justify-content:center;
}
.testimonial-slide{
  position:absolute; inset:0; margin:0;
  display:flex; flex-direction:column; gap:24px;
  align-items:center; text-align:center;
  padding:0 32px;
  opacity:0;
  transform: translateX(40px) scale(.98);
  transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);
  pointer-events:none;
}
.testimonial-slide.is-prev{ transform: translateX(-40px) scale(.98); }
.testimonial-slide.is-active{
  opacity:1;
  transform: translateX(0) scale(1);
  pointer-events:auto;
  position:relative;
}
.testimonial-stars{display:flex; gap:6px; color:var(--gold); justify-content:center;}
.testimonial-slide blockquote{
  margin:0;
  font-family:'Cormorant Garamond', 'Times New Roman', serif;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height:1.35; font-weight:500;
  color:var(--white);
  font-style:italic;
  max-width:820px;
  text-wrap:balance;
}
.testimonial-slide blockquote::before{ content:"\201C"; }
.testimonial-slide blockquote::after{ content:"\201D"; }
.testimonial-slide figcaption{
  display:flex; flex-direction:column; gap:6px; align-items:center;
  margin-top:8px;
}
.testimonial-name{font-size:18px; font-weight:600; color:var(--gold-2); letter-spacing:0.04em;}
.testimonial-loc{font-size:11px; color:var(--muted); letter-spacing:0.18em; text-transform:uppercase;}

.testimonial-controls{
  display:flex; align-items:center; justify-content:center; gap:24px;
  margin-top:48px;
}
.testimonial-arrow{
  width:46px; height:46px; border-radius:50%;
  background:transparent; border:1px solid var(--line-strong);
  color:var(--gold); cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  transition: all .3s cubic-bezier(.2,.7,.2,1);
}
.testimonial-arrow:hover{
  background:var(--gold); color:var(--black); border-color:var(--gold);
  transform: scale(1.08);
  box-shadow: 0 6px 18px rgba(212,175,55,0.35);
}
.testimonial-arrow:first-child svg{ transform: rotate(180deg); }
.testimonial-dots{ display:flex; gap:10px; }
.testimonial-dot{
  width:8px; height:8px; border-radius:50%;
  background:rgba(246,241,231,0.18);
  border:none; cursor:pointer;
  transition: all .35s cubic-bezier(.2,.7,.2,1);
  padding:0;
}
.testimonial-dot:hover{ background:rgba(212,175,55,0.45); }
.testimonial-dot.is-active{
  width:32px; border-radius:6px;
  background:var(--gold-grad);
  box-shadow: 0 0 12px rgba(212,175,55,0.45);
}

@media (max-width:900px){
  .testimonial-carousel{ padding:56px 24px 40px; }
  .testimonial-quote-mark{ font-size:140px; left:18px; top:0; }
  .testimonial-track{ min-height:280px; }
  .testimonial-slide{ padding:0 8px; gap:18px; }
  .testimonial-controls{ gap:16px; margin-top:32px; }
}

/* ---- FAQ ----------------------------------------------- */
.faq-grid{
  display:grid; grid-template-columns: 1fr 1.4fr; gap:80px;
  align-items:start;
}
.faq-list{display:flex; flex-direction:column;}
.faq-item{border-top:1px solid var(--line-soft);}
.faq-item:last-child{border-bottom:1px solid var(--line-soft);}
.faq-q{
  width:100%; background:transparent; border:none;
  padding:24px 0; cursor:pointer; text-align:left;
  display:grid; grid-template-columns: auto 1fr auto;
  gap:20px; align-items:center;
  color:var(--ivory);
  font-family:'Cormorant Garamond', 'Times New Roman', serif; font-size:18px; font-weight:500;
}
.faq-num{font-size:11px; color:var(--gold); letter-spacing:0.18em;}
.faq-q-text{font-family:'Cormorant Garamond', 'Times New Roman', serif;}
.faq-q-icon{color:var(--gold);}
.faq-item.is-open .faq-q{color:var(--gold-2);}
.faq-a{
  padding: 0 0 24px 50px;
  color:var(--bone); font-size:15px; max-width:640px;
}

@media (max-width:980px){
  .faq-grid{grid-template-columns:1fr; gap:32px;}
  .faq-a{padding-left:0;}
}

/* ---- FINAL CTA ----------------------------------------- */
.final-cta-card{
  position:relative;
  background:
    radial-gradient(circle at 50% 0%, rgba(212,175,55,0.12), transparent 70%),
    linear-gradient(180deg, #131313 0%, #0a0a0a 100%);
  border:1px solid var(--line-strong);
  padding:80px 48px;
  display:flex; flex-direction:column; align-items:center; gap:14px;
}

/* ---- FOOTER -------------------------------------------- */
.site-footer{
  background:#000;
  padding-top:80px;
  border-top:1px solid var(--line-soft);
  position:relative;
}
.site-footer::before{
  content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background: var(--gold-grad); opacity:.6;
}
.footer-top{
  display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:60px;
  border-bottom:1px solid var(--line-soft);
}
.footer-brand img{
  width:96px; height:96px; border-radius:50%;
  border:1px solid var(--line-strong);
  margin-bottom:18px;
  box-shadow: 0 6px 24px rgba(212,175,55,0.2);
}
.footer-brand p{color:var(--muted); font-size:14px; max-width:280px;}
.footer-social{
  display:flex; gap:10px; margin-top:18px;
}
.footer-social a{
  width:36px; height:36px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--line-soft);
  color:var(--bone);
  text-decoration:none;
  transition:all .2s ease;
}
.footer-social a:hover{border-color:var(--gold); color:var(--gold);}

.footer-col h4{
  font-family:'JetBrains Mono', monospace;
  font-size:11px; letter-spacing:0.24em;
  color:var(--gold);
  margin:0 0 18px;
  text-transform:uppercase;
}
.footer-col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:12px;}
.footer-col li{font-size:13px; color:var(--bone); display:flex; gap:8px; align-items:center;}
.footer-col li svg{color:var(--gold); flex-shrink:0;}
.footer-col a{color:var(--bone); text-decoration:none; transition:color .2s ease;}
.footer-col a:hover{color:var(--gold-2);}

.footer-bottom{
  display:flex; justify-content:space-between; align-items:center;
  padding:28px 0;
  font-size:11px;
  letter-spacing:0.16em;
  color:var(--muted);
  flex-wrap:wrap; gap:14px;
}
.footer-pay span{color:var(--ivory);}

@media (max-width:980px){
  .footer-top{grid-template-columns: 1fr 1fr; gap:32px;}
}
@media (max-width:600px){
  .footer-top{grid-template-columns: 1fr;}
}

/* ============================================================
   Responsive pass — tablet & phone tightening
   ============================================================ */

@media (max-width: 1100px){
  .nav-inner{ padding:14px 22px; gap:18px; }
  .nav-brand img{ width:60px; height:60px; }
  .nav-brand-text .serif{ font-size:22px; }
  .booking-extras{ padding:32px 28px; }
  .booking-call{ font-size:24px; }
}

@media (max-width: 900px){
  /* Hero — let it breathe naturally on phones */
  .hero{ min-height: auto; padding-top: 120px; padding-bottom: 60px; }
  .hero-inner{ gap: 40px; }
  .hero-marquee{ margin-top: 56px; }
  .hero-card{ padding: 22px; }
  .hero-card-img{ height: 240px; }
  .hero-card-meta{
    grid-template-columns: 1fr 1px 1fr; row-gap: 14px;
  }
  .hero-card-meta .hero-stat:nth-child(5),
  .hero-card-meta .hero-stat-divider:nth-child(4){ display:none; }
  .hero-stat .serif{ font-size: 28px; }

  /* Booking featured — tighten padding */
  .booking-section-feature{ padding-top: 60px; padding-bottom: 70px; }
  .section-head-feature{ margin-bottom: 32px; }
  .section-head-feature h2{ font-size: clamp(28px, 6.4vw, 44px); }
  .section-head-feature p{ font-size: 15px; }

  /* Booking shell on phones */
  .booking-shell-feature > .gold-corner{ width:18px; height:18px; }
  .booking-main{ min-height: auto; }
  .stepper-num{ width: 30px; height: 30px; font-size:10px; }
  .stepper-item{ padding:14px 14px; }

  /* Booking extras */
  .booking-extras{ margin-top: 24px; padding: 22px 18px; }
  .booking-extra-icon{ width:42px; height:42px; }
  .booking-extra strong{ font-size:13px; }
  .booking-extra span{ font-size:11px; }
  .booking-call{ font-size:22px; }

  /* Section-head-feature pill smaller on mobile */
  .section-head-feature .eyebrow{ padding:8px 16px; font-size:10px; }
}

@media (max-width: 720px){
  /* Hero text */
  h1{ font-size: clamp(34px, 8.5vw, 48px); }
  .hero-sub{ font-size: 16px; }
  .hero-cta .btn{ flex:1 1 auto; min-width:0; }
  .hero-trust{ grid-template-columns: 1fr; }

  /* About */
  .about-stats .serif{ font-size:28px; }
  .about-img-stack{ height: 320px; }

  /* FAQ */
  .faq-q{ font-size:15px; gap:14px; padding: 18px 0; }

  /* Final CTA */
  .final-cta-card{ padding: 56px 22px; }

  /* Footer */
  .footer-bottom{ flex-direction: column; align-items: flex-start; }
}

@media (max-width: 540px){
  .container{ padding: 0 18px; }
  .section{ padding: 64px 0; }

  /* Hero card */
  .hero-card-img{ height: 200px; }
  .hero-card-meta{
    grid-template-columns: 1fr; gap: 14px;
  }
  .hero-card-meta .hero-stat-divider{ display:none; }
  .hero-card-meta .hero-stat{ flex-direction: row; gap: 12px; align-items: baseline; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--line-soft); }
  .hero-card-meta .hero-stat:last-child{ border-bottom: none; }

  /* Booking */
  .booking-main{ padding: 22px 18px; }
  .booking-summary{ padding: 28px 22px; }
  .stepper-num{ margin: 0 auto; }
  .stepper-item{ justify-content: center; padding: 14px 8px; border-right: 1px solid var(--line-soft); }
  .vehicle-grid{ grid-template-columns: 1fr 1fr; gap: 10px; }
  .vehicle-card{ padding: 16px 14px; }
  .vehicle-silhouette{ height: 56px; }
  .pay-grid{ grid-template-columns: 1fr; }
  .service-row{ grid-template-columns: auto 1fr; gap: 14px; padding: 16px 18px; }
  .service-row-price{ grid-column: 1 / -1; text-align: right; }

  /* Booking extras CTA */
  .booking-call{ font-size: 20px; }

  /* Process flow on tiny screens */
  .how-step-node{ width: 76px; height: 76px; }
  .how-step-num{ width: 28px; height: 28px; font-size: 10px; top:-8px; right:-8px; }
  .how-flow-line{ left: 38px; }
  .how-step-body h3{ font-size: 20px; }

  /* Testimonial carousel */
  .testimonial-carousel{ padding: 44px 18px 32px; }
  .testimonial-quote-mark{ font-size: 110px; left: 12px; }
  .testimonial-slide blockquote{ font-size: 19px; }
  .testimonial-arrow{ width: 40px; height: 40px; }

  /* Gallery */
  .gallery-grid{ grid-template-columns: 1fr; grid-auto-rows: 200px; }
  .gallery-tile-0, .gallery-tile-3{ grid-column: span 1; grid-row: auto; }
  .ba-slider{ height: 280px; }
  .ba-tag{ padding: 6px 10px; font-size: 9px; }

  /* Sections */
  .section-head{ margin-bottom: 36px; }
  .section-head p{ font-size: 15px; }

  /* Cards */
  .service-card-img{ height: 180px; }
  .service-card-body{ padding: 22px; }

  /* About images on tiny screens — single image, full width */
  .about-img-stack{ height: 240px; }
  .about-img-2{ display: none; }
  .about-img-1{ width: 100%; height: 100%; }

  /* Booking summary becomes compact */
  .summary-row{ grid-template-columns: 90px 1fr; gap: 10px; }

  /* Final CTA */
  .final-cta-card{ padding: 44px 18px; }
}

@media (max-width: 380px){
  .nav-brand-text{ display: none; }
  .nav-brand img{ width: 48px; height: 48px; }
  h1{ font-size: clamp(28px, 9vw, 40px); }
  .vehicle-grid{ grid-template-columns: 1fr; }
}
