/* ============================================================
   RENT.ICONIC — Main Stylesheet
   Mobile-first · Cinematic hero · Luxury gold accents
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600;9..40,700&display=swap');

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;color-scheme:light}
body{
  font-family:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  background:#ffffff;color:#0d0d0d;line-height:1.55;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
ul,ol{list-style:none}

/* ── DESIGN TOKENS ───────────────────────────────────────── */
:root{
  --bg:#ffffff;--bg-soft:#fafafa;--bg-muted:#f5f5f3;
  --bg-dark:#0a0a0a;--bg-darker:#050505;
  --fg:#0d0d0d;--fg-soft:#444;--fg-muted:#888;--fg-light:#bbb;
  --border:#ebebeb;--border-dark:#d8d8d8;
  --gold:#d4af37;--gold-light:#f4e4a8;--gold-deep:#c99a2e;
  --success:#22c55e;--whatsapp:#25d366;
  --danger:#ef4444;--warning:#f59e0b;
  --r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-full:999px;
  --sh-sm:0 1px 2px rgba(0,0,0,.04);
  --sh-md:0 4px 14px rgba(0,0,0,.06),0 2px 6px rgba(0,0,0,.04);
  --sh-lg:0 12px 32px rgba(0,0,0,.1);
  --sh-xl:0 24px 64px rgba(0,0,0,.15);
  --sh-gold:0 4px 20px rgba(212,175,55,.35);
  --pad-section:3.5rem;
  --max-w:1200px;
  --nav-h:64px;
  --t-fast:.15s ease;--t-base:.25s ease;--t-slow:.4s cubic-bezier(.4,0,.2,1);
}

/* ── TYPO ────────────────────────────────────────────────── */
.serif,h1,.h1,h2,.h2,h3,.h3{
  font-family:'DM Serif Display',Georgia,serif;
  font-weight:400;line-height:1.15;letter-spacing:-.02em;
}
h1,.h1{font-size:clamp(2rem,5vw,3.4rem)}
h2,.h2{font-size:clamp(1.6rem,3.5vw,2.3rem)}
h3,.h3{font-size:1.2rem}
h4{font-size:.98rem;font-weight:600}
p{color:var(--fg-soft)}
.eyebrow{
  font-size:.7rem;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--fg-muted);display:inline-block;
}
.lead{font-size:1.05rem;color:var(--fg-soft);line-height:1.65}
.gold-text{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-light) 50%,var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;
}

