/* ═══════════════════════════════════════════
   MRL PROD — style.css
   Covering & Protection · Alpes-Maritimes
   ═══════════════════════════════════════════ */
 
/* ── RESET & VARIABLES ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
 
:root{
  --black:#0a0a0a;
  --dark:#111114;
  --surface:#18181c;
  --violet:#6d28d9;
  --violet-bright:#8b5cf6;
  --violet-dark:#4c1d95;
  --muted:#8a8a9a;
  --white:#f4f3fa;
  --border:rgba(255,255,255,0.08);
  --text-body:rgba(255,255,255,0.72);
}
 
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--white);
  font-family:'Barlow',sans-serif;
  font-weight:400;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
 
/* ── NAVIGATION ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2.5rem;height:64px;
  background:rgba(10,10,10,0.97);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(12px);
}
.nav-logo{
  display:flex;align-items:center;gap:1rem;
  text-decoration:none;flex-shrink:0;
}
.nav-logo-img{height:100px;width:auto;object-fit:contain}
.nav-logo-name{
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;font-size:1.15rem;
  letter-spacing:0.18em;color:var(--white);text-transform:uppercase;
}
.nav-center{display:flex;align-items:center;flex:1;justify-content:center}
.nav-links{display:flex;align-items:center;list-style:none;gap:0}
.nav-links li a{
  color:var(--muted);text-decoration:none;
  font-size:0.6rem;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;
  padding:0 1rem;display:flex;align-items:center;height:64px;
  transition:color 0.2s;border-right:1px solid var(--border);
}
.nav-links li:first-child a{border-left:1px solid var(--border)}
.nav-links li.active a,
.nav-links li a:hover{color:var(--white)}
.nav-links li.active a{color:var(--violet-bright)}
.nav-phone{
  display:flex;align-items:center;gap:0.5rem;flex-shrink:0;
  background:var(--violet);color:#fff;
  font-size:0.72rem;font-weight:500;letter-spacing:0.05em;
  padding:0 1.2rem;height:64px;text-decoration:none;
  transition:background 0.2s;white-space:nowrap;
}
.nav-phone:hover{background:var(--violet-bright)}
.nav-phone svg{width:13px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
 
/* ── HERO ── */
.hero{
  position:relative;height:calc(100vh - 64px);min-height:580px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;margin-top:64px;text-align:center;
}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease}
.hero-slide.active{opacity:1}
.hero-slide img{width:100%;height:100%;object-fit:cover;filter:brightness(0.45)}
.hero-grad{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,0.97) 0%,rgba(10,10,10,0.3) 55%,rgba(10,10,10,0.08) 100%);
}
.hero-grad-v{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(109,40,217,0.18) 0%,transparent 55%);
}
.hero-inner{
  position:relative;z-index:10;width:100%;max-width:900px;
  padding:0 3rem;display:flex;flex-direction:column;align-items:center;gap:0;
}
.hero-eyebrow{
  font-size:0.65rem;letter-spacing:0.32em;text-transform:uppercase;
  color:var(--violet-bright);margin-bottom:1.25rem;
  display:flex;align-items:center;gap:0.75rem;
}
.hero-eyebrow::before,
.hero-eyebrow::after{content:'';width:24px;height:1px;background:var(--violet-bright)}
.hero-h1{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(3.5rem,8vw,7rem);
  line-height:0.9;letter-spacing:0.01em;text-transform:uppercase;
  color:var(--white);margin-bottom:1.5rem;
}
.hero-h1 .stroke{color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,0.25)}
.hero-desc{
  max-width:580px;font-size:1rem;line-height:1.8;
  color:rgba(255,255,255,0.62);margin-bottom:2rem;font-weight:300;
}
.hero-btns{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-stats{display:flex;justify-content:center;gap:4rem;margin-bottom:1.5rem}
.h-snum{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:2.8rem;color:var(--violet-bright);line-height:1;
}
.h-slbl{font-size:0.6rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);margin-top:0.2rem}
.hero-dots{display:flex;justify-content:center;gap:0.5rem}
.dot{
  width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.2);
  border:none;cursor:pointer;padding:0;transition:background 0.3s,transform 0.3s;
}
.dot.active{background:var(--violet-bright);transform:scale(1.5)}
 
