:root {
  --mt-paper: #fbf8f1;
  --mt-paper-2: #f2eadc;
  --mt-paper-3: #e8decf;
  --mt-white: #ffffff;
  --mt-ink: #18251d;
  --mt-ink-2: #24352a;
  --mt-muted: #596457;
  --mt-muted-2: #7b8478;
  --mt-sage: #8faf8d;
  --mt-sage-soft: #dfeadd;
  --mt-sage-dark: #284f36;
  --mt-sage-deep: #173423;
  --mt-gold: #c59b4c;
  --mt-gold-soft: #efe0bf;
  --mt-danger: #9f3d2e;
  --mt-border: rgba(24, 37, 29, .12);
  --mt-border-strong: rgba(24, 37, 29, .22);
  --mt-shadow: 0 24px 70px rgba(24, 37, 29, .13);
  --mt-shadow-soft: 0 14px 40px rgba(24, 37, 29, .09);
  --mt-radius: 30px;
  --mt-radius-md: 22px;
  --mt-radius-sm: 16px;
  --mt-container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "DM Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--mt-ink);
  background: var(--mt-paper);
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  font-size: 17px;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
p { margin: 0 0 1rem; color: var(--mt-muted); }
strong { color: var(--mt-ink); }
h1, h2, h3, h4, h5, h6 {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--mt-ink);
  line-height: 1.04;
  margin: 0 0 1rem;
}
h1 { font-size: clamp(2.55rem, 5.7vw, 5.2rem); letter-spacing: -.06em; }
h2 { font-size: clamp(2rem, 3.9vw, 3.45rem); letter-spacing: -.045em; }
h3 { font-size: clamp(1.22rem, 1.8vw, 1.55rem); letter-spacing: -.025em; }

.container { width: min(var(--mt-container), calc(100% - 40px)); margin-inline: auto; }
.narrow { width: min(860px, calc(100% - 40px)); }
.section { padding: clamp(56px, 8vw, 96px) 0; }
.align-left { text-align: left !important; margin-inline: 0 !important; }