/* ── LAYOUT ──────────────────────────────────────────────── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 1.25rem}
.container-narrow{max-width:900px}
.section{padding:var(--pad-section) 0}
.section-sm{padding:2.5rem 0}
.divider{height:1px;background:var(--border);border:none}
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.6rem;min-height:48px;
  border-radius:var(--r-md);
  font-size:.88rem;font-weight:500;letter-spacing:.02em;
  border:1.5px solid transparent;cursor:pointer;
  transition:all var(--t-base);white-space:nowrap;line-height:1;
}
.btn-sm{padding:.55rem 1rem;min-height:38px;font-size:.78rem}
.btn-lg{padding:1rem 2rem;min-height:54px;font-size:.95rem}
.btn-primary{background:var(--fg);color:#fff;border-color:var(--fg)}
.btn-primary:hover{background:#222;transform:translateY(-1px)}
.btn-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);
  color:#0a0a0a;border:none;
  box-shadow:var(--sh-gold);
  font-weight:600;
}
.btn-gold:hover{
  background:linear-gradient(135deg,var(--gold-light) 0%,var(--gold) 100%);
  transform:translateY(-2px);
  box-shadow:0 6px 26px rgba(212,175,55,.55);
}
.btn-ghost{background:transparent;color:var(--fg);border-color:var(--border-dark)}
.btn-ghost:hover{background:var(--bg-muted);border-color:var(--fg)}
.btn-outline-light{
  background:rgba(255,255,255,.08);color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.btn-outline-light:hover{background:rgba(255,255,255,.15);border-color:#fff;transform:translateY(-1px)}
.btn-phone{
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 1.4rem;min-height:48px;
  background:rgba(34,197,94,.15);color:#fff;
  border:1.5px solid rgba(34,197,94,.45);
  border-radius:var(--r-md);
  font-size:.9rem;font-weight:500;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:all var(--t-base);
}
.btn-phone:hover{background:rgba(34,197,94,.25);border-color:var(--success);transform:translateY(-1px)}
.btn-phone svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.btn-block{width:100%}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}

/* ── NAV ─────────────────────────────────────────────────── */
.nav{
  position:sticky;top:0;z-index:100;
  height:var(--nav-h);
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav.nav-transparent{
  background:transparent;border-bottom:1px solid rgba(255,255,255,.1);
}
.nav.nav-transparent .nav-logo,
.nav.nav-transparent .nav-links a,
.nav.nav-transparent .lang-switch a{color:#fff}
.nav.nav-transparent .lang-switch a{color:rgba(255,255,255,.6)}
.nav.nav-transparent .lang-switch a.active{color:#fff}
.nav-inner{
  max-width:var(--max-w);height:100%;margin:0 auto;
  padding:0 1.25rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
}
.nav-logo{
  font-family:'DM Serif Display',serif;font-size:1.35rem;
  color:var(--fg);letter-spacing:-.01em;white-space:nowrap;
}
.nav-logo .dot{color:var(--gold)}
.nav-logo em{font-style:italic}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{
  font-size:.75rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  color:var(--fg-soft);transition:color var(--t-fast);
}
.nav-links a:hover,.nav-links a.active{color:var(--fg)}
.nav-right{display:flex;align-items:center;gap:.8rem}
.nav-phone{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.82rem;font-weight:600;color:var(--fg);
  padding:.4rem .8rem;border-radius:var(--r-sm);
  transition:background var(--t-fast);
}
.nav-phone:hover{background:var(--bg-muted)}
.nav-phone svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2}
.lang-switch{
  display:flex;gap:.4rem;align-items:center;
  font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;
}
.lang-switch a{color:var(--fg-muted);transition:color var(--t-fast)}
.lang-switch a.active{color:var(--fg)}
.lang-switch a:hover{color:var(--fg)}
.lang-switch span{color:var(--fg-light)}
.nav-burger{
  display:none;width:44px;height:44px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  position:relative;z-index:101;
  cursor:pointer;
}
.nav-burger span{
  width:22px;height:2px;background:var(--fg);
  transition:transform var(--t-base),opacity var(--t-base);
  transform-origin:center;
}
.nav.nav-transparent .nav-burger span{background:#fff}
/* Burger -> X animation when menu is open */
.nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.is-open span:nth-child(2){opacity:0}
.nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ══════════════════════════════════════════════════════════
   HERO CINÉMATOGRAPHIQUE (photo réelle S63 Lauterbrunnen)
   ══════════════════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;text-align:center;
  overflow:hidden;
  background:#0a0a0a;
  color:#fff;
  isolation:isolate;
  margin-top:calc(var(--nav-h) * -1);
  padding-top:var(--nav-h);
}
.hero-bg{
  position:absolute;inset:0;z-index:-3;
  background-image:url('/assets/img/both-cars-front.jpg');
  background-size:cover;
  background-position:center 60%;
  animation:hero-zoom 20s ease-in-out infinite alternate;
}
@keyframes hero-zoom{
  from{transform:scale(1.02)}
  to{transform:scale(1.1)}
}
/* Overlay sombre pour lisibilité texte */
.hero-overlay{
  position:absolute;inset:0;z-index:-2;
  background:
    linear-gradient(180deg,
      rgba(10,10,10,.55) 0%,
      rgba(10,10,10,.35) 40%,
      rgba(10,10,10,.55) 75%,
      rgba(10,10,10,.85) 100%),
    radial-gradient(ellipse at 70% 40%,rgba(212,175,55,.12) 0%,transparent 55%);
}
/* Bord supérieur dégradé pour nav */
.hero-topfade{
  position:absolute;top:0;left:0;right:0;
  height:180px;z-index:-1;
  background:linear-gradient(180deg,rgba(10,10,10,.7) 0%,transparent 100%);
  pointer-events:none;
}

/* Gold accent particles (garde le luxe) */
.hero-particles{position:absolute;inset:0;z-index:-1;pointer-events:none}
.hero-particle{
  position:absolute;
  width:2.5px;height:2.5px;border-radius:50%;
  background:rgba(212,175,55,.6);
  box-shadow:0 0 6px rgba(212,175,55,.8);
  animation:particle-rise linear infinite;
}
@keyframes particle-rise{
  from{transform:translateY(100vh);opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  to{transform:translateY(-10vh);opacity:0}
}

.hero-content{
  position:relative;z-index:2;
  padding:7rem 1.25rem 5rem;
  max-width:820px;
  width:100%;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;margin-bottom:1.3rem;
  color:rgba(255,255,255,.85);font-size:.7rem;letter-spacing:.2em;
  text-transform:uppercase;font-weight:500;
}
.hero-eyebrow::before,.hero-eyebrow::after{
  content:'';width:32px;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.hero h1{
  color:#fff;font-size:clamp(2.2rem,7vw,4.4rem);
  line-height:1.05;margin-bottom:1.3rem;
  text-shadow:0 4px 40px rgba(0,0,0,.8),0 2px 20px rgba(0,0,0,.6);
}
.hero h1 em{font-style:italic}
.hero-lead{
  max-width:560px;margin:0 auto 2.2rem;
  color:rgba(255,255,255,.92);
  font-size:clamp(.95rem,2.2vw,1.1rem);line-height:1.6;
  text-shadow:0 2px 10px rgba(0,0,0,.5);
}
.hero-ctas{
  display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;
  margin-bottom:1.8rem;
}
.hero-trust{
  display:flex;justify-content:center;gap:1.8rem;flex-wrap:wrap;
  font-size:.78rem;color:rgba(255,255,255,.75);
  padding-top:1rem;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
}
.hero-trust-item{display:flex;align-items:center;gap:.4rem}
.hero-trust-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--success);box-shadow:0 0 8px rgba(34,197,94,.8);
}

/* Scroll indicator */
.hero-scroll{
  position:absolute;bottom:1.5rem;left:50%;
  transform:translateX(-50%);
  color:rgba(255,255,255,.6);
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  animation:scroll-bounce 2s ease-in-out infinite;z-index:2;
}
.hero-scroll svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.5}
@keyframes scroll-bounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(8px)}
}

/* ── LOGO IMAGE (wordmark "Rent.Iconic") ─────────────────── */
.logo-img{
  height:22px;width:auto;
  display:inline-block;vertical-align:middle;
  object-fit:contain;
  flex-shrink:0;
  transition:opacity var(--t-base);
}
/* Par défaut on affiche la version noire (sur fond clair) */
.logo-img.logo-light{display:none}
/* Sur la nav transparente (hero), on affiche la version blanche */
.nav.nav-transparent .logo-img.logo-dark{display:none}
.nav.nav-transparent .logo-img.logo-light{display:inline-block}
/* Footer toujours sur fond blanc, donc version noire */
.footer-brand .logo-img{height:28px}
.nav-logo{
  display:inline-flex;align-items:center;gap:0;
  white-space:nowrap;
}
/* Le texte est dans le logo image, on cache le span */
.nav-logo > span{display:none}

