/* ══════════════════════════════════════════════════
   SADKI PRESTIGE CAR — style.css v5
   Palette : Rouge #C8102E · Blanc #FFFFFF · Noir #0A0A0A
   Style : Minimaliste luxury, responsive
══════════════════════════════════════════════════ */

/* ── VARIABLES ── */
:root {
  --red:        #C8102E;
  --red-dark:   #9B0A21;
  --red-light:  #E8314E;
  --white:      #FFFFFF;
  --black:      #0A0A0A;
  --dark:       #111111;
  --dark2:      #1a1a1a;
  --grey:       #888888;
  --grey-light: #f4f4f4;
  --border:     rgba(255,255,255,0.08);
  --shadow:     0 8px 40px rgba(0,0,0,0.18);
  --shadow-red: 0 8px 30px rgba(200,16,46,0.3);
  --radius:     12px;
  --radius-lg:  20px;
  --trans:      0.3s ease;
  --font-main:  'Inter', sans-serif;
  --font-serif: 'Playfair Display', serif;
  --nav-h:      72px;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-main);
  background: var(--white);
  color: var(--dark);
  line-height: 1.65;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a   { text-decoration: none; color: inherit; }
ul  { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }
input, select, textarea { font-family: inherit; }

/* ── UTILITIES ── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.sec-head   { text-align: center; margin-bottom: 52px; }
.sec-tag {
  display: inline-block;
  background: rgba(200,16,46,0.08);
  color: var(--red);
  border: 1px solid rgba(200,16,46,0.2);
  border-radius: 50px;
  padding: 6px 18px;
  font-size: 0.73rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.sec-title {
  font-family: var(--font-serif);
  font-size: clamp(1.7rem, 4vw, 2.7rem);
  font-weight: 700;
  color: var(--dark);
  line-height: 1.25;
}
.sec-title em  { color: var(--red); font-style: italic; }
.sec-title.white { color: var(--white); }
.sec-sub { color: var(--grey); margin-top: 12px; font-size: 0.97rem; }
.req { color: var(--red); }

/* ── ARABIC FONT ── */
:lang(ar), [dir="rtl"] body, .lang-ar {
  font-family: 'Segoe UI', Tahoma, 'Arabic Typesetting', var(--font-main), sans-serif;
}

/* ── KEYFRAMES ── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:none} }
@keyframes pulse-wa { 0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.5)} 70%{box-shadow:0 0 0 14px rgba(37,211,102,0)} }
@keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes spin     { to{transform:rotate(360deg)} }
@keyframes fillBar  { from{width:0} to{width:100%} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes slideDown{ from{opacity:0;transform:translateY(-10px)} to{opacity:1;transform:none} }
@keyframes scaleIn  { from{opacity:0;transform:scale(0.93) translateY(18px)} to{opacity:1;transform:none} }
@keyframes mobileMenuIn { from{opacity:0;transform:translateX(100%)} to{opacity:1;transform:none} }

/* ══════════════════════
   PRELOADER
══════════════════════ */
#preloader {
  position: fixed; inset: 0;
  background: var(--dark);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}
#preloader.hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.pre-inner { text-align: center; }
/* Logo sur fond noir : visible directement */
.pre-logo {
  height: 130px;
  width: auto;
  max-width: 340px;
  object-fit: contain;
  margin: 0 auto 28px;
}
.pre-fb {
  display: none; gap: 6px; align-items: baseline;
  font-size: 1.6rem; font-weight: 900; letter-spacing: 4px; margin-bottom: 24px;
}
.pfb-m { color: var(--white); }
.pfb-c { color: var(--red); font-size: 0.9em; letter-spacing: 3px; }
.pre-bar {
  width: 160px; height: 2px;
  background: rgba(255,255,255,0.1);
  border-radius: 2px; overflow: hidden;
  margin: 0 auto;
}
.pre-fill { height: 100%; background: var(--red); animation: fillBar 1.8s ease forwards; }

/* ══════════════════════
   FLOATING WHATSAPP
══════════════════════ */
.fab-wa {
  position: fixed; bottom: 96px; right: 22px;
  width: 54px; height: 54px;
  background: #25D366;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: 1.55rem;
  z-index: 800;
  box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  animation: pulse-wa 2.5s infinite;
  transition: transform var(--trans);
}
.fab-wa:hover { transform: scale(1.1); }

/* ══════════════════════
   NAVBAR
══════════════════════ */
.navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  transition: background var(--trans), box-shadow var(--trans), backdrop-filter var(--trans);

  /* ✅ Opaque tout le temps */
  background: rgba(10, 10, 10, 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 2px 30px rgba(0, 0, 0, 0.45);
}
.navbar.scrolled {
  background: rgba(10, 10, 10, 0.95);
  box-shadow: 0 2px 30px rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.nav-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0 24px;
  height: var(--nav-h);
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
}

/* Logo navbar */
.nav-logo {
  display: flex; align-items: center;
  flex-shrink: 0;
}
.nav-logo img {
  height: 88px;
  width: auto;
  max-width: 260px;
  object-fit: contain;
  filter: brightness(1.05);
}
.nl-fallback {
  display: none; gap: 4px; align-items: baseline;
  font-size: 1.15rem; font-weight: 900; letter-spacing: 3px;
}
.nlf-m { color: var(--white); }
.nlf-c { color: var(--red); font-size: 0.7em; letter-spacing: 2px; }

/* Desktop nav links */
.nav-links {
  display: flex; align-items: center; gap: 2px;
  margin: 0; flex: 1; justify-content: center;
}
.nl {
  color: rgba(255,255,255,0.78);
  padding: 8px 13px;
  border-radius: 8px;
  font-size: 0.87rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  transition: color var(--trans), background var(--trans);
  white-space: nowrap;
}
.nl:hover { color: var(--white); background: rgba(255,255,255,0.06); }
.nl.active { color: var(--red); }
.nl-admin {
  color: rgba(255,255,255,0.3);
  font-size: 0.75rem; padding: 6px 10px;
}
.nl-admin:hover { color: var(--red); background: rgba(200,16,46,0.08); }

/* Right controls */
.nav-right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }

/* Bouton Admin navbar */
.btn-admin-nav {
  display: flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  background: rgba(200,16,46,0.12);
  border: 1px solid rgba(200,16,46,0.3);
  border-radius: 8px;
  color: var(--red);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  transition: all var(--trans);
  white-space: nowrap;
}
.btn-admin-nav i { font-size: 0.82rem; }
.btn-admin-nav:hover {
  background: var(--red);
  color: var(--white);
  border-color: var(--red);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(200,16,46,0.35);
}
/* Masquer le texte "Admin" sur très petit écran, garder icône */
@media (max-width: 480px) {
  .btn-admin-nav span { display: none; }
  .btn-admin-nav { padding: 7px 10px; }
}

/* Language switcher */
.lang-sw {
  display: flex; gap: 2px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 3px;
}
.lsw {
  padding: 5px 10px;
  border-radius: 6px;
  font-size: 0.72rem;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.05em;
  transition: all var(--trans);
}
.lsw.active { background: var(--red); color: var(--white); }
.lsw:hover:not(.active) { color: var(--white); }

/* Burger */
.burger {
  display: none;
  flex-direction: column; justify-content: center;
  gap: 5px; width: 40px; height: 40px;
  padding: 8px;
  border-radius: 8px;
  transition: background var(--trans);
}
.burger:hover { background: rgba(255,255,255,0.07); }
.burger span {
  display: block; width: 22px; height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: var(--trans);
  transform-origin: center;
}

/* ══ MOBILE MENU ══ */
.mobile-menu-overlay {
   position: fixed; 
  top: 0; 
  left: 0; 
  right: 0; 
  bottom: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(4px);
  z-index: 950;
  opacity: 0; visibility: hidden;
  transition: opacity var(--trans), visibility var(--trans);
}
.mobile-menu-overlay.open { opacity: 1; visibility: visible; }