.screen-reader-text,
.skip-link {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.skip-link:focus {
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 99999;
  width: auto;
  height: auto;
  clip: auto;
  padding: 12px 16px;
  background: var(--mt-sage-deep);
  color: #fff;
  border-radius: 12px;
}
:focus-visible { outline: 3px solid rgba(197, 155, 76, .85); outline-offset: 4px; }

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: rgba(251, 248, 241, .96);
  backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--mt-border);
  transition: box-shadow .22s ease, background .22s ease;
}
.site-header.is-scrolled {
  box-shadow: 0 14px 42px rgba(24, 37, 29, .10);
  background: rgba(251, 248, 241, .99);
}
.topbar {
  background: var(--mt-sage-deep);
  color: rgba(255,255,255,.92);
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .01em;
}
.topbar-inner {
  min-height: 34px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  white-space: nowrap;
  overflow: hidden;
}
.topbar-inner span { overflow: hidden; text-overflow: ellipsis; }
.header-inner {
  min-height: 78px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex: 0 0 auto;
  max-width: 225px;
}
.brand-mark {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: linear-gradient(145deg, var(--mt-sage-dark), var(--mt-sage-deep));
  color: #fff;
  font-family: "Playfair Display", Georgia, serif;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(40, 79, 54, .22);
}
.brand-text { display: grid; line-height: 1.15; min-width: 0; }
.brand-text strong { font-size: 1.03rem; letter-spacing: -.02em; white-space: nowrap; }
.brand-text small { color: var(--mt-muted); font-weight: 800; font-size: .75rem; white-space: nowrap; }
.primary-nav {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  justify-content: center;
  overflow: hidden;
}
.menu-primary,
.mobile-menu,
.footer-menu { list-style: none; margin: 0; padding: 0; }
.menu-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2px;
  flex-wrap: nowrap;
  min-width: 0;
}
.menu-primary li { flex: 0 0 auto; }
.menu-primary a {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  padding: 7px 10px;
  border-radius: 999px;
  color: var(--mt-ink-2);
  font-weight: 850;
  font-size: .87rem;
  white-space: nowrap;
  line-height: 1;
}
.menu-primary a:hover,
.menu-primary .current-menu-item > a {
  background: rgba(143,175,141,.18);
  color: var(--mt-sage-deep);
}
.header-search {
  flex: 0 1 190px;
  min-width: 170px;
}
.mt-search-form,
.search-form {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 42px;
  border: 1px solid var(--mt-border);
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  box-shadow: 0 10px 24px rgba(24,37,29,.06);
  overflow: visible;
}
.mt-search-form label,
.search-form label { flex: 1; min-width: 0; }
.mt-search-form input[type="search"],
.search-form input[type="search"] {
  width: 100%;
  min-height: 40px;
  border: 0;
  outline: 0;
  background: transparent;
  padding: 0 8px 0 14px;
  color: var(--mt-ink);
  font: inherit;
  font-size: .86rem;
}
.mt-search-form input[type="search"]::placeholder,
.search-form input[type="search"]::placeholder { color: rgba(36,53,42,.58); }
.mt-search-submit,
.search-form button,
.search-submit {
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  min-height: 36px;
  display: grid;
  place-items: center;
  margin-right: 3px;
  border: 0;
  border-radius: 999px;
  padding: 0 !important;
  background: var(--mt-sage-dark);
  color: #fff;
  font-weight: 950;
  cursor: pointer;
  line-height: 1;
}
.mt-search-submit span { transform: translateY(-1px); font-size: 1.05rem; }
.mt-search-suggestions {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  display: none;
  background: var(--mt-white);
  border: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow-soft);
  border-radius: 18px;
  overflow: hidden;
  z-index: 20;
}
.mt-search-suggestions.is-visible { display: block; }
.mt-search-suggestions a { display: block; padding: 12px 15px; font-weight: 800; border-bottom: 1px solid var(--mt-border); }
.mt-search-suggestions a:last-child { border-bottom: 0; }
.header-actions {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
}
.cart-link {
  position: relative;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid var(--mt-border);
  border-radius: 999px;
  background: var(--mt-white);
  box-shadow: 0 10px 24px rgba(24,37,29,.06);
  font-size: 0;
  font-weight: 900;
}
.cart-icon { font-size: 0; }
.cart-icon:before {
  content: "🛒";
  font-size: 1.02rem;
  line-height: 1;
}
.cart-count {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 21px;
  height: 21px;
  padding: 0 6px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--mt-gold);
  color: var(--mt-ink);
  font-size: .7rem;
}
.menu-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid var(--mt-border);
  background: var(--mt-white);
  padding: 10px;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(24,37,29,.06);
}
.menu-toggle span { display: block; height: 2px; background: var(--mt-ink); margin: 5px 0; border-radius: 99px; }
.mobile-panel {
  display: none;
  position: fixed;
  inset: 112px 0 auto;
  z-index: 998;
  background: rgba(251, 248, 241, .99);
  border-bottom: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow);
}
.mobile-panel.is-open { display: block; }
.mobile-panel-inner { width: min(100% - 40px, var(--mt-container)); margin: 0 auto; padding: 20px 0 24px; }
.mobile-menu a { display: block; padding: 13px 0; border-bottom: 1px solid var(--mt-border); font-weight: 900; }
.mobile-search { margin: 18px 0; }
.mobile-trust { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.mobile-trust span { padding: 8px 10px; border-radius: 999px; background: var(--mt-white); border: 1px solid var(--mt-border); font-size: .82rem; font-weight: 900; }

/* Buttons */
.mt-btn,
.button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce button.button.alt,
.woocommerce a.button.alt {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 14px 22px !important;
  border-radius: 999px !important;
  font-weight: 950 !important;
  border: 1px solid transparent !important;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, color .22s ease;
  cursor: pointer;
  line-height: 1.1 !important;
  text-align: center;
}
.mt-btn:hover,
.button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover { transform: translateY(-2px); }
.mt-btn-primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce button.button.alt,
.woocommerce a.button.alt {
  background: var(--mt-sage-dark) !important;
  color: #fff !important;
  box-shadow: 0 16px 34px rgba(40, 79, 54, .23) !important;
}
.mt-btn-primary:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover { background: var(--mt-sage-deep) !important; color: #fff !important; }
.mt-btn-secondary {
  background: var(--mt-white) !important;
  color: var(--mt-sage-deep) !important;
  border-color: var(--mt-border-strong) !important;
  box-shadow: none !important;
}
.mt-btn-small { min-height: 44px; padding: 11px 17px !important; font-size: .92rem; }
.mt-btn-large { min-height: 58px; padding: 17px 25px !important; }
.mt-btn-full { width: 100%; }
.text-link { color: var(--mt-sage-dark); font-weight: 950; border-bottom: 2px solid rgba(197,155,76,.46); }

/* Ritual strip */
.ritual-strip {
  background: var(--mt-white);
  border-bottom: 1px solid var(--mt-border);
}
.ritual-strip-inner {
  min-height: 82px;
  display: grid;
  grid-template-columns: 260px 1fr;
  align-items: center;
  gap: 18px;
}
.ritual-strip-title { display: grid; gap: 2px; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--mt-sage-dark);
  font-size: .78rem;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.eyebrow:before { content: ""; width: 28px; height: 1px; background: var(--mt-gold); }
.ritual-strip-title strong { font-size: 1.06rem; }
.ritual-chips,
.home-filter-row { display: flex; gap: 10px; flex-wrap: wrap; }
.ritual-chips a,
.home-filter-row a,
.quick-filters a,
.mini-benefits span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 9px 13px;
  border-radius: 999px;
  background: rgba(143,175,141,.16);
  border: 1px solid rgba(40,79,54,.13);
  color: var(--mt-sage-deep);
  font-size: .9rem;
  font-weight: 900;
}
.ritual-chips a:hover,
.home-filter-row a:hover,
.quick-filters a:hover { background: var(--mt-sage-dark); color: #fff; }

/* Hero */
.hero {
  position: relative;
  overflow: hidden;
  padding: clamp(62px, 8vw, 108px) 0 clamp(60px, 8vw, 92px);
  background:
    radial-gradient(circle at 8% 6%, rgba(143,175,141,.34), transparent 34%),
    radial-gradient(circle at 90% 18%, rgba(197,155,76,.2), transparent 29%),
    linear-gradient(135deg, #fbf8f1 0%, #f4eadb 100%);
}
.hero:after {
  content: "";
  position: absolute;
  right: -150px;
  bottom: -210px;
  width: 520px;
  height: 520px;
  border-radius: 50%;
  background: rgba(143,175,141,.18);
  pointer-events: none;
}
.hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.03fr) minmax(360px, .82fr);
  gap: clamp(36px, 5vw, 72px);
  align-items: center;
}
.hero-content { max-width: 720px; }
.hero-lead {
  color: var(--mt-ink-2);
  font-size: clamp(1.06rem, 1.45vw, 1.22rem);
  line-height: 1.72;
  max-width: 650px;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 13px; margin: 30px 0 22px; }
.hero-trust,
.trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.hero-trust span,
.trust-row span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.74);
  border: 1px solid var(--mt-border);
  color: var(--mt-ink-2);
  font-weight: 900;
  font-size: .9rem;
}
.hero-trust span:before { content: "✓"; margin-right: 7px; color: var(--mt-sage-dark); font-weight: 950; }
.hero-showcase { position: relative; min-height: 540px; display: grid; place-items: center; }
.hero-product-card {
  position: relative;
  width: min(100%, 440px);
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.75);
  border-radius: 34px;
  padding: 18px;
  box-shadow: var(--mt-shadow);
}
.hero-product-media {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 335px;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(145deg, var(--mt-sage-soft), #fff);
  border: 1px solid var(--mt-border);
}
.hero-product-media img { width: min(82%, 300px); max-height: 300px; object-fit: contain; filter: drop-shadow(0 24px 28px rgba(24,37,29,.12)); }
.product-badge,
.woocommerce ul.products li.product .onsale,
.onsale {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 950;
  letter-spacing: .02em;
}
.product-badge { position: absolute; top: 16px; left: 16px; z-index: 2; }
.product-badge-green { background: var(--mt-sage-dark); color: #fff; }
.product-badge-gold { background: var(--mt-gold-soft); color: var(--mt-ink); }
.hero-product-content { display: grid; gap: 16px; padding: 19px 6px 2px; }
.rating { display: inline-flex; align-items: center; gap: 6px; color: var(--mt-gold); font-size: .92rem; font-weight: 950; letter-spacing: .05em; }
.rating small { color: var(--mt-muted); letter-spacing: 0; font-weight: 900; }
.hero-product-content h2 { font-size: clamp(1.8rem, 3vw, 2.55rem); margin-bottom: .35rem; }
.hero-product-content p { color: var(--mt-ink-2); margin: 0; }
.hero-price-row { display: flex; justify-content: space-between; align-items: center; gap: 14px; }
.hero-price-row strong { font-size: 1.65rem; color: var(--mt-sage-deep); }
.floating-proof {
  position: absolute;
  padding: 12px 15px;
  border-radius: 999px;
  background: var(--mt-white);
  border: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow-soft);
  font-weight: 950;
  font-size: .88rem;
}
.proof-one { top: 22px; left: -18px; }
.proof-two { right: -18px; bottom: 12px; }

/* Quality */
.quality-bar { background: var(--mt-sage-deep); color: #fff; padding: 24px 0; }
.quality-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.quality-item {
  display: grid;
  grid-template-columns: 50px 1fr;
  column-gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
}
.quality-item span {
  grid-row: span 2;
  width: 50px;
  height: 50px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.12);
  color: var(--mt-gold-soft);
  font-weight: 950;
}
.quality-item strong { color: #fff; }
.quality-item small { color: rgba(255,255,255,.72); line-height: 1.35; }

/* Sections */
.section-heading { max-width: 760px; margin: 0 auto 34px; text-align: center; }
.section-heading p { font-size: 1.02rem; }
.split-heading {
  max-width: none;
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  text-align: left;
}
.split-heading > div:first-child { max-width: 760px; }
.ritual-section { background: var(--mt-white); }
.ritual-grid { display: grid; grid-template-columns: minmax(0, .82fr) minmax(0, 1.18fr); gap: 38px; align-items: center; }
.ritual-card-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.ritual-card,
.category-card,
.reassurance-card,
.testimonial-card,
.fallback-product-card,
.commitment-list > div,
.faq-list details,
.score-card {
  border: 1px solid var(--mt-border);
  border-radius: var(--mt-radius-md);
  background: var(--mt-white);
  box-shadow: var(--mt-shadow-soft);
}
.ritual-card {
  display: block;
  padding: 24px;
  min-height: 214px;
  transition: transform .22s ease, border-color .22s ease, box-shadow .22s ease;
}
.ritual-card:hover,
.category-card:hover { transform: translateY(-4px); border-color: rgba(40,79,54,.32); box-shadow: var(--mt-shadow); }
.ritual-card span,
.category-card span { display: inline-flex; color: var(--mt-gold); font-weight: 950; margin-bottom: 18px; }
.ritual-card h3,
.category-card h3 { margin-bottom: .65rem; }
.products-highlight { background: var(--mt-paper); }
.home-filter-row { margin: -10px 0 28px; }

/* WooCommerce product grid */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 24px !important;
  margin: 0 !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { content: none !important; display: none !important; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 14px 14px 16px !important;
  border-radius: 28px;
  border: 1px solid var(--mt-border);
  background: var(--mt-white);
  box-shadow: var(--mt-shadow-soft);
  display: flex;
  flex-direction: column;
  min-height: 100%;
  position: relative;
  overflow: hidden;
}
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.woocommerce ul.products li.product img {
  width: 100% !important;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  padding: 28px;
  margin: 0 0 15px !important;
  background: linear-gradient(145deg, #f0eadc, var(--mt-sage-soft));
  border-radius: 22px;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  color: var(--mt-ink) !important;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 1.3rem !important;
  line-height: 1.14;
  padding: 0 !important;
  margin: 0 0 8px !important;
}
.woocommerce-loop-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 2px 0 10px;
}
.woocommerce-loop-card-meta span {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(143,175,141,.16);
  color: var(--mt-sage-deep);
  font-size: .75rem;
  font-weight: 950;
}
.woocommerce ul.products li.product .star-rating { color: var(--mt-gold); font-size: .85rem; margin: 0 0 8px; }
.woocommerce ul.products li.product .price {
  display: flex !important;
  align-items: baseline;
  gap: 6px;
  color: var(--mt-sage-deep) !important;
  font-size: 1.48rem !important;
  font-weight: 950 !important;
  margin: auto 0 14px !important;
}
.woocommerce ul.products li.product .price del { color: var(--mt-muted-2); font-size: .95rem; }
.woocommerce ul.products li.product .price ins { text-decoration: none; }
.woocommerce ul.products li.product .button {
  width: 100%;
  margin-top: auto !important;
  min-height: 50px;
  font-size: .95rem !important;
}
.woocommerce-loop-after-price {
  margin: -6px 0 12px;
  color: var(--mt-muted);
  font-size: .88rem;
  font-weight: 800;
}
.woocommerce-loop-after-price:before { content: "✓"; color: var(--mt-sage-dark); margin-right: 6px; }
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale {
  top: 24px !important;
  left: 24px !important;
  right: auto !important;
  min-height: 32px !important;
  line-height: 1 !important;
  background: var(--mt-gold) !important;
  color: var(--mt-ink) !important;
  border: 0 !important;
  z-index: 4;
}

.fallback-products-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.fallback-product-card { position: relative; padding: 16px; }
.fallback-product-card img { border-radius: 22px; background: var(--mt-sage-soft); margin-bottom: 18px; }
.fallback-product-card strong { display: block; font-size: 1.45rem; color: var(--mt-sage-deep); margin: 8px 0 14px; }

/* Testimonials */
.testimonials-section { background: var(--mt-white); }
.testimonials-high { padding-top: clamp(56px, 7vw, 82px); }
.score-card { padding: 18px 22px; display: grid; gap: 2px; min-width: 200px; text-align: right; }
.score-card strong { font-size: 2rem; color: var(--mt-sage-deep); line-height: 1; }
.score-card span { color: var(--mt-muted); font-size: .9rem; font-weight: 800; }
.testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.testimonial-card { padding: 24px; }
.testimonial-card strong { display: block; font-family: "Playfair Display", Georgia, serif; font-size: 1.25rem; margin: 10px 0; }
.testimonial-card > span:last-child { color: var(--mt-sage-dark); font-weight: 950; }

/* Cross sell */
.cross-sell-section { background: linear-gradient(180deg, var(--mt-white), var(--mt-paper)); }
.cross-sell-card {
  border-radius: 34px;
  background: var(--mt-sage-deep);
  color: #fff;
  padding: clamp(28px, 5vw, 54px);
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(320px, .7fr);
  gap: 30px;
  align-items: center;
  overflow: hidden;
  position: relative;
}
.cross-sell-card:after { content: ""; position: absolute; width: 360px; height: 360px; right: -120px; bottom: -150px; border-radius: 50%; background: rgba(197,155,76,.18); }
.cross-sell-content,
.cross-sell-products { position: relative; z-index: 1; }
.cross-sell-card h2,
.cross-sell-card strong { color: #fff; }
.cross-sell-card p { color: rgba(255,255,255,.76); }
.cross-sell-card .eyebrow { color: var(--mt-gold-soft); }
.cross-sell-products { display: grid; gap: 12px; }
.cross-sell-products a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 17px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.15);
}
.cross-sell-products span { color: var(--mt-gold-soft); font-weight: 950; }
.mini-benefits { display: flex; flex-wrap: wrap; gap: 8px; }
.mini-benefits span { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.16); }

