/* === Buttons === */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.85rem 1.75rem; border-radius: var(--radius-sm);
  font-size: 0.95rem; font-weight: 600; transition: var(--transition);
}
.btn--primary { background: var(--cap-red); color: var(--white); box-shadow: 0 2px 8px rgba(196,59,46,0.3); }
.btn--primary:hover { background: var(--cap-red-dark); transform: translateY(-2px); }
.btn--outline { background: var(--white); color: var(--ink); border: 1.5px solid rgba(0,0,0,0.12); }
.btn--outline:hover { border-color: var(--ink); transform: translateY(-2px); }
.btn--sm { padding: 0.5rem 1rem; font-size: 0.8rem; }
.btn--ghost { background: transparent; color: var(--cap-red); padding: 0.5rem 1rem; font-size: 0.85rem; }

/* === Sections === */
.section { padding: 5rem 0; }
.section--alt { background: var(--white); }
.section__header { text-align: center; max-width: 640px; margin: 0 auto 3rem; }
.section__tag { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--cap-red); margin-bottom: 0.75rem; }
.section__title { font-family: var(--font-display); font-size: 2.5rem; margin-bottom: 1rem; }
.section__desc { color: var(--ink-light); font-size: 1.05rem; }
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; }
@media (max-width: 640px) { .card-grid { grid-template-columns: 1fr; } }

/* === Filter chips === */
.filter-chip {
  padding: 0.3rem 0.75rem; border-radius: 100px; font-size: 0.75rem;
  font-weight: 500; background: var(--cream); color: var(--ink-light);
  transition: var(--transition); cursor: pointer; border: 1px solid transparent;
}
.filter-chip:hover { background: var(--cream-dark); }
.filter-chip.active { background: var(--cap-red); color: var(--white); }

/* === Event cards === */
.event-card {
  background: var(--white); border-radius: var(--radius-md); overflow: hidden;
  box-shadow: var(--shadow-sm); transition: var(--transition); border: 1px solid rgba(0,0,0,0.04);
}
.event-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.event-card__image { height: 140px; position: relative; display: flex; align-items: center; justify-content: center; background: var(--cream-dark); }
.event-card__date-badge { position: absolute; top: 0.75rem; left: 0.75rem; background: var(--white); border-radius: var(--radius-sm); padding: 0.4rem 0.6rem; text-align: center; box-shadow: var(--shadow-md); line-height: 1.1; }
.event-card__date-day { font-family: var(--font-display); font-size: 1.3rem; color: var(--cap-red); }
.event-card__date-month { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-light); font-weight: 600; }
.event-card__body { padding: 1.25rem; }
.event-card__title { font-family: var(--font-display); font-size: 1.1rem; margin-bottom: 0.5rem; }
.event-card__meta { display: flex; gap: 1rem; font-size: 0.78rem; color: var(--ink-muted); margin-bottom: 0.5rem; }
.event-card__excerpt { font-size: 0.85rem; color: var(--ink-light); line-height: 1.6; }

/* === Promo cards === */
.promo-card {
  background: var(--white); border-radius: var(--radius-md); overflow: hidden;
  box-shadow: var(--shadow-sm); transition: var(--transition); border: 1px solid rgba(0,0,0,0.04);
}
.promo-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }
.promo-card__header { display: flex; gap: 1rem; padding: 1.25rem 1.25rem 0; align-items: center; }
.promo-card__avatar {
  width: 48px; height: 48px; border-radius: var(--radius-sm); background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 0.85rem; color: var(--cap-red); flex-shrink: 0;
}
.promo-card__shop-name { font-weight: 600; font-size: 0.95rem; }
.promo-card__shop-cat { font-size: 0.75rem; color: var(--ink-muted); }
.promo-card__body { padding: 1rem 1.25rem 1.25rem; }
.promo-card__title { font-family: var(--font-display); font-size: 1.1rem; margin-bottom: 0.75rem; }
.promo-card__footer { display: flex; justify-content: space-between; align-items: center; padding-top: 0.75rem; border-top: 1px solid rgba(0,0,0,0.06); }
.promo-card__validity { font-size: 0.7rem; color: var(--ink-muted); }
.promo-card__badge { padding: 0.25rem 0.75rem; border-radius: 100px; font-size: 0.7rem; font-weight: 700; }
.promo-card__badge--discount { background: var(--cap-red-light); color: var(--cap-red); }
.promo-card__badge--new { background: var(--green-light); color: var(--green); }
.promo-card__badge--event { background: var(--orange-light); color: var(--orange); }

