/**
 * Meetles — Restyling de la page Single Event TEC (template single-event.php)
 * v2.4.0
 *
 * Cible : la page d un evenement individuel (ex. /table/tournoi-skyjo/)
 * S applique aussi avec le template custom dans le child theme BuddyBoss
 * (tribe-events/single-event.php).
 *
 * Strategie :
 *   - Override CSS pur (le template PHP reste intact)
 *   - Surcharge des styles inline avec !important (le template a beaucoup
 *     d inline styles sur .bgg-box et ses enfants)
 *   - Variables BuddyBoss avec fallback hex
 *
 * Sections couvertes :
 *   1. Bandeau date + titre haut (.bs-event-heading)
 *   2. Layout 2 colonnes (.bs-event-columns)
 *   3. Box BGG (.bgg-box)
 *   4. Bloc description / lieu / organisateur (.bs-event-main)
 *   5. Boutons de partage (.meetles-share-event)
 *   6. Meta block (.bs-single-pri-meta)
 *   7. RSVP / inscription (tribe-tickets-rsvp)
 *   8. Footer nav (partie precedente / suivante)
 */

/* ─── Container global ───────────────────────────────────────
   NE PAS toucher au wrapper racine .tribe-events-single :
   le theme BuddyBoss applique son propre fond + border-radius dessus.
   Si on ajoute max-width ici, le fond orange decoratif du theme
   apparait sur les cotes et les bords arrondis du wrapper masquent
   le contenu. */
