/* ==========================================================================
   Prolina Theme — Main Stylesheet
   Extracted 1:1 from new-design/index.html and extended with WooCommerce
   ========================================================================== */

/* ─── Design Tokens ──────────────────────────────────────────────────────── */
:root {
  --green-950: #060F05;
  --green-900: #0A1F08;
  --green-800: #1A3D10;
  --green-700: #244E18;
  --green-600: #3B6A28;
  --green-500: #6B9B5A;
  --green-400: #8CB87B;
  --sage-500:  #7AA86A;
  --sage-400:  #9DC29A;
  --sage-300:  #B7D4B2;
  --sage-200:  #D6E6D0;
  --sage-100:  #E5EFE2;
  --sage-50:   #F0F7EE;
  --cream:     #F5F1E8;
  --cream-2:   #EDE9DF;
  --paper:     #FBF8F1;
  --ink:       #0A1F08;
  --ink-2:     #3F5A36;
  --ink-3:     #6F8463;
  --line:      rgba(15,42,10,0.13);
  --line-soft: rgba(15,42,10,0.07);
  --ease:      cubic-bezier(.16,1,.3,1);
  --ease-in:   cubic-bezier(.4,0,1,1);
  --ease-std:  cubic-bezier(.65,0,.35,1);
}

/* ─── Reset ──────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0 }
html { scroll-behavior: smooth }
html, body {
  background: var(--cream);
  color: var(--ink);
  font-family: 'Barlow', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
body  { font-size: 15px; line-height: 1.55 }
img   { display: block; max-width: 100% }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit }
a     { color: inherit; text-decoration: none }

/* ─── Keyframes ──────────────────────────────────────────────────────────── */
@keyframes ticker      { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes float       { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes pulse-live  { 0%{transform:scale(.85);opacity:.8} 100%{transform:scale(1.7);opacity:0} }
@keyframes shimmer     { 0%{background-position:-300% 0} 100%{background-position:300% 0} }
@keyframes spin-slow   { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes orb         { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(22px,-18px) scale(1.06)} 66%{transform:translate(-16px,12px) scale(.96)} }
@keyframes wheel-breathe { 0%,100%{transform:scale(1)} 50%{transform:scale(1.016)} }
@keyframes toast-in    { from{transform:translateY(20px);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes bar-fill    { from{width:0} }
@keyframes thumb-sweep { from{width:0%} to{width:100%} }
@keyframes scroll-pulse { 0%,100%{opacity:.55} 50%{opacity:1} }

/* ─── Scroll Reveal ──────────────────────────────────────────────────────── */
.fade-up {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .85s var(--ease), transform .85s var(--ease);
}
.fade-up.visible { opacity: 1; transform: translateY(0) }

.stagger > * {
  opacity: 0; transform: translateY(20px);
  transition: opacity .65s var(--ease), transform .65s var(--ease);
}
.stagger.visible > *:nth-child(1) { opacity:1; transform:none; transition-delay:.04s }
.stagger.visible > *:nth-child(2) { opacity:1; transform:none; transition-delay:.13s }
.stagger.visible > *:nth-child(3) { opacity:1; transform:none; transition-delay:.22s }
.stagger.visible > *:nth-child(4) { opacity:1; transform:none; transition-delay:.31s }
.stagger.visible > *:nth-child(5) { opacity:1; transform:none; transition-delay:.40s }
.stagger.visible > *:nth-child(6) { opacity:1; transform:none; transition-delay:.49s }

@media (prefers-reduced-motion: reduce) {
  .fade-up, .stagger > * { transition: none; opacity: 1; transform: none }
  .announce-track, .stage-img, .bigcta-mark { animation: none }
}

/* ─── Type ───────────────────────────────────────────────────────────────── */
.label {
  font-family: 'Barlow Condensed', sans-serif;
  text-transform: uppercase; letter-spacing: .15em;
  font-weight: 700; font-size: 14px; color: var(--green-800);
}
.pg { max-width: 1320px; margin: 0 auto; padding: 0 28px }

/* ─── Announce Bar ───────────────────────────────────────────────────────── */
.announce {
  background: var(--green-900);
  color: var(--cream);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 500; font-size: 12px;
  letter-spacing: .22em; text-transform: uppercase;
  display: flex; align-items: center;
  overflow: hidden; white-space: nowrap;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.announce-track {
  display: inline-flex; align-items: center;
  animation: ticker 36s linear infinite; flex-shrink: 0;
}
.announce-item { display: inline-flex; align-items: center; gap: 16px; padding: 9px 22px }
.announce-dot  { width: 3px; height: 3px; border-radius: 50%; background: var(--sage-400); opacity: .6 }

/* ─── Nav ────────────────────────────────────────────────────────────────── */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 0;
  background: rgba(245,241,232,.88);
  backdrop-filter: blur(18px) saturate(1.5);
  -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; z-index: 100;
  transition: box-shadow .3s;
}
.nav.scrolled { box-shadow: 0 2px 24px rgba(15,42,10,.09) }
.brand { display: flex; align-items: center; gap: 12px; text-decoration: none; color: inherit; }
.brand-text { display: flex; flex-direction: column; line-height: 1 }
.brand-word { font-family: 'Barlow Condensed', sans-serif; font-weight: 800; font-size: 22px; letter-spacing: .04em; color: var(--green-800) }
.brand-tag  { font-family: 'Barlow Condensed', sans-serif; font-weight: 500; font-size: 9px; letter-spacing: .32em; color: var(--green-500); margin-top: 3px; text-transform: uppercase }
.nav-links { display: flex; gap: 36px; align-items: center }
.nav-links .nav-account { margin-left: -28px; }
.nav-links a {
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase;
  letter-spacing: .16em; font-weight: 500; font-size: 12px; color: var(--green-800);
  position: relative; transition: color .2s;
}
.nav-links a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -4px;
  height: 1px; background: var(--green-800);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease);
}
.nav-links a:hover::after { transform: scaleX(1) }
.nav-cart {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid var(--green-800); border-radius: 50%;
  color: var(--green-800); transition: all .25s var(--ease);
  flex-shrink: 0;
}
.nav-cart:hover { background: var(--green-800); color: var(--cream); transform: translateY(-1px) }
.nav-cart-count {
  position: absolute; top: -5px; right: -5px;
  min-width: 16px; height: 16px; padding: 0 3px;
  background: var(--green-800); color: var(--cream);
  border-radius: 999px; border: 1.5px solid var(--cream);
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  line-height: 1; letter-spacing: 0;
  display: inline-flex; align-items: center; justify-content: center;
  box-sizing: border-box;
  transition: background .25s var(--ease);
}
.nav-cart:hover .nav-cart-count { background: var(--cream); color: var(--green-800); border-color: var(--green-800); }
.nav-account {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid var(--green-800); border-radius: 50%;
  color: var(--green-800); transition: all .25s var(--ease); margin-left: 4px;
  flex-shrink: 0;
}
.nav-account:hover { background: var(--green-800); color: var(--cream); transform: translateY(-1px) }

/* ─── Cover Hero ─────────────────────────────────────────────────────────── */
.cover-hero {
  position: relative; width: 100%; height: 100vh; max-height: 100vh;
  overflow: hidden; display: flex; align-items: flex-end;
}
.cover-play-btn {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 84px; height: 84px; border-radius: 50%;
  background: var(--green-800); border: 2px solid rgba(255,255,255,.45);
  display: flex; align-items: center; justify-content: center;
  color: white; z-index: 10; cursor: pointer;
  transition: background .25s, transform .25s;
  box-shadow: 0 8px 32px rgba(0,0,0,.35);
}
.cover-play-btn:hover { background: var(--green-700); transform: translate(-50%,-50%) scale(1.07) }
.cover-hero-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center;
}
.cover-overlay {
  position: absolute; bottom: 0; left: 0; right: 0; height: 42%;
  background: linear-gradient(to top, rgba(4,12,3,0.78) 0%, transparent 100%);
  pointer-events: none; z-index: 1;
}
.cover-logo {
  position: absolute; top: 28px; left: 32px; z-index: 10;
  display: flex; flex-direction: column; gap: 3px;
}
.cover-logo-row { display: flex; align-items: center; gap: 10px; }
.cover-logo-wordmark {
  font-family: 'Barlow Condensed', sans-serif; font-size: 22px;
  font-weight: 700; color: white; letter-spacing: .18em;
  text-transform: uppercase; line-height: 1;
}
.cover-logo-tag {
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px;
  color: rgba(255,255,255,.65); letter-spacing: .22em; text-transform: uppercase;
  margin-left: 2px;
}
.cover-scroll {
  position: absolute; bottom: 36px; left: 50%;
  transform: translateX(-50%); z-index: 10;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  opacity: .55;
}
.cover-scroll-label { font-family: 'Barlow Condensed', sans-serif; font-size: 10px; color: white; letter-spacing: .28em; text-transform: uppercase; }
.cover-scroll-line  { width: 1px; height: 32px; background: white; animation: scroll-pulse 2s ease-in-out infinite; }
@media (max-width: 768px) {
  .cover-hero-img { object-position: center top }
  .cover-logo { top: 20px; left: 20px }
}

/* ─── Brand Intro Video ──────────────────────────────────────────────────── */
.brand-intro-vid-wrap {
  position: relative; width: 100%; max-width: 380px;
  aspect-ratio: 9/16; border-radius: 14px; overflow: hidden;
  background: var(--green-900);
  box-shadow: 0 24px 64px -24px rgba(15,42,10,.22);
}
.brand-intro-vid-wrap video { width: 100%; height: 100%; object-fit: cover; display: block; }
@media (max-width: 768px) { .brand-intro-vid-wrap { max-width: 100% } }

/* ─── Pricing Split (main product section) ──────────────────────────────── */
.pricing-split {
  display: grid;
  grid-template-columns: 60% 1fr;
  grid-template-rows: auto auto;
  column-gap: 32px;
  padding: 80px 48px;
  background: var(--cream);
  border-top: 1px solid var(--line);
  width: 100%;
  position: relative;
}
.ps-img-panel {
  grid-column: 1; grid-row: 1;
  border-radius: 12px; overflow: hidden;
  height: 600px; max-height: 600px;
}
.ps-main-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 40%; display: block;
  transition: opacity .35s ease;
}
.ps-img-controls {
  grid-column: 1; grid-row: 2;
  padding: 16px 0; display: flex; flex-direction: column; gap: 12px;
}
.ps-thumbs { display: flex; gap: 8px }
.ps-thumb {
  width: 56px; height: 56px; border-radius: 8px; overflow: hidden;
  cursor: pointer; border: 2px solid var(--line);
  transition: border-color .2s, transform .2s; flex-shrink: 0;
  background: var(--sage-100); position: relative;
}
.ps-thumb img { width: 100%; height: 100%; object-fit: cover; display: block }
.ps-thumb.active { border-color: var(--green-800) }
.ps-thumb:hover  { transform: translateY(-2px); border-color: var(--green-600) }
.ps-thumb-progress {
  position: absolute; bottom: 0; left: 0; height: 2px;
  width: 0%; background: var(--green-800); border-radius: 0 2px 0 0;
}
.ps-thumb.active .ps-thumb-progress { animation: thumb-sweep 3.5s linear forwards }
.ps-badges { display: flex; gap: 8px; flex-wrap: wrap }
.ps-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(10,31,8,.06); border: 1px solid var(--line);
  border-radius: 100px; padding: 5px 12px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; color: var(--ink-2);
}
.ps-badge-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--sage-500); flex-shrink: 0 }
.ps-right {
  grid-column: 2; grid-row: 1;
  display: flex; flex-direction: column;
  height: 600px; max-height: 600px;
}
.ps-right .selector { flex: 1; overflow-y: auto }
.ps-header { margin-bottom: 24px }
.ps-header-label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .15em; color: var(--ink-3);
  display: block; margin-bottom: 10px;
}
.ps-header-h2 {
  font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
  text-transform: uppercase; font-size: clamp(26px, 2.8vw, 44px);
  line-height: .95; color: var(--ink); letter-spacing: -.005em;
}
.ps-header-h2 span { color: var(--ink-3); font-style: italic; font-weight: 500 }
@media (max-width: 768px) {
  .pricing-split { display: flex; flex-direction: column; padding: 0; }
  .ps-img-panel  { height: 380px; max-height: 380px; border-radius: 0; order: 1 }
  .ps-img-controls { padding: 16px 20px; order: 2 }
  .ps-thumbs { overflow-x: auto; padding-bottom: 4px }
  .ps-right  { height: auto; max-height: none; order: 3 }
  .ps-right .selector { flex: none; overflow-y: visible; border-radius: 0; border: none; box-shadow: none; background: var(--cream); padding: 24px 20px 48px; }
  .ps-header { margin-bottom: 20px }
}

/* ─── Hero (product detail layout — classes reused) ─────────────────────── */
.hero {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px;
  padding: 48px 0 80px; align-items: start;
  position: relative; overflow: hidden;
}
.hero::before {
  content: ''; position: absolute; top: 60px; right: -180px;
  width: 480px; height: 480px; border-radius: 50%;
  background: radial-gradient(circle, rgba(157,194,154,.35), transparent 70%);
  filter: blur(55px); animation: orb 20s ease-in-out infinite;
  pointer-events: none; z-index: 0;
}
.hero > * { position: relative; z-index: 1; }
.stage {
  position: relative;
  background: linear-gradient(145deg, var(--sage-50), var(--sage-200));
  border-radius: 14px; aspect-ratio: 4/5; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--line-soft);
  box-shadow: 0 24px 64px -24px rgba(15,42,10,.22), 0 0 0 1px var(--line-soft);
}
.stage::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at 28% 18%, rgba(255,255,255,.42), transparent 52%);
  pointer-events: none;
}
.stage-img {
  position: absolute; inset: 0; z-index: 1;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  transition: transform .6s var(--ease), opacity .35s ease;
}
.stage:hover .stage-img { transform: scale(1.04) }
.badge-fresh {
  position: absolute; top: 18px; right: 18px;
  background: var(--green-800); color: var(--cream);
  padding: 7px 13px; border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif;
  text-transform: uppercase; font-size: 10px; letter-spacing: .18em; font-weight: 600;
  display: flex; align-items: center; gap: 9px; z-index: 3;
}
.badge-pulse {
  position: relative; width: 7px; height: 7px; border-radius: 50%; background: var(--sage-400);
}
.badge-pulse::after {
  content: ''; position: absolute; inset: -2px; border-radius: 50%;
  background: var(--sage-400); animation: pulse-live 2s ease-out infinite;
}
.thumbs { display: grid; grid-template-columns: repeat(5,1fr); gap: 8px; margin-top: 14px }
.thumb {
  aspect-ratio: 1; background: var(--sage-100); border: 1px solid var(--line-soft);
  border-radius: 8px; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .25s var(--ease); overflow: hidden; position: relative;
}
.thumb.active { border-color: var(--green-800); border-width: 1.5px; box-shadow: 0 4px 12px rgba(15,42,10,.12) }
.thumb:hover  { transform: translateY(-2px) }
.thumb img    { width: 100%; height: 100%; object-fit: cover }
.thumb-progress {
  position: absolute; bottom: 0; left: 0; height: 2.5px;
  width: 0%; background: var(--green-700); border-radius: 0 2px 0 0;
}
.thumb.active .thumb-progress { animation: thumb-sweep 3.5s linear forwards }
.thumb .placeholder {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  color: var(--green-500); font-family: 'Barlow Condensed'; font-size: 10px;
  letter-spacing: .18em; text-transform: uppercase;
  background: repeating-linear-gradient(45deg, var(--sage-100) 0 6px, var(--sage-200) 6px 12px);
}

