:root{
  --paper:#FBFAF7;
  --paper-2:#F3F1EC;
  --card:#FFFFFF;
  --ink:#111111;
  --ink-2:#3A3A38;
  --muted:#6A6A66;
  --muted-2:#9A9A95;
  --line:#E7E4DD;
  --line-2:#D9D5CC;
  --red:#E11C12;
  --red-soft:#FDEBEA;
  --red-deep:#B5140C;
  --green:#0E9F6E;
  --display:'Schibsted Grotesk',sans-serif;
  --body:'Hanken Grotesk',sans-serif;
  --r:16px;
  --shadow:0 1px 2px rgba(17,17,17,.04),0 12px 30px -18px rgba(17,17,17,.18);
  --shadow-lg:0 2px 4px rgba(17,17,17,.05),0 30px 60px -28px rgba(17,17,17,.28);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--ink);color:var(--paper)}
a{color:inherit}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-size:.8rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;color:var(--red);
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--red);border-radius:2px}
h1,h2,h3,h4{font-family:var(--display);font-weight:800;letter-spacing:-.02em;line-height:1.06}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--body);font-weight:700;font-size:1rem;
  text-decoration:none;cursor:pointer;border:none;
  padding:15px 26px;border-radius:12px;
  transition:transform .15s,box-shadow .2s,background-color .2s,color .2s,border-color .2s;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 24px -10px rgba(225,28,18,.6)}