/* ── BOUTONS ── */
.btn-vio{
  display:inline-flex;align-items:center;gap:0.6rem;
  background:var(--violet);color:#fff;
  padding:0.9rem 1.9rem;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:0.88rem;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;transition:background 0.2s;
}
.btn-vio:hover{background:var(--violet-bright)}
 
.btn-ol{
  display:inline-flex;align-items:center;gap:0.6rem;
  background:transparent;color:rgba(255,255,255,0.7);
  padding:0.9rem 1.9rem;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:0.88rem;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;border:1px solid rgba(255,255,255,0.2);
  transition:border-color 0.2s,color 0.2s;
}
.btn-ol:hover{border-color:var(--violet-bright);color:#fff}
 
.btn-wh{
  display:inline-flex;align-items:center;gap:0.65rem;
  background:#fff;color:var(--violet-dark);
  padding:0.9rem 1.9rem;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:0.85rem;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;white-space:nowrap;transition:background 0.2s;
}
.btn-wh:hover{background:#ede9fe}
.btn-wh svg{width:14px;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke:var(--violet-dark)}
 
.btn-wh-g{
  display:inline-flex;align-items:center;gap:0.65rem;
  background:rgba(255,255,255,0.1);color:#fff;
  padding:0.9rem 1.9rem;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:0.85rem;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;white-space:nowrap;
  border:1px solid rgba(255,255,255,0.25);transition:background 0.2s;
}
.btn-wh-g:hover{background:rgba(255,255,255,0.2)}
.btn-wh-g svg{width:14px;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke:#fff}
 
/* ── LABELS / TITRES SECTION ── */
.s-label{
  display:inline-flex;align-items:center;gap:0.7rem;
  font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--violet-bright);margin-bottom:0.6rem;
}
.s-label::before{content:'';width:18px;height:1px;background:var(--violet)}
 
.s-head{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(1.6rem,3vw,2.4rem);
  text-transform:uppercase;letter-spacing:0.05em;
  display:flex;align-items:center;gap:1.25rem;
  margin-bottom:0.75rem;color:var(--white);
}
.s-head-line{flex:1;height:1px;background:linear-gradient(to right,rgba(255,255,255,0.12),transparent)}
.s-head-arr{color:var(--muted);font-size:1.2rem}
.s-intro{font-size:0.92rem;color:var(--muted);margin-bottom:2.5rem;max-width:680px;line-height:1.85}
 
.section{padding:5.5rem 3rem}
 
/* ── DÉPLACEMENT BAND ── */
.deplace-band{
  background:var(--dark);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  display:grid;grid-template-columns:repeat(3,1fr);
}
.deplace-item{
  padding:2.2rem 2rem;border-right:1px solid var(--border);
  display:flex;align-items:flex-start;gap:1.1rem;
}
.deplace-item:last-child{border-right:none}
.deplace-icon{
  width:42px;height:42px;
  background:rgba(109,40,217,0.15);border:1px solid rgba(109,40,217,0.3);
  border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.deplace-icon svg{width:18px;stroke:var(--violet-bright);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.deplace-txt h3{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;
  font-size:1rem;letter-spacing:0.08em;text-transform:uppercase;
  color:var(--white);margin-bottom:0.25rem;
}
.deplace-txt p{font-size:0.8rem;color:var(--muted);line-height:1.6}
 
/* ── MARQUEE ── */
.marquee-bar{background:var(--violet);overflow:hidden;white-space:nowrap;padding:0.8rem 0}
.marquee-inner{
  display:inline-flex;gap:2.5rem;animation:marquee 22s linear infinite;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:0.82rem;letter-spacing:0.22em;color:rgba(255,255,255,0.85);text-transform:uppercase;
}
.msep{color:rgba(255,255,255,0.3)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
 
/* ── ARTISAN / À PROPOS ── */
.artisan-section{padding:5.5rem 3rem;background:var(--dark);border-top:1px solid var(--border)}
.artisan-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:center;max-width:1100px}
.artisan-visual{position:relative}
.artisan-img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:brightness(0.75) grayscale(10%)}
.artisan-badge{
  position:absolute;bottom:-1.5rem;right:-1.5rem;
  background:var(--violet);padding:1.4rem 1.6rem;text-align:center;
}
.ab-num{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:3rem;line-height:1;color:#fff}
.ab-txt{font-size:0.58rem;letter-spacing:0.22em;text-transform:uppercase;color:rgba(255,255,255,0.65);margin-top:0.3rem}
.artisan-text h2{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(2rem,3.2vw,2.8rem);text-transform:uppercase;
  line-height:0.95;margin-bottom:1.5rem;margin-top:0.5rem;
}
.artisan-text p{font-size:0.9rem;line-height:1.9;color:var(--text-body);margin-bottom:1rem}
.artisan-text p strong{color:rgba(255,255,255,0.92);font-weight:500}
 
/* ── VÉHICULES GRID ── */
.vehicules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin:2rem 0}
.vehicule-card{
  padding:1.8rem 1.5rem;background:var(--surface);
  border:1px solid var(--border);text-align:center;
  transition:border-color 0.25s,background 0.25s;cursor:default;
}
.vehicule-card:hover{border-color:var(--violet);background:rgba(109,40,217,0.08)}
.vehicule-icon{font-size:2rem;margin-bottom:0.75rem;display:block}
.vehicule-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:800;
  font-size:1rem;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--white);margin-bottom:0.35rem;
}
.vehicule-eg{font-size:0.72rem;color:var(--muted);line-height:1.5}
 
/* ── PRESTATIONS ── */
.prestations-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:repeat(2,220px);
  gap:3px;
}
.presta-card{position:relative;overflow:hidden;cursor:pointer;text-decoration:none;display:block}
.presta-card img{
  width:100%;height:100%;object-fit:cover;display:block;
  filter:brightness(0.42) grayscale(0.1);
  transition:transform 0.65s ease,filter 0.4s ease;
}
.presta-card:hover img{transform:scale(1.08);filter:brightness(0.28) grayscale(0)}
.presta-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,0.92) 0%,transparent 60%);
  transition:background 0.4s;
}
.presta-card:hover .presta-ov{
  background:linear-gradient(to top,rgba(76,29,149,0.94) 0%,rgba(109,40,217,0.38) 65%,transparent 100%);
}
.presta-card.featured::after{
  content:'★ POPULAIRE';position:absolute;top:1rem;left:1rem;
  background:var(--violet);color:#fff;
  font-family:'Barlow Condensed',sans-serif;font-weight:800;
  font-size:0.6rem;letter-spacing:0.2em;padding:0.3rem 0.7rem;
}
.presta-cnt{position:absolute;bottom:0;left:0;right:0;padding:1.5rem 1.6rem}
.presta-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:1.35rem;letter-spacing:0.12em;text-transform:uppercase;
  color:#fff;transition:letter-spacing 0.3s;margin-bottom:0.3rem;
}
.presta-card:hover .presta-name{letter-spacing:0.2em}
.presta-desc{
  font-size:0.74rem;color:rgba(255,255,255,0.65);line-height:1.55;
  max-height:0;overflow:hidden;transition:max-height 0.4s ease,opacity 0.3s;opacity:0;
}
.presta-card:hover .presta-desc{max-height:80px;opacity:1}
.presta-arr{
  position:absolute;top:1.2rem;right:1.2rem;
  width:34px;height:34px;border:1px solid rgba(255,255,255,0.18);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:rotate(45deg);
  transition:opacity 0.3s,transform 0.3s,border-color 0.3s;
}
.presta-card:hover .presta-arr{opacity:1;transform:rotate(0);border-color:var(--violet-bright)}
.presta-arr svg{width:14px;stroke:var(--violet-bright);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
 
/* ── SECTIONS PUB / RACING / BATEAU ── */
.pub-section{background:var(--dark);border-top:1px solid var(--border)}
.pub-grid{display:grid;grid-template-columns:1.1fr 1fr;min-height:480px}
.pub-visual{position:relative;overflow:hidden}
.pub-visual img{width:100%;height:100%;object-fit:cover;filter:brightness(0.65)}
.pub-visual-ov{
  position:absolute;inset:0;
  background:linear-gradient(to right,transparent 40%,var(--dark) 100%);
}
.pub-text{padding:4.5rem 4rem;display:flex;flex-direction:column;justify-content:center}
.pub-text h2{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(2rem,3vw,2.8rem);text-transform:uppercase;
  line-height:0.95;margin-bottom:1.5rem;margin-top:0.5rem;
}
.pub-text p{font-size:0.9rem;line-height:1.9;color:var(--text-body);margin-bottom:1rem}
.pub-text p strong{color:rgba(255,255,255,0.92);font-weight:500}
.pub-avantages{display:flex;flex-direction:column;gap:0.65rem;margin:1.5rem 0 2rem}
.pub-av{display:flex;align-items:flex-start;gap:0.75rem;font-size:0.84rem;color:var(--text-body);line-height:1.55}
.pub-av::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--violet-bright);flex-shrink:0;margin-top:0.55rem}
 
