/*
 Theme Name: Oasis Child
 Template: kadence
 Version: 1.0.0
 Description: Oasis Labs USA — luxury peptide spa redesign. Built from scratch atop Kadence.
 Author: Oasis Labs
*/

/* ============================================================
   HARD KADENCE RESET — neutralize every default that could
   interfere with full-width layout or token-driven design.
   ============================================================ */

:root {
  /* Override Kadence width system so every wrapper goes edge-to-edge.
     Design-scoped max-widths are applied per-section via .oasis-wrap. */
  --global-content-width: 100vw;
  --global-content-narrow-width: 100vw;
  --global-content-boxed-width: 100vw;
  --global-calc-content-width: 100vw;
  --global-content-edge-padding: 0px;
  --global-content-boxed-padding: 0px;
  --global-column-gap: 0px;
  --wp--style--global--content-size: 100vw;
  --wp--style--global--wide-size: 100vw;
}

/* Neutralize every wrapper Kadence lays down */
html, body { margin: 0; padding: 0; }
body.home,
body.home .site,
body.home .wp-site-blocks,
body.home .site-container,
body.home .content-container,
body.home .content-wrap,
body.home .site-content,
body.home #primary,
body.home #main,
body.home .site-main,
body.home .entry-content,
body.home .entry-content-wrap,
body.home .content-area,
body.home article,
body.home article.post,
body.home .entry,
body.home .entry-wrap {
  max-width: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Kadence puts content-width-fullwidth on body for fullwidth pages.
   Belt-and-suspenders: kill any inner content constraint it injects. */
body.home .entry-content > *,
body.home .entry-content .wp-block-group,
body.home .entry-content .kt-row-column-wrap,
body.home .entry-content .kadence-column,
body.home .entry-content .wp-block-kadence-rowlayout {
  max-width: none !important;
}

/* Kill default page title / entry header on home */
body.home .entry-header,
body.home .page-title,
body.home .entry-title { display: none !important; }

/* Kill hello-world spacing on the outer article */
body.home article.entry { padding: 0 !important; margin: 0 !important; }

/* Boxed content backgrounds interfere with full-bleed sections */
body.home { background: #f5f2ec; }

/* ============================================================
   DESIGN SYSTEM TOKENS
   ============================================================ */
:root {
  /* Colors — earth-tone palette: olive, taupe, sand, stone */
  --ol-cream-50:  #f5f3ee;
  --ol-cream-100: #edeae3;
  --ol-cream-200: #dfdad0;
  --ol-cream-300: #CEC7BB;
  --ol-sand:      #C9B99A;
  --ol-sage-100:  #d2d0c6;
  --ol-sage-300:  #B8B09E;
  --ol-sage-500:  #6B6F52;
  --ol-forest-700: #535740;
  --ol-forest-800: #424530;
  --ol-forest-900: #353525;
  --ol-ink-900:   #252518;
  --ol-ink-700:   #3e3d30;
  --ol-gold-500:  #C9B99A;
  --ol-gold-400:  #d6c8a8;

  --ol-bg:        var(--ol-cream-100);
  --ol-surface:   var(--ol-cream-50);
  --ol-text:      var(--ol-ink-900);
  --ol-text-soft: color-mix(in oklab, var(--ol-ink-900) 72%, transparent);
  --ol-text-inv:  var(--ol-cream-50);
  --ol-border:    color-mix(in oklab, var(--ol-ink-900) 12%, transparent);

  /* Typography */
  --ol-font-display: 'Cormorant Garamond', Georgia, serif;
  --ol-font-body:    'Jost', -apple-system, system-ui, sans-serif;

  --ol-fs-xs:   0.75rem;
  --ol-fs-sm:   0.875rem;
  --ol-fs-base: 1rem;
  --ol-fs-lg:   1.125rem;
  --ol-fs-xl:   1.25rem;
  --ol-fs-2xl:  1.5rem;
  --ol-fs-3xl:  2rem;
  --ol-fs-4xl:  2.75rem;
  --ol-fs-5xl:  4rem;
  --ol-fs-6xl:  5.75rem;

  /* Spacing scale */
  --sp-1:  0.25rem;
  --sp-2:  0.5rem;
  --sp-3:  0.75rem;
  --sp-4:  1rem;
  --sp-5:  1.25rem;
  --sp-6:  1.5rem;
  --sp-8:  2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  --sp-32: 8rem;

  --ol-radius-sm: 6px;
  --ol-radius-md: 12px;
  --ol-radius-lg: 20px;
  --ol-radius-pill: 999px;

  --ol-shadow-sm: 0 1px 2px rgba(20,32,26,.08);
  --ol-shadow-md: 0 10px 30px -12px rgba(20,32,26,.18);
  --ol-shadow-lg: 0 30px 80px -20px rgba(20,32,26,.28);

  --ol-ease: cubic-bezier(.2,.7,.2,1);
  --ol-dur:  .4s;

  --ol-z-base: 1;
  --ol-z-raised: 10;
  --ol-z-sticky: 100;
  --ol-z-header: 500;
  --ol-z-modal:  1000;

  --ol-wrap: 1280px;
}

/* Base body typography */
body {
  font-family: var(--ol-font-body);
  color: var(--ol-text);
  font-size: var(--ol-fs-base);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,h2,h3,h4 {
  font-family: var(--ol-font-display);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 0;
}

.oasis-wrap {
  max-width: var(--ol-wrap);
  margin-inline: auto;
  padding-inline: clamp(var(--sp-5), 4vw, var(--sp-12));
}

/* Temporary diagnostic block so we can visually confirm full-width wrappers. */
.oasis-diag {
  background: repeating-linear-gradient(135deg, var(--ol-sage-300) 0 12px, var(--ol-sage-100) 12px 24px);
  color: var(--ol-forest-900);
  font-family: var(--ol-font-body);
  padding: var(--sp-8) var(--sp-4);
  text-align: center;
  font-size: var(--ol-fs-lg);
  border-block: 2px solid var(--ol-forest-800);
}
.oasis-diag b { font-family: var(--ol-font-display); font-size: var(--ol-fs-2xl); }

/* ============================================================
   MOBILE NAVIGATION — hamburger + drawer
   ============================================================ */
.ol-navtoggle {
  display: none;
  position: absolute;
  top: 50%;
  right: clamp(var(--sp-4), 5vw, var(--sp-8));
  transform: translateY(-50%);
  z-index: 520;
  width: 48px;
  height: 48px;
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 22%, transparent);
  background: color-mix(in oklab, var(--ol-cream-50) 88%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--ol-radius-pill);
  cursor: pointer;
  padding: 0;
  align-items: center;
  justify-content: center;
}
.ol-navtoggle__bars {
  display: inline-flex;
  flex-direction: column;
  gap: 5px;
  width: 20px;
}
.ol-navtoggle__bars span {
  display: block;
  height: 2px;
  background: var(--ol-ink-900);
  border-radius: 2px;
  transition: transform .3s var(--ol-ease), opacity .2s var(--ol-ease);
}
.ol-navtoggle[aria-expanded="true"] .ol-navtoggle__bars span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ol-navtoggle[aria-expanded="true"] .ol-navtoggle__bars span:nth-child(2) { opacity: 0; }
.ol-navtoggle[aria-expanded="true"] .ol-navtoggle__bars span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.ol-drawer {
  position: fixed;
  inset: 0;
  z-index: 800;
  visibility: hidden;
  pointer-events: none;
}
.ol-drawer.is-open { visibility: visible; pointer-events: auto; }
.ol-drawer__scrim {
  position: absolute;
  inset: 0;
  background: color-mix(in oklab, var(--ol-ink-900) 55%, transparent);
  backdrop-filter: blur(6px);
  opacity: 0;
  transition: opacity .35s var(--ol-ease);
}
.ol-drawer.is-open .ol-drawer__scrim { opacity: 1; }
.ol-drawer__panel {
  position: absolute;
  top: 0; right: 0;
  bottom: 0;
  width: min(88vw, 380px);
  background: var(--ol-cream-50);
  border-left: 1px solid color-mix(in oklab, var(--ol-forest-900) 10%, transparent);
  box-shadow: -40px 0 80px -20px rgba(20,32,26,.4);
  padding: var(--sp-16) var(--sp-6) var(--sp-8);
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform .4s var(--ol-ease);
  display: flex;
  flex-direction: column;
  gap: var(--sp-8);
}
.ol-drawer.is-open .ol-drawer__panel { transform: translateX(0); }
.ol-drawer__close {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  width: 44px;
  height: 44px;
  border: 0;
  background: transparent;
  color: var(--ol-ink-900);
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 999px;
  transition: background var(--ol-dur) var(--ol-ease);
}
.ol-drawer__close:hover { background: color-mix(in oklab, var(--ol-forest-900) 8%, transparent); }
.ol-drawer__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ol-drawer__menu a {
  display: block;
  padding: var(--sp-4) var(--sp-3);
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-base);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ol-ink-900);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in oklab, var(--ol-forest-900) 6%, transparent);
}
.ol-drawer__menu .menu-item-has-children > a::after {
  content: "＋";
  float: right;
  font-weight: 300;
  color: var(--ol-forest-800);
}
.ol-drawer__menu .menu-item-has-children.is-open > a::after { content: "－"; }
.ol-drawer__menu .sub-menu {
  display: none;
  list-style: none;
  padding: 0 0 var(--sp-3) var(--sp-5);
  margin: 0;
  background: color-mix(in oklab, var(--ol-forest-900) 4%, transparent);
}
.ol-drawer__menu .menu-item-has-children.is-open > .sub-menu { display: block; }
.ol-drawer__menu .sub-menu a {
  font-size: var(--ol-fs-sm);
  padding: var(--sp-3) var(--sp-2);
  letter-spacing: 0.08em;
  border: 0;
  color: var(--ol-forest-800);
}
.ol-drawer__cta {
  margin-top: auto;
  padding-top: var(--sp-6);
  border-top: 1px solid color-mix(in oklab, var(--ol-forest-900) 10%, transparent);
}
.ol-drawer__cta .ol-btn {
  width: 100%;
  justify-content: center;
  padding: var(--sp-4) var(--sp-6);
}
.ol-drawer__menu svg { display: none; }
body.ol-drawer-open { overflow: hidden; }