/* === Bon card (gift voucher visual) === */
.bon-card {
  background: linear-gradient(135deg, var(--cap-red) 0%, var(--cap-red-dark) 100%);
  color: var(--white); padding: 2.5rem; border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl); position: relative; overflow: hidden;
}
.bon-card::before { content: ''; position: absolute; top: -30px; right: -30px; width: 120px; height: 120px; background: rgba(255,255,255,0.1); border-radius: 50%; }
.bon-card__label { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.15em; opacity: 0.8; margin-bottom: 0.5rem; }
.bon-card__title { font-family: var(--font-display); font-size: 2rem; margin-bottom: 0.5rem; }
.bon-card__amount { font-family: var(--font-display); font-size: 3.5rem; font-style: italic; margin: 1rem 0; }
.bon-card__footer { display: flex; justify-content: space-between; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,0.2); font-size: 0.8rem; opacity: 0.8; }
.bons__layout { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
@media (max-width: 900px) { .bons__layout { grid-template-columns: 1fr; gap: 2rem; } }
.bon-step { display: flex; gap: 1rem; align-items: flex-start; }
.bon-step__num { width: 32px; height: 32px; border-radius: 50%; background: var(--cap-red-light); color: var(--cap-red); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.85rem; flex-shrink: 0; }
.bon-step__text { font-size: 0.9rem; line-height: 1.5; }
.bon-step__text strong { display: block; margin-bottom: 0.15rem; }

/* === Member modal === */
.member-modal { display: none; position: fixed; inset: 0; z-index: 2000; background: rgba(0,0,0,0.5); backdrop-filter: blur(4px); align-items: center; justify-content: center; padding: 2rem; }
.member-modal.open { display: flex; }
.member-modal__content { background: var(--white); border-radius: var(--radius-lg); max-width: 560px; width: 100%; max-height: 90vh; overflow-y: auto; box-shadow: var(--shadow-xl); padding: 2rem; animation: modalIn 0.3s ease; }
@keyframes modalIn { from { opacity: 0; transform: translateY(20px) scale(0.98); } to { opacity: 1; transform: translateY(0) scale(1); } }
.member-modal__close { float: right; width: 36px; height: 36px; border-radius: 50%; background: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; }
.member-modal__close:hover { background: var(--cream-dark); }
.member-modal__header { display: flex; gap: 1rem; align-items: center; margin-top: 0.5rem; }
.member-modal__logo { width: 64px; height: 64px; border-radius: var(--radius-md); background: var(--cream); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.2rem; color: var(--cap-red); }
.member-modal__name { font-family: var(--font-display); font-size: 1.5rem; }
.member-modal__cat { font-size: 0.85rem; color: var(--ink-muted); }
.member-modal__body { margin-top: 1.5rem; }
.member-modal__section { margin-bottom: 1.5rem; }
.member-modal__section-title { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-muted); font-weight: 600; margin-bottom: 0.5rem; }
.member-modal__detail { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9rem; padding: 0.35rem 0; color: var(--ink-light); }
/* Clickable links inside the member modal (phone / mail / website) */
.member-modal__link { color: var(--cap-red); text-decoration: none; border-bottom: 1px solid transparent; transition: var(--transition); word-break: break-all; }
.member-modal__link:hover { color: var(--cap-red-dark); border-bottom-color: currentColor; }
.member-modal__hours { display: grid; grid-template-columns: auto 1fr; gap: 0.25rem 1rem; font-size: 0.85rem; }
.member-modal__hours dt { font-weight: 500; }
.member-modal__hours dd { color: var(--ink-light); }
.member-modal__promo { background: var(--cap-red-light); padding: 1rem; border-radius: var(--radius-sm); border-left: 3px solid var(--cap-red); }
.member-modal__promo-title { font-weight: 600; font-size: 0.85rem; color: var(--cap-red); }
.member-modal__promo-text { font-size: 0.85rem; color: var(--ink-light); margin-top: 0.25rem; }

