/* ============================================
   KLN-WEB · Stylesheet principal
   Palette : light + gradient signature lime → mint
   ============================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* KLN-WEB light palette */
  --bg:#fffaf3;
  --bg-2:#f5efe2;
  --bg-3:#fff9e8;
  --card:#ffffff;
  --line:#ebe4d5;
  --line-2:#d8d0bd;

  --ink:#161513;
  --ink-2:#2a2823;
  --ink-soft:#4d473e;
  --muted:#8a8276;

  --lime:#F0FF6C;
  --mint:#6BFDD9;
  --grad:linear-gradient(135deg,#F0FF6C 0%,#6BFDD9 100%);
  --grad-anim:linear-gradient(135deg,#F0FF6C 0%,#6BFDD9 50%,#F0FF6C 100%);

  --warn:#f59e0b;
  --danger:#dc2626;

  --shadow-sm:0 2px 12px rgba(22,21,19,.05);
  --shadow:0 16px 38px rgba(22,21,19,.08);
  --shadow-lg:0 28px 70px rgba(22,21,19,.14);
}

html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--lime);color:var(--ink)}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 18px;position:relative}
@media(min-width:780px){.container{padding:0 24px}}

h1,h2,h3,h4{
  font-family:'Bricolage Grotesque','Inter',sans-serif;
  font-weight:700;line-height:1.05;letter-spacing:-.025em;color:var(--ink);
}
h1{font-size:clamp(40px,7vw,82px);line-height:1;letter-spacing:-.04em;font-weight:800}
h2{font-size:clamp(28px,4.5vw,52px);letter-spacing:-.03em}
h3{font-size:clamp(19px,2.4vw,24px)}
h4{font-size:clamp(16px,2vw,19px)}
p{color:var(--ink-soft);font-size:15.5px}
.lead{font-size:clamp(15px,1.4vw,17.5px);color:var(--ink-soft);max-width:640px;line-height:1.55}

