:root{
  --bg: #fffaf7;
  --bg2:#f7f2ff;
  --card:#ffffff;
  --ink:#1f1b1a;
  --muted:#6b5f5c;
  --line: rgba(31,27,26,.10);
  --accent:#a97aa9;
  --accent2:#f0b7a4;
  --accent3:#88b8b3;
  --shadow: 0 20px 60px rgba(31,27,26,.10);
  --radius: 18px;
  --radius2: 26px;
  --wrap: 1120px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--ink);
  background:
    radial-gradient(900px 500px at 20% 0%, rgba(240,183,164,.35), transparent 55%),
    radial-gradient(900px 500px at 80% 10%, rgba(169,122,169,.25), transparent 55%),
    radial-gradient(900px 500px at 40% 90%, rgba(136,184,179,.25), transparent 55%),
    var(--bg);
}
a{color:inherit}
img{max-width:100%; display:block}
.wrap{max-width:var(--wrap); margin:0 auto; padding:0 20px}
.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip:focus{left:20px; top:20px; width:auto; height:auto; background:#fff; padding:10px 12px; border-radius:12px; box-shadow:var(--shadow); z-index:999}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  background: rgba(169,122,169,.14);
  border: 1px solid rgba(169,122,169,.25);
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
}
.top-offer{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,250,247,.88);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.top-offer__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:10px 0}
.top-offer__left{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
.top-offer__text{font-size:14px; color:var(--muted)}
.header{
  position: sticky;
  top: 50px;
  z-index: 40;
  background: rgba(255,250,247,.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 0}
.brand{display:flex; align-items:center; gap:10px}
.brand__mark{
  width:40px; height:40px; border-radius:14px;
  background: linear-gradient(135deg, rgba(240,183,164,.55), rgba(169,122,169,.35));
  display:grid; place-items:center;
  box-shadow: 0 10px 25px rgba(169,122,169,.18);
  border: 1px solid rgba(169,122,169,.20);
}
.brand__name{font-weight:700; letter-spacing:.2px}
.brand__tag{font-size:12px; color:var(--muted)}
.nav{display:flex; gap:18px; align-items:center}
.nav a{
  text-decoration:none;
  font-size:14px;
  color:var(--muted);
  padding:8px 10px;
  border-radius:999px;
}
.nav a:hover{background: rgba(31,27,26,.04); color:var(--ink)}
.header__cta{display:flex; gap:10px; align-items:center}

.btn-landing,
.btn-landing-partenaire,
#btn-desabonnement,
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  text-decoration:none;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 600;
  font-size: 14px;
  border: 1px solid transparent;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
  white-space:nowrap;
}
.btn:active{transform: translateY(1px)}

.btn-landing,
.btn-landing-partenaire,
#btn-desabonnement,
.btn--solid{
  background: linear-gradient(135deg, rgba(169,122,169,.95), rgba(240,183,164,.95));
  color:#1a1312;
  border-color: rgba(169,122,169,.25);
  box-shadow: 0 18px 40px rgba(169,122,169,.18);
}
.btn--solid:hover{box-shadow: 0 22px 55px rgba(169,122,169,.22)}
.btn--ghost{
  background: rgba(255,255,255,.60);
  border-color: rgba(31,27,26,.12);
}
.btn--ghost:hover{background: rgba(255,255,255,.85)}
.btn--lg{padding: 12px 18px; font-size:15px}
.btn--full{width:100%}
.hero{padding: 44px 0 10px}
.hero__inner{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items:start;
}
.eyebrow{margin:0 0 10px; color:var(--muted); font-weight:600}
h1,h2,h3{font-family: Fraunces, ui-serif, Georgia, serif; letter-spacing:-.2px}
h1{font-size: 46px; line-height:1.05; margin: 0 0 14px}
.lead{font-size: 18px; color: var(--muted); line-height:1.65; margin:0 0 18px}
.hero__stats{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap:12px;
  margin: 18px 0 20px;
}
.stat{
  background: rgba(255,255,255,.60);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px 14px;
}
.stat__num{font-weight:700}
.stat__label{font-size: 12px; color: var(--muted); margin-top: 6px}
.hero__actions{display:flex; gap:10px; flex-wrap:wrap}
.fineprint{margin:12px 0 0; font-size:12px; color:var(--muted)}
.hero__media{display:flex; flex-direction:column; gap:14px}
.portrait{
  position:relative;
  background: rgba(255,255,255,.55);
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  overflow:hidden;
  box-shadow: var(--shadow);
}
.portrait img{width:100%; height:auto}
.portrait__badge{
  position:absolute;
  left: 14px;
  bottom: 14px;
  right: 14px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(31,27,26,.12);
  border-radius: 18px;
  padding: 12px 12px;
  backdrop-filter: blur(10px);
}
.badge__title{font-weight:800}
.badge__meta{font-size:12px; color:var(--muted); margin-top:4px}
.soft-card{
  background: rgba(255,255,255,.60);
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  padding: 16px 16px;
}
.soft-card__title{font-weight:800; margin-bottom:8px}
.checklist{margin:0; padding-left: 18px; color: var(--muted); line-height:1.7}
.section{padding: 56px 0}
.section--alt{
  background:
    radial-gradient(700px 420px at 10% 20%, rgba(240,183,164,.22), transparent 60%),
    radial-gradient(700px 420px at 90% 40%, rgba(136,184,179,.18), transparent 60%),
    rgba(255,255,255,.35);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.section__head{margin-bottom: 18px}
.section__head h2{margin:0 0 8px; font-size:34px}
.muted{color:var(--muted)}
.lead2{font-size:16px; color:var(--muted); line-height:1.7}
.grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 18px;
}
.card{
  background: rgba(255,255,255,.72);
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  padding: 18px 16px;
  box-shadow: 0 14px 35px rgba(31,27,26,.07);
}
.card h3{margin:0 0 8px; font-size:22px}
.card p{margin:0; color:var(--muted); line-height:1.6}
.card__meta{margin-top:12px; font-size:12px; color:rgba(107,95,92,.9)}
.offer{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items:center;
}
.offer__card{
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(169,122,169,.22);
  border-radius: var(--radius2);
  padding: 18px 18px;
  box-shadow: var(--shadow);
}
.price{display:flex; align-items:flex-end; gap:12px}
.price__big{font-family:Fraunces, serif; font-size:52px; line-height:1}
.price__small{color:var(--muted); font-weight:700; padding-bottom:6px}
.offer__note{color:var(--muted); margin: 10px 0 14px}
.offer__bullets{display:grid; gap:10px; margin-top: 14px}
.bullet{display:flex; align-items:center; gap:10px; color:var(--muted)}
.dot{width:10px; height:10px; border-radius:999px; background: linear-gradient(135deg, var(--accent2), var(--accent))}
.cta-band{
  margin-top: 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 16px 16px;
  border-radius: var(--radius2);
  border: 1px solid rgba(31,27,26,.10);
  background: rgba(255,255,255,.60);
}
.cta-band__title{font-weight:800}
.cta-band__sub{font-size:13px; color:var(--muted); margin-top:4px}
.two-col{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items:start;
}
.quote{
  background: rgba(255,255,255,.70);
  border: 1px solid var(--line);
  border-radius: var(--radius2);
  padding: 18px 16px;
  box-shadow: 0 14px 35px rgba(31,27,26,.08);
}
.quote__mark{font-family:Fraunces, serif; font-size:54px; line-height:1; color:rgba(169,122,169,.75)}
.quote__text{margin: 6px 0 12px; color:var(--ink); font-size:16px; line-height:1.7}
.quote__by{color:var(--muted); font-weight:700; margin-bottom: 12px}
.quote__actions{display:flex; gap:10px; flex-wrap:wrap}
.steps{display:grid; grid-template-columns: repeat(3,1fr); gap:14px; margin-top: 18px}
.step{
  background: rgba(255,255,255,.70);
  border:1px solid var(--line);
  border-radius: var(--radius2);
  padding: 16px 16px;
  display:flex; gap:12px; align-items:flex-start;
}
.step__num{
  width:36px; height:36px; border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(136,184,179,.22);
  border: 1px solid rgba(136,184,179,.35);
  font-weight: 800;
}
.step__title{font-weight:800; margin-bottom:6px}
.step__text{color:var(--muted); line-height:1.6; font-size:14px}
.center{text-align:center; margin-top: 18px}
.footer-cta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding: 6px 0;
}
.footer{padding: 26px 0 30px}
.footer__inner{border-top: 1px solid var(--line); padding-top: 22px}
.footer__cols{display:grid; grid-template-columns: 1.2fr .8fr 1fr; gap:16px}
.footer__title{font-weight:800; margin-bottom:8px}
.footer__link{text-decoration:none; font-weight:700}
.footer__link:hover{text-decoration:underline}
.footer__bottom{display:flex; justify-content:space-between; gap:12px; flex-wrap:wrap; margin-top: 18px}
.small{font-size:12px}
.brand--footer .brand__mark{width:34px; height:34px}
@media (max-width: 980px){
  .nav{display:none}
  .hero__inner, .offer, .two-col{grid-template-columns: 1fr}
  h1{font-size: 40px}
  .grid{grid-template-columns: repeat(2,1fr)}
  .steps{grid-template-columns: 1fr}
  .footer__cols{grid-template-columns: 1fr}
  .header{top: 48px}
}
@media (max-width: 520px){
  h1{font-size: 34px}
  .hero__stats{grid-template-columns: 1fr}
  .grid{grid-template-columns: 1fr}
  .header__cta{display:none}
}
