/* FILE: style.css */
:root{--container:1200px;--sp-1:.5rem;--sp-2:1rem;--sp-3:1.5rem;--sp-4:2rem;--radius:14px;--ink:#111;--bg:#fff}
*{box-sizing:border-box}
html{scroll-behavior:auto}
html,body{margin:0;padding:0;overflow-x:hidden}
body{font-family:Montserrat,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;line-height:1.6;color:var(--ink);background:var(--bg)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}

.skip{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:var(--sp-2);top:var(--sp-2);width:auto;height:auto;background:#000;color:#fff;padding:var(--sp-1) var(--sp-2);border-radius:10px;z-index:9999}

/* Header */
header{position:fixed;top:0;left:0;right:0;z-index:1000;background:#000;color:#fff;box-shadow:0 6px 14px rgba(0,0,0,.15);will-change:transform,opacity;transition:transform .4s ease, opacity .3s ease}
header.header-hidden{transform:translateY(-110%);opacity:.02}
@media (prefers-reduced-motion: reduce){header{transition:none}}
.bar{max-width:var(--container);margin:0 auto;display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-2)}
.logo{width:auto;height:auto;max-height:clamp(36px,6vw,72px);transition:transform .6s cubic-bezier(.55,.06,.68,.19), filter .6s ease}
.brand{display:flex;flex-direction:column;position:relative;overflow:hidden}
.brand h1{margin:0;font-size:1.25rem;letter-spacing:.06em;text-transform:uppercase}
.brand p{margin:0;color:#d1d5db;font-weight:500;font-size:.9rem}
nav{margin-left:auto}
#site-nav{display:block}
.nav{list-style:none;display:flex;gap:var(--sp-3);margin:0;padding:0}
.nav a{font-weight:700;font-size:.95rem;opacity:.95}
.nav a:hover{color:#bdbdbd}

/* Burger */
.menu-toggle{display:none;margin-left:auto;width:44px;height:44px;border:0;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.menu-toggle span{display:block;width:26px;height:2px;background:#fff;margin:5px 0;transition:.25s ease}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Floating car clone for slide */
.car-fx{position:fixed;z-index:2000;pointer-events:none;will-change:transform,filter;transition:transform .7s cubic-bezier(.55,.06,.68,.19), filter .7s ease;mix-blend-mode:screen;backface-visibility:hidden}
.car-fx.run{filter:blur(1px);transform:translateX(0)}

section{scroll-margin-top:84px}

/* Hero */
.hero{padding:var(--sp-3) var(--sp-2) var(--sp-3);background:linear-gradient(180deg,#0a0a0a 0%,#111 50%,#1a1a1a 100%);color:#fff;min-height:calc(60svh - var(--header-h, 64px));display:grid;align-items:center}
@media (max-width:720px){.hero{min-height:calc(55svh - var(--header-h, 56px))}}
.hero .wrap{max-width:var(--container);margin:0 auto;display:grid;gap:var(--sp-3);padding-inline:clamp(16px,3vw,48px)}
.hero .wrap > div{max-width:90ch;margin:0 auto;text-align:center}
.lead{font-size:2rem;line-height:1.2;margin:0;font-weight:800}
.sub{margin:0 auto;max-width:75ch;color:#e5e7eb}
.cta{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-top:var(--sp-2);justify-content:center}
.btn{padding:.8rem 1.2rem;border-radius:999px;font-weight:700;border:2px solid #fff}
.btn.primary{background:#fff;color:#000;border-color:#fff}
.btn.ghost{background:transparent;color:#fff}

/* Services */
.services{padding:calc(var(--sp-4) + var(--sp-2)) var(--sp-2); padding-bottom:0}
.services .wrap{max-width:var(--container);margin:0 auto;padding-inline:clamp(16px,3vw,48px);text-align:center}
.services h2{margin:0 0 calc(var(--sp-4) + .5rem);font-size:2rem}
.service-rows{display:grid;gap:calc(var(--sp-4) * 2.5)}
.service-row{display:grid;gap:var(--sp-3);padding:var(--sp-4) var(--sp-2);background:#fff}
.service-media{border-radius:var(--radius);overflow:hidden}
.service-media img{width:100%;height:auto;object-fit:cover}
.service-content h3{margin:0 0 .6rem;font-size:1.5rem}
.service-content p{margin:0;color:#444}

/* Contact (fond stylé) */
.contact{
  position:relative;
  padding:clamp(18px,2.5vw,32px) var(--sp-2) clamp(56px,8vw,112px);
  background:
    radial-gradient(60% 80% at 10% 10%, rgba(255,255,255,.18) 0%, rgba(255,255,255,0) 60%),
    radial-gradient(50% 70% at 90% 30%, rgba(255,255,255,.14) 0%, rgba(255,255,255,0) 60%),
    linear-gradient(135deg,#0e0f12 0%, #16181d 40%, #0f1116 100%);
  color:#fff;border-top:1px solid rgba(255,255,255,.06);
}
.contact::before{content:"";position:absolute;inset:-2px;background:
  radial-gradient(20% 20% at 20% 80%, rgba(74,222,128,.08), transparent 60%),
  radial-gradient(22% 18% at 80% 20%, rgba(96,165,250,.08), transparent 60%);pointer-events:none;filter:blur(20px)}
.contact .wrap{max-width:var(--container);margin:0 auto;padding-inline:clamp(16px,3vw,48px)}
.contact-head{display:grid;gap:.6rem;justify-items:center;text-align:center;margin-bottom:clamp(10px,1.8vw,18px)}
.contact-head h2{margin:.1rem 0 .25rem;font-size:clamp(1.4rem,2.6vw,2rem)}
.contact-head p{margin:0;color:#cbd5e1}
.contact-head .coords{display:flex;flex-wrap:wrap;gap:.6rem 1rem;justify-content:center;align-items:center}
.contact-head .coords a{font-weight:800}
.cgv{display:flex;align-items:center;gap:.5rem}
.cgv .cgv-ico{font-size:1.4rem;text-decoration:none}

/* Contact — barre horizontale */
.contact-form-bar{
  background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
  border-radius:16px; backdrop-filter: blur(6px);
  padding:clamp(10px,1.6vw,14px);
  display:grid; grid-template-columns: repeat(12, 1fr);
  gap:.6rem; align-items:end;
}
.form-row{display:grid;gap:.25rem}
.form-row input,.form-row textarea{
  width:100%;padding:.6rem .7rem;border:1px solid rgba(255,255,255,.22);
  border-radius:10px;background:rgba(255,255,255,.06);color:#fff;font:inherit;outline:none
}
.form-row textarea{min-height:80px;resize:vertical}
.form-row label{font-weight:700;font-size:.9rem;color:#eef2ff}
.err{min-height:1em;color:#fecaca;font-weight:700;font-size:.82rem}
.form-status{font-weight:800;margin-top:.25rem}
.form-status.success{color:#86efac}.form-status.error{color:#fca5a5}.form-status.info{color:#fde68a}
.btn{padding:.7rem 1rem;border-radius:999px;font-weight:800;border:2px solid #fff;cursor:pointer}
.btn.primary{background:#fff;color:#111}
.btn.ghost{background:transparent;color:#fff}
.agree-line{display:flex;align-items:center;justify-content:space-between;gap:.6rem;background:rgba(255,255,255,.03);padding:.5rem .6rem;border-radius:10px;border:1px solid rgba(255,255,255,.12)}
.agree-line input[type="checkbox"]{width:18px;height:18px;accent-color:#fff;background:#fff;border:1px solid #fff;border-radius:4px}

/* Grille formulaire */
@media (min-width:992px){
  .col-name{grid-column: span 4}
  .col-email{grid-column: span 4}
  .col-phone{grid-column: span 4}
  .col-message{grid-column: 1 / -1}
  .col-agree{grid-column: 1 / -1}
  .col-actions{grid-column: 1 / -1; display:flex; gap:.6rem; align-items:center; justify-content:flex-end}
}
@media (min-width:720px) and (max-width:991.98px){
  .col-name,.col-email{grid-column: span 6}
  .col-phone{grid-column: span 12}
  .col-message{grid-column: 1 / -1}
  .col-agree{grid-column: 1 / -1}
  .col-actions{grid-column: 1 / -1; display:flex; gap:.6rem; align-items:center; justify-content:flex-end}
}
@media (max-width:719.98px){
  .contact-form-bar{grid-template-columns:1fr}
  .col-actions{display:flex;gap:.6rem;align-items:center}
}

/* ===== Footer : grand, © forcé en bas, contenu centré colonne ===== */
footer.site-footer{
  color:#fff;
  background:#0b0b0b url('./assets/SL-092619-23740-39.jpg') center/cover no-repeat;
  min-height:min(50svh,560px);
  padding:clamp(48px,6vw,96px) var(--sp-2) clamp(72px,8vw,128px);
  display:flex;
  flex-direction:column;
}
.foot-main{
  max-width:var(--container);
  width:100%;
  margin:0 auto;
  padding-inline:clamp(16px,3vw,48px);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  row-gap:clamp(18px,3.8vw,36px);
  text-align:center;
  flex:1;
}
.foot-main .title{margin:0;font-weight:800;font-size:clamp(1.4rem,2.6vw,2rem)}
.foot-main .tagline{margin:0;opacity:.95}
.legal{text-align:center;opacity:.95;margin:0}

@media (min-width:768px){ .foot-main{ row-gap:clamp(24px,4.5vw,42px); } }

@media (min-width:768px){
  .bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;max-width:none;width:100%;margin:0;padding-left:20px;padding-right:20px}
  .bar > .brand{grid-column:2;justify-self:center;text-align:center}
  .bar > nav{grid-column:3;justify-self:end}
}

@media (min-width:768px){
  .service-rows{gap:calc(var(--sp-4) * 3.25)}
  .service-row{grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-template-areas:"content media";align-items:center;padding:calc(var(--sp-4) * 1.25) var(--sp-3)}
  .service-row .service-content{grid-area:content;max-width:60ch;margin:0 auto;text-align:left}
  .service-row .service-media{grid-area:media}
  #service-achat{grid-template-columns: 1.15fr 0.85fr; column-gap: clamp(56px, 6vw, 120px); align-items:center}
  #service-achat .service-media{justify-self:end; align-self:center; max-width:min(520px,38vw)}
  #service-achat .service-media img{width:100%; height:auto; max-height:min(420px,46vh); object-fit:cover; border-radius:var(--radius)}
  #service-vente, #service-financement{
    display:grid; grid-template-columns: 1.15fr 0.85fr;
    column-gap: clamp(56px, 6vw, 120px); align-items:center; grid-template-areas: "content media";
  }
  #service-vente .service-content, #service-financement .service-content{grid-area:content; max-width:60ch; text-align:left; margin:0 auto 0 0;}
  #service-vente .service-media,   #service-financement .service-media{grid-area:media; justify-self:end; align-self:center; max-width:min(520px,38vw);}
  #service-vente .service-media img, #service-financement .service-media img{width:100%; height:auto; max-height:min(420px,46vh); object-fit:cover; border-radius:var(--radius); display:block;}
}

@media (max-width:720px){
  section{scroll-margin-top:72px}
  .bar{flex-wrap:wrap;justify-content:space-between}
  .menu-toggle{display:flex}
  nav{margin-left:0;width:100%}
  #site-nav{
    position:fixed; top:var(--header-h,56px); left:0; right:0;
    width:100%; background:#000; z-index:1100;
    transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:transform .25s ease, opacity .25s ease;
  }
  #site-nav.open{ transform:translateY(0); opacity:1; pointer-events:auto }
  .nav{flex-direction:column;gap:var(--sp-1);justify-content:flex-start;padding:var(--sp-1) 0;max-height:calc(100svh - var(--header-h,56px));overflow:auto}
  .nav li{border-top:1px solid rgba(255,255,255,.1)}
  .nav li:last-child{border-bottom:1px solid rgba(255,255,255,.1)}
  .nav a{display:block;padding:.8rem var(--sp-2)}
  .logo{max-height:44px}
  .brand{flex:1}
  .brand h1{font-size:1rem}
  .brand p{font-size:.8rem}
  .hero{padding:var(--sp-4) var(--sp-2)}
  .lead{font-size:1.4rem}
  .sub{font-size:.95rem}
  .cta{flex-direction:column}
  .btn{width:100%;text-align:center}
  .services{padding:var(--sp-4) var(--sp-2); padding-bottom:0}
  .services h2{font-size:1.5rem;margin-bottom:var(--sp-3)}
  .service-row{
    padding:var(--sp-3) var(--sp-1);
    grid-template-columns: 1fr;
    grid-template-areas:
      "content"
      "media";
  }
  .service-content h3{font-size:1.2rem}
  .service-row .service-media{
    display:block; grid-area:media; justify-self:center; align-self:center;
    width:100%; max-width:min(560px, 92vw); margin-top:.75rem; border-radius:var(--radius); overflow:hidden;
  }
  .service-row .service-media img{
    width:100%; height:auto; aspect-ratio:16/9; object-fit:cover; display:block;
  }
}

@media (prefers-reduced-motion:no-preference){
  a,.btn{transition:color .2s ease, background-color .2s ease, opacity .2s ease, transform .2s ease}
  .btn:hover{transform:translateY(-1px)}
}

/* UX */
h1,h2,h3,p,.lead,.sub,.title,#services-titre,#contact-titre{caret-color:transparent}
a:focus-visible,button:focus-visible{outline:2px solid #fff;outline-offset:2px}
main{padding-top:var(--header-h,64px)}
/* === Desktop: images plus à droite + même format (16/9) === */
@media (min-width: 768px){
  :root{
    --media-shift: clamp(250px, 2.2vw, 64px);     /* décale vers la droite */
    --media-maxw:  min(680px, 46vw);             /* images + larges */
    --media-gap:   clamp(28px, 3.5vw, 72px);     /* réduit l’espace blanc entre texte et image */
  }

  /* Réduit l'espace blanc + laisse plus de place à la colonne image */
  #service-achat,
  #service-vente,
  #service-financement{
    column-gap: var(--media-gap);
    grid-template-columns: 1.05fr 0.95fr; /* un peu plus de place à l'image */
  }

  /* Pousse la colonne image vers la bordure droite */
  #service-achat .service-media,
  #service-vente .service-media,
  #service-financement .service-media{
    justify-self: end;
    max-width: var(--media-maxw);
    transform: translateX(var(--media-shift));
  }

  /* Même format pour toutes les images */
  #service-achat .service-media img,
  #service-vente .service-media img,
  #service-financement .service-media img{
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    object-position: center;
    display: block;
    border-radius: var(--radius);
    max-height: min(420px, 46vh);
  }
}