/* ── RÉALISATIONS ── */
.reals-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}
.real-card{position:relative;overflow:hidden;aspect-ratio:3/4;cursor:pointer}
.real-card img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(0.55) grayscale(0.15);
  transition:transform 0.5s,filter 0.4s;
}
.real-card:hover img{transform:scale(1.08);filter:brightness(0.35) grayscale(0)}
.real-ov{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,0.92) 0%,transparent 55%);
  transition:background 0.4s;
}
.real-card:hover .real-ov{
  background:linear-gradient(to top,rgba(76,29,149,0.94) 0%,rgba(109,40,217,0.28) 60%,transparent 100%);
}
.real-info{position:absolute;bottom:0;left:0;right:0;padding:1.4rem}
.real-tag{font-size:0.58rem;letter-spacing:0.24em;text-transform:uppercase;color:var(--violet-bright);margin-bottom:0.35rem}
.real-name{font-family:'Barlow Condensed',sans-serif;font-weight:900;font-size:1.1rem;letter-spacing:0.08em;text-transform:uppercase;color:#fff}
 
/* ── MARQUES ── */
.brands-section{background:var(--dark);border-top:1px solid var(--border);padding:4.5rem 3rem}
.brands-logos{display:flex;align-items:center;flex-wrap:wrap;gap:1.75rem 3rem;margin-top:1.5rem}
.brand-pill{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:1.45rem;letter-spacing:0.15em;
  color:rgba(255,255,255,0.16);transition:color 0.25s;cursor:default;text-transform:uppercase;
}
.brand-pill:hover{color:rgba(255,255,255,0.7)}
 
/* ── ZONES ── */
.zones-section{padding:5.5rem 3rem;border-top:1px solid var(--border)}
.zones-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-top:2rem}
.zone-card{
  padding:1.6rem 1.4rem;background:var(--surface);
  border:1px solid var(--border);transition:border-color 0.25s,background 0.25s;
}
.zone-card:hover{border-color:var(--violet);background:rgba(109,40,217,0.07)}
.zone-name{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:1.2rem;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--white);margin-bottom:0.35rem;
}
.zone-detail{font-size:0.75rem;color:var(--muted);line-height:1.55}
 
