/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
img,svg{display:block;max-width:100%}
button,input,textarea{font:inherit}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  canvas{display:none!important}
}

/* ── TOKENS ── */
:root{
  --bg:       #0C0F18;
  --bg2:      #111520;
  --bg3:      #161B2E;
  --surface:  rgba(255,255,255,.04);
  --surface2: rgba(255,255,255,.07);
  --border:   rgba(255,255,255,.08);
  --border2:  rgba(255,255,255,.14);
  --gold:     #D4A853;
  --gold-lt:  #E8C97A;
  --gold-dk:  #A8813A;
  --gold-bg:  rgba(212,168,83,.08);
  --red:      #E05C5C;
  --green:    #4CAF84;
  --white:    #F5F4F0;
  --muted:    rgba(245,244,240,.45);
  --muted2:   rgba(245,244,240,.25);
  --radius:   14px;
  --radius-sm:8px;
  --t:        .3s cubic-bezier(.4,0,.2,1);
  --glow:     0 0 40px rgba(212,168,83,.15);
  --shadow:   0 24px 64px rgba(0,0,0,.5);
}

html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:'Space Grotesk',sans-serif;
  background:var(--bg);
  color:var(--white);
  line-height:1.65;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Fraunces',serif;line-height:1.15}
a{color:inherit;text-decoration:none}

/* ── LAYOUT ── */
.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
.wrap--sm{max-width:720px;margin:0 auto;padding:0 28px}
.wrap--md{max-width:900px;margin:0 auto;padding:0 28px}
section{padding:110px 0}
@media(max-width:768px){section{padding:72px 0}}

/* ── FADE-IN ── */
.fi{opacity:0;transform:translateY(32px);transition:opacity .75s cubic-bezier(.4,0,.2,1),transform .75s cubic-bezier(.4,0,.2,1)}
.fi.in{opacity:1;transform:none}
.fi-d1{transition-delay:.1s}.fi-d2{transition-delay:.2s}.fi-d3{transition-delay:.3s}
.fi-d4{transition-delay:.4s}.fi-d5{transition-delay:.5s}.fi-d6{transition-delay:.6s}

/* ── SECTION LABELS ── */
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);margin-bottom:18px;
}
.eyebrow::before{content:'';width:28px;height:1px;background:var(--gold)}

.sec-title{
  font-size:clamp(1.9rem,4vw,3rem);font-weight:900;color:var(--white);margin-bottom:14px;
}
.sec-sub{font-size:1.05rem;color:var(--muted);max-width:580px;line-height:1.75}
.sec-sub--center{margin-left:auto;margin-right:auto;text-align:center}
.center{text-align:center}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:15px 32px;border-radius:50px;
  font-family:'Space Grotesk',sans-serif;font-size:.95rem;font-weight:600;
  cursor:pointer;border:none;transition:var(--t);position:relative;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;background:rgba(255,255,255,0);transition:var(--t);
}
.btn:hover::before{background:rgba(255,255,255,.06)}

.btn-gold{
  background:linear-gradient(135deg,var(--gold),var(--gold-lt));
  color:#0C0F18;box-shadow:0 4px 24px rgba(212,168,83,.35);
}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 36px rgba(212,168,83,.5)}

.btn-outline{
  background:transparent;color:var(--gold);
  border:1.5px solid rgba(212,168,83,.5);
}
.btn-outline:hover{border-color:var(--gold);background:var(--gold-bg);transform:translateY(-2px)}

.btn-ghost{
  background:var(--surface);color:var(--white);
  border:1px solid var(--border2);
}
.btn-ghost:hover{background:var(--surface2);transform:translateY(-2px)}

.pulse{animation:pulse 2.8s infinite}
@keyframes pulse{
  0%,100%{box-shadow:0 4px 24px rgba(212,168,83,.35)}
  50%{box-shadow:0 4px 40px rgba(212,168,83,.6),0 0 0 8px rgba(212,168,83,.08)}
}

