/**
 * ALGM Bénévoles — Styles publics (v4.11+)
 *
 * Utilisés par le shortcode [algm_missions_publiques] pour afficher les
 * missions ouvertes hors de l'espace bénévole.
 *
 * Charte ALGM (tokens centraux exposés par theme-algm-block/style.css) :
 *   - Bleu marine : var(--algm-bleu)   #202346
 *   - Or          : var(--algm-or)     #EAB93A
 *   - Blanc       : var(--algm-blanc)  #FFFFFF
 *   - Gris bord   : var(--algm-gris-bord)
 *
 * Les alias locaux --algm-pub-* sont conservés pour la rétro-compatibilité
 * (anciens overrides éventuels) mais pointent désormais sur les tokens
 * centraux du thème. Toute nouvelle règle doit consommer --algm-* directement.
 *
 * Enqueue conditionnel : voir Shortcodes::enqueue_public_assets().
 */

.algm-pub-missions {
    /* Alias locaux → tokens centraux du thème (fallback pour usage standalone) */
    --algm-pub-bleu:   var(--algm-bleu,       #202346);
    --algm-pub-or:     var(--algm-or,         #EAB93A);
    --algm-pub-bg:     var(--algm-blanc,      #FFFFFF);
    --algm-pub-border: var(--algm-gris-bord,  #E0E0E0);
    --algm-pub-text:   var(--algm-texte,      #1A1A1A);
    --algm-pub-muted:  var(--algm-texte-muted,#6B7280);

    max-width: 1100px;
    margin: 40px auto;
    padding: 0 16px;
    color: var(--algm-pub-text);
    font-family: var(--algm-font-texte, 'Open Sans', Arial, sans-serif);
    line-height: 1.5;
}

.algm-pub-missions__header {
    text-align: center;
    margin-bottom: 28px;
}

.algm-pub-missions__title {
    color: var(--algm-pub-bleu);
    font-family: var(--algm-font-titre, Verdana, Geneva, sans-serif);
    font-size: clamp(1.6rem, 2.4vw, 2.1rem);
    margin: 0 0 8px;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.algm-pub-missions__intro {
    color: var(--algm-pub-muted);
    margin: 0 auto;
    max-width: 640px;
    font-size: 1rem;
}

/* ── Grille de cartes ──────────────────────────────────────────────────── */

.algm-pub-missions__grid {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.algm-pub-missions__card {
    background: var(--algm-pub-bg);
    border: 1px solid var(--algm-pub-border);
    border-radius: var(--algm-radius-lg, 12px);
    padding: 18px 18px 16px;
    box-shadow: var(--algm-shadow-sm, 0 1px 2px rgba(0, 0, 0, 0.04));
    display: flex;
    flex-direction: column;
    gap: 10px;
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.algm-pub-missions__card:hover {
    transform: translateY(-2px);
    box-shadow: var(--algm-shadow-lg, 0 6px 16px rgba(32, 35, 70, 0.12));
    border-color: var(--algm-pub-or);
}

.algm-pub-missions__type {
    display: inline-block;
    padding: 3px 10px;
    border-radius: var(--algm-radius-pill, 999px);
    color: var(--algm-blanc, #fff);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    align-self: flex-start;
}

.algm-pub-missions__card-title {
    color: var(--algm-pub-bleu);
    font-family: var(--algm-font-titre, Verdana, Geneva, sans-serif);
    font-size: 1.1rem;
    margin: 0;
    font-weight: 700;
    line-height: 1.3;
}

.algm-pub-missions__meta {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.92rem;
    color: var(--algm-pub-text);
}

.algm-pub-missions__meta li {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: baseline;
}

.algm-pub-missions__adresse {
    flex: 1 1 100%;
    color: var(--algm-pub-muted);
    font-size: 0.85rem;
    padding-left: 22px;
}

.algm-pub-missions__places {
    margin: 6px 0 0;
    padding-top: 10px;
    border-top: 1px dashed var(--algm-pub-border);
    font-size: 0.92rem;
}

.algm-pub-missions__places strong {
    color: var(--algm-pub-bleu);
}

.algm-pub-missions__places-total {
    color: var(--algm-pub-muted);
    font-size: 0.85rem;
    margin-left: 4px;
}

/* ── Pied de section : CTA ─────────────────────────────────────────────── */

.algm-pub-missions__footer {
    margin-top: 28px;
    text-align: center;
    padding: 24px 16px;
    background: var(--algm-pub-bg);
    border: 1px solid var(--algm-pub-border);
    box-shadow: var(--algm-shadow-lg, 0 6px 16px rgba(32, 35, 70, 0.12));
    border-color: var(--algm-pub-or);
    border-radius: var(--algm-radius-lg, 12px);
}

.algm-pub-missions__incite {
    color: var(--algm-pub-bleu);
    margin: 0 0 16px;
    font-size: 1rem;
    font-weight: 500;
}

/* Conteneur des deux boutons — en ligne sur desktop, empilés sur mobile */
.algm-pub-missions__actions {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 10px;
}

.algm-pub-missions__cta {
    display: inline-block;
    font-family: var(--algm-font-texte, 'Open Sans', Arial, sans-serif);
    font-weight: 700;
    text-decoration: none;
    padding: 13px 26px;
    border-radius: var(--algm-radius-pill, 999px);
    font-size: 1rem;
    line-height: 1.2;
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
    border: 2px solid transparent;
    white-space: nowrap;
}

/* Action principale : fond OR + texte BLEU (= standard .wp-block-button__link) */
.algm-pub-missions__cta--primary {
    background: var(--algm-pub-or);
    color: var(--algm-pub-bleu) !important;
    border-color: var(--algm-pub-or);
}

.algm-pub-missions__cta--primary:hover,
.algm-pub-missions__cta--primary:focus {
    background: var(--algm-pub-bleu);
    color: var(--algm-blanc, #fff) !important;
    border-color: var(--algm-pub-bleu);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(32, 35, 70, 0.20);
}

/* Action secondaire : fond blanc + bord BLEU + texte BLEU */
.algm-pub-missions__cta--secondary {
    background: var(--algm-pub-bg);
    color: var(--algm-pub-bleu) !important;
    border-color: var(--algm-pub-bleu);
}

.algm-pub-missions__cta--secondary:hover,
.algm-pub-missions__cta--secondary:focus {
    background: var(--algm-pub-bleu);
    color: var(--algm-blanc, #fff) !important;
    border-color: var(--algm-pub-bleu);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(32, 35, 70, 0.18);
}

/* Mobile : on empile les deux boutons en pleine largeur pour rester lisibles */
@media (max-width: 540px) {
    .algm-pub-missions__actions {
        display: flex;
        flex-direction: column;
        width: 100%;
        gap: 12px;
    }
    .algm-pub-missions__cta {
        width: 100%;
        white-space: normal;
    }
}

/* ── Etat vide ─────────────────────────────────────────────────────────── */

.algm-pub-missions__empty {
    text-align: center;
    padding: 30px 16px;
    background: var(--algm-gris, #F5F5F5);
    border: 1px dashed var(--algm-pub-border);
    border-radius: var(--algm-radius-lg, 12px);
}

.algm-pub-missions__empty p {
    color: var(--algm-pub-muted);
    margin: 0 0 14px;
}

/* ── Responsive ────────────────────────────────────────────────────────── */

@media (max-width: 540px) {
    .algm-pub-missions__grid {
        grid-template-columns: 1fr;
    }
    .algm-pub-missions__card {
        padding: 14px;
    }
}
