/**
 * Habari LM+ — Styles du tunnel d'abonnement
 *
 * S'appuie sur les classes de base d'auth.css (.habari-auth-*).
 * Ce fichier ne définit que les surcharges et composants spécifiques à LM+.
 *
 * Composants :
 *   .habari-lmplus-wrapper     → wrapper plus large que les pages auth classiques
 *   .habari-lmplus-card        → card légèrement plus large
 *   .habari-lmplus-badge       → badge "LM+" doré
 *   .habari-lmplus-offer       → bloc présentation de l'offre
 *   .habari-lmplus-price       → affichage prix
 *   .habari-lmplus-perks       → liste des bénéfices
 *   .habari-lmplus-legals      → checkboxes consentement RGPD
 *   .habari-lmplus-order-summary → récapitulatif commande
 *   .habari-lmplus-success     → état succès après paiement
 *
 * @package habari
 */


/* =============================================
   WRAPPER — légèrement plus large que .habari-auth-wrapper
   ============================================= */

.habari-lmplus-wrapper {
    max-width: 520px;
}

.habari-lmplus-card {
    padding: 2rem;
}


/* =============================================
   BADGE LM+
   ============================================= */

.habari-lmplus-badge {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.1em;
    text-transform: capitalize;
    padding: 0.2rem 0.6rem;
    color: #ffffff;
    background: var(--habari-gold);
    margin-bottom: 0.75rem;
    line-height: 1.6;
}


/* =============================================
   OFFRE — présentation prix + bénéfices
   ============================================= */

.habari-lmplus-offer {
    margin-bottom: 0;
}

.habari-lmplus-offer__details {
    display: flex;
    align-items: flex-start;
    gap: 1.5rem;
    flex-wrap: wrap;
}


/* ── Prix ── */

.habari-lmplus-price {
    display: flex;
    align-items: baseline;
    gap: 0.2rem;
    flex-shrink: 0;
}

.habari-lmplus-price__amount {
    font-family: var(--habari-font-heading);
    font-size: 2rem;
    font-weight: 700;
    color: var(--habari-dark-shark);
    line-height: 1;
}

.habari-lmplus-price__period {
    font-size: 0.9rem;
    color: var(--habari-dark-pale);
    font-weight: 400;
}


/* ── Bénéfices ── */

.habari-lmplus-perks {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
    flex: 1;
}

.habari-lmplus-perks li {
    font-size: 0.85rem;
    color: var(--habari-dark-shark);
    padding-left: 1.1rem;
    position: relative;
    line-height: 1.45;
}

.habari-lmplus-perks li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: var(--habari-primary-brand);
    font-weight: 700;
    font-size: 0.8rem;
}


/* =============================================
   CHECKBOXES LÉGALES (RGPD + rétractation)
   ============================================= */

.habari-lmplus-legals {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1rem;
    background: #f9f9f9;
    border-left: 3px solid var(--habari-dark-off);
}

.habari-lmplus-legal-check {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    cursor: pointer;
    font-size: 0.8rem;
    color: var(--habari-dark-shark);
    line-height: 1.5;
}

.habari-lmplus-legal-check input[type="checkbox"] {
    margin-top: 0.15rem;
    flex-shrink: 0;
    accent-color: var(--habari-primary-brand);
    width: 15px;
    height: 15px;
    cursor: pointer;
}

.habari-lmplus-legal-check a {
    color: var(--habari-secondary-navy);
    text-decoration: underline;
}

.habari-lmplus-legal-check a:hover {
    color: var(--habari-primary-brand);
}


/* =============================================
   RÉCAPITULATIF COMMANDE
   ============================================= */

.habari-lmplus-order-summary {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 0;
    border-top: 1px solid var(--habari-dark-off);
    border-bottom: 1px solid var(--habari-dark-off);
    font-size: 0.9rem;
    color: var(--habari-dark-shark);
}

.habari-lmplus-order-summary strong {
    font-weight: 700;
    color: var(--habari-primary-brand);
}

.habari-lmplus-order-hint {
    font-size: 0.75rem;
    color: var(--habari-dark-pale);
    margin: 0;
    line-height: 1.5;
}


/* =============================================
   ÉTAT SUCCÈS
   ============================================= */

.habari-lmplus-success {
    text-align: center;
    padding: 1rem 0;
}

.habari-lmplus-success__icon {
    display: flex;
    justify-content: center;
    margin-bottom: 1.25rem;
    color: var(--habari-success);
}

.habari-lmplus-success__btn {
    margin-top: 1.25rem;
    text-decoration: none;
}


/* =============================================
   STRIPE PAYMENT ELEMENT — conteneur
   ============================================= */

#habari-lmplus-payment-element {
    margin-bottom: 0.5rem;
}


/* =============================================
   PRÉFÉRENCE POST-PAIEMENT (checkbox optionnelle)
   ============================================= */

.habari-lmplus-pref {
    margin: 1rem 0 0.75rem;
    padding: 0.65rem 1rem;
    background: var(--habari-secondary-navy-off);
    border-left: 3px solid var(--habari-secondary-navy);
}

.habari-lmplus-pref .habari-lmplus-legal-check {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--habari-secondary-navy);
}

.habari-lmplus-pref input[type="checkbox"] {
    accent-color: var(--habari-secondary-navy);
}


/* =============================================
   PAGE FONCTIONNALITÉS LM+
   ============================================= */

.habari-features-page {
    padding: 3rem 0 4rem;
}

.habari-features-hero {
    text-align: center;
    margin-bottom: 2rem;
}

.habari-features-hero__title {
    font-family: var(--habari-font-heading);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--habari-dark-shark);
    margin: 0.75rem auto 0.5rem;
    max-width: 420px;
    line-height: 1.35;
}

.habari-features-price-display {
    margin: 0;
}

.habari-features-price-display strong {
    font-family: var(--habari-font-heading);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--habari-dark-shark);
}

.habari-features-price-display span {
    font-size: 0.9rem;
    color: var(--habari-dark-pale);
    margin-left: 0.2rem;
}

.habari-features-card {
    margin-bottom: 1.25rem;
}

.habari-features-section-title {
    font-family: var(--habari-font-heading);
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--habari-dark-shark);
    margin: 0 0 1.25rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--habari-dark-off);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.habari-features-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.habari-features-item {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
}

.habari-features-icon {
    flex-shrink: 0;
    margin-top: 0.05rem;
}

.habari-features-item--active .habari-features-icon {
    color: var(--habari-primary-brand);
}

.habari-features-item--coming .habari-features-icon {
    color: var(--habari-dark-pale);
}

.habari-features-item__text {
    font-size: 0.95rem;
    color: var(--habari-dark-shark);
    line-height: 1.5;
}

.habari-features-item--coming .habari-features-item__text {
    color: var(--habari-dark-pale);
}

.habari-features-item__badge {
    display: inline-block;
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 0.1rem 0.4rem;
    background: var(--habari-gold-off);
    color: var(--habari-gold);
    margin-left: 0.4rem;
    vertical-align: middle;
    line-height: 1.6;
}

.habari-features-cta {
    text-align: center;
    margin-top: 2rem;
}
