/* ===== Au PC Bien Portant — design system ===== */
:root{
  /* brand (from logo) */
  --brand:#203a89;
  --brand-700:#1a2f6f;
  --brand-300:#9fb0e6;
  --brand-tint:#eef1fb;

  /* action accent (tweakable) */
  --accent:#2f6bff;
  --accent-ink:#ffffff;

  /* light surface */
  --bg:#f6f5f1;
  --bg-2:#efeee8;
  --card:#ffffff;
  --ink:#15171e;
  --muted:#5b6172;
  --line:#e4e2da;

  /* gamer (dark) */
  --g-bg:#0a0b12;
  --g-bg-2:#10121d;
  --g-panel:#141728;
  --g-line:#262a40;
  --g-text:#e7e9f5;
  --g-muted:#8b90ad;
  --neon:#2ad6ff;
  --neon-2:#ff2d78;

  /* shape (tweakable) */
  --radius:18px;
  --radius-sm:12px;
  --radius-pill:999px;

  /* type (tweakable base) */
  --fs:18px;

  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope",system-ui,sans-serif;
  font-size:var(--fs);
  line-height:1.6;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:"Space Grotesk",sans-serif;line-height:1.05;margin:0;letter-spacing:-.02em;font-weight:700}
p{margin:0}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.mono{font-family:"Space Mono",monospace;letter-spacing:.02em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:clamp(64px,9vw,120px) 0}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Space Grotesk",sans-serif;font-weight:600;
  font-size:1.02rem;line-height:1;
  padding:16px 24px;border-radius:var(--radius-pill);
  border:1.5px solid transparent;cursor:pointer;
  transition:transform .18s var(--ease), box-shadow .25s var(--ease), background .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-primary{position:relative;overflow:hidden;background:linear-gradient(135deg,color-mix(in oklab,var(--accent),#fff 8%),var(--accent) 55%,color-mix(in oklab,var(--accent),#000 14%));color:var(--accent-ink);box-shadow:0 10px 26px -10px color-mix(in oklab,var(--accent),#000 10%)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 44px -12px color-mix(in oklab,var(--accent),#000 6%)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-tint)}
.btn-lg{padding:19px 30px;font-size:1.1rem}
.btn-neon{background:var(--neon);color:#04121a;box-shadow:0 0 0 1px var(--neon), 0 14px 40px -10px var(--neon)}
.btn-neon:hover{transform:translateY(-2px);box-shadow:0 0 0 1px var(--neon),0 20px 52px -10px var(--neon)}
.btn-neon-ghost{background:transparent;border-color:var(--g-line);color:var(--g-text)}
.btn-neon-ghost:hover{border-color:var(--neon);color:var(--neon)}

/* ---- chips ---- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--card);border:1px solid var(--line);
  padding:9px 15px;border-radius:var(--radius-pill);
  font-size:.92rem;font-weight:600;color:var(--ink);white-space:nowrap;
}
.chip .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}

.eyebrow{
  font-family:"Space Mono",monospace;text-transform:uppercase;
  letter-spacing:.18em;font-size:.78rem;font-weight:700;color:var(--brand);
}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:50;background:color-mix(in oklab,var(--bg),transparent 8%);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:74px;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-family:"Space Grotesk";font-weight:700}
.brand img{width:42px;height:42px;border-radius:10px}
.brand .bn{font-size:1.02rem;line-height:1.05;letter-spacing:-.01em}
.brand .bn small{display:block;font-family:"Space Mono";font-weight:400;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.nav-links{display:flex;align-items:center;gap:30px;font-weight:600;font-size:.98rem}
.nav-links a{color:var(--muted);transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-phone{display:flex;align-items:center;gap:8px;font-family:"Space Grotesk";font-weight:700;color:var(--brand)}
.burger{display:none;background:none;border:1px solid var(--line);border-radius:12px;width:46px;height:46px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:20px;height:2px;background:var(--ink);border-radius:2px}

/* ---- reveal ---- */
.reveal{opacity:1;transform:translateY(16px);transition:transform .6s var(--ease)}
.reveal.in{transform:none}
@media (prefers-reduced-motion:reduce){.reveal{transform:none;transition:none}}

/* ---- placeholder imagery ---- */
.ph{position:relative;overflow:hidden;border-radius:var(--radius);
  background:
   repeating-linear-gradient(135deg,var(--bg-2),var(--bg-2) 11px,#e7e6df 11px,#e7e6df 22px);
  border:1px solid var(--line);display:flex;align-items:flex-end;padding:16px}
.ph .lbl{font-family:"Space Mono";font-size:.72rem;color:var(--muted);background:var(--card);
  border:1px solid var(--line);padding:5px 10px;border-radius:8px}
.ph.dark{background:repeating-linear-gradient(135deg,#0e1020,#0e1020 11px,#15182b 11px,#15182b 22px);border-color:var(--g-line)}
.ph.dark .lbl{color:var(--g-muted);background:var(--g-panel);border-color:var(--g-line)}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px}

/* utility */
.center{text-align:center}
.eyebrow.center,.center .eyebrow{display:inline-block}

/* ============================================================
   ÉTINCELANT — shine sweeps, glows, sparkle, premium abonnement
   ============================================================ */

/* light sweep that runs across an element on hover */
@keyframes sweep{0%{transform:translateX(-130%) skewX(-20deg)}100%{transform:translateX(240%) skewX(-20deg)}}
.shine{position:relative;overflow:hidden;isolation:isolate}
.shine::after{content:"";position:absolute;top:-20%;left:0;width:55%;height:140%;z-index:1;pointer-events:none;
  background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.55) 50%,transparent 100%);
  transform:translateX(-130%) skewX(-20deg)}
.shine:hover::after{animation:sweep .85s var(--ease)}
.btn-primary::after,.btn-neon::after{height:160%;top:-30%}

/* auto, gentle, repeating shine for the flagship card */
@keyframes sweepLoop{0%{transform:translateX(-130%) skewX(-20deg);opacity:0}
  8%{opacity:1}22%{transform:translateX(240%) skewX(-20deg);opacity:0}100%{transform:translateX(240%) skewX(-20deg);opacity:0}}
.shine-loop::after{content:"";position:absolute;top:-20%;left:0;width:45%;height:140%;z-index:1;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.35),transparent);
  transform:translateX(-130%) skewX(-20deg);animation:sweepLoop 6.5s var(--ease) infinite}

/* soft radial glow behind hero / headings */
.glow{position:relative}
.glow-orb{position:absolute;border-radius:50%;filter:blur(38px);pointer-events:none;z-index:-1}

/* gradient text for the shiny word */
.sparkle-text{background:linear-gradient(100deg,var(--accent),color-mix(in oklab,var(--accent),#fff 55%) 45%,var(--accent));
  -webkit-background-clip:text;background-clip:text;color:transparent;background-size:200% 100%;animation:gleam 5s ease-in-out infinite}
@keyframes gleam{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* tiny twinkle stars (used sparingly) */
@keyframes twinkle{0%,100%{opacity:.15;transform:scale(.7)}50%{opacity:1;transform:scale(1)}}
.twinkle{position:absolute;pointer-events:none}
.twinkle::before,.twinkle::after{content:"";position:absolute;inset:0;
  background:conic-gradient(from 0deg,transparent,#fff,transparent,#fff,transparent);
  -webkit-mask:radial-gradient(circle,#000 1px,transparent 1.6px);mask:radial-gradient(circle,#000 1px,transparent 1.6px)}

/* ---- ABONNEMENT (premium, dark navy) ---- */
.abo{background:linear-gradient(165deg,#16265e 0%,#0f1a40 55%,#0b1330 100%);color:#eef1fb;position:relative;overflow:hidden}
.abo .eyebrow{color:#bcd0ff}
.abo-toggle{display:inline-flex;align-items:center;gap:4px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius-pill);padding:5px}
.abo-toggle button{font-family:"Space Grotesk";font-weight:600;font-size:.95rem;border:none;cursor:pointer;color:#cdd6f5;
  background:transparent;padding:10px 20px;border-radius:var(--radius-pill);transition:color .2s, background .25s var(--ease);white-space:nowrap}
.abo-toggle button.on{background:#fff;color:#14245c;box-shadow:0 6px 18px -8px rgba(0,0,0,.5)}
.abo-card{position:relative;display:grid;gap:18px;align-content:start;padding:30px 28px;border-radius:var(--radius);
  background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.abo-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.28)}
.abo-card.feat{background:linear-gradient(180deg,color-mix(in oklab,var(--accent),transparent 78%),rgba(255,255,255,.05));
  border-color:color-mix(in oklab,var(--accent),#fff 25%);box-shadow:0 0 0 1px color-mix(in oklab,var(--accent),#fff 10%),0 30px 70px -34px var(--accent)}
.abo-card .feats{list-style:none;padding:0;margin:0;display:grid;gap:11px}
.abo-card .feats li{display:flex;gap:10px;align-items:flex-start;font-size:1rem;color:#dbe2f7}
.abo-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;
  font-family:"Space Mono";font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:5px 14px;border-radius:7px;white-space:nowrap}
.abo-price{display:flex;align-items:baseline;gap:6px;font-family:"Space Grotesk";font-weight:700;color:#fff}
.abo-price .num{font-size:3.2rem;line-height:.9;letter-spacing:-.03em}
.abo-price .per{font-size:1rem;color:#aeb9e0;font-weight:600}

/* tarifs strip */
.tarif-card{display:flex;align-items:baseline;justify-content:space-between;gap:18px;padding:16px 0;border-bottom:1px dashed var(--line)}
.tarif-card:last-child{border-bottom:none}

@media (max-width:980px){.abo-grid{grid-template-columns:1fr !important}.abo-card.feat{order:-1}}

/* responsive */
@media (max-width:900px){
  .nav-links{display:none}
  .nav-phone .np-txt{display:none}
  .burger{display:flex}
  :root{--fs:17px}
}
@media (prefers-reduced-motion:reduce){
  .shine-loop::after,.sparkle-text,.twinkle::before,.twinkle::after{animation:none}
  .sparkle-text{background-position:0 50%}
}

/* ---- FUNNEL : process steps, témoignages, engagements, barre flottante ---- */

/* numbered step */
.step-num{flex:0 0 auto;width:46px;height:46px;border-radius:14px;display:grid;place-items:center;
  font-family:"Space Grotesk";font-weight:700;font-size:1.25rem;color:#fff;
  background:linear-gradient(135deg,color-mix(in oklab,var(--accent),#fff 10%),var(--accent));
  box-shadow:0 10px 24px -12px var(--accent)}
.step-card{position:relative}
.step-card:not(:last-child)::after{content:"";position:absolute;left:23px;top:54px;bottom:-26px;width:2px;
  background:linear-gradient(var(--brand-300),transparent);opacity:.6}
@media(min-width:781px){.step-card:not(:last-child)::after{display:none}}

/* testimonial */
.quote-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;
  display:grid;gap:16px;align-content:start;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.quote-card:hover{transform:translateY(-4px);box-shadow:0 24px 54px -30px rgba(20,30,80,.32)}
.quote-card .stars{display:inline-flex;gap:3px;color:var(--accent)}
.avatar{flex:0 0 auto;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  font-family:"Space Grotesk";font-weight:700;font-size:1rem;background:var(--brand-tint);color:var(--brand)}

/* engagements band */
.vow{display:grid;gap:12px;align-content:start}
.vow .ico{width:50px;height:50px;border-radius:14px;background:#fff;border:1px solid var(--brand-300);display:grid;place-items:center}

/* sticky callback bar */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:140;
  background:color-mix(in oklab,var(--card),transparent 4%);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);box-shadow:0 -14px 40px -24px rgba(20,30,80,.35);
  transform:translateY(110%);transition:transform .45s var(--ease)}
.sticky-cta.show{transform:none}
.sticky-in{display:flex;align-items:center;gap:18px;padding:13px 0}
.sticky-msg{display:flex;align-items:center;gap:13px;min-width:0}
.sticky-msg .t1{font-family:"Space Grotesk";font-weight:700;font-size:1.02rem;line-height:1.15}
.sticky-msg .t2{color:var(--muted);font-size:.86rem}
.sticky-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.sticky-x{flex:0 0 auto;width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:transparent;
  color:var(--muted);cursor:pointer;font-size:.95rem}
@media(max-width:620px){
  .sticky-msg .t2{display:none}
  .sticky-msg .sticky-ico{display:none}
  .sticky-cta .sticky-phone-txt{display:none}
}
