/* ===========================================================
   LD INVEST — Site styles (Lumière & Prestige)
   =========================================================== */

:root{
  --bg:#F7F4EF;
  --bg-2:#EDE8DF;
  --bg-3:#FFFFFF;
  --section-alt:#E0E6EF;
  --navy:#1C2B4A;
  --navy-2:#14203A;
  --ink:#1C2B4A;
  --ink-2:#2A3D5E;
  --ink-dim:#6B7A94;
  --ink-mute:#9AA6BA;
  --gold:#B8924F;
  --gold-soft:#D4AD72;
  --gold-pale:rgba(184,146,79,.12);
  --line:rgba(28,43,74,.10);
  --line-strong:rgba(28,43,74,.22);
  --line-light:rgba(28,43,74,.06);
  --pad-x:clamp(24px, 5vw, 96px);
  --max:1480px;
  --serif:"Fraunces","Times New Roman",serif;
  --sans:"Inter Tight",ui-sans-serif,system-ui,-apple-system,sans-serif;
  --shadow-sm:0 2px 12px rgba(28,43,74,.07);
  --shadow-md:0 8px 32px rgba(28,43,74,.10);
  --shadow-lg:0 20px 60px rgba(28,43,74,.14);
  --radius:2px;
  --transition:.26s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
body{font-size:15px;line-height:1.6;font-weight:400}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}

h1,h2,h3,h4{font-family:var(--serif);font-weight:300;letter-spacing:-.015em;line-height:1.08;color:var(--navy)}
h1{font-size:clamp(32px, 4.2vw, 64px);font-variation-settings:"opsz" 144;font-weight:300}
h2{font-size:clamp(24px, 3vw, 46px);font-variation-settings:"opsz" 96}
h3{font-size:clamp(18px, 1.8vw, 28px)}
h4{font-family:var(--serif);font-size:17px}
em{font-style:italic;color:var(--gold)}

.eyebrow{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.28em;font-weight:500;color:var(--gold);display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:"";display:inline-block;width:32px;height:1px;background:var(--gold);opacity:.7}

.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x);position:relative}
section{padding:clamp(48px,6vw,96px) 0;position:relative}
.rule{height:1px;background:var(--line)}

/* ====== NAV ====== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(247,244,239,.97);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
  transition:box-shadow var(--transition);
}
.nav.scrolled{box-shadow:var(--shadow-sm)}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:16px var(--pad-x);max-width:1640px;margin:0 auto}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:80px}
.brand .sub{font-family:var(--serif);font-style:italic;font-size:12px;color:var(--navy);opacity:.65;border-left:1px solid var(--line-strong);padding-left:16px;font-weight:400;letter-spacing:.01em}
.nav-links{display:flex;gap:32px;font-size:13px;letter-spacing:.02em}
.nav-links a{position:relative;padding:6px 0;color:var(--ink-dim);transition:color var(--transition)}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;background:var(--gold);transition:right var(--transition)}
.nav-links a:hover{color:var(--navy)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-links a.active{color:var(--navy)}
.nav-toggle{display:none;font-size:22px;color:var(--navy);padding:4px 8px;transition:color var(--transition)}
.nav-toggle:hover{color:var(--gold)}

/* Mobile menu */
.nav-mobile{display:none;flex-direction:column;gap:0;background:var(--bg-3);border-bottom:1px solid var(--line);box-shadow:var(--shadow-md)}
.nav-mobile.open{display:flex}
.nav-mobile a{padding:16px var(--pad-x);font-size:15px;color:var(--ink-dim);border-bottom:1px solid var(--line-light);transition:all var(--transition)}
.nav-mobile a:hover,.nav-mobile a.active{color:var(--navy);background:var(--bg-2);padding-left:calc(var(--pad-x) + 8px)}
.nav-mobile .nav-mobile-cta{margin:16px var(--pad-x) 20px;border-bottom:none}