/* ============================================
   ANIMATIONS / KEYFRAMES
   ============================================ */
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-20px) scale(1.06)}}
@keyframes gradMove{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes pulseM{0%{box-shadow:0 0 0 0 rgba(14,169,104,.5)}100%{box-shadow:0 0 0 10px rgba(14,169,104,0)}}
@keyframes pulseI{0%{box-shadow:0 0 0 0 rgba(22,21,19,.4)}100%{box-shadow:0 0 0 10px rgba(22,21,19,0)}}
@keyframes pulseR{0%{box-shadow:0 0 0 0 rgba(220,38,38,.5)}100%{box-shadow:0 0 0 10px rgba(220,38,38,0)}}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes stickFloat{0%,100%{transform:translateY(0) rotate(var(--rot,-5deg))}50%{transform:translateY(-6px) rotate(var(--rot,-5deg))}}
@keyframes shieldRot{0%,100%{transform:rotate(-3deg) scale(1)}50%{transform:rotate(3deg) scale(1.04)}}
@keyframes slideIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes popIn{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}

/* DECORATIVE BLOBS */
.blob{
  position:absolute;border-radius:50%;
  filter:blur(70px);pointer-events:none;z-index:0;opacity:.55;
  animation:blobFloat 20s ease-in-out infinite;
}
.blob.lime{background:#F0FF6C}
.blob.mint{background:#6BFDD9}

/* ============================================
   TOPBAR
   ============================================ */
.topbar{
  position:relative;z-index:60;
  background:var(--ink);color:#fff;
  text-align:center;padding:9px 14px;font-size:13px;font-weight:500;
}
.topbar strong{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;font-weight:800;
}
.topbar a{color:#fff;text-decoration:underline;font-weight:700}
.topbar .sep{margin:0 7px;color:#666}
@media(max-width:520px){.topbar{font-size:12px;padding:8px 10px}.topbar .sep{margin:0 5px}}

/* ============================================
   NAV
   ============================================ */
.nav{
  position:sticky;top:0;z-index:55;
  background:rgba(255,250,243,.85);
  backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
.nav.scrolled{background:rgba(255,250,243,.96);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;height:70px}
@media(min-width:780px){.nav-inner{height:84px}}

.logo{display:flex;align-items:center;flex-shrink:0}
.logo img{height:34px;width:auto;display:block}
@media(min-width:780px){.logo img{height:44px}}

.nav-links{display:none;align-items:center;gap:4px;flex-grow:1;justify-content:center}
@media(min-width:1020px){.nav-links{display:flex}}
.nav-links a{
  padding:9px 14px;border-radius:999px;
  font-size:14px;font-weight:500;color:var(--ink-soft);
  transition:color .2s,background .2s;
}
.nav-links a:hover,
.nav-links a.active{color:var(--ink);background:rgba(22,21,19,.05)}

.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-phone{
  display:inline-flex;align-items:center;gap:7px;
  font-weight:700;color:var(--ink);font-size:14px;
  padding:8px 13px;border-radius:999px;
  background:var(--card);border:1.5px solid var(--line);
  transition:all .2s;
}
.nav-phone:hover{border-color:var(--ink);transform:translateY(-1px)}
.nav-phone .ic{
  width:24px;height:24px;border-radius:50%;
  background:var(--grad);color:var(--ink);display:grid;place-items:center;
}
@media(max-width:600px){.nav-phone .num{display:none}.nav-phone{padding:7px}}

.nav-cta{
  display:inline-flex;align-items:center;gap:6px;
  padding:11px 20px;border-radius:999px;
  background:var(--ink);color:#fff;font-weight:800;font-size:14px;
  box-shadow:0 8px 22px rgba(22,21,19,.20);
  transition:transform .2s,box-shadow .2s,background .2s;
}
.nav-cta:hover{background:#000;transform:translateY(-1px);box-shadow:0 12px 28px rgba(22,21,19,.30)}
@media(max-width:380px){.nav-cta{padding:10px 14px;font-size:13px}}

.nav-burger{
  display:flex;flex-direction:column;justify-content:center;gap:4px;
  width:38px;height:38px;border-radius:10px;
  background:var(--card);border:1.5px solid var(--line);
  align-items:center;
}
@media(min-width:1020px){.nav-burger{display:none}}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s}
.nav.open .nav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav.open .nav-burger span:nth-child(2){opacity:0}
.nav.open .nav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.mobile-menu{
  display:none;position:absolute;top:100%;left:0;right:0;
  background:var(--card);border-bottom:1px solid var(--line);
  padding:14px 18px 18px;flex-direction:column;gap:4px;
  box-shadow:0 16px 40px rgba(22,21,19,.10);
}
.nav.open .mobile-menu{display:flex}
@media(min-width:1020px){.mobile-menu{display:none!important}}
.mobile-menu a{padding:11px 14px;border-radius:10px;font-size:15px;font-weight:600;color:var(--ink)}
.mobile-menu a:hover,
.mobile-menu a.active{background:var(--bg-2)}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:15px 24px;border-radius:999px;
  font-weight:700;font-size:15px;
  transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .2s;
  cursor:pointer;text-align:center;white-space:nowrap;
  position:relative;overflow:hidden;isolation:isolate;
}
.btn-lg{padding:18px 30px;font-size:16.5px}
.btn-block{width:100%}
.btn-dark{
  background:var(--ink);color:#fff;font-weight:800;
  box-shadow:0 14px 30px rgba(22,21,19,.25),inset 0 1px 0 rgba(255,255,255,.10);
}
.btn-dark:hover{background:#000;transform:translateY(-2px);box-shadow:0 18px 38px rgba(22,21,19,.35)}
.btn-grad{
  background:var(--grad-anim);background-size:200% 200%;color:var(--ink);font-weight:800;
  box-shadow:0 14px 30px rgba(107,253,217,.35),inset 0 1px 0 rgba(255,255,255,.30);
  animation:gradMove 5s ease infinite;border:1.5px solid rgba(22,21,19,.08);
}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 18px 38px rgba(107,253,217,.50)}
.btn-ghost{
  background:var(--card);color:var(--ink);border:1.5px solid var(--line-2);
}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}

/* ============================================
   EYEBROWS
   ============================================ */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--card);border:1.5px solid var(--line);
  font-size:12.5px;font-weight:700;color:var(--ink);
  margin-bottom:16px;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--ink);animation:pulseI 2s ease-out infinite}
.eyebrow.warn{border-color:#fecaca;background:#fef2f2;color:#991b1b}
.eyebrow.warn .dot{background:#dc2626;animation:pulseR 2s ease-out infinite}
.eyebrow.green{border-color:#86efac;background:#dcfce7;color:#0e6b3a}
.eyebrow.green .dot{background:#16a34a}

/* ============================================
   HERO
   ============================================ */
.hero{position:relative;padding:36px 0 56px;overflow:hidden}
@media(min-width:780px){.hero{padding:60px 0 90px}}
.hero .blob-h1{top:-100px;right:-100px;width:480px;height:480px;background:#F0FF6C;opacity:.45}
.hero .blob-h2{bottom:-50px;left:-100px;width:380px;height:380px;background:#6BFDD9;opacity:.4}

.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:40px;align-items:center;
}
@media(min-width:980px){.hero-grid{grid-template-columns:1.05fr .95fr;gap:50px}}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px 6px 6px;border-radius:999px;
  background:var(--card);border:1.5px solid var(--line);
  font-size:12.5px;font-weight:600;color:var(--ink);
  margin-bottom:20px;box-shadow:var(--shadow-sm);
}
.hero-eyebrow .em{
  width:24px;height:24px;border-radius:50%;
  background:var(--grad);display:grid;place-items:center;color:var(--ink);font-size:13px;
}
.hero-eyebrow .live{
  display:inline-block;width:7px;height:7px;border-radius:50%;background:#0ea968;
  box-shadow:0 0 0 0 rgba(14,169,104,.5);animation:pulseM 2s ease-out infinite;margin-right:5px;
}
.hero-eyebrow strong{font-weight:800;color:var(--ink)}

.hero h1{margin-bottom:18px}
.hero h1 .grad{
  background:linear-gradient(135deg,#0a8c5a 0%,#0d7e9c 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  display:inline-block;
}
.hero h1 .hl{
  position:relative;display:inline-block;color:var(--ink);
  background:var(--grad);padding:0 .12em;border-radius:8px;
}

.hero p.subtitle{
  font-size:clamp(16px,1.6vw,19px);color:var(--ink-soft);
  margin-bottom:24px;max-width:560px;line-height:1.55;
}
.hero p.subtitle strong{color:var(--ink);font-weight:700}

.hero-bullets{
  list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:28px;
}
.hero-bullets li{
  display:flex;align-items:center;gap:11px;
  font-size:15.5px;color:var(--ink);font-weight:600;
}
.hero-bullets li svg{
  flex-shrink:0;width:22px;height:22px;color:var(--ink);
  background:var(--grad);border-radius:50%;padding:4px;
}
.hero-bullets li strong{font-weight:800}

.hero-ctas{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.hero-trust{display:flex;flex-wrap:wrap;gap:16px;font-size:12.5px;color:var(--ink-soft);font-weight:500}
.hero-trust span{display:inline-flex;align-items:center;gap:5px}
.hero-trust svg{
  background:var(--grad);color:var(--ink);
  border-radius:50%;padding:2px;
}

/* HERO VISUAL */
.hero-visual{position:relative;display:flex;justify-content:center}
.dev-card{
  position:relative;
  background:var(--card);border:1.5px solid var(--line);
  border-radius:24px;padding:24px;
  box-shadow:var(--shadow-lg);
  width:100%;max-width:440px;
  transform:rotate(-1deg);transition:transform .4s ease;
}
.dev-card:hover{transform:rotate(0)}
@media(min-width:780px){.dev-card{padding:28px}}

.dev-card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:18px;
}
.dev-dots{display:flex;gap:5px}
.dev-dots span{width:10px;height:10px;border-radius:50%}
.dev-dots span:nth-child(1){background:#ef4444}
.dev-dots span:nth-child(2){background:#fbbf24}
.dev-dots span:nth-child(3){background:#10b981}
.dev-url{font-size:11.5px;color:var(--muted);font-weight:600;background:var(--bg-2);padding:4px 10px;border-radius:999px}

.dev-profile{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.dev-av{
  width:60px;height:60px;border-radius:50%;flex-shrink:0;
  background:var(--grad);background-size:200% 200%;
  display:grid;place-items:center;color:var(--ink);font-weight:800;font-size:24px;
  font-family:'Bricolage Grotesque',sans-serif;
  box-shadow:0 10px 24px rgba(107,253,217,.30);
  animation:gradMove 5s ease infinite;
}
.dev-name{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:800;color:var(--ink);line-height:1.2}
.dev-role{font-size:13px;color:var(--muted);margin-top:2px}
.dev-status{
  display:inline-flex;align-items:center;gap:6px;margin-top:6px;
  padding:4px 10px;border-radius:999px;
  background:#dcfce7;color:#0e6b3a;font-size:11px;font-weight:800;
}
.dev-status::before{content:"";width:7px;height:7px;border-radius:50%;background:#16a34a;animation:pulseM 2s ease-out infinite}

.dev-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.dev-mini-stat{
  background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:11px 14px;
}
.dev-mini-stat .lbl{font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.dev-mini-stat .val{font-size:19px;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;color:var(--ink);margin-top:3px;display:flex;align-items:center;gap:5px}
.dev-mini-stat .val.up{color:#0a8c5a}
.dev-mini-stat .val.warn{color:#b45309}

.dev-chart{margin:14px 0 12px;height:54px;background:linear-gradient(180deg,rgba(107,253,217,.18),transparent);border-radius:11px;border:1px solid var(--line);position:relative;overflow:hidden}
.dev-chart svg{position:absolute;inset:0;width:100%;height:100%}

.dev-feed{display:flex;flex-direction:column;gap:7px}
.dev-feed-row{
  display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:10px;
  background:#dcfce7;border:1px solid #86efac;
  font-size:12.5px;color:#0e6b3a;font-weight:600;
}
.dev-feed-row::before{content:"✅";font-weight:900}
.dev-feed-row.alert{background:#fef3c7;border-color:#fcd34d;color:#78350f}
.dev-feed-row.alert::before{content:"⚡"}

/* STICKERS */
.sticker{
  position:absolute;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:13px;
  background:var(--ink);border:1.5px solid var(--ink);
  border-radius:14px;padding:10px 14px;
  box-shadow:0 12px 28px rgba(22,21,19,.20);
  display:inline-flex;align-items:center;gap:7px;color:#fff;
  z-index:3;animation:stickFloat 7s ease-in-out infinite;
}
.sticker-price{
  --rot:7deg;top:-22px;right:-10px;
  background:var(--lime);color:var(--ink);border-color:var(--ink);
  padding:11px 14px;animation-delay:0s;
}
.sticker-price .small{display:block;font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.7;line-height:1}
.sticker-price .big{display:block;font-size:22px;line-height:1.1;margin-top:2px;font-weight:800}
.sticker-fast{
  --rot:-6deg;bottom:38px;left:-22px;
  background:var(--grad);background-size:200% 200%;border-color:var(--ink);color:var(--ink);
  animation-delay:-2.5s,gradMove 5s ease infinite;
}
.sticker-shield{
  --rot:4deg;top:42%;right:-22px;
  background:var(--mint);border-color:var(--ink);color:var(--ink);
  animation-delay:-4.5s;
}
@media(max-width:520px){
  .sticker-price{right:0;top:-18px}
  .sticker-fast{left:-12px;bottom:50px}
  .sticker-shield{right:-12px}
}

/* ============================================
   MARQUEE
   ============================================ */
.marquee-wrap{
  background:var(--ink);color:#fff;overflow:hidden;
  padding:18px 0;transform:rotate(-1deg);
  margin:0 -30px;border-top:1px solid #2a2823;border-bottom:1px solid #2a2823;
  position:relative;z-index:2;
}
.marquee-track{display:flex;gap:40px;animation:scroll 28s linear infinite;flex-shrink:0;white-space:nowrap}
.marquee-item{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:18px;
  white-space:nowrap;flex-shrink:0;color:#fff;
}
.marquee-item.grad{background:var(--grad);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradMove 5s ease infinite}
.marquee-item .star{color:var(--lime);font-size:14px}

/* ============================================
   SECTIONS
   ============================================ */
.section{padding:60px 0;position:relative;overflow:hidden}
@media(min-width:780px){.section{padding:90px 0}}
.section-head{max-width:740px;margin:0 auto 36px;text-align:center}
@media(min-width:780px){.section-head{margin-bottom:54px}}

.section-head h2{margin-bottom:12px}
.section-head h2 .hl{
  position:relative;display:inline-block;color:var(--ink);
  background:var(--grad);padding:0 .12em;border-radius:6px;
}
.section-head h2 .underline{position:relative;display:inline-block}
.section-head h2 .underline::after{
  content:"";position:absolute;left:-3%;right:-3%;bottom:.04em;height:.16em;
  background:var(--lime);z-index:-1;border-radius:4px;
}
.section-head .lead{margin:0 auto;font-size:15.5px}

/* STATS */
.stats-section{padding:50px 0;background:var(--bg-3)}
@media(min-width:780px){.stats-section{padding:60px 0}}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-width:980px;margin:0 auto}
@media(min-width:780px){.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px}}
.stat-card{
  position:relative;text-align:center;padding:26px 16px;border-radius:18px;
  background:var(--card);border:1.5px solid var(--line);
  transition:transform .3s,border-color .3s,box-shadow .3s;overflow:hidden;
}
.stat-card:hover{transform:translateY(-4px);border-color:var(--ink);box-shadow:var(--shadow)}
.stat-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.stat-card:hover::before{transform:scaleX(1)}
.stat-num{
  font-family:'Bricolage Grotesque',sans-serif;
  font-size:clamp(36px,5.5vw,56px);font-weight:800;line-height:1;letter-spacing:-.04em;
  color:var(--ink);
}
.stat-num .grad{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.stat-suffix{font-size:.55em;opacity:.75}
.stat-label{font-size:12.5px;color:var(--ink-soft);font-weight:600;margin-top:8px}

/* PROBLEM */
.problem .blob-x{top:30%;left:-100px;width:280px;height:280px;background:#fecaca;opacity:.5}
.problem-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;position:relative;z-index:2}
@media(min-width:780px){.problem-grid{grid-template-columns:repeat(4,1fr);gap:16px}}
.problem-card{
  background:var(--card);border:1.5px solid var(--line);border-radius:18px;
  padding:22px;transition:transform .25s,border-color .25s,box-shadow .25s;
}
.problem-card:hover{transform:translateY(-4px);border-color:#dc2626;box-shadow:0 14px 30px rgba(220,38,38,.10)}
.problem-emoji{
  width:48px;height:48px;border-radius:13px;
  background:#fef2f2;border:1.5px solid #fecaca;
  display:grid;place-items:center;margin-bottom:14px;font-size:24px;
}
.problem-card h3{font-size:17px;margin-bottom:6px;font-family:'Bricolage Grotesque',sans-serif}
.problem-card p{font-size:13.5px;color:var(--ink-soft)}
.problem-card .lose{
  display:inline-block;margin-top:12px;padding:5px 11px;border-radius:999px;
  background:#fef2f2;color:#991b1b;font-size:11.5px;font-weight:800;
  border:1px solid #fecaca;
}

/* SOLUTION (BENTO) */
.solution{position:relative;background:var(--bg-2)}
.solution .blob-y{top:0;right:-150px;width:380px;height:380px;background:#6BFDD9;opacity:.30}
.solution .blob-z{bottom:0;left:-150px;width:380px;height:380px;background:#F0FF6C;opacity:.30}
.bento{display:grid;grid-template-columns:1fr;gap:14px;position:relative;z-index:2}
@media(min-width:600px){.bento{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.bento{grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(160px,auto)}}
.bento > div{
  position:relative;background:var(--card);border:1.5px solid var(--line);
  border-radius:20px;padding:24px;overflow:hidden;
  transition:transform .25s,border-color .25s,box-shadow .25s;
}
.bento > div:hover{transform:translateY(-3px);border-color:var(--ink);box-shadow:var(--shadow-sm)}
@media(min-width:980px){
  .bento .b-1{grid-column:span 3;grid-row:span 2}
  .bento .b-2{grid-column:span 3}
  .bento .b-3{grid-column:span 2}
  .bento .b-4{grid-column:span 2}
  .bento .b-5{grid-column:span 2}
}
.bento h3{font-size:18px;margin-bottom:6px;font-family:'Bricolage Grotesque',sans-serif}
.bento p{font-size:13.5px;color:var(--ink-soft)}
.b-emoji{
  display:inline-grid;place-items:center;width:46px;height:46px;border-radius:12px;
  margin-bottom:14px;font-size:22px;
  background:var(--bg-3);border:1.5px solid var(--line);
}

.uptime-bars{display:flex;gap:2.5px;height:38px;align-items:flex-end;margin-top:14px}
.uptime-bars span{flex:1;background:#16a34a;border-radius:2px;opacity:.85}
.uptime-bars span.warn{background:var(--warn);opacity:.7}
.uptime-bars span:nth-child(odd){height:80%}
.uptime-bars span:nth-child(even){height:95%}
.uptime-bars span:nth-child(3n){height:100%}
.uptime-bars span:nth-child(7){height:60%}
.uptime-bars span:nth-child(13){height:70%}

.live-feed{margin-top:14px;display:flex;flex-direction:column;gap:8px}
.feed-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  background:var(--bg-3);border:1px solid var(--line);border-radius:11px;
  font-size:12.5px;color:var(--ink-soft);animation:slideIn .5s ease;
}
.feed-item strong{color:var(--ink);font-weight:700}
.feed-item .ico{
  width:24px;height:24px;border-radius:7px;display:grid;place-items:center;flex-shrink:0;font-size:11px;
}
.feed-item .ico.g{background:#dcfce7;color:#0e6b3a}
.feed-item .ico.b{background:rgba(107,253,217,.30);color:#0d6e8b}
.feed-item .ico.w{background:#fef3c7;color:#78350f}
.feed-item .time{margin-left:auto;font-size:10.5px;color:var(--muted)}

/* VALUE (dark accent) */
.value{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.value h2{color:#fff}
.value .lead{color:#cbcbd8}
.value .eyebrow{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:#fff}
.value .eyebrow .dot{background:var(--lime)}
.value .section-head h2 .hl{color:var(--ink);background:var(--grad)}
.value::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 0% 0%,rgba(240,255,108,.12),transparent 50%),
             radial-gradient(circle at 100% 100%,rgba(107,253,217,.12),transparent 50%);
  pointer-events:none;
}
.value-head{position:relative;z-index:2}

.value-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:10px;max-width:780px;margin:0 auto;
}
@media(min-width:600px){.value-grid{grid-template-columns:1fr 1fr;gap:12px}}
.value-row{
  display:flex;align-items:center;gap:14px;padding:14px;border-radius:14px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);
  transition:background .2s,transform .2s,border-color .2s;
}
.value-row:hover{background:rgba(255,255,255,.08);transform:translateX(2px);border-color:rgba(107,253,217,.4)}
.value-row .em{
  flex-shrink:0;width:42px;height:42px;border-radius:11px;
  background:var(--grad);background-size:200% 200%;
  display:grid;place-items:center;font-size:21px;color:var(--ink);
  animation:gradMove 5s ease infinite;
}
.value-row .txt{flex-grow:1;min-width:0}
.value-row .txt strong{display:block;color:#fff;font-size:14px;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;line-height:1.2;margin-bottom:2px}
.value-row .txt span{color:#a8a8c0;font-size:12.5px}
.value-row .price{flex-shrink:0;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:14px;color:var(--lime)}

.value-total{
  position:relative;z-index:2;
  margin:28px auto 0;max-width:780px;
  display:grid;grid-template-columns:1fr;gap:12px;
}
@media(min-width:600px){.value-total{grid-template-columns:1fr 1fr;align-items:stretch}}
.value-total-card{
  padding:22px 24px;border-radius:18px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);
}
.value-total-card.highlight{
  background:var(--grad);background-size:200% 200%;
  border:0;animation:gradMove 5s ease infinite;color:var(--ink);
  box-shadow:0 24px 50px rgba(107,253,217,.25);
}
.value-total .lbl{font-size:11.5px;color:#a8a8c0;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.value-total-card.highlight .lbl{color:rgba(22,21,19,.7)}
.value-total .num{
  font-family:'Bricolage Grotesque',sans-serif;font-size:38px;font-weight:800;line-height:1;
  margin-top:6px;color:#fff;
}
.value-total-card.highlight .num{color:var(--ink)}
.value-total .num .strike{position:relative;display:inline-block;color:#a8a8c0}
.value-total .num .strike::after{content:"";position:absolute;left:-2%;right:-2%;top:55%;height:.06em;background:var(--danger);border-radius:3px;transform:rotate(-3deg)}
.value-total .num .per{font-size:.45em;font-weight:600;opacity:.7;margin-left:2px}
.value-total .sub{font-size:13px;color:#cbcbd8;margin-top:6px}
.value-total-card.highlight .sub{color:rgba(22,21,19,.75)}

/* STEPS */
.steps{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:780px){.steps{grid-template-columns:repeat(3,1fr);gap:18px}}
.step{
  background:var(--card);border:1.5px solid var(--line);border-radius:20px;
  padding:26px 24px;transition:transform .25s,border-color .25s;
}
.step:hover{transform:translateY(-4px);border-color:var(--ink)}
.step-num{
  display:inline-grid;place-items:center;
  width:46px;height:46px;border-radius:13px;
  background:var(--grad);background-size:200% 200%;color:var(--ink);
  font-weight:800;font-size:20px;font-family:'Bricolage Grotesque',sans-serif;
  margin-bottom:14px;animation:gradMove 5s ease infinite;
  box-shadow:0 10px 22px rgba(107,253,217,.25);border:1.5px solid rgba(22,21,19,.08);
}
.step h3{margin-bottom:6px;font-size:18px}
.step p{font-size:14px}

/* PRICING */
.pricing{background:var(--bg-3)}
.pricing-grid{
  display:grid;grid-template-columns:1fr;gap:16px;max-width:1100px;margin:0 auto;
}
@media(min-width:780px){.pricing-grid{grid-template-columns:repeat(3,1fr);gap:20px}}
.price-card{
  position:relative;background:var(--card);border:1.5px solid var(--line);
  border-radius:22px;padding:32px 26px 26px;display:flex;flex-direction:column;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s;
  overflow:hidden;
}
.price-card:hover{transform:translateY(-6px);border-color:var(--ink);box-shadow:var(--shadow)}
.price-card.featured{
  background:var(--ink);color:#fff;border-color:var(--ink);
}
.price-card.featured h3,.price-card.featured h4,
.price-card.featured .plan-price .amount{color:#fff}
.price-card.featured .plan-tag{color:#a8a8c0}
.price-card.featured .plan-features li{color:#cbcbd8}
.price-card.featured .plan-features li.bold{color:#fff}
.price-card.featured .plan-divider{background:rgba(255,255,255,.15)}
.price-card.featured .plan-icon{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}
@media(min-width:780px){.price-card.featured{transform:translateY(-10px)}.price-card.featured:hover{transform:translateY(-14px)}}
.badge-pop{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%) rotate(-3deg);
  padding:7px 16px;border-radius:999px;
  background:var(--lime);color:var(--ink);
  font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  white-space:nowrap;border:1.5px solid var(--ink);
  box-shadow:0 10px 22px rgba(22,21,19,.20);
}
.plan-icon{display:inline-grid;place-items:center;width:46px;height:46px;border-radius:13px;font-size:24px;margin-bottom:14px;background:var(--bg-3);border:1.5px solid var(--line)}
.plan-name{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:800;margin-bottom:4px}
.plan-tag{font-size:13.5px;color:var(--ink-soft);margin-bottom:18px}
.plan-price{display:flex;align-items:baseline;gap:5px;margin-bottom:6px}
.plan-price .amount{font-family:'Bricolage Grotesque',sans-serif;font-size:54px;font-weight:800;line-height:1;letter-spacing:-.03em}
.plan-price .per{color:var(--muted);font-weight:500;font-size:14px}
.plan-divider{height:1px;background:var(--line);margin:20px 0 18px}
.plan-features{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px;flex-grow:1}
.plan-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink-soft)}
.plan-features li svg{flex-shrink:0;margin-top:2px;width:18px;height:18px;background:var(--grad);color:var(--ink);border-radius:50%;padding:3px}
.plan-features li.bold{color:var(--ink);font-weight:700}

/* TESTIMONIALS */
.testi-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:36px}
@media(min-width:780px){.testi-grid{grid-template-columns:repeat(3,1fr);gap:18px}}
.testi-card{
  position:relative;background:var(--card);border:1.5px solid var(--line);
  border-radius:18px;padding:24px;transition:transform .25s,border-color .25s,box-shadow .25s;
}
.testi-card:hover{transform:translateY(-4px);border-color:var(--ink);box-shadow:var(--shadow-sm)}
.stars{color:#f59e0b;margin-bottom:12px;display:flex;gap:2px}
.testi-quote{font-size:14.5px;color:var(--ink);line-height:1.55;margin-bottom:16px;font-weight:500}
.testi-author{display:flex;align-items:center;gap:11px;padding-top:14px;border-top:1px solid var(--line)}
.testi-av{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;color:var(--ink);font-weight:800;font-size:14px;
  font-family:'Bricolage Grotesque',sans-serif;flex-shrink:0;
  background:var(--grad);
}
.testi-name{font-weight:800;font-size:14px}
.testi-role{font-size:12.5px;color:var(--muted)}

/* GUARANTEE */
.guarantee{background:var(--bg-2);position:relative;overflow:hidden}
.guarantee::before{content:"";position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(240,255,108,.45),transparent 60%);pointer-events:none}
.guarantee::after{content:"";position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(107,253,217,.40),transparent 60%);pointer-events:none}
.guarantee-card{
  position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:30px;
  align-items:center;max-width:1000px;margin:0 auto;text-align:center;
}
@media(min-width:780px){.guarantee-card{grid-template-columns:auto 1fr;gap:50px;text-align:left}}
.shield-3d{
  width:120px;height:120px;border-radius:30px;
  background:var(--grad);background-size:200% 200%;
  display:grid;place-items:center;color:var(--ink);
  box-shadow:0 22px 50px rgba(107,253,217,.40),inset 0 2px 0 rgba(255,255,255,.40);
  animation:shieldRot 8s ease-in-out infinite,gradMove 5s ease infinite;
  margin:0 auto;border:1.5px solid rgba(22,21,19,.08);
}
.guarantee-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-top:14px}
.guarantee-list li{display:flex;align-items:flex-start;gap:11px;color:var(--ink-soft);font-size:14.5px;line-height:1.5;text-align:left}
.guarantee-list li svg{flex-shrink:0;width:20px;height:20px;color:var(--ink);background:var(--grad);border-radius:50%;padding:3px;margin-top:2px}
.guarantee-list strong{color:var(--ink);font-weight:800}

/* FAQ */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{
  background:var(--card);border:1.5px solid var(--line);border-radius:14px;
  margin-bottom:10px;overflow:hidden;transition:border-color .2s,box-shadow .2s;
}
.faq-item:hover{border-color:var(--line-2)}
.faq-item.open{border-color:var(--ink);box-shadow:0 12px 28px rgba(22,21,19,.08)}
.faq-q{
  width:100%;text-align:left;padding:18px 22px;
  font-weight:800;font-size:15.5px;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  font-family:'Bricolage Grotesque',sans-serif;
}
.faq-q .icn{
  width:28px;height:28px;border-radius:50%;
  background:var(--bg-3);color:var(--ink);
  display:grid;place-items:center;flex-shrink:0;font-weight:700;font-size:16px;
  transition:transform .3s,background .3s,color .3s;border:1px solid var(--line);
}
.faq-item.open .faq-q .icn{transform:rotate(45deg);background:var(--grad);color:var(--ink);border-color:transparent}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--ink-soft);font-size:14.5px}
.faq-a-inner{padding:0 22px 18px}

/* FINAL CTA */
.final{
  position:relative;padding:70px 0;overflow:hidden;text-align:center;
  background:var(--ink);color:#fff;
}
@media(min-width:780px){.final{padding:90px 0}}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(240,255,108,.20),transparent 40%),radial-gradient(circle at 80% 80%,rgba(107,253,217,.20),transparent 40%);pointer-events:none}
.final-inner{position:relative;z-index:2;max-width:760px;margin:0 auto;padding:0 18px}
.final h2{color:#fff;margin-bottom:14px;font-size:clamp(28px,4.5vw,48px)}
.final h2 .grad{background:var(--grad);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradMove 5s ease infinite}
.final p{color:#cbcbd8;font-size:16.5px;max-width:560px;margin:0 auto 28px}
.final-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}
.final .btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.30)}
.final .btn-ghost:hover{background:rgba(255,255,255,.08);border-color:#fff}
.final .micro{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:18px;font-size:12.5px;color:#a8a8c0;font-weight:500}
.final .micro span{display:inline-flex;align-items:center;gap:5px}
.final .micro svg{color:var(--lime)}

/* ============================================
   FOOTER
   ============================================ */
footer{
  background:var(--card);color:var(--ink-soft);
  padding:56px 0 26px;border-top:1px solid var(--line);
}
.footer-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:34px}
@media(min-width:780px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}}
.footer-brand .logo img{height:38px;margin-bottom:14px}
.footer-brand p{font-size:13.5px;color:var(--ink-soft);margin-bottom:16px;max-width:320px}
.footer-brand .footer-contacts{display:flex;flex-wrap:wrap;gap:8px}
.footer-brand .footer-phone{
  display:inline-flex;align-items:center;gap:7px;
  font-weight:700;color:var(--ink);font-size:14px;
  padding:9px 14px;border-radius:999px;
  background:var(--bg-3);border:1.5px solid var(--line);
  transition:all .2s;
}
.footer-brand .footer-phone:hover{border-color:var(--ink)}
.footer-brand .footer-phone .ic{
  width:22px;height:22px;border-radius:50%;background:var(--grad);color:var(--ink);
  display:grid;place-items:center;
}
.footer-col h3,.footer-col h4{
  font-family:'Bricolage Grotesque',sans-serif;font-size:13px;font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--ink);margin-bottom:14px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col a{font-size:13.5px;color:var(--ink-soft);transition:color .2s}
.footer-col a:hover{color:var(--ink)}
.footer-bottom{
  padding-top:24px;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  font-size:12.5px;color:var(--muted);
}
.footer-bottom strong{color:var(--ink)}
.footer-bottom a{color:var(--ink-soft);font-weight:600}
.footer-bottom a:hover{color:var(--ink)}

/* ============================================
   STICKY MOBILE
   ============================================ */
.sticky-mobile{
  display:none;position:fixed;left:8px;right:8px;bottom:8px;z-index:50;
  background:var(--card);border:1.5px solid var(--ink);border-radius:14px;
  padding:6px;box-shadow:0 -10px 30px rgba(22,21,19,.18);gap:6px;
  backdrop-filter:blur(12px);
}
.sticky-mobile .btn{flex:1;padding:13px 8px;font-size:14px}
@media(max-width:780px){.sticky-mobile{display:flex}body{padding-bottom:78px}}

/* ============================================
   MODAL CONTACT
   ============================================ */
.modal-bg{
  position:fixed;inset:0;z-index:200;
  background:rgba(22,21,19,.55);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:14px;
  opacity:0;transition:opacity .25s ease;
}
.modal-bg.open{display:flex;opacity:1}
.modal{
  background:var(--card);border:1.5px solid var(--line);border-radius:22px;
  width:100%;max-width:480px;max-height:92vh;overflow-y:auto;
  padding:30px;position:relative;
  transform:translateY(20px) scale(.98);transition:transform .35s cubic-bezier(.2,.8,.2,1);
  box-shadow:0 28px 70px rgba(22,21,19,.30);
}
.modal-bg.open .modal{transform:translateY(0) scale(1)}
@media(max-width:520px){.modal{padding:24px 20px;border-radius:18px}}
.modal-close{
  position:absolute;top:12px;right:12px;
  width:34px;height:34px;border-radius:50%;
  background:var(--bg-3);color:var(--ink-soft);
  display:grid;place-items:center;transition:all .2s;
  border:1px solid var(--line);
}
.modal-close:hover{background:#fef2f2;color:#dc2626;transform:rotate(90deg);border-color:#fecaca}
.modal-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:var(--lime);color:var(--ink);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:12px;border:1.5px solid var(--ink)}
.modal h3{font-family:'Bricolage Grotesque',sans-serif;font-size:24px;color:var(--ink);margin-bottom:6px;line-height:1.15}
.modal h3 .hl{color:var(--ink);background:var(--grad);padding:0 .12em;border-radius:6px}
.modal-sub{color:var(--ink-soft);font-size:14px;margin-bottom:20px}

.contact-options{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.contact-option{
  display:flex;align-items:center;gap:11px;padding:13px;border-radius:13px;
  border:1.5px solid var(--line);background:var(--card);
  font-weight:600;color:var(--ink);transition:all .2s;
}
.contact-option:hover{border-color:var(--ink);transform:translateX(2px);background:var(--bg-3)}
.contact-option .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.contact-option.phone .ic{background:var(--grad);color:var(--ink)}
.contact-option.wa .ic{background:#16a34a;color:#fff}
.contact-option .info{flex-grow:1;min-width:0}
.contact-option .lbl{font-size:11.5px;color:var(--muted);font-weight:600}
.contact-option .val{font-size:15px;color:var(--ink);font-weight:800;font-family:'Bricolage Grotesque',sans-serif}
.contact-option .arr{color:var(--muted);transition:transform .2s,color .2s}
.contact-option:hover .arr{transform:translateX(4px);color:var(--ink)}

.modal-divider{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.06em;margin:12px 0}
.modal-divider::before,.modal-divider::after{content:"";flex:1;height:1px;background:var(--line)}

.contact-form{display:flex;flex-direction:column;gap:10px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:480px){.form-row{grid-template-columns:1fr}}
.form-field label{font-size:12.5px;color:var(--ink);font-weight:700;margin-bottom:4px;display:block}
.form-field input,.form-field textarea{
  width:100%;padding:11px 13px;border-radius:10px;border:1.5px solid var(--line);
  background:var(--bg-3);font-size:14px;color:var(--ink);font-family:inherit;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted)}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--ink);background:#fff;box-shadow:0 0 0 3px rgba(107,253,217,.25)}
.form-field textarea{min-height:70px;resize:vertical}

.form-success{display:none;text-align:center;padding:24px 12px}
.form-success.show{display:block}
.form-success .ok{width:64px;height:64px;border-radius:50%;background:var(--grad);color:var(--ink);display:grid;place-items:center;margin:0 auto 14px;animation:popIn .45s cubic-bezier(.2,1.5,.3,1);box-shadow:0 16px 40px rgba(107,253,217,.40)}
.form-success h2,.form-success h4{font-size:20px;color:var(--ink);margin-bottom:4px;font-family:'Bricolage Grotesque',sans-serif}
.form-success p{font-size:13.5px;color:var(--ink-soft)}

/* ============================================
   REVEAL ANIMATIONS
   ============================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:none}
.stagger > *{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.stagger.visible > *{opacity:1;transform:none}
.stagger.visible > *:nth-child(1){transition-delay:0s}
.stagger.visible > *:nth-child(2){transition-delay:.08s}
.stagger.visible > *:nth-child(3){transition-delay:.16s}
.stagger.visible > *:nth-child(4){transition-delay:.24s}
.stagger.visible > *:nth-child(5){transition-delay:.32s}
.stagger.visible > *:nth-child(6){transition-delay:.40s}

/* ============================================
   MODULES LISTING & DETAIL
   ============================================ */
.promo-banner{
  display:flex;align-items:center;gap:12px;justify-content:center;flex-wrap:wrap;
  max-width:760px;margin:0 auto 36px;padding:14px 22px;border-radius:14px;
  background:var(--ink);color:#fff;
  font-size:14px;font-weight:600;text-align:center;
  box-shadow:0 12px 30px rgba(22,21,19,.18);
}
.promo-banner .fire{font-size:18px}
.promo-banner code{
  background:var(--grad);color:var(--ink);
  padding:4px 10px;border-radius:8px;font-weight:800;letter-spacing:.04em;
  font-family:'Bricolage Grotesque',monospace;font-size:14px;
}

.modules-grid{
  display:grid;grid-template-columns:1fr;gap:18px;max-width:1100px;margin:0 auto;
}
@media(min-width:680px){.modules-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.modules-grid{grid-template-columns:repeat(3,1fr)}}

.module-card{
  position:relative;background:var(--card);border:1.5px solid var(--line);
  border-radius:20px;padding:24px;display:flex;flex-direction:column;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s;
  overflow:hidden;
  color:inherit;text-decoration:none;
}
.module-card:hover{transform:translateY(-6px);border-color:var(--ink);box-shadow:var(--shadow)}
.module-card .module-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;border-radius:999px;
  font-weight:800;font-size:14.5px;
  background:var(--ink);color:#fff;
  width:100%;text-align:center;
  transition:background .2s;
  box-shadow:0 10px 22px rgba(22,21,19,.18);
}
.module-card:hover .module-cta{background:#000}
.module-card .module-cta .arr{transition:transform .25s}
.module-card:hover .module-cta .arr{transform:translateX(4px)}
.module-card.featured{
  background:linear-gradient(180deg,var(--bg-3) 0%,var(--card) 100%);
  border-color:var(--ink);
}
.module-badge{
  position:absolute;top:14px;right:14px;
  padding:5px 11px;border-radius:999px;
  background:var(--grad);color:var(--ink);
  font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  border:1.5px solid var(--ink);
}
.module-icon{
  display:inline-grid;place-items:center;
  width:56px;height:56px;border-radius:15px;
  background:var(--grad);color:var(--ink);
  font-size:28px;margin-bottom:16px;
  border:1.5px solid rgba(22,21,19,.08);
  box-shadow:0 8px 18px rgba(107,253,217,.25);
}
.module-icon img{
  width:100%;height:100%;object-fit:contain;border-radius:13px;
}
.module-card h3{
  font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:800;
  margin-bottom:8px;line-height:1.2;
}
.module-tagline{font-size:13.5px;color:var(--ink-soft);margin-bottom:14px;flex-grow:1}
.module-meta{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  padding-top:14px;border-top:1px solid var(--line);margin-bottom:14px;
}
.module-rating{
  display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--ink-soft);font-weight:600;
}
.module-rating .stars{color:#f59e0b;display:inline-flex;gap:1px}
.module-rating .stars svg{width:13px;height:13px}
.module-rating span.count{color:var(--muted);font-weight:500}
.module-compat{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 10px;border-radius:999px;
  background:var(--bg-3);color:var(--ink-soft);
  font-size:11.5px;font-weight:700;border:1px solid var(--line);
}
.module-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:14px}
.module-price{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:28px;color:var(--ink);line-height:1}
.module-price.free{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.module-price .ttc{font-size:.5em;color:var(--muted);font-weight:600;margin-left:4px}

/* Module detail page */
.module-detail-hero{
  position:relative;padding:50px 0 30px;overflow:hidden;
}
@media(min-width:780px){.module-detail-hero{padding:70px 0 40px}}
.module-detail-hero .blob-h1{top:-50px;right:-100px;width:340px;height:340px;background:#F0FF6C;opacity:.40}
.module-detail-hero .blob-h2{bottom:0;left:-100px;width:300px;height:300px;background:#6BFDD9;opacity:.30}

.module-detail-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr;gap:30px;align-items:start;
  max-width:1100px;margin:0 auto;
}
@media(min-width:900px){.module-detail-grid{grid-template-columns:1.4fr .9fr;gap:40px}}

.module-buy-card{
  position:relative;background:var(--card);
  border:1.5px solid var(--ink);border-radius:22px;
  padding:24px;box-shadow:var(--shadow);
}
@media(min-width:900px){.module-buy-card{position:sticky;top:90px}}
.module-buy-icon{
  display:inline-grid;place-items:center;width:54px;height:54px;border-radius:15px;
  background:var(--grad);color:var(--ink);font-size:28px;
  margin-bottom:14px;border:1.5px solid rgba(22,21,19,.08);
}
.module-buy-card .price{
  font-family:'Bricolage Grotesque',sans-serif;font-size:42px;font-weight:800;
  color:var(--ink);line-height:1;letter-spacing:-.03em;margin-bottom:4px;
}
.module-buy-card .price .ttc{font-size:.4em;color:var(--muted);font-weight:600;margin-left:6px}
.module-buy-card .price.free{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.module-buy-card .promo-line{font-size:13px;color:var(--ink-soft);margin-bottom:16px}
.module-buy-card .promo-line code{
  background:var(--ink);color:var(--lime);
  padding:2px 8px;border-radius:5px;font-weight:800;letter-spacing:.05em;font-size:12px;
}
.module-buy-card .features{
  list-style:none;display:flex;flex-direction:column;gap:8px;margin:14px 0 18px;
  padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.module-buy-card .features li{display:flex;align-items:flex-start;gap:8px;font-size:13.5px;color:var(--ink-soft)}
.module-buy-card .features li svg{flex-shrink:0;width:16px;height:16px;color:var(--ink);background:var(--grad);border-radius:50%;padding:3px;margin-top:2px}
.module-buy-card .features li strong{color:var(--ink);font-weight:700}

.module-feature-grid{
  display:grid;grid-template-columns:1fr;gap:14px;margin-top:24px;
}
@media(min-width:600px){.module-feature-grid{grid-template-columns:repeat(2,1fr)}}
.module-feature{
  background:var(--card);border:1.5px solid var(--line);border-radius:16px;
  padding:20px;transition:border-color .25s,transform .25s;
}
.module-feature:hover{border-color:var(--ink);transform:translateY(-2px)}
.module-feature .em{
  display:inline-block;font-size:24px;margin-bottom:10px;
}
.module-feature h3,.module-feature h4{font-size:15px;margin-bottom:6px;font-family:'Bricolage Grotesque',sans-serif;font-weight:800}
.module-feature p{font-size:13.5px;color:var(--ink-soft);line-height:1.5}

.spec-table{
  width:100%;border-collapse:collapse;margin:24px 0;
  background:var(--card);border:1.5px solid var(--line);border-radius:14px;overflow:hidden;
}
.spec-table th,.spec-table td{
  padding:12px 16px;text-align:left;font-size:14px;
  border-bottom:1px solid var(--line);
}
.spec-table tr:last-child th,.spec-table tr:last-child td{border-bottom:0}
.spec-table th{background:var(--bg-3);color:var(--ink);font-weight:800;width:40%}
.spec-table td{color:var(--ink-soft)}

/* Module hero image */
.module-hero-img{
  width:100px;height:100px;border-radius:22px;
  object-fit:cover;display:block;margin-bottom:16px;
  border:1.5px solid var(--line);
  background:var(--bg-3);
  box-shadow:0 12px 28px rgba(22,21,19,.10);
}

/* Module screenshot section */
.module-screenshot{
  margin:30px 0;border-radius:18px;overflow:hidden;
  border:1.5px solid var(--line);
  box-shadow:0 18px 44px rgba(22,21,19,.10);
  background:var(--bg-3);
}
.module-screenshot img{width:100%;height:auto;display:block}
.module-screenshot-caption{
  padding:10px 14px;font-size:12px;color:var(--muted);text-align:center;
  background:var(--card);border-top:1px solid var(--line);
}

/* YouTube embed responsive */
.video-wrap{
  position:relative;width:100%;padding-bottom:56.25%;
  border-radius:18px;overflow:hidden;
  background:#000;border:1.5px solid var(--line);
  box-shadow:0 18px 44px rgba(22,21,19,.14);
  margin:24px 0;
}
.video-wrap iframe{
  position:absolute;inset:0;width:100%;height:100%;border:0;
}

/* Module CAROUSEL */
.module-carousel{
  position:relative;margin:24px 0;
  border-radius:18px;overflow:hidden;
  background:var(--bg-3);border:1.5px solid var(--line);
  box-shadow:0 18px 44px rgba(22,21,19,.10);
}
.carousel-track{
  display:flex;overflow-x:auto;
  scroll-snap-type:x mandatory;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.carousel-track::-webkit-scrollbar{display:none}
.carousel-slide{
  flex:0 0 100%;scroll-snap-align:start;
  position:relative;display:flex;align-items:center;justify-content:center;
  background:var(--bg-3);
  aspect-ratio:16/10;
  margin:0;
}
.carousel-slide img{
  width:100%;height:100%;object-fit:contain;display:block;
  cursor:zoom-in;
}
.carousel-slide figcaption{
  position:absolute;bottom:0;left:0;right:0;
  padding:14px 70px 14px 18px;
  background:linear-gradient(to top,rgba(22,21,19,.85) 0%,rgba(22,21,19,.4) 60%,transparent 100%);
  color:#fff;font-size:13px;font-weight:500;
  pointer-events:none;
}

/* Carousel navigation */
.carousel-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.94);border:1.5px solid var(--line);
  display:grid;place-items:center;cursor:pointer;
  backdrop-filter:blur(6px);transition:background .2s,transform .2s,opacity .2s;
  z-index:5;color:var(--ink);
  box-shadow:0 8px 18px rgba(22,21,19,.18);
}
.carousel-nav:hover:not(:disabled){background:#fff;transform:translateY(-50%) scale(1.06)}
.carousel-nav:disabled{opacity:.35;cursor:not-allowed}
.carousel-prev{left:14px}
.carousel-next{right:14px}
.carousel-nav svg{width:18px;height:18px}

/* Carousel counter */
.carousel-counter{
  position:absolute;top:14px;right:14px;
  padding:6px 12px;border-radius:999px;
  background:rgba(22,21,19,.78);color:#fff;
  font-size:11.5px;font-weight:700;letter-spacing:.04em;
  backdrop-filter:blur(8px);z-index:5;
  font-family:'Bricolage Grotesque',sans-serif;
}

/* Carousel dots */
.carousel-dots{
  position:absolute;bottom:14px;left:50%;transform:translateX(-50%);
  display:flex;gap:6px;z-index:5;
  padding:6px 10px;border-radius:999px;
  background:rgba(22,21,19,.65);backdrop-filter:blur(8px);
}
.carousel-dots button{
  width:7px;height:7px;border-radius:50%;
  background:rgba(255,255,255,.45);border:0;cursor:pointer;padding:0;
  transition:background .2s,transform .2s,width .25s;
}
.carousel-dots button.active{background:var(--lime);width:18px;border-radius:5px}
.carousel-dots button:hover{background:rgba(255,255,255,.85)}

@media(max-width:520px){
  .carousel-slide{aspect-ratio:4/3}
  .carousel-nav{width:36px;height:36px}
  .carousel-prev{left:8px}.carousel-next{right:8px}
}

/* Lightbox */
.lightbox-bg{
  position:fixed;inset:0;z-index:300;
  background:rgba(22,21,19,.92);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:30px;
  opacity:0;transition:opacity .25s ease;cursor:zoom-out;
}
.lightbox-bg.open{display:flex;opacity:1}
.lightbox-bg img{
  max-width:100%;max-height:90vh;border-radius:14px;
  box-shadow:0 30px 80px rgba(0,0,0,.50);
}
.lightbox-close{
  position:absolute;top:18px;right:18px;
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.10);color:#fff;
  display:grid;place-items:center;cursor:pointer;
  border:1px solid rgba(255,255,255,.20);
}
.lightbox-close:hover{background:rgba(255,255,255,.20)}

/* Demo banner */
.demo-banner{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:18px 22px;border-radius:16px;
  background:linear-gradient(135deg,rgba(240,255,108,.20),rgba(107,253,217,.20));
  border:1.5px solid var(--line);
  margin:24px 0;
}
.demo-banner .em{
  width:46px;height:46px;border-radius:13px;
  background:var(--grad);color:var(--ink);
  display:grid;place-items:center;font-size:22px;flex-shrink:0;
  border:1.5px solid rgba(22,21,19,.08);
}
.demo-banner .txt{flex-grow:1;min-width:160px}
.demo-banner .txt strong{display:block;font-size:15px;color:var(--ink);font-family:'Bricolage Grotesque',sans-serif;font-weight:800}
.demo-banner .txt span{font-size:13px;color:var(--ink-soft)}
.demo-banner .btn{flex-shrink:0}

/* ============================================
   BLOG
   ============================================ */
.blog-grid{
  display:grid;grid-template-columns:1fr;gap:18px;
  max-width:1100px;margin:0 auto;
}
@media(min-width:680px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.blog-grid{grid-template-columns:repeat(3,1fr)}}

.blog-card{
  position:relative;background:var(--card);border:1.5px solid var(--line);
  border-radius:20px;overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s;
}
.blog-card:hover{transform:translateY(-6px);border-color:var(--ink);box-shadow:var(--shadow)}

.blog-cover{
  aspect-ratio:16/10;overflow:hidden;background:var(--bg-3);
  position:relative;
}
.blog-cover img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.blog-card:hover .blog-cover img{transform:scale(1.04)}

.blog-card-body{padding:22px;display:flex;flex-direction:column;flex-grow:1;gap:10px}
.blog-meta{
  display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);
  font-weight:600;letter-spacing:.02em;
}
.blog-meta .dot{display:inline-block;width:3px;height:3px;border-radius:50%;background:var(--muted)}
.blog-meta .tag{
  display:inline-block;padding:3px 9px;border-radius:999px;
  background:var(--bg-3);color:var(--ink-soft);
  border:1px solid var(--line);font-weight:700;font-size:11px;
}
.blog-card h3{
  font-family:'Bricolage Grotesque',sans-serif;font-size:19px;font-weight:800;
  line-height:1.25;color:var(--ink);
}
.blog-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;flex-grow:1}
.blog-card .read-more{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:800;color:var(--ink);font-size:13.5px;
  padding-top:10px;margin-top:auto;
  font-family:'Bricolage Grotesque',sans-serif;
}
.blog-card .read-more .arr{transition:transform .25s}
.blog-card:hover .read-more .arr{transform:translateX(4px)}

/* Blog post page */
.post-hero{position:relative;padding:50px 0 30px;overflow:hidden}
@media(min-width:780px){.post-hero{padding:70px 0 40px}}
.post-hero .blob-h1{top:-100px;right:-100px;width:380px;height:380px;background:#F0FF6C;opacity:.35}
.post-hero .blob-h2{bottom:-50px;left:-100px;width:340px;height:340px;background:#6BFDD9;opacity:.30}
.post-hero-inner{position:relative;z-index:2;max-width:820px;margin:0 auto;text-align:center}
.post-hero h1{font-size:clamp(30px,5vw,52px);margin-bottom:14px;line-height:1.1}
.post-hero .post-meta{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-size:13px;color:var(--ink-soft);font-weight:600;margin-bottom:14px;
}
.post-hero .post-meta .tag{
  display:inline-block;padding:4px 11px;border-radius:999px;
  background:var(--card);border:1.5px solid var(--line);font-weight:700;font-size:12px;color:var(--ink);
}
.post-hero .post-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted)}

.post-cover{
  max-width:1100px;margin:0 auto 30px;
  border-radius:24px;overflow:hidden;
  border:1.5px solid var(--line);
  box-shadow:0 24px 50px rgba(22,21,19,.12);
  aspect-ratio:16/9;background:var(--bg-3);
}
.post-cover img{width:100%;height:100%;object-fit:cover;display:block}

.post-content{
  max-width:760px;margin:0 auto;padding:0 18px;
  font-size:16.5px;color:var(--ink-soft);line-height:1.75;
}
.post-content h2{
  font-size:clamp(22px,3vw,32px);margin:40px 0 16px;color:var(--ink);
  letter-spacing:-.02em;font-family:'Bricolage Grotesque',sans-serif;
}
.post-content h3{
  font-size:clamp(18px,2.2vw,22px);margin:28px 0 12px;color:var(--ink);
  letter-spacing:-.015em;font-family:'Bricolage Grotesque',sans-serif;
}
.post-content p{margin-bottom:16px;font-size:16.5px;color:var(--ink-soft)}
.post-content strong{color:var(--ink);font-weight:700}
.post-content em{font-style:italic}
.post-content a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;font-weight:600}
.post-content a:hover{color:#000;text-decoration-thickness:2px}
.post-content ul,.post-content ol{margin:0 0 18px 24px}
.post-content li{margin-bottom:10px;font-size:16px}
.post-content hr{
  border:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--line),transparent);
  margin:40px 0;
}
.post-content blockquote{
  border-left:4px solid var(--ink);
  padding:12px 18px;margin:20px 0;
  background:var(--bg-3);border-radius:0 12px 12px 0;
  font-style:italic;color:var(--ink);
}
.post-content img{
  max-width:100%;height:auto;border-radius:14px;margin:20px 0;
  border:1.5px solid var(--line);
}

.post-footer{
  max-width:760px;margin:50px auto 0;padding:30px 18px;
  border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
}
.post-footer .back{font-weight:700;color:var(--ink-soft);font-size:14px}
.post-footer .back:hover{color:var(--ink)}

/* ============================================
   PAGE GENERIC (sub-pages)
   ============================================ */
.page-hero{position:relative;padding:60px 0 50px;overflow:hidden}
@media(min-width:780px){.page-hero{padding:90px 0 70px}}
.page-hero .blob-h1{top:-100px;right:-100px;width:380px;height:380px;background:#F0FF6C;opacity:.40}
.page-hero .blob-h2{bottom:-50px;left:-100px;width:340px;height:340px;background:#6BFDD9;opacity:.35}
.page-hero-inner{position:relative;z-index:2;max-width:840px;margin:0 auto;text-align:center}
.page-hero h1{font-size:clamp(34px,5.5vw,64px);margin-bottom:14px}
.page-hero .lead{margin:0 auto 24px;font-size:17px}

.breadcrumb{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;color:var(--muted);font-weight:500;
  margin-bottom:18px;
}
.breadcrumb a{color:var(--ink-soft)}
.breadcrumb a:hover{color:var(--ink)}
.breadcrumb .sep{opacity:.5}

.prose{max-width:760px;margin:0 auto;font-size:16px;color:var(--ink-soft);line-height:1.7}
.prose h2{font-size:clamp(24px,3vw,34px);margin:36px 0 16px}
.prose h3{font-size:clamp(19px,2vw,22px);margin:28px 0 10px}
.prose p{margin-bottom:16px;font-size:16px}
.prose ul,.prose ol{margin:0 0 16px 22px}
.prose li{margin-bottom:8px}
.prose strong{color:var(--ink);font-weight:700}
.prose a{color:var(--ink);text-decoration:underline;font-weight:600}
.prose a:hover{color:#000}

/* ============================================
   Panels narratifs (mockup erreur, rapport mensuel, compare)
   ============================================ */

/* Panel mockup site HS / Erreur 500 */
.error-mockup{
  max-width:580px;margin:0 auto 32px;
  background:#fff;border:1px solid var(--line);border-radius:18px;
  box-shadow:0 24px 60px -28px rgba(220,38,38,.18);
  overflow:hidden;
}
.error-mockup-bar{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;background:#faf6ee;border-bottom:1px solid var(--line);
  font-size:13px;color:var(--muted);
}
.error-mockup-bar .dots{display:flex;gap:6px}
.error-mockup-bar .dots span{width:10px;height:10px;border-radius:50%;background:#d8d0bd}
.error-mockup-bar .url{
  flex:1;text-align:center;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;
  font-size:12.5px;color:#8a8276;
}
.error-mockup-body{padding:32px 28px;text-align:center}
.error-mockup-code{
  font-size:64px;font-weight:900;line-height:1;color:#dc2626;
  letter-spacing:-.04em;margin-bottom:6px;
}
.error-mockup-title{
  font-size:18px;font-weight:800;color:var(--ink);margin-bottom:8px;
}
.error-mockup-sub{
  font-size:14.5px;color:var(--ink-soft);margin-bottom:22px;line-height:1.5;
}
.error-mockup-issues{
  list-style:none;padding:14px 0 0;margin:0;border-top:1px solid var(--line);
  display:grid;gap:8px;text-align:left;
}
.error-mockup-issues li{
  font-size:13.5px;color:var(--ink-soft);
  padding-left:22px;position:relative;
}
.error-mockup-issues li::before{
  content:"⚠️";position:absolute;left:0;top:0;font-size:13px;
}
.error-mockup-issues li.loss{color:#dc2626;font-weight:700}
.error-mockup-issues li.loss::before{content:"💸"}

/* Panel rapport mensuel */
.report-panel{
  max-width:780px;margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:22px;
  box-shadow:0 24px 60px -28px rgba(107,253,217,.35);
  overflow:hidden;
}
.report-panel-head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:18px 22px;background:linear-gradient(135deg,#fafff5,#f0fdf4);
  border-bottom:1px solid var(--line);
}
.report-panel-title{display:flex;flex-direction:column;gap:2px}
.report-panel-title .name{
  font-size:15.5px;font-weight:800;color:var(--ink);letter-spacing:-.01em;
}
.report-panel-title .sub{
  font-size:13px;color:var(--muted);font-weight:500;
}
.report-panel-status{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:99px;
  background:#dcfce7;color:#16a34a;
  font-size:12.5px;font-weight:700;letter-spacing:.02em;
}
.report-panel-status::before{
  content:"";width:7px;height:7px;border-radius:50%;background:#16a34a;
  box-shadow:0 0 0 3px rgba(22,163,74,.18);
}
.report-panel-body{padding:22px}
.report-metrics{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.report-metric{
  background:#faf9f5;border:1px solid var(--line);border-radius:14px;
  padding:16px 14px;text-align:center;
}
.report-metric .lbl{
  font-size:12px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;
}
.report-metric .val{
  font-size:26px;font-weight:900;color:var(--ink);letter-spacing:-.02em;
}
.report-metric .val.up{color:#16a34a}
.report-panel-footer{
  padding:14px 22px;background:#fafff5;border-top:1px solid var(--line);
  font-size:13.5px;color:var(--ink-soft);
}
.report-panel-footer strong{color:var(--ink)}
@media (max-width:680px){
  .report-metrics{grid-template-columns:repeat(2,1fr)}
  .report-panel-head{flex-direction:column;align-items:flex-start}
}

/* Panels avant / après */
.compare-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:18px;max-width:920px;margin:0 auto;
}
.compare-panel{
  background:#fff;border-radius:20px;padding:0;
  border:1px solid var(--line);overflow:hidden;
}
.compare-panel.before{box-shadow:0 18px 50px -28px rgba(220,38,38,.25)}
.compare-panel.after{box-shadow:0 18px 50px -28px rgba(22,163,74,.30)}
.compare-panel-head{
  padding:14px 20px;border-bottom:1px solid var(--line);
  font-size:13px;font-weight:800;letter-spacing:.05em;
}
.compare-panel.before .compare-panel-head{
  background:#fef2f2;color:#dc2626;
}
.compare-panel.after .compare-panel-head{
  background:#f0fdf4;color:#16a34a;
}
.compare-panel-body{padding:6px 20px 18px}
.compare-row{
  padding:14px 0;border-bottom:1px solid var(--line);
}
.compare-row:last-child{border-bottom:0}
.compare-row .lbl{
  font-size:12.5px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;
}
.compare-row .val{
  font-size:22px;font-weight:900;color:var(--ink);
  letter-spacing:-.02em;line-height:1.1;
}
.compare-row .note{
  display:block;font-size:13px;color:var(--ink-soft);
  font-weight:500;margin-top:4px;
}
.compare-panel.before .compare-row .val{color:#dc2626}
.compare-panel.after .compare-row .val{color:#16a34a}

/* ============================================================================
   redesign.css (concaténé pour réduire les requêtes bloquantes)
   ============================================================================ */
/* ============================================
   KLN-WEB · Redesign 2026
   Charge APRÈS main.css.
   - Override du chrome (topbar/nav/footer/modal/sticky)
   - Nouveaux composants pour pages refondues (préfixe .r-)
   - Garde intact l'intérieur de la page d'accueil
   ============================================ */

:root{
  /* === Palette éditoriale chaude === */
  --r-cream:#F2EBDC;       /* bone — crème chaud principal */
  --r-cream-2:#FAF5EA;     /* cream pâle — cards */
  --r-cream-3:#E5DBC5;     /* sand — sections soft */
  --r-paper:#FCF8EE;       /* paper — surfaces blanches chaudes */
  --r-ink:#1A1410;         /* espresso — noir chaud profond */
  --r-ink-soft:#3D3530;    /* clove — body text */
  --r-ink-mute:#776F66;    /* taupe — meta */
  --r-line:#1A1410;
  --r-line-soft:#D4C8AF;   /* line claire chaude */
  --r-orange:#D85F38;      /* terracotta — accent primaire */
  --r-orange-2:#B84D2A;    /* terracotta hover */
  --r-green:#6B8E60;       /* sage — CTA secondaire */
  --r-green-2:#557048;     /* sage hover */
  --r-yellow:#E8B547;      /* saffron — surligneurs / highlights */
  --r-yellow-2:#D49E2E;    /* saffron hover */
  --r-gold:#C68F2A;        /* gold — accents bandeau marine */
  --r-red:#C4422E;         /* rust red — alerts */
  --r-shadow:0 24px 60px -20px rgba(26,20,16,.25);
  --r-shadow-sm:0 6px 18px -6px rgba(26,20,16,.18);

  --r-font-sans:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  --r-font-display:'Bricolage Grotesque','Inter',sans-serif;
  --r-font-hand:'Caveat','Bricolage Grotesque',cursive;
  --r-font-marker:'Permanent Marker','Caveat',cursive;
}

/* ============================================
   GLOBAL — fond crème pour tout le site
   (l'accueil utilisait déjà un crème pâle, on harmonise)
   ============================================ */
body{background:var(--r-cream)}
::selection{background:var(--r-yellow);color:var(--r-ink)}

/* ============================================
   TOPBAR — fin, sombre, vivant
   ============================================ */
.topbar{
  background:var(--r-ink);
  color:rgba(255,255,255,.82);
  font-family:var(--r-font-sans);
  font-size:12.5px;font-weight:500;
  text-align:center;padding:8px 14px;
  letter-spacing:.01em;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;gap:0;
  flex-wrap:nowrap;white-space:nowrap;overflow:hidden;
}
.topbar strong{color:var(--r-orange);font-weight:800;letter-spacing:.04em}
.topbar .topbar-mid{color:#fff;font-weight:600}
.topbar a{
  color:#fff;font-weight:700;
  text-decoration:none;
  display:inline-flex;align-items:center;gap:5px;
  padding:1px 8px;border-radius:6px;
  transition:background .15s;
}
.topbar a:hover{background:rgba(255,255,255,.1)}
.topbar a .ph{font-size:11px;line-height:1}
.topbar .sep{margin:0 10px;color:rgba(255,255,255,.25);font-weight:300}

/* Petit point pulsant "live" devant la première mention */
.topbar-live{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:#3FD66B;
  margin-right:8px;flex-shrink:0;
  box-shadow:0 0 0 0 rgba(63,214,107,.6);
  animation:topbarPulse 2s ease-out infinite;
}
@keyframes topbarPulse{
  0%   {box-shadow:0 0 0 0 rgba(63,214,107,.55)}
  70%  {box-shadow:0 0 0 8px rgba(63,214,107,0)}
  100% {box-shadow:0 0 0 0 rgba(63,214,107,0)}
}
@media(max-width:680px){
  .topbar{font-size:11.5px;padding:6px 10px;gap:0}
  .topbar .sep{margin:0 6px}
  .topbar-live{width:7px;height:7px;margin-right:6px}
  /* On masque le bloc central + son séparateur pour garder live + strong + sep + tel sur une ligne */
  .topbar .topbar-mid,
  .topbar .topbar-mid + .sep{display:none}
}
@media(max-width:380px){
  .topbar{font-size:10.5px;padding:5px 8px}
  .topbar .sep{margin:0 5px}
  .topbar a{padding:1px 6px}
  .topbar a .ph{display:none}
}

/* ============================================
   NAV — espresso, contraste fort
   ============================================ */
.nav{
  background:var(--r-ink);
  border-bottom:0;
  position:sticky;top:0;z-index:50;
  transition:background .25s,box-shadow .25s;
}
.nav.scrolled{
  background:rgba(26,20,16,.94);
  backdrop-filter:blur(10px);
  box-shadow:0 8px 22px -16px rgba(0,0,0,.5);
}
.nav-inner{height:78px}
@media(min-width:780px){.nav-inner{height:92px}}
.nav .logo{background:transparent;padding:0;box-shadow:none}
.nav .logo img{height:48px;filter:brightness(0) invert(1)}
@media(min-width:780px){.nav .logo img{height:64px}}

.nav-links{gap:2px}
.nav-links a{
  font-family:var(--r-font-sans);font-weight:500;font-size:14.5px;
  color:rgba(255,255,255,.72);
  padding:8px 14px;border-radius:8px;
  transition:color .2s,background .2s;
  position:relative;
}
.nav-links a:hover{color:#fff;background:transparent}
.nav-links a.active{color:#fff;font-weight:600}
.nav-links a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:2px;height:2px;
  background:var(--r-orange);border-radius:2px;
}

.nav-phone{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--r-font-sans);font-weight:600;font-size:14px;
  color:var(--r-ink);
  padding:8px 14px;border-radius:999px;
  background:transparent;border:1.5px solid var(--r-line-soft);
  box-shadow:none;
  transition:border-color .2s,color .2s;
}
.nav-phone:hover{border-color:var(--r-ink);color:var(--r-ink);transform:none;box-shadow:none}
.nav-phone .ic{
  width:20px;height:20px;border-radius:50%;
  background:var(--r-orange);color:#fff;
  display:grid;place-items:center;
}

.nav-cta{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--r-font-sans);font-weight:700;font-size:14px;
  color:#fff;background:var(--r-ink);
  padding:10px 18px;border-radius:10px;
  border:0;box-shadow:none;
  transition:background .15s,transform .15s;
  text-transform:none;letter-spacing:.01em;
}
.nav-cta:hover{
  background:var(--r-orange);
  transform:translateY(-1px);
  box-shadow:0 8px 18px -8px rgba(216,95,56,.55);
}

.nav-burger{
  background:transparent;
  border:1.5px solid rgba(255,255,255,.22);
}
.nav-burger:hover{border-color:rgba(255,255,255,.55)}
.nav-burger span{background:#fff;height:2px}

/* Sélecteur de langue (dropdown) — sur fond espresso */
.lang-switcher{
  position:relative;
  display:inline-flex;
  margin-right:6px;
}
.lang-toggle{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 12px;border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.18);
  font-family:var(--r-font-sans);font-weight:600;font-size:12px;
  color:#fff;
  cursor:pointer;
  transition:border-color .15s,background .15s;
  letter-spacing:.04em;
}
.lang-toggle:hover{border-color:#fff;background:rgba(255,255,255,.1)}
.lang-toggle .flag{font-size:14px;line-height:1}
.lang-toggle .code{letter-spacing:.06em}
.lang-toggle .caret{transition:transform .2s;color:rgba(255,255,255,.6)}
.lang-switcher[data-lang-switcher].is-open .lang-toggle{
  background:#fff;color:var(--r-ink);border-color:#fff;
}
.lang-switcher[data-lang-switcher].is-open .lang-toggle .caret{
  transform:rotate(180deg);color:var(--r-ink);
}

.lang-menu{
  position:absolute;top:calc(100% + 8px);right:0;
  min-width:170px;
  background:var(--r-paper);
  border:1.5px solid var(--r-line-soft);
  border-radius:14px;
  box-shadow:0 18px 40px -16px rgba(26,20,16,.25), 0 6px 14px -10px rgba(26,20,16,.12);
  padding:6px;
  display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;transform:translateY(-6px) scale(.98);
  transform-origin:top right;
  transition:opacity .18s ease,transform .18s ease,visibility .18s;
  z-index:60;
}
.lang-switcher[data-lang-switcher].is-open .lang-menu{
  opacity:1;visibility:visible;transform:translateY(0) scale(1);
}
.lang-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:9px;
  font-family:var(--r-font-sans);font-weight:500;font-size:13.5px;
  color:var(--r-ink-soft);
  text-decoration:none;
  transition:background .15s,color .15s,padding-left .15s;
  position:relative;
}
.lang-item:hover{
  background:var(--r-cream-3);
  color:var(--r-ink);
  padding-left:16px;
}
.lang-item:hover .flag{transform:scale(1.15)}
.lang-item .flag{font-size:16px;line-height:1;flex-shrink:0;transition:transform .15s}
.lang-item .lbl{flex:1}
.lang-item.is-active{
  background:var(--r-ink);color:var(--r-cream);font-weight:600;
}
.lang-item.is-active::after{
  content:"✓";margin-left:6px;color:var(--r-yellow);font-weight:800;
}
.lang-item.is-active:hover{
  background:var(--r-ink);color:var(--r-cream);
  padding-left:12px;
}
.lang-item.is-active:hover .flag{transform:none}

/* Mobile : compact à gauche du burger (la caret est masquée pour gagner de la place) */
@media(max-width:779px){
  .lang-switcher{margin-right:4px}
  .lang-toggle{padding:6px 10px;gap:5px;font-size:11.5px}
  .lang-toggle .caret{display:none}
  .lang-menu{right:0;min-width:160px}
}
.mobile-menu{
  background:var(--r-ink);
  border-top:1px solid rgba(255,255,255,.12);
  padding:10px 14px;
}
.mobile-menu a{
  font-family:var(--r-font-sans);font-weight:500;color:rgba(255,255,255,.78);
  border-bottom:1px solid rgba(255,255,255,.08);
  border-radius:0;padding:13px 4px;font-size:15px;
}
.mobile-menu a:last-child{border-bottom:0}
.mobile-menu a:hover,
.mobile-menu a.active{background:transparent;color:#fff;font-weight:600}

/* ============================================
   FOOTER — espresso, accents terracotta & manuscrits
   ============================================ */
footer{
  background:var(--r-ink);
  color:rgba(255,255,255,.78);
  border-top:5px solid var(--r-orange);
  padding:56px 0 22px;
  font-family:var(--r-font-sans);
  position:relative;
}
footer .container{position:relative;z-index:1}

footer .footer-grid{
  display:grid;gap:36px;
  grid-template-columns:1fr;
  margin-bottom:36px;
  padding-bottom:30px;
  border-bottom:1.5px dashed rgba(255,255,255,.14);
}
@media(min-width:780px){
  footer .footer-grid{
    grid-template-columns:1.6fr 1fr 1fr 1fr;
    gap:40px;
    align-items:flex-start;
  }
}

/* Brand */
.footer-brand .logo img{
  height:42px;filter:brightness(0) invert(1);
  margin-bottom:16px;
}
.footer-brand p{
  color:rgba(255,255,255,.72);font-size:14.5px;line-height:1.6;
  margin:0 0 20px;max-width:340px;
}
.footer-brand .signature{
  display:inline-block;font-family:var(--r-font-hand);font-weight:700;
  font-size:22px;color:var(--r-yellow);line-height:1;
  margin-bottom:18px;transform:rotate(-2deg);
  position:relative;
}
.footer-brand .signature::after{
  content:"";display:block;width:70px;height:4px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 4'><path d='M2,2 Q20,0 40,2 T78,2' stroke='%23E8B547' stroke-width='2' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
  margin-top:4px;
}

/* Contacts pastilles */
.footer-contacts{display:flex;flex-wrap:wrap;gap:10px}
.footer-brand .footer-phone{
  background:transparent;
  border:1.5px solid rgba(255,255,255,.22);
  color:#fff;font-weight:600;font-size:13.5px;
  padding:9px 14px;border-radius:10px;
  display:inline-flex;align-items:center;gap:9px;
  transition:border-color .2s,background .2s,transform .15s;
}
.footer-brand .footer-phone:hover{
  background:rgba(216,95,56,.12);
  border-color:var(--r-orange);
  transform:translateY(-1px);
}
.footer-brand .footer-phone .ic{
  width:22px;height:22px;border-radius:50%;
  background:var(--r-orange);color:#fff;
  display:grid;place-items:center;flex-shrink:0;
}

/* Columns */
footer .footer-col h3,footer .footer-col h4,
footer h3,footer h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;margin:0 0 16px;
  display:inline-flex;align-items:center;gap:8px;
}
footer .footer-col h3::before,footer .footer-col h4::before,
footer h3::before,footer h4::before{
  content:"";width:8px;height:8px;
  background:var(--r-orange);border-radius:2px;
  flex-shrink:0;
}
footer .footer-col ul{
  list-style:none;display:flex;flex-direction:column;gap:10px;
  padding:0;margin:0;
}
footer .footer-col a{
  color:rgba(255,255,255,.72);font-size:14px;font-weight:500;
  transition:color .2s,padding-left .2s;
  position:relative;display:inline-block;
}
footer .footer-col a:hover{color:var(--r-yellow);padding-left:6px}

/* Bottom */
.footer-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;
  align-items:center;gap:12px;
  font-size:12.5px;color:rgba(255,255,255,.5);
  padding-top:8px;
}
.footer-bottom strong{color:rgba(255,255,255,.85);font-weight:700}
.footer-bottom a{color:rgba(255,255,255,.72);transition:color .2s}
.footer-bottom a:hover{color:var(--r-yellow)}
.footer-bottom .sep{margin:0 6px;color:rgba(255,255,255,.25)}

/* ============================================
   STICKY MOBILE — restyling
   ============================================ */
.sticky-mobile{
  display:none;
  background:var(--r-cream);
  border-top:1px solid var(--r-line-soft);
  padding:10px 12px;
  align-items:center;justify-content:center;gap:10px;
}
@media(max-width:780px){
  .sticky-mobile{display:flex}
  body{padding-bottom:72px}
}
.sticky-mobile .r-btn{flex:1;justify-content:center;text-align:center;padding:12px 16px;font-size:14px}

/* ============================================
   COOKIE BANNER — carte crème discrète bottom-right
   ============================================ */
.cookie-bar{
  position:fixed;right:20px;bottom:20px;left:auto;
  max-width:380px;
  background:var(--r-paper);
  color:var(--r-ink);
  border:1.5px solid var(--r-line-soft);
  border-left:4px solid var(--r-orange);
  border-radius:14px;
  padding:18px 20px;
  box-shadow:0 24px 60px -20px rgba(26,20,16,.30), 0 8px 16px -10px rgba(26,20,16,.15);
  z-index:60;
  font-family:var(--r-font-sans);
  animation:cookieSlideUp .35s cubic-bezier(.22,1,.36,1);
}
@keyframes cookieSlideUp{
  from{transform:translateY(20px) scale(.97);opacity:0}
  to{transform:translateY(0) scale(1);opacity:1}
}
.cookie-bar[hidden]{display:none}

.cookie-bar__text{
  font-size:13px;line-height:1.55;color:var(--r-ink-soft);
  margin-bottom:14px;
}
.cookie-bar__text strong{
  display:block;margin-bottom:6px;font-size:14px;color:var(--r-ink);
  font-family:var(--r-font-display);font-weight:800;
  letter-spacing:.01em;
  display:flex;align-items:center;gap:7px;
}
.cookie-bar__text strong::before{
  content:"🍪";font-size:16px;line-height:1;
}
.cookie-bar__text a{
  color:var(--r-orange);font-weight:700;
  text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px;
}
.cookie-bar__text a:hover{color:var(--r-orange-2)}

.cookie-bar__actions{
  display:flex;gap:8px;
  border-top:1px dashed var(--r-line-soft);
  padding-top:12px;
}
.cookie-bar__btn{
  flex:1;padding:9px 14px;border-radius:8px;
  font-family:var(--r-font-sans);font-weight:700;font-size:13px;
  border:1.5px solid;cursor:pointer;
  transition:all .15s ease;
  letter-spacing:.01em;
}
.cookie-bar__btn--refuse{
  background:transparent;color:var(--r-ink-mute);
  border-color:var(--r-line-soft);
}
.cookie-bar__btn--refuse:hover{
  color:var(--r-ink);border-color:var(--r-ink);background:var(--r-cream-2);
}
.cookie-bar__btn--accept{
  background:var(--r-ink);color:#fff;border-color:var(--r-ink);
}
.cookie-bar__btn--accept:hover{
  background:var(--r-orange);border-color:var(--r-orange);
  transform:translateY(-1px);
  box-shadow:0 6px 14px -6px rgba(216,95,56,.55);
}

@media(max-width:520px){
  .cookie-bar{
    left:12px;right:12px;bottom:12px;max-width:none;
    padding:16px;
  }
}

/* ============================================
   MODAL — restyling
   ============================================ */
.modal{
  background:var(--r-cream);
  border:3px solid var(--r-ink);
  box-shadow:8px 8px 0 var(--r-ink);
  border-radius:24px;
}
.modal-tag{
  background:var(--r-yellow);color:var(--r-ink);
  border:2px solid var(--r-ink);
  font-family:var(--r-font-sans);font-weight:800;
  padding:6px 14px;border-radius:999px;font-size:12.5px;letter-spacing:.04em;
  display:inline-block;margin-bottom:14px;
}
.modal h3{font-family:var(--r-font-display);color:var(--r-ink)}
.modal h3 .hl{
  background:linear-gradient(transparent 60%,var(--r-yellow) 60%);
  padding:0 4px;
}
.contact-option{
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  box-shadow:3px 3px 0 var(--r-ink);
  border-radius:16px;
  transition:all .15s;
}
.contact-option:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--r-ink)}
.contact-option.phone .ic{background:var(--r-orange);color:#fff}
.contact-option.wa .ic{background:#25D366;color:#fff}
.contact-option .info .lbl{color:var(--r-ink-mute);font-size:12.5px;font-weight:600}
.contact-option .info .val{color:var(--r-ink);font-weight:800;font-size:15.5px}
.modal-divider{
  display:flex;align-items:center;gap:12px;
  font-family:var(--r-font-display);font-weight:800;font-size:11.5px;
  letter-spacing:.18em;color:var(--r-ink-mute);
  margin:18px 0 14px;
  text-align:center;
}
.modal-divider::before,.modal-divider::after{
  content:"";flex:1;height:2px;background:var(--r-line-soft);
}
.contact-form .form-field input,
.contact-form .form-field textarea{
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  border-radius:12px;
  padding:11px 14px;font-size:14.5px;
  font-family:var(--r-font-sans);color:var(--r-ink);
  width:100%;transition:all .15s;
}
.contact-form .form-field input:focus,
.contact-form .form-field textarea:focus{
  outline:0;
  box-shadow:3px 3px 0 var(--r-ink);
  transform:translate(-1px,-1px);
}
.contact-form .form-field label{
  display:block;font-size:12.5px;font-weight:700;
  color:var(--r-ink);margin-bottom:6px;
  letter-spacing:.02em;
}
.form-success .ok{background:var(--r-green);color:#fff}
.form-success h2,.form-success h4{font-family:var(--r-font-display);color:var(--r-ink)}

/* ============================================
   COMPOSANTS REDESIGN — préfixe .r-
   ============================================ */

/* --- Page hero (compact) --- */
.r-pagehero{
  background:var(--r-cream);
  padding:18px 0 0;
  position:relative;
  border-bottom:0;
}
@media(min-width:780px){.r-pagehero{padding:24px 0 0}}

.r-crumb{
  display:flex;align-items:center;gap:7px;flex-wrap:wrap;
  font-family:var(--r-font-sans);font-size:11.5px;font-weight:500;
  color:var(--r-ink-mute);
  padding-bottom:14px;
  margin-bottom:24px;
  border-bottom:1px solid var(--r-line-soft);
  letter-spacing:.01em;
}
.r-crumb a{color:var(--r-ink-mute);transition:color .2s}
.r-crumb a:hover{color:var(--r-orange)}
.r-crumb .sep{color:var(--r-ink-mute);opacity:.45;font-weight:300}
.r-crumb .here{color:var(--r-ink);font-weight:600}

.r-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--r-yellow);color:var(--r-ink);
  border:1.5px solid var(--r-ink);
  font-family:var(--r-font-sans);font-weight:700;font-size:11px;
  padding:3px 10px;border-radius:6px;
  letter-spacing:.05em;text-transform:uppercase;
  margin-bottom:10px;
  box-shadow:none;
}
.r-eyebrow.green{background:#C5D5BA}
.r-eyebrow.orange{background:var(--r-orange);color:#fff;border-color:var(--r-ink)}
.r-eyebrow .em{font-size:12px}

.r-pagehero h1{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(26px,3.6vw,38px);line-height:1.05;
  letter-spacing:-.02em;color:var(--r-ink);
  margin:0 0 8px;text-transform:none;
}
.r-pagehero h1 .r-hl{
  background:linear-gradient(transparent 60%,var(--r-yellow) 60%);
  padding:0 4px;
}
.r-pagehero h1 .r-orange{color:var(--r-orange)}
.r-pagehero h1 .r-script{
  font-family:var(--r-font-hand);font-weight:700;
  color:var(--r-orange);text-transform:none;
  font-size:1.15em;letter-spacing:0;
  position:relative;display:inline-block;line-height:.9;
}
.r-pagehero h1 .r-script::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:-2px;height:5px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8'><path d='M2,5 Q40,1 80,4 T160,3 T198,5' stroke='%23D85F38' stroke-width='3' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
}
.r-pagehero .r-lead{
  font-family:var(--r-font-sans);font-size:14.5px;line-height:1.55;
  color:var(--r-ink-soft);max-width:680px;
  margin:0;
}
.r-pagehero .r-lead strong{color:var(--r-ink);font-weight:700}

/* --- Composant CTA création (home) --- */
.r-create-band{
  display:grid;gap:32px;grid-template-columns:1fr;align-items:center;
  background:var(--r-cream-2);
  border:2.5px solid var(--r-ink);
  border-radius:24px;
  padding:32px;
  box-shadow:6px 6px 0 var(--r-ink);
  max-width:1100px;margin:0 auto;
}
@media(min-width:880px){.r-create-band{grid-template-columns:1.05fr 1fr;gap:40px;padding:40px}}
.r-create-band-left h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(28px,3.8vw,44px);line-height:1.05;
  color:var(--r-ink);text-transform:uppercase;letter-spacing:-.02em;
  margin:6px 0 14px;
}
.r-create-band-left h2 .r-script{
  font-family:var(--r-font-hand);font-weight:700;
  text-transform:none;color:var(--r-orange);font-size:1.15em;letter-spacing:0;
}
.r-create-band-left p{
  font-family:var(--r-font-sans);font-size:15.5px;line-height:1.6;
  color:var(--r-ink-soft);max-width:480px;
}
.r-create-band-left p strong{color:var(--r-ink);font-weight:700}
.r-create-band-right{display:flex;flex-direction:column;gap:10px}
.r-create-item{
  display:flex;align-items:center;gap:14px;
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  border-radius:14px;
  padding:14px 16px;
  text-decoration:none;color:var(--r-ink);
  transition:transform .15s,box-shadow .15s,background .15s;
  box-shadow:3px 3px 0 var(--r-ink);
}
.r-create-item:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--r-ink);background:#fff}
.r-create-item .ic{
  width:40px;height:40px;border-radius:10px;
  background:var(--r-cream-3);color:var(--r-ink);
  border:2px solid var(--r-ink);
  display:grid;place-items:center;flex-shrink:0;
}
.r-create-item .ic svg{width:20px;height:20px;stroke-width:2.4}
.r-create-item .info{flex:1;min-width:0}
.r-create-item .info h3,.r-create-item .info h4{
  font-family:var(--r-font-display);font-weight:800;font-size:14.5px;
  color:var(--r-ink);text-transform:uppercase;letter-spacing:.01em;
  line-height:1.1;margin:0 0 2px;
}
.r-create-item .info p{
  font-family:var(--r-font-sans);font-size:12.5px;color:var(--r-ink-mute);
  margin:0;line-height:1.3;
}
.r-create-item .price{
  font-family:var(--r-font-display);font-weight:800;font-size:14px;
  color:var(--r-orange);flex-shrink:0;white-space:nowrap;
}

/* --- Section --- */
.r-section{padding:40px 0;position:relative}
@media(min-width:780px){.r-section{padding:60px 0}}
.r-section.alt{background:var(--r-cream-3)}
.r-section.dark{background:var(--r-ink);color:#fff}
.r-section.dark h2,.r-section.dark h3{color:#fff}

.r-sectionhead{text-align:center;max-width:740px;margin:0 auto 50px}
.r-sectionhead .r-eyebrow{margin-bottom:14px}
.r-sectionhead h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(30px,4.4vw,52px);line-height:1.05;
  color:var(--r-ink);text-transform:uppercase;letter-spacing:-.02em;
  margin-bottom:14px;
}
.r-sectionhead h2 .r-hl{background:linear-gradient(transparent 60%,var(--r-yellow) 60%);padding:0 5px}
.r-sectionhead h2 .r-orange{color:var(--r-orange)}
.r-sectionhead p{
  font-family:var(--r-font-sans);font-size:16.5px;line-height:1.6;
  color:var(--r-ink-soft);max-width:560px;margin:0 auto;
}

/* --- Buttons --- */
.r-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--r-font-sans);font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;font-size:14.5px;
  padding:14px 26px;border-radius:14px;
  border:2.5px solid var(--r-ink);
  box-shadow:4px 4px 0 var(--r-ink);
  transition:all .15s;
  cursor:pointer;
}
.r-btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--r-ink)}
.r-btn:active{transform:translate(0,0);box-shadow:2px 2px 0 var(--r-ink)}
.r-btn-lg{padding:18px 34px;font-size:16px;border-radius:16px}
.r-btn-block{width:100%}
.r-btn-green{background:var(--r-green);color:#fff}
.r-btn-green:hover{background:var(--r-green-2)}
.r-btn-orange{background:var(--r-orange);color:#fff}
.r-btn-orange:hover{background:var(--r-orange-2)}
.r-btn-dark{background:var(--r-ink);color:#fff}
.r-btn-dark:hover{background:#000}
.r-btn-ghost{background:var(--r-cream-2);color:var(--r-ink)}
.r-btn-ghost:hover{background:#fff}
.r-btn-yellow{background:var(--r-yellow);color:var(--r-ink)}
.r-btn-yellow:hover{background:var(--r-yellow-2)}

/* Brush button - bouton avec coup de pinceau */
.r-brushbtn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--r-font-sans);font-weight:800;color:#fff;
  text-transform:uppercase;letter-spacing:.04em;font-size:15px;
  padding:22px 50px;border:0;background:transparent;
  cursor:pointer;
  filter:drop-shadow(2px 3px 0 rgba(15,30,51,.25));
  transition:transform .15s;
}
.r-brushbtn::before{
  content:"";position:absolute;inset:0;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 80' preserveAspectRatio='none'><path d='M8,18 Q4,8 18,12 Q60,4 130,10 Q210,2 280,12 Q340,4 392,10 Q396,30 388,50 Q394,68 380,72 Q300,78 220,68 Q140,76 60,68 Q12,76 8,62 Q2,40 8,18 Z' fill='%236B8E60'/></svg>") no-repeat center/100% 100%;
  z-index:-1;
}
.r-brushbtn:hover{transform:translateY(-2px)}
.r-brushbtn .arr{font-size:1.1em;margin-left:6px}
.r-brushbtn.orange::before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 80' preserveAspectRatio='none'><path d='M8,18 Q4,8 18,12 Q60,4 130,10 Q210,2 280,12 Q340,4 392,10 Q396,30 388,50 Q394,68 380,72 Q300,78 220,68 Q140,76 60,68 Q12,76 8,62 Q2,40 8,18 Z' fill='%23D85F38'/></svg>")}
.r-brushbtn.dark::before{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 400 80' preserveAspectRatio='none'><path d='M8,18 Q4,8 18,12 Q60,4 130,10 Q210,2 280,12 Q340,4 392,10 Q396,30 388,50 Q394,68 380,72 Q300,78 220,68 Q140,76 60,68 Q12,76 8,62 Q2,40 8,18 Z' fill='%231A1410'/></svg>")}

/* --- Highlights & accents handwritten --- */
.r-hl{background:linear-gradient(transparent 60%,var(--r-yellow) 60%);padding:0 4px}
.r-hl-orange{background:linear-gradient(transparent 60%,#EBC5A1 60%);padding:0 4px}
.r-orange{color:var(--r-orange)}
.r-script{font-family:var(--r-font-hand);font-weight:700;font-size:1.2em;color:var(--r-orange);line-height:1}
.r-marker{font-family:var(--r-font-hand);font-weight:700;color:var(--r-ink)}
.r-uline{
  position:relative;display:inline-block;
}
.r-uline::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:-3px;height:6px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8'><path d='M2,5 Q40,1 80,4 T160,3 T198,5' stroke='%23D85F38' stroke-width='3' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
}
.r-uline.dark::after{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8'><path d='M2,5 Q40,1 80,4 T160,3 T198,5' stroke='%231A1410' stroke-width='3' fill='none' stroke-linecap='round'/></svg>")}

/* --- Post-it --- */
.r-postit{
  display:inline-block;
  background:#F2DDA0;
  padding:18px 22px;
  font-family:var(--r-font-hand);
  color:var(--r-ink);
  box-shadow:6px 8px 16px -6px rgba(15,30,51,.25), inset 0 -10px 24px -10px rgba(0,0,0,.05);
  position:relative;
  transform:rotate(2deg);
  text-align:center;
}
.r-postit::before{
  content:"";position:absolute;top:-10px;left:50%;transform:translateX(-50%) rotate(-3deg);
  width:60px;height:18px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(15,30,51,.06);
}
.r-postit .small{font-size:14px;font-weight:600;line-height:1;display:block;margin-bottom:4px;color:var(--r-ink-soft)}
.r-postit .big{font-size:34px;font-weight:700;line-height:1;color:var(--r-orange);display:block}
.r-postit .unit{font-size:14px;color:var(--r-ink-soft);font-weight:600;display:block;margin-top:2px}

/* --- Cards generic --- */
.r-card{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:18px;
  padding:26px;
  box-shadow:5px 5px 0 var(--r-ink);
  transition:all .2s;
}
.r-card:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--r-ink)}
.r-card.flat{box-shadow:none;transform:none}
.r-card.flat:hover{transform:none;box-shadow:none}
.r-card.tilt-l{transform:rotate(-1deg)}
.r-card.tilt-r{transform:rotate(1deg)}
.r-card.tilt-l:hover{transform:rotate(-1deg) translate(-3px,-3px)}
.r-card.tilt-r:hover{transform:rotate(1deg) translate(-3px,-3px)}
.r-card h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:20px;color:var(--r-ink);
  margin-bottom:8px;text-transform:uppercase;letter-spacing:.01em;
}
.r-card p{font-family:var(--r-font-sans);font-size:14.5px;color:var(--r-ink-soft);line-height:1.55}

/* --- Feature row (icône cercle + titre + sub) --- */
.r-feat{
  display:flex;align-items:flex-start;gap:18px;
  padding:14px 0;
}
.r-feat .ic{
  flex:0 0 auto;
  width:54px;height:54px;border-radius:50%;
  border:2.5px solid var(--r-ink);
  background:var(--r-cream-2);
  display:grid;place-items:center;
  color:var(--r-green);
}
.r-feat .ic.orange{color:var(--r-orange);background:#F4E4D5}
.r-feat .ic.green{color:var(--r-green);background:#DCE6D2}
.r-feat .ic.yellow{color:#9b7a00;background:var(--r-yellow)}
.r-feat .ic svg{width:24px;height:24px;stroke-width:2.5}
.r-feat h3,.r-feat h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:15.5px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--r-ink);margin-bottom:4px;
}
.r-feat p{font-family:var(--r-font-sans);font-size:14.5px;color:var(--r-green);font-weight:500;line-height:1.45}

/* --- Trio bottom (sans engagement / support / satisfait) --- */
.r-trio{
  display:grid;gap:18px;
  grid-template-columns:1fr;
  background:var(--r-cream-2);
  border:2.5px solid var(--r-ink);
  border-radius:18px;
  padding:22px;
  box-shadow:5px 5px 0 var(--r-ink);
}
@media(min-width:680px){.r-trio{grid-template-columns:1fr 1fr 1fr;gap:0}}
.r-trio-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:6px 16px;
  border-left:2px dashed var(--r-line-soft);
}
.r-trio-item:first-child{border-left:0}
@media(max-width:679px){
  .r-trio-item{border-left:0;border-top:2px dashed var(--r-line-soft);padding:14px 0}
  .r-trio-item:first-child{border-top:0;padding-top:6px}
}
.r-trio-item .ic{
  flex:0 0 auto;width:34px;height:34px;border-radius:50%;
  background:var(--r-cream-3);color:var(--r-ink);
  display:grid;place-items:center;border:2px solid var(--r-ink);
}
.r-trio-item .ic svg{width:16px;height:16px;stroke-width:2.5}
.r-trio-item h3,.r-trio-item h5{
  font-family:var(--r-font-display);font-weight:800;font-size:13px;
  text-transform:uppercase;letter-spacing:.05em;
  color:var(--r-ink);margin-bottom:2px;
}
.r-trio-item p{font-family:var(--r-font-sans);font-size:13px;color:var(--r-ink-mute);line-height:1.4}

/* --- Bandeau marine final (comme dans la DA) --- */
.r-band{
  background:var(--r-ink);color:#fff;
  padding:28px 26px;border-radius:18px;
  text-align:center;
  font-family:var(--r-font-display);font-weight:700;
  font-size:clamp(15px,1.6vw,18.5px);
  letter-spacing:.01em;line-height:1.5;
  position:relative;
  border:2.5px solid var(--r-ink);
  box-shadow:5px 5px 0 var(--r-orange);
}
.r-band .gold{color:var(--r-yellow);font-weight:800}
.r-band .arrow{display:inline-block;margin:0 6px;color:var(--r-orange)}

/* --- CTA section (final-style band) --- */
.r-ctaband{
  background:var(--r-ink);color:#fff;
  padding:60px 24px;border-radius:24px;
  text-align:center;
  position:relative;overflow:hidden;
  border:3px solid var(--r-ink);
  box-shadow:8px 8px 0 var(--r-orange);
}
.r-ctaband h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(30px,4.4vw,48px);line-height:1.05;
  text-transform:uppercase;letter-spacing:-.02em;color:#fff;
  margin-bottom:14px;
}
.r-ctaband h2 .gold{color:var(--r-yellow)}
.r-ctaband h2 .orange{color:var(--r-orange)}
.r-ctaband p{
  font-family:var(--r-font-sans);font-size:16px;color:rgba(255,255,255,.78);
  max-width:560px;margin:0 auto 26px;line-height:1.55;
}
.r-ctaband .actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* --- Module card (refonte) --- */
.r-module{
  display:flex;flex-direction:column;
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:20px;
  padding:24px;
  box-shadow:5px 5px 0 var(--r-ink);
  transition:all .2s;
  position:relative;color:var(--r-ink);
  height:100%;
}
.r-module:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--r-ink)}
.r-module .badge{
  position:absolute;top:-12px;right:18px;
  background:var(--r-yellow);color:var(--r-ink);
  border:2px solid var(--r-ink);
  padding:4px 12px;border-radius:999px;
  font-family:var(--r-font-sans);font-weight:800;font-size:11.5px;
  letter-spacing:.06em;text-transform:uppercase;
  box-shadow:2px 2px 0 var(--r-ink);
}
.r-module .badge.free{background:var(--r-green);color:#fff}
.r-module .badge.new{background:var(--r-orange);color:#fff}
.r-module-icon{
  width:64px;height:64px;border-radius:14px;
  background:var(--r-cream-3);
  border:2px solid var(--r-ink);
  display:grid;place-items:center;
  margin-bottom:14px;
  overflow:hidden;
}
.r-module-icon img{width:100%;height:100%;object-fit:contain;padding:6px}
.r-module h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:18px;line-height:1.2;
  color:var(--r-ink);margin-bottom:8px;
  text-transform:uppercase;letter-spacing:-.005em;
}
.r-module .tagline{
  font-family:var(--r-font-sans);font-size:14px;color:var(--r-ink-soft);
  line-height:1.5;margin-bottom:16px;flex:1;
}
.r-module .meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:10px;
  font-family:var(--r-font-sans);font-size:12.5px;color:var(--r-ink-mute);
  margin-bottom:14px;font-weight:600;
}
.r-module .meta .stars{display:inline-flex;gap:2px;color:var(--r-orange)}
.r-module .meta .stars svg{width:13px;height:13px}
.r-module .meta .compat{
  background:var(--r-cream-3);color:var(--r-ink);
  padding:3px 9px;border-radius:6px;
  font-size:11.5px;font-weight:700;
}
.r-module-foot{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  margin-top:auto;padding-top:14px;
  border-top:1.5px dashed var(--r-line-soft);
}
.r-module .price{
  font-family:var(--r-font-display);font-weight:800;font-size:22px;
  color:var(--r-ink);
}
.r-module .price.free{color:var(--r-green)}
.r-module .price .ttc{font-size:11px;color:var(--r-ink-mute);font-weight:600;margin-left:3px}
.r-module .cta{
  font-family:var(--r-font-sans);font-weight:800;font-size:13.5px;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--r-orange);display:inline-flex;align-items:center;gap:6px;
}
.r-module:hover .cta{transform:translateX(3px)}

/* --- Promo banner --- */
.r-promo{
  background:var(--r-yellow);
  border:2.5px solid var(--r-ink);
  border-radius:14px;
  padding:14px 22px;
  display:flex;align-items:center;justify-content:center;gap:12px;
  font-family:var(--r-font-sans);font-weight:700;font-size:15px;
  color:var(--r-ink);text-align:center;
  box-shadow:4px 4px 0 var(--r-ink);
  transform:rotate(-.5deg);
  margin-bottom:36px;
  flex-wrap:wrap;
}
.r-promo .fire{font-size:22px}
.r-promo code{
  background:var(--r-ink);color:var(--r-yellow);
  padding:3px 10px;border-radius:6px;
  font-family:'JetBrains Mono',monospace;font-weight:800;
  font-size:13.5px;letter-spacing:.04em;
}

/* --- Grid utilities --- */
.r-grid{display:grid;gap:24px}
.r-grid-2{grid-template-columns:1fr}
.r-grid-3{grid-template-columns:1fr}
.r-grid-4{grid-template-columns:1fr 1fr}
@media(min-width:680px){
  .r-grid-2{grid-template-columns:1fr 1fr}
  .r-grid-3{grid-template-columns:1fr 1fr}
  .r-grid-4{grid-template-columns:1fr 1fr 1fr 1fr}
}
@media(min-width:980px){
  .r-grid-3{grid-template-columns:1fr 1fr 1fr}
}

/* --- Prose (pages texte type CGV) --- */
.r-prose{
  font-family:var(--r-font-sans);font-size:15.5px;line-height:1.7;
  color:var(--r-ink-soft);max-width:780px;margin:0 auto;
}
.r-prose h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(22px,2.5vw,30px);color:var(--r-ink);
  text-transform:uppercase;letter-spacing:-.01em;
  margin:48px 0 14px;padding-bottom:12px;
  border-bottom:2.5px solid var(--r-ink);
  position:relative;
}
.r-prose h2:first-child{margin-top:0}
.r-prose h2::after{
  content:"";position:absolute;left:0;bottom:-2.5px;width:60px;height:2.5px;
  background:var(--r-orange);
}
.r-prose h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:18px;color:var(--r-ink);
  margin:28px 0 8px;
  text-transform:uppercase;letter-spacing:.01em;
}
.r-prose p{margin:0 0 14px}
.r-prose strong{color:var(--r-ink);font-weight:700}
.r-prose ul{margin:0 0 18px;padding-left:0;list-style:none}
.r-prose ul li{
  position:relative;padding:5px 0 5px 26px;
}
.r-prose ul li::before{
  content:"";position:absolute;left:0;top:14px;
  width:14px;height:2.5px;background:var(--r-orange);border-radius:2px;
}
.r-prose a{color:var(--r-orange);font-weight:700;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px}
.r-prose a:hover{color:var(--r-orange-2)}

/* --- TOC sticky côté CGV --- */
.r-toc{
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  border-radius:14px;
  padding:18px;font-family:var(--r-font-sans);
}
.r-toc h3,.r-toc h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:12px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--r-ink);margin-bottom:10px;
}
.r-toc ul{list-style:none;padding:0}
.r-toc li{padding:4px 0;font-size:13.5px}
.r-toc a{color:var(--r-ink-soft);transition:color .2s}
.r-toc a:hover{color:var(--r-orange)}

/* --- Tag PrestaShop / WP --- */
.r-techs{
  display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-bottom:24px;
}
.r-tech{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--r-font-sans);font-weight:800;font-size:13.5px;
  color:var(--r-ink);
}
.r-tech .icon{
  width:28px;height:28px;border-radius:8px;
  background:var(--r-paper);border:2px solid var(--r-ink);
  display:grid;place-items:center;
}
.r-techs .sep{color:var(--r-ink-mute);font-weight:300}

/* --- Blog cards --- */
.r-post{
  display:flex;flex-direction:column;
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:18px;
  overflow:hidden;
  box-shadow:5px 5px 0 var(--r-ink);
  transition:all .2s;
  height:100%;color:var(--r-ink);
}
.r-post:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--r-ink)}
.r-post-cover{
  aspect-ratio:16/9;background:var(--r-cream-3);
  border-bottom:2.5px solid var(--r-ink);
  display:grid;place-items:center;
  font-family:var(--r-font-hand);font-size:46px;color:var(--r-ink);
  position:relative;
}
.r-post-body{padding:22px;display:flex;flex-direction:column;flex:1}
.r-post-meta{
  display:flex;align-items:center;gap:10px;
  font-family:var(--r-font-sans);font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--r-ink-mute);
  margin-bottom:10px;
}
.r-post-tag{
  background:var(--r-yellow);color:var(--r-ink);
  border:1.5px solid var(--r-ink);
  padding:2px 9px;border-radius:6px;font-weight:800;
}
.r-post h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:21px;line-height:1.2;
  color:var(--r-ink);margin-bottom:10px;
  text-transform:uppercase;letter-spacing:-.005em;
}
.r-post .excerpt{
  font-family:var(--r-font-sans);font-size:14.5px;color:var(--r-ink-soft);
  line-height:1.55;flex:1;margin-bottom:14px;
}
.r-post .read{
  font-family:var(--r-font-sans);font-weight:800;font-size:13.5px;
  text-transform:uppercase;letter-spacing:.04em;
  color:var(--r-orange);display:inline-flex;align-items:center;gap:6px;
}

/* --- Article body --- */
.r-article{
  font-family:var(--r-font-sans);font-size:16.5px;line-height:1.75;
  color:var(--r-ink-soft);
}
.r-article > *{max-width:740px;margin-left:auto;margin-right:auto}
.r-article h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(24px,2.8vw,32px);color:var(--r-ink);
  text-transform:uppercase;letter-spacing:-.01em;
  margin:48px auto 16px;
}
.r-article h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:20px;color:var(--r-ink);
  margin:32px auto 10px;
  text-transform:uppercase;letter-spacing:0;
}
.r-article p{margin:0 auto 16px}
.r-article strong{color:var(--r-ink);font-weight:700}
.r-article ul,
.r-article ol{margin:0 auto 18px;padding-left:24px}
.r-article ul li,
.r-article ol li{padding:3px 0}
.r-article ul li::marker{color:var(--r-orange)}
.r-article ol li::marker{color:var(--r-orange);font-weight:800}
.r-article a{color:var(--r-orange);font-weight:700;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px}
.r-article blockquote{
  border-left:4px solid var(--r-orange);
  background:var(--r-cream-2);
  padding:18px 22px;border-radius:0 14px 14px 0;
  font-style:italic;color:var(--r-ink);
  margin:24px auto;
}
.r-article code{
  background:var(--r-ink);color:var(--r-yellow);
  padding:2px 8px;border-radius:5px;
  font-family:'JetBrains Mono',monospace;font-size:.92em;
}

/* --- Star rating --- */
.r-stars{display:inline-flex;gap:2px;color:var(--r-orange)}
.r-stars svg{width:14px;height:14px;fill:currentColor}

/* --- Generic icon helpers --- */
.r-ic-circle{
  width:46px;height:46px;border-radius:50%;
  border:2.5px solid var(--r-ink);
  background:var(--r-cream-2);
  display:grid;place-items:center;
}

/* --- Responsive utilities --- */
.r-text-center{text-align:center}
.r-mt-0{margin-top:0!important}
.r-mb-0{margin-bottom:0!important}
.r-mt-md{margin-top:32px}
.r-mb-md{margin-bottom:32px}

/* --- Hero arrow décorative --- */
.r-arrow{
  display:inline-block;
  width:80px;height:30px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 30'><path d='M5,20 Q25,5 50,15 T75,18 M67,12 L75,18 L66,22' stroke='%231A1410' stroke-width='2.5' fill='none' stroke-linecap='round'/></svg>") no-repeat center/contain;
}

/* --- Reveal animations (compat avec main.css) --- */
.reveal{opacity:1;transform:none}

/* ============================================
   OVERRIDES — sous-pages modules détail
   (réutilise les classes existantes, applique nouvelle DA)
   ============================================ */
.module-detail-hero,
.page-hero,
.post-hero{
  background:var(--r-cream);
  padding:18px 0 0;
  border-bottom:0;
  position:relative;
}
@media(min-width:780px){
  .module-detail-hero,.page-hero,.post-hero{padding:24px 0 0}
}
.module-detail-hero .blob,.page-hero .blob,.post-hero .blob{display:none}
.page-hero-inner,
.post-hero-inner{
  max-width:none!important;
  margin:0!important;
  text-align:left!important;
}
.module-detail-hero .breadcrumb,
.page-hero .breadcrumb,
.post-hero .breadcrumb{
  display:flex;align-items:center;gap:7px;flex-wrap:wrap;
  font-family:var(--r-font-sans);font-size:11.5px;font-weight:500;
  color:var(--r-ink-mute);
  padding-bottom:14px;margin-bottom:24px;
  border-bottom:1px solid var(--r-line-soft);
  letter-spacing:.01em;
}
.module-detail-hero .breadcrumb a,
.page-hero .breadcrumb a,
.post-hero .breadcrumb a{color:var(--r-ink-mute);transition:color .2s}
.module-detail-hero .breadcrumb a:hover,
.page-hero .breadcrumb a:hover,
.post-hero .breadcrumb a:hover{color:var(--r-orange)}
.module-detail-hero .breadcrumb .sep,
.page-hero .breadcrumb .sep,
.post-hero .breadcrumb .sep{opacity:.45;font-weight:300}
.module-detail-hero h1,
.page-hero h1,
.post-hero h1{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(26px,3.6vw,38px)!important;line-height:1.05!important;
  color:var(--r-ink);text-transform:none;letter-spacing:-.02em;
  margin:0 0 8px!important;
}
.module-detail-hero h1 .hl,
.page-hero h1 .hl,
.post-hero h1 .hl{
  background:linear-gradient(transparent 60%,var(--r-yellow) 60%);
  padding:0 4px;color:var(--r-ink);
  -webkit-text-fill-color:var(--r-ink);
}
.module-detail-hero .lead,
.page-hero .lead,
.post-hero .lead{
  font-family:var(--r-font-sans);color:var(--r-ink-soft);
  font-size:14.5px;line-height:1.55;max-width:680px;
  margin:0!important;
}
.module-detail-hero .module-hero-img{
  width:80px;height:80px;border-radius:18px;
  border:2.5px solid var(--r-ink);background:var(--r-cream-2);
  padding:8px;margin-bottom:14px;object-fit:contain;
}
.module-detail-hero .module-meta{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px;
  font-family:var(--r-font-sans);font-size:13.5px;font-weight:600;color:var(--r-ink-mute);
}
.module-detail-hero .module-rating{display:inline-flex;align-items:center;gap:6px}
.module-detail-hero .module-rating .stars{display:inline-flex;gap:2px;color:var(--r-orange)}
.module-detail-hero .module-rating .stars svg{width:14px;height:14px;fill:currentColor}
.module-detail-hero .module-rating .count{color:var(--r-ink-mute)}
.module-detail-hero .module-compat{
  background:var(--r-yellow);color:var(--r-ink);
  border:1.5px solid var(--r-ink);
  padding:3px 10px;border-radius:6px;font-size:11.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.04em;
}
.module-detail-grid{
  display:grid;grid-template-columns:1fr;gap:36px;
  margin-top:24px;
}
@media(min-width:980px){.module-detail-grid{grid-template-columns:1fr 360px;gap:48px}}

/* Module detail body — h2 stylés en uppercase avec underline orange */
.module-detail-hero h2,
.module-detail-hero + section h2{
  font-family:var(--r-font-display);font-weight:800;
  color:var(--r-ink);text-transform:uppercase;letter-spacing:-.01em;
  border-bottom:2.5px solid var(--r-ink);padding-bottom:10px;
  position:relative;
}
.module-detail-hero h2::after{
  content:"";position:absolute;left:0;bottom:-2.5px;width:60px;height:2.5px;
  background:var(--r-orange);
}
.module-detail-hero .prose{font-family:var(--r-font-sans);color:var(--r-ink-soft);font-size:15.5px;line-height:1.7}
.module-detail-hero .prose strong{color:var(--r-ink)}
.module-detail-hero .prose ul{padding-left:0;list-style:none;margin:14px 0}
.module-detail-hero .prose ul li{position:relative;padding:5px 0 5px 24px}
.module-detail-hero .prose ul li::before{
  content:"";position:absolute;left:0;top:14px;width:14px;height:2.5px;
  background:var(--r-orange);border-radius:2px;
}

/* Buy card */
.module-buy-card{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:20px;
  padding:28px;
  box-shadow:6px 6px 0 var(--r-ink);
  position:sticky;top:104px;
}
.module-buy-card .module-hero-img{
  width:64px;height:64px;border-radius:14px;
  border:2px solid var(--r-ink);background:var(--r-cream-3);
  padding:6px;margin-bottom:14px;
}
.module-buy-card .price{
  font-family:var(--r-font-display);font-weight:800;
  font-size:38px;color:var(--r-ink);line-height:1;
  margin-bottom:6px;
}
.module-buy-card .price.free{color:var(--r-green)}
.module-buy-card .price .ttc{font-size:13px;color:var(--r-ink-mute);font-weight:600;margin-left:4px;letter-spacing:0}
.module-buy-card .promo-line{
  font-family:var(--r-font-sans);font-size:13px;color:var(--r-ink-mute);
  margin-bottom:16px;font-weight:600;
}
.module-buy-card .features{
  list-style:none;padding:0;margin:0 0 18px;
  border-top:1.5px dashed var(--r-line-soft);
  border-bottom:1.5px dashed var(--r-line-soft);
  padding:14px 0;
}
.module-buy-card .features li{
  display:flex;align-items:flex-start;gap:10px;
  padding:6px 0;
  font-family:var(--r-font-sans);font-size:13.5px;color:var(--r-ink-soft);
}
.module-buy-card .features li svg{
  width:16px;height:16px;flex-shrink:0;
  color:var(--r-green);margin-top:2px;
}
.module-buy-card .features li strong{color:var(--r-ink);font-weight:800}

/* Spec table */
.spec-table{
  width:100%;border-collapse:collapse;
  font-family:var(--r-font-sans);font-size:14.5px;
  margin-top:14px;
  border:2px solid var(--r-ink);
  border-radius:12px;overflow:hidden;
  background:var(--r-paper);
}
.spec-table th,
.spec-table td{
  padding:12px 16px;text-align:left;
  border-bottom:1.5px dashed var(--r-line-soft);
}
.spec-table tr:last-child th,
.spec-table tr:last-child td{border-bottom:0}
.spec-table th{
  font-family:var(--r-font-display);font-weight:800;
  color:var(--r-ink);width:40%;
  background:var(--r-cream-3);
  text-transform:uppercase;font-size:12.5px;letter-spacing:.04em;
}
.spec-table td{color:var(--r-ink-soft)}

/* Module features grid */
.module-feature-grid{
  display:grid;grid-template-columns:1fr;gap:16px;
  margin-top:18px;
}
@media(min-width:680px){.module-feature-grid{grid-template-columns:1fr 1fr;gap:18px}}
.module-feature{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:16px;padding:20px;
  box-shadow:4px 4px 0 var(--r-ink);
  transition:all .2s;
}
.module-feature:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--r-ink)}
.module-feature .em{
  width:42px;height:42px;border-radius:10px;
  background:var(--r-yellow);
  border:2px solid var(--r-ink);
  display:grid;place-items:center;
  font-size:20px;margin-bottom:12px;
}
.module-feature h3,.module-feature h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:15.5px;color:var(--r-ink);
  text-transform:uppercase;letter-spacing:-.005em;
  margin-bottom:6px;line-height:1.2;
}
.module-feature p{
  font-family:var(--r-font-sans);font-size:14px;color:var(--r-ink-soft);
  line-height:1.55;
}

/* Carousel */
.module-carousel{
  margin-top:14px;border:2.5px solid var(--r-ink);
  border-radius:14px;overflow:hidden;
  background:var(--r-paper);
  box-shadow:5px 5px 0 var(--r-ink);
}
.carousel-slide figcaption{
  background:var(--r-cream-3);color:var(--r-ink);
  font-family:var(--r-font-sans);font-size:13px;font-weight:600;
  padding:10px 14px;border-top:2px solid var(--r-ink);
}
.carousel-nav{
  background:var(--r-cream-2);color:var(--r-ink);
  border:2px solid var(--r-ink);
  box-shadow:2px 2px 0 var(--r-ink);
  width:38px;height:38px;border-radius:50%;
}
.carousel-nav:hover{background:var(--r-orange);color:#fff}
.carousel-counter{
  background:var(--r-ink);color:#fff;
  font-family:var(--r-font-sans);font-weight:700;font-size:12px;
  padding:4px 10px;border-radius:999px;
}

.video-wrap{
  border:2.5px solid var(--r-ink);
  border-radius:14px;overflow:hidden;
  box-shadow:5px 5px 0 var(--r-ink);
  margin:18px 0;
}

/* page-hero / post-hero — éléments spécifiques (eyebrow, post-meta) */
.page-hero .hero-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--r-yellow);color:var(--r-ink);
  border:1.5px solid var(--r-ink);
  font-family:var(--r-font-sans);font-weight:700;font-size:11px;
  padding:3px 10px;border-radius:6px;
  letter-spacing:.05em;text-transform:uppercase;
  margin-bottom:10px;
}
.page-hero .hero-eyebrow .em{font-size:12px}
.page-hero .hero-eyebrow .live{display:none}

.post-hero .post-meta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--r-font-sans);font-size:11.5px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;color:var(--r-ink-mute);
  margin-bottom:10px;
}
.post-hero .post-meta .tag{
  background:var(--r-yellow);color:var(--r-ink);
  border:1.5px solid var(--r-ink);
  padding:2px 8px;border-radius:5px;font-weight:800;font-size:10.5px;
}
.post-hero .post-meta .dot{
  width:3px;height:3px;border-radius:50%;background:var(--r-ink-mute);
}

