/* ============================================
   FRISE EXPOSITIONS — sans image
   naudfred.com — thème enfant Kadence
   ============================================ */

.expo-frise {
  position: relative;
  max-width: 1100px;
  margin: 60px auto;
  padding: 0 20px 0 0;
}

.expo-ligne {
  position: absolute;
  left: 220px;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(to bottom, transparent, #B52240 3%, #B52240 97%, transparent);
}

.expo-item {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  margin-bottom: 40px;
  opacity: 1;
  min-height: 60px;
}

.expo-date-zone {
  width: 200px;
  flex-shrink: 0;
  text-align: right;
  padding-right: 20px;
  padding-top: 18px;
}

.expo-date {
  display: inline-block;
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10px;
  letter-spacing: .1em;
  color: rgba(240,237,232,0.7);
  background: rgba(20,20,18,0.6);
  padding: 4px 10px;
  border-radius: 3px;
  border: 0.5px solid rgba(181,34,64,0.4);
  white-space: nowrap;
}

.expo-noeud {
  position: absolute;
  left: 220px;
  top: 14px;
  transform: translateX(-50%);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #141412;
  border: 2px solid #B52240;
  box-shadow: 0 0 0 3px #141412, 0 0 0 5px #B52240;
  z-index: 2;
  flex-shrink: 0;
}

.expo-carte {
  flex: 1;
  margin-left: 60px;
  background: #F0EDE8;
  border: 1px solid rgba(181,34,64,0.35);
  border-left: 3px solid #B52240;
  border-radius: 4px;
  padding: 16px 24px;
  max-width: 680px;
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
}

.expo-carte::after {
  content: '';
  position: absolute;
  top: 20px;
  left: -10px;
  border-width: 8px 10px 8px 0;
  border-style: solid;
  border-color: transparent #B52240 transparent transparent;
}

.expo-info {
  flex: 1;
}

.expo-titre {
  font-family: 'DM Serif Display', serif;
  font-size: 20px;
  color: #141412;
  font-weight: 400;
  margin: 0 0 4px;
  line-height: 1.2;
}

.expo-lieu {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 11px;
  color: rgba(20,20,18,0.6);
  margin: 0;
  letter-spacing: .02em;
}

.expo-organisateur {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 10px;
  color: rgba(181,34,64,0.8);
  margin: 6px 0 0;
  letter-spacing: .04em;
}

/* Base — Expo Collective — texte noir sur ivoire */
.expo-type {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 9px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #141412;
  border: 0.5px solid rgba(20,20,18,0.3);
  padding: 3px 8px;
  border-radius: 2px;
  white-space: nowrap;
  flex-shrink: 0;
  align-self: center;
}

/* Expo Solo — carmin */
.expo-type.solo {
  color: #B52240;
  border-color: #B52240;
}

/* Ma vie — gris */
.expo-type.vie {
  color: #888780;
  border-color: rgba(136,135,128,0.4);
  font-style: italic;
}

/* Mon art — gris */
.expo-type.art {
  color: #888780;
  border-color: rgba(136,135,128,0.4);
  font-style: italic;
}
.expo-annee-sep {
  display: flex;
  align-items: center;
  margin: 48px 0 32px;
}

.expo-annee-sep span {
  font-family: 'DM Serif Display', serif;
  font-size: 48px;
  color: rgba(181,34,64,0.28);
  letter-spacing: -.02em;
  line-height: 1;
  padding-left: 20px;
  user-select: none;
}

/* ——— MOBILE ——— */
@media (max-width: 680px) {

  .expo-frise { padding: 0 16px; }
  .expo-ligne { left: 20px; }

  .expo-item {
    flex-direction: column;
    padding-left: 44px;
  }

  .expo-date-zone {
    width: 100%;
    text-align: left;
    padding-right: 0;
    padding-top: 0;
    margin-bottom: 6px;
  }

  .expo-noeud {
    left: 20px;
    top: 2px;
    transform: translateX(-50%);
  }

  .expo-carte {
    margin-left: 0;
    width: 100%;
    max-width: 100%;
    flex-direction: column;
    gap: 8px;
  }

  /* Badge type en haut de carte sur mobile */
  .expo-type {
    order: -1;
    align-self: flex-start;
  }

  .expo-carte::after {
  top: -10px;
  left: 16px;
  border-width: 0 8px 10px 8px;
  border-color: transparent transparent #B52240 transparent;
}

  .expo-type {
    align-self: flex-start;
  }
}

/* ══ HEADER PAGE EXPOSITIONS ══ */

.expo-page {
  background: #141412;
  min-height: 100vh;
  color: #F0EDE8;
}

.expo-page__header {
  text-align: center;
  padding: clamp(40px, 6vw, 80px) clamp(16px, 4vw, 48px) 0;
  margin-bottom: clamp(32px, 5vw, 60px);
}

.expo-page__breadcrumb {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  color: #888780;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin: 0 0 20px;
}

.expo-page__breadcrumb a {
  color: #888780;
  text-decoration: none;
  transition: color 0.3s ease;
}

.expo-page__breadcrumb a:hover {
  color: #B52240;
}

.expo-page__breadcrumb span {
  margin: 0 6px;
  opacity: 0.4;
}

.expo-page__title {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: #F0EDE8;
  font-weight: 400;
  margin: 0 0 16px;
  letter-spacing: -0.01em;
}

.expo-page__meta {
  font-family: 'IBM Plex Mono', monospace;
  font-size: 0.7rem;
  color: rgba(181,34,64,0.7);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 0 0 24px;
}

.expo-page__trait {
  width: 100%;
  height: 1px;
  background: #2C2C2A;
  margin: 0 0 0;
}

.expo-page__wrap {
  padding: clamp(40px, 5vw, 80px) clamp(16px, 4vw, 48px) 120px;
}