/* ============================================================================
   NEUS LOGPRO — ACCUEIL + SERVICES (compléments à vitrine.css)
   Règles spécifiques aux pages finales : hero "Ascension" de l'accueil,
   aperçu compact des modules, barre d'ancres + bandes de la page Services.
   (Les explorations A/B/C et les hero-propositions du bundle ont été retirées :
    code mort, non utilisé par les pages livrées.)
   ========================================================================== */

/* ---- HERO accueil : conteneur + eyebrow + sous-titre -------------------- */
.kin-hero { position: relative; overflow: hidden; padding-block: clamp(40px, 6vw, 80px) clamp(48px, 6vw, 76px); --ac: var(--primary); --ac-bg: var(--primary-weak); }
.kin-hero::before {
  content: ""; position: absolute; width: 720px; height: 720px; border-radius: 50%;
  right: -240px; top: -280px; pointer-events: none; z-index: 0;
  background: radial-gradient(circle, var(--ac) 0%, transparent 68%); opacity: .12;
}
.kin-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: 52px; align-items: center; position: relative; z-index: 1; }
@media (max-width: 980px) { .kin-grid { grid-template-columns: 1fr; gap: 38px; } }
.kin-eyebrow { display: inline-flex; align-items: center; gap: 9px; padding: 7px 14px; border-radius: var(--radius-pill); background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-xs); font-size: 13px; font-weight: 700; color: var(--text-soft); }
.kin-eyebrow .pip { width: 7px; height: 7px; border-radius: 50%; background: var(--ac); box-shadow: 0 0 0 4px color-mix(in srgb, var(--ac) 22%, transparent); }
.kin-sub { font-size: clamp(17px, 1.5vw, 21px); line-height: 1.5; color: var(--text-soft); font-weight: 500; max-width: 46ch; margin-top: 24px; text-wrap: pretty; }
.kin-sub b { color: var(--ink); font-weight: 700; }

/* ---- HERO "Ascension" : escalier de modules (rappel du logo) ------------ */
.hero-steps { position: relative; width: min(480px, 94%); aspect-ratio: 1 / 0.82; margin-inline: auto; }
.hero-steps svg.line { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.hero-steps svg.line polyline { fill: none; stroke: var(--primary); stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; opacity: .35; }
.hero-steps .stp { position: absolute; transform: translate(-50%, -50%); display: flex; flex-direction: column; align-items: center; gap: 8px; width: 110px; }
.hero-steps .stp .disc { width: 60px; height: 60px; border-radius: 16px; background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-md); display: grid; place-items: center; color: var(--ac); position: relative; }
.hero-steps .stp .disc svg { width: 27px; height: 27px; }
.hero-steps .stp .disc::after { content: ""; position: absolute; inset: 0; border-radius: 16px; box-shadow: 0 0 0 4px color-mix(in srgb, var(--ac) 16%, transparent); }
.hero-steps .stp small { font-size: 12px; font-weight: 700; color: var(--ink); white-space: nowrap; }
.hero-steps .stp.new .disc { background: var(--ac); color: #fff; }

/* ---- Accueil : aperçu compact des modules (teaser vers Services) -------- */
.home-mods { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 880px) { .home-mods { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .home-mods { grid-template-columns: 1fr; } }
.home-mod { display: flex; flex-direction: column; gap: 9px; padding: 22px; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-xs); text-decoration: none; color: inherit; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; position: relative; overflow: hidden; }
.home-mod:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: color-mix(in srgb, var(--ac) 45%, var(--border)); text-decoration: none; }
.home-mod .hm-ico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--ac-bg); color: var(--ac); }
.home-mod .hm-ico svg { width: 23px; height: 23px; }
.home-mod b { font-size: 17px; font-weight: 800; letter-spacing: -.01em; color: var(--ink); }
.home-mod span { font-size: 13.5px; line-height: 1.45; color: var(--text-soft); }
.home-mod .hm-new { position: absolute; top: 16px; right: 16px; font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--svc-bill); background: var(--svc-bill-bg); padding: 3px 8px; border-radius: var(--radius-pill); }
.home-mod.soon { background: var(--gray-50); border-style: dashed; align-items: center; justify-content: center; text-align: center; color: var(--text-muted); font-weight: 700; }

/* ---- Page Services : barre d'ancres sticky ------------------------------ */
.svc-jump { position: sticky; top: var(--header-h); z-index: 40; background: color-mix(in srgb, var(--white) 90%, transparent); backdrop-filter: saturate(150%) blur(12px); -webkit-backdrop-filter: saturate(150%) blur(12px); border-bottom: 1px solid var(--border); }
.svc-jump-inner { display: flex; gap: 8px; overflow-x: auto; padding-block: 12px; scrollbar-width: none; }
.svc-jump-inner::-webkit-scrollbar { display: none; }
.svc-jump a { white-space: nowrap; font-size: 13.5px; font-weight: 700; color: var(--text-muted); padding: 8px 14px; border-radius: var(--radius-pill); border: 1px solid var(--border); background: var(--surface); display: inline-flex; align-items: center; gap: 8px; transition: all var(--t-fast); }
.svc-jump a:hover { color: var(--text); text-decoration: none; border-color: var(--border-strong); }
.svc-jump a .d { width: 9px; height: 9px; border-radius: 3px; background: var(--ac, var(--primary)); }
.band[id] { scroll-margin-top: calc(var(--header-h) + 64px); }

/* ---- Bandes par module (Services) --------------------------------------- */
.band { padding-block: clamp(48px, 6vw, 84px); }
.band-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
@media (max-width: 860px) { .band-inner { grid-template-columns: 1fr; gap: 32px; } .band-inner .visual { order: 2; } }
.band--rev .band-inner > .copy { order: 2; }
@media (max-width: 860px) { .band--rev .band-inner > .copy { order: 0; } }
.band-num { font-family: var(--font-mono); font-size: 14px; font-weight: 700; color: var(--ac); letter-spacing: .06em; }
.band h2 { font-size: clamp(28px, 3.4vw, 44px); font-weight: 900; letter-spacing: -.03em; color: var(--ink); margin-top: 12px; line-height: 1.05; }
.band p.lead { font-size: clamp(16px, 1.5vw, 19px); line-height: 1.55; color: var(--text-soft); margin-top: 16px; text-wrap: pretty; }
.band .band-pts { list-style: none; padding: 0; margin: 22px 0 0; display: flex; flex-direction: column; gap: 11px; }
.band .band-pts li { display: flex; gap: 11px; font-size: 15.5px; color: var(--text-soft); line-height: 1.45; }
.band .band-pts li svg { width: 21px; height: 21px; flex-shrink: 0; color: var(--ac); margin-top: 1px; }
.band .visual { display: flex; justify-content: center; }
.band-card { width: 100%; max-width: 440px; border-radius: var(--radius-xl); background: var(--surface); border: 1px solid var(--border); box-shadow: var(--shadow-md); overflow: hidden; }
.band-ico-xl { width: 64px; height: 64px; border-radius: 17px; display: grid; place-items: center; background: var(--ac-bg); color: var(--ac); }
.band-ico-xl svg { width: 32px; height: 32px; }
