/*
 * SaaS sections — vitrine MinderServ (P4).
 * Briques réutilisables : hero, features, pricing, cta, faq, réassurance.
 * 100 % token-driven (cf. style.css :root). DA Indigo / Slate / Inter.
 */

/* ============================ Layout de base ============================ */
.sfc-section {
    padding-block: var(--space-section);
}
.sfc-section--alt { background: var(--color-secondary); }
.sfc-section--ink { background: var(--color-primary-950, #1e1b4b); color: var(--color-white); }
.sfc-container {
    width: 100%;
    max-width: var(--container-base);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}
.sfc-section-head {
    max-width: var(--container-narrow);
    margin-inline: auto;
    margin-bottom: var(--space-7);
    text-align: center;
}
.sfc-eyebrow {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: 600;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: var(--space-2);
}
.sfc-section-title {
    font-family: var(--font-heading);
    font-weight: 800;
    font-size: var(--text-2xl);
    line-height: var(--leading-tight);
    color: var(--color-ink);
    margin: 0 0 var(--space-3);
}
.sfc-section-sub {
    font-size: var(--text-lg);
    line-height: var(--leading-normal);
    color: var(--color-ink-soft);
    margin: 0;
}

/* ============================ Hero ============================ */
.sfc-saas-hero {
    padding-block: clamp(3rem, 8vw, 7rem);
    background:
        radial-gradient(60% 80% at 80% -10%, var(--color-primary-soft) 0%, transparent 60%),
        var(--color-surface-0);
}
.sfc-saas-hero__inner {
    display: grid;
    gap: var(--space-7);
    align-items: center;
}
@media (min-width: 900px) {
    .sfc-saas-hero__inner { grid-template-columns: 1.1fr 0.9fr; }
}
.sfc-saas-hero__title {
    font-family: var(--font-display);
    font-weight: 800;
    font-size: var(--text-hero);
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--color-ink);
    margin: var(--space-3) 0;
}
.sfc-saas-hero__title em { color: var(--color-primary); font-style: normal; }
.sfc-saas-hero__sub {
    font-size: var(--text-lg);
    line-height: var(--leading-normal);
    color: var(--color-ink-soft);
    max-width: 36ch;
    margin: 0 0 var(--space-5);
}
.sfc-saas-hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.sfc-saas-hero__note {
    margin-top: var(--space-4);
    font-size: var(--text-sm);
    color: var(--color-ink-soft);
    display: flex; align-items: center; gap: var(--space-2);
}
.sfc-saas-hero__note svg { width: 18px; height: 18px; flex: none; color: var(--color-success); }
.sfc-saas-hero__visual {
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-rule);
    background: var(--color-surface-1);
    box-shadow: var(--shadow-lg);
    overflow: hidden;
    aspect-ratio: 4 / 3;
    display: grid; place-items: center;
    color: var(--color-ink-soft);
}
.sfc-saas-hero__visual img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ============================ Features ============================ */
.sfc-features__grid {
    display: grid;
    gap: var(--space-5);
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.sfc-feature-card {
    background: var(--color-surface-1);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
    transition: transform var(--duration-base) var(--ease-out), box-shadow var(--duration-base) var(--ease-out);
}
.sfc-feature-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.sfc-feature-card__icon {
    display: inline-grid; place-items: center;
    width: 48px; height: 48px;
    border-radius: var(--radius-md);
    background: var(--color-primary-soft);
    color: var(--color-primary-deep);
    margin-bottom: var(--space-4);
}
.sfc-feature-card__icon svg { width: 26px; height: 26px; }
.sfc-feature-card__title {
    font-size: var(--text-lg); font-weight: 700; color: var(--color-ink);
    margin: 0 0 var(--space-2);
}
.sfc-feature-card__text { font-size: var(--text-base); line-height: var(--leading-normal); color: var(--color-ink-soft); margin: 0; }

/* ============================ Réassurance ============================ */
.sfc-reassurance__grid {
    display: grid; gap: var(--space-5);
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}
.sfc-reassurance__item { text-align: center; padding: var(--space-4); }
.sfc-reassurance__icon {
    display: inline-grid; place-items: center;
    width: 44px; height: 44px; border-radius: var(--radius-full);
    background: var(--color-primary-soft); color: var(--color-primary-deep);
    margin-bottom: var(--space-3);
}
.sfc-reassurance__icon svg { width: 24px; height: 24px; }
.sfc-reassurance__label { font-weight: 600; color: var(--color-ink); display: block; margin-bottom: var(--space-1); }
.sfc-reassurance__text { font-size: var(--text-sm); color: var(--color-ink-soft); }

/* ============================ Pack mobilité ============================ */
.sfc-pack-card { display: flex; flex-direction: column; }
.sfc-pack-card__specs {
    list-style: none; margin: var(--space-4) 0 0; padding: var(--space-4) 0 0;
    border-top: 1px solid var(--color-rule);
    display: grid; gap: var(--space-2);
}
.sfc-pack-card__specs li {
    display: flex; align-items: flex-start; gap: var(--space-2);
    font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--color-ink-soft);
}
.sfc-pack-card__specs svg {
    flex: 0 0 auto; width: 18px; height: 18px; margin-top: 2px;
    color: var(--color-primary);
}

