/* ══════════════════════════════════════
   VosObsèques Theme V2 — Complete CSS
   Extracted from theme2.html artifact
══════════════════════════════════════ */

body.theme-v2{font-family:var(--sans);background:var(--blanc);color:var(--encre);line-height:1.65;overflow-x:hidden}

/* ══ NAV ══ */
.v2-nav-bar{
  position:sticky;top:0;z-index:500;
  background:var(--blanc);
  border-bottom:1.5px solid var(--vert-l);
  height:64px;
  display:flex;align-items:center;
  padding:0 clamp(16px,4vw,60px);
  gap:0;
  box-shadow:0 1px 12px rgba(30,92,58,.07);
}
.nav-logo{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;flex-shrink:0;margin-right:28px;
}
.nav-logo-text{
  font-family:var(--serif);font-size:1.15rem;font-weight:600;
  color:var(--vert);line-height:1;
}
.nav-logo-text span{color:var(--or)}
.nav-menu{display:flex;align-items:center;gap:2px;flex:1}
.nav-item{position:relative}
.nav-link{
  display:flex;align-items:center;gap:4px;
  font-size:.825rem;font-weight:500;color:var(--gris-5);
  text-decoration:none;padding:8px 12px;border-radius:var(--r);
  transition:all .18s;white-space:nowrap;
  background:transparent;border:none;cursor:pointer;
  font-family:var(--sans);
}
.nav-link:hover,.nav-link.active{color:var(--vert);background:var(--vert-l)}
.nav-link svg{width:13px;height:13px;stroke:currentColor;transition:transform .2s}
.nav-item:hover>.nav-link svg{transform:rotate(180deg)}
.nav-link.active-page{color:var(--vert);font-weight:600}
.dropdown{
  display:none;position:absolute;top:calc(100% + 4px);left:0;
  background:var(--blanc);border:1px solid var(--gris-3);
  border-radius:var(--r2);box-shadow:var(--sh3);
  min-width:200px;padding:6px;z-index:200;
}
.nav-item:hover .dropdown{display:block}
.dd-link{
  display:block;padding:8px 12px;font-size:.825rem;color:var(--gris-5);
  text-decoration:none;border-radius:var(--r);transition:all .15s;
}
.dd-link:hover{background:var(--vert-l);color:var(--vert)}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto}
.btn-devis-nav{
  background:var(--vert);color:var(--blanc);
  padding:9px 20px;border-radius:50px;
  font-family:var(--sans);font-size:.825rem;font-weight:600;
  border:none;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;
  transition:all .18s;box-shadow:0 2px 10px rgba(30,92,58,.25);
  white-space:nowrap;
}
.btn-devis-nav:hover{background:var(--vert2);transform:translateY(-1px)}

/* ══ BOUTONS GLOBAUX ══ */
.btn-p{
  background:var(--vert);color:var(--blanc);
  padding:13px 26px;border-radius:50px;
  font-family:var(--sans);font-size:.9rem;font-weight:600;
  border:none;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:7px;
  transition:all .2s;box-shadow:var(--sh1);
}
.btn-p:hover{background:var(--vert2);transform:translateY(-1.5px);box-shadow:var(--sh2)}
.btn-s{
  background:transparent;color:var(--vert);
  padding:12px 24px;border-radius:50px;
  font-family:var(--sans);font-size:.9rem;font-weight:500;
  border:1.5px solid var(--vert);cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:7px;
  transition:all .2s;
}
.btn-s:hover{background:var(--vert-l)}
.btn-or{
  background:var(--or);color:var(--blanc);
  padding:13px 28px;border-radius:50px;
  font-family:var(--sans);font-size:.9rem;font-weight:600;
  border:none;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:7px;
  transition:all .2s;box-shadow:0 2px 12px rgba(212,135,74,.3);
}
.btn-or:hover{background:#c07840;transform:translateY(-1.5px)}

/* ══ TYPO SECTIONS ══ */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.7rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--vert3);margin-bottom:10px;
}
.eyebrow::before{content:'';width:22px;height:1.5px;background:var(--vert3)}
.eyebrow.light{color:rgba(255,255,255,.6)}
.eyebrow.light::before{background:rgba(255,255,255,.5)}
h2.titre{
  font-family:var(--serif);font-size:clamp(1.7rem,3vw,2.5rem);
  font-weight:500;color:var(--vert);line-height:1.18;margin-bottom:12px;
}
h2.titre em{font-style:italic;font-weight:400;color:var(--or)}
h2.titre.light{color:var(--blanc)}
.sous-titre{
  font-size:.95rem;font-weight:300;color:var(--gris-4);
  max-width:520px;line-height:1.75;
}
.sous-titre.large{max-width:680px}