/* ─── Billing Tabs ───────────────────────────────────────────────────────── */
.billing-tabs {
  display: flex; align-items: center; gap: 3px;
  background: var(--sage-100); border: 1px solid var(--line-soft);
  border-radius: 10px; padding: 4px; margin-bottom: 16px;
}
.btab {
  flex: 1; padding: 7px 10px; border: none; background: transparent;
  border-radius: 7px; font-family: 'Barlow Condensed'; font-size: 11px;
  letter-spacing: .12em; text-transform: uppercase; font-weight: 600;
  color: var(--ink-2); cursor: pointer; transition: all .2s var(--ease);
  white-space: nowrap; line-height: 1;
}
.btab.active { background: #fff; color: var(--green-800); box-shadow: 0 1px 4px rgba(15,42,10,.12) }
.btab-sep    { width: 1px; height: 18px; background: var(--line); flex-shrink: 0; margin: 0 2px }
.btab-one.active { background: var(--green-800) !important; color: var(--cream) !important; box-shadow: 0 2px 8px rgba(15,42,10,.2) !important }

/* ─── One-Time Options ───────────────────────────────────────────────────── */
.onetime-opts {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-top: 4px;
}
.onetime-opt {
  padding: 14px 10px; border: 1px solid var(--line-soft); border-radius: 10px;
  background: var(--sage-50, #f8faf6); cursor: pointer; text-align: center;
  transition: all .2s var(--ease); display: flex; flex-direction: column;
  gap: 3px; align-items: center;
}
.onetime-opt.active { border-color: var(--green-800); border-width: 1.5px; background: var(--sage-100); box-shadow: 0 4px 12px rgba(15,42,10,.1) }
.onetime-opt:hover  { border-color: var(--green-500) }
.onetime-wt  { font-family: 'Barlow Condensed'; font-size: 22px; font-weight: 700; color: var(--green-800); letter-spacing: .02em }
.onetime-srv { font-size: 10px; color: var(--ink-3); font-family: 'Barlow Condensed'; letter-spacing: .1em; text-transform: uppercase }
.onetime-note {
  margin-top: 10px; padding: 9px 14px; background: rgba(157,194,154,.12);
  border-radius: 8px; font-size: 12px; color: var(--green-700, #3a6b35);
  font-family: 'Barlow Condensed'; letter-spacing: .06em; text-align: center;
  border: 1px solid rgba(157,194,154,.25);
}
.plan-grams { font-size: 10px; color: var(--ink-3); font-family: 'Barlow Condensed'; letter-spacing: .1em; text-transform: uppercase; margin-top: 1px }

/* ─── Benefit Cards ──────────────────────────────────────────────────────── */
.benefit-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 44px }
.bcard         { perspective: 1000px; height: 540px; cursor: pointer; user-select: none }
.bcard-inner   { position: relative; width: 100%; height: 100%; transition: transform .65s cubic-bezier(.4,0,.2,1); transform-style: preserve-3d }
.bcard.flipped .bcard-inner { transform: rotateY(180deg) }
.bcard-front, .bcard-back {
  position: absolute; inset: 0; backface-visibility: hidden;
  -webkit-backface-visibility: hidden; border-radius: 16px; padding: 32px 28px;
}
.bcard-front {
  background: var(--sage-100); border: 1px solid var(--line-soft);
  display: flex; flex-direction: column; align-items: center; gap: 20px;
  text-align: center; transition: background .2s; padding: 44px 32px 38px;
}
.bcard-front:hover { background: var(--sage-200, #daebd9) }
.bcard-front-title { font-family: 'Barlow Condensed'; font-size: 27px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--green-800) }
.bcard-front-points { list-style: none; padding: 0; margin: 0; width: 100%; text-align: left; flex: 1; display: flex; flex-direction: column; justify-content: space-evenly }
.bcard-front-point {
  font-size: 16px; color: var(--green-700); font-family: 'Barlow Condensed'; letter-spacing: .04em;
  padding: 10px 0; border-bottom: 1px solid var(--line-soft);
  display: flex; align-items: center; gap: 10px;
}
.bcard-front-point:last-child { border-bottom: none }
.bcard-hint   { font-size: 10px; color: var(--ink-3); letter-spacing: .1em; font-family: 'Barlow Condensed'; text-transform: uppercase }
.bcard-back   { background: var(--green-800, #1a3d10); color: var(--cream); transform: rotateY(180deg); display: flex; flex-direction: column; gap: 0; overflow: hidden }
.bcard-back-scroll { overflow-y: auto; flex: 1; padding-right: 6px; display: flex; flex-direction: column; gap: 24px }
.bcard-back-title  { font-family: 'Barlow Condensed'; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: var(--sage-400, #9dc29a); margin-bottom: 10px; flex-shrink: 0 }
.bcard-back-point  { display: flex; flex-direction: column; gap: 8px }
.bcard-back-point-title { font-family: 'Barlow Condensed'; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--sage-300, #c1dbbf) }
.bcard-back-point-desc  { font-size: 12px; line-height: 1.7; color: rgba(245,241,232,.85); margin: 0 }
.bcard-back-icon   { opacity: .18; margin-top: 10px; flex-shrink: 0; display: flex; justify-content: center }
.bcard-benefit     { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.5; color: rgba(245,241,232,.9) }
.bcard-dot         { width: 6px; height: 6px; border-radius: 50%; background: var(--sage-400, #9dc29a); flex-shrink: 0; margin-top: 2px }
.bcard-close       { flex-shrink: 0; padding-top: 10px; font-size: 10px; color: rgba(245,241,232,.35); font-family: 'Barlow Condensed'; letter-spacing: .1em; text-transform: uppercase; text-align: center }
.bcard-pill {
  display: inline-flex; align-items: center; gap: 6px;
  border: 1.5px solid var(--green-700); color: var(--green-700);
  background: transparent; border-radius: 100px;
  font-family: 'Barlow Condensed'; font-size: 11px; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 5px 14px; margin-top: auto; cursor: pointer;
  transition: background .2s, color .2s;
}
.bcard-front:hover .bcard-pill { background: var(--green-700); color: white }
@media (max-width: 640px) {
  .benefit-cards { grid-template-columns: 1fr; height: auto }
  .bcard { height: 480px }
}

/* ─── Lifestyle Quote Section ────────────────────────────────────────────── */
.lifestyle-section { display: grid; grid-template-columns: 1fr 1fr; min-height: 640px; overflow: hidden }
.lifestyle-img-wrap { position: relative; overflow: hidden }
.lifestyle-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: 60% 20%; display: block;
  transform: scale(1.6); transform-origin: 72% 32%;
}
.lifestyle-text { background: var(--green-800); display: flex; flex-direction: column; justify-content: center; padding: 80px 64px; gap: 28px }
.lifestyle-body { font-family: 'Barlow Condensed'; font-size: clamp(19px, 1.8vw, 26px); font-weight: 400; font-style: italic; color: rgba(245,241,232,.92); line-height: 1.4; margin: 0 }
.lifestyle-punch { font-family: 'Barlow Condensed'; font-size: clamp(42px, 4vw, 64px); font-weight: 700; color: var(--cream); line-height: 1.02; letter-spacing: -.01em; margin: 0 }
.lifestyle-rule  { width: 40px; height: 2px; background: var(--sage-400); border-radius: 1px }
@media (max-width: 1024px) { .lifestyle-text { padding: 64px 44px } }
@media (max-width: 768px) {
  .lifestyle-section { grid-template-columns: 1fr; min-height: unset }
  .lifestyle-img-wrap { aspect-ratio: 3/2; position: relative; min-height: unset }
  .lifestyle-text  { padding: 48px 24px; gap: 20px }
  .lifestyle-body  { font-size: 19px }
  .lifestyle-punch { font-size: 34px }
}
@media (max-width: 480px) {
  .lifestyle-img-wrap { aspect-ratio: 4/3 }
  .lifestyle-text  { padding: 36px 20px }
  .lifestyle-punch { font-size: 28px }
}

/* ─── Section Label Overrides ────────────────────────────────────────────── */
#benefits .label, #faq .label, #process .label, #subscribers .label {
  font-size: 14px !important; color: var(--green-800) !important; opacity: 1 !important;
  letter-spacing: .15em !important; font-weight: 700 !important;
}
.section-dark .label { color: var(--sage-300, #c1dbbf) !important }

/* ─── How-Split (video placeholder layout) ───────────────────────────────── */
.how-split { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center }
.how-split-text .label {
  font-size: 14px !important; color: var(--green-800) !important; opacity: 1 !important;
  letter-spacing: .15em !important; font-weight: 700 !important; display: block; margin-bottom: 14px;
}
.how-split-video { display: flex; flex-direction: column; align-items: center; gap: 14px }
@media (max-width: 768px) {
  .how-split { grid-template-columns: 1fr; gap: 36px }
}

/* ─── Sticky Subscribe Bar ───────────────────────────────────────────────── */
.sticky-bar {
  position: fixed; left: 0; right: 0; z-index: 300;
  background: var(--green-800); height: 60px;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 32px; gap: 16px;
  opacity: 0; pointer-events: none;
  transition: opacity .35s ease, transform .35s var(--ease, cubic-bezier(.4,0,.2,1));
}
.sticky-bar.visible { opacity: 1; pointer-events: auto }
.sticky-bar-price { font-family: 'Barlow Condensed'; font-size: 17px; font-weight: 600; color: var(--cream); letter-spacing: .04em; white-space: nowrap }
.sticky-bar-cta {
  background: var(--cream); color: var(--green-800);
  font-family: 'Barlow Condensed'; font-size: 13px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  border: none; border-radius: 100px; padding: 10px 24px;
  cursor: pointer; white-space: nowrap; transition: opacity .2s;
}
.sticky-bar-cta:hover { opacity: .86 }
@media (min-width: 769px) { .sticky-bar { top: 0; transform: translateY(-100%) } .sticky-bar.visible { transform: translateY(0) } }
@media (max-width: 768px) { .sticky-bar { bottom: 0; transform: translateY(100%) } .sticky-bar.visible { transform: translateY(0) } }

/* ─── Trust Pills ────────────────────────────────────────────────────────── */
.trust-pills { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px }
.pill {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--sage-100); border: 1px solid var(--line-soft);
  color: var(--green-800); padding: 7px 12px; border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif;
  text-transform: uppercase; font-size: 11px; letter-spacing: .14em; font-weight: 500;
  transition: all .2s;
}
.pill:hover { background: var(--sage-200); transform: translateY(-1px) }
.pill .pdot  { width: 6px; height: 6px; border-radius: 50%; background: var(--sage-400) }

/* ─── Product Info ───────────────────────────────────────────────────────── */
.pinfo    { display: flex; flex-direction: column; gap: 20px; padding-top: 6px }
.cat-row  { display: flex; align-items: center; gap: 14px; color: var(--green-500); flex-wrap: wrap }
.cat-row .uae {
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px;
  color: var(--green-800); font-family: 'Barlow Condensed'; font-size: 10px;
  letter-spacing: .16em; text-transform: uppercase; font-weight: 500;
}
.hero-title {
  font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
  font-size: clamp(20px, 2.2vw, 28px); text-transform: uppercase;
  letter-spacing: .06em; color: var(--green-600, #3a6b35);
  line-height: 1.2; margin: 0 0 6px;
}
.h1 {
  font-size: 68px; line-height: .92; color: var(--green-800);
  font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
  text-transform: uppercase; letter-spacing: -.005em;
}
.h1 .alt { color: var(--green-500); font-style: italic; font-weight: 500 }
.edge-word { color: var(--green-800); font-style: normal; font-weight: 900; letter-spacing: .04em }
.label-display {
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase;
  letter-spacing: .18em; font-weight: 700; font-size: clamp(18px, 2vw, 26px);
  color: var(--green-500); display: block; margin-bottom: 14px; line-height: 1;
}
.rating  { display: flex; align-items: center; gap: 12px; color: var(--ink-2); font-size: 13px }
.stars   { display: inline-flex; gap: 2px; color: var(--green-800) }
.desc    { color: var(--ink-2); font-size: 15px; line-height: 1.7; max-width: 48ch }

/* ─── Selector / Plans ───────────────────────────────────────────────────── */
.selector {
  border: 1px solid var(--line); border-radius: 12px; padding: 20px;
  background: var(--paper); box-shadow: 0 4px 24px rgba(15,42,10,.04);
}
.selector h4 {
  font-family: 'Barlow Condensed'; text-transform: uppercase;
  letter-spacing: .18em; font-size: 11px; font-weight: 600; color: var(--green-500);
  margin-bottom: 10px; display: flex; justify-content: space-between; align-items: baseline;
}
.selector h4 .hint { color: var(--ink-3); font-weight: 400; letter-spacing: .14em }
.plans { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px }
.plan {
  position: relative; border: 1px solid var(--line); border-radius: 10px;
  padding: 14px 12px; background: var(--cream); text-align: left;
  transition: all .25s var(--ease); cursor: pointer;
}
.plan:hover  { border-color: var(--green-500); transform: translateY(-2px); box-shadow: 0 6px 16px rgba(15,42,10,.07) }
.plan.active { border-color: var(--green-800); background: var(--sage-100); box-shadow: inset 0 0 0 1px var(--green-800) }
.plan-name  { font-family: 'Barlow Condensed'; font-size: 18px; font-weight: 700; text-transform: uppercase; color: var(--green-800); letter-spacing: .04em; line-height: 1 }
.plan-qty   { font-family: 'Barlow Condensed'; text-transform: uppercase; font-size: 10px; letter-spacing: .18em; color: var(--green-500); margin-top: 6px }
.plan-price { font-family: 'Barlow Condensed'; font-size: 22px; font-weight: 600; color: var(--green-800); margin-top: 10px; letter-spacing: .02em }
.plan-price .ccy { font-size: 12px; font-weight: 500; color: var(--green-500); margin-right: 3px; letter-spacing: .1em }
.plan-flag {
  position: absolute; top: -8px; right: 10px;
  background: var(--green-800); color: var(--cream);
  font-family: 'Barlow Condensed'; font-size: 9px; letter-spacing: .18em;
  text-transform: uppercase; font-weight: 600; padding: 3px 7px; border-radius: 3px;
}
.freq { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px }
.freq-opt {
  border: 1px solid var(--line); border-radius: 10px; padding: 12px 14px;
  background: var(--cream); cursor: pointer; text-align: left;
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  transition: all .25s var(--ease);
}
.freq-opt:hover  { border-color: var(--green-500) }
.freq-opt.active { border-color: var(--green-800); background: var(--sage-100); box-shadow: inset 0 0 0 1px var(--green-800) }
.fo-label { font-family: 'Barlow Condensed'; text-transform: uppercase; font-weight: 600; font-size: 13px; letter-spacing: .1em; color: var(--green-800) }
.fo-sub   { font-size: 11px; color: var(--ink-3); margin-top: 3px; font-family: 'Barlow Condensed'; letter-spacing: .08em; text-transform: uppercase }
.fo-tag   { background: var(--green-800); color: var(--cream); font-family: 'Barlow Condensed'; font-size: 9px; font-weight: 600; letter-spacing: .16em; padding: 3px 7px; border-radius: 3px; text-transform: uppercase }

/* ─── Price Block ────────────────────────────────────────────────────────── */
.priceblock {
  display: grid; grid-template-columns: auto 1fr; gap: 18px;
  align-items: end; padding: 18px 0 6px;
  border-top: 1px solid var(--line); margin-top: 18px;
}
.price-num { font-family: 'Barlow Condensed'; font-size: 64px; font-weight: 700; color: var(--green-800); line-height: .85; letter-spacing: -.01em; transition: all .35s var(--ease) }
.price-num .ccy { font-size: 18px; font-weight: 500; color: var(--green-500); margin-right: 6px; letter-spacing: .06em; vertical-align: top; position: relative; top: 8px }
.price-meta    { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; text-align: right; padding-bottom: 6px }
.price-old     { text-decoration: line-through; color: var(--ink-3); font-size: 14px }
.price-perday  { font-family: 'Barlow Condensed'; font-size: 11px; text-transform: uppercase; letter-spacing: .16em; color: var(--green-500) }

/* ─── CTA Buttons ────────────────────────────────────────────────────────── */
.cta {
  width: 100%; background: var(--green-800); color: var(--cream);
  padding: 18px; border-radius: 8px;
  font-family: 'Barlow Condensed'; font-weight: 700; font-size: 15px;
  letter-spacing: .22em; text-transform: uppercase;
  display: flex; justify-content: center; align-items: center; gap: 10px;
  margin-top: 14px; transition: all .3s var(--ease);
  position: relative; overflow: hidden;
}
.cta::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
  background-size: 300% 100%; opacity: 0;
  transition: opacity .3s;
}
.cta:hover         { background: var(--green-900); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(15,42,10,.28) }
.cta:hover::after  { opacity: 1; animation: shimmer 2s infinite }
.cta:disabled      { opacity: .6; pointer-events: none }
.cta-secondary {
  width: 100%; background: transparent; color: var(--green-800);
  padding: 14px; border-radius: 8px;
  font-family: 'Barlow Condensed'; font-weight: 600; font-size: 13px;
  letter-spacing: .2em; text-transform: uppercase;
  border: 1px solid var(--green-800); margin-top: 8px;
  transition: all .25s var(--ease);
}
.cta-secondary:hover { background: var(--green-800); color: var(--cream) }
.includes {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px 18px;
  margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--line-soft);
}
.inc       { display: flex; align-items: flex-start; gap: 8px; font-size: 13px; color: var(--ink-2); line-height: 1.5 }
.inc-check { flex-shrink: 0; width: 14px; height: 14px; margin-top: 3px; color: var(--green-600) }

/* ─── Section Scaffold ───────────────────────────────────────────────────── */
.section { padding: 88px 0; border-top: 1px solid var(--line); position: relative; overflow: hidden }
.section-cream { background: var(--cream) }
.section-paper { background: var(--paper) }
.section-sage  { background: var(--sage-100) }
.section-dark  { background: linear-gradient(155deg, var(--green-800) 0%, var(--green-950) 65%, #020804 100%); color: var(--cream) }

/* ─── Grain Texture (fixed overlay) ─────────────────────────────────────── */
body::after {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='200'%20height='200'%3E%3Cfilter%20id='g'%20x='0'%20y='0'%3E%3CfeTurbulence%20type='fractalNoise'%20baseFrequency='0.65'%20numOctaves='3'%20stitchTiles='stitch'/%3E%3CfeColorMatrix%20type='saturate'%20values='0'/%3E%3C/filter%3E%3Crect%20width='200'%20height='200'%20filter='url(%23g)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
  background-repeat: repeat;
  opacity: 0.035;
  pointer-events: none;
  z-index: 9999;
}

/* ─── Section Header Grid ────────────────────────────────────────────────── */
.section-head {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px;
  align-items: end; margin-bottom: 52px;
}
.section-head .left .label { margin-bottom: 10px; display: block }
.h2 {
  font-family: 'Barlow Condensed'; font-weight: 700;
  text-transform: uppercase; font-size: 58px; line-height: .95;
  color: var(--green-800); letter-spacing: -.005em;
}
.section-dark .h2 { color: var(--cream) }
.h2 .mute { color: var(--green-500); font-style: italic; font-weight: 500 }
.lede { font-size: 16px; color: var(--ink-2); max-width: 52ch; line-height: 1.6 }
.section-dark .lede { color: rgba(245,241,232,.62) }

/* ─── Nutrient Cards ─────────────────────────────────────────────────────── */
.ngrid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px }
.ncard {
  background: var(--paper); border: 1px solid var(--line); border-radius: 12px;
  padding: 28px 22px; display: flex; flex-direction: column; gap: 18px;
  min-height: 230px; justify-content: space-between;
  transition: transform .3s var(--ease), box-shadow .3s;
}
.ncard:hover { transform: translateY(-4px); box-shadow: 0 14px 36px -14px rgba(15,42,10,.15) }
.nicon  { width: 46px; height: 46px; color: var(--green-800) }
.nval   { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 48px; color: var(--green-800); line-height: .9; letter-spacing: -.005em }
.nval .u { font-size: 18px; color: var(--green-500); font-weight: 500; letter-spacing: .02em }
.nlabel { font-family: 'Barlow Condensed'; font-size: 13px; text-transform: uppercase; letter-spacing: .16em; color: var(--green-800); font-weight: 600 }
.nsub   { font-size: 13px; color: var(--ink-2); line-height: 1.5 }

/* ─── Compare Section ────────────────────────────────────────────────────── */
.body-compare-wrap {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 28px;
  align-items: center; margin-top: 12px;
}
.body-side {
  display: flex; flex-direction: column; align-items: center; gap: 18px;
  padding: 36px 28px; border-radius: 16px; border: 1px solid var(--line);
  position: relative;
}
.body-side.fresh { background: linear-gradient(175deg, var(--sage-100), var(--sage-200)); border-color: var(--sage-400) }
.body-side.dried { background: var(--paper) }
.body-eyebrow { font-family: 'Barlow Condensed'; font-size: 9px; letter-spacing: .24em; text-transform: uppercase; color: var(--ink-3); font-weight: 600 }
.body-title   { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 18px; text-transform: uppercase; letter-spacing: .06em }
.body-side.fresh .body-title { color: var(--green-800) }
.body-side.dried .body-title { color: var(--ink-3) }
.body-fig-wrap { display: flex; align-items: center; justify-content: center; margin: 8px 0 }
.body-pct      { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 76px; line-height: .85; letter-spacing: -.01em }
.body-side.fresh .body-pct { color: var(--green-800) }
.body-side.dried .body-pct { color: var(--ink-3); opacity: .65 }
.body-pct-label { font-family: 'Barlow Condensed'; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-2); font-weight: 500; text-align: center; line-height: 1.4; max-width: 16ch }
.body-delta { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 0 4px }
.body-delta-pill {
  background: var(--green-800); color: var(--cream);
  font-family: 'Barlow Condensed'; font-size: 12px; font-weight: 700;
  letter-spacing: .1em; padding: 12px 18px; border-radius: 999px;
  text-transform: uppercase; box-shadow: 0 10px 28px rgba(15,42,10,.26);
  display: flex; align-items: center; gap: 8px; white-space: nowrap;
  writing-mode: vertical-lr; transform: rotate(180deg); text-orientation: mixed;
}
.compare-wrap  { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 32px }
.compare       { border-radius: 12px; padding: 28px; border: 1px solid var(--line) }
.compare.fresh { background: var(--sage-100); border-color: var(--sage-400) }
.compare.dried { background: var(--paper) }
.compare .ctitle { font-family: 'Barlow Condensed'; font-weight: 700; text-transform: uppercase; font-size: 22px; letter-spacing: .06em; color: var(--green-800); margin-bottom: 6px; display: flex; align-items: center; gap: 10px }
.compare.dried .ctitle { color: var(--ink-2) }
.compare .csub { font-family: 'Barlow Condensed'; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--green-500); margin-bottom: 22px }
.compare.dried .csub  { color: var(--ink-3) }
.clist         { list-style: none; display: flex; flex-direction: column; gap: 11px }
.clist li      { display: flex; gap: 10px; font-size: 14px; color: var(--ink-2); line-height: 1.5; align-items: flex-start }
.ctick         { width: 16px; height: 16px; flex-shrink: 0; margin-top: 3px; color: var(--green-600) }
.cx            { width: 16px; height: 16px; flex-shrink: 0; margin-top: 3px; color: var(--ink-3); opacity: .6 }
.cdot-grn      { width: 8px; height: 8px; border-radius: 50%; background: var(--green-800); flex-shrink: 0 }
.cdot-gry      { width: 8px; height: 8px; border-radius: 50%; background: var(--ink-3); opacity: .45; flex-shrink: 0 }

/* Body figure SVG animation */
.body-clip-rect { transition: none }
.body-clip-rect.animating { /* transition handled via JS requestAnimationFrame */ }

/* ─── Bar Charts (Biograph) ──────────────────────────────────────────────── */
.biograph    { margin-top: 32px; background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 28px }
.biograph h4 { font-family: 'Barlow Condensed'; font-size: 14px; text-transform: uppercase; letter-spacing: .18em; color: var(--green-500); font-weight: 600; margin-bottom: 18px; display: flex; justify-content: space-between; align-items: baseline }
.biograph h4 .src { font-family: 'DM Mono'; font-size: 10px; color: var(--ink-3); letter-spacing: .06em; text-transform: none }
.barrow      { display: grid; grid-template-columns: 140px 1fr 60px; gap: 16px; align-items: center; margin-bottom: 14px }
.barrow:last-child { margin-bottom: 0 }
.blab        { font-family: 'Barlow Condensed'; font-weight: 600; font-size: 14px; letter-spacing: .08em; text-transform: uppercase; color: var(--green-800) }
.blab .small { display: block; font-weight: 400; font-size: 10px; color: var(--ink-3); letter-spacing: .14em; margin-top: 2px }
.btrack      { height: 14px; background: var(--sage-100); border-radius: 3px; overflow: hidden; position: relative }
.bfill       { height: 100%; background: var(--green-800); border-radius: 3px; transition: width 1.4s cubic-bezier(.2,.8,.2,1) }
.bfill.dried { background: var(--ink-3); opacity: .5 }
.bval        { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 20px; color: var(--green-800); text-align: right }
.bval.muted  { color: var(--ink-3) }

/* ─── FAQ ────────────────────────────────────────────────────────────────── */
.faq        { border-top: 1px solid var(--line) }
.faq-item   { border-bottom: 1px solid var(--line) }
.faq-q      { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 26px 0; text-align: left; gap: 24px; transition: padding .25s }
.faq-q .qtxt { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 22px; text-transform: uppercase; letter-spacing: .04em; color: var(--green-800); line-height: 1.1; transition: color .2s }
.faq-item:hover .qtxt { color: var(--green-500) }
.faq-toggle { width: 34px; height: 34px; flex-shrink: 0; border-radius: 50%; border: 1px solid var(--green-800); display: flex; align-items: center; justify-content: center; color: var(--green-800); font-size: 22px; transition: all .3s var(--ease) }
.faq-item.open .faq-toggle { background: var(--green-800); color: var(--cream); transform: rotate(45deg) }
.faq-a      { max-height: 0; overflow: hidden; transition: max-height .4s var(--ease), padding .3s ease }
.faq-item.open .faq-a { max-height: 400px; padding: 0 64px 26px 0 }
.faq-a p    { color: var(--ink-2); font-size: 15px; line-height: 1.7 }

/* ─── Big CTA ────────────────────────────────────────────────────────────── */
.bigcta { padding: 130px 0; text-align: center; background: var(--green-900); color: var(--cream); position: relative; overflow: hidden }
.bigcta::before {
  content: ''; position: absolute; width: 640px; height: 640px; border-radius: 50%;
  background: radial-gradient(circle, rgba(157,194,154,.24), transparent 70%);
  filter: blur(80px); top: -220px; left: 50%; transform: translateX(-50%);
  animation: orb 18s ease-in-out infinite; pointer-events: none;
}
.bigcta::after {
  content: ''; position: absolute; width: 320px; height: 320px; border-radius: 50%;
  background: radial-gradient(circle, rgba(107,155,90,.18), transparent 70%);
  filter: blur(50px); bottom: -80px; right: 8%;
  animation: orb 24s ease-in-out infinite reverse; pointer-events: none;
}
.bigcta > * { position: relative; z-index: 1 }
.bigcta-mark { width: 80px; height: 80px; margin: 0 auto 28px; color: var(--sage-400); animation: float 5s ease-in-out infinite }
.bigcta h2   { font-family: 'Barlow Condensed'; font-weight: 700; font-size: 100px; line-height: .92; text-transform: uppercase; color: var(--cream); max-width: 14ch; margin: 0 auto; letter-spacing: -.01em }
.bigcta h2 .alt { color: var(--sage-400); font-style: italic; font-weight: 500 }
.bigcta .lede   { margin: 24px auto 40px; font-size: 18px; color: rgba(245,241,232,.65); max-width: 48ch; line-height: 1.5 }
.bigcta-buttons { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap }
.bigcta-buttons .b1, .bigcta-buttons .b2 { padding: 18px 32px; border-radius: 8px; font-family: 'Barlow Condensed'; font-weight: 700; font-size: 14px; letter-spacing: .22em; text-transform: uppercase; transition: all .3s var(--ease) }
.b1      { background: var(--cream); color: var(--green-900) }
.b1:hover { background: white; transform: translateY(-2px); box-shadow: 0 10px 28px rgba(245,241,232,.18) }
.b2      { background: transparent; color: var(--cream); border: 1px solid rgba(245,241,232,.38) }
.b2:hover { border-color: var(--cream); background: rgba(245,241,232,.06) }
.bigcta-trust { margin-top: 36px; font-family: 'Barlow Condensed'; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(245,241,232,.45); display: flex; justify-content: center; align-items: center; gap: 24px; flex-wrap: wrap }
.bigcta-trust .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--sage-400); opacity: .5 }

/* ─── Footer ─────────────────────────────────────────────────────────────── */
.footer { background: var(--green-900); color: rgba(245,241,232,.7); padding: 52px 0 40px; border-top: 1px solid rgba(245,241,232,.1) }
.footer-row { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 36px; margin-bottom: 36px }
.footer-brand { display: flex; align-items: center; gap: 12px; margin-bottom: 14px }
.footer-brand .brand-word { color: var(--cream) }
.footer-brand .brand-tag  { color: var(--sage-400) }
.footer-blurb { font-size: 13px; line-height: 1.7; max-width: 38ch }
.fcol h5 { font-family: 'Barlow Condensed'; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--sage-400); font-weight: 600; margin-bottom: 18px }
.fcol ul { list-style: none; display: flex; flex-direction: column; gap: 11px }
.fcol a  { font-family: 'Barlow Condensed'; font-size: 13px; letter-spacing: .1em; text-transform: uppercase; color: rgba(245,241,232,.82); font-weight: 500; transition: color .2s }
.fcol a:hover { color: var(--cream) }
.footer-base { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; border-top: 1px solid rgba(245,241,232,.1); font-family: 'DM Mono'; font-size: 11px; letter-spacing: .06em; color: rgba(245,241,232,.45) }
.footer-legal-links { display: flex; gap: 12px; align-items: center; }
.footer-legal-links a { color: rgba(245,241,232,.45); text-decoration: underline; transition: color .2s; }
.footer-legal-links a:hover { color: var(--cream); }
.footer-legal-links span { opacity: .4; }

/* ─── Toast ──────────────────────────────────────────────────────────────── */
.toast {
  position: fixed; bottom: 32px; right: 32px;
  background: var(--green-900); color: var(--cream);
  padding: 16px 20px; border-radius: 10px;
  display: flex; align-items: center; gap: 12px;
  font-family: 'Barlow Condensed'; font-size: 13px; letter-spacing: .12em;
  text-transform: uppercase; font-weight: 500;
  border: 1px solid var(--sage-400);
  box-shadow: 0 20px 50px rgba(0,0,0,.38);
  z-index: 10000; animation: toast-in .4s var(--ease); max-width: 380px;
}
.toast .tdot { width: 8px; height: 8px; border-radius: 50%; background: var(--sage-400); box-shadow: 0 0 0 3px rgba(157,194,154,.28); flex-shrink: 0 }
.toast .tx   { margin-left: auto; color: var(--sage-400); cursor: pointer; padding: 0 4px; font-size: 18px; line-height: 1 }

/* ─── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
  .hero  { grid-template-columns: 1fr; gap: 32px; padding: 32px 0 56px }
  .h1    { font-size: 48px }
  .h2    { font-size: 40px }
  .bigcta h2 { font-size: 60px }
  .section-head, .body-compare-wrap { grid-template-columns: 1fr; gap: 24px }
  .ngrid, .compare-wrap { grid-template-columns: 1fr }
  .footer-row { grid-template-columns: 1fr 1fr }
  .nav-links  { display: none }
  .body-delta-pill { writing-mode: horizontal-tb; transform: none }
  .body-compare-wrap { display: flex; flex-direction: column; align-items: stretch }
  .barrow { grid-template-columns: 120px 1fr 50px }
}
@media (max-width: 600px) {
  .plans   { grid-template-columns: 1fr }
  .includes { grid-template-columns: 1fr }
  .trust-pills { gap: 6px }
  .billing-tabs { flex-wrap: wrap }
  .onetime-opts { grid-template-columns: repeat(3,1fr) }
  .footer-row { grid-template-columns: 1fr }
  .footer-base { flex-direction: column; gap: 8px; text-align: center }
  .toast  { bottom: 72px; right: 16px; left: 16px; max-width: none }
}

/* ==========================================================================
   WooCommerce — Prolina-styled overrides
   ========================================================================== */

/* ─── Shared container ───────────────────────────────────────────────────── */
.prolina-woo .woo-main,
.woocommerce .pg,
.woocommerce-page .pg { max-width: 1320px; margin: 0 auto; padding: 50px 28px }

/* ─── WC notices ─────────────────────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  font-family: 'Barlow Condensed', sans-serif; font-size: 14px;
  letter-spacing: .08em; text-transform: uppercase;
  border-top-color: var(--green-800) !important;
  background: var(--sage-50) !important; color: var(--ink) !important;
  padding: 12px 20px !important; margin-bottom: 24px !important;
}
.woocommerce-error { border-top-color: #c0392b !important; background: #fdf5f5 !important; }

/* ─── Form inputs ────────────────────────────────────────────────────────── */
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="password"],
.woocommerce textarea,
.woocommerce select {
  font-family: 'Barlow', sans-serif !important;
  border: 1px solid var(--line) !important;
  border-radius: 8px !important;
  background: var(--paper) !important;
  color: var(--ink) !important;
  padding: 12px 14px !important;
  font-size: 15px !important;
  transition: border-color .2s !important;
}
.woocommerce input:focus,
.woocommerce textarea:focus,
.woocommerce select:focus { border-color: var(--green-800) !important; outline: none !important; }

/* ─── Buttons ────────────────────────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background: var(--green-800) !important; color: var(--cream) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  text-transform: uppercase !important; letter-spacing: .18em !important;
  font-size: 13px !important; font-weight: 700 !important;
  border-radius: 8px !important; padding: 14px 24px !important;
  border: none !important; transition: all .25s var(--ease) !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover { background: var(--green-900) !important; transform: translateY(-1px) !important; }
.woocommerce a.button.alt,
.woocommerce button.button.alt  { background: var(--green-700) !important; }

/* ─── Cart table ─────────────────────────────────────────────────────────── */
.woocommerce-cart table.cart { border-collapse: collapse; width: 100%; }
.woocommerce-cart table.cart th,
.woocommerce-cart table.cart td {
  padding: 16px 12px !important; border-bottom: 1px solid var(--line) !important;
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  letter-spacing: .08em; text-transform: uppercase;
}
.woocommerce-cart table.cart thead th { color: var(--ink-3); font-weight: 600; }
.woocommerce-cart .cart_totals h2,
.woocommerce-cart .cart_totals .cart-subtotal th,
.woocommerce-cart .cart_totals .order-total th {
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase; letter-spacing: .1em;
}
.woocommerce-cart .cart_totals .order-total .amount { font-size: 28px; color: var(--green-800); font-family: 'Barlow Condensed', sans-serif; font-weight: 700; }

/* ─── Checkout ───────────────────────────────────────────────────────────── */
.woocommerce-checkout h3,
.woocommerce-checkout h2 {
  font-family: 'Barlow Condensed', sans-serif !important;
  text-transform: uppercase !important; letter-spacing: .1em !important;
  color: var(--green-800) !important; margin-bottom: 20px !important;
}
.woocommerce-checkout #order_review_heading { display: none }
.woocommerce-checkout .woocommerce-checkout-review-order-table th,
.woocommerce-checkout .woocommerce-checkout-review-order-table td {
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase; letter-spacing: .08em;
  padding: 12px 8px !important; border-bottom: 1px solid var(--line) !important;
}
.woocommerce-checkout .order-total .amount { color: var(--green-800); font-weight: 700; font-size: 22px; }

/* ─── My Account ─────────────────────────────────────────────────────────── */

/* Sidebar nav */
.woocommerce-MyAccount-navigation ul { list-style: none; display: flex; flex-direction: column; gap: 2px; }
.woocommerce-MyAccount-navigation a {
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase;
  letter-spacing: .1em; font-size: 12px; font-weight: 600;
  color: var(--ink-2); padding: 11px 16px 11px 14px;
  border-left: 3px solid transparent;
  display: block; transition: all .2s; border-radius: 0 8px 8px 0;
}
.woocommerce-MyAccount-navigation a:hover {
  background: var(--sage-50); color: var(--green-800);
  border-left-color: var(--green-400);
}
.woocommerce-MyAccount-navigation .is-active a {
  background: var(--sage-100); color: var(--green-800);
  border-left-color: var(--green-800); font-weight: 700;
}

/* Section headings */
.woocommerce-MyAccount-content h2,
.woocommerce-MyAccount-content h3 {
  font-family: 'Barlow Condensed', sans-serif !important;
  text-transform: uppercase !important; letter-spacing: .1em !important;
  color: var(--green-800) !important; margin: 0 0 20px !important;
  font-size: 20px !important;
}

/* Orders / subscriptions / generic shop tables */
.woocommerce-MyAccount-content .woocommerce-orders-table,
.woocommerce-MyAccount-content .shop_table,
.woocommerce-MyAccount-content .ywsbs_subscription_table,
.woocommerce-MyAccount-content table.woocommerce-table {
  width: 100%; border-collapse: collapse; font-size: 14px;
}
.woocommerce-MyAccount-content .woocommerce-orders-table th,
.woocommerce-MyAccount-content .shop_table th,
.woocommerce-MyAccount-content .ywsbs_subscription_table th,
.woocommerce-MyAccount-content table.woocommerce-table th {
  background: var(--sage-50); color: var(--ink-2);
  font-family: 'Barlow Condensed', sans-serif; text-transform: uppercase;
  letter-spacing: .1em; font-size: 11px; font-weight: 700;
  padding: 12px 16px; border-bottom: 2px solid var(--line); text-align: left;
}
.woocommerce-MyAccount-content .woocommerce-orders-table td,
.woocommerce-MyAccount-content .shop_table td,
.woocommerce-MyAccount-content .ywsbs_subscription_table td,
.woocommerce-MyAccount-content table.woocommerce-table td {
  padding: 14px 16px; border-bottom: 1px solid var(--line-soft);
  color: var(--ink); vertical-align: middle;
  font-family: 'Barlow', sans-serif; font-size: 14px;
}
.woocommerce-MyAccount-content .woocommerce-orders-table tr:last-child td,
.woocommerce-MyAccount-content .shop_table tr:last-child td,
.woocommerce-MyAccount-content .ywsbs_subscription_table tr:last-child td { border-bottom: none; }
.woocommerce-MyAccount-content .woocommerce-orders-table tr:hover td,
.woocommerce-MyAccount-content .shop_table tr:hover td,
.woocommerce-MyAccount-content .ywsbs_subscription_table tr:hover td {
  background: var(--sage-50);
}

/* Order status badges */
.woocommerce-order-status,
mark.order-status {
  display: inline-block; padding: 3px 10px; border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  background: var(--sage-100); color: var(--green-800);
}
.woocommerce-order-status.status-processing, mark.order-status.status-processing,
.woocommerce-order-status.status-active,     mark.order-status.status-active {
  background: #d4edda; color: #1a5c2e;
}
.woocommerce-order-status.status-completed,  mark.order-status.status-completed {
  background: var(--green-800); color: var(--cream);
}
.woocommerce-order-status.status-cancelled,  mark.order-status.status-cancelled,
.woocommerce-order-status.status-expired,    mark.order-status.status-expired {
  background: #f8d7da; color: #7a1c23;
}
.woocommerce-order-status.status-on-hold,    mark.order-status.status-on-hold,
.woocommerce-order-status.status-pending,    mark.order-status.status-pending {
  background: #fff3cd; color: #7a5a00;
}
.woocommerce-order-status.status-refunded,   mark.order-status.status-refunded {
  background: #e2e3e5; color: #383d41;
}

/* Table action buttons — smaller outlined style */
.woocommerce-MyAccount-content .woocommerce-button.button,
.woocommerce-MyAccount-content a.button.view,
.woocommerce-MyAccount-content a.button.pay,
.woocommerce-MyAccount-content a.button.cancel {
  background: transparent !important; color: var(--green-800) !important;
  border: 1px solid var(--green-800) !important;
  padding: 6px 14px !important; font-size: 11px !important;
  border-radius: 6px !important; display: inline-block !important;
}
.woocommerce-MyAccount-content .woocommerce-button.button:hover,
.woocommerce-MyAccount-content a.button.view:hover,
.woocommerce-MyAccount-content a.button.pay:hover {
  background: var(--green-800) !important; color: var(--cream) !important;
  transform: none !important;
}
.woocommerce-MyAccount-content a.button.cancel {
  border-color: #c0392b !important; color: #c0392b !important;
}
.woocommerce-MyAccount-content a.button.cancel:hover {
  background: #c0392b !important; color: #fff !important;
}

/* Empty states */
.woocommerce-MyAccount-content .woocommerce-message {
  background: var(--sage-50) !important; border: 1px solid var(--line) !important;
  border-top: 3px solid var(--green-500) !important;
  padding: 24px 24px !important; border-radius: 10px !important;
  font-family: 'Barlow', sans-serif !important; font-size: 15px !important;
  text-transform: none !important; letter-spacing: 0 !important;
  display: flex !important; align-items: center !important;
  justify-content: space-between !important; flex-wrap: wrap !important; gap: 16px !important;
}

/* Account detail / address forms */
.woocommerce-MyAccount-content fieldset {
  border: 1px solid var(--line); border-radius: 12px;
  padding: 24px; margin-bottom: 24px;
}
.woocommerce-MyAccount-content fieldset legend {
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  text-transform: uppercase; letter-spacing: .12em;
  font-weight: 700; color: var(--ink-2); padding: 0 8px;
}

/* Subscription info box (YITH) */
.ywsbs-subscription-info-box,
.ywsbs_subscription_table + .ywsbs-subscription-detail {
  border: 1px solid var(--line); border-radius: 12px;
  padding: 24px; background: var(--paper); margin-top: 24px;
}

/* Responsive table pattern */
@media (max-width: 640px) {
  .woocommerce-MyAccount-content .woocommerce-orders-table thead,
  .woocommerce-MyAccount-content .ywsbs_subscription_table thead { display: none; }
  .woocommerce-MyAccount-content .woocommerce-orders-table td,
  .woocommerce-MyAccount-content .ywsbs_subscription_table td {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 14px; border-bottom: none;
  }
  .woocommerce-MyAccount-content .woocommerce-orders-table td::before,
  .woocommerce-MyAccount-content .ywsbs_subscription_table td::before {
    content: attr(data-title);
    font-family: 'Barlow Condensed', sans-serif; font-size: 11px;
    text-transform: uppercase; letter-spacing: .1em;
    font-weight: 700; color: var(--ink-3); flex-shrink: 0;
  }
  .woocommerce-MyAccount-content .woocommerce-orders-table tr,
  .woocommerce-MyAccount-content .ywsbs_subscription_table tr {
    display: block; border: 1px solid var(--line); border-radius: 10px;
    margin-bottom: 12px; padding: 6px 0; background: var(--paper);
  }
}

/* ==========================================================================
   Auth Interstitial — /my-account/ for guests arriving from add-to-cart
   ========================================================================== */

/* ─── Page wrapper ───────────────────────────────────────────────────────── */
.prolina-auth-page {
  max-width: 520px; margin: 0 auto; padding: 40px 0 72px;
}

/* ─── Hero header ────────────────────────────────────────────────────────── */
.auth-hero {
  text-align: center; margin-bottom: 36px;
}
.auth-hero svg { display: block; margin: 0 auto 20px; }
.auth-heading {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(28px, 5vw, 40px); font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--green-800); margin-bottom: 10px;
}
.auth-sub {
  font-family: 'Barlow', sans-serif; font-size: 15px; font-weight: 300;
  color: var(--ink-2); line-height: 1.65; max-width: 390px; margin: 0 auto;
}

/* ─── Card shell ─────────────────────────────────────────────────────────── */
.auth-card {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 16px; padding: 32px 36px 28px;
  box-shadow: 0 2px 24px rgba(10,31,8,.06);
}

/* ─── Tab switcher ───────────────────────────────────────────────────────── */
.auth-tabs {
  display: flex; gap: 4px; background: var(--cream-2);
  border-radius: 10px; padding: 4px; margin-bottom: 28px;
}
.auth-tab {
  flex: 1; padding: 10px 0; border: none; background: transparent;
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-2); border-radius: 8px; cursor: pointer;
  transition: all .2s var(--ease);
}
.auth-tab.active {
  background: var(--green-800); color: var(--cream);
  box-shadow: 0 1px 6px rgba(10,31,8,.18);
}
.auth-tab:not(.active):hover { background: var(--sage-100); color: var(--green-800); }

/* ─── Form panels ────────────────────────────────────────────────────────── */
.auth-panel { display: block; }
.auth-panel[hidden] { display: none; }

/* ─── Field groups ───────────────────────────────────────────────────────── */
.auth-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.auth-field label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-2);
}
.auth-field .required { color: #c0392b; margin-left: 2px; font-style: normal; }
.auth-field input {
  font-family: 'Barlow', sans-serif; font-size: 15px;
  border: 1px solid var(--line); border-radius: 8px;
  background: var(--cream); color: var(--ink);
  padding: 12px 14px; width: 100%; transition: border-color .2s;
}
.auth-field input:focus { border-color: var(--green-800); outline: none; }

/* ─── Remember / forgot row ──────────────────────────────────────────────── */
.auth-remember {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 22px; gap: 8px;
}
.auth-check-label {
  display: flex; align-items: center; gap: 8px;
  font-family: 'Barlow', sans-serif; font-size: 13px;
  color: var(--ink-2); cursor: pointer; user-select: none;
}
.auth-check-label input[type="checkbox"] {
  width: 15px; height: 15px; accent-color: var(--green-800); flex-shrink: 0;
}
.auth-forgot {
  font-family: 'Barlow', sans-serif; font-size: 12px;
  color: var(--ink-3); transition: color .2s; white-space: nowrap;
}
.auth-forgot:hover { color: var(--green-800); }
.auth-lost-password {
  text-align: center; margin-top: 16px;
}
.auth-forgot-link {
  font-family: 'Barlow', sans-serif; font-size: 13px;
  color: var(--green-700); text-decoration: underline;
  transition: color .2s;
}
.auth-forgot-link:hover { color: var(--green-800); }

/* ─── Submit button ──────────────────────────────────────────────────────── */
.auth-submit {
  width: 100%; display: flex !important; align-items: center;
  justify-content: center; gap: 10px;
  background: var(--green-800) !important; color: var(--cream) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 14px !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: .18em !important;
  padding: 16px 24px !important; border: none !important;
  border-radius: 10px !important; cursor: pointer;
  transition: all .25s var(--ease) !important; margin-top: 4px;
}
.auth-submit:hover {
  background: var(--green-900) !important; transform: translateY(-1px) !important;
}

/* ─── Auto-generate password note ───────────────────────────────────────── */
.auth-note {
  font-family: 'Barlow', sans-serif; font-size: 13px; color: var(--ink-3);
  padding: 10px 14px; background: var(--sage-50);
  border-radius: 8px; margin-bottom: 20px; line-height: 1.5;
}

/* ─── Guest bypass ───────────────────────────────────────────────────────── */
.auth-guest {
  text-align: center; margin-top: 22px; padding-top: 22px;
  border-top: 1px solid var(--line-soft);
}
.auth-guest-link {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  font-weight: 600; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-3); transition: color .2s;
}
.auth-guest-link:hover { color: var(--green-800); }