.sfc-pack-steps {
    list-style: none; margin: 0; padding: 0;
    display: grid; gap: var(--space-5);
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    counter-reset: sfc-pack-step;
}
.sfc-pack-step {
    display: flex; gap: var(--space-4); align-items: flex-start;
    background: var(--color-surface-1);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
    box-shadow: var(--shadow-sm);
}
.sfc-pack-step__num {
    flex: 0 0 auto;
    display: inline-grid; place-items: center;
    width: 40px; height: 40px; border-radius: var(--radius-full);
    background: var(--color-primary); color: var(--color-white);
    font-weight: 800; font-size: var(--text-lg);
}
.sfc-pack-step__title { font-size: var(--text-base); font-weight: 700; color: var(--color-ink); margin: 0 0 var(--space-1); }
.sfc-pack-step__text { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--color-ink-soft); margin: 0; }

/* ============================ Pricing ============================ */
.sfc-pricing__grid {
    display: grid; gap: var(--space-5);
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    align-items: stretch;
}
.sfc-price-card {
    display: flex; flex-direction: column;
    background: var(--color-surface-1);
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    box-shadow: var(--shadow-sm);
}
.sfc-price-card--featured {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-lg);
    position: relative;
}
.sfc-price-card__badge {
    position: absolute; top: calc(-1 * var(--space-3)); left: 50%; transform: translateX(-50%);
    background: var(--color-primary); color: var(--color-white);
    font-size: var(--text-xs); font-weight: 600; letter-spacing: var(--tracking-wide);
    text-transform: uppercase; padding: var(--space-1) var(--space-3); border-radius: var(--radius-pill);
}
.sfc-price-card__name { font-size: var(--text-lg); font-weight: 700; color: var(--color-ink); margin: 0 0 var(--space-2); }
.sfc-price-card__price { font-family: var(--font-display); font-weight: 800; font-size: var(--text-3xl); color: var(--color-ink); line-height: 1; }
.sfc-price-card__period { font-size: var(--text-sm); color: var(--color-ink-soft); }
.sfc-price-card__desc { font-size: var(--text-sm); color: var(--color-ink-soft); margin: var(--space-3) 0 var(--space-4); }
.sfc-price-card__list { list-style: none; margin: 0 0 var(--space-5); padding: 0; display: grid; gap: var(--space-2); }
.sfc-price-card__list li { display: flex; gap: var(--space-2); font-size: var(--text-base); color: var(--color-ink); }
.sfc-price-card__list svg { width: 20px; height: 20px; color: var(--color-success); flex: none; }
.sfc-price-card__cta { margin-top: auto; }