/* ====== CTAs ====== */
.cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 28px;
  background:var(--navy);color:#fff;
  border:2px solid var(--navy);
  border-radius:var(--radius);
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:500;font-family:var(--sans);text-align:center;justify-content:center;
  transition:all var(--transition);
}
.cta:hover{background:transparent;color:var(--navy)}
.cta-gold{background:var(--gold);border-color:var(--gold);color:#fff}
.cta-gold:hover{background:transparent;color:var(--gold)}
.cta-ghost{background:transparent;color:var(--navy);border-color:var(--line-strong)}
.cta-ghost:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.cta-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.cta-ghost-light:hover{background:#fff;color:var(--navy)}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.cta .arr{display:inline-block;transition:transform var(--transition)}
.cta:hover .arr{transform:translateX(4px)}

.cta-link{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--serif);font-style:italic;font-size:17px;
  color:var(--gold);font-weight:400;
  padding-bottom:3px;border-bottom:1px solid var(--gold);
  transition:all var(--transition);width:fit-content;
}
.cta-link:hover{color:var(--navy);border-color:var(--navy)}
.cta-link .arr{transition:transform var(--transition)}
.cta-link:hover .arr{transform:translateX(4px)}

/* ====== SECTION HEADERS ====== */
.sec-head{display:grid;grid-template-columns:auto 1fr;gap:36px;margin-bottom:48px;align-items:start}
.sec-num{font-family:var(--serif);font-style:italic;font-size:56px;font-weight:300;color:var(--gold);line-height:1;opacity:.65}
.sec-head .body h2{margin-top:-6px}
.sec-head .body h2 em{color:var(--gold)}
.sec-head .body .eyebrow{margin-bottom:12px}
.sec-head .body .lede{font-family:var(--serif);font-style:italic;font-size:clamp(15px,1.2vw,18px);line-height:1.55;color:var(--ink-dim);max-width:54ch;margin-top:16px;font-weight:300}

/* ====== PAGE HEADERS (sous-pages) ====== */
.page-head{
  padding:clamp(48px,5vw,80px) 0 clamp(28px,3vw,48px);
  border-bottom:1px solid var(--line);position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--bg) 0%,var(--bg-2) 100%);
}
.page-head::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(50% 70% at 85% 10%, rgba(184,146,79,.09), transparent 60%);
}
.page-head .crumbs{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:32px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.page-head .crumbs a{color:var(--ink-dim);transition:.2s}
.page-head .crumbs a:hover{color:var(--gold)}
.page-head .crumbs span.sep{color:var(--ink-mute);font-family:var(--serif);font-style:italic}
.page-head .crumbs span.current{color:var(--gold)}
.page-head h1{max-width:18ch;margin-bottom:16px;text-wrap:balance}
.page-head h1 em{color:var(--gold)}
.page-head .lede{font-family:var(--serif);font-style:italic;font-size:clamp(15px,1.1vw,18px);line-height:1.5;color:var(--ink-dim);max-width:48ch;font-weight:300;margin-top:16px}
.page-head .lede em{color:var(--gold)}
.page-head .meta-row{display:flex;flex-wrap:wrap;gap:48px;margin-top:48px;padding-top:32px;border-top:1px solid var(--line);font-size:13px}
.page-head .meta-row > div{display:flex;flex-direction:column;gap:6px}
.page-head .meta-row .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute)}
.page-head .meta-row .v{font-family:var(--serif);font-size:18px;color:var(--navy);font-weight:300}
.page-head .meta-row .v em{color:var(--gold)}

/* ====== CARDS GÉNÉRIQUES ====== */
.card{
  background:var(--bg-3);
  border:1px solid var(--line);
  padding:24px 20px;
  transition:all var(--transition);
  position:relative;overflow:hidden;
  border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:rgba(184,146,79,.3)}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform var(--transition)}
.card:hover::before{transform:scaleX(1)}

/* ====== HERO ====== */
.hero{
  min-height:72vh;display:flex;align-items:center;
  background:linear-gradient(160deg, #F7F4EF 0%, #EDE8DF 60%, #E5DECE 100%);
  position:relative;overflow:hidden;
  padding:clamp(64px,7vw,100px) 0 clamp(48px,5vw,80px);
}
.hero::after{
  content:"";position:absolute;
  top:-10%;right:-5%;
  width:clamp(300px,45vw,720px);height:clamp(300px,45vw,720px);
  background:radial-gradient(circle, rgba(184,146,79,.12) 0%, transparent 70%);
  pointer-events:none;
}
.hero .wrap{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;z-index:1}
.hero-content{display:flex;flex-direction:column;gap:32px}
.hero-eyebrow{display:flex;align-items:center;gap:14px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;color:var(--gold)}
.hero-eyebrow::before{content:"";display:inline-block;width:32px;height:1px;background:var(--gold)}
.hero h1{text-wrap:balance;color:var(--navy)}
.hero h1 em{color:var(--gold);font-style:italic}
.hero .sub{font-family:var(--serif);font-style:italic;font-size:clamp(15px,1.2vw,18px);color:var(--ink-dim);line-height:1.55;max-width:44ch;font-weight:300}
.hero .trust-row{display:flex;flex-wrap:wrap;gap:24px;margin-top:8px}
.hero .trust-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-dim)}
.hero .trust-item .icon{color:var(--gold);font-size:16px}
.hero-visual{position:relative}
.hero-photo{
  width:100%;aspect-ratio:1/1;
  background:var(--bg-2);
  border-radius:4px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  position:relative;
}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-badge{
  position:absolute;bottom:-28px;left:-28px;
  background:var(--bg-3);border:1px solid var(--line);
  padding:20px 24px;box-shadow:var(--shadow-md);
  border-left:3px solid var(--gold);
  animation:ld-float 5s ease-in-out infinite;
}
.hero-badge .num{font-family:var(--serif);font-size:28px;font-weight:300;color:var(--navy);line-height:1}
.hero-badge .lbl{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);margin-top:4px}