/* ─── WC notices inside auth card ───────────────────────────────────────── */
.prolina-auth-page .woocommerce-notices-wrapper { margin-bottom: 20px; }


/* ==========================================================================
   Order Confirmation (Thank You) Page
   ========================================================================== */

.prolina-thankyou { max-width: 760px; margin: 0 auto; padding: 72px 28px 96px; }

/* Hero */
.pty-hero {
  text-align: center; padding: 48px 28px 40px;
  background: var(--green-800); border: 1px solid var(--green-800);
  border-radius: 20px; margin-bottom: 36px;
  box-shadow: 0 2px 32px rgba(10,31,8,.18);
}
.pty-check-circle {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--cream); color: var(--green-800);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px; font-size: 30px; line-height: 1;
}
.pty-heading {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(30px, 5vw, 44px); font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--cream); margin-bottom: 10px;
}
.pty-sub {
  font-family: 'Barlow', sans-serif; font-size: 15px;
  color: rgba(245,241,232,.78); font-weight: 300; max-width: 400px; margin: 0 auto;
}

/* Order summary card */
.pty-summary {
  background: #ffffff; border: 1px solid var(--line);
  border-radius: 16px; padding: 28px 32px;
  margin-bottom: 32px; display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 20px 28px;
}
.pty-detail-label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-3); margin-bottom: 4px;
}
.pty-detail-value {
  font-family: 'Barlow', sans-serif; font-size: 15px;
  font-weight: 600; color: var(--ink);
}
.pty-detail-value .pty-status {
  display: inline-block; padding: 3px 10px; border-radius: 999px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  background: #d4edda; color: #1a5c2e;
}