/* ── FAQ ── */
.faq-section{padding:5.5rem 3rem;background:var(--dark);border-top:1px solid var(--border)}
.faq-list{max-width:780px;margin-top:2.5rem}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem 0;cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  font-size:1.05rem;letter-spacing:0.06em;text-transform:uppercase;
  color:var(--white);gap:1rem;transition:color 0.2s;
  background:none;border:none;width:100%;text-align:left;
}
.faq-q:hover{color:var(--violet-bright)}
.faq-icon{
  width:24px;height:24px;border:1px solid var(--border);border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background 0.25s,border-color 0.25s,transform 0.3s;
}
.faq-item.open .faq-icon{background:var(--violet);border-color:var(--violet);transform:rotate(45deg)}
.faq-icon svg{width:10px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding:0 0 1.5rem;font-size:0.9rem;line-height:1.85;color:var(--text-body)}
 
/* ── CTA ── */
.cta-band{
  background:var(--violet);padding:5rem 3rem;
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:3rem;
}
.cta-title{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:clamp(2.2rem,3.8vw,3.4rem);text-transform:uppercase;
  line-height:1.02;color:#fff;
}
.cta-sub{font-size:0.9rem;line-height:1.8;color:rgba(255,255,255,0.65);margin-top:0.65rem}
.cta-btns{display:flex;flex-direction:column;gap:0.75rem;align-items:flex-end}
 