.post-cover{
  max-width:1080px;margin:30px auto;
  border:2.5px solid var(--r-ink);border-radius:18px;overflow:hidden;
  box-shadow:6px 6px 0 var(--r-ink);
}
.post-cover img{display:block;width:100%;height:auto}

.post-content{
  max-width:760px;margin:0 auto;padding:0 18px 60px;
  font-family:var(--r-font-sans);font-size:16.5px;line-height:1.75;color:var(--r-ink-soft);
}
.post-content h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(24px,2.8vw,32px);color:var(--r-ink);
  text-transform:uppercase;letter-spacing:-.01em;
  margin:44px 0 14px;padding-bottom:10px;
  border-bottom:2.5px solid var(--r-ink);position:relative;
}
.post-content h2::after{
  content:"";position:absolute;left:0;bottom:-2.5px;width:50px;height:2.5px;
  background:var(--r-orange);
}
.post-content h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:20px;color:var(--r-ink);
  margin:30px 0 10px;text-transform:uppercase;letter-spacing:-.005em;
}
.post-content p{margin:0 0 16px}
.post-content strong{color:var(--r-ink);font-weight:700}
.post-content ul,
.post-content ol{margin:0 0 18px;padding-left:24px}
.post-content ul li::marker{color:var(--r-orange)}
.post-content ol li::marker{color:var(--r-orange);font-weight:800}
.post-content li{padding:3px 0}
.post-content a{color:var(--r-orange);font-weight:700;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:2px}
.post-content blockquote{
  border-left:4px solid var(--r-orange);
  background:var(--r-cream-2);
  padding:18px 22px;border-radius:0 14px 14px 0;
  font-style:italic;color:var(--r-ink);
  margin:24px 0;
}
.post-content code{
  background:var(--r-ink);color:var(--r-yellow);
  padding:2px 8px;border-radius:5px;
  font-family:'JetBrains Mono',monospace;font-size:.92em;
}
.post-content img{
  border:2.5px solid var(--r-ink);border-radius:14px;
  box-shadow:5px 5px 0 var(--r-ink);
  margin:24px auto;
}