/* What happens next */
.pty-steps {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 32px;
}
.pty-step {
  text-align: center; padding: 24px 16px;
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 14px; position: relative;
}
.pty-step-num {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--sage-100); color: var(--green-800);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 15px;
  margin: 0 auto 12px;
}
.pty-step-title {
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  text-transform: uppercase; letter-spacing: .1em;
  font-weight: 700; color: var(--green-800); margin-bottom: 6px;
}
.pty-step-desc {
  font-family: 'Barlow', sans-serif; font-size: 13px;
  color: var(--ink-2); line-height: 1.5;
}

/* Items table */
.pty-items {
  background: #ffffff; border: 1px solid var(--line);
  border-radius: 16px; overflow: hidden; margin-bottom: 32px;
}
.pty-items-heading {
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  text-transform: uppercase; letter-spacing: .12em; font-weight: 700;
  color: var(--ink-2); padding: 16px 24px;
  border-bottom: 1px solid var(--line); background: var(--sage-50);
}
.pty-items .woocommerce-table--order-details {
  width: 100%; border-collapse: collapse;
}
.pty-items .woocommerce-table--order-details th {
  display: none;
}
.pty-items .woocommerce-table--order-details td {
  padding: 14px 24px; border-bottom: 1px solid var(--line-soft);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink);
  vertical-align: middle;
}
.pty-items .woocommerce-table--order-details .product-name {
  font-weight: 600;
}
.pty-items .woocommerce-table--order-details tfoot tr:first-child td { border-top: 2px solid var(--line); }
.pty-items .woocommerce-table--order-details tfoot .order-total .amount {
  font-size: 18px; font-weight: 700; color: var(--green-800);
}
.pty-items .woocommerce-table--order-details tfoot th,
.pty-items .woocommerce-table--order-details tfoot td {
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  text-transform: uppercase; letter-spacing: .08em;
  padding: 12px 24px;
}
.pty-items .woocommerce-table--order-details tfoot th { display: table-cell; font-weight: 700; color: var(--ink-2); }