/* ====== SECTION STATS / CHIFFRES ====== */
.stats-strip{background:var(--navy);padding:clamp(32px,4vw,52px) 0}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;justify-content:center}
.stat-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 24px;border-right:1px solid rgba(255,255,255,.1)}
.stat-item:last-child{border-right:none}
.stat-item .num{font-family:var(--serif);font-weight:300;font-size:clamp(26px,2.8vw,44px);color:var(--gold);line-height:1}
.stat-item .lbl{font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:6px}

/* ====== ALTERNANCE VISUELLE DES SECTIONS ====== */
/* Accueil */
.indep{background:var(--bg-3)}
.clients-preview{background:var(--section-alt)}
.profile-teaser{background:var(--bg-3)}
.services-preview{background:var(--section-alt)}
/* À propos */
.stats{background:var(--bg-3)}
.values{background:var(--section-alt)}
.method{background:var(--bg-3)}
/* Offres */
.offers-index{background:var(--bg-3)}
#strategie{background:var(--bg-3)}
#fiscalite{background:var(--section-alt)}
#retraite{background:var(--bg-3)}
/* Clientèle */
#particuliers{background:var(--bg-3)}
#professionnels{background:var(--section-alt)}
#entreprises{background:var(--bg-3)}
/* Partenaires */
.intro-band{background:var(--bg-3)}
.partners-page{background:var(--section-alt)}
.quote-band{background:var(--bg-3)}
/* Contact */
.contact-main{background:var(--bg-3)}
.map-band{background:var(--section-alt)}

/* ====== INTRO / VALEUR AJOUTÉE ====== */
.intro-sec{background:var(--bg-3)}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,120px);align-items:center}
.intro-img{position:relative}
.intro-img .ph{width:100%;aspect-ratio:4/5;border-radius:4px}
.intro-img .accent-block{
  position:absolute;bottom:-20px;right:-20px;
  background:var(--gold);color:#fff;
  padding:20px 24px;
  font-family:var(--serif);font-style:italic;font-size:18px;
  font-weight:300;max-width:22ch;line-height:1.4;
}
.intro-text{display:flex;flex-direction:column;gap:28px}
.intro-text p{font-size:17px;line-height:1.7;color:var(--ink-dim)}
.intro-text p.large{font-family:var(--serif);font-style:italic;font-size:clamp(20px,1.6vw,26px);line-height:1.5;color:var(--ink);font-weight:300}

/* ====== SERVICES ====== */
.services-sec{background:var(--bg)}
.services-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.service-row{
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:start;gap:24px;
  padding:22px 0;
  border-bottom:1px solid var(--line);
  position:relative;cursor:pointer;
  transition:all var(--transition);
}
.service-row::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--gold);transform:scaleY(0);transform-origin:top;
  transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.service-row:hover{padding-left:20px}
.service-row:hover::before{transform:scaleY(1)}
.service-row:hover .svc-num{color:var(--gold);opacity:1}
.service-row:hover .svc-title{color:var(--gold)}
.svc-num{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--ink-mute);font-weight:300;transition:all var(--transition);min-width:32px;margin-top:6px}
.svc-body{display:flex;flex-direction:column;gap:10px}
.svc-title{font-family:var(--serif);font-size:clamp(16px,1.4vw,22px);font-weight:300;color:var(--navy);transition:color var(--transition);line-height:1.1}
.svc-desc{font-size:14px;line-height:1.6;color:var(--ink-dim);max-width:56ch}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.svc-tag{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);background:var(--bg-2);padding:4px 10px;border-radius:2px}
.svc-arrow{font-size:20px;color:var(--ink-mute);transition:all var(--transition);margin-top:8px}
.service-row:hover .svc-arrow{color:var(--gold);transform:translateX(6px)}

/* ====== PARTENAIRES CAROUSEL ====== */
.partners-sec{background:var(--bg-3);padding:clamp(40px,5vw,72px) 0 40px;overflow:hidden}
.partners-sec .sec-label{text-align:center;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:24px;padding-top:0}
.logos-track-wrap{overflow:hidden;position:relative;width:100%}
.logos-track-wrap::before,.logos-track-wrap::after{
  content:"";position:absolute;top:0;bottom:0;width:clamp(60px,8vw,120px);z-index:2;pointer-events:none;
}
.logos-track-wrap::before{left:0;background:linear-gradient(to right,var(--bg-3),transparent)}
.logos-track-wrap::after{right:0;background:linear-gradient(to left,var(--bg-3),transparent)}
.logos-track{display:flex;gap:0;width:max-content;animation:marquee 34s linear infinite}
.logos-track:hover{animation-play-state:paused}
.logos-track-2{animation-direction:reverse}
.logo-item{
  display:flex;align-items:center;justify-content:center;
  padding:0 18px;height:100px;
  filter:opacity(.85);
  transition:filter var(--transition);
  flex-shrink:0;
}
.logo-item:hover{filter:opacity(1)}
.logo-item img{height:auto;max-height:220px;max-width:390px;width:auto;object-fit:contain;display:block}
.logo-item .logo-text{font-family:var(--serif);font-style:italic;font-size:20px;font-weight:300;color:var(--navy);white-space:nowrap}

