/* ============================================================
   MediFiche — Design System
   Aesthetic: Clinical precision meets human warmth
   Typography: Instrument Serif (display) + DM Sans (body)
   Palette: Deep forest green + warm off-white + alert amber/red
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;1,9..40,300&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ─── TOKENS ─── */
:root {
  /* Brand */
  --brand: #1B6B52;
  --brand-mid: #2D9672;
  --brand-light: #E4F4EE;
  --brand-xlight: #F2FAF6;
  --brand-dark: #0D3D2E;
  --brand-border: #A8DCC8;

  /* Neutral */
  --bg: #F5F4F0;
  --surface: #FDFCF9;
  --surface-2: #F0EEE9;
  --border: rgba(27, 107, 82, 0.12);
  --border-strong: rgba(27, 107, 82, 0.22);
  --text: #1C1C18;
  --text-2: #4A4A44;
  --text-3: #7A7A72;

  /* Semantic */
  --danger-bg: #FDF0EF;
  --danger-border: #F5C4C0;
  --danger-text: #8B1A14;
  --danger-label: #C0392B;
  --warning-bg: #FDF6E8;
  --warning-border: #F5D98A;
  --warning-text: #6B3A00;
  --warning-label: #B45309;
  --info-bg: var(--brand-light);
  --info-border: var(--brand-border);
  --info-text: var(--brand-dark);

  /* Typography */
  --font-display: 'Instrument Serif', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;

  /* Spacing */
  --space-1: 4px; --space-2: 8px; --space-3: 12px;
  --space-4: 16px; --space-5: 20px; --space-6: 24px;
  --space-8: 32px; --space-10: 40px; --space-12: 48px;

  /* Radius */
  --r-sm: 6px; --r-md: 10px; --r-lg: 14px; --r-xl: 20px;

  /* Shadow */
  --shadow-sm: 0 1px 3px rgba(27,107,82,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(27,107,82,0.10), 0 2px 4px rgba(0,0,0,0.04);
  --shadow-lg: 0 8px 24px rgba(27,107,82,0.12), 0 4px 8px rgba(0,0,0,0.06);

  /* Transition */
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast: 120ms; --t-mid: 200ms; --t-slow: 350ms;
}

/* ─── BASE ─── */
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  line-height: 1.6;
}

/* ─── LAYOUT ─── */
.app-shell { display: flex; flex-direction: column; min-height: 100vh; }
.container { max-width: 760px; margin: 0 auto; padding: 0 var(--space-5); }
.container--wide { max-width: 960px; margin: 0 auto; padding: 0 var(--space-5); }

/* ─── NAV ─── */
.nav {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 200;
  height: 56px;
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 100%; width: 100%; padding: 0 var(--space-5);
}
.nav__logo {
  font-family: var(--font-display);
  font-size: 20px; color: var(--text); text-decoration: none;
  display: flex; align-items: center; gap: var(--space-2);
}
.nav__logo-accent { color: var(--brand-mid); font-style: italic; }
.nav__logo-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--brand-mid); margin-right: 2px; }
.nav__badge {
  font-size: 11px; font-weight: 500; letter-spacing: 0.04em;
  background: var(--brand-light); color: var(--brand);
  border: 1px solid var(--brand-border); padding: 3px 10px; border-radius: 20px;
}
.nav__version { font-size: 11px; color: var(--text-3); }

/* ─── DISCLAIMER ─── */
.disclaimer {
  background: var(--warning-bg);
  border-bottom: 1px solid var(--warning-border);
  padding: var(--space-3) var(--space-5);
  display: flex; align-items: flex-start; gap: var(--space-3);
}
.disclaimer__icon { font-size: 14px; flex-shrink: 0; margin-top: 1px; }
.disclaimer__text {
  font-size: 12px; color: var(--warning-text); line-height: 1.5;
  font-style: italic;
}
.disclaimer__text strong { font-style: normal; }

/* ─── HERO ─── */
.hero {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: var(--space-10) var(--space-5) var(--space-8);
  text-align: center;
  position: relative;
  overflow: hidden;
  z-index: 100;
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(45,150,114,0.06) 0%, transparent 70%);
  pointer-events: none;
}
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: 11px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--brand); background: var(--brand-light);
  border: 1px solid var(--brand-border); padding: 4px 12px; border-radius: 20px;
  margin-bottom: var(--space-4);
}
.hero__title {
  font-family: var(--font-display);
  font-size: clamp(26px, 4vw, 36px);
  color: var(--text); letter-spacing: -0.5px;
  margin-bottom: var(--space-3); line-height: 1.2;
}
.hero__title em { color: var(--brand-mid); font-style: italic; }
.hero__sub {
  font-size: 14px; color: var(--text-3);
  margin-bottom: var(--space-6); max-width: 420px; margin-left: auto; margin-right: auto;
}

/* ─── SEARCH ─── */
.search-block { position: relative; max-width: 520px; margin: 0 auto; }
.search-wrap {
  display: flex; gap: var(--space-2);
  background: var(--surface);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-xl);
  padding: var(--space-2);
  box-shadow: var(--shadow-md);
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.search-wrap:focus-within {
  border-color: var(--brand-mid);
  box-shadow: 0 0 0 3px rgba(45,150,114,0.12), var(--shadow-md);
}
.search-icon { display: flex; align-items: center; padding-left: var(--space-3); color: var(--text-3); font-size: 16px; flex-shrink: 0; }
.search-input {
  flex: 1; border: none; background: transparent;
  font-family: var(--font-body); font-size: 15px; color: var(--text);
  outline: none; padding: var(--space-2) var(--space-2);
  min-width: 0;
}
.search-input::placeholder { color: var(--text-3); }
.search-btn {
  height: 40px; padding: 0 var(--space-5);
  background: var(--brand); color: white;
  border: none; border-radius: var(--r-lg);
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  cursor: pointer; flex-shrink: 0;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.search-btn:hover { background: var(--brand-mid); }
.search-btn:active { transform: scale(0.97); }

/* ─── SEARCH DANS HERO COLORÉ ─── */
.hero-search .search-input { color: white; }
.hero-search .search-input::placeholder { color: rgba(255,255,255,0.55); }
.hero-search .search-wrap:focus-within {
  border-color: rgba(255,255,255,0.55) !important;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.12), var(--shadow-md);
}

/* ─── AUTOCOMPLETE ─── */
.autocomplete {
  position: fixed;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  overflow: hidden; z-index: 99999;
  display: none;
  animation: fadeSlide var(--t-mid) var(--ease);
}
@keyframes fadeSlide {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.autocomplete.open { display: block; }
.autocomplete__item {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  cursor: pointer; font-size: 14px; color: var(--text);
  border-bottom: 1px solid var(--border);
  transition: background var(--t-fast);
}
.autocomplete__item:last-child { border-bottom: none; }
.autocomplete__item:hover { background: var(--brand-xlight); }
.autocomplete__item-icon { font-size: 18px; flex-shrink: 0; }
.autocomplete__item-info { flex: 1; min-width: 0; }
.autocomplete__item-name { font-weight: 500; }
.autocomplete__item-cat { font-size: 12px; color: var(--text-3); }

/* ─── STATS BAR ─── */
.stats-bar {
  background: var(--brand-dark);
  padding: var(--space-3) var(--space-5);
  display: flex; align-items: center; justify-content: center; gap: var(--space-6);
}
.stats-bar__item { display: flex; align-items: center; gap: var(--space-2); color: rgba(255,255,255,0.75); font-size: 12px; }
.stats-bar__item strong { color: white; font-weight: 500; }

/* ─── MAIN ─── */
.main { flex: 1; padding: var(--space-6) 0 var(--space-12); }

/* ─── FICHE RESULT ─── */
.fiche-result {
  display: none; margin-bottom: var(--space-6);
  animation: slideIn var(--t-slow) var(--ease);
  scroll-margin-top: 300px;
}
.fiche-result.visible { display: block; }
@keyframes slideIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fiche-card {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.fiche-card__header {
  background: linear-gradient(135deg, var(--brand-dark) 0%, var(--brand) 100%);
  padding: var(--space-5) var(--space-6);
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4);
}
.fiche-card__header-left { display: flex; align-items: flex-start; gap: var(--space-4); }
.fiche-card__icon-wrap {
  width: 48px; height: 48px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.fiche-card__title { font-family: var(--font-display); font-size: 22px; color: white; line-height: 1.2; margin-bottom: 4px; }
.fiche-card__cat { font-size: 12px; color: rgba(255,255,255,0.65); letter-spacing: 0.04em; text-transform: uppercase; }
.fiche-card__close {
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2);
  color: white; border-radius: var(--r-md); width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; font-size: 16px;
  transition: background var(--t-fast);
}
.fiche-card__close:hover { background: rgba(255,255,255,0.22); }
.fiche-card__close--dark { background: var(--surface-2); color: var(--text-2); border-color: var(--border); }
.fiche-card__close--dark:hover { background: var(--border); }

.fiche-card__otc {
  background: var(--brand-xlight);
  border-top: 1px solid var(--brand-border);
  padding: var(--space-4) var(--space-6);
  display: flex; align-items: flex-start; gap: var(--space-3);
}
.fiche-card__otc-label { font-size: 11px; font-weight: 500; color: var(--brand); text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; margin-top: 2px; }
.fiche-card__otc-pills { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.otc-pill {
  font-size: 12px; background: white; color: var(--brand-dark);
  border: 1px solid var(--brand-border); border-radius: 20px; padding: 3px 10px;
}

.fiche-card__body { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--border); }
.fiche-bloc {
  background: var(--surface); padding: var(--space-5) var(--space-6);
}
.fiche-bloc.is-danger { background: var(--danger-bg); }
.fiche-bloc.is-warning { background: var(--warning-bg); }
.fiche-bloc.is-info { background: var(--info-bg); }
.fiche-bloc__label {
  font-size: 10px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em;
  display: flex; align-items: center; gap: var(--space-2);
  margin-bottom: var(--space-3); color: var(--text-3);
}
.fiche-bloc.is-danger .fiche-bloc__label { color: var(--danger-label); }
.fiche-bloc.is-warning .fiche-bloc__label { color: var(--warning-label); }
.fiche-bloc.is-info .fiche-bloc__label { color: var(--brand); }
.fiche-bloc__text {
  font-size: 13px; line-height: 1.7; color: var(--text-2);
}
.fiche-bloc.is-danger .fiche-bloc__text { color: var(--danger-text); }
.fiche-bloc.is-warning .fiche-bloc__text { color: var(--warning-text); }
.fiche-bloc.is-info .fiche-bloc__text { color: var(--info-text); }

/* ─── NO RESULT ─── */
.no-result {
  display: none; margin-bottom: var(--space-6);
  background: var(--surface); border: 1px dashed var(--border-strong);
  border-radius: var(--r-xl); padding: var(--space-8) var(--space-6);
  text-align: center;
}
.no-result.visible { display: block; }
.no-result__icon { font-size: 32px; margin-bottom: var(--space-3); }
.no-result__title { font-size: 15px; font-weight: 500; color: var(--text); margin-bottom: var(--space-2); }
.no-result__sub { font-size: 13px; color: var(--text-3); }

/* ─── SECTIONS ─── */
.section { margin-bottom: var(--space-8); }
.section__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); margin-top: var(--space-6); }
.section__label {
  font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--text-3); display: flex; align-items: center; gap: var(--space-2);
}
.section__badge {
  font-size: 11px; background: var(--brand-light); color: var(--brand);
  border: 1px solid var(--brand-border); padding: 2px 9px; border-radius: 20px;
}
.section__count { font-size: 12px; color: var(--text-3); }

