/* ══════════════════════════════════════════
   LocationVoitureMar.com — Shared Stylesheet
   Multi-page · Mobile-first · rentalcars-inspired
══════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none}
input,select,textarea{font-family:inherit}

:root{
  --blue:#003580;--blue2:#0071c2;--blue3:#006ce4;
  --sky:#f0f6ff;--sky2:#e1edff;
  --white:#fff;--off:#f4f6f9;
  --ink:#1a1a2e;--ink2:#2c3453;--mid:#4a5568;
  --gray:#6b7280;--gray2:#9ca3af;
  --border:#d1d9e6;--border2:#e8ecf4;
  --green:#047857;--amber:#f59e0b;--red:#dc2626;
  --ff:'Outfit',sans-serif;
  --r-sm:8px;--r:12px;--r-lg:16px;--r-xl:22px;--r-2xl:32px;
  --sh-sm:0 1px 4px rgba(0,0,0,.07);--sh:0 4px 20px rgba(0,0,0,.1);--sh-lg:0 16px 48px rgba(0,0,0,.14);
  --ease:cubic-bezier(.4,0,.2,1);--spring:cubic-bezier(.34,1.56,.64,1);
}
body{font-family:var(--ff);background:var(--off);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}

/* ── ANNOUNCE BAR ── */
.ann{background:var(--blue);padding:.45rem 1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.4rem}
.ann p{font-size:.78rem;color:rgba(255,255,255,.85)}
.ann a{color:#fcd34d;font-weight:700}
.ann strong{color:#fff}

/* ── HEADER ── */
header{background:var(--blue);position:sticky;top:0;z-index:900;box-shadow:0 2px 20px rgba(0,0,40,.3)}
.nav{max-width:1280px;margin:0 auto;padding:0 1.5rem;height:64px;display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.logo{font-size:1.2rem;font-weight:900;color:#fff;cursor:pointer;letter-spacing:-.02em;line-height:1.2;white-space:nowrap;flex-shrink:0}
.logo span{color:#fcd34d}.logo small{display:block;font-size:.6rem;font-weight:400;opacity:.7}
.nav-links{display:flex;list-style:none;gap:.1rem;align-items:center;flex:1;justify-content:center}
.nav-links a{color:rgba(255,255,255,.82);font-size:.84rem;font-weight:500;padding:.42rem .75rem;border-radius:var(--r-sm);transition:all .2s;white-space:nowrap}
.nav-links a:hover,.nav-links a.act{background:rgba(255,255,255,.16);color:#fff}
.nav-r{display:flex;gap:.5rem;align-items:center;flex-shrink:0}
.btn-wa-h{background:#25d366;color:#fff;padding:.48rem .95rem;border-radius:var(--r-sm);font-weight:700;font-size:.8rem;display:flex;align-items:center;gap:.3rem;transition:all .2s;white-space:nowrap}
.btn-wa-h:hover{background:#1ebe5d;transform:translateY(-1px)}
.ham{display:none;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.2);border-radius:var(--r-sm);color:#fff;font-size:1.25rem;line-height:1;padding:.38rem .55rem;flex-shrink:0}

/* ── MOBILE DRAWER ── */
.drawer{display:none;position:fixed;inset:0;background:#0d1117;z-index:9999;flex-direction:column;align-items:center;justify-content:center;padding:4.5rem 2rem 3rem;overflow-y:auto}
.drawer.open{display:flex}
.drawer-logo{font-size:1.4rem;font-weight:900;color:#fff;margin-bottom:2.5rem}
.drawer-logo span{color:#fcd34d}
.drawer nav{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:300px}
.drawer nav a{font-size:1rem;font-weight:600;color:rgba(255,255,255,.85);padding:.82rem 1.25rem;border-radius:var(--r);border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.05);text-align:center}
.drawer nav a:hover{background:rgba(255,255,255,.12)}
.drawer-divider{width:100%;max-width:300px;height:1px;background:rgba(255,255,255,.1);margin:1.5rem 0 1.25rem}
.drawer-wa{display:block;width:100%;max-width:300px;background:#25d366;color:#fff;padding:.88rem;border-radius:var(--r);font-size:.92rem;font-weight:700;text-align:center}
.dr-close{position:absolute;top:1.25rem;right:1.25rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:50%;color:#fff;font-size:1.1rem;width:38px;height:38px;display:flex;align-items:center;justify-content:center}

/* ── HERO ── */
.hero{background:#002468;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:url('/images/location-voiture-fes-hero.webp') center/cover;opacity:.5;z-index:0}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(140deg,rgba(0,36,104,.85) 0%,rgba(0,53,128,.72) 45%,rgba(0,82,204,.62) 100%);z-index:0}
.hero-inner{max-width:1280px;margin:0 auto;padding:4.5rem 1.5rem;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:.45rem;background:rgba(252,211,77,.15);border:1px solid rgba(252,211,77,.4);color:#fcd34d;font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .85rem;border-radius:100px;margin-bottom:1.25rem}
.hero h1{font-size:clamp(1.9rem,4.2vw,3.1rem);font-weight:900;color:#fff;line-height:1.08;letter-spacing:-.03em;margin-bottom:.9rem;max-width:760px}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.78);margin-bottom:1.75rem;font-weight:300;max-width:580px}
.hero-pills{display:flex;gap:.55rem;flex-wrap:wrap;margin-bottom:2rem}
.h-pill{display:flex;align-items:center;gap:.35rem;background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:.78rem;font-weight:500;padding:.34rem .82rem;border-radius:100px}
.hero-cta{display:flex;gap:.7rem;flex-wrap:wrap}
.btn-primary{background:#25d366;color:#fff;padding:.9rem 1.8rem;border-radius:var(--r);font-size:.97rem;font-weight:800;transition:all .2s}
.btn-primary:hover{background:#1ebe5d;transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.13);border:2px solid rgba(255,255,255,.3);color:#fff;padding:.86rem 1.8rem;border-radius:var(--r);font-size:.95rem;font-weight:700;transition:all .2s}
.btn-ghost:hover{background:rgba(255,255,255,.22)}

/* ── PAGE HERO (inner pages) ── */
.page-hero{background:linear-gradient(135deg,var(--blue) 0%,#0052b3 100%);padding:2.75rem 1.5rem;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;inset:0;background:url('/images/location-voiture-fes-hero.webp') center/cover;opacity:.07}
.ph-in{max-width:1280px;margin:0 auto;position:relative;z-index:1}
.ph-in h1{font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:900;color:#fff;letter-spacing:-.03em;margin-bottom:.5rem}
.ph-in p{font-size:.97rem;color:rgba(255,255,255,.72);max-width:600px}

/* ── BREADCRUMB ── */
.breadcrumb{background:#fff;border-bottom:1px solid var(--border2);padding:.7rem 0}
.bc-row{max-width:1280px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--gray);flex-wrap:wrap}
.bc-row a{color:var(--blue3)}
.bc-row a:hover{text-decoration:underline}
.bc-sep{color:var(--gray2)}

/* ── CONTAINER / SECTIONS ── */
.container{max-width:1280px;margin:0 auto;padding:0 1.5rem}
.sec{padding:4rem 0}
.sec-sm{padding:2.5rem 0}
.eyebrow{font-size:.7rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--blue3);display:flex;align-items:center;gap:.45rem;margin-bottom:.55rem}
.eyebrow::before{content:'';width:16px;height:2px;background:var(--blue3)}
.sec-h{font-size:clamp(1.45rem,2.8vw,2.1rem);font-weight:900;color:var(--ink);letter-spacing:-.03em;margin-bottom:.6rem;line-height:1.1}
.sec-p{font-size:.95rem;color:var(--mid);max-width:600px}
.sec-head{margin-bottom:2.5rem}
.sec-c{text-align:center}.sec-c .eyebrow{justify-content:center}.sec-c .sec-p{margin:0 auto}

/* ── TRUST BAR ── */
.trust{background:#fff;border-bottom:1px solid var(--border2)}
.trust-inner{max-width:1280px;margin:0 auto;padding:1.2rem 1.5rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem}
.t-item{display:flex;align-items:center;gap:.62rem;padding:.3rem .6rem}
.t-ico{font-size:1.3rem}
.t-title{font-size:.86rem;font-weight:700;color:var(--ink)}
.t-sub{font-size:.74rem;color:var(--gray)}

/* ── CAR GRID ── */
.cars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.car-card{background:#fff;border-radius:var(--r-xl);border:1.5px solid var(--border2);overflow:hidden;transition:all .28s var(--ease);display:flex;flex-direction:column}
.car-card:hover{border-color:var(--blue3);box-shadow:var(--sh-lg);transform:translateY(-5px)}
.cc-img{position:relative;height:200px;overflow:hidden;background:linear-gradient(145deg,#e8f0f8,#d2e3f0)}
.cc-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.car-card:hover .cc-img img{transform:scale(1.06)}
.cc-type{position:absolute;top:.7rem;left:.7rem;font-size:.66rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:.25rem .66rem;border-radius:100px;color:#fff;background:var(--blue2)}
.cc-body{padding:1.15rem;flex:1;display:flex;flex-direction:column}
.cc-brand{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--gray2);margin-bottom:.14rem}
.cc-name{font-size:1.15rem;font-weight:900;color:var(--ink);letter-spacing:-.02em;margin-bottom:.42rem}
.cc-desc{font-size:.82rem;color:var(--mid);margin-bottom:.85rem;flex:1}
.cc-specs{display:grid;grid-template-columns:repeat(4,1fr);gap:.32rem;padding:.8rem 0;border-top:1px solid var(--border2);border-bottom:1px solid var(--border2);margin-bottom:.85rem}
.sp-v{display:block;font-size:.76rem;font-weight:700;color:var(--ink);text-align:center}
.sp-k{display:block;font-size:.6rem;color:var(--gray2);text-transform:uppercase;text-align:center}
.cc-foot{display:flex;align-items:center;justify-content:space-between}
.price-r{font-size:1.2rem;font-weight:900;color:var(--blue);line-height:1}
.price-n{font-size:.67rem;color:var(--gray)}
.btn-det{background:var(--blue3);color:#fff;padding:.56rem 1.05rem;border-radius:var(--r-sm);font-size:.8rem;font-weight:700;transition:all .2s}
.btn-det:hover{background:var(--blue)}

/* ── CAR DETAIL ── */
.det-grid{display:grid;grid-template-columns:1fr 370px;gap:2rem;align-items:start}
.det-img{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--border2)}
.det-img img{width:100%;height:380px;object-fit:cover}
.det-specs{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-top:1.4rem}
.dsp{background:var(--sky);border-radius:var(--r-lg);padding:.9rem 1.05rem;display:flex;align-items:center;gap:.7rem}
.dsp-ico{font-size:1.25rem}
.dsp-lbl{font-size:.66rem;text-transform:uppercase;letter-spacing:.07em;color:var(--gray)}
.dsp-val{font-size:.92rem;font-weight:700;color:var(--ink)}
.det-aside{background:#fff;border-radius:var(--r-xl);border:1.5px solid var(--border2);padding:1.65rem;position:sticky;top:80px;box-shadow:var(--sh)}
.aside-price{font-size:1.95rem;font-weight:900;color:var(--blue);letter-spacing:-.03em;line-height:1}
.aside-per{font-size:.78rem;color:var(--gray);margin:.16rem 0 1.1rem}
.incl-item{display:flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--ink);margin-bottom:.42rem}
.incl-item::before{content:'✓';color:var(--green);font-weight:800}
.btn-wa-aside{width:100%;background:#25d366;color:#fff;padding:.95rem;border-radius:var(--r);font-size:.97rem;font-weight:800;display:block;text-align:center;transition:all .2s;margin-top:.75rem}
.btn-wa-aside:hover{background:#1ebe5d}
.btn-res-aside{width:100%;background:var(--blue3);color:#fff;padding:.95rem;border-radius:var(--r);font-size:.97rem;font-weight:800;display:block;text-align:center;transition:all .2s;margin-top:.6rem}
.btn-res-aside:hover{background:var(--blue)}

/* ── SEO CONTENT ── */
.seo-box{background:#fff;border-radius:var(--r-xl);border:1.5px solid var(--border2);padding:2.25rem}
.seo-box h2{font-size:1.35rem;font-weight:900;color:var(--ink);margin:1.4rem 0 .85rem;letter-spacing:-.02em}
.seo-box h2:first-child{margin-top:0}
.seo-box h3{font-size:1.05rem;font-weight:700;color:var(--blue);margin:1.3rem 0 .45rem}
.seo-box p{font-size:.94rem;color:var(--ink2);line-height:1.8;margin-bottom:.7rem}
.seo-box ul{margin:0 0 .8rem 1.4rem}
.seo-box li{font-size:.94rem;color:var(--ink2);line-height:1.75;margin-bottom:.35rem}
.seo-box a{color:var(--blue3);font-weight:600;text-decoration:underline}
.internal-links{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.internal-links a{background:var(--sky);border:1px solid var(--sky2);color:var(--blue);padding:.5rem 1rem;border-radius:100px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s}
.internal-links a:hover{background:var(--blue3);color:#fff}

/* ── REVIEWS ── */
.rev-box{background:#fff;border-radius:var(--r-xl);border:1.5px solid var(--border2);padding:2.25rem}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:1.5rem}
.rc{background:var(--off);border-radius:var(--r-lg);padding:1.2rem;border:1px solid var(--border2)}
.rc-stars{color:var(--amber);font-size:.86rem;margin-bottom:.55rem}
.rc-text{font-size:.84rem;color:var(--ink2);line-height:1.65;margin-bottom:.82rem;font-style:italic}
.rc-author{display:flex;align-items:center;gap:.55rem}
.rc-av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--blue3),var(--blue));color:#fff;font-weight:800;font-size:.78rem;display:flex;align-items:center;justify-content:center}
.rc-name{font-size:.82rem;font-weight:700;color:var(--ink)}
.rc-loc{font-size:.71rem;color:var(--gray)}
.rev-summary{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.rev-big{font-size:3.4rem;font-weight:900;color:var(--ink);line-height:1}

/* ── FAQ ── */
.faq-list{display:flex;flex-direction:column;gap:.55rem;max-width:840px;margin:0 auto}
.faq-item{background:#fff;border:1.5px solid var(--border2);border-radius:var(--r-lg);overflow:hidden}
.faq-q{padding:1.05rem 1.25rem;font-weight:700;font-size:.93rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:.75rem;color:var(--ink)}
.faq-ico{font-size:1.1rem;color:var(--gray2);transition:transform .25s}
.faq-item.open .faq-ico{transform:rotate(45deg);color:var(--blue3)}
.faq-a{max-height:0;overflow:hidden;font-size:.88rem;color:var(--mid);line-height:1.78;padding:0 1.25rem;transition:max-height .3s,padding .3s}
.faq-item.open .faq-a{max-height:600px;padding:0 1.25rem 1.05rem}

/* ── FORMS ── */
.form-box{background:#fff;border-radius:var(--r-xl);border:1.5px solid var(--border2);padding:2rem}
.fg-c{margin-bottom:1.1rem}
.fg-c label{display:block;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.09em;color:var(--gray);margin-bottom:.36rem}
.fg-c input,.fg-c select,.fg-c textarea{width:100%;padding:.75rem .95rem;border:1.5px solid var(--border);border-radius:var(--r);font-size:.9rem;color:var(--ink);transition:border-color .2s;background:#fff}
.fg-c input:focus,.fg-c select:focus,.fg-c textarea:focus{outline:none;border-color:var(--blue3);box-shadow:0 0 0 3px rgba(0,108,228,.1)}
.fg-c textarea{resize:vertical;min-height:108px}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.btn-submit{width:100%;background:var(--blue3);color:#fff;padding:.92rem;border-radius:var(--r);font-size:.97rem;font-weight:800;transition:all .2s;margin-top:.45rem}
.btn-submit:hover{background:var(--blue)}
.contact-grid{display:grid;grid-template-columns:1fr 355px;gap:2.5rem;align-items:start}
.contact-info{background:var(--ink);border-radius:var(--r-xl);padding:1.95rem;color:#fff;position:sticky;top:80px}
.contact-info h3{font-size:1.3rem;font-weight:900;margin-bottom:.38rem}
.contact-info p{font-size:.86rem;color:rgba(255,255,255,.6);margin-bottom:1.65rem}
.ci-row{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:1.4rem}
.ci-ico{width:38px;height:38px;border-radius:var(--r-sm);background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:1.05rem;flex-shrink:0}
.ci-lbl{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.4)}
.ci-val{font-size:.9rem;font-weight:600;color:#fff}
.ci-val a{color:#fff}
.btn-wa-ci{width:100%;background:#25d366;color:#fff;padding:.88rem;border-radius:var(--r);font-size:.93rem;font-weight:800;display:block;text-align:center;margin-top:1.4rem}
.form-ok{display:none;align-items:center;gap:.6rem;background:#ecfdf5;border:1.5px solid #6ee7b7;border-radius:var(--r);padding:.9rem 1.1rem;margin-top:.85rem;font-size:.88rem;font-weight:600;color:#065f46}
.form-ok.show{display:flex}

/* ── PRICE TABLE ── */
.price-table{background:#fff;border-radius:var(--r-xl);border:1.5px solid var(--border2);overflow:hidden;margin-bottom:1.2rem}
.pt-head{background:var(--ink);color:#fff;padding:1.05rem 1.3rem;font-size:.97rem;font-weight:800}
.pt-row{display:flex;justify-content:space-between;padding:.82rem 1.3rem;border-top:1px solid var(--border2);font-size:.86rem}
.pt-name{font-weight:600;color:var(--ink)}
.pt-price{font-weight:800;color:var(--blue)}
.pt-note{background:var(--sky);padding:.82rem 1.3rem;font-size:.76rem;color:var(--mid);border-top:1px solid var(--border2)}

/* ── CTA BANNER ── */
.cta-box{background:linear-gradient(135deg,var(--blue) 0%,var(--blue3) 100%);border-radius:var(--r-xl);padding:2.5rem;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap}
.cta-box h3{font-size:1.35rem;font-weight:900;color:#fff;margin-bottom:.3rem}
.cta-box p{font-size:.9rem;color:rgba(255,255,255,.73)}
.cta-btns{display:flex;gap:.65rem;flex-wrap:wrap}

/* ── FOOTER ── */
footer{background:var(--ink);color:#fff;padding:3.5rem 0 0;margin-top:3rem}
.footer-grid{max-width:1280px;margin:0 auto;padding:0 1.5rem 2.85rem;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.2rem}
.f-logo{font-size:1.3rem;font-weight:900;color:#fff;margin-bottom:1rem;display:block}
.f-logo span{color:var(--amber)}
.f-desc{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.75;max-width:260px;margin-bottom:1.4rem}
.f-col-h{font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.37);margin-bottom:.95rem}
.f-link{display:block;font-size:.84rem;color:rgba(255,255,255,.6);margin-bottom:.52rem;transition:color .2s}
.f-link:hover{color:#fff}
.f-ci{display:flex;align-items:flex-start;gap:.55rem;margin-bottom:.78rem}
.f-ci span{font-size:.84rem;color:rgba(255,255,255,.6);line-height:1.5}
.f-ci strong{color:#fff}
.footer-bar{border-top:1px solid rgba(255,255,255,.07);padding:1.2rem 1.5rem;max-width:1280px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:.65rem;flex-wrap:wrap;font-size:.78rem;color:rgba(255,255,255,.37)}
.footer-bar a{color:rgba(255,255,255,.37)}
.footer-bar a:hover{color:rgba(255,255,255,.7)}

/* ── FLOATING WA ── */
.wa-float{position:fixed;bottom:1.75rem;right:1.75rem;z-index:800;width:58px;height:58px;background:#25d366;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 6px 30px rgba(37,211,102,.55);transition:all .3s var(--spring)}
.wa-float:hover{transform:scale(1.12)}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .det-grid,.contact-grid{grid-template-columns:1fr}
  .cars-grid,.rev-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .det-aside,.contact-info{position:static}
}
@media(max-width:768px){
  .nav-links{display:none}
  .ham{display:flex}
  .cars-grid,.rev-grid{grid-template-columns:1fr}
  .fg-row{grid-template-columns:1fr}
  .trust-inner{flex-direction:column;gap:.65rem}
  .footer-grid{grid-template-columns:1fr}
  .cta-box{flex-direction:column;text-align:center}
  .footer-bar{flex-direction:column;text-align:center;gap:.5rem}
  .btn-wa-h .wa-txt{display:none}
}
@media(max-width:480px){
  .sec{padding:2.5rem 0}
  .container{padding:0 1rem}
  .nav{padding:0 1rem}
  .hero-inner{padding:3rem 1rem}
  .logo small{display:none}
}
.price-eur{display:block;font-size:.72em;color:var(--gray);font-weight:600;white-space:nowrap;margin-top:.1rem}
.aside-price .price-eur{display:block;font-size:.42em;margin-top:.2rem;color:var(--gray)}