/* Blog cards (.blog-grid / .blog-card) override pour cohérence */
.blog-grid{
  display:grid;grid-template-columns:1fr;gap:24px;
}
@media(min-width:680px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.blog-grid{grid-template-columns:1fr 1fr 1fr}}
.blog-card{
  display:flex;flex-direction:column;
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:18px;overflow:hidden;
  box-shadow:5px 5px 0 var(--r-ink);
  transition:all .2s;color:var(--r-ink);
  height:100%;
}
.blog-card:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--r-ink)}
.blog-card .blog-cover{
  aspect-ratio:16/9;border-bottom:2.5px solid var(--r-ink);
  overflow:hidden;background:var(--r-cream-3);
}
.blog-card .blog-cover img{width:100%;height:100%;object-fit:cover;display:block}
.blog-card .blog-card-body{padding:22px;display:flex;flex-direction:column;flex:1}
.blog-card .blog-meta{
  display:flex;align-items:center;gap:10px;
  font-family:var(--r-font-sans);font-size:12px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;color:var(--r-ink-mute);
  margin-bottom:10px;
}
.blog-card .blog-meta .tag{
  background:var(--r-yellow);color:var(--r-ink);
  border:1.5px solid var(--r-ink);
  padding:2px 9px;border-radius:6px;font-weight:800;font-size:11px;
}
.blog-card .blog-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--r-ink-mute)}
.blog-card h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:21px;line-height:1.2;
  color:var(--r-ink);margin-bottom:10px;
  text-transform:uppercase;letter-spacing:-.005em;
}
.blog-card p{font-family:var(--r-font-sans);font-size:14.5px;color:var(--r-ink-soft);line-height:1.55;flex:1;margin-bottom:14px}
.blog-card .read-more{
  font-family:var(--r-font-sans);font-weight:800;font-size:13.5px;
  text-transform:uppercase;letter-spacing:.04em;color:var(--r-orange);
}