/* ─── PATH CARDS ─── */
.cards-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-3); }
.path-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--space-4);
  cursor: pointer; user-select: none;
  transition: border-color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  animation: cardIn var(--t-slow) var(--ease) both;
}
.path-card__btns { display: none !important; gap: 6px; align-items: center; justify-content: flex-end; margin-top: var(--space-2); }
.path-card--active .path-card__btns { display: flex !important; }
@keyframes cardIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.path-card:hover { border-color: var(--brand-mid); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.path-card:active { transform: scale(0.97); }
.path-card__icon { font-size: 24px; margin-bottom: var(--space-3); line-height: 1; }
.path-card__name { font-size: 13px; font-weight: 500; color: var(--text); margin-bottom: 2px; line-height: 1.3; }
.path-card__cat { font-size: 11px; color: var(--text-3); }
.path-card__sub { font-size: 11px; color: var(--brand); margin-top: 4px; }

/* ─── FOOTER ─── */
.footer {
  background: var(--brand-dark); color: rgba(255,255,255,0.6);
  padding: var(--space-8) var(--space-5); text-align: center;
}
.footer__logo { font-family: var(--font-display); font-size: 18px; color: white; margin-bottom: var(--space-3); }
.footer__logo span { color: var(--brand-mid); font-style: italic; }
.footer__disclaimer {
  font-size: 12px; max-width: 560px; margin: 0 auto var(--space-4);
  line-height: 1.6; font-style: italic;
}
.footer__meta { font-size: 11px; color: rgba(255,255,255,0.35); }

/* ─── FOOTER NAVIGATION LÉGALE ─── */
.footer__nav {
  display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5);
  justify-content: center; margin: var(--space-5) 0 var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.footer__nav-link {
  font-size: 12px; color: rgba(255,255,255,0.5);
  text-decoration: none; transition: color var(--t-fast);
  cursor: pointer; background: none; border: none; font-family: var(--font-body);
}
.footer__nav-link:hover { color: var(--brand-mid); }

/* ─── PAGES LÉGALES (overlay SPA) ─── */
.legal-overlay {
  position: fixed; inset: 0; z-index: 8000;
  background: var(--bg);
  display: none; flex-direction: column;
  overflow-y: auto;
  animation: legalFadeIn var(--t-slow) var(--ease) forwards;
}
.legal-overlay.active { display: flex; }
@keyframes legalFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.legal-header {
  position: sticky; top: 0; z-index: 10;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-4) var(--space-6);
}
.legal-header__back {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: 13px; color: var(--brand);
  cursor: pointer; background: none; border: none;
  font-family: var(--font-body); padding: var(--space-2) var(--space-3);
  border-radius: var(--r-sm); transition: background var(--t-fast);
}
.legal-header__back:hover { background: var(--brand-light); }
.legal-header__title {
  font-family: var(--font-display); font-size: 20px;
  color: var(--text); flex: 1;
}
.legal-header__badge {
  font-size: 11px; color: var(--text-3); padding: 3px 8px;
  background: var(--surface-2); border-radius: var(--r-sm);
}
.legal-body {
  max-width: 760px; width: 100%;
  margin: 0 auto; padding: var(--space-10) var(--space-6) var(--space-12);
}
.legal-body h2 {
  font-family: var(--font-display); font-size: 22px;
  color: var(--brand-dark); margin: var(--space-10) 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--brand-border);
}
.legal-body h2:first-child { margin-top: 0; }
.legal-body h3 {
  font-size: 14px; font-weight: 500; color: var(--text);
  margin: var(--space-5) 0 var(--space-2); text-transform: uppercase;
  letter-spacing: .04em; font-size: 12px; color: var(--text-3);
}
.legal-body p {
  font-size: 14px; color: var(--text-2); line-height: 1.75;
  margin-bottom: var(--space-4);
}
.legal-body ul {
  margin: 0 0 var(--space-4) var(--space-6);
  font-size: 14px; color: var(--text-2); line-height: 1.75;
}
.legal-body ul li { margin-bottom: var(--space-1); }
.legal-body strong { color: var(--text); font-weight: 500; }
.legal-body a { color: var(--brand); text-decoration: underline; }
.legal-info-box {
  background: var(--brand-xlight); border: 1px solid var(--brand-border);
  border-radius: var(--r-md); padding: var(--space-4) var(--space-5);
  margin: var(--space-4) 0; font-size: 13px; color: var(--brand-dark);
  line-height: 1.65;
}
.legal-contact-block {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--space-5);
  margin-top: var(--space-6);
}
.legal-contact-block p { margin-bottom: var(--space-2); }
[data-theme="dark"] .legal-overlay { background: var(--bg); }
[data-theme="dark"] .legal-header { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .legal-body h2 { color: var(--brand-mid); border-color: #2A2A4A; }


/* ─── BOUTON SCROLL HAUT/BAS ─── */
#scroll-fab {
  position: fixed; bottom: 24px; right: 24px; z-index: 7000;
  display: flex; flex-direction: column; gap: 6px;
  opacity: 0; pointer-events: none;
  transition: opacity var(--t-mid) var(--ease);
}
#scroll-fab.visible { opacity: 1; pointer-events: auto; }
.scroll-fab-btn {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--brand); color: white; border: none;
  font-size: 18px; cursor: pointer; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 12px rgba(27,107,82,0.30);
  transition: background var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
}
.scroll-fab-btn:hover { background: var(--brand-mid); transform: scale(1.08); box-shadow: 0 6px 16px rgba(27,107,82,0.40); }
.scroll-fab-btn:active { transform: scale(0.95); }
[data-theme="dark"] .scroll-fab-btn { background: #2D5042; box-shadow: 0 4px 12px rgba(0,0,0,0.40); }
[data-theme="dark"] .scroll-fab-btn:hover { background: #1B6B52; }

/* ─── NIVEAUX FORMATION ─── */
.fm-niveaux {
  display: flex; gap: 6px; padding: var(--space-3) var(--space-5);
  background: var(--surface); border-bottom: 1px solid var(--border);
  flex-wrap: wrap; align-items: center;
}
.fm-niveaux__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-3); margin-right: 4px;
}
.fm-niveau-btn {
  padding: 5px 14px; border-radius: 20px; font-size: 12px; font-weight: 600;
  cursor: pointer; border: 1.5px solid var(--border-strong);
  background: var(--surface-2); color: var(--text-3);
  font-family: var(--font-body); transition: all var(--t-fast);
  white-space: nowrap;
}
.fm-niveau-btn:hover { border-color: var(--brand); color: var(--brand); }
.fm-niveau-btn.active { background: var(--brand); color: white; border-color: var(--brand); }
.fm-niveau-btn[data-n="1"].active { background: #1B6B52; border-color: #1B6B52; }
.fm-niveau-btn[data-n="2"].active { background: #1E40AF; border-color: #1E40AF; }
.fm-niveau-btn[data-n="3"].active { background: #5B21B6; border-color: #5B21B6; }
.fm-niveau-btn[data-n="4"].active { background: #991B1B; border-color: #991B1B; }
/* Niveaux formation : boutons affichés — contenu complet visible à tous les niveaux */
[data-theme="dark"] .fm-niveaux { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .fm-niveau-btn { background: #12122A; color: #8080A0; border-color: #2A2A4A; }
[data-theme="dark"] .fm-niveau-btn:hover { border-color: #4CAF90; color: #4CAF90; }


/* ─── UTILITIES ─── */
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
.divider { border: none; border-top: 1px solid var(--border); margin: var(--space-6) 0; }

/* ─── RESPONSIVE ─── */
@media (max-width: 600px) {
  .fiche-card__body { grid-template-columns: 1fr; }
  .cards-grid { grid-template-columns: repeat(2, 1fr); }
  .hero { padding: var(--space-8) var(--space-4) var(--space-6); }
  .fiche-card__header { padding: var(--space-4); }
  .fiche-bloc { padding: var(--space-4); }
  .stats-bar { gap: var(--space-4); flex-wrap: wrap; justify-content: center; }
  .fiche-card__otc { flex-direction: column; }
}

/* ─── LISTES DANS FICHES ─── */
.fiche-bloc__text ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.fiche-bloc__text ul li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; line-height: 1.5; }
.fiche-bloc__text ul li::before { content: '—'; color: var(--brand-mid); font-weight: 500; flex-shrink: 0; margin-top: 1px; }
.fiche-bloc.is-danger .fiche-bloc__text ul li::before { color: var(--danger-label); }
.fiche-bloc.is-warning .fiche-bloc__text ul li::before { color: var(--warning-label); }
.fiche-bloc.is-info .fiche-bloc__text ul li::before { color: var(--brand); }

/* ─── ONGLETS ─── */
.fiche-tabs { display: flex; border-bottom: 1px solid var(--border); background: var(--surface); overflow-x: auto; scrollbar-width: none; }
.fiche-tabs::-webkit-scrollbar { display: none; }
.fiche-tab { padding: var(--space-3) var(--space-5); font-size: 13px; font-weight: 500; color: var(--text-3); border-bottom: 2px solid transparent; cursor: pointer; white-space: nowrap; transition: color var(--t-fast), border-color var(--t-fast); background: none; border-top: none; border-left: none; border-right: none; font-family: var(--font-body); }
.fiche-tab:hover { color: var(--brand); }
.fiche-tab.active { color: var(--brand); border-bottom-color: var(--brand); }
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* ─── VENTE COMPLEMENTAIRE ─── */
.vente-header { padding: var(--space-4) var(--space-6) var(--space-2); font-size: 12px; color: var(--text-3); font-style: italic; }
.vente-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--space-3); padding: var(--space-2) var(--space-6) var(--space-5); }
.vente-card { background: var(--brand-xlight); border: 1px solid var(--brand-border); border-radius: var(--r-lg); padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
.vente-card__icon { font-size: 18px; }
.vente-card__produit { font-size: 13px; font-weight: 500; color: var(--brand-dark); line-height: 1.4; }
.vente-card__raison { font-size: 12px; color: var(--text-3); line-height: 1.4; }

/* ─── BOUTON IMPRESSION ─── */
.btn-print { background: var(--surface-2); border: 1px solid var(--border); color: var(--text-2); border-radius: var(--r-md); width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; cursor: pointer; font-size: 15px; transition: background var(--t-fast); }
.btn-print:hover { background: white; }

/* ─── SOURCES ─── */
.fiche-sources { background: var(--surface-2); border-top: 1px solid var(--border); padding: var(--space-3) var(--space-6); display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.fiche-sources__label { font-size: 11px; font-weight: 500; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; }
.fiche-sources__links { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.fiche-sources__link { font-size: 11px; color: var(--brand); text-decoration: none; border-bottom: 1px solid var(--brand-border); transition: color var(--t-fast); }
.fiche-sources__link:hover { color: var(--brand-mid); }
.fiche-sources__sep { font-size: 11px; color: var(--text-3); }

/* ─── BANNIÈRE PATHOLOGIES HERO ─── */
.patho-hero-banner {
  background: linear-gradient(135deg, var(--brand-dark) 0%, #1a5c45 100%);
  position: relative; overflow: hidden;
  padding: var(--space-5) var(--space-5) var(--space-6);
  text-align: center;
}
.patho-hero-banner__before {
  content: '';
  position: absolute; font-size: 120px; opacity: 0.06;
  top: -8px; right: 24px; pointer-events: none;
  width: 120px; height: 120px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Ctext y='52' font-size='52'%3E💊%3C/text%3E%3C/svg%3E") no-repeat center/contain;
  opacity: 0.08;
}
.patho-hero-banner__inner { position: relative; z-index: 1; max-width: 760px; margin: 0 auto; }
.patho-hero-banner__eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.65); background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2); padding: 4px 12px; border-radius: 20px;
  margin-bottom: var(--space-3);
}
.patho-hero-banner__title {
  font-family: var(--font-display);
  font-size: clamp(20px, 3vw, 28px);
  color: white; letter-spacing: -0.3px; margin-bottom: var(--space-4); line-height: 1.2;
}
.patho-hero-banner__title em { color: #7FD4AD; font-style: italic; }
.patho-hero-banner__items {
  display: flex; align-items: center; justify-content: center;
  gap: var(--space-3); flex-wrap: wrap;
}
.patho-hero-banner__item {
  display: flex; align-items: center; gap: 5px;
  color: rgba(255,255,255,0.8); font-size: 13px;
}
.patho-hero-banner__item strong { color: white; font-weight: 600; }
.patho-hero-banner__sep {
  width: 1px; height: 20px; background: rgba(255,255,255,0.2); flex-shrink: 0;
}
@media (max-width: 600px) {
  .patho-hero-banner__sep { display: none; }
  .patho-hero-banner { padding: var(--space-4) var(--space-4) var(--space-5); }
}

/* ─── DISCLAIMER CHECKLIST ─── */
.disclaimer-check { background: linear-gradient(135deg, #B45309 0%, #D97706 50%, #B45309 100%); background-size: 200% 200%; animation: shimmer 3s ease infinite; padding: var(--space-4) var(--space-5); display: flex; align-items: center; justify-content: center; gap: var(--space-3); flex-wrap: wrap; border-top: 3px solid #FCD34D; border-bottom: 3px solid #FCD34D; box-shadow: 0 4px 20px rgba(180,83,9,0.4); position: relative; z-index: 0; }
@keyframes shimmer { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
.disclaimer-check__icon { font-size: 22px; animation: pulse-icon 2s ease infinite; }
@keyframes pulse-icon { 0%,100% { transform: scale(1); } 50% { transform: scale(1.2); } }
.disclaimer-check__text { font-size: 14px; font-weight: 500; color: white; text-align: center; text-shadow: 0 1px 2px rgba(0,0,0,0.3); }
.disclaimer-check__text strong { font-size: 15px; font-weight: 700; display: block; margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.06em; color: #FCD34D; }
.disclaimer-check__pills { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px; margin-top: 6px; }
.disclaimer-check__pill { background: rgba(255,255,255,0.18); border: 1px solid rgba(255,255,255,0.35); border-radius: 20px; padding: 3px 12px; font-size: 12px; font-weight: 500; color: white; }

@media (max-width: 600px) {
  .vente-grid { grid-template-columns: 1fr 1fr; padding: var(--space-4); }
}

/* ═══════════════════════════════
   PAGE MAD — MATÉRIEL MÉDICAL
   ═══════════════════════════════ */

/* ─── NAV TABS (router) ─── */
.page-nav {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  display: flex; padding: 0 var(--space-5);
  overflow-x: auto; scrollbar-width: none;
}
.page-nav::-webkit-scrollbar { display: none; }
.page-nav__tab {
  padding: var(--space-3) var(--space-5);
  font-size: 14px; font-weight: 500; color: var(--text-3);
  border-bottom: 2px solid transparent;
  cursor: pointer; white-space: nowrap;
  background: none; border-top: none; border-left: none; border-right: none;
  font-family: var(--font-body); transition: color var(--t-fast), border-color var(--t-fast);
}
.page-nav__tab:hover { color: var(--brand); }
.page-nav__tab.active { color: var(--brand); border-bottom-color: var(--brand); }

/* ─── PAGE VIEWS ─── */
.page-view { display: none; }
.page-view.active { display: block; }

/* ─── MAD HERO ─── */
.mad-hero {
  background: linear-gradient(135deg, #1E3A5F 0%, #2C5282 100%);
  padding: var(--space-8) var(--space-5) var(--space-6);
  text-align: center; color: white;
  position: relative; overflow: hidden;
}
.mad-hero::before {
  content: '🏠';
  position: absolute; font-size: 120px; opacity: 0.06;
  top: -10px; right: 20px; pointer-events: none;
}
.mad-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2); padding: 4px 12px; border-radius: 20px;
  margin-bottom: var(--space-4);
}
.mad-hero__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 3.5vw, 30px);
  color: white; margin-bottom: var(--space-2); letter-spacing: -0.3px;
}
.mad-hero__title em { color: #90CDF4; font-style: italic; }
.mad-hero__sub { font-size: 13px; color: rgba(255,255,255,0.65); max-width: 420px; margin: 0 auto; }

/* ─── FILTERS ─── */
.mad-filters-wrap { background: var(--surface); border-bottom: 1px solid var(--border); padding: var(--space-3) var(--space-5); }
#mad-filters { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.mad-filter {
  padding: var(--space-2) var(--space-4);
  font-size: 13px; font-weight: 500; border-radius: 20px;
  border: 1.5px solid var(--border); background: var(--surface);
  color: var(--text-2); cursor: pointer; white-space: nowrap;
  font-family: var(--font-body);
  transition: all var(--t-fast) var(--ease);
}
.mad-filter:hover { border-color: var(--brand-mid); color: var(--brand); }
.mad-filter.active { background: var(--brand); border-color: var(--brand); color: white; }

/* ─── MAD MAIN ─── */
.mad-main { max-width: 760px; margin: 0 auto; padding: var(--space-5) var(--space-5) var(--space-12); }
.mad-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }
.mad-section-label { font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-3); }
.mad-count { font-size: 12px; color: var(--text-3); }

/* ─── MAD DETAIL PANEL ─── */
.mad-detail {
  display: none; background: var(--surface);
  border: 1px solid var(--border-strong); border-radius: var(--r-xl);
  overflow: hidden; margin-bottom: var(--space-5);
  box-shadow: var(--shadow-lg);
  animation: slideIn var(--t-slow) var(--ease);
}
.mad-detail.visible { display: block; }
.mad-detail__header {
  background: linear-gradient(135deg, var(--brand-dark) 0%, var(--brand) 100%);
  padding: var(--space-5) var(--space-6);
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4);
}
.mad-detail__header-left { display: flex; align-items: flex-start; gap: var(--space-4); }
.mad-detail__icon {
  width: 48px; height: 48px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.12); display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.mad-detail__nom { font-family: var(--font-display); font-size: 20px; color: white; margin-bottom: 4px; }
.mad-detail__rx { font-size: 12px; color: rgba(255,255,255,0.75); }
.mad-detail__close {
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2);
  color: white; border-radius: var(--r-md); width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; font-size: 16px;
  transition: background var(--t-fast);
}
.mad-detail__close:hover { background: rgba(255,255,255,0.22); }
.mad-detail__body { padding: var(--space-5) var(--space-6); display: flex; flex-direction: column; gap: var(--space-5); }
.mad-detail__section-label {
  font-size: 11px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.07em; color: var(--text-3); margin-bottom: var(--space-2);
}
.mad-detail__text { font-size: 13px; color: var(--text-2); line-height: 1.7; }
.mad-detail__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.mad-detail__list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; line-height: 1.5; color: var(--text-2); }
.mad-detail__list li::before { content: '—'; color: var(--brand-mid); font-weight: 500; flex-shrink: 0; }
.mad-patho-btn {
  font-size: 12px; font-weight: 500; padding: 5px 12px; border-radius: 20px;
  background: var(--brand-light); color: var(--brand-dark);
  border: 1px solid var(--brand-border); cursor: pointer;
  font-family: var(--font-body); transition: background var(--t-fast);
}
.mad-patho-btn:hover { background: var(--brand-mid); color: white; }

/* ─── MAD CARDS ─── */
#mad-grid { display: flex; flex-direction: column; gap: var(--space-3); }
.mad-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--space-4) var(--space-5);
  display: flex; align-items: center; gap: var(--space-4);
  cursor: pointer; transition: border-color var(--t-fast), box-shadow var(--t-fast);
  animation: cardIn var(--t-slow) var(--ease) both;
}
.mad-card:hover { border-color: var(--brand-mid); box-shadow: var(--shadow-sm); }
.mad-card__icon { font-size: 28px; flex-shrink: 0; width: 44px; text-align: center; }
.mad-card__body { flex: 1; min-width: 0; }
.mad-card__nom { font-size: 14px; font-weight: 500; color: var(--text); margin-bottom: 2px; }
.mad-card__indication { font-size: 12px; color: var(--text-3); margin-bottom: 6px; }
.mad-card__tags { display: flex; flex-wrap: wrap; gap: 5px; }
.mad-tag { font-size: 11px; padding: 2px 8px; border-radius: 20px; font-weight: 500; }
.mad-tag--rx { background: #FDF6E8; color: #B45309; border: 1px solid #F5D98A; }
.mad-tag--libre { background: var(--brand-light); color: var(--brand); border: 1px solid var(--brand-border); }
.mad-tag--link { background: #F0EDFF; color: #5B3FD4; border: 1px solid #C5B8F8; }
.mad-card__arrow { font-size: 20px; color: var(--text-3); flex-shrink: 0; }

/* ─── NAV MAD BUTTON (accueil) ─── */
.mad-home-btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  background: var(--brand-dark); color: white;
  border: none; border-radius: var(--r-lg); padding: var(--space-3) var(--space-5);
  font-size: 14px; font-weight: 500; cursor: pointer;
  font-family: var(--font-body); margin-top: var(--space-4);
  transition: opacity var(--t-fast);
}
.mad-home-btn:hover { opacity: 0.88; }

@media (max-width: 600px) {
  .mad-detail__body { padding: var(--space-4); }
  .mad-card { padding: var(--space-3) var(--space-4); }
}

/* ─── MAD INLINE DETAIL ─── */
.mad-inline-detail { max-height: 0; overflow: hidden; transition: max-height 0.35s cubic-bezier(0.16,1,0.3,1); background: var(--brand-xlight); border-left: 3px solid var(--brand-mid); border-radius: 0 0 var(--r-lg) var(--r-lg); margin-bottom: 2px; }
.mad-inline-detail.open { max-height: 800px; }
.mad-card--active { border-color: var(--brand-mid); border-bottom-left-radius: 0; border-bottom-right-radius: 0; background: var(--brand-xlight); }
.mad-card__btn-edit { display: none; }
.mad-card--active .mad-card__btn-edit { display: inline-flex; }
.path-card--active .mad-card__btn-edit { display: inline-flex; }
.mad-card--active .mad-card__indication { display: none; }
.mad-card__arrow { font-size: 20px; color: var(--text-3); flex-shrink: 0; transition: transform 0.2s var(--ease); }
.mad-card__arrow.open { transform: rotate(90deg); color: var(--brand); }

/* ─── MÉDECINE NATURELLE ─── */
.nat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--space-3); padding: var(--space-4) var(--space-6) var(--space-5); }
.nat-card { background: #F2FAF6; border: 1px solid var(--brand-border); border-radius: var(--r-lg); padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
.nat-card__icon { font-size: 20px; }
.nat-card__titre { font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; color: var(--brand); }
.nat-card__text { font-size: 13px; color: var(--text-2); line-height: 1.6; }

@media (max-width: 600px) {
  .nat-grid { grid-template-columns: 1fr; padding: var(--space-4); }
}

/* ─── PATH CARD ACCORDION ─── */
.path-card-wrap { display: contents; }
.path-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--space-4);
  cursor: pointer; user-select: none;
  display: flex; flex-direction: column; align-items: flex-start;
  transition: border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
  animation: cardIn var(--t-slow) var(--ease) both;
  position: relative;
}
.path-card:hover { border-color: var(--brand-mid); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.path-card__arrow {
  position: absolute; top: var(--space-3); right: var(--space-3);
  font-size: 16px; color: var(--text-3);
  transition: transform 0.25s var(--ease), color 0.15s;
}
.path-card__arrow.open { transform: rotate(90deg); color: var(--brand); }

/* ─── FICHE INLINE SLOT ─── */
.fiche-inline-slot {
  max-height: 0; overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.16,1,0.3,1);
  background: var(--surface);
  border: 1px solid var(--brand-mid);
  border-top: none;
  border-bottom-left-radius: var(--r-lg);
  border-bottom-right-radius: var(--r-lg);
  margin-bottom: 2px;
}
.fiche-inline-slot.open { max-height: 2000px; }

