/* =============================================================================
   Intexo — Site vitrine styles
   "Efficient Trust". Construit sur les tokens de colors_and_type.css.
   Préfixe BEM : .sc-* (showcase)
   ========================================================================== */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: clip; }
img  { max-width: 100%; display: block; }

/* Lucide icons sized via font-size */
.lic { display: inline-flex; }
.lic svg { width: 1em; height: 1em; stroke-width: 1.85; }

/* ---- Layout -------------------------------------------------------------- */
.sc-container { max-width: 1180px; margin: 0 auto; padding: 0 32px; }
.sc-section   { padding: 96px 0; position: relative; }
.sc-section--dark {
  background: var(--dark-bg);
  color: var(--dark-fg);
}
.sc-section--tinted {
  background: var(--surface-sunken);
}

/* ---- Overline / badge ----------------------------------------------------- */
.sc-overline {
  display: inline-flex; align-items: center; gap: 8px;
  font: var(--text-overline); text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--primary);
  margin-bottom: 16px;
}
.sc-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font: var(--text-sm); font-weight: 500; color: var(--fg-muted);
  background: var(--surface-sunken); border: 1px solid var(--border);
  border-radius: var(--radius-full); padding: 5px 12px;
  margin-bottom: 20px;
}
.sc-badge--primary {
  color: var(--primary); background: var(--primary-tint); border-color: var(--amber-100);
}

/* ---- Buttons ------------------------------------------------------------- */
.sc-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-sans); font-weight: 600; border: 1px solid transparent;
  border-radius: var(--radius); cursor: pointer;
  transition: all .18s cubic-bezier(.4,0,.2,1);
  white-space: nowrap; text-decoration: none; line-height: 1;
}
.sc-btn--md { font-size: 14px; padding: 9px 18px; }
.sc-btn--lg { font-size: 16px; padding: 13px 28px; }

.sc-btn--primary {
  background: var(--primary); color: var(--primary-foreground); border-color: var(--primary);
}
.sc-btn--primary:hover {
  background: var(--primary-hover); border-color: var(--primary-hover);
  transform: translateY(-1px); box-shadow: var(--shadow-md);
}
.sc-btn--primary:active { transform: none; }

.sc-btn--accent {
  background: var(--accent); color: var(--accent-foreground); border-color: var(--accent);
}
.sc-btn--accent:hover {
  background: var(--accent-hover); border-color: var(--accent-hover);
  transform: translateY(-1px); box-shadow: var(--shadow-md);
}

.sc-btn--secondary {
  background: var(--surface); color: var(--fg); border-color: var(--border-strong);
}
.sc-btn--secondary:hover {
  background: var(--surface-sunken); border-color: var(--border-focus);
  color: var(--primary); transform: translateY(-1px);
}

.sc-btn--ghost {
  background: transparent; color: var(--fg-muted); border-color: transparent;
}
.sc-btn--ghost:hover { background: var(--surface-sunken); color: var(--fg); }

.sc-btn--outline-light {
  background: transparent; color: var(--white); border-color: rgba(255,255,255,.35);
}
.sc-btn--outline-light:hover {
  background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.6);
  transform: translateY(-1px);
}

/* ---- Header -------------------------------------------------------------- */
.sc-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(248,250,252,.82);
  background: color-mix(in oklab, var(--bg) 82%, transparent);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.sc-header.scrolled {
  border-bottom-color: var(--border);
  background: rgba(255,255,255,.96);
  background: color-mix(in oklab, var(--surface) 96%, transparent);
  box-shadow: var(--shadow-xs);
}
.sc-header__in {
  max-width: 1180px; margin: 0 auto; padding: 0 32px; height: 68px;
  display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
}
.sc-brand {
  display: flex; align-items: center; gap: 10px;
  color: var(--fg); cursor: pointer; text-decoration: none; justify-self: start;
}
.sc-wordmark {
  font-family: var(--font-display); font-weight: 700;
  letter-spacing: -0.02em; font-size: 20px; color: var(--fg);
}
.sc-wordmark em { color: var(--primary); font-style: normal; }
.sc-nav { display: flex; gap: 30px; justify-self: center; }
.sc-nav a {
  font: var(--text-sm); font-weight: 500; color: var(--fg-muted);
  cursor: pointer; transition: color .18s; text-decoration: none;
  position: relative;
}
.sc-nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -24px; height: 2px;
  background: var(--accent); transform: scaleX(0); transition: transform .2s;
  border-radius: 1px;
}
.sc-nav a:hover  { color: var(--primary); }
.sc-nav a.active { color: var(--primary); }
.sc-nav a.active::after { transform: scaleX(1); }

.sc-header__cta { display: flex; align-items: center; gap: 12px; justify-self: end; }
.sc-menu-btn {
  display: none; background: none; border: 0; color: var(--fg);
  cursor: pointer; padding: 6px; border-radius: var(--radius);
  transition: background .15s;
}
.sc-menu-btn:hover { background: var(--surface-sunken); }

/* Mobile nav — toujours en flex sur mobile, show/hide via opacity */
.sc-mobnav {
  display: none; /* caché sur desktop */
  position: fixed; top: 68px; left: 0; right: 0; z-index: 49;
  background: var(--surface); border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-md); padding: 12px 32px 20px;
  flex-direction: column; gap: 2px;
}
.sc-mobnav a {
  font: var(--text-body); font-weight: 500; color: var(--fg);
  padding: 12px 4px; border-bottom: 1px solid var(--border); text-decoration: none;
  transition: color .15s;
}
.sc-mobnav a:hover, .sc-mobnav a.active { color: var(--primary); }
.sc-mobnav .sc-btn { margin-top: 12px; width: 100%; justify-content: center; }

/* ---- Pages légales ------------------------------------------------------- */
.sc-legal-section { padding: 72px 0 96px; background: var(--bg); }
.sc-legal { max-width: 940px; margin: 0 auto; padding: 0 32px; }
.sc-legal__head { text-align: center; margin-bottom: 40px; }
.sc-legal__head .sc-overline { justify-content: center; }
.sc-legal__title {
  font: var(--text-h1); letter-spacing: -0.015em; color: var(--fg); margin: 10px 0 8px;
}
.sc-legal__updated { font: var(--text-sm); color: var(--fg-subtle); margin: 0; }
.sc-legal__body {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: 40px 44px;
}
.sc-legal__intro {
  font: var(--text-body-lg); color: var(--fg-muted); margin: 0 0 8px; line-height: 1.6;
}
.sc-legal__sec { margin-top: 32px; }
.sc-legal__h2 {
  font: var(--text-h3); color: var(--fg); margin: 0 0 12px;
  padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.sc-legal__p { font: var(--text-body); color: var(--fg-muted); margin: 0 0 12px; line-height: 1.7; }
.sc-legal__list {
  margin: 0 0 12px; padding-left: 20px; display: flex; flex-direction: column; gap: 8px;
}
.sc-legal__list li { font: var(--text-body); color: var(--fg-muted); line-height: 1.6; }
.sc-legal__note {
  display: flex; align-items: flex-start; gap: 8px; margin: 36px 0 0;
  padding: 14px 16px; border-radius: var(--radius); background: var(--primary-tint);
  border: 1px solid var(--border); font: var(--text-sm); color: var(--fg-muted); line-height: 1.5;
}
.sc-legal__note .lic { color: var(--primary); flex-shrink: 0; margin-top: 2px; }
.sc-legal__foot {
  margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
}
.sc-legal__back {
  display: inline-flex; align-items: center; gap: 6px;
  font: var(--text-sm); font-weight: 600; color: var(--primary);
}
.sc-legal__back:hover { color: var(--primary-hover); }
.sc-legal__back .lic { transition: transform .18s ease; }
.sc-legal__back:hover .lic { transform: translateX(-3px); }
@media (max-width: 600px) {
  .sc-legal-section { padding: 48px 0 64px; }
  .sc-legal { padding: 0 18px; }
  .sc-legal__body { padding: 28px 22px; }
}

/* ---- Footer -------------------------------------------------------------- */
.sc-footer {
  background: var(--dark-bg); color: var(--dark-fg-muted);
  padding: 64px 0 40px;
}
.sc-footer__grid {
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px;
  padding-bottom: 48px; border-bottom: 1px solid var(--dark-border);
}
.sc-footer__brand .sc-wordmark { color: var(--white); font-size: 18px; }
.sc-footer__tagline { font: var(--text-sm); color: var(--dark-fg-muted); margin-top: 10px; line-height: 1.6; }
.sc-footer__col h4 {
  font: var(--text-sm); font-weight: 600; color: var(--dark-fg); margin: 0 0 14px;
  text-transform: uppercase; letter-spacing: .08em;
}
.sc-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.sc-footer__col a { font: var(--text-sm); color: var(--dark-fg-muted); text-decoration: none; transition: color .18s; }
.sc-footer__col a:hover { color: var(--white); }
.sc-footer__col a.active { color: var(--primary); font-weight: 600; }
.sc-footer__bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 28px; flex-wrap: wrap; gap: 12px;
}
.sc-footer__copy { font: var(--text-caption); color: var(--dark-fg-muted); }
.sc-footer__certs { display: flex; gap: 16px; }
.sc-footer__cert {
  font: var(--text-caption); color: var(--dark-fg-muted);
  display: flex; align-items: center; gap: 5px;
}

/* ---- Modal --------------------------------------------------------------- */
.sc-modal-scrim {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(15,23,42,.55);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  display: grid; place-items: center; padding: 24px;
  animation: sc-fade-in .18s ease;
}
.sc-modal {
  background: var(--surface); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg); width: 100%; max-width: 460px;
  padding: 32px; position: relative;
  animation: sc-slide-up .22s cubic-bezier(.4,0,.2,1);
}
.sc-modal__close {
  position: absolute; top: 16px; right: 16px;
  background: none; border: 0; cursor: pointer; color: var(--fg-muted);
  display: grid; place-items: center; padding: 4px; border-radius: var(--radius);
  transition: color .15s, background .15s;
}
.sc-modal__close:hover { color: var(--fg); background: var(--surface-sunken); }
.sc-modal h2 { font: var(--text-h3); margin-bottom: 6px; }
.sc-modal p  { font: var(--text-sm); color: var(--fg-muted); margin-bottom: 22px; }

/* Form */
.sc-form { display: flex; flex-direction: column; gap: 14px; }
.sc-field { display: flex; flex-direction: column; gap: 5px; }
.sc-field label { font: var(--text-sm); font-weight: 500; color: var(--fg); }
.sc-field input,
.sc-field select,
.sc-field textarea {
  font: var(--text-body); color: var(--fg);
  background: var(--surface); border: 1px solid var(--border-strong);
  border-radius: var(--radius); padding: 9px 12px;
  transition: border-color .18s, box-shadow .18s; width: 100%;
}
.sc-field textarea { resize: vertical; min-height: 92px; font-family: inherit; }
.sc-field input:focus, .sc-field select:focus, .sc-field textarea:focus {
  outline: none; border-color: var(--border-focus);
  box-shadow: 0 0 0 3px var(--primary-tint);
}
.sc-form .sc-btn { margin-top: 4px; width: 100%; justify-content: center; }

/* Success state */
.sc-modal__success {
  text-align: center; padding: 20px 0 8px;
}
.sc-modal__check {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--success-tint); color: var(--success);
  display: grid; place-items: center; margin: 0 auto 16px; font-size: 26px;
}

/* ---- Scroll Reveal -------------------------------------------------------- */
.reveal {
  opacity: 0; transform: translateY(18px);
  transition: opacity .55s cubic-bezier(.4,0,.2,1), transform .55s cubic-bezier(.4,0,.2,1);
}
.reveal.visible { opacity: 1; transform: none; }
.reveal-delay-1 { transition-delay: .08s; }
.reveal-delay-2 { transition-delay: .16s; }
.reveal-delay-3 { transition-delay: .24s; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ---- Hero (plein écran) --------------------------------------------------- */
.sc-hero {
  background: linear-gradient(150deg, #16181c 0%, #1a1b1e 60%, #0f1012 100%);
  color: var(--white);
  position: relative;
  overflow: hidden;
  display: flex;
}
/* Image de fond + voile dégradé (sombre à gauche pour la lisibilité du texte) */
.sc-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    linear-gradient(90deg, rgba(16,18,20,.94) 0%, rgba(16,18,20,.82) 28%, rgba(16,18,20,.45) 58%, rgba(16,18,20,.28) 100%),
    linear-gradient(0deg, rgba(15,16,18,.85) 0%, rgba(15,16,18,0) 22%, rgba(15,16,18,0) 78%, rgba(22,24,28,.6) 100%),
    url("assets/hero_bg.jpg") center / cover no-repeat;
}
/* Dot grid overlay */
.sc-hero::before {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 90% 75% at 50% 0%, black 15%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 90% 75% at 50% 0%, black 15%, transparent 80%);
}
.sc-hero__inner {
  position: relative; z-index: 2;
  display: flex; flex-direction: column;
  width: 100%;
  min-height: calc(100vh - 68px);
  min-height: calc(100svh - 68px);
  padding: 88px 0 40px;
}
.sc-hero__text {
  max-width: 800px; margin: 0 auto;
  flex: 1 1 auto;
  display: flex; flex-direction: column; justify-content: center; align-items: center;
  text-align: center;
  animation: sc-hero-in .8s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes sc-hero-in { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .sc-hero__text { animation: none; } }

.sc-hero__trust-badge {
  display: inline-flex; align-items: center; gap: 7px;
  font: var(--text-sm); font-weight: 500;
  color: var(--amber-300);
  background: rgba(251,191,36,.1); border: 1px solid rgba(251,191,36,.22);
  border-radius: var(--radius-full); padding: 5px 13px;
  margin-bottom: 22px;
}

.sc-hero__h1 {
  font: 700 62px/1.05 var(--font-display);
  letter-spacing: -0.03em; color: var(--white); margin: 0 0 22px;
}
.sc-hero__h1 em {
  font-style: normal;
  background: linear-gradient(90deg, var(--amber-400), var(--amber-600));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}

.sc-hero__sub {
  font: var(--text-body-lg); color: rgba(255,255,255,.66);
  margin: 0 auto 40px; max-width: 600px; line-height: 1.65;
}

.sc-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 20px; justify-content: center; }

.sc-hero__hint {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font: var(--text-sm); color: rgba(255,255,255,.4);
}
.sc-hero__hint .lic { color: rgba(255,255,255,.3); }

/* ---- InboxPreview --------------------------------------------------------- */
.sc-inbox {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: 0 28px 80px rgba(0,0,0,.5), 0 4px 16px rgba(0,0,0,.3);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.06);
  max-width: 100%;
}
.sc-inbox__bar {
  background: var(--surface-sunken); border-bottom: 1px solid var(--border);
  padding: 9px 14px; display: flex; align-items: center; gap: 6px;
}
.sc-inbox__dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.sc-inbox__bar-title {
  flex: 1; text-align: center;
  font: var(--text-caption); color: var(--fg-subtle);
  font-family: var(--font-mono);
}

