/* =========================================================
   PHYSIOLUM — Subpages component layer
   Builds on physiolum.css tokens (#page scope). Loaded AFTER it.
   ========================================================= */

/* keep fixed header clear of page tops */
.page-main { padding-top: 0; }

/* ---------------------------------------------------------
   PAGE HERO — photo band (eyebrow / title / subtitle)
   --------------------------------------------------------- */
.page-hero {
  position: relative; overflow: hidden;
  display: flex; align-items: flex-end;
  min-height: clamp(420px, 60vh, 620px);
  padding-top: clamp(120px, 14vw, 180px);
}
.page-hero__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.page-hero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(34,8,17,.18) 0%, rgba(34,8,17,.05) 30%, rgba(34,8,17,.55) 78%, rgba(34,8,17,.82) 100%),
    linear-gradient(96deg, rgba(34,8,17,.55) 0%, rgba(34,8,17,.18) 46%, transparent 78%);
}
.page-hero__inner { position: relative; z-index: 2; width: 100%; padding-bottom: clamp(40px, 5vw, 74px); }
.page-hero .eyebrow { color: var(--ambre-light); }
.page-hero__title {
  font-family: var(--f-head); font-weight: var(--display-weight);
  font-size: clamp(2.3rem, 5vw, 4rem); line-height: 1.1;
  letter-spacing: var(--title-tracking); color: #fff; margin: 0; max-width: 20ch;
  text-wrap: balance;
}
.page-hero__title em { font-style: italic; color: var(--ambre-light); }
.page-hero__sub { font-size: clamp(1.05rem, 1.5vw, 1.24rem); color: rgba(255,255,255,.86); margin: 22px 0 0; max-width: 46ch; line-height: 1.55; }
.page-hero__title-em { color: var(--ambre-light); }

/* tinted (no-photo) hero — warm wash, dark ink. tarifs / legal / rdv */
.page-hero--tint {
  align-items: center; text-align: center; min-height: clamp(340px, 44vh, 460px);
  background:
    radial-gradient(120% 120% at 50% -20%, color-mix(in srgb, var(--ambre) 16%, transparent), transparent 56%),
    linear-gradient(180deg, var(--bg-alt) 0%, var(--bg) 100%);
  border-bottom: 1px solid var(--hair);
}
.page-hero--tint .page-hero__inner { padding-block: clamp(30px, 4vw, 50px); }
.page-hero--tint .eyebrow { color: var(--accent); justify-content: center; display: inline-flex; }
.page-hero--tint .page-hero__title { color: var(--brand-deep); margin-inline: auto; }
.page-hero--tint .page-hero__title em { color: var(--brand); }
.page-hero--tint .page-hero__sub { color: var(--ink-soft); margin-inline: auto; }
.page-hero__ornament { display: block; width: 54px; height: 1px; margin: 26px auto 0; background: var(--accent); opacity: .5; }

/* ---------------------------------------------------------
   GENERIC SECTION SCAFFOLD
   --------------------------------------------------------- */
.sec { padding: var(--sec-y) 0; }
.sec--alt { background: var(--bg-alt); }
.sec-head { max-width: 50ch; margin: 0 0 clamp(36px, 5vw, 60px); }
.sec-head--center { margin-inline: auto; text-align: center; }
.sec-head--center .eyebrow { justify-content: center; display: inline-flex; }
.sec-title { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(1.9rem, 3.8vw, 3rem); line-height: 1.14; letter-spacing: var(--title-tracking); color: var(--brand-deep); margin: 0; text-wrap: balance; }
.sec-title em { font-style: italic; color: var(--brand); }
.prose { color: var(--ink-soft); font-size: 1.08rem; line-height: 1.66; }
.prose p { margin: 0 0 1.1em; max-width: 64ch; }
.prose strong { color: var(--brand-deep); font-weight: 700; }
.prose p:last-child { margin-bottom: 0; }

/* split — text column beside a framed photo */
.split { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(34px, 6vw, 76px); align-items: center; }
.split--rev .split__media { order: -1; }
.split__media { position: relative; border-radius: var(--radius); overflow: hidden;
  box-shadow: 0 1px 0 rgba(255,255,255,.6) inset, 0 2px 8px -2px rgba(95,32,50,.10), 0 44px 84px -40px rgba(95,32,50,.46); }
.split__media img { display: block; width: 100%; height: clamp(380px, 44vw, 560px); object-fit: cover; }
.split__media::after { content: ""; position: absolute; inset: 0; border-radius: inherit; box-shadow: inset 0 0 0 1px rgba(95,32,50,.07); pointer-events: none; }
.split--square .split__media img { height: clamp(380px, 40vw, 520px); }