/* Categories and commitments */
.categories-section { background: var(--mt-paper); }
.category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.category-card { display: block; padding: 24px; min-height: 230px; }
.commitments-section { background: var(--mt-white); }
.commitments-grid { display: grid; grid-template-columns: minmax(0, .82fr) minmax(0, 1.05fr); gap: 42px; align-items: start; }
.commitment-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
.commitment-list > div { padding: 22px; box-shadow: none; }
.commitment-list p { margin: 8px 0 0; }

/* FAQ */
.faq-home-section { background: var(--mt-paper-2); }
.faq-home-grid { display: grid; grid-template-columns: minmax(0, .65fr) minmax(0, 1fr); gap: 42px; align-items: start; }
.faq-list { display: grid; gap: 12px; }
.faq-list details { padding: 18px 20px; box-shadow: none; }
.faq-list summary { cursor: pointer; font-weight: 950; color: var(--mt-ink); }
.faq-list p { margin: 12px 0 0; }
.final-cta-section { background: var(--mt-paper); }
.final-cta-card,
.cta-card {
  border-radius: 34px;
  text-align: center;
  padding: clamp(36px, 6vw, 72px);
  background:
    radial-gradient(circle at top left, rgba(143,175,141,.25), transparent 32%),
    var(--mt-white);
  border: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow-soft);
}
.final-cta-card p,
.cta-card p { max-width: 720px; margin: 0 auto 24px; }

/* WooCommerce shop page */
.shop-hero {
  background: linear-gradient(135deg, var(--mt-sage-deep), var(--mt-sage-dark));
  color: #fff;
  padding: clamp(46px, 6vw, 78px) 0;
}
.shop-hero h1,
.shop-hero strong { color: #fff; }
.shop-hero p { color: rgba(255,255,255,.76); max-width: 720px; }
.shop-hero .eyebrow { color: var(--mt-gold-soft); }
.shop-hero-grid { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 28px; align-items: center; }
.shop-hero-trust { display: grid; gap: 10px; }
.shop-hero-trust span,
.checkout-trust span {
  display: inline-flex;
  align-items: center;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
  font-weight: 900;
}
.shop-section { background: var(--mt-paper); }
.shop-layout { display: grid; grid-template-columns: 292px minmax(0, 1fr); gap: 28px; align-items: start; }
.shop-filters-panel {
  position: sticky;
  top: 146px;
  padding: 20px;
  border-radius: 24px;
  background: var(--mt-white);
  border: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow-soft);
}
.shop-filters-panel h2 { font-size: 1.45rem; }
.quick-filters { display: flex; flex-wrap: wrap; gap: 8px; margin: 16px 0; }
.shop-filter-widget { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--mt-border); }
.shop-filter-title { font-size: 1.1rem; margin-bottom: 10px; }
.filter-help { font-size: .9rem; margin-bottom: 0; }
.shop-products-area .woocommerce-result-count { color: var(--mt-muted); font-weight: 800; }
.shop-products-area .woocommerce-ordering select,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.input-text,
select,
textarea {
  min-height: 48px;
  border: 1px solid var(--mt-border);
  border-radius: 14px;
  background: #fff;
  padding: 10px 12px;
  font: inherit;
  color: var(--mt-ink);
}
.category-bottom-seo {
  margin-top: 42px;
  padding: 34px;
  border-radius: 28px;
  background: var(--mt-white);
  border: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow-soft);
}
.category-bottom-seo h2 { font-size: clamp(1.7rem, 3vw, 2.6rem); }
.checkout-trust {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 0 0 24px;
  padding: 16px;
  background: var(--mt-sage-deep);
  border-radius: 20px;
}
.woocommerce div.product div.images img { border-radius: 28px; background: var(--mt-white); }
.woocommerce div.product .product_title { font-size: clamp(2.2rem, 4vw, 4rem); }
.woocommerce div.product p.price,
.woocommerce div.product span.price { color: var(--mt-sage-deep); font-size: 2rem; font-weight: 950; }
.woocommerce div.product form.cart .button { min-height: 58px; padding-inline: 28px !important; }
.woocommerce-tabs,
.related.products,
.upsells.products { margin-top: 54px; }
.woocommerce-error,
.woocommerce-info,
.woocommerce-message {
  border-top-color: var(--mt-sage-dark) !important;
  background: var(--mt-white) !important;
  border-radius: 18px;
  box-shadow: var(--mt-shadow-soft);
}
.woocommerce-info::before,
.woocommerce-message::before { color: var(--mt-sage-dark) !important; }

/* Generic content pages */
.page .site-main > .page-hero,
.archive .site-main > .page-hero { padding: 72px 0 34px; }
.content-wrap,
.page-content,
.entry-content {
  width: min(920px, calc(100% - 40px));
  margin: 0 auto;
}
.entry-content h2,
.entry-content h3 { margin-top: 2rem; }
.entry-content p,
.entry-content li { font-size: 1.04rem; }
.entry-content a { color: var(--mt-sage-dark); font-weight: 900; text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 3px; }