/* Final block override (utilisé par plusieurs pages) */
.final{padding:30px 0 60px}
.final-inner{
  background:var(--r-ink);color:#fff;
  padding:50px 26px;border-radius:24px;
  text-align:center;border:3px solid var(--r-ink);
  box-shadow:8px 8px 0 var(--r-orange);
  max-width:1100px;margin:0 auto;
}
.final-inner h2{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(28px,4.4vw,46px);line-height:1.05;
  text-transform:uppercase;letter-spacing:-.02em;
  color:#fff;margin-bottom:14px;
}
.final-inner h2 .grad{
  color:var(--r-yellow);
  background:none;-webkit-text-fill-color:var(--r-yellow);
  text-fill-color:var(--r-yellow);
}
.final-inner p{
  font-family:var(--r-font-sans);font-size:16px;color:rgba(255,255,255,.78);
  max-width:560px;margin:0 auto 24px;line-height:1.55;
}
.final-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
/* Boutons à l'intérieur du final-inner sombre — variante adaptée */
.final-inner .r-btn-orange{background:var(--r-yellow);color:var(--r-ink);border-color:#fff;box-shadow:4px 4px 0 #fff}
.final-inner .r-btn-orange:hover{background:var(--r-yellow-2);color:var(--r-ink);box-shadow:6px 6px 0 #fff}
.final-inner .r-btn-ghost{background:transparent;color:#fff;border-color:#fff;box-shadow:none}
.final-inner .r-btn-ghost:hover{background:#fff;color:var(--r-ink);box-shadow:none}

/* ============================================
   HOME — composants spécifiques
   ============================================ */
.r-home-hero{
  background:var(--r-cream);
  padding:36px 0 56px;
  border-bottom:2px solid var(--r-ink);
  position:relative;overflow:hidden;
}
@media(min-width:780px){.r-home-hero{padding:50px 0 80px}}
.r-home-hero-grid{
  display:grid;grid-template-columns:1fr;gap:40px;align-items:center;
}
@media(min-width:980px){.r-home-hero-grid{grid-template-columns:1.1fr .9fr;gap:60px}}
.r-stack{
  display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-bottom:24px;
}
.r-stack-item{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--r-font-sans);font-weight:800;font-size:14px;
  color:var(--r-ink);
}
.r-stack-item .badge{
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  width:32px;height:32px;border-radius:8px;
  display:grid;place-items:center;
  box-shadow:2px 2px 0 var(--r-ink);
}
.r-stack-item .badge img,
.r-stack-item .badge svg{width:18px;height:18px}
.r-stack-sep{color:var(--r-ink-mute);font-weight:300;font-size:18px}

.r-home-hero h1{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(34px,5.6vw,62px);line-height:1;
  letter-spacing:-.025em;text-transform:none;
  color:var(--r-ink);margin-bottom:18px;
}
.r-home-hero h1 .ln-script{
  font-family:var(--r-font-hand);font-weight:700;
  text-transform:none;color:var(--r-orange);
  font-size:1.05em;letter-spacing:0;display:inline-block;
  position:relative;line-height:1;
  margin-right:.15em;
}
.r-home-hero h1 .ln-script::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:-3px;height:6px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8'><path d='M2,5 Q40,1 80,4 T160,3 T198,5' stroke='%23D85F38' stroke-width='3' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
}
.r-home-hero .r-lead{
  font-family:var(--r-font-sans);font-size:18px;line-height:1.55;
  color:var(--r-ink-soft);max-width:540px;margin-bottom:28px;
}
.r-home-hero .r-lead strong{color:var(--r-ink);font-weight:700}

.r-home-feats{
  display:flex;flex-direction:column;gap:8px;
  margin-bottom:32px;max-width:540px;
}
.r-home-feats .r-feat{padding:12px 0;align-items:center}
.r-home-feats .r-feat:not(:last-child){border-bottom:1.5px dashed var(--r-line-soft)}

.r-home-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:18px}

.r-tagline-hand{
  font-family:var(--r-font-hand);font-weight:700;
  font-size:clamp(22px,2.6vw,32px);line-height:1.1;
  color:var(--r-ink);
  display:inline-block;position:relative;
  margin-top:8px;
}
.r-tagline-hand::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:8px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8'><path d='M2,5 Q40,1 80,4 T160,3 T198,5' stroke='%231A1410' stroke-width='2.5' fill='none' stroke-linecap='round'/></svg>") no-repeat center/100% 100%;
}
.r-tagline-hand .plus{color:var(--r-orange);font-size:1.2em;margin:0 4px}