/* ─── FICHE INLINE CARD ─── */
.fiche-inline-card { overflow: hidden; }
.fiche-inline-header {
  background: linear-gradient(135deg, var(--brand-dark) 0%, var(--brand) 100%);
  padding: var(--space-4) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
}
.fiche-inline-header-left { display: flex; align-items: center; gap: var(--space-3); }

/* ─── MAD CATEGORIES GROUPÉES ─── */
.mad-cat-group { margin-bottom: var(--space-6); }
.mad-cat-title {
  font-size: 13px; font-weight: 500; color: var(--brand-dark);
  text-transform: uppercase; letter-spacing: 0.07em;
  padding: var(--space-3) 0 var(--space-3);
  border-bottom: 2px solid var(--brand-light);
  margin-bottom: var(--space-3);
  display: flex; align-items: center; gap: var(--space-2);
}

/* ─── MAD INLINE DETAIL (remplace le panel flottant) ─── */
.mad-inline-detail {
  display: none;
}
.mad-inline-detail.open { display: block; }
.mad-inline-card {
  background: var(--brand-xlight);
  border: 1px solid var(--brand-border);
  border-radius: var(--r-lg);
  margin-bottom: var(--space-3);
  overflow: visible;
  animation: slideIn var(--t-mid) var(--ease);
}