/* CTAs */
.pty-actions {
  display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}
.pty-btn-primary {
  background: var(--green-800); color: var(--cream);
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .18em;
  padding: 14px 28px; border-radius: 10px;
  transition: all .25s var(--ease); display: inline-block;
}
.pty-btn-primary:hover { background: var(--green-900); transform: translateY(-1px); }
.pty-btn-secondary {
  background: transparent; color: var(--green-800);
  border: 1.5px solid var(--green-800);
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .18em;
  padding: 14px 28px; border-radius: 10px;
  transition: all .25s var(--ease); display: inline-block;
}
.pty-btn-secondary:hover { background: var(--green-800); color: var(--cream); transform: translateY(-1px); }

/* Failed order */
.pty-failed-hero { text-align: center; padding: 48px 28px; }
.pty-failed-icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: #f8d7da; color: #7a1c23;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 20px; font-size: 30px;
}

@media (max-width: 640px) {
  .pty-steps { grid-template-columns: 1fr; }
  .pty-summary { grid-template-columns: 1fr 1fr; }
  .pty-items .woocommerce-table--order-details td { padding: 12px 16px; }
}


/* ==========================================================================
   My Account — Edit Account / Edit Address Forms
   ========================================================================== */

/* Two-column first/last row layout */
.woocommerce-EditAccountForm .woocommerce-form-row,
.woocommerce-address-fields .woocommerce-form-row {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px;
}
.woocommerce-EditAccountForm .woocommerce-form-row--first,
.woocommerce-EditAccountForm .woocommerce-form-row--last,
.woocommerce-address-fields .woocommerce-form-row--first,
.woocommerce-address-fields .woocommerce-form-row--last {
  width: calc(50% - 10px); display: inline-flex; vertical-align: top;
}
.woocommerce-EditAccountForm .woocommerce-form-row--first,
.woocommerce-address-fields .woocommerce-form-row--first { margin-right: 20px; }
.woocommerce-EditAccountForm .clear,
.woocommerce-address-fields .clear { display: block; clear: both; height: 0; }

/* Labels */
.woocommerce-EditAccountForm label,
.woocommerce-address-fields label,
.woocommerce-checkout label {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 12px !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: .1em !important;
  color: var(--ink-2) !important; margin-bottom: 6px !important;
}
.woocommerce-EditAccountForm .required,
.woocommerce-address-fields .required { color: #c0392b; margin-left: 2px; }

/* Fieldset (password section) */
.woocommerce-EditAccountForm fieldset {
  border: 1px solid var(--line); border-radius: 12px;
  padding: 28px 24px 24px; margin: 28px 0 24px;
}
.woocommerce-EditAccountForm fieldset legend {
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  text-transform: uppercase; letter-spacing: .12em;
  font-weight: 700; color: var(--ink-2); padding: 0 10px;
}

/* Helper text below display name */
.woocommerce-EditAccountForm #account_display_name_description em {
  font-family: 'Barlow', sans-serif; font-size: 12px;
  color: var(--ink-3); display: block; margin-top: 4px; font-style: normal;
}

/* Save button */
.woocommerce-EditAccountForm .woocommerce-Button,
.woocommerce-EditAccountForm button[type="submit"],
.woocommerce-address-fields button[type="submit"] {
  margin-top: 8px;
}

/* ==========================================================================
   Single Product Page
   ========================================================================== */

/* Outer wrapper */
.woocommerce-page.single-product #content,
.woocommerce.single-product #content { max-width: 1160px; margin: 0 auto; padding: 64px 28px 96px; }

/* Product layout — image left, summary right */
.woocommerce div.product {
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start;
}
.woocommerce div.product .woocommerce-product-gallery { grid-column: 1; }
.woocommerce div.product .entry-summary { grid-column: 2; }
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .up-sells,
.woocommerce div.product .related { grid-column: 1 / -1; }

/* Gallery */
.woocommerce div.product .woocommerce-product-gallery__wrapper img {
  border-radius: 16px; width: 100%; height: auto; display: block;
}
.woocommerce div.product .flex-control-thumbs { margin-top: 12px; display: flex; gap: 8px; }
.woocommerce div.product .flex-control-thumbs li { list-style: none; }
.woocommerce div.product .flex-control-thumbs img {
  border-radius: 8px; border: 2px solid transparent; cursor: pointer;
  transition: border-color .2s;
}
.woocommerce div.product .flex-control-thumbs .flex-active { border-color: var(--green-800); }

/* Product title */
.woocommerce div.product .product_title.entry-title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: clamp(28px, 4vw, 42px) !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: .04em !important;
  color: var(--green-800) !important; line-height: 1.1 !important;
  margin-bottom: 16px !important;
}

/* Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 28px !important; font-weight: 700 !important;
  color: var(--green-800) !important; margin-bottom: 20px !important;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
  opacity: .5; font-size: 18px !important; margin-right: 8px;
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
  font-family: 'Barlow', sans-serif; font-size: 15px;
  color: var(--ink-2); line-height: 1.65; margin-bottom: 28px;
  font-weight: 300;
}

/* Variation selects */
.woocommerce div.product .variations td,
.woocommerce div.product .variations th {
  padding: 8px 0 !important; vertical-align: middle;
}
.woocommerce div.product .variations label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-2);
}
.woocommerce div.product .variations select {
  appearance: auto; min-width: 160px;
}

/* Stock badge */
.woocommerce div.product .stock {
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: var(--green-600); margin-bottom: 16px; display: block;
}
.woocommerce div.product .out-of-stock { color: #c0392b; }

/* Add to cart form */
.woocommerce div.product form.cart { margin-bottom: 24px; }
.woocommerce div.product .qty {
  width: 64px !important; text-align: center !important;
  border: 1px solid var(--line) !important; border-radius: 8px !important;
  padding: 12px 8px !important; font-size: 15px !important;
  background: var(--paper) !important; color: var(--ink) !important;
}
.woocommerce div.product .single_add_to_cart_button {
  background: var(--green-800) !important; color: var(--cream) !important;
  font-family: 'Barlow Condensed', sans-serif !important;
  text-transform: uppercase !important; letter-spacing: .18em !important;
  font-size: 13px !important; font-weight: 700 !important;
  border-radius: 10px !important; padding: 14px 28px !important;
  border: none !important; cursor: pointer !important;
  transition: all .25s var(--ease) !important; margin-left: 10px !important;
}
.woocommerce div.product .single_add_to_cart_button:hover {
  background: var(--green-900) !important; transform: translateY(-1px) !important;
}

/* Product tabs (description, reviews) */
.woocommerce div.product .woocommerce-tabs { margin-top: 48px; border-top: 2px solid var(--line); }
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex; gap: 0; list-style: none; margin: 0; padding: 0; border-bottom: 1px solid var(--line);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  margin: 0; padding: 0; background: none; border: none;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  display: block; padding: 14px 24px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-3); border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: all .2s;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--green-800); border-bottom-color: var(--green-800);
}
.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel {
  padding: 32px 0; font-family: 'Barlow', sans-serif; font-size: 15px;
  color: var(--ink-2); line-height: 1.65; font-weight: 300;
}
.woocommerce div.product .woocommerce-tabs h2 {
  font-family: 'Barlow Condensed', sans-serif !important;
  text-transform: uppercase !important; letter-spacing: .1em !important;
  color: var(--green-800) !important; font-size: 18px !important; margin-bottom: 16px !important;
}

/* Related / upsell products */
.woocommerce .related.products h2,
.woocommerce .up-sells.products h2 {
  font-family: 'Barlow Condensed', sans-serif !important;
  text-transform: uppercase !important; letter-spacing: .1em !important;
  color: var(--green-800) !important; margin-bottom: 24px !important;
}
.woocommerce .related.products ul.products,
.woocommerce .up-sells.products ul.products {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 24px; list-style: none; margin: 0; padding: 0;
}
.woocommerce .related.products ul.products li.product,
.woocommerce .up-sells.products ul.products li.product {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: 14px; overflow: hidden; transition: box-shadow .25s;
}
.woocommerce .related.products ul.products li.product:hover,
.woocommerce .up-sells.products ul.products li.product:hover {
  box-shadow: 0 4px 24px rgba(10,31,8,.1);
}
.woocommerce .related.products ul.products li.product a.woocommerce-loop-product__link,
.woocommerce .up-sells.products ul.products li.product a { display: block; padding: 16px; }
.woocommerce .related.products ul.products li.product .price,
.woocommerce .up-sells.products ul.products li.product .price {
  font-family: 'Barlow Condensed', sans-serif; font-size: 16px;
  font-weight: 700; color: var(--green-800);
}

/* Breadcrumb */
.woocommerce .woocommerce-breadcrumb {
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--ink-3); margin-bottom: 32px;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--ink-3); }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--green-800); }

@media (max-width: 768px) {
  .woocommerce div.product {
    grid-template-columns: 1fr;
  }
}


/* ==========================================================================
   Order Details panel — thankyou page fixes
   ========================================================================== */

/* Hide the duplicate "Order details" h2 that order-details.php renders;
   .pty-items already has its own heading strip */