/* Activate under 900px; hide Kadence's inline nav */
@media (max-width: 900px) {
  .ol-navtoggle { display: inline-flex; }
  body.home .site-header-item-main-navigation,
  body.home .header-navigation,
  body.home .main-navigation,
  body.home .primary-menu-container { display: none !important; }
  body.home .site-header-main-section-right { min-width: 0; }
  body.home .site-main-header-inner-wrap { padding-block: var(--sp-3) !important; }
  body.home .site-branding img.custom-logo { height: 40px !important; }
}

/* ============================================================
   HEADER — custom luxury overlay on hero
   ============================================================ */

/* Kill Kadence's duplicate branding text next to the logo */
body.home .site-title,
body.home .site-description,
body.home .site-branding .site-title-wrap,
body.home p.site-title { display: none !important; }

/* Header is fixed — travels with the viewport, semi-opaque cream
   glass, hairline bottom divider. Padding matches the hero wrap. */
body.home .site-header {
  position: fixed !important;
  top: 0; left: 0; right: 0;
  width: 100% !important;
  background: color-mix(in oklab, var(--ol-cream-50) 22%, transparent) !important;
  backdrop-filter: blur(46px) saturate(1.7);
  -webkit-backdrop-filter: blur(46px) saturate(1.7);
  border-bottom: 1px solid color-mix(in oklab, var(--ol-forest-900) 10%, transparent) !important;
  box-shadow: 0 1px 24px -12px rgba(20,32,26,.25) !important;
  z-index: 500;
}
body.home .site-header-wrap,
body.home .site-header-inner-wrap,
body.home .site-header-upper-wrap,
body.home .site-header-upper-inner-wrap,
body.home .site-main-header-wrap {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
/* Match hero inset exactly */
body.home .site-header .site-container,
body.home .site-header-main-section-left,
body.home .site-header-main-section-right {
  background: transparent !important;
}
body.home .site-header .site-container {
  max-width: var(--ol-wrap) !important;
  margin-inline: auto !important;
  padding-inline: clamp(var(--sp-5), 4vw, var(--sp-12)) !important;
  width: 100% !important;
}
body.home .site-main-header-inner-wrap {
  padding-block: var(--sp-4) !important;
}

/* Logo sizing — keep SVG crisp and a touch smaller than default */
body.home .site-branding img.custom-logo {
  height: 48px !important;
  width: auto !important;
  max-width: none !important;
  filter: drop-shadow(0 2px 8px rgba(20,32,26,.12));
}

/* Menu links */
body.home .header-menu-container .menu-item > a,
body.home .site-header-item-main-navigation a {
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-sm) !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--ol-ink-900) !important;
  transition: color var(--ol-dur) var(--ol-ease) !important;
}
body.home .header-menu-container .menu-item > a:hover {
  color: var(--ol-forest-700) !important;
}

