/* ============================================================
   Leven University — supplemental front-end styles
   (design tokens live in theme.json; this handles atmosphere,
   layout and decorative treatment the block system can't express)
   ============================================================ */

:root {
  --leven-gold: var(--wp--preset--color--primary, #caa244);
  --leven-gold-lt: #e7cd86;
  --leven-cream: var(--wp--preset--color--contrast, #f4efe3);
  --leven-night: var(--wp--preset--color--base, #0a0a0b);
}

body {
  -webkit-font-smoothing: antialiased;
  letter-spacing: 0.01em;
  background-color: #0a0a0b;
}

/* keep display headings from hyphen-breaking single words */
h1, h2, h3, h4, .wp-block-heading {
  word-break: keep-all;
  overflow-wrap: normal;
  hyphens: none;
}

/* per request: remove the default 1.5rem block gap between constrained children.
   No !important + higher specificity so explicit inline margins (e.g. the
   "View All Courses" button's margin-top) are still respected. */
:root .is-layout-constrained > * { margin-block-start: 0; }
/* keep readable spacing for prose inside the white inner-page content */
.leven-page-body .wp-block-post-content > * { margin-block-start: 1.2rem; }
.leven-page-body .wp-block-post-content > :first-child { margin-block-start: 0; }
.leven-page-body .wp-block-post-content > h2 { margin-block-start: 2.2rem; }
.leven-page-body .wp-block-post-content > h3 { margin-block-start: 1.7rem; }

/* ---- Utility / shared ---- */
.leven-eyebrow {
  font-family: var(--wp--preset--font-family--body);
  text-transform: uppercase;
  letter-spacing: 0.34em;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--leven-gold);
}
.leven-eyebrow a { text-decoration: none; }

/* ---- Header / nav : transparent, laid over the hero ---- */
header.wp-block-template-part {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: transparent;
  border-bottom: 1px solid transparent;
  transition: background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
}
header.wp-block-template-part.leven-scrolled {
  background: rgba(11, 10, 18, 0.92);
  backdrop-filter: blur(10px);
  border-bottom-color: rgba(202, 162, 68, 0.16);
}
.leven-header { width: 100%; }
.wp-block-site-logo img { width: 96px; height: auto; }
/* non-home pages: push first content below the fixed header */
body:not(.home) main { padding-top: 5.5rem; }
/* pages with a banner let it bleed under the fixed menu (banner clears it internally) */
body:not(.home) main:has(.leven-page-banner) { padding-top: 0; }

/* ============================================================
   INSIDE PAGES — short hero banner + white content
   ============================================================ */
.leven-page-banner {
  position: relative;
  overflow: hidden;
  text-align: center;
  background: #000 url("../images/page-banner.png") right 14%/auto 185% no-repeat;
  padding-top: clamp(7rem, 12vh, 9.5rem);
  padding-bottom: clamp(2.5rem, 5vh, 4rem);
}
/* darken so the centered title stays legible over her image */
.leven-page-banner:before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(0,0,0,0.82) 0%, rgba(0,0,0,0.55) 45%, rgba(0,0,0,0.35) 70%, rgba(0,0,0,0.55) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.35) 55%, rgba(0,0,0,0.72) 100%);
  z-index: 0;
}
.leven-page-banner > * { position: relative; z-index: 1; }
.leven-page-banner .wp-block-post-title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  color: var(--leven-cream);
  margin: 0.3rem 0 0;
  text-shadow: 0 2px 24px rgba(0,0,0,0.6);
}

