/* ==========================================================
 * INFOS PRATIQUES — page service Pépites
 * Socle propre : layout general.php + hero aligné sur /chroniques.
 * Aucune surcharge historique v3-static-shell dans ce fichier.
 * ========================================================== */

body.static-infos-pratiques {
  --ip-acc: #ff6233;
  --ip-acc-strong: #ea5527;
  --ip-bg: #ffffff;
  --ip-paper: #ffffff;
  --ip-warm: #f8f9fa;
  --ip-ink: #2c2c2c;
  --ip-ink2: color-mix(in srgb, var(--ip-ink) 84%, transparent);
  --ip-muted: #6f7278;
  --ip-rule: #eaeaea;
  --ip-page-bg: linear-gradient(180deg, var(--ip-bg) 0%, var(--ip-warm) 100%);
  --ip-radius: 10px;
  --ip-radius-lg: 14px;
  --ip-shadow-soft: 0 10px 28px rgba(16, 24, 40, 0.06);
  --ip-shadow-card: 0 12px 28px rgba(16, 24, 40, 0.08);
  --ip-font-s: "Montserrat", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --ip-font-d: "Lora", Georgia, serif;

  margin: 0;
  background: var(--ip-page-bg);
  color: var(--ip-ink);
  font-family: var(--ip-font-s);
  color-scheme: light;
}

body.static-infos-pratiques,
body.static-infos-pratiques *,
body.static-infos-pratiques *::before,
body.static-infos-pratiques *::after {
  box-sizing: border-box;
}

body.static-infos-pratiques .ip-general-main,
body.static-infos-pratiques .v3-main-wrapper {
  padding-top: 0;
  overflow-x: clip;
  background: var(--ip-page-bg);
}

body.static-infos-pratiques .p-header {
  position: absolute;
  inset: 0 0 auto 0;
  z-index: 50;
  background: transparent;
}

/* ================= HERO — référence /chroniques ================= */

.ip-hero {
  position: relative;
  isolation: isolate;
  display: flex;
  align-items: flex-end;
  width: 100%;
  min-height: clamp(430px, 64vh, 760px);
  overflow: hidden;
  background:
    radial-gradient(circle at 76% 22%, rgba(255, 184, 92, .22), transparent 34%),
    linear-gradient(135deg, #080a0d 0%, #10141a 46%, #2b1e16 100%);
}

.ip-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: var(--ip-hero-image, none);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  opacity: .92;
  transform: scale(1.01);
}

.ip-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(90deg, rgba(5, 7, 10, .88) 0%, rgba(7, 8, 10, .70) 32%, rgba(10, 10, 10, .38) 64%, rgba(10, 10, 10, .26) 100%),
    linear-gradient(180deg, rgba(10, 10, 10, .18) 0%, rgba(10, 10, 10, .42) 42%, rgba(10, 10, 10, .82) 100%);
}

.ip-hero__container {
  position: relative;
  z-index: 2;
  width: min(1240px, calc(100% - 2rem));
  max-width: calc(100vw - 2rem);
  margin: 0 auto;
  padding: 8.35rem 0 3.85rem;
}

.ip-hero__text {
  max-width: 1040px;
  color: #ffffff;
}

.ip-hero__breadcrumb,
.ip-hero__eyebrow {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0 0 1rem;
  color: rgba(255, 255, 255, 0.82);
  font-family: var(--ip-font-s);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.25;
  text-transform: uppercase;
}

.ip-hero__breadcrumb a {
  color: inherit;
  text-decoration: none;
}

.ip-hero__sep {
  opacity: 0.65;
}

.ip-hero__label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  margin: 0 0 0.9rem;
  padding: 0.36rem 0.72rem;
  border-radius: 4px;
  background: var(--ip-acc);
  color: #ffffff;
  font-family: var(--ip-font-s);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 0 10px 24px rgba(255, 98, 51, 0.18);
}

.ip-hero__eyebrow {
  color: rgba(255, 255, 255, 0.80);
}

.ip-hero__title {
  max-width: 1040px;
  /*margin: 0;*/
  color: #ffffff;
  font-family: var(--ip-font-d);
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 700;
  line-height: 0.96;
  letter-spacing: -0.03em;
  text-wrap: balance;
}

.ip-hero__title::after {
  content: '';
  display: block;
  width: 82px;
  height: 4px;
  margin-top: 1rem;
  border-radius: 999px;
  background: var(--ip-acc);
}

.ip-hero__subtitle {
  max-width: 720px;
  margin: 1.1rem 0 0;
  color: rgba(255, 255, 255, 0.88);
  font-family: var(--ip-font-s);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.78;
}

.ip-hero-quicknav {
  position: relative;
  z-index: 5;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0.5rem;
  width: min(1240px, calc(100% - 2rem));
  max-width: calc(100vw - 2rem);
  margin: -40px auto 2rem;
  padding: 1rem 1.05rem;
  border: 1px solid var(--ip-rule);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--ip-shadow-soft);
  backdrop-filter: blur(12px);
}

.ip-hero-quicknav a {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  min-width: 0;
  min-height: 34px;
  max-width: 100%;
  padding: 0.52rem 0.78rem;
  border: 1px solid var(--ip-rule);
  border-radius: 999px;
  background: var(--ip-paper);
  color: var(--ip-ink);
  font-family: var(--ip-font-s);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  transition: transform 0.18s ease, color 0.18s ease, border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

.ip-hero-quicknav a.is-active,
.ip-hero-quicknav a:hover,
.ip-hero-quicknav a:focus-visible {
  background: var(--ip-acc);
  border-color: var(--ip-acc);
  color: #ffffff;
  outline: none;
  box-shadow: 0 10px 16px rgba(255, 98, 51, 0.16);
}

.ip-hero-quicknav a:hover,
.ip-hero-quicknav a:focus-visible {
  transform: translateY(-1px);
}

.infos-pratiques-page {
  display: grid;
  gap: clamp(26px, 3vw, 44px);
  width: min(1240px, calc(100% - 2rem));
  max-width: calc(100vw - 2rem);
  margin: 0 auto;
  padding: 0 0 4.2rem;
  font-family: var(--ip-font-s);
  color: var(--ip-ink);
}

.infos-pratiques-page > .ip-section-nav:first-child {
  margin-top: 0;
}

.infos-pratiques-page * { box-sizing: border-box; }

.ip-kicker {
  margin: 0 0 10px;
  font-family: var(--ip-font-s);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ip-acc);
}