.pty-items .woocommerce-order-details__title { display: none !important; }

/* Pad the order details section content */
.pty-items .woocommerce-order-details {
  padding: 0 0 8px;
}

/* Item meta — remove bullets, indent cleanly */
.pty-items .wc-item-meta,
.pty-items .woocommerce-item__meta {
  list-style: none !important; padding: 0 !important; margin: 4px 0 0 !important;
}
.pty-items .wc-item-meta li,
.pty-items .woocommerce-item__meta li {
  font-family: 'Barlow', sans-serif; font-size: 12px;
  color: var(--ink-3); line-height: 1.6;
}
.pty-items .wc-item-meta li::before,
.pty-items .woocommerce-item__meta li::before { display: none !important; }

/* Product name cell */
.pty-items .woocommerce-table--order-details .product-name {
  padding-left: 24px !important;
}
.pty-items .woocommerce-table--order-details .product-total {
  text-align: right; padding-right: 24px !important;
}

/* Show thead row (product / total labels) */
.pty-items .woocommerce-table--order-details thead { display: table-header-group; }
.pty-items .woocommerce-table--order-details thead th {
  background: none !important; padding: 12px 24px 8px !important;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-3); border-bottom: 1px solid var(--line-soft) !important;
}
.pty-items .woocommerce-table--order-details thead th.product-total { text-align: right; }

/* tfoot — labels left-flush, values right-flush, full table width */
.pty-items .woocommerce-table--order-details { width: 100%; table-layout: fixed; }
.pty-items .woocommerce-table--order-details tfoot th,
.pty-items .woocommerce-table--order-details tfoot td {
  border-bottom: 1px solid var(--line-soft) !important;
  padding-top: 12px !important; padding-bottom: 12px !important;
}
.pty-items .woocommerce-table--order-details tfoot th {
  text-align: left !important; padding-left: 24px !important; padding-right: 16px !important;
  width: auto;
}
.pty-items .woocommerce-table--order-details tfoot td {
  text-align: right !important; padding-right: 24px !important; width: 160px;
}

/* Customer details section (billing / shipping addresses) */
.pty-items .woocommerce-customer-details {
  padding: 24px 24px 28px;
  border-top: 2px solid var(--line);
}
.pty-items .woocommerce-columns--addresses {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
}
.pty-items .woocommerce-column__title {
  font-family: 'Barlow Condensed', sans-serif !important;
  font-size: 12px !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: .12em !important;
  color: var(--green-800) !important; margin-bottom: 10px !important;
}
.pty-items .woocommerce-customer-details address {
  font-family: 'Barlow', sans-serif; font-size: 14px;
  color: var(--ink-2); line-height: 1.7; font-style: normal;
}
.pty-items .woocommerce-customer-details--phone,
.pty-items .woocommerce-customer-details--email {
  margin: 2px 0 0; font-size: 13px; color: var(--ink-3);
}

@media (max-width: 560px) {
  .pty-items .woocommerce-columns--addresses { grid-template-columns: 1fr; gap: 24px; }
}


/* ==========================================================================
   Cart Page
   ========================================================================== */

.woo-main .shop_table {
  width: 100%; border-collapse: collapse;
}
.woo-main .shop_table th {
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
  padding: 0 12px 12px; border-bottom: 2px solid var(--line);
}
.woo-main .shop_table td {
  padding: 18px 12px; border-bottom: 1px solid var(--line-soft);
  vertical-align: middle; font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink-2);
}
/* Column widths */
.woo-main .shop_table .product-remove { width: 40px; text-align: center; }
.woo-main .shop_table .product-thumbnail { width: 88px; }
.woo-main .shop_table .product-price,
.woo-main .shop_table .product-quantity,
.woo-main .shop_table .product-subtotal { width: 110px; text-align: right; }

/* Thumbnail */
.woo-main .shop_table .product-thumbnail img {
  width: 72px; height: 72px; object-fit: cover; border-radius: 8px;
  border: 1px solid var(--line-soft);
}

/* Product name link */
.woo-main .shop_table .product-name a {
  font-family: 'Barlow', sans-serif; font-weight: 600; font-size: 14px;
  color: var(--green-800);
}
.woo-main .shop_table .product-name a:hover { color: var(--green-600); }

/* Remove button */
.woo-main .shop_table a.remove {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; border-radius: 50%;
  font-size: 16px; color: var(--ink-3); border: 1px solid var(--line);
  transition: all .2s var(--ease);
}
.woo-main .shop_table a.remove:hover {
  background: #7a1c23; color: #fff; border-color: #7a1c23;
}

/* Quantity input in cart */
.woo-main .shop_table .quantity input[type="number"] {
  width: 56px; padding: 6px 8px; text-align: center; border-radius: 6px;
  border: 1px solid var(--line); background: var(--paper);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink);
}
.woo-main .shop_table .quantity input[type="number"]:focus {
  outline: none; border-color: var(--green-500);
}

/* Actions row */
.woo-main .shop_table .actions { padding: 16px 0; }
.woo-main .shop_table .actions .coupon { display: flex; gap: 8px; align-items: center; }
.woo-main .shop_table .actions .coupon input[type="text"] {
  padding: 9px 14px; border: 1px solid var(--line); border-radius: 999px;
  font-family: 'Barlow', sans-serif; font-size: 13px; background: var(--paper);
}
.woo-main .shop_table .actions .button {
  padding: 9px 18px; border: 1px solid var(--green-800); border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--green-800);
  cursor: pointer; transition: all .2s var(--ease);
}
.woo-main .shop_table .actions .button:hover {
  background: var(--green-800); color: var(--cream);
}

/* Cart totals box */
.cart_totals {
  border: 1px solid var(--line); border-radius: 12px;
  padding: 28px; min-width: 300px; max-width: 380px;
  background: var(--paper);
}
.cart_totals h2 {
  font-family: 'Barlow Condensed', sans-serif; font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; color: var(--green-800);
  margin-bottom: 20px;
}
.cart_totals .shop_table { font-size: 14px; }
.cart_totals .shop_table th {
  font-size: 11px; padding: 10px 0; text-align: left; border-bottom: none;
  border-top: 1px solid var(--line-soft);
}
.cart_totals .shop_table td {
  padding: 10px 0; text-align: right; border-bottom: none;
  border-top: 1px solid var(--line-soft);
}
.cart_totals .shop_table tr:first-child th,
.cart_totals .shop_table tr:first-child td { border-top: none; }
.cart_totals .shop_table .order-total th,
.cart_totals .shop_table .order-total td {
  font-weight: 700; color: var(--green-800); font-size: 16px;
  border-top: 2px solid var(--line);
}
.cart_totals .wc-proceed-to-checkout { margin-top: 20px; }
.cart_totals .checkout-button {
  display: block; width: 100%; padding: 14px 24px;
  background: var(--green-800); color: var(--cream);
  border-radius: 999px; text-align: center; font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em;
  transition: background .2s var(--ease);
}
.cart_totals .checkout-button:hover { background: var(--green-700); }

/* Empty cart */
.woocommerce-cart .cart-empty {
  text-align: center; padding: 80px 24px 40px;
  font-family: 'Barlow', sans-serif; color: var(--ink-3); font-size: 15px;
}
.woocommerce-cart .cart-empty::before {
  content: '🛒'; display: block; font-size: 48px; margin-bottom: 16px; opacity: .4;
}
.woocommerce-cart .return-to-shop { text-align: center; margin-top: 24px; }
.woocommerce-cart .return-to-shop .button,
.woocommerce-cart .return-to-shop a {
  display: inline-block; padding: 11px 28px;
  border: 1px solid var(--green-800); border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--green-800);
  transition: all .2s var(--ease);
}
.woocommerce-cart .return-to-shop .button:hover,
.woocommerce-cart .return-to-shop a:hover { background: var(--green-800); color: var(--cream); }

/* ==========================================================================
   Checkout Page
   ========================================================================== */

.woo-main .woocommerce-checkout .form-row {
  margin-bottom: 18px;
}
.woo-main .woocommerce-checkout .form-row label {
  display: block; font-family: 'Barlow Condensed', sans-serif; font-size: 10px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-3); margin-bottom: 6px;
}
.woo-main .woocommerce-checkout .form-row label .required { color: #7a1c23; }
.woo-main .woocommerce-checkout .form-row input[type="text"],
.woo-main .woocommerce-checkout .form-row input[type="email"],
.woo-main .woocommerce-checkout .form-row input[type="tel"],
.woo-main .woocommerce-checkout .form-row input[type="password"],
.woo-main .woocommerce-checkout .form-row textarea,
.woo-main .woocommerce-checkout .form-row select {
  width: 100%; padding: 11px 14px; border: 1px solid var(--line);
  border-radius: 8px; background: var(--paper);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink);
  transition: border-color .2s var(--ease);
  -webkit-appearance: none; appearance: none;
}
.woo-main .woocommerce-checkout .form-row input:focus,
.woo-main .woocommerce-checkout .form-row select:focus,
.woo-main .woocommerce-checkout .form-row textarea:focus {
  outline: none; border-color: var(--green-500);
}
.woo-main .woocommerce-checkout .form-row.woocommerce-invalid input,
.woo-main .woocommerce-checkout .form-row.woocommerce-invalid select {
  border-color: #7a1c23;
}
/* Select arrow */
.woo-main .woocommerce-checkout .form-row select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236F8463'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px;
}

/* Section headings */
.woo-main .woocommerce-billing-fields h3,
.woo-main .woocommerce-shipping-fields h3,
.woo-main .woocommerce-additional-fields h3 {
  font-family: 'Barlow Condensed', sans-serif; font-size: 22px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--green-800);
  margin: 0 0 24px; padding-bottom: 12px; border-bottom: 1px solid var(--line-soft);
}

/* Order review table */
.woocommerce-checkout-review-order-table {
  width: 100%; border-collapse: collapse;
  margin-bottom: 24px; border: 1px solid var(--line); border-radius: 10px; overflow: hidden;
}
.woocommerce-checkout-review-order-table thead th {
  background: var(--sage-50); padding: 12px 16px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
}
.woocommerce-checkout-review-order-table thead .product-total { text-align: right; }
.woocommerce-checkout-review-order-table tbody td {
  padding: 14px 16px; border-bottom: 1px solid var(--line-soft);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink-2);
}
.woocommerce-checkout-review-order-table tbody .product-total { text-align: right; }
.woocommerce-checkout-review-order-table tfoot th {
  padding: 12px 16px !important; text-align: left !important;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3);
  border-top: 1px solid var(--line-soft);
}
.woocommerce-checkout-review-order-table tfoot td {
  padding: 12px 16px !important; text-align: right !important;
  font-size: 14px; color: var(--ink-2); border-top: 1px solid var(--line-soft);
}
.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
  font-weight: 700; color: var(--green-800); font-size: 16px;
  border-top: 2px solid var(--line) !important;
}

/* Payment methods */
#payment { background: var(--paper); border: 1px solid var(--line); border-radius: 10px; padding: 24px; }
#payment .payment_methods { list-style: none; margin: 0 0 20px; }
#payment .payment_methods li { padding: 14px 0; border-bottom: 1px solid var(--line-soft); }
#payment .payment_methods li:last-child { border-bottom: none; }
#payment .payment_methods label {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink-2);
}
#payment .payment_methods input[type="radio"] { accent-color: var(--green-800); width: 16px; height: 16px; }
#payment .payment_box { margin: 8px 0 0 26px; font-size: 13px; color: var(--ink-3); }

/* Place Order button */
#place_order {
  display: block; width: 100%; padding: 16px 24px;
  background: var(--green-800); color: var(--cream);
  border: none; border-radius: 999px; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif; font-size: 15px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .16em;
  transition: background .25s var(--ease), transform .2s var(--ease);
}
#place_order:hover { background: var(--green-700); transform: translateY(-1px); }

/* ==========================================================================
   My Account — Edit Address
   ========================================================================== */

.addr-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3);
  transition: color .2s var(--ease);
}
.addr-back:hover { color: var(--green-800); }
.addr-page-title {
  font-family: 'Barlow Condensed', sans-serif; font-size: 26px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; color: var(--green-800);
  margin: 16px 0 32px;
}

.addr-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0 28px;
}
.addr-grid p.form-row { margin-bottom: 18px; }
.addr-grid .form-row.form-row-wide,
.addr-grid .form-row.address-field.validate-required:has(#billing_address_1),
.addr-grid p#billing_address_1_field,
.addr-grid p#billing_address_2_field,
.addr-grid p#billing_city_field,
.addr-grid p#billing_country_field,
.addr-grid p#shipping_address_1_field,
.addr-grid p#shipping_address_2_field,
.addr-grid p#shipping_city_field,
.addr-grid p#shipping_country_field { grid-column: 1 / -1; }

.addr-form label {
  display: block; font-family: 'Barlow Condensed', sans-serif; font-size: 10px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-3); margin-bottom: 6px;
}
.addr-form input[type="text"],
.addr-form input[type="tel"],
.addr-form input[type="email"],
.addr-form select {
  width: 100%; padding: 11px 14px; border: 1px solid var(--line);
  border-radius: 8px; background: var(--paper);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink);
  -webkit-appearance: none; appearance: none; transition: border-color .2s var(--ease);
}
.addr-form input:focus, .addr-form select:focus { outline: none; border-color: var(--green-500); }
.addr-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236F8463'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px;
}
.addr-submit {
  margin-top: 28px; padding: 13px 32px;
  background: var(--green-800); color: var(--cream); border: none; border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; cursor: pointer;
  transition: background .25s var(--ease);
}
.addr-submit:hover { background: var(--green-700); }

/* Account details form extras */
.acct-field-hint {
  display: block; margin-top: 5px;
  font-family: 'Barlow', sans-serif; font-size: 11px; color: var(--ink-3);
}
.acct-password-section {
  border: 1px solid var(--line-soft); border-radius: 10px;
  padding: 20px 20px 4px; margin: 28px 0 0;
}
.acct-section-label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--green-800);
  padding: 0 8px;
}
.acct-form-footer { margin-top: 28px; }

@media (max-width: 640px) {
  .addr-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   404 Page
   ========================================================================== */

.page-404 {
  display: flex; align-items: center; justify-content: center;
  min-height: 70vh; padding: 88px 28px;
}
.page-404-inner { text-align: center; max-width: 520px; }
.page-404-number {
  display: block; font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(100px, 20vw, 180px); font-weight: 700; line-height: 1;
  color: var(--sage-200); letter-spacing: -.02em; user-select: none;
}
.page-404-heading {
  font-family: 'Barlow Condensed', sans-serif; font-size: 32px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--green-800);
  margin: 8px 0 16px;
}
.page-404-message {
  font-family: 'Barlow', sans-serif; font-size: 15px; color: var(--ink-3);
  line-height: 1.65; margin-bottom: 36px;
}
.page-404-cta {
  display: inline-block; padding: 13px 32px;
  background: var(--green-800); color: var(--cream); border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  transition: background .25s var(--ease), transform .2s var(--ease);
}
.page-404-cta:hover { background: var(--green-700); transform: translateY(-2px); }

/* ==========================================================================
   Legal Pages (Privacy Policy, Terms & Conditions)
   ========================================================================== */

.legal-page { padding-top: 72px; padding-bottom: 100px; }
.legal-wrap { max-width: 760px; margin: 0 auto; }

