﻿.events-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 25px 15px;
}

.events-intro {
  text-align: center;
  margin-bottom: 30px;
}

.events-intro h2 {
  color: #004080;
  font-size: 34px;
  margin-bottom: 10px;
  font-family: "Roboto", Arial, sans-serif;
}

.events-intro p {
  font-size: 18px;
  line-height: 1.7;
}

/* =========================
   EVENT PRINCIPAL
========================= */

.event-featured-card {
  background: white;
  border-radius: 14px;
  padding: 24px;
  margin-bottom: 35px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.12);
  border: 1px solid rgba(0,0,0,0.08);
}

.event-featured-date {
  background: #004080;
  color: white;
  padding: 14px;
  border-radius: 10px;
  text-align: center;
  margin-bottom: 20px;
}

.event-featured-date span {
  display: block;
  font-size: 42px;
  font-weight: bold;
}

.event-featured-date small {
  display: block;
  font-size: 18px;
  margin-top: 5px;
}

.event-featured-date strong {
  display: block;
  margin-top: 10px;
  font-size: 22px;
}

.event-featured-content h3 {
  color: #004080;
  font-size: 30px;
  margin-top: 0;
}

.event-featured-content p {
  font-size: 18px;
  line-height: 1.8;
}

.event-location-box {
  background: #eef5ff;
  padding: 18px;
  border-left: 5px solid #004080;
  border-radius: 8px;
  margin-top: 20px;
}

.event-featured-image {
  margin-top: 25px;
}

.event-featured-image img {
  width: 100%;
  max-width: 500px;
  display: block;
  margin: 0 auto;
  border-radius: 12px;
  box-shadow: 0 4px 14px rgba(0,0,0,0.16);
}

/* =========================
   HISTORIQUE
========================= */

.events-history h3 {
  color: #004080;
  font-size: 30px;
  margin-bottom: 20px;
}

.event-history-grid {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.event-history-card {
  background: white;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,0.10);
  border: 1px solid rgba(0,0,0,0.08);
}

.event-history-image img {
  width: 100%;
  max-height: 350px;
  object-fit: cover;
  display: block;
}

.event-history-content {
  padding: 20px;
}

.event-badge {
  display: inline-block;
  background: #004080;
  color: white;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 14px;
  margin-bottom: 12px;
}

.event-history-content h4 {
  margin-top: 0;
  color: #004080;
  font-size: 24px;
}

.event-history-content p {
  font-size: 17px;
  line-height: 1.7;
}

/* =========================
   MOBILE
========================= */

@media (max-width: 768px) {

  .events-page {
    padding: 18px 10px;
  }

  .events-intro h2 {
    font-size: 28px;
  }

  .event-featured-content h3 {
    font-size: 25px;
  }

  .event-featured-content p {
    font-size: 17px;
    text-align: left;
  }

}

/* =========================
   REMERCIEMENTS EVENEMENTS
========================= */

.event-thanks {
  margin-top: 10px;
  padding: 12px;
  background: #fff7e6;
  border-left: 4px solid #f0b400;
  border-radius: 6px;
  color: #7a5a00;
  font-style: italic;
  font-size: 16px;
  line-height: 1.6;
}


.event-thanks {
  margin-top: 12px;
  padding: 10px 14px;
  background: #f3f3f3;
  border-left: 4px solid #888;
  border-radius: 6px;
  color: #444;
  font-weight: bold;
  font-size: 15px;
}


/* Bouton Google Maps */
.event-maps-button {

  display: inline-flex;
  align-items: center;
  gap: 8px;

  margin-top: 16px;

  padding: 12px 18px;

  background: #d93025;

  color: #ffffff !important;

  text-decoration: none;

  border-radius: 10px;

  font-weight: 700;

  font-size: 16px;

  box-shadow:
    0 4px 12px rgba(0,0,0,.15);

  transition:
    transform .18s ease,
    background .18s ease;

}

.event-maps-button:hover {

  background: #b3261e;

  transform: translateY(-2px);

}

@media (max-width: 768px) {

  .event-maps-button {

    width: 100%;

    justify-content: center;

    text-align: center;

    font-size: 15px;

  }

}