/* ── GUARANTEES BAR ──────────────────────────────────────── */
.guarantees{
  background:var(--bg-soft);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:1.6rem 0;
}
.guarantees-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
}
.g-item{display:flex;align-items:center;gap:.8rem}
.g-icon{
  width:38px;height:38px;border-radius:var(--r-md);
  background:var(--fg);color:#fff;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.g-icon svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8}
.g-text .g-title{font-size:.85rem;font-weight:600;line-height:1.3}
.g-text .g-sub{font-size:.72rem;color:var(--fg-muted);margin-top:.15rem}

/* ── SECTION HEAD ────────────────────────────────────────── */
.section-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:2rem;gap:1.5rem;flex-wrap:wrap;
}
.section-head .h-text{max-width:560px}
.section-head h2{margin-top:.5rem}
.section-head .h-sub{margin-top:.5rem;color:var(--fg-muted);font-size:.95rem}
.section-head .h-action a{
  font-size:.82rem;font-weight:500;color:var(--fg);
  display:inline-flex;align-items:center;gap:.4rem;
  padding-bottom:.2rem;border-bottom:1px solid var(--fg);
  transition:gap var(--t-base);
}
.section-head .h-action a:hover{gap:.7rem}

/* ── VEHICLE CARD ────────────────────────────────────────── */
.vehicle-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;
}
.v-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;transition:all var(--t-base);display:flex;flex-direction:column;
}
.v-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px);border-color:var(--border-dark)}
.v-card-img{
  position:relative;height:220px;background:var(--bg-muted);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
}
.v-card-img img,.v-card-img svg,.v-card-img object{
  width:100%;height:100%;object-fit:cover;transition:transform .6s ease;
}
.v-card:hover .v-card-img img,.v-card:hover .v-card-img svg{transform:scale(1.04)}
.v-card-badges{position:absolute;top:12px;left:12px;display:flex;gap:.4rem;z-index:2}
.v-badge{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-full);
  padding:.3rem .75rem;font-size:.7rem;font-weight:500;
  display:inline-flex;align-items:center;gap:.35rem;box-shadow:var(--sh-sm);
}
.v-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--success)}
.v-card-body{padding:1.1rem 1.2rem 1.3rem;flex:1;display:flex;flex-direction:column}
.v-meta{display:flex;align-items:center;gap:.4rem;margin-bottom:.3rem;font-size:.7rem;color:var(--fg-muted)}
.v-brand{font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--fg)}
.v-sep{color:var(--fg-light)}
.v-name{
  font-family:'DM Serif Display',serif;font-size:1.25rem;
  margin-bottom:.5rem;line-height:1.25;
}
.v-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}
.v-chip{
  font-size:.7rem;color:var(--fg-soft);background:var(--bg-muted);
  padding:.25rem .65rem;border-radius:var(--r-full);
}
.v-card-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:.9rem;margin-top:auto;border-top:1px solid var(--border);
}
.v-price{display:flex;align-items:baseline;gap:.25rem}
.v-price-amount{font-family:'DM Serif Display',serif;font-size:1.3rem}
.v-price-unit{font-size:.78rem;color:var(--fg-muted)}
.v-rating{display:flex;align-items:center;gap:.3rem;font-size:.82rem;font-weight:500}
.v-rating .star{color:var(--gold)}
.v-rating .count{color:var(--fg-muted);font-weight:400;font-size:.75rem}

/* ── FLEET SECTION (premium presentation) ────────────────── */
.fleet-section{
  background:linear-gradient(180deg,#fff 0%,var(--bg-soft) 100%);
  scroll-margin-top:var(--nav-h);
}
.fleet-grid{
  grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
  gap:1.8rem;
  max-width:920px;margin:0 auto;
}
.v-card-feature{
  border:1px solid var(--border);
  position:relative;overflow:hidden;
}
.v-card-feature .v-card-img{height:280px;background:#0a0a0a}
.v-card-feature .v-card-img img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 60%;
  transition:transform .8s cubic-bezier(.4,0,.2,1);
}
.v-card-feature:hover .v-card-img img{transform:scale(1.06)}
.v-card-feature .v-card-body{padding:1.4rem 1.5rem 1.5rem}
.v-card-feature .v-name{
  font-size:1.5rem;margin-bottom:.6rem;line-height:1.15;
}
.v-card-desc{
  font-size:.88rem;color:var(--fg-muted);line-height:1.6;
  margin-bottom:1rem;
}
.v-badge-gold{
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);
  color:#0a0a0a;border:none;font-weight:600;
}
/* Badge "Bientôt disponible" — ambre lumineux */
.v-badge-soon{
  background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);
  color:#fff;border:none;font-weight:600;
}
.v-badge-soon .v-badge-dot{
  background:#fde68a;
  animation:pulse-soon 1.6s ease-in-out infinite;
}
@keyframes pulse-soon{
  0%,100%{box-shadow:0 0 0 0 rgba(253,230,138,.6);transform:scale(1)}
  50%{box-shadow:0 0 0 6px rgba(253,230,138,0);transform:scale(1.15)}
}

/* Card "Bientôt disponible" : overlay subtil sur l'image + style désaturé */
.v-card-soon .v-card-img{position:relative}
.v-card-soon .v-card-img img{
  filter:saturate(.85) brightness(.85);
  transition:filter var(--t-base);
}
.v-card-soon:hover .v-card-img img{
  filter:saturate(1) brightness(.95);
}
.v-card-overlay-soon{
  position:absolute;inset:0;
  background:linear-gradient(180deg,
    rgba(10,10,10,.1) 0%,
    rgba(10,10,10,.5) 60%,
    rgba(10,10,10,.85) 100%);
  display:flex;align-items:flex-end;justify-content:center;
  padding:1.5rem;
  pointer-events:none;
}
.v-soon-content{
  text-align:center;color:#fff;
  transform:translateY(0);
  transition:transform var(--t-base);
}
.v-card-soon:hover .v-soon-content{
  transform:translateY(-4px);
}
.v-soon-eyebrow{
  display:block;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:#f59e0b;margin-bottom:.4rem;font-weight:600;
}
.v-soon-content h4{
  font-family:'DM Serif Display',serif;
  font-size:1.15rem;color:#fff;
  font-weight:400;line-height:1.3;
}
.v-chips strong{color:var(--fg);font-weight:600}
.v-price-from{
  font-size:.7rem;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em;
  margin-right:.3rem;
}
.v-card-cta{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.82rem;font-weight:500;color:var(--fg);
  padding:.5rem .9rem;border:1px solid var(--border-dark);border-radius:var(--r-sm);
  transition:all var(--t-fast);
}
.v-card-feature:hover .v-card-cta{
  background:var(--fg);color:#fff;border-color:var(--fg);gap:.6rem;
}