.btn-primary:hover{background:var(--red-deep);transform:translateY(-1px);box-shadow:0 14px 30px -10px rgba(225,28,18,.7)}
.btn-dark{background:var(--ink);color:var(--paper)}
.btn-dark:hover{transform:translateY(-1px);background:#000}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--ink)}

/* ---------- top bar ---------- */
.topbar{
  background:var(--ink);color:var(--paper);
  font-size:.84rem;font-weight:500;
  text-align:center;padding:9px 16px;
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.topbar b{color:#fff;font-weight:700}
.topbar .star{color:var(--red);font-weight:700}

/* ---------- nav ---------- */
nav{position:sticky;top:0;z-index:100;background:rgba(251,250,247,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 28px;height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:40px;width:auto;display:block}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:.96rem;font-weight:600;color:var(--ink-2);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .login{font-size:.96rem;font-weight:600;text-decoration:none;color:var(--ink)}
.nav-cta .login:hover{color:var(--red)}
.nav-cta .btn{padding:11px 20px;font-size:.95rem}

/* ---------- hero ---------- */
.hero{position:relative;padding:48px 0 66px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.badge-soft{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--card);border:1px solid var(--line);
  border-radius:99px;padding:7px 8px 7px 16px;
  font-size:.85rem;font-weight:600;color:var(--ink-2);
  box-shadow:var(--shadow);margin-bottom:28px;
}
.badge-soft .tag{background:var(--red-soft);color:var(--red-deep);font-weight:700;font-size:.76rem;padding:4px 11px;border-radius:99px}
.hero h1{font-size:clamp(2.7rem,5vw,4.3rem);margin-bottom:24px}
.hero h1 .rot{color:var(--red);display:inline-block}
.hero .sub{font-size:1.22rem;color:var(--muted);max-width:540px;margin-bottom:34px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.hero-proof{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.avatars{display:flex}
.avatars span{
  width:40px;height:40px;border-radius:50%;border:2.5px solid var(--paper);
  margin-left:-12px;background:var(--paper-2);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--ink-2);
}
.avatars span:first-child{margin-left:0}
.avatars span.more{background:var(--ink);color:var(--paper);font-size:.78rem}
.proof-text .stars{color:var(--red);letter-spacing:1px;font-size:.95rem}
.proof-text .stars svg{width:15px;height:15px;display:inline-block;vertical-align:-2px}
.proof-text small{display:block;color:var(--muted);font-size:.86rem;font-weight:500}
.proof-text b{font-weight:700}

/* hero visual card */
.hero-card{
  position:relative;background:var(--card);border:1px solid var(--line);
  border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden;
}
.hero-card .hc-top{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.hero-card .hc-top .pair{font-weight:700;font-size:.95rem;display:flex;align-items:center;gap:9px}
.hero-card .hc-top .pair i{width:9px;height:9px;border-radius:50%;background:var(--red);display:inline-block}
.hero-card .hc-top .chg{font-family:var(--display);font-weight:800;color:#0E9F6E;background:#E6F6EF;border-radius:8px;padding:3px 10px;font-size:.9rem}
.hero-card .hc-chart{padding:20px 22px 8px}
.hero-card svg{display:block;width:100%;height:auto}
.hero-card .hc-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line)}
.hero-card .hc-stats div{padding:16px 18px;border-right:1px solid var(--line)}
.hero-card .hc-stats div:last-child{border-right:none}
.hero-card .hc-stats .k{font-size:.74rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.hero-card .hc-stats .v{font-family:var(--display);font-weight:800;font-size:1.15rem;margin-top:3px}
.hero-float{
  position:absolute;background:var(--card);border:1px solid var(--line);
  box-shadow:var(--shadow);border-radius:14px;padding:12px 16px;
  display:flex;align-items:center;gap:11px;font-weight:600;font-size:.9rem;
}
.hero-float .ic{width:34px;height:34px;border-radius:9px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center}
.hero-float .ic svg{width:18px;height:18px}
/* VSL video placeholder */
.vsl{display:block;cursor:pointer}
.vsl-frame{
  position:relative;aspect-ratio:16/10;width:100%;
  border-radius:22px;overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow-lg);
  background:
    radial-gradient(130% 120% at 70% 0,rgba(225,28,18,.10),transparent 55%),
    linear-gradient(155deg,#1A1A1A,#0C0C0C);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  transition:transform .25s,box-shadow .25s;
}
.vsl:hover .vsl-frame{transform:translateY(-3px);box-shadow:0 2px 4px rgba(17,17,17,.06),0 40px 70px -30px rgba(17,17,17,.4)}
.vsl-tag{
  position:absolute;top:16px;left:16px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.16);border-radius:99px;
  padding:6px 13px;font-size:.78rem;font-weight:700;color:#fff;letter-spacing:.02em;
}
.vsl-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 0 rgba(225,28,18,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(225,28,18,.6)}70%{box-shadow:0 0 0 9px rgba(225,28,18,0)}100%{box-shadow:0 0 0 0 rgba(225,28,18,0)}}
.vsl-play{
  width:78px;height:78px;border-radius:50%;border:none;cursor:pointer;
  background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 34px -8px rgba(225,28,18,.7);
  transition:transform .2s,background-color .2s;z-index:2;
}
.vsl-play svg{width:30px;height:30px;margin-left:4px}
.vsl:hover .vsl-play{transform:scale(1.08);background:var(--red-deep)}
.vsl-cap{text-align:center;z-index:2;padding:0 28px;display:flex;flex-direction:column;gap:6px}
.vsl-cap .pl{font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.vsl-cap .hint{font-size:.86rem;color:rgba(255,255,255,.5);max-width:300px;margin:0 auto}
.hero-float.f1{top:-20px;right:-18px;animation:floaty 5s ease-in-out infinite}
.hero-float.f2{bottom:-20px;left:-22px;animation:floaty 6s ease-in-out infinite reverse}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.hc-draw{stroke-dasharray:600;stroke-dashoffset:600;animation:draw 1.8s ease .3s forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ---------- trust band ---------- */
.trust{background:#00b67a}
.trust-inner{padding:18px 0;display:flex;align-items:center;gap:14px 40px;flex-wrap:wrap;justify-content:center}
.trust .lab{font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85)}
/* Trustpilot native rating */
.tp{display:flex;align-items:center;gap:16px;text-decoration:none;color:#fff;flex-wrap:wrap;justify-content:center}
.tp-logo{display:inline-flex;align-items:center;gap:7px;font-family:var(--display);font-weight:700;font-size:1.05rem;color:#fff}
.tp-logo svg{width:20px;height:20px;color:#fff}
.tp-label{font-family:var(--display);font-weight:800;font-size:1.02rem;color:#fff}
.tp-stars{display:inline-flex;gap:4px}
.tp-stars i{display:inline-flex;align-items:center;justify-content:center}
.tp-stars i svg{width:24px;height:24px;color:#fff}
.tp-meta{font-size:.92rem;color:rgba(255,255,255,.92);font-weight:500}
.tp-meta b{color:#fff;font-weight:700}
.tp:hover .tp-label{text-decoration:underline}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,.8,.3,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}

/* ---------- sections ---------- */
section.block{padding:96px 0}
.sec-head{max-width:680px}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(2rem,3.6vw,3rem);margin-bottom:16px}
.sec-head p{font-size:1.12rem;color:var(--muted)}
.sec-head h2 .red{color:var(--red)}

/* ---------- écosystème (alternance) ---------- */
.eco{display:flex;flex-direction:column;gap:34px;margin-top:60px}
.eco-row{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.eco-row:nth-child(even) .eco-media{order:-1}
.eco-num{font-family:var(--display);font-weight:800;font-size:.92rem;color:var(--red);letter-spacing:.06em;margin-bottom:14px}
.eco-text h3{font-size:1.7rem;margin-bottom:14px}
.eco-text p{color:var(--muted);font-size:1.06rem;margin-bottom:20px}
.eco-list{list-style:none;display:flex;flex-direction:column;gap:11px}
.eco-list li{display:flex;gap:11px;align-items:flex-start;font-weight:500;font-size:1rem}
.eco-list li svg{width:20px;height:20px;color:var(--red);flex-shrink:0;margin-top:3px}

/* ---------- programme / modules ---------- */
.cur-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:26px}
.cur-stats .cs{display:inline-flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:99px;padding:9px 18px;font-weight:600;font-size:.92rem;box-shadow:var(--shadow)}
.cur-stats .cs svg{width:17px;height:17px;color:var(--red)}
.curriculum{max-width:920px;margin:52px auto 0;display:flex;flex-direction:column;gap:14px}
.module{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:box-shadow .2s,border-color .2s}
.module[open]{border-color:var(--line-2);box-shadow:var(--shadow)}
.module>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:18px;padding:20px 22px}
.module>summary::-webkit-details-marker{display:none}
.module .mod-num{flex-shrink:0;width:46px;height:46px;border-radius:12px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:1.2rem;transition:background-color .2s}
.module[open] .mod-num{background:var(--red)}
.module .mod-head{flex:1;min-width:0}
.module .mod-k{display:block;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.module .mod-t{display:block;font-family:var(--display);font-weight:800;font-size:1.14rem;line-height:1.22}
.module .mod-meta{flex-shrink:0;display:flex;align-items:center;gap:14px}
.module .mod-count{font-size:.84rem;color:var(--muted);font-weight:600;white-space:nowrap}
.module .mod-chev{width:30px;height:30px;border-radius:8px;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--red);transition:transform .3s,background-color .2s}
.module[open] .mod-chev{transform:rotate(180deg);background:var(--red);color:#fff}
.module .mod-chev svg{width:16px;height:16px}
.module .parts{padding:2px 22px 18px 86px;display:flex;flex-direction:column}
.module .part{display:flex;align-items:center;gap:13px;padding:12px 0;border-top:1px solid var(--line)}
.module .part .pi{flex-shrink:0;width:28px;height:28px;border-radius:8px;background:var(--red-soft);color:var(--red-deep);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:.84rem}
.module .part .pt{flex:1;font-weight:500;font-size:.98rem}
.module .part .pl{font-size:.72rem;color:#0E9F6E;font-weight:700;background:#E6F6EF;padding:3px 10px;border-radius:99px;white-space:nowrap}
@media(max-width:600px){
  .module>summary{gap:13px;padding:16px}
  .module .mod-num{width:40px;height:40px;font-size:1.05rem}
  .module .mod-count{display:none}
  .module .parts{padding:2px 16px 16px 16px}
  .module .part .pl{display:none}
}
/* placeholder image */
.ph{
  position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  background:
    radial-gradient(120% 120% at 100% 0,rgba(225,28,18,.06),transparent 45%),
    repeating-linear-gradient(45deg,rgba(17,17,17,.018) 0 14px,transparent 14px 28px),
    var(--paper-2);
  min-height:330px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  text-align:center;padding:30px;box-shadow:var(--shadow);
}
.ph::before,.ph::after{content:"";position:absolute;width:20px;height:20px;border:2px solid var(--red);opacity:.5}
.ph::before{top:14px;left:14px;border-right:0;border-bottom:0}
.ph::after{bottom:14px;right:14px;border-left:0;border-top:0}
.ph .ico{width:46px;height:46px;color:var(--red);opacity:.85}
.ph .ico svg{width:100%;height:100%}
.ph .pl{font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.ph .hint{font-size:.88rem;color:var(--muted-2);max-width:280px}

/* ---------- programmes ---------- */
#programmes{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:58px;align-items:stretch}
.plan{
  position:relative;background:var(--card);border:1px solid var(--line);border-radius:20px;
  padding:34px 30px;display:flex;flex-direction:column;box-shadow:var(--shadow);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.plan:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.plan.featured{border-color:var(--red);box-shadow:0 30px 60px -30px rgba(225,28,18,.4)}
.plan .ribbon{position:absolute;top:-13px;left:30px;background:var(--red);color:#fff;font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;padding:6px 14px;border-radius:99px}
.plan .lvl{font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.plan h3{font-size:1.6rem;margin-bottom:8px}
.plan .desc{color:var(--muted);font-size:.96rem;margin-bottom:24px;min-height:48px}
.plan .price{display:flex;align-items:baseline;gap:7px;padding-bottom:22px;margin-bottom:22px;border-bottom:1px solid var(--line)}
.plan .price .amt{font-family:var(--display);font-weight:800;font-size:2.7rem;letter-spacing:-.03em}
.plan .price .per{color:var(--muted);font-weight:600;font-size:.95rem}
.plan .price .amt.sm{font-size:1.6rem;color:var(--red)}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:30px;flex:1}
.plan li{display:flex;gap:11px;align-items:flex-start;font-size:.97rem;font-weight:500}
.plan li svg{width:18px;height:18px;color:var(--red);flex-shrink:0;margin-top:3px}
.plan li.off{color:var(--muted-2)}
.plan li.off svg{color:var(--muted-2)}
.plan .btn{width:100%}
.plan .btn.disabled{background:var(--paper-2);color:var(--muted-2);border:1px solid var(--line-2);cursor:not-allowed;box-shadow:none}
.plan .ps{text-align:center;font-size:.8rem;color:var(--muted);margin-top:13px}
.plan .more-link{display:inline-flex;align-items:center;justify-content:center;gap:7px;width:100%;margin-top:10px;font-weight:700;font-size:.92rem;color:var(--ink);text-decoration:none;padding:9px;border-radius:10px;transition:color .2s,background-color .2s}
.plan .more-link svg{width:15px;height:15px;transition:transform .2s}
.plan .more-link:hover{color:var(--red)}
.plan .more-link:hover svg{transform:translateX(3px)}

/* ---------- experts ---------- */
.experts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:58px}
.expert{background:var(--card);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.expert:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.expert .ph{border:0;border-radius:0;border-bottom:1px solid var(--line);min-height:280px}
.expert .ex-body{padding:24px 26px 28px}
.expert .ex-name{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}
.expert h3{font-size:1.3rem}
.expert .ex-spec{font-size:.82rem;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}
.expert p{color:var(--muted);font-size:.95rem;margin-bottom:16px}
.expert .cred{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;font-weight:600;color:var(--ink-2);background:var(--paper-2);border:1px solid var(--line);border-radius:99px;padding:6px 12px}
.expert .cred svg{width:15px;height:15px;color:var(--red)}

/* ---------- résultats / stats ---------- */
#chiffres{background:var(--ink);color:var(--paper)}
#chiffres .eyebrow{color:#FF6A60}
#chiffres .eyebrow::before{background:#FF6A60}
#chiffres .sec-head h2{color:var(--paper)}
#chiffres .sec-head p{color:rgba(251,250,247,.65)}
.kpi{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:54px}
.kpi .item{border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:30px 26px;background:rgba(255,255,255,.03)}
.kpi .n{font-family:var(--display);font-weight:800;font-size:clamp(2.2rem,3.6vw,3rem);color:#fff;line-height:1}
.kpi .l{color:rgba(251,250,247,.65);font-size:.92rem;margin-top:10px;font-weight:500}

/* ---------- avis ---------- */
.rating-line{display:flex;align-items:center;gap:14px;margin-top:24px}
.rating-line .stars{color:var(--red)}
.rating-line .stars svg{width:20px;height:20px}
.rating-line .sc{font-family:var(--display);font-weight:800;font-size:1.3rem}
.rating-line .mt{color:var(--muted);font-weight:500;font-size:.95rem}
.reviews{columns:3;column-gap:24px;margin-top:50px}
.review{break-inside:avoid;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:26px;margin-bottom:24px;box-shadow:var(--shadow)}
.review .stars{color:#00b67a;margin-bottom:14px}
.review .stars svg{width:16px;height:16px}
.review p{font-size:1rem;font-weight:500;margin-bottom:18px}
.review .who{display:flex;align-items:center;gap:12px}
.review .av{width:42px;height:42px;border-radius:50%;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;color:var(--ink-2)}
.review .who .nm{font-weight:700;font-size:.93rem}
.review .who .rl{font-size:.8rem;color:var(--muted)}
.reviews-marquee{margin-top:42px;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 5%,#000 95%,transparent 100%)}
.reviews-track{display:flex;gap:30px;width:max-content;animation:reviews-scroll 75s linear infinite}
.reviews-track + .reviews-track{margin-top:30px}
.reviews-track.reverse{animation-direction:reverse}
.reviews-marquee:hover .reviews-track{animation-play-state:paused}
@keyframes reviews-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.reviews-marquee .review{flex:0 0 370px;width:370px;margin-bottom:0;display:flex;flex-direction:column}
.reviews-marquee .review .stars{display:flex;gap:3px}
.reviews-marquee .review .stars svg{width:19px;height:19px}
.reviews-marquee .review p{font-size:1.08rem;line-height:1.5;flex:1}
.reviews-marquee .review .av{width:46px;height:46px;font-size:1.1rem}
.tp-cta{margin-top:24px;text-align:center}
.proof-block{margin-top:46px;padding-top:46px;border-top:1px solid var(--line)}
.proof-stack{margin-bottom:clamp(36px,5vw,48px)}
.proof-stack .proof-block{margin-top:0;padding-top:0;border-top:0}
.proof-stack .proof-block + .proof-block{margin-top:38px;padding-top:38px;border-top:1px solid var(--line)}
.booking-bundle{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--card);box-shadow:var(--shadow)}
.booking-intro{padding:clamp(28px,4vw,42px) clamp(24px,4vw,42px) 26px}
.booking-intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,40px);align-items:center}
.booking-intro h2{font-size:clamp(1.9rem,3vw,2.6rem);margin-bottom:12px}
.booking-intro h2 .red{color:var(--red)}
.booking-intro p{color:var(--muted);font-size:1.1rem;margin-bottom:22px;max-width:640px}
.booking-intro .call-points{margin-bottom:0}
.booking-intro-photo img{display:block;width:100%;height:min(300px,36vw);min-height:220px;object-fit:cover;object-position:center top;border-radius:16px;border:1px solid var(--line)}
.booking-bundle > .booking{margin-top:0;border:0;border-radius:0;box-shadow:none;border-top:1px solid var(--line)}
.call-card-booking{padding:0;background:transparent;border:0;box-shadow:none}
.proof-head{text-align:center;max-width:640px;margin:0 auto 32px}
.proof-head .eyebrow{justify-content:center}
.proof-head h3{font-family:var(--display);font-weight:800;font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:10px}
.proof-head p{color:var(--muted);font-size:1rem}
.proof-block + .proof-block{margin-top:38px;padding-top:38px}
.call-card > .booking:not(.booking-bundle .booking){margin-top:46px;padding-top:46px;border-top:1px solid var(--line)}
.proof-head h3 .red{color:var(--red)}
.payouts-head{text-align:center;max-width:640px;margin:0 auto}
.payouts-head h4{font-family:var(--display);font-weight:800;font-size:1.5rem;margin-bottom:8px}
.payouts-head p{color:var(--muted);font-size:1rem}
.payouts{margin-top:26px;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%)}
.payouts-track{display:flex;gap:18px;width:max-content;animation:payouts-scroll 55s linear infinite}
.payouts-track + .payouts-track{margin-top:18px}
.payouts-track.reverse{animation-direction:reverse;animation-duration:68s}
.payouts:hover .payouts-track{animation-play-state:paused}
@keyframes payouts-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.payout{flex:0 0 auto;height:215px;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow)}
.payout img{display:block;height:100%;width:auto}
@media(prefers-reduced-motion:reduce){.reviews-track,.payouts-track{animation:none}}
@media(max-width:560px){
  .reviews-marquee .review{flex:0 0 248px;width:248px;padding:18px;border-radius:14px}
  .reviews-marquee .review .stars svg{width:14px;height:14px}
  .reviews-marquee .review p{font-size:.84rem;margin-bottom:14px}
  .reviews-marquee .review .av{width:34px;height:34px;font-size:.9rem}
  .reviews-track{gap:16px}
  .reviews-track + .reviews-track{margin-top:16px}
  .payout{height:150px}
  .payouts-head h4{font-size:1.25rem}
}
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.res{background:var(--card);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s;text-decoration:none;color:inherit;display:block}
.res:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.res .ph{border:0;border-radius:0;border-bottom:1px solid var(--line);min-height:170px}
.res .rb{padding:22px 24px 26px}
.res .tagline{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.res h3{font-size:1.18rem;line-height:1.25;margin-bottom:10px}
.res .more{font-weight:700;font-size:.9rem;color:var(--ink);display:inline-flex;align-items:center;gap:6px}
.res .more svg{width:15px;height:15px}

/* ---------- appel / cta ---------- */
.cta-call{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.call-card{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:50px;box-shadow:var(--shadow-lg)}
.call-card h2{font-size:clamp(1.9rem,3vw,2.6rem);margin-bottom:14px}
.call-card p{color:var(--muted);font-size:1.1rem;margin-bottom:26px}
.call-intro{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;margin-bottom:42px}
.call-actions{display:flex;gap:14px;flex-wrap:wrap}
.call-card-solo{text-align:center;max-width:680px;margin:0 auto}
.call-card-solo .eyebrow{justify-content:center}
.call-card-solo p{max-width:480px;margin-left:auto;margin-right:auto;margin-bottom:0}
.btn-cta-groupe{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  width:100%;max-width:520px;margin:34px auto 0;
  padding:22px 30px;font-size:1.2rem;border-radius:16px;
}
.btn-cta-groupe .cta-groupe-label{font-weight:800;letter-spacing:-.01em}
.btn-cta-groupe .cta-groupe-price{display:flex;align-items:baseline;gap:4px;font-size:1rem;font-weight:600;opacity:.95}
.btn-cta-groupe .cta-groupe-price strong{font-family:var(--display);font-size:1.65rem;font-weight:800;letter-spacing:-.03em}
@media(max-width:480px){
  .btn-cta-groupe{flex-direction:column;gap:6px;padding:20px 24px;text-align:center}
  .btn-cta-groupe .cta-groupe-price strong{font-size:1.5rem}
}
.call-points{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:0}
.call-points li{display:flex;gap:11px;align-items:flex-start;font-weight:600;font-size:1rem}
.call-points li svg{width:20px;height:20px;color:var(--red);flex-shrink:0;margin-top:3px}
.call-photo img{display:block;width:100%;height:300px;object-fit:cover;object-position:center top;border-radius:16px;border:1px solid var(--line)}
.booking{background:var(--paper-2);border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.booking-head{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;background:var(--ink);color:var(--paper)}
.booking-head .bk-title{font-family:var(--display);font-weight:800;font-size:1.05rem}
.booking-head .bk-tz{font-size:.78rem;color:rgba(251,250,247,.7);text-align:right}
.cal-embed{width:100%;height:auto;max-height:640px;overflow-y:auto;overflow-x:hidden;background:var(--card);-webkit-overflow-scrolling:touch}
.cal-embed>div{width:100%}
.cal-embed iframe{width:100%!important;border:0}
@media(max-width:820px){.call-intro{grid-template-columns:1fr;gap:30px}.call-photo img{height:260px}.cal-embed{max-height:560px}.booking-intro-grid{grid-template-columns:1fr}.booking-intro-photo img{height:260px;min-height:0}}

/* ---------- faq ---------- */
.faq{max-width:820px;margin:50px auto 0;display:flex;flex-direction:column;gap:14px}
details{background:var(--card);border:1px solid var(--line);border-radius:14px;transition:box-shadow .2s,border-color .2s}
details[open]{border-color:var(--line-2);box-shadow:var(--shadow)}
summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:22px 24px;font-family:var(--display);font-weight:700;font-size:1.12rem}
summary::-webkit-details-marker{display:none}
summary .pl{flex-shrink:0;width:30px;height:30px;border-radius:8px;background:var(--paper-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--red);font-size:1.2rem;font-weight:700;transition:transform .3s,background-color .2s}
details[open] summary .pl{transform:rotate(45deg);background:var(--red);color:#fff}
details .ans{padding:0 24px 24px;color:var(--muted)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(251,250,247,.7);padding:70px 0 34px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:46px;border-bottom:1px solid rgba(255,255,255,.12)}
.foot-brand img{height:42px;margin-bottom:18px}
.foot-brand p{font-size:.95rem;max-width:300px;margin-bottom:20px}
.foot-brand .social{display:flex;gap:10px}
.foot-brand .social a{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:var(--paper);transition:background-color .2s,border-color .2s}
.foot-brand .social a:hover{background:var(--red);border-color:var(--red)}
.foot-brand .social svg{width:18px;height:18px}
.foot-tp{display:inline-flex;align-items:center;gap:11px;margin-top:22px;text-decoration:none;color:var(--paper)}
.foot-tp .ftp-stars{display:inline-flex;gap:2px}
.foot-tp .ftp-stars i{width:22px;height:22px;background:#00b67a;display:inline-flex;align-items:center;justify-content:center;border-radius:3px}
.foot-tp .ftp-stars i svg{width:15px;height:15px;color:#fff}
.foot-tp .ftp-logo{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:700;font-size:.98rem}
.foot-tp .ftp-logo svg{width:17px;height:17px;color:#00b67a}
.foot-tp .ftp-meta{font-size:.82rem;color:rgba(251,250,247,.6);font-weight:500}
.foot-tp:hover .ftp-logo{text-decoration:underline}
.foot-col h4{font-family:var(--display);font-size:.84rem;letter-spacing:.08em;text-transform:uppercase;color:var(--paper);margin-bottom:16px}
.foot-col a{display:block;font-size:.95rem;color:rgba(251,250,247,.7);text-decoration:none;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{padding-top:28px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.85rem}
.foot-bottom .links{display:flex;gap:22px;flex-wrap:wrap}
.foot-bottom a{color:rgba(251,250,247,.7);text-decoration:none}
.foot-bottom a:hover{color:#fff}
.risk{margin-top:26px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-size:.78rem;line-height:1.7;color:rgba(251,250,247,.45)}

/* ---------- sous-pages (page hero / contenus) ---------- */
.page-hero{padding:54px 0 60px;background:var(--paper-2);border-bottom:1px solid var(--line)}
.page-hero-groupe{padding:44px 0 56px}
.page-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center}
.page-hero-groupe .page-hero-grid{grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,56px);align-items:center}
.page-hero-groupe .page-hero-copy{display:flex;flex-direction:column;justify-content:center;max-width:540px}
.page-hero-groupe h1{font-size:clamp(2rem,3.8vw,3.1rem);margin-bottom:16px;line-height:1.08}
.page-hero-groupe .lead{font-size:1.08rem;margin-bottom:22px;line-height:1.55}
.page-hero-groupe .hero-cta-stack{margin-bottom:20px}
.page-hero-groupe .price-tag{margin-bottom:14px}
.page-hero-groupe .price-tag .amt{font-size:2.4rem}
.page-hero-groupe .pill-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:0;margin-top:4px}
.page-hero-groupe .pill{font-size:.8rem;padding:7px 12px;justify-content:flex-start}
.page-hero-groupe .pill svg{width:14px;height:14px;flex-shrink:0}
.back-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:.92rem;color:var(--muted);text-decoration:none;margin-bottom:22px;transition:color .2s}
.back-link:hover{color:var(--red)}
.back-link svg{width:16px;height:16px}
.page-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.8rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:16px}
.page-eyebrow::before{content:"";width:22px;height:2px;background:var(--red);border-radius:2px}
.page-hero h1{font-size:clamp(2.2rem,4.6vw,3.5rem);margin-bottom:18px}
.page-hero h1 .red{color:var(--red)}
.page-hero .lead{font-size:1.2rem;color:var(--muted);max-width:560px;margin-bottom:26px}
.page-hero .ph{min-height:320px}
.hero-shot{position:relative}
.hero-shot-frame{border-radius:20px;overflow:hidden;border:1px solid var(--line);background:var(--ink);box-shadow:0 24px 60px -28px rgba(17,17,17,.28);aspect-ratio:16/9}
.hero-shot-frame img{display:block;width:100%;height:100%;object-fit:contain;background:var(--ink)}
.hero-shot > img{display:block;width:100%;height:auto;border-radius:20px;border:1px solid var(--line);box-shadow:0 24px 60px -28px rgba(17,17,17,.28);background:transparent}
.page-hero-groupe .hero-shot{width:100%;align-self:center}
.page-hero-groupe .hero-shot-frame{aspect-ratio:16/9}
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}
.pill{display:inline-flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--line);border-radius:99px;padding:8px 15px;font-weight:600;font-size:.88rem;box-shadow:var(--shadow)}
.pill svg{width:15px;height:15px;color:var(--red)}
.page-actions{display:flex;gap:14px;flex-wrap:wrap}
.price-tag{display:flex;align-items:baseline;gap:8px;margin-bottom:24px}
.price-tag .amt{font-family:var(--display);font-weight:800;font-size:2.8rem;letter-spacing:-.03em}
.price-tag .per{color:var(--muted);font-weight:600}
/* feature grid */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px 26px;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.feat:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feat .fi{width:50px;height:50px;border-radius:13px;background:var(--red-soft);color:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feat .fi svg{width:25px;height:25px}
.feat h3{font-size:1.22rem;margin-bottom:10px}
.feat p{color:var(--muted);font-size:.97rem}
/* lives spotlight (groupe) */
.lives-spot{padding:72px 0;background:var(--ink);color:#fff;border-bottom:1px solid rgba(255,255,255,.08)}
.lives-spot .eyebrow{color:rgba(255,255,255,.72)}
.lives-spot .eyebrow::before{background:var(--red)}
.lives-spot-head{max-width:720px;margin:0 auto;text-align:center}
.lives-spot-head h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-bottom:14px}
.lives-spot-head h2 .red{color:var(--red)}
.lives-spot-head p{color:rgba(255,255,255,.72);font-size:1.08rem;line-height:1.55}
.lives-schedule{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:42px;max-width:760px;margin-left:auto;margin-right:auto}
.live-slot{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:28px 26px;text-align:center;transition:transform .2s,border-color .2s,background .2s}
.live-slot:hover{transform:translateY(-4px);border-color:rgba(225,28,18,.45);background:rgba(225,28,18,.08)}
.live-day{display:block;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-bottom:8px}
.live-time{display:block;font-family:var(--display);font-weight:900;font-size:2.4rem;letter-spacing:-.03em;color:#fff;margin-bottom:8px}
.live-label{display:block;font-size:.92rem;color:rgba(255,255,255,.68);font-weight:500}
/* avant / après + grille maîtrise */
.mastery-shift{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:stretch;margin-top:52px;max-width:980px;margin-left:auto;margin-right:auto}
.shift-panel{border-radius:20px;padding:28px 26px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.04)}
.shift-before{border-color:rgba(255,255,255,.08);opacity:.88}
.shift-after{border-color:rgba(225,28,18,.35);background:linear-gradient(145deg,rgba(225,28,18,.12),rgba(255,255,255,.04));box-shadow:0 20px 50px -30px rgba(225,28,18,.35)}
.shift-label{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:12px}
.shift-after .shift-label{color:var(--red)}
.shift-panel h3{font-size:1.35rem;margin-bottom:16px;line-height:1.2}
.shift-panel ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.shift-panel li{font-size:.95rem;color:rgba(255,255,255,.78);line-height:1.45;padding-left:18px;position:relative}
.shift-panel li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.25)}
.shift-after li::before{background:var(--red)}
.shift-bridge{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:0 4px}
.shift-arrow{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--red);color:#fff;font-size:1.3rem;font-weight:800;box-shadow:0 8px 24px rgba(225,28,18,.4)}
.shift-bridge-txt{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.5);text-align:center;max-width:72px;line-height:1.3}
.mastery-block{margin-top:48px;padding-top:48px;border-top:1px solid rgba(255,255,255,.08)}
.mastery-block-head{text-align:center;max-width:680px;margin:0 auto 34px}
.mastery-block-head h3{font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:10px}
.mastery-block-head p{color:rgba(255,255,255,.68);font-size:1.02rem;line-height:1.55}
.mastery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mastery-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:22px 20px;transition:transform .2s,border-color .2s,background .2s}
.mastery-card:hover{transform:translateY(-4px);border-color:rgba(225,28,18,.35);background:rgba(225,28,18,.08)}
.mastery-card .mc-ic{width:42px;height:42px;border-radius:11px;background:rgba(225,28,18,.15);color:var(--red);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.mastery-card .mc-ic svg{width:22px;height:22px}
.mastery-card h4{font-size:1rem;margin-bottom:8px;line-height:1.25}
.mastery-card p{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.45}
@media(max-width:1024px){
  .mastery-grid{grid-template-columns:repeat(2,1fr)}
  .mastery-shift{grid-template-columns:1fr;gap:16px}
  .shift-bridge{flex-direction:row;padding:8px 0}
  .shift-arrow{transform:rotate(90deg)}
}
@media(max-width:760px){
  .lives-schedule{grid-template-columns:1fr;max-width:400px}
  .mastery-grid{grid-template-columns:1fr}
}
/* témoignages + carousel Discord */
.discord-gallery-head{margin-top:0;text-align:center;max-width:640px;margin-left:auto;margin-right:auto}
.discord-gallery-head .eyebrow{display:inline-flex;margin-bottom:14px}
.discord-gallery-head h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-bottom:10px}
.discord-gallery-head h2 .red{color:var(--red)}
.discord-gallery-head h3{font-family:var(--display);font-weight:800;font-size:1.5rem;margin-bottom:8px}
.discord-gallery-head p{color:var(--muted);font-size:1rem}
.discord-gallery{margin-top:32px;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%)}
.discord-track{display:flex;gap:18px;width:max-content;animation:discord-scroll 60s linear infinite}
.discord-track + .discord-track{margin-top:18px}
.discord-track.reverse{animation-direction:reverse;animation-duration:72s}
.discord-gallery:hover .discord-track{animation-play-state:paused}
@keyframes discord-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.discord-shot{flex:0 0 auto;height:240px;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--card);box-shadow:var(--shadow)}
.discord-shot img{display:block;height:100%;width:auto;max-width:none}
@media(prefers-reduced-motion:reduce){.discord-track{animation:none}}
@media(max-width:560px){.discord-shot{height:180px}.discord-gallery-head h2{font-size:1.6rem}.discord-gallery-head h3{font-size:1.25rem}}
/* locked banner (mastermind) */
.locked{max-width:760px;margin:40px auto 0;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:40px;text-align:center;box-shadow:var(--shadow)}
.locked .lk-ic{width:60px;height:60px;border-radius:16px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.locked .lk-ic svg{width:28px;height:28px}
.locked h3{font-size:1.5rem;margin-bottom:12px}
.locked p{color:var(--muted);margin-bottom:22px}

/* ---------- Contact Louis ---------- */
.call-louis{
  background:linear-gradient(165deg,var(--ink) 0%,#1a1210 42%,#120e0c 100%);
  color:var(--paper);border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);
  position:relative;overflow:hidden;
}
.call-louis::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 55% 45% at 88% 18%,rgba(225,28,18,.22),transparent 60%),
    radial-gradient(ellipse 40% 50% at 8% 82%,rgba(225,28,18,.1),transparent 55%);
}
.call-louis .wrap{position:relative;z-index:1}
.call-louis .eyebrow{color:rgba(255,255,255,.72)}
.call-louis .eyebrow::before{background:var(--red)}
.call-louis h2{font-size:clamp(2rem,3.8vw,3rem);margin-bottom:16px;color:#fff}
.call-louis h2 .red{color:#ff6b62}
.call-louis .cl-lead{color:rgba(251,250,247,.72);font-size:1.1rem;line-height:1.6;max-width:480px;margin-bottom:28px}
.cl-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(36px,5vw,72px);align-items:center}
.cl-feats{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.cl-feats li{display:flex;gap:12px;align-items:flex-start;font-weight:600;font-size:1rem;color:rgba(251,250,247,.9)}
.cl-feats li svg{width:20px;height:20px;color:var(--red);flex-shrink:0;margin-top:2px}
.cl-badge{
  display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;
  background:rgba(225,28,18,.15);border:1px solid rgba(225,28,18,.35);
  border-radius:99px;padding:7px 14px;font-size:.78rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#ffb4af;
}
.cl-badge .dot{width:8px;height:8px;border-radius:50%;background:#22c58b;box-shadow:0 0 0 0 rgba(34,197,139,.55);animation:cl-pulse 2.2s ease infinite}
@keyframes cl-pulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,139,.5)}70%{box-shadow:0 0 0 8px rgba(34,197,139,0)}}
.cl-phone{position:relative;display:flex;justify-content:center}
.cl-glow{
  position:absolute;width:min(420px,90%);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(225,28,18,.35),transparent 68%);
  filter:blur(40px);top:50%;left:50%;transform:translate(-50%,-50%);z-index:0;pointer-events:none;
}
.cl-device{
  position:relative;z-index:1;width:min(400px,100%);
  background:var(--card);border:1px solid var(--line);border-radius:28px;
  box-shadow:0 40px 100px -30px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.06) inset;
  overflow:hidden;transform:rotate(-1.5deg);
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.cl-device:hover{transform:rotate(0deg) translateY(-6px)}
.cl-chat-head{display:flex;align-items:center;gap:12px;padding:16px 18px;background:var(--paper);border-bottom:1px solid var(--line)}
.cl-chat-head img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid var(--line)}
.cl-chat-head .who b{display:block;font-family:var(--display);font-size:1rem;color:var(--ink)}
.cl-chat-head .who span{font-size:.78rem;color:var(--muted)}
.cl-chat-head .status{margin-left:auto;display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.05em}
.cl-chat-head .status i{width:7px;height:7px;border-radius:50%;background:var(--green)}
.cl-chat-body{background:var(--paper-2);padding:20px 16px 16px;min-height:340px;display:flex;flex-direction:column;gap:12px}
.cl-msg{max-width:88%;display:flex;flex-direction:column;gap:4px;opacity:0;transform:translateY(14px)}
.cl-phone.in .cl-msg{animation:cl-pop .55s cubic-bezier(.22,.8,.3,1) forwards}
.cl-phone.in .cl-msg:nth-child(1){animation-delay:.15s}
.cl-phone.in .cl-msg:nth-child(2){animation-delay:.55s}
.cl-phone.in .cl-msg:nth-child(3){animation-delay:.95s}
.cl-phone.in .cl-msg:nth-child(4){animation-delay:1.35s}
.cl-phone.in .cl-msg:nth-child(5){animation-delay:1.75s}
.cl-phone.in .cl-typing{opacity:0;animation:cl-pop .55s cubic-bezier(.22,.8,.3,1) 2.15s forwards}
@keyframes cl-pop{to{opacity:1;transform:none}}
.cl-msg .bubble{padding:11px 14px;border-radius:18px;font-size:.88rem;line-height:1.45}
.cl-msg .meta{font-size:.66rem;color:var(--muted-2);padding:0 6px}
.cl-msg.student{align-self:flex-end;align-items:flex-end}
.cl-msg.student .bubble{background:var(--red);color:#fff;border-bottom-right-radius:5px}
.cl-msg.louis{align-self:flex-start;align-items:flex-start}
.cl-msg.louis .bubble{background:var(--card);border:1px solid var(--line);color:var(--ink);border-bottom-left-radius:5px}
.cl-msg .chart-mini{margin-top:8px;padding:8px;border-radius:10px;background:rgba(17,17,17,.06);font-size:.72rem;color:var(--muted);display:flex;align-items:center;gap:8px}
.cl-msg.student .chart-mini{background:rgba(255,255,255,.18);color:#fff}
.cl-msg.student .chart-mini svg{color:#fff}
.cl-msg .chart-mini svg{width:28px;height:28px;color:var(--red);flex-shrink:0}
.cl-typing{align-self:flex-start;display:flex;gap:5px;padding:12px 16px;background:var(--card);border:1px solid var(--line);border-radius:18px;border-bottom-left-radius:5px}
.cl-typing span{width:7px;height:7px;border-radius:50%;background:var(--muted-2);animation:cl-dot 1.2s ease infinite}
.cl-typing span:nth-child(2){animation-delay:.15s}
.cl-typing span:nth-child(3){animation-delay:.3s}
@keyframes cl-dot{0%,80%,100%{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}
.cl-chat-compose{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid var(--line);background:var(--paper)}
.cl-chat-compose .fake{flex:1;padding:10px 14px;border-radius:14px;border:1.5px solid var(--line-2);background:var(--paper-2);font-size:.84rem;color:var(--muted-2)}
.cl-chat-compose .send{width:40px;height:40px;border-radius:12px;background:var(--red);color:#fff;display:grid;place-items:center;flex-shrink:0}
.cl-chat-compose .send svg{width:18px;height:18px}
@media(prefers-reduced-motion:reduce){
  .cl-msg{opacity:1;transform:none;animation:none!important}
  .cl-badge .dot{animation:none}
  .cl-typing span{animation:none}
}

/* ---------- responsive ---------- */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:54px}
  .page-hero-grid{grid-template-columns:1fr;gap:40px}
  .page-hero-groupe .page-hero-grid{grid-template-columns:1fr}
  .page-hero-groupe .page-hero-copy{max-width:none}
  .page-hero-groupe .hero-shot{order:-1}
  .page-hero-groupe .pill-row{grid-template-columns:1fr}
  .eco-row{grid-template-columns:1fr;gap:30px}
  .eco-row:nth-child(even) .eco-media{order:0}
  .plans{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}
  .experts-grid{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}
  .feat-grid{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}
  .kpi{grid-template-columns:repeat(2,1fr)}
  .reviews{columns:2}
  .res-grid{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}
  .call-card{grid-template-columns:1fr;gap:34px;padding:38px}
  .cl-grid{grid-template-columns:1fr;gap:44px}
  .cl-device{transform:none;max-width:380px;margin:0 auto}
  .foot-top{grid-template-columns:1fr 1fr}
  .nav-links,.nav-cta .login{display:none}
}
@media(max-width:600px){
  body{font-size:16px}
  section.block{padding:68px 0}
  .reviews{columns:1}
  .kpi{grid-template-columns:1fr 1fr}
  .hero-float{display:none}
  .topbar{font-size:.76rem}
  .foot-top{grid-template-columns:1fr}
  .call-card{padding:28px}
  .locked{padding:28px}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .reveal{opacity:1;transform:none}
}