/* result / checklist box */
.subt { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--accent); margin: 30px 0 16px; display: flex; align-items: center; gap: .8em; }
.subt::before { content: ""; width: 26px; height: 1px; background: currentColor; opacity: .5; }
.checklist { list-style: none; margin: 18px 0 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.checklist li { display: flex; gap: 13px; align-items: flex-start; font-size: 1.04rem; color: var(--brand-deep); }
.checklist .tick { margin-top: 2px; }
.box {
  background: var(--bg); border: 1px solid var(--hair); border-radius: var(--radius);
  padding: clamp(26px, 3vw, 40px);
  box-shadow: 0 1px 1px rgba(95,32,50,.04), 0 22px 48px -34px rgba(95,32,50,.28);
}

/* key message callout */
.callout {
  position: relative; margin-top: clamp(34px, 4vw, 52px);
  padding: clamp(28px, 3.4vw, 44px) clamp(28px, 3.6vw, 48px);
  background: var(--bg-alt); border: 1px solid var(--hair);
  border-radius: var(--radius);
  font-family: var(--f-head); font-size: clamp(1.3rem, 2.3vw, 1.7rem);
  line-height: 1.36; color: var(--brand-deep); text-wrap: pretty;
}
.callout::before {
  content: ""; position: absolute; left: 0; top: 18px; bottom: 18px; width: 3px; border-radius: 3px;
  background: var(--halo);
}
.callout strong { font-weight: 600; color: var(--brand); }
.callout--halo { background: var(--bg); }

.cta-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; margin-top: clamp(30px, 4vw, 44px); }

/* ---------------------------------------------------------
   BENEFIT / MECHANISM CARD GRID
   --------------------------------------------------------- */
.cardgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: clamp(16px, 2vw, 24px); }
.bcard {
  background: var(--bg); border: 1px solid var(--hair); border-radius: var(--radius);
  padding: clamp(24px, 2.6vw, 34px);
  box-shadow: 0 1px 1px rgba(95,32,50,.04), 0 22px 48px -36px rgba(95,32,50,.26);
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s;
}
.bcard:hover { transform: translateY(-4px); box-shadow: 0 30px 60px -38px rgba(95,32,50,.4); }
.bcard__ic {
  width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 20px;
  background: color-mix(in srgb, var(--grenat) 11%, var(--bg)); border: 1px solid color-mix(in srgb, var(--grenat) 22%, transparent);
  color: var(--brand);
}
.bcard__ic svg { width: 25px; height: 25px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.bcard__t { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.4rem; color: var(--brand-deep); margin: 0 0 8px; }
.bcard__d { color: var(--ink-soft); font-size: .98rem; line-height: 1.55; margin: 0; }

/* ---------------------------------------------------------
   DOSE BARS (Arndt–Schulz)
   --------------------------------------------------------- */
.dose { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(16px, 2.4vw, 28px); margin-top: clamp(30px, 4vw, 46px); }
.dose__col { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px; }
.dose__bar-track { width: 100%; height: clamp(140px, 18vw, 210px); display: flex; align-items: flex-end; }
.dose__bar { width: 100%; border-radius: 12px 12px 0 0; transform-origin: bottom; }
.dose__bar--low  { background: linear-gradient(180deg, color-mix(in srgb, var(--wine-300) 60%, var(--bg)), var(--wine-300)); }
.dose__bar--opt  { background: var(--halo); box-shadow: 0 0 40px -6px color-mix(in srgb, var(--orange) 50%, transparent); }
.dose__bar--high { background: linear-gradient(180deg, color-mix(in srgb, var(--wine-400) 60%, var(--bg)), var(--wine-500)); }
.dose__name { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.25rem; color: var(--brand-deep); }
.dose__sub { font-family: var(--f-ui); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-soft); }
.dose__col--opt .dose__sub { color: var(--orange); }
.dose__val { font-family: var(--f-ui); font-size: 13px; color: var(--ink-soft); }

/* ---------------------------------------------------------
   WARM / COLD color cards (chromothérapie)
   --------------------------------------------------------- */