.ip-lead {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 320px);
  gap: clamp(22px, 3vw, 42px);
  align-items: end;
  padding: clamp(18px, 2.6vw, 34px) 0 clamp(22px, 3vw, 38px);
  border-top: 1px solid var(--ip-rule);
  border-bottom: 1px solid var(--ip-rule);
  background: transparent;
}

.ip-lead h2 {
  max-width: 800px;
  font-family: var(--ip-font-d);
  font-size: clamp(2rem, 4.3vw, 3.6rem);
  font-weight: 700;
  line-height: 1.06;
  letter-spacing: -.035em;
}

.ip-lead p:not(.ip-kicker) {
  margin: 16px 0 0;
  max-width: 74ch;
  color: var(--ip-ink2);
  font-size: clamp(.98rem, 1.25vw, 1.08rem);
  line-height: 1.72;
}

.ip-lead__aside {
  display: grid;
  gap: 10px;
  align-content: start;
  padding: 18px 0 0 22px;
  border-left: 2px solid var(--ip-rule);
}

.ip-lead__aside span {
  color: var(--ip-muted);
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.ip-lead__aside a,
.ip-inline-link,
.ip-mini-link {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  align-items: center;
  gap: 7px;
  color: var(--ip-ink);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  transition: color .16s ease, transform .16s ease;
}

.ip-lead__aside a::after,
.ip-inline-link::after,
.ip-mini-link::after { content: "→"; color: var(--ip-acc); }

.ip-lead__aside a:hover,
.ip-inline-link:hover,
.ip-mini-link:hover { color: var(--ip-acc); transform: translateX(2px); }

.ip-section-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-top: 1px solid var(--ip-rule);
  border-bottom: 1px solid var(--ip-rule);
  background: transparent;
}

.ip-section-nav a {
  flex: 1 1 auto;
  padding: 13px 16px;
  color: var(--ip-ink2);
  border-right: 1px solid var(--ip-rule);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-align: center;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .16s ease, color .16s ease;
}

.ip-section-nav a:last-child { border-right: 0; }
.ip-section-nav a:hover,
.ip-section-nav a:focus-visible {
  color: #fff;
  background: var(--ip-ink);
  outline: none;
}

.ip-section-head {
  display: grid;
  gap: 10px;
  margin-bottom: clamp(18px, 2.4vw, 30px);
  padding-bottom: 16px;
  border-bottom: 2px solid var(--ip-ink);
}

.ip-section-head--split {
  grid-template-columns: minmax(0, .9fr) minmax(260px, .5fr);
  align-items: end;
  gap: clamp(20px, 4vw, 56px);
}

.ip-card {
  overflow: hidden;
}

.ip-card__header {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--ip-rule);
}

.ip-card__header h3 {
  margin: 0;
  color: var(--ip-ink);
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
}

.ip-card__header span {
  display: block;
  margin-top: 5px;
  color: var(--ip-muted);
  font-size: .78rem;
  font-weight: 700;
}

.ip-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-height: 42px;
  padding: 10px 16px;
  border: 1px solid var(--ip-ink);
  border-radius: 0;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
  transition: background .16s ease, color .16s ease, border-color .16s ease;
}

.ip-btn--primary {
  background: var(--ip-ink);
  color: var(--ip-paper);
}

.ip-btn--secondary {
  background: transparent;
  color: var(--ip-ink);
}

.ip-btn:hover,
.ip-btn:focus-visible {
  border-color: var(--ip-acc);
  background: var(--ip-acc);
  color: #fff;
  outline: none;
}

.ip-bottom-grid {
  display: grid;
  grid-template-columns: minmax(280px, .52fr) minmax(0, .48fr);
  gap: clamp(18px, 2.4vw, 28px);
}

.ip-note-card {
  background:
    linear-gradient(90deg, rgba(255,98,51,.08), transparent 34%),
    var(--ip-warm);
}

.ip-note-card p:not(.ip-kicker) {
  margin-top: 14px;
}

.ip-note-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}


@media (max-width: 1040px) {

  .ip-lead__aside {
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid var(--ip-rule);
    padding-top: 18px;
  }
}

@media (max-width: 680px) {
  .infos-pratiques-page { gap: 26px; }

  .ip-section-nav a {
    flex-basis: 50%;
    border-bottom: 1px solid var(--ip-rule);
  }

  .ip-section-nav a:nth-child(2n) { border-right: 0; }
  .ip-section-nav a:nth-last-child(-n+2) { border-bottom: 0; }
  .ip-note-actions .ip-btn { width: 100%; }
}

/* Marchés réguliers — page alimentée par l’export JSON indépendant de l’agenda. */
.ip-markets-page {
  gap: clamp(24px, 3vw, 42px);
}

.ip-markets-lead .ip-lead__aside strong {
  color: var(--ip-ink);
  font-size: clamp(1.25rem, 2.5vw, 1.9rem);
  font-weight: 900;
  line-height: 1;
}

.ip-markets-lead .ip-lead__aside em {
  color: var(--ip-muted);
  font-size: .82rem;
  font-style: normal;
  font-weight: 700;
}

.ip-market-filters {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--ip-rule);
  background: var(--ip-warm);
}

.ip-market-filters__grid {
  display: grid;
  grid-template-columns: minmax(220px, 1.3fr) repeat(4, minmax(150px, 1fr));
  gap: 12px;
  align-items: end;
}

.ip-market-filters label {
  display: grid;
  gap: 8px;
}

.ip-market-filters label span {
  color: var(--ip-muted);
  font-size: .66rem;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
}

.ip-market-filters input,
.ip-market-filters select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--ip-rule);
  border-radius: 6px;
  background: var(--ip-paper);
  color: var(--ip-ink);
  padding: 9px 10px;
  font: inherit;
  font-size: .9rem;
}

.ip-market-filters__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.ip-market-filters__actions span {
  margin-left: auto;
  color: var(--ip-muted);
  font-size: .8rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.ip-market-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid var(--ip-rule);
  border-left: 1px solid var(--ip-rule);
}

.ip-market-card {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  gap: 14px;
  padding: 18px;
  border-right: 1px solid var(--ip-rule);
  border-bottom: 1px solid var(--ip-rule);
  background: var(--ip-paper);
  color: var(--ip-ink);
}

.ip-market-card__top,
.ip-market-card__footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.ip-market-card__top span,
.ip-market-card__top em {
  color: var(--ip-acc);
  font-size: .64rem;
  font-style: normal;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
}