/* Visuel hero (laptop + post-it + café) */
.r-home-visual{
  position:relative;
  min-height:380px;
  display:flex;align-items:center;justify-content:center;
}
.r-home-visual .laptop{
  width:100%;max-width:520px;aspect-ratio:5/4;
  background:var(--r-cream-2);
  border:3px solid var(--r-ink);
  border-radius:18px;
  box-shadow:8px 8px 0 var(--r-ink);
  position:relative;overflow:hidden;
  display:grid;place-items:center;
}
.r-home-visual .laptop::before{
  content:"";position:absolute;top:0;left:0;right:0;height:30px;
  background:var(--r-ink);
  display:grid;
}
.r-home-visual .laptop::after{
  content:"";position:absolute;top:10px;left:14px;
  width:10px;height:10px;border-radius:50%;
  background:#ff5f57;
  box-shadow:16px 0 0 #febc2e, 32px 0 0 #28c940;
}
.r-home-visual .laptop .scr{
  position:absolute;top:30px;left:0;right:0;bottom:0;
  padding:22px 24px;
  font-family:var(--r-font-sans);
  background:var(--r-paper);
  display:flex;flex-direction:column;gap:14px;
  overflow:hidden;
}

/* Dashboard monitoring inside laptop */
.dash-head{
  display:flex;align-items:center;gap:10px;
  padding-bottom:12px;
  border-bottom:1.5px dashed var(--r-line-soft);
}
.dash-head .dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--r-green);
  box-shadow:0 0 0 4px rgba(107,142,96,.18);
  animation:dashPulse 2s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes dashPulse{
  0%,100%{box-shadow:0 0 0 4px rgba(107,142,96,.18)}
  50%{box-shadow:0 0 0 8px rgba(107,142,96,.05)}
}
.dash-head .site{
  font-family:var(--r-font-display);font-weight:800;
  font-size:15px;color:var(--r-ink);flex:1;
  text-overflow:ellipsis;overflow:hidden;white-space:nowrap;
}
.dash-head .badge{
  font-family:var(--r-font-sans);font-weight:800;
  font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  background:#DCE6D2;color:var(--r-green-2);
  padding:4px 9px;border-radius:6px;
  border:1.5px solid var(--r-green);
}