.duo { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(18px, 2.4vw, 28px); }
.tonecard { border-radius: var(--radius); overflow: hidden; border: 1px solid var(--hair); background: var(--bg); box-shadow: 0 22px 48px -36px rgba(95,32,50,.3); }
.tonecard__swatch { height: 90px; }
.tonecard__swatch--warm { background: linear-gradient(120deg, #d62f3a, #f26b1f 55%, #f5a623); }
.tonecard__swatch--cold { background: linear-gradient(120deg, #5577b8, #5e7fa8 50%, #6a5aa8); }
.tonecard__body { padding: clamp(22px, 2.6vw, 32px); }
.tonecard__k { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin: 0 0 6px; }
.tonecard__t { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.5rem; color: var(--brand-deep); margin: 0 0 12px; }
.tonecard__d { color: var(--ink-soft); margin: 0; line-height: 1.55; }

/* simple icon item list (2-col) */
.iconlist { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(18px, 2.6vw, 30px); }
.iconitem { display: flex; gap: 16px; align-items: flex-start; }
.iconitem__ic { flex: none; width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: color-mix(in srgb, var(--accent) 14%, var(--bg)); border: 1px solid color-mix(in srgb, var(--accent) 26%, transparent); color: var(--accent); }
.iconitem__ic svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.iconitem__t { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.25rem; color: var(--brand-deep); margin: 0 0 4px; }
.iconitem__d { color: var(--ink-soft); margin: 0; font-size: .98rem; line-height: 1.5; }

/* ---------------------------------------------------------
   PRICING
   --------------------------------------------------------- */
.price-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: clamp(18px, 2.4vw, 28px); }
.price-card {
  position: relative; display: flex; flex-direction: column;
  background: var(--bg); border: 1px solid var(--hair); border-radius: calc(var(--radius) + 4px);
  padding: clamp(28px, 3vw, 40px);
  box-shadow: 0 1px 1px rgba(95,32,50,.04), 0 26px 54px -38px rgba(95,32,50,.3);
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s;
}
.price-card:hover { transform: translateY(-5px); box-shadow: 0 38px 70px -40px rgba(95,32,50,.42); }
.price-card--feat { border-color: color-mix(in srgb, var(--orange) 40%, transparent); }
.price-card--feat::before { content: "Première séance"; position: absolute; top: -12px; left: clamp(28px,3vw,40px); font-family: var(--f-ui); font-size: 11px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: #fff; background: var(--halo); padding: 5px 13px; border-radius: 999px; }
.price-card__ic { width: 50px; height: 50px; border-radius: 14px; display: grid; place-items: center; margin-bottom: 22px; background: color-mix(in srgb, var(--grenat) 11%, var(--bg)); border: 1px solid color-mix(in srgb, var(--grenat) 22%, transparent); color: var(--brand); }
.price-card__ic svg { width: 25px; height: 25px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.price-card__name { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.6rem; color: var(--brand-deep); margin: 0 0 3px; }
.price-card__meta { font-family: var(--f-ui); font-size: 12.5px; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); margin: 0 0 18px; }
.price-card__desc { color: var(--ink-soft); font-size: .98rem; line-height: 1.55; margin: 0 0 26px; flex: 1; }
.price-card__foot { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding-top: 20px; border-top: 1px solid var(--hair); }
.price-card__price { font-family: var(--f-head); font-weight: 600; font-size: 2.4rem; color: var(--brand-deep); line-height: 1; }
.price-card__dur { font-family: var(--f-ui); font-size: 12.5px; color: var(--ink-soft); display: inline-flex; align-items: center; gap: 6px; }
.price-note { margin: clamp(34px, 4vw, 52px) auto 0; max-width: 70ch; text-align: center; color: var(--ink-soft); font-size: 1rem; line-height: 1.7; }

/* ---------------------------------------------------------
   RDV / CONTACT FORM
   --------------------------------------------------------- */
.bookgrid { display: grid; grid-template-columns: 1.45fr 1fr; gap: clamp(30px, 4vw, 56px); align-items: start; }
.formcard { background: var(--bg); border: 1px solid var(--hair); border-radius: calc(var(--radius) + 4px); padding: clamp(28px, 3.4vw, 48px); box-shadow: 0 1px 1px rgba(95,32,50,.04), 0 30px 64px -40px rgba(95,32,50,.3); }
.form-h { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(1.5rem, 2.6vw, 2rem); color: var(--brand-deep); margin: 0 0 26px; }
.field { margin-bottom: 22px; }
.field > label { display: block; font-family: var(--f-ui); font-size: 13px; font-weight: 600; letter-spacing: .02em; color: var(--brand-deep); margin-bottom: 9px; }
.field .req { color: var(--orange); }
.field .opt { font-weight: 400; color: var(--ink-soft); text-transform: none; letter-spacing: 0; }
.inp {
  width: 100%; font-family: var(--f-body); font-size: 15px; color: var(--ink);
  background: var(--bg-alt); border: 1px solid var(--hair); border-radius: 12px;
  padding: 13px 15px; transition: border-color .2s, box-shadow .2s, background .2s;
}
.inp::placeholder { color: color-mix(in srgb, var(--ink-soft) 75%, transparent); }
.inp:focus { outline: none; border-color: color-mix(in srgb, var(--orange) 55%, transparent); background: var(--bg); box-shadow: 0 0 0 4px color-mix(in srgb, var(--orange) 12%, transparent); }
textarea.inp { resize: vertical; min-height: 110px; }
.chips { display: flex; flex-wrap: wrap; gap: 10px; }
.chip {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-family: var(--f-ui); font-size: 14px; color: var(--brand-deep);
  padding: 10px 16px; border-radius: 999px; border: 1px solid var(--hair); background: var(--bg-alt);
  transition: border-color .2s, background .2s, color .2s;
}
.chip input { position: absolute; opacity: 0; pointer-events: none; }
.chip:hover { border-color: color-mix(in srgb, var(--orange) 40%, transparent); }
.chip:has(input:checked) { background: color-mix(in srgb, var(--orange) 12%, var(--bg)); border-color: color-mix(in srgb, var(--orange) 55%, transparent); color: var(--brand); }
.chip__dot { width: 9px; height: 9px; border-radius: 50%; border: 1.5px solid currentColor; opacity: .5; transition: opacity .2s, background .2s; }
.chip:has(input:checked) .chip__dot { opacity: 1; background: var(--orange); border-color: var(--orange); }
.helper { font-size: 13px; color: var(--ink-soft); margin: -2px 0 12px; }
.subfield-l { font-family: var(--f-ui); font-size: 11.5px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-soft); margin: 16px 0 10px; }
.days { display: flex; flex-wrap: wrap; gap: 8px; }
.day {
  cursor: pointer; font-family: var(--f-ui); font-size: 13.5px; color: var(--brand-deep);
  min-width: 52px; text-align: center; padding: 9px 6px; border-radius: 11px; border: 1px solid var(--hair); background: var(--bg-alt);
  transition: border-color .2s, background .2s, color .2s;
}
.day input { position: absolute; opacity: 0; pointer-events: none; }
.day:hover { border-color: color-mix(in srgb, var(--orange) 40%, transparent); }
.day:has(input:checked) { background: color-mix(in srgb, var(--orange) 12%, var(--bg)); border-color: color-mix(in srgb, var(--orange) 55%, transparent); color: var(--brand); }
.day--off { opacity: .45; cursor: not-allowed; }
.timeslots { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.slot {
  cursor: pointer; display: flex; align-items: center; gap: 14px;
  padding: 16px; border-radius: 14px; border: 1px solid var(--hair); background: var(--bg-alt);
  transition: border-color .2s, background .2s;
}
.slot input { position: absolute; opacity: 0; pointer-events: none; }
.slot:hover { border-color: color-mix(in srgb, var(--orange) 40%, transparent); }
.slot:has(input:checked) { background: color-mix(in srgb, var(--orange) 10%, var(--bg)); border-color: color-mix(in srgb, var(--orange) 55%, transparent); }
.slot__ic { flex: none; width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; background: var(--bg); border: 1px solid var(--hair); color: var(--orange); }
.slot__ic svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.slot__t { font-family: var(--f-ui); font-size: 14.5px; font-weight: 600; color: var(--brand-deep); }
.slot__d { font-size: 12.5px; color: var(--ink-soft); }
.consent { display: flex; gap: 12px; align-items: flex-start; margin: 6px 0 24px; }
.consent input { margin-top: 3px; width: 18px; height: 18px; accent-color: var(--orange); flex: none; }
.consent label { font-size: 13px; color: var(--ink-soft); line-height: 1.5; }
.form-tarif {
  margin-top: 26px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px;
  padding: 22px 24px; border-radius: var(--radius);
  background: color-mix(in srgb, var(--ambre) 12%, var(--bg-alt)); border: 1px solid color-mix(in srgb, var(--ambre) 30%, transparent);
}
.form-tarif__t { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.2rem; color: var(--brand-deep); margin: 0 0 4px; }
.form-tarif__d { font-size: 13.5px; color: var(--ink-soft); margin: 0; }

/* info sidebar */
.infocard { background: var(--bg); border: 1px solid var(--hair); border-radius: calc(var(--radius) + 4px); padding: clamp(26px, 3vw, 38px); box-shadow: 0 1px 1px rgba(95,32,50,.04), 0 26px 54px -40px rgba(95,32,50,.28); }
.infocard + .infocard { margin-top: 22px; }
.info-brand { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; margin-bottom: 20px; }
.info-h { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin: 0 0 16px; }
.info-row { display: flex; gap: 13px; align-items: flex-start; margin-bottom: 16px; }
.info-row:last-child { margin-bottom: 0; }
.info-row__ic { flex: none; width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; background: var(--bg-alt); border: 1px solid var(--hair); color: var(--brand); }
.info-row__ic svg { width: 19px; height: 19px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.info-row__t { font-size: 14.5px; color: var(--brand-deep); font-weight: 600; line-height: 1.4; }
.info-row__d, .info-row__d a { font-size: 14px; color: var(--ink-soft); line-height: 1.5; text-decoration: none; }
.info-row__d a:hover { color: var(--brand); }
.hours { list-style: none; margin: 0; padding: 0; }
.hours li { display: flex; justify-content: space-between; gap: 16px; padding: 9px 0; border-bottom: 1px solid var(--hair); font-size: 14px; color: var(--ink-soft); }
.hours li:last-child { border-bottom: 0; }
.hours li span:first-child { color: var(--brand-deep); font-weight: 600; }
.hours .closed { color: var(--ink-soft); opacity: .7; }
.socials { display: flex; gap: 10px; margin-top: 14px; }
.social { width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; background: var(--bg-alt); border: 1px solid var(--hair); color: var(--brand); transition: background .2s, color .2s, transform .2s; }
.social:hover { background: var(--brand); color: #fff; transform: translateY(-2px); }
.social svg { width: 19px; height: 19px; fill: currentColor; }

/* map */
.map-block {
  margin-top: clamp(40px, 5vw, 64px); border-radius: calc(var(--radius) + 4px); overflow: hidden;
  border: 1px solid var(--hair); position: relative; aspect-ratio: 16 / 7;
  background:
    repeating-linear-gradient(45deg, transparent 0 22px, rgba(95,32,50,.03) 22px 44px),
    linear-gradient(180deg, var(--bg-alt), var(--bg));
  display: grid; place-items: center; text-align: center;
}
.map-block__inner { display: grid; gap: 14px; justify-items: center; padding: 24px; }
.map-pin { width: 52px; height: 52px; border-radius: 50%; display: grid; place-items: center; background: var(--bg); border: 1px solid var(--hair); color: var(--brand); box-shadow: 0 18px 40px -22px rgba(95,32,50,.4); }
.map-pin svg { width: 26px; height: 26px; fill: none; stroke: currentColor; stroke-width: 1.5; }
.map-block__t { font-family: var(--f-head); font-style: italic; font-size: 1.2rem; color: var(--brand-deep); }

/* ---------------------------------------------------------
   FAQ ACCORDION
   --------------------------------------------------------- */
.faqgrid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(34px, 6vw, 80px); align-items: start; }
.faq-aside { position: sticky; top: 110px; }
.faq-orn { font-size: 1.4rem; color: var(--accent); margin-top: 20px; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-top: 1px solid var(--hair); }
.faq-item:last-child { border-bottom: 1px solid var(--hair); }
.faq-q {
  width: 100%; display: flex; align-items: flex-start; gap: 20px; text-align: left; cursor: pointer;
  background: none; border: 0; padding: 26px 4px; color: var(--brand-deep);
  font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(1.15rem, 1.9vw, 1.45rem); line-height: 1.3;
}
.faq-num { font-family: var(--f-ui); font-size: 13px; font-weight: 600; color: var(--accent); min-width: 30px; padding-top: .35em; }
.faq-q-txt { flex: 1; }
.faq-tog { flex: none; width: 30px; height: 30px; position: relative; margin-top: .15em; }
.faq-tog::before, .faq-tog::after { content: ""; position: absolute; left: 50%; top: 50%; width: 14px; height: 2px; background: var(--brand); border-radius: 2px; transform: translate(-50%,-50%); transition: transform .3s cubic-bezier(.2,.8,.2,1); }
.faq-tog::after { transform: translate(-50%,-50%) rotate(90deg); }
.faq-item[open] .faq-tog::after { transform: translate(-50%,-50%) rotate(0); }
.faq-a { overflow: hidden; }
.faq-a-inner { padding: 0 4px 28px 50px; color: var(--ink-soft); font-size: 1.04rem; line-height: 1.66; max-width: 64ch; }
/* native <details> open animation via grid-rows fallback */
details.faq-item summary { list-style: none; }
details.faq-item summary::-webkit-details-marker { display: none; }

/* method flow (Lumière → Cellule → Énergie → Réparation) */
.flow { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin: 26px 0 0; }
.flow__step { font-family: var(--f-ui); font-weight: 600; font-size: 14px; color: var(--brand-deep); background: var(--bg); border: 1px solid var(--hair); border-radius: 999px; padding: 9px 18px; box-shadow: 0 8px 20px -14px rgba(95,32,50,.3); }
.flow__step--accent { background: var(--halo); color: #fff; border-color: transparent; }
.flow__arrow { color: var(--orange); font-size: 16px; }
.flow__foot { margin: 20px 0 0; font-size: 14px; color: var(--ink-soft); font-style: italic; }

/* ---------------------------------------------------------
   PATHOLOGIES CATALOGUE
   --------------------------------------------------------- */
.path-group { margin-top: clamp(44px, 6vw, 72px); }
.path-group:first-of-type { margin-top: 0; }
.path-group__head { display: flex; align-items: center; gap: 18px; margin-bottom: clamp(24px, 3vw, 36px); }
.path-group__n { font-family: var(--f-ui); font-size: 13px; font-weight: 600; letter-spacing: .04em; color: var(--accent); }
.path-group__t { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(1.5rem, 2.8vw, 2.1rem); color: var(--brand-deep); margin: 0; }
.path-group__t em { font-style: italic; color: var(--brand); }
.path-group__rule { flex: 1; height: 1px; background: var(--hair); }
.path-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: clamp(16px, 2vw, 22px); }
.path-card {
  display: flex; flex-direction: column; background: var(--bg); border: 1px solid var(--hair); border-radius: var(--radius);
  padding: clamp(24px, 2.6vw, 32px);
  box-shadow: 0 1px 1px rgba(95,32,50,.04), 0 20px 44px -36px rgba(95,32,50,.26);
  transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s, border-color .3s;
}
.path-card:hover { transform: translateY(-3px); border-color: color-mix(in srgb, var(--brand) 22%, var(--hair)); box-shadow: 0 30px 58px -40px rgba(95,32,50,.4); }
.path-card__t { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.3rem; line-height: 1.25; color: var(--brand-deep); margin: 0 0 10px; }
.path-card__intro { color: var(--ink-soft); font-size: .98rem; line-height: 1.55; margin: 0 0 18px; }
.tags { display: flex; flex-wrap: wrap; gap: 8px; margin: 0 0 18px; }
.tag { font-family: var(--f-ui); font-size: 12px; color: var(--brand); background: color-mix(in srgb, var(--brand) 7%, var(--bg-alt)); border: 1px solid var(--hair); border-radius: 999px; padding: 5px 12px; }
.path-card__obj { display: flex; gap: 10px; align-items: flex-start; margin-top: auto; padding-top: 16px; border-top: 1px solid var(--hair); font-size: .95rem; color: var(--brand-deep); }
.path-card__obj svg { flex: none; width: 18px; height: 18px; margin-top: 2px; fill: none; stroke: var(--orange); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.path-card__note { font-size: 12.5px; color: var(--ink-soft); font-style: italic; margin: 12px 0 0; }
.notice {
  display: inline-flex; align-items: center; gap: 11px; margin: 0 auto clamp(30px, 4vw, 44px);
  font-family: var(--f-ui); font-size: 13.5px; color: var(--ink-soft);
  background: var(--bg-alt); border: 1px solid var(--hair); border-radius: 999px; padding: 10px 20px;
}
.notice__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--halo); flex: none; }

/* important disclaimer block */
.disclaimer {
  margin-top: clamp(44px, 6vw, 72px); display: flex; gap: 20px; align-items: flex-start;
  padding: clamp(26px, 3vw, 40px); border-radius: var(--radius);
  background: var(--bg-alt); border: 1px solid var(--hair);
}
.disclaimer__ic { flex: none; width: 48px; height: 48px; border-radius: 14px; display: grid; place-items: center; background: var(--bg); border: 1px solid var(--hair); color: var(--orange); }
.disclaimer__ic svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.disclaimer__k { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--orange); margin: 0 0 8px; }
.disclaimer p { margin: 0; color: var(--ink-soft); line-height: 1.6; max-width: 64ch; }

/* ---------------------------------------------------------
   PRO — wavelength spectrum, penetration, parameters, refs
   --------------------------------------------------------- */
.therapeutic-window { margin-top: 8px; }
.spectrum-bar {
  position: relative; height: 46px; border-radius: 999px; overflow: hidden; margin: 18px 0 8px;
  background: linear-gradient(90deg, #6a3aa8 0%, #4060c0 16%, #3aa0c0 32%, #4caf50 48%, #d4c020 62%, #f08020 78%, #d62f3a 100%);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.08);
}
.spectrum-window { position: absolute; top: -4px; bottom: -4px; left: 56%; right: 6%; border: 2px solid #fff; border-radius: 12px; box-shadow: 0 0 0 1px rgba(0,0,0,.2), 0 6px 16px -6px rgba(0,0,0,.4); display: grid; place-items: center; }
.spectrum-window span { font-family: var(--f-ui); font-size: 12px; font-weight: 700; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,.5); }
.spectrum-scale { display: flex; justify-content: space-between; font-family: var(--f-ui); font-size: 11.5px; color: var(--ink-soft); }
.pen-list { list-style: none; margin: 22px 0 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.pen-row { display: grid; grid-template-columns: 1fr; gap: 6px; }
.pen-top { display: flex; justify-content: space-between; gap: 12px; font-family: var(--f-ui); font-size: 13px; }
.pen-top b { color: var(--brand-deep); font-weight: 600; }
.pen-top span { color: var(--orange); font-weight: 600; }
.pen-track { height: 8px; border-radius: 999px; background: var(--bg-alt); overflow: hidden; }
.pen-fill { height: 100%; border-radius: 999px; background: var(--halo); }

.param-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: clamp(16px, 2vw, 22px); }
.param-card { background: var(--bg); border: 1px solid var(--hair); border-radius: var(--radius); padding: clamp(22px, 2.4vw, 30px); }
.param-card__k { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin: 0 0 8px; }
.param-card__v { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.5rem; color: var(--brand-deep); margin: 0 0 8px; }
.param-card__d { color: var(--ink-soft); font-size: .92rem; line-height: 1.5; margin: 0; }
.factor-list { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 12px 28px; }
.factor-list li { display: flex; gap: 11px; align-items: flex-start; color: var(--ink-soft); font-size: .98rem; line-height: 1.5; }
.factor-list li::before { content: ""; flex: none; width: 7px; height: 7px; margin-top: .5em; border-radius: 50%; background: var(--halo); }

.refgrid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: clamp(16px, 2vw, 22px); }
.refcard { background: var(--bg); border: 1px solid var(--hair); border-radius: var(--radius); padding: clamp(22px, 2.4vw, 30px); }
.refcard__h { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin: 0 0 16px; padding-bottom: 12px; border-bottom: 1px solid var(--hair); }
.refcard ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.refcard li { font-size: .94rem; line-height: 1.45; color: var(--brand-deep); }
.refcard li span { display: block; color: var(--ink-soft); font-size: .86rem; margin-top: 3px; }

.warncols { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(18px, 2.4vw, 28px); }
.warncard { border-radius: var(--radius); padding: clamp(26px, 3vw, 38px); border: 1px solid var(--hair); }
.warncard--alert { background: color-mix(in srgb, var(--grenat) 6%, var(--bg)); border-color: color-mix(in srgb, var(--grenat) 24%, transparent); }
.warncard--safe { background: color-mix(in srgb, var(--green) 8%, var(--bg)); border-color: color-mix(in srgb, var(--green) 26%, transparent); }
.warncard__h { display: flex; align-items: center; gap: 11px; font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.3rem; color: var(--brand-deep); margin: 0 0 18px; }
.warncard__h svg { width: 22px; height: 22px; fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.warncard--alert .warncard__h svg { stroke: var(--grenat); }
.warncard--safe .warncard__h svg { stroke: var(--green); }
.warnlist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 13px; }
.warnlist li { display: flex; gap: 12px; align-items: flex-start; color: var(--ink-soft); font-size: .98rem; line-height: 1.5; }
.warnlist li::before { content: ""; flex: none; width: 6px; height: 6px; margin-top: .55em; border-radius: 50%; }
.warncard--alert .warnlist li::before { background: var(--grenat); }
.warncard--safe .warnlist li::before { background: var(--green); }
.pro-highlight {
  margin-top: clamp(30px, 4vw, 44px); padding: clamp(28px, 3.4vw, 44px); border-radius: var(--radius);
  background: var(--bg-alt); border: 1px solid var(--hair);
}
.pro-highlight__k { font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); margin: 0 0 12px; }
.pro-highlight p { color: var(--ink-soft); line-height: 1.65; margin: 0 0 22px; max-width: 70ch; }

/* numbered pro sections */
.pro-num { display: flex; align-items: baseline; gap: 18px; margin-bottom: clamp(28px, 3.4vw, 44px); }
.pro-num__n { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(2.2rem, 4vw, 3.4rem); line-height: .9; color: color-mix(in srgb, var(--accent) 60%, var(--hair)); flex: none; }
.pro-num__txt .eyebrow { margin-bottom: 8px; }
.pro-num__txt h2 { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(1.6rem, 2.8vw, 2.3rem); color: var(--brand-deep); margin: 0; line-height: 1.16; }
.pro-num__txt .pro-num__sub { font-family: var(--f-head); font-style: italic; color: var(--ink-soft); font-size: 1.1rem; margin: 6px 0 0; }

/* ---------------------------------------------------------
   CTA BAND (self-contained — no clip-path dependency)
   --------------------------------------------------------- */
.cta-band {
  position: relative; overflow: hidden; text-align: center;
  padding: clamp(72px, 10vw, 132px) 0;
  background:
    radial-gradient(70% 80% at 50% 0%, color-mix(in srgb, var(--orange) 30%, transparent), transparent 62%),
    linear-gradient(170deg, #54202F 0%, #3F1221 58%, #2F0D18 100%);
  color: var(--wine-50);
}
.cta-band__inner { position: relative; z-index: 1; max-width: 700px; margin: 0 auto; padding-inline: var(--gut); }
.cta-band .eyebrow { color: var(--ambre-light); justify-content: center; display: inline-flex; }
.cta-band__title { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(2rem, 4.6vw, 3.4rem); line-height: 1.12; letter-spacing: var(--title-tracking); color: #fff; margin: 0 0 .5em; text-wrap: balance; }
.cta-band__title em { font-style: italic; color: var(--ambre-light); }
.cta-band__text { color: rgba(255,255,255,.82); font-size: 1.12rem; line-height: 1.6; margin: 0 auto 36px; max-width: 46ch; }
.cta-band__actions { display: flex; flex-wrap: wrap; gap: 16px; justify-content: center; align-items: center; }
.cta-band .btn-gradient {
  background: #FBF1EF; background-image: none; color: var(--bourgogne);
  box-shadow: 0 1px 0 rgba(255,255,255,.7) inset, 0 10px 30px rgba(20,8,14,.36);
}
.cta-band .btn-gradient:hover { background: #fff; transform: translateY(-2px); box-shadow: 0 16px 40px rgba(20,8,14,.46); }
.cta-band .btn-ghost { color: #fbf1ef; background: color-mix(in srgb, #fff 12%, transparent); border-color: color-mix(in srgb, #fff 32%, transparent); }
.cta-band .btn-ghost:hover { border-color: #fff; color: #fff; background: color-mix(in srgb, #fff 16%, transparent); }
@media (max-width: 540px) { .cta-band__actions .btn { width: 100%; justify-content: center; } }

/* ---------------------------------------------------------
   FORMATION — coming soon
   --------------------------------------------------------- */
.fm {
  position: relative; overflow: hidden; min-height: 100vh; display: grid; place-items: center; text-align: center;
  background:
    radial-gradient(60% 60% at 50% 16%, color-mix(in srgb, var(--ambre) 22%, transparent), transparent 60%),
    radial-gradient(70% 60% at 50% 100%, color-mix(in srgb, var(--grenat) 18%, transparent), transparent 64%),
    var(--bg);
  padding: clamp(120px, 16vw, 200px) var(--gut) clamp(60px, 8vw, 100px);
}
.fm__inner { position: relative; z-index: 1; max-width: 660px; }
.fm__badge { display: inline-flex; align-items: center; gap: 9px; font-family: var(--f-ui); font-size: 12px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--orange); background: color-mix(in srgb, var(--orange) 12%, var(--bg)); border: 1px solid color-mix(in srgb, var(--orange) 30%, transparent); border-radius: 999px; padding: 8px 18px; margin-bottom: 28px; }
.fm__badge::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--orange); animation: fm-pulse 2.4s ease-in-out infinite; }
@keyframes fm-pulse { 0%,100% { opacity: 1; box-shadow: 0 0 0 0 color-mix(in srgb, var(--orange) 40%, transparent); } 50% { opacity: .7; box-shadow: 0 0 0 7px color-mix(in srgb, var(--orange) 0%, transparent); } }
.fm__title { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(2.6rem, 6.4vw, 4.6rem); line-height: 1.06; letter-spacing: var(--title-tracking); color: var(--brand-deep); margin: 0 0 26px; }
.fm__title em { font-style: italic; background: var(--halo); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.fm__lede { font-size: clamp(1.08rem, 1.6vw, 1.28rem); color: var(--ink-soft); line-height: 1.6; margin: 0 0 38px; }
.fm__actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }

/* ---------------------------------------------------------
   LEGAL
   --------------------------------------------------------- */
.legal { padding: clamp(54px, 7vw, 96px) 0 var(--sec-y); }
.legal-content { max-width: 760px; margin: 0 auto; }
.legal-content h2 { font-family: var(--f-head); font-weight: var(--display-weight); font-size: clamp(1.5rem, 2.8vw, 2.1rem); color: var(--brand-deep); margin: clamp(40px, 5vw, 60px) 0 .5em; padding-top: clamp(20px, 3vw, 30px); border-top: 1px solid var(--hair); }
.legal-content h2:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.legal-content h3 { font-family: var(--f-head); font-weight: var(--display-weight); font-size: 1.35rem; color: var(--brand); margin: 1.8em 0 .5em; }
.legal-content h4 { font-family: var(--f-ui); font-size: 13px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--accent); margin: 1.6em 0 .5em; }
.legal-content p { color: var(--ink-soft); line-height: 1.7; margin: 0 0 1.1em; }
.legal-content ul { color: var(--ink-soft); line-height: 1.7; margin: 0 0 1.2em; padding-left: 1.3em; }
.legal-content li { margin-bottom: .5em; }
.legal-content strong { color: var(--brand-deep); }
.legal-content a { color: var(--brand); text-decoration: underline; text-underline-offset: 2px; }
.legal-box { background: var(--bg-alt); border: 1px solid var(--hair); border-radius: var(--radius); padding: clamp(22px, 3vw, 34px); margin: 1.6em 0; }
.legal-box p:last-child { margin-bottom: 0; }
.legal-updated { font-family: var(--f-ui); font-size: 13px; color: var(--ink-soft); margin-top: 2.4em; padding-top: 1.4em; border-top: 1px solid var(--hair); }

/* ---------------------------------------------------------
   small shared: page CTA band reuse (.rdv already styled) + breadcrumb
   --------------------------------------------------------- */
.xlink { display: inline-flex; align-items: center; gap: .5em; font-family: var(--f-ui); font-weight: 600; font-size: 13px; letter-spacing: .04em; text-transform: uppercase; color: var(--brand); text-decoration: none; }
.xlink svg { width: 16px; height: 16px; transition: transform .3s; }
.xlink:hover svg { transform: translateX(4px); }

/* ---------------------------------------------------------
   RESPONSIVE
   --------------------------------------------------------- */
@media (max-width: 940px) {
  .split, .bookgrid, .faqgrid { grid-template-columns: 1fr; }
  .split--rev .split__media { order: 0; }
  .warncols, .duo, .iconlist, .factor-list { grid-template-columns: 1fr; }
  .faq-aside { position: static; }
  .timeslots { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .dose { gap: 12px; }
  .dose__name { font-size: 1.05rem; }
  .price-card__price { font-size: 2rem; }
  .pro-num__n { font-size: 2rem; }
  .faq-a-inner { padding-left: 4px; }
  .page-hero { min-height: clamp(360px, 56vh, 480px); }
}
