/* =============================================================
   Composants UI v2.0 — Boutons, Hero, Cards, Sections…
   ============================================================= */

/* ─── Boutons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--w-semibold);
  line-height: 1;
  border: 2px solid transparent;
  border-radius: var(--r-full);
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--t);
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0);
  transition: background var(--t-fast);
}
.btn:hover::before { background: rgba(255,255,255,.08); }
.btn:active::before { background: rgba(0,0,0,.08); }

/* Primaire */
.btn--primary {
  background: var(--gradient-primary);
  color: #fff;
  box-shadow: var(--shadow-btn);
}
.btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-btn-hover);
  color: #fff;
}
.btn--primary:active { transform: translateY(0); }

/* Outline blanc */
.btn--outline-white {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.35);
  color: #fff;
  backdrop-filter: blur(8px);
}
.btn--outline-white:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.6);
  color: #fff;
  transform: translateY(-2px);
}

/* Outline bleu */
.btn--outline {
  background: transparent;
  border-color: var(--primary);
  color: var(--primary);
}
.btn--outline:hover {
  background: var(--primary-light);
  transform: translateY(-1px);
}

/* Or/gold */
.btn--gold {
  background: var(--gradient-gold);
  color: var(--gray-900);
  font-weight: var(--w-bold);
  box-shadow: 0 2px 10px rgba(201,130,0,.30);
}
.btn--gold:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(201,130,0,.40);
  color: var(--gray-900);
}

/* Ghost */
.btn--ghost {
  background: var(--gray-100);
  color: var(--text);
  border-color: transparent;
}
.btn--ghost:hover { background: var(--gray-200); }

/* Tailles */
.btn--sm { padding: var(--s-2) var(--s-4); font-size: var(--text-xs); }
.btn--lg { padding: var(--s-4) var(--s-8); font-size: var(--text-base); }
.btn--xl { padding: var(--s-5) var(--s-10); font-size: var(--text-lg); }

/* ─── Badge / Étiquette ───────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 3px var(--s-3);
  font-size: var(--text-xs);
  font-weight: var(--w-bold);
  border-radius: var(--r-full);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  white-space: nowrap;
  line-height: 1.4;
}
.badge--primary { background: var(--primary-light); color: var(--primary); }
.badge--gold    { background: var(--accent-light);  color: var(--accent-dark); }
.badge--success { background: #dcfce7; color: #15803d; }
.badge--gray    { background: var(--gray-100); color: var(--gray-600); }
.badge--white   { background: rgba(255,255,255,.15); color: #fff; }

/* ─── Hero ────────────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 90svh;
  min-height: 90vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--gradient-hero);
}

@media (min-width: 768px)  { .hero { min-height: 85vh; } }
@media (min-width: 1280px) { .hero { min-height: 80vh; } }

/* Photo de fond */
.hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  transition: transform 12s linear;
}
.hero:hover .hero__bg { transform: scale(1.04); }

/* Overlay en dégradé */
.hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(0deg, rgba(5,17,31,.95) 0%, rgba(5,17,31,.6) 50%, rgba(5,17,31,.2) 100%),
    radial-gradient(ellipse 70% 55% at 75% 40%, rgba(30,90,170,.22) 0%, transparent 60%);
}

/* Décoration géométrique */
.hero__deco {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
}
.hero__deco::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 65vmin;
  height: 65vmin;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.06);
  animation: rotate 40s linear infinite;
}
.hero__deco::after {
  content: '';
  position: absolute;
  bottom: 10%;
  right: 5%;
  width: 30vmin;
  height: 30vmin;
  border-radius: 50%;
  border: 1px solid rgba(201,130,0,.12);
  animation: rotate 25s linear infinite reverse;
}
@keyframes rotate { from { transform: rotate(0); } to { transform: rotate(360deg); } }

/* Contenu */
.hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: var(--s-16) 0 var(--s-12);
}