.sc-inbox__body { display: grid; grid-template-columns: 150px 1fr 108px; }

/* List column */
.sc-inbox__list { border-right: 1px solid var(--border); }
.sc-inbox__col-head {
  padding: 9px 11px; border-bottom: 1px solid var(--border);
  font: var(--text-caption); font-weight: 600;
  text-transform: uppercase; letter-spacing: .07em; color: var(--fg-muted);
  display: flex; justify-content: space-between; align-items: center;
}
.sc-inbox__count {
  background: var(--primary-tint); color: var(--primary);
  font: var(--text-caption); font-weight: 700;
  border-radius: 10px; padding: 1px 7px;
}
.sc-inbox__row {
  padding: 9px 11px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background .12s;
}
.sc-inbox__row:hover { background: var(--surface-sunken); }
.sc-inbox__row:focus-visible { outline: 2px solid var(--border-focus); outline-offset: -2px; }
.sc-inbox__row.active { background: var(--primary-tint); box-shadow: inset 2px 0 0 var(--primary); }
.sc-inbox__row-top {
  display: flex; justify-content: space-between; align-items: center;
  gap: 6px; margin-bottom: 4px;
}
.sc-inbox__row-name {
  font: var(--text-sm); font-weight: 500; color: var(--fg);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sc-inbox__row-meta {
  display: flex; align-items: center; gap: 4px;
  font: var(--text-caption); color: var(--fg-subtle);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.sc-inbox__row-meta .lic { flex-shrink: 0; }

/* Detail column */
.sc-inbox__detail { padding: 11px 12px; border-right: 1px solid var(--border); }
.sc-inbox__detail-head {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 7px;
}
.sc-inbox__detail-head strong { font-size: 13px; color: var(--fg); }
.sc-inbox__time { font: var(--text-caption); color: var(--fg-subtle); }
.sc-inbox__summary {
  font: var(--text-sm); color: var(--fg-muted);
  line-height: 1.5; margin: 0 0 10px;
  font-style: italic;
}
.sc-inbox__fields { display: flex; flex-direction: column; gap: 7px; }
.sc-inbox__field {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  font: var(--text-caption);
}
.sc-inbox__field-k { color: var(--fg-subtle); white-space: nowrap; }
.sc-inbox__field-v {
  color: var(--fg); font-weight: 600; text-align: right;
  display: inline-flex; align-items: center; gap: 4px;
}
.sc-inbox__field-v .lic { flex-shrink: 0; }
.sc-inbox__field--ok .sc-inbox__field-v { color: var(--green-700); }
.sc-inbox__field--ok .sc-inbox__field-v .lic { color: var(--green-600); }
.sc-inbox__field--no .sc-inbox__field-v { color: var(--fg-subtle); font-weight: 500; }

/* Score column */
.sc-inbox__score-col {
  padding: 14px 10px;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 3px; text-align: center;
}
.sc-inbox__score-num {
  font: 700 36px/1 var(--font-mono);
  letter-spacing: -0.03em; color: var(--score-high-fg);
}
.sc-inbox__score-sub {
  font: var(--text-caption); color: var(--fg-subtle); margin-bottom: 6px;
}
.sc-inbox__score-badge {
  font: var(--text-caption); font-weight: 700;
  border-radius: 10px; padding: 2px 8px; margin-bottom: 10px;
  text-align: center; transition: background .2s, color .2s;
}
.sc-inbox__score-badge--high { background: var(--score-high-bg); color: var(--score-high-fg); }
.sc-inbox__score-badge--mid  { background: var(--score-mid-bg);  color: var(--score-mid-fg); }
.sc-inbox__score-badge--low  { background: var(--score-low-bg);  color: var(--score-low-fg); }
.sc-inbox__cta-btn {
  font: var(--text-caption); font-weight: 700;
  background: var(--primary); color: white;
  border: none; border-radius: var(--radius-sm);
  padding: 6px 8px; cursor: pointer; width: 100%;
  transition: background .15s;
}
.sc-inbox__cta-btn:hover { background: var(--primary-hover); }

/* ---- InboxPreview — animation au scroll (.is-on) ------------------------- */
/* Lignes en cascade */
.sc-inbox.is-on .sc-inbox__list .sc-inbox__row { animation: sc-row-in .45s ease both; }
.sc-inbox.is-on .sc-inbox__list .sc-inbox__row:nth-child(2) { animation-delay: .04s; }
.sc-inbox.is-on .sc-inbox__list .sc-inbox__row:nth-child(3) { animation-delay: .14s; }
.sc-inbox.is-on .sc-inbox__list .sc-inbox__row:nth-child(4) { animation-delay: .24s; }
@keyframes sc-row-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* Balayage d'analyse sur le panneau détail (une passe) */
.sc-inbox__detail { position: relative; overflow: hidden; }
.sc-inbox.is-on .sc-inbox__detail::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(105deg, transparent 35%, rgba(217,119,6,.16) 50%, transparent 65%);
  transform: translateX(-120%);
  animation: sc-scan 1.5s cubic-bezier(.4,0,.2,1) .15s 1 forwards;
}
@keyframes sc-scan { to { transform: translateX(120%); } }

/* Champs extraits qui apparaissent en cascade (rejoués à chaque sélection
   grâce au remount du panneau détail via key={selected}) */
.sc-inbox.is-on .sc-inbox__field { animation: sc-field-in .4s ease both; }
.sc-inbox.is-on .sc-inbox__field:nth-child(1) { animation-delay: .42s; }
.sc-inbox.is-on .sc-inbox__field:nth-child(2) { animation-delay: .54s; }
.sc-inbox.is-on .sc-inbox__field:nth-child(3) { animation-delay: .66s; }
.sc-inbox.is-on .sc-inbox__field:nth-child(4) { animation-delay: .78s; }
@keyframes sc-field-in { from { opacity: 0; transform: translateX(-6px); } to { opacity: 1; transform: none; } }

/* Pastille « live » qui pulse */
.sc-inbox__live {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green-500); margin-right: 5px; vertical-align: middle;
  animation: sc-pulse 1.8s ease-out infinite;
}
@keyframes sc-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(34,197,94,.45); }
  70%  { box-shadow: 0 0 0 6px rgba(34,197,94,0); }
  100% { box-shadow: 0 0 0 0 rgba(34,197,94,0); }
}
@media (prefers-reduced-motion: reduce) {
  .sc-inbox.is-on .sc-inbox__list .sc-inbox__row,
  .sc-inbox.is-on .sc-inbox__detail::after,
  .sc-inbox.is-on .sc-inbox__field,
  .sc-inbox__live { animation: none !important; }
}

/* ---- Floating labels ----------------------------------------------------- */
.sc-floating-label {
  position: absolute; z-index: 2;
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--white); border-radius: var(--radius-full);
  padding: 9px 16px; box-shadow: 0 8px 32px rgba(0,0,0,.22), var(--shadow-ring);
  font: var(--text-sm); font-weight: 600; color: var(--fg);
  white-space: nowrap; pointer-events: none;
  animation: sc-float 4s ease-in-out infinite;
}
.sc-floating-label .lic { color: var(--accent); }
.sc-floating-label--tr { top: -18px; right: -22px; }
.sc-floating-label--bl { bottom: -18px; left: -18px; animation-delay: -2s; }
@keyframes sc-float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-6px); }
}

/* Hero responsive */
@media (max-width: 960px) {
  .sc-hero__inner { padding: 56px 0 32px; }
  .sc-hero__text { max-width: 100%; }
  .sc-hero__h1 { font-size: 40px; }
  .sc-floating-label { display: none; } /* évite les labels hors-écran en mobile */
  /* Voile plus dense en pile verticale pour garder le texte lisible */
  .sc-hero::after {
    background:
      linear-gradient(180deg, rgba(16,18,20,.9) 0%, rgba(16,18,20,.74) 40%, rgba(16,18,20,.5) 100%),
      url("assets/hero_bg.jpg") center / cover no-repeat;
  }
}
@media (max-width: 600px) {
  .sc-hero__h1 { font-size: 32px; }
  .sc-hero__sub { font-size: 16px; }
  .sc-hero__ctas { flex-direction: column; }
  .sc-hero__ctas .sc-btn { width: 100%; justify-content: center; }
}

/* ---- Metrics band --------------------------------------------------------- */
.sc-metrics {
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 44px 0;
}
.sc-metrics__inner {
  display: grid; grid-template-columns: repeat(4, 1fr);
}
.sc-metric {
  padding: 12px 32px;
  text-align: center;
  border-right: 1px solid var(--border);
}
.sc-metric:last-child { border-right: 0; }

.sc-metric__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--primary-tint); color: var(--primary);
  font-size: 16px; margin-bottom: 12px;
}
.sc-metric__value {
  font: 700 38px/1 var(--font-mono);
  letter-spacing: -0.03em; color: var(--fg);
  margin-bottom: 6px;
}
.sc-metric__label {
  font: var(--text-sm); font-weight: 500; color: var(--fg-muted);
}

/* ---- Trust bar ------------------------------------------------------------ */
.sc-trustbar {
  padding: 44px 0;
  background: var(--bg);
}
.sc-trustbar__label {
  text-align: center;
  font: var(--text-sm); font-weight: 600;
  color: var(--fg-subtle);
  text-transform: uppercase; letter-spacing: .11em;
  margin: 0 0 40px;
}
.sc-trustbar__logos {
  display: flex; align-items: center; justify-content: center;
  gap: 16px; flex-wrap: wrap;
}
.sc-trustbar__logo {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-display); font-weight: 700; font-size: 15px;
  color: var(--fg-muted);
  filter: grayscale(1) opacity(.45);
  transition: filter .22s, transform .18s, background .18s, color .18s, border-color .18s;
  cursor: default;
  padding: 10px 18px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  user-select: none;
}
.sc-trustbar__logo:hover {
  filter: none;
  background: var(--brand-bg, var(--primary-tint));
  color: var(--brand-color, var(--primary));
  border-color: var(--brand-border, var(--amber-100));
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

/* Variante hero : posée sur l'image, en bas, sans bande blanche */
.sc-trustbar--hero {
  margin-top: auto; padding: 0; background: transparent;
  padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1);
}
.sc-trustbar--hero .sc-trustbar__label {
  text-align: center; color: rgba(255,255,255,.5); margin: 0 0 16px;
}
.sc-trustbar--hero .sc-trustbar__logos { justify-content: center; gap: 12px; }
.sc-trustbar--hero .sc-trustbar__logo {
  filter: none;
  color: rgba(255,255,255,.72);
  background: rgba(255,255,255,.05);
  border-color: rgba(255,255,255,.16);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.sc-trustbar--hero .sc-trustbar__logo:hover {
  color: var(--white);
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.4);
  box-shadow: none;
}

/* Metrics responsive */
@media (max-width: 760px) {
  .sc-metrics__inner { grid-template-columns: repeat(2, 1fr); }
  .sc-metric { border-right: 0; border-bottom: 1px solid var(--border); }
  .sc-metric:nth-child(odd) { border-right: 1px solid var(--border); }
  .sc-metric:nth-last-child(-n+2) { border-bottom: 0; }
}
@media (max-width: 600px) {
  .sc-metric__value { font-size: 30px; }
  .sc-trustbar { padding: 40px 0; }
  .sc-trustbar__logos { gap: 10px; }
  .sc-trustbar__logo { font-size: 13px; padding: 8px 14px; }
}

/* ---- Bento fonctionnalités ------------------------------------------------ */
.sc-bento-section {
  padding: 96px 0;
  background: var(--surface-sunken);
  /* 1re section de la page Fonctionnalités : occupe au moins la hauteur
     visible (sous le header sticky) pour ne pas laisser apparaître la
     section suivante sur les grands écrans. */
  min-height: calc(100vh - 68px);
  display: flex; flex-direction: column; justify-content: center;
}
.sc-bento-section__head { text-align: center; margin-bottom: 56px; }
.sc-bento-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-bento-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 520px; margin: 0 auto; line-height: 1.65; text-align: center;
}

.sc-bento {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  grid-template-areas:
    "hero hero capture capture"
    "hero hero routage relance"
    "dashboard dashboard crm crm";
}

.sc-bento-card {
  position: relative; overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 26px;
  display: flex; flex-direction: column;
  transition: box-shadow .22s, transform .22s, border-color .22s;
}
.sc-bento-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--accent, var(--primary)) 38%, var(--border));
  box-shadow: 0 16px 42px color-mix(in oklab, var(--accent, var(--primary)) 18%, transparent);
}

.sc-bento-card--large {
  grid-area: hero;
  background: linear-gradient(135deg, #16181c 0%, #1c1d20 60%, #111214 100%);
  border-color: rgba(251,191,36,.16);
  color: var(--white);
}
.sc-bento-card--large:hover {
  transform: translateY(-3px);
  border-color: rgba(251,191,36,.34);
  box-shadow: 0 26px 70px rgba(217,119,6,.24);
}
.sc-bento-card__glow {
  position: absolute; top: -42%; right: -18%; width: 340px; height: 340px; border-radius: 50%;
  background: radial-gradient(circle, rgba(251,191,36,.22), transparent 62%); pointer-events: none;
}

.sc-bento-card__icon {
  position: relative;
  width: 42px; height: 42px; border-radius: 11px;
  background: color-mix(in oklab, var(--accent, var(--primary)) 14%, transparent);
  color: var(--accent, var(--primary));
  display: grid; place-items: center; font-size: 20px;
  margin-bottom: 16px; flex-shrink: 0;
}
.sc-bento-card--large .sc-bento-card__icon {
  background: rgba(251,191,36,.16); color: var(--amber-300);
}

.sc-bento-card__body { flex: 1; }

.sc-bento-card__badge {
  position: relative;
  display: inline-flex; align-items: center; gap: 6px;
  font: var(--text-caption); font-weight: 600; letter-spacing: .04em;
  background: rgba(251,191,36,.12); color: var(--amber-300);
  border: 1px solid rgba(251,191,36,.22);
  border-radius: var(--radius-full); padding: 4px 11px;
  margin-bottom: 18px; width: fit-content;
}

.sc-bento-card--large h3 {
  position: relative;
  font: 700 28px/1.1 var(--font-display);
  letter-spacing: -0.02em; color: var(--white); margin: 0 0 10px;
}
.sc-bento-card__body h3 {
  font: 700 18px/1.25 var(--font-display);
  letter-spacing: -0.01em; color: var(--fg); margin: 0 0 8px;
}
.sc-bento-card--large > p {
  position: relative;
  font: var(--text-body); color: rgba(255,255,255,.6);
  line-height: 1.65; margin: 0 0 24px; max-width: 380px;
}
.sc-bento-card__body p {
  font: var(--text-sm); color: var(--fg-muted); line-height: 1.6; margin: 0;
}

/* Chips */
.sc-bento-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 16px; }
.sc-bento-chip {
  font: var(--text-caption); font-weight: 600;
  color: var(--accent, var(--primary));
  background: color-mix(in oklab, var(--accent, var(--primary)) 12%, transparent);
  border-radius: var(--radius-full); padding: 3px 10px;
}