/* ══ SECTIONS ══ */
.v2-section{padding:clamp(52px,8vw,88px) clamp(16px,4vw,60px)}
.v2-section.gris{background:var(--gris-1)}
.v2-section.vert-pale{background:var(--vert-ll)}
.v2-section.vert-fonce{background:var(--vert)}

/* ══ HERO ══ */
.theme-v2 .hero:not(.hero--small){
  display:grid;grid-template-columns:1.05fr 1fr;
  min-height:calc(100vh - 64px);max-height:900px;
}
.hero-g{
  background:var(--vert);
  padding:clamp(48px,7vw,88px) clamp(32px,5vw,72px);
  display:flex;flex-direction:column;justify-content:center;
  position:relative;overflow:hidden;
}
.hero-g::before{
  content:'';position:absolute;bottom:-100px;right:-60px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%);
}
.hero-g::after{
  content:'';position:absolute;top:-40px;left:40px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,135,74,.15) 0%,transparent 70%);
}
.hero-chip{
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.8);font-size:.72rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;
  padding:6px 14px;border-radius:50px;margin-bottom:24px;width:fit-content;
}
.hero-chip-dot{width:6px;height:6px;border-radius:50%;background:var(--or);flex-shrink:0}
h1.hero-h1{
  font-family:var(--serif);
  font-size:clamp(2.2rem,4vw,3.4rem);
  font-weight:500;color:var(--blanc);line-height:1.1;margin-bottom:18px;
  position:relative;z-index:1;
}
h1.hero-h1 em{font-style:italic;font-weight:400;color:#a8dfc0}
.hero-sub{
  font-size:.975rem;font-weight:300;color:rgba(255,255,255,.65);
  max-width:440px;line-height:1.75;margin-bottom:32px;
  position:relative;z-index:1;
}
.hero-stats{
  display:flex;gap:24px;margin-bottom:32px;
  position:relative;z-index:1;flex-wrap:wrap;
}
.hero-stat{border-left:2px solid rgba(255,255,255,.2);padding-left:14px}
.hero-stat-v{
  font-family:var(--serif);font-size:1.7rem;font-weight:500;
  color:var(--blanc);line-height:1;
}
.hero-stat-l{font-size:.7rem;color:rgba(255,255,255,.45);margin-top:3px;font-weight:300}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:1}
.btn-hero-p{
  background:var(--or);color:var(--blanc);padding:13px 26px;border-radius:50px;
  font-family:var(--sans);font-size:.875rem;font-weight:600;border:none;cursor:pointer;
  text-decoration:none;display:inline-flex;align-items:center;gap:7px;
  transition:all .2s;box-shadow:0 4px 16px rgba(212,135,74,.4);
}
.btn-hero-p:hover{background:#c07840;transform:translateY(-2px)}
.btn-hero-s{
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);
  padding:13px 22px;border-radius:50px;
  font-family:var(--sans);font-size:.875rem;font-weight:400;
  border:1px solid rgba(255,255,255,.2);cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:7px;transition:all .2s;
}
.btn-hero-s:hover{background:rgba(255,255,255,.18);color:var(--blanc)}