/* ---- Dropdown (submenu) panels ---- */
body.home .header-navigation .menu .sub-menu,
body.home .header-menu-container .sub-menu,
body.home .site-header .sub-menu {
  background: color-mix(in oklab, var(--ol-cream-50) 94%, transparent) !important;
  backdrop-filter: blur(22px) saturate(1.3);
  -webkit-backdrop-filter: blur(22px) saturate(1.3);
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 12%, transparent) !important;
  border-radius: var(--ol-radius-md) !important;
  box-shadow: var(--ol-shadow-lg) !important;
  padding: var(--sp-3) 0 !important;
  min-width: 14rem !important;
  margin-top: 0 !important;
  overflow: visible !important;
}

/* Invisible bridge between parent link and submenu so the hover
   intent stays alive as the cursor travels down — Kadence's default
   gap causes the menu to close mid-travel. */
body.home .site-header .menu-item-has-children { position: relative; }
body.home .site-header .sub-menu::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -16px;
  height: 16px;
  background: transparent;
}
/* Dropdown parents must match sibling menu items exactly — no extra
   padding, same baseline. The ::before bridge on the sub-menu covers
   the hover gap instead. */
body.home .site-header .header-menu-container .menu-item,
body.home .site-header .header-menu-container .menu-item-has-children {
  display: flex !important;
  align-items: center !important;
}
body.home .site-header .header-menu-container .menu-item > a,
body.home .site-header .header-menu-container .menu-item-has-children > a {
  display: inline-flex !important;
  align-items: center !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  min-height: 2.5rem !important;
  line-height: 1 !important;
}
body.home .site-header .header-menu-container .menu-item-has-children > a .nav-drop-title-wrap {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Keep the dropdown latched open while the cursor is anywhere inside
   the parent <li> or the sub-menu itself, even over the bridge gap. */
body.home .site-header .menu-item-has-children:hover > .sub-menu,
body.home .site-header .menu-item-has-children:focus-within > .sub-menu,
body.home .site-header .sub-menu:hover {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
  transform: none !important;
  display: block !important;
}
body.home .site-header .sub-menu li { background: transparent !important; }
body.home .site-header .sub-menu li > a {
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: var(--ol-ink-900) !important;
  padding: var(--sp-3) var(--sp-5) !important;
  border: 0 !important;
  background: transparent !important;
  transition: all var(--ol-dur) var(--ol-ease) !important;
}
body.home .site-header .sub-menu li > a:hover,
body.home .site-header .sub-menu li.current-menu-item > a {
  background: color-mix(in oklab, var(--ol-forest-900) 6%, transparent) !important;
  color: var(--ol-forest-800) !important;
  padding-left: calc(var(--sp-5) + 4px) !important;
}
/* Caret arrows next to parent menu items */
body.home .site-header .header-menu-container .menu-item-has-children > a .nav-drop-title-wrap svg,
body.home .site-header .header-menu-container .dropdown-nav-special-toggle svg {
  stroke: var(--ol-forest-800) !important;
  color: var(--ol-forest-800) !important;
}

/* Cart / account icons */
body.home .site-header .header-cart-button,
body.home .site-header .header-account-button {
  color: var(--ol-ink-900) !important;
  background: color-mix(in oklab, var(--ol-cream-50) 60%, transparent) !important;
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 10%, transparent) !important;
  border-radius: var(--ol-radius-pill) !important;
  padding: var(--sp-3) var(--sp-4) !important;
  backdrop-filter: blur(8px);
}

/* Hide the top "free shipping" info bar on home — distracts from the luxe feel.
   Re-enable site-wide elsewhere by not scoping to .home if desired. */
/* Keep the rotating announcement ticker but restyle it to match the
   luxury palette. Original JS may or may not exist — we provide our
   own rotation below just in case. */
.ol-ticker {
  position: relative;
  z-index: 600;
  background: var(--ol-forest-900);
  color: var(--ol-cream-50);
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-xs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-align: center;
  padding: var(--sp-3) var(--sp-4);
}
.ol-ticker-track {
  position: relative;
  display: block;
  min-height: 1.5em;
}
.ol-ticker-item {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .5s var(--ol-ease), transform .5s var(--ol-ease);
  pointer-events: none;
}
.ol-ticker-item.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.ol-ticker-item em {
  font-style: normal;
  opacity: .75;
  margin-left: .4em;
}
/* Hide any legacy broken ticker DOM that the prior theme may still inject */
body.home .ol-announcement-track,
body.home .ol-announcement-item { display: none !important; }

/* Our fresh ticker sits above the fixed header */
.ol-ticker { position: fixed; top: 0; left: 0; right: 0; }
body.home .site-header { top: 34px !important; }
body.home .ol-hero { padding-top: 34px; }

/* Push the hero up under the transparent header */
body.home .ol-hero { margin-top: 0; }