@media (min-width: 768px) { .hero__content { padding: var(--s-20) 0 var(--s-16); } }

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-1) var(--s-4);
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: var(--r-full);
  color: rgba(255,255,255,.85);
  font-size: var(--text-xs);
  font-weight: var(--w-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
  margin-bottom: var(--s-5);
  backdrop-filter: blur(6px);
}

.hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-4xl), 7vw, var(--text-7xl));
  font-weight: var(--w-extrabold);
  color: #fff;
  line-height: var(--lh-none);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--s-6);
  max-width: 720px;
}

.hero__title em {
  font-style: normal;
  background: var(--gradient-gold);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero__desc {
  font-size: clamp(var(--text-base), 2vw, var(--text-xl));
  color: rgba(255,255,255,.7);
  line-height: var(--lh-relaxed);
  max-width: 520px;
  margin: 0 0 var(--s-8);
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  align-items: center;
}

.hero__scroll {
  position: absolute;
  bottom: var(--s-6);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-2);
  color: rgba(255,255,255,.4);
  font-size: var(--text-xs);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  animation: bounce 2.5s ease-in-out infinite;
}
@keyframes bounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(6px); }
}
.hero__scroll svg { opacity: .5; }

/* Stats dans le hero */
.hero__stats {
  display: flex;
  gap: var(--s-6);
  margin-top: var(--s-10);
  padding-top: var(--s-8);
  border-top: 1px solid rgba(255,255,255,.12);
}
.hero__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--w-extrabold);
  color: #fff;
  line-height: 1;
}
.hero__stat-label {
  font-size: var(--text-xs);
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  margin-top: var(--s-1);
}

/* ─── Cards Actualités ────────────────────────────────────── */
.card-news {
  background: var(--surface);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  transition: all var(--t);
  text-decoration: none;
  color: var(--text);
  group: true;
}

.card-news:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-card-hover);
  border-color: var(--navy-200);
  color: var(--text);
  text-decoration: none;
}

.card-news__img {
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--navy-900);
  position: relative;
  flex-shrink: 0;
}

.card-news__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--t-slow);
}
.card-news:hover .card-news__img img { transform: scale(1.06); }

/* Placeholder image */
.card-news__img-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: var(--gradient-primary);
  color: rgba(255,255,255,.2);
  font-size: 3rem;
}

.card-news__body {
  padding: var(--s-5) var(--s-5) var(--s-6);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.card-news__meta {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-3);
  flex-wrap: wrap;
}

.card-news__date {
  font-size: var(--text-xs);
  color: var(--text-subtle);
  font-weight: var(--w-medium);
  display: flex; align-items: center; gap: var(--s-1);
}

.card-news__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: var(--w-bold);
  line-height: var(--lh-snug);
  color: var(--text);
  margin: 0 0 var(--s-3);
  transition: color var(--t-fast);
}
.card-news:hover .card-news__title { color: var(--primary); }

.card-news__excerpt {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: var(--lh-relaxed);
  flex: 1;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card-news__read-more {
  margin-top: var(--s-4);
  font-size: var(--text-sm);
  font-weight: var(--w-semibold);
  color: var(--primary);
  display: flex; align-items: center; gap: var(--s-1);
  transition: gap var(--t-fast);
}
.card-news:hover .card-news__read-more { gap: var(--s-2); }
.card-news__read-more .arrow {
  transition: transform var(--t-fast);
}
.card-news:hover .card-news__read-more .arrow { transform: translateX(4px); }

/* ─── Section Actualités ──────────────────────────────────── */
.section-news { background: var(--bg); }

.section-news__more {
  text-align: center;
  margin-top: var(--s-10);
}

/* ─── Cards Événements ────────────────────────────────────── */
.events-list {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}

.card-event {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  background: var(--surface);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-xs);
  text-decoration: none;
  color: var(--text);
  transition: all var(--t-fast);
}
.card-event:hover {
  border-color: var(--navy-300);
  box-shadow: var(--shadow-sm);
  transform: translateX(3px);
  color: var(--text);
}

