/* ============================================================
   CAMPAGNE.CSS — CSS unique pour la page Campagne (hors Screen)
   ------------------------------------------------------------
   Toutes les valeurs visuelles passent par des variables CSS.
   Override : campagneData.config.tokens.main (5 vars principales)
              + campagneData.config.tokens.custom (exceptions fines)
              injectées via <style>:root{...}</style> par
              services/RouterPage.js → CampagneThemeStructure.
   ============================================================ */

:root {
    /* === Variables principales (5) ===
       Surchargées par campagneData.config.tokens.main.
       Toutes les variables fines en dessous en dérivent par défaut. */
    --cp-primary: #13A0BB;
    --cp-secondary: #FFFFFF;
    --cp-dark: #000000;
    --cp-text: #000000;
    --cp-radius: 5px;

    /* === Bouton don (CTA principal) === */
    --cp-donation-button-bg: var(--cp-primary);
    --cp-donation-button-color: var(--cp-secondary);
    --cp-donation-button-border: var(--cp-primary);
    --cp-donation-button-hover-bg: var(--cp-secondary);
    --cp-donation-button-hover-color: var(--cp-primary);
    --cp-donation-button-radius: 30px;

    /* === Barre de progression === */
    --cp-bar-bg: var(--cp-dark);
    --cp-bar-text-primary: var(--cp-secondary);
    --cp-bar-text-secondary: var(--cp-primary);
    --cp-bar-fill: var(--cp-primary);

    /* === Hero / Carousel === */
    --cp-hero-bg: var(--cp-primary);

    /* === Countdown (compteur date) === */
    --cp-countdown-box-bg: var(--cp-dark);
    --cp-countdown-box-color: var(--cp-secondary);
    --cp-countdown-box-alert-color: #904747;
    --cp-countdown-legend-color: var(--cp-primary);
    --cp-countdown-title-color: var(--cp-dark);

    /* === Modal de don === */
    --cp-modal-title-color: var(--cp-primary);
    --cp-modal-button-bg: var(--cp-primary);
    --cp-modal-button-color: var(--cp-secondary);
    --cp-modal-button-radius: 20px;
    --cp-modal-button-hover-bg: var(--cp-secondary);
    --cp-modal-button-hover-color: var(--cp-primary);
    --cp-modal-product-card-hover-bg: #DEDEDE;
    --cp-modal-product-card-title-color: var(--cp-primary);
    --cp-modal-product-card-description-color: var(--cp-dark);
    --cp-modal-product-card-quantity-hover-bg: var(--cp-primary);
    --cp-modal-product-card-quantity-hover-color: var(--cp-secondary);
    --cp-modal-product-card-showmore-color: var(--cp-primary);

    /* === Section custom (csection) === */
    --cp-csection-bg: #F2F2F2;
    --cp-csection-heading-color: var(--cp-primary);
    --cp-csection-text-color: var(--cp-dark);

    /* === Titres & liens === */
    --cp-title-border: var(--cp-primary);
    --cp-title-link: var(--cp-primary);
    --cp-title-link-hover: var(--cp-dark);

    /* === Bouton équipe === */
    --cp-team-button-bg: var(--cp-primary);
    --cp-team-button-color: var(--cp-secondary);
    --cp-team-button-hover-bg: var(--cp-secondary);
    --cp-team-button-hover-color: var(--cp-primary);

    /* === Produits === */
    --cp-products-item-bg: var(--cp-primary);

    /* === Time ago (timestamps) === */
    --cp-time-ago-color: #797979;

    /* === ALD only (template === "ALD") === */
    --cp-block-don-bg: linear-gradient(90deg, rgba(71,116,144,1) 0%, rgba(112,170,205,1) 100%);
    --cp-block-don-color: var(--cp-secondary);
    --cp-block-don-product-bg: var(--cp-secondary);
    --cp-block-don-product-color: var(--cp-primary);
    --cp-block-don-product-hover-bg: var(--cp-primary);
    --cp-block-don-product-hover-color: var(--cp-secondary);
    --cp-block-don-button-bg: var(--cp-secondary);
    --cp-block-don-button-color: var(--cp-primary);
    --cp-block-don-button-border: var(--cp-primary);

    --cp-tabs-bg: var(--cp-block-don-bg);
    --cp-tabs-item-bg: rgba(112,170,205,1);
    --cp-tabs-item-color: var(--cp-secondary);
    --cp-tabs-item-selected-bg: var(--cp-secondary);
    --cp-tabs-item-selected-color: var(--cp-primary);
}