@keyframes marquee{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ====== CERTIFICATIONS SECTION ====== */
.cred-sec{background:var(--navy);padding:clamp(40px,5vw,68px) 0;border-bottom:3px solid var(--gold)}
.cred-sec-head{text-align:center;margin-bottom:40px}
.cred-sec-head .eyebrow{justify-content:center;color:rgba(184,146,79,.8);margin-bottom:14px}
.cred-sec-head h3{font-family:var(--serif);font-size:clamp(22px,2.2vw,34px);color:#fff;font-weight:300;letter-spacing:-.015em}
.cred-sec-head h3 em{color:var(--gold)}
.cred-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.cred-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:28px 20px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;transition:background var(--transition),transform var(--transition),border-color var(--transition);animation:cred-pulse 4s ease-in-out infinite}
.cred-card:nth-child(1){animation-delay:0s}
.cred-card:nth-child(2){animation-delay:1s}
.cred-card:nth-child(3){animation-delay:2s}
.cred-card:nth-child(4){animation-delay:3s}
.cred-card:hover{background:rgba(255,255,255,.1);transform:translateY(-5px);border-color:rgba(184,146,79,.5);animation:none}
.cred-logo-pill{background:#fff;border-radius:6px;padding:8px 14px;display:flex;align-items:center;justify-content:center;min-height:52px;min-width:90px}
.cred-logo-pill img{max-height:32px;max-width:120px;width:auto;height:auto;filter:none;display:block}
.cred-acronym{font-family:var(--serif);font-size:clamp(30px,2.8vw,42px);font-weight:300;color:var(--gold);letter-spacing:-.02em;line-height:1}
.cred-card-tag{font-size:11px;font-family:var(--sans);font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.7);line-height:1.5}
.cred-card-desc{font-family:var(--serif);font-style:italic;font-size:13px;color:rgba(255,255,255,.45);font-weight:300;line-height:1.55}
@keyframes cred-pulse{0%,100%{border-color:rgba(255,255,255,.12)}50%{border-color:rgba(184,146,79,.4)}}
@media(max-width:900px){.cred-cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.cred-cards{grid-template-columns:1fr}}

/* ====== ANIMATIONS NATURELLES ====== */
@keyframes ld-float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-7px)}
}
@keyframes ld-glow-pulse{
  0%,100%{box-shadow:var(--shadow-md)}
  50%{box-shadow:var(--shadow-md),0 0 0 10px rgba(184,146,79,.12)}
}
.hero .cta-gold{animation:ld-glow-pulse 4s ease-in-out infinite}

/* ====== PARTENAIRES PAGE — LOGO IMAGE ====== */
.pcard-logo{
  display:flex;align-items:center;justify-content:center;
  height:120px;overflow:hidden;padding:0 0 8px;
  border-bottom:1px solid var(--line);
  margin-bottom:0;flex-shrink:0;flex-grow:0;
}
.pcard-logo img{
  max-height:250%;max-width:90%;width:auto;height:auto;
  object-fit:contain;display:block;margin:0 auto;
}
.pcard-site{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);border-bottom:1px solid rgba(184,146,79,.3);
  padding-bottom:1px;transition:all var(--transition);width:fit-content;
  margin-top:auto;padding-top:12px;
}
.pcard-site:hover{color:var(--navy);border-color:var(--navy)}