/* CTA secondaire sous flotte */
.fleet-cta{
  text-align:center;margin-top:3rem;
  padding:2rem 1.5rem;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  max-width:600px;margin-left:auto;margin-right:auto;margin-top:3rem;
}
.fleet-cta p{
  font-size:1.05rem;color:var(--fg);margin-bottom:1.2rem;
  font-family:'DM Serif Display',serif;
}
.fleet-cta-actions{
  display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;
}
.fleet-cta-actions .btn{min-width:auto}
.fleet-cta-actions .btn-ghost svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2}

/* ── HOW IT WORKS ────────────────────────────────────────── */
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.how-card{
  background:var(--bg-soft);border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.8rem 1.5rem;transition:all var(--t-base);
}
.how-card:hover{background:#fff;box-shadow:var(--sh-md);border-color:var(--border-dark)}
.how-num{
  font-family:'DM Serif Display',serif;font-size:2rem;
  color:var(--gold);line-height:1;margin-bottom:1rem;display:block;
}
.how-icon{
  width:40px;height:40px;border-radius:var(--r-md);
  background:var(--fg);color:#fff;
  display:flex;align-items:center;justify-content:center;margin-bottom:1rem;
}
.how-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.8}
.how-title{font-size:1.05rem;font-weight:600;margin-bottom:.4rem;letter-spacing:-.01em}
.how-desc{font-size:.9rem;color:var(--fg-muted);line-height:1.6}

/* ── TESTIMONIALS ────────────────────────────────────────── */
.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.t-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .5s cubic-bezier(.4,0,.2,1),box-shadow .5s ease;
  box-shadow:0 4px 14px rgba(10,10,10,.04);
}
.t-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 50px rgba(10,10,10,.1),0 8px 18px rgba(10,10,10,.05);
}
.t-photo{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  background:#0a0a0a;
}
.t-photo img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s cubic-bezier(.4,0,.2,1);
}
.t-card:hover .t-photo img{transform:scale(1.06)}
.t-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 50%,rgba(10,10,10,.5) 100%);
  pointer-events:none;
}
.t-photo-tag{
  position:absolute;left:1rem;bottom:1rem;z-index:2;
  display:inline-flex;align-items:center;
  padding:.4rem .85rem;
  background:rgba(10,10,10,.75);backdrop-filter:blur(8px);
  border:1px solid rgba(212,175,55,.4);
  color:var(--gold);
  font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  border-radius:999px;
}
.t-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}
.t-stars{color:var(--gold);font-size:.95rem;letter-spacing:3px;margin-bottom:.8rem}
.t-text{font-size:.92rem;color:var(--fg);line-height:1.7;margin-bottom:1.2rem;flex:1;font-weight:400}
.t-author{display:flex;align-items:center;gap:.8rem;padding-top:1rem;border-top:1px solid var(--border)}
.t-avatar{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-deep));
  display:flex;align-items:center;justify-content:center;
  font-size:.78rem;font-weight:700;color:#0a0a0a;
  flex-shrink:0;
}
.t-name{font-size:.9rem;font-weight:600;color:var(--fg)}
.t-role{font-size:.76rem;color:var(--fg-muted);margin-top:.1rem}