.badge{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 18px;border-radius:50px;
  background:var(--surface);border:1px solid var(--border2);
  font-size:.78rem;font-weight:500;color:var(--muted);margin-top:14px;
}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0}

/* ── NAV ── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:background .4s,box-shadow .4s,padding .3s;
}
#nav.scrolled{
  background:rgba(12,15,24,.9);backdrop-filter:blur(20px);
  box-shadow:0 1px 0 var(--border);padding:12px 0;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:'Fraunces',serif;font-size:1.2rem;font-weight:700;
  color:var(--white);display:flex;align-items:center;gap:10px;
  letter-spacing:-.01em;
}
.nav-links{
  display:flex;align-items:center;gap:32px;list-style:none;
}
.nav-links a{font-size:.88rem;font-weight:500;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--white)}
.nav-cta{padding:10px 24px;font-size:.88rem}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-cta{display:none}
}

/* ── HERO ── */
#hero{
  min-height:100vh;display:flex;align-items:center;
  padding:140px 0 80px;position:relative;overflow:hidden;
}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-grad{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse 80% 60% at 60% 40%,rgba(212,168,83,.07) 0%,transparent 65%),
    radial-gradient(ellipse 50% 80% at 10% 80%,rgba(76,175,132,.05) 0%,transparent 60%);
}
.hero-content{position:relative;z-index:2;max-width:680px}

.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 16px;border-radius:50px;
  background:var(--gold-bg);border:1px solid rgba(212,168,83,.2);
  font-size:.75rem;font-weight:600;color:var(--gold);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:28px;
  opacity:0;animation:fadeUp .7s .2s forwards;
}
.hero-tag svg{width:14px;height:14px}

.hero-h1{
  font-size:clamp(2.4rem,6vw,4.4rem);font-weight:900;
  color:var(--white);margin-bottom:24px;
  opacity:0;animation:fadeUp .8s .35s forwards;
}
.hero-h1 .accent{
  color:transparent;
  -webkit-text-stroke:1.5px var(--gold);
  font-style:italic;
}
.hero-h1 .highlight{
  position:relative;display:inline-block;
}
.hero-h1 .highlight::after{
  content:'';position:absolute;bottom:4px;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--gold-lt));
  border-radius:2px;transform:scaleX(0);transform-origin:left;
  animation:underlineGrow .6s 1.1s forwards;
}
@keyframes underlineGrow{to{transform:scaleX(1)}}

.hero-sub{
  font-size:1.15rem;color:var(--muted);font-weight:400;max-width:520px;
  margin-bottom:40px;line-height:1.75;
  opacity:0;animation:fadeUp .8s .5s forwards;
}

.hero-actions{
  display:flex;flex-wrap:wrap;align-items:center;gap:16px;
  opacity:0;animation:fadeUp .8s .65s forwards;
}

.hero-proof{
  display:flex;align-items:center;gap:12px;margin-top:56px;
  opacity:0;animation:fadeUp .8s .8s forwards;
}
.hero-avatars{display:flex}
.hero-avatar{
  width:36px;height:36px;border-radius:50%;
  border:2px solid var(--bg);
  background:linear-gradient(135deg,var(--gold-dk),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:700;color:#0C0F18;
  margin-left:-10px;
}
.hero-avatar:first-child{margin-left:0}
.hero-proof-text{font-size:.85rem;color:var(--muted)}
.hero-proof-text strong{color:var(--white);font-weight:600}

.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:0;animation:fadeUp .6s 1.2s forwards;
}
.hero-scroll span{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted2)}
.scroll-line{
  width:1px;height:40px;background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollPulse 2s infinite;
}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.1)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* ── TICKER ── */
#ticker{
  background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:18px 0;overflow:hidden;position:relative;
}
#ticker::before,#ticker::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;
}
#ticker::before{left:0;background:linear-gradient(to right,var(--bg2),transparent)}
#ticker::after{right:0;background:linear-gradient(to left,var(--bg2),transparent)}
.ticker-track{
  display:flex;gap:64px;white-space:nowrap;
  animation:ticker 30s linear infinite;
}
.ticker-track:hover{animation-play-state:paused}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ticker-item{
  display:flex;align-items:center;gap:10px;
  font-size:.82rem;font-weight:500;color:var(--muted);
  flex-shrink:0;
}
.ticker-item span{color:var(--gold);font-weight:700}
.ticker-sep{color:var(--border2);font-size:1.2rem}

