:root{
  --ink:#0D0D0D;
  --ink-2:#1A1A1A;
  --ink-3:#222222;
  --line:#262626;
  --line-soft:#363636;
  --white:#FFFFFF;
  --white-2:#E8E8E8;
  --white-3:#B8B8B8;
  --fire:#FF6B2B;
  --fire-2:#FF9A6C;
  --fire-deep:#A8431A;
  --muted:#888888;
  --shadow:0 30px 80px -30px rgba(255,107,43,.22), 0 30px 80px -30px rgba(0,0,0,.7);
}
*{box-sizing:border-box;margin:0;padding:0;min-width:0}
html{scroll-behavior:smooth;overflow-x:hidden;width:100%;max-width:100vw}
body{
  font-family:'Barlow','Inter',system-ui,sans-serif;
  background:var(--ink);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
  font-weight:400;line-height:1.5;overflow-x:hidden;
  width:100%;max-width:100vw;
}
img,video,iframe{max-width:100%;height:auto}
.serif{font-family:'Bebas Neue',sans-serif;font-weight:400;letter-spacing:.01em}
.mono{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.italic{font-style:italic}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

.wrap{max-width:1320px;margin:0 auto;padding:0 32px}
.row{display:flex;align-items:center;gap:16px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--fire)}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--fire)}
.rule{height:1px;background:var(--line);width:100%}

nav.top{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:saturate(140%) blur(14px);background:rgba(13,13,13,.78);border-bottom:1px solid rgba(255,255,255,.06)}
nav.top .inner{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;max-width:1440px;margin:0 auto}
/* ─── Logo Johane [Shift] (système de marque Shift) ─── */
/* Composant réutilisable. Variante fond clair par défaut. Ajouter
   .dark sur le wrapper pour le rendu sur fond sombre. Couleur de
   marque pilotée par --logo-accent. */
.logo{
  --logo-accent:#FF6B2B;
  display:inline-flex;
  align-items:baseline;
  gap:0.28em;
  font-family:'Inter',system-ui,sans-serif;
  line-height:1;
  white-space:nowrap;
  text-decoration:none;
  color:inherit;
}
.logo .qualifier{
  font-family:'Fraunces',Georgia,serif;
  font-size:1.34rem;
  font-weight:500;
  letter-spacing:-0.005em;
  color:#0A0A0F;
}
.logo.dark .qualifier{color:#FFFFFF}
.logo .mark{
  display:inline-flex;
  align-items:baseline;
  font-weight:800;
  font-size:1.4rem;
  letter-spacing:-0.02em;
  color:var(--logo-accent);
}
.logo .bracket{font-weight:300;opacity:.9}
.logo .name{margin-inline:0.05em}

/* Hover doux sur le logo cliquable */
@media (hover:hover) and (pointer:fine){
  a.logo:hover .mark{filter:brightness(1.08)}
}

/* Ajustement mobile : un peu plus compact pour économiser l'espace */
@media (max-width:640px){
  .logo .qualifier{font-size:1.1rem}
  .logo .mark{font-size:1.15rem}
}

/* Ancien .brand conservé pour compat (footer, etc. si encore utilisé) */
.brand{display:flex;align-items:center;gap:12px;font-size:18px;letter-spacing:.02em;font-family:'Montserrat',system-ui,sans-serif;font-weight:900;text-transform:uppercase}
.brand .mark{
  width:34px;height:34px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--fire-2),var(--fire) 55%,var(--fire-deep));
  display:grid;place-items:center;color:#fff;font-family:'Montserrat',sans-serif;font-weight:900;font-size:16px;line-height:1;padding-top:1px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.25), 0 6px 20px -4px rgba(255,107,43,.55);
}
.brand .name{font-weight:900;color:var(--white)}
.brand .name em{font-family:'Montserrat',sans-serif;font-style:normal;font-weight:900;color:var(--fire);font-size:1em;letter-spacing:.02em;margin:0 1px}
.brand .name .br{color:var(--fire);font-weight:900;margin:0 5px;font-family:'Montserrat',sans-serif}
.navlinks{display:flex;gap:34px;font-size:13px;color:#bfbfbf}
.navlinks a{position:relative;padding:6px 0;transition:color .2s}
.navlinks a:hover,.navlinks a.active{color:var(--white)}
.navlinks a.active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--fire)}
.nav-cta{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;border:1px solid var(--line-soft);border-radius:999px;font-size:13px;transition:background .2s,border-color .2s}
.nav-cta:hover{background:var(--ink-3);border-color:var(--fire)}
.nav-cta .dot{width:6px;height:6px;border-radius:50%;background:var(--fire);box-shadow:0 0 0 4px rgba(255,107,43,.18)}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-cta-member{color:var(--fire);border-color:rgba(255,107,43,.4)}
.nav-cta-member:hover{background:rgba(255,107,43,.08);border-color:var(--fire)}
.nav-cta-member svg{flex-shrink:0}
@media (max-width:860px){.navlinks{display:none}}
@media (max-width:640px){.nav-cta-member .nav-cta-label{display:none}.nav-cta-member{padding:10px 12px}}