/* ============================================================
   BUTTONS (shared)
   ============================================================ */
.ol-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-4) var(--sp-8);
  border-radius: var(--ol-radius-pill);
  font-family: var(--ol-font-body);
  font-weight: 500;
  font-size: var(--ol-fs-sm);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  transition: all var(--ol-dur) var(--ol-ease);
  border: 1px solid transparent;
  cursor: pointer;
  line-height: 1;
}
.ol-btn--dark {
  background: var(--ol-forest-900);
  color: var(--ol-cream-50);
  box-shadow: var(--ol-shadow-md);
}
.ol-hero .ol-btn--dark {
  padding: var(--sp-5) var(--sp-10);
  font-size: var(--ol-fs-base);
  letter-spacing: 0.14em;
}
.ol-btn--dark:hover {
  background: var(--ol-forest-800);
  transform: translateY(-1px);
  box-shadow: var(--ol-shadow-lg);
}
.ol-btn--ghost {
  background: transparent;
  color: var(--ol-forest-900);
  border-color: color-mix(in oklab, var(--ol-forest-900) 30%, transparent);
}
.ol-btn--ghost:hover {
  background: color-mix(in oklab, var(--ol-forest-900) 6%, transparent);
}

.ol-eyebrow {
  display: inline-block;
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-xs);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ol-forest-800);
  padding: var(--sp-2) var(--sp-4);
  border: 1px solid color-mix(in oklab, var(--ol-forest-800) 25%, transparent);
  border-radius: var(--ol-radius-pill);
  background: color-mix(in oklab, var(--ol-cream-50) 70%, transparent);
  backdrop-filter: blur(6px);
}

/* ============================================================
   HERO
   ============================================================ */
.ol-hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  width: 100%;
  overflow: hidden;
  isolation: isolate;
  display: flex;
  align-items: center;
}

.ol-hero__bg {
  position: absolute;
  inset: 0;
  background-image: url('assets/images/hero-bg.jpg');
  background-size: cover;
  background-position: center;
  z-index: -2;
  transform: scale(1.02);
}

/* Soft readability veil over the hero image — cream on the copy
   side fading to transparent, keeping the silk alive on the right. */
.ol-hero__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient( 95deg,
      color-mix(in oklab, var(--ol-cream-100) 82%, transparent) 0%,
      color-mix(in oklab, var(--ol-cream-100) 55%, transparent) 38%,
      color-mix(in oklab, var(--ol-cream-100) 10%, transparent) 62%,
      transparent 100%);
}

.ol-hero__inner {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  align-items: center;
  gap: var(--sp-16);
  padding-block: var(--sp-24);
}

.ol-hero__copy { max-width: 38rem; }

.ol-hero__title {
  font-size: clamp(3rem, 6.5vw, var(--ol-fs-6xl));
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin-block: var(--sp-6) var(--sp-6);
  color: var(--ol-ink-900);
  font-weight: 500;
}
.ol-hero__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--ol-forest-800);
}

.ol-hero__lede {
  font-size: var(--ol-fs-lg);
  line-height: 1.6;
  color: var(--ol-text-soft);
  max-width: 32rem;
  margin-block: 0 var(--sp-10);
}

.ol-hero__cta-row {
  display: flex;
  align-items: center;
  gap: var(--sp-6);
  flex-wrap: wrap;
}

/* Floating cards column */
.ol-hero__cards {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  align-items: flex-end;
}

.ol-card {
  background: color-mix(in oklab, var(--ol-cream-50) 92%, transparent);
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 8%, transparent);
  border-radius: var(--ol-radius-lg);
  padding: var(--sp-6) var(--sp-6);
  box-shadow: var(--ol-shadow-lg);
  backdrop-filter: blur(16px) saturate(1.1);
  max-width: 22rem;
  width: 100%;
  transition: transform var(--ol-dur) var(--ol-ease);
}
.ol-card:hover { transform: translateY(-2px); }

.ol-card--trust {
  transform: rotate(-1.2deg);
  padding: var(--sp-5);
}
.ol-card--trust:hover { transform: rotate(-1.2deg) translateY(-2px); }
.ol-card--trust .trustpilot-widget {
  width: 100%;
  min-height: 150px;
}
.ol-card--trust iframe { width: 100% !important; border: 0 !important; }

.ol-card__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--ol-fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ol-forest-800);
  margin-bottom: var(--sp-3);
  font-weight: 600;
}
.ol-stars {
  color: var(--ol-gold-500);
  font-size: var(--ol-fs-base);
  letter-spacing: 0.1em;
}
.ol-card__quote {
  font-family: var(--ol-font-display);
  font-style: italic;
  font-size: var(--ol-fs-xl);
  line-height: 1.3;
  color: var(--ol-ink-900);
  margin: 0 0 var(--sp-3);
}
.ol-card__meta {
  font-size: var(--ol-fs-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ol-text-soft);
  margin: 0;
}

.ol-card--product {
  transform: rotate(1.5deg) translateX(-1rem);
  padding: var(--sp-5) var(--sp-6) var(--sp-6);
  position: relative;
  max-width: 21rem;
  text-align: center;
}
.ol-card--product .ol-card__badge { display: inline-block; }
.ol-card--product:hover { transform: rotate(1.5deg) translateX(-1rem) translateY(-2px); }

/* Style the Woo [products] output inside the card so it feels native.
   Woo wraps in .woocommerce > ul.products > li.product. */
