/* =========================================================
   QUALICONNECT — Page de conversion (sous la visite, archi B)
   Réunit les 5 chantiers. Réutilise les tokens de styles.css.
   ========================================================= */

/* Conteneur des sections de conversion (pages "Qui sommes-nous" / "Références"). */
#conversion { position: relative; }
.cv-wrap { max-width: 1040px; margin: 0 auto; padding: 0 24px; }
.cv-section { padding: clamp(60px, 10vw, 128px) 0; }
.cv-section--tight { padding: clamp(40px, 6vw, 72px) 0; }
.cv-eyebrow { font-size: .76rem; letter-spacing: .24em; text-transform: uppercase; font-weight: 600; color: var(--accent); margin-bottom: 16px; }
.cv-title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.9rem, 4.5vw, 3rem); letter-spacing: -.02em; line-height: 1.08; color: var(--text); }
.cv-lead { margin-top: 18px; max-width: 64ch; color: var(--text-dim); font-size: clamp(1.02rem, 1.6vw, 1.15rem); font-weight: 300; line-height: 1.65; }

/* Typographie : titres équilibrés + paragraphes sans "orphelins" (lignes bancales) */
#conversion h2, #conversion h3, #conversion h4 { text-wrap: balance; }
#conversion p, .cv-quote__text { text-wrap: pretty; }

/* ---- Boutons ---- */
.cv-cta { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; padding: 16px 30px; border-radius: 99px; font-weight: 600; color: var(--accent-ink); background: linear-gradient(95deg, var(--accent), var(--accent-2)); box-shadow: 0 14px 42px -10px rgba(56,214,245,.55); transition: transform .3s var(--ease), box-shadow .3s var(--ease); }
.cv-cta:hover, .cv-cta:focus-visible { transform: translateY(-3px); box-shadow: 0 20px 54px -10px rgba(56,214,245,.8); outline: none; }
.cv-cta svg { transition: transform .3s var(--ease); }
.cv-cta:hover svg { transform: translateX(4px); }
.cv-cta--ghost { background: none; color: var(--text); border: 1px solid var(--glass-brd); box-shadow: none; }
.cv-cta--ghost:hover, .cv-cta--ghost:focus-visible { border-color: var(--accent); background: rgba(255,255,255,.05); box-shadow: none; }

/* ---- Hero ---- */
.cv-hero { text-align: center; padding: clamp(78px, 13vw, 158px) 0 clamp(48px, 8vw, 88px); background: radial-gradient(120% 80% at 50% -5%, rgba(56,214,245,.14), transparent 62%); }
.cv-hero__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.2rem, 6vw, 4rem); letter-spacing: -.025em; line-height: 1.05; color: var(--text); }
.cv-hero__sub { margin: 22px auto 32px; max-width: 660px; color: var(--text-dim); font-size: clamp(1.05rem, 2vw, 1.3rem); font-weight: 300; line-height: 1.55; }

/* ---- Engagements ---- */
.cv-engagements { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 42px; }
.cv-eng { position: relative; padding: 28px 28px 30px; border-radius: var(--radius); background: var(--glass-bg); border: 1px solid var(--glass-brd); box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); }
.cv-eng__ic { font-size: 1.7rem; line-height: 1; }
.cv-eng h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.18rem; margin: 14px 0 6px; color: #fff; }
.cv-eng__metric { color: var(--accent); font-weight: 600; font-size: .9rem; margin-bottom: 10px; }
.cv-eng p { color: var(--text-dim); font-size: .95rem; font-weight: 300; line-height: 1.6; }
.cv-eng sup a { color: var(--accent); text-decoration: none; font-weight: 700; }