.hero{padding:130px 0 90px;position:relative;background:radial-gradient(1100px 600px at 85% -10%, rgba(255,107,43,.22), transparent 60%),radial-gradient(900px 500px at -10% 110%, rgba(255,107,43,.08), transparent 60%),var(--ink);border-bottom:1px solid var(--line);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.5fr 1fr;grid-template-areas:"text photo" "text badge";column-gap:64px;row-gap:0;align-items:start}
.hero-text{grid-area:text}
.portrait--ghost{grid-area:photo;align-self:start}
.hero-badge{grid-area:badge;align-self:start;justify-self:center;margin:0 !important}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:16px}}
.hero h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(58px,8.5vw,132px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;text-wrap:balance}
.hero h1 em{font-family:'Bebas Neue',sans-serif;font-style:normal;font-weight:400;color:var(--fire);letter-spacing:.005em;font-size:1em;text-transform:uppercase;text-decoration:underline;text-decoration-thickness:.055em;text-underline-offset:.1em}
.hero-sub{max-width:480px;margin-top:32px;color:#b8b8b8;font-size:17px;line-height:1.55}
.hero-meta{display:flex;align-items:center;gap:24px;margin-top:40px;flex-wrap:wrap}
.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;margin-bottom:36px;background:#1a0d08;border:1px solid rgba(255,107,43,.35);border-radius:999px;color:#FF6B2B;font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-variant-ligatures:none;font-feature-settings:"liga" 0,"clig" 0,"calt" 0,"kern" 0;position:relative;z-index:10;isolation:isolate}
.hero-badge > span{color:#FF6B2B;opacity:1;font-variant-ligatures:none;font-feature-settings:"liga" 0,"clig" 0}

.btn{display:inline-flex;align-items:center;gap:12px;padding:16px 24px;border-radius:999px;font-size:14px;transition:transform .25s cubic-bezier(.2,.8,.2,1),background .2s,box-shadow .25s cubic-bezier(.2,.8,.2,1),color .2s,border-color .2s;will-change:transform}
.btn .arrow{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;transition:transform .25s cubic-bezier(.2,.8,.2,1)}
.btn-primary{background:var(--fire);color:#fff;font-weight:500;box-shadow:0 14px 40px -10px rgba(255,107,43,.55)}
.btn-primary .arrow{background:#fff;color:var(--fire)}
.btn-ghost{border:1px solid var(--line-soft);color:var(--white);background:transparent}
.btn-ghost .arrow{background:rgba(255,255,255,.05);border:1px solid var(--line-soft);transition:background .2s,border-color .2s,color .2s}

/* Hover effects: only on real pointing devices (avoids sticky hover on mobile) */
@media (hover:hover) and (pointer:fine){
  .btn:hover .arrow{transform:translateX(3px)}
  .btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 52px -12px rgba(255,107,43,.72)}
  .btn-ghost:hover{border-color:var(--fire);background:rgba(255,107,43,.06);color:#fff}
  .btn-ghost:hover .arrow{background:rgba(255,107,43,.12);border-color:var(--fire);color:var(--fire)}
}
/* Pressed state (works on desktop + mobile, gives tactile feedback on tap) */
.btn-primary:active{transform:translateY(0);box-shadow:0 8px 22px -10px rgba(255,107,43,.45);transition-duration:.05s}
.btn-ghost:active{background:rgba(255,107,43,.1);border-color:var(--fire);transition-duration:.05s}

.portrait{position:relative;aspect-ratio:4/5;border-radius:8px;overflow:hidden;background:repeating-linear-gradient(135deg, #1f1f1f 0 2px, transparent 2px 14px),linear-gradient(180deg, #1f1f1f, #141414);border:1px solid var(--line-soft);box-shadow:var(--shadow)}
.portrait--ghost{background:transparent !important;border:0 !important;border-radius:0 !important;box-shadow:none !important;overflow:visible !important;margin-top:20px;aspect-ratio:1/1;filter:drop-shadow(0 30px 40px rgba(0,0,0,.55)) drop-shadow(0 10px 18px rgba(0,0,0,.4))}
.portrait--ghost > image-slot{overflow:visible !important;background:transparent !important;border:0 !important;box-shadow:none !important}
.portrait--ghost > image-slot > img{background:transparent !important}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;grid-template-areas:none;column-gap:0;row-gap:0}.hero-text{display:contents}.hero h1{order:1;grid-area:auto}.hero-sub{order:2;grid-area:auto}.portrait--ghost{order:3;grid-area:auto;margin-top:16px !important;width:100% !important;aspect-ratio:1/1 !important;opacity:1 !important;transform:none !important}.hero-badge{order:4;grid-area:auto;margin-top:0}.hero-meta{order:5;grid-area:auto}.hero{padding:110px 0 32px}}
.portrait .frame-label{position:absolute;top:18px;left:18px;color:var(--fire)}
.portrait .placeholder{position:absolute;inset:0;display:grid;place-items:center;color:#5a5a5a;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.portrait .caption{position:absolute;left:20px;right:20px;bottom:20px;display:flex;justify-content:space-between;align-items:end;gap:16px;color:#bfbfbf}
.portrait .caption .who{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.02em;color:var(--white);text-transform:uppercase}
.portrait .caption .role{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fire)}
.badge-live{position:absolute;top:18px;right:18px;display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(13,13,13,.78);border:1px solid var(--line-soft);border-radius:999px;color:var(--white);font-size:11px;letter-spacing:.06em}
.badge-live .pulse{width:6px;height:6px;border-radius:50%;background:var(--fire);box-shadow:0 0 0 0 rgba(255,107,43,.7);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,107,43,.6)}70%{box-shadow:0 0 0 12px rgba(255,107,43,0)}100%{box-shadow:0 0 0 0 rgba(255,107,43,0)}}

.ticker{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-2);overflow:hidden;width:100%;max-width:100vw;position:relative}
.ticker-inner{display:flex;gap:64px;padding:18px 0;align-items:center;white-space:nowrap;animation:scroll 38s linear infinite;width:max-content}
.ticker span{color:#999;font-size:13px;display:inline-flex;gap:14px;align-items:center}
.ticker .star{color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
@media (max-width:860px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{padding:42px 32px;border-right:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
.stat:last-child{border-right:0}
@media (max-width:860px){.stat:nth-child(2){border-right:0}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}}
.stat .num{font-family:'Bebas Neue',sans-serif;font-size:64px;line-height:1;color:var(--white);letter-spacing:.005em}
.stat .num em{font-style:italic;color:var(--fire)}
.stat .lbl{font-size:13px;color:#999;max-width:200px}

section{position:relative}
.section-title{display:flex;align-items:end;justify-content:space-between;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.section-title h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(46px,6.4vw,86px);line-height:.95;letter-spacing:.005em;max-width:880px;text-transform:uppercase}
.section-title h2 em{font-style:italic;color:var(--fire)}
.section-title .meta{display:flex;flex-direction:column;gap:8px;color:#999;font-size:13px;min-width:180px;text-align:right}

.video-section{padding:120px 0 110px;background:var(--ink)}
.video-shell{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--line-soft);background:radial-gradient(700px 300px at 30% 20%, rgba(255,107,43,.28), transparent 60%),linear-gradient(180deg,#1c1c1c,#0a0a0a);aspect-ratio:16/9;box-shadow:var(--shadow);cursor:pointer;transition:transform .4s ease}
.video-shell:hover{transform:translateY(-3px)}
.video-shell .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:108px;height:108px;border-radius:50%;background:var(--fire);display:grid;place-items:center;transition:transform .3s, box-shadow .3s;box-shadow:0 0 0 0 rgba(255,107,43,.5), 0 30px 60px -20px rgba(255,107,43,.7)}
.video-shell:hover .play{transform:translate(-50%,-50%) scale(1.05);box-shadow:0 0 0 18px rgba(255,107,43,.16), 0 30px 60px -20px rgba(255,107,43,.7)}
.video-shell .play svg{margin-left:5px}
.video-shell .vmeta{position:absolute;left:32px;right:32px;bottom:28px;display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap}
.video-shell .vmeta .title{font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,2.8vw,40px);max-width:680px;line-height:1.05;letter-spacing:.01em;color:var(--white);text-transform:uppercase}
.video-shell .vmeta .right{display:flex;align-items:center;gap:18px;color:#bfbfbf;font-size:13px}
.video-shell .vmeta .right .chip{padding:6px 12px;border:1px solid var(--line-soft);border-radius:999px;background:rgba(13,13,13,.6)}
.video-shell .corner{position:absolute;top:24px;left:24px;display:flex;align-items:center;gap:10px;color:#bfbfbf}
.video-shell .corner .yt{width:30px;height:22px;background:#FF0033;border-radius:5px;display:grid;place-items:center}
.video-shell .corner .yt::after{content:"";border-left:8px solid #fff;border-top:5px solid transparent;border-bottom:5px solid transparent;margin-left:2px}

.vid-list{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:860px){.vid-list{grid-template-columns:1fr}}
.vid-card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--ink-2);transition:border-color .2s,transform .2s}
.vid-card:hover{border-color:var(--fire);transform:translateY(-2px)}
.vid-thumb{aspect-ratio:16/9;position:relative;background:repeating-linear-gradient(135deg, #1f1f1f 0 2px, transparent 2px 12px),linear-gradient(180deg,#222,#0f0f0f);border-bottom:1px solid var(--line)}
.vid-thumb .play-sm{position:absolute;left:14px;bottom:14px;width:36px;height:36px;border-radius:50%;background:rgba(13,13,13,.78);border:1px solid var(--line-soft);display:grid;place-items:center;color:var(--fire)}
.vid-thumb .duration{position:absolute;right:12px;bottom:12px;padding:4px 8px;background:rgba(13,13,13,.85);border-radius:4px;color:var(--white);font-family:'Barlow',sans-serif;font-weight:600;font-size:11px}
.vid-body{padding:18px}
.vid-body .t{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:.01em;line-height:1.05;color:var(--white);text-transform:uppercase}
.vid-body .m{margin-top:10px;display:flex;justify-content:space-between;color:#999;font-size:12px}

.about{background:radial-gradient(900px 500px at 80% 10%, rgba(255,107,43,.12), transparent 60%),linear-gradient(180deg,#161616,#0d0d0d);color:var(--white);padding:130px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about .wrap{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
@media (max-width:980px){.about .wrap{grid-template-columns:1fr;gap:56px}}
.about h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(48px,6.4vw,92px);line-height:.95;letter-spacing:.005em;margin-top:18px;color:var(--white);text-transform:uppercase}
.about h2 em{font-style:italic;color:var(--fire)}
.about p{color:#b8b8b8;font-size:17px;line-height:1.65;margin-top:24px;max-width:560px}
.about .quote{font-family:'Barlow',sans-serif;font-style:italic;font-weight:500;font-size:19px;line-height:1.45;color:var(--white);border-left:2px solid var(--fire);padding-left:20px;margin-top:32px}
.about-img{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:4/5;background:radial-gradient(500px 300px at 30% 20%, rgba(255,107,43,.4), transparent 60%),repeating-linear-gradient(135deg, #1f1f1f 0 2px, transparent 2px 16px),linear-gradient(180deg,#1f1f1f,#0f0f0f);border:1px solid var(--line-soft);box-shadow:0 30px 80px -30px rgba(255,107,43,.4)}
.about-img--ghost{background:transparent !important;border:0 !important;border-radius:0 !important;box-shadow:none !important;overflow:visible !important;filter:drop-shadow(0 30px 40px rgba(0,0,0,.55)) drop-shadow(0 10px 18px rgba(0,0,0,.4))}
.about-img--ghost > image-slot{overflow:visible !important;background:transparent !important;border:0 !important;box-shadow:none !important}
.about-img .placeholder{position:absolute;inset:0;display:grid;place-items:center;color:#5a5a5a;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.about-img .tag{position:absolute;top:18px;left:18px;color:var(--fire)}
.about-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}

.sig{margin-top:34px;display:flex;align-items:center;gap:18px}
.sig-name{font-family:'Bebas Neue',sans-serif;font-size:32px;letter-spacing:.02em;color:var(--white);line-height:1;text-transform:uppercase}
.sig-meta{font-size:12px;color:var(--fire);letter-spacing:.06em;text-transform:uppercase}

.ebooks{padding:130px 0;background:var(--ink);border-top:1px solid var(--line)}
.ebook-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:32px}
@media (max-width:980px){.ebook-grid{grid-template-columns:1fr}}
.ebook{position:relative;padding:28px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));display:flex;flex-direction:column;gap:22px;transition:transform .25s,border-color .25s,background .25s}
.ebook:hover{transform:translateY(-4px);border-color:var(--fire)}
.ebook .cover{aspect-ratio:3/4;border-radius:6px;overflow:hidden;position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:22px;box-shadow:0 18px 40px -20px rgba(0,0,0,.7), inset 0 0 0 1px rgba(255,255,255,.06)}
.ebook .cover .num{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;opacity:.7;text-transform:uppercase}
.ebook .cover .ctitle{font-family:'Bebas Neue',sans-serif;font-size:34px;line-height:1;letter-spacing:.01em;text-transform:uppercase}
.ebook .cover .ctitle em{font-style:italic}
.ebook .cover .sub{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;opacity:.75;text-transform:uppercase}
.ebook .cover .seal{width:42px;height:42px;border-radius:50%;border:1px solid currentColor;display:grid;place-items:center;font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.02em}
.ebook .cover > image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0;border-radius:6px;--slot-bg:transparent}
.ebook .cover > *:not(image-slot){position:relative;z-index:2}
.cover-1{background:linear-gradient(165deg,#A8431A 0%,#FF6B2B 60%,#FF9A6C 100%);color:#fff}
.cover-2{background:linear-gradient(165deg,#A8431A 0%,#FF6B2B 60%,#FF9A6C 100%);color:#fff}
.cover-3{background:linear-gradient(165deg,#A8431A 0%,#FF6B2B 60%,#FF9A6C 100%);color:#fff}

.ebook .info .cat{color:var(--fire);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-family:'Barlow',sans-serif;font-weight:600}
.ebook .info .name{margin-top:10px;font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:.01em;color:var(--white);line-height:1.05;text-transform:uppercase}
.ebook .info .desc{margin-top:10px;color:#a8a8a8;font-size:14px;line-height:1.55}
.ebook .foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:18px;margin-top:auto}
.ebook .price{font-family:'Bebas Neue',sans-serif;font-size:36px;color:var(--white);letter-spacing:.01em}
.ebook .price em{font-style:italic;color:var(--fire)}
.ebook .price .strike{font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;text-decoration:line-through;color:#666;margin-left:8px;letter-spacing:.06em}
.ebook .add{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;background:var(--fire);color:#fff;font-size:13px;font-weight:500;box-shadow:0 8px 20px -8px rgba(255,107,43,.45);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s cubic-bezier(.2,.8,.2,1)}
@media (hover:hover) and (pointer:fine){
  .ebook .add:hover{transform:translateY(-2px);box-shadow:0 14px 30px -8px rgba(255,107,43,.65)}
}
.ebook .add:active{transform:translateY(0);box-shadow:0 5px 14px -8px rgba(255,107,43,.35);transition-duration:.05s}

/* ─── Blog cards (compact, click-worthy) ─── */
.blog{padding:120px 0;background:var(--ink-2);border-top:1px solid var(--line)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.blog-grid{grid-template-columns:1fr;gap:20px}}
.post{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;background:var(--ink);overflow:hidden;text-decoration:none;color:inherit;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease}
.post:hover{transform:translateY(-6px);border-color:var(--fire);box-shadow:0 30px 60px -30px rgba(255,107,43,.45),0 20px 40px -20px rgba(0,0,0,.6)}
.post .thumb{aspect-ratio:16/10;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.post .thumb > image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0;--slot-bg:transparent}
.post .thumb .ph{position:absolute;inset:0;z-index:0;background:repeating-linear-gradient(135deg,#1f1f1f 0 2px,transparent 2px 14px),linear-gradient(180deg,#252525,#0f0f0f)}
.post .thumb .ph.glow{background:radial-gradient(420px 200px at 20% 30%,rgba(255,107,43,.4),transparent 60%),repeating-linear-gradient(135deg,#1f1f1f 0 2px,transparent 2px 14px),linear-gradient(180deg,#252525,#0f0f0f)}
.post .thumb .ph.warm{background:linear-gradient(135deg,#FF6B2B 0%,#A8431A 100%)}
.post .thumb::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,transparent 35%,transparent 60%,rgba(0,0,0,.7) 100%);pointer-events:none}
.post .cat-badge{position:absolute;top:14px;left:14px;z-index:2;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:rgba(13,13,13,.78);border:1px solid var(--line-soft);border-radius:999px;color:var(--fire);font-family:'Barlow',sans-serif;font-weight:600;font-size:10px;letter-spacing:.14em;text-transform:uppercase;backdrop-filter:blur(6px)}
.post .cat-badge::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--fire)}
.post .read-time{position:absolute;bottom:14px;left:14px;z-index:2;color:#fff;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.post .read-time::before{content:"";width:14px;height:1px;background:var(--fire)}
.post .body{padding:22px;display:flex;flex-direction:column;gap:12px;flex:1}
.post .meta-top{display:flex;align-items:center;gap:10px;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#888}
.post .meta-top .dot{width:3px;height:3px;border-radius:50%;background:var(--line-soft)}
.post h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:24px;line-height:1.08;letter-spacing:.01em;color:var(--white);text-transform:uppercase;transition:color .25s}
.post:hover h3{color:var(--fire)}
.post .excerpt{color:#a8a8a8;font-size:14px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.post .foot{display:flex;justify-content:space-between;align-items:center;color:#888;font-size:12px;border-top:1px solid var(--line);padding:14px 22px;margin-top:auto;background:rgba(255,107,43,.02);transition:background .25s}
.post:hover .foot{background:rgba(255,107,43,.08)}
.post .foot .by{display:inline-flex;align-items:center;gap:8px}
.post .foot .by .av{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--fire-deep),var(--fire));display:grid;place-items:center;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:11px;letter-spacing:.02em}
.post .foot .read{color:var(--fire);display:inline-flex;align-items:center;gap:8px;font-weight:600;letter-spacing:.04em}
.post .foot .read .arrow{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(255,107,43,.14);border:1px solid rgba(255,107,43,.3);transition:transform .3s,background .25s,color .25s}
.post:hover .foot .read .arrow{transform:translateX(4px);background:var(--fire);color:#fff}

/* ─── Affiliate program ─── */
.affiliate{position:relative;padding:130px 0;background:radial-gradient(900px 500px at 15% -10%, rgba(255,107,43,.14), transparent 60%),linear-gradient(180deg,var(--ink),#0a0a0a);border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.affiliate::before{content:"";position:absolute;top:-200px;right:-200px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(255,107,43,.18),transparent 70%);pointer-events:none}
.affiliate .aff-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center;position:relative}
@media (max-width:980px){.affiliate{padding:90px 0}.affiliate .aff-grid{grid-template-columns:1fr;gap:48px}}
.affiliate h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(48px,6.4vw,92px);line-height:.95;letter-spacing:.005em;margin-top:18px;color:var(--white);text-transform:uppercase}
.affiliate h2 em{font-style:italic;color:var(--fire)}
.affiliate p.aff-lead{color:#b8b8b8;font-size:17px;line-height:1.65;margin-top:24px;max-width:520px}
.aff-pct{display:inline-flex;align-items:baseline;gap:6px;margin-top:32px;padding:18px 28px;border:1px solid var(--line-soft);border-radius:14px;background:linear-gradient(135deg,rgba(255,107,43,.12),rgba(255,107,43,0));box-shadow:inset 0 0 0 1px rgba(255,107,43,.18)}
.aff-pct .big{font-family:'Bebas Neue',sans-serif;font-size:64px;line-height:1;color:var(--fire);letter-spacing:.005em}
.aff-pct .lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#bfbfbf;margin-left:8px}
.aff-cta{display:flex;align-items:center;margin-top:36px;gap:18px;flex-wrap:wrap}
.aff-trust{font-family:'Barlow',sans-serif;font-size:12px;letter-spacing:.05em;color:#888}
.aff-trust strong{color:#bfbfbf}

/* ─── Simulateur de gains affilié ─── */
.aff-sim{margin-top:36px;padding:26px 28px;border:1px solid var(--line-soft);border-radius:16px;background:linear-gradient(180deg,rgba(255,107,43,.04),rgba(255,107,43,.01)),var(--ink-2);box-shadow:0 30px 60px -30px rgba(0,0,0,.5),inset 0 0 0 1px rgba(255,107,43,.08);max-width:520px}
.aff-sim-head{margin-bottom:22px}
.aff-sim-head .eyebrow{display:block;margin-bottom:6px}
.aff-sim-head h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:30px;line-height:1.05;color:var(--white);letter-spacing:.01em;margin:0}
.aff-sim-head h3 em{color:var(--fire);font-style:italic}
.aff-sim-row{margin-bottom:18px}
.aff-sim-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.aff-sim-label label{font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#bfbfbf}
.aff-sim-output{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--fire);letter-spacing:.02em;line-height:1}
.aff-sim-hint{font-size:12px;color:#9a9a9a;margin-top:8px;letter-spacing:.01em;line-height:1.5}
.aff-sim-hint strong{color:#d8d8d8;font-weight:600}

/* Custom range slider (dark theme + orange thumb) */
.aff-sim input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:6px;background:linear-gradient(90deg,var(--fire) 0,var(--fire) var(--p,40%),#2a2a2a var(--p,40%),#2a2a2a 100%);outline:none;cursor:pointer;border:none;padding:0}
.aff-sim input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--fire);box-shadow:0 4px 12px rgba(255,107,43,.4);cursor:grab;transition:transform .15s}
.aff-sim input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.12)}
.aff-sim input[type=range]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--fire);box-shadow:0 4px 12px rgba(255,107,43,.4);cursor:grab}
.aff-sim input[type=range]::-moz-range-thumb:active{cursor:grabbing;transform:scale(1.12)}

.aff-sim-result{margin:26px 0 18px;padding:24px 22px;border-radius:14px;background:linear-gradient(135deg,rgba(255,107,43,.18),rgba(255,107,43,.04));border:1px solid rgba(255,107,43,.32);text-align:center}
.aff-sim-result-lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#bfbfbf;margin-bottom:4px}
.aff-sim-amount{font-family:'Bebas Neue',sans-serif;font-size:68px;line-height:1;color:var(--fire);letter-spacing:.005em;transition:transform .15s}
.aff-sim-amount.pulse{animation:simPulse .35s ease-out}
@keyframes simPulse{0%{transform:scale(1)}50%{transform:scale(1.04)}100%{transform:scale(1)}}
.aff-sim-period{font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#bfbfbf;margin-top:2px}
.aff-sim-detail{font-size:12px;color:#888;margin-top:10px;letter-spacing:.01em}
.aff-sim-cta{width:100%;justify-content:center}

@media (max-width:640px){
  .aff-sim{padding:22px 20px}
  .aff-sim-amount{font-size:56px}
  .aff-sim-head h3{font-size:26px}
}

.aff-steps{display:flex;flex-direction:column;gap:16px}
.aff-step{position:relative;display:grid;grid-template-columns:64px 1fr;gap:22px;align-items:start;padding:24px 26px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));transition:transform .25s,border-color .25s,background .25s}
.aff-step:hover{transform:translateY(-3px);border-color:var(--fire);background:linear-gradient(180deg,rgba(255,107,43,.06),var(--ink-3))}
.aff-step .n{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--fire);background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.35);letter-spacing:.02em}
.aff-step h4{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:24px;letter-spacing:.01em;color:var(--white);text-transform:uppercase;line-height:1.05}
.aff-step p{color:#a8a8a8;font-size:14px;line-height:1.55;margin-top:6px}
.aff-step .code{display:inline-block;margin-top:10px;padding:4px 10px;border-radius:6px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.35);color:var(--fire);font-family:'Barlow',monospace;font-weight:700;font-size:12px;letter-spacing:.14em}

.closing{padding:130px 0 0;background:var(--ink);border-top:1px solid var(--line)}
.closing-inner{position:relative;border-radius:18px;overflow:hidden;background:radial-gradient(700px 400px at 80% -10%, rgba(255,107,43,.32), transparent 60%),radial-gradient(500px 300px at 10% 110%, rgba(255,107,43,.18), transparent 60%),linear-gradient(180deg,#1a1a1a,#0a0a0a);border:1px solid var(--line-soft);padding:80px 64px;box-shadow:var(--shadow)}
@media (max-width:860px){.closing-inner{padding:48px 28px}}
.closing h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(48px,6.6vw,96px);line-height:.96;letter-spacing:.005em;max-width:880px;color:var(--white);text-transform:uppercase}
.closing h2 em{font-style:normal;color:var(--fire)}
.closing p{margin-top:24px;color:#b8b8b8;font-size:16px;max-width:540px}
form.nl{margin-top:36px;display:flex;gap:10px;max-width:540px;flex-wrap:wrap;border:1px solid var(--line-soft);border-radius:999px;padding:8px;background:rgba(13,13,13,.6)}
form.nl input{flex:1;min-width:200px;background:transparent;border:0;outline:0;color:var(--white);padding:10px 16px;font:inherit;font-size:14px}
form.nl input::placeholder{color:#777}
form.nl button{background:var(--fire);color:#fff;font-weight:500;padding:12px 22px;border-radius:999px;display:inline-flex;align-items:center;gap:10px;font-size:14px;box-shadow:0 10px 24px -8px rgba(255,107,43,.5);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s cubic-bezier(.2,.8,.2,1)}
@media (hover:hover) and (pointer:fine){
  form.nl button:hover{transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(255,107,43,.7)}
}
form.nl button:active{transform:translateY(0);box-shadow:0 6px 16px -8px rgba(255,107,43,.4);transition-duration:.05s}
.nl-msg{margin-top:14px;font-size:13px;color:#a8a8a8;display:flex;align-items:center;gap:10px}
.nl-msg .ok{color:var(--fire)}
.nl-meta{display:flex;gap:24px;margin-top:30px;color:#999;font-size:12px;flex-wrap:wrap}
.nl-meta .av{display:flex}
.nl-meta .av span{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--ink);margin-left:-8px;background:linear-gradient(135deg,#FF9A6C,#A8431A)}
.nl-meta .av span:first-child{margin-left:0;background:linear-gradient(135deg,#FF6B2B,#A8431A)}
.nl-meta .av span:nth-child(2){background:linear-gradient(135deg,#FF9A6C,#FF6B2B)}
.nl-meta .av span:nth-child(3){background:linear-gradient(135deg,#FFB99A,#FF6B2B)}

footer{padding:120px 0 40px;background:var(--ink)}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;border-bottom:1px solid var(--line);padding-bottom:48px}
@media (max-width:860px){.foot-top{grid-template-columns:1fr 1fr;gap:32px}}
.foot-top h4{font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#888;margin-bottom:18px}
.foot-top ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.foot-top ul a{color:#b8b8b8;font-size:14px;transition:color .2s}
.foot-top ul a:hover{color:var(--fire)}
.foot-brand{max-width:360px}
.foot-brand .tag{font-family:'Barlow',sans-serif;font-style:italic;font-weight:500;font-size:18px;line-height:1.4;color:var(--white);margin-top:16px}
.foot-brand .tag em{color:var(--fire)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:32px;color:#888;font-size:12px;flex-wrap:wrap;gap:16px}
.foot-bot .links{display:flex;gap:24px}
.foot-bot .links a:hover{color:var(--white)}
.foot-socials{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px;padding-top:48px;border-top:1px solid var(--line-soft)}
.foot-socials .soc{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:32px 18px;border:1px solid var(--line-soft);border-radius:14px;background:rgba(255,255,255,.015);color:var(--white);text-decoration:none;overflow:hidden;transition:border-color .35s, transform .35s, background .35s}
.foot-socials .soc::before{content:"";position:absolute;inset:-1px;border-radius:14px;opacity:0;transition:opacity .35s;pointer-events:none;background:radial-gradient(120% 80% at 50% 100%, var(--soc-color) 0%, transparent 60%);mix-blend-mode:screen}
.foot-socials .soc::after{content:"";position:absolute;left:50%;bottom:0;height:2px;width:0;background:var(--soc-color);transition:width .4s ease;transform:translateX(-50%);box-shadow:0 0 18px var(--soc-color)}
.foot-socials .soc:hover,.foot-socials .soc:active,.foot-socials .soc:focus-visible{transform:translateY(-3px);border-color:var(--soc-color);background:rgba(255,255,255,.03)}
.foot-socials .soc:hover::before,.foot-socials .soc:active::before,.foot-socials .soc:focus-visible::before{opacity:.35}
.foot-socials .soc:hover::after,.foot-socials .soc:active::after,.foot-socials .soc:focus-visible::after{width:60%}
.foot-socials .soc-ic{width:34px;height:34px;color:var(--soc-color);filter:drop-shadow(0 0 10px color-mix(in srgb, var(--soc-color) 35%, transparent));transition:filter .35s,transform .35s}
.foot-socials .soc:hover .soc-ic,.foot-socials .soc:active .soc-ic,.foot-socials .soc:focus-visible .soc-ic{filter:drop-shadow(0 0 18px var(--soc-color));transform:scale(1.08)}
.foot-socials .soc-name{font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#a8a8a8;transition:color .35s}
.foot-socials .soc:hover .soc-name,.foot-socials .soc:active .soc-name,.foot-socials .soc:focus-visible .soc-name{color:var(--white)}
.foot-socials .soc-handle{font-family:'JetBrains Mono',monospace;font-size:10px;color:#666;letter-spacing:.04em}
@media (max-width:760px){.foot-socials{grid-template-columns:repeat(2,1fr)}}
.foot-mark{font-family:'Bebas Neue',sans-serif;font-size:clamp(56px,13vw,200px);line-height:.85;letter-spacing:.02em;color:transparent;-webkit-text-stroke:1px var(--line-soft);text-align:center;text-transform:uppercase;white-space:nowrap;margin:60px 0 30px;user-select:none}
.foot-mark em{font-style:normal;color:var(--fire);-webkit-text-stroke:0}
.foot-mark .br{font-style:normal;color:var(--fire);-webkit-text-stroke:0;margin:0 .08em;opacity:.85}

/* Testimonials (home) */
.testi{padding:120px 0;background:linear-gradient(180deg,var(--ink),var(--ink-2));border-top:1px solid var(--line)}
.testi-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:48px;flex-wrap:wrap}
.testi-head h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(46px,6vw,84px);line-height:.95;letter-spacing:.005em;text-transform:uppercase;max-width:780px;margin-top:14px}
.testi-head h2 em{font-style:italic;color:var(--fire)}
.testi-head .meta{display:flex;flex-direction:column;gap:6px;color:#999;font-size:13px;text-align:right;min-width:200px}
.testi-head .meta .stars{color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;letter-spacing:.08em;font-size:15px}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:980px){.testi-grid{grid-template-columns:1fr}}
.tcard{position:relative;display:flex;flex-direction:column;gap:18px;padding:32px;border:1px solid var(--line);border-radius:14px;background:var(--ink);transition:transform .3s,border-color .3s,box-shadow .3s}
.tcard:hover{transform:translateY(-4px);border-color:var(--fire);box-shadow:0 24px 50px -24px rgba(255,107,43,.35)}
.tcard .quote-mark{position:absolute;top:18px;right:24px;font-family:'Bebas Neue',sans-serif;font-size:90px;line-height:1;color:var(--fire);opacity:.18;font-style:italic;pointer-events:none}
.tcard .stars{color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;font-size:14px;letter-spacing:.08em;position:relative;z-index:1}
.tcard .body{color:#d8d8d8;font-size:15px;line-height:1.6;position:relative;z-index:1}
.tcard .body em{color:var(--white);font-style:normal;font-weight:600;background:linear-gradient(180deg,transparent 60%,rgba(255,107,43,.25) 60%);padding:0 2px}
.tcard .result{padding:10px 14px;border-radius:10px;background:rgba(255,107,43,.08);border:1px solid rgba(255,107,43,.25);font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.04em;color:var(--fire);display:inline-flex;align-self:flex-start;align-items:center;gap:8px}
.tcard .result::before{content:"→";font-weight:700}
.tcard .who{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.tcard .who .ph{position:relative;width:46px;height:46px;border-radius:50%;flex:none;display:grid;place-items:center;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.04em;box-shadow:inset 0 0 0 1px rgba(255,255,255,.15);overflow:hidden}
/* When a photo loads, it covers the gradient + initials. When it 404s,
   the inline onerror removes the <img> so the gradient/initials show. */
.tcard .who .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
.tcard .who .ph.a{background:linear-gradient(135deg,#A8431A,#FF6B2B)}
.tcard .who .ph.b{background:linear-gradient(135deg,#7C2D12,#FF9A6C)}
.tcard .who .ph.c{background:linear-gradient(135deg,#FF6B2B,#FFB99A)}
.tcard .who .n{font-family:'Bebas Neue',sans-serif;font-size:20px;letter-spacing:.04em;text-transform:uppercase;color:var(--white)}
.tcard .who .r{font-size:11px;color:#888;letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
@media (max-width:640px){.testi{padding:80px 0}.tcard{padding:24px}}

.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Hero stats (compact, between hero & ticker) */
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink)}
.hero-stats .stat{padding:36px 32px;border-right:1px solid var(--line);text-align:center;align-items:center}
.hero-stats .stat:last-child{border-right:0}
.hero-stats .num{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,5.6vw,72px);line-height:1;color:var(--fire);letter-spacing:.01em}
.hero-stats .lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:#bfbfbf;margin-top:8px;max-width:none}
@media (max-width:640px){.hero-stats .stat{padding:24px 12px}.hero-stats .num{font-size:40px}.hero-stats .lbl{font-size:11px;letter-spacing:.14em}}

/* Free ebook section */
.free-ebook-section{padding:100px 0;background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 100%);border-bottom:1px solid var(--line)}
.free-ebook{position:relative;display:grid;grid-template-columns:300px 1fr;gap:56px;align-items:center;padding:48px;border-radius:18px;background:radial-gradient(700px 400px at 90% -20%,rgba(255,107,43,.18),transparent 60%),linear-gradient(180deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-soft);overflow:hidden}
.free-ebook::before{content:'';position:absolute;inset:-2px;border-radius:20px;background:conic-gradient(from 0deg,transparent,rgba(255,107,43,.45),transparent 30%,transparent 70%,rgba(255,107,43,.45),transparent);animation:halo 7s linear infinite;z-index:0;opacity:.55}
.free-ebook::after{content:'';position:absolute;inset:1px;border-radius:17px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));z-index:0}
.free-ebook > *{position:relative;z-index:1}
@keyframes halo{to{transform:rotate(360deg)}}
.free-ebook .ph-cover{aspect-ratio:3/4;border-radius:8px;display:flex;flex-direction:column;justify-content:space-between;text-align:left;padding:22px;color:var(--white);background:linear-gradient(165deg,#A8431A 0%,#FF6B2B 60%,#FF9A6C 100%);box-shadow:0 24px 50px -16px rgba(255,107,43,.5),inset 0 0 0 1px rgba(255,255,255,.12)}
.free-ebook .cover-badge{align-self:flex-start;font-family:'Barlow',sans-serif;font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 10px;border:1px solid rgba(255,255,255,.4);border-radius:999px;background:rgba(0,0,0,.18)}
.free-ebook .cover-title{font-family:'Bebas Neue',sans-serif;font-size:32px;line-height:.95;letter-spacing:.01em;text-transform:uppercase;margin-top:auto}
.free-ebook .cover-title em{font-style:normal;text-decoration:underline;text-decoration-thickness:.05em;text-underline-offset:.08em}
.free-ebook .cover-sub{font-family:'Barlow',sans-serif;font-weight:600;font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.85;margin-top:14px}
.badge-free{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.4);border-radius:999px;color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.free-ebook h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(34px,4.2vw,56px);line-height:.98;letter-spacing:.01em;color:var(--white);text-transform:uppercase;margin-top:14px}
.free-ebook p{color:#bfbfbf;font-size:16px;line-height:1.55;margin-top:14px;max-width:520px}
.email-form{margin-top:24px;display:flex;gap:10px;max-width:520px;flex-wrap:wrap;border:1px solid var(--line-soft);border-radius:999px;padding:6px;background:rgba(13,13,13,.7)}
.email-form input{flex:1;min-width:180px;background:transparent;border:0;outline:0;color:var(--white);padding:10px 16px;font:inherit;font-size:14px}
.email-form input::placeholder{color:#777}
.email-form .btn{padding:12px 20px;border-radius:999px;background:var(--fire);color:#fff;font-family:'Barlow',sans-serif;font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 10px 24px -8px rgba(255,107,43,.5);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s cubic-bezier(.2,.8,.2,1)}
@media (hover:hover) and (pointer:fine){
  .email-form .btn:hover{transform:translateY(-2px);box-shadow:0 16px 36px -10px rgba(255,107,43,.7)}
}
.email-form .btn:active{transform:translateY(0);box-shadow:0 6px 16px -8px rgba(255,107,43,.4);transition-duration:.05s}
@media (max-width:860px){.free-ebook{grid-template-columns:1fr;padding:32px;gap:32px}.free-ebook .ph-cover{max-width:320px;margin:0 auto;width:80%}}
@media (max-width:640px){.free-ebook-section{padding:64px 0}.email-form{flex-direction:column;border-radius:14px}.email-form input,.email-form .btn{width:100%;justify-content:center}}

/* ─── Mobile responsive (≤640px) ─── */
@media (max-width:640px){
  .wrap{padding:0 20px}
  nav.top .inner{padding:14px 20px}
  .nav-cta{font-size:12px;padding:8px 14px}
  .nav-cta .dot{display:none}
  /* Sur mobile la newsletter est déjà accessible en bas de page → on
     enlève le CTA top bar pour gagner de la place. */
  .nav-cta-newsletter{display:none}

  /* Hero compact pour iPhone : tout doit tenir dans un seul écran */
  .hero{padding:80px 0 20px}
  .hero-grid{gap:0 !important}
  .hero h1{font-size:clamp(44px,12vw,72px);line-height:.94}
  .hero-sub{font-size:14px;margin-top:14px;line-height:1.45}
  .hero-meta{gap:10px;margin-top:18px}
  .hero-meta .btn{width:100%;justify-content:center;padding:13px 18px;font-size:13px}
  .hero-badge{font-size:10px;letter-spacing:.14em;gap:7px;padding:7px 12px;flex-wrap:nowrap;justify-content:center;margin-bottom:14px !important;white-space:nowrap;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:geometricPrecision;position:relative;z-index:10;isolation:isolate}
  .hero-badge > span{opacity:1 !important;color:var(--fire) !important;font-weight:700 !important}
  .portrait--ghost{width:55% !important;justify-self:center !important}

  .stats .stat{padding:28px 20px}
  .stat .num{font-size:48px}
  .stat .lbl{font-size:12px}

  section.about,.ebooks,.blog,.closing,.vid-section{padding:80px 0}
  .section-title{margin-bottom:32px;gap:16px}
  .section-title .meta{text-align:left;min-width:0}

  .video-shell{aspect-ratio:16/10}
  .video-shell .vmeta{left:20px;right:20px;bottom:20px;gap:14px}
  .video-shell .play{width:64px;height:64px}

  .about .wrap{gap:40px}
  .about p{font-size:15px}
  .about .quote{font-size:16px;padding-left:16px}
  .about-cta{gap:10px}
  .about-cta .btn{width:100%;justify-content:center}

  .ebook{padding:22px;gap:18px}
  .ebook .cover .ctitle{font-size:28px}

  .post.big h3,.post h3{font-size:22px}

  .closing-inner{padding:48px 24px}
  form.nl{flex-direction:column;border-radius:18px;padding:10px;gap:8px}
  form.nl input,form.nl button{width:100%}
  form.nl button{justify-content:center;padding:14px}

  footer{padding:80px 0 32px}
  .foot-top{grid-template-columns:1fr 1fr;gap:28px;padding-bottom:36px}
  .foot-brand{grid-column:1/-1;max-width:none}
  .foot-mark{font-size:clamp(40px,15vw,80px);margin:48px 0}
  .foot-bot{flex-direction:column;align-items:flex-start;gap:12px}
  .foot-bot .links{flex-wrap:wrap}

  .badge-live{font-size:10px;padding:5px 10px;top:14px;right:14px}
}

/* ─── Tablet tweaks (641–860px) ─── */
@media (min-width:641px) and (max-width:860px){
  .hero{padding:140px 0 80px}
  .hero-meta .btn{padding:14px 20px}
  .closing-inner{padding:64px 36px}
}

.social-section{padding:90px 0;background:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.social-section .wrap{display:flex;flex-direction:column;align-items:center;gap:24px}
.social-section .eyebrow{display:inline-flex}
.social-title{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(40px,5.4vw,76px);line-height:.95;letter-spacing:.005em;text-transform:uppercase;color:var(--white);max-width:780px;margin-top:6px}
.social-title em{font-style:italic;color:var(--fire)}
.social-section .foot-socials{margin-top:18px;justify-content:center}
@media (max-width:640px){.social-section{padding:64px 0}}

/* ─── Ebook detail page ─── */
.ebook-page{padding:140px 0 80px;position:relative;background:radial-gradient(1100px 600px at 85% -10%,rgba(255,107,43,.22),transparent 60%),radial-gradient(900px 500px at -10% 110%,rgba(255,107,43,.08),transparent 60%),var(--ink);overflow:hidden}
.ebook-page .breadcrumb{display:flex;flex-wrap:wrap;gap:8px 10px;align-items:center;color:#888;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:32px}
.ebook-page .breadcrumb > span:last-child{max-width:100%;white-space:normal;overflow-wrap:anywhere}
.ebook-page .breadcrumb a{color:#888;transition:color .2s}
.ebook-page .breadcrumb a:hover{color:var(--fire)}
.ebook-page .breadcrumb .sep{color:var(--line-soft)}
.ebook-hero{display:grid;grid-template-columns:420px 1fr;gap:64px;align-items:start}
@media (max-width:980px){.ebook-hero{grid-template-columns:1fr;gap:40px}}
.ebook-cover-big{position:relative;aspect-ratio:3/4;border-radius:10px;overflow:hidden;border:1px solid var(--line-soft);box-shadow:0 30px 80px -20px rgba(255,107,43,.4),0 30px 80px -30px rgba(0,0,0,.7);transition:transform .4s ease}
.ebook-cover-big:hover{transform:translateY(-6px) rotate(-1deg)}
.ebook-cover-big > image-slot{position:absolute;inset:0;width:100%;height:100%;--slot-bg:transparent}
.ebook-meta-tag{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;background:rgba(255,107,43,.08);border:1px solid rgba(255,107,43,.35);border-radius:999px;color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;backdrop-filter:blur(8px);margin-bottom:24px}
.ebook-page h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase}
.ebook-page h1 em{font-style:italic;color:var(--fire)}
.ebook-page .lead{margin-top:24px;color:#b8b8b8;font-size:18px;line-height:1.55;max-width:560px}
.ebook-stats-row{display:flex;gap:24px;margin-top:32px;flex-wrap:wrap}
.ebook-stat{padding:14px 20px;border:1px solid var(--line);border-radius:12px;background:var(--ink-2)}
.ebook-stat .v{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--fire);line-height:1}
.ebook-stat .l{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#999;margin-top:6px}
.ebook-price-card{margin-top:32px;padding:28px 32px;border-radius:16px;background:radial-gradient(500px 300px at 80% -20%,rgba(255,107,43,.25),transparent 60%),linear-gradient(180deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-soft);box-shadow:0 24px 50px -16px rgba(255,107,43,.3)}
.ebook-price-card .row{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.ebook-price-card .now{font-family:'Bebas Neue',sans-serif;font-size:64px;line-height:1;color:var(--white);letter-spacing:.01em}
.ebook-price-card .now em{font-style:italic;color:var(--fire)}
.ebook-price-card .was{font-family:'Barlow',sans-serif;font-weight:600;font-size:16px;text-decoration:line-through;color:#666;letter-spacing:.06em}
.ebook-price-card .badge{font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fire);padding:4px 10px;border:1px solid rgba(255,107,43,.35);border-radius:999px;background:rgba(255,107,43,.08)}
.ebook-price-card .promo-row{margin-top:18px;display:flex;gap:8px;flex-wrap:wrap}
.ebook-price-card .promo-row input{flex:1;min-width:160px;background:var(--ink);border:1px solid var(--line-soft);border-radius:10px;color:var(--white);padding:10px 14px;font:inherit;font-size:13px;letter-spacing:.06em}
.ebook-price-card .promo-row input:focus{outline:none;border-color:var(--fire)}
.ebook-price-card .promo-row button{padding:10px 16px;border-radius:10px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.35);color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;transition:background .2s,color .2s}
.ebook-price-card .promo-row button:hover{background:var(--fire);color:#fff}
.ebook-cta{margin-top:24px;display:flex;gap:12px;flex-wrap:wrap}
.ebook-cta .btn{padding:18px 28px;font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.ebook-guarantees{margin-top:20px;display:flex;gap:18px;flex-wrap:wrap;color:#999;font-size:12px}
.ebook-guarantees span{display:inline-flex;align-items:center;gap:8px}
.ebook-guarantees span::before{content:"✓";color:var(--fire);font-weight:700}

/* Benefits + TOC */
.ebook-benefits{padding:90px 0;background:var(--ink);border-top:1px solid var(--line)}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
@media (max-width:860px){.benefits-grid{grid-template-columns:1fr}}
.benefit{padding:28px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));transition:border-color .25s,transform .25s}
.benefit:hover{border-color:var(--fire);transform:translateY(-3px)}
.benefit .ic{width:44px;height:44px;border-radius:12px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.35);display:grid;place-items:center;color:var(--fire);margin-bottom:18px}
.benefit h4{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:22px;letter-spacing:.01em;color:var(--white);text-transform:uppercase;line-height:1.05}
.benefit p{color:#a8a8a8;font-size:14px;line-height:1.55;margin-top:8px}

.ebook-toc{padding:90px 0;background:var(--ink-2);border-top:1px solid var(--line)}
.toc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:32px}
@media (max-width:860px){.toc-grid{grid-template-columns:1fr}}
.toc-item{display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:center;padding:18px 22px;border:1px solid var(--line);border-radius:12px;background:var(--ink);transition:border-color .25s}
.toc-item:hover{border-color:var(--fire)}
.toc-item .n{width:36px;height:36px;border-radius:50%;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.35);display:grid;place-items:center;color:var(--fire);font-family:'Bebas Neue',sans-serif;font-size:18px}
.toc-item .t{color:var(--white);font-family:'Barlow',sans-serif;font-weight:600;font-size:15px;line-height:1.35}
.toc-item .t small{display:block;color:#888;font-weight:500;font-size:12px;margin-top:3px}

.ebook-faq{padding:90px 0;background:var(--ink);border-top:1px solid var(--line)}
.faq-list{display:flex;flex-direction:column;gap:12px;max-width:820px;margin:32px auto 0}
.faq-item{border:1px solid var(--line);border-radius:12px;background:var(--ink-2);overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:20px 24px;cursor:pointer;font-family:'Barlow',sans-serif;font-weight:600;font-size:15px;color:var(--white);transition:background .2s}
.faq-q:hover{background:var(--ink-3)}
.faq-q::after{content:"+";color:var(--fire);font-size:22px;font-family:'Bebas Neue',sans-serif;line-height:1;transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;color:#b8b8b8;font-size:14px;line-height:1.6;padding:0 24px}
.faq-item.open .faq-a{max-height:400px;padding:0 24px 22px}

/* ─── Ebooks catalogue page ─── */
.catalogue{padding:140px 0 100px;background:radial-gradient(900px 500px at 85% -10%,rgba(255,107,43,.18),transparent 60%),var(--ink)}
.catalogue h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;max-width:980px}
.catalogue h1 em{font-style:italic;color:var(--fire)}
.catalogue .lead{margin-top:24px;color:#b8b8b8;font-size:18px;max-width:620px;line-height:1.55}

/* ─── About page ─── */
.about-page{padding:140px 0 100px;background:radial-gradient(900px 500px at 80% 10%,rgba(255,107,43,.12),transparent 60%),linear-gradient(180deg,#161616,#0d0d0d);border-bottom:1px solid var(--line)}
.about-page h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;max-width:980px;margin-top:18px}
.about-page h1 em{font-style:italic;color:var(--fire)}
.about-page .grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;margin-top:64px}
@media (max-width:980px){.about-page .grid{grid-template-columns:1fr;gap:48px}}
.about-page .photo{position:relative;aspect-ratio:4/5;border-radius:10px;overflow:hidden;border:1px solid var(--line-soft);box-shadow:0 30px 80px -20px rgba(255,107,43,.3)}
.about-page .photo > image-slot{position:absolute;inset:0;width:100%;height:100%;--slot-bg:transparent}
.about-page .bio p{color:#b8b8b8;font-size:17px;line-height:1.7;margin-bottom:18px}
.about-page .bio h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:32px;letter-spacing:.01em;color:var(--white);text-transform:uppercase;margin-top:36px;margin-bottom:14px}
.about-page .bio h3 em{font-style:italic;color:var(--fire)}
.about-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink)}
@media (max-width:860px){.about-stats-grid{grid-template-columns:repeat(2,1fr)}}

/* ─── Contact page ─── */
.contact-page{padding:140px 0 100px;background:var(--ink)}
.contact-page h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;max-width:980px}
.contact-page h1 em{font-style:italic;color:var(--fire)}
.contact-page .lead{margin-top:24px;color:#b8b8b8;font-size:18px;max-width:620px}
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;margin-top:64px}
@media (max-width:980px){.contact-grid{grid-template-columns:1fr;gap:48px}}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-form label{font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#999;display:block;margin-bottom:8px}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:12px;color:var(--white);padding:14px 18px;font:inherit;font-size:15px;font-family:'Barlow',sans-serif}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:none;border-color:var(--fire)}
.contact-form textarea{resize:vertical;min-height:140px}
.contact-form .submit{align-self:flex-start;margin-top:8px}
.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-card{padding:24px 28px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));transition:border-color .25s}
.contact-card:hover{border-color:var(--fire)}
.contact-card .lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fire);margin-bottom:8px}
.contact-card .v{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:.01em;color:var(--white);text-transform:uppercase}
.contact-card .d{color:#a8a8a8;font-size:13px;margin-top:6px}

/* ─── Blog listing page ─── */
.blog-page{padding:140px 0 100px;background:var(--ink)}
.blog-page h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;max-width:980px}
.blog-page h1 em{font-style:italic;color:var(--fire)}
.blog-page .lead{margin-top:24px;color:#b8b8b8;font-size:18px;max-width:620px;line-height:1.55}
.blog-filters{margin-top:48px;display:flex;gap:10px;flex-wrap:wrap}
.blog-filter{padding:10px 18px;border:1px solid var(--line-soft);border-radius:999px;color:#bfbfbf;font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:.2s}
.blog-filter:hover,.blog-filter.active{background:var(--fire);color:#fff;border-color:var(--fire)}
.blog-empty{margin-top:64px;padding:80px 32px;border:1px dashed var(--line-soft);border-radius:18px;background:var(--ink-2);text-align:center}
.blog-empty .ic{font-family:'Bebas Neue',sans-serif;font-size:80px;line-height:1;color:var(--fire);opacity:.4;margin-bottom:18px}
.blog-empty h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:42px;letter-spacing:.01em;color:var(--white);text-transform:uppercase}
.blog-empty h2 em{font-style:italic;color:var(--fire)}
.blog-empty p{color:#b8b8b8;font-size:16px;margin-top:14px;max-width:540px;margin-left:auto;margin-right:auto}

/* ─── Admin layout ─── */
.admin-shell{display:flex;min-height:100vh;background:var(--ink)}
.admin-sidebar{width:240px;flex-shrink:0;background:var(--ink-2);border-right:1px solid var(--line);padding:24px 18px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh;overflow-y:auto}
@media (max-width:980px){.admin-shell{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;gap:16px;padding:14px 18px;overflow-x:auto}.admin-sidebar .admin-nav{flex-direction:row;overflow-x:auto;flex-wrap:nowrap}.admin-user{display:none}}
.admin-brand{display:flex;align-items:center;gap:10px;color:var(--white);font-family:'Montserrat',sans-serif;font-weight:900;font-size:15px;text-transform:uppercase;letter-spacing:1px;text-decoration:none;flex-shrink:0}
.admin-brand .mark{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--fire-2),var(--fire) 55%,var(--fire-deep));display:grid;place-items:center;color:#fff;font-weight:900;font-size:14px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}
.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.admin-link{display:block;padding:10px 14px;border-radius:8px;color:#bfbfbf;font-family:'Barlow',sans-serif;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.06em;text-decoration:none;white-space:nowrap;transition:.2s}
.admin-link:hover{background:var(--ink-3);color:var(--white)}
.admin-link.active{background:rgba(255,107,43,.12);color:var(--fire);border-left:3px solid var(--fire);padding-left:11px}
.admin-user{padding-top:18px;border-top:1px solid var(--line);font-size:12px}
.admin-user .who{color:var(--white);font-family:'Barlow',sans-serif;font-weight:700;margin-bottom:4px}
.admin-user .role{color:#999;text-transform:uppercase;letter-spacing:.1em;font-size:10px}
.admin-main{flex:1;padding:32px 40px;min-width:0;overflow-x:hidden}
@media (max-width:640px){.admin-main{padding:20px}}

.admin-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:32px;flex-wrap:wrap}
.admin-head h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(32px,3.6vw,48px);line-height:1.05;letter-spacing:.005em;color:var(--white);text-transform:uppercase}
.admin-head h1 em{font-style:italic;color:var(--fire)}
.admin-head .sub{color:#999;font-size:14px;margin-top:4px}
.admin-actions{display:flex;gap:10px;flex-wrap:wrap}
.admin-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;background:var(--fire);color:#fff;font-family:'Barlow',sans-serif;font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;text-decoration:none;border:0;cursor:pointer;transition:.2s}
.admin-btn:hover{background:var(--fire-2)}
.admin-btn-ghost{background:transparent;border:1px solid var(--line-soft);color:var(--white)}
.admin-btn-ghost:hover{border-color:var(--fire);background:rgba(255,107,43,.08)}
.admin-btn-danger{background:#7a1a1a;color:#fff}
.admin-btn-danger:hover{background:#a82a2a}

.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px}
@media (max-width:1100px){.admin-stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.admin-stats{grid-template-columns:1fr}}
.admin-card{padding:20px 22px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));transition:border-color .2s}
.admin-card:hover{border-color:var(--fire)}
.admin-card .lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#999;margin-bottom:8px}
.admin-card .v{font-family:'Bebas Neue',sans-serif;font-size:36px;line-height:1;color:var(--white);letter-spacing:.005em}
.admin-card .v em{font-style:italic;color:var(--fire)}
.admin-card .delta{margin-top:6px;color:#888;font-size:12px}
.admin-card .delta.up{color:#4ade80}
.admin-card .delta.down{color:#ff7373}

.admin-panel{padding:20px 24px;border:1px solid var(--line);border-radius:14px;background:var(--ink-2);margin-bottom:18px}
.admin-panel h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:24px;color:var(--white);text-transform:uppercase;letter-spacing:.005em;margin-bottom:14px}
.admin-panel h2 em{font-style:italic;color:var(--fire)}

.admin-table{width:100%;border-collapse:collapse;font-size:13px;font-family:'Barlow',sans-serif}
.admin-table th{text-align:left;padding:12px 14px;color:#999;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--line);background:var(--ink)}
.admin-table td{padding:14px;color:var(--white);border-bottom:1px solid var(--line)}
.admin-table tr:hover td{background:rgba(255,255,255,.02)}
.admin-table .muted{color:#888;font-size:12px}
.admin-table .num{font-family:'Bebas Neue',sans-serif;color:var(--fire);font-size:18px;letter-spacing:.01em}
.admin-pill{display:inline-block;padding:3px 9px;border-radius:999px;font-size:10px;font-family:'Barlow',sans-serif;font-weight:700;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line-soft)}
.admin-pill.ok{color:var(--fire);border-color:rgba(255,107,43,.4);background:rgba(255,107,43,.1)}
.admin-pill.warn{color:#ffd24a;border-color:rgba(255,210,74,.4);background:rgba(255,210,74,.08)}
.admin-pill.bad{color:#ff7373;border-color:rgba(255,115,115,.4);background:rgba(255,115,115,.08)}
.admin-pill.muted{color:#999}

.admin-form{display:grid;gap:14px;max-width:760px}
.admin-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:640px){.admin-form .row{grid-template-columns:1fr}}
.admin-field label{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#999;display:block;margin-bottom:6px}
.admin-field input,.admin-field textarea,.admin-field select{width:100%;background:var(--ink);border:1px solid var(--line-soft);border-radius:8px;color:var(--white);padding:10px 12px;font:inherit;font-family:'Barlow',sans-serif;font-size:14px}
.admin-field input:focus,.admin-field textarea:focus,.admin-field select:focus{outline:none;border-color:var(--fire)}
.admin-field textarea{min-height:120px;resize:vertical}
.admin-field .hint{margin-top:6px;color:#888;font-size:12px}

.admin-search{display:flex;gap:8px;margin-bottom:20px}
.admin-search input{flex:1;background:var(--ink);border:1px solid var(--line-soft);border-radius:8px;color:var(--white);padding:10px 14px;font:inherit;font-family:'Barlow',sans-serif;font-size:14px}
.admin-search input:focus{outline:none;border-color:var(--fire)}

.admin-empty{padding:48px 24px;text-align:center;color:#888;border:1px dashed var(--line-soft);border-radius:12px;background:var(--ink-2)}

.admin-modules{display:flex;flex-direction:column;gap:14px;margin-top:18px}
.admin-module{padding:14px;border:1px solid var(--line);border-radius:10px;background:var(--ink-3)}
.admin-module .mod-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.admin-module .mod-title{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.01em;color:var(--white);text-transform:uppercase}
.admin-lessons{display:flex;flex-direction:column;gap:6px}
.admin-lesson{display:grid;grid-template-columns:1fr 110px 60px;gap:8px;align-items:center;padding:8px 10px;border-radius:6px;background:var(--ink)}
.admin-lesson input{background:transparent;border:0;color:var(--white);font-family:'Barlow',sans-serif;font-size:13px;padding:4px;width:100%}
.admin-lesson .duration{color:#888;font-size:12px;text-align:right}
.admin-lesson button{font-size:11px;padding:4px 8px;border-radius:6px;background:#7a1a1a;color:#fff;border:0;cursor:pointer}

/* Quill editor on admin/blog */
.ql-toolbar.ql-snow{background:var(--ink-3);border:1px solid var(--line-soft);border-bottom:0;border-radius:8px 8px 0 0}
.ql-container.ql-snow{background:var(--ink);border:1px solid var(--line-soft);border-radius:0 0 8px 8px;color:var(--white);font-family:'Barlow',sans-serif;font-size:15px;min-height:340px}
.ql-snow .ql-stroke{stroke:#bfbfbf}
.ql-snow .ql-fill{fill:#bfbfbf}
.ql-snow .ql-picker-label{color:#bfbfbf}
.ql-snow.ql-toolbar button:hover .ql-stroke{stroke:var(--fire)}
.ql-snow.ql-toolbar button.ql-active .ql-stroke{stroke:var(--fire)}
.ql-snow .ql-editor h2,.ql-snow .ql-editor h3{color:var(--white);font-family:'Bebas Neue',sans-serif}
.ql-snow .ql-editor a{color:var(--fire)}

.admin-chart{padding:24px;border:1px solid var(--line);border-radius:14px;background:var(--ink-2);margin-bottom:18px}
.admin-chart h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:24px;color:var(--white);text-transform:uppercase;margin-bottom:14px}
.admin-chart h2 em{font-style:italic;color:var(--fire)}
.admin-chart canvas{max-height:280px}

/* ─── Blog article (single post) ─── */
.article-page{padding:120px 0 80px;background:var(--ink)}
.article-hero{max-width:760px;margin:0 auto 40px}
.article-hero .cat{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border:1px solid var(--line-soft);border-radius:999px;color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px}
.article-hero .cat::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--fire)}
.article-hero h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(40px,5.4vw,72px);line-height:1.02;letter-spacing:.005em;color:var(--white);text-transform:uppercase}
.article-hero .lead{color:#b8b8b8;font-size:18px;line-height:1.55;margin-top:18px}
.article-hero .meta{display:flex;gap:18px;align-items:center;flex-wrap:wrap;color:#888;font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-top:24px;padding-top:24px;border-top:1px solid var(--line)}
.article-hero .meta .by{display:inline-flex;align-items:center;gap:10px;color:var(--white)}
.article-hero .meta .by .av{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--fire-deep),var(--fire));display:grid;place-items:center;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:14px}
.article-body{max-width:760px;margin:0 auto;color:#dcdcdc;font-size:17px;line-height:1.75;font-family:'Barlow',sans-serif}
.article-body h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:36px;line-height:1.05;color:var(--white);letter-spacing:.005em;text-transform:uppercase;margin:48px 0 16px}
.article-body h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:24px;color:var(--white);text-transform:uppercase;margin:36px 0 12px}
.article-body p{margin:0 0 18px}
.article-body ul,.article-body ol{margin:0 0 18px 22px;padding:0}
.article-body li{margin-bottom:8px}
.article-body strong{color:var(--white);font-weight:700}
.article-body em{color:var(--fire);font-style:italic}
.article-body blockquote{border-left:3px solid var(--fire);background:rgba(255,107,43,.06);padding:18px 24px;margin:24px 0;color:var(--white);font-style:italic}
.article-body code{background:rgba(255,107,43,.12);color:var(--fire);padding:2px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:14px}
.article-body pre{background:var(--ink-2);border:1px solid var(--line);border-radius:10px;padding:18px;overflow-x:auto;font-family:'JetBrains Mono',monospace;font-size:13px;line-height:1.55;color:#e8e8e8;margin:24px 0}
.article-body pre code{background:transparent;color:inherit;padding:0}
.article-body a{color:var(--fire);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.article-body a:hover{color:var(--fire-2)}
.article-body img{max-width:100%;height:auto;border-radius:10px;border:1px solid var(--line);margin:24px 0}
.article-share{max-width:760px;margin:48px auto 0;padding:24px;border-top:1px solid var(--line);display:flex;gap:14px;align-items:center;flex-wrap:wrap;color:#999;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.article-share a{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border:1px solid var(--line-soft);border-radius:999px;color:var(--white);transition:.2s}
.article-share a:hover{border-color:var(--fire);color:var(--fire)}

/* ─── Affiliate dashboard ─── */
.aff-dash{padding:120px 0 80px;background:radial-gradient(900px 500px at 15% -10%,rgba(255,107,43,.14),transparent 60%),var(--ink);min-height:100vh}
.aff-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:32px}
@media (max-width:980px){.aff-stat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.aff-stat-grid{grid-template-columns:1fr}}
.aff-stat{padding:24px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));transition:border-color .2s}
.aff-stat:hover{border-color:var(--fire)}
.aff-stat .lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#999;margin-bottom:8px}
.aff-stat .v{font-family:'Bebas Neue',sans-serif;font-size:42px;line-height:1;color:var(--white);letter-spacing:.005em}
.aff-stat .v em{font-style:italic;color:var(--fire)}
.aff-stat .sub{margin-top:6px;color:#888;font-size:12px}

.aff-share{margin-top:32px;padding:28px 32px;border-radius:16px;background:radial-gradient(500px 300px at 90% -20%,rgba(255,107,43,.18),transparent 60%),linear-gradient(180deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-soft)}
.aff-share h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:28px;color:var(--white);text-transform:uppercase;letter-spacing:.01em;margin-bottom:14px}
.aff-share h3 em{font-style:italic;color:var(--fire)}
.aff-share .row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.aff-share .lbl{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#888;min-width:80px}
.aff-share .v{flex:1;min-width:240px;background:var(--ink);border:1px solid var(--line-soft);border-radius:10px;color:var(--white);padding:10px 14px;font:inherit;font-family:'Barlow',monospace;font-weight:700;font-size:14px;letter-spacing:.06em}
.aff-share button{padding:10px 14px;border-radius:10px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.4);color:var(--fire);font-family:'Barlow',sans-serif;font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .2s,color .2s}
.aff-share button:hover{background:var(--fire);color:#fff}

/* ─── Member dashboard ─── */
.member-page{padding:120px 0 80px;background:radial-gradient(900px 500px at 85% -10%,rgba(255,107,43,.18),transparent 60%),var(--ink);min-height:100vh}
.member-head{display:flex;justify-content:space-between;align-items:end;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.member-head h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;margin-top:14px}
.member-head h1 em{font-style:italic;color:var(--fire)}
.member-head .sub{color:#b8b8b8;font-size:15px;max-width:520px;margin-top:8px}
.member-head .logout-link{color:#888;font-size:13px;font-family:'Barlow',sans-serif;font-weight:600;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--line-soft);padding:10px 16px;border-radius:999px;transition:.2s}
.member-head .logout-link:hover{color:var(--white);border-color:var(--fire)}
.member-section-title{font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--fire);margin:32px 0 16px}
.member-card{position:relative;display:grid;grid-template-columns:180px 1fr;gap:24px;padding:24px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));margin-bottom:14px;transition:border-color .2s,transform .2s}
.member-card:hover{border-color:var(--fire);transform:translateY(-2px)}
@media (max-width:640px){.member-card{grid-template-columns:1fr;gap:14px;padding:18px}}
.member-card .cover{aspect-ratio:3/4;border-radius:8px;background:linear-gradient(165deg,#A8431A 0%,#FF6B2B 60%,#FF9A6C 100%);display:flex;align-items:flex-end;padding:14px;color:#fff;font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.02em;line-height:1;text-transform:uppercase}
.member-card .body h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:26px;letter-spacing:.01em;color:var(--white);text-transform:uppercase;line-height:1.05;margin-bottom:6px}
.member-card .body .meta{color:#888;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.progress{margin-top:14px;height:6px;background:var(--ink);border:1px solid var(--line);border-radius:999px;overflow:hidden}
.progress .bar{height:100%;background:linear-gradient(90deg,var(--fire-deep),var(--fire),var(--fire-2));transition:width .4s ease}
.progress-label{display:flex;justify-content:space-between;align-items:center;font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.06em;color:#bfbfbf;margin-top:10px}
.progress-label strong{color:var(--fire)}
.member-card .actions{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.member-empty{padding:48px 32px;border:1px dashed var(--line-soft);border-radius:18px;background:var(--ink-2);text-align:center;color:#a8a8a8}
.member-empty h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:28px;color:var(--white);text-transform:uppercase;margin-bottom:10px}
.member-empty h3 em{font-style:italic;color:var(--fire)}

/* ─── Formation lesson reader ─── */
.lesson-page{padding:96px 0 40px;background:var(--ink);min-height:100vh}
.lesson-grid{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start}
@media (max-width:980px){.lesson-grid{grid-template-columns:1fr}}
.lesson-sidebar{position:sticky;top:96px;align-self:start;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;padding:18px;max-height:calc(100vh - 120px);overflow-y:auto}
@media (max-width:980px){.lesson-sidebar{position:static;max-height:none}}
.lesson-sidebar h2{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:22px;color:var(--white);text-transform:uppercase;letter-spacing:.01em;line-height:1.1;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.lesson-sidebar .mod{margin-bottom:12px}
.lesson-sidebar .mod-title{font-family:'Barlow',sans-serif;font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#999;margin-bottom:8px}
.lesson-sidebar .ls{display:flex;gap:10px;align-items:flex-start;padding:8px 10px;border-radius:8px;color:#bfbfbf;font-size:13px;line-height:1.4;transition:background .2s,color .2s}
.lesson-sidebar .ls:hover{background:var(--ink-3);color:var(--white)}
.lesson-sidebar .ls.active{background:rgba(255,107,43,.12);color:var(--white)}
.lesson-sidebar .ls .ic{flex-shrink:0;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;font-size:11px;color:#666;border:1px solid var(--line-soft);background:var(--ink)}
.lesson-sidebar .ls.done .ic{color:#fff;background:var(--fire);border-color:var(--fire)}
.lesson-sidebar .ls.active .ic{color:var(--fire);border-color:var(--fire)}
.lesson-main h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:.01em;color:var(--white);text-transform:uppercase;margin-bottom:14px}
.lesson-main h1 em{font-style:italic;color:var(--fire)}
.lesson-main .meta{display:flex;gap:18px;color:#999;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:24px;flex-wrap:wrap}
.lesson-video{position:relative;width:100%;aspect-ratio:16/9;background:#000;border:1px solid var(--line-soft);border-radius:14px;overflow:hidden;margin-bottom:24px}
.lesson-video iframe{width:100%;height:100%;border:0;display:block}
.lesson-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.lesson-notes{margin-top:24px;padding:24px;border:1px solid var(--line);border-radius:14px;background:var(--ink-2)}
.lesson-notes h3{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:22px;color:var(--white);text-transform:uppercase;margin-bottom:10px}
.lesson-notes .hint{color:#888;font-size:12px;margin-bottom:10px}
.lesson-notes textarea{width:100%;min-height:160px;background:var(--ink);border:1px solid var(--line-soft);border-radius:10px;color:var(--white);padding:14px 18px;font:inherit;font-family:'Barlow',sans-serif;font-size:14px;line-height:1.55;resize:vertical}
.lesson-notes textarea:focus{outline:none;border-color:var(--fire)}
.lesson-notes .saved{color:var(--fire);font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-top:10px;display:none}
.lesson-notes .saved.show{display:inline-block}

/* ─── Certificate page ─── */
.cert-page{padding:140px 0 80px;background:radial-gradient(900px 500px at 50% -10%,rgba(255,107,43,.2),transparent 60%),var(--ink)}
.cert-card{max-width:760px;margin:0 auto;padding:48px 40px;border:1px solid var(--line-soft);border-radius:20px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));text-align:center;box-shadow:0 30px 80px -20px rgba(255,107,43,.3)}
@media (max-width:640px){.cert-card{padding:32px 24px}}
.cert-card .seal{width:88px;height:88px;border-radius:50%;display:grid;place-items:center;margin:0 auto 20px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.5);color:var(--fire);font-family:'Bebas Neue',sans-serif;font-size:38px}
.cert-card .who{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(40px,5vw,68px);line-height:1;color:var(--white);text-transform:uppercase;letter-spacing:.005em;margin-bottom:12px}
.cert-card .who em{font-style:italic;color:var(--fire)}
.cert-card .formation-line{color:#b8b8b8;font-size:16px;margin-bottom:8px}
.cert-card .formation-name{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--fire);font-style:italic;letter-spacing:.01em;text-transform:uppercase}
.cert-card .meta{display:flex;justify-content:center;gap:32px;flex-wrap:wrap;color:#888;font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin:32px 0 24px}
.cert-card .meta .v{display:block;color:var(--white);font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:.02em;margin-top:6px}

/* ─── Auth pages (login, register, forgot, reset) ─── */
.auth-page{min-height:100vh;padding:120px 0 80px;background:radial-gradient(900px 500px at 85% -10%,rgba(255,107,43,.2),transparent 60%),radial-gradient(700px 400px at -10% 110%,rgba(255,107,43,.08),transparent 60%),var(--ink);display:flex;align-items:center;justify-content:center}
.auth-card{width:100%;max-width:480px;padding:48px 44px;border:1px solid var(--line-soft);border-radius:18px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));box-shadow:0 30px 80px -20px rgba(0,0,0,.7),inset 0 0 0 1px rgba(255,255,255,.02)}
@media (max-width:640px){.auth-card{padding:32px 24px}}
.auth-card .eyebrow{margin-bottom:14px}
.auth-card h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(40px,4.5vw,56px);line-height:.98;letter-spacing:.005em;color:var(--white);text-transform:uppercase}
.auth-card h1 em{font-style:italic;color:var(--fire)}
.auth-card .sub{margin-top:14px;color:#b8b8b8;font-size:15px;line-height:1.55}
.auth-form{margin-top:28px;display:flex;flex-direction:column;gap:14px}
.auth-field label{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#9a9a9a;margin-bottom:6px;display:block}
.auth-field input{width:100%;background:var(--ink);border:1px solid var(--line-soft);border-radius:12px;color:var(--white);padding:14px 18px;font:inherit;font-size:15px;font-family:'Barlow',sans-serif;transition:border-color .2s}
.auth-field input:focus{outline:none;border-color:var(--fire)}
.auth-form .submit{margin-top:8px;width:100%;justify-content:center;padding:16px 22px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.auth-error{padding:12px 16px;border-radius:10px;background:rgba(255,73,73,.08);border:1px solid rgba(255,73,73,.35);color:#ff7373;font-size:13px;font-family:'Barlow',sans-serif;display:none}
.auth-error.show{display:block}
.auth-success{padding:12px 16px;border-radius:10px;background:rgba(255,107,43,.08);border:1px solid rgba(255,107,43,.35);color:var(--fire);font-size:13px;font-family:'Barlow',sans-serif;display:none}
.auth-success.show{display:block}
.auth-footer{margin-top:24px;padding-top:24px;border-top:1px solid var(--line);text-align:center;color:#999;font-size:13px}
.auth-footer a{color:var(--fire);font-weight:600;transition:color .2s}
.auth-footer a:hover{color:var(--fire-2)}
.auth-aux{display:flex;justify-content:space-between;align-items:center;font-size:12px;margin-top:-4px}
.auth-aux a{color:#999;transition:color .2s}
.auth-aux a:hover{color:var(--fire)}

/* ─── Checkout success / cancel ─── */
.checkout-page{min-height:100vh;padding:140px 0 80px;background:radial-gradient(900px 500px at 85% -10%,rgba(255,107,43,.22),transparent 60%),var(--ink);display:flex;align-items:center;justify-content:center}
.checkout-card{width:100%;max-width:640px;padding:56px 48px;border:1px solid var(--line-soft);border-radius:20px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));box-shadow:0 30px 80px -20px rgba(255,107,43,.35),inset 0 0 0 1px rgba(255,255,255,.02);text-align:center}
@media (max-width:640px){.checkout-card{padding:40px 24px}}
.checkout-icon{width:80px;height:80px;border-radius:50%;display:grid;place-items:center;margin:0 auto 24px;background:rgba(255,107,43,.12);border:1px solid rgba(255,107,43,.35)}
.checkout-icon svg{width:36px;height:36px;color:var(--fire)}
.checkout-page h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(40px,5vw,64px);line-height:.98;letter-spacing:.005em;color:var(--white);text-transform:uppercase}
.checkout-page h1 em{font-style:italic;color:var(--fire)}
.checkout-page .sub{margin-top:16px;color:#b8b8b8;font-size:16px;line-height:1.55}
.checkout-detail{margin-top:28px;padding:20px 24px;border-radius:12px;border:1px solid var(--line);background:var(--ink);text-align:left}
.checkout-detail .row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:8px 0;border-bottom:1px solid var(--line)}
.checkout-detail .row:last-child{border-bottom:0}
.checkout-detail .l{color:#9a9a9a;font-family:'Barlow',sans-serif;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.checkout-detail .v{color:var(--white);font-family:'Barlow',sans-serif;font-weight:600;font-size:14px}
.checkout-cta{margin-top:32px;display:flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* ─── YouTube page ─── */
.yt-page{padding:140px 0 100px;background:radial-gradient(900px 500px at 50% -10%,rgba(255,0,51,.18),transparent 60%),var(--ink)}
.yt-page h1{font-family:'Bebas Neue',sans-serif;font-weight:400;font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:.005em;color:var(--white);text-transform:uppercase;max-width:980px}
.yt-page h1 em{font-style:italic;color:var(--fire)}
.yt-page .lead{margin-top:24px;color:#b8b8b8;font-size:18px;max-width:620px;line-height:1.55}
.yt-channel-cta{margin-top:36px;display:inline-flex;align-items:center;gap:14px;padding:14px 24px;border:1px solid var(--line-soft);border-radius:14px;background:var(--ink-2);transition:border-color .2s,transform .2s;color:var(--white);text-decoration:none}
.yt-channel-cta:hover{border-color:#FF0033;transform:translateY(-2px)}
.yt-channel-cta .ic{width:36px;height:24px;background:#FF0033;border-radius:6px;display:grid;place-items:center}
.yt-channel-cta .ic::after{content:"";border-left:9px solid #fff;border-top:6px solid transparent;border-bottom:6px solid transparent;margin-left:2px}
.yt-channel-cta .info .h{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:.01em;text-transform:uppercase;line-height:1}
.yt-channel-cta .info .s{font-family:'Barlow',sans-serif;font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#999;margin-top:4px}
.yt-list-page{margin-top:64px;display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:980px){.yt-list-page{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.yt-list-page{grid-template-columns:1fr}}