.ol-card--product .woocommerce { margin: 0 !important; }
.ol-card--product ul.products {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: block !important;
}
.ol-card--product ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  background: transparent !important;
}
.ol-card--product ul.products li.product {
  text-align: center !important;
}
.ol-card--product ul.products li.product .attachment-woocommerce_thumbnail,
.ol-card--product ul.products li.product img {
  border-radius: var(--ol-radius-md) !important;
  margin: 0 auto var(--sp-4) !important;
  height: 250px !important;
  width: auto !important;
  max-width: 100% !important;
  object-fit: contain !important;
  display: block !important;
  background: linear-gradient(160deg, var(--ol-cream-200), var(--ol-sage-100));
  padding: var(--sp-3) var(--sp-4);
  box-sizing: border-box;
}
.ol-card--product ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--ol-font-display) !important;
  font-size: var(--ol-fs-xl) !important;
  font-weight: 500 !important;
  color: var(--ol-ink-900) !important;
  padding: 0 !important;
  margin: 0 auto var(--sp-2) !important;
  line-height: 1.2 !important;
  text-align: center !important;
}
.ol-card--product ul.products li.product .price {
  color: var(--ol-forest-800) !important;
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-base) !important;
  font-weight: 500 !important;
  margin: 0 auto var(--sp-3) !important;
  line-height: 1.25 !important;
  text-align: center !important;
  display: block !important;
}
/* Tighten any variant / attribute selector Woo renders — centered */
.ol-card--product ul.products li.product .variations,
.ol-card--product ul.products li.product .variations_form,
.ol-card--product ul.products li.product .attribute_pa_size,
.ol-card--product ul.products li.product .kadence-woo-variation-wrap {
  font-size: var(--ol-fs-sm) !important;
  margin: 0 auto var(--sp-3) !important;
  text-align: center !important;
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
}
.ol-card--product ul.products li.product .kadence-woo-variation-item,
.ol-card--product ul.products li.product .kadence-woo-variation-item-btn,
.ol-card--product ul.products li.product select,
.ol-card--product ul.products li.product .variations td {
  font-size: var(--ol-fs-sm) !important;
  padding: 6px 14px !important;
  min-height: 0 !important;
  line-height: 1.2 !important;
}
.ol-card--product ul.products li.product .price del { opacity: .5; }
.ol-card--product ul.products li.product .button {
  display: inline-flex !important;
  align-items: center;
  background: var(--ol-forest-900) !important;
  color: var(--ol-cream-50) !important;
  border-radius: var(--ol-radius-pill) !important;
  padding: var(--sp-3) var(--sp-6) !important;
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  margin: 0 !important;
  border: 0 !important;
  transition: all var(--ol-dur) var(--ol-ease) !important;
}
.ol-card--product ul.products li.product .button:hover {
  background: var(--ol-forest-800) !important;
  transform: translateY(-1px);
}
.ol-card--product ul.products li.product .added_to_cart {
  display: none !important;
}
.ol-card__badge {
  display: inline-block;
  font-size: var(--ol-fs-xs);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ol-cream-50);
  background: var(--ol-forest-800);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--ol-radius-sm);
  margin-bottom: var(--sp-4);
}
.ol-card__product-img {
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--ol-cream-200), var(--ol-sage-100));
  border-radius: var(--ol-radius-md);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-4);
}
.ol-card__product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ol-card__product-title {
  font-family: var(--ol-font-display);
  font-size: var(--ol-fs-2xl);
  margin: 0 0 var(--sp-1);
  color: var(--ol-ink-900);
}
.ol-card__product-sub {
  font-size: var(--ol-fs-sm);
  color: var(--ol-text-soft);
  margin: 0 0 var(--sp-4);
}
.ol-card__cta {
  display: inline-block;
  font-size: var(--ol-fs-xs);
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ol-forest-800);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 2px;
}

/* ============================================================
   FOOTER — dark forest, atmospheric
   ============================================================ */

/* Hide Kadence's default footer on the home page — we render our
   own. wp_footer() is still fired so scripts stay intact. */
body.home .site-footer { display: none !important; }

.ol-footer {
  position: relative;
  color: var(--ol-cream-50);
  padding: clamp(var(--sp-20), 10vw, var(--sp-24)) 0 var(--sp-10);
  overflow: hidden;
  isolation: isolate;
}
.ol-footer__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: url('assets/images/footer-bg.jpg');
  background-size: cover;
  background-position: center;
}
.ol-footer__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--ol-forest-900) 82%, transparent) 0%,
      color-mix(in oklab, var(--ol-forest-900) 65%, transparent) 40%,
      color-mix(in oklab, var(--ol-forest-900) 92%, transparent) 100%);
}

.ol-footer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.ol-footer__brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-12);
}
.ol-footer__logo-svg {
  display: block;
  width: clamp(240px, 28vw, 360px);
  height: auto;
  margin: 0 auto var(--sp-4);
  color: var(--ol-gold-400);
  overflow: visible;
}
/* The SVG has exactly 10 direct-child <path> elements — the 9
   "Oasis Labs" letters plus the single outer triangle outline.
   Every interior detail (moon, mountain, palm fronds, stars) lives
   inside a nested <mask>/<g> and is therefore NOT a direct child,
   so the `>` combinator naturally excludes them. */
.ol-footer__logo-svg > path {
  stroke: var(--ol-gold-400);
  stroke-width: 0.5;
  stroke-linejoin: round;
  stroke-linecap: round;
  paint-order: stroke fill;
  vector-effect: non-scaling-stroke;
}
.ol-footer__tag {
  font-family: var(--ol-font-display);
  font-size: var(--ol-fs-lg);
  font-style: italic;
  color: var(--ol-cream-50);
  margin: 0;
}
.ol-footer__tag em {
  color: var(--ol-gold-400);
  font-style: italic;
}

.ol-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(var(--sp-8), 5vw, var(--sp-20));
  width: 100%;
  max-width: 56rem;
  margin-bottom: var(--sp-16);
  text-align: left;
}
.ol-footer__col h4 {
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-xs);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ol-gold-400);
  margin: 0 0 var(--sp-5);
}
.ol-footer__col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.ol-footer__col a {
  font-size: var(--ol-fs-sm);
  color: color-mix(in oklab, var(--ol-cream-50) 85%, transparent);
  text-decoration: none;
  transition: color var(--ol-dur) var(--ol-ease);
}
.ol-footer__col a:hover {
  color: var(--ol-cream-50);
}

.ol-footer__divider {
  width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, color-mix(in oklab, var(--ol-gold-400) 30%, transparent), transparent);
  margin-bottom: var(--sp-10);
}