.card-event__date {
  flex-shrink: 0;
  width: 52px;
  height: 60px;
  border-radius: var(--r);
  background: var(--gradient-primary);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
}
.card-event__day {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--w-extrabold);
  line-height: 1;
}
.card-event__month {
  font-size: 10px;
  font-weight: var(--w-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  opacity: .8;
}

.card-event__info { flex: 1; min-width: 0; }
.card-event__title {
  font-size: var(--text-base);
  font-weight: var(--w-semibold);
  color: var(--text);
  margin: 0 0 var(--s-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color var(--t-fast);
}
.card-event:hover .card-event__title { color: var(--primary); }
.card-event__location {
  font-size: var(--text-xs);
  color: var(--text-subtle);
  display: flex; align-items: center; gap: var(--s-1);
}
.card-event__arrow { opacity: .3; transition: opacity var(--t-fast), transform var(--t-fast); }
.card-event:hover .card-event__arrow { opacity: .7; transform: translateX(3px); }

/* Vide / no events */
.events-empty {
  padding: var(--s-10);
  text-align: center;
  background: var(--surface);
  border-radius: var(--r-md);
  border: 1px dashed var(--border);
  color: var(--text-subtle);
  font-size: var(--text-sm);
}

/* ─── Boîte infos pratiques ───────────────────────────────── */
.info-card {
  background: var(--surface);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.info-card__header {
  background: var(--gradient-primary);
  color: #fff;
  padding: var(--s-5) var(--s-6);
}
.info-card__header h2,
.info-card__header h3,
.info-card__header h4 {
  color: #fff;
  margin: 0;
  font-size: var(--text-xl);
}

.info-card__body {
  padding: var(--s-5) var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}

.info-item {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
}
.info-item__icon {
  width: 36px; height: 36px;
  background: var(--primary-light);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--primary);
  font-size: 1rem;
}
.info-item__label {
  font-size: var(--text-xs);
  font-weight: var(--w-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  color: var(--text-subtle);
  margin-bottom: var(--s-1);
}
.info-item__value {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: var(--lh-snug);
}
.info-item__value a { color: var(--text-muted); text-decoration: none; }
.info-item__value a:hover { color: var(--primary); }

/* ─── Section Agenda + infos ──────────────────────────────── */
.section-agenda { background: var(--surface); }

.agenda-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-8);
}

@media (min-width: 1024px) {
  .agenda-grid {
    grid-template-columns: 1fr 380px;
    align-items: start;
  }
}

/* ─── CityKomi Section ────────────────────────────────────── */
.section-citykomi {
  background: var(--gradient-citykomi);
  color: #fff;
  position: relative;
  overflow: hidden;
}

.section-citykomi::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: rgba(255,255,255,.04);
  pointer-events: none;
}
.section-citykomi::after {
  content: '';
  position: absolute;
  bottom: -30%;
  left: -5%;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: rgba(201,130,0,.08);
  pointer-events: none;
}

.citykomi-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-10);
  align-items: center;
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .citykomi-layout { grid-template-columns: 1fr 1fr; gap: var(--s-12); }
}

.citykomi-content h2 {
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  color: #fff;
  margin-bottom: var(--s-4);
}

.citykomi-content p {
  font-size: var(--text-lg);
  color: rgba(255,255,255,.75);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--s-8);
}

.citykomi-features {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  margin-bottom: var(--s-8);
}

.citykomi-feature {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
}

.citykomi-feature__icon {
  width: 36px; height: 36px;
  background: rgba(255,255,255,.12);
  border-radius: var(--r);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 1rem;
  border: 1px solid rgba(255,255,255,.12);
}

