/* ============================================
   Ixila — Pages d'offre (8 pages)
   ============================================ */

/* --- Page hero variants --- */
.page-hero--offre,
.page-hero--fast,
.page-hero--fast-roi,
.page-hero--comparaison,
.page-hero--support,
.page-hero--conseil,
.page-hero--formation,
.page-hero--accompagnement {
    background:
        radial-gradient(ellipse at 20% 0%, rgba(217, 79, 112, 0.10), transparent 60%),
        radial-gradient(ellipse at 80% 100%, rgba(43, 86, 114, 0.08), transparent 55%),
        var(--c-light);
}
.page-hero--fast {
    background:
        radial-gradient(ellipse at 100% 0%, rgba(217, 79, 112, 0.18), transparent 50%),
        var(--c-light);
}
.page-hero__eyebrow {
    font-family: var(--ff-mono);
    font-size: var(--fs-small);
    color: var(--c-primary);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    margin: 0 0 var(--sp-md);
}

/* --- Listes a puces dans .prose --- */
.prose ul {
    margin: 0 0 var(--sp-lg);
    padding-left: var(--sp-xl);
}
.prose ul li {
    margin-bottom: var(--sp-sm);
    line-height: var(--lh-normal);
    color: var(--c-text-soft);
}
.prose ul ul {
    margin-top: var(--sp-sm);
    margin-bottom: 0;
}

/* --- Page /offre : grille 4 axes --- */
.axes-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--sp-xl);
}
.axis-card {
    position: relative;
    background: var(--c-white);
    border-radius: var(--radius-lg);
    padding: var(--sp-2xl) var(--sp-xl) var(--sp-xl);
    border: 1px solid var(--c-border);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);
    display: flex;
    flex-direction: column;
}
.axis-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--c-primary-light);
}
.axis-card__num {
    font-family: var(--ff-mono);
    font-size: var(--fs-small);
    color: var(--c-primary);
    letter-spacing: var(--ls-wider);
    margin-bottom: var(--sp-md);
}
.axis-card__title {
    font-family: var(--ff-display);
    font-size: var(--fs-h3);
    color: var(--c-text);
    margin: 0 0 var(--sp-sm);
    font-weight: 600;
}
.axis-card__lead {
    color: var(--c-primary);
    font-style: italic;
    margin: 0 0 var(--sp-md);
    font-size: var(--fs-body);
}
.axis-card__text {
    color: var(--c-text-soft);
    line-height: var(--lh-normal);
    margin: 0 0 var(--sp-lg);
    font-size: var(--fs-body);
    flex: 1;
}
.axis-card__link {
    color: var(--c-primary);
    font-weight: var(--fw-medium);
    text-decoration: none;
    font-size: var(--fs-small);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    transition: color var(--transition-fast), gap var(--transition-fast);
    display: inline-flex;
    align-items: center;
    gap: var(--sp-xs);
}
.axis-card__link:hover {
    color: var(--c-primary-dark);
    gap: var(--sp-md);
}

/* --- Page Fast : 4 piliers (lettres FAST) --- */
.fast-pillars-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-lg);
}
.fast-pillar {
    background: var(--c-light);
    border-radius: var(--radius-lg);
    padding: var(--sp-xl);
    text-align: center;
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}
.fast-pillar:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}
.fast-pillar__letter {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border-radius: var(--radius-full);
    background: var(--c-primary);
    color: var(--c-white);
    font-family: var(--ff-display);
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: var(--sp-md);
    box-shadow: var(--shadow-glow-primary);
}
.fast-pillar__title {
    font-family: var(--ff-display);
    font-size: var(--fs-h4);
    color: var(--c-text);
    margin: 0 0 var(--sp-sm);
    font-weight: 600;
}
.fast-pillar__text {
    color: var(--c-text-soft);
    line-height: var(--lh-normal);
    margin: 0;
    font-size: var(--fs-body);
}

/* --- Citations / quote cards --- */
.quote-card {
    background: var(--c-white);
    border-left: 4px solid var(--c-primary);
    border-radius: var(--radius-md);
    padding: var(--sp-xl) var(--sp-2xl);
    margin: var(--sp-xl) 0;
    font-family: var(--ff-display);
    font-size: var(--fs-body-lg);
    line-height: var(--lh-relaxed);
    color: var(--c-text);
    font-style: italic;
    box-shadow: var(--shadow-sm);
}

/* --- FAQ accordion --- */
.faq-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
}
.faq-item details {
    background: var(--c-white);
    border: 1px solid var(--c-border);
    border-radius: var(--radius-md);
    padding: var(--sp-lg) var(--sp-xl);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.faq-item details[open] {
    border-color: var(--c-primary);
    box-shadow: var(--shadow-sm);
}
.faq-item summary {
    font-family: var(--ff-display);
    font-weight: 600;
    color: var(--c-text);
    cursor: pointer;
    list-style: none;
    position: relative;
    padding-right: var(--sp-2xl);
    font-size: var(--fs-body-lg);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
    content: '+';
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    color: var(--c-primary);
    font-size: 1.5rem;
    font-weight: 300;
    transition: transform var(--transition-fast);
}
.faq-item details[open] summary::after {
    transform: translateY(-50%) rotate(45deg);
}
.faq-item details p {
    margin: var(--sp-md) 0 0;
    color: var(--c-text-soft);
    line-height: var(--lh-normal);
}

/* --- KPI ROI cards --- */
.section--roi { background: var(--c-white); }
.roi-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-lg);
}
.roi-card {
    text-align: center;
    background: var(--c-light);
    border-radius: var(--radius-lg);
    padding: var(--sp-xl);
    border: 1px solid var(--c-border);
    transition: transform var(--transition-normal), border-color var(--transition-normal);
}
.roi-card:hover {
    transform: translateY(-3px);
    border-color: var(--c-primary-light);
}
.roi-card__label {
    margin: 0 0 var(--sp-sm);
    font-size: var(--fs-small);
    color: var(--c-text-muted);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
}
.roi-card__value {
    margin: 0 0 var(--sp-xs);
    font-family: var(--ff-display);
    font-size: clamp(1.75rem, 3vw, 2.5rem);
    font-weight: 700;
    color: var(--c-primary);
    line-height: 1.1;
}
.roi-card__sub {
    margin: 0;
    color: var(--c-text-soft);
    font-size: var(--fs-small);
}