/* ============================================================
   Layout de base
   ============================================================ */

.campagne-page {
    /* Font verrouillée pour l'instant — non variabilisée
       (cohérence visuelle, fallbacks, chargement Google Fonts). */
    font-family: Archivo, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
                 "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif,
                 "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

body {
    margin: 0;
    padding: 0;
}

/* ============================================================
   Utilitaires
   ============================================================ */

.-text-primary {
    color: var(--cp-primary);
}

/* ============================================================
   Hero / Carousel
   ============================================================ */

.carousel-hero {
    background-color: var(--cp-hero-bg);
}

/* ============================================================
   Barre de progression
   ============================================================ */

.bar {
    background-color: var(--cp-bar-bg);
}

.bar-text-primary {
    color: var(--cp-bar-text-primary);
}

.bar-text-secondary {
    color: var(--cp-bar-text-secondary);
}

/* ============================================================
   Bouton don (CTA principal)
   ============================================================ */

.donation-button {
    color: var(--cp-donation-button-color);
    background-color: var(--cp-donation-button-bg);
    padding-left: 3rem;
    padding-right: 3rem;
    height: 4rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: var(--cp-donation-button-radius);
    cursor: pointer;
    font-weight: 900;
    text-transform: uppercase;
    font-size: 1.125rem;
    line-height: 1.75rem;
    border: 1px solid var(--cp-donation-button-border);
}

.donation-button:hover {
    color: var(--cp-donation-button-hover-color);
    background-color: var(--cp-donation-button-hover-bg);
}

/* ============================================================
   Countdown (compteur date)
   ============================================================ */

.countdown-wrapper {
    max-width: 800px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
}

.countdown-box-alert,
.countdown-box {
    background-color: var(--cp-countdown-box-bg);
    font-size: 2rem;
    font-weight: 700;
    color: var(--cp-countdown-box-color);
    border-radius: var(--cp-radius);
    width: 7rem;
    height: 7rem;
    margin: 0 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.countdown-box-alert {
    color: var(--cp-countdown-box-alert-color);
}

.countdown-legend {
    font-size: 1rem;
    color: var(--cp-countdown-legend-color);
}

.countdown-title {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--cp-countdown-title-color);
    margin-bottom: 20px;
    text-transform: uppercase;
    text-align: center;
    padding: 0 10%;
}

/* ============================================================
   Modal de don
   ============================================================ */

.modal-submit-title {
    color: var(--cp-modal-title-color);
    text-transform: uppercase;
}

.modal-submit-button {
    background-color: var(--cp-modal-button-bg);
    color: var(--cp-modal-button-color);
    border-radius: var(--cp-modal-button-radius) !important;
}

.modal-submit-button:hover {
    background-color: var(--cp-modal-button-hover-bg) !important;
    color: var(--cp-modal-button-hover-color) !important;
    border-color: var(--cp-primary) !important;
}

.modal-submit-product-card {
    cursor: pointer;
}

.modal-submit-product-card:hover {
    background-color: var(--cp-modal-product-card-hover-bg);
}

.modal-submit-product-card-title {
    color: var(--cp-modal-product-card-title-color);
    text-transform: uppercase;
    font-size: .775rem;
    font-weight: 900;
    line-height: 1.25rem;
}

.modal-submit-product-card-description {
    color: var(--cp-modal-product-card-description-color);
    font-size: .700rem;
}

.modal-submit-product-card-quantity-button:hover {
    background-color: var(--cp-modal-product-card-quantity-hover-bg) !important;
    color: var(--cp-modal-product-card-quantity-hover-color) !important;
}

.modal-submit-product-card-showmore {
    color: var(--cp-modal-product-card-showmore-color);
    text-transform: uppercase;
}

/* ============================================================
   Section custom (csection)
   ============================================================ */

.csection {
    background-color: var(--cp-csection-bg);
}

.csection h1,
.csection h2,
.csection h3,
.csection h4,
.csection h5,
.csection h6 {
    color: var(--cp-csection-heading-color) !important;
}

.csection p {
    color: var(--cp-csection-text-color) !important;
    font-size: 1rem;
}

/* ============================================================
   Titres & liens
   ============================================================ */

.title {
    border-bottom: 2px solid var(--cp-title-border);
    text-transform: uppercase;
    font-weight: 700;
    font-size: 1.5rem;
    line-height: 2rem;
    width: auto;
}

.title-link {
    color: var(--cp-title-link);
    text-decoration: none !important;
}

.title-link:hover {
    color: var(--cp-title-link-hover);
}

/* ============================================================
   Bouton équipe
   ============================================================ */

.team-page-button {
    color: var(--cp-team-button-color);
    background-color: var(--cp-team-button-bg);
    padding-left: 1.25rem;
    padding-right: 1.25rem;
    height: 2.25rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 30px;
    cursor: pointer;
    font-weight: 900;
    text-transform: uppercase;
    font-size: 0.75rem;
    line-height: 1rem;
    text-decoration: none;
}

.team-page-button:hover {
    color: var(--cp-team-button-hover-color);
    background-color: var(--cp-team-button-hover-bg);
    border: 1px solid var(--cp-primary);
}

/* ============================================================
   Misc
   ============================================================ */

.time-ago {
    font-size: 0.75rem;
    line-height: 1rem;
    color: var(--cp-time-ago-color);
}

/* ============================================================
   Produits
   ============================================================ */

.products-section {
    margin-top: 5vh;
}

.products-item {
    background-color: var(--cp-products-item-bg);
    width: 220px;
    padding-top: 30px;
    padding-bottom: 10px;
    gap: 10px;
    -webkit-box-shadow: 0px 5px 31px -12px rgba(0, 0, 0, 0.75);
    -moz-box-shadow: 0px 5px 31px -12px rgba(0, 0, 0, 0.75);
    box-shadow: 0px 5px 31px -12px rgba(0, 0, 0, 0.75);
}

/* ============================================================
   ALD only (template === "ALD")
   ============================================================ */

.block-don {
    background: var(--cp-block-don-bg);
    color: var(--cp-block-don-color);
}

.block-don-product-item {
    background-color: var(--cp-block-don-product-bg);
    color: var(--cp-block-don-product-color);
}

.block-don-product-item:hover {
    background-color: var(--cp-block-don-product-hover-bg);
    color: var(--cp-block-don-product-hover-color);
}

.block-don-donation-button {
    color: var(--cp-block-don-button-color);
    background-color: var(--cp-block-don-button-bg);
    padding-left: 3rem;
    padding-right: 3rem;
    height: 4rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: var(--cp-radius);
    cursor: pointer;
    font-weight: 900;
    font-size: 1.125rem;
    line-height: 1.75rem;
    border: 1px solid var(--cp-block-don-button-border);
}

.tabs {
    background: var(--cp-tabs-bg);
    padding: 10px;
    border-radius: var(--cp-radius);
}

.tabs-item {
    background-color: var(--cp-tabs-item-bg);
    color: var(--cp-tabs-item-color);
    border-radius: var(--cp-radius);
}

.tabs-item-selected {
    background-color: var(--cp-tabs-item-selected-bg);
    color: var(--cp-tabs-item-selected-color);
    border-radius: var(--cp-radius);
}

/* ============================================================
   Mobile
   ============================================================ */

@media (max-width: 600px) {
    body {
        padding-bottom: 3rem;
    }

    .donation-button {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        height: 3rem;
        font-size: 0.8rem;
        line-height: 1.75rem;
    }

    .countdown-box-alert,
    .countdown-box {
        font-size: 1rem;
        width: 5rem;
        height: 5rem;
        margin: 0 4px;
    }

    .countdown-legend {
        font-size: 0.8rem;
    }

    .countdown-title {
        font-size: 1rem;
    }

    .products-section {
        margin-top: 15px;
    }

    .products-item {
        width: 95%;
        border-radius: 10px;
        padding: 15px 10px;
        min-height: initial;
    }
}