/* Ping d'alerte (carte routage) */
.sc-bento-ping {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 16px;
  padding: 8px 13px; border-radius: var(--radius-full);
  background: color-mix(in oklab, var(--accent) 9%, transparent);
  font: 600 12.5px/1.2 var(--font-sans); color: var(--fg); width: fit-content;
}
.sc-bento-ping .lic { color: var(--accent); flex-shrink: 0; }
.sc-bento-ping__dot { position: relative; width: 9px; height: 9px; border-radius: 50%; background: var(--accent); flex-shrink: 0; }
.sc-bento-ping__dot::after {
  content: ""; position: absolute; inset: -5px; border-radius: 50%;
  border: 2px solid var(--accent); animation: sc-bping 1.8s ease-out infinite;
}
@keyframes sc-bping { 0% { transform: scale(.5); opacity: .9; } 100% { transform: scale(1.45); opacity: 0; } }

/* AI demo inside large card */
.sc-qual-demo {
  margin-top: auto;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius); padding: 16px;
}
.sc-qual-demo__header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
}
.sc-qual-demo__name { font: var(--text-sm); font-weight: 600; color: rgba(255,255,255,.85); }
.sc-qual-score-big {
  font: 700 26px/1 var(--font-mono); letter-spacing: -0.03em;
  color: #4ade80; background: rgba(74,222,128,.14);
  border-radius: 8px; padding: 4px 10px;
}
.sc-qual-demo__reasoning {
  font: var(--text-sm); color: rgba(255,255,255,.5);
  font-style: italic; line-height: 1.55;
  padding: 10px 12px;
  background: rgba(255,255,255,.04);
  border-radius: var(--radius-sm);
  border-left: 2px solid rgba(251,191,36,.35);
  margin-bottom: 12px;
}
.sc-qual-signals { display: flex; flex-wrap: wrap; gap: 6px; }
.sc-qual-signal {
  display: inline-flex; align-items: center; gap: 5px;
  font: var(--text-caption); font-weight: 600;
  border-radius: var(--radius-full); padding: 3px 9px;
}
.sc-qual-signal--ok  { color: #4ade80; background: rgba(74,222,128,.12); }
.sc-qual-signal--off { color: rgba(255,255,255,.3); background: rgba(255,255,255,.06); }

/* Timeline de relances */
.sc-bento-timeline { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }
.sc-bento-tl-item  { display: flex; align-items: center; gap: 10px; }
.sc-bento-tl-dot   { width: 8px; height: 8px; border-radius: 50%; background: var(--accent, var(--primary)); flex-shrink: 0; }
.sc-bento-tl-day   { font: var(--text-sm); font-weight: 700; color: var(--accent, var(--primary)); min-width: 36px; }
.sc-bento-tl-label { font: var(--text-sm); color: var(--fg-muted); }

/* Mini bar chart (carte pilotage) */
.sc-bento-bars {
  display: flex; align-items: flex-end; gap: 6px;
  height: 56px; margin-top: 16px; padding-top: 8px;
}
.sc-bento-bar {
  flex: 1; border-radius: 3px 3px 0 0;
  background: color-mix(in oklab, var(--accent, var(--primary)) 22%, transparent); transition: background .18s;
}
.sc-bento-bar--hi { background: var(--accent, var(--primary)); }

/* Bento responsive */
@media (max-width: 960px) {
  .sc-bento {
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas:
      "hero hero"
      "capture capture"
      "routage relance"
      "dashboard dashboard"
      "crm crm";
  }
  .sc-bento-card--large { min-height: 380px; }
  .sc-bento-section { padding: 72px 0; }
}
@media (max-width: 600px) {
  .sc-bento {
    grid-template-columns: 1fr;
    grid-template-areas: "hero" "capture" "routage" "relance" "dashboard" "crm";
  }
  .sc-bento-card--large { min-height: 0; }
  .sc-bento-section { padding: 56px 0; }
  .sc-bento-section__h2 { font-size: 30px; }
}

/* ---- Pour qui — un bloc complet par métier (identité + critères + usages) - */
.sc-sectors-section {
  padding: 96px 0;
  background: var(--bg);
}
.sc-sectors-section__head { text-align: center; margin-bottom: 56px; }
.sc-sectors-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-sectors-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 580px; margin: 0 auto; line-height: 1.65;
}

.sc-sectors { display: flex; flex-direction: column; gap: 20px; }

.sc-sector {
  display: grid; grid-template-columns: 320px 1fr;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--sector-color, var(--primary));
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow .2s, transform .2s;
}
.sc-sector:hover {
  box-shadow: 0 16px 48px color-mix(in oklab, var(--sector-color, var(--primary)) 16%, transparent);
  transform: translateY(-2px);
}

/* Colonne identité */
.sc-sector__id {
  padding: 30px 28px;
  background: color-mix(in oklab, var(--sector-color, var(--primary)) 6%, transparent);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
}
.sc-sector__icon {
  width: 48px; height: 48px; border-radius: 13px;
  background: color-mix(in oklab, var(--sector-color, var(--primary)) 14%, transparent);
  color: var(--sector-color, var(--primary));
  display: grid; place-items: center; margin-bottom: 18px;
}
.sc-sector__sector {
  font: var(--text-caption); font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--sector-color, var(--primary)); margin-bottom: 6px;
}
.sc-sector__title {
  font: 700 22px/1.2 var(--font-display);
  letter-spacing: -0.015em; color: var(--fg); margin: 0 0 8px;
}
.sc-sector__roles { font: var(--text-sm); color: var(--fg-subtle); margin: 0 0 22px; }
.sc-sector__stat {
  margin-top: auto;
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
}
.sc-sector__stat-num {
  font: 700 26px/1 var(--font-mono); letter-spacing: -0.03em;
  color: var(--sector-color, var(--primary));
  white-space: nowrap; flex-shrink: 0;
}
.sc-sector__stat-label { font: var(--text-sm); color: var(--fg-muted); line-height: 1.4; }

/* Colonne détail — critères vérifiés + automatisations */
.sc-sector__detail {
  padding: 30px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 30px;
}
.sc-sector__block-label {
  display: flex; align-items: center; gap: 7px;
  font: var(--text-caption); font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  color: var(--fg-subtle); margin-bottom: 16px;
}
.sc-sector__block-label .lic { color: var(--sector-color, var(--primary)); }
.sc-sector__list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 11px;
}
.sc-sector__item {
  display: flex; align-items: flex-start; gap: 10px;
  font: var(--text-sm); color: var(--fg-muted); line-height: 1.5;
}
.sc-sector__item-ic {
  width: 18px; height: 18px; border-radius: 5px; flex-shrink: 0; margin-top: 1px;
  background: color-mix(in oklab, var(--sector-color, var(--primary)) 14%, transparent);
  color: var(--sector-color, var(--primary));
  display: grid; place-items: center;
}
.sc-sector__item-ic--use { border-radius: 50%; }

/* Sectors responsive */
@media (max-width: 920px) {
  .sc-sector { grid-template-columns: 1fr; }
  .sc-sector__id { border-right: none; border-bottom: 1px solid var(--border); }
  .sc-sector__stat { margin-top: 18px; }
  .sc-sectors-section { padding: 72px 0; }
}
@media (max-width: 560px) {
  .sc-sector__detail { grid-template-columns: 1fr; gap: 24px; padding: 26px 24px; }
  .sc-sectors-section__h2 { font-size: 30px; }
  .sc-sectors-section { padding: 56px 0; }
}

/* ---- Comment ça marche — timeline 3 étapes -------------------------------- */
.sc-how-section {
  padding: 96px 0;
  background: var(--surface-sunken);
  border-top: 1px solid var(--border);
}
.sc-how-section__head { text-align: center; margin-bottom: 56px; }
.sc-how-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-how-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 460px; margin: 0 auto; line-height: 1.65; text-align: center;
}

/* Connector line drawn behind the step numbers */
.sc-how-steps {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  position: relative;
}
.sc-how-steps::before {
  content: "";
  position: absolute;
  top: 27px;          /* vertically centered on the 54px badge */
  left: calc(100% / 6);   /* center of col 1 */
  right: calc(100% / 6);  /* center of col 3 */
  height: 2px;
  background: linear-gradient(90deg, var(--primary) 0%, var(--accent) 100%);
  z-index: 0;
}

.sc-how-step {
  position: relative; z-index: 1;
  text-align: center; display: flex; flex-direction: column; align-items: center;
}

/* Numbered badge — ring gap hides the connector line underneath */
.sc-how-step__num {
  width: 54px; height: 54px; border-radius: 50%;
  background: var(--primary); color: var(--white);
  font: 700 17px/1 var(--font-mono); letter-spacing: -0.02em;
  display: grid; place-items: center;
  margin-bottom: 28px; flex-shrink: 0;
  outline: 4px solid var(--surface-sunken);
  box-shadow: 0 0 0 2px var(--primary);
}

.sc-how-step__card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 28px 24px;
  text-align: left; width: 100%;
  transition: box-shadow .2s, transform .2s;
}
.sc-how-step__card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.sc-how-step__card-icon {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--primary-tint); color: var(--primary);
  display: grid; place-items: center; font-size: 18px;
  margin-bottom: 16px;
}
.sc-how-step__card h3 {
  font: 700 18px/1.25 var(--font-display);
  letter-spacing: -0.01em; color: var(--fg); margin: 0 0 10px;
}
.sc-how-step__card p {
  font: var(--text-sm); color: var(--fg-muted); line-height: 1.6; margin: 0 0 18px;
}

/* Channel / tool icons row */
.sc-how-channels {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: auto;
}
.sc-how-channel {
  display: flex; align-items: center; gap: 6px;
  font: var(--text-caption); font-weight: 600; color: var(--fg-muted);
  background: var(--surface-sunken); border: 1px solid var(--border);
  border-radius: var(--radius-full); padding: 4px 10px;
}

/* Inline score preview (step 2) */
.sc-how-score-preview {
  display: flex; align-items: center; gap: 12px;
  background: var(--surface-sunken); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 12px 14px;
}
.sc-how-score-preview__num {
  font: 700 32px/1 var(--font-mono); letter-spacing: -0.03em; color: var(--score-high-fg);
}
.sc-how-score-preview__info { display: flex; flex-direction: column; gap: 4px; }
.sc-how-score-preview__label {
  font: var(--text-caption); font-weight: 600; color: var(--score-high-fg);
  background: var(--score-high-bg); border-radius: 10px; padding: 2px 8px; width: fit-content;
}
.sc-how-score-preview__time {
  font: var(--text-caption); color: var(--fg-subtle);
  display: flex; align-items: center; gap: 4px;
}

/* How-it-works responsive */
@media (max-width: 760px) {
  .sc-how-steps {
    grid-template-columns: 1fr; gap: 0;
  }
  /* Vertical line on the left */
  .sc-how-steps::before {
    top: 27px; bottom: 27px; left: 27px; right: auto;
    width: 2px; height: auto;
  }
  .sc-how-step {
    flex-direction: row; align-items: flex-start; gap: 20px;
    text-align: left; padding-bottom: 32px;
  }
  .sc-how-step:last-child { padding-bottom: 0; }
  .sc-how-step__num { margin-bottom: 0; flex-shrink: 0; }
  .sc-how-step__card { flex: 1; }
}
@media (max-width: 600px) {
  .sc-how-section { padding: 56px 0; }
  .sc-how-section__h2 { font-size: 30px; }
}

/* ---- Intégrations --------------------------------------------------------- */
.sc-int-section {
  padding: 96px 0;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.sc-int-section__head { text-align: center; margin-bottom: 56px; }
.sc-int-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-int-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 480px; margin: 0 auto; line-height: 1.65; text-align: center;
}

/* ---- Family sections (full width, one band per family) */
.sc-int-fams { display: flex; flex-direction: column; }
.sc-int-fam {
  display: grid; grid-template-columns: 250px 1fr; gap: 40px;
  padding: 36px 0; border-top: 1px solid var(--border); align-items: start;
}
.sc-int-fam:first-child { border-top: none; padding-top: 4px; }

.sc-int-fam__aside { display: flex; flex-direction: column; }
.sc-int-fam__icon {
  width: 46px; height: 46px; border-radius: 12px; margin-bottom: 14px;
  display: grid; place-items: center;
  color: var(--accent, var(--primary));
  background: color-mix(in oklab, var(--accent, var(--primary)) 13%, var(--white));
}
.sc-int-fam__title { font: 600 20px/1.2 var(--font-display); color: var(--fg); margin: 0; }
.sc-int-fam__count {
  font: var(--text-caption); font-weight: 700; letter-spacing: .05em;
  color: var(--accent, var(--primary)); text-transform: uppercase; margin-top: 6px;
}
.sc-int-fam__blurb {
  font: var(--text-sm); color: var(--fg-muted); line-height: 1.55;
  margin: 12px 0 0; max-width: 30ch;
}

.sc-int-fam__grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(212px, 1fr)); gap: 14px;
}
.sc-int-item {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 18px;
  display: flex; flex-direction: column; gap: 7px;
  transition: box-shadow .18s, transform .18s, border-color .18s;
}
.sc-int-item:hover {
  box-shadow: var(--shadow-md); transform: translateY(-2px);
  border-color: color-mix(in oklab, var(--accent, var(--primary)) 45%, transparent);
}
.sc-int-item__head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px;
}
.sc-int-item__icon {
  width: 40px; height: 40px; border-radius: 10px; flex: none;
  display: grid; place-items: center;
  color: var(--accent, var(--primary));
  background: color-mix(in oklab, var(--accent, var(--primary)) 11%, var(--white));
}
.sc-int-item__name { font: 600 15.5px/1.2 var(--font-display); color: var(--fg); }
.sc-int-item__desc { font: var(--text-caption); color: var(--fg-muted); line-height: 1.5; }
.sc-int-item__status {
  font: 600 11px/1 var(--font-sans); letter-spacing: .02em; flex: none;
  border-radius: var(--radius-full); padding: 5px 10px;
  display: inline-flex; align-items: center; gap: 5px;
}
.sc-int-item__status--live { color: var(--green-700); background: var(--green-50); }
.sc-int-item__status--soon {
  color: var(--fg-subtle); background: var(--surface-sunken); border: 1px solid var(--border);
}
.sc-int-item__dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--green-600);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--green-500) 30%, transparent);
}

