/* ##########################################################################
   BLOC 32 — CONFÉRENCE (article détail)
   Dernière MàJ : 28/02/2026
   - Sans sommaire
   - Infos pratiques via MODALE
   - Parties répétables + pause + cartes intervenants
   ########################################################################## */

.sep-conf{ color: var(--sep-ink); }

/* largeur confortable (lisibilité) */
.sep-conf-wrap{
  max-width: var(--sep-container);
  margin: 0 auto;
  padding: 0 var(--sep-gutter);
}

/* HERO */
.sep-conf-hero{
  border-bottom: 1px solid var(--sep-line);
  background: linear-gradient(180deg, rgba(109,40,217,.06), rgba(255,255,255,1));
  padding: clamp(2.2rem, 6vw, 4.2rem) 0;
}
.sep-conf-hero > *{
  max-width: var(--sep-container);
  margin-inline: auto;
  padding-inline: var(--sep-gutter);
}

/* Réglage rapide : taille titre */
.sep-conf-title{
  font-size: clamp(1.9rem, 5vw, 3.0rem);
  letter-spacing: -0.03em;
  margin: 0 0 .85rem;
  max-width: 28ch;
}

.sep-conf-lead{
  color: var(--sep-muted);
  font-size: clamp(1.02rem, 2.2vw, 1.18rem);
  max-width: var(--sep-max);
  margin: 0 0 1.35rem;
  line-height: var(--sep-lh);
}

/* boutons : on scope car tes styles .btn sont scoppés sur .sep-home */
.sep-conf .btn-primary{
  background: var(--sep-accent);
  border-color: var(--sep-accent);
}
.sep-conf .btn-primary:hover{
  background: var(--sep-accent-2);
  border-color: var(--sep-accent-2);
}
.sep-conf .btn-outline-primary{
  color: var(--sep-accent);
  border-color: rgba(109, 40, 217, .35);
}
.sep-conf .btn-outline-primary:hover{
  background: rgba(109, 40, 217, .08);
  border-color: rgba(109, 40, 217, .55);
  color: var(--sep-accent);
}

/* meta chips (détail conf) */
.sep-conf-meta{
  display: flex;
  flex-wrap: wrap;
  gap: .55rem .55rem;
  margin-bottom: 1.25rem;
}
.sep-chip{
  display:inline-flex;
  align-items:center;
  padding: .40rem .70rem;
  border-radius: 999px;
  font-size: .86rem;
  color: var(--sep-ink);
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(27,19,39,.12);
  box-shadow: 0 6px 18px rgba(27,19,39,.06);
}

/* sections */
.sep-conf-block{
  padding: clamp(1.2rem, 2.5vw, 1.8rem) 0;
}
.sep-conf-h2{
  font-size: clamp(1.25rem, 2.2vw, 1.65rem);
  letter-spacing: -0.02em;
  margin: 0 0 .9rem;
}

/* programme (DL simple) */
.sep-schedule{
  margin: 0;
  padding: 0;
}
.sep-schedule-row{
  display: grid;
  grid-template-columns: 90px 1fr;
  gap: .9rem;
  padding: .85rem .95rem;
  border: 1px solid rgba(27,19,39,.10);
  border-radius: var(--sep-radius-lg);
  background: var(--sep-surface);
  box-shadow: 0 10px 26px rgba(27,19,39,.06);
}
.sep-schedule-row + .sep-schedule-row{ margin-top: .65rem; }