/* Footer */
.site-footer { background: var(--mt-sage-deep); color: #fff; }
.footer-prelude { border-bottom: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.04); }
.footer-prelude-inner { min-height: 70px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.footer-prelude strong { color: #fff; font-size: 1.2rem; }
.footer-prelude span { color: rgba(255,255,255,.72); }
.footer-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1.25fr) repeat(3, minmax(140px, .55fr)) minmax(220px, .8fr);
  gap: 34px;
  padding: 54px 0 32px;
}
.site-footer .brand-mark { background: rgba(255,255,255,.14); box-shadow: none; }
.site-footer .brand-text strong,
.site-footer h3 { color: #fff; }
.site-footer .brand-text small,
.site-footer p,
.site-footer small,
.site-footer a,
.footer-bottom { color: rgba(255,255,255,.72); }
.footer-brand p { margin-top: 18px; max-width: 380px; }
.footer-trust { display: flex; flex-wrap: wrap; gap: 8px; }
.footer-trust span {
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.1);
  color: #fff;
  font-weight: 850;
  font-size: .82rem;
}
.footer-col h3 { font-size: 1.15rem; font-family: "DM Sans", system-ui, sans-serif; margin-bottom: 14px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.footer-col a:hover { color: #fff; }
.newsletter-form { display: flex; gap: 8px; margin: 12px 0 8px; }
.newsletter-form input,
.newsletter-form button { min-height: 46px; border-radius: 999px; border: 1px solid rgba(255,255,255,.14); }
.newsletter-form input { min-width: 0; flex: 1; padding: 0 14px; background: rgba(255,255,255,.08); color: #fff; }
.newsletter-form button { padding: 0 15px; background: var(--mt-gold); color: var(--mt-ink); font-weight: 950; }
.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  align-items: center;
  padding: 20px 0;
  border-top: 1px solid rgba(255,255,255,.1);
  font-size: .9rem;
}
.footer-bottom p { margin: 0; color: rgba(255,255,255,.72); }
.footer-menu { display: flex; flex-wrap: wrap; gap: 14px; }

/* Notices and old compatibility */
.notice-box,
.reassurance-card { padding: 22px; }
.intro-commerce,
.story-band,
.reassurance-section,
.cta-section { background: var(--mt-paper); }
.reassurance-grid,
.story-grid,
.intro-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }

/* Responsive */
@media (max-width: 1280px) {
  .header-search { display: none; }
}

@media (max-width: 1060px) {
  .primary-nav { display: none; }
  .menu-toggle { display: inline-block; }
  .hero-grid { grid-template-columns: 1fr; }
  .hero-showcase { min-height: auto; }
  .proof-one { left: 24px; }
  .proof-two { right: 24px; bottom: 30px; }
  .quality-grid { grid-template-columns: repeat(2, 1fr); }
  .category-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .shop-layout { grid-template-columns: 1fr; }
  .shop-filters-panel { position: static; }
}

@media (max-width: 860px) {
  body { font-size: 16px; }
  .topbar-inner { justify-content: center; text-align: center; }
  .topbar-inner span:first-child { display: none; }
  .header-inner { min-height: 72px; gap: 12px; }
  .brand { max-width: none; }
  .brand-text small { display: none; }
  .header-search { display: none; }
  .hide-sm { display: none !important; }
  .mobile-panel { inset: 106px 0 auto; }
  .ritual-strip-inner { grid-template-columns: 1fr; padding: 18px 0; align-items: start; }
  .ritual-chips { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 6px; scroll-snap-type: x proximity; }
  .ritual-chips a { white-space: nowrap; scroll-snap-align: start; }
  .hero { padding-top: 48px; }
  .hero-actions .mt-btn { width: 100%; }
  .hero-trust span { flex: 1 1 100%; justify-content: center; }
  .hero-product-card { width: min(100%, 390px); }
  .hero-product-media { min-height: 280px; }
  .hero-product-media img { max-height: 250px; }
  .floating-proof { display: none; }
  .quality-grid,
  .ritual-grid,
  .ritual-card-grid,
  .testimonial-grid,
  .commitments-grid,
  .commitment-list,
  .faq-home-grid,
  .cross-sell-card,
  .shop-hero-grid,
  .reassurance-grid,
  .story-grid,
  .intro-grid { grid-template-columns: 1fr; }
  .split-heading { display: grid; gap: 12px; }
  .score-card { text-align: left; }
  .woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; gap: 16px !important; }
  .woocommerce ul.products li.product { padding: 10px 10px 14px !important; border-radius: 22px; }
  .woocommerce ul.products li.product img { padding: 18px; border-radius: 18px; }
  .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 1.12rem !important; }
  .woocommerce ul.products li.product .price { font-size: 1.25rem !important; }
  .category-grid { grid-template-columns: 1fr; }
  .footer-prelude-inner,
  .footer-bottom { display: grid; }
  .footer-grid { grid-template-columns: 1fr; }
}

@media (max-width: 560px) {
  .container,
  .narrow,
  .content-wrap,
  .page-content,
  .entry-content { width: min(100% - 28px, var(--mt-container)); }
  .brand-mark { width: 42px; height: 42px; border-radius: 14px; }
  .brand-text strong { font-size: .95rem; }
  .cart-link { min-width: 48px; }
  h1 { font-size: clamp(2.2rem, 13vw, 3.05rem); }
  h2 { font-size: clamp(1.85rem, 10vw, 2.5rem); }
  .hero-product-content { padding-inline: 0; }
  .hero-price-row { display: grid; }
  .hero-price-row .mt-btn { width: 100%; }
  .quality-grid { grid-template-columns: 1fr; }
  .home-filter-row { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 8px; }
  .home-filter-row a { white-space: nowrap; }
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
  .fallback-products-grid { grid-template-columns: 1fr; }
  .cross-sell-card,
  .final-cta-card,
  .cta-card { border-radius: 24px; }
  .newsletter-form { display: grid; }
}

@media (max-width: 520px) {
  .container { width: min(var(--mt-container), calc(100% - 28px)); }
  .topbar { font-size: .72rem; }
  .topbar-inner { min-height: 30px; }
  .topbar-inner span:last-child { width: 100%; text-align: center; }
  .header-inner { min-height: 68px; }
  .brand-mark { width: 42px; height: 42px; border-radius: 14px; }
  .brand-text strong { font-size: .95rem; }
  .cart-link, .menu-toggle { width: 42px; height: 42px; }
  .mobile-panel { inset: 98px 0 auto; }
}


/* Conversion copy update */
.woocommerce ul.products li.product .button,
.fallback-product-card .mt-btn {
  width: 100%;
  margin-top: 12px !important;
}
.woocommerce ul.products li.product .price {
  font-size: 1.22rem !important;
  font-weight: 950 !important;
  color: var(--mt-sage-deep) !important;
}
.hero-product-content p,
.ritual-card p,
.category-card p,
.commitment-list p,
.faq-list p,
.testimonial-card p {
  font-size: 1rem;
}
@media (max-width: 720px) {
  .hero-showcase { min-height: auto; }
  .hero-product-card { width: 100%; }
  .hero-product-media { min-height: 260px; }
}

/* ==========================================================
   Espace client premium + template article automatisé
   ========================================================== */

.account-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    border: 1px solid rgba(31, 42, 36, .14);
    background: #fff;
    color: #20382a;
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 10px 25px rgba(31,42,36,.08);
}

.account-link:hover,
.account-link:focus-visible {
    background: #e8f0e6;
    color: #173321;
}

.woocommerce-account .woocommerce {
    width: min(1180px, calc(100% - 32px));
    margin: 44px auto 80px;
    display: grid;
    grid-template-columns: 270px minmax(0, 1fr);
    gap: 28px;
    align-items: start;
}

.woocommerce-account .woocommerce-MyAccount-navigation {
    position: sticky;
    top: 110px;
    background: #fff;
    border: 1px solid rgba(31,42,36,.10);
    border-radius: 28px;
    padding: 14px;
    box-shadow: 0 18px 50px rgba(31,42,36,.08);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 6px;
}

.woocommerce-account .woocommerce-MyAccount-navigation a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 42px;
    padding: 10px 14px;
    border-radius: 16px;
    color: #26382d;
    font-weight: 800;
    text-decoration: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation a:focus-visible {
    background: #e8f0e6;
    color: #1f4a32;
}

.woocommerce-account .woocommerce-MyAccount-content {
    min-width: 0;
}

.mt-account-dashboard,
.mt-account-section {
    display: grid;
    gap: 24px;
}