/* ---- API / Webhook banner (socle) */
.sc-int-api {
  margin-top: 24px;
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 28px; align-items: center;
  background: linear-gradient(150deg, #16181c 0%, #1c1d20 60%, #111214 100%);
  border: 1px solid rgba(251,191,36,.15);
  border-radius: var(--radius-lg); padding: 32px;
}
.sc-int-api__left { display: flex; flex-direction: column; gap: 14px; }
.sc-int-api__icon {
  width: 42px; height: 42px; border-radius: 10px;
  background: rgba(251,191,36,.12); color: var(--amber-300);
  display: grid; place-items: center; font-size: 20px;
}
.sc-int-api h3 { font: 700 22px/1.2 var(--font-display); color: var(--white); margin: 0; }
.sc-int-api__left > p {
  font: var(--text-sm); color: rgba(255,255,255,.62); line-height: 1.6; margin: 0; max-width: 42ch;
}
.sc-int-api__cta {
  display: inline-flex; align-items: center; gap: 6px; align-self: flex-start;
  font: var(--text-sm); font-weight: 600; color: var(--amber-300);
  text-decoration: none; transition: color .18s, gap .18s;
}
.sc-int-api__cta:hover { color: var(--white); gap: 10px; }
.sc-int-api__code {
  background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius); padding: 16px 18px;
  font: 12.5px/1.7 var(--font-mono); color: rgba(255,255,255,.65);
  white-space: pre;
}
.sc-int-api__code .kw  { color: var(--amber-300); }
.sc-int-api__code .str { color: #86efac; }
.sc-int-api__code .num { color: #fca5a5; }

/* Integrations responsive */
@media (max-width: 860px) {
  .sc-int-fam { grid-template-columns: 1fr; gap: 20px; padding: 28px 0; }
  .sc-int-fam__blurb { max-width: none; }
}
@media (max-width: 760px) {
  .sc-int-api { grid-template-columns: 1fr; gap: 20px; padding: 24px; }
}
@media (max-width: 600px) {
  .sc-int-section { padding: 56px 0; }
  .sc-int-section__h2 { font-size: 30px; }
}

/* ---- Pricing / Tarifs ----------------------------------------------------- */
.sc-pricing-section { padding: 96px 0; background: var(--bg); border-top: 1px solid var(--border); }
.sc-pricing__head { text-align: center; margin-bottom: 36px; }
.sc-pricing__h2 { font: var(--text-h2); letter-spacing: -0.01em; color: var(--fg); margin: 14px 0 0; }
.sc-pricing__sub { font: var(--text-body-lg); color: var(--fg-muted); max-width: 520px; margin: 14px auto 0; line-height: 1.6; }

/* Toggle mensuel / annuel */
.sc-pricing__toggle { display: inline-flex; gap: 4px; margin-top: 26px; padding: 4px; background: var(--surface-sunken); border: 1px solid var(--border); border-radius: var(--radius-full); }
.sc-pricing__toggle-btn { display: inline-flex; align-items: center; gap: 8px; border: none; cursor: pointer; background: transparent; color: var(--fg-muted); font: 600 14px/1 var(--font-sans); padding: 9px 18px; border-radius: var(--radius-full); transition: background .18s, color .18s, box-shadow .18s; }
.sc-pricing__toggle-btn.is-active { background: var(--surface); color: var(--fg); box-shadow: var(--shadow-sm); }
.sc-pricing__save { font: 700 11px/1 var(--font-sans); color: var(--green-700); background: var(--green-50); border-radius: var(--radius-full); padding: 3px 7px; }

/* Bandeau fondateur */
.sc-pricing__founder { display: flex; align-items: center; justify-content: center; gap: 12px; max-width: 760px; margin: 0 auto 40px; padding: 14px 22px; text-align: center; background: var(--primary-tint); border: 1px solid color-mix(in oklab, var(--primary) 25%, transparent); border-radius: var(--radius-md); font: var(--text-sm); color: var(--fg-muted); }
.sc-pricing__founder strong { color: var(--primary-hover); font-weight: 700; }
.sc-pricing__founder-icon { flex: none; display: grid; place-items: center; color: var(--primary); }

/* Cartes de prix */
.sc-pricing__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; align-items: start; }
.sc-price-card { position: relative; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px 26px; display: flex; flex-direction: column; transition: box-shadow .18s, transform .18s, border-color .18s; }
.sc-price-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.sc-price-card.is-featured { border-color: var(--primary); box-shadow: 0 0 0 1px var(--primary), var(--shadow-md); }
.sc-price-card__ribbon { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); white-space: nowrap; font: 700 11px/1 var(--font-sans); letter-spacing: .03em; text-transform: uppercase; color: var(--primary-foreground); background: var(--primary); border-radius: var(--radius-full); padding: 6px 14px; box-shadow: var(--shadow-sm); }
.sc-price-card__top { display: flex; align-items: center; gap: 12px; }
.sc-price-card__icon { width: 42px; height: 42px; flex: none; border-radius: 11px; display: grid; place-items: center; color: var(--primary); background: var(--primary-tint); }
.sc-price-card__name { font: 600 20px/1.2 var(--font-display); color: var(--fg); margin: 0; }
.sc-price-card__tagline { font: var(--text-sm); color: var(--fg-muted); line-height: 1.5; margin: 14px 0 0; min-height: 40px; }
.sc-price-card__price { display: flex; align-items: baseline; gap: 6px; margin-top: 18px; }
.sc-price-card__amount { font: 700 40px/1 var(--font-display); letter-spacing: -0.02em; color: var(--fg); }
.sc-price-card__cur { font-size: 24px; margin-left: 2px; }
.sc-price-card__per { font: var(--text-sm); color: var(--fg-subtle); }
.sc-price-card__billed { font: var(--text-caption); color: var(--fg-subtle); margin: 6px 0 0; }
.sc-price-card__leads { display: inline-flex; align-items: center; gap: 7px; font: 600 13px/1.3 var(--font-sans); color: var(--fg); background: var(--surface-sunken); border-radius: var(--radius-full); padding: 7px 13px; margin: 18px 0 0; align-self: flex-start; }
.sc-price-card__leads .lic { color: var(--primary); }
.sc-price-card__cta { width: 100%; justify-content: center; margin-top: 20px; }
.sc-price-card__features { list-style: none; margin: 22px 0 0; padding: 22px 0 0; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: 11px; }
.sc-price-card__features li { display: flex; align-items: flex-start; gap: 9px; font: var(--text-sm); color: var(--fg-muted); line-height: 1.45; }
.sc-price-card__features .lic { flex: none; color: var(--green-600); margin-top: 1px; }

/* Tableau comparatif */
.sc-pricing__compare { margin-top: 64px; }
.sc-pricing__compare-title { font: var(--text-h3); text-align: center; color: var(--fg); margin: 0 0 28px; }
.sc-ptable__scroll { overflow-x: auto; padding: 14px 0 2px; }
.sc-ptable { width: 100%; min-width: 660px; table-layout: fixed; border-collapse: separate; border-spacing: 0; }
.sc-ptable__col-label { width: 34%; }
.sc-ptable__col { width: 22%; }

/* En-tête : nom du palier + rappel de prix, centré au-dessus de la colonne */
.sc-ptable thead th { vertical-align: bottom; padding: 0 14px 18px; text-align: center; }
.sc-ptable__corner { text-align: left !important; font: 600 13px/1.4 var(--font-sans); color: var(--fg-subtle); }
.sc-ptable__plan { position: relative; }
.sc-ptable__plan-tag { display: inline-block; font: 700 10px/1 var(--font-sans); letter-spacing: .05em; text-transform: uppercase; color: var(--primary-foreground); background: var(--primary); border-radius: var(--radius-full); padding: 4px 9px; margin-bottom: 8px; }
.sc-ptable__plan-name { display: block; font: 600 17px/1.2 var(--font-display); color: var(--fg); }
.sc-ptable__plan.is-featured .sc-ptable__plan-name { color: var(--primary-hover); }
.sc-ptable__plan-price { display: block; font: 700 14px/1.2 var(--font-mono); color: var(--fg-muted); margin-top: 4px; }
.sc-ptable__plan-price small { font: 500 11px/1 var(--font-sans); color: var(--fg-subtle); }

/* Colonne mise en avant — fond teinté, coins arrondis haut/bas */
.sc-ptable thead th.is-featured { background: var(--primary-tint); border-radius: var(--radius-md) var(--radius-md) 0 0; box-shadow: inset 0 2px var(--primary); }
.sc-ptable tbody td.is-featured { background: var(--primary-tint); }
.sc-ptable tbody tr:last-child td.is-featured { border-radius: 0 0 var(--radius-md) var(--radius-md); }

/* Lignes de groupe + cellules */
.sc-ptable__group td { font: 700 11.5px/1.3 var(--font-sans); letter-spacing: .06em; text-transform: uppercase; color: var(--fg-subtle); background: var(--surface-sunken); padding: 9px 16px; }
.sc-ptable__group td:first-child { border-radius: var(--radius-sm) 0 0 var(--radius-sm); }
.sc-ptable__group td:last-child { border-radius: 0 var(--radius-sm) var(--radius-sm) 0; }
.sc-ptable tbody th[scope="row"] { font: var(--text-sm); font-weight: 500; color: var(--fg); text-align: left; padding: 14px 16px; border-bottom: 1px solid var(--border); }
.sc-ptable tbody td { text-align: center; padding: 14px 16px; border-bottom: 1px solid var(--border); }
.sc-ptable tbody tr:last-child th[scope="row"], .sc-ptable tbody tr:last-child td { border-bottom: none; }
.sc-ptable__yes { color: var(--green-600); }
.sc-ptable__no { color: var(--fg-subtle); }
.sc-ptable__cell { font: var(--text-sm); font-weight: 600; color: var(--fg); }

/* Le rappel du nom de ligne dans chaque cellule — masqué sur desktop
   (la colonne de gauche suffit), révélé en mobile via data-label. */
.sc-ptable tbody td::before { content: none; }

/* Mobile : 3 colonnes plein écran, sans scroll horizontal.
   On replie la colonne de libellés et on rappelle le nom de la ligne
   discrètement dans chaque cellule (data-label). */
@media (max-width: 640px) {
  .sc-ptable__scroll { overflow-x: visible; padding: 0; }
  .sc-ptable { min-width: 0; }
  .sc-ptable__col-label { width: 0; }
  .sc-ptable__col { width: 33.333%; }

  /* Colonne de libellés repliée (coin d'en-tête + th de ligne) */
  .sc-ptable__corner,
  .sc-ptable tbody th[scope="row"] {
    padding: 0 !important; width: 0; max-width: 0;
    font-size: 0; overflow: hidden; white-space: nowrap; border: 0;
  }

  .sc-ptable thead th { padding: 0 6px 14px; }
  .sc-ptable__plan-name  { font-size: 14px; }
  .sc-ptable__plan-price { font-size: 12px; }
  .sc-ptable__plan-price small { display: none; }
  .sc-ptable__plan-tag { font-size: 8.5px; padding: 3px 6px; margin-bottom: 6px; }

  .sc-ptable tbody td {
    padding: 11px 7px; text-align: center; vertical-align: top;
  }
  .sc-ptable tbody td::before {
    content: attr(data-label);
    display: block;
    font: 600 9.5px/1.25 var(--font-sans);
    color: var(--fg-subtle);
    margin-bottom: 5px;
    visibility: hidden; /* ligne fantôme : garde les ✓ alignés */
  }
  /* Nom de ligne affiché uniquement dans la colonne du milieu */
  .sc-ptable tbody td:nth-of-type(2)::before { visibility: visible; }
  .sc-ptable__cell { font-size: 12px; }
}

/* Pricing responsive */
@media (max-width: 900px) {
  .sc-pricing__grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .sc-price-card.is-featured { order: -1; }
}
@media (max-width: 600px) {
  .sc-pricing-section { padding: 56px 0; }
  .sc-pricing__h2 { font-size: 30px; }
  .sc-pricing__founder { flex-direction: column; gap: 8px; }
}

/* ---- Waitlist / Accès anticipé ------------------------------------------- */
.sc-waitlist-section {
  padding: 96px 0;
  background: linear-gradient(150deg, #16181c 0%, #1a1b1e 60%, #0f1012 100%);
  color: var(--white);
  position: relative; overflow: hidden;
}
/* Subtle dot grid (same as hero) */
.sc-waitlist-section::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 100%, black 10%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 100%, black 10%, transparent 70%);
}

.sc-waitlist__inner {
  display: grid; grid-template-columns: 1fr 420px; gap: 64px; align-items: center;
  position: relative;
}