.citykomi-feature__text {
  font-size: var(--text-sm);
  color: rgba(255,255,255,.8);
  line-height: var(--lh-snug);
}
.citykomi-feature__text strong { color: #fff; display: block; margin-bottom: 2px; }

.citykomi-badges {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.badge-store {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: var(--r-md);
  color: #fff;
  text-decoration: none;
  transition: all var(--t-fast);
  backdrop-filter: blur(6px);
  min-width: 140px;
}
.badge-store:hover {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.4);
  color: #fff;
  transform: translateY(-2px);
}
.badge-store__icon { font-size: 1.4rem; }
.badge-store__text { line-height: var(--lh-tight); }
.badge-store__label {
  display: block;
  font-size: 10px;
  opacity: .7;
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
}
.badge-store__name {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--w-bold);
}

/* Mockup téléphone */
.citykomi-mockup {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.phone-mockup {
  width: 200px;
  height: 400px;
  border-radius: 36px;
  background: rgba(255,255,255,.1);
  border: 2px solid rgba(255,255,255,.2);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.2);
  position: relative;
  backdrop-filter: blur(10px);
}

.phone-mockup__notch {
  width: 80px; height: 20px;
  background: rgba(255,255,255,.15);
  border-radius: 0 0 16px 16px;
  margin: 0 auto 8px;
  flex-shrink: 0;
}

.phone-mockup__screen {
  flex: 1;
  padding: var(--s-2) var(--s-3);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}

.phone-notification {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-sm);
  padding: var(--s-2) var(--s-3);
  display: flex; gap: var(--s-2); align-items: center;
}
.phone-notification__dot {
  width: 8px; height: 8px;
  background: var(--gold-300);
  border-radius: 50%;
  flex-shrink: 0;
}
.phone-notification__text {
  font-size: 8px;
  color: rgba(255,255,255,.8);
  line-height: 1.4;
}
.phone-notification__text strong { color: #fff; display: block; }

/* ─── Cards Élus ──────────────────────────────────────────── */
.card-elu {
  background: var(--surface);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--border);
  text-align: center;
  padding: var(--s-6) var(--s-4);
  display: flex; flex-direction: column; align-items: center;
  transition: all var(--t);
}
.card-elu:hover { transform: translateY(-4px); box-shadow: var(--shadow-card-hover); }

.card-elu__photo {
  width: 88px; height: 88px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--border);
  margin-bottom: var(--s-4);
  background: var(--gray-100);
}

.card-elu__photo-placeholder {
  width: 88px; height: 88px;
  border-radius: 50%;
  background: var(--gradient-primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem;
  margin-bottom: var(--s-4);
  color: rgba(255,255,255,.5);
}

.card-elu__name {
  font-size: var(--text-base);
  font-weight: var(--w-bold);
  margin-bottom: var(--s-1);
}

.card-elu__role {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: var(--w-bold);
  background: var(--primary-light);
  color: var(--primary);
  padding: 3px var(--s-3);
  border-radius: var(--r-full);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  margin-bottom: var(--s-3);
}

.card-elu__commissions {
  display: flex; flex-wrap: wrap; gap: var(--s-1); justify-content: center;
  margin-bottom: var(--s-3);
}
.card-elu__commission-tag {
  font-size: 10px;
  padding: 2px var(--s-2);
  background: var(--gray-100); color: var(--text-muted);
  border-radius: var(--r-full);
}

.card-elu__fonction {
  font-size: var(--text-xs);
  font-weight: var(--w-bold);
  color: var(--primary);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  margin-bottom: var(--s-1);
}

.card-elu__metier {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-bottom: var(--s-3);
}

.card-elu__bio {
  font-size: var(--text-xs);
  color: var(--text-subtle);
  line-height: 1.6;
  margin-bottom: var(--s-3);
  text-align: left;
}

.card-elu__email {
  font-size: var(--text-xs);
  color: var(--text-subtle);
  text-decoration: none;
  display: flex; align-items: center; gap: var(--s-1);
}
.card-elu__email:hover { color: var(--primary); }

/* ─── Documents / Comptes-rendus ──────────────────────────── */
.card-doc {
  display: flex; align-items: center; gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  text-decoration: none; color: var(--text);
  transition: all var(--t-fast);
  box-shadow: var(--shadow-xs);
}
.card-doc:hover {
  border-color: var(--navy-300);
  box-shadow: var(--shadow-sm);
  transform: translateX(3px);
  color: var(--text);
}
.card-doc__icon {
  width: 44px; height: 44px; flex-shrink: 0;
  background: #fee2e2; border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem;
}
.card-doc__info { flex: 1; min-width: 0; }
.card-doc__title {
  font-size: var(--text-sm); font-weight: var(--w-semibold);
  margin: 0 0 var(--s-1);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.card-doc__meta { font-size: var(--text-xs); color: var(--text-subtle); }
.card-doc__dl {
  flex-shrink: 0;
  color: var(--primary);
  font-size: var(--text-xs); font-weight: var(--w-semibold);
  display: flex; align-items: center; gap: var(--s-1);
}

/* ─── Salle des fêtes ─────────────────────────────────────── */
.salle-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--s-8);
}
@media (min-width: 768px) { .salle-grid { grid-template-columns: 1fr 1fr; } }

