/* Solid'AM — Calendrier public (Event Calendar wrapper)
 * V1.12 §8.1+§8.2 — styles pour la barre de filtres + popover enrichi
 * + harmonisation visuelle Event Calendar avec les couleurs de marque.
 *
 * Les CSS variables --sa-cal-* sont injectées par PHP via un <style>
 * inline dans le shortcode (couleurs brand non disponibles côté front
 * via CSS vars admin).
 */

/* --- Wrapper principal -------------------------------------------------- */
.solidam-calendar-wrap {
  max-width: 1080px;
  margin: 30px auto;
  padding: 24px 28px;
  background: #ffffff;
  border: 1px solid #e6e8eb;
  border-radius: 14px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.04);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  box-sizing: border-box;
}
/* Pas de min-height — Event Calendar v5 calcule sa hauteur via
   l'option `height: 'auto'`. Imposer un min-height créerait juste
   un espace blanc sous le calendrier. */
.solidam-calendar-wrap #solidam-calendar { width: 100%; }

/* --- Barre de filtres -------------------------------------------------- */
.sa-cal-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 18px 24px;
  margin-bottom: 18px;
  padding: 14px 16px;
  background: #f7f9fa;
  border: 1px solid #e6e8eb;
  border-radius: 10px;
  font-size: 14px;
}
.sa-cal-filter-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
}
.sa-cal-filter-group strong {
  margin-right: 4px;
  color: #444;
  font-weight: 600;
}
.sa-cal-filter-group label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  user-select: none;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background-color .15s ease;
}
.sa-cal-filter-group label:hover {
  background: rgba(0,0,0,0.04);
}
.sa-cal-filter-group input[type="checkbox"] {
  margin: 0;
  accent-color: var(--sa-cal-accent, #5EBC67);
}
.sa-cal-type-dot {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,0.15);
  vertical-align: middle;
}

/* --- Fix : rangée fantôme en haut du dayGridMonth ----------------------
   Event Calendar v5 pose un `style="margin-bottom: NNpx"` inline sur
   <header class="ec-header"> au runtime pour réserver l'espace des
   events qui débordent au-dessus de la première rangée du grid (logique
   interne de la lib pour empiler les multi-day events sticky). En mode
   dayGridMonth tous nos events sont single-day et tiennent dans leur
   case → ce margin produit juste une bande vide entre l'en-tête des
   jours de la semaine et la première rangée. Comme l'inline style est
   posé par JS, on doit forcer avec !important. */
.solidam-calendar-wrap .ec-header {
  margin-bottom: 0 !important;
}