/* ── FORM ── */
#formulaire{background:var(--bg2)}
.form-layout{
  display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start;margin-top:64px;
}
@media(max-width:900px){.form-layout{grid-template-columns:1fr;gap:40px}}

.form-pitch{}
.form-pitch .sec-title{font-size:clamp(1.7rem,3vw,2.4rem)}
.pitch-list{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:14px}
.pitch-item{
  display:flex;align-items:flex-start;gap:14px;
  font-size:.9rem;color:var(--muted);line-height:1.5;
}
.pitch-icon{
  width:28px;height:28px;border-radius:8px;background:var(--gold-bg);
  border:1px solid rgba(212,168,83,.2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;
  font-size:.85rem;
}
.pitch-item strong{color:var(--white);display:block;font-size:.92rem;font-weight:600;margin-bottom:2px}

.form-card{
  background:var(--bg3);border:1px solid var(--border2);border-radius:24px;
  padding:40px 36px;box-shadow:var(--shadow);
}
@media(max-width:600px){.form-card{padding:28px 20px}}

.step-bar{display:flex;align-items:center;margin-bottom:32px}
.s-dot{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;transition:var(--t);
  background:var(--surface);border:1.5px solid var(--border2);color:var(--muted);
}
.s-dot.on{background:var(--gold);border-color:var(--gold);color:#0C0F18}
.s-dot.done{background:var(--green);border-color:var(--green);color:#fff}
.s-line{flex:1;height:1px;background:var(--border);max-width:60px;position:relative;overflow:hidden}
.s-line-fill{position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.4,0,.2,1)}

.prog{height:2px;background:var(--border);border-radius:2px;margin-bottom:28px;overflow:hidden}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--gold-dk),var(--gold-lt));border-radius:2px;transition:width .5s cubic-bezier(.4,0,.2,1);width:33%}

.fstep{display:none;animation:stepIn .35s cubic-bezier(.4,0,.2,1) forwards}
.fstep.on{display:block}
@keyframes stepIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

.fstep-title{font-family:'Fraunces',serif;font-size:1.35rem;font-weight:700;margin-bottom:6px}
.fstep-sub{font-size:.85rem;color:var(--muted);margin-bottom:24px}

.fgroup{margin-bottom:18px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:480px){.frow{grid-template-columns:1fr}}
label{display:block;font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:6px;letter-spacing:.03em}
label .opt{font-weight:400;font-size:.75rem}
input[type=text],input[type=email],input[type=url],input[type=tel]{
  width:100%;padding:13px 16px;
  background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);
  color:var(--white);font-size:.9rem;outline:none;transition:border-color .2s,background .2s;
}
input::placeholder{color:var(--muted2)}
input:focus{border-color:var(--gold);background:rgba(212,168,83,.04)}
input.err{border-color:var(--red)!important}
.fnote{font-size:.75rem;color:var(--muted2);margin-top:5px}
.ferr{font-size:.75rem;color:var(--red);margin-top:4px;display:none}
input.err ~ .ferr{display:block}

.factions{display:flex;gap:12px;align-items:center;margin-top:24px}
.fbtn-back{
  background:none;border:none;cursor:pointer;
  font-size:.85rem;color:var(--muted);padding:8px;transition:color .2s;
}
.fbtn-back:hover{color:var(--white)}
.fbtn-next{flex:1;justify-content:center}