/* Hero droite — formulaire */
.hero-d{
  background:var(--blanc);
  display:flex;align-items:center;justify-content:center;
  padding:clamp(32px,5vw,56px) clamp(24px,4vw,48px);
  position:relative;
}
.hero-d::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 60% 30%,rgba(30,92,58,.04) 0%,transparent 60%);
}
.form-card{
  background:var(--blanc);border-radius:var(--r3);
  padding:32px 28px 24px;width:100%;max-width:420px;
  box-shadow:var(--sh3);border:1px solid var(--gris-3);
  position:relative;z-index:1;
}
.form-urgence{
  display:flex;align-items:flex-start;gap:9px;
  background:var(--or-l);border:1px solid rgba(212,135,74,.25);
  border-radius:var(--r);padding:9px 12px;margin-bottom:18px;
}
.form-urgence svg{width:15px;height:15px;stroke:var(--or);flex-shrink:0;margin-top:1px}
.form-urgence span{font-size:.75rem;color:var(--or);font-weight:500;line-height:1.4}
.form-card-titre{
  font-family:var(--serif);font-size:1.45rem;font-weight:500;
  color:var(--vert);line-height:1.2;margin-bottom:4px;
}
.form-card-sub{font-size:.8rem;color:var(--gris-4);margin-bottom:18px;font-weight:300}
.sit-tabs{
  display:grid;grid-template-columns:repeat(3,1fr);
  background:var(--gris-1);border-radius:var(--r);padding:3px;gap:2px;margin-bottom:16px;
}
.sit-btn{
  padding:7px 4px;text-align:center;
  font-family:var(--sans);font-size:.75rem;font-weight:500;
  border:none;background:transparent;border-radius:6px;
  cursor:pointer;color:var(--gris-4);transition:all .18s;line-height:1.3;
}
.sit-btn.active{background:var(--blanc);color:var(--vert);box-shadow:var(--sh1);font-weight:600}
.fg{margin-bottom:11px}
.fl{display:block;font-size:.72rem;font-weight:600;color:var(--encre);margin-bottom:4px;letter-spacing:.03em}
.fi{
  width:100%;padding:10px 13px;
  border:1.5px solid var(--gris-3);border-radius:var(--r);
  font-family:var(--sans);font-size:.875rem;color:var(--encre);
  outline:none;background:var(--blanc);appearance:none;
  transition:border-color .18s,box-shadow .18s;
}
.fi:focus{border-color:var(--vert3);box-shadow:0 0 0 3px rgba(58,158,104,.12)}
.fi::placeholder{color:var(--gris-4)}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.btn-form{
  width:100%;padding:13px;background:var(--vert);color:var(--blanc);
  border:none;border-radius:var(--r2);cursor:pointer;
  font-family:var(--sans);font-size:.9rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:7px;
  box-shadow:0 3px 14px rgba(30,92,58,.22);transition:all .2s;margin-top:4px;
}
.btn-form:hover{background:var(--vert2);transform:translateY(-1px)}
.form-gars{display:flex;justify-content:center;gap:14px;margin-top:12px;flex-wrap:wrap}
.fg-item{display:flex;align-items:center;gap:4px;font-size:.68rem;color:var(--gris-4)}
.fg-item svg{width:11px;height:11px;stroke:var(--vert3);flex-shrink:0}

/* Trust strip */
.trust-strip{
  background:var(--vert-ll);border-top:1.5px solid var(--vert-l);border-bottom:1.5px solid var(--vert-l);
  padding:12px clamp(16px,4vw,60px);
  display:flex;align-items:center;justify-content:center;gap:clamp(16px,4vw,48px);flex-wrap:wrap;
}
.trust-item{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--gris-5)}
.trust-item b{color:var(--vert)}
.trust-item svg{width:15px;height:15px;stroke:var(--vert3)}
.trust-sep{width:1px;height:16px;background:var(--gris-3)}

/* Comment ça marche */
.steps-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;margin-top:44px;background:var(--gris-3);border-radius:var(--r3);overflow:hidden;
}
.step-card{background:var(--blanc);padding:36px 32px;transition:background .2s}
.step-card:hover{background:var(--vert-ll)}
.step-n{
  font-family:var(--serif);font-size:3.5rem;font-weight:400;
  color:var(--vert-l);line-height:1;margin-bottom:16px;display:block;user-select:none;
}
.step-icone{
  width:46px;height:46px;border-radius:12px;background:var(--vert-l);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.step-icone svg{width:21px;height:21px;stroke:var(--vert)}
.step-titre{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--vert);margin-bottom:8px}
.step-desc{font-size:.85rem;color:var(--gris-4);line-height:1.7;font-weight:300}
.step-tag{
  display:inline-block;margin-top:12px;font-size:.66rem;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--vert3);
  background:var(--vert-l);padding:3px 9px;border-radius:50px;
}