.mobile-menu {
  position: fixed; 
  top: 0; 
  left: 0; 
  right: 0; 
  bottom: 0;
  width: 100%;
  height: 100vh;
  background: var(--dark);
  z-index: 960;
  display: flex; 
  flex-direction: column;
  padding: 32px 24px;
  transform: translateY(-100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  overflow-y: auto;
}
.mobile-menu.open { transform: translateY(0); }
.mobile-menu.open { transform: translateX(0); }

.mobile-menu-close {
  align-self: flex-end;
  width: 40px; height: 40px;
  background: rgba(255,255,255,0.07);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.7);
  font-size: 1.1rem;
  margin-bottom: 24px;
  transition: background var(--trans), color var(--trans);
}
.mobile-menu-close:hover { background: var(--red); color: var(--white); }

.mobile-nav-links { 
  display: flex; 
  flex-direction: column; 
  gap: 16px; 
  flex: 1;
  justify-content: center;
}
.mnl {
  display: block;
  padding: 18px 16px;
  font-size: 1.3rem;
  font-weight: 600;
  color: rgba(255,255,255,0.9);
  border-radius: 10px;
  transition: all var(--trans);
  border-bottom: 1px solid rgba(255,255,255,0.04);
  text-align: center;
}
.mnl:hover { background: rgba(255,255,255,0.06); color: var(--white); padding-left: 22px; }

/* Mobile lang switcher */
.mobile-lang-sw {
  display: flex; gap: 8px;
  margin: 24px 0;
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.mlsw {
  flex: 1;
  padding: 10px;
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  transition: all var(--trans);
  letter-spacing: 0.05em;
}
.mlsw.active { background: var(--red); color: var(--white); border-color: var(--red); }

.mobile-menu-footer {}
.mobile-wa-btn {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%;
  padding: 14px;
  background: #25D366;
  color: var(--white);
  border-radius: var(--radius);
  font-size: 0.95rem;
  font-weight: 700;
  transition: background var(--trans);
}
.mobile-wa-btn:hover { background: #1ebe5a; }
.mobile-wa-btn i { font-size: 1.2rem; }

/* ══════════════════════════════════════
   HERO — Design Professionnel v2
══════════════════════════════════════ */

/* ── Keyframes supplémentaires ── */
@keyframes heroFadeSlideUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes heroBadgePop {
  from { opacity: 0; transform: translateY(-12px) scale(0.92); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes timelineGrow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}
@keyframes grainMove {
  0%   { transform: translate(0, 0); }
  25%  { transform: translate(-2px, 2px); }
  50%  { transform: translate(2px, -2px); }
  75%  { transform: translate(-1px, -1px); }
  100% { transform: translate(0, 0); }
}
@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); opacity: 1; }
  50%       { transform: translateY(8px); opacity: 0.4; }
}

/* ── Structure principale ── */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  overflow: hidden;
  background: var(--dark);
}

/* ── Slides ── */
.hero-slides { position: absolute; inset: 0; z-index: 0; }

.hs {
  position: absolute; inset: 0;
  opacity: 0;
  transition: opacity 1.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.hs.active { opacity: 1; }

.hs-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
  transform: scale(1.06);
  transition: transform 8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}
.hs.active .hs-img { transform: scale(1); }

/* Gradient par slide (bas vers haut) */
.hs-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(
    to top,
    rgba(0,0,0,0.85) 0%,
    rgba(0,0,0,0.3) 50%,
    rgba(0,0,0,0.15) 100%
  );
}

/* ── Overlay principal multi-gradient ── */
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(135deg, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.3) 60%, transparent 100%),
    linear-gradient(to bottom, rgba(0,0,0,0.35) 0%, transparent 40%, rgba(0,0,0,0.5) 100%);
}

/* ── Texture grain ── */
.hero-grain {
  position: absolute; inset: -50%;
  z-index: 1;
  width: 200%; height: 200%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
  background-size: 256px 256px;
  opacity: 0.55;
  pointer-events: none;
  animation: grainMove 0.4s steps(1) infinite;
}

/* ── Flèches de navigation ── */
.hero-arrow {
  position: absolute; z-index: 5;
  top: 50%; transform: translateY(-50%);
  width: 52px; height: 52px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: 0.95rem;
  cursor: pointer;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: all 0.3s ease;
}
.hero-arrow:hover {
  background: var(--red);
  border-color: var(--red);
  transform: translateY(-50%) scale(1.1);
  box-shadow: 0 0 0 6px rgba(200,16,46,0.18);
}
.hero-prev { left: 28px; }
.hero-next { right: 28px; }

/* ── Barre de progression (timeline) ── */
.hero-timeline {
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 3px;
  background: rgba(255,255,255,0.1);
  z-index: 5;
}
.hero-timeline-bar {
  height: 100%;
  background: linear-gradient(to right, var(--red-light), var(--red));
  transform-origin: left center;
  transform: scaleX(0);
}
.hero-timeline-bar.running {
  animation: timelineGrow var(--slider-duration, 5s) linear forwards;
}

/* ── Compteur de slides ── */
.hero-slide-counter {
  position: absolute;
  right: 36px; bottom: 120px;
  z-index: 5;
  display: flex; flex-direction: column; align-items: center;
  gap: 8px;
}
.hsc-current {
  font-size: 2rem; font-weight: 800;
  color: var(--white);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.hsc-sep {
  width: 1px; height: 32px;
  background: rgba(255,255,255,0.25);
}
.hsc-total {
  font-size: 0.82rem; font-weight: 600;
  color: rgba(255,255,255,0.4);
  font-variant-numeric: tabular-nums;
}

/* ── Label slide actif ── */
.hero-slide-label {
  position: absolute;
  left: 36px; bottom: 130px;
  z-index: 5;
  display: flex; align-items: center; gap: 10px;
}
.hero-slide-label::before {
  content: '';
  display: block; width: 28px; height: 2px;
  background: var(--red);
  flex-shrink: 0;
}
#heroSlideLabelText {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  transition: opacity 0.4s ease;
}

/* ── Dots ── */
.hero-dots {
  position: absolute;
  left: 36px; bottom: 88px;
  z-index: 5;
  display: flex; gap: 6px; align-items: center;
}
.hero-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
  cursor: pointer;
  transition: all 0.35s ease;
  border: none;
}
.hero-dot.active {
  background: var(--white);
  width: 22px;
  border-radius: 3px;
}
.hero-dot:hover:not(.active) { background: rgba(255,255,255,0.6); }

/* ── Contenu hero ── */
.hero-content {
  position: relative; z-index: 3;
  text-align: center;
  padding: calc(var(--nav-h) + 60px) 24px 60px;
  max-width: 860px;
  width: 100%;
}

/* Badge "location premium" */
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(200,16,46,0.15);
  border: 1px solid rgba(200,16,46,0.35);
  border-radius: 50px;
  padding: 7px 18px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.85);
  margin-bottom: 22px;
  animation: heroBadgePop 0.7s ease 0.3s both;
  backdrop-filter: blur(8px);
}
.hero-badge i { color: var(--red); font-size: 0.75rem; }

/* Titre H1 */
.hero-h1 {
  font-family: var(--font-serif);
  font-size: clamp(2.4rem, 7vw, 5.2rem);
  font-weight: 700;
  color: var(--white);
  line-height: 1.1;
  margin-bottom: 24px;
  animation: heroFadeSlideUp 0.8s ease 0.5s both;
}
.hero-h1-line { display: block; }
.hero-h1-accent {
  display: block;
  color: var(--red);
  font-style: italic;
  text-shadow: 0 0 60px rgba(200,16,46,0.4);
}
.hero-h1-sub {
  font-size: 0.68em;
  font-weight: 400;
  color: rgba(255,255,255,0.7);
  font-family: var(--font-main);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-top: 8px;
}

/* Features pills */
.hero-features {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 10px 16px;
  margin-bottom: 34px;
  animation: heroFadeSlideUp 0.8s ease 0.7s both;
}
.hero-features > span {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.83rem;
  color: rgba(255,255,255,0.75);
  font-weight: 500;
}
.hero-features i { color: var(--red); font-size: 0.8rem; }
.hf-dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  background: rgba(255,255,255,0.25);
}