/* FORÇAGE bouton Google Maps propre */
.event-location-box .event-maps-button {
  display: block !important;
  width: fit-content !important;
  max-width: 100% !important;

  margin-top: 18px !important;
  padding: 13px 18px !important;

  background: #ffffff !important;
  color: #004080 !important;

  border: 2px solid #004080 !important;
  border-radius: 8px !important;

  text-decoration: none !important;
  font-weight: 900 !important;
  font-size: 16px !important;
  line-height: 1.4 !important;

  box-shadow: 0 3px 10px rgba(0,0,0,0.12) !important;
}

.event-location-box .event-maps-button:hover {
  background: #004080 !important;
  color: #ffffff !important;
}

@media (max-width: 768px) {
  .event-location-box .event-maps-button {
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
  }
}


/* Petit bouton Maps discret sous le texte */
.event-location-box .event-maps-button {

  display: inline-flex !important;

  align-items: center !important;

  justify-content: center !important;

  margin-top: 10px !important;

  padding: 7px 12px !important;

  font-size: 12px !important;

  font-weight: 700 !important;

  width: auto !important;

  max-width: 100% !important;

  border-radius: 6px !important;

  line-height: 1.2 !important;

}

@media (max-width: 768px) {

  .event-location-box .event-maps-button {

    font-size: 11px !important;

    padding: 6px 10px !important;

  }

}