/* ---- Équipe ---- */
.cv-block { margin-top: 22px; padding: 26px 28px; border-radius: var(--radius); border: 1px solid var(--glass-brd); background: var(--glass-bg); box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); }
.cv-block h3 { font-family: var(--font-display); font-weight: 600; font-size: 1.18rem; color: #fff; margin-bottom: 8px; }
.cv-block p { color: var(--text-dim); font-weight: 300; line-height: 1.65; }
.cv-block--paris { border-color: color-mix(in srgb, var(--accent) 42%, transparent); }
.cv-values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 26px; }
.cv-value { padding: 22px 22px 24px; border-radius: var(--radius); background: rgba(255,255,255,.03); border: 1px solid var(--glass-brd); }
.cv-value h4 { font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; color: var(--accent); margin-bottom: 6px; }
.cv-value p { color: var(--text-dim); font-size: .92rem; font-weight: 300; }

/* ---- Témoignages ---- */
.cv-testimonials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 42px; }
.cv-quote { display: flex; flex-direction: column; padding: 28px; border-radius: var(--radius); background: var(--glass-bg); border: 1px solid var(--glass-brd); box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); }
.cv-quote__text { color: var(--text); font-size: 1rem; line-height: 1.62; }
.cv-quote__text::before { content: "“"; font-family: var(--font-display); color: var(--accent); font-size: 2.4rem; line-height: 0; display: block; margin-bottom: 10px; }
.cv-quote__author { display: flex; align-items: center; gap: 13px; margin-top: 22px; }
.cv-avatar { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-display); font-weight: 600; font-size: .95rem; color: var(--accent-ink); flex: none; background: linear-gradient(135deg, var(--accent), var(--accent-2)); }
.cv-quote__name { font-weight: 600; color: #fff; font-size: .95rem; }
.cv-quote__role { color: var(--text-faint); font-size: .82rem; }

/* ---- Partenaires ---- */
.cv-partners__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.2rem, 2.4vw, 1.6rem); color: var(--text); margin-bottom: 6px; letter-spacing: -.01em; }
.cv-partners { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 16px 38px; margin-top: 30px; }
.cv-partner { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.05rem, 2vw, 1.3rem); color: var(--text-dim); opacity: .82; letter-spacing: -.01em; transition: opacity .2s, color .2s; }
.cv-partner:hover { opacity: 1; color: #fff; }

/* ---- CTA final ---- */
.cv-final { text-align: center; padding: clamp(70px, 11vw, 138px) 0; background: radial-gradient(120% 95% at 50% 100%, rgba(124,140,255,.16), transparent 60%); border-top: 1px solid rgba(255,255,255,.06); }
.cv-final__title { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.9rem, 5vw, 3.2rem); letter-spacing: -.02em; color: var(--text); }
.cv-final p { color: var(--text-dim); margin: 16px auto 30px; max-width: 560px; font-weight: 300; }
.cv-final__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---- Footer ---- */
.cv-footer { border-top: 1px solid rgba(255,255,255,.07); padding: 50px 0 44px; }
.cv-footer__in { display: flex; flex-wrap: wrap; gap: 28px 40px; justify-content: space-between; }
.cv-footer__brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: #fff; }
.cv-footer__brand img { width: 30px; height: 30px; border-radius: 8px; mix-blend-mode: screen; }
.cv-footer__brand b { color: var(--accent); }
.cv-footer__brand span { font-family: var(--font-display); font-weight: 600; }
.cv-footer__tag { color: var(--text-faint); font-size: .9rem; margin-top: 10px; max-width: 280px; }
.cv-footer__col h5 { font-size: .74rem; letter-spacing: .18em; text-transform: uppercase; color: var(--text-faint); margin-bottom: 12px; }
.cv-footer__col a { display: block; color: var(--text-dim); text-decoration: none; font-size: .94rem; padding: 4px 0; transition: color .2s; }
.cv-footer__col a:hover { color: #fff; }
.cv-footer__legal { margin-top: 34px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.06); font-size: .8rem; color: var(--text-faint); line-height: 1.6; }
.cv-footer__legal a { color: var(--text-dim); }
#sla-note { display: block; margin-top: 6px; }