/* CTA Boutons */
.hero-ctas {
  display: flex; gap: 14px;
  justify-content: center; flex-wrap: wrap;
  margin-bottom: 32px;
  animation: heroFadeSlideUp 0.8s ease 0.9s both;
}
.hero-btn-primary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 32px;
  background: var(--red);
  color: var(--white);
  border-radius: 50px;
  font-size: 0.94rem; font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: 0 8px 32px rgba(200,16,46,0.45);
  transition: all 0.3s ease;
  position: relative; overflow: hidden;
}
.hero-btn-primary::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 60%);
}
.hero-btn-primary:hover {
  background: var(--red-dark);
  transform: translateY(-3px);
  box-shadow: 0 16px 48px rgba(200,16,46,0.55);
}
.hero-btn-primary i { font-size: 0.85rem; transition: transform 0.3s ease; }
.hero-btn-primary:hover i { transform: translateX(4px); }

.hero-btn-secondary {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 32px;
  background: rgba(255,255,255,0.08);
  color: var(--white);
  border: 1.5px solid rgba(255,255,255,0.28);
  border-radius: 50px;
  font-size: 0.94rem; font-weight: 600;
  backdrop-filter: blur(12px);
  transition: all 0.3s ease;
}
.hero-btn-secondary i { color: #25D366; font-size: 1.1rem; }
.hero-btn-secondary:hover {
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.5);
  transform: translateY(-3px);
}

/* Badges de confiance */
.hero-trust {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 8px 20px;
  animation: heroFadeSlideUp 0.8s ease 1.1s both;
}
.hero-trust-item {
  display: flex; align-items: center; gap: 5px;
  font-size: 0.75rem;
  color: rgba(255,255,255,0.45);
  font-weight: 500;
}
.hero-trust-item i { color: rgba(200,16,46,0.7); font-size: 0.7rem; }

/* ── Barre de stats ── */
.hero-stats {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: rgba(5,5,5,0.82);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(255,255,255,0.05);
  margin-top: auto;
}
.hs-stat {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  padding: 22px 10px 18px;
  border-right: 1px solid rgba(255,255,255,0.05);
  transition: background 0.3s ease;
  position: relative;
}
.hs-stat:last-child { border-right: none; }
.hs-stat::after {
  content: '';
  position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 0; height: 2px;
  background: var(--red);
  transition: width 0.4s ease;
}
.hs-stat:hover::after { width: 40px; }
.hs-stat:hover { background: rgba(200,16,46,0.05); }