/* ── CTA DARK (simplifié: 1 bouton gros vers bit.ly) ────── */
.cta-dark{
  background:linear-gradient(135deg,#0a0a0a 0%,#1a1a1a 100%);
  color:#fff;padding:4rem 0;text-align:center;position:relative;overflow:hidden;
}
.cta-dark::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at top,rgba(212,175,55,.1) 0%,transparent 60%);
  pointer-events:none;
}
.cta-dark h2{color:#fff;margin-bottom:.7rem;position:relative}
.cta-dark .lead{color:rgba(255,255,255,.7);margin:0 auto 2rem;max-width:520px;position:relative}
.cta-dark-actions{
  display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;
  position:relative;
}
.cta-dark-phone{
  margin-top:1.5rem;color:rgba(255,255,255,.6);font-size:.82rem;position:relative;
}
.cta-dark-phone a{color:#fff;font-weight:600;border-bottom:1px solid var(--gold);padding-bottom:1px}

/* ── FAQ ─────────────────────────────────────────────────── */
.faq{max-width:780px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border);padding:1.2rem 0;background:transparent}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-size:1.05rem;font-weight:600;cursor:pointer;width:100%;text-align:left;
  color:#0d0d0d;
  background:transparent;border:none;padding:.4rem 0;
  font-family:inherit;
}
.faq-q:hover{color:var(--gold-deep)}
.faq-q::after{
  content:'+';font-size:1.5rem;color:var(--gold);
  transition:transform var(--t-base);font-weight:300;
  flex-shrink:0;
}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-item.open .faq-q{color:var(--gold-deep)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height var(--t-slow),padding var(--t-slow);
  color:#0d0d0d;font-size:.95rem;line-height:1.75;font-weight:400;
}
.faq-item.open .faq-a{max-height:500px;padding-top:.9rem}
.faq-a a{color:var(--gold-deep);font-weight:600;border-bottom:1px solid var(--gold)}
.faq-a strong{color:#0d0d0d;font-weight:700}

/* ── FOOTER ──────────────────────────────────────────────── */
.footer{background:#fff;border-top:1px solid var(--border);padding:3rem 0 1.5rem}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;
  gap:2.5rem;margin-bottom:2.5rem;
}
.footer-brand .nav-logo{font-size:1.6rem;margin-bottom:.8rem;display:inline-block}
.footer-tagline{font-size:.85rem;color:var(--fg-muted);line-height:1.6;max-width:260px;margin-bottom:1rem}
.footer-social{display:flex;gap:.6rem}
.footer-social a{
  width:36px;height:36px;border:1px solid var(--border);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t-fast);
}
.footer-social a:hover{background:var(--fg);border-color:var(--fg)}
.footer-social a:hover svg{stroke:#fff;fill:#fff}
.footer-social svg{width:16px;height:16px;stroke:var(--fg);fill:var(--fg)}
.footer-col h4{
  font-size:.72rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:1rem;
}
.footer-col ul li{margin-bottom:.6rem}
.footer-col a{font-size:.85rem;color:var(--fg-muted);transition:color var(--t-fast)}
.footer-col a:hover{color:var(--fg)}
.footer-col .phone-highlight{
  display:inline-block;
  font-size:1rem;font-weight:600;color:var(--fg);
  padding:.5rem .9rem;
  border:1px solid var(--border-dark);border-radius:var(--r-sm);
  margin-bottom:.6rem;
}
.footer-col .phone-highlight:hover{background:var(--fg);color:#fff;border-color:var(--fg)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:1.5rem;border-top:1px solid var(--border);
  font-size:.75rem;color:var(--fg-muted);gap:1rem;flex-wrap:wrap;
}
.footer-payments{display:flex;gap:.4rem;align-items:center}
.footer-payments span{
  padding:.2rem .5rem;border:1px solid var(--border);border-radius:var(--r-sm);
  font-size:.66rem;font-weight:600;color:var(--fg-muted);
}

/* ── BREADCRUMBS ─────────────────────────────────────────── */
.breadcrumbs{
  padding:1rem 0;font-size:.78rem;color:var(--fg-muted);
  display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;
}
.breadcrumbs a:hover{color:var(--fg);text-decoration:underline}
.breadcrumbs .sep{color:var(--fg-light)}
.breadcrumbs .current{color:var(--fg);font-weight:500}

/* ── VEHICLE DETAIL PAGE ─────────────────────────────────── */
.v-detail{display:grid;grid-template-columns:1fr 420px;gap:3rem;align-items:flex-start}
.v-gallery{display:flex;flex-direction:column;gap:.8rem}
.v-gallery-main{
  aspect-ratio:16/10;background:var(--bg-muted);
  border-radius:var(--r-lg);overflow:hidden;position:relative;
}
.v-gallery-main img,.v-gallery-main svg,.v-gallery-main object{
  width:100%;height:100%;object-fit:cover;
}
.v-gallery-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.v-gallery-thumbs .thumb{
  aspect-ratio:4/3;background:var(--bg-muted);border-radius:var(--r-md);
  overflow:hidden;cursor:pointer;border:2px solid transparent;
  transition:all var(--t-fast);
}
.v-gallery-thumbs .thumb:hover,.v-gallery-thumbs .thumb.active{border-color:var(--fg)}
.v-gallery-thumbs .thumb img,.v-gallery-thumbs .thumb svg,.v-gallery-thumbs .thumb object{
  width:100%;height:100%;object-fit:cover;
}

.v-info-head{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}
.v-info-head .eyebrow{margin-bottom:.5rem}
.v-info-head h1{margin-bottom:.7rem;font-size:clamp(1.8rem,3vw,2.5rem)}
.v-info-head .v-rating{font-size:.9rem}

.v-specs-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:1rem;margin-bottom:2rem;
}
.v-spec{
  padding:1rem;background:var(--bg-soft);border-radius:var(--r-md);border:1px solid var(--border);
}
.v-spec-label{font-size:.7rem;color:var(--fg-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:.3rem}
.v-spec-value{font-family:'DM Serif Display',serif;font-size:1.2rem}

.v-features{margin-bottom:2rem}
.v-features h3{margin-bottom:1rem;font-size:1.1rem}
.v-features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
.v-feature{display:flex;align-items:center;gap:.6rem;font-size:.87rem;color:var(--fg-soft)}
.v-feature svg{width:16px;height:16px;stroke:var(--success);fill:none;stroke-width:2.5;flex-shrink:0}

/* ── BOOKING CARD ────────────────────────────────────────── */
.booking-card{
  position:sticky;top:calc(var(--nav-h) + 1rem);
  background:#fff;border:1px solid var(--border-dark);border-radius:var(--r-lg);
  padding:1.6rem;box-shadow:var(--sh-md);
}
.booking-card-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1.3rem}
.booking-price{display:flex;align-items:baseline;gap:.3rem}
.booking-price .amount{font-family:'DM Serif Display',serif;font-size:1.8rem}
.booking-price .unit{font-size:.88rem;color:var(--fg-muted)}
.date-picker{
  display:grid;grid-template-columns:1fr 1fr;
  border:1px solid var(--border-dark);border-radius:var(--r-md);
  margin-bottom:.8rem;overflow:hidden;
}
.date-field{padding:.7rem .9rem;border-right:1px solid var(--border)}
.date-field:last-child{border-right:none}
.date-field label{font-size:.62rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:.2rem}
.date-field input{border:none;outline:none;width:100%;font-size:.85rem;background:transparent;min-height:auto}
.booking-summary{
  background:var(--bg-soft);border-radius:var(--r-md);
  padding:1rem;margin:1rem 0;font-size:.85rem;
}
.booking-summary .line{display:flex;justify-content:space-between;padding:.35rem 0;color:var(--fg-soft)}
.booking-summary .line.total{
  border-top:1px solid var(--border-dark);padding-top:.6rem;margin-top:.3rem;
  font-weight:600;color:var(--fg);font-size:.95rem;
}
.booking-note{font-size:.72rem;color:var(--fg-muted);text-align:center;margin-top:.7rem}
.booking-note svg{display:inline;width:12px;height:12px;vertical-align:middle;margin-right:.2rem}