/* ── FOOTER ── */
footer{background:var(--dark);border-top:1px solid var(--border)}
.footer-top{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:3rem;padding:4.5rem 3rem 3.5rem}
.footer-brand{
  font-family:'Barlow Condensed',sans-serif;font-weight:900;
  font-size:1.6rem;letter-spacing:0.18em;
  color:var(--white);display:block;margin-bottom:0.25rem;text-decoration:none;
}
.footer-brand span{color:var(--violet-bright)}
.footer-tagline{font-size:0.7rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--violet-bright);margin-bottom:1rem}
.footer-desc{font-size:0.82rem;line-height:1.85;color:var(--muted);margin-bottom:1.5rem}
.fc-link{
  display:flex;align-items:center;gap:0.65rem;
  font-size:0.8rem;color:var(--muted);text-decoration:none;
  margin-bottom:0.5rem;transition:color 0.2s;
}
.fc-link:hover{color:var(--white)}
.fc-link svg{width:13px;stroke:var(--violet-bright);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.footer-col h4{font-size:0.58rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--violet-bright);margin-bottom:1.4rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:0.65rem}
.footer-col ul a{font-size:0.8rem;color:var(--muted);text-decoration:none;transition:color 0.2s,padding-left 0.2s;display:block}
.footer-col ul a:hover{color:var(--white);padding-left:0.35rem}
.footer-zones-seo{
  font-size:0.75rem;color:rgba(255,255,255,0.25);
  margin-top:1.5rem;padding-top:1.5rem;
  border-top:1px solid var(--border);line-height:1.9;
}
.footer-bot{
  padding:1.4rem 3rem;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  font-size:0.72rem;color:var(--muted);
}
.footer-bot-brand{
  font-family:'Barlow Condensed',sans-serif;font-weight:700;
  letter-spacing:0.16em;font-size:0.8rem;color:var(--violet-bright);
}
 
/* ── BOUTONS FIXES ── */
.fixed-contacts{position:fixed;right:1.25rem;bottom:1.25rem;display:flex;flex-direction:column;gap:0.5rem;z-index:300}
.fc-btn{width:48px;height:48px;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:transform 0.2s}
.fc-btn:hover{transform:scale(1.1)}
.fc-btn-mail{background:var(--surface);border:1px solid var(--border)}
.fc-btn-wa{background:#25d366}
.fc-btn svg{width:21px;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.fc-btn-mail svg{stroke:var(--muted)}
.fc-btn-wa svg{stroke:#fff}
 
/* ── REVEAL ON SCROLL ── */
.rv{opacity:0;transform:translateY(24px);transition:opacity 0.7s ease,transform 0.7s ease}
.rv.on{opacity:1;transform:none}
.rv1{transition-delay:0.08s}
.rv2{transition-delay:0.18s}
.rv3{transition-delay:0.28s}
.rv4{transition-delay:0.38s}
.rv5{transition-delay:0.48s}
.rv6{transition-delay:0.56s}
.rv7{transition-delay:0.64s}
.rv8{transition-delay:0.72s}
 
/* ═══════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════ */
/* ── BURGER BUTTON ── */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 42px;
  height: 42px;
  background: transparent;
  border: 1px solid var(--border);
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  z-index: 210;
}

.nav-burger span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

.nav-burger.open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.nav-burger.open span:nth-child(2) {
  opacity: 0;
}

.nav-burger.open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ── MENU MOBILE — caché par défaut ── */
.nav-mobile {
  display: none;
  position: fixed;
  top: 64px;
  left: 0;
  right: 0;
  z-index: 199;
  background: rgba(10, 10, 10, 0.98);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(16px);
  list-style: none;
  flex-direction: column;
  padding: 1rem 0;
}

.nav-mobile li {
  list-style: none;
  border-bottom: 1px solid var(--border);
}

.nav-mobile li:last-child {
  border-bottom: none;
}

.nav-mobile a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.5rem;
  color: var(--muted);
  text-decoration: none;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.nav-mobile a:hover {
  color: var(--white);
  background: rgba(109, 40, 217, 0.08);
}

/* SVG forcés à une taille fixe */
.nav-mobile a svg {
  width: 12px !important;
  height: 12px !important;
  min-width: 12px;
  max-width: 12px;
  flex: 0 0 12px;
  stroke: var(--violet-bright);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  opacity: 0.65;
}

.nav-mobile-tel {
  justify-content: center;
  margin: 1rem 1.5rem 0.5rem;
  background: var(--violet);
  color: #fff;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
}

.nav-mobile-tel svg {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px;
  max-width: 14px;
  flex: 0 0 14px;
  stroke: #fff;
}

/* ── RESPONSIVE NAV ── */
@media (max-width: 1100px) {
  nav {
    padding: 0 1.25rem;
  }

  .nav-links {
    display: none;
  }

  .nav-burger {
    display: flex;
  }

  .nav-mobile.open {
    display: flex;
  }
}

/* Sécurité desktop : jamais visible */
@media (min-width: 1101px) {
  .nav-mobile {
    display: none !important;
  }

  .nav-burger {
    display: none !important;
}
/* FORCE MENU MOBILE */
#nav-mobile.nav-mobile {
  display: none !important;
  position: fixed;
  top: 64px;
  left: 0;
  right: 0;
  z-index: 999;
  background: rgba(10, 10, 10, 0.98);
  border-bottom: 1px solid var(--border);
  list-style: none;
  padding: 1rem 0;
  margin: 0;
  flex-direction: column;
}

#nav-mobile.nav-mobile.open {
  display: flex !important;
}

#nav-mobile.nav-mobile li {
  list-style: none;
  margin: 0;
  padding: 0;
}