.ip-market-card__top em {
  color: var(--ip-muted);
}

.ip-market-card h3 {
  margin: 0;
  color: var(--ip-ink);
  font-family: var(--ip-font-d);
  font-size: clamp(1.35rem, 2vw, 1.85rem);
  line-height: 1.08;
  letter-spacing: -.035em;
}

.ip-market-card p {
  margin: 0;
  color: var(--ip-ink2);
  font-size: .92rem;
  line-height: 1.6;
}

.ip-market-facts {
  display: grid;
  gap: 0;
  margin: 0;
  border-top: 1px solid var(--ip-rule);
}

.ip-market-facts div {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid var(--ip-rule);
}

.ip-market-facts dt {
  color: var(--ip-muted);
  font-size: .64rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.ip-market-facts dd {
  margin: 0;
  color: var(--ip-ink);
  font-size: .9rem;
  font-weight: 750;
  line-height: 1.35;
}

.ip-market-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ip-market-tags span {
  padding: 6px 8px;
  border: 1px solid var(--ip-rule);
  border-radius: 999px;
  color: var(--ip-muted);
  font-size: .7rem;
  font-weight: 800;
}

.ip-market-card__footer {
  margin-top: auto;
  padding-top: 4px;
}

.ip-market-card__footer small {
  color: var(--ip-muted);
  font-size: .76rem;
  font-weight: 700;
}

.ip-market-empty strong {
  color: var(--ip-acc);
}

@media (max-width: 1120px) {
  .ip-market-filters__grid,
  .ip-market-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 680px) {
  .ip-market-filters__grid,
  .ip-market-grid { grid-template-columns: 1fr; }
  .ip-market-filters__actions,
  .ip-market-filters__actions .ip-btn { width: 100%; }
  .ip-market-filters__actions span { margin-left: 0; }
  .ip-market-facts div { grid-template-columns: 1fr; gap: 4px; }
}

/* ================= DARK MODE ================= */

html[data-theme="dark"] body.static-infos-pratiques,
html.theme-dark body.static-infos-pratiques,
body.static-infos-pratiques[data-theme="dark"] {
  --ip-bg: #121212;
  --ip-paper: #17191f;
  --ip-warm: #1b1e25;
  --ip-ink: #e0e0e0;
  --ip-ink2: #cbd1da;
  --ip-muted: #b4bac5;
  --ip-rule: rgba(255, 255, 255, 0.08);
  --ip-page-bg: linear-gradient(180deg, #121212 0%, #0e1015 100%);
  --ip-shadow-soft: 0 12px 28px rgba(0, 0, 0, 0.24);
  --ip-shadow-card: 0 14px 32px rgba(0, 0, 0, 0.24);
  background: var(--ip-page-bg);
  color-scheme: dark;
}

html[data-theme="dark"] body.static-infos-pratiques .ip-general-main,
html.theme-dark body.static-infos-pratiques .ip-general-main,
body.static-infos-pratiques[data-theme="dark"] .ip-general-main,
html[data-theme="dark"] body.static-infos-pratiques .v3-main-wrapper,
html.theme-dark body.static-infos-pratiques .v3-main-wrapper,
body.static-infos-pratiques[data-theme="dark"] .v3-main-wrapper {
  background: var(--ip-page-bg);
}

html[data-theme="dark"] body.static-infos-pratiques .ip-hero-quicknav,
html.theme-dark body.static-infos-pratiques .ip-hero-quicknav,
body.static-infos-pratiques[data-theme="dark"] .ip-hero-quicknav {
  background: rgba(19, 22, 29, .96);
  border-color: rgba(255, 255, 255, .08);
  box-shadow: 0 18px 38px rgba(0, 0, 0, .28);
}

html[data-theme="dark"] body.static-infos-pratiques .ip-hero-quicknav a,
html.theme-dark body.static-infos-pratiques .ip-hero-quicknav a,
body.static-infos-pratiques[data-theme="dark"] .ip-hero-quicknav a,
html[data-theme="dark"] body.static-infos-pratiques .ip-section-nav a,
html.theme-dark body.static-infos-pratiques .ip-section-nav a,
body.static-infos-pratiques[data-theme="dark"] .ip-section-nav a {
  background: var(--ip-paper);
  border-color: var(--ip-rule);
  color: var(--ip-ink);
}

html[data-theme="dark"] body.static-infos-pratiques .ip-hero-quicknav a.is-active,
html[data-theme="dark"] body.static-infos-pratiques .ip-hero-quicknav a:hover,
html[data-theme="dark"] body.static-infos-pratiques .ip-hero-quicknav a:focus-visible,
html.theme-dark body.static-infos-pratiques .ip-hero-quicknav a.is-active,
html.theme-dark body.static-infos-pratiques .ip-hero-quicknav a:hover,
html.theme-dark body.static-infos-pratiques .ip-hero-quicknav a:focus-visible,
body.static-infos-pratiques[data-theme="dark"] .ip-hero-quicknav a.is-active,
body.static-infos-pratiques[data-theme="dark"] .ip-hero-quicknav a:hover,
body.static-infos-pratiques[data-theme="dark"] .ip-hero-quicknav a:focus-visible,
html[data-theme="dark"] body.static-infos-pratiques .ip-section-nav a:hover,
html[data-theme="dark"] body.static-infos-pratiques .ip-section-nav a:focus-visible,
html.theme-dark body.static-infos-pratiques .ip-section-nav a:hover,
html.theme-dark body.static-infos-pratiques .ip-section-nav a:focus-visible,
body.static-infos-pratiques[data-theme="dark"] .ip-section-nav a:hover,
body.static-infos-pratiques[data-theme="dark"] .ip-section-nav a:focus-visible {
  background: var(--ip-acc);
  border-color: var(--ip-acc);
  color: #ffffff;
}

html[data-theme="dark"] body.static-infos-pratiques .ip-note-card,
html.theme-dark body.static-infos-pratiques .ip-note-card,
body.static-infos-pratiques[data-theme="dark"] .ip-note-card {
  background:
    linear-gradient(90deg, rgba(255,98,51,.10), transparent 34%),
    var(--ip-warm);
}

html[data-theme="dark"] body.static-infos-pratiques .ip-btn--primary,
html.theme-dark body.static-infos-pratiques .ip-btn--primary,
body.static-infos-pratiques[data-theme="dark"] .ip-btn--primary {
  background: #ffffff;
  border-color: #ffffff;
  color: #111111;
}


@media (max-width: 860px) {
  .ip-hero__container,
  .ip-hero-quicknav,
  .infos-pratiques-page {
    width: calc(100% - 1.2rem);
    max-width: calc(100vw - 1.2rem);
  }

  .ip-hero__container {
    padding-top: 6.4rem;
    padding-bottom: 2.6rem;
  }

  .ip-hero-quicknav {
    margin-top: -26px;
    padding: 0.9rem;
    border-radius: 12px;
  }
}

@media (max-width: 640px) {
  .ip-hero {
    min-height: auto;
  }

  .ip-hero__container {
    padding-top: 6.6rem;
    padding-bottom: 2.25rem;
  }

  .ip-hero__breadcrumb,
  .ip-hero__eyebrow {
    font-size: 0.68rem;
    letter-spacing: 0.1em;
  }

  .ip-hero__label {
    min-height: 28px;
    font-size: 0.66rem;
  }

  .ip-hero__title {
    max-width: 100%;
    font-size: clamp(2rem, 10vw, 2.85rem);
  }

  .ip-hero__title::after {
    width: 68px;
  }

  .ip-hero__subtitle {
    font-size: 0.95rem;
    line-height: 1.7;
  }

  .ip-hero-quicknav a {
    flex: 1 1 calc(50% - 0.5rem);
    min-height: 32px;
    font-size: 0.71rem;
  }
}

/* Infos pratiques — filtres autonomes des repères utiles */
.ip-useful-zone-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: 0 0 1rem;
}

.ip-useful-zone-tabs button {
  border: 1px solid var(--ip-rule);
  border-radius: 999px;
  background: var(--ip-paper);
  color: var(--ip-ink);
  cursor: pointer;
  font: 800 .76rem/1 var(--ip-font-s);
  padding: .62rem .85rem;
}

.ip-useful-zone-tabs button.is-active,
.ip-useful-zone-tabs button:hover,
.ip-useful-zone-tabs button:focus-visible {
  border-color: var(--ip-acc);
  background: var(--ip-acc);
  color: #fff;
}

/* === DEBUT correctif Infos pratiques v11 === */
.ip-useful-zone-tabs { display: none !important; }
/* === FIN correctif Infos pratiques v11 === */


/* Marchés réguliers — refonte service éditoriale Pépites. */
.markets-v2-body {
  --mk-orange: #ff6233;
  --mk-orange-dark: #e85228;
  --mk-violet: #9b3fb4;
  --mk-ink: #171717;
  --mk-text: #242424;
  --mk-muted: #6f7278;
  --mk-line: rgba(20, 20, 20, .10);
  --mk-bg: #ffffff;
  --mk-card: #ffffff;
  --mk-soft: #f5f2ef;
  --mk-shadow: 0 16px 44px rgba(18, 24, 32, .08);
  --mk-shadow-strong: 0 24px 70px rgba(18, 24, 32, .14);
  --mk-ui: "Montserrat", Arial, sans-serif;
  --mk-serif: "Lora", Georgia, serif;
  background: var(--mk-bg);
  color: var(--mk-text);
}

.markets-v2-main { overflow: clip; background: var(--mk-bg); }

.markets-v2-body .p-header {
  position: absolute;
  inset: 0 0 auto 0;
  z-index: 60;
  background: transparent;
  border-bottom: 0;
  box-shadow: none;
  color: #fff;
}

.markets-v2-body .p-header a,
.markets-v2-body .p-header__link,
.markets-v2-body .p-header__theme-btn,
.markets-v2-body .p-header__burger { color: #fff; }

.markets-v2-body .p-header__theme-btn {
  border-color: rgba(255,255,255,.25);
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
}

.markets-hero {
  position: relative;
  min-height: clamp(520px, 70vh, 760px);
  display: grid;
  align-items: end;
  isolation: isolate;
  background:
    linear-gradient(120deg, #111 0%, #1b1714 54%, #2c211b 100%);
}

.markets-hero.has-image::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: var(--markets-hero-image);
  background-size: cover;
  background-position: center;
  filter: saturate(.95) contrast(1.05);
}

.markets-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 84% 22%, rgba(255, 140, 75, .16), transparent 32%),
    linear-gradient(90deg, rgba(0,0,0,.88) 0%, rgba(0,0,0,.68) 42%, rgba(0,0,0,.36) 72%, rgba(0,0,0,.40) 100%),
    linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.16) 45%, rgba(0,0,0,.78) 100%);
}