/* Left — text block */
.sc-waitlist__badge {
  display: inline-flex; align-items: center; gap: 7px;
  font: var(--text-sm); font-weight: 600;
  color: var(--amber-300); background: rgba(251,191,36,.12);
  border: 1px solid rgba(251,191,36,.22); border-radius: var(--radius-full);
  padding: 5px 13px; margin-bottom: 22px;
}
.sc-waitlist__h2 {
  font: 700 44px/1.08 var(--font-display);
  letter-spacing: -0.025em; color: var(--white); margin: 0 0 18px;
}
.sc-waitlist__h2 em {
  font-style: normal;
  background: linear-gradient(90deg, var(--amber-400), var(--amber-600));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sc-waitlist__sub {
  font: var(--text-body-lg); color: rgba(255,255,255,.58);
  line-height: 1.65; margin: 0 0 36px; max-width: 420px;
}
.sc-waitlist__perks { display: flex; flex-direction: column; gap: 12px; }
.sc-waitlist__perk {
  display: flex; align-items: center; gap: 10px;
  font: var(--text-sm); font-weight: 500; color: rgba(255,255,255,.7);
}
.sc-waitlist__perk-dot {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  background: rgba(74,222,128,.15); color: #4ade80;
  display: grid; place-items: center; font-size: 11px;
}

/* Right — form card */
.sc-waitlist__card {
  background: var(--surface); border-radius: var(--radius-lg);
  box-shadow: 0 32px 80px rgba(0,0,0,.45), 0 4px 16px rgba(0,0,0,.25);
  padding: 36px 32px;
}
.sc-waitlist__card-title {
  font: 700 22px/1.2 var(--font-display); color: var(--fg);
  margin: 0 0 6px;
}
.sc-waitlist__card-sub {
  font: var(--text-sm); color: var(--fg-muted); margin: 0 0 24px;
}

/* Success state */
.sc-waitlist__success {
  text-align: center; padding: 20px 0;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.sc-waitlist__success-check {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--score-high-bg); color: var(--score-high-fg);
  display: grid; place-items: center; font-size: 26px;
}
.sc-waitlist__success h3 { font: 700 22px/1 var(--font-display); color: var(--fg); margin: 0; }
.sc-waitlist__success p  { font: var(--text-sm); color: var(--fg-muted); margin: 0; }

/* Waitlist responsive */
@media (max-width: 960px) {
  .sc-waitlist__inner { grid-template-columns: 1fr; gap: 44px; }
  .sc-waitlist__h2 { font-size: 34px; }
  .sc-waitlist-section { padding: 72px 0; }
}
@media (max-width: 600px) {
  .sc-waitlist__h2 { font-size: 28px; }
  .sc-waitlist__card { padding: 24px 20px; }
  .sc-waitlist-section { padding: 56px 0; }
}

/* =============================================================================
   CONTACT PAGE — en-tête + canaux + formulaire enrichi + coordonnées + mini-FAQ
   ========================================================================== */
.sc-contact-section { padding: 96px 0; background: var(--bg); }

.sc-contact__head { text-align: center; max-width: 640px; margin: 0 auto 44px; }
.sc-contact__head .sc-overline { justify-content: center; }
.sc-contact__h2 { font: var(--text-h2); letter-spacing: -0.01em; color: var(--fg); margin: 0 0 14px; }
.sc-contact__sub { font: var(--text-body-lg); color: var(--fg-muted); margin: 0; }

/* ---- Canaux ------------------------------------------------------------- */
.sc-contact__channels {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-bottom: 56px;
}
.sc-channel {
  display: flex; flex-direction: column; align-items: flex-start; gap: 8px;
  text-align: left; cursor: pointer;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px 22px;
  font-family: inherit; box-shadow: var(--shadow-xs);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.sc-channel:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: var(--border-strong); }
.sc-channel:focus-visible { outline: 2px solid var(--ring); outline-offset: 2px; }
.sc-channel__ic {
  width: 42px; height: 42px; border-radius: var(--radius-md); flex-shrink: 0;
  display: grid; place-items: center; margin-bottom: 6px;
  background: var(--primary-tint); color: var(--primary-hover);
}
.sc-channel:hover .sc-channel__ic { background: var(--primary); color: var(--primary-foreground); }
.sc-channel__title { font: 600 17px/1.25 var(--font-display); color: var(--fg); }
.sc-channel__desc { font: var(--text-sm); color: var(--fg-muted); flex: 1; }
.sc-channel__cta {
  display: inline-flex; align-items: center; gap: 6px; margin-top: 4px;
  font: var(--text-sm); font-weight: 600; color: var(--primary);
}
.sc-channel:hover .sc-channel__cta { color: var(--primary-hover); }
.sc-channel__cta .lic { transition: transform .18s ease; }
.sc-channel:hover .sc-channel__cta .lic { transform: translateX(3px); }

/* ---- Grille formulaire / coordonnées ------------------------------------ */
.sc-contact__grid {
  display: grid; grid-template-columns: 1fr 380px; gap: 28px; align-items: start;
  scroll-margin-top: 90px;
}
.sc-contact__formcard {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
  padding: 32px 30px;
}
.sc-contact__formtitle { font: 700 22px/1.2 var(--font-display); color: var(--fg); margin: 0 0 6px; }
.sc-contact__formsub { font: var(--text-sm); color: var(--fg-muted); margin: 0 0 24px; }
.sc-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.sc-field__opt { color: var(--fg-subtle); font-weight: 400; }
.sc-contact__legal { font: var(--text-caption); color: var(--fg-subtle); margin: 2px 0 0; line-height: 1.5; }

/* Coordonnées — carte near-black (contraste, aligné DA app Intexo) */
.sc-contact__aside {
  position: sticky; top: 90px;
  background: linear-gradient(155deg, #16181c 0%, #1c1d20 100%);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.sc-contact__aside-inner { padding: 30px 26px; }
.sc-contact__aside-title {
  font: var(--text-overline); text-transform: uppercase; letter-spacing: .12em;
  color: var(--amber-400); margin: 0 0 20px;
}
.sc-contact__line {
  display: flex; align-items: flex-start; gap: 12px; color: var(--fg-on-dark);
  font: var(--text-sm); font-weight: 500; margin-bottom: 16px;
}
a.sc-contact__line:hover { color: var(--amber-300); }
.sc-contact__line-ic {
  width: 34px; height: 34px; border-radius: var(--radius); flex-shrink: 0;
  display: grid; place-items: center;
  background: rgba(251,191,36,.12); color: var(--amber-400);
}
.sc-contact__line-label {
  display: block; font: var(--text-caption); color: rgba(255,255,255,.5);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 2px;
}
.sc-contact__aside-sep { height: 1px; background: rgba(255,255,255,.08); margin: 6px 0 20px; }
.sc-contact__assure { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.sc-contact__assure li {
  display: flex; align-items: center; gap: 10px;
  font: var(--text-sm); color: rgba(255,255,255,.72);
}
.sc-contact__assure-dot {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  background: rgba(74,222,128,.15); color: #4ade80;
  display: grid; place-items: center;
}

/* ---- Mini-FAQ contact --------------------------------------------------- */
.sc-contact__faq { max-width: 720px; margin: 64px auto 0; }
.sc-contact__faq-title { font: var(--text-h3); color: var(--fg); text-align: center; margin: 0 0 24px; }

/* ---- Contact responsive ------------------------------------------------- */
@media (max-width: 900px) {
  .sc-contact__channels { grid-template-columns: 1fr; gap: 14px; }
  .sc-contact__grid { grid-template-columns: 1fr; gap: 22px; }
  .sc-contact__aside { position: static; }
}
@media (max-width: 600px) {
  .sc-contact-section { padding: 64px 0; }
  .sc-contact__formcard { padding: 24px 20px; }
  .sc-form__row { grid-template-columns: 1fr; }
}

/* ---- Demo preview section (aperçu animé + « comment ça marche ») --------- */
.sc-demo-section { padding: 96px 0; background: var(--bg); }
.sc-demo-section__inner {
  display: grid; grid-template-columns: 1fr 1.05fr; gap: 72px; align-items: center;
}
.sc-demo-section__h2 {
  font: 700 38px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 16px;
}
.sc-demo-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  line-height: 1.6; margin: 0 0 32px; max-width: 420px;
}
.sc-demo-steps { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 20px; }
.sc-demo-step { display: flex; gap: 14px; align-items: flex-start; }
.sc-demo-step__num {
  flex: none; width: 30px; height: 30px; border-radius: 50%;
  display: grid; place-items: center;
  font: 700 14px/1 var(--font-mono); color: var(--primary);
  background: var(--primary-tint); border: 1px solid var(--amber-100);
}
.sc-demo-step__title {
  display: flex; align-items: center; gap: 7px;
  font: var(--text-body); font-weight: 600; color: var(--fg); margin-bottom: 3px;
}
.sc-demo-step__title .lic { color: var(--primary); }
.sc-demo-step__desc { font: var(--text-sm); color: var(--fg-muted); margin: 0; line-height: 1.55; }
.sc-demo-section__visual { position: relative; }

@media (max-width: 900px) {
  .sc-demo-section { padding: 64px 0; }
  .sc-demo-section__inner { grid-template-columns: 1fr; gap: 48px; }
  .sc-demo-section__h2 { font-size: 30px; }
  .sc-demo-section__sub { max-width: 100%; }
  .sc-demo-section__visual { max-width: 460px; }
}
/* Aperçu compacté sur petit écran (3 colonnes → resserrées) */
@media (max-width: 600px) {
  .sc-inbox__body { grid-template-columns: 104px 1fr 78px; }
  .sc-inbox__bar-title { font-size: 10px; }
  .sc-inbox__col-head { padding: 8px 9px; }
  .sc-inbox__row { padding: 8px 9px; }
  .sc-inbox__detail { padding: 9px; }
  .sc-inbox__detail-head { flex-direction: column; align-items: flex-start; gap: 1px; }
  .sc-inbox__summary { font-size: 11.5px; margin-bottom: 8px; }
  .sc-inbox__field { font-size: 10.5px; }
  .sc-inbox__score-col { padding: 10px 6px; }
  .sc-inbox__score-num { font-size: 26px; }
  .sc-inbox__cta-btn { font-size: 10px; padding: 5px 5px; }
}

/* ---- Outcomes (ce que ça change / gains) --------------------------------- */
.sc-outcomes-section { padding: 96px 0; background: var(--surface-sunken); }
.sc-outcomes-section__head { text-align: center; max-width: 620px; margin: 0 auto 48px; }
.sc-outcomes-section__head .sc-overline { justify-content: center; }
.sc-outcomes-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-outcomes-section__sub { font: var(--text-body-lg); color: var(--fg-muted); margin: 0; line-height: 1.6; }

.sc-compare {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 0; align-items: stretch;
  max-width: 920px; margin: 0 auto;
}
.sc-compare__col {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 28px 28px 30px;
}
.sc-compare__col--before { opacity: .92; }
.sc-compare__col--after {
  border-color: var(--amber-100);
  box-shadow: 0 14px 40px rgba(217,119,6,.1);
}
.sc-compare__tag {
  font: var(--text-sm); font-weight: 700; letter-spacing: .01em;
  margin-bottom: 18px; display: inline-flex; align-items: center;
}
.sc-compare__col--before .sc-compare__tag { color: var(--fg-subtle); }
.sc-compare__col--after .sc-compare__tag { color: var(--primary); }
.sc-compare__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.sc-compare__col li {
  display: flex; align-items: flex-start; gap: 10px;
  font: var(--text-body); color: var(--fg); line-height: 1.45;
}
.sc-compare__col--before li { color: var(--fg-muted); }
.sc-compare__ic {
  flex: none; width: 20px; height: 20px; border-radius: 50%;
  display: grid; place-items: center; margin-top: 1px;
}
.sc-compare__ic--x { background: var(--red-50); color: var(--red-600); }
.sc-compare__ic--check { background: var(--green-50); color: var(--green-600); }
.sc-compare__arrow {
  display: grid; place-items: center; color: var(--primary);
  width: 56px; align-self: center;
}

.sc-gains {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  max-width: 920px; margin: 36px auto 0;
}
.sc-gain {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 24px;
  text-align: center;
}
.sc-gain__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--primary-tint); color: var(--primary); margin-bottom: 12px;
}
.sc-gain__num {
  font: 700 34px/1 var(--font-mono); letter-spacing: -0.03em;
  color: var(--fg); margin-bottom: 8px;
}
.sc-gain__unit { font-size: 16px; color: var(--fg-muted); margin-left: 2px; }
.sc-gain__label { font: var(--text-sm); color: var(--fg-muted); line-height: 1.45; }

@media (max-width: 820px) {
  .sc-outcomes-section { padding: 64px 0; }
  .sc-outcomes-section__h2 { font-size: 30px; }
  .sc-compare { grid-template-columns: 1fr; gap: 14px; max-width: 480px; }
  .sc-compare__arrow { transform: rotate(90deg); width: auto; padding: 2px 0; }
  .sc-gains { grid-template-columns: 1fr; max-width: 480px; gap: 14px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE FONCTIONNALITÉS — sections de détail
   ═══════════════════════════════════════════════════════════════════════════ */

/* ---- 1. Anatomie d'un score ---------------------------------------------- */
.sc-anatomy-section { padding: 96px 0; background: var(--bg); }
.sc-anatomy-section__head { text-align: center; max-width: 680px; margin: 0 auto 56px; }
.sc-anatomy-section__h2 { font: var(--text-h2); letter-spacing: -0.01em; margin: 14px 0 14px; }
.sc-anatomy-section__sub { font: var(--text-body-lg); color: var(--fg-muted); }

.sc-anatomy { display: grid; grid-template-columns: 320px 1fr; gap: 24px; align-items: stretch; }

/* Carte verdict */
.sc-anatomy__verdict {
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  padding: 28px 24px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.sc-anatomy__lead { display: flex; align-items: center; gap: 11px; width: 100%; }
.sc-anatomy__lead-ic {
  width: 34px; height: 34px; flex-shrink: 0; border-radius: 9px;
  background: var(--surface-sunken); color: var(--fg-muted);
  display: grid; place-items: center;
}
.sc-anatomy__lead-id { display: flex; flex-direction: column; min-width: 0; }
.sc-anatomy__lead-id strong { font: 600 14px/1.2 var(--font-sans); color: var(--fg); }
.sc-anatomy__lead-id span { font: var(--text-caption); color: var(--fg-subtle); }

/* Jauge radiale animée */
.sc-gauge { position: relative; width: 150px; height: 150px; }
.sc-gauge__svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.sc-gauge__track { fill: none; stroke: var(--surface-sunken); stroke-width: 11; }
.sc-gauge__arc {
  fill: none; stroke: var(--success); stroke-width: 11; stroke-linecap: round;
  stroke-dasharray: var(--c); stroke-dashoffset: var(--c);
}
.reveal.visible .sc-gauge__arc { animation: sc-gauge-fill 1.2s cubic-bezier(.22,1,.36,1) .15s forwards; }
@keyframes sc-gauge-fill { to { stroke-dashoffset: var(--off); } }
.sc-gauge__center {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 2px;
}
.sc-gauge__num { font: 700 46px/1 var(--font-mono); letter-spacing: -0.03em; color: var(--success); }
.sc-gauge__max { font: var(--text-caption); color: var(--fg-subtle); }

.sc-anatomy__reco {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: var(--radius-full);
  background: var(--score-high-bg); color: var(--score-high-fg);
  font: 600 13px/1 var(--font-sans);
}
.sc-anatomy__scale { display: flex; width: 100%; gap: 4px; }
.sc-anatomy__scale-seg {
  flex: 1; text-align: center; padding: 6px 4px; border-radius: 6px;
  font: var(--text-caption); color: var(--fg-subtle);
  background: var(--surface-sunken); opacity: .6;
}
.sc-anatomy__scale-seg--high.is-on {
  opacity: 1; background: var(--score-high-bg); color: var(--score-high-fg); font-weight: 700;
  box-shadow: 0 0 0 1.5px color-mix(in oklab, var(--success) 45%, transparent);
}
.sc-anatomy__meta {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: center;
  font: var(--text-caption); color: var(--fg-subtle);
}
.sc-anatomy__meta span { display: inline-flex; align-items: center; gap: 4px; }
.sc-anatomy__meta-dot { width: 3px; height: 3px; border-radius: 50%; background: var(--border-strong); }

/* Dissection */
.sc-anatomy__detail { display: flex; flex-direction: column; gap: 14px; }
.sc-anatomy__block {
  padding: 18px 20px; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
}
.sc-anatomy__block-label {
  display: flex; align-items: center; gap: 7px; margin-bottom: 12px;
  font: var(--text-overline); text-transform: uppercase; letter-spacing: 0.1em; color: var(--fg-subtle);
}
.sc-anatomy__block-label .lic { color: var(--primary); }
.sc-anatomy__reasoning {
  font: var(--text-body); color: var(--fg); font-style: italic;
  padding-left: 14px; border-left: 3px solid color-mix(in oklab, var(--primary) 40%, transparent);
}
.sc-anatomy__entities { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
.sc-anatomy__entity {
  display: flex; align-items: center; gap: 8px; min-width: 0;
  padding: 9px 11px; background: var(--surface-sunken); border-radius: var(--radius);
}
.sc-anatomy__entity-ic { color: var(--primary); flex-shrink: 0; display: grid; place-items: center; }
.sc-anatomy__entity-k { font: var(--text-caption); color: var(--fg-subtle); flex-shrink: 0; }
.sc-anatomy__entity-v {
  font: 600 12.5px/1.2 var(--font-sans); color: var(--fg); margin-left: auto;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.sc-anatomy__signals { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 12px; }
.sc-anatomy__signal {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: var(--radius-full); font: 500 12.5px/1 var(--font-sans);
}
.sc-anatomy__signal--pos { background: var(--green-50); color: var(--green-700); }
.sc-anatomy__signal--neg { background: var(--surface-sunken); color: var(--fg-subtle); }
.sc-anatomy__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.sc-anatomy__tag {
  padding: 4px 10px; border-radius: var(--radius-full);
  background: var(--primary-tint); color: var(--primary-hover);
  font: 600 12px/1 var(--font-mono); border: 1px solid color-mix(in oklab, var(--primary) 18%, transparent);
}

@media (max-width: 880px) {
  .sc-anatomy { grid-template-columns: 1fr; }
  .sc-anatomy__entities { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .sc-anatomy-section { padding: 64px 0; }
  .sc-anatomy__entities { grid-template-columns: 1fr; }
}

/* ---- 2. Capture multi-canal ---------------------------------------------- */
.sc-capture-section { padding: 96px 0; background: var(--surface-sunken); }
.sc-capture-section__head { text-align: center; max-width: 660px; margin: 0 auto 56px; }
.sc-capture-section__h2 { font: var(--text-h2); letter-spacing: -0.01em; margin: 14px 0 14px; }
.sc-capture-section__sub { font: var(--text-body-lg); color: var(--fg-muted); }

.sc-capture { display: grid; grid-template-columns: 1.15fr 1fr; gap: 32px; align-items: center; }

/* Constellation */
.sc-capture__hub { position: relative; aspect-ratio: 1.18 / 1; min-height: 340px; }
.sc-capture__wires { position: absolute; inset: 0; width: 100%; height: 100%; }
.sc-capture__wire {
  stroke: color-mix(in oklab, var(--primary) 55%, var(--fg-subtle));
  stroke-width: 1; stroke-dasharray: 2.5 2.5;
  animation: sc-wire-flow 2.4s linear infinite;
}
@keyframes sc-wire-flow { to { stroke-dashoffset: -18; } }
.sc-capture__node {
  position: absolute; transform: translate(-50%, -50%);
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  padding: 11px 14px; min-width: 84px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md); box-shadow: var(--shadow-sm);
}
.sc-capture__node-ic {
  width: 32px; height: 32px; border-radius: 9px; display: grid; place-items: center;
  background: var(--primary-tint); color: var(--primary);
}
.sc-capture__node-name { font: 600 12.5px/1 var(--font-sans); color: var(--fg); }
.sc-capture__node--soon { opacity: .82; }
.sc-capture__node-badge {
  position: absolute; top: -9px; right: -9px;
  padding: 2px 7px; border-radius: var(--radius-full);
  background: var(--fg); color: var(--bg); font: 600 9px/1.3 var(--font-sans);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.sc-capture__core {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 2px;
  width: 124px; height: 124px; border-radius: 50%; justify-content: center;
  background: var(--surface); border: 2px solid var(--primary);
  box-shadow: 0 0 0 8px color-mix(in oklab, var(--primary) 10%, transparent),
              0 14px 36px color-mix(in oklab, var(--primary) 22%, transparent);
}
.sc-capture__core-ic { color: var(--primary); margin-bottom: 2px; }
.sc-capture__core strong { font: 700 17px/1 var(--font-display); color: var(--fg); }
.sc-capture__core-sub { font: var(--text-caption); color: var(--fg-subtle); }

/* Sortie normalisée */
.sc-capture__out {
  padding: 26px; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm);
}
.sc-capture__out-head {
  display: flex; align-items: center; gap: 9px; margin-bottom: 16px;
  font: 600 15px/1.3 var(--font-display); color: var(--fg);
}
.sc-capture__out-ic { color: var(--success); flex-shrink: 0; display: grid; place-items: center; }
.sc-capture__record {
  padding: 16px; background: var(--surface-sunken);
  border-radius: var(--radius); display: flex; flex-direction: column; gap: 9px;
}
.sc-capture__rec-row { display: flex; align-items: baseline; gap: 12px; font: var(--text-sm); }
.sc-capture__rec-k { color: var(--fg-subtle); width: 64px; flex-shrink: 0; }
.sc-capture__rec-v { color: var(--fg); font-weight: 500; min-width: 0; }
.sc-capture__rec-foot {
  display: flex; align-items: center; gap: 7px; margin-top: 4px; padding-top: 11px;
  border-top: 1px dashed var(--border-strong);
  font: 600 12.5px/1 var(--font-sans); color: var(--success);
}
.sc-capture__note {
  display: flex; align-items: center; gap: 8px; margin-top: 16px;
  font: var(--text-sm); color: var(--fg-muted);
}
.sc-capture__note .lic { color: var(--primary); flex-shrink: 0; }

@media (max-width: 820px) {
  .sc-capture { grid-template-columns: 1fr; gap: 28px; }
  .sc-capture__hub { max-width: 420px; margin: 0 auto; width: 100%; }
}
@media (max-width: 520px) { .sc-capture-section { padding: 64px 0; } }

/* ---- 3. Moteur de règles ------------------------------------------------- */
.sc-rules-section { padding: 96px 0; background: var(--bg); }
.sc-rules-section__head { text-align: center; max-width: 640px; margin: 0 auto 40px; }
.sc-rules-section__h2 { font: var(--text-h2); letter-spacing: -0.01em; margin: 14px 0 14px; }
.sc-rules-section__sub { font: var(--text-body-lg); color: var(--fg-muted); }

.sc-rules-scale { max-width: 760px; margin: 0 auto 32px; }
.sc-rules-scale__bar {
  position: relative; display: flex; height: 40px; border-radius: var(--radius);
  overflow: visible; border: 1px solid var(--border);
}
.sc-rules-scale__zone {
  display: grid; place-items: center; font: 600 12.5px/1 var(--font-sans);
}
.sc-rules-scale__zone--low  { flex: 0 0 30%; background: var(--score-low-bg);  color: var(--score-low-fg);  border-radius: var(--radius) 0 0 var(--radius); }
.sc-rules-scale__zone--mid  { flex: 0 0 30%; background: var(--score-mid-bg);  color: var(--score-mid-fg); }
.sc-rules-scale__zone--high { flex: 0 0 40%; background: var(--score-high-bg); color: var(--score-high-fg); border-radius: 0 var(--radius) var(--radius) 0; }
.sc-rules-scale__mark {
  position: absolute; top: -7px; bottom: -7px; width: 2px; transform: translateX(-50%);
  background: var(--fg);
}
.sc-rules-scale__mark b {
  position: absolute; top: -20px; left: 50%; transform: translateX(-50%);
  font: 700 12px/1 var(--font-mono); color: var(--fg);
}
.sc-rules-scale__note {
  display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 14px;
  font: var(--text-sm); color: var(--fg-muted);
}
.sc-rules-scale__note .lic { color: var(--primary); }

.sc-rules { display: flex; flex-direction: column; gap: 14px; max-width: 920px; margin: 0 auto; }
.sc-rule {
  display: grid; grid-template-columns: 200px 28px 1fr; align-items: center; gap: 16px;
  padding: 18px 22px; background: var(--surface);
  border: 1px solid var(--border); border-left: 3px solid var(--rule-color);
  border-radius: var(--radius-lg); transition: box-shadow .2s, transform .2s;
}
.sc-rule:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.sc-rule--high { --rule-color: var(--success); }
.sc-rule--mid  { --rule-color: var(--amber-500); }
.sc-rule--low  { --rule-color: var(--fg-subtle); }
.sc-rule__cond { display: flex; flex-direction: column; gap: 4px; }
.sc-rule__cond-ic {
  width: 30px; height: 30px; border-radius: 8px; display: grid; place-items: center; margin-bottom: 3px;
  background: color-mix(in oklab, var(--rule-color) 14%, transparent); color: var(--rule-color);
}
.sc-rule__cond-range { font: 700 15px/1.1 var(--font-mono); color: var(--fg); letter-spacing: -0.01em; }
.sc-rule__cond-label { font: var(--text-caption); color: var(--fg-subtle); text-transform: uppercase; letter-spacing: 0.08em; }
.sc-rule__arrow { color: var(--rule-color); display: grid; place-items: center; }
.sc-rule__actions { display: flex; flex-wrap: wrap; gap: 8px; }
.sc-rule__action {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 13px; border-radius: var(--radius-full);
  background: var(--surface-sunken); border: 1px solid var(--border);
  font: 500 13px/1 var(--font-sans); color: var(--fg);
}
.sc-rule__action .lic { color: var(--rule-color); }

@media (max-width: 720px) {
  .sc-rule { grid-template-columns: 1fr; gap: 12px; }
  .sc-rule__arrow { display: none; }
  .sc-rules-section { padding: 64px 0; }
}

/* ---- 4. Tableau de bord & ROI -------------------------------------------- */
.sc-dash-section { padding: 96px 0; background: var(--surface-sunken); }
.sc-dash-section__head { text-align: center; max-width: 660px; margin: 0 auto 48px; }
.sc-dash-section__h2 { font: var(--text-h2); letter-spacing: -0.01em; margin: 14px 0 14px; }
.sc-dash-section__sub { font: var(--text-body-lg); color: var(--fg-muted); }

.sc-dash {
  max-width: 980px; margin: 0 auto; overflow: hidden;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg);
}
.sc-dash__bar {
  display: flex; align-items: center; gap: 12px; padding: 13px 20px;
  background: var(--surface-sunken); border-bottom: 1px solid var(--border);
}
.sc-dash__dots { display: flex; gap: 6px; }
.sc-dash__dots i { width: 10px; height: 10px; border-radius: 50%; background: var(--border-strong); }
.sc-dash__bar-title { font: var(--text-sm); color: var(--fg-muted); font-weight: 500; }
.sc-dash__bar-live {
  margin-left: auto; display: inline-flex; align-items: center; gap: 6px;
  font: var(--text-caption); color: var(--success); font-weight: 600;
}
.sc-dash__live-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); animation: sc-pulse 1.8s ease-in-out infinite; }
@keyframes sc-pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

.sc-dash__kpis { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--border); }
.sc-dash__kpi { display: flex; flex-direction: column; gap: 5px; padding: 18px 20px; background: var(--surface); }
.sc-dash__kpi-top { display: flex; align-items: center; justify-content: space-between; }
.sc-dash__kpi-ic {
  width: 28px; height: 28px; border-radius: 8px; display: grid; place-items: center;
  background: var(--primary-tint); color: var(--primary);
}
.sc-dash__kpi-delta {
  display: inline-flex; align-items: center; gap: 2px;
  font: 600 11.5px/1 var(--font-sans); color: var(--success);
}
.sc-dash__kpi-val { font: 700 28px/1 var(--font-mono); letter-spacing: -0.03em; color: var(--fg); margin-top: 4px; }
.sc-dash__kpi-label { font: var(--text-caption); color: var(--fg-subtle); }

.sc-dash__grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 1px; background: var(--border); border-top: 1px solid var(--border); }
.sc-dash__panel { padding: 20px 22px; background: var(--surface); display: flex; flex-direction: column; gap: 14px; }
.sc-dash__panel-title { font: var(--text-overline); text-transform: uppercase; letter-spacing: 0.1em; color: var(--fg-subtle); }

.sc-dash__funnel { display: flex; flex-direction: column; gap: 10px; }
.sc-dash__funnel-row { display: grid; grid-template-columns: 74px 1fr 34px; align-items: center; gap: 10px; }
.sc-dash__funnel-label { font: var(--text-sm); color: var(--fg-muted); }
.sc-dash__funnel-track { height: 22px; background: var(--surface-sunken); border-radius: 5px; overflow: hidden; }
.sc-dash__funnel-fill {
  height: 100%; border-radius: 5px;
  background: linear-gradient(90deg, color-mix(in oklab, var(--primary) 65%, white), var(--primary));
  transform: scaleX(0); transform-origin: left; transition: transform .9s cubic-bezier(.22,1,.36,1);
}
.reveal.visible .sc-dash__funnel-fill { transform: scaleX(1); }
.sc-dash__funnel-count { font: 600 13px/1 var(--font-mono); color: var(--fg); text-align: right; }

.sc-dash__channels { display: flex; flex-direction: column; gap: 9px; }
.sc-dash__chan { display: grid; grid-template-columns: 76px 1fr 34px; align-items: center; gap: 10px; }
.sc-dash__chan-name { font: var(--text-sm); color: var(--fg-muted); }
.sc-dash__chan-track { height: 8px; background: var(--surface-sunken); border-radius: var(--radius-full); overflow: hidden; }
.sc-dash__chan-fill { height: 100%; border-radius: var(--radius-full); transform: scaleX(0); transform-origin: left; transition: transform .9s cubic-bezier(.22,1,.36,1) .2s; }
.reveal.visible .sc-dash__chan-fill { transform: scaleX(1); }
.sc-dash__chan-pct { font: 600 12.5px/1 var(--font-mono); color: var(--fg-muted); text-align: right; }

.sc-dash__trend { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; }
.sc-dash__spark { width: 100%; height: 62px; }
.sc-dash__spark-area { fill: color-mix(in oklab, var(--primary) 12%, transparent); }
.sc-dash__spark-line { fill: none; stroke: var(--primary); stroke-width: 2; stroke-linejoin: round; stroke-linecap: round; vector-effect: non-scaling-stroke; }

@media (max-width: 760px) {
  .sc-dash__kpis { grid-template-columns: 1fr 1fr; }
  .sc-dash__grid { grid-template-columns: 1fr; }
  .sc-dash-section { padding: 64px 0; }
}
@media (max-width: 460px) { .sc-dash__kpis { grid-template-columns: 1fr; } }

/* ---- 5. Avant / Après ---------------------------------------------------- */
.sc-ba-section { padding: 96px 0; background: var(--bg); }
.sc-ba-section__head { text-align: center; max-width: 600px; margin: 0 auto 48px; }
.sc-ba-section__h2 { font: var(--text-h2); letter-spacing: -0.01em; margin: 14px 0 14px; }
.sc-ba-section__sub { font: var(--text-body-lg); color: var(--fg-muted); }

.sc-ba { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; max-width: 920px; margin: 0 auto; align-items: start; }
.sc-ba__col { padding: 30px 28px; border-radius: var(--radius-lg); }
.sc-ba__col--before { background: var(--surface); border: 1px solid var(--border); }
.sc-ba__col--after {
  background: linear-gradient(160deg, color-mix(in oklab, var(--primary) 9%, var(--surface)), var(--surface));
  border: 1px solid color-mix(in oklab, var(--primary) 30%, var(--border));
  box-shadow: 0 18px 50px color-mix(in oklab, var(--primary) 14%, transparent);
}
.sc-ba__col-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 20px; padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
  font: 700 18px/1.2 var(--font-display); letter-spacing: -0.01em; color: var(--fg);
}
.sc-ba__col-ic { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; flex-shrink: 0; }
.sc-ba__col--before .sc-ba__col-ic { background: var(--surface-sunken); color: var(--fg-subtle); }
.sc-ba__col--after .sc-ba__col-ic { background: var(--primary-tint); color: var(--primary); }
.sc-ba__list { list-style: none; display: flex; flex-direction: column; gap: 13px; margin: 0; padding: 0; }
.sc-ba__list li { display: flex; align-items: flex-start; gap: 11px; font: var(--text-body); }
.sc-ba__col--before .sc-ba__list li { color: var(--fg-subtle); }
.sc-ba__col--after .sc-ba__list li { color: var(--fg); }
.sc-ba__bullet { width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0; display: grid; place-items: center; margin-top: 1px; }
.sc-ba__bullet--no { background: var(--surface-sunken); color: var(--fg-subtle); }
.sc-ba__bullet--ok { background: var(--success); color: #fff; }
.sc-ba__vs {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 2;
}
.sc-ba__vs span {
  display: grid; place-items: center; width: 52px; height: 52px; border-radius: 50%;
  background: var(--fg); color: var(--bg); font: 700 15px/1 var(--font-display); letter-spacing: 0.04em;
  box-shadow: 0 8px 24px rgba(0,0,0,.18); border: 3px solid var(--surface-sunken);
}

@media (max-width: 720px) {
  .sc-ba { grid-template-columns: 1fr; gap: 28px; }
  .sc-ba__vs { position: static; transform: none; display: flex; justify-content: center; }
  .sc-ba-section { padding: 64px 0; }
}

/* ---- 6. Sécurité & souveraineté (bande sombre) --------------------------- */
.sc-security-section { padding: 100px 0; background: var(--dark-bg); position: relative; overflow: hidden; }
.sc-security-section::before {
  content: ""; position: absolute; top: -30%; left: 50%; transform: translateX(-50%);
  width: 680px; height: 680px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklab, var(--primary) 22%, transparent), transparent 65%);
  pointer-events: none;
}
.sc-security-section__head { position: relative; text-align: center; max-width: 660px; margin: 0 auto 52px; }
.sc-security-section__h2 { font: var(--text-h2); letter-spacing: -0.01em; color: var(--dark-fg); margin: 14px 0 14px; }
.sc-security-section__sub { font: var(--text-body-lg); color: var(--dark-fg-muted); }
.sc-overline--ondark { color: var(--amber-400); }
.sc-overline--ondark .lic { color: var(--amber-400); }