#nav-mobile.nav-mobile a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  color: var(--muted);
  text-decoration: none;
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

#nav-mobile.nav-mobile svg {
  width: 12px !important;
  height: 12px !important;
  min-width: 12px !important;
  max-width: 12px !important;
  flex: 0 0 12px !important;
  stroke: var(--violet-bright);
  fill: none;
  stroke-width: 2;
}

#nav-mobile .nav-mobile-tel svg {
  width: 14px !important;
  height: 14px !important;
}

@media (min-width: 1101px) {
  #nav-mobile.nav-mobile {
    display: none !important;
  }
/* ===== FIX NAV MOBILE ===== */

.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 42px;
  height: 42px;
  background: transparent;
  border: 1px solid var(--border);
  cursor: pointer;
  z-index: 1001;
}

.nav-burger span {
  width: 20px;
  height: 2px;
  background: var(--white);
  transition: 0.3s ease;
}

.nav-mobile {
  display: none;
}

@media (max-width: 1100px) {
  nav {
    padding: 0 1rem;
  }

  .nav-center,
  .nav-links,
  .nav-phone {
    display: none;
  }

  .nav-logo-img {
    height: 72px;
  }

  .nav-burger {
    display: flex;
  }

  .nav-mobile {
    position: fixed;
    top: 64px;
    left: 0;
    right: 0;
    z-index: 1000;
    display: none;
    flex-direction: column;
    background: rgba(10, 10, 10, 0.98);
    border-bottom: 1px solid var(--border);
    list-style: none;
    padding: 1rem 0;
  }

  .nav-mobile.open {
    display: flex;
  }

  .nav-mobile li {
    list-style: none;
  }

  .nav-mobile a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 1.5rem;
    color: var(--muted);
    text-decoration: none;
    font-size: 0.72rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
  }

  .nav-mobile a:hover {
    color: var(--white);
    background: rgba(109, 40, 217, 0.1);
  }

  .nav-burger.open span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }

  .nav-burger.open span:nth-child(2) {
    opacity: 0;
  }

  .nav-burger.open span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }
}
@media (max-width: 700px) {
  nav {
    height: 64px;
    padding: 0 1rem;
  }

  .nav-logo-img {
    height: 72px;
  }

  .nav-phone {
    display: none;
  }

  .nav-burger {
    margin-left: auto;
  }

  .hero {
    margin-top: 64px;
  }
}