.ol-footer__disclaimer {
  max-width: 58rem;
  font-size: var(--ol-fs-xs);
  line-height: 1.7;
  color: color-mix(in oklab, var(--ol-cream-50) 62%, transparent);
  margin: 0 auto var(--sp-12);
  letter-spacing: 0.01em;
}

.ol-footer__bar {
  width: 100%;
  max-width: 56rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
  padding-top: var(--sp-6);
  border-top: 1px solid color-mix(in oklab, var(--ol-cream-50) 10%, transparent);
}
.ol-footer__copy,
.ol-footer__legal {
  font-size: var(--ol-fs-xs);
  color: color-mix(in oklab, var(--ol-cream-50) 70%, transparent);
  margin: 0;
  letter-spacing: 0.04em;
}
.ol-footer__legal a {
  color: color-mix(in oklab, var(--ol-cream-50) 70%, transparent);
  text-decoration: none;
  margin: 0 var(--sp-2);
}
.ol-footer__legal a:hover { color: var(--ol-gold-400); }
.ol-footer__legal span { color: color-mix(in oklab, var(--ol-cream-50) 30%, transparent); }

@media (max-width: 720px) {
  .ol-footer__nav { grid-template-columns: 1fr; text-align: center; gap: var(--sp-8); }
  .ol-footer__col ul { align-items: center; }
  .ol-footer__bar { justify-content: center; text-align: center; }
}

/* ============================================================
   HOW IT WORKS — dark forest accordion
   ============================================================ */
.ol-how {
  position: relative;
  background: var(--ol-forest-900);
  color: var(--ol-cream-50);
  padding: clamp(var(--sp-20), 12vw, var(--sp-32)) 0;
  overflow: hidden;
  isolation: isolate;
}
.ol-how__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background-image: url('assets/images/footer-bg.jpg');
  background-size: cover;
  background-position: center;
}
.ol-how::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg,
      color-mix(in oklab, var(--ol-forest-900) 72%, transparent) 0%,
      color-mix(in oklab, var(--ol-forest-900) 55%, transparent) 50%,
      color-mix(in oklab, var(--ol-forest-900) 85%, transparent) 100%);
  pointer-events: none;
}
.ol-how__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
  gap: clamp(var(--sp-12), 6vw, var(--sp-20));
  align-items: start;
}
.ol-how__header { position: sticky; top: 120px; }
.ol-how__title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.02;
  color: var(--ol-cream-50);
  margin: var(--sp-5) 0 var(--sp-5);
  letter-spacing: -0.015em;
}
.ol-how__title em {
  font-style: italic;
  color: var(--ol-gold-400);
  font-weight: 500;
}
.ol-how__lede {
  font-size: var(--ol-fs-lg);
  color: color-mix(in oklab, var(--ol-cream-50) 80%, transparent);
  line-height: 1.6;
  margin: 0;
  max-width: 26rem;
}
.ol-eyebrow--dark {
  color: var(--ol-gold-400);
  background: transparent;
  border-color: color-mix(in oklab, var(--ol-gold-400) 35%, transparent);
  backdrop-filter: none;
}

/* Accordion items */
.ol-how__accordion {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.ol-acc {
  background: color-mix(in oklab, var(--ol-cream-50) 4%, transparent);
  border: 1px solid color-mix(in oklab, var(--ol-cream-50) 10%, transparent);
  border-radius: var(--ol-radius-lg);
  overflow: hidden;
  transition: all var(--ol-dur) var(--ol-ease);
}
.ol-acc[open] {
  background: color-mix(in oklab, var(--ol-cream-50) 7%, transparent);
  border-color: color-mix(in oklab, var(--ol-gold-400) 28%, transparent);
}
.ol-acc summary {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  padding: var(--sp-6) var(--sp-8);
  font-family: var(--ol-font-display);
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  font-weight: 500;
  color: var(--ol-cream-50);
  cursor: pointer;
  list-style: none;
  transition: color var(--ol-dur) var(--ol-ease);
}
.ol-acc summary::-webkit-details-marker { display: none; }
.ol-acc summary:hover { color: var(--ol-gold-400); }
.ol-acc__num {
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-xs);
  font-weight: 500;
  letter-spacing: 0.14em;
  color: var(--ol-gold-400);
  border: 1px solid color-mix(in oklab, var(--ol-gold-400) 40%, transparent);
  border-radius: var(--ol-radius-pill);
  padding: 6px 10px;
  flex: 0 0 auto;
}
.ol-acc__chevron {
  margin-left: auto;
  width: 2.25rem;
  height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: color-mix(in oklab, var(--ol-cream-50) 10%, transparent);
  color: var(--ol-cream-50);
  font-size: 1.5rem;
  font-weight: 300;
  transition: transform var(--ol-dur) var(--ol-ease), background var(--ol-dur) var(--ol-ease);
  flex: 0 0 auto;
}
.ol-acc[open] .ol-acc__chevron {
  transform: rotate(45deg);
  background: var(--ol-gold-500);
  color: var(--ol-ink-900);
}
.ol-acc > p {
  padding: 0 var(--sp-8) var(--sp-8) calc(var(--sp-8) + 3.75rem + var(--sp-5));
  margin: 0;
  font-size: var(--ol-fs-base);
  line-height: 1.7;
  color: color-mix(in oklab, var(--ol-cream-50) 82%, transparent);
}
@media (max-width: 820px) {
  .ol-how__inner { grid-template-columns: 1fr; }
  .ol-how__header { position: static; }
  .ol-acc summary { padding: var(--sp-5); gap: var(--sp-3); font-size: 1.125rem; }
  .ol-acc > p { padding: 0 var(--sp-5) var(--sp-5) var(--sp-5); }
}

/* ============================================================
   LEADERS IN PRECISION
   ============================================================ */
