:root{
  --bg:#0c0d10;
  --bg-2:#121419;
  --card:#161922;
  --card-2:#1d212c;
  --line:#272b36;
  --text:#eef0f4;
  --muted:#9aa0ad;
  --gold:#c8a24a;
  --gold-2:#e3c878;
  --green:#37b24d;
  --red:#e03131;
  --radius:16px;
  --shadow:0 20px 60px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{max-width:100%;overflow-x:hidden}
img{max-width:100%}
.ico{display:inline-block;width:1.05em;height:1.05em;vertical-align:-.16em;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:none}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.container{width:min(1180px,92%);margin:0 auto}
h1,h2,h3,.brand-name{font-family:'Cormorant Garamond',serif;font-weight:600;letter-spacing:.3px}
a{color:inherit;text-decoration:none}
.accent{color:var(--gold-2)}
.eyebrow{
  text-transform:uppercase;letter-spacing:.28em;font-size:.72rem;
  color:var(--gold);font-weight:600;margin-bottom:14px;font-family:'Inter',sans-serif;
}
.eyebrow.center,.section-title{text-align:center}
.center{text-align:center}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 24px;border-radius:999px;font-weight:600;font-size:.95rem;
  cursor:pointer;border:1px solid transparent;transition:.2s;font-family:'Inter',sans-serif;
  background:transparent;color:var(--text);
}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#1a1405;border:none}
.btn-gold:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold-2)}
.btn-block{width:100%}

/* Nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(12,13,16,.82);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;gap:10px;font-size:1.35rem}
.brand-mark{color:var(--gold)}
.brand-name{font-size:1.4rem}
.nav-links{display:flex;align-items:center;gap:28px;font-size:.95rem}
.nav-links a:not(.btn){color:var(--muted)}
.nav-links a:not(.btn):hover{color:var(--text)}

/* Hero */
.hero{position:relative;overflow:hidden;padding:70px 0 90px;background:#0a0b0e}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.hero-overlay{position:absolute;inset:0;z-index:0;
  background:
    linear-gradient(105deg, rgba(8,9,11,.92) 0%, rgba(8,9,11,.74) 42%, rgba(8,9,11,.40) 100%),
    radial-gradient(1100px 520px at 82% -10%, rgba(200,162,74,.22), transparent 60%),
    url("https://images.unsplash.com/photo-1606664515524-ed2f786a0bd6?q=80&w=1600&auto=format&fit=crop") center/cover;
}
@media(max-width:920px){
  /* Mobile : berline claire de jour (recadrée portrait) — image nette et bien visible */
  .hero-overlay{background:
    linear-gradient(180deg, rgba(8,9,11,.68) 0%, rgba(8,9,11,.44) 46%, rgba(8,9,11,.88) 100%),
    url("https://images.unsplash.com/photo-1606152421802-db97b9c7a11b?q=80&w=900&h=1500&fit=crop&crop=entropy") center/cover;}
}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:54px;align-items:center}
.hero-text,.booking-card{min-width:0}
.hero-text h1{font-size:clamp(2.4rem,4.6vw,4rem);line-height:1.04;margin:8px 0 18px}
.lead{color:var(--muted);font-size:1.12rem;max-width:520px}
.hero-bullets{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:24px;color:#cfd3db}
.hero-bullets li{font-size:.98rem;display:flex;align-items:center;gap:10px}
.hero-bullets li svg{width:18px;height:18px;color:var(--gold-2)}

/* Booking card */
.booking-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow)}
.booking-card h2{font-size:1.85rem}
.booking-sub{color:var(--muted);font-size:.92rem;margin:4px 0 18px}
.field{margin-bottom:14px;position:relative}
.field label{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}
.field .opt{text-transform:none;letter-spacing:0;color:#6a7080}
.field input{
  width:100%;min-width:0;max-width:100%;padding:12px 14px;background:var(--bg-2);border:1px solid var(--line);
  border-radius:10px;color:var(--text);font-size:1rem;font-family:inherit;transition:.15s;
}
.field input:focus{outline:none;border-color:var(--gold);background:#14161d}
.field input::placeholder{color:#5d6470}
/* Empêche les champs date/heure de déborder sur iOS Safari (largeur native imposée) */
.field input[type="datetime-local"],.field input[type="date"],.field input[type="time"]{
  -webkit-appearance:none;appearance:none;min-height:46px;line-height:1.2;
}
.field input[type="datetime-local"]::-webkit-date-and-time-value{text-align:left;margin:0}
.field input[type="datetime-local"]::-webkit-calendar-picker-indicator{margin-left:auto}
.field-row{display:flex;gap:12px}
.field-row .field{flex:1;min-width:0}
.field-hint{font-size:.78rem;color:var(--muted);margin:-2px 0 14px;line-height:1.45}
.field-hint strong{color:var(--gold-2);font-weight:600}
.field-hint svg{width:15px;height:15px;color:var(--gold-2);vertical-align:-.18em;margin-right:5px}
.field-narrow{max-width:110px}

/* Autocomplete */
.autocomplete{position:relative}
.suggestions{list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:30;
  background:var(--card-2);border:1px solid var(--line);border-radius:10px;overflow:hidden;display:none;max-height:240px;overflow-y:auto;box-shadow:var(--shadow)}
.suggestions.open{display:block}
.suggestions li{padding:10px 14px;font-size:.9rem;cursor:pointer;border-bottom:1px solid var(--line);color:#cfd3db}
.suggestions li:last-child{border-bottom:none}
.suggestions li.sugg-item:hover,.suggestions li.active{background:rgba(200,162,74,.14);color:#fff}
.suggestions li.sugg-header,.suggestions li.sugg-header:hover{cursor:default;background:rgba(200,162,74,.07);color:var(--gold);font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.suggestions li.sugg-info,.suggestions li.sugg-info:hover{cursor:default;background:transparent;color:var(--muted);font-style:italic}

/* Classes selector */
.classes{display:grid;grid-template-columns:1fr;gap:8px}
.class-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:var(--bg-2);cursor:pointer;transition:.15s}
.class-opt:hover{border-color:#3a3f4d}
.class-opt.selected{border-color:var(--gold);background:rgba(200,162,74,.10)}
.class-opt .c-name{font-weight:600}
.class-opt .c-meta{font-size:.78rem;color:var(--muted)}
.class-opt .c-cap{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;color:var(--gold-2);white-space:nowrap}
.class-opt .c-cap svg{width:15px;height:15px}

/* Quote box */
.quote-box{background:linear-gradient(135deg,rgba(200,162,74,.14),rgba(200,162,74,.04));
  border:1px solid rgba(200,162,74,.4);border-radius:12px;padding:14px 16px;margin:6px 0 16px}
.route-map{height:190px;border-radius:12px;overflow:hidden;margin-bottom:12px;border:1px solid rgba(200,162,74,.35);background:#0a0b0e}
.route-map .leaflet-container{background:#0a0b0e;font-family:inherit}
.leaflet-control-attribution{background:rgba(12,13,16,.7)!important;color:#6a7080!important;font-size:.62rem!important}
.leaflet-control-attribution a{color:#8a90a0!important}
.quote-stats{display:flex;gap:12px;justify-content:space-between;align-items:flex-end}
.qstat{display:flex;flex-direction:column;gap:3px}
.qlabel{font-size:.66rem;text-transform:uppercase;letter-spacing:.09em;color:var(--muted)}
.qval{font-size:1.02rem;color:var(--text);font-weight:600}
.qprice{text-align:right}
.qprice .qval{color:var(--gold-2);font-family:'Cormorant Garamond',serif;font-size:1.55rem;line-height:1}
.quote-note{font-size:.74rem;color:var(--muted);display:block;margin-top:10px}

.consent{display:flex;gap:9px;align-items:flex-start;margin:4px 0 14px;font-size:.78rem;color:var(--muted);line-height:1.4;cursor:pointer}
.consent input{margin-top:2px;width:16px;height:16px;flex:none;accent-color:var(--gold)}
.consent a{color:var(--gold-2);text-decoration:underline}

.form-msg{margin-top:12px;font-size:.92rem;text-align:center;min-height:1.2em}
.form-msg.ok{color:var(--green)}
.form-msg.err{color:var(--red)}

/* Confirmation animée (Lottie) */
.booking-success{text-align:center;padding:14px 6px 6px}
.booking-success .success-anim{width:150px;height:150px;margin:0 auto}
.booking-success h3{font-size:1.7rem;margin-top:4px}
.booking-success p{color:var(--muted);font-size:.95rem;margin:6px 0 18px}

/* Reveal au scroll (actif seulement si JS dispo, sinon contenu visible) */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease;will-change:opacity,transform}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}

/* Sections */
.section{padding:90px 0}
.section-dark{background:var(--bg-2)}
.section-title{font-size:clamp(1.8rem,3vw,2.6rem);margin:6px auto 46px;max-width:760px}

/* Fleet */
.fleet{display:flex;flex-wrap:wrap;justify-content:center;gap:26px}
.fleet-card{flex:0 1 460px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.fleet-card:hover{transform:translateY(-6px);border-color:rgba(200,162,74,.5);box-shadow:var(--shadow)}
.fleet-photo{position:relative;height:240px;overflow:hidden}
.fleet-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.fleet-card:hover .fleet-photo img{transform:scale(1.06)}
.fleet-photo .badge{position:absolute;top:12px;left:12px;font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;
  color:#1a1405;background:linear-gradient(135deg,var(--gold),var(--gold-2));border-radius:999px;padding:5px 12px;font-weight:700}
.fleet-body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.fleet-card h3{font-size:1.7rem;margin-bottom:8px}
.fleet-card p{color:var(--muted);font-size:.96rem}
.model-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.model-tag{font-size:.76rem;color:var(--gold-2);background:rgba(200,162,74,.10);
  border:1px solid rgba(200,162,74,.32);border-radius:999px;padding:4px 11px}
.fleet-thumbs{display:flex;gap:8px;margin-top:16px}
.fleet-thumbs img{width:33%;height:62px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.fleet-card .caps{display:flex;gap:16px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line);font-size:.85rem;color:#cfd3db}
.caps span{display:inline-flex;align-items:center;gap:7px}
.caps svg{width:17px;height:17px;color:var(--gold-2)}

/* Zones */
.zones{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.zone{position:relative;min-height:320px;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;align-items:flex-end;background-size:cover;background-position:center;transition:.3s}
.zone::before{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(8,9,11,.05) 0%, rgba(8,9,11,.35) 52%, rgba(8,9,11,.88) 100%);transition:.3s}
.zone:hover{transform:translateY(-5px);border-color:rgba(200,162,74,.55)}
.zone:hover::before{background:linear-gradient(180deg, rgba(8,9,11,.12) 0%, rgba(8,9,11,.42) 52%, rgba(8,9,11,.9) 100%)}
.zone-body{position:relative;padding:24px}
.zone h3{font-size:1.7rem;color:var(--gold-2);margin-bottom:8px}
.zone p{color:#dfe2e8;font-size:.95rem}
.zone-mtp{background-image:url("/img/montpellier.jpg")}
.zone-nimes{background-image:url("/img/nimes.jpg")}
.zone-avignon{background-image:url("/img/avignon.jpg")}

/* Features */
.features{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;max-width:980px;margin:0 auto}
.feature{text-align:center;padding:24px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);transition:.2s}
.feature:hover{transform:translateY(-4px);border-color:rgba(200,162,74,.45)}
.feat-ico{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;margin:0 auto 16px;border-radius:50%;background:rgba(200,162,74,.12);border:1px solid rgba(200,162,74,.32);color:var(--gold-2)}
.feat-ico svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.feature h3{font-size:1.3rem;margin-bottom:6px}
.feature p{color:var(--muted);font-size:.92rem}

/* Footer */
.footer{background:#08090b;border-top:1px solid var(--line);padding:54px 0 26px}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
.brand-name.big{font-size:2rem}
.footer-zones{color:var(--gold);letter-spacing:.1em;font-size:.85rem}
.footer-contact{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.footer-contact p{color:var(--muted);font-size:.95rem}
.footer-contact svg{width:16px;height:16px;color:var(--gold-2);vertical-align:-.2em;margin-right:7px}
.footer-contact a:not(.btn):hover{color:var(--gold-2)}
.copyright{margin-top:34px;padding-top:20px;border-top:1px solid var(--line);color:#6a7080;font-size:.82rem;text-align:center}
.legal-links{margin-bottom:10px}
.legal-links a{color:var(--muted)}
.legal-links a:hover{color:var(--gold-2)}

/* Pages légales */
.legal-top{position:sticky;top:0;z-index:50;background:rgba(12,13,16,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.legal-top .container{display:flex;align-items:center;justify-content:space-between;height:68px}
.legal{max-width:820px;margin:0 auto;padding:44px 0 80px}
.legal h1{font-size:clamp(1.9rem,4vw,2.6rem);margin-bottom:6px}
.legal .updated{color:var(--muted);font-size:.85rem;margin-bottom:24px}
.legal h2{font-size:1.35rem;margin:30px 0 10px;color:var(--gold-2)}
.legal p,.legal li{color:#cfd3db;font-size:.96rem;margin-bottom:10px;line-height:1.7}
.legal ul{padding-left:22px;margin-bottom:10px}
.legal a{color:var(--gold-2);text-decoration:underline}
.legal .todo{background:rgba(200,162,74,.12);border:1px solid rgba(200,162,74,.4);border-radius:6px;padding:1px 7px;color:var(--gold-2);font-size:.9rem;font-weight:600}

/* Bandeau cookies */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:95;max-width:700px;margin:0 auto;
  background:var(--card-2);border:1px solid var(--line);border-radius:14px;padding:16px 18px;
  display:flex;gap:18px;align-items:center;justify-content:space-between;box-shadow:var(--shadow)}
.cookie-banner[hidden]{display:none}
.cookie-banner p{font-size:.84rem;color:#cfd3db;margin:0;line-height:1.5}
.cookie-banner a{color:var(--gold-2);text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex:none}
.cookie-actions .btn{padding:9px 18px;font-size:.9rem}
@media(max-width:600px){
  .cookie-banner{flex-direction:column;align-items:stretch;left:10px;right:10px;bottom:10px}
  .cookie-actions{justify-content:flex-end}
}

/* Bouton WhatsApp flottant */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:80;
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#25d366;color:#fff;
  box-shadow:0 10px 30px rgba(37,211,102,.45);
  transition:transform .18s, box-shadow .18s;
}
.wa-float:hover{transform:scale(1.08);box-shadow:0 14px 38px rgba(37,211,102,.6)}
.wa-float::after{
  content:"Réserver sur WhatsApp";
  position:absolute;right:72px;white-space:nowrap;
  background:#161922;color:#eef0f4;border:1px solid var(--line);
  padding:8px 14px;border-radius:999px;font-size:.85rem;font-weight:500;
  opacity:0;transform:translateX(8px);transition:.18s;pointer-events:none;
}
.wa-float:hover::after{opacity:1;transform:translateX(0)}

/* Responsive */
@media(max-width:920px){
  .hero{padding:46px 0 64px}
  .hero-grid{grid-template-columns:minmax(0,1fr);gap:32px}
  .features{grid-template-columns:minmax(0,1fr)}
  .zones{grid-template-columns:repeat(2,minmax(0,1fr))}
  .nav-links a:not(.btn){display:none}
  .section{padding:64px 0}
  .section-title{margin-bottom:34px}
  .lead{font-size:1.05rem}
}
@media(max-width:560px){
  .zones{grid-template-columns:minmax(0,1fr)}
  .features{grid-template-columns:repeat(2,minmax(0,1fr))}
  .booking-card{padding:22px}
  .field-row{flex-direction:column;gap:0}
  .field-narrow{max-width:none}
  .footer-inner{flex-direction:column;align-items:flex-start}
  .footer-contact{align-items:flex-start}
  .zone{min-height:240px}
  .wa-float{width:56px;height:56px;right:16px;bottom:16px}
  .wa-float::after{display:none}
}