.confirm-wrap{text-align:center;padding:16px 0}
.confirm-ring{
  width:80px;height:80px;border-radius:50%;
  background:rgba(76,175,132,.1);border:2px solid rgba(76,175,132,.3);
  display:flex;align-items:center;justify-content:center;margin:0 auto 24px;
  animation:ringIn .6s cubic-bezier(.4,0,.2,1);
}
@keyframes ringIn{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.confirm-ring svg{stroke-dasharray:50;stroke-dashoffset:50;animation:checkDraw .5s .3s forwards}
@keyframes checkDraw{to{stroke-dashoffset:0}}
.confirm-title{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:700;margin-bottom:12px}
.confirm-body{font-size:.9rem;color:var(--muted);line-height:1.75;margin-bottom:24px}
.confirm-email{color:var(--gold);font-weight:600}

/* ── STATS ── */
#stats{
  background:var(--bg);padding:72px 0;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
}
@media(max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat-cell{
  background:var(--bg);padding:36px 28px;text-align:center;
  transition:background .3s;
}
.stat-cell:hover{background:var(--bg2)}
.stat-num{
  font-family:'Fraunces',serif;font-size:clamp(2rem,4vw,3rem);
  font-weight:900;color:var(--gold);line-height:1;margin-bottom:8px;
}
.stat-label{font-size:.82rem;color:var(--muted);line-height:1.45;max-width:120px;margin:0 auto}

/* ── FOR WHOM ── */
#pourqui{background:var(--bg2)}
.cards-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;
}
@media(max-width:900px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cards-grid{grid-template-columns:1fr}}

.who-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  padding:28px 24px;transition:var(--t);position:relative;overflow:hidden;
}
.who-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold),var(--gold-lt));
  transform:scaleX(0);transition:transform .3s;transform-origin:left;
}
.who-card:hover{transform:translateY(-5px);border-color:var(--border2);box-shadow:0 16px 48px rgba(0,0,0,.35)}
.who-card:hover::before{transform:scaleX(1)}
.who-icon{font-size:1.8rem;margin-bottom:14px}
.who-title{font-size:1rem;font-weight:700;color:var(--white);margin-bottom:8px}
.who-desc{font-size:.85rem;color:var(--muted);line-height:1.6}
.who-tag{
  display:inline-block;margin-top:14px;padding:4px 12px;border-radius:50px;
  background:var(--gold-bg);border:1px solid rgba(212,168,83,.15);
  font-size:.72rem;font-weight:600;color:var(--gold);letter-spacing:.05em;
}

/* ── SERVICES ── */
#services{background:var(--bg)}
.services-bento{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:auto auto;
  gap:18px;margin-top:56px;
}
@media(max-width:900px){.services-bento{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.services-bento{grid-template-columns:1fr}}

.svc{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 28px;transition:var(--t);position:relative;overflow:hidden;
}
.svc:hover{border-color:rgba(212,168,83,.3);box-shadow:var(--glow);transform:translateY(-4px)}
.svc.featured{
  grid-column:1/3;
  background:linear-gradient(135deg,rgba(212,168,83,.1) 0%,var(--bg2) 60%);
  border-color:rgba(212,168,83,.2);
}
@media(max-width:900px){.svc.featured{grid-column:1/3}}
@media(max-width:560px){.svc.featured{grid-column:1}}
.svc-num{
  font-family:'Fraunces',serif;font-size:3rem;font-weight:900;
  color:rgba(212,168,83,.12);line-height:1;margin-bottom:8px;
}
.svc-title{font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:10px}
.svc-desc{font-size:.88rem;color:var(--muted);line-height:1.65}
.svc-icon{font-size:1.6rem;margin-bottom:14px}

/* ── ABOUT ── */
#about{
  background:var(--bg2);position:relative;overflow:hidden;
}
#about::before{
  content:'';position:absolute;right:-200px;top:-200px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,168,83,.06) 0%,transparent 70%);
  pointer-events:none;
}
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
@media(max-width:860px){.about-layout{grid-template-columns:1fr;gap:48px}}