/* ---- Options & achats ponctuels (réutilise la carte de prix) ---- */
.sfc-options .sfc-price-card__cta { display: flex; flex-direction: column; align-items: stretch; gap: var(--space-2); }
.sfc-option-card__icon {
    display: inline-grid; place-items: center;
    width: 44px; height: 44px; border-radius: var(--radius-md);
    background: var(--color-primary-soft); color: var(--color-primary-deep);
    margin-bottom: var(--space-3);
}
.sfc-option-card__icon svg { width: 24px; height: 24px; }
.sfc-option-card__link {
    text-align: center; font-size: var(--text-sm); font-weight: 600;
    color: var(--color-primary); text-decoration: none;
}
.sfc-option-card__link:hover { color: var(--color-primary-deep); text-decoration: underline; }

/* ============================ CTA band ============================ */
.sfc-cta-band {
    background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-deep) 100%);
    color: var(--color-white);
    border-radius: var(--radius-xl);
    padding: clamp(2rem, 5vw, 4rem);
    text-align: center;
}
.sfc-cta-band__title { font-family: var(--font-display); font-weight: 800; font-size: var(--text-2xl); margin: 0 0 var(--space-3); color: var(--color-white); }
.sfc-cta-band__sub { font-size: var(--text-lg); opacity: .92; margin: 0 auto var(--space-5); max-width: 48ch; }
.sfc-cta-band__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }
.sfc-cta-band .sfc-btn--primary { background: var(--color-white); color: var(--color-primary-deep); }
.sfc-cta-band .sfc-btn--ghost { color: var(--color-white); border-color: rgba(255,255,255,.5); }

/* ============================ FAQ ============================ */
.sfc-faq { max-width: var(--container-narrow); margin-inline: auto; }
.sfc-faq__item {
    border: 1px solid var(--color-rule);
    border-radius: var(--radius-md);
    background: var(--color-surface-1);
    margin-bottom: var(--space-3);
    overflow: hidden;
}
.sfc-faq__item[open] { border-color: var(--color-primary-soft); box-shadow: var(--shadow-sm); }
.sfc-faq__q {
    cursor: pointer; list-style: none;
    padding: var(--space-4) var(--space-5);
    font-weight: 600; color: var(--color-ink);
    display: flex; justify-content: space-between; align-items: center; gap: var(--space-4);
}
.sfc-faq__q::-webkit-details-marker { display: none; }
.sfc-faq__q::after { content: "+"; font-size: var(--text-xl); color: var(--color-primary); line-height: 1; }
.sfc-faq__item[open] .sfc-faq__q::after { content: "–"; }
.sfc-faq__a { padding: 0 var(--space-5) var(--space-4); color: var(--color-ink-soft); line-height: var(--leading-normal); }
.sfc-faq__link { display: inline-block; margin-top: var(--space-2); font-weight: 600; color: var(--color-primary); }
.sfc-faq__link:hover { color: var(--color-primary-deep); }

/* ============================ Boutons (compléments) ============================ */
.sfc-header__cta { white-space: nowrap; }
.sfc-header__topline-side--right { display: flex; align-items: center; gap: var(--space-2); }
.sfc-mobile-drawer__cta { display: grid; gap: var(--space-2); padding: var(--space-5); }
.sfc-footer__contact a { color: var(--color-primary); }

/* ============================ Prose (pages de contenu) ============================ */
.sfc-prose { max-width: var(--container-narrow); margin-inline: auto; color: var(--color-ink); }
.sfc-prose__head { margin-bottom: var(--space-6); }
.sfc-prose h2 { font-size: var(--text-xl); font-weight: 700; color: var(--color-ink); margin: var(--space-6) 0 var(--space-3); }
.sfc-prose h3 { font-size: var(--text-lg); font-weight: 600; color: var(--color-ink); margin: var(--space-5) 0 var(--space-2); }
.sfc-prose p, .sfc-prose li { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--color-ink-soft); }
.sfc-prose p { margin: 0 0 var(--space-4); }
.sfc-prose ul, .sfc-prose ol { margin: 0 0 var(--space-4) var(--space-5); }
.sfc-prose a { color: var(--color-primary); }
.sfc-prose a:hover { color: var(--color-primary-deep); }