.tribe-events-single {
    color: var(--bb-body-text-color, #1c2126);
}

/* "Retour à toutes les tables" (top link) — discret */
.tribe-events-back {
    margin: 0 0 16px;
}
.tribe-events-back a {
    font-size: 13px;
    color: var(--bb-content-secondary-text-color, #5b6975) !important;
    text-decoration: none !important;
}
.tribe-events-back a:hover {
    color: var(--bb-primary-color, #385dff) !important;
}

/* ─── 1) Bandeau date + titre haut ───────────────────────────── */
.bs-event-heading {
    display: flex;
    align-items: stretch;
    gap: 20px;
    padding: 24px;
    background: var(--bb-content-background-color, #fff);
    border: 1px solid var(--bb-content-border-color, #e7e9ec);
    border-radius: 12px;
    margin-bottom: 24px;
}

/* Mini-bloc date "MAI 23" à gauche */
.tribe-event-schedule-short {
    flex: 0 0 80px;
}
.bs-schedule-short-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: var(--bb-content-alternate-background-color, #f4f5f7);
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
}
.bs-schedule-short-m {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--bb-primary-color, #385dff);
    letter-spacing: 0.5px;
    margin: 0;
    padding: 0;
}
.bs-schedule-short-d {
    font-size: 32px;
    font-weight: 700;
    line-height: 1;
    color: var(--bb-headings-color, #1c2126);
    margin: 0;
    padding: 0;
}

/* Bloc titre à droite */
.tribe-event-schedule-long {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
}
.bs-tribe-events-single-heading .tribe-events-single-event-title {
    font-size: 28px;
    font-weight: 700;
    margin: 0;
    line-height: 1.2;
    color: var(--bb-headings-color, #1c2126);
}
.bs-tribe-events-single-heading h2 {
    font-size: 14px;
    font-weight: 500;
    margin: 4px 0 0;
    color: var(--bb-content-secondary-text-color, #5b6975);
    line-height: 1.4;
}
.tribe-events-schedule .tribe-events-cost {
    display: inline-block;
    margin-top: 6px;
    padding: 2px 10px;
    background: #fff4dd;
    color: #b8770a;
    font-size: 12px;
    font-weight: 600;
    border-radius: 999px;
}

/* ─── Nav top (Partie Précédente / Prochaine) ───────────────── */
#tribe-events-header,
#tribe-events-footer {
    border: none;
    padding: 0;
    margin: 12px 0;
}
.tribe-events-sub-nav {
    display: flex;
    justify-content: space-between;
    list-style: none;
    padding: 0;
    margin: 0;
}
.tribe-events-sub-nav li a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 6px 14px;
    color: var(--bb-content-secondary-text-color, #5b6975) !important;
    background: var(--bb-content-alternate-background-color, #f4f5f7);
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none !important;
    transition: background .15s ease, color .15s ease;
}
.tribe-events-sub-nav li a:hover {
    background: var(--bb-primary-color, #385dff);
    color: #fff !important;
}

/* ─── 2) Layout 2 colonnes ──────────────────────────────────── */
.bs-event-columns {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 24px;
    align-items: start;
}
.bs-event-box {
    grid-column: 1;
}
.bs-event-main {
    grid-column: 2;
    min-width: 0;
}

/* ─── 3) Box BGG (override des inline styles) ───────────────── */
.bgg-box {
    padding: 20px !important;
    border: 1px solid var(--bb-content-border-color, #e7e9ec) !important;
    border-radius: 12px !important;
    background: var(--bb-content-background-color, #fff) !important;
    text-align: center;
}
.bgg-box h3 {
    font-size: 14px !important;
    font-weight: 600;
    margin: 0 0 12px !important;
    color: var(--bb-content-secondary-text-color, #5b6975);
    text-align: left;
    line-height: 1.4;
}
.bgg-box p {
    margin: 0 0 12px !important;
}
.bgg-box .jeupresente {
    text-align: left;
    margin: 0 0 16px !important;
}
.bgg-box .jeupresente strong {
    font-size: 18px;
    font-weight: 700;
    color: var(--bb-primary-color, #385dff);
}
.bgg-box img {
    max-width: 100% !important;
    width: auto !important;
    max-height: 280px;
    border: none !important;
    border-radius: 8px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    display: block;
    margin: 0 auto;
}
.bgg-box a[href*="boardgamegeek.com"] {
    display: inline-block;
    margin-top: 16px !important;
    padding: 10px 20px;
    background: var(--bb-primary-button-background-regular, #5867f5);
    color: var(--bb-primary-button-text-regular, #fff) !important;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none !important;
    transition: background .15s ease, transform .15s ease;
}
.bgg-box a[href*="boardgamegeek.com"]:hover {
    background: var(--bb-primary-button-background-hover, #4858dd);
    transform: translateY(-1px);
    color: #fff !important;
}
.bgg-box em {
    display: block;
    padding: 24px;
    color: var(--bb-content-secondary-text-color, #939597);
    font-style: italic;
    font-size: 13px;
}

/* ─── 4) Bloc droite : description / lieu / organisateur ─── */
.bs-event-main {
    background: var(--bb-content-background-color, #fff);
    border: 1px solid var(--bb-content-border-color, #e7e9ec);
    border-radius: 12px;
    padding: 24px;
}
.bs-single-body {
    margin: 0;
}
.tribe-events-event-image,
.bs-single-body > a > img,
.bs-single-body img.attachment-full {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin-bottom: 16px;
}
.tribe-events-single-event-description.tribe-events-content {
    font-size: 14px;
    line-height: 1.6;
    color: var(--bb-body-text-color, #1c2126);
}
.tribe-events-single-event-description.tribe-events-content p {
    margin: 0 0 12px;
}
.tribe-events-single-event-description.tribe-events-content a {
    color: var(--bb-primary-color, #385dff);
    word-break: break-word;
}

/* Bloc lieu + organisateur custom */
.event-city {
    margin: 16px 0 0 !important;
    padding: 12px 16px;
    background: var(--bb-content-alternate-background-color, #f4f5f7);
    border-radius: 8px;
    font-size: 13px;
    line-height: 1.6;
    color: var(--bb-body-text-color, #1c2126);
}
.event-city strong {
    color: var(--bb-headings-color, #1c2126);
}
.event-city a {
    color: var(--bb-primary-color, #385dff);
    font-weight: 500;
    text-decoration: none;
}
.event-city a:hover {
    text-decoration: underline;
}
.event-city small {
    display: block;
    margin-top: 4px;
    font-style: italic;
    color: var(--bb-content-secondary-text-color, #939597);
    font-size: 11px;
}

/* Bouton "Ajouter au calendrier" */
.tribe-events-c-subscribe-dropdown__container,
.tribe-events-c-subscribe-dropdown {
    margin-top: 16px !important;
}
.tribe-events-c-subscribe-dropdown__button {
    border-radius: 999px !important;
    border: 1px solid var(--bb-primary-color, #385dff) !important;
    color: var(--bb-primary-color, #385dff) !important;
    padding: 8px 16px !important;
    background: transparent !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    transition: background .15s ease, color .15s ease;
}
.tribe-events-c-subscribe-dropdown__button:hover {
    background: var(--bb-primary-color, #385dff) !important;
    color: #fff !important;
}

/* ─── 5) Boutons de partage (override + alignement) ───────── */
.meetles-share-event {
    background: var(--bb-content-background-color, #fff) !important;
    border: 1px solid var(--bb-content-border-color, #e7e9ec) !important;
    border-radius: 12px !important;
    padding: 16px 20px !important;
    margin: 24px 0 !important;
    box-shadow: none !important;
}
.meetles-share-label {
    color: var(--bb-body-text-color, #1c2126) !important;
    font-size: 14px !important;
}
.meetles-share-btn {
    border-radius: 999px !important;
    padding: 8px 14px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}
/* Couleurs marques preservees (.meetles-share-fb etc dans le template) */

/* ─── 6) Meta block (Detail/Heure/Type) ───────────────────── */
.bs-single-pri-meta {
    margin: 24px 0;
}
.tribe-events-meta-group {
    background: var(--bb-content-background-color, #fff);
    border: 1px solid var(--bb-content-border-color, #e7e9ec);
    border-radius: 12px;
    padding: 20px 24px;
    margin: 0 0 16px;
}
.tribe-events-single-section-title {
    font-size: 13px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px;
    color: var(--bb-headings-color, #1c2126) !important;
    margin: 0 0 12px !important;
    padding: 0 !important;
    border: none !important;
}
.tribe-events-single-section dl {
    margin: 0;
}
.tribe-events-single-section dt {
    font-weight: 600;
    color: var(--bb-content-secondary-text-color, #5b6975);
    font-size: 12px;
    margin: 12px 0 4px;
}
.tribe-events-single-section dd {
    margin: 0 0 8px;
    font-size: 14px;
    color: var(--bb-body-text-color, #1c2126);
}

/* Type joueurs souhaités — badge pill */
.tribe-events-meta-group .meetles_player_types,
.tribe-events-meta-group [class*="player-types"] {
    display: inline-block;
    padding: 4px 10px;
    background: var(--bb-content-alternate-background-color, #f4f5f7);
    border-radius: 999px;
    font-size: 12px;
    margin: 2px 4px 2px 0;
}

/* Bouton "Table ouverte au public" (badge category) */
.tribe-events-single .tribe_events_cat-public,
.tribe-events-event-cat-public a,
a[href*="tribe_events_cat=public"] {
    display: inline-block;
    padding: 6px 14px;
    background: #f0a020;
    color: #fff !important;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none !important;
}

/* ─── 7) RSVP / Inscription ───────────────────────────────── */
.tribe-tickets__rsvp,
.tribe-tickets-rsvp,
.tribe-events-tickets-rsvp,
.tribe-tickets__rsvp-wrapper {
    background: var(--bb-content-background-color, #fff);
    border: 1px solid var(--bb-content-border-color, #e7e9ec);
    border-radius: 12px;
    padding: 24px;
    margin: 24px 0;
}
.tribe-tickets__rsvp-ar-title,
.tribe-tickets__rsvp-title {
    font-size: 18px !important;
    font-weight: 700 !important;
    margin: 0 0 12px !important;
    color: var(--bb-headings-color, #1c2126);
}
.tribe-tickets__rsvp-actions-button-going,
.tribe-tickets__rsvp-actions-button-not-going,
.tribe-tickets-rsvp-actions-rsvp-going-button,
.tribe-common-c-btn.tribe-tickets__rsvp-actions-button-going {
    border-radius: 999px !important;
    padding: 10px 24px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    background: var(--bb-primary-button-background-regular, #5867f5) !important;
    color: var(--bb-primary-button-text-regular, #fff) !important;
    border: none !important;
    transition: background .15s ease, transform .15s ease;
}
.tribe-tickets__rsvp-actions-button-going:hover {
    background: var(--bb-primary-button-background-hover, #4858dd) !important;
    transform: translateY(-1px);
}

/* Compteur "0 Participants / 7 restant(s)" */
.tribe-tickets__rsvp-ar-quantity,
.tribe-tickets-rsvp-message,
.tribe-tickets__rsvp-availability {
    font-size: 13px;
    color: var(--bb-content-secondary-text-color, #5b6975);
}

/* ─── 8) Reset overrides du theme BuddyBoss si necessaires ─── */
.tribe-events-single h1,
.tribe-events-single h2,
.tribe-events-single h3 {
    font-family: var(--bb-font-family, inherit);
}

/* ─── Responsive ≤ 720px ─────────────────────────────────── */
@media (max-width: 720px) {
    .bs-event-heading {
        flex-direction: row;
        padding: 16px;
        gap: 14px;
    }
    .tribe-event-schedule-short {
        flex: 0 0 64px;
    }
    .bs-schedule-short-date {
        width: 64px;
        height: 64px;
    }
    .bs-schedule-short-d {
        font-size: 24px;
    }
    .bs-tribe-events-single-heading .tribe-events-single-event-title {
        font-size: 20px;
    }
    .bs-event-columns {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .bs-event-box,
    .bs-event-main {
        grid-column: 1;
    }
    .bs-event-main {
        padding: 16px;
    }
    .bgg-box img {
        max-height: 220px;
    }
    .meetles-share-event {
        padding: 12px !important;
    }
}