/* ====== BLOG ====== */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:8px}
.blog-card{
  background:var(--bg-3);border:1px solid var(--line);
  display:flex;flex-direction:column;
  border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:all var(--transition);
  text-decoration:none;color:inherit;
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(184,146,79,.3)}
.blog-thumb{
  width:100%;aspect-ratio:16/9;overflow:hidden;
  background:var(--bg-2);position:relative;flex-shrink:0;
}
.blog-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1)}
.blog-card:hover .blog-thumb img{transform:scale(1.04)}
.blog-thumb.ph-thumb{
  background:linear-gradient(135deg,var(--bg-2) 0%,var(--bg) 100%);
  display:flex;align-items:center;justify-content:center;
}
.blog-body{padding:24px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.blog-tags{display:flex;flex-wrap:wrap;gap:8px}
.blog-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);background:var(--gold-pale);padding:3px 9px;border-radius:2px;font-weight:500}
.blog-title{font-family:var(--serif);font-size:clamp(16px,1.3vw,20px);font-weight:300;line-height:1.25;color:var(--navy);transition:color var(--transition)}
.blog-card:hover .blog-title{color:var(--gold)}
.blog-title em{color:var(--gold);font-style:italic}
.blog-excerpt{font-size:14px;line-height:1.65;color:var(--ink-dim);flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.blog-meta{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-mute);margin-top:auto}
.blog-meta .date{font-family:var(--serif);font-style:italic;font-size:13px}
.blog-meta .read{letter-spacing:.08em}
.blog-read-more{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--gold);display:inline-flex;align-items:center;gap:8px;margin-top:12px;transition:all var(--transition)}
.blog-card:hover .blog-read-more{gap:12px}

/* Article page */
.article-wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}
.article-head{padding:clamp(48px,5vw,80px) 0 clamp(28px,3vw,48px);border-bottom:1px solid var(--line);background:linear-gradient(135deg,var(--bg) 0%,var(--bg-2) 100%)}
.article-body{padding:clamp(40px,5vw,72px) 0}
.article-body h2{font-size:clamp(20px,2vw,28px);margin-top:48px;margin-bottom:18px;color:var(--navy)}
.article-body h3{font-size:clamp(17px,1.6vw,22px);margin-top:36px;margin-bottom:14px;color:var(--navy)}
.article-body p{font-size:17px;line-height:1.75;color:var(--ink-dim);margin-bottom:20px}
.article-body ul,.article-body ol{padding-left:24px;margin-bottom:20px}
.article-body li{font-size:17px;color:var(--ink-dim);line-height:1.7;margin-bottom:8px}
.article-body strong{color:var(--navy);font-weight:500}
.article-body em{color:var(--gold);font-style:italic}
.article-body blockquote{border-left:3px solid var(--gold);padding:16px 24px;margin:32px 0;background:var(--bg-2);border-radius:0 4px 4px 0}
.article-body blockquote p{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--navy);margin-bottom:0;line-height:1.5}
.article-cta-inline{background:var(--navy);padding:32px 36px;border-radius:4px;margin:40px 0;position:relative;overflow:hidden}
.article-cta-inline::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 10% 0%,rgba(184,146,79,.20),transparent 55%);pointer-events:none}
.article-cta-inline h4{color:#fff;font-size:clamp(18px,1.6vw,22px);margin-bottom:10px;font-weight:300}
.article-cta-inline p{color:rgba(255,255,255,.7);font-size:15px;margin-bottom:20px}
.article-back{display:inline-flex;align-items:center;gap:8px;font-family:var(--serif);font-style:italic;font-size:15px;color:var(--gold);margin-bottom:32px;transition:all var(--transition)}
.article-back:hover{gap:12px}
.article-mini-cta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;padding:16px 24px;background:var(--gold-pale);border:1px solid rgba(184,146,79,.22);border-left:3px solid var(--gold);border-radius:2px;margin:32px 0}
.article-mini-cta .text{font-family:var(--serif);font-style:italic;color:var(--navy);font-size:16px;font-weight:300;line-height:1.4}
.article-closing-cta{margin:40px 0 0;padding:28px 32px;background:var(--bg-2);border-radius:2px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.article-closing-cta p{font-size:15px;color:var(--ink-dim);line-height:1.6;margin:0!important;max-width:52ch}
.article-closing-cta p strong{color:var(--navy)}

/* ====== ARTICLE SIDEBAR LAYOUT ====== */
.article-layout{max-width:var(--max);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x);display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:clamp(32px,4vw,60px);align-items:start}
.article-sidebar{position:sticky;top:88px;display:flex;flex-direction:column;gap:20px}
.aside-card{background:var(--bg-3);border:1px solid var(--line);padding:24px;border-radius:var(--radius)}
.aside-title{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.aside-title::before{content:"";display:inline-block;width:24px;height:1px;background:var(--gold);opacity:.7}
.aside-key-points{list-style:none;display:flex;flex-direction:column;gap:10px;padding:0}
.aside-key-points li{font-size:13px;line-height:1.55;color:var(--ink-dim);padding-left:18px;position:relative}
.aside-key-points li::before{content:"→";position:absolute;left:0;color:var(--gold);font-size:11px;top:1px}
.aside-related{display:flex;flex-direction:column;gap:0}
.aside-related a{display:flex;flex-direction:column;gap:4px;font-size:13px;line-height:1.4;color:var(--navy);text-decoration:none;transition:color var(--transition);padding:12px 0;border-bottom:1px solid var(--line)}
.aside-related a:last-child{border-bottom:none;padding-bottom:0}
.aside-related a:hover{color:var(--gold)}
.aside-related .aside-tag{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);background:var(--gold-pale);padding:2px 7px;border-radius:2px;width:fit-content}
.aside-cta-card{background:var(--navy);padding:24px;border-radius:var(--radius);position:relative;overflow:hidden}
.aside-cta-card::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 90% at 10% 0%,rgba(184,146,79,.20),transparent 55%);pointer-events:none}
.aside-cta-card .aside-title{color:var(--gold-soft)}
.aside-cta-card .aside-title::before{background:var(--gold-soft)}
.aside-cta-card p{font-size:13px;color:rgba(255,255,255,.75);line-height:1.6;margin-bottom:16px!important}
@media(max-width:1100px){.article-layout{grid-template-columns:1fr}.article-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:20px}}
@media(max-width:640px){.article-sidebar{grid-template-columns:1fr}}