/* ============================ Contact ============================ */
.sfc-contact__grid { display: grid; gap: var(--space-6); }
@media (min-width: 820px) { .sfc-contact__grid { grid-template-columns: 0.8fr 1.2fr; } }
.sfc-contact__form .wpcf7-form-control:not(.wpcf7-submit) {
    width: 100%; padding: var(--space-3) var(--space-4);
    border: 1px solid var(--color-rule); border-radius: var(--radius-sm);
    background: var(--color-surface-1); color: var(--color-ink); font: inherit;
    margin-bottom: var(--space-3);
}
.sfc-contact__form .wpcf7-form-control:focus { outline: none; box-shadow: var(--shadow-focus); border-color: var(--color-primary); }
.sfc-contact__form .wpcf7-submit {
    background: var(--color-primary); color: var(--color-white);
    border: 0; border-radius: var(--radius-sm); padding: var(--space-3) var(--space-6);
    font-weight: 600; cursor: pointer;
}
.sfc-contact__form .wpcf7-submit:hover { background: var(--color-primary-deep); }
.sfc-contact__form label { display: block; margin-bottom: var(--space-3); font-size: var(--text-sm); font-weight: 500; color: var(--color-ink); }
.sfc-contact__form .sfc-form-row { display: grid; gap: var(--space-4); }
@media (min-width: 560px) { .sfc-contact__form .sfc-form-row { grid-template-columns: 1fr 1fr; } }
.sfc-contact__form select.wpcf7-form-control { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--color-ink-soft) 50%), linear-gradient(135deg, var(--color-ink-soft) 50%, transparent 50%); background-position: calc(100% - 18px) center, calc(100% - 13px) center; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: var(--space-7); }
.sfc-form-consent { font-weight: 400 !important; color: var(--color-ink-soft); }
.sfc-form-consent .wpcf7-list-item { margin: 0; }

/* ============================ Blog ============================ */
.sfc-blog__grid { display: grid; gap: var(--space-5); grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); }
.sfc-blog-card {
    display: flex; flex-direction: column; background: var(--color-surface-1);
    border: 1px solid var(--color-rule); border-radius: var(--radius-lg); overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: box-shadow var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out);
}
.sfc-blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.sfc-blog-card__media img { width: 100%; height: 180px; object-fit: cover; display: block; }
.sfc-blog-card__body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-2); flex: 1; }
.sfc-blog-card__date { font-size: var(--text-sm); color: var(--color-ink-soft); }
.sfc-blog-card__title { font-size: var(--text-lg); font-weight: 700; margin: 0; line-height: var(--leading-snug); }
.sfc-blog-card__title a { color: var(--color-ink); }
.sfc-blog-card__title a:hover { color: var(--color-primary); }
.sfc-blog-card__excerpt { color: var(--color-ink-soft); line-height: var(--leading-normal); margin: 0; }
.sfc-blog-card__more { margin-top: auto; font-weight: 600; color: var(--color-primary); }
.sfc-blog__pagination { margin-top: var(--space-7); text-align: center; }
.sfc-blog__pagination a, .sfc-blog__pagination .current {
    display: inline-block; padding: var(--space-2) var(--space-3); margin: 0 2px;
    border: 1px solid var(--color-rule); border-radius: var(--radius-sm); color: var(--color-ink);
}
.sfc-blog__pagination .current { background: var(--color-primary); color: var(--color-white); border-color: var(--color-primary); }
.sfc-blog__back { display: inline-block; margin-bottom: var(--space-4); color: var(--color-primary); font-weight: 600; }
.sfc-prose__media img { width: 100%; height: auto; border-radius: var(--radius-md); margin-bottom: var(--space-5); }

@media (prefers-reduced-motion: reduce) {
    .sfc-feature-card { transition: none; }
    .sfc-feature-card:hover { transform: none; }
    .sfc-blog-card { transition: none; }
    .sfc-blog-card:hover { transform: none; }
}
