:root{
  --bg-deep:#0a0a0e;
  --bg-mid:#141420;
  --bg-warm:#1c1815;
  --gold:#bb986f;
  --gold-soft:rgba(187,152,111,.75);
  --text:#ffffff;
  --text-mute:rgba(255,255,255,.55);
  --text-faint:rgba(255,255,255,.3);
  --serif:'Fraunces', Georgia, serif;
  --sans:'Inter', -apple-system, system-ui, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--text);
  background:var(--bg-deep);
  overflow-x:hidden;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
/* ========== BACKGROUND : gradient + spirales ========== */
.bg-layer{
  position:fixed;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(187,152,111,.08), transparent 60%),
    radial-gradient(ellipse 70% 50% at 85% 30%, rgba(110,90,140,.07), transparent 60%),
    radial-gradient(ellipse 90% 70% at 50% 90%, rgba(187,152,111,.05), transparent 60%),
    linear-gradient(180deg, #0a0a0e 0%, #141420 40%, #1c1815 100%);
}
.spirals{
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  opacity:.15;
}
.spirals svg{
  position:absolute;
  will-change:transform;
}
.spiral-1{top:-10%;left:-8%;width:50vw;height:50vw;animation:spin 120s linear infinite, float1 18s ease-in-out infinite}
.spiral-2{bottom:-15%;right:-10%;width:55vw;height:55vw;animation:spin-reverse 180s linear infinite, float2 22s ease-in-out infinite}
.spiral-3{top:40%;right:5%;width:30vw;height:30vw;animation:spin 90s linear infinite, float1 15s ease-in-out infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes spin-reverse{to{transform:rotate(-360deg)}}
@keyframes float1{0%,100%{translate:0 0}50%{translate:3vw -2vw}}
@keyframes float2{0%,100%{translate:0 0}50%{translate:-2vw 3vw}}
/* ========== NAVBAR transparente ========== */
nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:50;
  padding:20px 48px;
  display:flex;
  align-items:center;
  gap:32px;
  background:transparent;
  transition:background .4s ease, padding .4s ease, backdrop-filter .4s ease;
}
nav .logo{margin-right:auto}
nav.scrolled{
  padding:14px 48px;
  background:rgba(10,10,14,.55);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.logo{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  color:var(--text);
}
.logo img{
  width:44px;height:44px;
  display:block;
  transition:transform .4s cubic-bezier(.77,0,.18,1);
}
.logo:hover img{transform:rotate(-6deg) scale(1.05)}
nav.scrolled .logo img{width:38px;height:38px}
.nav-links{
  display:flex;
  gap:40px;
  list-style:none;
  align-items:center;
}
.nav-icons{display:flex;gap:18px;align-items:center;margin-left:8px;padding-left:22px;border-left:1px solid rgba(255,255,255,.12)}
.nav-icons a{
  color:var(--text-mute);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;height:36px;
  border-radius:50%;
  transition:all .3s;
}
.nav-icons a:hover{color:var(--gold);background:rgba(187,152,111,.1)}
.nav-icons svg{width:18px;height:18px}
.nav-links a{
  font-family:'Bricolage Grotesque',var(--sans);
  font-size:15px;
  font-weight:500;
  color:var(--text);
  text-decoration:none;
  letter-spacing:.005em;
  position:relative;
  transition:color .3s;
}
.nav-links a::after{
  content:'';
  position:absolute;
  left:0;right:0;bottom:-4px;
  height:1px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:right;
  transition:transform .4s cubic-bezier(.77,0,.18,1);
}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:15px;
  letter-spacing:.01em;
  color:var(--gold);
  text-decoration:none;
  padding:10px 22px 10px 24px;
  border:1px solid var(--gold-soft);
  border-radius:999px;
  transition:all .3s;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.nav-cta svg{width:15px;height:15px}
.nav-cta:hover{background:var(--gold);color:var(--bg-deep);border-color:var(--gold)}
@media(max-width:780px){
  nav{padding:18px 18px}
  nav.scrolled{padding:12px 18px}
  .nav-links{gap:4px}
  .nav-links li:not(.nav-icons){display:none}
  .nav-icons{margin-left:0;padding-left:0;border-left:0;gap:6px}
  .nav-icons a{width:34px;height:34px}
  .logo img{width:38px;height:38px}
}
@media(max-width:420px){
  nav{padding:14px 14px}
  .nav-cta span, .nav-cta{font-size:11px;padding:7px 12px;gap:6px}
  .nav-cta svg{width:13px;height:13px}
}
/* ========== HERO ========== */
.hero{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:120px 24px 80px;
  position:relative;
}
.eyebrow{
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:32px;
}
h1{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(44px, 7vw, 92px);
  line-height:1.02;
  letter-spacing:-.03em;
  max-width:900px;
  margin-bottom:36px;
}
h1 em{font-style:italic;color:var(--gold);font-weight:400}
.hero-word, .hero-anim{
  opacity:0;
  transform:translateY(20px);
  animation:heroReveal 1.3s cubic-bezier(.22,.61,.36,1) forwards;
  animation-delay:var(--d, 0s);
}
.hero-word{display:inline-block}
.hero-accent{position:relative}
.hero-accent::after{
  content:'';
  position:absolute;
  left:0;bottom:.06em;
  width:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:0;
  animation:heroUnderline 1.6s cubic-bezier(.77,0,.18,1) 2.3s forwards;
}
@keyframes heroReveal{
  to{opacity:1;transform:none}
}
@keyframes heroUnderline{
  to{width:100%;opacity:.7}
}
.hero-trust{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:10px 20px;
  justify-content:center;
  align-items:center;
  margin:0 0 36px;
  color:var(--text-mute);
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.hero-trust li{
  display:inline-flex;
  align-items:center;
  gap:20px;
}
.hero-trust li:not(:last-child)::after{
  content:'';
  width:4px;height:4px;
  border-radius:50%;
  background:var(--gold);
}
.hero-signoff{
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin:0 0 28px;
  padding:7px 22px 7px 7px;
  border:1px solid rgba(187,152,111,.28);
  border-radius:999px;
  background:linear-gradient(135deg, rgba(187,152,111,.1), rgba(187,152,111,.02));
}
.hero-signoff-text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
  gap:6px;
  line-height:1;
}
.hero-signoff-text em{
  font-family:var(--serif);
  font-style:italic;
  font-size:17px;
  font-weight:400;
  color:var(--text);
}
.hero-signoff-text span{
  font-family:var(--sans);
  font-size:10px;
  font-weight:500;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
}
.hero-avatar{
  width:44px;height:44px;
  border-radius:50%;
  background-image:url('test_avatar.jpg');
  background-size:cover;
  background-position:52% 28%;
  border:1.5px solid var(--gold-soft);
  box-shadow:0 0 16px rgba(187,152,111,.3);
  flex-shrink:0;
}
@media(prefers-reduced-motion:reduce){
  .hero-word, .hero-anim{animation:none;opacity:1;transform:none}
  .hero-accent::after{animation:none;width:100%;opacity:.7}
}
.hero-sub{
  font-size:17px;
  color:var(--text-mute);
  max-width:520px;
  margin-bottom:32px;
}
.btn-primary{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:16px;
  letter-spacing:.005em;
  color:var(--text);
  text-decoration:none;
  padding:14px 30px;
  border:1px solid var(--gold);
  border-radius:999px;
  background:linear-gradient(135deg, rgba(187,152,111,.12), rgba(187,152,111,.04));
  transition:all .4s cubic-bezier(.77,0,.18,1);
  position:relative;
  overflow:hidden;
}
.btn-primary svg{width:17px;height:17px;transition:transform .4s}
.btn-primary:hover{background:var(--gold);color:var(--bg-deep);transform:translateY(-2px);box-shadow:0 16px 36px rgba(187,152,111,.25)}
.btn-primary:hover svg{transform:translateX(4px)}
.scroll-hint{
  position:absolute;
  bottom:40px;
  left:50%;
  translate:-50% 0;
  font-size:11px;
  letter-spacing:.3em;
  color:var(--text-faint);
  text-transform:uppercase;
  animation:bob 2.5s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
/* ========== SECTIONS ========== */
section{padding:120px 48px;position:relative}
.section-inner{max-width:1100px;margin:0 auto}
.section-label{
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:24px;
}
h2{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(36px, 5vw, 60px);
  line-height:1.08;
  letter-spacing:-.02em;
  margin-bottom:28px;
}
h2 em{font-style:italic;color:var(--gold);font-weight:400}
/* ========== HISTOIRE ========== */
.histoire{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.histoire-text p{color:var(--text-mute);font-size:17px;margin-bottom:20px;line-height:1.7}
.histoire-text strong{color:var(--text);font-weight:500}
.histoire-carousel{
  position:relative;
  aspect-ratio:4/5;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.6);
}
.histoire-carousel::after{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg, transparent 48%, rgba(10,10,14,.75) 100%);
  box-shadow:inset 0 0 0 1px rgba(187,152,111,.18);
  border-radius:14px;
  z-index:1;
}
.histoire-carousel .slide{
  position:absolute;inset:0;
  opacity:0;
  transition:opacity 1.1s ease;
  z-index:0;
}
.histoire-carousel .slide.active{opacity:1}
.histoire-carousel .slide img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 10%;
  filter:brightness(.94) contrast(1.04);
  transition:transform 7s ease-out;
  transform:scale(1);
}
.histoire-carousel .slide.active img{transform:scale(1.06)}
.histoire-counter{
  position:absolute;
  top:14px;right:14px;
  z-index:3;
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  padding:6px 14px;
  border-radius:999px;
  background:rgba(10,10,14,.55);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(187,152,111,.25);
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:14px;
  letter-spacing:-.01em;
  color:var(--gold-soft);
}
.histoire-counter #carouselCurrent{
  color:var(--text);
  font-weight:400;
  font-size:17px;
  min-width:18px;
  display:inline-block;
  text-align:center;
}
.histoire-counter .sep{opacity:.6}
.histoire-nav{
  position:absolute;
  bottom:18px;left:50%;translate:-50% 0;
  display:flex;gap:6px;z-index:3;
}
.histoire-nav button{
  width:6px;height:6px;
  border-radius:50%;
  background:rgba(255,255,255,.35);
  border:0;cursor:pointer;
  transition:all .3s;padding:0;
}
.histoire-nav button.active{background:var(--gold);width:20px;border-radius:4px}
@media(max-width:880px){.histoire{grid-template-columns:1fr;gap:48px}}
/* ========== CAROUSEL ========== */
.carousel-section{padding:80px 0}
.carousel{
  max-width:min(92vw, 700px);
  margin:0 auto;
  aspect-ratio:4/5;
  position:relative;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.carousel .slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity 1s ease;
}
.carousel .slide.active{opacity:1}
.carousel .slide img{width:100%;height:100%;object-fit:cover}
.carousel-nav{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:20px;
}
.carousel-nav button{
  width:7px;height:7px;
  border-radius:50%;
  background:rgba(255,255,255,.25);
  border:0;cursor:pointer;
  transition:all .3s;
  padding:0;
}
.carousel-nav button.active{background:var(--gold);width:24px;border-radius:4px}
/* ========== ACCOMPAGNEMENT | 5 piliers ========== */
.piliers{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:1px;
  margin-top:64px;
  background:rgba(255,255,255,.08);
  border-radius:16px;
  overflow:hidden;
}
.pilier{
  background:var(--bg-deep);
  padding:44px 22px 32px;
  transition:background .4s;
  position:relative;
  overflow:hidden;
}
.pilier:hover{background:var(--bg-mid)}
.pilier-num{
  position:absolute;
  top:-8px;
  right:4px;
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:96px;
  line-height:1;
  color:var(--gold);
  opacity:.12;
  pointer-events:none;
  transition:opacity .5s cubic-bezier(.77,0,.18,1), transform .5s cubic-bezier(.77,0,.18,1);
}
.pilier:hover .pilier-num{
  opacity:.26;
  transform:translate(-4px, 4px);
}
.pilier h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:18px;
  margin-bottom:12px;
  letter-spacing:-.01em;
  line-height:1.2;
  position:relative;
}
.pilier p{color:var(--text-mute);font-size:13px;line-height:1.55;position:relative}
@media(max-width:980px){.piliers{grid-template-columns:repeat(2, 1fr)}}
@media(max-width:560px){.piliers{grid-template-columns:1fr}}
/* ========== PROCESSUS ========== */
.process{margin-top:80px}
.process h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:26px;
  margin-bottom:32px;
  letter-spacing:-.01em;
}
.process-list{list-style:none}
.process-list li{
  display:flex;
  gap:24px;
  padding:22px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  color:var(--text-mute);
  font-size:16px;
}
.process-list li::before{
  content:'→';
  color:var(--gold);
  font-size:18px;
  flex-shrink:0;
}
.process-list strong{color:var(--text);font-weight:500;margin-right:6px}
/* ========== TARIF ========== */
.pricing{
  margin-top:100px;
  text-align:center;
  padding:72px 32px 56px;
  border:1px solid rgba(187,152,111,.25);
  border-radius:20px;
  background:linear-gradient(180deg, rgba(187,152,111,.04), transparent);
  position:relative;
}
.pricing::before{
  content:'';
  position:absolute;
  top:40%;left:50%;
  translate:-50% -50%;
  width:55%;height:70%;
  background:radial-gradient(ellipse, rgba(187,152,111,.13), transparent 70%);
  animation:pricingPulse 5s ease-in-out infinite;
  pointer-events:none;
  z-index:0;
}
.pricing > *{position:relative;z-index:1}
@keyframes pricingPulse{
  0%,100%{opacity:.55;scale:1}
  50%{opacity:1;scale:1.08}
}
.price-wrap{display:flex;align-items:baseline;justify-content:center;gap:18px}
.price-strike{
  font-family:var(--serif);
  font-size:32px;
  font-weight:300;
  color:var(--text-faint);
  text-decoration:line-through;
  text-decoration-color:var(--gold-soft);
  text-decoration-thickness:1.5px;
  letter-spacing:-.02em;
}
.price-amount{
  font-family:var(--serif);
  font-size:84px;
  font-weight:300;
  color:var(--gold);
  line-height:1;
  letter-spacing:-.04em;
}
.price-amount sup{font-size:36px;vertical-align:super;margin-left:4px}
.price-badge{
  position:absolute;
  top:-15px;left:50%;
  translate:-50% 0;
  z-index:2;
  display:inline-block;
  font-family:var(--sans);
  font-size:11px;
  font-weight:600;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--bg-deep);
  background:linear-gradient(135deg, #d4b087, var(--gold));
  border:0;
  padding:9px 20px;
  border-radius:999px;
  box-shadow:0 10px 28px rgba(187,152,111,.4), 0 0 0 1px rgba(255,255,255,.1) inset;
}
.price-period{color:var(--text-mute);font-size:15px;margin:16px 0 8px}
.price-period-inline{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--text-mute);margin-left:-6px;align-self:flex-end;padding-bottom:14px}
.price-note{color:var(--text-faint);font-size:13px;letter-spacing:.04em;margin-bottom:36px}
/* ========== TRANSFORMATION ========== */
.transformation{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:start;
  margin:64px auto 0;
  max-width:820px;
}
.transform-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}
.transform-tag{
  font-family:var(--sans);
  font-size:11px;
  font-weight:500;
  letter-spacing:.4em;
  text-transform:uppercase;
  color:var(--gold);
  background:rgba(187,152,111,.1);
  border:1px solid var(--gold-soft);
  padding:6px 18px;
  border-radius:999px;
  margin-bottom:20px;
}
.transform-img{
  width:100%;
  aspect-ratio:4/5;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(187,152,111,.18);
  box-shadow:0 24px 60px rgba(0,0,0,.55);
  position:relative;
  transition:transform .5s cubic-bezier(.77,0,.18,1), box-shadow .5s, border-color .5s;
}
.transform-img::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(10,10,14,.4));
  pointer-events:none;
}
.transform-card:hover .transform-img{
  transform:translateY(-4px);
  box-shadow:0 32px 72px rgba(0,0,0,.65);
  border-color:rgba(187,152,111,.4);
}
.transform-img img{width:100%;height:100%;object-fit:cover;display:block}
.transform-date{
  margin-top:24px;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.transform-month{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:18px;
  color:var(--text-mute);
  letter-spacing:.01em;
  margin-bottom:2px;
}
.transform-year{
  font-family:var(--serif);
  font-weight:300;
  font-size:54px;
  line-height:1;
  color:var(--gold);
  letter-spacing:-.02em;
  position:relative;
  padding-bottom:14px;
}
.transform-year::after{
  content:'';
  position:absolute;
  left:50%;bottom:0;
  translate:-50% 0;
  width:32px;height:1px;
  background:var(--gold-soft);
}
.quote{
  max-width:680px;
  margin:64px auto 0;
  text-align:center;
  position:relative;
}
.quote::before{
  content:'"';
  font-family:var(--serif);
  font-style:italic;
  font-size:120px;
  color:var(--gold);
  opacity:.35;
  line-height:.6;
  display:block;
  margin-bottom:12px;
}
.quote p{
  font-family:var(--serif);
  font-size:19px;
  line-height:1.6;
  color:var(--text);
  font-style:italic;
  margin-bottom:20px;
  font-weight:300;
}
.quote-signature{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
  font-size:20px;
  color:var(--gold);
  margin-top:32px;
  letter-spacing:-.01em;
}
/* ========== CTA FINAL ========== */
.final-cta{
  text-align:center;
  padding:140px 32px;
}
.final-cta h2{max-width:780px;margin-left:auto;margin-right:auto}
.final-cta p{
  color:var(--text-mute);
  max-width:520px;
  margin:0 auto 48px;
  font-size:17px;
}
.contact-alt{
  margin-top:60px;
  color:var(--text-faint);
  font-size:14px;
}
.contact-alt a{color:var(--gold);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .3s}
.contact-alt a:hover{border-color:var(--gold)}
/* ========== YOUTUBE ========== */
.youtube-block{
  text-align:center;
  padding:80px 32px;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.youtube-block h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:42px;
  letter-spacing:-.02em;
  margin-bottom:20px;
}
.youtube-block p{
  color:var(--text-mute);
  max-width:520px;
  margin:0 auto 32px;
}
.yt-link{
  color:var(--gold);
  text-decoration:none;
  font-size:13px;
  letter-spacing:.2em;
  text-transform:uppercase;
  border-bottom:1px solid var(--gold-soft);
  padding-bottom:4px;
  transition:border-color .3s;
}
.yt-link:hover{border-color:var(--gold)}
/* ========== PROCESS (Comment ça se passe) ========== */
.process{
  margin-top:96px;
  padding:56px 48px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(187,152,111,.06), rgba(255,255,255,.02));
  border:1px solid rgba(187,152,111,.18);
  position:relative;
  overflow:hidden;
}
.process::before{
  content:'';
  position:absolute;
  top:-60%;right:-20%;
  width:60%;height:200%;
  background:radial-gradient(ellipse, rgba(187,152,111,.1), transparent 60%);
  pointer-events:none;
}
.process-header{
  text-align:center;
  margin-bottom:40px;
  position:relative;
}
.process-header .section-label{margin-bottom:12px}
.process h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:34px;
  letter-spacing:-.02em;
  margin-bottom:0;
}
.process h3 em{font-style:italic;color:var(--gold)}
.process-list{
  list-style:none;
  max-width:780px;
  margin:0 auto;
  display:grid;
  gap:14px;
  position:relative;
}
.process-list li{
  display:flex;
  gap:26px;
  padding:24px 28px;
  background:rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.06);
  border-radius:14px;
  color:var(--text-mute);
  font-size:14.5px;
  line-height:1.6;
  align-items:flex-start;
  transition:all .45s cubic-bezier(.77,0,.18,1);
  position:relative;
  overflow:hidden;
}
.process-list li::after{
  content:'';
  position:absolute;
  left:0;top:24px;bottom:24px;
  width:2px;
  background:linear-gradient(180deg, transparent, var(--gold), transparent);
  opacity:0;
  transition:opacity .45s;
}
.process-list li:hover{
  border-color:rgba(187,152,111,.35);
  background:rgba(187,152,111,.05);
  transform:translateX(4px);
}
.process-list li:hover::after{opacity:.8}
.process-list li::before{
  content:counter(step,decimal-leading-zero);
  counter-increment:step;
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:34px;
  line-height:1;
  color:var(--gold);
  flex-shrink:0;
  min-width:40px;
  padding-top:2px;
  opacity:.9;
  letter-spacing:-.02em;
}
.process-list{counter-reset:step}
.process-list strong{
  font-family:var(--serif);
  font-weight:400;
  font-style:normal;
  color:var(--text);
  display:block;
  margin-bottom:6px;
  font-size:20px;
  line-height:1.25;
  letter-spacing:-.01em;
}
@media(max-width:640px){.process{padding:36px 24px}.process h3{font-size:26px}}
/* ========== YT CARD (inside histoire) ========== */
.yt-card{
  display:flex;gap:24px;
  align-items:flex-start;
  margin-top:56px;
  padding:32px;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(187,152,111,.05), rgba(255,255,255,.015));
  border:1px solid rgba(187,152,111,.18);
  text-decoration:none;
  color:inherit;
  transition:all .4s cubic-bezier(.77,0,.18,1);
  position:relative;
  overflow:hidden;
}
.yt-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at top left, rgba(187,152,111,.08), transparent 60%);
  opacity:0;transition:opacity .4s;
  pointer-events:none;
}
.yt-card:hover{border-color:rgba(187,152,111,.4);transform:translateY(-2px);box-shadow:0 20px 46px rgba(0,0,0,.35)}
.yt-card:hover::before{opacity:1}
.yt-card:hover .arrow{transform:translateX(6px)}
.yt-card-icon{
  flex-shrink:0;
  width:56px;height:56px;
  border-radius:50%;
  background:rgba(187,152,111,.15);
  border:1px solid rgba(187,152,111,.3);
  display:flex;align-items:center;justify-content:center;
  color:var(--gold);
}
.yt-card-icon svg{width:24px;height:24px}
.yt-card-body{flex:1}
.yt-handle{
  font-family:var(--serif);
  font-size:26px;
  font-weight:400;
  margin-bottom:10px;
  letter-spacing:-.01em;
}
.yt-handle em{font-style:italic;color:var(--text)}
.yt-card-body p{color:var(--text-mute);font-size:14.5px;line-height:1.65;margin-bottom:16px}
.yt-card-link{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--gold);
  border-bottom:1px solid var(--gold-soft);
  padding-bottom:3px;
}
.yt-card-link .arrow{transition:transform .3s}
@media(max-width:640px){.yt-card{flex-direction:column;padding:24px}}
/* ========== YT EMBED inside histoire ========== */
.yt-embed{
  margin-top:24px;
  border-radius:14px;
  overflow:hidden;
  aspect-ratio:16/9;
  background:#000;
  border:1px solid rgba(187,152,111,.35);
  box-shadow:
    0 30px 70px rgba(0,0,0,.6),
    0 0 0 6px rgba(187,152,111,.06),
    0 0 80px rgba(187,152,111,.18);
  position:relative;
  transition:box-shadow .6s cubic-bezier(.77,0,.18,1), border-color .6s;
}
.yt-embed:hover{
  border-color:rgba(187,152,111,.55);
  box-shadow:
    0 36px 80px rgba(0,0,0,.65),
    0 0 0 8px rgba(187,152,111,.1),
    0 0 100px rgba(187,152,111,.28);
}
.yt-embed iframe{width:100%;height:100%;border:0;display:block}
/* ========== EMAIL copy ========== */
.mail-copy{
  background:none;border:0;cursor:pointer;
  font:inherit;color:var(--gold);
  border-bottom:1px dashed var(--gold-soft);
  padding:0 0 2px;
  transition:border-color .3s;
  position:relative;
}
.mail-copy:hover{border-bottom-style:solid}
.mail-copy.copied::after{
  content:'Copié !';
  position:absolute;
  left:50%;top:-32px;
  translate:-50% 0;
  background:var(--gold);
  color:var(--bg-deep);
  padding:4px 10px;
  border-radius:6px;
  font-size:11px;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-family:var(--sans);
  white-space:nowrap;
  animation:pop .6s ease;
}
@keyframes pop{0%{opacity:0;transform:translate(-50%,6px)}15%{opacity:1;transform:translate(-50%,0)}85%{opacity:1}100%{opacity:0}}
/* ========== MODAL mentions ========== */
.modal-backdrop{
  position:fixed;inset:0;
  background:rgba(5,5,8,.8);
  backdrop-filter:blur(12px);
  z-index:100;
  opacity:0;pointer-events:none;
  transition:opacity .3s;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
}
.modal-backdrop.open{opacity:1;pointer-events:auto}
.modal{
  max-width:600px;width:100%;
  background:linear-gradient(180deg, var(--bg-mid), var(--bg-deep));
  border:1px solid rgba(187,152,111,.2);
  border-radius:16px;
  padding:40px;
  position:relative;
  color:var(--text-mute);
  font-size:14px;
  line-height:1.7;
  max-height:80vh;
  overflow-y:auto;
}
.modal h4{
  font-family:var(--serif);
  font-weight:400;
  font-size:24px;
  color:var(--text);
  margin-bottom:20px;
}
.modal p{margin-bottom:14px}
.modal strong{color:var(--text)}
.modal-close{
  position:absolute;top:16px;right:16px;
  background:none;border:0;color:var(--text-mute);
  font-size:22px;cursor:pointer;
  width:32px;height:32px;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:all .3s;
}
.modal-close:hover{background:rgba(255,255,255,.06);color:var(--text)}
/* ========== FOOTER ========== */
footer{
  padding:48px 48px 32px;
  text-align:center;
  color:var(--text-faint);
  font-size:13px;
  border-top:1px solid rgba(255,255,255,.05);
}
footer .logo{font-size:22px;display:inline-block;margin-bottom:16px}
footer .logo img{width:44px;height:44px;display:block;margin:0 auto}
/* ========== FLOATING CTA ========== */
.floating-cta{
  position:fixed;
  bottom:28px;right:28px;
  z-index:40;
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--bg-deep);
  background:var(--gold);
  padding:14px 22px 14px 24px;
  border-radius:999px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:10px;
  box-shadow:0 14px 38px rgba(187,152,111,.35), 0 4px 12px rgba(0,0,0,.3);
  transition:transform .3s cubic-bezier(.77,0,.18,1), box-shadow .3s;
  opacity:0;
  transform:translateY(20px);
  pointer-events:none;
}
.floating-cta.show{opacity:1;transform:translateY(0);pointer-events:auto}
.floating-cta:hover{transform:translateY(-3px);box-shadow:0 20px 46px rgba(187,152,111,.5), 0 6px 16px rgba(0,0,0,.35)}
.floating-cta svg{width:16px;height:16px}
.floating-cta .duration{
  font-family:var(--sans);
  font-style:normal;
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  opacity:.75;
  padding-left:10px;
  margin-left:4px;
  border-left:1px solid rgba(10,10,14,.3);
}
@media(max-width:560px){
  .floating-cta{bottom:16px;right:16px;font-size:14px;padding:12px 18px}
  .floating-cta .duration{display:none}
}
/* ========== REVEAL ========== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s ease, transform 1s ease}
.reveal.in{opacity:1;transform:none}
@media(max-width:780px){
  section{padding:80px 22px}
  .nav-cta{font-size:12px;padding:8px 16px}
  .btn-primary{font-size:15px;padding:14px 26px;gap:10px}
  .btn-primary svg{width:14px;height:14px}
  .hero{padding:110px 22px 100px}
  .final-cta{padding:90px 22px 120px}
  .pricing{padding:44px 22px;margin-top:72px}
  .price-amount{font-size:64px}
  .price-amount sup{font-size:28px}
  .price-strike{font-size:24px}
  .price-period-inline{font-size:16px;padding-bottom:10px}
  .price-wrap{gap:12px;flex-wrap:wrap}
  .youtube-block h3{font-size:30px}
  .process{padding:36px 20px;margin-top:64px}
  .process h3{font-size:24px}
  .process-list li{padding:20px 20px;gap:16px;font-size:14px}
  .process-list li::before{font-size:26px;min-width:30px}
  .process-list strong{font-size:17px}
  .yt-card{padding:22px;gap:16px}
  .yt-handle{font-size:22px}
  .modal{padding:28px 22px}
  .modal h4{font-size:20px}
  footer{padding:40px 22px 110px}
  .transformation{gap:20px;margin-top:48px}
  .transform-year{font-size:42px}
  .transform-month{font-size:16px}
  .quote::before{font-size:90px}
  .quote p{font-size:17px}
  .quote-signature{font-size:18px;margin-top:24px}
  .pilier-num{font-size:72px}
  .pilier{padding:34px 18px 26px}
  .price-badge{font-size:10px;padding:8px 16px;letter-spacing:.22em}
  h2{margin-bottom:20px}
  .histoire-text p{font-size:16px}
}
</content>
</invoke>