/* ─── MAD CARD ACTIVE ─── */
.mad-card--active {
  border-color: var(--brand-mid);
  background: var(--brand-xlight);
}
.mad-card__arrow { font-size: 20px; color: var(--text-3); flex-shrink: 0; transition: transform var(--t-mid); }
.mad-card__arrow.open { transform: rotate(90deg); color: var(--brand); }

/* ─── MÉDECINE NATURELLE ─── */
.mn-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1px; background: var(--border);
  margin: 0;
}
.mn-bloc {
  background: var(--surface);
  padding: var(--space-5) var(--space-6);
}
.mn-bloc__label {
  font-size: 11px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.07em; color: var(--brand); margin-bottom: var(--space-3);
}
.mn-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 6px; }
.mn-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; line-height: 1.55; color: var(--text-2); }
.mn-list li::before { content: '—'; color: var(--brand-mid); font-weight: 500; flex-shrink: 0; margin-top: 1px; }
.mn-disclaimer {
  font-size: 11px; font-style: italic; color: var(--text-3);
  padding: var(--space-3) var(--space-6);
  border-top: 1px solid var(--border);
  background: var(--surface-2);
}

@media (max-width: 600px) {
  .mn-grid { grid-template-columns: 1fr; }
}

/* ─── CARTE PATHOLOGIE ACTIVE (toggle) ─── */
.path-card--active {
  border-color: var(--brand-mid);
  background: var(--brand-xlight);
}
.path-card--active .path-card__name { color: var(--brand-dark); }
.path-card--active .path-card__btns { display: flex !important; }

/* ─── FICHE HEADER CLIQUABLE ─── */
.fiche-card__header { cursor: pointer; }
.fiche-card__header:hover { opacity: 0.92; }

/* ─── FICHE PATHOLOGIE INLINE (comme MAD) ─── */
.path-inline-detail {
  grid-column: 1 / -1;
  display: none;
  margin-bottom: var(--space-2);
}
.path-inline-detail.open { display: block; }
.path-inline-card {
  background: var(--brand-xlight);
  border: 1px solid var(--brand-border);
  border-radius: var(--r-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  animation: slideIn var(--t-mid) var(--ease);
}

/* ═══════════════════════════════
   PAGE DERMATOLOGIE
   ═══════════════════════════════ */
.dermato-hero {
  background: linear-gradient(135deg, #6B2D5E 0%, #A0527A 100%);
  padding: var(--space-8) var(--space-5) var(--space-6);
  text-align: center; color: white; position: relative; overflow: hidden;
}
.dermato-hero::before {
  content: '🧴'; position: absolute; font-size: 120px; opacity: 0.06;
  top: -10px; right: 20px; pointer-events: none;
}
.dermato-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.65); background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2); padding: 4px 12px; border-radius: 20px;
  margin-bottom: var(--space-4);
}
.dermato-hero__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 3.5vw, 30px);
  color: white; margin-bottom: var(--space-2); letter-spacing: -0.3px;
}
.dermato-hero__title em { color: #F5AACF; font-style: italic; }
.dermato-hero__sub { font-size: 13px; color: rgba(255,255,255,0.65); }

/* ─── DÉTAIL DERMATO ─── */
.dermato-detail-header {
  background: linear-gradient(135deg, #6B2D5E 0%, #A0527A 100%);
  padding: var(--space-5) var(--space-6);
  display: flex; align-items: flex-start; gap: var(--space-4);
}
.dermato-detail-icon {
  width: 48px; height: 48px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.15); display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.dermato-detail-nom { font-family: var(--font-display); font-size: 18px; color: white; margin-bottom: 4px; }
.dermato-detail-desc { font-size: 12px; color: rgba(255,255,255,0.75); line-height: 1.5; }
.dermato-detail-body { padding: var(--space-5) var(--space-6); display: flex; flex-direction: column; gap: var(--space-5); }

/* ─── PRODUITS DERMATO ─── */
.dermato-produits { display: flex; flex-direction: column; gap: var(--space-3); }
.dermato-grid-produits {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-3); margin-top: var(--space-2);
}
.dermato-produit-card {
  background: white; border: 1px solid #E8D5E4;
  border-radius: var(--r-lg); padding: var(--space-4);
  display: flex; flex-direction: column; gap: 4px;
}
.dermato-produit__nom { font-size: 13px; font-weight: 500; color: #6B2D5E; line-height: 1.3; }
.dermato-produit__usage { font-size: 12px; color: var(--text-2); line-height: 1.4; }
.dermato-produit__texture {
  font-size: 11px; color: #A0527A; font-weight: 500;
  background: #F9EEF5; padding: 2px 8px; border-radius: 10px;
  align-self: flex-start; margin-top: 2px;
}

/* ─── À ÉVITER ─── */
.dermato-eviter li::before { color: #C0392B !important; }

/* ─── SOURCES ─── */
.dermato-sources {
  font-size: 11px; color: var(--text-3); font-style: italic;
  padding-top: var(--space-3); border-top: 1px solid var(--border);
}

@media (max-width: 600px) {
  .dermato-grid-produits { grid-template-columns: 1fr 1fr; }
  .dermato-detail-body { padding: var(--space-4); }
}

/* ─── GAMME PRODUIT + NATUREL ─── */
.dermato-produit__gamme {
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.07em; color: #A0527A; margin-bottom: 4px;
}
.dermato-naturel {
  background: linear-gradient(135deg, #E8F5E4 0%, #F0FAE8 100%);
  border: 1.5px solid #A8D5A2;
  border-radius: var(--r-lg); padding: var(--space-4) var(--space-5);
}
.dermato-naturel__label {
  font-size: 12px; font-weight: 600; color: #2D6A4F;
  margin-bottom: var(--space-2); text-transform: uppercase; letter-spacing: 0.06em;
}
.dermato-naturel__content {
  font-size: 13px; color: #1B4332; line-height: 1.6;
}

.path-inline-card { overflow: visible !important; max-height: none !important; }

/* ─── FIX SCROLL CONTENU COMPLET ─── */
.dermato-detail-body,
.mad-detail__body,
.mad-inline-card,
.mad-inline-detail,
.path-inline-card,
.path-inline-detail {
  max-height: none !important;
  overflow: visible !important;
}
.dermato-grid-produits {
  overflow: visible !important;
}

/* ═══════════════════════════════
   PAGE FORMATION
   ═══════════════════════════════ */
.formation-hero {
  background: linear-gradient(135deg, #3B1F6B 0%, #5B3FD4 100%);
  padding: var(--space-8) var(--space-5) var(--space-6);
  text-align: center; color: white; position: relative; overflow: hidden;
}
.formation-hero::before {
  content: '📚'; position: absolute; font-size: 120px; opacity: 0.06;
  top: -10px; right: 20px; pointer-events: none;
}
.formation-hero__eyebrow {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.65); background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.2); padding: 4px 12px; border-radius: 20px;
  margin-bottom: var(--space-4);
}
.formation-hero__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 3.5vw, 30px);
  color: white; margin-bottom: var(--space-2);
}
.formation-hero__title em { color: #7EC8E3; font-style: italic; }
.formation-hero__sub { font-size: 13px; color: rgba(255,255,255,0.65); }

/* ─── LISTE FORMATIONS ─── */
.formation-main { max-width: 760px; margin: 0 auto; padding: var(--space-5) var(--space-5) var(--space-12); }
.formation-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-4); }

#formation-list { display: flex; flex-direction: column; gap: var(--space-2); }