/* ---- Pages légales ---- */
.legal { max-width: 800px; margin: 0 auto; padding: clamp(40px, 7vw, 84px) 24px clamp(50px, 8vw, 90px); }
.legal h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(1.8rem, 4vw, 2.6rem); letter-spacing: -.02em; }
.legal__updated { color: var(--text-faint); font-size: .85rem; margin: 8px 0 34px; }
.legal h2 { font-family: var(--font-display); font-weight: 600; font-size: 1.3rem; color: #fff; margin: 34px 0 10px; }
.legal p, .legal li { color: var(--text-dim); font-weight: 300; line-height: 1.72; }
.legal ul { margin: 8px 0 8px 22px; display: grid; gap: 4px; }
.legal a { color: var(--accent); }
.legal strong { color: var(--text); font-weight: 600; }

/* ---- Diagnostic interactif (aimant à leads) ---- */
.cv-checklist { display: grid; gap: 10px; margin-top: 38px; }
.cv-check { display: flex; align-items: flex-start; gap: 14px; padding: 15px 18px; border-radius: 14px; background: var(--glass-bg); border: 1px solid var(--glass-brd); cursor: pointer; transition: border-color .2s, background .2s; }
.cv-check:hover { border-color: color-mix(in srgb, var(--accent) 42%, transparent); }
.cv-check input { appearance: none; -webkit-appearance: none; width: 22px; height: 22px; border-radius: 6px; border: 2px solid rgba(255, 255, 255, .32); background: rgba(255, 255, 255, .05); flex: none; margin-top: 1px; cursor: pointer; transition: background .2s, border-color .2s; position: relative; }
.cv-check:hover input { border-color: color-mix(in srgb, var(--accent) 60%, transparent); }
.cv-check input:checked { background: var(--accent); border-color: var(--accent); }
.cv-check input:checked::after { content: "✓"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--accent-ink); font-size: .82rem; font-weight: 700; }
.cv-check span { color: var(--text); font-size: .98rem; line-height: 1.45; }

.cv-verdict { margin-top: 30px; padding: 26px; border-radius: var(--radius); border: 1px solid var(--glass-brd); background: var(--glass-bg); text-align: center; box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,.08); }
.cv-verdict__score { font-family: var(--font-display); font-size: 2.4rem; font-weight: 600; line-height: 1; color: var(--accent); }
.cv-verdict__label { font-family: var(--font-display); font-weight: 600; font-size: 1.2rem; color: #fff; margin: 8px 0 6px; }
.cv-verdict__desc { color: var(--text-dim); font-size: .96rem; max-width: 56ch; margin: 0 auto; }

.cv-form { margin: 28px auto 0; display: flex; flex-direction: column; gap: 14px; max-width: 460px; text-align: left; }
.cv-form input[type=email] { width: 100%; padding: 15px 18px; border-radius: 12px; border: 1px solid var(--glass-brd); background: rgba(255,255,255,.04); color: var(--text); font-family: var(--font-body); font-size: 1rem; }
.cv-form input[type=email]::placeholder { color: var(--text-faint); }
.cv-form input[type=email]:focus { outline: none; border-color: var(--accent); }
.cv-form__consent { display: flex; align-items: flex-start; gap: 10px; font-size: .84rem; color: var(--text-faint); line-height: 1.5; }
.cv-form__consent input { margin-top: 3px; flex: none; width: 16px; height: 16px; accent-color: var(--accent); }
.cv-form__consent a { color: var(--text-dim); }
.cv-form .cv-cta { justify-content: center; border: 0; cursor: pointer; font-family: var(--font-body); font-size: 1.02rem; }
.cv-form__msg { font-size: .92rem; }
.cv-form__msg--ok { padding: 16px 18px; border-radius: 12px; background: color-mix(in srgb, var(--accent) 14%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 42%, transparent); color: #fff; }
.cv-form__msg--err { color: #ff9a9a; }

/* ---- Révélation au scroll ---- */
.cv-reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.cv-reveal.is-in { opacity: 1; transform: none; }

/* ---- Responsive ---- */
@media (max-width: 860px) { .cv-testimonials { grid-template-columns: 1fr; } }
@media (max-width: 720px) {
  .cv-engagements, .cv-values { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .cv-reveal { opacity: 1; transform: none; transition: none; }
}
