/**
 * 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 — plus prominent (couleur primary + size 96) */
.tribe-event-schedule-short {
    flex: 0 0 96px;
}
.bs-schedule-short-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 96px;
    height: 96px;
    background: linear-gradient(135deg, var(--bb-primary-color, #385dff), var(--bb-primary-button-background-hover, #4858dd));
    color: #fff;
    border-radius: 14px;
    padding: 8px 0;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(56, 93, 255, 0.25);
}
.bs-schedule-short-m {
    font-size: 13px !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.85) !important;
    letter-spacing: 1px;
    margin: 0;
    padding: 0;
    line-height: 1;
}
.bs-schedule-short-d {
    font-size: 38px !important;
    font-weight: 800 !important;
    line-height: 1;
    color: #fff !important;
    margin: 4px 0 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;
}
/* On masque le prix (Free / Gratuit) — l info n est pas utile sur Meetles */
.tribe-events-schedule .tribe-events-cost,
.tribe-events-cost,
.tribe-events-c-small-cta__price {
    display: none !important;
}

/* ─── 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 — carte prominente avec icones et accent */
.event-city {
    margin: 20px 0 0 !important;
    padding: 18px 20px !important;
    background: linear-gradient(135deg, #fff8e1, #ffffff);
    border: 1px solid var(--bb-content-border-color, #e7e9ec);
    border-left: 4px solid #f0a020;
    border-radius: 12px;
    font-size: 15px !important;
    line-height: 1.7 !important;
    color: var(--bb-body-text-color, #1c2126);
    box-shadow: 0 2px 6px rgba(0,0,0,.03);
}
.event-city strong {
    display: inline-block;
    color: var(--bb-headings-color, #1c2126);
    font-weight: 700;
    font-size: 14px;
    margin-right: 4px;
}
.event-city a {
    color: var(--bb-primary-color, #385dff);
    font-weight: 600;
    text-decoration: none;
    border-bottom: 1px dashed var(--bb-primary-color, #385dff);
    padding-bottom: 1px;
}
.event-city a:hover {
    color: var(--bb-primary-button-background-hover, #4858dd);
    border-bottom-style: solid;
}
.event-city small {
    display: block !important;
    margin-top: 8px !important;
    font-style: italic;
    color: var(--bb-content-secondary-text-color, #939597) !important;
    font-size: 12px !important;
}

/* 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 (Details / Infos / Type) ─────────────────
   Layout en grille 2 colonnes sur desktop, en pile sur mobile.
   Chaque ligne dt/dd alignee horizontalement avec un picto pour
   les labels courants (Date, Heure, Type, etc.) via [data-*]
   ou matching de texte. */
.bs-single-pri-meta {
    margin: 32px 0;
}
/* TEC met deja Details + Infos cote a cote dans .primary via flex.
   On force display: grid 2 cols ici (et NON sur .bs-single-pri-meta)
   pour que les 2 meta-groups occupent vraiment 50/50. */
.tribe-events-single-section.tribe-events-event-meta.primary,
.tribe-events-single-section.primary {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
    align-items: start !important;
    margin: 0 0 16px !important;
}
.tribe-events-single-section.secondary {
    margin: 0 !important;
}
.tribe-events-meta-group {
    /* Override des regles natives TEC v6 qui forcent width: 168px + flex: 1 0 140px
       + margin-right: var(--tec-spacer-5) sur ces meta-groups. Ces regles sont
       pensees pour le layout flex natif de TEC mais on a passe le parent en
       grid 2 cols, donc on libere completement le sizing. */
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    flex: none !important;
    margin: 0 !important;
    padding: 22px 26px !important;
    background: var(--bb-content-background-color, #fff);
    border: 1px solid var(--bb-content-border-color, #e7e9ec);
    border-radius: 12px;
    transition: border-color .2s ease, box-shadow .2s ease;
    box-sizing: border-box;
}
.tribe-events-meta-group:hover {
    border-color: var(--bb-content-border-color, #d1d5db);
    box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.tribe-events-single-section-title {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: var(--bb-primary-color, #385dff) !important;
    margin: 0 0 16px !important;
    padding: 0 0 12px !important;
    border: none !important;
    border-bottom: 2px solid var(--bb-content-alternate-background-color, #f4f5f7) !important;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Lignes dt/dd : layout horizontal compact, picto a gauche */
.tribe-events-single-section dl {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.tribe-events-single-section dt {
    font-weight: 600 !important;
    color: var(--bb-content-secondary-text-color, #5b6975) !important;
    font-size: 11px !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 0 0 2px !important;
    display: flex;
    align-items: center;
    gap: 6px;
}
.tribe-events-single-section dd {
    margin: 0 !important;
    padding: 0 0 0 24px;
    font-size: 15px !important;
    color: var(--bb-body-text-color, #1c2126) !important;
    font-weight: 500;
    line-height: 1.4;
}

/* Masquer la ligne Prix (Free / Gratuit) — utilisateur ne veut pas
   afficher de prix sur Meetles. Plusieurs selecteurs pour couvrir les
   versions de TEC. */
.tribe-events-meta-group dt.tribe-events-event-cost-label,
.tribe-events-meta-group dd.tribe-events-event-cost,
.tribe-events-meta-group .tribe-events-event-cost-label,
.tribe-events-meta-group .tribe-events-event-cost,
.tribe-events-meta-group .tribe-events-meta-cost-label,
.tribe-events-meta-group .tribe-events-meta-cost,
.tribe-events-event-cost-label,
.tribe-events-event-cost,
.tribe-events-meta-cost-label,
.tribe-events-meta-cost {
    display: none !important;
}

/* Pictos contextuels devant les labels (matching du texte courant) */
.tribe-events-single-section dt:first-of-type::before {
    content: "📅";
    font-size: 14px;
    margin-right: 2px;
}
.tribe-events-single-section dt:nth-of-type(2)::before {
    content: "🕒";
    font-size: 14px;
    margin-right: 2px;
}
.tribe-events-single-section dt:nth-of-type(3)::before,
.tribe-events-single-section dt:nth-of-type(n+3)::before {
    content: "🏷";
    font-size: 14px;
    margin-right: 2px;
}

/* Type joueurs : tags pill verts */
.tribe-events-meta-group dd:has(+ dt, :only-child) {
    /* aucun changement specifique */
}
.tribe-events-meta-group .meetles_player_types,
.tribe-events-meta-group [class*="player-types"] {
    display: inline-block;
    padding: 5px 12px;
    background: rgba(56, 93, 255, 0.08);
    color: var(--bb-primary-color, #385dff);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    margin: 2px 4px 2px 0;
}

/* Responsive meta */
@media (max-width: 720px) {
    .tribe-events-single-section.tribe-events-event-meta.primary,
    .tribe-events-single-section.primary {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    .tribe-events-meta-group {
        padding: 18px 20px;
    }
}

/* Bouton "Table ouverte au public" (badge category)
   IMPORTANT : on cible UNIQUEMENT les liens <a>, pas la classe
   .tribe_events_cat-public qui est ajoutee par WP post_class() sur le
   wrapper de l article entier — sinon on transforme tout le post en
   bulle orange. */
.tribe-events-meta-group a[href*="tribe_events_cat="],
.tribe-events-event-categories a[href*="tribe_events_cat="] {
    display: inline-block;
    padding: 6px 14px;
    background: #f0a020;
    color: #fff !important;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none !important;
    margin: 2px 4px 2px 0;
}

/* ─── 7) RSVP / Inscription — bloc mis en avant ─────────────── */
.tribe-tickets__rsvp,
.tribe-tickets-rsvp,
.tribe-events-tickets-rsvp,
.tribe-tickets__rsvp-wrapper {
    background: linear-gradient(135deg, var(--bb-content-background-color, #fff), #f8f9ff);
    border: 2px solid var(--bb-primary-color, #385dff);
    border-radius: 16px;
    padding: 28px 32px !important;
    margin: 32px 0 !important;
    box-shadow: 0 8px 24px rgba(56, 93, 255, 0.12);
    position: relative;
}
.tribe-tickets__rsvp::before,
.tribe-tickets-rsvp::before {
    content: "🎲 Inscrivez-vous !";
    position: absolute;
    top: -14px;
    left: 24px;
    background: var(--bb-primary-color, #385dff);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 14px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.tribe-tickets__rsvp-ar-title,
.tribe-tickets__rsvp-title {
    font-size: 22px !important;
    font-weight: 700 !important;
    margin: 0 0 14px !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: 14px 36px !important;
    font-size: 16px !important;
    font-weight: 600 !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, box-shadow .2s ease;
    box-shadow: 0 4px 12px rgba(56, 93, 255, 0.3);
}
.tribe-tickets__rsvp-actions-button-going:hover {
    background: var(--bb-primary-button-background-hover, #4858dd) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(56, 93, 255, 0.4);
}

/* Compteur "0 Participants / 7 restant(s)" */
.tribe-tickets__rsvp-ar-quantity,
.tribe-tickets-rsvp-message,
.tribe-tickets__rsvp-availability,
.tribe-tickets-rsvp .tribe-tickets-meta__remaining {
    font-size: 14px !important;
    color: var(--bb-content-secondary-text-color, #5b6975) !important;
    font-weight: 500;
}
/* X restant(s) en vert si disponible */
.tribe-tickets__rsvp-availability--available,
.tribe-tickets-rsvp__count {
    color: #2f9e44 !important;
    font-weight: 600 !important;
}

/* ─── 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;
    }
}

/* ============================================================
   v2.5.0 — Fiche single d'un prototype (bannière + accent)
   ============================================================ */
.meetles-proto-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0 0 20px;
  padding: 14px 18px;
  background: #fffbeb;
  border: 1px solid #fcd34d;
  border-left: 5px solid #f59e0b;
  border-radius: 10px;
  color: #92400e;
}
.meetles-proto-banner-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  background: #f59e0b;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  flex-shrink: 0;
}
.meetles-proto-banner-text {
  font-size: 15px;
  line-height: 1.5;
}

/* ============================================================
   v2.6.0 — Détails du prototype sur la fiche single
   ============================================================ */
.meetles-proto-details {
  margin: -8px 0 20px;
  padding: 12px 16px;
  background: #fffdf5;
  border: 1px solid #fde68a;
  border-radius: 10px;
}
.meetles-proto-dl { margin: 0; display: grid; gap: 6px; }
.meetles-proto-dl-row { display: flex; gap: 8px; flex-wrap: wrap; }
.meetles-proto-dl-row dt { font-weight: 700; color: #92400e; margin: 0; min-width: 190px; }
.meetles-proto-dl-row dd { margin: 0; color: #1f2937; }
.meetles-proto-feedback { margin: 10px 0 0; color: #1f2937; line-height: 1.55; }