.formation-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: var(--space-4) var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  cursor: pointer; transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.formation-card:hover { border-color: #2E6DA4; box-shadow: var(--shadow-sm); }
.formation-card--active { border-color: #2E6DA4; background: #EEF4FB; }
.formation-card__left { display: flex; align-items: center; gap: var(--space-3); }
.formation-card__icon { font-size: 24px; flex-shrink: 0; }
.formation-card__nom { font-size: 14px; font-weight: 500; color: var(--text); }
.formation-card__cat { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.formation-card__arrow { font-size: 20px; color: var(--text-3); transition: transform var(--t-mid); }
.formation-card__arrow.open { transform: rotate(90deg); color: #2E6DA4; }

/* ─── INLINE DETAIL FORMATION ─── */
.formation-inline { display: none; margin-bottom: var(--space-3); }
.formation-inline.open { display: block; }

.formation-detail {
  background: var(--surface); border: 1px solid #A8C8E8;
  border-radius: var(--r-xl); overflow: visible;
  box-shadow: var(--shadow-md); animation: slideIn var(--t-mid) var(--ease);
}
.formation-detail__header {
  background: linear-gradient(135deg, #1E3A5F 0%, #2E6DA4 100%);
  padding: var(--space-5) var(--space-6);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  cursor: pointer; border-radius: var(--r-xl) var(--r-xl) 0 0;
}
.formation-detail__header:hover { opacity: 0.92; }
.formation-detail__header-left { display: flex; align-items: center; gap: var(--space-4); }
.formation-detail__icon {
  width: 48px; height: 48px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.15); display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.formation-detail__nom { font-family: var(--font-display); font-size: 20px; color: white; margin-bottom: 4px; }
.formation-detail__cat { font-size: 12px; color: rgba(255,255,255,0.7); }

.formation-detail__body {
  padding: 0; display: flex; flex-direction: column;
  overflow: visible; max-height: none;
}

/* ─── SECTIONS ─── */
.formation-section {
  padding: var(--space-5) var(--space-6);
  border-bottom: 1px solid var(--border);
  overflow: visible;
}
.formation-section:last-child { border-bottom: none; }
.formation-section__title {
  font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.07em; margin-bottom: var(--space-3);
  display: flex; align-items: center; gap: var(--space-2);
}
.formation-section--physio { background: #F0F7FF; }
.formation-section--physio .formation-section__title { color: #1E3A5F; }
.formation-section--consequences { background: #FDF6E8; }
.formation-section--consequences .formation-section__title { color: #B45309; }
.formation-section--mecanisme { background: #F0FFF4; }
.formation-section--mecanisme .formation-section__title { color: #1B6B52; }
.formation-section--cles { background: linear-gradient(135deg, #F0FFF4 0%, #EEF4FB 100%); }
.formation-section--cles .formation-section__title { color: #1B6B52; }

.formation-physio-text {
  font-size: 13px; line-height: 1.75; color: var(--text-2);
}

.formation-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.formation-list li {
  display: flex; align-items: flex-start; gap: 8px;
  font-size: 13px; line-height: 1.6; color: var(--text-2);
}
.formation-list li::before { content: '—'; color: var(--brand-mid); font-weight: 600; flex-shrink: 0; }
.formation-list--cles li::before { content: '✓'; color: #1B6B52; }

/* ─── EFFETS SECONDAIRES ─── */
.formation-es-group { margin-bottom: var(--space-3); }
.formation-es__freq {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--danger-label);
  margin-bottom: var(--space-2); padding: 2px 8px;
  background: var(--danger-bg); border-radius: 4px; display: inline-block;
}

/* ─── CLASSES PHARMACOLOGIQUES ─── */
.formation-classes {
  display: flex; flex-direction: column; gap: var(--space-3);
  margin-top: var(--space-3);
}
.formation-classe-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden;
}
.formation-classe__header {
  background: #EEF4FB; padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid #A8C8E8;
}
.formation-classe__nom {
  font-size: 13px; font-weight: 600; color: #1E3A5F; margin-bottom: 2px;
}
.formation-classe__famille {
  font-size: 11px; color: #2E6DA4; font-style: italic;
}
.formation-classe__body { padding: var(--space-3) var(--space-4); }
.formation-classe__row {
  display: flex; gap: var(--space-3); margin-bottom: 5px;
  font-size: 13px; line-height: 1.5;
}
.formation-classe__label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  color: var(--text-3); letter-spacing: 0.05em; min-width: 70px; margin-top: 1px;
}
.formation-classe__val { color: var(--text-2); }
.formation-classe__remarque {
  margin-top: var(--space-2); font-size: 12px; color: #1B6B52;
  font-style: italic; padding-top: var(--space-2);
  border-top: 1px dashed var(--border);
}

@media (max-width: 600px) {
  .formation-section { padding: var(--space-4); }
  .formation-detail__header { padding: var(--space-4); }
  .formation-classe__row { flex-direction: column; gap: 2px; }
}

/* ═══════════════════════════════
   FORMATION — REDESIGN MAGAZINE
   ═══════════════════════════════ */

/* ─── DÉTAIL ─── */
.fm-detail {
  background: var(--surface);
  border: 1px solid #A8C8E8;
  border-radius: var(--r-xl);
  overflow: visible;
  box-shadow: var(--shadow-lg);
  animation: slideIn var(--t-mid) var(--ease);
  margin-bottom: var(--space-3);
}

/* ─── HEADER ─── */
.fm-header {
  background: linear-gradient(135deg, #1E3A5F 0%, #2E6DA4 100%);
  padding: var(--space-5) var(--space-6);
  display: flex; align-items: center; justify-content: space-between;
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  cursor: pointer; gap: var(--space-4);
}
.fm-header:hover { opacity: 0.92; }
.fm-header__left { display: flex; align-items: center; gap: var(--space-4); }
.fm-header__icon {
  width: 52px; height: 52px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; flex-shrink: 0;
}
.fm-header__nom { font-family: var(--font-display); font-size: 22px; color: white; margin-bottom: 4px; }
.fm-header__cat { font-size: 12px; color: rgba(255,255,255,0.7); }

/* ─── LE SAVIEZ-VOUS ─── */
.fm-saviez {
  display: flex; gap: var(--space-4); align-items: flex-start;
  background: linear-gradient(135deg, #FDF6E8 0%, #FFF9F0 100%);
  border-left: 4px solid #F5A623;
  padding: var(--space-4) var(--space-6);
  margin: 0;
}
.fm-saviez__icon { font-size: 28px; flex-shrink: 0; }
.fm-saviez__title {
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; color: #B45309; margin-bottom: 4px;
}
.fm-saviez__text { font-size: 13px; color: #6B3A00; line-height: 1.65; }

/* ─── BODY 2 COLONNES ─── */
.fm-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--border);
}
.fm-col { display: flex; flex-direction: column; }
.fm-col:first-child { border-right: 1px solid var(--border); }

/* ─── SECTIONS ─── */
.fm-section {
  padding: var(--space-5) var(--space-5);
  border-bottom: 1px solid var(--border);
  overflow: visible;
}
.fm-section:last-child { border-bottom: none; }
.fm-section__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; margin-bottom: var(--space-3);
  display: flex; align-items: center; gap: 6px;
}
.fm-section--physio { background: #F5F9FF; }
.fm-section--physio .fm-section__label { color: #1E3A5F; }
.fm-section--meca { background: #F0FFF4; }
.fm-section--meca .fm-section__label { color: #1B6B52; }
.fm-section--consequences { background: #FFF9F0; }
.fm-section--consequences .fm-section__label { color: #B45309; }
.fm-section--effets { background: #FFF5F5; }
.fm-section--effets .fm-section__label { color: #C0392B; }
.fm-section--classes { background: var(--surface); }
.fm-section--classes .fm-section__label { color: #1E3A5F; }
.fm-section--schema { background: #F8F9FA; }
.fm-section--schema .fm-section__label { color: #555; }
.fm-section--points {
  background: linear-gradient(135deg, #E8F5E9 0%, #E3F2FD 100%);
  border-top: 2px solid #1B6B52;
  padding: var(--space-5) var(--space-6);
  border-radius: 0 0 var(--r-xl) var(--r-xl);
}
.fm-section--points .fm-section__label { color: #1B6B52; }

.fm-text { font-size: 13px; line-height: 1.75; color: var(--text-2); }

/* ─── SCHÉMA ─── */
.fm-schema { padding: var(--space-2) 0; overflow: visible; }
.fm-schema svg { width: 100%; height: auto; }

/* ─── CONSÉQUENCES ─── */
.fm-consequences { display: flex; flex-direction: column; gap: 6px; }
.fm-consequence-item {
  font-size: 12px; color: #6B3A00; background: rgba(180,83,9,0.08);
  border-radius: var(--r-sm); padding: 5px 10px; line-height: 1.4;
}

/* ─── EFFETS SECONDAIRES ─── */
.fm-effets { display: flex; flex-wrap: wrap; gap: 8px; }
.fm-effet {
  font-size: 12px; padding: 4px 10px; border-radius: 20px;
  font-weight: 500; line-height: 1.4;
}
.fm-effet--danger { background: var(--danger-bg); color: var(--danger-text); border: 1px solid var(--danger-border); }
.fm-effet--warning { background: var(--warning-bg); color: var(--warning-text); border: 1px solid var(--warning-border); }
.fm-effet--info { background: var(--brand-light); color: var(--brand-dark); border: 1px solid var(--brand-border); }

/* ─── CLASSES PHARMACOLOGIQUES ─── */
.fm-classes { display: flex; flex-direction: column; gap: var(--space-3); }
.fm-classe {
  border-left: 3px solid var(--brand);
  border-radius: 0 var(--r-md) var(--r-md) 0;
  overflow: hidden;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left-width: 3px;
}
.fm-classe__header { padding: var(--space-2) var(--space-3); }
.fm-classe__nom { font-size: 12px; font-weight: 700; }
.fm-classe__body { padding: var(--space-2) var(--space-3); border-top: 1px solid var(--border); }
.fm-classe__row { display: flex; gap: var(--space-2); margin-bottom: 3px; font-size: 12px; }
.fm-classe__label { font-weight: 600; color: var(--text-3); min-width: 65px; font-size: 11px; margin-top: 1px; }
.fm-classe__val { color: var(--text-2); }
.fm-classe__remarque {
  font-size: 11px; font-style: italic; margin-top: 5px;
  padding-top: 5px; border-top: 1px dashed var(--border);
}

/* ─── POINTS CLÉS ─── */
.fm-points { display: flex; flex-direction: column; gap: 8px; }
.fm-point {
  display: flex; align-items: flex-start; gap: var(--space-3);
  font-size: 13px; color: var(--text-2); line-height: 1.5;
  background: white; border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
  border: 1px solid rgba(27,107,82,0.15);
}
.fm-point__check {
  color: #1B6B52; font-weight: 800; font-size: 16px;
  flex-shrink: 0; line-height: 1.2;
}

@media (max-width: 640px) {
  .fm-body { grid-template-columns: 1fr; }
  .fm-col:first-child { border-right: none; border-bottom: 1px solid var(--border); }
  .fm-header { padding: var(--space-4); }
  .fm-section { padding: var(--space-4); }
  .fm-section--points { padding: var(--space-4); }
}

/* ─── FORMATION GROUPES ─── */
.formation-group { margin-bottom: var(--space-6); }
.formation-group__title {
  font-size: 13px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.07em; padding: var(--space-3) 0 var(--space-3) var(--space-4);
  border-left: 3px solid var(--brand);
  margin-bottom: var(--space-3);
}

/* ═══════════════════════════════
   MATÉRIEL MÉDICAL — STYLE MAGAZINE
   ═══════════════════════════════ */
.vm-detail {
  background: var(--surface); border: 1px solid #A8C8E8;
  border-radius: var(--r-xl); overflow: visible;
  box-shadow: var(--shadow-lg); animation: slideIn var(--t-mid) var(--ease);
  margin-bottom: var(--space-3);
}
.vm-header {
  background: linear-gradient(135deg, #1B4F72 0%, #2E86C1 100%);
  padding: var(--space-5) var(--space-6);
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-4);
  cursor: pointer; border-radius: var(--r-xl) var(--r-xl) 0 0;
}
.vm-header:hover { opacity: 0.92; }
.vm-header__left { display: flex; align-items: flex-start; gap: var(--space-4); }
.vm-header__icon {
  width: 52px; height: 52px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; flex-shrink: 0;
}
.vm-header__nom { font-family: var(--font-display); font-size: 20px; color: white; margin-bottom: 4px; }
.vm-header__cat { font-size: 12px; color: rgba(255,255,255,0.7); }

.vm-top { padding: var(--space-3) var(--space-5); border-bottom: 1px solid var(--border); background: #F5F9FF; display: flex; flex-direction: column; gap: var(--space-2); cursor: pointer; }
.vm-badge { font-size: 12px; font-weight: 500; padding: 4px 12px; border-radius: 20px; }
.vm-badge--rx { background: #FDF6E8; color: #B45309; border: 1px solid #F5D98A; }
.vm-badge--libre { background: var(--brand-light); color: var(--brand); border: 1px solid var(--brand-border); }

.vm-body { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--border); }
.vm-col { display: flex; flex-direction: column; }
.vm-col:first-child { border-right: 1px solid var(--border); }

.vm-section { padding: var(--space-5) var(--space-5); border-bottom: 1px solid var(--border); }
.vm-section:last-child { border-bottom: none; }
.vm-section__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; margin-bottom: var(--space-3);
}
.vm-section--desc { background: #F5F9FF; }
.vm-section--desc .vm-section__label { color: #1B4F72; }
.vm-section--indication { background: #F0FFF4; }
.vm-section--indication .vm-section__label { color: #1B6B52; }
.vm-section--conseils { background: #FFF9F0; }
.vm-section--conseils .vm-section__label { color: #B45309; }
.vm-section--patho { background: #F5F0FF; }
.vm-section--patho .vm-section__label { color: #6B2D5E; }

.vm-text { font-size: 13px; line-height: 1.7; color: var(--text-2); }
.vm-list { display: flex; flex-direction: column; gap: 6px; }
.vm-list__item { font-size: 13px; color: var(--text-2); line-height: 1.55; padding-left: 4px; }

/* ═══════════════════════════════
   DERMATOLOGIE — STYLE MAGAZINE
   ═══════════════════════════════ */
.dv-detail {
  background: var(--surface); border: 1px solid #E8D5E4;
  border-radius: var(--r-xl); overflow: visible;
  box-shadow: var(--shadow-lg); animation: slideIn var(--t-mid) var(--ease);
  margin-bottom: var(--space-3);
}
.dv-header {
  background: linear-gradient(135deg, #6B2D5E 0%, #A0527A 100%);
  padding: var(--space-4) var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-3);
  cursor: pointer; border-radius: var(--r-xl) var(--r-xl) 0 0;
}
.dv-header:hover { opacity: 0.92; }
.dv-header__left { display: flex; align-items: flex-start; gap: var(--space-3); }
.dv-header__icon {
  width: 52px; height: 52px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; flex-shrink: 0;
}
.dv-header__nom { font-family: var(--font-display); font-size: 20px; color: white; margin-bottom: 4px; line-height: 1.2; }
.dv-header__desc { font-size: 12px; color: rgba(255,255,255,0.75); line-height: 1.5; max-width: 500px; }

.dv-symptomes-bar {
  background: #F9EEF5; border-bottom: 1px solid #E8D5E4;
  padding: var(--space-3) var(--space-6);
  display: flex; align-items: flex-start; gap: var(--space-3); flex-wrap: wrap;
}
.dv-symptomes-label { font-size: 11px; font-weight: 700; color: #6B2D5E; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; margin-top: 3px; }
.dv-symptomes-list { display: flex; flex-wrap: wrap; gap: 6px; }
.dv-symptome { font-size: 12px; background: white; color: #6B2D5E; border: 1px solid #E8D5E4; padding: 3px 10px; border-radius: 20px; }

.dv-body { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--border); }
.dv-col { display: flex; flex-direction: column; }
.dv-col:first-child { border-right: 1px solid var(--border); }

.dv-section { padding: var(--space-5) var(--space-5); border-bottom: 1px solid var(--border); overflow: visible; }
.dv-section:last-child { border-bottom: none; }
.dv-section__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; margin-bottom: var(--space-3);
}
.dv-section--conseils { background: #F5FFF5; }
.dv-section--conseils .dv-section__label { color: #1B6B52; }
.dv-section--eviter { background: #FFF5F5; }
.dv-section--eviter .dv-section__label { color: #C0392B; }
.dv-section--produits { background: #F9F5FF; overflow: visible; }
.dv-section--produits .dv-section__label { color: #6B2D5E; }

.dv-conseil-item, .dv-eviter-item {
  font-size: 13px; line-height: 1.55; color: var(--text-2);
  padding: 4px 0; border-bottom: 1px solid var(--border);
}
.dv-conseil-item:last-child, .dv-eviter-item:last-child { border-bottom: none; }
.dv-eviter-item { color: #C0392B; }

.dv-produits-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--space-2); margin-top: var(--space-2);
}
.dv-produit {
  background: white; border: 1px solid #E8D5E4;
  border-radius: var(--r-md); padding: var(--space-3);
}
.dv-produit__gamme {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: #A0527A; margin-bottom: 3px;
}
.dv-produit__nom { font-size: 12px; font-weight: 600; color: #6B2D5E; line-height: 1.3; margin-bottom: 3px; }
.dv-produit__usage { font-size: 11px; color: var(--text-3); line-height: 1.4; margin-bottom: 5px; }
.dv-produit__texture {
  font-size: 10px; background: #F9EEF5; color: #A0527A;
  padding: 2px 7px; border-radius: 10px; font-weight: 500;
}
.dv-naturel {
  margin: var(--space-3) var(--space-3); padding: var(--space-4);
  background: linear-gradient(135deg, #E8F5E4 0%, #F0FAE8 100%);
  border: 1.5px solid #A8D5A2; border-radius: var(--r-lg);
}
.dv-naturel__label { font-size: 11px; font-weight: 700; color: #2D6A4F; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 6px; }
.dv-naturel__text { font-size: 13px; color: #1B4332; line-height: 1.6; }

.dv-sources {
  font-size: 11px; color: var(--text-3); font-style: italic;
  padding: var(--space-3) var(--space-6);
  border-top: 1px solid var(--border); background: var(--surface-2);
  border-radius: 0 0 var(--r-xl) var(--r-xl);
}

@media (max-width: 640px) {
  .vm-body, .dv-body { grid-template-columns: 1fr; }
  .vm-col:first-child, .dv-col:first-child { border-right: none; border-bottom: 1px solid var(--border); }
  .dv-produits-grid { grid-template-columns: 1fr; }
  .vm-header, .dv-header { padding: var(--space-4); }
}

/* ═══════════════════════════════
   PATHOLOGIES — STYLE MAGAZINE
   ═══════════════════════════════ */
.pf-card {
  background: var(--surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--r-xl);
  overflow: visible;
  box-shadow: var(--shadow-lg);
}
.path-inline-card .pf-card { border-radius: var(--r-xl); }

.pf-header {
  background: linear-gradient(135deg, var(--brand-dark) 0%, var(--brand) 100%);
  padding: var(--space-4) var(--space-5);
  cursor: pointer; border-radius: var(--r-xl) var(--r-xl) 0 0;
  display: flex; flex-direction: column; gap: var(--space-3);
}
.pf-header:hover { opacity: 0.92; }
.pf-header__btns {
  display: flex; gap: 6px; align-items: center; justify-content: flex-end;
}
.pf-header__left { display: flex; align-items: center; gap: var(--space-3); }
.pf-header__texts { min-width: 0; }
.pf-header__icon {
  width: 48px; height: 48px; border-radius: var(--r-lg);
  background: rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; flex-shrink: 0;
}
.pf-header__nom {
  font-family: var(--font-display); font-size: 20px; color: white;
  margin-bottom: 2px; line-height: 1.2;
}
.pf-header__cat { font-size: 12px; color: rgba(255,255,255,0.7); }

.pf-otc {
  background: var(--brand-xlight); border-bottom: 1px solid var(--brand-border);
  padding: var(--space-3) var(--space-6);
  display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap;
}
.pf-otc__label {
  font-size: 11px; font-weight: 700; color: var(--brand);
  text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap;
}
.pf-otc__pills { display: flex; flex-wrap: wrap; gap: var(--space-2); }

.pf-body {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--border);
}
.pf-col { display: flex; flex-direction: column; }
.pf-col:first-child { border-right: 1px solid var(--border); }

.pf-section {
  padding: var(--space-5) var(--space-5);
  border-bottom: 1px solid var(--border);
  overflow: visible; flex: 1;
}
.pf-section:last-child { border-bottom: none; }
.pf-section__label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em; margin-bottom: var(--space-3);
}
.pf-section--conseils { background: #F0FFF4; }
.pf-section--conseils .pf-section__label { color: #1B6B52; }
.pf-section--regime { background: #F5F9FF; }
.pf-section--regime .pf-section__label { color: #1E3A5F; }
.pf-section--ci { background: var(--danger-bg); }
.pf-section--ci .pf-section__label { color: var(--danger-label); }
.pf-section--alerte { background: var(--warning-bg); }
.pf-section--alerte .pf-section__label { color: var(--warning-label); }

.pf-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 5px; }
.pf-list li { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; line-height: 1.55; color: var(--text-2); }
.pf-list li::before { content: '—'; font-weight: 600; flex-shrink: 0; margin-top: 1px; }
.pf-section--conseils .pf-list li::before { color: #1B6B52; }
.pf-section--regime .pf-list li::before { color: #1E3A5F; }
.pf-section--ci .pf-list li::before { color: var(--danger-label); }
.pf-section--alerte .pf-list li::before { color: var(--warning-label); }

@media (max-width: 640px) {
  .pf-body { grid-template-columns: 1fr; }
  .pf-col:first-child { border-right: none; border-bottom: 1px solid var(--border); }
  .pf-header { padding: var(--space-4); }
  .pf-section { padding: var(--space-4); }
}

/* ═══════════════════════════════
   MODE NUIT
   ═══════════════════════════════ */
[data-theme="dark"] {
  --brand:          #4CAF90;
  --brand-mid:      #3D9B7A;
  --brand-dark:     #2D7A5E;
  --brand-light:    #1E3D30;
  --brand-xlight:   #152C22;
  --brand-border:   #2D5042;

  --surface:        #1A1A2E;
  --surface-2:      #16213E;
  --border:         #2A2A4A;
  --text:           #E8E8F0;
  --text-2:         #B0B0C8;
  --text-3:         #707090;

  --danger-bg:      #2D1515;
  --danger-text:    #FF8080;
  --danger-label:   #FF6060;
  --danger-border:  #5D2525;
  --warning-bg:     #2D2010;
  --warning-text:   #FFB060;
  --warning-label:  #FF9040;
  --warning-border: #5D4020;

  background: #0F0F1E;
  color: #E8E8F0;
}

[data-theme="dark"] body { background: #0F0F1E; }
[data-theme="dark"] .page-nav { background: #12122A; border-bottom-color: #2A2A4A; }
[data-theme="dark"] .nav__logo { color: #4CAF90; }
[data-theme="dark"] .page-nav__tab { color: #B0B0C8; }
[data-theme="dark"] .page-nav__tab.active { color: #4CAF90; border-bottom-color: #4CAF90; }
[data-theme="dark"] .search-block { background: transparent; border-color: transparent; }
[data-theme="dark"] .search-wrap { background: #1E1E32 !important; border-color: #3A3A5A !important; }
[data-theme="dark"] .search-input { background: transparent !important; border: none; color: #E8E8F0; }
[data-theme="dark"] .search-input::placeholder { color: #6060A0; }
/* Hero search (MAD, DERMATO, Formation) : fond transparent coloré même en dark */
[data-theme="dark"] .hero-search.search-block { background: transparent; border-color: transparent; }
[data-theme="dark"] .hero-search .search-wrap { background: rgba(255,255,255,0.10) !important; border-color: rgba(255,255,255,0.20) !important; }
[data-theme="dark"] .hero-search .search-input { background: transparent !important; border: none; color: white; }
[data-theme="dark"] .hero-search .search-input::placeholder { color: rgba(255,255,255,0.50); }
[data-theme="dark"] .autocomplete { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .autocomplete__item:hover { background: #25253D; }
[data-theme="dark"] .autocomplete__item-name { color: #E8E8F0; }
[data-theme="dark"] .stats-bar { background: #12122A; border-color: #2A2A4A; color: #B0B0C8; }
[data-theme="dark"] .path-card { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .path-card:hover { border-color: #4CAF90; background: #1E2E28; }
[data-theme="dark"] .path-card--active { background: #1E2E28; border-color: #4CAF90; }
[data-theme="dark"] .path-card__name { color: #E8E8F0; }
[data-theme="dark"] .path-card__cat { color: #707090; }
[data-theme="dark"] .section-label { color: #4CAF90; }
[data-theme="dark"] .section-label::after { background: #2D5042; }

/* Fiches pathologies dark */
[data-theme="dark"] .pf-otc { background: #152C22; border-color: #2D5042; }
[data-theme="dark"] .pf-section--conseils { background: #152C22; }
[data-theme="dark"] .pf-section--regime { background: #151C2D; }
[data-theme="dark"] .pf-section--ci { background: #2D1515; }
[data-theme="dark"] .pf-section--alerte { background: #2D2010; }
[data-theme="dark"] .pf-list li { color: #B0B0C8; }

/* Onglets dark */
[data-theme="dark"] .fiche-tabs { background: #12122A; border-color: #2A2A4A; }
[data-theme="dark"] .fiche-tab { color: #B0B0C8; }
[data-theme="dark"] .fiche-tab.active { color: #4CAF90; border-bottom-color: #4CAF90; }
[data-theme="dark"] .tab-panel { background: #1A1A2E; }

/* MAD dark */
[data-theme="dark"] .mad-main { background: #0F0F1E; }
[data-theme="dark"] .mad-card { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .mad-card:hover { border-color: #4CAF90; }
[data-theme="dark"] .mad-card--active { background: #1E2E28; border-color: #4CAF90; }
[data-theme="dark"] .mad-card__nom { color: #E8E8F0; }
[data-theme="dark"] .mad-cat-title { color: #4CAF90; border-color: #2D5042; }
[data-theme="dark"] .mad-filter { background: #1A1A2E; border-color: #2A2A4A; color: #B0B0C8; }
[data-theme="dark"] .mad-filter.active { background: #4CAF90; color: white; border-color: #4CAF90; }
[data-theme="dark"] .mad-filters-wrap { background: #12122A; border-color: #2A2A4A; }
[data-theme="dark"] .mad-section-label { color: #B0B0C8; }
[data-theme="dark"] .vm-detail, [data-theme="dark"] .dv-detail { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .vm-section--desc { background: #151C2D; }
[data-theme="dark"] .vm-section--indication { background: #152C22; }
[data-theme="dark"] .vm-section--conseils { background: #2D2010; }
[data-theme="dark"] .vm-section--patho { background: #251525; }
.vm-section--custom { background: #FFFBF0; border-left: 3px solid #B45309; }
.vm-section--custom .vm-section__label { color: #92400E; }
[data-theme="dark"] .vm-section--custom { background: #2D2010; border-left-color: #D97706; }
[data-theme="dark"] .vm-section--custom .vm-section__label { color: #FBBF24; }
[data-theme="dark"] .vm-text { color: #B0B0C8; }
[data-theme="dark"] .vm-list__item { color: #B0B0C8; }
[data-theme="dark"] .vm-top { background: #151C2D; border-color: #2A2A4A; }

/* Dermato dark */
[data-theme="dark"] .dv-symptomes-bar { background: #251525; border-color: #3A2A3A; }
[data-theme="dark"] .dv-symptome { background: #1A1A2E; border-color: #3A2A3A; color: #C080B0; }
[data-theme="dark"] .dv-section--conseils { background: #152C22; }
[data-theme="dark"] .dv-section--eviter { background: #2D1515; }
[data-theme="dark"] .dv-section--produits { background: #1E1A2E; }
[data-theme="dark"] .dv-conseil-item, [data-theme="dark"] .dv-eviter-item { color: #B0B0C8; border-color: #2A2A4A; }
[data-theme="dark"] .dv-eviter-item { color: #FF8080; }
[data-theme="dark"] .dv-produit { background: #12122A; border-color: #2A2A3A; }
[data-theme="dark"] .dv-produit__nom { color: #C080B0; }
[data-theme="dark"] .dv-produit__usage { color: #707090; }
[data-theme="dark"] .dv-sources { background: #12122A; color: #505070; border-color: #2A2A4A; }

/* Formation dark */
[data-theme="dark"] .formation-card { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .formation-card:hover { border-color: #2E6DA4; }
[data-theme="dark"] .formation-card--active { background: #151C2D; border-color: #2E6DA4; }
[data-theme="dark"] .formation-card__nom { color: #E8E8F0; }
[data-theme="dark"] .formation-card__cat { color: #707090; }
[data-theme="dark"] .formation-main { background: #0F0F1E; }
[data-theme="dark"] .formation-group__title { color: #4CAF90; }
[data-theme="dark"] .fm-detail { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .fm-saviez { background: #2A2010; border-left-color: #F5A623; }
[data-theme="dark"] .fm-saviez__text { color: #C8A060; }
[data-theme="dark"] .fm-section--physio { background: #151C2D; }
[data-theme="dark"] .fm-section--meca { background: #152C22; }
[data-theme="dark"] .fm-section--consequences { background: #2D2010; }
[data-theme="dark"] .fm-section--effets { background: #2D1515; }
[data-theme="dark"] .fm-section--classes { background: #1A1A2E; }
[data-theme="dark"] .fm-section--schema { background: #12122A; }
[data-theme="dark"] .fm-section--points { background: linear-gradient(135deg, #152C22 0%, #151C2D 100%); border-top-color: #4CAF90; }
[data-theme="dark"] .fm-text { color: #B0B0C8; }
[data-theme="dark"] .fm-consequence-item { background: rgba(180,83,9,0.15); color: #C8A060; }
[data-theme="dark"] .fm-classe { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .fm-classe__body { border-top-color: #2A2A4A; }
[data-theme="dark"] .fm-classe__val { color: #B0B0C8; }
[data-theme="dark"] .fm-classe__remarque { border-top-color: #2A2A4A; }
[data-theme="dark"] .fm-point { background: #12122A; border-color: rgba(76,175,144,0.2); }
[data-theme="dark"] .fm-list li { color: #B0B0C8; }
[data-theme="dark"] .fm-body { border-top-color: #2A2A4A; }
[data-theme="dark"] .fm-col:first-child { border-right-color: #2A2A4A; }
[data-theme="dark"] .fm-section { border-bottom-color: #2A2A4A; }

/* SVG schemas dark — inversion légère */
[data-theme="dark"] .fm-schema svg rect[fill="white"],
[data-theme="dark"] .fm-schema svg rect[fill="#fff"] { fill: #1A1A2E !important; }

/* Footer dark */
[data-theme="dark"] .footer { background: #12122A; border-color: #2A2A4A; color: #505070; }
[data-theme="dark"] .disclaimer-bar { background: #2D2010; border-color: #5D4020; }
[data-theme="dark"] .checklist-bar { background: #12122A; border-color: #2A2A4A; }
[data-theme="dark"] .checklist-item { color: #B0B0C8; }

/* ─── BOUTON MODE NUIT ─── */
.dark-toggle {
  background: none; border: 1.5px solid var(--border);
  border-radius: 20px; padding: 4px 12px;
  cursor: pointer; font-size: 14px;
  color: var(--text-2); transition: all var(--t-fast);
  display: flex; align-items: center; gap: 6px;
  white-space: nowrap;
}
.dark-toggle:hover { border-color: var(--brand); color: var(--brand); }

/* ═══════════════════════════════
   ZOOM IMAGE (LIGHTBOX)
   ═══════════════════════════════ */
.fm-schema { cursor: zoom-in; position: relative; }
.fm-schema::after {
  content: '🔍';
  position: absolute; top: 8px; right: 8px;
  font-size: 16px; opacity: 0.4;
  pointer-events: none; transition: opacity var(--t-fast);
}
.fm-schema:hover::after { opacity: 0.9; }

.lightbox-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.85);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: fadeInLB 0.2s ease;
  cursor: zoom-out;
}
@keyframes fadeInLB { from { opacity: 0; } to { opacity: 1; } }
.lightbox-content {
  background: white; border-radius: 16px;
  padding: 24px; max-width: 90vw; max-height: 90vh;
  overflow: auto; position: relative;
  animation: scaleLB 0.2s ease;
  cursor: default;
}
[data-theme="dark"] .lightbox-content { background: #1A1A2E; }
@keyframes scaleLB { from { transform: scale(0.9); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.lightbox-content svg { width: 80vw; max-width: 900px; height: auto; }
.lightbox-close {
  position: absolute; top: 12px; right: 14px;
  background: none; border: none; font-size: 22px;
  cursor: pointer; color: var(--text-3); line-height: 1;
  padding: 4px 8px; border-radius: 8px;
  transition: background var(--t-fast);
}
.lightbox-close:hover { background: var(--border); }

/* ═══════════════════════════════
   FILTRES THÉMATIQUES PATHOLOGIES
   ═══════════════════════════════ */
.theme-filters-wrap {
  background: var(--surface); border-bottom: 1px solid var(--border);
  padding: var(--space-3) var(--space-5);
}
.theme-filters {
  display: flex; gap: var(--space-2);
  flex-wrap: wrap;
}

/* ─── GROUPES THÉMATIQUES ─── */
.theme-group { margin-bottom: var(--space-7); }
.theme-group__title {
  font-size: 13px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.07em; color: var(--brand);
  padding: var(--space-2) 0 var(--space-3) var(--space-2);
  border-left: 3px solid var(--brand);
  margin-bottom: var(--space-3);
  display: flex; align-items: center; gap: var(--space-2);
}
.theme-group__count {
  font-size: 11px; background: var(--brand-light);
  color: var(--brand); padding: 1px 7px; border-radius: 10px;
  font-weight: 500; letter-spacing: 0;
}

/* dark mode */
[data-theme="dark"] .theme-filters-wrap { background: #12122A; border-color: #2A2A4A; }
[data-theme="dark"] .theme-group__title { color: #4CAF90; border-color: #4CAF90; }
[data-theme="dark"] .theme-group__count { background: #152C22; color: #4CAF90; }

/* ═══════════════════════════════
   MINIATURES PRODUITS DERMATO
   ═══════════════════════════════ */
.dv-produits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--space-3);
  margin-top: var(--space-3);
  overflow: visible;
}
.dv-produit {
  background: white; border: 1px solid #E8D5E4;
  border-radius: var(--r-lg); overflow: hidden;
  display: flex; flex-direction: column;
  transition: box-shadow var(--t-fast), transform var(--t-fast);
}
.dv-produit:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.dv-produit__miniature {
  height: 110px; display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end;
  padding-bottom: 6px; position: relative;
}
.dv-produit__svg {
  width: 52px; flex-shrink: 0;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.18));
}
.dv-produit__svg svg { width: 100%; height: auto; }
.dv-produit__brand-badge {
  position: absolute; top: 8px; left: 8px;
  font-size: 9px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.04em; padding: 2px 7px;
  border-radius: 10px; white-space: nowrap;
  max-width: calc(100% - 16px); overflow: hidden; text-overflow: ellipsis;
}
.dv-produit__info {
  padding: var(--space-3);
  display: flex; flex-direction: column; gap: 4px; flex: 1;
}
.dv-produit__nom {
  font-size: 12px; font-weight: 600; color: #6B2D5E;
  line-height: 1.3;
}
.dv-produit__usage {
  font-size: 11px; color: var(--text-3);
  line-height: 1.4; flex: 1;
}
.dv-produit__texture {
  font-size: 10px; background: #F9EEF5; color: #A0527A;
  padding: 2px 7px; border-radius: 10px;
  font-weight: 500; align-self: flex-start; margin-top: 2px;
}

/* Dark mode miniatures */
[data-theme="dark"] .dv-produit { background: #1A1A2E; border-color: #2A2A3A; }
[data-theme="dark"] .dv-produit__nom { color: #C080B0; }
[data-theme="dark"] .dv-produit__texture { background: #251525; color: #C080B0; }

@media (max-width: 480px) {
  .dv-produits-grid { grid-template-columns: repeat(2, 1fr); }
}


.ce-confirm.open { opacity: 1; }
.ce-confirm__box {
  background: var(--surface); border-radius: var(--r-xl);
  padding: var(--space-6); max-width: 380px; width: 90%;
  box-shadow: var(--shadow-lg);
  transform: scale(0.95); transition: transform 0.2s;
}
.ce-confirm.open .ce-confirm__box { transform: scale(1); }
.ce-confirm__title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: var(--space-2); }
.ce-confirm__msg { font-size: 13px; color: var(--text-3); margin-bottom: var(--space-5); line-height: 1.5; }
.ce-confirm__btns { display: flex; gap: var(--space-3); justify-content: flex-end; }
.ce-btn--danger { background: #C0392B; color: white; }
.ce-btn--danger:hover { background: #9B2E20; }

/* Dark mode */
[data-theme="dark"] .pf-mn-bande { background: #152C22; border-color: #2D5042; }
[data-theme="dark"] .pf-mn-tag { background: #1A2E1A; color: #4CAF90; border-color: #2D5042; }
[data-theme="dark"] .ce-confirm__box { background: #1A1A2E; }



/* ═══════════════════════════════
   CUSTOMIZER v2 — Modale centrée
   ═══════════════════════════════ */
body.modal-open { overflow: hidden; }

.btn-customize {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600;
  background: rgba(255,255,255,0.15); color: white;
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: 14px; padding: 4px 10px;
  cursor: pointer; transition: background var(--t-fast);
  white-space: nowrap; flex-shrink: 0;
}
.btn-customize:hover { background: rgba(255,255,255,0.28); }
.btn-customize--light {
  background: var(--brand-light); color: var(--brand-dark);
  border-color: var(--brand-border);
}
.btn-customize--light:hover { background: var(--brand-border); }
.custom-badge {
  font-size: 10px; background: #F5A623; color: white;
  padding: 2px 7px; border-radius: 10px; font-weight: 600;
  margin-left: 4px; vertical-align: middle;
}

/* Overlay */
.customizer-modal {
  position: fixed; inset: 0; z-index: 9000;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  background: rgba(0,0,0,0.6);
  opacity: 0; pointer-events: none;
  transition: opacity 0.2s ease;
  cursor: default;
  overflow: hidden;   /* bloque le scroll du fond via la modale */
}
.customizer-modal.open { opacity: 1; pointer-events: all; }
/* .customizer-overlay supprimé — click-to-close géré sur .customizer-modal */

/* Panel centré */
.customizer-panel--center {
  position: relative;
  background: var(--surface); border-radius: var(--r-xl);
  width: 100%; max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;   /* empêche le scroll de se propager au fond */
  box-shadow: 0 20px 60px rgba(0,0,0,0.35);
  transform: scale(0.95) translateY(10px);
  transition: transform 0.2s ease;
  display: flex; flex-direction: column;
}
.customizer-modal.open .customizer-panel--center { transform: scale(1) translateY(0); }

/* Header fixe */
.ce-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: var(--space-4); padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 10;
  background: var(--surface);
  border-radius: var(--r-xl) var(--r-xl) 0 0;
}
.ce-title { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 3px; }
.ce-subtitle { font-size: 12px; color: var(--text-3); }
.ce-close {
  background: var(--surface-2); border: none; border-radius: 50%;
  width: 32px; height: 32px; cursor: pointer; font-size: 14px;
  color: var(--text-3); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.ce-close:hover { background: var(--border); }

/* Body scrollable */
.ce-body {
  padding: var(--space-4) var(--space-5);
  display: flex; flex-direction: column; gap: var(--space-3);
}

/* Sections */
.ce-section-block { border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.ce-section-title {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--brand);
  background: var(--brand-xlight); padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--border);
}
.ce-list { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-2) var(--space-3); }
.ce-list--mn { padding: var(--space-2) var(--space-3); }
.ce-item {
  display: flex; align-items: flex-start; gap: var(--space-2);
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: var(--space-2) var(--space-3);
}
.ce-item--compact { padding: var(--space-2) var(--space-3); }
.ce-item--derma { flex-direction: column; align-items: stretch; }
.ce-item__fields { flex: 1; display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.ce-input {
  width: 100%; border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: 7px 10px; font-size: 13px; color: var(--text);
  background: var(--surface); outline: none;
  transition: border-color var(--t-fast);
  font-family: var(--font-sans); box-sizing: border-box;
}
.ce-input:focus { border-color: var(--brand); }
.ce-input--sub { font-size: 12px; }
.ce-row-inline { display: flex; gap: 6px; }
.ce-color-row {
  display: flex; align-items: center; gap: 8px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 5px 10px; flex-wrap: wrap;
}
.ce-color-label { font-size: 11px; color: var(--text-3); white-space: nowrap; }
.ce-color-picker { width: 32px; height: 26px; border: none; border-radius: 4px; cursor: pointer; padding: 0; flex-shrink: 0; }
.ce-color-hint { font-size: 11px; color: var(--text-3); font-style: italic; }
.ce-remove {
  background: none; border: none; cursor: pointer;
  color: var(--text-3); font-size: 16px; padding: 2px 4px;
  border-radius: 4px; flex-shrink: 0; transition: color var(--t-fast);
}
.ce-remove:hover { color: var(--danger-label); }
.ce-add {
  background: none; border: 2px dashed var(--border);
  border-radius: var(--r-lg); padding: var(--space-2) var(--space-4);
  font-size: 12px; color: var(--brand); cursor: pointer; font-weight: 500;
  transition: all var(--t-fast); text-align: center;
  margin: var(--space-2) var(--space-3); display: inline-block;
}
.ce-add:hover { border-color: var(--brand); background: var(--brand-xlight); }
.ce-add--sm { border-width: 1px; border-radius: 20px; }

/* Footer fixe */
.ce-footer {
  display: flex; justify-content: flex-end; align-items: center;
  padding: var(--space-3) var(--space-5); gap: var(--space-3);
  border-top: 1px solid var(--border);
  position: sticky; bottom: 0; z-index: 10;
  background: var(--surface);
  border-radius: 0 0 var(--r-xl) var(--r-xl);
}
.ce-btn {
  padding: 8px 20px; border-radius: 20px;
  font-size: 13px; font-weight: 600; cursor: pointer;
  border: none; transition: all var(--t-fast);
}
.ce-btn--save { background: var(--brand); color: white; }
.ce-btn--save:hover { background: var(--brand-dark); }
.ce-btn--cancel { background: none; border: 1px solid var(--border); color: var(--text-3); }
.ce-btn--cancel:hover { border-color: var(--text-2); color: var(--text); }

/* Toast */
.customizer-toast {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: #1A1A2E; color: white; border-radius: 24px;
  padding: 10px 20px; font-size: 13px; font-weight: 500;
  z-index: 9999; opacity: 0; transition: all 0.25s ease; white-space: nowrap;
}
.customizer-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ═══════════════════════════════
   BANDE UNIFIÉE — Fiche pathologie
   ═══════════════════════════════ */
.pf-bande {
  background: linear-gradient(135deg, #F0FAF4 0%, #EEF4FB 100%);
  border-bottom: 1px solid var(--border);
  padding: var(--space-3) var(--space-6);
}
.pf-bande__header {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.pf-bande__title {
  font-size: 11px; font-weight: 700; color: var(--brand);
  text-transform: uppercase; letter-spacing: 0.07em;
}
.pf-bande__sections { display: flex; flex-direction: column; gap: var(--space-2); }
.pf-bande__section { display: flex; align-items: flex-start; gap: var(--space-3); flex-wrap: wrap; }
.pf-bande__label {
  font-size: 11px; font-weight: 600; color: var(--text-3);
  min-width: 130px; padding-top: 3px; white-space: nowrap;
}
.pf-bande__items { display: flex; flex-wrap: wrap; gap: 5px; }
.pf-bande__pill {
  font-size: 12px; background: white; color: var(--text-2);
  border: 1px solid var(--border); padding: 3px 9px;
  border-radius: 20px; line-height: 1.4;
  max-width: 220px; overflow: hidden;
  text-overflow: ellipsis; white-space: nowrap;
}

/* Dark */
[data-theme="dark"] .ce-input { background: #12122A; border-color: #2A2A4A; color: #E8E8F0; }
[data-theme="dark"] .ce-item { background: #12122A; border-color: #2A2A4A; }
[data-theme="dark"] .customizer-panel--center { background: #1A1A2E; }
[data-theme="dark"] .ce-footer { background: #1A1A2E; border-color: #2A2A4A; }
[data-theme="dark"] .pf-bande { background: #151C2D; border-color: #2A2A4A; }
[data-theme="dark"] .pf-bande__pill { background: #1A1A2E; border-color: #2A2A4A; color: #B0B0C8; }

/* ─── Accordéon customizer ─── */
.ce-accord { display: flex; flex-direction: column; }
.ce-accord__item { border-bottom: 1px solid var(--border); }
.ce-accord__item:last-child { border-bottom: none; }
.ce-accord__hdr {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  background: var(--brand-xlight); border: none; cursor: pointer;
  padding: var(--space-3) var(--space-4); text-align: left;
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--brand);
  transition: background var(--t-fast);
}
.ce-accord__hdr:hover { background: var(--brand-light); }
.ce-accord__arrow {
  font-size: 18px; color: var(--brand); font-weight: 300;
  transition: transform 0.2s ease; flex-shrink: 0;
}
/* Corps caché par défaut — le panel scrolle, pas le corps */
.ce-accord__body {
  display: none;
  padding: var(--space-2) var(--space-3) var(--space-3);
}
.ce-accord__item.open .ce-accord__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

[data-theme="dark"] .ce-accord__hdr { background: #152C22; }
[data-theme="dark"] .ce-accord__hdr:hover { background: #1E3D30; }
[data-theme="dark"] .ce-accord__item { border-color: #2A2A4A; }

/* Variante danger (À éviter) */
.ce-accord__hdr--danger {
  background: #FDF0EF !important; color: #C0392B !important;
}
.ce-accord__hdr--danger:hover { background: #FACACA !important; }
.ce-accord__hdr--danger .ce-accord__arrow { color: #C0392B !important; }
[data-theme="dark"] .ce-accord__hdr--danger { background: #2D1515 !important; color: #FF8080 !important; }

/* ─── Bouton adapt small (dermato + MAD) ─── */
.btn-adapt-small {
  font-size: 11px; font-weight: 600; padding: 3px 9px;
  border: 1px solid var(--brand); color: var(--brand);
  background: var(--brand-xlight); border-radius: 12px;
  cursor: pointer; white-space: nowrap;
  transition: all var(--t-fast);
}
.btn-adapt-small:hover { background: var(--brand); color: white; }
.btn-adapt-danger { border-color: var(--danger-label) !important; color: var(--danger-label) !important; background: var(--danger-bg) !important; }
.btn-adapt-danger:hover { background: var(--danger-label) !important; color: white !important; }

/* ─── Textarea customizer ─── */
.ce-textarea {
  width: 100%; border: 1px solid var(--border); border-radius: var(--r-sm);
  padding: 8px 10px; font-size: 13px; color: var(--text);
  background: var(--surface); outline: none; resize: vertical;
  font-family: var(--font-sans); box-sizing: border-box; min-height: 70px;
  transition: border-color var(--t-fast);
}
.ce-textarea:focus { border-color: var(--brand); }

/* ─── Bouton + Catégorie dans MAD ─── */
.mad-filter--add {
  background: none; border: 1.5px dashed var(--brand) !important;
  color: var(--brand) !important; font-weight: 700;
}
.mad-filter--add:hover { background: var(--brand-xlight) !important; }
.mad-empty {
  text-align: center; color: var(--text-3); font-size: 13px;
  padding: var(--space-6); font-style: italic;
}

[data-theme="dark"] .ce-textarea { background: #12122A; border-color: #2A2A4A; color: #E8E8F0; }