.salle-features { display: flex; flex-direction: column; gap: var(--s-3); }
.salle-feature {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--gray-50); border-radius: var(--r-sm);
  font-size: var(--text-sm);
}
.salle-feature__icon { font-size: 1.25rem; }

.tarif-table { width: 100%; border-collapse: collapse; }
.tarif-table th {
  text-align: left; padding: var(--s-3) var(--s-4);
  background: var(--primary-light); color: var(--primary);
  font-size: var(--text-xs); font-weight: var(--w-bold);
  text-transform: uppercase; letter-spacing: var(--ls-wide);
}
.tarif-table td {
  padding: var(--s-3) var(--s-4);
  font-size: var(--text-sm); border-bottom: 1px solid var(--border);
}
.tarif-table tr:last-child td { border-bottom: none; }
.tarif-table tr:hover td { background: var(--gray-50); }

/* ─── Formulaire réservation ──────────────────────────────── */
.form-grid { display: grid; grid-template-columns: 1fr; gap: var(--s-4); }
@media (min-width: 640px) { .form-grid { grid-template-columns: 1fr 1fr; } }
.form-group { display: flex; flex-direction: column; gap: var(--s-2); }
.form-group--full { grid-column: 1 / -1; }

.form-label {
  font-size: var(--text-sm); font-weight: var(--w-semibold); color: var(--text);
}
.form-label--required::after { content: ' *'; color: var(--error); }

.form-input, .form-textarea, .form-select {
  width: 100%;
  padding: var(--s-3) var(--s-4);
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-size: var(--text-base);
  color: var(--text);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  appearance: none;
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  outline: none;
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px rgba(30,90,170,.12);
}
.form-textarea { min-height: 120px; resize: vertical; }

/* ─── Pagination ──────────────────────────────────────────── */
.pagination {
  display: flex; align-items: center; justify-content: center;
  gap: var(--s-2); margin-top: var(--s-10); flex-wrap: wrap;
}
.page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px;
  font-size: var(--text-sm); font-weight: var(--w-semibold);
  border-radius: var(--r-sm);
  text-decoration: none; color: var(--text-muted);
  transition: all var(--t-fast);
  border: 1px solid var(--border);
  background: var(--surface);
}
.page-numbers:hover { background: var(--primary-light); color: var(--primary); border-color: var(--navy-200); }
.page-numbers.current { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ─── Section services rapides (homepage) ─────────────────── */
.quick-services {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-3);
}
@media (min-width: 640px) {
  .quick-services { grid-template-columns: repeat(4, 1fr); }
}

.quick-service {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--s-5) var(--s-4);
  text-align: center;
  text-decoration: none;
  color: var(--text);
  display: flex; flex-direction: column; align-items: center; gap: var(--s-3);
  box-shadow: var(--shadow-xs);
  transition: all var(--t);
}
.quick-service:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--navy-200);
  color: var(--primary);
}
.quick-service__icon {
  width: 52px; height: 52px;
  background: var(--primary-light);
  border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  transition: background var(--t-fast);
}
.quick-service:hover .quick-service__icon { background: var(--navy-100); }
.quick-service__label {
  font-size: var(--text-sm); font-weight: var(--w-semibold);
  line-height: var(--lh-snug);
}