.mt-account-hero {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    padding: clamp(26px, 4vw, 42px);
    border-radius: 34px;
    background:
        radial-gradient(circle at 12% 8%, rgba(198,161,91,.18), transparent 34%),
        linear-gradient(135deg, #fff 0%, #f2eadc 100%);
    border: 1px solid rgba(31,42,36,.10);
    box-shadow: 0 22px 70px rgba(31,42,36,.10);
}

.mt-account-kicker {
    margin: 0 0 10px;
    color: #31513b;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.mt-account-hero h2,
.mt-account-section h2 {
    margin: 0;
    color: #16251c;
    font-family: "Playfair Display", Georgia, serif;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 1;
    letter-spacing: -.04em;
}

.mt-account-hero p,
.mt-account-section > p,
.mt-account-card p,
.mt-resource-card p {
    color: #425046;
    font-size: 1rem;
    line-height: 1.7;
}

.mt-account-hero p {
    max-width: 680px;
    margin: 14px 0 0;
}

.mt-account-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.mt-account-stat,
.mt-account-card,
.mt-resource-card,
.mt-sidebar-card {
    padding: 22px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid rgba(31,42,36,.10);
    box-shadow: 0 16px 45px rgba(31,42,36,.07);
}

.mt-account-stat span,
.mt-account-stat small {
    display: block;
    color: #6b776e;
    font-weight: 700;
}

.mt-account-stat strong {
    display: block;
    margin: 8px 0 6px;
    color: #20382a;
    font-size: 1.7rem;
    line-height: 1;
}

.mt-account-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.mt-account-action {
    display: block;
    padding: 20px;
    border-radius: 24px;
    background: #31513b;
    color: #fff;
    text-decoration: none;
    box-shadow: 0 16px 40px rgba(31,81,59,.18);
}

.mt-account-action:nth-child(even) {
    background: #fff;
    color: #20382a;
    border: 1px solid rgba(31,42,36,.10);
}

.mt-account-action strong,
.mt-account-action span {
    display: block;
}

.mt-account-action strong {
    font-size: 1.02rem;
}

.mt-account-action span {
    margin-top: 6px;
    opacity: .78;
    font-weight: 600;
}

.mt-account-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.mt-account-card-large {
    grid-column: 1 / -1;
}

.mt-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 18px;
}

.mt-card-head h3,
.mt-account-card h3,
.mt-resource-card h3 {
    margin: 0;
    color: #16251c;
    font-size: 1.35rem;
    line-height: 1.15;
}

.mt-card-head a,
.mt-card-link,
.mt-resource-card a {
    color: #31513b;
    font-weight: 900;
    text-decoration: none;
}

.mt-account-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.mt-account-table {
    width: 100%;
    min-width: 700px;
    border-collapse: collapse;
    overflow: hidden;
    border-radius: 18px;
}

.mt-account-table th,
.mt-account-table td {
    padding: 14px 12px;
    border-bottom: 1px solid rgba(31,42,36,.08);
    text-align: left;
    vertical-align: middle;
}

.mt-account-table th {
    color: #31513b;
    background: #e8f0e6;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.mt-status-pill,
.mt-table-btn {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 10px;
    border-radius: 999px;
    background: #eef5ec;
    color: #31513b;
    font-size: .85rem;
    font-weight: 900;
    text-decoration: none;
}

.mt-muted,
.mt-account-note,
.mt-empty-state {
    color: #69766d;
    font-size: .95rem;
    line-height: 1.65;
}

.mt-account-filters,
.mt-preferences-form,
.mt-support-form {
    display: grid;
    gap: 16px;
    padding: 22px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid rgba(31,42,36,.10);
    box-shadow: 0 16px 45px rgba(31,42,36,.07);
}

.mt-account-filters {
    grid-template-columns: minmax(180px, 1fr) minmax(160px, 1fr) auto;
    align-items: end;
}

.mt-account-filters label,
.mt-support-form label,
.mt-form-grid label {
    display: grid;
    gap: 8px;
    color: #26382d;
    font-weight: 900;
}

.mt-account-filters input,
.mt-account-filters select,
.mt-support-form input,
.mt-support-form select,
.mt-support-form textarea {
    width: 100%;
    border: 1px solid rgba(31,42,36,.18);
    border-radius: 16px;
    padding: 13px 14px;
    background: #fff;
    color: #1f2a24;
    font: inherit;
}

.mt-form-grid,
.mt-resource-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.mt-resource-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.mt-check-row {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 16px;
    border-radius: 18px;
    background: #fbf8f1;
    border: 1px solid rgba(31,42,36,.08);
    color: #26382d;
    font-weight: 700;
}

.mt-check-row input {
    margin-top: 5px;
}

.mt-ticket-list ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}

.mt-ticket-list li {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    border-radius: 16px;
    background: #fbf8f1;
}

.mt-ticket-list li strong,
.mt-ticket-list li span {
    display: block;
}

/* Template article automatisé */
.mt-single-post {
    background: #fbf8f1;
    color: #1f2a24;
}

.mt-container {
    width: min(1120px, calc(100% - 40px));
    margin-inline: auto;
}

.mt-article-hero {
    padding: 72px 0 48px;
    background: radial-gradient(circle at top left, rgba(143,175,141,.22), transparent 36%), linear-gradient(135deg, #fbf8f1 0%, #f3eadb 100%);
    border-bottom: 1px solid rgba(31,42,36,.08);
}

.mt-article-hero-inner {
    max-width: 860px;
}

.mt-article-kicker {
    display: inline-flex;
    align-items: center;
    margin-bottom: 18px;
    padding: 8px 14px;
    border-radius: 999px;
    background: #e8f0e6;
    color: #31513b;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.mt-article-title {
    margin: 0;
    color: #16251c;
    font-family: "Playfair Display", Georgia, serif;
    font-size: clamp(2.35rem, 5vw, 4.8rem);
    line-height: .98;
    letter-spacing: -.055em;
    font-weight: 800;
    max-width: 920px;
}

.mt-article-excerpt {
    margin-top: 24px;
    max-width: 760px;
    color: #33443a;
    font-size: clamp(1.08rem, 2vw, 1.35rem);
    line-height: 1.65;
    font-weight: 500;
}

.mt-article-excerpt p {
    margin: 0;
}

.mt-article-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    margin-top: 26px;
    color: #647267;
    font-size: .95rem;
    font-weight: 700;
}

.mt-meta-separator {
    color: #c6a15b;
}

.mt-article-cover {
    width: min(1120px, calc(100% - 40px));
    margin: -12px auto 0;
    border-radius: 32px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 24px 70px rgba(31,42,36,.14);
}

.mt-article-cover-img {
    display: block;
    width: 100%;
    height: clamp(260px, 48vw, 560px);
    object-fit: cover;
}

.mt-article-layout {
    display: grid;
    grid-template-columns: 280px minmax(0, 760px);
    gap: 56px;
    align-items: start;
    padding: 72px 0;
}

.mt-article-main {
    min-width: 0;
}

.mt-article-sidebar {
    position: sticky;
    top: 110px;
}

.mt-sidebar-label {
    display: block;
    margin-bottom: 12px;
    color: #31513b;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .12em;
    text-transform: uppercase;
}

.mt-sidebar-card p {
    margin: 0;
    color: #425046;
    line-height: 1.65;
}

.mt-article-content {
    font-size: 1.08rem;
    line-height: 1.85;
    color: #26342c;
}

.mt-article-content > *:first-child {
    margin-top: 0;
}

.mt-article-content p {
    margin: 0 0 1.5em;
}

.mt-article-content h2,
.mt-article-content h3,
.mt-article-content h4 {
    color: #16251c;
    line-height: 1.18;
    letter-spacing: -.025em;
}

.mt-article-content h2 {
    margin: 2.2em 0 .75em;
    font-size: clamp(1.7rem, 3vw, 2.45rem);
}

.mt-article-content h3 {
    margin: 1.9em 0 .7em;
    font-size: clamp(1.35rem, 2.4vw, 1.85rem);
}

.mt-article-content a {
    color: #31513b;
    font-weight: 900;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 4px;
}

.mt-article-content ul,
.mt-article-content ol {
    margin: 0 0 1.6em 1.4em;
    padding: 0;
}

.mt-article-content li {
    margin-bottom: .65em;
}

.mt-article-content blockquote {
    margin: 2.2em 0;
    padding: 28px 32px;
    border-left: 5px solid #c6a15b;
    border-radius: 0 24px 24px 0;
    background: #fff;
    color: #25342b;
    font-size: 1.22rem;
    line-height: 1.65;
    font-weight: 700;
    box-shadow: 0 14px 36px rgba(31,42,36,.08);
}

.mt-article-content img {
    max-width: 100%;
    height: auto;
    border-radius: 24px;
}

.mt-article-tags {
    margin-top: 48px;
    padding-top: 28px;
    border-top: 1px solid rgba(31,42,36,.1);
}

.mt-tags-title {
    display: block;
    margin-bottom: 14px;
    color: #31513b;
    font-weight: 900;
}

.mt-tags-list,
.mt-post-navigation {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.mt-tags-list a {
    display: inline-flex;
    padding: 8px 13px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid rgba(31,42,36,.1);
    color: #31513b;
    font-weight: 800;
    text-decoration: none;
}

.mt-post-navigation {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-top: 48px;
}

.mt-post-nav-item a {
    display: block;
    height: 100%;
    padding: 22px;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(31,42,36,.1);
    color: #1f2a24;
    text-decoration: none;
    box-shadow: 0 14px 36px rgba(31,42,36,.07);
}

.mt-post-nav-item span {
    display: block;
    margin-bottom: 8px;
    color: #647267;
    font-size: .82rem;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.mt-post-nav-item strong {
    display: block;
    color: #16251c;
    font-size: 1.05rem;
    line-height: 1.35;
}

.mt-post-nav-next {
    text-align: right;
}

.mt-page-links {
    margin-top: 32px;
    padding: 18px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid rgba(31,42,36,.1);
    font-weight: 900;
}

@media (max-width: 1100px) {
    .woocommerce-account .woocommerce {
        grid-template-columns: 1fr;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        position: static;
        overflow-x: auto;
        padding: 10px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        display: flex;
        min-width: max-content;
    }
}

@media (max-width: 900px) {
    .mt-account-hero,
    .mt-card-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .mt-account-stats,
    .mt-account-actions,
    .mt-account-grid,
    .mt-resource-grid,
    .mt-form-grid,
    .mt-account-filters,
    .mt-article-layout {
        grid-template-columns: 1fr;
    }

    .mt-article-sidebar {
        position: static;
        order: -1;
    }
}

@media (max-width: 680px) {
    .woocommerce-account .woocommerce {
        width: min(100% - 24px, 1180px);
        margin-top: 28px;
    }

    .mt-account-hero,
    .mt-account-stat,
    .mt-account-card,
    .mt-resource-card,
    .mt-account-filters,
    .mt-preferences-form,
    .mt-support-form {
        border-radius: 22px;
        padding: 18px;
    }

    .mt-account-action {
        border-radius: 20px;
        padding: 17px;
    }

    .mt-container,
    .mt-article-cover {
        width: min(100% - 28px, 1120px);
    }

    .mt-article-hero {
        padding: 48px 0 34px;
    }

    .mt-article-title {
        font-size: clamp(2.05rem, 12vw, 3rem);
        line-height: 1.02;
    }

    .mt-article-cover {
        border-radius: 24px;
    }

    .mt-article-cover-img {
        height: 260px;
    }

    .mt-article-layout {
        padding: 42px 0;
    }

    .mt-article-content {
        font-size: 1rem;
        line-height: 1.78;
    }

    .mt-post-navigation {
        grid-template-columns: 1fr;
    }

    .mt-post-nav-next {
        text-align: left;
    }
}


/* ==========================================================
   Maison Théoria 1.4 — expérience sensorielle e-commerce thé
   ========================================================== */
.mt-sensory-filter .mt-filter-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
}
.mt-filter-head span,
.quiz-trust span,
.mt-product-sensory span,
.mt-format-options > span {
    color: var(--mt-sage-dark);
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .11em;
    text-transform: uppercase;
}
.mt-filter-head h2 { margin: 4px 0 0; font-size: 1.25rem; }
.mt-filter-head a { color: var(--mt-muted); font-weight: 800; font-size: .9rem; }
.mt-filter-form {
    display: grid;
    gap: 12px;
    margin: 18px 0;
}
.mt-filter-form label {
    display: grid;
    gap: 7px;
    color: var(--mt-ink);
    font-weight: 800;
    font-size: .92rem;
}
.mt-filter-form select {
    width: 100%;
    min-height: 44px;
    border-radius: 14px;
    border: 1px solid rgba(32, 61, 43, .16);
    background: #fff;
    padding: 0 12px;
    color: var(--mt-ink);
    font: inherit;
}
.quiz-section {
    background: linear-gradient(135deg, #f7f1e7 0%, #eef5eb 100%);
    border-block: 1px solid rgba(32, 61, 43, .08);
}
.quiz-grid {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 38px;
    align-items: start;
}
.quiz-intro h2 { margin: 12px 0 16px; }
.quiz-trust { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.quiz-trust span {
    display: inline-flex;
    padding: 8px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,.78);
    border: 1px solid rgba(32, 61, 43, .08);
}
.mt-quiz {
    display: grid;
    gap: 16px;
    padding: 22px;
    border-radius: 30px;
    background: #fff;
    box-shadow: 0 24px 70px rgba(32, 61, 43, .10);
    border: 1px solid rgba(32, 61, 43, .08);
}
.mt-quiz fieldset { border: 0; padding: 0; margin: 0; display: grid; gap: 10px; }
.mt-quiz legend { margin-bottom: 8px; color: var(--mt-ink); font-weight: 900; }
.mt-quiz label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 16px;
    background: var(--mt-paper-2);
    border: 1px solid rgba(32, 61, 43, .08);
    cursor: pointer;
    font-weight: 700;
}
.mt-quiz input { accent-color: var(--mt-sage-dark); }
.quiz-result {
    padding: 18px;
    border-radius: 22px;
    background: #f8fbf6;
    border: 1px solid rgba(32, 61, 43, .10);
}
.quiz-result strong { display: block; color: var(--mt-ink); font-size: 1.1rem; }
.quiz-result p { margin: 6px 0 0; color: var(--mt-muted); }
.quiz-result a { display: inline-flex; margin-top: 12px; color: var(--mt-sage-dark); font-weight: 900; }
.mt-product-sensory,
.mt-product-buying-options {
    margin-top: 18px;
    padding: 18px;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(32, 61, 43, .10);
    box-shadow: 0 16px 40px rgba(32, 61, 43, .07);
}
.mt-sensory-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.mt-sensory-card {
    padding: 14px;
    border-radius: 18px;
    background: var(--mt-paper-2);
}
.mt-sensory-card strong { display: block; margin-top: 5px; color: var(--mt-ink); }
.mt-sensory-card small { display: block; margin-top: 4px; color: var(--mt-muted); line-height: 1.45; }
.mt-tasting-summary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 12px;
}
.mt-tasting-summary div {
    padding: 14px;
    border-radius: 18px;
    background: #f8fbf6;
}
.mt-tasting-summary strong { display: block; margin-top: 5px; color: var(--mt-sage-dark); }
.mt-product-buying-options { display: grid; gap: 14px; }
.mt-format-options div { display: flex; flex-wrap: wrap; gap: 9px; margin: 10px 0 8px; }
.mt-format-options button {
    border: 1px solid rgba(32,61,43,.16);
    border-radius: 999px;
    background: #fff;
    padding: 10px 13px;
    color: var(--mt-ink);
    font-weight: 900;
    cursor: default;
}
.mt-format-options button.is-active { background: var(--mt-sage-dark); color: #fff; }
.mt-format-options small,
.mt-subscription-callout small { display: block; color: var(--mt-muted); line-height: 1.5; }
.mt-subscription-callout {
    padding: 16px;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(198,161,91,.14), rgba(143,175,141,.14));
}
.mt-subscription-callout strong { color: var(--mt-ink); font-size: 1.05rem; }
.mt-subscription-callout p { margin: 6px 0 6px; color: var(--mt-muted); }
.mt-product-profile-section { padding: 30px 0; }
.mt-product-profile-card {
    width: min(1180px, calc(100% - 40px));
    margin-inline: auto;
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 28px;
    padding: 28px;
    border-radius: 32px;
    background: #fff;
    border: 1px solid rgba(32, 61, 43, .10);
    box-shadow: 0 24px 70px rgba(32, 61, 43, .09);
}
.mt-product-profile-card h2 { margin: 10px 0 12px; }
.mt-profile-bars { display: grid; gap: 16px; }
.mt-profile-bar div { display: flex; justify-content: space-between; gap: 16px; margin-bottom: 8px; font-weight: 900; }
.mt-profile-bar i,
.mt-loyalty-progress {
    display: block;
    height: 12px;
    border-radius: 999px;
    background: #e5eadf;
    overflow: hidden;
}
.mt-profile-bar i::before,
.mt-loyalty-progress i {
    content: "";
    display: block;
    width: var(--value);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--mt-sage-dark), var(--mt-gold));
}
.mt-product-accessories { padding: 30px 0 70px; }
.mt-accessory-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}
.mt-accessory-card {
    display: grid;
    gap: 10px;
    padding: 18px;
    border-radius: 26px;
    background: #fff;
    border: 1px solid rgba(32, 61, 43, .10);
    text-decoration: none;
    color: var(--mt-ink);
    box-shadow: 0 16px 42px rgba(32, 61, 43, .08);
}
.mt-accessory-card img { width: 100%; aspect-ratio: 1 / 1; object-fit: contain; border-radius: 18px; background: var(--mt-paper-2); }
.mt-accessory-card span { color: var(--mt-sage-dark); font-weight: 900; font-size: 1.1rem; }
.mt-traceability-tab ul { display: grid; gap: 12px; padding-left: 18px; }
.mt-loyalty-card {
    display: grid;
    gap: 16px;
    padding: 24px;
    border-radius: 26px;
    background: #fff;
    box-shadow: 0 18px 50px rgba(32,61,43,.08);
}
.mt-loyalty-card span { color: var(--mt-muted); font-weight: 800; }
.mt-loyalty-card strong { display: block; font-size: clamp(2rem, 5vw, 4rem); color: var(--mt-sage-dark); line-height: 1; }
.mt-loyalty-progress { --value: 0%; height: 16px; }
@media (max-width: 900px) {
    .quiz-grid,
    .mt-product-profile-card,
    .mt-accessory-grid { grid-template-columns: 1fr; }
}
@media (max-width: 680px) {
    .mt-sensory-grid,
    .mt-tasting-summary { grid-template-columns: 1fr; }
    .mt-quiz { padding: 16px; border-radius: 24px; }
    .mt-product-profile-card { width: min(100% - 28px, 1180px); padding: 20px; border-radius: 24px; }
}