/* --- Check-lists --- */
.check-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-md);
}
.check-list li {
    position: relative;
    padding-left: var(--sp-xl);
    color: var(--c-text);
    line-height: var(--lh-normal);
    font-size: var(--fs-body-lg);
}
.check-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    top: 2px;
    width: 24px;
    height: 24px;
    border-radius: var(--radius-full);
    background: var(--c-primary);
    color: var(--c-white);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 0.85rem;
}
.check-list--two-col {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: var(--sp-md) var(--sp-2xl);
}

/* --- Tableau de comparaison --- */
.comparison-table-wrap {
    overflow-x: auto;
    border-radius: var(--radius-lg);
    border: 1px solid var(--c-border);
    background: var(--c-white);
}
.comparison-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--fs-body);
}
.comparison-table thead th {
    background: var(--c-light);
    padding: var(--sp-lg);
    text-align: left;
    font-family: var(--ff-display);
    color: var(--c-text);
    font-weight: 600;
    border-bottom: 2px solid var(--c-border);
}
.comparison-table tbody th {
    text-align: left;
    padding: var(--sp-md) var(--sp-lg);
    font-weight: 600;
    color: var(--c-text);
    background: var(--c-light);
    width: 25%;
    border-bottom: 1px solid var(--c-border);
}
.comparison-table td {
    padding: var(--sp-md) var(--sp-lg);
    color: var(--c-text-soft);
    border-bottom: 1px solid var(--c-border);
    vertical-align: top;
}
.comparison-table tbody tr:last-child th,
.comparison-table tbody tr:last-child td {
    border-bottom: 0;
}
.comparison-table__highlight {
    background: rgba(217, 79, 112, 0.06);
    color: var(--c-text) !important;
    font-weight: var(--fw-medium);
}
.comparison-table thead th.comparison-table__highlight {
    background: rgba(217, 79, 112, 0.12);
    color: var(--c-primary);
}

/* --- Duo grid (formation classique vs Fast) --- */
.duo-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--sp-xl);
}
.duo-card {
    background: var(--c-white);
    padding: var(--sp-2xl);
    border-radius: var(--radius-lg);
    border: 1px solid var(--c-border);
}
.duo-card--highlight {
    background: linear-gradient(135deg, rgba(217, 79, 112, 0.04), rgba(217, 79, 112, 0.10));
    border-color: var(--c-primary);
    box-shadow: var(--shadow-md);
}
.duo-card__title {
    font-family: var(--ff-display);
    font-size: var(--fs-h3);
    color: var(--c-text);
    margin: 0 0 var(--sp-lg);
    font-weight: 600;
}
.duo-card--highlight .duo-card__title { color: var(--c-primary); }
.duo-card__list {
    list-style: disc;
    padding-left: var(--sp-xl);
    margin: 0 0 var(--sp-lg);
    color: var(--c-text-soft);
    line-height: var(--lh-normal);
}
.duo-card__list li { margin-bottom: var(--sp-sm); }
.duo-card__list ul { padding-left: var(--sp-lg); margin-top: var(--sp-sm); }
.duo-card__note {
    margin: 0 0 var(--sp-sm);
    padding: var(--sp-md);
    background: var(--c-light);
    border-radius: var(--radius-sm);
    font-size: var(--fs-small);
    color: var(--c-text-soft);
    line-height: var(--lh-normal);
}
.duo-card--highlight .duo-card__note {
    background: rgba(255, 255, 255, 0.6);
}

/* --- Sources tarifaires --- */
.sources-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--sp-sm);
}
.sources-list li {
    padding: var(--sp-md) var(--sp-lg);
    background: var(--c-white);
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--c-primary);
    color: var(--c-text-soft);
    font-size: var(--fs-body);
}

/* --- Page Formation : phases --- */
.phases-grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-lg);
}
.phase-card {
    background: var(--c-white);
    border-radius: var(--radius-lg);
    padding: var(--sp-xl);
    border-top: 3px solid var(--c-primary);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
}
.phase-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}
.phase-card__title {
    font-family: var(--ff-display);
    font-size: var(--fs-h4);
    color: var(--c-primary);
    margin: 0 0 var(--sp-sm);
    font-weight: 600;
}
.phase-card__text {
    color: var(--c-text-soft);
    line-height: var(--lh-normal);
    margin: 0;
    font-size: var(--fs-body);
}

/* --- Section zoom Fast --- */
.section--fast-zoom .section__title {
    text-align: center;
}

/* --- Utility --- */
.text-center { text-align: center; }

/* --- Responsive --- */
@media (max-width: 768px) {
    .duo-grid, .fast-pillars-grid, .axes-grid, .roi-grid, .phases-grid {
        grid-template-columns: 1fr;
    }
    .check-list--two-col {
        grid-template-columns: 1fr;
    }
    .quote-card {
        padding: var(--sp-lg);
        font-size: var(--fs-body);
    }
}