/* ─── Page Les Élus ────────────────────────────────────────── */
.elus-photo-wrap {
  margin: var(--s-8) 0;
  border-radius: var(--r-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.elus-photo {
  width: 100%;
  height: auto;
  display: block;
}
.elus-photo-caption {
  background: var(--navy-800);
  color: rgba(255,255,255,.65);
  font-size: var(--text-sm);
  text-align: center;
  margin: 0;
  padding: var(--s-3) var(--s-4);
}

.elus-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--s-6);
  margin: var(--s-8) 0;
}

.elu-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--s-6);
  transition: box-shadow var(--t), transform var(--t);
}
.elu-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.elu-card__header {
  display: flex;
  align-items: flex-start;
  gap: var(--s-4);
  margin-bottom: var(--s-4);
}
.elu-card__avatar {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border-radius: 50%;
  background: var(--primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-lg);
  font-weight: var(--w-bold);
  font-family: var(--font-display);
}
.elu-card__name {
  font-size: var(--text-base);
  font-weight: var(--w-bold);
  color: var(--text-primary);
  line-height: var(--lh-snug);
}
.elu-card__fonction {
  font-size: var(--text-sm);
  color: var(--primary);
  font-weight: var(--w-semibold);
  margin-top: 2px;
}
.elu-card__metier {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: 2px;
}
.elu-card__bio {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--lh-relaxed);
  margin: 0;
}

p.lead {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--s-6);
}

/* ─── Page Contact ─────────────────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-8);
  align-items: start;
}
@media (min-width: 768px) {
  .contact-layout {
    grid-template-columns: 1fr 1.4fr;
  }
}

/* ─── Formulaire de contact ────────────────────────────────── */
.contact-form { display: flex; flex-direction: column; gap: var(--s-5); }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-4);
}
@media (max-width: 480px) { .form-row { grid-template-columns: 1fr; } }

.form-group { display: flex; flex-direction: column; gap: var(--s-2); }

.form-label {
  font-size: var(--text-sm);
  font-weight: var(--w-semibold);
  color: var(--text-primary);
}
.form-label span { color: var(--primary); }

.form-input {
  width: 100%;
  padding: var(--s-3) var(--s-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--text-primary);
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-md);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
  outline: none;
  -webkit-appearance: none;
}
.form-input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-light);
}
.form-input::placeholder { color: var(--text-muted); }

.form-textarea { resize: vertical; min-height: 120px; }

select.form-input { cursor: pointer; }

/* ─── Salle des Fêtes ──────────────────────────────────────── */
.sdf-info-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-10);
  align-items: start;
}
@media (min-width: 768px) {
  .sdf-info-grid { grid-template-columns: 1.2fr 1fr; }
}

.sdf-features {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--s-4);
}
.sdf-features li {
  display: flex; align-items: flex-start; gap: var(--s-3);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--lh-relaxed);
}
.sdf-feat-icon {
  font-size: 1.25rem;
  flex-shrink: 0;
  margin-top: 2px;
}