/* ── CALENDAR ────────────────────────────────────────────── */
.calendar{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.2rem;max-width:520px;
}
.cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}
.cal-head h4{font-size:1rem}
.cal-nav{display:flex;gap:.3rem}
.cal-nav button{
  width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
}
.cal-nav svg{width:14px;height:14px;stroke:var(--fg);fill:none;stroke-width:2}
.cal-weekdays,.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.2rem}
.cal-weekdays{margin-bottom:.4rem}
.cal-weekdays div{
  font-size:.66rem;font-weight:600;text-transform:uppercase;
  color:var(--fg-muted);text-align:center;padding:.3rem 0;
}
.cal-day{
  aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:.82rem;border-radius:var(--r-sm);cursor:pointer;
  transition:background var(--t-fast);position:relative;
}
.cal-day:hover:not(.disabled):not(.booked){background:var(--bg-muted)}
.cal-day.empty{cursor:default}
.cal-day.disabled{color:var(--fg-light);cursor:not-allowed}
.cal-day.booked{
  background:repeating-linear-gradient(45deg,#f5f5f5,#f5f5f5 3px,#e5e5e5 3px,#e5e5e5 6px);
  color:var(--fg-light);cursor:not-allowed;text-decoration:line-through;
}
.cal-day.today{font-weight:600;border:1px solid var(--border-dark)}
.cal-day.selected{background:var(--fg)!important;color:#fff!important}

/* ── FORMS ───────────────────────────────────────────────── */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.4rem}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:.85rem 1rem;min-height:48px;
  border:1px solid var(--border-dark);border-radius:var(--r-md);
  background:#fff;font-size:.95rem;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--fg);box-shadow:0 0 0 3px rgba(0,0,0,.05);
}
.form-group .hint{font-size:.75rem;color:var(--fg-muted);margin-top:.3rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* ── STEPPER ─────────────────────────────────────────────── */
.stepper{display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem;gap:.5rem;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:.5rem}
.step-num{
  width:28px;height:28px;border-radius:50%;
  background:var(--bg-muted);color:var(--fg-muted);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:600;transition:all var(--t-base);
}
.step.active .step-num{background:var(--fg);color:#fff}
.step.done .step-num{background:var(--success);color:#fff}
.step-label{font-size:.78rem;color:var(--fg-muted)}
.step.active .step-label{color:var(--fg);font-weight:500}
.step-bar{width:40px;height:1px;background:var(--border-dark)}

/* ── ALERTS ──────────────────────────────────────────────── */
.alert{
  padding:1rem 1.2rem;border-radius:var(--r-md);font-size:.88rem;
  display:flex;align-items:flex-start;gap:.7rem;margin-bottom:1rem;
}
.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}
.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}

/* ── FLOATING ACTIONS — Bouton Réserver toujours visible ─── */
.float-contact{
  position:fixed;bottom:1.2rem;right:1.2rem;z-index:90;
  display:flex;align-items:center;gap:.6rem;
  flex-direction:row-reverse;
}

/* Le gros bouton Réserver doré */
.float-btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.95rem 1.4rem;height:54px;
  background:linear-gradient(135deg,var(--gold) 0%,var(--gold-deep) 100%);
  color:#0a0a0a;
  font-size:.92rem;font-weight:600;letter-spacing:.02em;
  border-radius:var(--r-full);
  box-shadow:
    0 10px 28px rgba(212,175,55,.45),
    0 4px 12px rgba(0,0,0,.18),
    inset 0 1px 0 rgba(255,255,255,.3);
  transition:all var(--t-base);
  white-space:nowrap;
  position:relative;overflow:hidden;
}
.float-btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--gold-light) 0%,var(--gold) 100%);
  opacity:0;transition:opacity var(--t-base);
}
.float-btn-primary:hover::before{opacity:1}
.float-btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:
    0 14px 36px rgba(212,175,55,.55),
    0 6px 18px rgba(0,0,0,.22),
    inset 0 1px 0 rgba(255,255,255,.4);
}
.float-btn-primary > *{position:relative;z-index:1}
.float-btn-primary .icon-spark{
  width:18px;height:18px;fill:#0a0a0a;
  animation:spark-pulse 2.4s ease-in-out infinite;
}
@keyframes spark-pulse{
  0%,100%{transform:scale(1);opacity:1}
  50%{transform:scale(1.18) rotate(20deg);opacity:.75}
}
.float-btn-primary .icon-arrow{
  width:14px;height:14px;stroke:#0a0a0a;fill:none;stroke-width:2.5;
  transition:transform var(--t-base);
}
.float-btn-primary:hover .icon-arrow{transform:translateX(3px)}

/* Petits boutons ronds WhatsApp et Phone (à côté) */
.float-btn{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(0,0,0,.22);color:#fff;
  transition:all var(--t-base);
  flex-shrink:0;
}
.float-btn:hover,.float-btn:active{transform:scale(1.08)}
.float-btn.whatsapp{background:var(--whatsapp)}
.float-btn.phone{background:var(--fg)}
.float-btn svg{width:22px;height:22px;fill:#fff}
.float-btn.phone svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2}

