/* ===== CD54 BILLARD - THE EVENTS CALENDAR STYLES ===== */
/* Version: 1.4.3 - Alignement emoji, texte informatif, nettoyage */
/* Configuration par défaut de The Events Calendar */

/* ============================================================
   1. RESET & OVERRIDES TRIBE EVENTS
   ============================================================ */

/* Reset des styles par défaut de Tribe */
.tribe-events,
.tribe-events-single,
.single-tribe_events {
  font-family: var(--cd54-font-body, 'Inter', sans-serif) !important;
}

/* Supprimer les bordures et backgrounds par défaut */
.tribe-events-single-event-title,
.tribe-events-schedule,
.tribe-events-meta-group,
.tribe-events-single-section-title {
  border: none !important;
  background: transparent !important;
}

/* ============================================================
   2. CONTAINER PRINCIPAL - ÉVÉNEMENT SINGLE
   ============================================================ */

/* Reset Astra pour les événements */
.single-tribe_events #primary,
.single-tribe_events .ast-container {
  max-width: 100% !important;
  padding: 0 !important;
}

.single-tribe_events .ast-article-single {
  background: transparent !important;
  padding: 0 !important;
  box-shadow: none !important;
}

/* ============================================================
   3. HEADER ÉVÉNEMENT - STYLE HERO
   ============================================================ */

/* Container header avec fond coloré */
.tribe-events-single > .tribe-events-back,
.tribe-events-single > .tribe-events-notices,
.tribe-events-single > .tribe-events-single-event-title,
.tribe-events-single > .tribe-events-schedule {
  position: relative;
  z-index: 2;
}

/* Wrapper pour le header - créé via pseudo-element */
.tribe-events-single {
  position: relative;
}

.tribe-events-single::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 320px;
  background: linear-gradient(
    165deg,
    rgba(254, 253, 251, 0.98) 0%,
    rgba(255, 255, 255, 0.98) 50%,
    rgba(248, 249, 252, 0.98) 100%
  );
  z-index: 0;
}

/* Contenu au-dessus du fond */
.tribe-events-single > * {
  position: relative;
  z-index: 1;
}

/* ============================================================
   4. NAVIGATION RETOUR
   ============================================================ */

.tribe-events-back {
  padding: 24px 0 16px !important;
  max-width: 1100px;
  margin: 0 auto;
}