.sc-security-grid { position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.sc-security-card {
  padding: 26px 24px; border-radius: var(--radius-lg);
  background: color-mix(in oklab, var(--dark-surface) 92%, white);
  border: 1px solid var(--dark-border); transition: border-color .2s, transform .2s, box-shadow .2s;
}
.sc-security-card:hover {
  transform: translateY(-3px); border-color: color-mix(in oklab, var(--primary) 50%, var(--dark-border));
  box-shadow: 0 18px 44px rgba(0,0,0,.34);
}
.sc-security-card__ic {
  width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; margin-bottom: 16px;
  background: color-mix(in oklab, var(--primary) 20%, transparent); color: var(--amber-400);
}
.sc-security-card h3 { font: 700 18px/1.25 var(--font-display); letter-spacing: -0.01em; color: var(--dark-fg); margin: 0 0 8px; }
.sc-security-card p { font: var(--text-body); color: var(--dark-fg-muted); line-height: 1.6; margin: 0; }

@media (max-width: 880px) { .sc-security-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) {
  .sc-security-grid { grid-template-columns: 1fr; }
  .sc-security-section { padding: 72px 0; }
}

/* ---- CTA band (fin de page) ---------------------------------------------- */
.sc-cta-band {
  padding: 88px 0;
  /* Image du hero en fond, très atténuée sous un voile sombre dense */
  background:
    linear-gradient(150deg, rgba(26,27,30,.93) 0%, rgba(31,32,36,.90) 55%, rgba(20,21,24,.95) 100%),
    url("assets/hero_bg.jpg") center / cover no-repeat;
  color: var(--white);
  position: relative; overflow: hidden;
  border-top: 1px solid rgba(255,255,255,.08);
}
.sc-cta-band::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 0%, black 10%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 0%, black 10%, transparent 70%);
}
.sc-cta-band__inner { position: relative; text-align: center; }
.sc-cta-band__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--white); margin: 0 0 16px;
}
.sc-cta-band__h2 em {
  font-style: normal;
  background: linear-gradient(90deg, var(--amber-400), var(--amber-600));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.sc-cta-band__sub {
  font: var(--text-body-lg); color: rgba(255,255,255,.58);
  line-height: 1.6; margin: 0 auto 32px; max-width: 480px;
}
.sc-cta-band__ctas {
  display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
@media (max-width: 700px) {
  .sc-cta-band { padding: 64px 0; }
  .sc-cta-band__h2 { font-size: 30px; }
  .sc-cta-band__ctas .sc-btn { width: 100%; justify-content: center; }
}

/* ---- FAQ ------------------------------------------------------------------ */
.sc-faq-section {
  padding: 96px 0;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.sc-faq-section__head { text-align: center; margin-bottom: 48px; }
.sc-faq-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-faq-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted); margin: 0; text-align: center;
}

.sc-faq { max-width: 720px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }

.sc-faq-item {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.sc-faq-item.open {
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px var(--primary-tint);
}

.sc-faq-item__q {
  width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 20px 22px; background: none; border: 0; cursor: pointer; text-align: left;
  font: 600 16px/1.4 var(--font-sans); color: var(--fg);
  transition: color .18s;
}
.sc-faq-item__q:hover { color: var(--primary); }
.sc-faq-item__q .lic { flex-shrink: 0; color: var(--fg-muted); transition: transform .25s cubic-bezier(.4,0,.2,1), color .18s; }
.sc-faq-item.open .sc-faq-item__q .lic { transform: rotate(180deg); color: var(--primary); }

.sc-faq-item__a {
  max-height: 0; overflow: hidden;
  transition: max-height .32s cubic-bezier(.4,0,.2,1);
}
.sc-faq-item.open .sc-faq-item__a { max-height: 400px; }
.sc-faq-item__a p {
  font: var(--text-body); color: var(--fg-muted); line-height: 1.65;
  padding: 0 22px 20px; margin: 0;
  border-top: 1px solid var(--border);
  padding-top: 16px;
}

/* ---- Engagements ---------------------------------------------------------- */
/* Bande sombre — tranche nette avec la section claire « Ce que ça change » */
.sc-engagements-section {
  padding: 104px 0;
  background: var(--dark-bg);
  border-top: 1px solid var(--dark-border);
}
.sc-engagements-section__head { text-align: center; margin-bottom: 48px; }
.sc-engagements-section__h2 {
  font: 700 36px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--white); margin: 0 0 14px;
}
.sc-engagements-section__sub {
  font: var(--text-body-lg); color: var(--dark-fg-muted); margin: 0; text-align: center;
}

.sc-engagements {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
  max-width: 860px; margin: 0 auto;
}

.sc-engagement-card {
  background: var(--dark-surface); border: 1px solid var(--dark-border);
  border-radius: var(--radius-lg); padding: 24px;
  display: flex; gap: 18px; align-items: flex-start;
  transition: box-shadow .2s, transform .2s, border-color .2s;
}
.sc-engagement-card:hover {
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
  border-color: rgba(255,255,255,.14);
  transform: translateY(-2px);
}

.sc-engagement-card__icon {
  width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0;
  background: rgba(217,119,6,.16); color: var(--amber-400);
  display: grid; place-items: center; font-size: 20px;
}
.sc-engagement-card__body h4 {
  font: 700 17px/1.2 var(--font-display); color: var(--white); margin: 0 0 6px;
}
.sc-engagement-card__body p {
  font: var(--text-sm); color: var(--dark-fg-muted); line-height: 1.6; margin: 0;
}

/* FAQ + Engagements responsive */
@media (max-width: 600px) {
  .sc-faq-section { padding: 56px 0; }
  .sc-faq-section__h2 { font-size: 28px; }
  .sc-faq-item__q { font-size: 15px; padding: 16px 18px; }
  .sc-faq-item__a p { padding: 0 18px 16px; padding-top: 14px; }
  .sc-engagements { grid-template-columns: 1fr; }
  .sc-engagements-section { padding: 56px 0; }
  .sc-engagements-section__h2 { font-size: 28px; }
}

/* ---- Focus visible (accessibilité) --------------------------------------- */
.sc-btn:focus-visible,
.sc-modal__close:focus-visible,
.sc-menu-btn:focus-visible,
.sc-field input:focus-visible,
.sc-field select:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.sc-nav a:focus-visible,
.sc-mobnav a:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ---- Animations ---------------------------------------------------------- */
@keyframes sc-fade-in  { from { opacity: 0; } to { opacity: 1; } }
@keyframes sc-slide-up { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* ---- Responsive ---------------------------------------------------------- */
@media (max-width: 960px) {
  .sc-nav { display: none; }
  .sc-menu-btn { display: block; justify-self: end; }
  .sc-header__cta { display: none; }
  .sc-header__in { grid-template-columns: 1fr auto; }
  .sc-footer__grid { grid-template-columns: 1fr 1fr; }

  /* Mobile nav : toujours display:flex sur mobile, animée via height + opacity */
  .sc-mobnav {
    display: flex;
    max-height: 0; overflow: hidden; opacity: 0; pointer-events: none;
    transition: max-height .28s cubic-bezier(.4,0,.2,1), opacity .22s;
  }
  .sc-mobnav.open {
    max-height: 400px; opacity: 1; pointer-events: auto;
  }
}

@media (max-width: 600px) {
  .sc-container { padding: 0 20px; }
  .sc-section { padding: 64px 0; }
  .sc-footer__grid { grid-template-columns: 1fr; }
  .sc-footer__bottom { flex-direction: column; text-align: center; }
}

/* =============================================================================
   PAGE « POUR QUI » — sections enrichies
   ========================================================================== */

/* ---- 1. Signaux de douleur — « Vous reconnaissez-vous ? » ----------------- */
.sc-pain-section {
  padding: 96px 0;
  background: var(--surface-sunken);
}
.sc-pain-section__head { text-align: center; margin-bottom: 56px; }
.sc-pain-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-pain-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 540px; margin: 0 auto; line-height: 1.65;
}

.sc-pain-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.sc-pain-card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px 24px 22px;
  display: flex; flex-direction: column; gap: 14px;
  transition: box-shadow .2s, transform .2s, border-color .2s;
}
.sc-pain-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--primary) 35%, var(--border));
  box-shadow: 0 14px 40px rgba(0,0,0,.06);
}
.sc-pain-card__check {
  position: absolute; top: 18px; right: 18px;
  width: 22px; height: 22px; border-radius: 7px;
  background: var(--primary-tint); color: var(--primary);
  display: grid; place-items: center;
}
.sc-pain-card__icon {
  width: 40px; height: 40px; border-radius: 11px;
  background: var(--surface-sunken); color: var(--fg-muted);
  display: grid; place-items: center;
}
.sc-pain-card p {
  font: var(--text-body); color: var(--fg); line-height: 1.55; margin: 0;
}