.about-visual{
  position:relative;
}
.about-card-main{
  background:var(--bg3);border:1px solid var(--border2);border-radius:20px;
  padding:36px;position:relative;z-index:1;
}
.about-avatar{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--gold-dk),var(--gold-lt));
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:1.6rem;font-weight:900;color:#0C0F18;
  margin-bottom:20px;
}
.about-name{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:700;margin-bottom:4px}
.about-role{font-size:.85rem;color:var(--gold);font-weight:500;margin-bottom:16px}
.about-bio-card{font-size:.9rem;color:var(--muted);line-height:1.7}
.about-stats-row{
  display:flex;gap:24px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border);
}
.astat{text-align:center}
.astat-n{font-family:'Fraunces',serif;font-size:1.6rem;font-weight:700;color:var(--gold)}
.astat-l{font-size:.75rem;color:var(--muted);margin-top:2px}

.about-float{
  position:absolute;bottom:-20px;right:-20px;
  background:var(--gold-bg);border:1px solid rgba(212,168,83,.25);
  border-radius:var(--radius);padding:16px 20px;z-index:2;
  backdrop-filter:blur(8px);
}
.about-float-n{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:700;color:var(--gold)}
.about-float-l{font-size:.72rem;color:var(--muted);margin-top:2px}

.about-text .sec-title{font-size:clamp(1.7rem,3vw,2.5rem)}
.about-text p{font-size:.95rem;color:var(--muted);line-height:1.8;margin-top:16px}
.about-features{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:12px}
.about-feat{
  display:flex;align-items:center;gap:12px;
  font-size:.9rem;color:var(--muted);
}
.feat-check{
  width:22px;height:22px;border-radius:6px;
  background:rgba(76,175,132,.1);border:1px solid rgba(76,175,132,.25);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--green);font-size:.75rem;font-weight:700;
}

/* ── PROCESS ── */
#processus{background:var(--bg)}
.process-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;margin-top:56px;position:relative;
}
@media(max-width:768px){.process-grid{grid-template-columns:1fr}}
.process-grid::before{
  content:'';position:absolute;top:36px;left:calc(16.6% + 12px);right:calc(16.6% + 12px);
  height:1px;background:repeating-linear-gradient(90deg,var(--gold-dk) 0,var(--gold-dk) 8px,transparent 8px,transparent 16px);
  opacity:.4;
}
@media(max-width:768px){.process-grid::before{display:none}}

.proc-step{text-align:center;padding:0 16px}
.proc-num{
  width:72px;height:72px;border-radius:50%;
  background:var(--bg2);border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 24px;font-family:'Fraunces',serif;font-size:1.5rem;font-weight:900;
  color:var(--gold);transition:var(--t);position:relative;z-index:1;
}
.proc-step.in .proc-num{
  background:linear-gradient(135deg,var(--gold-dk),var(--gold));color:#0C0F18;
  box-shadow:0 0 0 8px rgba(212,168,83,.1),var(--glow);
}
.proc-step.in .proc-num::after{
  content:'';position:absolute;inset:-6px;border-radius:50%;
  border:1px solid rgba(212,168,83,.2);animation:procRing 2s ease-out;
}
@keyframes procRing{from{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}
.proc-title{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;margin-bottom:10px;color:var(--white)}
.proc-desc{font-size:.88rem;color:var(--muted);line-height:1.65}
.proc-detail{
  margin-top:16px;padding:14px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-sm);
}
.proc-detail-item{
  font-size:.78rem;color:var(--muted2);display:flex;align-items:center;gap:8px;margin-bottom:6px;
}
.proc-detail-item:last-child{margin-bottom:0}
.proc-detail-item::before{content:'→';color:var(--gold);font-size:.8rem}