/* Tableau tarifs */
.sdf-tarif-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  margin-bottom: var(--s-4);
}
.sdf-tarif-table th,
.sdf-tarif-table td {
  padding: var(--s-3) var(--s-4);
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.sdf-tarif-table th {
  font-weight: var(--w-semibold);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  color: var(--text-muted);
  background: var(--surface-alt);
}
.sdf-tarif-table tr:last-child td { border-bottom: none; }
.sdf-tarif-table tr:hover td { background: var(--primary-light); }
.tarif-prix {
  font-weight: var(--w-bold);
  color: var(--primary);
  text-align: center !important;
}
.sdf-tarif-notes {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: var(--lh-relaxed);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.sdf-tarif-notes p { margin: 0; display: flex; align-items: flex-start; gap: var(--s-2); }
.sdf-tarif-notes svg { flex-shrink: 0; margin-top: 2px; }

/* Légende calendrier */
.sdf-legend {
  display: flex;
  gap: var(--s-6);
  justify-content: center;
  margin-bottom: var(--s-6);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  flex-wrap: wrap;
}
.sdf-legend > div { display: flex; align-items: center; gap: var(--s-2); }
.sdf-legend__dot {
  width: 12px; height: 12px;
  border-radius: 3px;
  display: inline-block;
}
.sdf-legend__dot--free     { background: #d1fae5; border: 1px solid #6ee7b7; }
.sdf-legend__dot--reserved { background: #fee2e2; border: 1px solid #fca5a5; }
.sdf-legend__dot--past     { background: var(--border); }

/* Grille de calendriers */
.sdf-calendars {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
}
@media (min-width: 640px)  { .sdf-calendars { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1024px) { .sdf-calendars { grid-template-columns: 1fr 1fr 1fr; } }

/* Calendrier mensuel */
.sdf-cal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
}
.sdf-cal__month {
  background: var(--primary);
  color: #fff;
  text-align: center;
  font-weight: var(--w-semibold);
  font-size: var(--text-sm);
  padding: var(--s-3);
  text-transform: capitalize;
}
.sdf-cal__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--border);
  padding: var(--s-2);
  gap: 2px;
}
.sdf-cal__head {
  text-align: center;
  font-size: 10px;
  font-weight: var(--w-bold);
  color: var(--text-muted);
  text-transform: uppercase;
  padding: var(--s-1) 0;
}
.sdf-cal__day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-sm);
  font-size: var(--text-xs);
  font-weight: var(--w-medium);
  transition: all var(--t-fast);
}
.sdf-cal__day--empty    { background: transparent; }
.sdf-cal__day--past     { color: var(--text-muted); background: transparent; }
.sdf-cal__day--free     { background: #d1fae5; color: #065f46; cursor: default; }
.sdf-cal__day--reserved { background: #fee2e2; color: #991b1b; font-weight: var(--w-bold); }

/* ─── Carousel galerie ────────────────────────────────────── */
.carousel {
  position: relative;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--gray-900);
  margin: var(--s-12) 0;
}
.carousel__viewport { overflow: hidden; }
.carousel__track {
  display: flex;
  transition: transform 400ms cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.carousel__slide {
  flex: 0 0 100%;
  position: relative;
}
.carousel__slide img {
  width: 100%;
  height: clamp(320px, 60vw, 680px);
  object-fit: cover;
  display: block;
}
.carousel__caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: var(--s-3) var(--s-6);
  background: linear-gradient(transparent, rgba(5,17,31,.75));
  color: #fff;
  font-size: var(--text-sm);
}
.carousel__btn {
  position: absolute;
  top: 50%; transform: translateY(-50%);
  width: 44px; height: 44px;
  border-radius: var(--r-full);
  border: none;
  background: rgba(5,17,31,.5);
  backdrop-filter: blur(4px);
  color: #fff;
  font-size: 1.5rem;
  line-height: 1;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  z-index: 2;
  transition: background var(--t-fast);
}
.carousel__btn:hover { background: rgba(5,17,31,.8); }
.carousel__prev { left: var(--s-3); }
.carousel__next { right: var(--s-3); }
.carousel__dots {
  position: absolute;
  bottom: var(--s-3);
  left: 50%; transform: translateX(-50%);
  display: flex; gap: var(--s-2);
  z-index: 2;
}
.carousel__dot {
  width: 8px; height: 8px;
  border-radius: var(--r-full);
  border: none; padding: 0;
  background: rgba(255,255,255,.45);
  cursor: pointer;
  transition: background var(--t-fast), width var(--t-fast);
}
.carousel__dot--active { background: #fff; width: 24px; }
.carousel--empty {
  height: 200px;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: var(--s-3);
  color: var(--text-muted);
  background: var(--gray-100);
  border-radius: var(--r-md);
  border: 2px dashed var(--gray-300);
  margin: var(--s-12) 0;
  font-size: var(--text-sm);
}

/* ─── Comptes-rendus ──────────────────────────────────────── */
.cr-year {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-bottom: var(--s-3);
  overflow: hidden;
  background: var(--surface);
}

.cr-year__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s-4) var(--s-5);
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: background var(--t);
}
.cr-year__summary::-webkit-details-marker { display: none; }
.cr-year__summary:hover { background: var(--gray-50); }