/* --- Event Calendar : harmonisation couleurs brand --------------------- */
.solidam-calendar-wrap .ec {
  --ec-button-bg-color: var(--sa-cal-accent, #5EBC67);
  --ec-button-active-bg-color: var(--sa-cal-primary, #4CAF50);
  --ec-button-text-color: #ffffff;
  --ec-button-hover-bg-color: var(--sa-cal-primary, #4CAF50);
  --ec-today-bg-color: rgba(94, 188, 103, 0.08);
  --ec-event-text-color: #ffffff;
  --ec-now-indicator-color: var(--sa-cal-primary, #4CAF50);
  font-family: inherit;
}

/* Boutons header propre + arrondis cohérents avec le reste du plugin */
.solidam-calendar-wrap .ec-toolbar {
  margin-bottom: 16px;
}
.solidam-calendar-wrap .ec-button {
  border-radius: 8px;
  font-weight: 500;
  padding: 6px 14px;
  transition: transform .12s ease, box-shadow .15s ease;
}
.solidam-calendar-wrap .ec-button:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 2px 6px var(--sa-cal-glow, rgba(94,188,103,0.25));
}
.solidam-calendar-wrap .ec-button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--sa-cal-glow, rgba(94,188,103,0.25));
}

/* --- Rendu compact des events dans les cellules dayGridMonth -----------
   Quand le titre est long (ex. "Distribution alimentaire mardi"), Event
   Calendar v5 le rend en gros texte qui chevauche l'heure et déborde
   visuellement. On compacte la taille + on tronque proprement avec
   ellipsis (le tooltip natif `title=""` posé par eventDidMount donne
   le titre complet au survol). */
.solidam-calendar-wrap .ec-event {
  padding: 2px 4px;
  font-size: 12px;
  line-height: 1.3;
  border-radius: 4px;
}
.solidam-calendar-wrap .ec-event-time {
  font-size: 11px;
  font-weight: 600;
  opacity: 0.85;
  margin-right: 4px;
}
.solidam-calendar-wrap .ec-event-title {
  font-weight: 500;
  font-size: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: block;
}
/* En vue agenda (listMonth), on autorise le wrap : la cellule est
   pleine largeur, donc tronquer n'a aucun intérêt. */
.solidam-calendar-wrap .ec-list .ec-event-title {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

/* --- Bouton « S'abonner au calendrier (.ics) » sous le calendrier ----
   V1.12 §8.5 — Affiché juste après le grid Event Calendar quand
   l'URL d'abonnement est disponible (cfg.subscribeUrl). */
.solidam-calendar-wrap .sa-cal-subscribe {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid #f0f0f0;
}
.solidam-calendar-wrap .sa-cal-subscribe__btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: var(--sa-cal-accent, #5EBC67);
  color: #ffffff !important;
  text-decoration: none !important;
  border-radius: 8px;
  font-weight: 500;
  font-size: 14px;
  transition: background-color .15s ease, transform .12s ease;
}
.solidam-calendar-wrap .sa-cal-subscribe__btn:hover {
  background: var(--sa-cal-primary, #4CAF50);
  transform: translateY(-1px);
}
.solidam-calendar-wrap .sa-cal-subscribe__btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--sa-cal-glow, rgba(94,188,103,0.25));
}
.solidam-calendar-wrap .sa-cal-subscribe__btn::before {
  content: "📅"; /* Icône simple, suffisante sans dépendance */
  font-size: 16px;
}
.solidam-calendar-wrap .sa-cal-subscribe__hint {
  color: #666;
  font-size: 13px;
}

/* --- Popover enrichi ---------------------------------------------------
   Structure DOM :
     .sa-cal-popover                ← root, fixed full-screen centerer
       .sa-cal-popover__backdrop    ← overlay sombre, sibling du panel
       .sa-cal-popover__panel       ← panel blanc en colonne
         .sa-cal-popover__header
         .sa-cal-popover__body
         .sa-cal-popover__footer    ← optionnel
   Le panel wrap header+body+footer pour qu'ils restent empilés en
   colonne (le root utilise flex pour centrer le panel à l'écran). */
.sa-cal-popover {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100000;
  padding: 16px;
  box-sizing: border-box;
}
.sa-cal-popover__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(20,30,42,0.55);
  cursor: pointer;
  z-index: 0;
}
.sa-cal-popover__panel {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 480px;
  background: #ffffff;
  border: 1px solid #e6e8eb;
  border-radius: 12px;
  box-shadow: 0 12px 36px rgba(0,0,0,0.18);
  overflow: hidden;
  box-sizing: border-box;
}
.sa-cal-popover__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 18px 12px;
  border-bottom: 1px solid #f0f0f0;
}
.sa-cal-popover__dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,0.15);
  flex: 0 0 auto;
}
.sa-cal-popover__title {
  margin: 0;
  flex: 1;
  font-size: 17px;
  font-weight: 600;
  color: #1d2327;
}
.sa-cal-popover__close {
  background: transparent;
  border: 0;
  font-size: 28px;
  line-height: 1;
  color: #666;
  cursor: pointer;
  padding: 0 4px;
  margin-left: 8px;
}
.sa-cal-popover__close:hover { color: #000; }
.sa-cal-popover__body {
  padding: 14px 18px 16px;
  font-size: 14px;
  color: #3c434a;
  line-height: 1.5;
}
.sa-cal-popover__row {
  margin-bottom: 8px;
}
.sa-cal-popover__row strong {
  color: #1d2327;
  font-weight: 600;
}
.sa-cal-popover__desc {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid #f0f0f0;
}
.sa-cal-popover__desc--empty {
  font-style: italic;
  color: #888;
}
.sa-cal-popover__footer {
  padding: 12px 18px 16px;
  text-align: right;
  border-top: 1px solid #f0f0f0;
}
.sa-cal-popover__add-cal {
  display: inline-block;
  background: var(--sa-cal-accent, #5EBC67);
  color: #ffffff !important;
  text-decoration: none !important;
  padding: 8px 16px;
  border-radius: 8px;
  font-weight: 500;
  font-size: 14px;
  transition: background-color .15s ease;
}
.sa-cal-popover__add-cal:hover {
  background: var(--sa-cal-primary, #4CAF50);
}

/* --- Responsive mobile ------------------------------------------------ */
@media (max-width: 768px) {
  .solidam-calendar-wrap {
    padding: 16px 12px;
    margin: 16px auto;
    border-radius: 12px;
  }
  /* Mobile : on laisse Event Calendar gérer la hauteur via height:'auto'. */
  .sa-cal-filters {
    padding: 10px 12px;
    gap: 10px 16px;
    font-size: 13px;
  }
  .sa-cal-popover__title { font-size: 16px; }
  .solidam-calendar-wrap .ec-toolbar {
    flex-wrap: wrap;
    gap: 8px;
  }
}