/* Simulateur prix */
.simu-card{
  background:var(--blanc);border:1.5px solid var(--vert-l);
  border-radius:var(--r3);padding:36px;box-shadow:var(--sh2);
  max-width:760px;margin:44px auto 0;
}
.simu-tabs{
  display:flex;gap:4px;margin-bottom:24px;
  background:var(--gris-1);padding:4px;border-radius:var(--r);
}
.simu-tab{
  flex:1;padding:9px;text-align:center;border:none;background:transparent;
  font-family:var(--sans);font-size:.82rem;font-weight:500;color:var(--gris-4);
  border-radius:6px;cursor:pointer;transition:all .18s;
}
.simu-tab.active{background:var(--blanc);color:var(--vert);box-shadow:var(--sh1);font-weight:600}
.simu-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.simu-result{
  background:var(--vert-ll);border:1.5px solid var(--vert-l);
  border-radius:var(--r2);padding:20px;text-align:center;margin-top:4px;
}
.simu-result-titre{font-size:.75rem;font-weight:600;color:var(--gris-4);margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em}
.simu-result-val{font-family:var(--serif);font-size:2rem;font-weight:600;color:var(--vert);margin-bottom:4px}
.simu-result-sub{font-size:.75rem;color:var(--gris-4);font-weight:300}

/* Annuaire preview */
.search-bar{
  background:var(--blanc);border:1.5px solid var(--gris-3);
  border-radius:var(--r3);padding:24px;box-shadow:var(--sh2);margin-bottom:20px;
}
.search-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end}
.search-bar label{font-size:.72rem;font-weight:600;color:var(--encre);display:block;margin-bottom:4px}
.search-bar input,.search-bar select{
  width:100%;padding:10px 14px;border:1.5px solid var(--gris-3);
  border-radius:var(--r);font-family:var(--sans);font-size:.875rem;
  color:var(--encre);outline:none;background:var(--blanc);appearance:none;
  transition:border-color .18s;
}
.search-bar input:focus,.search-bar select:focus{border-color:var(--vert3)}
.search-chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.chip{
  padding:5px 12px;border-radius:50px;font-size:.73rem;font-weight:500;
  background:var(--gris-1);color:var(--gris-5);border:1px solid var(--gris-3);
  cursor:pointer;transition:all .18s;
}
.chip:hover,.chip.active{background:var(--vert);color:var(--blanc);border-color:var(--vert)}