.tribe-events-back a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: var(--cd54-text-secondary, #6B7280) !important;
  font-family: var(--cd54-font-body, 'Inter', sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  padding: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  transition: all 0.3s ease !important;
}

.tribe-events-back a::before {
  content: '←';
  font-size: 16px;
}

.tribe-events-back a:hover {
  color: var(--cd54-primary, #DD183B) !important;
  transform: translateX(-4px) !important;
}

/* ============================================================
   5. NOTICE "ÉVÉNEMENT PASSÉ"
   ============================================================ */

.tribe-events-notices {
  max-width: 1100px !important;
  margin: 0 auto 16px !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
}

.tribe-events-notices ul {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.tribe-events-notices li {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: rgba(245, 158, 11, 0.12) !important;
  color: #B45309 !important;
  padding: 10px 20px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
}

.tribe-events-notices li::before {
  content: '⏱';
  font-size: 14px;
}

/* ============================================================
   6. TITRE DE L'ÉVÉNEMENT
   ============================================================ */

.tribe-events-single-event-title {
  max-width: 1100px !important;
  margin: 0 auto 16px !important;
  padding: 0 !important;
  font-family: var(--cd54-font-heading, 'Outfit', sans-serif) !important;
  font-size: clamp(1.5rem, 3.5vw, 2rem) !important;
  font-weight: 700 !important;
  color: var(--cd54-text-dark, #1a1a2e) !important;
  line-height: 1.2 !important;
}

/* ============================================================
   7. DATE & HEURE
   ============================================================ */

.tribe-events-schedule {
  max-width: 1100px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 24px !important;
  flex-wrap: wrap !important;
}

.tribe-events-schedule h2 {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0 !important;
  font-family: var(--cd54-font-body, 'Inter', sans-serif) !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  color: var(--cd54-text-dark, #1F2937) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Séparateur après la date */
.tribe-events-schedule::after {
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background: var(--cd54-border-light, #E5E7EB);
  margin-top: 24px;
  flex-basis: 100%;
}

/* ============================================================
   8. CONTENU PRINCIPAL
   ============================================================ */

.tribe-events-single-event-description {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  position: relative !important;
}

/* Layout 2 colonnes (contenu 2/3 + carte 1/3) */
.cd54-two-columns {
  display: flex !important;
  gap: 24px !important;
  align-items: stretch !important; /* Étendre les colonnes sur toute la hauteur */
}

.cd54-content-col {
  flex: 2 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
}

.cd54-map-col {
  flex: 1 !important;
  position: relative !important;
  top: 110px !important;
  min-width: 320px !important;
  max-width: 400px !important;
  align-self: flex-start !important; /* Aligner en haut */
}

/* ============================================================
   GOOGLE MAPS - STYLES
   ============================================================ */

/* Wrapper externe - gère les coins arrondis et l'ombre */
.cd54-map-wrapper {
  border-radius: 16px !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1) !important;
  overflow: hidden !important;
  position: relative !important;
  /* Padding-top pour réserver de l'espace au marqueur/InfoWindow */
  padding-top: 60px !important;
  background: #e5e5e5 !important;
}

/* Conteneur de la carte - remonte dans le padding du wrapper */
.cd54-map-container {
  height: 600px !important;
  width: 100% !important;
  background: #e5e5e5 !important;
  position: relative !important;
  margin-top: -60px !important;
  /* Pas de border-radius ici - géré par le wrapper */
}

/* Forcer overflow visible sur les éléments Google Maps internes */
.cd54-map-container .gm-style,
.cd54-map-container .gm-style > div,
.cd54-map-container > div {
  overflow: visible !important;
}

/* S'assurer que le marqueur et l'InfoWindow sont au-dessus */
.cd54-map-container .gm-style-iw,
.cd54-map-container .gm-style-iw-c,
.cd54-map-container .gm-style-iw-t {
  z-index: 1000 !important;
}

/* ============================================================
   INFOWINDOW - DESIGN MODERNE
   ============================================================ */

/* Conteneur principal InfoWindow */
.cd54-map-container .gm-style-iw-c {
  padding: 0 !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18), 0 2px 8px rgba(0, 0, 0, 0.1) !important;
  border: none !important;
  overflow: visible !important;
}

/* Conteneur intérieur - IMPORTANT: pas de restriction de hauteur */
.cd54-map-container .gm-style-iw-d {
  overflow: visible !important;
  overflow-y: visible !important;
  overflow-x: visible !important;
  padding: 0 !important;
  max-height: none !important;
  height: auto !important;
}

/* Forcer le contenu à s'afficher entièrement */
.cd54-map-container .gm-style-iw,
.cd54-map-container .gm-style-iw-c,
.cd54-map-container .gm-style-iw-d,
.cd54-map-container .gm-style-iw-d > div {
  max-height: none !important;
  overflow: visible !important;
}

/* Bouton fermer (croix) - compact et élégant */
.cd54-map-container .gm-style-iw-c > button,
.cd54-map-container .gm-style-iw-c button.gm-ui-hover-effect,
.cd54-map-container button[aria-label="Fermer"],
.cd54-map-container button[aria-label="Close"] {
  position: absolute !important;
  top: 4px !important;
  right: 4px !important;
  width: 18px !important;
  height: 18px !important;
  background: rgba(255, 255, 255, 0.9) !important;
  border-radius: 50% !important;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15) !important;
  opacity: 1 !important;
  z-index: 9999 !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.15s ease !important;
  padding: 0 !important;
  border: none !important;
}

.cd54-map-container .gm-style-iw-c > button:hover,
.cd54-map-container .gm-style-iw-c button.gm-ui-hover-effect:hover,
.cd54-map-container button[aria-label="Fermer"]:hover,
.cd54-map-container button[aria-label="Close"]:hover {
  background: #fff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
  transform: scale(1.15) !important;
}

/* Icône de la croix - plus petite */
.cd54-map-container .gm-style-iw-c > button > span,
.cd54-map-container .gm-style-iw-c button.gm-ui-hover-effect > span {
  background-color: #555 !important;
  width: 10px !important;
  height: 10px !important;
  margin: 0 !important;
}

/* Flèche de l'InfoWindow */
.cd54-map-container .gm-style-iw-tc::after {
  background: #fff !important;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1) !important;
}

/* Masquer le fond blanc par défaut de Google */
.cd54-map-container .gm-style-iw-t::after {
  display: none !important;
}

/* ============================================================
   GOOGLE MAPS - MASQUER ÉLÉMENTS NON DÉSIRÉS (footer, attributions)
   ============================================================ */

/* Masquer le footer complet de Google Maps */
.cd54-map-wrapper .gm-style > div:last-child,
.cd54-map-wrapper .gmnoscreen,
.cd54-map-wrapper .gm-style-cc {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Masquer les liens d'attribution (sauf ceux dans l'InfoWindow) */
.cd54-map-wrapper a[href*="maps.google.com/maps"]:not(.gm-style-iw-d a),
.cd54-map-wrapper a[href*="terms"]:not(.gm-style-iw-d a),
.cd54-map-wrapper a[title*="Conditions"]:not(.gm-style-iw-d a),
.cd54-map-wrapper a[title*="conditions"]:not(.gm-style-iw-d a),
.cd54-map-wrapper a[title*="Google"]:not(.gm-style-iw-d a),
.cd54-map-wrapper .gm-style > div > div > div > a[href*="google"] {
  display: none !important;
}

/* Masquer le texte de copyright en bas */
.cd54-map-wrapper span[style*="background-image"],
.cd54-map-wrapper .gm-style span:has(a[href*="google"]) {
  display: none !important;
}

/* Fallback - masquer tous les éléments en bas de la carte */
.cd54-map-wrapper .gm-style > div > div:last-child > div:last-child {
  display: none !important;
}

/* Mobile : colonne unique */
@media (max-width: 991px) {
  .cd54-two-columns {
    flex-direction: column !important;
  }

  .cd54-map-col {
    position: static !important;
    max-width: 100% !important;
    width: 100% !important;
    order: -1 !important;
    margin-bottom: 24px !important;
  }

  .cd54-map-wrapper {
    padding-top: 40px !important; /* Moins d'espace sur mobile */
  }

  .cd54-map-container {
    height: 300px !important;
    margin-top: -40px !important;
  }
}

/* Titres dans le contenu */
.tribe-events-single-event-description h2,
.tribe-events-single-event-description h3,
.tribe-events-single-event-description h4 {
  font-family: var(--cd54-font-heading, 'Outfit', sans-serif) !important;
  color: var(--cd54-text-dark, #1F2937) !important;
  margin-top: 32px !important;
  margin-bottom: 16px !important;
}

/* Alignement emoji UNIQUEMENT dans le premier paragraphe (Convocation officielle) */
.cd54-content-col > p:first-child img.emoji {
  position: relative !important;
  top: 1.9rem !important;
  margin-right: 8px !important;
  width: 28px !important;
  height: 28px !important;
  max-width: none !important;
  min-width: 28px !important;
  min-height: 28px !important;
}

.tribe-events-single-event-description h2 {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
}

.tribe-events-single-event-description h2::before {
  content: '';
  width: 4px;
  height: 24px;
  background: var(--cd54-primary, #DD183B);
  border-radius: 2px;
}

.tribe-events-single-event-description h3 {
  font-size: 1.25rem !important;
  font-weight: 600 !important;
}

/* Paragraphes */
.tribe-events-single-event-description p {
  font-size: 1.05rem !important;
  line-height: 1.8 !important;
  color: var(--cd54-text-dark, #374151) !important;
  margin-bottom: 1.25em !important;
}

/* Listes */
.tribe-events-single-event-description ul,
.tribe-events-single-event-description ol {
  margin: 1.5em 0 !important;
  padding-left: 0 !important;
  list-style: none !important;
}

.tribe-events-single-event-description li {
  position: relative !important;
  padding-left: 28px !important;
  margin-bottom: 12px !important;
  line-height: 1.6 !important;
}

.tribe-events-single-event-description ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  background: var(--cd54-primary, #DD183B);
  border-radius: 50%;
}

.tribe-events-single-event-description ol {
  counter-reset: item;
}

.tribe-events-single-event-description ol li::before {
  content: counter(item);
  counter-increment: item;
  position: absolute;
  left: 0;
  top: 0;
  width: 24px;
  height: 24px;
  background: var(--cd54-primary, #DD183B);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Liens */
.tribe-events-single-event-description a {
  color: var(--cd54-primary, #DD183B) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
  border-bottom: 2px solid rgba(221, 24, 59, 0.3) !important;
  transition: all 0.2s ease !important;
}

.tribe-events-single-event-description a:hover {
  border-bottom-color: var(--cd54-primary, #DD183B) !important;
}

/* ============================================================
   BOUTONS PDF - Géré par JavaScript (fallback CSS)
   ============================================================ */
/* NOTE: Les styles inline sont appliqués par JS dans functions.php.
   CSS ci-dessous = fallback et structure de base uniquement */

.tribe-events-single-event-description .wp-block-file,
.cd54-content-col .wp-block-file {
  margin: 24px 0 !important;
}

/* Fallback : styles de base si JS ne charge pas */
.tribe-events-single-event-description a[href$=".pdf"],
.cd54-content-col a[href$=".pdf"],
.tribe-events-single-event-description a[href*="drive.google.com"],
.cd54-content-col a[href*="drive.google.com"],
.tribe-events-single-event-description .wp-block-file a,
.cd54-content-col .wp-block-file a {
  text-decoration: none !important;
  border-bottom: none !important;
  cursor: pointer !important;
}

/* Images dans le contenu */
.tribe-events-single-event-description img {
  max-width: 100% !important;
  height: auto !important;
  border-radius: 16px !important;
  margin: 24px 0 !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1) !important;
}

/* Reset pour les images Google Maps (ne pas hériter des styles ci-dessus) */
.cd54-map-wrapper img,
.cd54-map-container img,
.gm-style img {
  margin: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  max-width: none !important;
  height: auto !important;
}

/* Supprimer les ombres sur les tuiles et éléments internes de Google Maps */
.cd54-map-container *,
.cd54-map-container .gm-style *,
.cd54-map-container .gm-style > div,
.cd54-map-container .gm-style > div > div {
  box-shadow: none !important;
}

/* Images cassées - masquer */
.tribe-events-single-event-description img[src=""],
.tribe-events-single-event-description img:not([src]) {
  display: none !important;
}

/* ============================================================
   9. MÉTADONNÉES - GRILLE MODERNE
   ============================================================ */

/* Container des métadonnées - 2 colonnes pleine largeur */
.tribe-events-event-meta {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 0 0 48px !important;
  background: transparent !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
}

/* Override TEC : forcer pleine largeur des colonnes */
@media (min-width: 768px) {
  .tribe-events-event-meta.primary,
  .tribe-events-event-meta.secondary {
    width: 100% !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    position: static !important;
  }
}

/* Supprimer les bordures doubles TEC */
.tribe-events-event-meta,
.tribe-events-event-meta::before,
.tribe-events-event-meta::after {
  border: none !important;
}

/* Carte métadonnée individuelle */
.tribe-events-meta-group {
  background: #fff !important;
  border-radius: 20px !important;
  padding: 24px !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06) !important;
  border: 1px solid rgba(0, 0, 0, 0.04) !important;
  transition: all 0.3s ease !important;
  width: 100% !important;
}

/* Carte Venue Map */
.tribe-events-venue-map {
  border-radius: 16px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1) !important;
  order: -1;
  width: 100%;
}

@media (min-width: 768px) {
  .tribe-events-venue-map {
    order: 1;
    width: 100%;
  }

  .tribe-events-venue-map > div,
  .tribe-events-venue-map > iframe {
    max-height: 270px;
    height: 270px;
  }
}

.tribe-events-meta-group:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1) !important;
}

/* Titre de section (DÉTAILS, LIEU, ORGANISATEUR) */
.tribe-events-single-section-title {
  font-family: var(--cd54-font-heading, 'Outfit', sans-serif) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 1.5px !important;
  color: var(--cd54-primary, #DD183B) !important;
  margin: 0 0 20px 0 !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid rgba(221, 24, 59, 0.15) !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

/* Icônes pour les titres de section */
.tribe-events-meta-group.tribe-events-meta-group-details .tribe-events-single-section-title::before {
  content: '📋';
  font-size: 16px;
}

.tribe-events-meta-group.tribe-events-meta-group-venue .tribe-events-single-section-title::before {
  content: '📍';
  font-size: 16px;
}

.tribe-events-meta-group.tribe-events-meta-group-organizer .tribe-events-single-section-title::before {
  content: '👤';
  font-size: 16px;
}

/* Labels (Date:, Heure:, etc.) */
.tribe-events-meta-group dt {
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--cd54-text-secondary, #6B7280) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  margin-bottom: 4px !important;
}

/* Valeurs */
.tribe-events-meta-group dd {
  font-size: 15px !important;
  font-weight: 500 !important;
  color: var(--cd54-text-dark, #1F2937) !important;
  margin: 0 0 16px 0 !important;
  padding: 0 !important;
}

.tribe-events-meta-group dd:last-child {
  margin-bottom: 0 !important;
}

/* Liens dans les métadonnées */
.tribe-events-meta-group a {
  color: var(--cd54-text-dark, #1F2937) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}

.tribe-events-meta-group a:hover {
  color: var(--cd54-primary, #DD183B) !important;
}

/* Catégories stylées en tags */
.tribe-events-event-categories {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 4px !important;
}

.tribe-events-event-categories a {
  display: inline-block !important;
  background: linear-gradient(135deg, rgba(221, 24, 59, 0.1), rgba(221, 24, 59, 0.05)) !important;
  color: var(--cd54-primary, #DD183B) !important;
  padding: 6px 14px !important;
  border-radius: 20px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  border: 1px solid rgba(221, 24, 59, 0.2) !important;
  transition: all 0.2s ease !important;
}

.tribe-events-event-categories a:hover {
  background: var(--cd54-primary, #DD183B) !important;
  color: #fff !important;
  transform: scale(1.05) !important;
}

/* ============================================================
   10. LIEN GOOGLE MAPS
   ============================================================ */

/* Lien Google Maps */
.tribe-events-gmap {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-top: 12px !important;
  padding: 8px 16px !important;
  background: rgba(221, 24, 59, 0.08) !important;
  color: var(--cd54-primary, #DD183B) !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: all 0.2s ease !important;
}

.tribe-events-gmap::before {
  content: '🗺️';
}

.tribe-events-gmap:hover,
.tribe-events-meta-group-venue .tribe-events-gmap:hover,
a.tribe-events-gmap:hover {
  background: var(--cd54-primary-dark, #b81432) !important;
  color: #fff !important;
  text-decoration: none !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 12px rgba(221, 24, 59, 0.3) !important;
}

/* Format adresse venue structuré (format français) :
   Adresse 1
   Adresse 2 (si présente)
   54310 HOMECOURT France    [+ Google Map]
*/
.tribe-events-meta-group-venue .tribe-address {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: baseline !important;
}

/* Rue (adresse 1) - sur sa propre ligne (100% largeur) */
.tribe-events-meta-group-venue .tribe-street-address {
  flex: 0 0 100% !important;
  margin-bottom: 4px !important;
}

/* Adresse 2 (si présente) - sur sa propre ligne */
.tribe-events-meta-group-venue .tribe-address2 {
  flex: 0 0 100% !important;
  margin-bottom: 4px !important;
}

/* Supprimer TOUTES les virgules TEC sur l'adresse */
.tribe-events-meta-group-venue .tribe-address span::before,
.tribe-events-meta-group-venue .tribe-locality::before,
.tribe-events-meta-group-venue .tribe-postal-code::before,
.tribe-events-meta-group-venue .tribe-region::before,
.tribe-events-meta-group-venue .tribe-country-name::before {
  content: none !important;
  display: none !important;
}

/* Réordonner : Code postal (1) - Ville (2) - Pays (3) */
.tribe-events-meta-group-venue .tribe-postal-code {
  order: 1 !important;
}

.tribe-events-meta-group-venue .tribe-postal-code::after {
  content: '\00a0' !important; /* espace insécable */
}

.tribe-events-meta-group-venue .tribe-locality {
  order: 2 !important;
}

.tribe-events-meta-group-venue .tribe-locality::after {
  content: '\00a0' !important; /* espace après ville */
}

.tribe-events-meta-group-venue .tribe-country-name {
  order: 3 !important;
}

/* Container venue - position relative pour le lien Google Map */
.tribe-events-meta-group-venue {
  position: relative !important;
}

/* Lien Google Map - positionné en bas à droite de l'adresse */
.tribe-events-meta-group-venue .tribe-events-gmap {
  position: absolute !important;
  right: 24px !important;
  bottom: 60px !important; /* Au niveau de la ligne CP Ville Pays */
}

/* ============================================================
   11. BOUTON AJOUTER AU CALENDRIER - Géré par JavaScript
   ============================================================ */
/* NOTE: Le positionnement et le style sont gérés dynamiquement par JS
   dans functions.php (section TEC Layout). CSS ci-dessous = fallback */

/* Nouvelle structure TEC : .tribe-events-c-subscribe-dropdown */
.tribe-events-c-subscribe-dropdown {
  margin: 0 !important;
  padding: 0 !important;
}

.tribe-events-c-subscribe-dropdown__button {
  cursor: pointer !important;
}

/* Ancienne structure (compatibilité) */
.tribe-events-cal-links {
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

.tribe-events-cal-links::before {
  display: none !important;
}

/* ============================================================
   12. NAVIGATION ÉVÉNEMENTS (PRÉCÉDENT/SUIVANT)
   ============================================================ */

.tribe-events-nav-pagination {
  max-width: 1100px !important;
  margin: 0 auto !important;
  padding: 32px 0 56px !important;
  background: transparent !important;
  border-radius: 0 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 16px !important;
  border-top: none !important;
}

.tribe-events-nav-pagination a {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 16px 24px !important;
  background: #fff !important;
  color: var(--cd54-text-dark, #1F2937) !important;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 12px !important;
  font-family: var(--cd54-font-body, 'Inter', sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  transition: all 0.3s ease !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04) !important;
  max-width: 100% !important;
}

.tribe-events-nav-pagination a:hover {
  border-color: var(--cd54-primary, #DD183B) !important;
  color: var(--cd54-primary, #DD183B) !important;
  box-shadow: 0 4px 16px rgba(221, 24, 59, 0.15) !important;
  transform: translateY(-2px) !important;
}

.tribe-events-nav-previous a::before {
  content: '←';
  font-size: 18px;
  color: var(--cd54-primary, #DD183B);
}

.tribe-events-nav-next a::after {
  content: '→';
  font-size: 18px;
  color: var(--cd54-primary, #DD183B);
}

/* Sub-nav responsive */
@media (min-width: 768px) {
  .tribe-events-single .tribe-events-sub-nav {
    font-size: var(--tec-font-size-3);
    width: 100%;
  }
}

/* ============================================================
   13. VUE LISTE DES ÉVÉNEMENTS
   ============================================================ */

/* Header liste */
.tribe-events-header {
  max-width: 1100px !important;
  margin: 0 auto 32px !important;
  padding: 32px 24px !important;
}

.tribe-events-header__title {
  font-family: var(--cd54-font-heading, 'Outfit', sans-serif) !important;
  font-size: 2.25rem !important;
  font-weight: 700 !important;
  color: var(--cd54-text-dark, #1F2937) !important;
  position: relative !important;
  display: inline-block !important;
}

.tribe-events-header__title::after {
  content: '';
  position: absolute;
  bottom: -8px;
  left: 0;
  width: 60px;
  height: 4px;
  background: var(--cd54-primary, #DD183B);
  border-radius: 2px;
}

/* Carte événement dans la liste */
.tribe-events-calendar-list__event {
  max-width: 1100px !important;
  margin: 0 auto 24px !important;
  background: #fff !important;
  border-radius: 20px !important;
  padding: 0 !important;
  overflow: hidden !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06) !important;
  border: 1px solid rgba(0, 0, 0, 0.04) !important;
  transition: all 0.3s ease !important;
  display: flex !important;
  align-items: stretch !important;
}

.tribe-events-calendar-list__event:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.12) !important;
}

/* Badge date à gauche */
.tribe-events-calendar-list__event-date-tag {
  background: linear-gradient(135deg, var(--cd54-primary, #DD183B), #E8304F) !important;
  color: #fff !important;
  padding: 24px 20px !important;
  min-width: 100px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.tribe-events-calendar-list__event-date-tag-month {
  font-size: 11px !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  opacity: 0.9 !important;
}

.tribe-events-calendar-list__event-date-tag-daynum {
  font-size: 36px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  margin: 4px 0 !important;
}

/* Contenu de la carte */
.tribe-events-calendar-list__event-wrapper {
  flex: 1 !important;
  padding: 24px 28px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

/* Titre événement */
.tribe-events-calendar-list__event-title {
  font-family: var(--cd54-font-heading, 'Outfit', sans-serif) !important;
  font-size: 1.35rem !important;
  font-weight: 600 !important;
  margin: 0 0 8px 0 !important;
}

.tribe-events-calendar-list__event-title a {
  color: var(--cd54-text-dark, #1F2937) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}

.tribe-events-calendar-list__event:hover .tribe-events-calendar-list__event-title a {
  color: var(--cd54-primary, #DD183B) !important;
}

/* Détails événement (heure, lieu) */
.tribe-events-calendar-list__event-datetime-wrapper,
.tribe-events-calendar-list__event-venue {
  font-size: 14px !important;
  color: var(--cd54-text-secondary, #6B7280) !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-top: 4px !important;
}

/* ============================================================
   14. VUE CALENDRIER MOIS
   ============================================================ */

.tribe-events-calendar-month {
  max-width: 1100px !important;
  margin: 0 auto !important;
}

.tribe-events-calendar-month__calendar {
  border-radius: 20px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08) !important;
  border: 1px solid rgba(0, 0, 0, 0.04) !important;
}

/* En-têtes jours de la semaine */
.tribe-events-calendar-month__header-column {
  background: linear-gradient(135deg, var(--cd54-primary, #DD183B), #E8304F) !important;
  color: #fff !important;
  font-family: var(--cd54-font-heading, 'Outfit', sans-serif) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  padding: 16px 8px !important;
}

/* Cellules du calendrier */
.tribe-events-calendar-month__day {
  background: #fff !important;
  border-color: rgba(0, 0, 0, 0.06) !important;
  min-height: 100px !important;
  transition: background 0.2s ease !important;
}

.tribe-events-calendar-month__day:hover {
  background: rgba(221, 24, 59, 0.02) !important;
}

/* Jour avec événement */
.tribe-events-calendar-month__day--has-events {
  background: rgba(221, 24, 59, 0.04) !important;
}

/* Indicateur d'événement */
.tribe-events-calendar-month__calendar-event-indicator {
  background: var(--cd54-primary, #DD183B) !important;
  width: 8px !important;
  height: 8px !important;
}

/* ============================================================
   15. RESPONSIVE
   ============================================================ */

@media (max-width: 992px) {
  .tribe-events-single-event-description,
  .tribe-events-event-meta,
  .tribe-events-cal-links,
  .tribe-events-nav-pagination {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .tribe-events-event-meta {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 782px) {
  .tribe-events-single-event-title {
    font-size: 1.35rem !important;
    padding: 0 16px !important;
  }

  .tribe-events-schedule {
    padding: 0 16px !important;
  }

  .tribe-events-back {
    padding: 20px 16px 12px !important;
  }

  .tribe-events-notices {
    margin-left: 16px !important;
    margin-right: 16px !important;
  }

  .tribe-events-single-event-description,
  .tribe-events-event-meta,
  .tribe-events-cal-links,
  .tribe-events-nav-pagination {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .tribe-events-nav-pagination {
    flex-direction: column !important;
  }

  .tribe-events-nav-pagination a {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
  }

  /* Liste événements mobile */
  .tribe-events-calendar-list__event {
    flex-direction: column !important;
    margin-left: 12px !important;
    margin-right: 12px !important;
  }

  .tribe-events-calendar-list__event-date-tag {
    flex-direction: row !important;
    gap: 8px !important;
    padding: 16px 20px !important;
    min-width: auto !important;
  }

  .tribe-events-calendar-list__event-date-tag-daynum {
    font-size: 24px !important;
  }
}

@media (max-width: 544px) {
  .tribe-events-single-event-title {
    font-size: 1.25rem !important;
  }

  .tribe-events-single-event-description h2 {
    font-size: 1.25rem !important;
  }

  .tribe-events-meta-group {
    padding: 20px !important;
  }

  .tribe-events-cal-links a {
    width: 100% !important;
    padding: 14px 24px !important;
  }
}

/* ============================================================
   16. ACCESSIBILITÉ
   ============================================================ */

.tribe-events-single a:focus,
.tribe-events-nav-pagination a:focus,
.tribe-events-calendar-list__event-title a:focus {
  outline: 3px solid var(--cd54-primary, #DD183B) !important;
  outline-offset: 3px !important;
}

/* Améliorer le contraste pour les textes sur fond sombre */
@media (prefers-contrast: more) {
  .tribe-events-single-event-title,
  .tribe-events-schedule h2,
  .tribe-events-back a {
    text-shadow: none !important;
  }
}

/* ============================================================
   17. PRINT STYLES
   ============================================================ */

@media print {
  .tribe-events-single::before {
    display: none !important;
  }

  .tribe-events-single-event-title {
    color: #000 !important;
  }

  .tribe-events-nav-pagination,
  .tribe-events-cal-links,
  .tribe-events-back {
    display: none !important;
  }
}