/* ── COMPARISON ── */
#comparaison{background:var(--bg2)}
.compare-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:56px;
  max-width:860px;margin-left:auto;margin-right:auto;
}
@media(max-width:640px){.compare-grid{grid-template-columns:1fr}}
.cmp-col{}
.cmp-head{
  padding:18px 24px;border-radius:var(--radius) var(--radius) 0 0;
  font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
}
.cmp-head.bad{background:rgba(224,92,92,.1);border:1px solid rgba(224,92,92,.2);color:var(--red)}
.cmp-head.good{background:rgba(76,175,132,.08);border:1px solid rgba(76,175,132,.2);color:var(--green)}
.cmp-body{border-radius:0 0 var(--radius) var(--radius);overflow:hidden}
.cmp-item{
  display:flex;align-items:flex-start;gap:14px;padding:16px 20px;
  background:var(--bg3);border-bottom:1px solid var(--border);font-size:.875rem;color:var(--muted);line-height:1.5;
}
.cmp-item:last-child{border-bottom:none}
.cmp-ic{flex-shrink:0;margin-top:1px;font-size:.9rem}

/* ── TESTIMONIALS ── */
#temoignages{background:var(--bg);overflow:hidden}
.testi-outer{position:relative;margin-top:48px;overflow:hidden}
.testi-outer::before,.testi-outer::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.testi-outer::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.testi-outer::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.testi-scroll{
  display:flex;gap:20px;padding-bottom:4px;
  will-change:transform;
}
.testi-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 28px;flex-shrink:0;width:340px;
  transition:border-color .3s,transform .3s;
}
.testi-card:hover{border-color:var(--border2);transform:translateY(-4px)}
.stars{display:flex;gap:3px;margin-bottom:18px}
.stars span{color:var(--gold);font-size:.95rem}
.testi-text{font-size:.9rem;color:var(--muted);line-height:1.75;margin-bottom:24px;font-style:italic}
.testi-text::before{content:'\201C';font-size:2rem;color:var(--gold);font-family:'Fraunces',serif;line-height:0;vertical-align:-.5rem;margin-right:4px}
.testi-author{display:flex;align-items:center;gap:14px}
.testi-av{
  width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-size:.95rem;font-weight:700;color:#0C0F18;flex-shrink:0;
}
.testi-info{}
.testi-name{font-size:.88rem;font-weight:700;color:var(--white)}
.testi-site{font-size:.78rem;color:var(--gold);margin-top:3px;font-weight:500}
.testi-visitors{font-size:.74rem;color:var(--muted);margin-top:2px}
.testi-badge{
  margin-left:auto;padding:3px 10px;border-radius:50px;
  background:var(--gold-bg);font-size:.7rem;font-weight:600;color:var(--gold);white-space:nowrap;
}

/* ── FAQ ── */
#faq{background:var(--bg2)}
.faq-list{margin-top:48px;display:flex;flex-direction:column;gap:12px}
.faq-item{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  transition:border-color .2s;
}
.faq-item.open{border-color:rgba(212,168,83,.3)}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 28px;text-align:left;
  font-family:'Space Grotesk',sans-serif;font-size:.95rem;font-weight:600;color:var(--white);
  transition:color .2s;
}
.faq-q:hover{color:var(--gold)}
.faq-item.open .faq-q{color:var(--gold)}
.faq-arrow{
  width:28px;height:28px;border-radius:50%;border:1px solid var(--border2);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .3s,background .2s,border-color .2s;color:var(--muted);
}
.faq-item.open .faq-arrow{transform:rotate(45deg);background:var(--gold-bg);border-color:rgba(212,168,83,.3);color:var(--gold)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(.4,0,.2,1);
}
.faq-a-inner{padding:0 28px 22px;font-size:.9rem;color:var(--muted);line-height:1.75}