/* ── FADE-IN ─────────────────────────────────────────────── */
.fade-in{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.fade-in.visible{opacity:1;transform:none}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE (mobile-first polish)
   ══════════════════════════════════════════════════════════ */
@media (max-width:1024px){
  .v-detail{grid-template-columns:1fr;gap:2rem}
  .booking-card{position:static}
  .footer-grid{grid-template-columns:1fr 1fr 1fr;gap:2rem}
  .footer-brand{grid-column:span 3}
}

@media (max-width:768px){
  :root{--pad-section:2.8rem}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-links.mobile-open{
    display:flex !important;
    position:fixed !important;
    top:var(--nav-h) !important;
    left:0 !important;right:0 !important;
    width:100vw !important;
    height:calc(100vh - var(--nav-h)) !important;
    background:#fff !important;
    border-top:1px solid var(--border);
    flex-direction:column !important;
    padding:1.5rem 1.5rem 2rem !important;gap:0 !important;
    box-shadow:0 8px 30px rgba(0,0,0,.15);
    overflow-y:auto;z-index:1000 !important;
    align-items:stretch !important;
    animation:slide-down .25s ease;
  }
  @keyframes slide-down{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
  .nav-links.mobile-open li{border-bottom:1px solid var(--border);list-style:none;width:100%}
  .nav-links.mobile-open li:last-child{border-bottom:none}
  .nav-links.mobile-open a{
    font-size:1.05rem;padding:1.1rem 0;
    display:block;color:var(--fg) !important;
    letter-spacing:.05em;text-transform:uppercase;font-weight:500;
  }
  .nav.nav-transparent .nav-burger.is-open span,
  .nav .nav-burger.is-open span{background:var(--fg) !important}
  /* Quand le menu est ouvert, force la nav en mode clair */
  .nav:has(.nav-burger.is-open){
    background:rgba(255,255,255,.98) !important;
    border-bottom:1px solid var(--border);
  }
  .nav:has(.nav-burger.is-open) .nav-logo span,
  .nav:has(.nav-burger.is-open) .lang-switch a.active{color:var(--fg) !important}
  .nav-phone{padding:.4rem .7rem;font-size:.8rem}
  .nav-phone .nav-phone-text{display:none}

  /* Hero mobile */
  .hero{min-height:90vh;padding-top:var(--nav-h)}
  .hero-bg{
    background-image:url('/assets/img/both-cars-mobile.jpg');
    background-position:center 75%;
    background-size:cover;
  }
  /* Overlay un peu plus léger sur mobile pour voir les voitures */
  .hero-overlay{
    background:
      linear-gradient(180deg,
        rgba(10,10,10,.5) 0%,
        rgba(10,10,10,.2) 35%,
        rgba(10,10,10,.35) 70%,
        rgba(10,10,10,.85) 100%),
      radial-gradient(ellipse at 50% 35%,rgba(212,175,55,.1) 0%,transparent 60%);
  }
  .hero-content{padding:2rem 1rem 3rem;width:100%}
  .hero h1{font-size:clamp(2rem,8.5vw,2.8rem);line-height:1.1;margin-bottom:1rem}
  .hero-lead{font-size:.95rem;line-height:1.55;padding:0 .3rem;margin-bottom:1.5rem}
  .hero-eyebrow{font-size:.65rem;letter-spacing:.18em;margin-bottom:1rem}
  .hero-eyebrow::before,.hero-eyebrow::after{width:24px}
  .hero-ctas{flex-direction:column;width:100%;gap:.6rem;margin-bottom:1.2rem}
  .hero-ctas .btn,.hero-ctas .btn-phone{width:100%;justify-content:center;font-size:.9rem}
  .hero-trust{gap:1rem;font-size:.7rem;padding:0 .5rem;flex-wrap:wrap;justify-content:center}
  .hero-scroll{display:none}

  /* Sections */
  .section{padding:var(--pad-section) 0}
  .section-head{flex-direction:column;align-items:flex-start;margin-bottom:1.5rem}
  .section-head h2{font-size:clamp(1.5rem,5.5vw,1.9rem)}
  .section-head .h-sub{font-size:.88rem}

  /* Guarantees 2x2 */
  .guarantees-grid{grid-template-columns:1fr 1fr;gap:.9rem}
  .g-item{gap:.55rem}
  .g-icon{width:34px;height:34px}
  .g-text .g-title{font-size:.78rem}
  .g-text .g-sub{font-size:.68rem}

  /* Vehicle cards */
  .vehicle-grid{grid-template-columns:1fr;gap:1rem}
  .v-card-img{height:200px}
  .v-card-feature .v-card-img{height:240px}
  .v-card-feature .v-card-body{padding:1.2rem}
  .v-card-feature .v-name{font-size:1.3rem}
  .v-card-desc{font-size:.85rem}
  .v-name{font-size:1.1rem}
  .v-price-amount{font-size:1.2rem}
  .fleet-cta{margin-top:2rem;padding:1.5rem 1.2rem}
  .fleet-cta p{font-size:.95rem}
  .fleet-cta-actions{flex-direction:column}
  .fleet-cta-actions .btn{width:100%}

  /* How */
  .how-grid{grid-template-columns:1fr;gap:1rem}
  .how-card{padding:1.4rem 1.3rem}

  /* Testimonials */
  .test-grid{grid-template-columns:1fr;gap:.8rem}

  /* CTA dark */
  .cta-dark{padding:3rem 0}
  .cta-dark-actions{flex-direction:column;width:100%;padding:0 1.5rem}
  .cta-dark-actions .btn{width:100%}

  /* Footer */
  .footer{padding:2.5rem 0 1rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.5rem}
  .footer-brand{grid-column:span 2}
  .footer-bottom{flex-direction:column;text-align:center;gap:.8rem}
  .form-row{grid-template-columns:1fr}

  /* FAQ */
  .faq-q{font-size:.95rem}
  .faq-a{font-size:.88rem}

  /* Booking */
  .booking-card{padding:1.2rem}
  .booking-price .amount{font-size:1.5rem}

  /* Stepper */
  .stepper{gap:.25rem;margin-bottom:1.8rem}
  .step-label{font-size:.68rem}
  .step-bar{width:18px}
}

@media (max-width:480px){
  .nav-inner{padding:0 1rem;gap:.6rem}
  .nav-logo{font-size:1.15rem}
  .logo-img{height:18px}
  .footer-brand .logo-img{height:24px}
  .lang-switch{font-size:.62rem;gap:.2rem}

  .hero-content{padding:4.5rem 1rem 3rem}
  .hero h1{font-size:clamp(1.8rem,9vw,2.2rem)}

  .v-gallery-thumbs{grid-template-columns:repeat(3,1fr)}
  .v-specs-grid{grid-template-columns:1fr 1fr;gap:.6rem}
  .v-spec{padding:.8rem}
  .v-features-grid{grid-template-columns:1fr}

  .footer-grid{grid-template-columns:1fr;gap:1.8rem}
  .footer-brand{grid-column:span 1}

  .container{padding:0 1rem}

  /* Reduce floating btn size on very small screens */
  .float-btn{width:44px;height:44px}
  .float-btn svg{width:20px;height:20px}
  .float-btn-primary{padding:.75rem 1.1rem;height:48px;font-size:.85rem}
  .float-btn-primary .icon-spark{width:16px;height:16px}
  .float-contact{bottom:1rem;right:1rem;gap:.4rem}
  /* Bottom safe area to prevent floating CTA from hiding content */
  .footer{padding-bottom:5rem}
}

/* ── PRINT ───────────────────────────────────────────────── */
@media print{
  .nav,.footer,.cta-dark,.booking-card,.float-contact{display:none}
}

/* ══════════════════════════════════════════════════════════
   INTRO PREMIUM — Sobre Hermès/Rolls-Royce
   Apparition logo → trait or → dissolution → hero
   ══════════════════════════════════════════════════════════ */
.intro-overlay{
  position:fixed;inset:0;z-index:9999;
  background:#0a0a0a;
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
  /* Animation principale : dissolution vers le haut */
  animation:intro-exit 600ms cubic-bezier(.7,0,.3,1) 2400ms forwards;
}
.intro-overlay.skipped{
  animation:intro-exit-fast 280ms ease forwards !important;
}
.intro-overlay.hidden{display:none !important}

@keyframes intro-exit{
  0%   {opacity:1;transform:translateY(0);visibility:visible}
  99%  {opacity:0;transform:translateY(-30px);visibility:hidden}
  100% {opacity:0;visibility:hidden;display:none}
}
@keyframes intro-exit-fast{
  to{opacity:0;visibility:hidden}
}

.intro-content{
  display:flex;flex-direction:column;align-items:center;
  gap:1.6rem;
  /* Apparition lente du contenu central */
  opacity:0;transform:translateY(8px);
  animation:intro-content-in 1100ms cubic-bezier(.4,0,.2,1) 250ms forwards;
}
@keyframes intro-content-in{
  to{opacity:1;transform:translateY(0)}
}

.intro-logo{
  height:54px;width:auto;
  display:block;
  /* Glow doré subtil */
  filter:drop-shadow(0 0 20px rgba(212,175,55,.15));
}

.intro-line{
  width:0;height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(212,175,55,.3) 15%,
    rgba(212,175,55,.95) 50%,
    rgba(212,175,55,.3) 85%,
    transparent 100%);
  /* Trait qui se trace après l'apparition du logo */
  animation:intro-line-draw 900ms cubic-bezier(.5,0,.2,1) 1100ms forwards;
}
@keyframes intro-line-draw{
  to{width:240px}
}

.intro-skip{
  position:absolute;top:1.5rem;right:1.5rem;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.5);
  background:transparent;border:none;cursor:pointer;
  pointer-events:auto;
  padding:.5rem .9rem;
  transition:color var(--t-fast);
  font-family:'DM Sans',sans-serif;
  /* Apparition retardée du bouton skip */
  opacity:0;
  animation:intro-skip-in 400ms ease 800ms forwards;
}
@keyframes intro-skip-in{
  to{opacity:1}
}
.intro-skip::after{
  content:'›';margin-left:.4rem;font-size:1.1rem;line-height:0;
  position:relative;top:1px;
}
.intro-skip:hover{color:#fff}

/* Hero : zoom léger qui se résout pendant l'intro */
body.intro-active .hero-bg{
  transform:scale(1.18);
}
body:not(.intro-active) .hero-bg{
  transform:scale(1.02);
  transition:transform 1800ms cubic-bezier(.4,0,.2,1);
}

/* Hero content : fade-in après dissolution intro */
body.intro-active .hero-content,
body.intro-active .hero-eyebrow,
body.intro-active .hero h1,
body.intro-active .hero-lead,
body.intro-active .hero-ctas,
body.intro-active .hero-trust,
body.intro-active .hero-scroll{
  opacity:0;
}
body:not(.intro-active) .hero-eyebrow{
  animation:hero-fade-in 700ms ease 200ms backwards;
}
body:not(.intro-active) .hero h1{
  animation:hero-fade-in 800ms ease 350ms backwards;
}
body:not(.intro-active) .hero-lead{
  animation:hero-fade-in 700ms ease 550ms backwards;
}
body:not(.intro-active) .hero-ctas{
  animation:hero-fade-in 700ms ease 700ms backwards;
}
body:not(.intro-active) .hero-trust,
body:not(.intro-active) .hero-scroll{
  animation:hero-fade-in 700ms ease 900ms backwards;
}
@keyframes hero-fade-in{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:none}
}