/* ---- 3. « Vos journées, version Intexo » — timeline d'une journée --------- */
.sc-daily-section {
  padding: 96px 0;
  background: var(--surface-sunken);
}
.sc-daily-section__head { text-align: center; margin-bottom: 56px; }
.sc-daily-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-daily-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 560px; margin: 0 auto; line-height: 1.65;
}

.sc-daily-timeline {
  max-width: 720px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 4px;
}
.sc-daily-item {
  display: grid; grid-template-columns: 48px 1fr; gap: 20px;
}
.sc-daily-item__rail {
  position: relative;
  display: flex; justify-content: center;
}
.sc-daily-item__rail::before {
  content: ""; position: absolute; top: 0; bottom: 0; width: 2px;
  background: var(--border);
}
.sc-daily-item:first-child .sc-daily-item__rail::before { top: 24px; }
.sc-daily-item:last-child  .sc-daily-item__rail::before { bottom: calc(100% - 24px); }
.sc-daily-item__dot {
  position: relative; z-index: 1;
  width: 44px; height: 44px; border-radius: 13px; flex-shrink: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--primary);
  display: grid; place-items: center;
}
.sc-daily-item__body {
  padding: 0 0 32px; min-width: 0;
}
.sc-daily-item__time {
  display: inline-block;
  font: var(--text-caption); font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-tint);
  padding: 3px 10px; border-radius: 999px;
  margin-bottom: 10px;
}
.sc-daily-item__body h3 {
  font: 700 19px/1.25 var(--font-display);
  letter-spacing: -0.01em; color: var(--fg); margin: 0 0 6px;
}
.sc-daily-item__body p {
  font: var(--text-body); color: var(--fg-muted); line-height: 1.6; margin: 0;
}

/* ---- 4. « Comment ça se passe » — workflow léger -------------------------- */
.sc-flow-section {
  padding: 96px 0;
  background: var(--bg);
}
.sc-flow-section__head { text-align: center; margin-bottom: 56px; }
.sc-flow-section__h2 {
  font: 700 40px/1.1 var(--font-display);
  letter-spacing: -0.025em; color: var(--fg); margin: 0 0 14px;
}
.sc-flow-section__sub {
  font: var(--text-body-lg); color: var(--fg-muted);
  max-width: 560px; margin: 0 auto; line-height: 1.65;
}

.sc-flow-strip {
  display: flex; align-items: stretch; justify-content: center;
  gap: 8px; max-width: 920px; margin: 0 auto;
}
.sc-flow-step {
  flex: 1; text-align: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 30px 24px;
}
.sc-flow-step__icon {
  width: 52px; height: 52px; border-radius: 14px; margin: 0 auto 16px;
  background: var(--primary-tint); color: var(--primary);
  display: grid; place-items: center;
}
.sc-flow-step h3 {
  font: 700 18px/1.25 var(--font-display);
  letter-spacing: -0.01em; color: var(--fg); margin: 0 0 8px;
}
.sc-flow-step p {
  font: var(--text-sm); color: var(--fg-muted); line-height: 1.55; margin: 0;
}
.sc-flow-arrow {
  display: flex; align-items: center; color: var(--fg-subtle);
  flex-shrink: 0;
}
.sc-flow-link {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin: 36px auto 0; width: fit-content;
  font: var(--text-sm); font-weight: 600; color: var(--primary);
  text-decoration: none; transition: gap .2s, color .2s;
}
.sc-flow-link:hover { gap: 12px; color: var(--primary-strong, var(--primary)); }