/* Cartes agences */
.agences-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px}
.agence-card{
  background:var(--blanc);border:1px solid var(--gris-3);
  border-radius:var(--r2);overflow:hidden;
  box-shadow:var(--sh1);transition:all .2s;cursor:pointer;
}
.agence-card:hover{box-shadow:var(--sh3);transform:translateY(-3px);border-color:var(--vert-l)}
.ac-top{padding:18px 18px 12px;display:flex;gap:12px;align-items:flex-start}
.ac-av{
  width:46px;height:46px;border-radius:10px;background:var(--vert-l);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--vert);flex-shrink:0;
}
.ac-info{flex:1}
.ac-name{font-weight:600;font-size:.9rem;color:var(--vert);margin-bottom:3px;line-height:1.2}
.ac-loc{font-size:.73rem;color:var(--gris-4);display:flex;align-items:center;gap:3px}
.ac-loc svg{width:10px;height:10px;stroke:var(--gris-4)}
.ac-badges{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px}
.badge{font-size:.62rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 7px;border-radius:4px}
.b-hab{background:var(--vert-l);color:var(--vert)}
.b-ouv{background:#e8f8ee;color:#0e6b3c}
.b-urg{background:#fff3e8;color:#c07840}
.b-cert{background:var(--gris-1);color:var(--gris-5)}
.ac-mid{padding:0 18px 10px;display:flex;align-items:center;gap:10px}
.ac-stars{font-size:.73rem;color:var(--or);display:flex;align-items:center;gap:3px}
.ac-stars b{font-size:.8rem;color:var(--encre)}
.ac-rev{font-size:.68rem;color:var(--gris-4)}
.ac-dist{margin-left:auto;font-size:.7rem;color:var(--gris-4);display:flex;align-items:center;gap:3px}
.ac-services{
  padding:10px 18px;border-top:1px solid var(--gris-2);
  display:flex;gap:4px;flex-wrap:wrap;
}
.svc-tag{font-size:.67rem;color:var(--gris-4);background:var(--gris-1);padding:3px 8px;border-radius:4px}
.ac-foot{
  padding:10px 18px 16px;
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;
}
.ac-prix{font-size:.73rem;color:var(--gris-4)}
.ac-prix b{font-family:var(--serif);font-size:1.05rem;color:var(--vert);font-weight:500}
.btn-devis-card{
  padding:7px 15px;border-radius:50px;background:var(--vert);color:var(--blanc);
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  border:none;cursor:pointer;transition:all .18s;
}
.btn-devis-card:hover{background:var(--vert2)}

/* Features grille 2x2 */
.feat-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;margin-top:44px;background:var(--gris-3);border-radius:var(--r3);overflow:hidden;
}
.feat{background:var(--blanc);padding:34px 32px;transition:background .2s}
.feat:hover{background:var(--vert-ll)}
.feat-icon{
  width:44px;height:44px;border-radius:11px;background:var(--vert);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.feat-icon svg{width:20px;height:20px;stroke:var(--blanc)}
.feat-titre{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--vert);margin-bottom:7px}
.feat-desc{font-size:.85rem;color:var(--gris-4);line-height:1.7;font-weight:300}
.feat-puce{
  display:inline-block;margin-top:10px;font-size:.65rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--or);
  background:var(--or-l);padding:3px 9px;border-radius:50px;
}

/* Témoignages */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:44px}
.testi{
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r2);padding:26px;transition:all .2s;
}
.testi:hover{background:rgba(255,255,255,.13);transform:translateY(-3px)}
.testi-stars{color:#f0c060;font-size:.88rem;letter-spacing:2px;margin-bottom:12px}
.testi-q{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:.95rem;color:rgba(255,255,255,.88);line-height:1.6;margin-bottom:18px;
}
.testi-au{display:flex;align-items:center;gap:10px}
.testi-av{
  width:36px;height:36px;border-radius:50%;background:var(--vert2);
  display:flex;align-items:center;justify-content:center;
  font-size:.73rem;font-weight:600;color:var(--blanc);flex-shrink:0;
}
.testi-name{font-size:.82rem;font-weight:600;color:var(--blanc);line-height:1.2}
.testi-ctx{font-size:.7rem;color:rgba(255,255,255,.4);font-weight:300}
.score-row{
  display:flex;align-items:center;gap:18px;margin-top:36px;padding-top:28px;
  border-top:1px solid rgba(255,255,255,.12);
}
.score-big{font-family:var(--serif);font-size:3rem;font-weight:500;color:var(--blanc);line-height:1}
.score-stars{color:#f0c060;font-size:1rem;letter-spacing:3px;margin-bottom:3px}
.score-label{font-size:.78rem;color:rgba(255,255,255,.4);font-weight:300}

/* Guides cards */
.guides-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:40px}
.guide-card{
  background:var(--blanc);border:1px solid var(--gris-3);
  border-radius:var(--r2);overflow:hidden;box-shadow:var(--sh1);
  transition:all .2s;cursor:pointer;text-decoration:none;display:block;
}
.guide-card:hover{box-shadow:var(--sh3);transform:translateY(-3px);border-color:var(--vert-l)}
.gc-color{height:5px}
.gc-body{padding:20px}
.gc-cat{
  font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--vert3);margin-bottom:8px;
}
.gc-titre{font-family:var(--serif);font-size:1rem;font-weight:500;color:var(--encre);margin-bottom:6px;line-height:1.3}
.gc-desc{font-size:.8rem;color:var(--gris-4);line-height:1.6;font-weight:300}
.gc-lire{
  display:flex;align-items:center;gap:4px;margin-top:12px;
  font-size:.75rem;font-weight:600;color:var(--vert);
}
.gc-lire svg{width:13px;height:13px;stroke:var(--vert)}