/* Mobile : intro plus rapide et logo plus petit */
@media (max-width:768px){
  .intro-overlay{animation-delay:1900ms}
  .intro-logo{height:42px}
  .intro-line{
    animation:intro-line-draw-mobile 800ms cubic-bezier(.5,0,.2,1) 1000ms forwards;
  }
  @keyframes intro-line-draw-mobile{to{width:180px}}
  .intro-skip{top:1rem;right:1rem;font-size:.65rem}
}

/* Réduit l'animation pour les utilisateurs qui préfèrent moins de mouvement */
@media (prefers-reduced-motion:reduce){
  .intro-overlay,.intro-content,.intro-line,.intro-skip{
    animation-duration:.01ms !important;
    animation-delay:0ms !important;
  }
}

/* ── HARD OVERRIDE pour forcer le mode clair (anti-iOS auto-dark) ── */
html, body {
  background-color: #ffffff !important;
  color: #0d0d0d !important;
}
section, .section, .container {
  background-color: transparent;
}
section:not([class*="dark"]):not(.cta-dark):not(.hero):not(.cond-hero):not(.cond-hero-img):not(.cond-dark-section):not(.cond-extra-light) {
  background-color: #ffffff;
}
.faq-q, .faq-a {
  color: #0d0d0d !important;
}
.faq-a strong { color: #0d0d0d !important; }
/* Conditions page : fond du body en noir pour qu'on voie pas de blanc partout */
body:has(.cond-page) {
  background-color: #0a0a0a !important;
}
.cond-extra-light {
  background-color: #ffffff !important;
}
