/* =========================================================
   VF AUTOMOBILES — vitrine
   DA sur-mesure : charcoal + azur (#2C8FD4) + rouge (#D93B2D)
   Archivo (display) · Hanken Grotesk (texte)
   ========================================================= */

:root{
  --ink:#16171A;        /* warm near-black, surfaces sombres */
  --ink-2:#1D1F23;      /* cartes sur sombre */
  --ink-3:#2C2F36;      /* filets sur sombre */
  --paper:#F6F5F1;      /* off-white chaud, page */
  --paper-2:#FFFFFF;    /* cartes sur clair */
  --line:#E7E3DB;       /* filets sur clair */
  --blue:#2C8FD4;
  --blue-bright:#54AEEC;
  --blue-deep:#1E6FA8;
  --red:#D93B2D;
  --text:#1A1B1E;
  --text-2:#5C616B;
  --inv:#F2F3F5;
  --inv-2:#A4AAB4;
  --maxw:1200px;
  --pad:clamp(20px,5vw,40px);
  --r:14px;
  --r-lg:22px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --shadow:0 18px 50px -22px rgba(10,12,20,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:var(--paper);color:var(--text);
  line-height:1.6;font-size:16.5px;font-weight:400;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
svg{display:block}
.ico{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}

/* ---------- emblem / marque ---------- */
.emblem{width:100%;height:100%}
#vf-mark .mk-blue{color:var(--blue)}
#vf-mark .mk-red{color:var(--red)}
.brand{display:flex;align-items:center;gap:11px}
.brand-badge{width:42px;height:42px;border-radius:11px;background:var(--ink);display:grid;place-items:center;flex:0 0 auto;padding:8px;border:1px solid rgba(255,255,255,.08)}
.brand-badge .emblem{width:26px;height:26px}
.brand-word{font-family:"Archivo",sans-serif;font-weight:800;font-size:18px;letter-spacing:.12em;line-height:1;color:var(--inv);display:flex;flex-direction:column;gap:3px}
.brand-word b{font-weight:900}
.brand-word b, .brand-word{color:inherit}
.brand-word small{font-family:"Hanken Grotesk";font-weight:600;font-size:9.5px;letter-spacing:.18em;color:var(--inv-2);text-transform:uppercase}

/* =========================================================
   HEADER
   ========================================================= */
.site-head{position:fixed;top:0;left:0;right:0;z-index:60;transition:.35s var(--ease)}
.site-head .brand-word{color:#fff}
.head-inner{display:flex;align-items:center;gap:24px;height:74px}
.nav{display:none;margin-left:auto;gap:30px}
.nav a{font-weight:600;font-size:14.5px;color:rgba(255,255,255,.82);letter-spacing:.01em;position:relative;padding:6px 0;transition:.2s}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:2px;background:var(--blue);transition:right .3s var(--ease)}
.nav a:hover{color:#fff}
.nav a:hover::after{right:0}
.head-cta{display:none;align-items:center;gap:16px}
.tel-link{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:#fff}
.tel-link .ico{width:17px;height:17px;stroke:var(--blue-bright)}
.tel-link:hover{color:var(--blue-bright)}

/* état scrollé */
.site-head.scrolled{background:rgba(18,19,22,.86);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08)}
.site-head.scrolled .head-inner{height:64px}

.burger{margin-left:auto;width:44px;height:44px;display:grid;place-content:center;gap:5px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:11px;cursor:pointer}
.burger span{width:20px;height:2px;background:#fff;border-radius:2px;transition:.3s var(--ease)}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0;z-index:55;background:var(--ink);padding:96px var(--pad) 40px;display:flex;flex-direction:column;gap:8px;transform:translateY(-100%);transition:transform .45s var(--ease);visibility:hidden}
.mobile-menu.open{transform:translateY(0);visibility:visible}
.mobile-menu nav{display:flex;flex-direction:column}
.mobile-menu nav a{font-family:"Archivo";font-weight:800;font-size:30px;letter-spacing:-.01em;color:#fff;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-menu nav a:active{color:var(--blue-bright)}
.mm-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}
.mm-meta{margin-top:22px;color:var(--inv-2);font-size:14px;line-height:1.7}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:"Hanken Grotesk";font-weight:700;font-size:15px;line-height:1;padding:14px 22px;border-radius:11px;cursor:pointer;border:1.5px solid transparent;transition:.25s var(--ease);white-space:nowrap}
.btn .ico{width:18px;height:18px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 24px -10px rgba(44,143,212,.7)}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.22)}
.btn-ghost:hover{background:rgba(255,255,255,.13);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-line{background:transparent;border-color:currentColor;color:var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-sm{padding:11px 18px;font-size:14px}
.btn-lg{padding:16px 28px;font-size:16px}
.btn-block{width:100%}

/* =========================================================
   TYPO HELPERS
   ========================================================= */
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:12.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-deep);margin-bottom:18px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--red);flex:0 0 auto}
.eyebrow-light{color:var(--blue-bright)}
.h2{font-family:"Archivo";font-weight:800;font-size:clamp(28px,5vw,46px);line-height:1.04;letter-spacing:-.02em;color:var(--text)}
.h2-inv{color:#fff}
.lead{font-size:clamp(17px,2.3vw,20px);line-height:1.55;color:var(--text);font-weight:500;margin-top:18px}
.lead-inv{color:var(--inv)}
.body{color:var(--text-2);margin-top:16px;font-size:16.5px}

.section{padding:clamp(64px,9vw,118px) 0}
.sec-head{max-width:680px;margin-bottom:clamp(36px,5vw,56px)}
.sec-head-row{max-width:none;display:flex;flex-wrap:wrap;gap:24px;align-items:flex-end;justify-content:space-between}
.sec-note{color:var(--inv-2);font-size:14.5px;line-height:1.6;text-align:left}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;background:var(--ink);color:#fff;padding-top:120px;padding-bottom:clamp(50px,7vw,80px);overflow:hidden}
.hero-grid-bg{position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 78%);
  -webkit-mask-image:radial-gradient(120% 90% at 70% 0%,#000 30%,transparent 78%)}
.hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--blue),var(--red),transparent);opacity:.6}
.hero-inner{position:relative;z-index:2;display:grid;gap:clamp(36px,5vw,56px)}
.hero-title{font-family:"Archivo";font-weight:900;font-size:clamp(31px,6.2vw,49px);line-height:1.02;letter-spacing:-.03em;margin-bottom:16px}
.hero-title em{font-style:normal;color:var(--blue-bright);position:relative}
.hero-sub{font-size:clamp(15.5px,2vw,18px);line-height:1.55;color:var(--inv);max-width:500px;font-weight:500}
.hero-sub strong{color:#fff;font-weight:700}
.hero-chips{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.hero-chips li{font-size:12.5px;font-weight:600;color:var(--inv);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.13);padding:7px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:7px}
.hero-chips li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--blue-bright)}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.hero-trust{display:flex;align-items:center;flex-wrap:wrap;gap:9px;margin-top:22px;color:var(--inv-2);font-size:14px;font-weight:500}
.hero-trust strong{color:#fff}
.hero-trust .stars,.stars{color:#FBBF24;letter-spacing:2px;font-size:15px}
.hero-trust .sep{opacity:.4}
.hero-tel{color:#fff;font-weight:700;border-bottom:1px solid rgba(255,255,255,.28)}
.hero-tel:hover{color:var(--blue-bright)}

.hero-media{position:relative}
.hero-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 40px 90px -40px rgba(0,0,0,.9);aspect-ratio:4/3}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:50% 62%}
.photo-tag{position:absolute;left:14px;bottom:14px;background:rgba(18,19,22,.7);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.14);color:#fff;font-size:12px;font-weight:600;letter-spacing:.04em;padding:7px 12px;border-radius:9px}
.float-card{position:absolute;right:-6px;bottom:-18px;max-width:248px;background:var(--paper-2);color:var(--text);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);border:1px solid var(--line)}
.fc-quote{display:block;font-weight:600;font-size:14px;line-height:1.4;color:var(--text)}
.fc-by{display:flex;align-items:center;gap:7px;margin-top:9px;font-size:11.5px;color:var(--text-2);font-weight:600}
.fc-stars{color:#FBBF24;letter-spacing:1px}

/* hero — rail derniers véhicules */
.hero-rail{position:relative;z-index:2;margin-top:clamp(30px,5vw,42px);padding-top:22px;border-top:1px solid var(--ink-3);display:flex;flex-direction:column;gap:14px}
.rail-label{font-family:"Archivo";font-weight:800;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--inv-2);line-height:1.35}
.rail-br{display:none}
.rail-track{display:flex;gap:11px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.rail-track::-webkit-scrollbar{display:none}
.rail-track>a{flex:0 0 auto;width:142px;position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--ink-3);background:var(--ink-2)}
.rail-track>a img{width:100%;height:88px;object-fit:cover;transition:transform .5s var(--ease)}
.rail-track>a:hover img{transform:scale(1.07)}
.rail-track>a>span{position:absolute;left:0;right:0;bottom:0;padding:16px 10px 7px;font-size:12px;font-weight:700;color:#fff;background:linear-gradient(to top,rgba(8,9,12,.9),transparent)}
.rail-all{flex:0 0 auto;display:inline-flex;align-items:center;padding:0 6px;font-weight:700;font-size:13.5px;color:var(--blue-bright);white-space:nowrap}
.rail-all:hover{color:#fff}

/* =========================================================
   TRUST STRIP
   ========================================================= */
.strip{background:var(--ink-2);border-top:1px solid var(--ink-3);border-bottom:1px solid var(--ink-3)}
.strip-inner{display:grid;grid-template-columns:1fr;gap:0}
.strip-item{display:flex;align-items:center;gap:13px;padding:18px 4px;color:var(--inv);font-size:14.5px;font-weight:500;border-bottom:1px solid var(--ink-3)}
.strip-item:last-child{border-bottom:none}
.strip-item strong{color:#fff;font-weight:700}
.strip-item .ico{width:24px;height:24px;stroke:var(--blue-bright);flex:0 0 auto}

/* =========================================================
   GARAGE (about)
   ========================================================= */
.garage{background:var(--paper)}
.two-col{display:grid;gap:clamp(34px,5vw,60px);align-items:center}
.col-media{position:relative}
.framed{border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:3/4;background:#ddd}
.framed img{width:100%;height:100%;object-fit:cover}
.badge-stat{position:absolute;right:-8px;bottom:-18px;background:var(--ink);color:#fff;border-radius:16px;padding:16px 20px;text-align:center;box-shadow:var(--shadow)}
.badge-stat .bs-num{display:block;font-family:"Archivo";font-weight:900;font-size:26px;color:var(--blue-bright);line-height:1}
.badge-stat .bs-lbl{display:block;font-size:11.5px;color:var(--inv-2);font-weight:600;margin-top:5px;letter-spacing:.02em}
.pillars{list-style:none;margin:26px 0 30px;display:flex;flex-direction:column;gap:16px}
.pillars li{display:flex;gap:13px;align-items:flex-start}
.pillars .ico{width:24px;height:24px;stroke:var(--blue);background:rgba(44,143,212,.1);border-radius:7px;padding:3px;flex:0 0 auto;stroke-width:2.4}
.pillars strong{display:block;font-weight:700;font-size:16px}
.pillars span{color:var(--text-2);font-size:14.5px}

/* =========================================================
   SERVICES
   ========================================================= */
.services{background:var(--paper-2)}
.svc-grid{display:grid;grid-template-columns:1fr;gap:14px}
.svc{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;overflow:hidden;transition:.3s var(--ease)}
.svc::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);transform:scaleY(0);transform-origin:top;transition:transform .35s var(--ease)}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.svc:hover::before{transform:scaleY(1)}
.svc-no{font-family:"Archivo";font-weight:800;font-size:13px;color:var(--text-2);letter-spacing:.1em;position:absolute;top:24px;right:24px;opacity:.5}
.svc-ico{width:38px;height:38px;fill:none;stroke:var(--blue);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;margin-bottom:18px}
.svc h3{font-family:"Archivo";font-weight:800;font-size:20px;letter-spacing:-.01em;margin-bottom:9px}
.svc p{color:var(--text-2);font-size:15px;line-height:1.55}

/* =========================================================
   VEHICULES (gallery)
   ========================================================= */
.vehicles{background:var(--ink);color:#fff}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;grid-auto-flow:dense}
.g-item{position:relative;border-radius:var(--r);overflow:hidden;cursor:pointer;background:var(--ink-2);border:1px solid var(--ink-3);aspect-ratio:1/1}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.g-item:hover img{transform:scale(1.06)}
.g-item figcaption{position:absolute;left:0;right:0;bottom:0;padding:34px 16px 14px;display:flex;flex-direction:column;gap:2px;background:linear-gradient(to top,rgba(10,11,14,.86),transparent);opacity:0;transform:translateY(8px);transition:.35s var(--ease)}
.g-item:hover figcaption{opacity:1;transform:translateY(0)}
.g-name{font-family:"Archivo";font-weight:800;font-size:16px;color:#fff}
.g-meta{font-size:12.5px;color:var(--inv-2);font-weight:600}
.g-tall{grid-row:span 2;aspect-ratio:1/2}
.g-cta{margin-top:32px;display:flex;flex-direction:column;gap:16px;align-items:flex-start;padding:26px;background:var(--ink-2);border:1px solid var(--ink-3);border-radius:var(--r-lg)}
.g-cta p{font-family:"Archivo";font-weight:800;font-size:clamp(19px,3vw,26px);letter-spacing:-.01em}

/* =========================================================
   REVIEWS
   ========================================================= */
.reviews{background:var(--paper)}
.rev-layout{display:grid;gap:24px}
.rev-score{background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:34px 30px;display:flex;flex-direction:column;gap:4px;align-items:flex-start;align-self:start}
.rs-num{font-family:"Archivo";font-weight:900;font-size:62px;line-height:1;color:#fff}
.rs-stars{color:#FBBF24;font-size:22px;letter-spacing:3px;margin-top:6px}
.rs-meta{color:var(--inv);font-weight:600;margin-top:6px}
.rs-tag{color:var(--inv-2);font-size:13px;margin-top:14px;line-height:1.5}
.rev-grid{display:grid;grid-template-columns:1fr;gap:14px}
.rev{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:24px;display:flex;flex-direction:column;gap:12px}
.rev-stars{color:#FBBF24;font-size:15px;letter-spacing:2px}
.rev p{font-size:15.5px;line-height:1.6;color:var(--text)}
.rev cite{font-style:normal;font-weight:700;font-size:14.5px;color:var(--text)}
.rev cite span{color:var(--text-2);font-weight:500}

/* =========================================================
   CONTACT
   ========================================================= */
.contact{background:var(--ink);color:#fff}
.contact-grid{align-items:start}
.form{margin-top:26px;display:flex;flex-direction:column;gap:14px}
.f-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form label{display:flex;flex-direction:column;gap:7px;font-size:13px;font-weight:600;color:var(--inv-2);letter-spacing:.02em}
.form input,.form select,.form textarea{font-family:inherit;font-size:15.5px;color:#fff;background:var(--ink-2);border:1.5px solid var(--ink-3);border-radius:11px;padding:13px 15px;transition:.2s;font-weight:500}
.form textarea{resize:vertical}
.form input::placeholder,.form textarea::placeholder{color:#6a707b}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--blue);background:#16181d}
.form select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23A4AAB4' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.form-note{font-size:12.5px;color:var(--inv-2);text-align:center;font-weight:500}
.form.sent{opacity:.5;pointer-events:none}

.contact-info{display:flex;flex-direction:column;gap:16px}
.ci-card{background:var(--ink-2);border:1px solid var(--ink-3);border-radius:var(--r-lg);padding:28px}
.ci-card h3{font-family:"Archivo";font-weight:800;font-size:19px;margin-bottom:18px}
.ci-list{list-style:none;display:flex;flex-direction:column;gap:18px;margin-bottom:22px}
.ci-list li{display:flex;gap:14px;align-items:flex-start}
.ci-list .ico{width:22px;height:22px;stroke:var(--blue-bright);flex:0 0 auto;margin-top:2px}
.ci-list strong{display:block;font-weight:700;font-size:16px;color:#fff}
.ci-list span{font-size:13.5px;color:var(--inv-2)}
.ci-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ci-actions .btn-line{color:#fff;border-color:rgba(255,255,255,.25)}
.ci-actions .btn-line:hover{background:#fff;color:var(--ink)}
.ci-map{display:block;position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--ink-3);height:230px}
.ci-map img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.ci-map:hover img{transform:scale(1.04)}
.map-link{position:absolute;right:12px;bottom:12px;background:var(--blue);color:#fff;font-weight:700;font-size:13px;padding:9px 14px;border-radius:9px;box-shadow:var(--shadow)}
.map-link:hover{background:var(--blue-deep)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-foot{background:#0F1013;color:var(--inv);padding:clamp(48px,7vw,72px) 0 28px}
.foot-inner{display:grid;grid-template-columns:1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.brand-foot .brand-word{color:#fff;font-size:17px}
.foot-brand p{margin-top:16px;color:var(--inv-2);font-size:14px;line-height:1.65;max-width:380px}
.foot-nav{display:flex;flex-direction:column;gap:11px}
.foot-nav h4{font-family:"Archivo";font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:#fff;margin-bottom:5px}
.foot-nav a{color:var(--inv-2);font-size:14.5px;transition:.2s}
.foot-nav a:hover{color:var(--blue-bright)}
.foot-bottom{display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding-top:24px;color:var(--inv-2);font-size:13px}

/* =========================================================
   MOBILE STICKY BAR
   ========================================================= */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--ink-3);border-top:1px solid var(--ink-3);box-shadow:0 -8px 24px -12px rgba(0,0,0,.5)}
.mobile-bar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:9px 4px;background:var(--ink);color:#fff;font-size:11.5px;font-weight:700}
.mobile-bar a .ico{width:19px;height:19px}
.mobile-bar .mb-wa{background:#1f8f4e}
.mobile-bar .mb-primary{background:var(--blue);font-size:13.5px}

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(8,9,12,.94);display:none;align-items:center;justify-content:center;padding:20px}
.lightbox.open{display:flex}
.lightbox figure{max-width:min(900px,92vw);max-height:86vh;display:flex;flex-direction:column;gap:10px}
.lightbox img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:12px}
.lightbox figcaption{color:#fff;text-align:center;font-weight:600;font-size:14px}
.lb-close{position:absolute;top:18px;right:20px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:18px;cursor:pointer}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:28px;line-height:1;cursor:pointer}
.lb-prev{left:14px}.lb-next{right:14px}
.lb-close:hover,.lb-nav:hover{background:var(--blue)}

/* =========================================================
   REVEAL ANIM
   ========================================================= */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto}}

/* =========================================================
   RESPONSIVE — tablette / desktop
   ========================================================= */
@media(min-width:640px){
  .strip-inner{grid-template-columns:1fr 1fr}
  .strip-item{border-bottom:1px solid var(--ink-3)}
  .strip-item:nth-child(2n){border-right:none}
  .svc-grid{grid-template-columns:1fr 1fr}
  .rev-grid{grid-template-columns:1fr 1fr}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .g-wide{grid-column:span 2;aspect-ratio:auto}
}

@media(min-width:900px){
  body{font-size:17px}
  .burger,.mobile-menu,.mobile-bar{display:none}
  .nav{display:flex}
  .head-cta{display:flex}
  .hero{padding-top:138px;padding-bottom:46px}
  .hero-inner{grid-template-columns:1.08fr .92fr;align-items:center;gap:clamp(40px,5vw,66px)}
  .hero-photo{aspect-ratio:4/3;max-height:460px}
  .hero-rail{flex-direction:row;align-items:center;gap:26px}
  .rail-label{flex:0 0 auto}
  .rail-br{display:block}
  .rail-track{flex:1;min-width:0}
  .strip-inner{grid-template-columns:repeat(4,1fr)}
  .strip-item{border-bottom:none;border-right:1px solid var(--ink-3);padding:24px;justify-content:center;text-align:left}
  .strip-item:last-child{border-right:none}
  .two-col{grid-template-columns:1fr 1fr}
  .garage .two-col{grid-template-columns:.85fr 1.15fr}
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .gallery{grid-template-columns:repeat(4,1fr);gap:14px}
  .g-cta{flex-direction:row;align-items:center;justify-content:space-between;padding:30px 38px}
  .rev-layout{grid-template-columns:.62fr 1.38fr;gap:28px}
  .rev-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1.1fr .9fr;gap:clamp(34px,4vw,56px)}
  .foot-inner{grid-template-columns:2fr 1fr 1fr;gap:48px}
  .f-row{grid-template-columns:1fr 1fr}
}

@media(min-width:1100px){
  .hero-title{font-size:clamp(44px,4vw,56px)}
  .g-tall{aspect-ratio:auto;grid-row:span 2}
}