.markets-hero__container,
.markets-v2 {
  width: min(1240px, calc(100% - 2rem));
  margin-inline: auto;
}

.markets-hero__container { padding: 8rem 0 5.5rem; }
.markets-hero__content { max-width: 860px; color: #fff; }

.markets-hero__breadcrumb,
.markets-hero__eyebrow,
.markets-kicker {
  font-family: var(--mk-ui);
  font-size: .72rem;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.markets-hero__breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: .42rem;
  margin-bottom: 1rem;
  color: rgba(255,255,255,.82);
}

.markets-hero__breadcrumb a { color: inherit; text-decoration: none; }
.markets-hero__breadcrumb a:hover { color: #fff; }

.markets-hero__label {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  margin-bottom: .92rem;
  padding: .36rem .72rem;
  border-radius: 5px;
  background: var(--mk-orange);
  color: #fff;
  font-family: var(--mk-ui);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 14px 28px rgba(255, 98, 51, .22);
}

.markets-hero__eyebrow { margin: 0 0 1rem; color: rgba(255,255,255,.82); }

.markets-hero__title {
  max-width: 900px;
  margin: 0;
  color: #fff;
  font-family: var(--mk-serif);
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 700;
  line-height: .96;
  letter-spacing: -.03em;
  text-wrap: balance;
}

.markets-hero__title::after {
  content: "";
  display: block;
  width: 82px;
  height: 4px;
  margin-top: 1rem;
  border-radius: 999px;
  background: var(--mk-orange);
}

.markets-hero__subtitle {
  max-width: 760px;
  margin: 1.1rem 0 0;
  color: rgba(255,255,255,.88);
  font-family: var(--mk-ui);
  font-size: 1rem;
  line-height: 1.78;
}

.markets-hero__stats {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 1.35rem;
}

.markets-hero__stats span {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  min-height: 38px;
  padding: .58rem .85rem;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 10px;
  background: rgba(255,255,255,.10);
  color: #fff;
  font-family: var(--mk-ui);
  font-size: .78rem;
  font-weight: 800;
  backdrop-filter: blur(10px);
}


.markets-v2 { position: relative; z-index: 5; padding-bottom: clamp(3rem, 6vw, 5rem); }

.markets-v2-main { overflow: clip; background: #fff; }

.markets-filters {
  display: grid;
  gap: .9rem;
  margin: -3.1rem auto clamp(2.3rem, 4vw, 3.4rem);
  padding: 1.05rem;
  border: 1px solid rgba(24,24,24,.08);
  border-radius: 15px;
  background: rgba(255,255,255,.98);
  box-shadow: 0 18px 50px rgba(18, 24, 32, .10);
  backdrop-filter: blur(16px);
}

.markets-filters__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .85rem;
  align-items: center;
}

.markets-search { position: relative; display: block; }
.markets-search i { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: var(--mk-muted); }
.markets-search input {
  width: 100%;
  height: 48px;
  padding: .8rem 1rem .8rem 2.8rem;
  border: 1px solid var(--mk-line);
  border-radius: 10px;
  background: #fff;
  color: var(--mk-text);
  font: 600 .9rem/1.2 var(--mk-ui);
  outline: none;
}
.markets-search input:focus { border-color: rgba(255,98,51,.45); box-shadow: 0 0 0 4px rgba(255,98,51,.10); }

.markets-reset {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  color: var(--mk-orange);
  font: 800 .78rem/1 var(--mk-ui);
  text-decoration: none;
  white-space: nowrap;
}

.markets-chips { display: flex; flex-wrap: wrap; gap: .55rem; }
.markets-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  min-height: 36px;
  padding: .55rem .78rem;
  border: 1px solid var(--mk-line);
  border-radius: 999px;
  background: #fff;
  color: var(--mk-text);
  font: 800 .74rem/1 var(--mk-ui);
  text-decoration: none;
  box-shadow: 0 6px 14px rgba(18, 24, 32, .04);
}
.markets-chip.is-active { border-color: var(--mk-orange); background: var(--mk-orange); color: #fff; box-shadow: 0 10px 18px rgba(255, 98, 51, .16); }
.markets-chip--soft { background: rgba(255,98,51,.07); border-color: rgba(255,98,51,.18); color: var(--mk-orange); }

.markets-active-filters { display: flex; flex-wrap: wrap; align-items: center; gap: .55rem; padding-top: .15rem; }
.markets-active-filters > span { color: var(--mk-muted); font: 900 .66rem/1 var(--mk-ui); letter-spacing: .12em; text-transform: uppercase; }
.markets-active-filters a { display: inline-flex; align-items: center; gap: .35rem; min-height: 30px; padding: .4rem .62rem; border-radius: 999px; background: rgba(20,20,20,.05); color: var(--mk-text); font: 800 .72rem/1 var(--mk-ui); text-decoration: none; }
.markets-active-filters a:hover { background: rgba(255,98,51,.10); color: var(--mk-orange); }

.markets-filters__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
  gap: .8rem;
  align-items: end;
}
.markets-filter-field { display: grid; gap: .45rem; }
.markets-filter-field span {
  color: var(--mk-muted);
  font: 800 .64rem/1 var(--mk-ui);
  letter-spacing: .13em;
  text-transform: uppercase;
}
.markets-filter-field select,
.markets-list-tools select {
  width: 100%;
  height: 44px;
  border: 1px solid var(--mk-line);
  border-radius: 9px;
  background: #fff;
  color: var(--mk-text);
  padding: 0 .8rem;
  font: 700 .82rem/1 var(--mk-ui);
}
.markets-submit {
  height: 44px;
  padding: 0 1.25rem;
  border: 0;
  border-radius: 8px;
  background: var(--mk-orange);
  color: #fff;
  font: 900 .78rem/1 var(--mk-ui);
  cursor: pointer;
}
.markets-submit:hover { background: var(--mk-orange-dark); }

.markets-section-head { margin-bottom: 1.25rem; }
.markets-section-head--split,
.markets-section-head--list {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1.5rem;
}
.markets-section-head h2 {
  margin: 0;
  color: var(--mk-ink);
  font-family: var(--mk-serif);
  font-size: clamp(1.85rem, 3.2vw, 2.75rem);
  line-height: 1.03;
  letter-spacing: -.035em;
}
.markets-section-head h2::after {
  content: "";
  display: block;
  width: 62px;
  height: 3px;
  margin-top: .72rem;
  border-radius: 999px;
  background: var(--mk-orange);
}
.markets-section-head a { color: var(--mk-orange); font: 800 .78rem/1 var(--mk-ui); text-decoration: none; }
.markets-kicker { margin: 0 0 .55rem; color: var(--mk-orange); }
.markets-section-intro { max-width: 620px; margin: .65rem 0 0; color: var(--mk-muted); font: 500 .92rem/1.65 var(--mk-ui); }

.markets-next { margin-bottom: clamp(2.4rem, 5vw, 4.2rem); }
.markets-next-grid { display: grid; grid-template-columns: minmax(0, 1.18fr) repeat(2, minmax(0, .91fr)); gap: 1rem; align-items: stretch; }
.markets-next-card,
.markets-day-nav,
.markets-day-group,
.markets-info-strip,
.markets-signature,
.markets-empty {
  border: 1px solid var(--mk-line);
  border-radius: 12px;
  background: var(--mk-card);
  box-shadow: 0 10px 30px rgba(18, 24, 32, .045);
}
.markets-next-card {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  gap: 1rem;
  min-height: 180px;
  padding: 1rem;
}
.markets-next-card.is-primary { grid-template-columns: 138px minmax(0, 1fr); }
.markets-next-card__date {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  justify-content: center;
  gap: .45rem;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(255,98,51,.12), rgba(255,98,51,.04));
  color: var(--mk-orange);
  padding: 1rem;
  text-align: center;
}
.markets-next-card__date span { font: 800 .69rem/1 var(--mk-ui); letter-spacing: .11em; text-transform: uppercase; }
.markets-next-card__date strong { color: var(--mk-ink); font: 700 .98rem/1.28 var(--mk-serif); }
.markets-next-card__body { display: flex; min-width: 0; flex-direction: column; }
.markets-card-city,
.markets-row__city { margin: 0; color: var(--mk-orange); font: 800 .67rem/1.25 var(--mk-ui); letter-spacing: .06em; text-transform: uppercase; }
.markets-card-city i,
.markets-row__city i { margin-right: .38rem; }
.markets-next-card h3,
.markets-row h3 {
  margin: .45rem 0 .55rem;
  color: var(--mk-ink);
  font-family: var(--mk-serif);
  font-size: clamp(1.22rem, 1.9vw, 1.48rem);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -.025em;
}
.markets-card-badges { display: flex; flex-wrap: wrap; gap: .35rem; margin: .55rem 0 0; }
.markets-card-badges span,
.markets-row__tags span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: .34rem .62rem;
  border: 1px solid rgba(255,98,51,.18);
  border-radius: 999px;
  background: rgba(255,98,51,.05);
  color: #dc633f;
  font: 700 .65rem/1.1 var(--mk-ui);
  letter-spacing: .01em;
}
.markets-card-badges span + span,
.markets-row__tags span + span {
  border-color: rgba(20,20,20,.08);
  background: #faf8f6;
  color: #6f7278;
}
.markets-card-summary { display: -webkit-box; margin: .7rem 0 .85rem; overflow: hidden; color: var(--mk-muted); font: 500 .86rem/1.55 var(--mk-ui); -webkit-box-orient: vertical; -webkit-line-clamp: 3; }
.markets-next-card a,
.markets-row__link,
.markets-signature a,
.markets-show-all a { display: inline-flex; align-items: center; gap: .25rem; margin-top: auto; color: var(--mk-orange); font: 900 .76rem/1 var(--mk-ui); text-decoration: none; }
.markets-next-card a:hover,
.markets-row__link:hover { color: var(--mk-orange-dark); }