.hss-icon {
  font-size: 0.8rem;
  color: rgba(200,16,46,0.6);
  margin-bottom: 6px;
}
.hss-n {
  font-size: 1.8rem; font-weight: 800;
  color: var(--white);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.hss-l {
  font-size: 0.65rem;
  color: rgba(255,255,255,0.4);
  margin-top: 4px;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ── Scroll hint ── */
.hero-scroll-hint {
  position: absolute;
  bottom: 50px; left: 50%;
  transform: translateX(-50%);
  z-index: 4;
  text-align: center;
}
.scroll-hint-inner {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.scroll-hint-mouse {
  width: 22px; height: 36px;
  border: 2px solid rgba(255,255,255,0.25);
  border-radius: 11px;
  display: flex; justify-content: center;
  padding-top: 5px;
}
.scroll-hint-wheel {
  width: 3px; height: 6px;
  background: var(--red);
  border-radius: 2px;
  animation: scrollBounce 1.6s ease infinite;
}
.scroll-hint-text {
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.25);
  font-weight: 600;
}

/* ── Boutons génériques (conservés pour autres sections) ── */
.btn-red, .btn-white {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px;
  border-radius: 50px;
  font-size: 0.93rem; font-weight: 600; letter-spacing: 0.02em;
  transition: transform var(--trans), box-shadow var(--trans), background var(--trans);
}
.btn-red { background: var(--red); color: var(--white); box-shadow: var(--shadow-red); }
.btn-red:hover { background: var(--red-dark); transform: translateY(-2px); box-shadow: 0 14px 40px rgba(200,16,46,0.45); }
.btn-white { background: rgba(255,255,255,0.1); color: var(--white); border: 1px solid rgba(255,255,255,0.3); backdrop-filter: blur(8px); }
.btn-white:hover { background: rgba(255,255,255,0.2); transform: translateY(-2px); }

/* ── Responsive ── */
@media (max-width: 768px) {
  .hero-prev { left: 12px; }
  .hero-next { right: 12px; }
  .hero-arrow { width: 42px; height: 42px; font-size: 0.85rem; }
  .hero-slide-counter { right: 16px; bottom: 110px; }
  .hsc-current { font-size: 1.5rem; }
  .hero-slide-label { left: 16px; bottom: 118px; }
  .hero-dots { left: 16px; bottom: 86px; }
  .hero-content { padding: calc(var(--nav-h) + 40px) 20px 50px; }
  .hero-h1 { font-size: clamp(2rem, 8vw, 3.4rem); }
  .hero-trust { display: none; }
  .hero-scroll-hint { display: none; }
  .hss-n { font-size: 1.45rem; }
  .hs-stat { padding: 16px 6px 14px; }
}
@media (max-width: 480px) {
  .hero-badge { font-size: 0.65rem; padding: 6px 14px; }
  .hero-h1 { font-size: clamp(1.8rem, 8.5vw, 2.8rem); }
  .hero-features { gap: 8px 12px; font-size: 0.78rem; }
  .hero-btn-primary, .hero-btn-secondary { padding: 13px 22px; font-size: 0.88rem; }
  .hero-slide-counter { display: none; }
  .hf-dot { display: none; }
  .hss-icon { display: none; }
}

/* ══════════════════════
   MARQUEE
══════════════════════ */
.marquee-band {
  background: var(--dark);
  border-top: 1px solid rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  overflow: hidden; padding: 13px 0;
}
.marquee-track {
  display: flex; align-items: center;
  white-space: nowrap;
  animation: marquee 28s linear infinite;
}
.marquee-track span { padding: 0 22px; font-size: 0.76rem; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
.marquee-track .sep { color: var(--red); padding: 0 4px; font-size: 0.45rem; }

/* ══════════════════════
   FLEET
══════════════════════ */
.section-fleet { padding: 96px 0; background: var(--white); }
.fleet-filters { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 48px; }
.ff-btn {
  padding: 9px 22px; border-radius: 50px; font-size: 0.83rem; font-weight: 600;
  color: var(--grey); border: 1.5px solid #e0e0e0; background: transparent;
  transition: all var(--trans);
}
.ff-btn:hover { border-color: var(--red); color: var(--red); }
.ff-btn.active { background: var(--red); color: var(--white); border-color: var(--red); box-shadow: var(--shadow-red); }

.fleet-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 26px; }

/* Vehicle Card */
.vcard {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 22px rgba(0,0,0,0.07);
  border: 1px solid #f0f0f0;
  transition: transform var(--trans), box-shadow var(--trans);
  cursor: pointer;
}
.vcard:hover { transform: translateY(-6px); box-shadow: 0 18px 50px rgba(0,0,0,0.13); }
.vcard-img-wrap { position: relative; height: 195px; overflow: hidden; background: #f8f8f8; }
.vcard-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.vcard:hover .vcard-img-wrap img { transform: scale(1.06); }
.vcard-badge { position: absolute; top: 12px; left: 12px; padding: 4px 11px; border-radius: 50px; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; }
.badge-luxe      { background: #0A0A0A; color: #FFD700; }
.badge-premium   { background: var(--red); color: var(--white); }
.badge-suv       { background: #1a3a4a; color: #7ecfff; }
.badge-economique{ background: #1a3a1a; color: #7ddd7d; }
.stock-badge { position: absolute; top: 12px; right: 12px; padding: 4px 10px; border-radius: 50px; font-size: 0.66rem; font-weight: 700; }
.avail { background: rgba(40,200,80,0.13); color: #20a040; border: 1px solid rgba(40,200,80,0.3); }
.low   { background: rgba(255,160,0,0.13); color: #cc7700; border: 1px solid rgba(255,160,0,0.3); }
.out   { background: rgba(200,16,46,0.1);  color: var(--red); border: 1px solid rgba(200,16,46,0.25); }
.vcard-body { padding: 18px 20px; }
.vcard-type  { font-size: 0.68rem; font-weight: 700; color: var(--red); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 3px; }
.vcard-brand { font-size: 0.76rem; color: var(--grey); font-weight: 500; margin-bottom: 2px; }
.vcard-model { font-size: 1.1rem; font-weight: 700; color: var(--dark); margin-bottom: 12px; }
.vcard-specs { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.vspec { display: flex; align-items: center; gap: 4px; font-size: 0.76rem; color: var(--grey); }
.vspec i { color: var(--red); font-size: 0.68rem; }
.vcard-price { display: flex; align-items: baseline; gap: 5px; margin-bottom: 14px; }
.vpc-val { font-size: 1.4rem; font-weight: 800; color: var(--red); }
.vpc-per { font-size: 0.78rem; color: var(--grey); }
.vcard-btn {
  width: 100%; padding: 11px; background: var(--red); color: var(--white);
  border-radius: var(--radius); font-size: 0.86rem; font-weight: 600;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  transition: background var(--trans), transform var(--trans);
}
.vcard-btn:hover { background: var(--red-dark); transform: translateY(-1px); }
.vcard-btn.btn-out { background: #ddd; color: #999; cursor: not-allowed; pointer-events: none; }

/* ══════════════════════
   WHY US
══════════════════════ */
.section-why { padding: 96px 0; background: var(--dark); }
.section-why .sec-title { color: var(--white); }
.section-why .sec-tag { background: rgba(200,16,46,0.14); color: #E8314E; }
.why-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(275px, 1fr)); gap: 22px; }
.why-card {
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.065);
  border-radius: var(--radius-lg); padding: 34px 26px;
  transition: transform var(--trans), border-color var(--trans), box-shadow var(--trans);
}
.why-card:hover { transform: translateY(-4px); border-color: rgba(200,16,46,0.4); box-shadow: 0 12px 40px rgba(200,16,46,0.1); }
.wc-icon { width: 52px; height: 52px; background: rgba(200,16,46,0.1); border-radius: 14px; display: flex; align-items: center; justify-content: center; font-size: 1.35rem; color: var(--red); margin-bottom: 18px; }
.why-card h3 { font-size: 0.97rem; font-weight: 700; color: var(--white); margin-bottom: 9px; }
.why-card p  { font-size: 0.86rem; color: rgba(255,255,255,0.48); line-height: 1.68; }

/* ══════════════════════
   BOOKING FORM
══════════════════════ */
.section-booking { padding: 96px 0; background: #fafafa; }
.quick-book-wrap { max-width: 880px; margin: 0 auto; }
.qb-form { background: var(--white); border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden; }
.qb-section { padding: 30px 34px; border-bottom: 1px solid #f2f2f2; }
.qb-sec-title { font-size: 0.85rem; font-weight: 700; color: var(--dark); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 18px; display: flex; align-items: center; gap: 8px; }
.qb-sec-title i { color: var(--red); }
.qb-grid   { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.qb-grid-3 { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 14px; }
.qb-field  { display: flex; flex-direction: column; gap: 5px; }
.qb-field.qb-field-full { margin-top: 14px; }
.qb-field label { font-size: 0.78rem; font-weight: 600; color: #555; letter-spacing: 0.03em; }
.qb-field input, .qb-field select, .qb-field textarea {
  padding: 11px 13px; border: 1.5px solid #e6e6e6; border-radius: var(--radius);
  font-size: 0.89rem; color: var(--dark); background: #fafafa;
  transition: border-color var(--trans), box-shadow var(--trans); outline: none;
}
.qb-field input:focus, .qb-field select:focus, .qb-field textarea:focus {
  border-color: var(--red); background: var(--white); box-shadow: 0 0 0 3px rgba(200,16,46,0.07);
}
.qb-field textarea { resize: vertical; min-height: 68px; }
.qb-promo-wrap { display: flex; gap: 8px; }
.qb-promo-wrap input { flex: 1; }
.btn-promo { padding: 11px 15px; background: var(--dark); color: var(--white); border-radius: var(--radius); font-size: 0.8rem; font-weight: 600; white-space: nowrap; transition: background var(--trans); }
.btn-promo:hover { background: var(--red); }
.promo-msg { font-size: 0.76rem; font-weight: 600; margin-top: 3px; }
.promo-msg.ok  { color: #20a040; }
.promo-msg.err { color: var(--red); }

/* Price recap */
.qb-price-recap { padding: 22px 34px; background: linear-gradient(135deg, #111 0%, #1a0a0a 100%); border-bottom: 1px solid rgba(255,255,255,0.05); }
.qbpr-title { font-size: 0.75rem; font-weight: 700; color: rgba(255,255,255,0.38); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 12px; }
.qbpr-row { display: flex; justify-content: space-between; align-items: center; padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.88rem; color: rgba(255,255,255,0.65); }
.qbpr-row strong { color: var(--white); font-weight: 700; }
.qbpr-total { border-bottom: none; margin-top: 4px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.1); font-weight: 700; font-size: 0.97rem; color: var(--white); }
.qbpr-total strong { color: var(--red); font-size: 1.15rem; }
.disc-val { color: #4dd; }

/* WA selector */
.wa-selector { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wa-opt input { display: none; }
.wa-card { display: flex; align-items: center; gap: 12px; padding: 14px; border: 2px solid #e8e8e8; border-radius: var(--radius); cursor: pointer; transition: border-color var(--trans), background var(--trans); }
.wa-opt input:checked + .wa-card { border-color: #25D366; background: rgba(37,211,102,0.04); }
.wa-card > i.fa-whatsapp { font-size: 1.7rem; color: #25D366; }
.wa-info strong { display: block; font-size: 0.83rem; font-weight: 700; color: var(--dark); }
.wa-info span   { font-size: 0.76rem; color: var(--grey); }
.wa-check { color: #25D366; font-size: 1rem; opacity: 0; transition: opacity var(--trans); margin-left: auto; }
.wa-opt input:checked + .wa-card .wa-check { opacity: 1; }

/* Submit */
.btn-wa-send {
  width: 100%; padding: 17px; background: #25D366; color: var(--white);
  font-size: 0.97rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: background var(--trans);
}
.btn-wa-send:hover { background: #1ebe5a; }
.btn-wa-send i { font-size: 1.25rem; }
.qb-note { text-align: center; padding: 13px 34px; font-size: 0.76rem; color: var(--grey); background: #fafafa; }
.qb-note i { color: var(--red); margin-right: 5px; }

/* ══════════════════════
   EXPERIENCE
══════════════════════ */
.section-exp { display: grid; grid-template-columns: 1fr 1fr; min-height: 500px; background: var(--dark); }
.exp-img-side { overflow: hidden; }
.exp-img-side img { width: 100%; height: 100%; object-fit: cover; }
.exp-text-side { padding: 68px 56px; display: flex; flex-direction: column; justify-content: center; gap: 18px; }
.exp-p { color: rgba(255,255,255,0.58); font-size: 0.93rem; line-height: 1.8; }
.exp-ms { display: flex; flex-direction: column; gap: 16px; }
.ms { display: flex; gap: 16px; align-items: flex-start; }
.ms-yr { min-width: 48px; font-size: 0.8rem; font-weight: 700; color: var(--red); padding-top: 2px; }
.ms p  { font-size: 0.86rem; color: rgba(255,255,255,0.52); line-height: 1.55; }

/* ══════════════════════
   REVIEWS
══════════════════════ */
.section-reviews {
  padding: 96px 0;
  background: linear-gradient(135deg, #fafafa 0%, #f5f5f5 100%);
}
.stars-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, #fff9e6 0%, #fffbf0 100%);
  border: 2px solid #f0c000;
  border-radius: 50px;
  padding: 10px 22px;
  margin-top: 16px;
  color: #f0c000;
  font-weight: 700;
  font-size: 0.88rem;
  box-shadow: 0 4px 15px rgba(240, 192, 0, 0.1);
}
.stars-badge span { color: var(--grey); font-weight: 500; }
.rev-carousel {
  display: block;
  position: relative;
  min-height: 300px;
}
.rev-card {
  background: var(--white);
  border-radius: 16px;
  padding: 26px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.04);
  display: none;
  animation: slideIn 0.5s ease-out;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.rev-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--red), #ff6b9d);
}

.rev-card:hover {
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
  transform: translateY(-4px);
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.rev-stars {
  display: flex;
  gap: 3px;
  color: #f0c000;
  font-size: 1rem;
  margin-bottom: 16px;
  letter-spacing: 1px;
}

.rev-stars i {
  text-shadow: 0 2px 4px rgba(240, 192, 0, 0.2);
}
.rev-text {
  font-size: 0.95rem;
  color: #333;
  line-height: 1.8;
  margin-bottom: 24px;
  font-style: italic;
  border-left: 3px solid #f0c000;
  padding-left: 16px;
  position: relative;
}

.rev-text::before {
  content: '"';
  position: absolute;
  left: -8px;
  top: -8px;
  font-size: 2.5rem;
  color: rgba(240, 192, 0, 0.15);
  font-style: normal;
}.rev-footer { display: flex; align-items: center; gap: 11px; }
.rev-user {
  display: flex;
  align-items: center;
  gap: 14px;
  padding-top: 16px;
  border-top: 1px solid #f0f0f0;
}

.rev-avatar {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--red), #ff6b9d);
  color: var(--white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 1.15rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(200, 16, 46, 0.25);
}

.rev-user > div h4 {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--dark);
  margin: 0;
}

.rev-user > div span {
  font-size: 0.8rem;
  color: #999;
  display: block;
  margin-top: 2px;
}
.rev-date { font-size: 0.73rem; color: var(--grey); }
.rev-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 18px;
}
.rev-nav button {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--white);
  border: 2px solid #e5e5e5;
  color: #999;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  font-size: 0.95rem;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.rev-nav button:hover {
  background: var(--red);
  border-color: var(--red);
  color: white;
  box-shadow: 0 8px 24px rgba(200, 16, 46, 0.35);
  transform: scale(1.12);
}

.rev-nav button:active {
  transform: scale(0.92);
}
#revDots {
  display: flex;
  gap: 10px;
}

.rev-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #ddd;
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  border: 2px solid transparent;
}

.rev-dot:hover {
  background: #ccc;
  transform: scale(1.15);
}

.rev-dot.active {
  background: var(--red);
  transform: scale(1.4);
  box-shadow: 0 0 0 4px rgba(200, 16, 46, 0.15);
  border-color: rgba(200, 16, 46, 0.3);
}

/* ══════════════════════
   EXTRAS
══════════════════════ */
.section-extras { padding: 96px 0; background: var(--white); }
.extras-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.ext-card { position: relative; height: 250px; border-radius: var(--radius-lg); overflow: hidden; cursor: pointer; }
.ext-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.ext-card:hover img { transform: scale(1.08); }
.ext-over { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(0,0,0,0.75) 0%, transparent 55%); display: flex; flex-direction: column; align-items: center; justify-content: flex-end; padding: 22px; color: white; }
.ext-over i { font-size: 1.4rem; color: var(--red); margin-bottom: 7px; }
.ext-over h3 { font-size: 0.93rem; font-weight: 700; text-align: center; }

/* ══════════════════════
   FAQ
══════════════════════ */
.section-faq { padding: 96px 0; background: #fafafa; }
.faq-list { max-width: 740px; margin: 0 auto; display: flex; flex-direction: column; gap: 9px; }
.faq-item { background: var(--white); border: 1px solid #ebebeb; border-radius: var(--radius); overflow: hidden; transition: border-color var(--trans); }
.faq-item.open { border-color: rgba(200,16,46,0.28); }
.faq-q { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 17px 20px; font-size: 0.9rem; font-weight: 600; color: var(--dark); text-align: left; gap: 12px; }
.faq-q i { color: var(--red); font-size: 0.78rem; min-width: 15px; transition: transform var(--trans); }
.faq-item.open .faq-q i { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s ease, padding 0.3s ease; }
.faq-item.open .faq-a { max-height: 280px; padding: 0 20px 16px; }
.faq-a p { font-size: 0.86rem; color: #555; line-height: 1.7; }

/* ══════════════════════
   CONTACT
══════════════════════ */
.section-contact { padding: 96px 0; background: var(--dark); }
.section-contact .sec-title { color: var(--white); }
.section-contact .sec-tag { background: rgba(200,16,46,0.14); color: #E8314E; }
.contact-wrap { display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 32px; }
.contact-infos { display: flex; flex-direction: column; gap: 18px; }
.ci-item { display: flex; gap: 13px; align-items: flex-start; }
.ci-ico { width: 36px; height: 36px; background: rgba(200,16,46,0.1); border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 0.92rem; color: var(--red); flex-shrink: 0; }
.ci-item h4 { font-size: 0.75rem; font-weight: 700; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 4px; }
.ci-item p, .ci-item a { font-size: 0.86rem; color: rgba(255,255,255,0.72); line-height: 1.6; }
.ci-item a:hover { color: var(--red); }
.contact-socials { display: flex; gap: 9px; margin-top: 2px; }
.soc-btn { width: 38px; height: 38px; background: rgba(255,255,255,0.05); border-radius: 9px; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.55); font-size: 0.95rem; transition: all var(--trans); }
.soc-btn:hover { background: var(--red); color: var(--white); transform: translateY(-2px); }
.soc-wa:hover { background: #25D366; }

/* Contact form */
.contact-form { background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.065); border-radius: var(--radius-lg); padding: 30px; }
.contact-form h3 { font-size: 1.05rem; font-weight: 700; color: var(--white); margin-bottom: 20px; }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; margin-bottom: 13px; }
.cf-field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 13px; }
.cf-field label { font-size: 0.75rem; font-weight: 600; color: rgba(255,255,255,0.45); text-transform: uppercase; letter-spacing: 0.05em; }
.cf-field input, .cf-field textarea { padding: 11px 13px; background: rgba(255,255,255,0.055); border: 1.5px solid rgba(255,255,255,0.09); border-radius: var(--radius); color: var(--white); font-size: 0.88rem; outline: none; transition: border-color var(--trans); }
.cf-field input:focus, .cf-field textarea:focus { border-color: var(--red); }
.cf-field input::placeholder, .cf-field textarea::placeholder { color: rgba(255,255,255,0.22); }
.cf-field textarea { resize: vertical; min-height: 88px; }
.contact-form .btn-red { width: 100%; justify-content: center; }
.contact-map { border-radius: var(--radius-lg); overflow: hidden; height: 100%; min-height: 280px; }
.contact-map iframe { width: 100%; height: 100%; min-height: 280px; }

/* ══════════════════════
   FOOTER — ULTRA COMPACT (1 ligne)
══════════════════════ */
.footer {
  background: #050505;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding: 0;
}
.footer-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px 20px;
  padding: 10px 0;
  min-height: 68px;
}
.footer-logo-wrap {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.footer-logo {
  height: 64px;
  width: auto;
  object-fit: contain;
  filter: brightness(1.1);
  display: block;
}
.footer-fb {
  font-size: 0.95rem; font-weight: 900;
  letter-spacing: 3px; color: var(--white);
}
.footer-fb span { color: var(--red); }
.footer-copy {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.28);
  white-space: nowrap;
  flex: 1;
  text-align: center;
}
.footer-social { display: flex; flex-direction: row; gap: 7px; }
.footer-social a {
  width: 30px; height: 30px;
  background: rgba(255,255,255,0.05);
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.4); font-size: 0.78rem;
  transition: all var(--trans);
}
.footer-social a:hover { background: var(--red); color: white; }

/* ══════════════════════
   MODALS
══════════════════════ */
.modal-wrap { position: fixed; inset: 0; z-index: 1100; display: none; align-items: center; justify-content: center; padding: 20px; }
.modal-wrap.open { display: flex; }
.modal-bg { position: absolute; inset: 0; background: rgba(0,0,0,0.78); backdrop-filter: blur(7px); cursor: pointer; }
.modal-box { position: relative; background: var(--white); border-radius: var(--radius-lg); max-width: 820px; width: 100%; max-height: 92vh; overflow-y: auto; animation: scaleIn 0.3s ease; z-index: 1; }
.modal-close { position: absolute; top: 14px; right: 14px; width: 34px; height: 34px; background: rgba(0,0,0,0.06); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--dark); font-size: 0.9rem; z-index: 2; transition: background var(--trans), color var(--trans); }
.modal-close:hover { background: var(--red); color: white; }

/* Vehicle modal */
.mv-layout { display: grid; grid-template-columns: 1.1fr 1fr; }
.mv-img-side { position: relative; }
.mv-img { width: 100%; height: 320px; object-fit: cover; border-radius: var(--radius-lg) 0 0 var(--radius-lg); }
.mv-gallery{
  display:flex;
  gap:10px;
  padding:12px;
  overflow-x:auto;
  background:#fff;
}

.mv-thumb{
  width:72px;
  height:58px;
  object-fit:cover;
  border-radius:10px;
  cursor:pointer;
  border:2px solid transparent;
  transition:.25s;
  flex-shrink:0;
}

.mv-thumb:hover{
  transform:scale(1.04);
}

.mv-thumb.active{
  border-color:var(--red);
}

.mv-nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:42px;
  height:42px;
  border-radius:50%;
  background:rgba(0,0,0,.55);
  color:#fff;
  z-index:5;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:.25s;
}

.mv-nav:hover{
  background:var(--red);
}

.mv-nav.prev{
  left:12px;
}

.mv-nav.next{
  right:12px;
}
.mv-stock { position: absolute; top: 14px; left: 14px; padding: 4px 11px; border-radius: 50px; font-size: 0.7rem; font-weight: 700; }
.mv-info { padding: 32px 28px; overflow-y: auto; }
.mv-brand { font-size: 0.72rem; font-weight: 600; color: var(--grey); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 3px; }
.mv-model { font-size: 1.35rem; font-weight: 800; color: var(--dark); margin-bottom: 9px; }
.mv-badge { display: inline-block; padding: 3px 11px; border-radius: 50px; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 14px; }
.mv-price-line { display: flex; align-items: baseline; gap: 6px; margin-bottom: 18px; padding-bottom: 18px; border-bottom: 1px solid #f0f0f0; }
.mvp-from { font-size: 0.78rem; color: var(--grey); }
.mvp-val  { font-size: 1.55rem; font-weight: 800; color: var(--red); }
.mvp-per  { font-size: 0.78rem; color: var(--grey); }
.mv-specs { display: flex; flex-wrap: wrap; gap: 11px; margin-bottom: 14px; }
.mv-spec  { display: flex; align-items: center; gap: 5px; font-size: 0.8rem; color: var(--grey); }
.mv-spec i { color: var(--red); }
.mv-desc { font-size: 0.86rem; color: #555; line-height: 1.7; margin-bottom: 14px; }
.mv-features { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 22px; }
.mv-features span { padding: 4px 11px; background: #f4f4f4; border-radius: 50px; font-size: 0.73rem; color: #555; }
.mv-actions { display: flex; flex-direction: column; gap: 9px; }
.mv-actions .btn-red, .mv-actions .btn-wa { width: 100%; justify-content: center; padding: 11px; }
.btn-wa { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px 22px; background: #25D366; color: white; border-radius: 50px; font-size: 0.88rem; font-weight: 600; transition: background var(--trans), transform var(--trans); }
.btn-wa:hover { background: #1ebe5a; transform: translateY(-1px); }

/* WA Recap modal */
.modal-wa-box { max-width: 560px; }
.wa-recap-inner { padding: 36px 32px; }
.war-header { text-align: center; margin-bottom: 24px; }
.war-icon { font-size: 2.8rem; color: #25D366; margin-bottom: 10px; display: block; }
.war-header h2 { font-size: 1.3rem; font-weight: 800; color: var(--dark); margin-bottom: 5px; }
.war-header p  { font-size: 0.85rem; color: var(--grey); }
.war-content { background: #f9f9f9; border-radius: var(--radius); padding: 18px; margin-bottom: 22px; font-size: 0.86rem; color: var(--dark); line-height: 1.8; }
.war-content .war-row { display: flex; justify-content: space-between; align-items: center; padding: 5px 0; border-bottom: 1px solid #efefef; }
.war-content .war-row:last-child { border-bottom: none; }
.war-content .war-total { background: var(--dark); color: var(--white); border-radius: var(--radius); padding: 12px 14px; margin-top: 11px; display: flex; justify-content: space-between; font-weight: 700; }
.war-content .war-total strong { color: var(--red); font-size: 1.1rem; }
.war-choice-label { font-size: 0.78rem; font-weight: 700; color: var(--grey); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 11px; }
.war-btns { display: flex; flex-direction: column; gap: 9px; }
.btn-wa-num { display: flex; align-items: center; gap: 13px; padding: 14px 18px; background: rgba(37,211,102,0.07); border: 1.5px solid rgba(37,211,102,0.28); border-radius: var(--radius); cursor: pointer; transition: all var(--trans); text-align: left; width: 100%; }
.btn-wa-num:hover { background: rgba(37,211,102,0.14); border-color: #25D366; transform: translateY(-1px); }
.btn-wa-num > i { font-size: 1.7rem; color: #25D366; }
.btn-wa-num > div strong { display: block; font-size: 0.86rem; font-weight: 700; color: var(--dark); }
.btn-wa-num > div span  { font-size: 0.78rem; color: var(--grey); }
.btn-ghost-modal { display: block; width: 100%; text-align: center; padding: 11px; margin-top: 12px; border: 1.5px solid #e0e0e0; border-radius: var(--radius); font-size: 0.83rem; font-weight: 600; color: var(--grey); transition: all var(--trans); }
.btn-ghost-modal:hover { border-color: var(--red); color: var(--red); }

/* CMI Modal */
.modal-cmi-box { max-width: 460px; }
.cmi-step { padding: 36px 32px; }
.cmi-header { text-align: center; margin-bottom: 22px; }
.cmi-logo-wrap { display: inline-flex; align-items: center; gap: 7px; background: var(--dark); color: white; padding: 7px 16px; border-radius: 50px; font-size: 0.8rem; font-weight: 700; margin-bottom: 7px; }
.cmi-logo-wrap i { color: #4dea7f; }
.cmi-sub { font-size: 0.8rem; color: var(--grey); }
.cmi-amount { text-align: center; font-size: 1.9rem; font-weight: 800; color: var(--red); margin-bottom: 22px; padding-bottom: 18px; border-bottom: 1px solid #f0f0f0; }
.cmi-form { display: flex; flex-direction: column; gap: 14px; }
.cmi-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.cmi-field { display: flex; flex-direction: column; gap: 5px; }
.cmi-field label { font-size: 0.75rem; font-weight: 600; color: #555; text-transform: uppercase; letter-spacing: 0.04em; }
.cmi-input-wrap { position: relative; }
.cmi-input-wrap input { width: 100%; padding: 11px 38px 11px 13px; border: 1.5px solid #e8e8e8; border-radius: var(--radius); font-size: 0.9rem; outline: none; transition: border-color var(--trans); }
.cmi-input-wrap input:focus { border-color: var(--red); }
.cmi-input-wrap i { position: absolute; right: 11px; top: 50%; transform: translateY(-50%); color: var(--grey); font-size: 1.05rem; }
.cmi-field > input { padding: 11px 13px; border: 1.5px solid #e8e8e8; border-radius: var(--radius); font-size: 0.9rem; outline: none; transition: border-color var(--trans); }
.cmi-field > input:focus { border-color: var(--red); }
.btn-cmi-pay { width: 100%; padding: 14px; background: var(--red); color: white; border-radius: var(--radius); font-size: 0.93rem; font-weight: 700; display: flex; align-items: center; justify-content: center; gap: 7px; transition: background var(--trans), transform var(--trans); margin-top: 4px; }
.btn-cmi-pay:hover { background: var(--red-dark); transform: translateY(-1px); }
.cmi-legal { text-align: center; font-size: 0.7rem; color: var(--grey); margin-top: 12px; }
.cmi-processing { text-align: center; padding: 20px 0; }
.cmi-spinner { width: 50px; height: 50px; border: 4px solid #f0f0f0; border-top-color: var(--red); border-radius: 50%; animation: spin 0.9s linear infinite; margin: 0 auto 22px; }
.cmi-processing h3 { font-size: 1.1rem; font-weight: 700; color: var(--dark); margin-bottom: 7px; }
.cmi-processing p  { font-size: 0.86rem; color: var(--grey); }
.cmi-result { text-align: center; padding: 10px 0; }
.cmi-result-icon { font-size: 3.2rem; margin-bottom: 14px; }
.cmi-result.success .cmi-result-icon { color: #28a745; }
.cmi-result.fail    .cmi-result-icon { color: var(--red); }
.cmi-result h3 { font-size: 1.25rem; font-weight: 800; margin-bottom: 9px; }
.cmi-result p  { font-size: 0.86rem; color: var(--grey); margin-bottom: 18px; }

/* ══════════════════════
   CHATBOT
══════════════════════ */
.chatbot-wrap { position: fixed; bottom: 22px; right: 22px; z-index: 850; }
.chatbot-toggle { width: 54px; height: 54px; background: var(--red); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: white; font-size: 1.25rem; box-shadow: var(--shadow-red); position: relative; transition: transform var(--trans), background var(--trans); }
.chatbot-toggle:hover { transform: scale(1.08); background: var(--red-dark); }
.chatbot-badge { position: absolute; top: -4px; right: -4px; width: 19px; height: 19px; background: #25D366; border-radius: 50%; font-size: 0.65rem; font-weight: 700; color: white; display: flex; align-items: center; justify-content: center; }
.chatbot-box { position: absolute; bottom: 66px; right: 0; width: 310px; background: white; border-radius: var(--radius-lg); box-shadow: 0 16px 60px rgba(0,0,0,0.18); overflow: hidden; display: none; animation: slideDown 0.25s ease; }
.chatbot-box.open { display: flex; flex-direction: column; }
.cb-header { display: flex; align-items: center; gap: 11px; padding: 13px 15px; background: var(--dark); color: white; }
.cb-avatar { width: 34px; height: 34px; background: var(--red); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 0.95rem; }
.cb-hinfo strong { display: block; font-size: 0.86rem; }
.cb-online { font-size: 0.68rem; color: #4dd480; display: flex; align-items: center; gap: 4px; }
.cb-online i { font-size: 0.42rem; }
.cb-close-btn { margin-left: auto; color: rgba(255,255,255,0.38); font-size: 0.88rem; transition: color var(--trans); }
.cb-close-btn:hover { color: white; }
.cb-messages { flex: 1; padding: 14px; overflow-y: auto; display: flex; flex-direction: column; gap: 9px; max-height: 270px; background: #f8f8f8; }
.cb-msg { display: flex; }
.cb-msg.bot  { justify-content: flex-start; }
.cb-msg.user { justify-content: flex-end; }
.cb-bubble { max-width: 85%; padding: 9px 13px; border-radius: 14px; font-size: 0.81rem; line-height: 1.55; }
.cb-msg.bot  .cb-bubble { background: white; color: var(--dark); border: 1px solid #eee; border-radius: 4px 14px 14px 14px; }
.cb-msg.user .cb-bubble { background: var(--red); color: white; border-radius: 14px 4px 14px 14px; }
.cb-quick-btns { display: flex; flex-wrap: wrap; gap: 5px; padding: 9px 11px; background: #f0f0f0; border-top: 1px solid #e8e8e8; }
.cb-qbtn { padding: 5px 9px; background: white; border: 1px solid #ddd; border-radius: 50px; font-size: 0.7rem; font-weight: 600; color: var(--dark); transition: all var(--trans); }
.cb-qbtn:hover { background: var(--red); color: white; border-color: var(--red); }
.cb-input-wrap { display: flex; gap: 7px; padding: 9px 11px; background: white; border-top: 1px solid #eee; }
.cb-input { flex: 1; padding: 8px 11px; border: 1.5px solid #e8e8e8; border-radius: var(--radius); font-size: 0.81rem; outline: none; transition: border-color var(--trans); }
.cb-input:focus { border-color: var(--red); }
.cb-send { width: 34px; height: 34px; background: var(--red); border-radius: var(--radius); color: white; font-size: 0.8rem; display: flex; align-items: center; justify-content: center; transition: background var(--trans); }
.cb-send:hover { background: var(--red-dark); }

/* ══════════════════════
   TOAST
══════════════════════ */
.toast-wrap { position: fixed; bottom: 88px; left: 50%; transform: translateX(-50%); z-index: 9000; display: flex; flex-direction: column; gap: 7px; pointer-events: none; }
.toast { background: var(--dark); color: white; padding: 11px 22px; border-radius: 50px; font-size: 0.83rem; font-weight: 600; box-shadow: var(--shadow); border-left: 3px solid var(--red); animation: slideDown 0.3s ease; pointer-events: auto; }
.toast.success { border-left-color: #28a745; }
.toast.error   { border-left-color: var(--red); }

/* ══════════════════════
   ANIMATIONS
══════════════════════ */
.anim { opacity: 0; transform: translateY(22px); transition: opacity 0.6s ease, transform 0.6s ease; }
.anim.visible { opacity: 1; transform: none; }

/* ══════════════════════
   RTL SUPPORT
══════════════════════ */
[dir="rtl"] .hero-h1 em { display: inline; }
[dir="rtl"] .nav-inner  { flex-direction: row-reverse; }
[dir="rtl"] .ms         { flex-direction: row-reverse; }
[dir="rtl"] .qb-form    { text-align: right; }
[dir="rtl"] .faq-q      { text-align: right; }
[dir="rtl"] .mobile-menu { right: auto; left: 0; transform: translateX(-100%); }
[dir="rtl"] .mobile-menu.open { transform: translateX(0); }
[dir="rtl"] .mobile-menu-close { align-self: flex-start; }

/* ══════════════════════
   RESPONSIVE
══════════════════════ */
@media (max-width: 1100px) {
  .nav-links { gap: 0; }
  .nl { padding: 7px 10px; font-size: 0.83rem; }
  .contact-wrap { grid-template-columns: 1fr 1fr; }
  .contact-map  { grid-column: span 2; min-height: 220px; }
  /* footer ultra-compact */
  .extras-grid  { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 900px) {
  /* Nav : masquer desktop links, afficher burger */
  .nav-links { display: none; }
  .burger    { display: flex; }
  .lang-sw   { display: none; }

  .section-exp { grid-template-columns: 1fr; }
  .exp-img-side { height: 260px; }
  .exp-text-side { padding: 44px 28px; }
  .rev-carousel { grid-template-columns: 1fr 1fr; }
  .qb-grid-3 { grid-template-columns: 1fr 1fr; }

  /* footer ultra-compact mobile */
  .footer-strip { padding: 8px 0; min-height: 60px; }
  .footer-copy  { font-size: 0.65rem; }
}

@media (max-width: 700px) {
  .contact-wrap { grid-template-columns: 1fr; }
  .contact-map  { grid-column: auto; }
  .mv-layout    { grid-template-columns: 1fr; }
  .mv-img { height: 200px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .rev-carousel { grid-template-columns: 1fr; }
  .qb-grid   { grid-template-columns: 1fr; }
  .qb-grid-3 { grid-template-columns: 1fr; }
  .wa-selector { grid-template-columns: 1fr; }
  .war-btns  { flex-direction: column; }
  .qb-section { padding: 22px 18px; }
  .qb-price-recap { padding: 18px 18px; }
  .qb-note    { padding: 12px 18px; }
  .btn-wa-send { padding: 15px 18px; }
  .cf-row { grid-template-columns: 1fr; }
  /* footer ultra-compact petit écran */
  .footer-strip { justify-content: center; gap: 8px; }
  .footer-copy  { text-align: center; flex: 1 1 100%; order: 3; font-size: 0.62rem; }
  .fleet-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
}

@media (max-width: 500px) {
  .fleet-grid  { grid-template-columns: 1fr; }
  .why-grid    { grid-template-columns: 1fr; }
  .extras-grid { grid-template-columns: 1fr 1fr; }
  .ext-card    { height: 170px; }
  .hero-stats  { flex-wrap: wrap; }
  .hs-stat     { min-width: 50%; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.05); }
  .chatbot-box { width: calc(100vw - 44px); right: 0; }
  .footer-logo { height: 52px; }
  .modal-box { margin: 10px; }
  .war-header h2 { font-size: 1.1rem; }
  .nav-logo img { height: 68px; max-width: 200px; }
  .btn-admin-nav span { display: none; }
  .btn-admin-nav { padding: 7px 10px; }
}

@media (max-width: 380px) {
  .extras-grid { grid-template-columns: 1fr; }
  .nav-logo img { height: 52px; max-width: 160px; }
  .btn-red, .btn-white { padding: 12px 18px; font-size: 0.86rem; }
  .hero-h1 { font-size: clamp(1.7rem, 9vw, 2.4rem); }
}

/* ══════════════════════
   EXTRAS — IMAGE FALLBACK
   Dégradés si images manquantes
══════════════════════ */
.ext-card:nth-child(1) { background: linear-gradient(135deg,#1a1a1a,#2a0a0a); }
.ext-card:nth-child(2) { background: linear-gradient(135deg,#0a1a0a,#1a2a1a); }
.ext-card:nth-child(3) { background: linear-gradient(135deg,#0a0a2a,#1a1a2a); }
.ext-card:nth-child(4) { background: linear-gradient(135deg,#1a0a1a,#2a1a0a); }
.ext-card img { background: transparent; }

/* ══════════════════════
   EXPERIENCE — IMAGE FALLBACK
══════════════════════ */
.exp-img-side {
  background: linear-gradient(160deg, #1a0a0a 0%, #0a0a0a 50%, #C8102E18 100%);
}

/* ══════════════════════
   VÉHICULE CARD — AMÉLIORATION
══════════════════════ */
.vcard-img-wrap {
  background: linear-gradient(135deg, #f5f5f5, #eaeaea);
}
.vcard-img-wrap img[src=''] {
  opacity: 0;
}

/* ══════════════════════
   AMÉLIORATION SCROLL MOBILE
══════════════════════ */
@media (max-width: 900px) {
  html { -webkit-text-size-adjust: 100%; }
  .hero-content { padding-top: calc(var(--nav-h) + 32px); }
  .section-fleet,
  .section-why,
  .section-booking,
  .section-reviews,
  .section-extras,
  .section-faq,
  .section-contact { padding: 72px 0; }
  .sec-head { margin-bottom: 36px; }
}

@media (max-width: 700px) {
  .section-fleet,
  .section-why,
  .section-booking,
  .section-reviews,
  .section-extras,
  .section-faq,
  .section-contact { padding: 56px 0; }
  .container { padding: 0 16px; }
  .hero-h1 { font-size: clamp(1.9rem, 8vw, 2.8rem); }
  .hero-sub { font-size: 0.88rem; }
  .exp-text-side { padding: 36px 20px; }
  .wa-recap-inner { padding: 24px 18px; }
  .cmi-step { padding: 24px 18px; }
  .chatbot-box { right: -10px; }
}

/* ══════════════════════
   PRINT : masquer éléments inutiles
══════════════════════ */
@media print {
  .navbar, .fab-wa, .chatbot-wrap, .preloader, .mobile-menu, .mobile-menu-overlay { display: none !important; }
}

/* ══════════════════════════════════════
   GALERIE 5 PHOTOS — MODAL VÉHICULE
══════════════════════════════════════ */

/* Conteneur de miniatures dans le modal */
.mv-gallery {
  display: flex;
  gap: 6px;
  padding: 8px 10px;
  background: rgba(0,0,0,0.55);
  flex-wrap: wrap;
  justify-content: center;
  min-height: 0;
}
.mv-gallery:empty { display: none; }

/* Chaque miniature */
.mv-thumb {
  width: 54px;
  height: 40px;
  object-fit: cover;
  border-radius: 5px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: border-color 0.2s, transform 0.2s, opacity 0.2s;
  opacity: 0.65;
  flex-shrink: 0;
}
.mv-thumb:hover   { opacity: 1; transform: scale(1.06); }
.mv-thumb.active  { border-color: var(--red); opacity: 1; }

/* Badge compteur de photos sur la carte véhicule */
.gallery-count {
  position: absolute;
  bottom: 8px;
  right: 8px;
  background: rgba(0,0,0,0.68);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 50px;
  display: flex;
  align-items: center;
  gap: 4px;
  backdrop-filter: blur(4px);
  letter-spacing: 0.03em;
}
.gallery-count i { font-size: 0.58rem; color: rgba(255,255,255,0.75); }

/* Responsive : miniatures plus petites sur mobile */
@media (max-width: 700px) {
  .mv-thumb { width: 42px; height: 30px; }
  .mv-img   { height: 180px; }
}
@media (max-width: 400px) {
  .mv-thumb { width: 36px; height: 26px; }
}

/* ══════════════════════════════════════
   ADMIN — IMAGE GALLERY IN TABLE
══════════════════════════════════════ */
.dt-img-gallery {
  position: relative;
  display: inline-block;
  line-height: 0;
}
.dt-img-count {
  position: absolute;
  bottom: 2px;
  right: 2px;
  background: rgba(0,0,0,0.72);
  color: #fff;
  font-size: 0.58rem;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 4px;
  white-space: nowrap;
  pointer-events: none;
}

/* ══════════════════════════════════════
   MOBILE CSS — CORRECTIONS CRITIQUES
══════════════════════════════════════ */

/* ── Navbar : z-index cohérent, pas d'overlay de menu sur le slider ── */
.navbar               { z-index: 900; }
.mobile-menu-overlay  { z-index: 950; }
.mobile-menu          { z-index: 960; }
#preloader            { z-index: 9999; }

/* ── Logo : une seule occurrence visible (fallback caché par défaut) ── */
.nav-logo { position: relative; }
.nl-fallback {
  display: none;          /* masqué jusqu'à ce que JS active onerror */
  gap: 4px; align-items: baseline;
  font-size: 1.05rem; font-weight: 900; letter-spacing: 2px;
}

/* ── Burger : toujours visible sur mobile, jamais en desktop ── */
@media (min-width: 901px) {
  .burger       { display: none !important; }
  .mobile-menu,
  .mobile-menu-overlay { display: none !important; transform: none !important; }
}
@media (max-width: 900px) {
  .nav-links  { display: none !important; }    /* liens desktop masqués */
  .lang-sw    { display: none; }               /* sélecteur langue desktop masqué */
  .burger     { display: flex !important; }    /* burger toujours visible */

  /* Éviter que le preloader masque le contenu après chargement */
  #preloader.hidden { display: none !important; }

  /* Hero : contenu bien centré sous la navbar */
  .hero-content {
    padding-top: calc(var(--nav-h) + 48px);
    padding-bottom: 32px;
  }

  /* Navbar logo adapté */
  .nav-logo img {
    height: 64px;
    max-width: 180px;
  }

  /* Éviter overflow horizontal */
  body { overflow-x: hidden; }

  /* Modal véhicule : full-width sur mobile */
  .modal-box {
    max-width: calc(100vw - 24px);
    margin: 0 auto;
    max-height: 95vh;
  }
}

@media (max-width: 500px) {
  .nav-logo img { height: 52px; max-width: 150px; }

  /* Hero stats sur 2 colonnes */
  .hero-stats  { flex-wrap: wrap; }
  .hs-stat     { min-width: 50%; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.05); }

  /* Bouton admin nav : icône seule */
  .btn-admin-nav span { display: none; }
  .btn-admin-nav      { padding: 7px 10px; }

  /* Fleet grid : 1 colonne */
  .fleet-grid { grid-template-columns: 1fr; }

  /* Modal véhicule : empilement vertical */
  .mv-layout { grid-template-columns: 1fr; }
  .mv-img    { height: 200px; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .mv-info   { padding: 22px 18px; }

  /* Galerie miniatures */
  .mv-gallery { padding: 6px 8px; gap: 4px; }
}

@media (max-width: 380px) {
  .nav-logo img   { height: 44px; max-width: 130px; }
  .hero-h1        { font-size: clamp(1.6rem, 9vw, 2.2rem); }
  .btn-red, .btn-white { padding: 11px 16px; font-size: 0.84rem; }
  .extras-grid    { grid-template-columns: 1fr; }
}