.legal-page .legal-updated {
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
  margin-bottom: 12px;
}
.legal-page h1 {
  font-family: 'Barlow Condensed', sans-serif; font-size: clamp(32px, 5vw, 52px);
  font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
  color: var(--green-800); margin-bottom: 24px; line-height: 1.1;
}
.legal-page .legal-intro {
  font-family: 'Barlow', sans-serif; font-size: 15px; color: var(--ink-2);
  line-height: 1.75; margin-bottom: 48px; padding-bottom: 32px;
  border-bottom: 2px solid var(--line);
}
.legal-page h2 {
  font-family: 'Barlow Condensed', sans-serif; font-size: 20px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--green-800);
  margin-top: 40px; margin-bottom: 14px; padding-bottom: 8px;
  border-bottom: 1px solid var(--line-soft);
}
.legal-page h3 {
  font-family: 'Barlow', sans-serif; font-size: 14px; font-weight: 700;
  color: var(--green-700); margin-top: 20px; margin-bottom: 8px;
  text-transform: uppercase; letter-spacing: .08em;
}
.legal-page p {
  font-family: 'Barlow', sans-serif; font-size: 15px; color: var(--ink-2);
  line-height: 1.75; margin-bottom: 14px;
}
.legal-page ul {
  margin: 0 0 16px 0; padding-left: 20px;
}
.legal-page ul li {
  font-family: 'Barlow', sans-serif; font-size: 15px; color: var(--ink-2);
  line-height: 1.75; margin-bottom: 6px;
}
.legal-page a { color: var(--green-600); text-decoration: underline; }
.legal-page a:hover { color: var(--green-800); }
.legal-table {
  width: 100%; border-collapse: collapse; margin: 16px 0 20px; font-size: 14px;
}
.legal-table th {
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
  padding: 10px 14px; background: var(--sage-50); border-bottom: 2px solid var(--line);
  text-align: left;
}
.legal-table td {
  padding: 10px 14px; border-bottom: 1px solid var(--line-soft);
  font-family: 'Barlow', sans-serif; color: var(--ink-2); vertical-align: top;
}
.legal-table tr:last-child td { border-bottom: none; }

/* ==========================================================================
   Cookie Consent Banner
   ========================================================================== */

.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999;
  background: var(--green-900); color: var(--cream);
  padding: 18px 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  transform: translateY(0); transition: transform .4s var(--ease);
  box-shadow: 0 -4px 24px rgba(0,0,0,.18);
}
.cookie-banner.is-hidden { transform: translateY(110%); pointer-events: none; }
.cookie-banner-text {
  font-family: 'Barlow', sans-serif; font-size: 13px; color: var(--sage-300);
  line-height: 1.55; flex: 1;
}
.cookie-banner-text a { color: var(--sage-400); text-decoration: underline; }
.cookie-banner-text a:hover { color: var(--cream); }
.cookie-banner-actions { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-btn-accept {
  padding: 9px 20px; background: var(--green-500); color: var(--cream);
  border: none; border-radius: 999px; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  transition: background .2s var(--ease);
}
.cookie-btn-accept:hover { background: var(--green-400); }
.cookie-btn-decline {
  padding: 9px 20px; background: transparent; color: var(--sage-300);
  border: 1px solid var(--sage-500); border-radius: 999px; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  transition: all .2s var(--ease);
}
.cookie-btn-decline:hover { background: rgba(255,255,255,.07); color: var(--cream); }

@media (max-width: 640px) {
  .cookie-banner { flex-direction: column; align-items: flex-start; padding: 20px 20px 24px; }
  .cookie-banner-actions { width: 100%; }
  .cookie-btn-accept, .cookie-btn-decline { flex: 1; text-align: center; }
}


/* ==========================================================================
   Select2 — WooCommerce country / state dropdowns
   (applies inside address form, checkout, and any WC select2 field)
   ========================================================================== */

.addr-form .select2-container,
.checkout-page-wrap .select2-container,
.woo-main .select2-container {
  width: 100% !important;
}
.addr-form .select2-container .select2-selection--single,
.checkout-page-wrap .select2-container .select2-selection--single,
.woo-main .select2-container .select2-selection--single {
  height: auto !important; min-height: 46px;
  padding: 10px 36px 10px 14px !important;
  border: 1px solid var(--line) !important; border-radius: 8px !important;
  background: var(--paper) !important; box-shadow: none !important;
  display: flex; align-items: center;
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink) !important;
  transition: border-color .2s var(--ease);
}
.addr-form .select2-container--open .select2-selection--single,
.addr-form .select2-container .select2-selection--single:focus,
.checkout-page-wrap .select2-container--open .select2-selection--single,
.woo-main .select2-container--open .select2-selection--single {
  border-color: var(--green-500) !important; outline: none !important;
}
/* Hide default arrow, we'll use CSS */
.addr-form .select2-selection__arrow,
.checkout-page-wrap .select2-selection__arrow,
.woo-main .select2-selection__arrow {
  display: none !important;
}
.addr-form .select2-container .select2-selection--single::after,
.checkout-page-wrap .select2-container .select2-selection--single::after,
.woo-main .select2-container .select2-selection--single::after {
  content: '';
  position: absolute; right: 14px; top: 50%; transform: translateY(-50%);
  width: 10px; height: 6px; pointer-events: none;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236F8463'/%3E%3C/svg%3E") no-repeat center;
}
.addr-form .select2-container .select2-selection--single,
.checkout-page-wrap .select2-container .select2-selection--single,
.woo-main .select2-container .select2-selection--single {
  position: relative;
}
.addr-form .select2-selection__rendered,
.checkout-page-wrap .select2-selection__rendered,
.woo-main .select2-selection__rendered {
  padding: 0 !important; line-height: 1 !important;
  color: var(--ink) !important;
  font-family: 'Barlow', sans-serif !important; font-size: 14px !important;
}
/* Dropdown */
.select2-dropdown {
  border: 1px solid var(--line) !important; border-radius: 8px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,.1) !important; background: var(--paper) !important;
  overflow: hidden;
}
.select2-search--dropdown .select2-search__field {
  border: 1px solid var(--line) !important; border-radius: 6px !important;
  padding: 8px 10px !important; font-family: 'Barlow', sans-serif !important;
  font-size: 13px !important;
}
.select2-results__option {
  font-family: 'Barlow', sans-serif !important; font-size: 14px !important;
  color: var(--ink-2) !important; padding: 10px 14px !important;
}
.select2-results__option--highlighted,
.select2-results__option[aria-selected="true"] {
  background: var(--sage-50) !important; color: var(--green-800) !important;
}


/* ==========================================================================
   Cart Page — full redesign classes
   ========================================================================== */

/* ==========================================================================
   Cart Page
   ========================================================================== */

.cart-page-wrap {
  padding-top: 80px !important;
  padding-bottom: 140px !important;
}

/* Heading */
.cart-page-heading {
  font-family: 'Barlow Condensed', sans-serif; font-size: clamp(28px, 4vw, 42px);
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: var(--green-800); margin-bottom: 40px;
}

/* ── Two-column layout ──────────────────────────────────────────────── */
.cart-layout {
  display: grid; grid-template-columns: 1fr 360px; gap: 48px; align-items: start;
}
@media (max-width: 900px) {
  .cart-layout { grid-template-columns: 1fr; }
}

/* ── Cart table ─────────────────────────────────────────────────────── */
.cart-table { width: 100%; border-collapse: collapse; }

/* Column headers */
.cart-table th {
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; color: var(--ink-3);
  padding: 0 0 12px; border-bottom: 1px solid var(--line); text-align: left;
}
.ct-head-sub   { text-align: right !important; }
.ct-head-remove { width: 36px; }

/* Cells */
.cart-table td {
  padding: 20px 0; border-bottom: 1px solid var(--line-soft);
  vertical-align: top; font-family: 'Barlow', sans-serif;
  font-size: 14px; color: var(--ink-2);
}

/* Thumbnail column */
.ct-thumb { width: 96px; padding-right: 20px !important; }
.ct-thumb a { display: block; line-height: 0; }
.ct-thumb img {
  width: 88px; height: 88px; object-fit: cover; border-radius: 10px;
  border: 1px solid var(--line-soft); display: block;
}

/* Info column: name + meta */
.ct-info { padding-right: 20px !important; }

.ct-info-name {
  font-family: 'Barlow Condensed', sans-serif; font-size: 17px; font-weight: 700;
  letter-spacing: .02em; line-height: 1.3; color: var(--green-800);
  text-decoration: none; display: inline-block; margin-bottom: 6px;
}
.ct-info-name:hover { color: var(--green-600); }

/* Variation / plan data — styled as pills */
.ct-item-meta { margin: 6px 0 0; }
.ct-item-meta .variation,
.ct-item-meta .wc-item-meta {
  display: flex; flex-wrap: wrap; gap: 5px;
  list-style: none; margin: 0; padding: 0;
}
.ct-item-meta .variation dt,
.ct-item-meta .variation dd,
.ct-item-meta .wc-item-meta li {
  display: inline-flex; align-items: center; gap: 4px;
  border-radius: 999px; padding: 3px 10px;
  padding-left:0;
  font-family: 'Barlow', sans-serif; font-size: 11px; color: var(--ink-2);
  margin: 0;
}
.ct-item-meta .variation dt::after { content: ':'; margin-right: 2px; }
.ct-item-meta .wc-item-meta-label { font-weight: 600; color: var(--ink-3); margin-right: 2px; }
/* Fallback if WC outputs plain <p> tags inside meta wrapper */
.ct-item-meta p {
  display: inline-flex; align-items: center;
  background: var(--sage-50); border: 1px solid var(--line);
  border-radius: 999px; padding: 3px 10px; margin: 0;
  font-family: 'Barlow', sans-serif; font-size: 11px; color: var(--ink-2);
}

/* Subtotal column */
.ct-sub {
  width: 100px; text-align: right; font-weight: 700; font-size: 15px;
  color: var(--green-800); padding-left: 12px !important; white-space: nowrap;
}

/* Remove column */
.ct-remove { width: 36px; padding-left: 12px !important; text-align: right; }
.ct-remove-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  font-size: 15px; color: var(--ink-3); border: 1px solid var(--line);
  text-decoration: none; transition: background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
}
.ct-remove-btn:hover { background: #7a1c23; color: #fff; border-color: #7a1c23; }

/* ── Mobile: card layout ─────────────────────────────────────────────── */
@media (max-width: 640px) {
  .cart-table thead { display: none; }
  .cart-table,
  .cart-table tbody { display: block; }
  .cart-table tr {
    display: grid;
    grid-template-columns: 88px 1fr 36px;
    grid-template-rows: auto auto;
    column-gap: 14px;
    padding: 16px 0; border-bottom: 1px solid var(--line-soft);
  }
  .cart-table td { padding: 0 !important; border: none; }
  .ct-thumb  { grid-column: 1; grid-row: 1 / 3; }
  .ct-info   { grid-column: 2; grid-row: 1; padding-right: 0 !important; }
  .ct-remove { grid-column: 3; grid-row: 1; text-align: right; }
  .ct-sub    { grid-column: 2; grid-row: 2; padding-top: 10px !important;
               text-align: left; font-size: 15px; }
}

/* ── Cart actions ───────────────────────────────────────────────────── */
.cart-actions {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 0 0; gap: 12px; flex-wrap: wrap;
}
.cart-actions-left {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.cart-continue-link {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
  text-decoration: none; transition: color .2s var(--ease);
}
.cart-continue-link:hover { color: var(--green-800); }
.cart-coupon { display: flex; gap: 8px; align-items: center; }
.cart-coupon-input {
  padding: 9px 16px; border: 1px solid var(--line); border-radius: 999px;
  font-family: 'Barlow', sans-serif; font-size: 13px; color: var(--ink);
  background: var(--paper); width: 180px; outline: none;
  transition: border-color .2s var(--ease);
}
.cart-coupon-input:focus { border-color: var(--green-700); }
.cart-coupon-btn {
  padding: 9px 20px; border: 1px solid var(--green-800); border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--green-800);
  cursor: pointer; background: transparent; white-space: nowrap;
  transition: all .2s var(--ease);
}
.cart-coupon-btn:hover { background: var(--green-800); color: var(--cream); }
/* Update cart button — hidden, triggered via JS */
.cart-update-btn { display: none; }

/* ── Cart totals panel ──────────────────────────────────────────────── */
.cart-totals-col .cart_totals {
  border: 1px solid var(--line); border-radius: 14px;
  padding: 24px; background: var(--paper);
  position: sticky; top: 100px;
}
.cart-totals-col .cart_totals h2 {
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; color: var(--green-800);
  margin-bottom: 20px;
}
.cart-totals-col .shop_table { width: 100%; border-collapse: collapse;     display: flex;
    flex-direction: column;}
    .cart-totals-col .shop_table tr{
      display: flex; justify-content: space-between; width: 100%;
    }
.cart-totals-col .shop_table th,
.cart-totals-col .shop_table td {
  font-family: 'Barlow', sans-serif; font-size: 14px;
  padding: 12px 0; color: var(--ink-2); border-top: 1px solid var(--line-soft);
}
.cart-totals-col .shop_table tr.order-total{
  border-top: 1px solid var(--line) !important;
}
.cart-totals-col .shop_table tr.order-total * {
  border: none !important;
}
.cart-totals-col .shop_table th { text-align: left; font-weight: 500; }
.cart-totals-col .shop_table td { text-align: right; }
.cart-totals-col .shop_table tr:first-child th,
.cart-totals-col .shop_table tr:first-child td { border-top: none; }
.cart-totals-col .shop_table .order-total th,
.cart-totals-col .shop_table .order-total td {
  font-weight: 700; color: var(--green-800); font-size: 17px;
  border-top: 2px solid var(--line); padding-top: 16px;
  display: flex; justify-content: center; align-items: center;
}
.cart-totals-col .wc-proceed-to-checkout { margin-top: 20px; }
.cart-totals-col .checkout-button {
  display: block; width: 100%; padding: 15px 24px;
  background: var(--green-800); color: var(--cream); border: none;
  border-radius: 999px; text-align: center; text-decoration: none;
  font-family: 'Barlow Condensed', sans-serif; font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .16em;
  transition: background .2s var(--ease), transform .2s var(--ease);
}
.cart-totals-col .checkout-button:hover { background: var(--green-700); transform: translateY(-1px); }

/* ── Shipping section in cart totals: stacked block layout ──────────── */
/* Break the shipping row out of the 2-col table layout */
.cart-totals-col .shop_table .woocommerce-shipping-totals,
.cart-totals-col .shop_table .woocommerce-shipping-totals td {
  display: flex;
  min-width: 100% !important;
  flex: 1 1 0;
  padding-left: 0;
  padding-right: 0;
  text-align: left !important;
  border: none;
}
.cart-totals-col .shop_table .woocommerce-shipping-totals tr {
    display: flex !important;
  width: 100%;
  text-align: left !important;
}
.cart-totals-col .shop_table .woocommerce-shipping-totals td {
  display: flex;
  flex-direction: column;
  flex:1 ;
  width: 100%;
  text-align: left !important;
}
/* Hide the <th> — label lives inside the td via ::before */
.cart-totals-col .shop_table .woocommerce-shipping-totals th {
  display: none;
}
.cart-totals-col .shop_table .woocommerce-shipping-totals {
  border-top: 1px solid var(--line-soft);
  padding: 16px 0 12px;
}
/* "Shipping" title rendered inside the td, above the methods list */
.cart-totals-col .shop_table .woocommerce-shipping-totals td::before {
  content: 'Shipping';
  display: block;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; color: var(--ink-3);
  margin-bottom: 12px;
}

/* Shipping methods list */
.woocommerce-shipping-methods {
  list-style: none; margin: 0 0 10px; padding: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.woocommerce-shipping-methods li {
  display: flex; align-items: center;gap: 8px;
}
.woocommerce-shipping-methods label {
  font-family: 'Barlow', sans-serif; font-size: 13px; color: var(--ink);
  cursor: pointer; display: flex; align-items: center; gap: 8px;
  flex: 1; padding: 8px 10px;
  border: 1px solid var(--line); border-radius: 8px;
  transition: border-color .15s var(--ease), background .15s var(--ease);
}
.woocommerce-shipping-methods li:has(input:checked) label,
.woocommerce-shipping-methods label:hover {
  border-color: var(--green-600); background: var(--sage-50);
}
.woocommerce-shipping-methods input[type="radio"] {
  accent-color: var(--green-800); width: 14px; height: 14px; flex-shrink: 0;
}
.woocommerce-shipping-methods .amount {
  font-size: 12px; font-weight: 700; color: var(--green-800); margin-left: auto;
}

/* Address line + Change address button */
.woocommerce-shipping-destination {
  font-family: 'Barlow', sans-serif; font-size: 12px; color: var(--ink-3);
  margin: 0; display: flex; flex-direction: column; gap: 8px; align-items: flex-start;
}
/* Strip any inline text before the link so it renders cleanly */
.woocommerce-shipping-destination > :not(a) {
  font-size: 11px;
}
a.shipping-calculator-button,
button.shipping-calculator-button {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  border: 1px solid var(--line); border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--ink-2);
  background: var(--paper); cursor: pointer; text-decoration: none;
  transition: border-color .2s var(--ease), color .2s var(--ease), background .2s var(--ease);
}
a.shipping-calculator-button:hover,
button.shipping-calculator-button:hover {
  border-color: var(--green-700); color: var(--green-800); background: var(--sage-50);
}

/* Shipping calculator form */
.shipping-calculator-form {
  margin-top: 14px; display: flex; flex-direction: column; gap: 10px;
}
.shipping-calculator-form p,
.shipping-calculator-form .form-row { margin: 0; }
.shipping-calculator-form label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3);
  display: block; margin-bottom: 4px;
}
.shipping-calculator-form .input-text,
.shipping-calculator-form select {
  width: 100%; padding: 9px 12px; border: 1px solid var(--line); border-radius: 8px;
  font-family: 'Barlow', sans-serif; font-size: 13px; color: var(--ink);
  background: #fff; box-sizing: border-box; outline: none;
  transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.shipping-calculator-form .input-text:focus,
.shipping-calculator-form select:focus {
  border-color: var(--green-700); box-shadow: 0 0 0 3px rgba(90,120,80,.1);
}
.shipping-calculator-form .select2-container { width: 100% !important; }
.shipping-calculator-form .select2-container--default .select2-selection--single {
  height: auto; border: 1px solid var(--line); border-radius: 8px; padding: 9px 12px;
}
.shipping-calculator-form .select2-container--default .select2-selection--single .select2-selection__rendered {
  padding: 0; line-height: 1.4; color: var(--ink);
}
.shipping-calculator-form .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%; top: 0;
}
.shipping-calculator-form [name="calc_shipping"] {
  width: 100%; padding: 10px 20px; background: var(--green-800); color: var(--cream);
  border: none; border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  cursor: pointer; transition: background .2s var(--ease);
}
.shipping-calculator-form [name="calc_shipping"]:hover { background: var(--green-700); }