.dash-uptime{
  display:flex;align-items:flex-end;justify-content:space-between;gap:10px;
  padding:4px 0;
}
.dash-uptime .num{
  font-family:var(--r-font-display);font-weight:800;
  font-size:42px;color:var(--r-ink);line-height:.95;letter-spacing:-.02em;
}
.dash-uptime .num .pct{font-size:24px;color:var(--r-green-2);margin-left:2px}
.dash-uptime .lbl{
  font-family:var(--r-font-sans);font-size:11.5px;font-weight:600;
  color:var(--r-ink-mute);text-transform:uppercase;letter-spacing:.06em;
  text-align:right;line-height:1.3;max-width:130px;
}

.dash-bars{
  display:flex;gap:3px;align-items:flex-end;height:30px;
}
.dash-bars .b{
  flex:1;background:var(--r-green);border-radius:2px;
  min-width:4px;
}
.dash-bars .b.warn{background:var(--r-yellow-2)}
.dash-bars .b.down{background:var(--r-red)}

.dash-feed{
  margin-top:auto;
  display:flex;flex-direction:column;gap:6px;
}
.dash-feed .row{
  display:flex;align-items:center;gap:10px;
  padding:7px 10px;border-radius:8px;
  background:var(--r-cream-2);
  font-family:var(--r-font-sans);font-size:12px;color:var(--r-ink-soft);
}
.dash-feed .row .ic{
  width:20px;height:20px;border-radius:50%;
  background:var(--r-green);color:#fff;
  display:grid;place-items:center;font-weight:800;font-size:11px;
  flex-shrink:0;
}
.dash-feed .row strong{color:var(--r-ink);font-weight:700}
.dash-feed .row .when{margin-left:auto;color:var(--r-ink-mute);font-size:11px;flex-shrink:0}

/* Smartphone mockup qui dépasse */
.r-phone{
  position:absolute;left:-18px;bottom:-22px;
  width:172px;
  background:var(--r-ink);
  border-radius:22px;
  padding:8px 7px 18px;
  box-shadow:6px 6px 0 var(--r-ink), 12px 14px 28px -10px rgba(26,20,16,.35);
  transform:rotate(-7deg);
  z-index:3;
}
.r-phone::before{
  content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);
  width:60px;height:5px;border-radius:5px;background:#3D3530;
}
.r-phone .screen{
  background:var(--r-paper);border-radius:14px;
  padding:24px 12px 12px;
  font-family:var(--r-font-sans);
}
.r-phone .sms-from{
  font-size:10.5px;font-weight:800;color:var(--r-ink);
  letter-spacing:.05em;text-transform:uppercase;
  display:flex;align-items:center;gap:6px;margin-bottom:6px;
}
.r-phone .sms-from .av{
  width:18px;height:18px;border-radius:50%;
  background:var(--r-orange);color:#fff;
  display:grid;place-items:center;
  font-size:10px;font-weight:800;font-family:var(--r-font-display);
}
.r-phone .sms-from .time{margin-left:auto;color:var(--r-ink-mute);font-size:9px;font-weight:600}
.r-phone .sms-bubble{
  background:var(--r-cream-3);
  padding:9px 11px;border-radius:12px 12px 12px 4px;
  font-size:12px;line-height:1.4;color:var(--r-ink);
}
.r-phone .sms-bubble strong{color:var(--r-orange);font-weight:800}

@media(max-width:980px){
  .r-phone{display:none}
}

.r-postit-fix{
  position:absolute;top:-10px;right:-10px;
  background:#F2DDA0;
  padding:18px 22px;
  font-family:var(--r-font-hand);
  color:var(--r-ink);
  box-shadow:6px 8px 18px -6px rgba(15,30,51,.25), inset 0 -10px 24px -10px rgba(0,0,0,.05);
  transform:rotate(8deg);
  text-align:center;z-index:2;
  min-width:130px;
}
.r-postit-fix::before{
  content:"";position:absolute;top:-8px;left:50%;transform:translateX(-50%) rotate(-3deg);
  width:54px;height:14px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(15,30,51,.06);
}
.r-postit-fix .small{font-size:14px;font-weight:600;line-height:1.1;display:block;margin-bottom:4px;color:var(--r-ink-soft)}
.r-postit-fix .big{font-size:32px;font-weight:700;line-height:1;color:var(--r-orange);display:block}
.r-postit-fix .unit{font-size:13px;color:var(--r-ink-soft);font-weight:600;display:block;margin-top:2px}

/* Bandeau techs ("PrestaShop & WordPress on s'occupe de tout") */
.r-techband{
  background:var(--r-ink);color:#fff;
  padding:22px 24px;border-radius:18px;
  font-family:var(--r-font-display);font-weight:700;
  font-size:clamp(15px,1.7vw,18.5px);line-height:1.5;
  text-align:center;
  border:3px solid var(--r-ink);
  box-shadow:5px 5px 0 var(--r-orange);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;
}
.r-techband .stack{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.18);
  padding:6px 14px;border-radius:999px;font-size:13.5px;font-weight:700;
}
.r-techband .stack .ic{
  width:22px;height:22px;border-radius:50%;
  background:#fff;display:grid;place-items:center;
  color:var(--r-ink);
}
.r-techband .text{flex:1;min-width:200px}
.r-techband .gold{color:var(--r-yellow);font-weight:800}

/* Alerte mockup */
.r-alertbox{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:18px;padding:22px;
  box-shadow:6px 6px 0 var(--r-ink);
  font-family:var(--r-font-sans);
  position:relative;
}
.r-alertbox.error{border-color:var(--r-red);box-shadow:6px 6px 0 var(--r-red)}
.r-alertbox-head{
  display:flex;align-items:center;gap:12px;
  margin-bottom:14px;padding-bottom:12px;
  border-bottom:1.5px dashed var(--r-line-soft);
}
.r-alertbox-head .ic{
  width:38px;height:38px;border-radius:10px;
  background:var(--r-red);color:#fff;
  display:grid;place-items:center;
  border:2px solid var(--r-ink);
  flex-shrink:0;
}
.r-alertbox-head .ic.ok{background:var(--r-green)}
.r-alertbox-head h3,.r-alertbox-head h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:15px;color:var(--r-ink);
  text-transform:uppercase;letter-spacing:.02em;margin-bottom:2px;
}
.r-alertbox-head .time{font-size:12px;color:var(--r-ink-mute);font-weight:600}
.r-alertbox p{font-size:14px;color:var(--r-ink-soft);line-height:1.5}
.r-alertbox p strong{color:var(--r-ink)}
.r-alertbox .url{
  display:inline-block;margin-top:8px;
  font-family:'JetBrains Mono',monospace;font-size:12.5px;
  background:var(--r-cream-3);color:var(--r-ink);
  padding:4px 10px;border-radius:6px;
}