/* === Open/Closed badge on member cards === */
.member-card__open-badge {
  display: inline-block; font-size: 0.65rem; font-weight: 600;
  padding: 0.1rem 0.4rem; border-radius: 100px; margin-left: 0.4rem;
  vertical-align: middle; line-height: 1;
}
.member-card__open-badge--open { background: #dcfce7; color: #16a34a; }
.member-card__open-badge--closed { background: #fce4ec; color: #c62828; }

/* === Open now filter chip === */
.filter-chip--open { border: 1.5px solid #16a34a; color: #16a34a; background: transparent; }
.filter-chip--open:hover { background: #dcfce7; }
.filter-chip--open.active { background: #16a34a; color: var(--white); border-color: #16a34a; }

/* "Ouvert maintenant" toggle row — visually separated from category filters
   with a top border and proper spacing so it stops looking crammed. */
.members__toggle-row {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(0,0,0,.08);
  display: flex;
  justify-content: flex-start;
}

/* === Mobile bottom-sheet drag handle (hidden on desktop via pages.css) === */
/* Full-width tap area so user can grab or tap anywhere across the top of the sheet.
   Shows a grabber bar + a result-count hint that makes the affordance obvious. */
@media (max-width: 900px) {
  .members__sidebar-handle {
    display: flex !important;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 16px 8px;
    cursor: grab;
    touch-action: none;        /* Required so touchmove doesn't scroll the page */
    flex-shrink: 0;
    user-select: none;
    -webkit-user-select: none;
    border-bottom: 1px solid rgba(0, 0, 0, .05);
    position: relative;
  }
  /* Grabber bar */
  .members__sidebar-handle::before {
    content: '';
    width: 44px;
    height: 5px;
    background: rgba(0, 0, 0, .22);
    border-radius: 4px;
    transition: background .15s ease, width .15s ease;
  }
  .members__sidebar-handle:hover::before,
  .members__sidebar-handle:focus-visible::before,
  .members__sidebar:not([data-sheet-state="peek"]) .members__sidebar-handle::before {
    background: rgba(0, 0, 0, .38);
  }
  .members__sidebar-handle:active { cursor: grabbing; }
  .members__sidebar-handle:active::before {
    width: 52px;
    background: rgba(0, 0, 0, .5);
  }

  /* Count hint ("42 commerces") shown inside the handle area, with a rotating
     chevron to make the drag/expand affordance obvious. */
  .members__sheet-hint {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--ink-light);
    letter-spacing: 0.01em;
  }
  .members__sheet-hint span {
    color: var(--cap-red);
    font-weight: 700;
  }
  /* Chevron after the text: up by default (suggests "pull up"), flips when the
     sheet is in full state (suggests "pull down"). */
  .members__sheet-hint::after {
    content: '';
    width: 8px;
    height: 8px;
    border-right: 2px solid currentColor;
    border-top: 2px solid currentColor;
    transform: rotate(-45deg);            /* Chevron pointing up */
    margin-left: 2px;
    opacity: 0.55;
    transition: transform .28s cubic-bezier(.33, 1, .68, 1);
  }
  .members__sidebar[data-sheet-state="full"] .members__sheet-hint::after {
    transform: rotate(135deg);            /* Chevron pointing down when fully open */
  }
}

/* Map legend — top-right to avoid Leaflet zoom (top-left), count (bottom-left)
   and attribution (bottom-right). */
.members__legend {
  position: absolute;
  right: 12px;
  top: 12px;
  background: rgba(255,255,255,.95);
  border-radius: var(--radius-sm);
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
  padding: .55rem .75rem;
  font-size: .78rem;
  z-index: 500;
  min-width: 140px;
}
.members__legend-title {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .68rem;
  color: var(--ink-muted);
  margin-bottom: .3rem;
}
.members__legend-item {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin: .2rem 0;
  color: var(--ink);
}
.members__legend-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid;
  display: inline-block;
  flex-shrink: 0;
}

/* === Admin edit modal === */
.admin-modal {
  position: fixed; inset: 0; z-index: 3000;
  display: flex; align-items: center; justify-content: center;
  padding: 1rem;
}
.admin-modal__backdrop {
  position: absolute; inset: 0; background: rgba(0,0,0,0.5); backdrop-filter: blur(4px);
}
.admin-modal__panel {
  position: relative; background: var(--white); border-radius: var(--radius-lg);
  max-width: 720px; width: 100%; max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow-xl); animation: modalIn 0.3s ease;
}
.admin-modal__header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.5rem 1.75rem 0;
}
.admin-modal__body { padding: 1.25rem 1.75rem; }
.admin-modal__body label { font-size: 0.8rem; font-weight: 500; color: var(--ink-muted); display: block; margin-bottom: 0.25rem; }
.admin-modal__row { display: flex; gap: 1rem; margin-bottom: 0.75rem; }
.admin-modal__row > .admin-modal__field { flex: 1; min-width: 0; }
.admin-modal__field { margin-bottom: 0.25rem; }
.admin-modal__footer {
  display: flex; gap: 0.75rem; justify-content: flex-end; align-items: center;
  padding: 1rem 1.75rem 1.5rem; border-top: 1px solid var(--border);
}

/* === Hours editor === */
.hours-editor { display: flex; flex-direction: column; gap: 0.35rem; }
.hours-editor__row { display: flex; align-items: center; gap: 0.75rem; }
.hours-editor__day { width: 80px; font-size: 0.85rem; font-weight: 500; color: var(--ink-light); flex-shrink: 0; }
.hours-editor__input { flex: 1; padding: 0.4rem 0.6rem; font-size: 0.85rem; }

@media (max-width: 640px) {
  .admin-modal__row { flex-direction: column; gap: 0.5rem; }
  .admin-modal__row > .admin-modal__field { max-width: 100% !important; }
  .admin-modal__panel { max-height: 95vh; }
  .hours-editor__day { width: 60px; font-size: 0.8rem; }
  /* Logo upload widget stacks on narrow screens */
  .logo-upload { flex-direction: column; align-items: flex-start; }
  .logo-upload__preview { width: 100% !important; max-width: 140px; }
  /* Bons merchants CTA already stacks via its own media query */

  /* === Member modal becomes a bottom sheet on phones === */
  /* Anchored to the bottom edge, full width, slides up — feels native on mobile. */
  .member-modal { align-items: flex-end; padding: 0; }
  .member-modal__content {
    max-width: 100%;
    width: 100%;
    max-height: 88vh;
    border-radius: 18px 18px 0 0;
    padding: 1.5rem 1.25rem 2rem;
    animation: memberSheetUp 0.28s cubic-bezier(.33, 1, .68, 1);
  }
  /* Drag-handle affordance at the top of the sheet (purely visual, not interactive) */
  .member-modal__content::before {
    content: '';
    display: block;
    width: 42px;
    height: 4px;
    background: rgba(0, 0, 0, .18);
    border-radius: 4px;
    margin: -0.25rem auto 1rem;
  }
}
@keyframes memberSheetUp {
  from { transform: translateY(100%); opacity: 0.8; }
  to   { transform: translateY(0);    opacity: 1; }
}

/* === Form inputs === */
.form-input { width: 100%; padding: 0.7rem 1rem; border: 1.5px solid rgba(0,0,0,0.1); border-radius: var(--radius-sm); font-size: 0.9rem; font-family: var(--font-body); transition: var(--transition); }
.form-input:focus { outline: none; border-color: var(--cap-red); }
.form-label { font-size: 0.75rem; font-weight: 600; color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.08em; display: block; margin-bottom: 0.4rem; }

/* === Pages === */
.page-section { display: none; }
.page-section.active { display: block; }

/* === New members card (section "Ils viennent de nous rejoindre") === */
.new-member-card {
  background: var(--white); border-radius: var(--radius-md); padding: 1.25rem;
  box-shadow: var(--shadow-sm); transition: var(--transition); border: 1px solid rgba(0,0,0,0.04);
  cursor: pointer;
}
.new-member-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: rgba(196,59,46,.2); }
.new-member-card__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: .9rem; }
.new-member-card__badge { background: var(--cap-red-light); color: var(--cap-red); padding: .22rem .55rem; border-radius: 100px; font-size: .68rem; font-weight: 700; display: inline-flex; align-items: center; gap: .3rem; }
.new-member-card__date { font-size: .7rem; color: var(--ink-muted); }
.new-member-card__body { display: flex; gap: 1rem; align-items: flex-start; }
.new-member-card__logo { width: 64px; height: 64px; border-radius: var(--radius-sm); object-fit: contain; background: var(--cream); padding: 4px; flex-shrink: 0; }
.new-member-card__initials { width: 64px; height: 64px; border-radius: var(--radius-sm); background: var(--cream-dark); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.1rem; color: var(--cap-red); flex-shrink: 0; }
.new-member-card__name { font-family: var(--font-display); font-size: 1.1rem; margin: 0 0 .2rem 0; }
.new-member-card__cat { font-size: .8rem; color: var(--ink-muted); }
.new-member-card__desc { font-size: .82rem; color: var(--ink-light); margin-top: .5rem; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* === Member logo (list avatar variant) === */
.member-card__logo { width: 44px; height: 44px; border-radius: var(--radius-sm); object-fit: contain; background: var(--cream-dark); padding: 3px; flex-shrink: 0; }
.member-modal__logo-img { width: 64px; height: 64px; border-radius: var(--radius-md); object-fit: contain; background: var(--cream); padding: 4px; }

/* === Atelier card (event with workshop type) === */
.event-card__kind-badge { position: absolute; top: .75rem; right: .75rem; background: var(--jura-blue); color: var(--white); padding: .22rem .6rem; border-radius: 100px; font-size: .65rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; box-shadow: var(--shadow-sm); }
.event-card__kind-badge--atelier { background: var(--cap-red); }
.event-card__price { display: inline-flex; gap: .35rem; align-items: center; font-weight: 600; font-size: .8rem; color: var(--cap-red); margin-top: .5rem; }
.event-card__price-free { color: var(--green); }
.event-card__seats { margin-top: .75rem; }
.event-card__seats-bar { height: 6px; background: var(--cream-dark); border-radius: 100px; overflow: hidden; margin-top: .3rem; }
.event-card__seats-fill { height: 100%; background: linear-gradient(90deg, var(--green), var(--cap-red)); transition: width .4s ease; border-radius: 100px; }
.event-card__seats-meta { display: flex; justify-content: space-between; font-size: .72rem; color: var(--ink-muted); }
.event-card__actions { margin-top: .85rem; display: flex; gap: .5rem; }

/* === Atelier registration modal === */
.atelier-modal { display: none; position: fixed; inset: 0; z-index: 2500; background: rgba(0,0,0,0.5); backdrop-filter: blur(4px); align-items: center; justify-content: center; padding: 1rem; }
.atelier-modal.open { display: flex; }
.atelier-modal__content { background: var(--white); border-radius: var(--radius-lg); max-width: 560px; width: 100%; max-height: 92vh; overflow-y: auto; box-shadow: var(--shadow-xl); animation: modalIn 0.3s ease; }
.atelier-modal__header { padding: 1.5rem 1.75rem 0; display: flex; justify-content: space-between; align-items: flex-start; }
.atelier-modal__title { font-family: var(--font-display); font-size: 1.4rem; margin-bottom: .25rem; }
.atelier-modal__sub { font-size: .85rem; color: var(--ink-muted); }
.atelier-modal__close { width: 36px; height: 36px; border-radius: 50%; background: var(--cream); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; cursor: pointer; border: none; }
.atelier-modal__body { padding: 1rem 1.75rem 1.5rem; }
.atelier-modal__info { background: var(--cream); padding: .9rem 1rem; border-radius: var(--radius-sm); font-size: .85rem; margin-bottom: 1rem; display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.atelier-modal__info-item { display: flex; gap: .5rem; align-items: center; color: var(--ink-light); }
.atelier-modal__info-item i { color: var(--cap-red); flex-shrink: 0; }
@media (max-width: 640px) { .atelier-modal__info { grid-template-columns: 1fr; } }

/* === Logo upload widget (admin) === */
.logo-upload { display: flex; gap: 1rem; align-items: center; }
.logo-upload__preview { width: 80px; height: 80px; border-radius: var(--radius-sm); background: var(--cream); display: flex; align-items: center; justify-content: center; overflow: hidden; border: 1.5px dashed rgba(0,0,0,.12); flex-shrink: 0; }
.logo-upload__preview img { max-width: 100%; max-height: 100%; object-fit: contain; }
.logo-upload__placeholder { font-size: .7rem; color: var(--ink-muted); text-align: center; padding: .5rem; }
.logo-upload__actions { flex: 1; display: flex; flex-direction: column; gap: .35rem; }
.logo-upload__file-btn { display: inline-flex; align-items: center; gap: .4rem; padding: .5rem .85rem; background: var(--cream); border-radius: var(--radius-sm); font-size: .8rem; cursor: pointer; border: 1.5px solid rgba(0,0,0,.1); width: fit-content; }
.logo-upload__file-btn:hover { border-color: var(--cap-red); }
.logo-upload__hint { font-size: .72rem; color: var(--ink-muted); }

/* Address autocomplete (admin member editor) */
.address-suggestion:hover { background: var(--cream); }
.address-suggestion:last-child { border-bottom: none !important; }

/* === Animations === */
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
@keyframes fadeSlideDown { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeSlideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes scaleIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.6s ease, transform 0.6s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