/* No-shipping notices */
.cart-totals-col .woocommerce-no-shipping-available-html,
.cart-totals-col .woocommerce-shipping-not-supported-html {
  font-family: 'Barlow', sans-serif; font-size: 12px; color: var(--ink-3); margin: 0;
}

/* ── Empty cart state ───────────────────────────────────────────────── */
.cart-empty-state {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; padding: 100px 28px;
}
.cart-empty-icon { color: var(--sage-300); margin-bottom: 24px; }
.cart-empty-heading {
  font-family: 'Barlow Condensed', sans-serif; font-size: 32px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--green-800); margin: 0 0 12px;
}
.cart-empty-msg {
  font-family: 'Barlow', sans-serif; font-size: 15px; color: var(--ink-3); margin-bottom: 32px;
}
.cart-empty-btn {
  display: inline-block; padding: 13px 32px;
  background: var(--green-800); color: var(--cream); border-radius: 999px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 13px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  transition: background .25s var(--ease), transform .2s var(--ease);
}
.cart-empty-btn:hover { background: var(--green-700); transform: translateY(-2px); }



/* ==========================================================================
   Checkout Page — redesign classes
   ========================================================================== */

.checkout-page-wrap {
  padding: 72px 28px 100px;
}
.checkout-page-heading {
  font-family: 'Barlow Condensed', sans-serif; font-size: clamp(28px, 4vw, 42px);
  font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  color: var(--green-800); margin-bottom: 48px;
}

/* Two-column layout */
.checkout-cols {
  display: grid; grid-template-columns: 1fr 420px; gap: 56px; align-items: start;
}
@media (max-width: 960px) {
  .checkout-cols { grid-template-columns: 1fr; }
}
.checkout-col-order {
  position: sticky; top: 100px;
  align-self: start;            /* essential: grid item must not stretch to row height */
}
.checkout-order-heading {
  font-family: 'Barlow Condensed', sans-serif; font-size: 20px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--green-800);
  margin-bottom: 20px;
}

/* Billing/Shipping field sections */
.checkout-form .woocommerce-billing-fields h3,
.checkout-form .woocommerce-shipping-fields h3,
.checkout-form .woocommerce-additional-fields h3 {
  font-family: 'Barlow Condensed', sans-serif; font-size: 18px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--green-800);
  margin: 0 0 20px; padding-bottom: 10px; border-bottom: 1px solid var(--line-soft);
}
.checkout-form .woocommerce-shipping-fields { margin-top: 36px; }

/* Form rows */
.checkout-form .form-row { margin-bottom: 16px; }
.checkout-form .form-row label {
  display: block; font-family: 'Barlow Condensed', sans-serif; font-size: 10px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .12em;
  color: var(--ink-3); margin-bottom: 6px;
}
.checkout-form .form-row label .required { color: #7a1c23; }
.checkout-form .form-row input.input-text,
.checkout-form .form-row input[type="text"],
.checkout-form .form-row input[type="email"],
.checkout-form .form-row input[type="tel"],
.checkout-form .form-row input[type="password"],
.checkout-form .form-row textarea,
.checkout-form .form-row select {
  width: 100%; padding: 11px 14px; border: 1px solid var(--line);
  border-radius: 8px; background: var(--paper);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink);
  -webkit-appearance: none; appearance: none;
  transition: border-color .2s var(--ease);
}
.checkout-form .form-row input:focus,
.checkout-form .form-row select:focus,
.checkout-form .form-row textarea:focus {
  outline: none; border-color: var(--green-500);
}
.checkout-form .form-row.woocommerce-invalid input,
.checkout-form .form-row.woocommerce-invalid select {
  border-color: #7a1c23;
}
.checkout-form .form-row select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236F8463'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 36px;
}

/* Two-col form rows */
.checkout-form .form-row-first { float: left; width: 48%; clear: left; }
.checkout-form .form-row-last  { float: right; width: 48%; }
.checkout-form .form-row-wide  { clear: both; }
.checkout-form #customer_details::after,
.checkout-form .woocommerce-billing-fields::after,
.checkout-form .woocommerce-shipping-fields::after { content: ''; display: table; clear: both; }

/* Checkout order review table */
.checkout-form #order_review,
.woocommerce-checkout-review-order {
  border: 1px solid var(--line); border-radius: 12px; overflow: hidden;
  background: var(--paper);
}
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; }
.woocommerce-checkout-review-order-table thead th {
  background: var(--sage-50); padding: 12px 18px;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
  text-align: left;
}
.woocommerce-checkout-review-order-table thead .product-total { text-align: right; }
.woocommerce-checkout-review-order-table tbody td {
  padding: 14px 18px; border-bottom: 1px solid var(--line-soft);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink-2);
}
.woocommerce-checkout-review-order-table tbody .product-total { text-align: right; }
.woocommerce-checkout-review-order-table tfoot th {
  padding: 11px 18px; text-align: left;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3);
  border-top: 1px solid var(--line-soft);
}
.woocommerce-checkout-review-order-table tfoot td {
  padding: 11px 18px; text-align: right;
  font-size: 14px; color: var(--ink-2); border-top: 1px solid var(--line-soft);
}
.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
  font-weight: 700; color: var(--green-800); font-size: 17px;
  border-top: 2px solid var(--line);
}

/* ── Shipping row in checkout order summary ──────────────────────────── */
/* Hide the <th> — label rendered via ::before on the <td> */
.woocommerce-checkout-review-order-table tfoot .woocommerce-shipping-totals th { display: none; }
.woocommerce-checkout-review-order-table tfoot .woocommerce-shipping-totals td {
  width: 100%; text-align: left !important;;
}
.woocommerce-checkout-review-order-table tfoot .woocommerce-shipping-totals td::before {
  content: 'Shipping';
  display: block;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em; color: var(--ink-3);
  margin-bottom: 8px;
}

/* Payment box */
#payment {
  background: var(--paper); border-top: 1px solid var(--line-soft);
  padding: 20px 18px 18px;
}

/* Payment method card list */
#payment .payment_methods {
  list-style: none; margin: 0 0 16px; padding: 0;
  display: flex; flex-direction: column; gap: 8px;
}

/* Each method = a selectable card */
#payment .payment_methods li.wc_payment_method {
  border: 1.5px solid var(--line);
  border-radius: 10px;
  padding: 0;
  background: var(--paper);
  transition: border-color .2s var(--ease), background .2s var(--ease);
  overflow: hidden;
}

/* Highlight the selected card */
#payment .payment_methods li.wc_payment_method:has(input[type="radio"]:checked) {
  border-color: var(--green-800);
  background: var(--sage-50);
}

/* Hide native radio — replaced by custom dot */
#payment .payment_methods input[type="radio"] {
  position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none;
}

/* Label row — this is the clickable card face */
#payment .payment_methods li.wc_payment_method > label {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; cursor: pointer;
  font-family: 'Barlow', sans-serif; font-size: 14px; font-weight: 500;
  color: var(--ink);
}

/* Custom radio circle */
#payment .payment_methods li.wc_payment_method > label::before {
  content: '';
  flex-shrink: 0;
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--line);
  background: var(--paper);
  transition: border-color .2s var(--ease), background .2s var(--ease);
  box-shadow: inset 0 0 0 4px var(--paper);
}

/* Filled dot when selected */
#payment .payment_methods li.wc_payment_method:has(input:checked) > label::before {
  border-color: var(--green-800);
  background: var(--green-800);
  box-shadow: inset 0 0 0 3px var(--sage-50);
}

/* Payment description box (shown when method is selected) */
#payment .payment_box {
  margin: 0; padding: 0 16px 14px 46px;
  font-family: 'Barlow', sans-serif; font-size: 13px;
  color: var(--ink-3); line-height: 1.5;
}
#payment .payment_box p { margin: 0; }

/* Place Order */
#place_order {
  display: block; width: 100%; padding: 16px 24px;
  background: var(--green-800); color: var(--cream);
  border: none; border-radius: 999px; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif; font-size: 15px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .16em;
  transition: background .25s var(--ease), transform .2s var(--ease);
  margin-top: 4px;
}
#place_order:hover { background: var(--green-700); transform: translateY(-1px); }

/* ── Cart items in order review ──────────────────────────────────────── */
/* Clean up the product-name cell: name on top, qty badge below */
.woocommerce-checkout-review-order-table tbody .cart_item td.product-name {
  display: flex; flex-direction: column; gap: 4px;
}
.woocommerce-checkout-review-order-table tbody .cart_item td.product-name > *:first-child {
  font-family: 'Barlow', sans-serif; font-size: 14px; font-weight: 600;
  color: var(--ink);
}
/* Quantity badge */
.woocommerce-checkout-review-order-table .product-quantity {
  display: none;
}
/* Subtotal column */
.woocommerce-checkout-review-order-table tbody .product-total {
  vertical-align: middle;
}
.woocommerce-checkout-review-order-table tbody .product-total .woocommerce-Price-amount {
  font-family: 'Barlow Condensed', sans-serif; font-size: 15px; font-weight: 700;
  color: var(--green-800);
}
/* Variation meta inside cart item */
.woocommerce-checkout-review-order-table .variation {
  margin: 4px 0 0; padding: 0; list-style: none;
  display: flex; flex-wrap: wrap; gap: 4px;
}
.woocommerce-checkout-review-order-table .variation dt,
.woocommerce-checkout-review-order-table .variation dd {
  margin: 0;
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3);
  background: var(--sage-50); border: 1px solid var(--line);
  border-radius: 999px; padding: 2px 8px;
}
.woocommerce-checkout-review-order-table .variation dd::before { content: none; }

/* ── Coupon form on checkout ─────────────────────────────────────────── */
.checkout-page-wrap .woocommerce-form-coupon-toggle,
.checkout-page-wrap .woocommerce-info {
  margin-bottom: 20px;
  padding: 12px 16px;
  background: var(--sage-50); border: 1px solid var(--line);
  border-radius: 10px;
  font-family: 'Barlow', sans-serif; font-size: 13px; color: var(--ink-2);
}
.checkout-page-wrap .woocommerce-info a.showcoupon {
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--green-800); text-decoration: underline;
}
.checkout_coupon.woocommerce-form-coupon {
  display: flex; gap: 10px; align-items: flex-end;
  margin-bottom: 32px; padding: 16px 20px;
  background: var(--sage-50); border: 1px solid var(--line); border-radius: 10px;
}
.checkout_coupon .form-row { margin: 0; flex: 1; }
.checkout_coupon .form-row label {
  font-family: 'Barlow Condensed', sans-serif; font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--ink-3);
  display: block; margin-bottom: 6px;
}
.checkout_coupon .form-row input.input-text {
  width: 100%; padding: 11px 14px; border: 1px solid var(--line);
  border-radius: 8px; background: var(--paper);
  font-family: 'Barlow', sans-serif; font-size: 14px; color: var(--ink);
  transition: border-color .2s var(--ease);
}
.checkout_coupon .form-row input.input-text:focus { outline: none; border-color: var(--green-500); }
.checkout_coupon .button[name="apply_coupon"] {
  padding: 11px 20px; flex-shrink: 0;
  background: var(--green-800); color: var(--cream);
  border: none; border-radius: 999px; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; white-space: nowrap;
  transition: background .2s var(--ease);
}
.checkout_coupon .button[name="apply_coupon"]:hover { background: var(--green-700); }

/* ── Privacy policy notice — redundant, hidden ───────────────────────── */
/* Prolina has a linked Privacy Policy; this inline text is not needed. */
.woocommerce-privacy-policy-text { display: none; }