/* ── PRICING ── */
#tarifs{background:var(--bg)}
.pricing-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:56px;
  max-width:760px;margin-left:auto;margin-right:auto;
}
@media(max-width:640px){.pricing-grid{grid-template-columns:1fr}}
.plan-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:20px;
  padding:36px 32px;position:relative;transition:var(--t);
}
.plan-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.plan-card.popular{
  border-color:rgba(212,168,83,.4);
  background:linear-gradient(160deg,rgba(212,168,83,.07) 0%,var(--bg2) 50%);
}
.plan-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--gold-dk),var(--gold));
  color:#0C0F18;font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 18px;border-radius:50px;white-space:nowrap;
}
.plan-name{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:700;margin-bottom:6px}
.plan-desc{font-size:.85rem;color:var(--muted);margin-bottom:28px}
.plan-price{
  font-family:'Fraunces',serif;font-size:3rem;font-weight:900;color:var(--gold);
  line-height:1;margin-bottom:4px;
}
.plan-price-note{font-size:.78rem;color:var(--muted2);margin-bottom:28px}
.plan-divider{height:1px;background:var(--border);margin-bottom:24px}
.plan-features{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.plan-feat{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;color:var(--muted)}
.plan-feat .ok{color:var(--green);font-weight:700;flex-shrink:0}
.plan-feat .na{color:var(--muted2);flex-shrink:0}

/* ── GUARANTEES ── */
#garanties{
  background:var(--bg2);
  border-top:1px solid var(--border);
}
.guarantees-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;
}
@media(max-width:768px){.guarantees-row{grid-template-columns:1fr;gap:16px}}
.guar-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 24px;text-align:center;transition:var(--t);
}
.guar-card:hover{border-color:rgba(212,168,83,.25);transform:translateY(-4px);box-shadow:var(--glow)}
.guar-icon{
  width:56px;height:56px;border-radius:50%;
  background:var(--gold-bg);border:1px solid rgba(212,168,83,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin:0 auto 20px;
}
.guar-title{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:700;margin-bottom:10px}
.guar-desc{font-size:.88rem;color:var(--muted);line-height:1.65}

/* ── CTA FINAL ── */
#cta-final{
  background:var(--bg);padding:130px 0;
  position:relative;overflow:hidden;text-align:center;
}
.cta-glow{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:700px;height:400px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(212,168,83,.1) 0%,transparent 70%);
  pointer-events:none;
}
.cta-ring{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:500px;height:500px;border-radius:50%;
  border:1px solid rgba(212,168,83,.08);pointer-events:none;
}
.cta-ring-2{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:800px;border-radius:50%;
  border:1px solid rgba(212,168,83,.04);pointer-events:none;
}
.cta-content{position:relative;z-index:1}
.cta-title{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:900;margin-bottom:18px;color:var(--white)}
.cta-title .em{color:var(--gold);font-style:italic}
.cta-sub{font-size:1.05rem;color:var(--muted);max-width:500px;margin:0 auto 40px;line-height:1.75}
.cta-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:16px}
.cta-reassure{
  display:flex;justify-content:center;gap:28px;margin-top:32px;flex-wrap:wrap;
}
.cta-r-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--muted)}
.cta-r-item .dot{width:5px;height:5px;border-radius:50%;background:var(--green);flex-shrink:0}

/* ── FOOTER ── */
footer{
  background:#070A10;border-top:1px solid var(--border);
  padding:56px 0 32px;
}
.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px;
}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

.footer-brand{
  font-family:'Fraunces',serif;font-size:1.3rem;font-weight:700;
  display:flex;align-items:center;gap:10px;margin-bottom:14px;
  letter-spacing:-.01em;
}
.footer-tagline{font-size:.85rem;color:var(--muted);line-height:1.6;margin-bottom:20px}
.footer-social{display:flex;gap:10px}
.social-btn{
  width:36px;height:36px;border-radius:9px;background:var(--surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;color:var(--muted);transition:var(--t);
}
.social-btn:hover{background:var(--gold-bg);border-color:rgba(212,168,83,.3);color:var(--gold)}

.footer-col-title{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);margin-bottom:16px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:.85rem;color:var(--muted);transition:color .2s}
.footer-links a:hover{color:var(--gold)}