/* Site Protégé — grille 4 cartes capacités */
.r-protect-grid{
  display:grid;gap:18px;grid-template-columns:1fr;
  max-width:1080px;margin:0 auto;
}
@media(min-width:680px){.r-protect-grid{grid-template-columns:1fr 1fr}}
.r-protect-card{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:18px;padding:22px;
  box-shadow:5px 5px 0 var(--r-ink);
  font-family:var(--r-font-sans);
  display:flex;flex-direction:column;gap:14px;
  transition:transform .2s,box-shadow .2s;
}
.r-protect-card:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--r-ink)}
.r-protect-card .head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:12px;border-bottom:1.5px dashed var(--r-line-soft);
}
.r-protect-card .head .ic{
  width:44px;height:44px;border-radius:12px;
  background:var(--r-cream-3);color:var(--r-ink);
  border:2px solid var(--r-ink);
  display:grid;place-items:center;flex-shrink:0;
}
.r-protect-card .head .ic svg{width:22px;height:22px;stroke-width:2.4}
.r-protect-card.watch .head .ic{background:#DCE6D2;color:var(--r-green-2)}
.r-protect-card.security .head .ic{background:#F3DCC4;color:var(--r-orange-2)}
.r-protect-card.plugins .head .ic{background:#F2DDA0;color:#9B7A00}
.r-protect-card.backup .head .ic{background:var(--r-cream-3);color:var(--r-ink)}
.r-protect-card .head h3,.r-protect-card .head h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:16px;color:var(--r-ink);
  text-transform:uppercase;letter-spacing:.01em;line-height:1.1;margin-bottom:3px;
}
.r-protect-card .head .sub{font-size:12px;color:var(--r-ink-mute);font-weight:600}
.r-protect-card ul{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:8px;flex:1;
}
.r-protect-card ul li{
  font-size:14px;color:var(--r-ink-soft);line-height:1.45;
  padding-left:22px;position:relative;
}
.r-protect-card ul li::before{
  content:"";position:absolute;left:0;top:8px;
  width:14px;height:2.5px;background:var(--r-orange);border-radius:2px;
}
.r-protect-card ul li strong{color:var(--r-ink);font-weight:700}
.r-protect-card .metric{
  padding-top:12px;
  border-top:1.5px dashed var(--r-line-soft);
  font-family:var(--r-font-sans);font-size:13px;color:var(--r-ink-mute);
  display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;
}
.r-protect-card .metric strong{
  font-family:var(--r-font-display);font-weight:800;
  font-size:24px;color:var(--r-ink);line-height:1;
}
.r-protect-card.watch .metric strong{color:var(--r-green-2)}
.r-protect-card.security .metric strong{color:var(--r-orange-2)}
.r-protect-card.plugins .metric strong{color:#9B7A00}

/* Pricing — 3 plans */
.r-plans{
  display:grid;gap:22px;
  grid-template-columns:1fr;
  max-width:1080px;margin:0 auto;
  align-items:stretch;
}
@media(min-width:780px){.r-plans{grid-template-columns:1fr 1fr 1fr}}

.r-plan{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:20px;
  padding:28px 26px;
  box-shadow:5px 5px 0 var(--r-ink);
  display:flex;flex-direction:column;
  position:relative;transition:transform .2s;
}
.r-plan:hover{transform:translate(-2px,-2px);box-shadow:7px 7px 0 var(--r-ink)}

.r-plan-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--r-font-sans);font-weight:800;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;
  padding:4px 10px;border-radius:6px;
  background:var(--r-cream-3);color:var(--r-ink);
  border:1.5px solid var(--r-line-soft);
  align-self:flex-start;margin-bottom:14px;
}
.r-plan.essential .r-plan-tag{background:#DCE6D2;color:var(--r-green-2);border-color:var(--r-green)}
.r-plan.business .r-plan-tag{background:var(--r-orange);color:#fff;border-color:var(--r-ink)}
.r-plan.performance .r-plan-tag{background:var(--r-ink);color:var(--r-yellow);border-color:var(--r-ink)}

.r-plan h3{
  font-family:var(--r-font-display);font-weight:800;
  font-size:24px;color:var(--r-ink);
  text-transform:uppercase;letter-spacing:-.01em;margin-bottom:6px;line-height:1;
}
.r-plan .lead-line{
  font-family:var(--r-font-hand);font-weight:700;font-size:18px;
  color:var(--r-orange);line-height:1.1;margin-bottom:18px;
}

.r-plan .price{
  font-family:var(--r-font-display);font-weight:800;
  font-size:48px;color:var(--r-ink);line-height:1;
  margin:0;display:flex;align-items:baseline;gap:4px;
}
.r-plan .price .cur{font-size:24px;color:var(--r-ink);font-weight:800}
.r-plan .price .per{
  font-family:var(--r-font-sans);font-size:14px;color:var(--r-ink-mute);
  font-weight:600;margin-left:2px;
}
.r-plan .price-note{
  font-family:var(--r-font-sans);font-size:12px;color:var(--r-ink-mute);
  font-weight:600;margin-top:4px;margin-bottom:18px;
}

.r-plan ul{
  list-style:none;padding:0;margin:0 0 24px;
  border-top:1.5px dashed var(--r-line-soft);
  padding-top:16px;flex:1;
}
.r-plan ul li{
  padding:6px 0;display:flex;align-items:flex-start;gap:10px;
  font-family:var(--r-font-sans);font-size:14px;color:var(--r-ink-soft);
  line-height:1.4;
}
.r-plan ul li svg{
  width:16px;height:16px;flex-shrink:0;
  color:var(--r-green);margin-top:3px;
}
.r-plan ul li strong{color:var(--r-ink);font-weight:700}
.r-plan ul li.bonus svg{color:var(--r-green-2)}

.r-plan-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:var(--r-font-sans);font-weight:700;font-size:14px;
  text-align:center;
  padding:13px 18px;border-radius:12px;
  border:2px solid var(--r-ink);
  background:var(--r-cream-2);color:var(--r-ink);
  text-transform:uppercase;letter-spacing:.04em;
  transition:background .15s,color .15s,transform .15s;
  cursor:pointer;
}
.r-plan-cta:hover{background:var(--r-ink);color:var(--r-cream);transform:translateY(-1px)}

/* Variante featured (Business) — visuellement dominante */
.r-plan.business{
  background:var(--r-ink);
  color:rgba(255,255,255,.85);
  border-color:var(--r-ink);
  box-shadow:5px 5px 0 var(--r-orange);
  transform:scale(1.02);
}
.r-plan.business:hover{
  transform:scale(1.02) translate(-2px,-2px);
  box-shadow:7px 7px 0 var(--r-orange);
}
@media(min-width:780px){.r-plan.business{transform:scale(1.04);z-index:2}}
.r-plan.business h3{color:#fff}
.r-plan.business .lead-line{color:var(--r-yellow)}
.r-plan.business .price{color:#fff}
.r-plan.business .price .cur{color:#fff}
.r-plan.business .price .per{color:rgba(255,255,255,.6)}
.r-plan.business .price-note{color:rgba(255,255,255,.55)}
.r-plan.business ul{border-top-color:rgba(255,255,255,.18)}
.r-plan.business ul li{color:rgba(255,255,255,.78)}
.r-plan.business ul li strong{color:#fff}
.r-plan.business ul li svg{color:var(--r-yellow)}
.r-plan.business ul li.bonus svg{color:var(--r-yellow)}
.r-plan.business .r-plan-cta{
  background:var(--r-orange);color:#fff;border-color:var(--r-orange);
  box-shadow:0 6px 18px -6px rgba(216,95,56,.6);
}
.r-plan.business .r-plan-cta:hover{
  background:var(--r-yellow);color:var(--r-ink);border-color:var(--r-yellow);
}
.r-plan.business .r-plan-ribbon{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--r-yellow);color:var(--r-ink);
  border:2px solid var(--r-ink);
  font-family:var(--r-font-sans);font-weight:800;font-size:11px;
  letter-spacing:.08em;text-transform:uppercase;
  padding:5px 14px;border-radius:8px;
  box-shadow:2px 2px 0 var(--r-ink);
  white-space:nowrap;
}

/* Upsell band */
.r-upsell{
  margin-top:36px;
  background:var(--r-cream-2);
  border:2px dashed var(--r-line);
  border-radius:18px;padding:24px;
  display:grid;gap:16px;align-items:center;
  grid-template-columns:1fr;
}
@media(min-width:780px){.r-upsell{grid-template-columns:auto 1fr}}
.r-upsell-head h3,.r-upsell-head h4{
  font-family:var(--r-font-display);font-weight:800;
  font-size:17px;color:var(--r-ink);
  text-transform:uppercase;letter-spacing:.01em;
  margin-bottom:4px;
  display:flex;align-items:center;gap:8px;
}
.r-upsell-head h3 .em,.r-upsell-head h4 .em{font-size:18px}
.r-upsell-head p{
  font-family:var(--r-font-sans);font-size:13.5px;
  color:var(--r-ink-soft);max-width:280px;line-height:1.45;
}
.r-upsell-pills{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-start;
}
@media(min-width:780px){.r-upsell-pills{justify-content:flex-end}}
.r-upsell-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  border-radius:12px;
  padding:10px 16px;
  box-shadow:2px 2px 0 var(--r-ink);
  font-family:var(--r-font-sans);font-weight:600;font-size:13.5px;
  color:var(--r-ink-soft);
}
.r-upsell-pill .qty{
  font-family:var(--r-font-display);font-weight:800;font-size:15px;
  color:var(--r-ink);
}
.r-upsell-pill .arr{color:var(--r-orange);font-weight:800}
.r-upsell-pill .price{
  font-family:var(--r-font-display);font-weight:800;font-size:15px;
  color:var(--r-orange);
}

/* Testimonial card */
.r-testi{
  background:var(--r-paper);
  border:2.5px solid var(--r-ink);
  border-radius:18px;padding:24px;
  box-shadow:5px 5px 0 var(--r-ink);
  height:100%;display:flex;flex-direction:column;
}
.r-testi .stars{color:var(--r-orange);margin-bottom:10px;display:inline-flex;gap:2px}
.r-testi .stars svg{width:16px;height:16px;fill:currentColor}
.r-testi blockquote{
  font-family:var(--r-font-sans);font-size:15px;color:var(--r-ink);
  line-height:1.55;font-style:normal;margin-bottom:18px;flex:1;
}
.r-testi blockquote::before{content:"« ";color:var(--r-orange);font-weight:800}
.r-testi blockquote::after{content:" »";color:var(--r-orange);font-weight:800}
.r-testi-author{display:flex;align-items:center;gap:10px}
.r-testi-author .av{
  width:38px;height:38px;border-radius:50%;
  background:var(--r-yellow);
  border:2px solid var(--r-ink);
  display:grid;place-items:center;
  font-family:var(--r-font-display);font-weight:800;font-size:14px;color:var(--r-ink);
}
.r-testi-author .meta .name{font-family:var(--r-font-display);font-weight:800;font-size:14px;color:var(--r-ink)}
.r-testi-author .meta .role{font-family:var(--r-font-sans);font-size:12px;color:var(--r-ink-mute)}

/* FAQ */
.r-faq-item{
  background:var(--r-paper);
  border:2px solid var(--r-ink);
  border-radius:14px;
  margin-bottom:12px;
  overflow:hidden;
}
.r-faq-q{
  width:100%;padding:16px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  font-family:var(--r-font-display);font-weight:800;
  font-size:15px;color:var(--r-ink);
  text-align:left;text-transform:uppercase;letter-spacing:.01em;
  cursor:pointer;
}
.r-faq-q:hover{background:var(--r-cream-2)}
.r-faq-q .arrow{
  width:24px;height:24px;border-radius:50%;
  background:var(--r-orange);color:#fff;
  display:grid;place-items:center;flex-shrink:0;
  transition:transform .25s;
  font-size:14px;font-weight:800;
}
.r-faq-item.open .r-faq-q .arrow{transform:rotate(45deg)}
.r-faq-a{
  max-height:0;overflow:hidden;transition:max-height .35s ease;
}
.r-faq-item.open .r-faq-a{max-height:400px}
.r-faq-a-inner{
  padding:0 20px 18px;
  font-family:var(--r-font-sans);font-size:14.5px;color:var(--r-ink-soft);line-height:1.65;
}

/* Stat number */
.r-stat{text-align:center}
.r-stat .num{
  font-family:var(--r-font-display);font-weight:800;
  font-size:56px;line-height:1;color:var(--r-orange);
  letter-spacing:-.02em;
}
.r-stat .num .plus{color:var(--r-ink)}
.r-stat .label{
  font-family:var(--r-font-sans);font-size:13.5px;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--r-ink-mute);font-weight:700;margin-top:6px;
}

/* ============================================
   RESPONSIVE — ajustements mobile globaux
   ============================================ */
@media(max-width:780px){
  /* Topbar — plus tassé */
  .topbar{font-size:11.5px;padding:6px 10px;letter-spacing:0}
  .topbar .sep{margin:0 5px}
  .topbar a{font-weight:600}

  /* Header / nav */
  .nav-inner{height:68px}
  .nav .logo img{height:44px}

  /* Page hero — compact */
  .r-pagehero{padding:14px 0 0}
  .r-crumb,
  .module-detail-hero .breadcrumb,
  .page-hero .breadcrumb,
  .post-hero .breadcrumb{
    font-size:11px;padding-bottom:10px;margin-bottom:18px;gap:5px;
  }
  .r-pagehero h1,
  .module-detail-hero h1,
  .page-hero h1,
  .post-hero h1{font-size:24px!important}
  .r-pagehero .r-lead,
  .module-detail-hero .lead,
  .page-hero .lead,
  .post-hero .lead{font-size:13.5px}

  /* Sections plus compactes */
  .r-section{padding:32px 0}
  .r-sectionhead{margin-bottom:28px}
  .r-sectionhead h2{font-size:24px;line-height:1.1}
  .r-sectionhead p{font-size:14.5px}

  /* CTA bands */
  .r-ctaband{padding:32px 18px;border-radius:18px;box-shadow:5px 5px 0 var(--r-orange)}
  .r-ctaband h2{font-size:22px;line-height:1.1}
  .r-ctaband p{font-size:14px}
  .r-ctaband .actions{flex-direction:column;align-items:stretch;gap:10px}
  .r-ctaband .actions > *{width:100%}

  /* Cards & components */
  .r-card{padding:20px}
  .r-card h3{font-size:18px}
  .r-card p{font-size:13.5px}
  .r-create-band{padding:22px;gap:22px;border-radius:18px;box-shadow:4px 4px 0 var(--r-ink)}
  .r-create-item{padding:11px 12px;gap:10px}
  .r-create-item .ic{width:34px;height:34px}
  .r-create-item .info h3,.r-create-item .info h4{font-size:13px}
  .r-create-item .info p{font-size:11.5px}
  .r-create-item .price{font-size:13px}
  .r-protect-card{padding:18px}
  .r-protect-card .head .ic{width:38px;height:38px}
  .r-protect-card .head h3,.r-protect-card .head h4{font-size:14px}

  /* Pricing plans */
  .r-plan{padding:22px 20px;box-shadow:4px 4px 0 var(--r-ink)}
  .r-plan h3{font-size:21px}
  .r-plan .price{font-size:38px}
  .r-plan.business{transform:none}
  .r-plan.business:hover{transform:translate(-2px,-2px)}
  .r-plans{gap:18px}

  /* Upsell pills wrap */
  .r-upsell{padding:20px;gap:14px}
  .r-upsell-pills{justify-content:flex-start;gap:8px}
  .r-upsell-pill{padding:8px 12px;font-size:12.5px}

  /* Buttons */
  .r-btn{padding:12px 22px;font-size:13.5px;border-radius:12px;box-shadow:3px 3px 0 var(--r-ink)}
  .r-btn-lg{padding:14px 24px;font-size:14.5px;border-radius:13px}
  .r-btn:hover{box-shadow:4px 4px 0 var(--r-ink)}

  /* Brush button */
  .r-brushbtn{padding:18px 36px;font-size:13.5px}

  /* Home hero stack */
  .r-home-hero{padding:30px 0 36px}
  .r-home-hero h1{font-size:42px;line-height:.95}
  .r-home-hero .r-lead{font-size:15.5px}
  .r-home-feats .r-feat{padding:10px 0}
  .r-home-feats .r-feat .ic{width:44px;height:44px}
  .r-home-feats .r-feat h3,.r-home-feats .r-feat h4{font-size:14px}
  .r-home-feats .r-feat p{font-size:13px}
  .r-home-actions{flex-direction:column;align-items:stretch;gap:10px}
  .r-home-actions > *{width:100%}
  .r-home-visual{min-height:280px}
  .r-home-visual .laptop{max-width:380px}
  .r-postit-fix{min-width:108px;padding:14px 18px}
  .r-postit-fix .big{font-size:26px}

  /* Tagline hand */
  .r-tagline-hand{font-size:20px}

  /* Stats */
  .r-stat .num{font-size:42px}
  .r-stat .label{font-size:12px}

  /* Tech band */
  .r-techband{padding:18px;gap:10px;font-size:14px}
  .r-techband .stack{font-size:12.5px;padding:5px 12px}

  /* Stack items hero */
  .r-stack{gap:10px;margin-bottom:18px}
  .r-stack-item{font-size:13px}

  /* FAQ */
  .r-faq-q{font-size:13.5px;padding:14px 16px;gap:10px}
  .r-faq-a-inner{padding:0 16px 14px;font-size:13.5px}

  /* Testimonials */
  .r-testi{padding:20px}
  .r-testi blockquote{font-size:14px}

  /* Prose */
  .r-prose{font-size:14.5px}
  .r-prose h2{font-size:20px;margin:32px 0 12px}
  .r-prose h3{font-size:16px}

  /* Footer */
  footer{padding:42px 0 18px;border-top-width:4px}
  footer .footer-grid{gap:28px;padding-bottom:24px;margin-bottom:24px}
  .footer-brand .logo img{height:38px;margin-bottom:14px}
  .footer-brand p{font-size:13.5px;margin-bottom:16px}
  .footer-brand .signature{font-size:20px;margin-bottom:14px}
  footer .footer-col h3,footer .footer-col h4{font-size:11.5px}
  footer .footer-col a{font-size:13.5px}
  .footer-bottom{flex-direction:column;align-items:flex-start;font-size:12px;line-height:1.6}
  .footer-bottom > div{width:100%}

  /* Modal */
  .modal{margin:14px;padding:24px 20px;max-height:calc(100vh - 28px);overflow-y:auto}
  .modal h3{font-size:20px}
  .modal-sub{font-size:13.5px}

  /* 404 */
  .r-404{padding:54px 0}
  .r-404 .num{font-size:120px;text-shadow:4px 4px 0 var(--r-ink)}

  /* Module detail buy card pas sticky en mobile */
  .module-buy-card{position:static;margin-top:14px}

  /* Modules grid stars sur 1 ligne */
  .r-module .meta{font-size:11.5px;gap:8px}
}

/* Très petits écrans */
@media(max-width:420px){
  .r-pagehero h1,
  .module-detail-hero h1,
  .page-hero h1,
  .post-hero h1{font-size:22px!important}
  .r-home-hero h1{font-size:36px}
  .r-sectionhead h2{font-size:22px}
  .r-ctaband h2{font-size:20px}
  .topbar{font-size:11px;padding:6px 8px}
  .topbar .sep{margin:0 4px}
  .r-section{padding:28px 0}
  .nav-inner{height:54px}
  .r-home-visual .laptop{max-width:320px}
  .r-stack-sep{display:none}
  .r-stack{gap:8px}
}

/* --- 404 page --- */
.r-404{
  text-align:center;padding:80px 0;
  font-family:var(--r-font-sans);
}
.r-404 .num{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(120px,18vw,200px);line-height:.9;
  color:var(--r-orange);text-shadow:6px 6px 0 var(--r-ink);
  margin-bottom:20px;
}
.r-404 h1{
  font-family:var(--r-font-display);font-weight:800;
  font-size:clamp(28px,4vw,42px);text-transform:uppercase;
  color:var(--r-ink);margin-bottom:14px;letter-spacing:-.02em;
}
.r-404 p{color:var(--r-ink-soft);font-size:17px;margin-bottom:30px;max-width:480px;margin-left:auto;margin-right:auto}