.cr-year__label {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  font-weight: var(--w-semibold);
  font-size: var(--text-lg);
  color: var(--text);
}

.cr-year__chevron {
  color: var(--primary);
  transition: transform var(--t);
  flex-shrink: 0;
}
.cr-year[open] .cr-year__chevron { transform: rotate(180deg); }

.cr-year__count {
  font-size: var(--text-xs);
  font-weight: var(--w-medium);
  color: var(--text-muted);
  background: var(--gray-100);
  padding: 2px var(--s-3);
  border-radius: var(--r-full);
  white-space: nowrap;
}

.cr-list {
  border-top: 1px solid var(--border);
}

.cr-item {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  padding: var(--s-3) var(--s-5);
  border-bottom: 1px solid var(--gray-100);
  transition: background var(--t);
}
.cr-item:last-child { border-bottom: none; }
.cr-item:hover { background: var(--gray-50); }

.cr-item__icon {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  border-radius: var(--r-sm);
  background: #eff6ff;
  color: var(--primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.cr-item__body { flex: 1; min-width: 0; }

.cr-item__title {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: var(--w-medium);
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cr-item__date {
  display: block;
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}

.cr-item__dl {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: var(--s-1) var(--s-3);
  border-radius: var(--r-full);
  border: 1.5px solid var(--primary);
  color: var(--primary);
  font-size: var(--text-xs);
  font-weight: var(--w-semibold);
  text-decoration: none;
  transition: background var(--t), color var(--t);
  white-space: nowrap;
}
.cr-item__dl:hover { background: var(--primary); color: #fff; }

/* ─── Page Détail événement ───────────────────────────────── */
.event-hero {
  background: var(--navy-900, #0f1f3d);
  color: #fff;
  padding: var(--s-10) 0 var(--s-12);
}
.event-hero__back {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--text-sm);
  color: rgba(255,255,255,.6);
  text-decoration: none;
  margin-bottom: var(--s-8);
  transition: color var(--t-fast);
}
.event-hero__back:hover { color: #fff; }
.event-hero__date-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  background: var(--gradient-primary);
  border-radius: var(--r-lg);
  padding: var(--s-3) var(--s-5);
  margin-bottom: var(--s-5);
  min-width: 80px;
}
.event-hero__day {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--w-extrabold);
  line-height: 1;
}
.event-hero__month {
  font-size: var(--text-xs);
  font-weight: var(--w-bold);
  text-transform: uppercase;
  letter-spacing: var(--ls-wide);
  opacity: .85;
}
.event-hero__title {
  font-size: var(--text-3xl);
  font-weight: var(--w-extrabold);
  margin: 0 0 var(--s-6);
  line-height: var(--lh-tight);
}
.event-hero__meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-5);
}
.event-hero__meta li {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--text-sm);
  color: rgba(255,255,255,.75);
}

/* ─── Page La Commune : intro texte + plan ────────────────── */
.commune-intro {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-8);
  align-items: start;
  margin-bottom: var(--s-10);
}
@media (min-width: 768px) {
  .commune-intro {
    grid-template-columns: 3fr 2fr;
  }
}
.commune-plan {
  margin: 0;
  position: sticky;
  top: calc(var(--header-h) + var(--s-6));
}