.footer-bottom{
  padding-top:24px;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-legal{font-size:.78rem;color:var(--muted2)}
.footer-legal a{color:var(--muted);transition:color .2s}
.footer-legal a:hover{color:var(--white)}

/* ── LANG SWITCHER ── */
.lang-sw{position:relative}
.lang-btn{
  background:var(--surface);border:1px solid var(--border2);
  color:var(--white);padding:8px 16px;border-radius:50px;
  cursor:pointer;font-size:.8rem;font-weight:600;
  display:flex;align-items:center;gap:7px;transition:var(--t);
  font-family:'Space Grotesk',sans-serif;
}
.lang-btn:hover{background:var(--surface2)}
.lang-btn svg{transition:transform .2s}
.lang-sw.open .lang-btn svg{transform:rotate(180deg)}
.lang-menu{
  position:absolute;top:calc(100% + 10px);right:0;
  background:var(--bg2);border:1px solid var(--border2);
  border-radius:var(--radius);padding:8px;min-width:170px;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:opacity .2s,transform .2s,visibility .2s;
  z-index:200;box-shadow:var(--shadow);
}
.lang-sw.open .lang-menu{opacity:1;visibility:visible;transform:none}
.lang-menu a{
  display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-radius:var(--radius-sm);font-size:.83rem;color:var(--muted);
  transition:var(--t);text-decoration:none;
}
.lang-menu a:hover{background:var(--surface);color:var(--white)}
.lang-menu a.current{color:var(--gold);background:var(--gold-bg);font-weight:600}
.lang-flag{font-size:1rem;line-height:1}

/* ── LEGAL PAGES ── */
.legal-wrap{max-width:780px;margin:0 auto;padding:140px 28px 80px}
.legal-title{font-family:'Fraunces',serif;font-size:clamp(2rem,4vw,3rem);font-weight:900;margin-bottom:8px}
.legal-date{font-size:.82rem;color:var(--muted);margin-bottom:48px}
.legal-body h2{font-family:'Fraunces',serif;font-size:1.35rem;font-weight:700;color:var(--gold);margin:36px 0 12px}
.legal-body h3{font-size:1rem;font-weight:700;color:var(--white);margin:20px 0 8px}
.legal-body p{font-size:.92rem;color:var(--muted);line-height:1.8;margin-bottom:12px}
.legal-body ul{list-style:none;margin:0 0 16px;padding:0;display:flex;flex-direction:column;gap:8px}
.legal-body li{font-size:.9rem;color:var(--muted);line-height:1.6;padding-left:18px;position:relative}
.legal-body li::before{content:'—';position:absolute;left:0;color:var(--gold)}
.legal-body a{color:var(--gold);text-decoration:underline;text-underline-offset:3px}

/* ── CONTACT FORM ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:48px}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}
.contact-info{}
.contact-info-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:24px}
.contact-info-icon{width:40px;height:40px;border-radius:10px;background:var(--gold-bg);border:1px solid rgba(212,168,83,.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.contact-info-label{font-size:.78rem;color:var(--muted);margin-bottom:3px}
.contact-info-val{font-size:.9rem;font-weight:600;color:var(--white)}
.contact-form-card{background:var(--bg2);border:1px solid var(--border2);border-radius:20px;padding:36px}
.contact-form-card .fgroup{margin-bottom:18px}
.contact-form-card textarea{
  width:100%;padding:13px 16px;background:var(--surface);border:1.5px solid var(--border);
  border-radius:var(--radius-sm);color:var(--white);font-size:.9rem;outline:none;
  transition:border-color .2s;resize:vertical;min-height:120px;font-family:'Space Grotesk',sans-serif;
}
.contact-form-card textarea:focus{border-color:var(--gold)}
.contact-form-card textarea::placeholder{color:var(--muted2)}
.contact-success{
  text-align:center;padding:32px;display:none;
}
.contact-success.show{display:block}