.ol-leaders {
  background: var(--ol-cream-100);
  padding: clamp(var(--sp-20), 10vw, var(--sp-32)) 0;
}
.ol-leaders__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: clamp(var(--sp-12), 6vw, var(--sp-20));
  align-items: center;
}
.ol-leaders__title {
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.02;
  color: var(--ol-ink-900);
  margin: var(--sp-5) 0 var(--sp-5);
  letter-spacing: -0.015em;
}
.ol-leaders__title em {
  font-style: italic;
  color: var(--ol-forest-800);
  font-weight: 500;
}
.ol-leaders__lede {
  font-size: var(--ol-fs-lg);
  line-height: 1.55;
  color: var(--ol-text-soft);
  margin: 0 0 var(--sp-10);
  max-width: 36rem;
}
.ol-leaders__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.ol-leaders__list li {
  display: flex;
  gap: var(--sp-5);
  align-items: flex-start;
  padding-left: 0;
}
.ol-leaders__dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: var(--ol-forest-900);
  color: var(--ol-gold-500);
  font-size: var(--ol-fs-base);
  flex: 0 0 auto;
  margin-top: 2px;
}
.ol-leaders__list h3 {
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-base);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin: 0 0 var(--sp-1);
  color: var(--ol-ink-900);
}
.ol-leaders__list p {
  font-size: var(--ol-fs-sm);
  color: var(--ol-text-soft);
  line-height: 1.55;
  margin: 0;
}
.ol-leaders__gallery {
  position: relative;
  min-height: 540px;
}
.ol-leaders__img {
  position: absolute;
  border-radius: var(--ol-radius-lg);
  box-shadow: var(--ol-shadow-lg);
  transition: transform var(--ol-dur) var(--ol-ease);
}
.ol-leaders__img--primary {
  top: 0;
  left: 0;
  width: 78%;
  transform: rotate(-2deg);
  z-index: 2;
}
.ol-leaders__img--secondary {
  bottom: 0;
  right: 0;
  width: 52%;
  transform: rotate(3deg);
  z-index: 3;
}
.ol-leaders__img:hover { transform: scale(1.02); }
@media (max-width: 900px) {
  .ol-leaders__inner { grid-template-columns: 1fr; }
  .ol-leaders__gallery { min-height: auto; display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
  .ol-leaders__img { position: static; width: 100% !important; transform: none !important; }
}

/* ============================================================
   FEATURED PRODUCTS GRID
   ============================================================ */
.ol-products {
  background: var(--ol-cream-50);
  padding: clamp(var(--sp-20), 10vw, var(--sp-32)) 0 clamp(var(--sp-16), 8vw, var(--sp-24));
}
.ol-products__header {
  text-align: center;
  max-width: 52rem;
  margin: 0 auto var(--sp-10);
}
.ol-products__title {
  font-size: clamp(2.25rem, 4vw, 3.25rem);
  line-height: 1.05;
  color: var(--ol-ink-900);
  margin: var(--sp-5) 0 var(--sp-4);
}
.ol-products__lede {
  font-size: var(--ol-fs-lg);
  color: var(--ol-text-soft);
  line-height: 1.6;
  margin: 0;
}

/* Category tabs */
.ol-products__tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-2);
  margin: 0 auto var(--sp-12);
  padding: var(--sp-2);
  background: var(--ol-cream-100);
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 8%, transparent);
  border-radius: var(--ol-radius-pill);
  width: fit-content;
  max-width: 100%;
}
.ol-tab {
  display: inline-flex;
  align-items: center;
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--ol-radius-pill);
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ol-text-soft);
  text-decoration: none;
  transition: all var(--ol-dur) var(--ol-ease);
  white-space: nowrap;
}
.ol-tab:hover { color: var(--ol-forest-800); background: color-mix(in oklab, var(--ol-cream-50) 60%, transparent); }
.ol-tab.is-active {
  background: var(--ol-forest-900);
  color: var(--ol-cream-50);
  box-shadow: var(--ol-shadow-sm);
}

/* Grid — override Woo's default loop styling */
.ol-products__grid .woocommerce {
  margin: 0 !important;
}
.ol-products__grid ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: var(--sp-6) !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.ol-products__grid ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: var(--sp-5) !important;
  float: none !important;
  background: var(--ol-cream-50) !important;
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 8%, transparent) !important;
  border-radius: var(--ol-radius-lg) !important;
  display: flex !important;
  flex-direction: column !important;
  text-align: center !important;
  transition: all var(--ol-dur) var(--ol-ease) !important;
  box-shadow: 0 1px 2px rgba(20,32,26,.04);
}
.ol-products__grid ul.products li.product.ol-hide,
.ol-card--product ul.products li.product.ol-hide { display: none !important; }
.ol-products__grid ul.products li.product:hover {
  transform: translateY(-4px);
  box-shadow: var(--ol-shadow-md);
  border-color: color-mix(in oklab, var(--ol-forest-900) 20%, transparent) !important;
}
.ol-products__grid ul.products li.product a.woocommerce-LoopProduct-link {
  display: flex !important;
  flex-direction: column !important;
  text-decoration: none !important;
  color: inherit !important;
}
.ol-products__grid ul.products li.product img {
  aspect-ratio: 1 / 1 !important;
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  object-fit: contain !important;
  background: linear-gradient(160deg, var(--ol-cream-100), var(--ol-sage-100));
  border-radius: var(--ol-radius-md) !important;
  padding: var(--sp-5) !important;
  margin: 0 0 var(--sp-4) !important;
  box-sizing: border-box;
}
.ol-products__grid ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--ol-font-display) !important;
  font-size: var(--ol-fs-xl) !important;
  font-weight: 500 !important;
  line-height: 1.15 !important;
  color: var(--ol-ink-900) !important;
  padding: 0 !important;
  margin: 0 0 var(--sp-2) !important;
  min-height: 2.6em;
}
.ol-products__grid ul.products li.product .price {
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-sm) !important;
  font-weight: 500 !important;
  color: var(--ol-forest-800) !important;
  margin: 0 0 var(--sp-4) !important;
  display: block !important;
}
.ol-products__grid ul.products li.product .price del { opacity: .5; margin-right: 4px; }
.ol-products__grid ul.products li.product .price ins { text-decoration: none; }