.leven-page-body {
  --wp--style--global--content-size: 920px;
  background: #fbf8f0;
  color: #322c24;
}
.leven-page-body :where(h1,h2,h3,h4,h5,h6) { color: #1c1712; }
.leven-page-body p,
.leven-page-body li { color: #3c352c; }
.leven-page-body a:where(:not(.wp-element-button)) { color: #a9842f; }
.leven-page-body a:where(:not(.wp-element-button)):hover { color: #8a6a23; }
.leven-page-body strong { color: #1c1712; }
.leven-page-body .leven-eyebrow { color: #a9842f; }
.leven-page-body hr { border-color: rgba(0,0,0,0.12); }
.leven-page-body .is-style-outline .wp-block-button__link {
  border-color: #a9842f !important;
  color: #a9842f !important;
}
.wp-block-navigation {
  font-family: var(--wp--preset--font-family--body);
  text-transform: uppercase;
  letter-spacing: 0.13em;
  font-size: 0.78rem;
  font-weight: 500;
}
.wp-block-navigation a { text-decoration: none; }
.wp-block-navigation a:hover { color: var(--leven-gold) !important; }

/* ============================================================
   HERO — full-bleed celestial field
   ============================================================ */
.leven-hero {
  position: relative;
  background-color: #000;
  overflow: hidden;
  min-height: min(100vh, 880px);
  display: flex;
  align-items: center;
  padding-top: clamp(120px, 15vh, 180px);
  padding-bottom: clamp(60px, 9vh, 110px);
}
/* her image / artwork on its own layer so it can fade in.
   max-width:none + margin:0 override WordPress's constrained-layout rule
   (.is-layout-constrained > :where(...) {max-width:760px}) so the layers go full-bleed. */
.leven-hero-bg,
.leven-hero-sparkles {
  max-width: none !important;
  margin: 0 !important;
}
.leven-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center right;
  background-repeat: no-repeat;
  z-index: 0;
  animation: levenHeroReveal 1.9s ease both;
}
/* left-side scrim — covers the artwork's baked-in left text so the live copy reads cleanly */
.leven-hero:before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,0.9) 0%, rgba(0,0,0,0.7) 34%, rgba(0,0,0,0.25) 52%, rgba(0,0,0,0) 70%);
  z-index: 1;
}
.leven-hero-sparkles {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}
.leven-hero-row { position: relative; z-index: 3; width: 100%; }

/* ---- hero animations ---- */
@keyframes levenHeroReveal {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes levenFadeUp {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: translateY(0); }
}
.leven-hero-copy > *,
.leven-hero-credit {
  opacity: 0;
  animation: levenFadeUp .85s cubic-bezier(.2,.7,.2,1) both;
}
.leven-hero-copy > *:nth-child(1) { animation-delay: .35s; }
.leven-hero-copy > *:nth-child(2) { animation-delay: .48s; }
.leven-hero-copy > *:nth-child(3) { animation-delay: .61s; }
.leven-hero-copy > *:nth-child(4) { animation-delay: .74s; }
.leven-hero-copy > *:nth-child(5) { animation-delay: .87s; }
.leven-hero-copy > *:nth-child(6) { animation-delay: 1.0s; }
.leven-hero-credit { animation-delay: 1.15s; }

@media (prefers-reduced-motion: reduce) {
  .leven-hero-bg,
  .leven-hero-copy > *,
  .leven-hero-credit {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
  .leven-hero-sparkles { display: none; }
}
.leven-hero-copy { text-shadow: 0 1px 18px rgba(0,0,0,0.6); padding-right: 2.5rem; }

/* headline — tight vertical rhythm */
.leven-hero-copy .leven-eyebrow { margin: 0 0 0.55rem; }
.leven-hero-title {
  font-size: clamp(3.8rem, 8vw, 6.8rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 0.84 !important;
  margin: 0;
  text-shadow: 0 2px 34px rgba(0,0,0,0.7);
}
.leven-hero-title .leven-accent {
  color: var(--leven-gold);
  display: block;
  font-weight: 700;
  line-height: 0.84 !important;
}
.leven-hero-sub {
  font-family: var(--wp--preset--font-family--display);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(1.7rem, 3.4vw, 2.7rem);
  line-height: 1 !important;
  color: var(--leven-cream);
  margin: 0.15rem 0 0;
}
.leven-hero-lede { max-width: 30rem; margin: 0; }

/* celestial divider below the subtitle */
.leven-hero-divider {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  width: min(100%, 23rem);
  margin: 1.15rem 0 1.5rem;
}
.leven-hero-divider::before,
.leven-hero-divider::after {
  content: "";
  height: 1px;
  flex: 1;
}
.leven-hero-divider::before { background: linear-gradient(90deg, transparent, rgba(202,162,68,0.9)); }
.leven-hero-divider::after  { background: linear-gradient(90deg, rgba(202,162,68,0.9), transparent); }
.leven-hero-divider-orn {
  flex: none;
  width: 24px;
  height: 24px;
  background: url("../images/divider-ornament.svg") center/contain no-repeat;
  filter: drop-shadow(0 0 6px rgba(202,162,68,0.5));
}
.leven-hero-divider-col { display: none; }

/* founder credit caption, lower right, with gold divider */
.leven-hero-credit-col { align-self: stretch; text-align: right; }
.leven-hero-credit-col .wp-block-group { height: 100%; }
.leven-hero-credit {
  display: inline-block;
  margin: auto 0 1.5rem auto;
  border-left: 2px solid var(--leven-gold);
  padding: 0.2rem 0 0.2rem 1rem;
  text-align: left;
  max-width: 240px;
}
.leven-credit-name {
  color: var(--leven-gold);
  font-style: italic;
  margin: 0;
  line-height: 1.1;
}
.leven-credit-role {
  color: var(--leven-cream);
  font-family: var(--wp--preset--font-family--body);
  font-size: 0.82rem;
  letter-spacing: 0.05em;
  margin: 0.35rem 0 0;
  opacity: 0.85;
}

/* ============================================================
   SECTION ATMOSPHERE — no more flat black voids
   ============================================================ */
.leven-stars,
.has-cosmic-gradient-background {
  position: relative;
  background-color: #0d0b16;
  background-image: url("../images/section-texture.svg");
  background-size: cover;
  background-position: center;
}
/* keep the gold cosmic glow on hero-style sections */
.has-cosmic-gradient-background {
  background-image: linear-gradient(180deg, rgba(11,10,18,0.4), rgba(11,10,18,0.4)), url("../images/section-texture.svg");
}
/* hairline gold dividers between stacked sections */
section.wp-block-group { border-top: 1px solid rgba(202,162,68,0.08); }

/* ============================================================
   CARDS — features + sciences + testimonials
   ============================================================ */
.leven-card {
  background: linear-gradient(165deg, rgba(34,34,38,0.92) 0%, rgba(15,15,17,0.94) 100%);
  border: 1px solid rgba(202, 162, 68, 0.22);
  border-radius: 16px;
  overflow: hidden;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  box-shadow: 0 10px 30px -22px rgba(0,0,0,0.9), inset 0 1px 0 rgba(255,255,255,0.03);
}
.leven-card:hover {
  transform: translateY(-6px);
  border-color: rgba(202, 162, 68, 0.6);
  box-shadow: 0 26px 50px -24px rgba(0,0,0,0.95), 0 0 0 1px rgba(202,162,68,0.15);
}
.leven-card .wp-block-image { margin: 0; }
.leven-card .wp-block-image img { display: block; width: 100%; }

.leven-icon-wrap {
  width: 64px; height: 64px;
  display: grid; place-content: center;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 35%, rgba(202,162,68,0.18), rgba(202,162,68,0.02));
  border: 1px solid rgba(202, 162, 68, 0.45);
  margin-bottom: 0.5rem;
}
.leven-card img[src*="icon-"] { width: 30px !important; height: 30px !important; }

/* Feature row — borderless, centered, with vertical dividers (matches original) */
.leven-features { gap: 0 !important; }
.leven-feature { text-align: center; padding: 0.5rem clamp(1rem, 2.5vw, 2.6rem); }
.leven-features .leven-feature + .leven-feature {
  border-left: 1px solid rgba(202, 162, 68, 0.2);
}
.leven-feature .leven-icon-wrap {
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 0;
}
.leven-feature h3 { color: var(--leven-cream); }
.leven-feature .leven-eyebrow a { text-decoration: none; }

/* Sciences — black + faded-purple nebula background, gold-bordered cards */
.leven-sciences-section {
  background-color: #070608;
  background-image: url("../images/sciences-bg.svg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
/* sciences showcase page: butt the nebula section right up under the banner */
.leven-page-banner + .leven-sciences-section {
  margin-top: 0 !important;
  padding-top: var(--wp--preset--spacing--40) !important;
}
.leven-sciences { align-items: stretch; }
.leven-science-card {
  text-align: center;
  background: rgba(8,6,12,0.28);
  border: 1px solid rgba(202,162,68,0.55);
  border-radius: 14px;
  padding: 1.85rem 1rem 1.6rem !important;
  box-shadow: none;
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.leven-science-card:hover {
  transform: translateY(-6px);
  border-color: rgba(202,162,68,0.95);
  box-shadow: 0 18px 42px -22px rgba(0,0,0,0.85);
}
.leven-science-icon { margin: 0 auto; }
.leven-science-icon img { width: 84px; height: 84px; filter: drop-shadow(0 4px 14px rgba(124,92,255,0.35)); }
.leven-science-card h3 { color: var(--leven-cream); }
.leven-violet-btn .wp-block-button__link {
  border: 1px solid rgba(168,128,255,0.7) !important;
  color: #c8acff !important;
  background: transparent !important;
  box-shadow: none;
  font-size: 0.72rem;
  padding: 0.6rem 1.3rem;
}
.leven-violet-btn .wp-block-button__link:hover {
  background: #7c5cff !important;
  color: #fff !important;
  border-color: #7c5cff !important;
}

/* ============================================================
   NEWSLETTER band
   ============================================================ */
.leven-newsletter {
  background: linear-gradient(135deg, #caa244 0%, #e7cd86 48%, #b48f36 100%);
  color: var(--leven-night);
  position: relative;
}
.leven-newsletter :where(h1,h2,h3,p) { color: #1b1408; }
.leven-newsletter input[type="email"],
.leven-newsletter input[type="text"] {
  border-radius: 999px; border: none; padding: 0.95rem 1.4rem;
  min-width: 220px; font-size: 1rem;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer.wp-block-template-part {
  border-top: 1px solid rgba(202, 162, 68, 0.18);
  background-color: #0a0a0b;
  background-image: url("../images/section-texture.svg");
  background-size: cover;
}
footer .wp-block-navigation,
.leven-footer-links { text-transform: none; letter-spacing: 0.02em; font-size: 0.92rem; }
.leven-footer-links a { text-decoration: none; }
.leven-footer-links li { margin: 0.3rem 0; }

/* ============================================================
   Buttons — a touch more presence
   ============================================================ */
.wp-block-button__link { box-shadow: 0 8px 24px -12px rgba(202,162,68,0.7); }
.is-style-outline .wp-block-button__link {
  border: 1px solid rgba(202,162,68,0.7) !important;
  color: var(--leven-gold) !important;
  background: transparent !important;
  box-shadow: none;
}
.is-style-outline .wp-block-button__link:hover {
  background: var(--leven-gold) !important;
  color: var(--leven-night) !important;
}

/* ============================================================
   Responsive
   ============================================================ */
/* tab bar is mobile-only (base hidden; the media query shows it) */
.leven-tabbar { display: none; }

@media (max-width: 781px) {
  /* ---- HERO: her face up top, copy pushed to the bottom ---- */
  .leven-hero-row {
    max-width: min(92vw, 440px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .leven-hero-copy {
    max-width: 100vw !important;
    min-width: 0 !important;        /* let the flex item shrink below content size */
    box-sizing: border-box;
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
  }
  .leven-hero-copy > * { max-width: 100% !important; }
  .leven-hero {
    text-align: center;
    min-height: 94vh;
    align-items: flex-end;            /* copy sits at the bottom */
    padding-top: 80px;
    padding-bottom: 2.25rem;
  }
  .leven-hero-bg { background-position: 66% top; }   /* keep her head/face in view */
  .leven-hero:before {
    background: linear-gradient(180deg,
      rgba(0,0,0,0.12) 0%, rgba(0,0,0,0.18) 34%, rgba(0,0,0,0.6) 64%, rgba(0,0,0,0.92) 100%);
  }
  .leven-hero-copy { padding-right: 0; text-align: center; }
  .leven-hero-title { font-size: clamp(2.7rem, 13vw, 3.6rem); }
  .leven-hero-sub { font-size: clamp(1.3rem, 6vw, 1.7rem); }
  .leven-hero-divider { margin: 0.7rem auto 1rem; }
  .leven-hero .leven-hero-copy p.leven-hero-lede {
    max-width: min(88vw, 420px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    font-size: 0.95rem;
    white-space: normal !important;
    overflow-wrap: break-word !important;
    word-break: normal !important;
  }
  .leven-hero .wp-block-buttons {
    max-width: 330px;
    margin-left: auto;
    margin-right: auto;
  }
  .leven-hero .wp-block-buttons {
    justify-content: center;
    flex-direction: column;
    align-items: stretch;
    gap: 0.6rem;
  }
  .leven-hero .wp-block-button { width: 100%; }
  .leven-hero .wp-block-button__link { display: block; text-align: center; }

  /* ---- HEADER: just logo + hamburger (Enroll lives in the tab bar) ---- */
  .leven-header .wp-block-buttons { display: none; }
  .wp-block-site-logo img { width: 80px; }
  .wp-block-navigation__responsive-container-open,
  .wp-block-navigation__responsive-container-close { color: var(--leven-gold); }

  /* ---- SIDE DRAWER menu ---- */
  .wp-block-navigation__responsive-container.is-menu-open {
    left: auto;
    right: 0;
    width: min(82vw, 330px);
    background-color: rgba(9, 8, 13, 0.98) !important;
    border-left: 1px solid rgba(202, 162, 68, 0.3);
    box-shadow: -16px 0 50px rgba(0,0,0,0.6);
    padding-top: 4.5rem;
  }
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    align-items: stretch;
  }
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
    gap: 0.25rem;
  }
  .wp-block-navigation__responsive-container.is-menu-open a {
    font-size: 1.05rem;
    letter-spacing: 0.06em;
    padding: 0.55rem 0;
    border-bottom: 1px solid rgba(202,162,68,0.12);
    display: block;
    width: 100%;
  }

  /* ---- stacked features: dividers become horizontal ---- */
  .leven-features .leven-feature + .leven-feature {
    border-left: none;
    border-top: 1px solid rgba(202, 162, 68, 0.2);
    margin-top: 1.5rem;
    padding-top: 2rem;
  }

  /* ---- BOTTOM TAB BAR (4 items) ---- */
  .leven-tabbar {
    display: flex;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    box-sizing: border-box;
    z-index: 90;
    background: rgba(9, 8, 13, 0.96);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    border-top: 1px solid rgba(202, 162, 68, 0.25);
    padding: 0.35rem 0.25rem calc(0.35rem + env(safe-area-inset-bottom));
  }
  .leven-tabbar a {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    padding: 0.35rem 0;
    font-family: var(--wp--preset--font-family--body);
    font-size: 0.56rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #b9b3a7;
    text-decoration: none;
    white-space: nowrap;
  }
  .leven-tabbar a svg { width: 21px; height: 21px; }
  .leven-tabbar .leven-tab-enroll { color: var(--leven-gold); }
  body { padding-bottom: 62px; }   /* clear the fixed tab bar */
  html, body { overflow-x: hidden; }
}

/* ============================================================
   WooCommerce product cards — equal-height covers
   Book covers come in mixed shapes (square journals + tall
   covers). Lock every product image to one aspect ratio so the
   titles/prices/buttons line up across the grid.
   ============================================================ */
.wc-block-product-template .wc-block-components-product-image,
.wc-block-product-template .wc-block-components-product-image > a {
  display: block;
  width: 100%;
}
.wc-block-product-template .wc-block-components-product-image img {
  aspect-ratio: 3 / 4;
  width: 100%;
  height: auto;
  object-fit: cover;          /* fills the box, crops edges evenly */
  object-position: center;
  border-radius: 6px;
  background: #f4efe3;        /* warm fill behind any letterboxing */
}
/* Make each card a flex column so the button always sits at the bottom */
.wc-block-product-template.is-flex-container > li,
.wc-block-product-template__responsive > li {
  display: flex;
  flex-direction: column;
}

/* Titles — bolder, and clamped to 2 lines so every price/button lines up */
.wc-block-product-template .wp-block-post-title {
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.3;
  margin-top: 0;
  margin-bottom: 0.5rem;
  min-height: 2.6em;          /* reserve 2 lines so short + long titles align */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.wc-block-product-template .wp-block-post-title a {
  font-weight: 600;
  color: inherit;
}

/* Price — fixed slot so it sits at the same height on every card */
.wc-block-product-template .wc-block-components-product-price {
  margin: 0 0 0.85rem;
  font-weight: 600;
  color: var(--leven-gold, #caa244);
}

/* Buttons — slim pill, not the fat full-width global style */
.wc-block-product-template .wc-block-components-product-button {
  margin-top: auto;            /* pin to bottom of card */
}
.wc-block-product-template .wc-block-components-product-button .wp-block-button__link,
.wc-block-product-template .wc-block-components-product-button .wc-block-components-product-button__button {
  width: auto;
  padding: 0.5rem 1.25rem;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  line-height: 1.2;
}

/* ============================================================
   SINGLE PRODUCT PAGE — light "parchment" layout to match
   the inner pages. Wrapped by .leven-page-body.leven-product-page
   in templates/single-product.html.
   ============================================================ */
.leven-product-page {
  --wp--style--global--content-size: 1180px;
}
.leven-product-page .woocommerce-breadcrumb {
  font-family: var(--wp--preset--font-family--body);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #8a8175;
  margin-bottom: 1.8rem;
}
.leven-product-page .woocommerce-breadcrumb a { color: #a9842f; }

/* two-column: gallery + summary */
.leven-product-page div.product {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(1.5rem, 4vw, 3.5rem);
  align-items: start;
}
/* WooCommerce core forces these to width:48% + float, which shrinks each
   side to ~half of its grid cell. Override so each column fills its cell. */
.leven-product-page div.product .woocommerce-product-gallery,
.leven-product-page div.product .summary,
.leven-product-page div.product .entry-summary {
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}
.leven-product-page div.product .woocommerce-product-gallery__wrapper,
.leven-product-page div.product .woocommerce-product-gallery__image { width: 100%; }
.leven-product-page div.product .woocommerce-product-gallery img {
  width: 100%;
  height: auto;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 18px 50px rgba(0,0,0,0.10);
}

/* title + price */
.leven-product-page .product_title {
  font-family: var(--wp--preset--font-family--display);
  font-weight: 600;
  line-height: 1.1;
  color: #1c1712;
  margin: 0 0 0.6rem;
  font-size: clamp(2rem, 1.6rem + 1.6vw, 2.9rem);
}
.leven-product-page div.product p.price,
.leven-product-page div.product span.price {
  color: #a9842f;
  font-weight: 600;
  font-size: 1.5rem;
  margin-bottom: 1.2rem;
}
.leven-product-page div.product p.price del { color: #b3a99a; font-weight: 400; }
.leven-product-page div.product p.price ins { text-decoration: none; }
.leven-product-page .woocommerce-product-details__short-description {
  color: #4a4338;
  line-height: 1.7;
  margin-bottom: 1.6rem;
}

/* sale flag */
.leven-product-page span.onsale {
  background: var(--leven-gold, #caa244);
  color: #1c1712;
  border-radius: 999px;
  font-family: var(--wp--preset--font-family--body);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.66rem;
  min-height: 0;
  min-width: 0;
  padding: 6px 14px;
  line-height: 1;
}

/* add-to-cart form: quantity + Add to Cart + Buy Now on one inline row */
.leven-product-page form.cart {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.8rem;
}
.leven-product-page form.cart::before,
.leven-product-page form.cart::after { content: none; display: none; }   /* kill Woo clearfix that forces a wrap */
.leven-product-page form.cart .quantity { margin: 0; float: none; }
.leven-product-page form.cart .quantity .qty {
  height: 44px;
  width: 64px;
  padding: 0 0 0 0.4rem;
  border: 1px solid #d9d0bf;
  border-radius: 999px;
  background: #fff;
  color: #1c1712;
  text-align: center;
  font-weight: 600;
  font-size: 0.95rem;
  box-sizing: border-box;
}
/* the two cart buttons — slim fixed-height pills, sized to their text */
.leven-product-page .single_add_to_cart_button,
.leven-product-page .leven-buy-now {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: auto;
  height: 44px;
  padding: 0 1.5rem;
  margin: 0;
  border: none;
  border-radius: 999px !important;
  font-family: var(--wp--preset--font-family--body);
  font-weight: 600;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
  cursor: pointer;
  transition: background-color .15s ease, color .15s ease;
}
.leven-product-page .single_add_to_cart_button {
  background: var(--leven-gold, #caa244);
  color: #1c1712;
}
.leven-product-page .single_add_to_cart_button:hover { background: #b78d33; color: #1c1712; }
/* Buy Now — dark pill, secondary to the gold add-to-cart */
.leven-product-page .leven-buy-now {
  background: #1c1712;
  color: #f4efe3;
}
.leven-product-page .leven-buy-now:hover { background: #000; color: #fff; }

/* product meta (sku / category) */
.leven-product-page .product_meta {
  font-size: 0.78rem;
  color: #7c7264;
  border-top: 1px solid rgba(0,0,0,0.08);
  padding-top: 1.1rem;
}
.leven-product-page .product_meta a { color: #a9842f; }

/* ---- TABS: flat underline style ---- */
.leven-product-page .woocommerce-tabs { margin-top: clamp(2.5rem, 6vw, 4.5rem); }
.leven-product-page .woocommerce-tabs ul.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 2rem;
  margin: 0 0 1.8rem;
  padding: 0 0 0 0;
  border-bottom: 1px solid rgba(0,0,0,0.12);
}
.leven-product-page .woocommerce-tabs ul.tabs::before,
.leven-product-page .woocommerce-tabs ul.tabs::after { display: none; }
.leven-product-page .woocommerce-tabs ul.tabs li {
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  margin: 0;
}
.leven-product-page .woocommerce-tabs ul.tabs li::before,
.leven-product-page .woocommerce-tabs ul.tabs li::after { display: none; }
.leven-product-page .woocommerce-tabs ul.tabs li a {
  display: inline-block;
  padding: 0.6rem 0;
  font-family: var(--wp--preset--font-family--body);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-size: 0.78rem;
  color: #8a8175 !important;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.leven-product-page .woocommerce-tabs ul.tabs li.active a,
.leven-product-page .woocommerce-tabs ul.tabs li a:hover {
  color: #1c1712 !important;
  border-bottom-color: var(--leven-gold, #caa244);
}
.leven-product-page .woocommerce-Tabs-panel {
  color: #4a4338;
  line-height: 1.75;
  max-width: 760px;
}
.leven-product-page .woocommerce-Tabs-panel h2 {
  font-size: 1.4rem;
  color: #1c1712;
  margin-bottom: 0.8rem;
}

/* ---- RELATED PRODUCTS: full container width, aligned with the product above ----
   WooCommerce renders these INSIDE div.product, so they land as a grid item.
   Span both columns so the section is the full width, not the gallery width. */
.leven-product-page div.product .related.products,
.leven-product-page div.product .upsells.products {
  grid-column: 1 / -1;
}
.leven-product-page .related.products {
  width: 100%;
  clear: both;
  margin: clamp(2.5rem, 6vw, 4.5rem) 0 0;
  padding-top: clamp(2.5rem, 6vw, 4rem);
  border-top: 1px solid rgba(0,0,0,0.08);
}
.leven-product-page .upsells.products { margin-top: clamp(2.5rem, 6vw, 4.5rem); }
.leven-product-page .related.products > h2,
.leven-product-page .upsells.products > h2 {
  font-size: 1.7rem;
  color: #1c1712;
  margin-bottom: 1.6rem;
  text-align: center;
}
/* fill the full width with cards (more per row on wide screens) */
.leven-product-page .related.products ul.products {
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
.leven-product-page ul.products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.leven-product-page ul.products::before,
.leven-product-page ul.products::after { display: none; }
.leven-product-page ul.products li.product {
  display: flex;
  flex-direction: column;
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  text-align: center;
}
.leven-product-page ul.products li.product > a img {
  aspect-ratio: 3 / 4;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 6px;
  background: #f4efe3;
  margin-bottom: 0.75rem;
}
.leven-product-page ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--wp--preset--font-family--body);
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1.3;
  color: #1c1712;
  padding: 0;
  margin: 0 0 0.4rem;
  min-height: 2.6em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.leven-product-page ul.products li.product .price {
  color: #a9842f;
  font-weight: 600;
  font-size: 0.95rem;
  margin: 0 0 0.85rem;
}
.leven-product-page ul.products li.product .price del { color: #b3a99a; font-weight: 400; }
.leven-product-page ul.products li.product .price ins { text-decoration: none; }
.leven-product-page ul.products li.product .button {
  margin-top: auto;
  align-self: center;
  background: transparent;
  color: #1c1712;
  border: 1.5px solid #d9cdb4;
  padding: 0.5rem 1.25rem;
  font-size: 0.68rem;
}
.leven-product-page ul.products li.product .button:hover {
  background: var(--leven-gold, #caa244);
  border-color: var(--leven-gold, #caa244);
  color: #1c1712;
}

/* responsive */
@media (max-width: 980px) {
  .leven-product-page div.product { grid-template-columns: 1fr; }
  .leven-product-page ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px) {
  .leven-product-page ul.products { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .leven-product-page form.cart { gap: 0.5rem; }
  .leven-product-page form.cart .quantity .qty { width: 64px; }
}

/* ============================================================
   SHOP / CATEGORY ARCHIVE — light layout, equal-height cards.
   Cards inherit the .leven-product-page ul.products rules above;
   these add the toolbar (count + sort) and pagination.
   ============================================================ */
.leven-archive-page .leven-term-description {
  color: #4a4338;
  line-height: 1.7;
  max-width: 760px;
  margin: 0 auto 2rem;
  text-align: center;
}
/* result count + ordering toolbar */
.leven-archive-page .woocommerce-result-count {
  float: none;
  margin: 0;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #8a8175;
}
.leven-archive-page .woocommerce-ordering { float: none; margin: 0; }
.leven-archive-page .woocommerce-ordering select.orderby,
.leven-archive-page select.orderby {
  height: 44px;
  border: 1px solid #d9d0bf;
  border-radius: 999px;
  background: #fff;
  color: #1c1712;
  font-family: var(--wp--preset--font-family--body);
  font-size: 0.8rem;
  padding: 0 2.2rem 0 1.1rem;
  cursor: pointer;
}
/* put count on the left, sort on the right, above the grid */
.leven-archive-page .woocommerce-result-count,
.leven-archive-page .woocommerce-ordering {
  display: inline-block;
  vertical-align: middle;
}
.leven-archive-page .woocommerce-notices-wrapper + .woocommerce-result-count,
.leven-archive-page .woocommerce-result-count {
  margin-bottom: 1.5rem;
}
.leven-archive-page .woocommerce-ordering { margin-bottom: 1.5rem; }
@media (min-width: 600px) {
  .leven-archive-page .woocommerce-ordering { float: right; }
}

/* pagination */
.leven-archive-page .woocommerce-pagination {
  margin-top: 2.5rem;
  text-align: center;
}
.leven-archive-page .woocommerce-pagination ul {
  display: inline-flex;
  gap: 0.4rem;
  border: none;
  margin: 0;
  padding: 0;
}
.leven-archive-page .woocommerce-pagination ul li {
  border: none;
  margin: 0;
}
.leven-archive-page .woocommerce-pagination ul li a,
.leven-archive-page .woocommerce-pagination ul li span {
  min-width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.5rem;
  border-radius: 999px;
  border: 1px solid #e0d8c8;
  background: #fff;
  color: #1c1712;
  font-weight: 600;
  font-size: 0.85rem;
}
.leven-archive-page .woocommerce-pagination ul li span.current {
  background: var(--leven-gold, #caa244);
  border-color: var(--leven-gold, #caa244);
  color: #1c1712;
}
.leven-archive-page .woocommerce-pagination ul li a:hover {
  border-color: var(--leven-gold, #caa244);
  color: #a9842f;
}
/* a little breathing room above the grid */
.leven-archive-page ul.products { margin-top: 0.5rem; clear: both; }

/* ============================================================
   CART PAGE — light, on-brand. Covers the classic WooCommerce
   cart (rendered here via Themify's WooCommerce module) plus the
   block cart as a fallback. Scoped to the cart page only.
   ============================================================ */
body.woocommerce-cart .themify_builder_content,
body.woocommerce-cart .module-woocommerce { max-width: none; }

/* section heading ("Cart totals") */
body.woocommerce-cart .cart_totals > h2,
body.woocommerce-cart .wc-block-cart__totals-title {
  font-family: var(--wp--preset--font-family--display);
  font-weight: 600;
  font-size: 1.3rem;
  color: #1c1712;
  margin: 0 0 1rem;
  text-transform: none;
  letter-spacing: 0;
}

/* ---- line-items table ---- */
body.woocommerce-cart table.shop_table {
  border: none;
  border-collapse: collapse;
  background: transparent;
  width: 100%;
  margin: 0;
}
body.woocommerce-cart table.cart thead th {
  border: none;
  border-bottom: 1px solid rgba(0,0,0,0.14);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.7rem;
  font-weight: 600;
  color: #8a8175;
  padding: 0 0.6rem 0.8rem;
  text-align: left;
}
body.woocommerce-cart table.cart td {
  border: none;
  border-bottom: 1px solid rgba(0,0,0,0.07);
  padding: 1rem 0.6rem;
  vertical-align: middle;
  background: transparent;
}
body.woocommerce-cart td.product-thumbnail img {
  width: 60px;
  height: 80px;
  object-fit: cover;
  border-radius: 6px;
  background: #f4efe3;
  display: block;
}
body.woocommerce-cart td.product-name a {
  color: #1c1712;
  font-weight: 600;
  text-decoration: none;
}
body.woocommerce-cart td.product-name a:hover { color: #a9842f; }
body.woocommerce-cart .product-price,
body.woocommerce-cart .product-subtotal { color: #3c352c; font-weight: 600; }
body.woocommerce-cart .product-subtotal { color: #1c1712; }
body.woocommerce-cart a.remove {
  color: #a9842f !important;
  border: 1px solid #e0d8c8;
  border-radius: 999px;
  width: 22px; height: 22px; line-height: 20px;
  font-size: 15px; text-align: center;
  background: #fff;
}
body.woocommerce-cart a.remove:hover { background: #a9842f; color: #fff !important; }

/* quantity stepper */
body.woocommerce-cart .quantity .qty {
  height: 42px; width: 64px;
  border: 1px solid #d9d0bf; border-radius: 999px;
  background: #fff; color: #1c1712;
  text-align: center; font-weight: 600; box-sizing: border-box;
}

/* coupon + update-cart row */
body.woocommerce-cart td.actions { padding: 1.4rem 0.6rem 0; }
body.woocommerce-cart .coupon { display: inline-flex; gap: 0.4rem; vertical-align: middle; }
body.woocommerce-cart .coupon .input-text {
  height: 44px;
  border: 1px solid #d9d0bf; border-radius: 999px;
  background: #fff; color: #1c1712;
  padding: 0 1.1rem; min-width: 170px; box-sizing: border-box;
}
/* shared button shape — CLASSIC cart only (not block component buttons) */
body.woocommerce-cart .woocommerce .button,
body.woocommerce-cart .woocommerce .checkout-button {
  border-radius: 999px !important;
  font-family: var(--wp--preset--font-family--body);
  text-transform: uppercase; letter-spacing: 0.06em;
  font-weight: 600; font-size: 0.74rem;
  height: 44px; padding: 0 1.5rem;
  display: inline-flex; align-items: center; justify-content: center;
  border: none; cursor: pointer; line-height: 1;
  transition: background-color .15s ease, color .15s ease;
}
body.woocommerce-cart .coupon button,
body.woocommerce-cart button[name="update_cart"] {
  background: #1c1712; color: #f4efe3;
}
body.woocommerce-cart .coupon button:hover,
body.woocommerce-cart button[name="update_cart"]:hover { background: #000; }
body.woocommerce-cart button[name="update_cart"]:disabled { opacity: 0.45; cursor: default; }

/* ---- totals card (right column) ---- */
body.woocommerce-cart .cart_totals {
  float: none;
  width: 100%;
  background: #fff;
  border: 1px solid #ece3d2;
  border-radius: 12px;
  padding: 1.6rem 1.6rem 1.8rem;
  box-shadow: 0 14px 40px rgba(0,0,0,0.06);
}
body.woocommerce-cart .cart_totals table { width: 100%; margin: 0; }
body.woocommerce-cart .cart_totals table th,
body.woocommerce-cart .cart_totals table td {
  border: none;
  border-bottom: 1px solid rgba(0,0,0,0.07);
  padding: 0.7rem 0;
  background: transparent;
  color: #3c352c;
}
body.woocommerce-cart .cart_totals th { font-weight: 600; text-align: left; }
body.woocommerce-cart .cart_totals .order-total th,
body.woocommerce-cart .cart_totals .order-total td {
  font-size: 1.05rem;
  color: #1c1712;
  border-bottom: none;
  padding-top: 1rem;
}
body.woocommerce-cart .cart_totals .order-total .amount { color: #a9842f; font-weight: 700; }
body.woocommerce-cart .wc-proceed-to-checkout { padding: 1.2rem 0 0; }
body.woocommerce-cart .wc-proceed-to-checkout a.checkout-button {
  width: 100%;
  background: var(--leven-gold, #caa244);
  color: #1c1712;
  height: 50px; font-size: 0.8rem;
}
body.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover { background: #b78d33; color: #1c1712; }

/* desktop: items left, totals right */
@media (min-width: 900px) {
  body.woocommerce-cart .woocommerce { overflow: hidden; }   /* contain floats */
  body.woocommerce-cart form.woocommerce-cart-form {
    float: left;
    width: calc(100% - 360px);
    padding-right: 2.2rem;
    box-sizing: border-box;
  }
  body.woocommerce-cart .cart-collaterals {
    float: right;
    width: 340px;
  }
  body.woocommerce-cart .cart-collaterals .cross-sells { display: none; }
}

/* ============================================================
   BLOCK CART & CHECKOUT — native WooCommerce blocks, on-brand.
   Rendered via theme templates page-cart.html / page-checkout.html
   (which override WooCommerce's dark default templates) inside the
   light .leven-page-body.leven-commerce-page wrapper.
   ============================================================ */
.leven-commerce-page { --wp--style--global--content-size: 1100px; }
/* line items (cart) + summary items (checkout) */
body.woocommerce-cart .wc-block-cart-items__row,
body.woocommerce-checkout .wc-block-components-order-summary-item {
  border-color: rgba(0,0,0,0.08) !important;
}
body.woocommerce-cart .wc-block-cart-item__image img,
body.woocommerce-checkout .wc-block-components-order-summary-item__image img {
  border-radius: 6px;
  background: #f4efe3;
}
body.woocommerce-cart .wc-block-cart-item__product-name,
body.woocommerce-cart .wc-block-cart-item__product-name a,
body.woocommerce-checkout .wc-block-components-product-name {
  color: #1c1712 !important;
  font-weight: 600;
  text-decoration: none;
}
body.woocommerce-cart .wc-block-cart-item__product-name a:hover { color: #a9842f !important; }

/* quantity steppers (block) */
body.woocommerce-cart .wc-block-components-quantity-selector {
  border: 1px solid #d9d0bf;
  border-radius: 999px;
  background: #fff;
}

/* totals / order-summary CARD goes on the sidebar container only */
body.woocommerce-cart .wc-block-cart__sidebar .wc-block-components-sidebar,
body.woocommerce-checkout .wc-block-checkout__sidebar .wc-block-components-sidebar {
  background: #fff;
  border: 1px solid #ece3d2;
  border-radius: 12px;
  box-shadow: 0 14px 40px rgba(0,0,0,0.06);
  padding: 1.5rem 1.6rem;
}
/* each inner total line (Subtotal / Add coupons / Estimated total) stays
   transparent — no per-row boxes that look like buttons */
body.woocommerce-cart .wc-block-cart__sidebar .wc-block-components-totals-wrapper,
body.woocommerce-checkout .wc-block-checkout__sidebar .wc-block-components-totals-wrapper {
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
body.woocommerce-cart .wc-block-components-totals-item__value,
body.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  color: #1c1712;
}
body.woocommerce-cart .wc-block-components-totals-footer-item .wc-block-formatted-money-amount,
body.woocommerce-checkout .wc-block-components-totals-footer-item .wc-block-formatted-money-amount {
  color: #a9842f;
}

/* checkout form fields */
body.woocommerce-checkout .wc-block-components-text-input input,
body.woocommerce-checkout .wc-block-components-text-input .components-combobox-control__input,
body.woocommerce-checkout .wc-block-components-select .wc-blocks-components-select__select,
body.woocommerce-checkout .wc-block-components-address-form input,
body.woocommerce-checkout .wc-block-components-combobox input,
body.woocommerce-checkout select {
  border: 1px solid #d9d0bf !important;
  border-radius: 8px !important;
  background: #fff !important;
  color: #1c1712 !important;
}
body.woocommerce-checkout .wc-block-components-text-input label,
body.woocommerce-checkout .wc-block-components-checkout-step__description { color: #8a8175; }

/* step titles in the display serif */
body.woocommerce-checkout .wc-block-components-checkout-step__title,
body.woocommerce-checkout .wc-block-components-title {
  font-family: var(--wp--preset--font-family--display);
  font-weight: 600;
  color: #1c1712;
}

/* primary buttons: Proceed to Checkout / Place Order → gold pill */
body.woocommerce-cart .wc-block-cart__submit-button,
body.woocommerce-cart .wc-block-cart__submit-container .wc-block-components-button,
body.woocommerce-checkout .wc-block-components-checkout-place-order-button {
  width: 100%;
  background: var(--leven-gold, #caa244) !important;
  color: #1c1712 !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
}
body.woocommerce-cart .wc-block-cart__submit-button:hover,
body.woocommerce-checkout .wc-block-components-checkout-place-order-button:hover {
  background: #b78d33 !important;
  color: #1c1712 !important;
}

/* ============================================================
   TUTOR LMS — recolor pink → Leven gold + course-card polish.
   (Courses archive at /courses/.)
   ============================================================ */
:root,
body.tutor-lms {
  --tutor-color-primary: #caa244;
  --tutor-color-primary-rgb: 202, 162, 68;
  --tutor-color-primary-hover: #a9842f;
  --tutor-color-primary-hover-rgb: 169, 132, 47;
}

/* course grid cards */
.tutor-course-list .tutor-card,
.tutor-card.tutor-course-card,
.tutor-course-listing-item .tutor-card {
  background: #fff;
  border: 1px solid #ece3d2;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 14px 40px rgba(0,0,0,0.06);
}
.tutor-course-list .tutor-card-body { padding: 1.1rem 1.2rem 1.3rem; }
.tutor-course-thumbnail img { border-radius: 0; }
.tutor-course-name a {
  color: #1c1712 !important;
  font-weight: 600;
  text-decoration: none;
}
.tutor-course-name a:hover { color: #a9842f !important; }
.tutor-course-price,
.tutor-course-price .price { color: #a9842f !important; }

/* buttons → gold pills */
.tutor-btn.tutor-btn-primary,
.tutor-btn.tutor-btn-outline-primary {
  border-radius: 999px !important;
}
.tutor-btn.tutor-btn-primary {
  background: #caa244 !important;
  border-color: #caa244 !important;
  color: #1c1712 !important;
}
.tutor-btn.tutor-btn-primary:hover {
  background: #b78d33 !important;
  border-color: #b78d33 !important;
}
.tutor-btn.tutor-btn-outline-primary {
  border-color: #caa244 !important;
  color: #a9842f !important;
}
.tutor-btn.tutor-btn-outline-primary:hover {
  background: #caa244 !important;
  color: #1c1712 !important;
}

/* links/accents */
.tutor-color-primary,
a.tutor-color-primary { color: #a9842f !important; }

/* ---- Courses archive (/courses/): light page + clear the fixed header ---- */
body.post-type-archive-courses .wp-site-blocks { background: #fbf8f0; }
/* no dark banner here, so make the overlay header solid + readable */
body.post-type-archive-courses header.wp-block-template-part {
  background: rgba(11, 10, 18, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(202, 162, 68, 0.16);
}
/* push the course grid below the fixed header, with breathing room */
body.post-type-archive-courses .tutor-wrap.course-archive-page {
  padding-top: clamp(6.5rem, 9vw, 8.5rem) !important;
  padding-bottom: var(--wp--preset--spacing--60, 4.5rem);
}
body.post-type-archive-courses { color: #322c24; }
body.post-type-archive-courses .tutor-color-black,
body.post-type-archive-courses .tutor-fs-3 { color: #1c1712 !important; }

/* ---- Single course (enroll) page: light page + clear the fixed header ---- */
body.single-courses .wp-site-blocks { background: #fbf8f0; }
body.single-courses header.wp-block-template-part {
  background: rgba(11, 10, 18, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(202, 162, 68, 0.16);
}
body.single-courses .tutor-full-width-course-top { padding-top: clamp(6.5rem, 9vw, 8.5rem); }
/* inherited light text → dark on the cream page */
body.single-courses .tutor-course-details-page,
body.single-courses .tutor-course-details-page p,
body.single-courses .tutor-course-details-page li,
body.single-courses .tutor-course-details-page label,
body.single-courses .tutor-course-details-page .tutor-color-secondary,
body.single-courses .tutor-course-details-page .tutor-color-muted { color: #3c352c; }
body.single-courses .tutor-course-details-page :where(h1,h2,h3,h4,h5,h6),
body.single-courses .tutor-course-details-page .tutor-color-black { color: #1c1712; }
body.single-courses [class*="course-header"],
body.single-courses .tutor-course-header-wrap { color: #1c1712; }
/* details tabs */
body.single-courses .tutor-course-details-tab .tutor-nav-link { color: #8a8175 !important; }
body.single-courses .tutor-course-details-tab .tutor-nav-link.is-active { color: #1c1712 !important; }
/* sidebar pricing card stays a clean white card */
body.single-courses .tutor-single-course-sidebar {
  background: #fff;
  border: 1px solid #ece3d2;
  border-radius: 12px;
  box-shadow: 0 14px 40px rgba(0,0,0,0.06);
}

/* ---- Membership hero on the courses archive ---- */
.leven-courses-hero {
  position: relative;
  text-align: center;
  background: radial-gradient(120% 140% at 70% 10%, #2e2512 0%, #141019 45%, #0a0a0b 100%);
  border: 1px solid rgba(202,162,68,0.22);
  border-radius: 16px;
  padding: clamp(2.2rem, 5vw, 3.4rem) 1.5rem;
  margin: 0 0 2.5rem;
  overflow: hidden;
}
.leven-courses-hero__eyebrow {
  color: var(--leven-gold, #caa244);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  font-size: 0.72rem;
  font-weight: 600;
  margin: 0 0 0.6rem;
}
.leven-courses-hero__title {
  font-family: var(--wp--preset--font-family--display);
  color: #f4efe3 !important;
  font-weight: 600;
  line-height: 1.05;
  font-size: clamp(1.8rem, 1.3rem + 2vw, 2.9rem);
  margin: 0 0 0.9rem;
}
.leven-courses-hero__text {
  color: #d8d0c2 !important;
  max-width: 640px;
  margin: 0 auto 1.6rem;
  line-height: 1.7;
  font-size: 1rem;
}
.leven-courses-hero__text strong { color: var(--leven-gold, #caa244); font-weight: 600; }
.leven-courses-hero__cta {
  display: inline-block;
  background: var(--leven-gold, #caa244);
  color: #1c1712 !important;
  text-decoration: none;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.78rem;
  padding: 0.85rem 2rem;
  border-radius: 999px;
  transition: background-color .15s ease;
}
.leven-courses-hero__cta:hover { background: #b78d33; color: #1c1712 !important; }