@media(max-width:980px){
  .blog-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .blog-grid{grid-template-columns:1fr}
}

/* ====== TÉMOIGNAGES ====== */
.testi-sec{background:var(--section-alt);padding:clamp(48px,6vw,96px) 0}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.testi-card{
  background:var(--bg);
  padding:24px 20px 20px;
  border:1px solid var(--line);
  display:flex;flex-direction:column;position:relative;
  border-radius:var(--radius);
  transition:all var(--transition);
}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(184,146,79,.25)}
.testi-card .marks{font-family:var(--serif);font-size:52px;line-height:.7;color:var(--gold);height:24px;font-style:italic;opacity:.5}
.testi-card blockquote{font-family:var(--serif);font-size:15px;line-height:1.55;font-weight:300;color:var(--navy);margin-bottom:20px;flex:1;text-wrap:pretty;padding-right:68px}
.testi-card .author{display:flex;align-items:center;gap:14px;padding-top:24px;border-top:1px solid var(--line)}
.testi-card .avatar{width:44px;height:44px;border-radius:999px;background:var(--bg-2);font-family:var(--serif);font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--gold);font-style:italic;border:1px solid var(--line)}
.testi-card .who .name{font-weight:500;font-size:15px;color:var(--navy)}
.testi-card .who .role{font-size:12px;color:var(--ink-mute);letter-spacing:.04em;margin-top:2px}
.testi-card .stars{position:absolute;top:14px;right:20px;color:var(--gold);font-size:11px;letter-spacing:.2em}
.testi-foot{margin-top:48px;padding-top:32px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--ink-dim);flex-wrap:wrap;gap:18px}
.testi-foot strong{font-family:var(--serif);font-style:italic;color:var(--navy);font-size:22px;font-weight:300}

/* ====== FAQ ACCORDION ====== */
.faq-sec{background:var(--bg)}
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq-item{border-bottom:1px solid var(--line)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:18px 0;cursor:pointer;
  font-family:var(--serif);font-size:clamp(14px,1.1vw,17px);font-weight:300;
  color:var(--navy);transition:color var(--transition);
}
.faq-q:hover{color:var(--gold)}
.faq-q .faq-icon{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;color:var(--ink-dim);flex-shrink:0;
  transition:all var(--transition);
}
.faq-item.open .faq-q{color:var(--gold)}
.faq-item.open .faq-icon{background:var(--gold);border-color:var(--gold);color:#fff;transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1),padding .4s;
  padding-bottom:0;
}
.faq-a-inner{font-size:16px;line-height:1.7;color:var(--ink-dim);padding-bottom:28px;max-width:72ch}
.faq-item.open .faq-a{max-height:400px;padding-bottom:0}