/* ---- Carte sur-mesure — même style que les cartes métier ------------------ */
.sc-other-card {
  display: flex; align-items: center; gap: 28px;
  margin-top: 20px;
  padding: 30px 32px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--primary);
  border-radius: var(--radius-lg);
  transition: box-shadow .2s, transform .2s;
}
.sc-other-card:hover {
  box-shadow: 0 16px 48px color-mix(in oklab, var(--primary) 16%, transparent);
  transform: translateY(-2px);
}
.sc-other-card__icon {
  width: 48px; height: 48px; border-radius: 13px; flex-shrink: 0;
  background: color-mix(in oklab, var(--primary) 14%, transparent);
  color: var(--primary);
  display: grid; place-items: center;
}
.sc-other-card__text { flex: 1; min-width: 0; }
.sc-other-card__text h3 {
  font: 700 22px/1.2 var(--font-display);
  letter-spacing: -0.015em; color: var(--fg); margin: 0 0 8px;
}
.sc-other-card__text p {
  font: var(--text-body); color: var(--fg-muted); line-height: 1.6; margin: 0;
  max-width: 640px;
}
.sc-other-card__cta { flex-shrink: 0; white-space: nowrap; }

/* ---- « Pour qui » responsive --------------------------------------------- */
@media (max-width: 860px) {
  .sc-pain-grid  { grid-template-columns: repeat(2, 1fr); }
  .sc-flow-strip { flex-direction: column; max-width: 460px; }
  .sc-flow-arrow { transform: rotate(90deg); justify-content: center; padding: 2px 0; }
  .sc-pain-section, .sc-daily-section, .sc-flow-section { padding: 72px 0; }
  .sc-other-card { flex-direction: column; align-items: flex-start; gap: 20px; padding: 30px 28px; }
}
@media (max-width: 600px) {
  .sc-pain-grid { grid-template-columns: 1fr; max-width: 440px; margin: 0 auto; }
  .sc-pain-section__h2,
  .sc-daily-section__h2, .sc-flow-section__h2 { font-size: 30px; }
  .sc-pain-section, .sc-daily-section, .sc-flow-section { padding: 56px 0; }
  .sc-other-card__cta { width: 100%; }
}

/* =============================================================================
   THÈMES — sélectionnables via le panneau Tweaks (data-theme sur <body>)
   -----------------------------------------------------------------------------
   « defaut » : aucun override → look d'origine (body clair + hero sombre).
   « sombre » : tout le site sombre, hero classique (hero_bg.jpg).
   « light »  : tout le site clair + hero clair (hero_bg_white.jpg), texte foncé.
   « colore » : ambiance orange + hero orange (hero_bg_orange.jpg).
   « clair-orange » : base claire (hero blanc) + nav orange & accents orange.
   Sombre & light reçoivent en plus une bande orange (section Engagements).
   Le site est piloté par tokens sémantiques : surcharger les tokens reteinte
   automatiquement toutes les sections. Bloc placé en fin de fichier pour gagner
   la cascade sur les surcharges au niveau élément (hero, labels…).
   ========================================================================== */

/* Îlots toujours clairs : l'aperçu email et les labels flottants gardent des
   neutres figés (texte lisible quel que soit le thème) ; l'accent reste piloté
   par le thème via --primary / --primary-tint. */
.sc-inbox {
  --fg: #1c1d20; --fg-muted: #4a4d52; --fg-subtle: #8a8f98;
  --surface: #ffffff; --surface-sunken: #f4f0ea; --border: #e9e5df;
}
.sc-floating-label { color: #1c1d20; }

/* ---- Thème SOMBRE — tout le site en near-black ---------------------------- */
body.sc[data-theme="sombre"] {
  --bg: #0f1012;
  --surface: #16181c;
  --surface-sunken: #1c1d20;
  --surface-rail: #16181c;
  --fg: #e7e8ea;
  --fg-muted: #9aa0a6;
  --fg-subtle: #6b7177;
  --border: #26282d;
  --border-strong: #34373d;
  --primary-tint: rgba(217,119,6,.16);
  --accent-tint: rgba(217,119,6,.16);
  --amber-100: rgba(217,119,6,.30);
}
/* Hero inchangé (image classique, texte blanc) — déjà sombre. */

/* ---- Thème LIGHT — tout le site clair + hero clair ------------------------ */
body.sc[data-theme="light"] {
  --bg: #ffffff;
  --surface: #ffffff;
  --surface-sunken: #f6f1ea;
  --border: #ece6de;
}
/* Hero clair partagé par « light » et « clair-orange » (même image blanche) */
body[data-theme="light"] .sc-hero,
body[data-theme="clair-orange"] .sc-hero {
  background: linear-gradient(150deg, #fbfbfc 0%, #ffffff 60%, #f6f7f9 100%);
  color: var(--fg);
}
body[data-theme="light"] .sc-hero::after,
body[data-theme="clair-orange"] .sc-hero::after {
  background:
    linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.72) 32%, rgba(255,255,255,.4) 62%, rgba(255,255,255,.56) 100%),
    linear-gradient(0deg, rgba(255,255,255,.9) 0%, rgba(255,255,255,0) 24%, rgba(255,255,255,0) 76%, rgba(255,255,255,.7) 100%),
    url("assets/hero_bg_white.jpg") center / cover no-repeat;
}
body[data-theme="light"] .sc-hero::before,
body[data-theme="clair-orange"] .sc-hero::before {
  background-image: radial-gradient(rgba(0,0,0,.05) 1px, transparent 1px);
}
body[data-theme="light"] .sc-hero__h1,
body[data-theme="clair-orange"] .sc-hero__h1 { color: var(--fg); }
body[data-theme="light"] .sc-hero__sub,
body[data-theme="clair-orange"] .sc-hero__sub { color: var(--fg-muted); }
body[data-theme="light"] .sc-hero__hint,
body[data-theme="light"] .sc-hero__hint .lic,
body[data-theme="clair-orange"] .sc-hero__hint,
body[data-theme="clair-orange"] .sc-hero__hint .lic { color: var(--fg-subtle); }
body[data-theme="light"] .sc-hero__trust-badge,
body[data-theme="clair-orange"] .sc-hero__trust-badge {
  color: var(--primary); background: var(--primary-tint); border-color: var(--amber-100);
}
body[data-theme="light"] .sc-hero .sc-btn--outline-light,
body[data-theme="clair-orange"] .sc-hero .sc-btn--outline-light {
  color: var(--fg); border-color: rgba(0,0,0,.2);
}
body[data-theme="light"] .sc-hero .sc-btn--outline-light:hover,
body[data-theme="clair-orange"] .sc-hero .sc-btn--outline-light:hover {
  background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.4); color: var(--fg);
}
body[data-theme="light"] .sc-trustbar--hero,
body[data-theme="clair-orange"] .sc-trustbar--hero { border-top-color: rgba(0,0,0,.1); }
body[data-theme="light"] .sc-trustbar--hero .sc-trustbar__label,
body[data-theme="clair-orange"] .sc-trustbar--hero .sc-trustbar__label { color: var(--fg-subtle); }
body[data-theme="light"] .sc-trustbar--hero .sc-trustbar__logo,
body[data-theme="clair-orange"] .sc-trustbar--hero .sc-trustbar__logo {
  color: var(--fg-muted); background: rgba(0,0,0,.025); border-color: var(--border);
}
body[data-theme="light"] .sc-trustbar--hero .sc-trustbar__logo:hover,
body[data-theme="clair-orange"] .sc-trustbar--hero .sc-trustbar__logo:hover {
  color: var(--primary); background: var(--primary-tint); border-color: var(--amber-100);
}

/* ---- Thème COLORÉ — ambiance orange + hero orange ------------------------- */
body.sc[data-theme="colore"] {
  --bg: #fff8f3;
  --surface: #ffffff;
  --surface-sunken: #fff1e8;
  --border: #f7e3d4;
  --border-strong: #f0cbb0;
  --primary: var(--orange-600);
  --primary-hover: #c2410c;
  --primary-active: #9a3412;
  --primary-tint: #ffedd5;
  --accent: var(--orange-600);
  --accent-hover: #c2410c;
  --accent-active: #9a3412;
  --accent-tint: #ffedd5;
  --amber-100: #ffe0c7;
}
body[data-theme="colore"] .sc-hero {
  background: linear-gradient(150deg, #7c2d12 0%, #9a3412 58%, #6f2710 100%);
}
body[data-theme="colore"] .sc-hero::after {
  background:
    linear-gradient(90deg, rgba(108,38,15,.82) 0%, rgba(108,38,15,.5) 34%, rgba(108,38,15,.18) 64%, rgba(108,38,15,.42) 100%),
    linear-gradient(0deg, rgba(80,26,10,.72) 0%, rgba(80,26,10,0) 24%, rgba(80,26,10,0) 76%, rgba(80,26,10,.5) 100%),
    url("assets/hero_bg_orange.jpg") center / cover no-repeat;
}
body[data-theme="colore"] .sc-hero__trust-badge {
  color: #fff; background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.32);
}
body[data-theme="colore"] .sc-hero .sc-btn--accent {
  background: #fff; color: #9a3412; border-color: #fff;
}
body[data-theme="colore"] .sc-hero .sc-btn--accent:hover {
  background: #fff3ea; border-color: #fff3ea; color: #9a3412;
}

/* Voile vertical par thème en mobile (cf. règle .sc-hero::after @960px) */
@media (max-width: 960px) {
  body[data-theme="light"] .sc-hero::after,
  body[data-theme="clair-orange"] .sc-hero::after {
    background:
      linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.66) 45%, rgba(255,255,255,.82) 100%),
      url("assets/hero_bg_white.jpg") center / cover no-repeat;
  }
  body[data-theme="colore"] .sc-hero::after {
    background:
      linear-gradient(180deg, rgba(108,38,15,.86) 0%, rgba(108,38,15,.55) 45%, rgba(80,26,10,.6) 100%),
      url("assets/hero_bg_orange.jpg") center / cover no-repeat;
  }
}

/* ---- Bandes oranges — sombre & light (+ clair-orange) --------------------- */
/* La section « Engagements » devient une bande orange pour rythmer ces thèmes
   monochromes. Orange profond (brûlé) en sombre, orange vif en clair. */
body[data-theme="sombre"] .sc-engagements-section {
  background: linear-gradient(150deg, #9a3412 0%, #c2410c 52%, #7c2d12 100%);
  border-top-color: rgba(0,0,0,.28);
}
/* L'overline « Nos engagements » est orange par défaut → invisible sur la bande
   orange : on le passe en blanc (avec ses icônes). */
body[data-theme="sombre"] .sc-engagements-section .sc-overline,
body[data-theme="sombre"] .sc-engagements-section .sc-overline .lic { color: #fff; }
body[data-theme="sombre"] .sc-engagements-section__sub { color: rgba(255,255,255,.82); }
body[data-theme="sombre"] .sc-engagement-card {
  background: rgba(0,0,0,.20); border-color: rgba(255,255,255,.12);
}
body[data-theme="sombre"] .sc-engagement-card:hover {
  border-color: rgba(255,255,255,.26); box-shadow: 0 16px 44px rgba(0,0,0,.4);
}
body[data-theme="sombre"] .sc-engagement-card__icon {
  background: rgba(255,255,255,.18); color: #fff;
}
body[data-theme="sombre"] .sc-engagement-card__body p { color: rgba(255,255,255,.80); }

body[data-theme="light"] .sc-engagements-section,
body[data-theme="clair-orange"] .sc-engagements-section {
  background: linear-gradient(150deg, #fb923c 0%, #f97316 50%, #ea580c 100%);
  border-top-color: rgba(0,0,0,.06);
}
body[data-theme="light"] .sc-engagements-section .sc-overline,
body[data-theme="light"] .sc-engagements-section .sc-overline .lic,
body[data-theme="clair-orange"] .sc-engagements-section .sc-overline,
body[data-theme="clair-orange"] .sc-engagements-section .sc-overline .lic { color: #fff; }
body[data-theme="light"] .sc-engagements-section__sub,
body[data-theme="clair-orange"] .sc-engagements-section__sub { color: rgba(255,255,255,.9); }
body[data-theme="light"] .sc-engagement-card,
body[data-theme="clair-orange"] .sc-engagement-card {
  background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.30);
}
body[data-theme="light"] .sc-engagement-card:hover,
body[data-theme="clair-orange"] .sc-engagement-card:hover {
  border-color: rgba(255,255,255,.55); box-shadow: 0 16px 44px rgba(124,45,18,.28);
}
body[data-theme="light"] .sc-engagement-card__icon,
body[data-theme="clair-orange"] .sc-engagement-card__icon {
  background: rgba(255,255,255,.25); color: #fff;
}
body[data-theme="light"] .sc-engagement-card__body p,
body[data-theme="clair-orange"] .sc-engagement-card__body p { color: rgba(255,255,255,.88); }

/* ---- Thème CLAIR-ORANGE — base claire (comme light) + nav & accents orange */
body.sc[data-theme="clair-orange"] {
  --bg: #ffffff;
  --surface: #ffffff;
  --surface-sunken: #fff6ef;
  --border: #f1e6dc;
  --border-strong: #e8d3c2;
  --primary: var(--orange-600);
  --primary-hover: #c2410c;
  --primary-active: #9a3412;
  --primary-tint: #ffedd5;
  --accent: var(--orange-600);
  --accent-hover: #c2410c;
  --accent-active: #9a3412;
  --accent-tint: #ffedd5;
  --amber-100: #ffe0c7;
}
body[data-theme="clair-orange"] .sc-header,
body[data-theme="clair-orange"] .sc-header.scrolled {
  background: linear-gradient(90deg, #ea580c 0%, #f97316 100%);
  border-bottom-color: rgba(0,0,0,.06);
}
body[data-theme="clair-orange"] .sc-header.scrolled { box-shadow: 0 2px 16px rgba(234,88,12,.26); }
body[data-theme="clair-orange"] .sc-brand,
body[data-theme="clair-orange"] .sc-wordmark,
body[data-theme="clair-orange"] .sc-wordmark em { color: #fff; }
body[data-theme="clair-orange"] .sc-nav a { color: rgba(255,255,255,.82); }
body[data-theme="clair-orange"] .sc-nav a:hover,
body[data-theme="clair-orange"] .sc-nav a.active { color: #fff; }
body[data-theme="clair-orange"] .sc-nav a::after { background: #fff; }
body[data-theme="clair-orange"] .sc-menu-btn { color: #fff; }
body[data-theme="clair-orange"] .sc-menu-btn:hover { background: rgba(255,255,255,.16); }
body[data-theme="clair-orange"] .sc-header .sc-btn--accent {
  background: #fff; color: #c2410c; border-color: #fff;
}
body[data-theme="clair-orange"] .sc-header .sc-btn--accent:hover {
  background: #fff3ea; color: #9a3412; border-color: #fff3ea;
}