.markets-section-head--list { margin-bottom: 1.15rem; }
.markets-section-head--list h2 { font-family: var(--mk-ui); font-size: clamp(1.45rem, 2.5vw, 2.1rem); line-height: 1; text-transform: uppercase; letter-spacing: .025em; }
.markets-section-head--list h2 span { color: var(--mk-orange); }
.markets-list-tools { display: flex; align-items: center; gap: .85rem; color: var(--mk-muted); font: 600 .78rem/1.2 var(--mk-ui); }
.markets-list-tools p { margin: 0; }

.markets-week-layout { display: grid; grid-template-columns: 236px minmax(0, 1fr); gap: 1.4rem; align-items: start; }
.markets-day-nav { position: sticky; top: 1rem; padding: .78rem; }
.markets-day-nav p { margin: .35rem .55rem .65rem; color: var(--mk-orange); font: 800 .64rem/1 var(--mk-ui); letter-spacing: .12em; text-transform: uppercase; }
.markets-day-nav a { display: flex; align-items: center; justify-content: space-between; gap: .8rem; padding: .76rem .82rem; border-radius: 10px; color: var(--mk-text); font: 700 .84rem/1.1 var(--mk-ui); text-decoration: none; }
.markets-day-nav a:hover,
.markets-day-nav a.is-active { background: rgba(255,98,51,.08); color: var(--mk-orange); }
.markets-day-nav em { min-width: 28px; padding: .24rem .45rem; border-radius: 999px; background: rgba(20,20,20,.045); color: var(--mk-muted); font: 700 .68rem/1 var(--mk-ui); font-style: normal; text-align: center; }
.markets-day-nav a.is-active em,
.markets-day-nav a:hover em { background: #fff; color: var(--mk-orange); }

.markets-day-groups { display: grid; gap: 1rem; }
.markets-day-group { overflow: hidden; }
.markets-day-group__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.05rem 1.25rem; border-bottom: 1px solid var(--mk-line); background: #fff; }
.markets-day-group__head h3 { margin: 0; color: var(--mk-ink); font: 800 1rem/1 var(--mk-ui); letter-spacing: .05em; text-transform: uppercase; }
.markets-day-group__head span { color: var(--mk-muted); font: 700 .76rem/1 var(--mk-ui); }
.markets-day-group__list { display: grid; }
.markets-row { display: grid; grid-template-columns: 132px minmax(0, 1fr) 172px auto; gap: 1.1rem; align-items: center; padding: 1.22rem 1.35rem; border-top: 1px solid rgba(20,20,20,.07); }
.markets-row:first-child { border-top: 0; }
.markets-row:hover { background: rgba(255,98,51,.025); }
.markets-row__time strong { display: block; color: var(--mk-ink); font: 700 .98rem/1.2 var(--mk-serif); }
.markets-row__time span { display: block; margin-top: .26rem; color: var(--mk-muted); font: 700 .69rem/1.15 var(--mk-ui); text-transform: uppercase; letter-spacing: .05em; }
.markets-row__time.is-uncertain strong { color: var(--mk-muted); font-family: var(--mk-ui); font-size: .84rem; }
.markets-row__main p:not(.markets-row__city) { margin: 0; color: var(--mk-muted); font: 500 .9rem/1.58 var(--mk-ui); }
.markets-row__main small { display: inline-flex; margin-top: .48rem; color: var(--mk-text); font: 600 .75rem/1.35 var(--mk-ui); opacity: .66; }
.markets-row__tags { display: flex; flex-wrap: wrap; gap: .42rem; align-items: flex-start; align-content: flex-start; }
.markets-row__link { white-space: nowrap; align-self: center; }

.markets-show-all { display: flex; justify-content: center; margin-top: 1.6rem; }
.markets-show-all a { padding: .85rem 1.1rem; border: 1px solid var(--mk-line); border-radius: 999px; background: #fff; color: var(--mk-text); }

.markets-info-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-top: clamp(2rem, 4vw, 3rem);
  padding: 1.25rem;
  background: #fff;
}
.markets-info-strip > div { display: grid; grid-template-columns: 48px minmax(0,1fr); gap: 1rem; align-items: start; }
.markets-info-strip span { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 999px; background: rgba(255,98,51,.08); color: var(--mk-orange); box-shadow: 0 8px 20px rgba(18,24,32,.04); }
.markets-info-strip h2 { margin: 0 0 .35rem; font: 700 1.18rem/1.2 var(--mk-serif); color: var(--mk-ink); }
.markets-info-strip p { margin: 0; color: var(--mk-muted); font: 500 .88rem/1.55 var(--mk-ui); }

.markets-signature { display: grid; grid-template-columns: 150px minmax(0, 1fr) auto; gap: 1.25rem; align-items: center; margin-top: 1.4rem; padding: 1rem; overflow: hidden; }
.markets-signature__image { min-height: 104px; border-radius: 10px; background: linear-gradient(135deg, rgba(255,98,51,.14), rgba(30,30,30,.04)); }
.markets-signature h2 { margin: 0; font: 700 clamp(1.55rem, 2.2vw, 2rem)/1.1 var(--mk-serif); color: var(--mk-ink); }
.markets-signature p:not(.markets-kicker) { margin: .45rem 0 0; color: var(--mk-muted); font: 500 .92rem/1.55 var(--mk-ui); }
.markets-signature a { margin: 0; padding: .9rem 1.05rem; border: 1px solid var(--mk-line); border-radius: 999px; color: var(--mk-text); white-space: nowrap; }

.markets-empty { padding: clamp(1.4rem, 3vw, 2.2rem); }
.markets-empty h2 { margin: 0; font: 700 2rem/1.1 var(--mk-serif); }
.markets-empty p:not(.markets-kicker) { color: var(--mk-muted); font: 500 .95rem/1.65 var(--mk-ui); }

.service-footer { background: #141414; color: rgba(255,255,255,.76); font-family: var(--mk-ui); }
.service-footer__container { width: min(1240px, calc(100% - 2rem)); margin: 0 auto; display: grid; grid-template-columns: minmax(220px, 1.2fr) repeat(3, minmax(150px, .7fr)) minmax(220px, .9fr); gap: 2rem; padding: clamp(2.5rem, 5vw, 4rem) 0; }
.service-footer__logo { color: #fff; text-decoration: none; text-transform: uppercase; font-weight: 900; letter-spacing: -.02em; }
.service-footer__logo span { color: var(--mk-orange); }
.service-footer h2 { margin: 0 0 .9rem; color: #fff; font: 900 .72rem/1 var(--mk-ui); letter-spacing: .12em; text-transform: uppercase; }
.service-footer p { margin: .9rem 0 0; max-width: 30ch; font: 500 .84rem/1.6 var(--mk-ui); }
.service-footer__nav a { display: block; margin-top: .55rem; color: rgba(255,255,255,.72); text-decoration: none; font: 600 .84rem/1.2 var(--mk-ui); }
.service-footer__socials div { display: flex; gap: .5rem; }
.service-footer__socials a { display: grid; place-items: center; width: 34px; height: 34px; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; color: #fff; text-decoration: none; }
.service-footer__newsletter { position: relative; }
.service-footer__newsletter input { width: 100%; height: 42px; padding: 0 3rem 0 .8rem; border: 0; border-radius: 5px; font: 600 .84rem var(--mk-ui); }
.service-footer__newsletter button { position: absolute; right: 0; bottom: 0; width: 44px; height: 42px; border: 0; border-radius: 0 5px 5px 0; background: var(--mk-orange); color: #fff; cursor: pointer; }
.service-footer__bottom { width: min(1240px, calc(100% - 2rem)); margin: 0 auto; display: flex; justify-content: space-between; gap: 1rem; padding: 1.15rem 0; border-top: 1px solid rgba(255,255,255,.10); color: rgba(255,255,255,.46); font: 500 .78rem/1.4 var(--mk-ui); }
.service-footer__bottom nav { display: flex; gap: 1rem; }
.service-footer__bottom a { color: inherit; text-decoration: none; }

.visually-hidden { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

html[data-theme="dark"] .markets-v2-body {
  --mk-bg: #101217;
  --mk-card: #171a20;
  --mk-text: #eef1f5;
  --mk-ink: #ffffff;
  --mk-muted: #b6bdc8;
  --mk-line: rgba(255,255,255,.10);
  --mk-soft: #171a20;
}
html[data-theme="dark"] .markets-v2-main { background: var(--mk-bg); }
html[data-theme="dark"] .markets-search input,
html[data-theme="dark"] .markets-filter-field select,
html[data-theme="dark"] .markets-chip { background: #171a20; color: var(--mk-text); }
html[data-theme="dark"] .markets-active-filters a { background: rgba(255,255,255,.06); color: var(--mk-text); }
html[data-theme="dark"] .markets-filters { background: rgba(18, 21, 27, .96); }
html[data-theme="dark"] .markets-day-group__head,
html[data-theme="dark"] .markets-info-strip { background: var(--mk-card); }
html[data-theme="dark"] .markets-show-all a,
html[data-theme="dark"] .markets-signature a { background: #171a20; color: var(--mk-text); }

@media (max-width: 1120px) {
  .markets-filters__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .markets-submit { grid-column: 1 / -1; }
  .markets-next-grid { grid-template-columns: 1fr; }
  .markets-next-card,
  .markets-next-card.is-primary { grid-template-columns: 128px minmax(0, 1fr); }
  .markets-week-layout { grid-template-columns: 220px minmax(0, 1fr); }
  .markets-row { grid-template-columns: 130px minmax(0, 1fr); }
  .markets-row__tags { grid-column: 2; }
  .markets-row__link { grid-column: 2; }
  .service-footer__container { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 780px) {
  .markets-hero { min-height: auto; }
  .markets-hero__container { padding: 6.6rem 0 4rem; }
  .markets-hero__title { font-size: clamp(2rem, 10vw, 2.85rem); max-width: 100%; }
  .markets-hero__subtitle { font-size: .95rem; line-height: 1.65; }
  .markets-filters { margin-top: -2.35rem; padding: .9rem; border-radius: 13px; }
  .markets-filters__top,
  .markets-filters__grid { grid-template-columns: 1fr; }
  .markets-submit { grid-column: auto; width: 100%; }
  .markets-reset { justify-content: flex-start; }
  .markets-section-head--split,
  .markets-section-head--list { align-items: start; flex-direction: column; }
  .markets-week-layout { grid-template-columns: 1fr; }
  .markets-day-nav { position: static; display: flex; flex-wrap: nowrap; gap: .4rem; overflow-x: auto; padding: .65rem; scroll-snap-type: x proximity; }
  .markets-day-nav p { flex: 0 0 100%; margin-bottom: .25rem; }
  .markets-day-nav a { flex: 0 0 auto; min-width: 120px; scroll-snap-align: start; }
  .markets-row { grid-template-columns: 1fr; gap: .7rem; }
  .markets-row__tags,
  .markets-row__link { grid-column: auto; }
  .markets-info-strip { grid-template-columns: 1fr; }
  .markets-signature { grid-template-columns: 1fr; }
  .markets-signature a { justify-content: center; white-space: normal; }
  .service-footer__container { grid-template-columns: 1fr; }
  .service-footer__bottom { flex-direction: column; }
}

@media (max-width: 520px) {
  .markets-hero__breadcrumb,
  .markets-hero__eyebrow,
  .markets-kicker { font-size: .66rem; letter-spacing: .10em; }
  .markets-next-card,
  .markets-next-card.is-primary { grid-template-columns: 1fr; }
  .markets-next-card__date { min-height: 92px; }
  .markets-list-tools { flex-direction: column; align-items: start; }
  .markets-day-group__head { align-items: start; flex-direction: column; gap: .45rem; }
  .service-footer__bottom nav { flex-wrap: wrap; }
}


/* Marches - bloc A voir cette semaine configurable */
.markets-next-grid--equal {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.markets-next-grid--equal .markets-next-card,
.markets-next-grid--equal .markets-next-card.is-primary {
  grid-column: auto;
  grid-row: auto;
  min-height: 0;
}

.markets-next-grid--compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.markets-next-grid--compact .markets-next-card {
  min-height: 0;
}

.markets-next-grid--compact .markets-next-card__date {
  min-width: 96px;
}

@media (max-width: 980px) {
  .markets-next-grid--equal,
  .markets-next-grid--compact {
    grid-template-columns: 1fr;
  }

  .markets-next-grid--equal .markets-next-card,
  .markets-next-grid--compact .markets-next-card {
    grid-column: auto;
  }
}


/* ==========================================================
 * DESIGN FINAL : MARCHÉS RÉGULIERS (PIXEL PERFECT)
 * ========================================================== */

/* 1. Cartes "À voir cette semaine" (Spotlight) */
.markets-next-card {
    padding: 0 !important;
    gap: 0 !important;
    align-items: stretch !important;
    overflow: hidden !important;
}

@media (min-width: 521px) {
    .markets-next-card { grid-template-columns: 120px minmax(0, 1fr) !important; }
    .markets-next-card.is-primary { grid-template-columns: 140px minmax(0, 1fr) !important; }
}

.markets-next-card__date {
    border-radius: 0 !important;
    padding: 1.5rem 1rem !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
}

.markets-next-card__body {
    padding: 1.5rem !important;
    justify-content: center !important;
}

/* Couleurs pastels ULTRA douces sur le bloc date entier */
.markets-next-card.c-orange .markets-next-card__date { background: #fff6f0 !important; color: #ea5527 !important; }
.markets-next-card.c-pink .markets-next-card__date { background: #fdf0f2 !important; color: #d84b6b !important; }
.markets-next-card.c-green .markets-next-card__date { background: #f0f5f1 !important; color: #447a54 !important; }
.markets-next-card__date strong { color: var(--mk-ink) !important; }

/* 2. Menu latéral "Parcourir par jour" (Desktop) */
.markets-day-nav {
    background: #fff !important;
    padding: 1.25rem !important;
    border-radius: 12px !important;
}
.markets-day-nav p {
    color: var(--mk-orange) !important;
    margin-bottom: 1rem !important;
}
.markets-day-nav a.is-active {
    background: #fff0eb !important;
}

.markets-day-nav__scroll {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

/* UX Mobile Menu des Jours (Scrolling horizontal) */
@media (max-width: 780px) {
    .markets-day-nav {
        display: block !important;
        padding: 1rem !important;
        overflow: hidden !important;
    }
    .markets-day-nav p {
        margin-bottom: 0.85rem !important;
    }
    .markets-day-nav__scroll {
        display: flex;
        flex-direction: row;
        gap: 0.6rem;
        overflow-x: auto;
        padding-bottom: 0.6rem;
        scroll-snap-type: x proximity;
        -webkit-overflow-scrolling: touch;
        margin-left: -1rem;
        margin-right: -1rem;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    .markets-day-nav__scroll a {
        flex: 0 0 auto !important;
        min-width: 140px !important;
        scroll-snap-align: start;
        margin: 0 !important;
    }
    .markets-day-nav__scroll::-webkit-scrollbar {
        height: 4px;
    }
    .markets-day-nav__scroll::-webkit-scrollbar-track {
        background: rgba(0,0,0,0.05);
        border-radius: 4px;
    }
    .markets-day-nav__scroll::-webkit-scrollbar-thumb {
        background: rgba(255, 98, 51, 0.4);
        border-radius: 4px;
    }
    html[data-theme="dark"] .markets-day-nav__scroll::-webkit-scrollbar-track {
        background: rgba(255,255,255,0.05);
    }
}

/* 3. En-têtes de jours (LUNDI, MARDI...) dans la liste */
.markets-day-group__head {
    background: #fff9f6 !important;
    border: none !important;
    border-top: 1px solid var(--mk-orange) !important;
    padding: 1rem 1.25rem !important;
    border-radius: 8px 8px 0 0 !important;
    margin-bottom: 0 !important;
}
.markets-day-group__head h3,
.markets-day-group__head span {
    color: var(--mk-orange) !important;
}

/* 4. Lignes des marchés */
.markets-row {
    gap: 1.5rem !important;
    padding: 1.5rem 1.25rem !important;
    border-top: 1px solid var(--mk-line) !important;
}

@media (min-width: 1121px) {
    .markets-row { grid-template-columns: 100px minmax(0, 1fr) 180px auto !important; }
}

.markets-day-group__list .markets-row:first-child {
    border-top: none !important;
}

/* Boîte beige pour les horaires */
.markets-row__time {
    background: #f8f6f4 !important;
    border-radius: 10px !important;
    padding: 1.2rem 0.5rem !important;
    text-align: center !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 80px !important;
}
.markets-row__time strong {
    font-size: 1.1rem !important;
}

/* 5. Surcouches Dark Mode (Nuit) */
html[data-theme="dark"] .markets-next-card.c-orange .markets-next-card__date { background: rgba(255, 98, 51, 0.15) !important; }
html[data-theme="dark"] .markets-next-card.c-pink .markets-next-card__date { background: rgba(233, 30, 99, 0.15) !important; }
html[data-theme="dark"] .markets-next-card.c-green .markets-next-card__date { background: rgba(76, 175, 80, 0.15) !important; }
html[data-theme="dark"] .markets-row__time { background: rgba(255, 255, 255, 0.05) !important; }
html[data-theme="dark"] .markets-day-group__head { background: rgba(255, 98, 51, 0.08) !important; }