/* CTA bande */
.cta-band{
  background:var(--vert);
  padding:clamp(44px,7vw,72px) clamp(16px,4vw,60px);
  display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;right:-60px;top:-80px;
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.07) 0%,transparent 70%);
}
.cta-band-l .eyebrow{color:rgba(255,255,255,.55)}
.cta-band-l .eyebrow::before{background:rgba(255,255,255,.4)}
.cta-band h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:500;color:var(--blanc);margin-bottom:10px;line-height:1.2}
.cta-band p{font-size:.9rem;color:rgba(255,255,255,.6);line-height:1.7;font-weight:300;max-width:480px}
.cta-band-r{display:flex;flex-direction:column;gap:10px;align-items:flex-end;flex-shrink:0;position:relative;z-index:1}

/* ══ FOOTER ══ */
.v2-footer{
  background:var(--encre);
  padding:clamp(48px,7vw,72px) clamp(16px,4vw,60px) 24px;
}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;margin-bottom:44px}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:12px;text-decoration:none}
.footer-logo-text{font-family:var(--serif);font-size:1.1rem;font-weight:500;color:var(--blanc)}
.footer-logo-text span{color:var(--or)}
.footer-about{font-size:.8rem;color:rgba(255,255,255,.35);line-height:1.7;font-weight:300;max-width:240px;margin-bottom:16px}
.footer-legal{font-size:.72rem;color:rgba(255,255,255,.25);line-height:1.6;font-weight:300}
.footer-col-titre{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:12px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:7px}
.footer-links a{font-size:.8rem;color:rgba(255,255,255,.5);text-decoration:none;font-weight:300;transition:color .18s}
.footer-links a:hover{color:rgba(255,255,255,.85)}
.footer-bottom{
  padding-top:20px;border-top:1px solid rgba(255,255,255,.07);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
}
.footer-bottom span{font-size:.72rem;color:rgba(255,255,255,.2);font-weight:300}

/* ══ ANIMATIONS ══ */
.fade-up{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease}
.fade-up.show{opacity:1;transform:none}

/* ══ RESPONSIVE ══ */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .theme-v2 .hero:not(.hero--small){grid-template-columns:1fr;max-height:none}
  .steps-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .testi-grid{grid-template-columns:1fr}
  .fr2{grid-template-columns:1fr}
  .search-row{grid-template-columns:1fr}
  .cta-band{grid-template-columns:1fr}
  .cta-band-r{align-items:flex-start}
  .footer-top{grid-template-columns:1fr}
}

/* ══ MOBILE NAV ══ */
.v2-nav-toggle{
  display:none;background:none;border:none;cursor:pointer;padding:8px;z-index:501;
}
.v2-nav-toggle span{display:block;width:22px;height:2px;background:var(--encre);margin:5px 0;border-radius:2px;transition:all .2s}
.v2-nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.v2-nav-toggle.active span:nth-child(2){opacity:0}
.v2-nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.v2-nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:400}
.v2-nav-overlay.active{display:block}

@media(max-width:1024px){
  .v2-nav-toggle{display:block}
  .nav-menu,.nav-right{
    position:fixed;top:0;right:-300px;width:300px;height:100vh;
    background:var(--blanc);flex-direction:column;align-items:stretch;
    padding:80px 20px 20px;box-shadow:var(--sh3);transition:right .3s;
    overflow-y:auto;z-index:450;
  }
  .nav-menu.open,.nav-right.open{right:0}
  .nav-right{top:auto;bottom:0;height:auto;padding:20px;right:-300px;position:fixed;
    border-top:1px solid var(--gris-2);z-index:451;
  }
  .nav-link{padding:10px 12px;font-size:.9rem}
  .dropdown{
    position:static;box-shadow:none;border:none;display:none;padding-left:16px;min-width:auto;
  }
  .nav-item.open .dropdown{display:block}
}