/* ==========================================================
   Version 1.6 — Homepage plus fluide, hero réduit, quiz UX/UI, blog
   ========================================================== */
:root { --mt-container: 1220px; }
.section { padding: clamp(48px, 6vw, 78px) 0; }
.hero-fluid {
  min-height: calc(100vh - 112px);
  max-height: 780px;
  display: flex;
  align-items: center;
  padding: clamp(38px, 5.2vw, 72px) 0;
  background:
    radial-gradient(circle at 8% 10%, rgba(143,175,141,.28), transparent 30%),
    radial-gradient(circle at 88% 16%, rgba(197,155,76,.17), transparent 28%),
    linear-gradient(135deg, #fbf8f1 0%, #f3eadb 100%);
}
.hero-fluid:after { display: none; }
.hero-fluid-grid {
  display: grid;
  grid-template-columns: minmax(0, .94fr) minmax(320px, .7fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: center;
}
.hero-fluid .hero-content { max-width: 670px; }
.hero-fluid h1 {
  font-size: clamp(2.6rem, 5.15vw, 5.05rem);
  line-height: .96;
  letter-spacing: -.065em;
  margin-bottom: 18px;
}
.hero-fluid .hero-lead {
  max-width: 620px;
  font-size: clamp(1.02rem, 1.3vw, 1.16rem);
  line-height: 1.68;
}
.hero-fluid .hero-actions { margin: 24px 0 18px; }
.compact-trust span { min-height: 34px; font-size: .84rem; }
.hero-product-scene {
  min-height: 0;
  position: relative;
  display: grid;
  justify-items: center;
  align-content: center;
  padding: clamp(16px, 3vw, 34px);
}
.hero-product-scene:before {
  content: "";
  position: absolute;
  inset: 10% 6% 3%;
  border-radius: 46% 54% 50% 50%;
  background: rgba(255,255,255,.42);
  filter: blur(.2px);
  border: 1px solid rgba(24,37,29,.08);
}
.hero-product-scene img {
  position: relative;
  z-index: 1;
  width: min(80%, 380px);
  max-height: 440px;
  object-fit: contain;
  filter: drop-shadow(0 34px 46px rgba(24,37,29,.18));
}
.hero-scene-badge {
  position: absolute;
  top: 9%;
  left: 10%;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--mt-sage-dark);
  color: #fff;
  font-weight: 950;
  font-size: .82rem;
  box-shadow: var(--mt-shadow-soft);
}
.hero-product-mini {
  position: relative;
  z-index: 3;
  width: min(100%, 380px);
  display: grid;
  gap: 4px;
  margin-top: -20px;
  padding: 15px 18px;
  border-radius: 24px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(24,37,29,.1);
  box-shadow: var(--mt-shadow-soft);
}
.hero-product-mini strong { font-size: 1.2rem; }
.hero-product-mini > span:last-child { color: var(--mt-muted); font-weight: 850; }
.quality-strip {
  background: var(--mt-sage-deep);
  color: #fff;
  padding: 10px 0;
}
.quality-strip-inner {
  display: flex;
  justify-content: center;
  gap: 12px 28px;
  flex-wrap: wrap;
  font-size: .88rem;
  font-weight: 900;
}
.quality-strip-inner span:before { content: "✓"; margin-right: 8px; color: var(--mt-gold-soft); }
.section-soft { background: var(--mt-paper); }
.section-white { background: var(--mt-white); }
.woocommerce ul.products { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; gap: 22px !important; }
.woocommerce ul.products li.product { border-radius: 24px; box-shadow: 0 12px 32px rgba(24,37,29,.07); }
.woocommerce ul.products li.product img { aspect-ratio: 1 / .82; padding: 20px; background: linear-gradient(145deg, #f4eddf, #e5efdf); }
.quiz-redesign {
  background:
    radial-gradient(circle at left center, rgba(143,175,141,.2), transparent 28%),
    var(--mt-paper-2);
}
.quiz-redesign-grid {
  display: grid;
  grid-template-columns: minmax(260px, .42fr) minmax(0, .9fr);
  gap: clamp(26px, 5vw, 60px);
  align-items: start;
}
.quiz-redesign .quiz-intro { position: sticky; top: 120px; }
.mt-quiz-clean {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
  display: grid;
  gap: 18px;
}
.mt-quiz-clean fieldset { border: 0; padding: 0; margin: 0; }
.mt-quiz-clean legend { display: none; }
.quiz-step {
  padding: 0 0 18px;
  border-bottom: 1px solid rgba(24,37,29,.11);
}
.quiz-step > strong {
  display: block;
  margin-bottom: 12px;
  color: var(--mt-ink);
  font-size: 1.06rem;
}
.quiz-choice-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.quiz-choice-grid label {
  position: relative;
  min-height: 112px;
  display: grid;
  align-content: center;
  gap: 6px;
  padding: 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(24,37,29,.11);
  cursor: pointer;
  transition: border-color .2s ease, transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.quiz-choice-grid label:hover { transform: translateY(-2px); box-shadow: var(--mt-shadow-soft); }
.quiz-choice-grid input { position: absolute; opacity: 0; pointer-events: none; }
.quiz-choice-grid span { color: var(--mt-ink); font-weight: 950; }
.quiz-choice-grid small { color: var(--mt-muted); font-weight: 750; line-height: 1.35; }
.quiz-choice-grid label:has(input:checked) {
  border-color: rgba(40,79,54,.48);
  background: #fff;
  box-shadow: 0 14px 36px rgba(40,79,54,.12);
}
.quiz-choice-grid label:has(input:checked)::after {
  content: "✓";
  position: absolute;
  right: 14px;
  top: 12px;
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: var(--mt-sage-dark);
  color: #fff;
  font-size: .8rem;
  font-weight: 950;
}
.quiz-action-row {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
}
.quiz-result {
  padding: 18px 20px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(24,37,29,.11);
  box-shadow: none;
}
.quiz-result strong { display: block; font-size: 1.08rem; margin-bottom: 6px; }
.quiz-result p { margin-bottom: 8px; }
.quiz-result a { color: var(--mt-sage-dark); font-weight: 950; }
.ritual-card-grid-four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.ritual-card-grid-four .ritual-card { min-height: 190px; }
.blog-home-section { background: var(--mt-paper); }
.blog-card-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 20px; }
.blog-card {
  display: grid;
  align-content: start;
  padding: 24px;
  border-radius: 26px;
  background: #fff;
  border: 1px solid var(--mt-border);
  box-shadow: var(--mt-shadow-soft);
  min-height: 250px;
}
.blog-card > span { color: var(--mt-gold); font-weight: 950; font-size: .85rem; margin-bottom: 12px; }
.blog-card h3 { font-size: clamp(1.25rem, 2.1vw, 1.62rem); }
.blog-card p { margin-bottom: 18px; }
.final-band { background: var(--mt-sage-deep); color: #fff; padding: clamp(36px, 5vw, 58px) 0; }
.final-band h2, .final-band strong { color: #fff; }
.final-band .eyebrow { color: var(--mt-gold-soft); }
.final-band-inner { display: flex; justify-content: space-between; align-items: center; gap: 28px; }
.final-band .mt-btn-primary { background: #fff !important; color: var(--mt-sage-deep) !important; box-shadow: none !important; }

@media (max-width: 1120px) {
  .hero-fluid { min-height: auto; max-height: none; }
  .hero-fluid-grid, .quiz-redesign-grid { grid-template-columns: 1fr; }
  .quiz-redesign .quiz-intro { position: static; }
  .ritual-card-grid-four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .hero-fluid { padding: 40px 0 46px; }
  .hero-fluid h1 { font-size: clamp(2.25rem, 11vw, 3.45rem); }
  .hero-product-scene { padding-top: 6px; }
  .hero-product-scene img { width: min(72%, 310px); max-height: 340px; }
  .quiz-choice-grid, .blog-card-grid, .testimonial-grid, .commitment-list { grid-template-columns: 1fr; }
  .quiz-action-row { grid-template-columns: 1fr; }
  .ritual-card-grid-four { grid-template-columns: 1fr; }
  .final-band-inner { display: grid; }
  .woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 560px) {
  .quality-strip-inner { justify-content: flex-start; gap: 6px 16px; }
  .quality-strip-inner span { flex: 1 1 100%; }
  .hero-fluid .hero-actions .mt-btn { width: 100%; }
  .hero-product-mini { width: 100%; margin-top: -12px; }
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
}


/* ==========================================================
   Version 1.6.1 — pleine largeur, héros plus compacts, espace client refondu
   ========================================================== */
:root { --mt-container: 100%; }
.container,
.mt-container,
.content-wrap,
.page-content,
.entry-content,
.narrow {
  width: calc(100% - clamp(28px, 4vw, 72px));
  max-width: none;
  margin-inline: auto;
}

body { overflow-x: hidden; }
.section { padding: clamp(42px, 5vw, 72px) 0; }
h1 { font-size: clamp(2.2rem, 4.6vw, 4.5rem); }
h2 { font-size: clamp(1.85rem, 3.1vw, 3rem); }

.page .site-main > .page-hero,
.archive .site-main > .page-hero { padding: 42px 0 18px; }
.page-hero h1,
.shop-hero h1,
.woocommerce-account .page-hero h1 {
  font-size: clamp(2.1rem, 4.4vw, 4rem);
  line-height: 1;
  max-width: 14ch;
}
.page-content-wide,
.page-content-section .container { width: calc(100% - clamp(28px, 4vw, 72px)); max-width: none; }
.page-content-section .entry-content,
.page-content-section p,
.page-content-section ul,
.page-content-section ol { max-width: 100%; }

/* Header : éviter le chevauchement */
.menu-primary a { padding: 7px 8px; font-size: .84rem; }
@media (max-width: 1380px) {
  .primary-nav { display: none; }
  .menu-toggle { display: inline-block; }
  .header-search { display: none; }
}

/* Hero accueil plus compact et plus respirant */
.hero-fluid {
  min-height: auto;
  max-height: none;
  padding: clamp(32px, 4.5vw, 60px) 0;
}
.hero-fluid-grid {
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .72fr);
  gap: clamp(24px, 4vw, 54px);
  align-items: center;
}
.hero-fluid .hero-content { max-width: 760px; }
.hero-fluid h1 {
  font-size: clamp(2.45rem, 4.4vw, 4.7rem);
  line-height: .98;
  max-width: 11ch;
}
.hero-fluid .hero-lead { max-width: 780px; }
.hero-product-scene { padding: 10px 0 0; }
.hero-product-scene:before {
  inset: 6% 0 0 8%;
  border-radius: 40px;
  background: rgba(255,255,255,.34);
}
.hero-product-scene img { width: min(76%, 360px); max-height: 360px; }
.hero-product-mini {
  width: min(100%, 420px);
  margin-top: -8px;
  padding: 14px 16px;
  border-radius: 20px;
}

/* Sections boutique plus ouvertes */
.shop-layout { grid-template-columns: 1fr; }
.shop-filters-panel {
  position: static;
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 20px;
  border-radius: 20px;
  box-shadow: none;
}
.shop-filter-widget { margin-top: 0; padding-top: 0; border-top: 0; }
@media (max-width: 900px) {
  .shop-filters-panel { grid-template-columns: 1fr; }
}

/* Quiz : présentation plus UX et moins encadrée */
.quiz-redesign {
  background: linear-gradient(180deg, #f2eadc 0%, #fbf8f1 100%);
}
.quiz-redesign-grid {
  grid-template-columns: minmax(320px, .6fr) minmax(0, 1.1fr);
  gap: clamp(24px, 4vw, 50px);
  align-items: start;
}
.quiz-redesign .quiz-intro { position: static; max-width: 560px; }
.mt-quiz-clean {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}
.quiz-step {
  padding: 0 0 16px;
  margin-bottom: 4px;
}
.quiz-step > strong { font-size: 1rem; margin-bottom: 10px; }
.quiz-choice-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.quiz-choice-grid label {
  min-height: 88px;
  border-radius: 18px;
  padding: 14px 16px;
  background: rgba(255,255,255,.92);
}
.quiz-choice-grid small { font-size: .88rem; }
.quiz-action-row { grid-template-columns: 220px minmax(0, 1fr); }
.quiz-result {
  border-radius: 18px;
  background: rgba(255,255,255,.92);
}
@media (max-width: 980px) {
  .quiz-redesign-grid,
  .hero-fluid-grid { grid-template-columns: 1fr; }
  .quiz-choice-grid { grid-template-columns: 1fr; }
  .quiz-action-row { grid-template-columns: 1fr; }
}

/* Account page : navigation horizontale et pleine largeur */
.woocommerce-account .woocommerce {
  width: calc(100% - clamp(28px, 4vw, 72px));
  max-width: none;
  margin: 28px auto 64px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 26px;
}
.woocommerce-account .woocommerce-MyAccount-navigation {
  position: static;
  top: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.woocommerce-account .woocommerce-MyAccount-navigation a {
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(31,42,36,.10);
  box-shadow: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation a:focus-visible {
  background: #31513b;
  border-color: #31513b;
  color: #fff;
}
.woocommerce-account .woocommerce-MyAccount-content { min-width: 0; }
.mt-account-dashboard, .mt-account-section { gap: 20px; }
.mt-account-hero {
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 22px;
  align-items: end;
}
.mt-account-hero h2, .mt-account-section h2 { font-size: clamp(2rem, 4vw, 3.6rem); }
.mt-account-hero p { max-width: 780px; }
.mt-account-stats { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mt-account-actions { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mt-account-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.mt-account-stat,
.mt-account-card,
.mt-resource-card,
.mt-sidebar-card,
.mt-account-filters,
.mt-preferences-form,
.mt-support-form {
  border-radius: 20px;
  box-shadow: none;
}
.mt-account-card-large { grid-column: 1 / -1; }
@media (max-width: 1100px) {
  .mt-account-hero { grid-template-columns: 1fr; align-items: start; }
  .mt-account-stats, .mt-account-actions, .mt-account-grid, .mt-resource-grid, .mt-form-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 760px) {
  .woocommerce-account .woocommerce-MyAccount-navigation ul { flex-wrap: nowrap; overflow-x: auto; padding-bottom: 6px; }
  .mt-account-stats, .mt-account-actions, .mt-account-grid, .mt-resource-grid, .mt-form-grid {
    grid-template-columns: 1fr;
  }
}

/* Blog et cartes : sensation moins enfermée */
.blog-card,
.woocommerce ul.products li.product,
.testimonial-card,
.ritual-card {
  border-radius: 20px;
}

/* ==========================================================
   Version 1.7 — Mes Points : programme fidélité réel
   ========================================================== */
.mt-loyalty-page { gap: 22px; }
.mt-loyalty-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(190px, 260px);
  gap: clamp(18px, 3vw, 34px);
  align-items: stretch;
  padding: clamp(22px, 4vw, 38px);
  border-radius: 24px;
  background: linear-gradient(135deg, #fff 0%, #f2eadc 100%);
  border: 1px solid rgba(31,42,36,.10);
}
.mt-loyalty-balance {
  display: grid;
  place-items: center;
  text-align: center;
  padding: 22px;
  border-radius: 22px;
  background: #31513b;
  color: #fff;
}
.mt-loyalty-balance span,
.mt-loyalty-balance small { color: rgba(255,255,255,.78); font-weight: 850; }
.mt-loyalty-balance strong { color: #fff; font-size: clamp(3rem, 6vw, 5rem); line-height: .9; }
.mt-loyalty-progress-card,
.mt-loyalty-convert-form,
.mt-loyalty-coupon-box {
  padding: 22px;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(31,42,36,.10);
}
.mt-loyalty-progress { height: 18px; border-radius: 999px; overflow: hidden; background: #e8f0e6; }
.mt-loyalty-progress span { display: block; height: 100%; border-radius: 999px; background: #31513b; }
.mt-loyalty-convert-form { display: flex; align-items: center; justify-content: space-between; gap: 18px; }
.mt-loyalty-convert-form p { margin: 0; max-width: 620px; }
.mt-loyalty-convert-form .mt-btn[disabled] { opacity: .58; cursor: not-allowed; }
.mt-loyalty-coupon-box { margin-bottom: 18px; border-color: rgba(40,79,54,.25); }
.mt-loyalty-coupon-box span { display: block; color: #31513b; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: .78rem; }
.mt-loyalty-coupon-box strong { display: block; margin: 8px 0; font-size: clamp(1.45rem, 3vw, 2.2rem); color: #16251c; }
.mt-loyalty-history small { color: #69766d; font-weight: 800; }
@media (max-width: 760px) {
  .mt-loyalty-hero { grid-template-columns: 1fr; }
  .mt-loyalty-convert-form { display: grid; }
  .mt-loyalty-convert-form .mt-btn { width: 100%; }
}