.sep-schedule dt{
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.sep-schedule dd{
  margin: 0;
  color: var(--sep-muted);
}

/* Mini étape (accueil) */
.sep-conf-mini{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 1rem;
  padding: .95rem 1.05rem;
  border: 1px solid rgba(27,19,39,.10);
  border-radius: var(--sep-radius-lg);
  background: var(--sep-surface);
  box-shadow: 0 10px 26px rgba(27,19,39,.06);
}

.sep-mini-left{
  display: flex;
  flex-direction: column;
  gap: .25rem;
}

.sep-mini-time{
  font-weight: 900;
  font-variant-numeric: tabular-nums;
}

.sep-mini-title{
  color: var(--sep-muted);
  font-weight: 750;
}

.sep-mini-text{
  margin: 0;
  color: var(--sep-muted);
  line-height: var(--sep-lh);
}

/* PARTIES */
.sep-conf-part{
  /* variables “thème” (fallback = accent global) */
  --part-accent: var(--sep-accent);
  --part-tint: rgba(109,40,217,.06);
  --part-border: rgba(109,40,217,.22);
  --part-glow: rgba(109,40,217,.16);

  position: relative;
  overflow: hidden;

  margin: 1.25rem 0;
  border: 1px solid rgba(27,19,39,.10);
  border-radius: calc(var(--sep-radius-lg) + 2px);

  /* pastel + lisible */
  background: linear-gradient(180deg, var(--part-tint), #fff 65%);
  box-shadow: 0 14px 40px rgba(27,19,39,.07);
  padding: 1.05rem 1.05rem 1.15rem;
}

/* barre d’accent (signature visuelle) */
.sep-conf-part::before{
  content:"";
  position:absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: var(--part-accent);
}

/* aura douce (spirituel, très léger) */
.sep-conf-part::after{
  content:"";
  position:absolute;
  inset: -20% -15% auto auto;
  width: 260px;
  height: 260px;
  background: radial-gradient(closest-side, var(--part-glow), transparent 70%);
  pointer-events:none;
  filter: blur(1px);
  opacity: .9;
}

/* variantes : Partie 1 / Partie 2 */
.sep-conf-part--p1{
  --part-accent: var(--sep-p1-accent);
  --part-tint: var(--sep-p1-tint);
  --part-border: var(--sep-p1-border);
  --part-glow: var(--sep-p1-glow);
}
.sep-conf-part--p2{
  --part-accent: var(--sep-p2-accent);
  --part-tint: var(--sep-p2-tint);
  --part-border: var(--sep-p2-border);
  --part-glow: var(--sep-p2-glow);
}

/* En-tête de partie */
.sep-part-head{
  display:flex;
  align-items:center; /* réglage rapide : alignement vertical */
  justify-content:space-between;
  gap: 1rem;
  padding-bottom: .9rem;

  border-bottom: 1px solid rgba(27,19,39,.08);
  margin-bottom: 1rem;
}

/* Si thème p1/p2 : bordure d’en-tête teintée */
.sep-conf-part--p1 .sep-part-head,
.sep-conf-part--p2 .sep-part-head{
  border-bottom-color: var(--part-border);
}

.sep-part-left{
  display:flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .65rem;
  min-width: 0;
}

.sep-part-tag{
  display:inline-flex;
  align-self:flex-start;
  padding: .20rem .55rem;
  border-radius: 999px;

  /* par défaut, suit le thème si --part-* existe */
  border: 1px solid var(--part-border, rgba(109,40,217,.22));
  background: var(--part-tint, rgba(109,40,217,.08));

  font-weight: 800;
  font-size: .82rem;
  color: var(--sep-ink);
}

.sep-part-title{
  margin: 0;
  font-size: 1.15rem; /* réglage rapide : taille titre partie */
  font-weight: 850;
  letter-spacing: -0.02em;
}

.sep-part-time{
  color: var(--sep-muted);
  font-weight: 750;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  margin-top: .25rem;
}

/* repère “point” au début du time (teinté) */
.sep-conf-part .sep-part-time{
  position: relative;
  padding-left: 1.05rem;
}
.sep-conf-part .sep-part-time::before{
  content:"";
  position:absolute;
  left: 0;
  top: .55em;
  width: .55rem;
  height: .55rem;
  border-radius: 999px;
  background: var(--part-accent);
  box-shadow: 0 0 0 4px var(--part-tint);
}

/* Grille contenu + aside intervenant */
.sep-part-grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 1.05rem 1.15rem;
  align-items:start;
}

.sep-part-content p{ line-height: var(--sep-lh); }
.sep-part-content ul{ padding-left: 1.2rem; }
.sep-part-content li + li{ margin-top: .35rem; }

/* Carte intervenant (CTA) */
.sep-speaker-card{
  border: 1px solid rgba(27,19,39,.10);
  border-radius: var(--sep-radius-lg);
  overflow: hidden;
  background: var(--sep-surface);
  box-shadow: 0 12px 30px rgba(27,19,39,.06);
  margin: 0;
}
.sep-speaker-body{ padding: .85rem .95rem; }
.sep-speaker-card .sep-speaker-bio{
  margin: 0;
  color: var(--sep-muted);
  line-height: 1.65;
}

/* Conférencier CTA (remplace photo + bio) */
.sep-speaker-card.sep-speaker-cta .sep-speaker-body{
  display: flex;
  flex-direction: column;
  gap: .6rem;
}
.sep-speaker-card.sep-speaker-cta .btn{
  width: 100%;
  justify-content: center;
}

/* PAUSE */
.sep-conf-break{
  margin: 1.15rem 0;
  border-radius: calc(var(--sep-radius-lg) + 2px);
  border: 1px dashed rgba(27,19,39,.22);
  background: linear-gradient(180deg, rgba(27,19,39,.03), rgba(27,19,39,.01));
  padding: .95rem 1.05rem;
}

/* Mobile-first : 2 colonnes simples */
.sep-break-inner{
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 1rem;
  align-items: center;
}

.sep-break-title{ margin: 0; font-weight: 900; }
.sep-break-sub{ margin: .15rem 0 0; color: var(--sep-muted, #6b7280); }

/* Responsive : la pause passe en 1 colonne sur petit écran */
@media (max-width: 576px){
  .sep-break-inner{
    grid-template-columns: 1fr;
    align-items: start;
  }
}