/* Retire anciens pictos/animations */
.event-featured-date-inline::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: -10px !important;
  border-radius: 999px !important;
  pointer-events: none !important;

  background:
    radial-gradient(circle at 4% 50%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 12% 8%, #fff3b0 0 4px, transparent 5px),
    radial-gradient(circle at 24% 0%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 38% -2%, #fff3b0 0 4px, transparent 5px),
    radial-gradient(circle at 52% -2%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 66% 0%, #fff3b0 0 4px, transparent 5px),
    radial-gradient(circle at 80% 8%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 96% 50%, #fff3b0 0 4px, transparent 5px),
    radial-gradient(circle at 80% 92%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 66% 100%, #fff3b0 0 4px, transparent 5px),
    radial-gradient(circle at 52% 102%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 38% 100%, #fff3b0 0 4px, transparent 5px),
    radial-gradient(circle at 24% 100%, #ffd66b 0 4px, transparent 5px),
    radial-gradient(circle at 12% 92%, #fff3b0 0 4px, transparent 5px);

  filter: drop-shadow(0 0 5px rgba(255, 207, 86, .95));
}

.event-featured-date-inline::after {
  content: "" !important;
  position: absolute !important;
  inset: -10px !important;
  border-radius: 999px !important;
  border: 2px dashed rgba(255, 214, 107, .55) !important;
  pointer-events: none !important;
  animation: none !important;
}

@media (max-width: 768px) {
  .event-featured-date-inline {
    gap: 8px !important;
    padding: 15px 18px !important;
  }

  .event-featured-date-inline span {
    font-size: 17px !important;
  }

  .event-featured-date-inline strong {
    font-size: 16px !important;
    padding: 6px 8px !important;
  }
}


/* Supprime anciens effets */
.event-featured-date-inline::before,
.event-featured-date-inline::after {

  content: none !important;

}

/* Halo lumineux doux */
.event-featured-date-inline {

  box-shadow:
    0 0 12px rgba(255,255,255,.55),
    0 0 24px rgba(255,214,107,.45),
    0 0 38px rgba(255,214,107,.28) !important;

  animation: haloBlink 2.4s ease-in-out infinite !important;

}

@keyframes haloBlink {

  0% {

    box-shadow:
      0 0 8px rgba(255,255,255,.35),
      0 0 18px rgba(255,214,107,.20),
      0 0 28px rgba(255,214,107,.12);

  }

  50% {

    box-shadow:
      0 0 18px rgba(255,255,255,.90),
      0 0 34px rgba(255,214,107,.70),
      0 0 52px rgba(255,214,107,.45);

  }

  100% {

    box-shadow:
      0 0 8px rgba(255,255,255,.35),
      0 0 18px rgba(255,214,107,.20),
      0 0 28px rgba(255,214,107,.12);

  }

}


/* Taille originale */
.event-featured-date-inline span {

  font-size: 24px !important;

  font-weight: 900 !important;

  color: #ffffff !important;

}

.event-featured-date-inline strong {

  font-size: 22px !important;

  font-weight: 900 !important;

  background: #ffffff !important;

  color: #004080 !important;

  padding: 7px 11px !important;

  border-radius: 8px !important;

}

/* Halo BLANC */
.event-featured-date-inline {

  box-shadow:
    0 0 10px rgba(255,255,255,.35),
    0 0 22px rgba(255,255,255,.28),
    0 0 38px rgba(255,255,255,.18) !important;

  animation: haloWhiteBlink 2.2s ease-in-out infinite !important;

}

@keyframes haloWhiteBlink {

  0% {

    box-shadow:
      0 0 8px rgba(255,255,255,.18),
      0 0 18px rgba(255,255,255,.12),
      0 0 28px rgba(255,255,255,.08);

  }

  50% {

    box-shadow:
      0 0 18px rgba(255,255,255,.70),
      0 0 34px rgba(255,255,255,.52),
      0 0 54px rgba(255,255,255,.34);

  }

  100% {

    box-shadow:
      0 0 8px rgba(255,255,255,.18),
      0 0 18px rgba(255,255,255,.12),
      0 0 28px rgba(255,255,255,.08);

  }

}

/* Mobile */
@media (max-width: 768px) {

  .event-featured-date-inline {

    padding: 14px 18px !important;

    gap: 8px !important;

  }

  .event-featured-date-inline span {

    font-size: 18px !important;

  }

  .event-featured-date-inline strong {

    font-size: 16px !important;

  }

}


/* =========================================
   VERSION FINALE DATE EVENEMENT
   Bande longue + halo blanc clignotant
========================================= */

.event-featured-date-inline {
  position: relative !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 14px !important;

  width: 100% !important;
  max-width: 520px !important;

  margin: 0 auto 28px auto !important;
  padding: 18px 26px !important;

  border-radius: 999px !important;
  background: linear-gradient(135deg, #004080, #0066cc) !important;

  overflow: visible !important;

  animation: haloFinalWhite 2.6s ease-in-out infinite !important;

  box-shadow:
    0 0 8px rgba(255,255,255,.18),
    0 0 20px rgba(255,255,255,.16),
    0 0 36px rgba(255,255,255,.10) !important;
}

/* Supprime les anciens pictos, calendrier, guirlandes */
.event-featured-date-inline::before,
.event-featured-date-inline::after {
  content: none !important;
  display: none !important;
}

.event-featured-date-inline span {
  display: inline-block !important;
  margin: 0 !important;

  color: #ffffff !important;
  font-size: 26px !important;
  font-weight: 900 !important;
  line-height: 1 !important;

  text-transform: uppercase !important;
}

.event-featured-date-inline strong {
  display: inline-block !important;
  margin: 0 !important;

  color: #004080 !important;
  background: #ffffff !important;

  padding: 7px 14px !important;
  border-radius: 8px !important;

  font-size: 22px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

@keyframes haloFinalWhite {
  0% {
    box-shadow:
      0 0 8px rgba(255,255,255,.12),
      0 0 18px rgba(255,255,255,.10),
      0 0 30px rgba(255,255,255,.06);
  }

  50% {
    box-shadow:
      0 0 18px rgba(255,255,255,.55),
      0 0 34px rgba(255,255,255,.38),
      0 0 58px rgba(255,255,255,.24);
  }

  100% {
    box-shadow:
      0 0 8px rgba(255,255,255,.12),
      0 0 18px rgba(255,255,255,.10),
      0 0 30px rgba(255,255,255,.06);
  }
}

@media (max-width: 768px) {
  .event-featured-date-inline {
    max-width: 100% !important;
    padding: 14px 18px !important;
    gap: 8px !important;
  }

  .event-featured-date-inline span {
    font-size: 18px !important;
  }

  .event-featured-date-inline strong {
    font-size: 16px !important;
    padding: 6px 8px !important;
  }
}


/* Correction forme date : rectangle arrondi léger, pas pilule */
.event-featured-date-inline {
  border-radius: 12px !important;
  max-width: 620px !important;
  padding: 18px 30px !important;
}