/* Variant / size selector buttons */
.ol-products__grid ul.products li.product .kadence-woo-variation-wrap,
.ol-products__grid ul.products li.product .variations_form {
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin: 0 0 var(--sp-3) !important;
  font-size: var(--ol-fs-xs) !important;
}
.ol-products__grid ul.products li.product .kadence-woo-variation-item,
.ol-products__grid ul.products li.product select {
  font-size: var(--ol-fs-xs) !important;
  padding: 4px 10px !important;
}

/* Add to cart pinned at the bottom — push via margin-top:auto */
.ol-products__grid ul.products li.product .button,
.ol-products__grid ul.products li.product .add_to_cart_button {
  margin-top: auto !important;
  align-self: stretch !important;
  display: block !important;
  background: var(--ol-forest-900) !important;
  color: var(--ol-cream-50) !important;
  border: 0 !important;
  border-radius: var(--ol-radius-pill) !important;
  padding: var(--sp-3) var(--sp-5) !important;
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  text-align: center !important;
  transition: all var(--ol-dur) var(--ol-ease) !important;
  cursor: pointer;
}
.ol-products__grid ul.products li.product .button:hover,
.ol-products__grid ul.products li.product .add_to_cart_button:hover {
  background: var(--ol-forest-800) !important;
  transform: translateY(-1px);
}
.ol-products__grid ul.products li.product .added_to_cart { display: none !important; }
.ol-products__grid ul.products li.product .onsale {
  background: var(--ol-gold-500) !important;
  color: var(--ol-ink-900) !important;
  font-family: var(--ol-font-body) !important;
  font-size: var(--ol-fs-xs) !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  padding: 4px 10px !important;
  border-radius: var(--ol-radius-pill) !important;
  min-height: 0 !important;
  min-width: 0 !important;
  line-height: 1 !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
}

.ol-products__footer {
  text-align: center;
  margin-top: var(--sp-12);
}
.ol-btn--lg {
  padding: var(--sp-5) var(--sp-10) !important;
  font-size: var(--ol-fs-base) !important;
}

@media (max-width: 1100px) {
  .ol-products__grid ul.products { grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
}
@media (max-width: 820px) {
  .ol-products__grid ul.products { grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
}
@media (max-width: 480px) {
  .ol-products__grid ul.products { grid-template-columns: 1fr !important; }
}

/* ============================================================
   MARQUEE — infinite trust-signal loop
   ============================================================ */
.ol-marquee {
  position: relative;
  width: 100%;
  background: var(--ol-forest-900);
  color: var(--ol-cream-50);
  overflow: hidden;
  padding: var(--sp-6) 0;
  border-block: 1px solid color-mix(in oklab, var(--ol-cream-50) 12%, transparent);
}
.ol-marquee::before,
.ol-marquee::after {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  width: 12%;
  z-index: 2;
  pointer-events: none;
}
.ol-marquee::before {
  left: 0;
  background: linear-gradient(90deg, var(--ol-forest-900), transparent);
}
.ol-marquee::after {
  right: 0;
  background: linear-gradient(-90deg, var(--ol-forest-900), transparent);
}
.ol-marquee__track {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  width: max-content;
  animation: ol-marquee-scroll 45s linear infinite;
  white-space: nowrap;
}
.ol-marquee__item {
  font-family: var(--ol-font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.5rem, 2.4vw, 2.25rem);
  letter-spacing: 0.01em;
  color: var(--ol-cream-50);
  line-height: 1;
}
.ol-marquee__dot {
  color: var(--ol-gold-500);
  font-size: 1rem;
  opacity: .8;
}
@keyframes ol-marquee-scroll {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .ol-marquee__track { animation-duration: 120s; }
}

/* ============================================================
   MISSION — Built on Trust
   ============================================================ */
.ol-mission {
  background: var(--ol-cream-100);
  padding: clamp(var(--sp-16), 10vw, var(--sp-32)) 0;
  position: relative;
}
.ol-mission__inner {
  max-width: 62rem;
  text-align: center;
}
.ol-mission__title {
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
  line-height: 1.05;
  color: var(--ol-ink-900);
  margin-block: var(--sp-6) var(--sp-8);
  letter-spacing: -0.015em;
}
.ol-mission__title em {
  font-style: italic;
  color: var(--ol-forest-800);
  font-weight: 500;
}
.ol-mission__body {
  font-size: var(--ol-fs-lg);
  line-height: 1.65;
  color: var(--ol-text-soft);
  max-width: 48rem;
  margin: 0 auto var(--sp-10);
}
.ol-mission__checks {
  list-style: none;
  padding: 0;
  margin: 0 auto var(--sp-10);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sp-3) var(--sp-6);
  max-width: 56rem;
}
.ol-mission__checks li {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  background: var(--ol-cream-50);
  border: 1px solid color-mix(in oklab, var(--ol-forest-900) 10%, transparent);
  border-radius: var(--ol-radius-pill);
  font-family: var(--ol-font-body);
  font-size: var(--ol-fs-sm);
  font-weight: 500;
  color: var(--ol-ink-900);
  letter-spacing: 0.04em;
}
.ol-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 999px;
  background: var(--ol-forest-700);
  color: var(--ol-cream-50);
  font-size: 0.75rem;
  font-weight: 600;
}
.ol-mission__note {
  font-family: var(--ol-font-display);
  font-style: italic;
  font-size: var(--ol-fs-lg);
  color: var(--ol-forest-800);
  margin: 0;
}

/* Hero responsive */
@media (max-width: 960px) {
  .ol-hero__inner {
    grid-template-columns: 1fr;
    gap: var(--sp-12);
    padding-block: var(--sp-16);
  }
  .ol-hero__cards { align-items: stretch; }
  .ol-card--product { transform: none; }
  .ol-card--trust { transform: none; }
  .ol-hero__title { font-size: clamp(2.5rem, 10vw, 4.5rem); }
}