/* ====== FINAL CTA ====== */
.cta-final{padding:0;background:var(--bg)}
.cta-final-inner{
  position:relative;overflow:hidden;
  background:var(--navy);
  padding:clamp(56px,6vw,88px) 0;
}
.cta-final-inner::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(60% 90% at 10% 0%, rgba(184,146,79,.20), transparent 55%),
    radial-gradient(50% 70% at 100% 100%, rgba(255,255,255,.04), transparent 50%);
}
.cta-final .wrap{position:relative;z-index:1}
.cta-final .eyebrow{color:var(--gold-soft)}
.cta-final .eyebrow::before{background:var(--gold-soft)}
.cta-final h2{margin-top:14px;max-width:20ch;margin-bottom:28px;color:#fff;font-weight:300}
.cta-final h2 em{color:var(--gold)}
.cta-final .channels{display:grid;grid-template-columns:repeat(3,1fr);gap:0;padding-top:32px;border-top:1px solid rgba(255,255,255,.12);margin-top:48px}
.cta-final .channels > div{padding:0 32px 0 0;border-right:1px solid rgba(255,255,255,.12)}
.cta-final .channels > div:last-child{border-right:none;padding-left:32px;padding-right:0}
.cta-final .channels > div:nth-child(2){padding-left:32px}
.cta-final .channels .lbl{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:10px}
.cta-final .channels .v{font-family:var(--serif);font-size:17px;color:#fff;font-weight:300}
.cta-final .channels .v a{color:inherit;transition:color var(--transition)}
.cta-final .channels .v a:hover{color:var(--gold)}

/* ====== FOOTER ====== */
footer{padding:64px 0 36px;background:var(--navy-2);color:rgba(255,255,255,.5);font-size:13px;border-top:1px solid rgba(255,255,255,.08);position:relative;z-index:5}
footer a{color:rgba(255,255,255,.5);transition:color var(--transition)}
footer a:hover{color:var(--gold)}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot h5{font-family:var(--serif);font-style:italic;font-size:16px;color:#fff;font-weight:300;margin-bottom:18px}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-brand img{height:60px;filter:invert(1) brightness(2);margin-bottom:14px}
.foot-brand p{max-width:34ch;line-height:1.6;margin-bottom:18px}
.foot-brand .foot-contact{font-size:13px;line-height:1.9}
.foot-brand .foot-contact .l{font-family:ui-monospace,monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-right:8px}
.foot-bot{margin-top:32px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:20px;font-size:12px;color:rgba(255,255,255,.3)}
.foot-bot a{color:rgba(255,255,255,.3)}
.foot-bot a:hover{color:var(--gold)}
.foot-bot em{font-family:var(--serif);color:var(--gold);font-style:italic}

/* ====== SCROLL REVEAL ====== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}
.reveal-left.visible{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .65s cubic-bezier(.4,0,.2,1),transform .65s cubic-bezier(.4,0,.2,1)}
.reveal-right.visible{opacity:1;transform:none}

/* Staggered reveal for grids */
.reveal-stagger > *{opacity:0;transform:translateY(24px);transition:opacity .55s cubic-bezier(.4,0,.2,1),transform .55s cubic-bezier(.4,0,.2,1)}
.reveal-stagger.visible > *{opacity:1;transform:none}
.reveal-stagger.visible > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.visible > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.visible > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.visible > *:nth-child(4){transition-delay:.26s}

/* ====== PLACEHOLDERS PHOTO ====== */
.ph{
  position:relative;
  background-color:var(--bg-2);
  background-image:repeating-linear-gradient(135deg, rgba(184,146,79,.07) 0 12px, transparent 12px 24px);
  overflow:hidden;
}
.ph::after{content:attr(data-label);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:ui-monospace,"SF Mono",Menlo,monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);text-align:center;line-height:1.7;padding:0 24px}

/* ====== CONTACT FORM ====== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:8px}
.form-group label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);font-weight:500}
.form-group input,.form-group textarea,.form-group select{
  background:var(--bg-3);
  border:1px solid var(--line-strong);
  padding:14px 16px;
  font-size:16px;color:var(--navy);
  border-radius:var(--radius);
  outline:none;
  transition:border-color var(--transition),box-shadow var(--transition);
  width:100%;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px var(--gold-pale);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--ink-mute)}
.form-group textarea{resize:vertical;min-height:140px}

/* ====== PAGE OFFRES — TARIFS ====== */
.offre-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.offre-card{
  background:var(--bg-3);border:1px solid var(--line);
  padding:40px 32px;border-radius:var(--radius);
  display:flex;flex-direction:column;gap:20px;
  box-shadow:var(--shadow-sm);
  transition:all var(--transition);
}
.offre-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(184,146,79,.3)}
.offre-card.featured{border-color:var(--gold);border-width:2px;position:relative}
.offre-card.featured::before{content:"Recommandé";position:absolute;top:-1px;right:24px;background:var(--gold);color:#fff;font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:6px 12px}
.offre-card .offre-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:500}
.offre-card h3{font-size:clamp(20px,1.8vw,26px);color:var(--navy)}
.offre-card .offre-price{font-family:var(--serif);font-size:clamp(28px,3vw,40px);color:var(--navy);font-weight:300;line-height:1}
.offre-card .offre-price span{font-size:16px;color:var(--ink-dim)}
.offre-card .offre-desc{font-size:15px;color:var(--ink-dim);line-height:1.65}
.offre-card ul{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1}
.offre-card li{display:flex;gap:10px;font-size:15px;color:var(--ink-dim)}
.offre-card li::before{content:"✓";color:var(--gold);font-weight:600;flex-shrink:0}

/* ====== PAGE CLIENTÈLE ====== */
.client-profile{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.profile-card{
  background:var(--bg-3);border:1px solid var(--line);
  padding:40px 32px;border-radius:var(--radius);
  border-top:3px solid var(--gold);
  box-shadow:var(--shadow-sm);
  transition:all var(--transition);
}
.profile-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.profile-card h3{font-size:clamp(20px,1.6vw,26px);color:var(--navy);margin-bottom:12px}
.profile-card p{font-size:15px;color:var(--ink-dim);line-height:1.65;margin-bottom:18px}
.profile-card ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.profile-card li{display:flex;gap:10px;font-size:14px;color:var(--ink-dim)}
.profile-card li::before{content:"—";color:var(--gold);flex-shrink:0}

/* ====== PAGE À PROPOS ====== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,100px);align-items:start}
.about-values{display:flex;flex-direction:column;gap:32px;margin-top:16px}
.value-item{display:flex;gap:24px;align-items:start;padding:24px 0;border-bottom:1px solid var(--line)}
.value-item:last-child{border-bottom:none}
.value-num{font-family:var(--serif);font-style:italic;font-size:40px;font-weight:300;color:var(--gold);opacity:.5;line-height:1;flex-shrink:0;min-width:48px}
.value-body h4{color:var(--navy);font-size:20px;margin-bottom:8px}
.value-body p{font-size:15px;color:var(--ink-dim);line-height:1.65}

/* ====== MENTIONS LÉGALES / RGPD ====== */
.legal-body{max-width:72ch}
.legal-body h2{font-size:clamp(24px,2.4vw,36px);margin-top:56px;margin-bottom:20px;padding-top:48px;border-top:1px solid var(--line);color:var(--navy)}
.legal-body h2:first-child{margin-top:0;padding-top:0;border-top:none}
.legal-body h3{font-size:22px;margin-top:36px;margin-bottom:14px;color:var(--navy)}
.legal-body p{font-size:16px;color:var(--ink-dim);line-height:1.75;margin-bottom:16px}
.legal-body ul,.legal-body ol{padding-left:24px;margin-bottom:16px}
.legal-body li{font-size:16px;color:var(--ink-dim);line-height:1.7;margin-bottom:8px}
.legal-body a{color:var(--gold);border-bottom:1px solid rgba(184,146,79,.4);transition:all var(--transition)}
.legal-body a:hover{color:var(--navy);border-color:var(--navy)}
.legal-body strong{color:var(--navy);font-weight:500}

/* ====== UTILITIES ====== */
.text-gold{color:var(--gold)}
.text-mute{color:var(--ink-dim)}
.text-navy{color:var(--navy)}
.text-white{color:#fff}
.text-mono{font-family:ui-monospace,monospace}
.italic{font-style:italic}
.divider{height:1px;background:var(--line);margin:48px 0}
.bg-white{background:var(--bg-3)}
.bg-cream{background:var(--bg)}
.bg-navy{background:var(--navy);color:#fff}
.mt-0{margin-top:0!important}

/* ====== RESPONSIVE ====== */
@media (max-width:1100px){
  .hero .wrap{grid-template-columns:1fr;gap:48px}
  .hero-visual{order:-1;max-width:360px;margin:0 auto}
  .hero-badge{bottom:-16px;left:-16px}
  .intro-grid{grid-template-columns:1fr;gap:40px}
  .intro-img{max-width:440px}
  .about-grid{grid-template-columns:1fr}
  .offre-grid{grid-template-columns:1fr 1fr}
  .client-profile{grid-template-columns:1fr}
}

@media (max-width:980px){
  .nav-links{display:none}
  .nav-toggle{display:block}
  .nav-row{padding:14px var(--pad-x)}
  .nav-row .cta{padding:10px 16px;font-size:11px}
  .nav-row .cta .arr{display:none}
  .sec-head{grid-template-columns:1fr;gap:14px;margin-bottom:48px}
  .sec-num{font-size:56px}
  .testi-grid{grid-template-columns:1fr 1fr;gap:16px}
  .cta-final .channels{grid-template-columns:1fr}
  .cta-final .channels > div{padding:18px 0!important;border-right:none!important;border-bottom:1px solid rgba(255,255,255,.12)}
  .cta-final .channels > div:last-child{border-bottom:none}
  .page-head .meta-row{gap:24px}
  .page-head .meta-row > div{flex:1 1 calc(50% - 12px)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:0}
  .stat-item:nth-child(2){border-right:none}
  .stat-item:nth-child(3){border-right:none}
  .stat-item{padding:24px;border-bottom:1px solid rgba(255,255,255,.08)}
  .stat-item:last-child,.stat-item:nth-child(3):nth-last-child(1){border-bottom:none}
  .foot{grid-template-columns:1fr 1fr;gap:36px}
  .offre-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
}

@media (max-width:640px){
  .testi-grid{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr}
  .service-row{grid-template-columns:auto 1fr;gap:20px}
  .svc-arrow{display:none}
  .stats-grid{grid-template-columns:1fr 1fr}
  .hero-badge{display:none}
  .hero-visual{max-width:280px}
  .hero-photo{aspect-ratio:4/3}
}
