/** Shopify CDN: Minification failed

Line 1128:12 Unexpected ";"

**/
/* ═══════════════════════════════════════
   DESIGN SYSTEM
═══════════════════════════════════════ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

img {
  display: block;
  max-width: 100%;
}

button {
  cursor: pointer;
}

a {
  text-decoration: none;
  cursor: pointer;
}

.sub-menu a {
  padding: 0;
}

:root {
  --heading-color: #561A24;
  --canvas: #F8F2E6;
  --canvas2: #F2EAD8;
  --canvas3: #EDE2CC;
  --canvas-dk: #E2D5BE;
  --ink: #1A1206;
  --ink2: #2E2014;
  --ink3: #323232;
  --ink4: #7A6654;
  --ink5: #A89880;
  --gold: #A8681A;
  --gold2: #C8881E;
  --gold3: #E8AA38;
  --gold-pale: #F5E8C8;
  --gold-line: rgba(168, 104, 26, .18);
  --jungle: #1C2B1A;
  --jungle2: #243322;
  --burg: #6A1428;
  --teal: #183448;
  --blush: #B87080;
  --ochre: #B85C14;
  --D: 'Cormorant', serif;
  --S: 'EB Garamond', serif;
  --U: 'Jost', sans-serif;
}

body {
  font-family: var(--U);
  background: var(--canvas);
  color: var(--ink);
  overflow-x: hidden;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9000;
  opacity: .016;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
}

::-webkit-scrollbar {
  width: 3px;
}

::-webkit-scrollbar-thumb {
  background: var(--gold-line);
}

/* page routing */
.page {
  display: none;
}

.page.active {
  display: block;
}

/* ── TYPOGRAPHY ── */
.t-disp {
  font-family: var(--D);
  font-weight: 300;
  line-height: .95;
}

.t-serif {
  font-family: var(--S);
  font-weight: 400;
  line-height: 1.8;
}

.rule {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size:14px;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  font-family: var(--U);
  padding-bottom: 9px;
}

.rule::before,
.rule::after {
  content: '';
  flex: 1;
  height: 0.5px;
  background:var(--gold);
}

.rule-c {
  justify-content: center;
}

.rule-dk {
  color: rgba(200, 146, 26, .65);
}

.rule-dk::before,
.rule-dk::after {
  background: rgba(200, 146, 26, .15);
}

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 13px 32px;
  font-size: 13px;
  letter-spacing: .24em;
  text-transform: uppercase;
  font-weight: 400;
  border: none;
  font-family: var(--U);
  transition: all .28s;
}

.btn-ink {
  background: var(--ink);
  color: var(--canvas);
}

.btn-ink:hover {
  background: var(--ink2);
  box-shadow: 0 8px 24px rgba(26, 18, 6, .16);
}

.btn-gold {
  background: var(--gold);
  color: var(--canvas);
}

.btn-gold:hover {
  background: var(--heading-color);
}

.btn-ghost {
  background: transparent;
  border: 1px solid var(--gold-line);
  color: var(--ink3);
}

.btn-ghost:hover {
  border-color: var(--gold);
  color: var(--gold2);
  background: var(--gold-pale);
}

.btn-ghost-dk {
  background: transparent;
  border: 1px solid rgba(200, 146, 26, .25);
  color: rgba(248, 242, 230, .7);
}

.btn-ghost-dk:hover {
  border-color: rgba(200, 146, 26, .6);
  background: rgba(200, 146, 26, .08);
  color: var(--canvas);
}

/* ── ANIMATIONS ── */
/* .reveal { opacity:0; transform:translateY(18px); transition:opacity .75s ease, transform .75s ease; } */
.reveal.vis {
  opacity: 1;
  transform: none;
}

.d1 {
  transition-delay: .12s
}

.d2 {
  transition-delay: .24s
}

.d3 {
  transition-delay: .38s
}

.d4 {
  transition-delay: .52s
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(16px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@keyframes pip {

  0%,
  100% {
    opacity: 1;
    transform: scale(1)
  }

  50% {
    opacity: .4;
    transform: scale(.7)
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg)
  }
}

@keyframes mq {
  from {
    transform: translateX(0)
  }

  to {
    transform: translateX(-50%)
  }
}

@keyframes sweep {
  0% {
    top: 22%;
    opacity: 0
  }

  8% {
    opacity: 1
  }

  92% {
    opacity: 1
  }

  100% {
    top: 78%;
    opacity: 0
  }
}

@keyframes ldot {

  0%,
  100% {
    opacity: .3;
    transform: scale(.8)
  }

  50% {
    opacity: 1;
    transform: scale(1)
  }
}

@keyframes rg {

  0%,
  100% {
    transform: scale(1);
    opacity: .6
  }

  50% {
    transform: scale(1.18);
    opacity: .4
  }
}

@keyframes rslow {
  from {
    transform: rotate(0)
  }

  to {
    transform: rotate(360deg)
  }
}

.pip {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold3);
  animation: pip 2.2s ease-in-out infinite;
}

/* ── NAV ── */
header {
  position: relative;
  top: 0;
  left: 0;
  right: 0;
  z-index: 600;
  height: auto;
  background: rgba(248, 242, 230, .95);
  backdrop-filter: blur(20px) saturate(1.4);
  /* border-bottom: 1px solid var(--gold-line); */
  transition: box-shadow .3s;
}
header .header-inner{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
}

main#MainContent {
  /* margin-top: 121px; */
  position: relative;
}

.logo img {
  width: 100px;
  margin: 10px 0;
}

header {
  transition: all 0.3s ease;
}

header.fixed {
  box-shadow: 0 2px 32px rgba(26, 18, 6, .07);
  position: fixed !important;
  top: 0 !important;
  animation: fadeInDown 0.35s ease-out;
}

@keyframes fadeInDown {
  from {
    transform: translateY(-20px);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

/* CENTER LOGO */
.logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  cursor: pointer;
  justify-self: center;
}

.logo-main {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 400;
  color: var(--ink);
  letter-spacing: .28em;
  text-transform: uppercase;
  line-height: 1;
}

.logo-sub {
  font-size: 9px;
  color: var(--gold);
  letter-spacing: .52em;
  margin-top: 4px;
  font-weight: 300;
  text-transform: uppercase;
}

/* LEFT NAV */
.nav-left {
  display: flex;
  align-items: center;
  justify-self: start;
}

nav ul {
  display: flex;
  list-style: none;
}

nav li {
  position: relative;
}
nav a {
    display: flex;
    padding: 0 22px;
    height: 68px;
    line-height: 68px;
    font-size: 14px;
    text-transform: uppercase;
    color: var(--ink3);
    font-weight: 300;
    transition: color .22s;
    white-space: nowrap;
    align-items: center;
}
.sub-menu a {
    font-size: 14px;
    height: auto;
    line-height: 36px;
    text-transform: capitalize;
    transition:ease-in-out 0.5s;
}
.sub-menu a:hover{
  color: var(--heading-color);
  text-decoration:underline;
}
nav a:hover {
  color: var(--heading-color);
  text-decoration:underline;
}
.right-submenu-caption{
  color:var(--gold);
}
.right-submenu-title {
    font-size: 22px;
    line-height: 27px;
    font-weight: 600;
    color:var(--heading-color);
}

.right-submenu-title{
 
}
.nav-right nav .right-submenu{
    font-size: 14px;
    height: auto;
    line-height: 36px;
    text-transform: capitalize;
    transition: ease-in-out 0.5s;
}

/* dropdown */
.drop{
    display: grid;
    position: fixed;
    top: 80px;
    left: 0;
    right: 0;
    background: var(--canvas);
    border-bottom: 1px solid var(--gold-line);
    box-shadow: 0 16px 56px rgba(26, 18, 6, .14);
    padding: 36px 80px;
    gap: 32px;
    grid-template-columns: 1.1fr 1fr 1fr;
    z-index: 700;

    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition:
        opacity .35s ease,
        transform .35s ease,
        visibility .35s ease;
    pointer-events: none;
}

.has-drop:hover .drop{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
}


.has-drop {
  position: static;
}


.drop-head {
    font-size: 16px;
    text-transform: uppercase;
    margin-bottom: 0;
    font-weight: 500;
    color: var(--heading-color);
}
#shop_all {
    display: flex;
    font-size: 13px;
    color: white;
    padding: 6px 10px;
    transition: color .2s;
    border-bottom: 1px solid transparent;
    background: var(--gold);
    width: fit-content;
    border-radius: 5px;
    height: auto;
    line-height: normal;
}
#shop_all:hover{
  background: var(--heading-color);
  text-decoration:none;
}

.drop-link {
  display: block;
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
  padding: 4px 0;
  transition: color .2s;
  border-bottom: 1px solid transparent;
}

.drop-link:hover {
  color: var(--ink);
}

.drop-feat {
  border-left: 1px solid var(--gold-line);
  padding-left: 24px;
}

.nav-right {
  display: flex;
  align-items: center;
  gap: 6px;
  justify-self: end;
}

.nav-scan {
  padding: 9px 18px !important;
  font-size: 11px !important;
}

.nav-cart {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
  transition: color .2s;
}

.nav-cart:hover {
  color: var(--ink);
  cursor: pointer;
}

.nav-icon:hover {
  color: var(--gold);
}

.nav-icon svg {
  stroke: currentColor;
  fill: none;
  stroke-width: 1.4;
  stroke-linecap: round;
  stroke-linejoin: round;
}



.nav-cart-icon {
  position: relative;
}

.cart-count {
  position: absolute;
  top: -2px;
  right: -2px;
  background: var(--gold);
  color: var(--canvas);
  font-size: 9px;
  font-family: var(--U);
  width: 14px;
  height: 14px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0;
}
.nav-scan-btn {
    font-family: var(--U);
    font-size: 13px;
    letter-spacing: .2em;
    text-transform: uppercase;
    background: var(--gold);
    color: var(--canvas);
    border: none;
    padding: 9px 18px;
    cursor: pointer;
    transition: all .25s;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 7px;
    border-radius: 5px;
    margin-right: 10px;
}

.nav-scan-btn::before {
  content: '';
  width: 5px;
  height: 5px;
  background: var(--canvas);
  border-radius: 50%;
  flex-shrink: 0;
}

.nav-scan-btn:hover {
  background:#461324;
}

/* ── MARQUEE ── */
.marquee {
  overflow: hidden;
  padding: 10px 0;
  background: var(--canvas2);
  border-top: 1px solid var(--gold-line);
  border-bottom: 1px solid var(--gold-line);
}

.mq-track {
  display: flex;
  white-space: nowrap;
  animation: mq 36s linear infinite;
}

.mq-item {
  padding: 0 28px;
  font-size: 13px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.mq-dot {
  font-size: 6px;
  opacity: .4;
}



/* notification */
.notif {
  position: fixed;
  bottom: 28px;
  right: 28px;
  background: var(--ink);
  border: 1px solid var(--gold-line);
  color: var(--canvas);
  padding: 11px 22px;
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  z-index: 9999;
  transform: translateY(72px);
  opacity: 0;
  transition: all .3s;
  font-family: var(--U);
}

.notif.show {
  transform: translateY(0);
  opacity: 1;
}

/* ════════════════════════════════════════
   PAGE 1 — HOMEPAGE
════════════════════════════════════════ */
/* hero */
.hero {
  min-height: 100vh;
  padding-top: 0px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: var(--canvas);
  position: relative;
  overflow: hidden;
}

.hero-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 1px solid var(--gold-line);
  position: relative;
  z-index: 2;
}
.hero-kicker {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 25px;
    opacity: 0;
    animation: fadeUp .8s ease .2s forwards;
}

.kicker-line {
  width: 24px;
  height: 1px;
  background: var(--gold);
}
.kicker-txt {
    font-size: 19px;
    text-transform: capitalize;
    color: var(--gold);
    font-weight: 300;
}
.hero-h1 {
    font-family: var(--D);
    font-size:60px;
    font-weight: 300;
    color: var(--ink);
    line-height: .92;
    margin-bottom: 13px;
    opacity: 0;
    animation: fadeUp 1s ease .4s forwards;
}
h2.hero-h1{
  color: var(--heading-color);
}
.hero-desc {
    font-family: var(--S);
    font-size: 18px;
    line-height: normal;
    color: var(--ink3);
    max-width: 480px;
    margin-bottom: 14px;
    opacity: 0;
    animation: fadeUp .8s ease .8s forwards;
}
.hero-mantra {
    font-size: 18px;
    letter-spacing: .04em;
    color: var(--gold);
    margin-bottom: 36px;
    font-weight: 300;
    opacity: 0;
    animation: fadeUp .7s ease .95s forwards;
    font-family: var(--S);
    font-style: italic;
    line-height: normal;
}
.hero-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp .8s ease 1.1s forwards;
}

.scan-icon {
  width: 16px;
  height: 16px;
  border: 1.5px solid currentColor;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.scan-icon::after {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  animation: pip 2s ease-in-out infinite;
}

.hero-right {
  background: var(--canvas2);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.hero-orn {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  border: 1px solid;
}

.pstack {
  position: relative;
  width: 340px;
  height: 420px;
  z-index: 2;
}

.ps {
  position: absolute;
  transition: transform .5s ease;
}

.ps img {
  box-shadow: 0 20px 56px rgba(26, 18, 6, .16), 0 6px 16px rgba(26, 18, 6, .1);
  border-radius: 2px;
}

.ps-main {
  width: 172px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.ps-left {
  width: 112px;
  bottom: 55px;
  left: 0;
  transform: rotate(-7deg);
}

.ps-right {
  width: 112px;
  bottom: 75px;
  right: 0;
  transform: rotate(7deg);
}

.ps-top {
  width: 96px;
  bottom: 220px;
  left: 50%;
  transform: translateX(-26%);
}

.pstack:hover .ps-left {
  transform: rotate(-11deg) translateX(-8px);
}

.pstack:hover .ps-right {
  transform: rotate(11deg) translateX(8px);
}

.pstack:hover .ps-top {
  transform: translateX(-26%) translateY(-8px);
}

.ps-shad {
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 172px;
  height: 36px;
  background: radial-gradient(ellipse, rgba(26, 18, 6, .14), transparent 70%);
  filter: blur(14px);
}

.leaf-lbl {
  position: absolute;
  font-family: var(--S);
  font-style: italic;
  color: var(--gold);
  opacity: .3;
  font-size: 11px;
  pointer-events: none;
}

.scroll-word {
  font-size: 12px;
  letter-spacing: .36em;
  text-transform: uppercase;
  color: var(--ink5);
  font-weight: 300;
}

.scroll-tick {
  width: 1px;
  height: 30px;
  background: linear-gradient(180deg, var(--gold-line), transparent);
}

/* hero SVG ornament */
.hero-branch {
  position: absolute;
  top: 110px;
  right: -1px;
  width: 76px;
  opacity: .11;
  pointer-events: none;
}

/* ── FEATURED TRIO ── */
.pfeat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin: 0 80px;
}

.pfeat {
  background: var(--canvas);
  cursor: pointer;
  transition: background .28s;
  position: relative;
}

.pfeat:hover {
  background: var(--canvas2);
}

.pfeat-accent {
  height: 2px;
  width: 100%;
}

.pfeat-img {
  height: 400px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  position: relative;
}

.pfeat-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 36px 28px;
  transition: transform .65s ease;
}

.pfeat:hover .pfeat-img img {
  transform: scale(1.05);
}

.pfeat-veil {
  position: absolute;
  inset: 0;
  background: rgba(26, 18, 6, 0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .3s;
}

.pfeat:hover .pfeat-veil {
  background: rgba(26, 18, 6, .07);
}

.pfeat-cta {
  opacity: 0;
  font-family: var(--S);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink);
  border: 1px solid var(--ink);
  padding: 10px 22px;
  background: var(--canvas);
  transition: opacity .25s, background .25s, color .25s;
  cursor: pointer;
}

.pfeat:hover .pfeat-cta {
  opacity: 1;
}

.pfeat-cta:hover {
  background: var(--ink);
  color: var(--canvas);
}

.pfeat-body {
  padding: 20px 24px 28px;
  border-top: 1px solid var(--canvas-dk);
}

.pfeat-line {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 5px;
}

.pfeat-name {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 5px;
  line-height: 1.2;
}

.pfeat-tag {
  font-family: var(--S);
  font-size: 12.5px;
  font-style: italic;
  color: var(--ink3);
  margin-bottom: 14px;
  line-height: 1.6;
}

.pfeat-foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-top: 12px;
  border-top: 1px solid var(--canvas-dk);
}

.pfeat-price {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 300;
  color: var(--ink);
}

.pfeat-sub {
  font-size: 12px;
  color: var(--ink4);
  margin-top: 2px;
}

.pfeat-atc {
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-family: var(--U);
  font-weight: 300;
  color: var(--ink4);
  padding: 8px 16px;
  border: 1px solid var(--canvas-dk);
  background: none;
  cursor: pointer;
  transition: all .22s;
}

.pfeat-atc:hover {
  background: var(--ink);
  color: var(--canvas);
  border-color: var(--ink);
}

/* secondary scroll row label */
.pmore-label {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 48px 80px 20px;
}

.pmore-label-text {
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--ink4);
  font-weight: 300;
}

.pmore-label-line {
  flex: 1;
  height: 1px;
  background: var(--gold-line);
}

/* tighten scroll cards slightly for the secondary row */
.psc-sm {
  flex: 0 0 calc(33.333% - 1px);
}

@media(max-width:900px) {
  .pfeat-grid {
    grid-template-columns: 1fr;
    margin: 0;
  }

  .pmore-label {
    padding: 40px 32px 16px;
  }
}

display:flex;
align-items:center;
justify-content:center;
gap:28px;
margin-top:36px;
padding:0 80px;
}

.pscroll-arr {
  width: 40px;
  height: 40px;
  border: 1px solid var(--gold-line);
  background: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  color: var(--gold);
  transition: all .22s;
  flex-shrink: 0;
}

.pscroll-arr:hover {
  border-color: var(--gold);
  background: var(--gold);
  color: var(--canvas);
}

.pscroll-bar-wrap {
  flex: 1;
  max-width: 320px;
  height: 1px;
  background: var(--gold-line);
  position: relative;
  overflow: hidden;
}

.pscroll-bar-fill {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  background: var(--gold);
  width: 33%;
  transition: width .3s ease;
}

.pscroll-count {
  font-family: var(--S);
  font-size: 10px;
  letter-spacing: .16em;
  color: var(--ink4);
  flex-shrink: 0;
}

.pgrid {
  display: none;
}

/* keep for backwards compat */
.pc {
  background: var(--canvas);
  overflow: hidden;
  transition: background .3s;
  position: relative;
}

.pc:hover {
  background: var(--canvas2);
}

.pc-rule {
  height: 2px;
  width: 100%;
}

.pc-img {
  height: 380px;
  position: relative;
  overflow: hidden;
}

.pc-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .65s ease;
}

.pc-img.contain img {
  object-fit: contain;
  padding: 32px;
}

.pc:hover .pc-img img {
  transform: scale(1.04);
}

.pc-veil {
  position: absolute;
  inset: 0;
  background: rgba(26, 18, 6, 0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .3s;
}

.pc:hover .pc-veil {
  background: rgba(26, 18, 6, .16);
}

.pc-cta {
  opacity: 0;
  transform: translateY(6px);
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--canvas);
  border: 1px solid rgba(248, 242, 230, .5);
  padding: 10px 22px;
  transition: all .28s;
  font-family: var(--U);
  font-weight: 300;
  background: rgba(26, 18, 6, .08);
  backdrop-filter: blur(4px);
}

.pc:hover .pc-cta {
  opacity: 1;
  transform: translateY(0);
}

.pc-body {
  padding: 22px 26px 30px;
}

.pc-line {
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink5);
  margin-bottom: 6px;
  font-weight: 300;
}

.pc-name {
  font-family: var(--D);
  font-size: 21px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.15;
}

.pc-tag {
  font-family: var(--S);
  font-size: 13px;
  font-style: italic;
  color: var(--ink3);
  line-height: 1.65;
  margin-bottom: 16px;
}

.pc-foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-top: 14px;
  border-top: 1px solid var(--canvas-dk);
}

.pc-price {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 300;
  color: var(--ink);
}

.pc-sub {
  font-size: 12px;
  color: var(--gold);
  margin-top: 2px;
  font-weight: 300;
}

.btn-add {
  background: none;
  border: 1px solid var(--canvas-dk);
  padding: 9px 16px;
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink2);
  font-family: var(--U);
  transition: all .22s;
}

.btn-add:hover {
  background: var(--ink);
  color: var(--canvas);
  border-color: var(--ink);
}

/* scan section */
.scan-sec {
  background: var(--canvas2);
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--gold-line);
  border-bottom: 1px solid var(--gold-line);
  min-height: 560px;
}

.scan-vis {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 70px 50px;
  position: relative;
  overflow: hidden;
  border-right: 1px solid var(--gold-line);
}

.scan-vis::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(168, 104, 26, .06), transparent 65%);
}

.sfc {
  position: relative;
  width: 270px;
  height: 270px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sr {
  position: absolute;
  border-radius: 50%;
  border: 1px solid;
  pointer-events: none;
}

.sr1 {
  width: 270px;
  height: 270px;
  border-color: rgba(168, 104, 26, .1);
  animation: rslow 24s linear infinite;
}

.sr2 {
  width: 210px;
  height: 210px;
  border-color: rgba(168, 104, 26, .18);
  animation: rslow 16s linear infinite reverse;
}

.sr3 {
  width: 152px;
  height: 152px;
  border-color: rgba(168, 104, 26, .28);
}

.sr4 {
  width: 270px;
  height: 270px;
  border: none;
  position: absolute;
  background: repeating-conic-gradient(from 0deg, rgba(168, 104, 26, .13) 0deg 2deg, transparent 2deg 10deg);
  border-radius: 50%;
  animation: rslow 10s linear infinite;
}

.scan-sweep {
  position: absolute;
  width: 152px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold2), transparent);
  animation: sweep 2.8s ease-in-out infinite;
  z-index: 3;
}

.ldot {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 8px 2px rgba(168, 104, 26, .3);
  animation: ldot 2.6s ease-in-out infinite;
  z-index: 4;
}

.dchips {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.dchips.l {
  left: -4px;
}

.dchips.r {
  right: -4px;
  align-items: flex-end;
}

.dc {
  background: var(--canvas);
  border: 1px solid var(--gold-line);
  padding: 5px 11px;
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--gold);
  font-family: var(--U);
  font-weight: 300;
  box-shadow: 0 2px 10px rgba(26, 18, 6, .06);
  animation: ldot 3.4s ease-in-out infinite;
}

.dc:nth-child(2) {
  animation-delay: .9s
}

.dc:nth-child(3) {
  animation-delay: 1.8s
}

.face-sil {
  position: relative;
  z-index: 2;
  width: 100px;
  height: 138px;
  border-radius: 50% 50% 46% 46%;
  background: var(--canvas);
  border: 1px solid rgba(168, 104, 26, .2);
  box-shadow: 0 4px 24px rgba(26, 18, 6, .06);
}

.scan-copy {
  padding: 64px 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.scan-live {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    padding-bottom: 15px;
}

.sl-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  animation: pip 2s ease-in-out infinite;
}
.sl-txt {
    font-size: 13px;
    letter-spacing: .24em;
    text-transform: uppercase;
    color: var(--gold);
    font-weight: 300;
}
.scan-h2 {
  font-family: var(--D);
  font-size: clamp(32px, 3.2vw, 52px);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.05;
  margin-bottom: 18px;
}

.scan-h2 em {
  font-style: italic;
  color: var(--gold2);
}

.scan-body {
  font-family: var(--S);
  font-size: 16px;
  line-height: 1.88;
  color: var(--ink3);
  max-width: 400px;
  margin-bottom: 32px;
}

.ssteps {
  display: flex;
  flex-direction: column;
  margin-bottom: 36px;
}

.sstep {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 12px;
  padding: 13px 0;
  border-bottom: 1px solid var(--canvas-dk);
}

.sstep:last-child {
  border: none;
}

.sn {
  font-family: var(--D);
  font-size: 30px;
  font-weight: 300;
  color: rgba(168, 104, 26, .2);
  line-height: 1.1;
}

.stitle {
  font-size: 13px;
  font-weight: 400;
  color: var(--ink);
  letter-spacing: .06em;
  margin-bottom: 2px;
}

.sdesc {
  font-size: 13px;
  color: var(--ink4);
  font-weight: 300;
  line-height: 1.65;
}

.scan-note {
  font-size: 12px;
  color: var(--ink5);
  margin-top: 9px;
  font-weight: 300;
}

/* ritual tabs */
.ritual {
  background: var(--canvas2);
  padding: 100px 80px;
}

.rtabs {
  display: flex;
  justify-content: center;
  border-bottom: 2px solid var(--canvas-dk);
  margin-bottom: 72px;
  gap: 0;
}

.rtab {
  padding: 16px 40px;
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink4);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all .28s;
  font-weight: 300;
  white-space: nowrap;
}

.rtab.on {
  color: var(--ink);
  border-bottom-color: var(--gold);
}

.rtab:hover:not(.on) {
  color: var(--ink2);
}

.rc {
  display: none;
}

.rc.on {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}

/* Step list */
.rstep {
  /*display:grid; grid-template-columns:56px 1fr;*/
  gap: 20px;
  padding: 28px 0;
  border-bottom: 1px solid var(--canvas-dk);
  align-items: start;
  transition: background .2s;
}

.rstep:last-child {
  border: none;
  padding-bottom: 0;
}

.rn {
  font-family: var(--D);
  font-size: 48px;
  font-weight: 300;
  color: rgba(168, 104, 26, .12);
  line-height: 1;
  padding-top: 4px;
}

.rname {
  font-family: var(--D);
  font-size: 24px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.15;
}

.rdesc {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.82;
  margin-bottom: 12px;
}

.rprice-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 4px;
  flex-wrap: wrap;
}

.rprice {
  font-size: 18px;
  color: var(--ink);
  font-family: var(--D);
  font-weight: 300;
}

.r-view {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .16em;
  color: var(--gold);
  text-transform: uppercase;
  cursor: pointer;
  border-bottom: 1px solid rgba(168, 104, 26, .3);
  padding-bottom: 1px;
  transition: border-color .2s;
}

.r-view:hover {
  border-color: var(--gold);
}

.r-atc {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 9px 18px;
  cursor: pointer;
  transition: background .22s;
}

.r-atc:hover {
  background: var(--gold);
}

/* Right visual panel */
.rvis {
  position: relative;
  background: var(--canvas);
  border: 1px solid var(--gold-line);
  padding: 48px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 520px;
}

.rvis-badge {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.rvis-title {
  font-family: var(--D);
  font-size: 36px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.15;
  text-align: center;
  margin-bottom: 6px;
}

.rvis-meaning {
  font-family: var(--D);
  font-size: 16px;
  font-weight: 300;
  font-style: italic;
  color: var(--gold2);
  text-align: center;
  margin-bottom: 24px;
}

.rvis-divider {
  width: 48px;
  height: 1px;
  background: var(--gold-line);
  margin: 0 auto 24px;
}

.rvis-products {
  display: flex;
  gap: 12px;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 28px;
}

.rvis-img {
  width: 88px;
  height: 110px;
  overflow: hidden;
  border: 1px solid var(--canvas-dk);
}

.rvis-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.rvis-total-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 8px;
  justify-content: center;
}

.rvis-total-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .2em;
  color: var(--ink4);
  text-transform: uppercase;
}

.rvis-total {
  font-family: var(--D);
  font-size: 42px;
  font-weight: 300;
  color: var(--ink);
}

.rvis-save {
  font-family: var(--S);
  font-size: 14px;
  color: var(--gold);
  text-align: center;
  margin-bottom: 28px;
}

.rvis-cta-stack {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  max-width: 260px;
}

.rvis-btn-primary {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 16px 24px;
  cursor: pointer;
  transition: background .22s;
  width: 100%;
}

.rvis-btn-primary:hover {
  background: var(--gold);
}

.rvis-btn-secondary {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink3);
  border: 1px solid var(--canvas-dk);
  padding: 13px 24px;
  cursor: pointer;
  transition: all .22s;
  width: 100%;
}

.rvis-btn-secondary:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.rvis-proof {
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink4);
  text-align: center;
  margin-top: 14px;
  font-style: italic;
}

.rc1,
.rc2,
.rc3 {
  display: none;
}

.rc3 {
  width: 172px;
  height: 172px;
  border-color: rgba(168, 104, 26, .2);
}

.rglow {
  position: absolute;
  width: 190px;
  height: 190px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(168, 104, 26, .09), transparent 70%);
  animation: rg 3.5s ease-in-out infinite;
}

.rb {
  border-radius: 3px;
  box-shadow: 0 14px 44px rgba(26, 18, 6, .14);
  position: relative;
  z-index: 2;
}

/* testimonials */
.testi {
  background: var(--canvas2);
  padding: 80px 80px;
}

.tgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: 52px;
  background: var(--canvas-dk);
}

.tc {
  background: var(--canvas2);
  padding: 38px 34px;
  position: relative;
  overflow: hidden;
  transition: background .3s;
}

.tc:hover {
  background: var(--canvas);
}

.tc::before {
  content: '\201C';
  font-family: var(--D);
  font-size: 110px;
  color: rgba(168, 104, 26, .06);
  position: absolute;
  top: -18px;
  left: 12px;
  line-height: 1;
}

.tc-stars {
  color: var(--gold);
  font-size: 12px;
  letter-spacing: 2.5px;
  margin-bottom: 12px;
}

.tc-text {
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink);
  line-height: 1.82;
  position: relative;
  z-index: 1;
  margin-bottom: 18px;
}

.tc-author {
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink4);
  font-weight: 400;
}

.tc-prod {
  font-size: 11px;
  color: var(--gold);
  letter-spacing: .1em;
  margin-top: 3px;
}

/* benefits */
.benefits {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--ink);
}

.bene {
  padding: 26px 30px;
  border-right: 1px solid rgba(248, 242, 230, .04);
}

.bene:last-child {
  border: none;
}

.bene-ico {
  font-size: 13px;
  color: var(--gold3);
  opacity: .55;
  margin-bottom: 6px;
}

.bene-title {
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--canvas);
  font-weight: 400;
  margin-bottom: 3px;
}

.bene-desc {
  font-size: 13px;
  color: rgba(248, 242, 230, .3);
  font-weight: 300;
  line-height: 1.65;
}

/* sets */
.sets {
  background: var(--canvas);
  padding: 80px 80px;
  border-top: 1px solid var(--gold-line);
}

.sets-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.sc {
  background: var(--canvas);
  padding: 32px 24px;
  text-align: center;
  cursor: pointer;
  transition: background .28s;
  position: relative;
}

.sc::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gold-line);
  transition: background .28s;
}

.sc:hover::before {
  background: var(--gold);
}

.sc:hover {
  background: var(--canvas2);
}

.sc-name {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 11px;
  line-height: 1.2;
}

.sc-items {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.8;
  margin-bottom: 18px;
  font-style: italic;
}

.sc-price {
  font-family: var(--D);
  font-size: 38px;
  font-weight: 300;
  color: var(--ink);
}

.sc-save {
  font-size: 14px;
  color: var(--gold);
  margin-top: 4px;
  letter-spacing: .08em;
}

.sc-btn {
  margin-top: 24px;
  padding: 14px 18px;
  background: transparent;
  border: 1px solid var(--canvas-dk);
  color: var(--ink3);
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  width: 100%;
  font-family: var(--U);
  font-weight: 300;
  transition: all .22s;
}

.sc-btn:hover {
  background: var(--ink);
  color: var(--canvas);
  border-color: var(--ink);
}

.sc.sig {
  background: var(--gold-pale);
}

.sc.sig::before {
  background: var(--gold);
}

.sc.sig .sc-name,
.sc.sig .sc-price {
  color: var(--gold);
}

/* founder strip */
.founder {
  display: grid;
  grid-template-columns: 5fr 7fr;
  min-height: 500px;
  background: var(--jungle);
}

.f-img-col {
  position: relative;
  overflow: hidden;
}

.f-img-col img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  filter: brightness(.8) saturate(1.05);
}

.f-img-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 55%, rgba(26, 43, 26, .4) 100%);
}

.f-plate {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 26px 34px;
  background: linear-gradient(0deg, rgba(13, 22, 12, .9), transparent);
}

.fn-name {
  font-family: var(--D);
  font-size: 25px;
  font-weight: 400;
  color: var(--canvas);
  letter-spacing: .04em;
}

.fn-role {
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .7);
  font-weight: 300;
  margin-top: 3px;
}

.f-copy {
  padding: 60px 76px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-left: 1px solid rgba(200, 146, 26, .08);
}


.f-quote {
  font-family: var(--D);
  font-size: clamp(18px, 1.9vw, 27px);
  font-style: italic;
  font-weight: 300;
  color: var(--canvas);
  line-height: 1.5;
  margin-bottom: 16px;
  padding-left: 16px;
  border-left: 2px solid rgba(200, 146, 26, .45);
}

.f-p {
  font-family: var(--S);
  font-size: 15px;
  line-height: 1.9;
  color: rgba(248, 242, 230, .38);
  max-width: 460px;
  margin-bottom: 26px;
}

.f-bottom {
  display: flex;
  align-items: center;
  gap: 0;
  padding-top: 22px;
  border-top: 1px solid rgba(200, 146, 26, .1);
}

.fcred {
  text-align: center;
  padding: 0 22px;
}

.fcred:first-child {
  padding-left: 0;
}

.fc-n {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 300;
  color: rgba(200, 146, 26, .8);
  line-height: 1;
}

.fc-l {
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(248, 242, 230, .25);
  margin-top: 2px;
  font-weight: 300;
}

.fcred-sep {
  width: 1px;
  height: 34px;
  background: rgba(200, 146, 26, .1);
}

.fig-link {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(200, 146, 26, .2);
  padding: 9px 15px;
  margin-left: auto;
  transition: all .22s;
}

.fig-link:hover {
  border-color: rgba(200, 146, 26, .5);
  background: rgba(200, 146, 26, .06);
}

.fig-ic {
  width: 16px;
  height: 16px;
  border: 1.5px solid rgba(200, 146, 26, .65);
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fig-ic::after {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(200, 146, 26, .75);
}

.fig-t {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .7);
  font-weight: 300;
}

/* prana book */
.book {
  background: var(--jungle2);
  padding: 100px 80px;
}

.book-intro {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}

.book-kicker {
  font-size: 10px;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .75);
  font-weight: 300;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.book-kicker::before,
.book-kicker::after {
  content: '';
  width: 32px;
  height: 1px;
  background: rgba(200, 146, 26, .35);
  display: block;
}

.book-h2 {
  font-family: var(--D);
  font-size: clamp(42px, 5.5vw, 80px);
  font-weight: 300;
  color: var(--canvas);
  line-height: .95;
  margin-bottom: 22px;
}

.book-h2 em {
  font-style: italic;
  color: rgba(200, 146, 26, .9);
}

.book-sub {
  font-family: var(--S);
  font-size: 16px;
  color: rgba(248, 242, 230, .45);
  line-height: 1.9;
  max-width: 480px;
  margin: 0 auto 52px;
}

.book-hero {
  position: relative;
  width: 100%;
  height: 600px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid rgba(200, 146, 26, .12);
}

.book-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 45%;
  filter: brightness(.82) saturate(1.2);
  transition: transform 5.5s ease;
}

.book-hero:hover img {
  transform: scale(1.04);
}

.bh-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(13, 20, 12, .15) 0%, transparent 35%, rgba(13, 20, 12, .98) 100%);
}

.bh-frame {
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(200, 146, 26, .18);
  pointer-events: none;
}

.bh-frame::before,
.bh-frame::after {
  content: '';
  position: absolute;
  width: 28px;
  height: 28px;
  border-color: rgba(200, 146, 26, .5);
  border-style: solid;
}

.bh-frame::before {
  top: -1px;
  left: -1px;
  border-width: 2px 0 0 2px;
}

.bh-frame::after {
  bottom: -1px;
  right: -1px;
  border-width: 0 2px 2px 0;
}

.bh-badge {
  position: absolute;
  top: 40px;
  right: 40px;
  width: 96px;
  height: 96px;
  border-radius: 50%;
  border: 1px solid rgba(200, 146, 26, .4);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  z-index: 3;
}

.bh-badge-t {
  font-size: 7px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .75);
  font-weight: 300;
}

.bh-badge-n {
  font-family: var(--D);
  font-size: 22px;
  color: var(--canvas);
  font-weight: 300;
  line-height: 1;
}

.bh-badge-b {
  font-size: 6.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(248, 242, 230, .35);
}

.bh-txt {
  position: absolute;
  bottom: 52px;
  left: 60px;
  right: 60px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  z-index: 2;
}

.bh-q {
  font-family: var(--D);
  font-size: clamp(20px, 2.4vw, 34px);
  font-style: italic;
  font-weight: 300;
  color: white;
  max-width: 600px;
  line-height: 1.4;
}

.bh-q span {
  display: block;
  font-family: var(--S);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .6);
  font-style: normal;
  margin-top: 14px;
  font-weight: 300;
}

.ba-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(200, 146, 26, .07);
  margin-top: 1px;
}

.ba {
  background: rgba(13, 22, 12, .88);
  padding: 36px 32px;
  cursor: pointer;
  transition: background .3s;
  position: relative;
  overflow: hidden;
}

.ba::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, rgba(200, 146, 26, .7), transparent);
  transform: scaleX(0);
  transform-origin: left;
  transition: .38s;
}

.ba:hover::after {
  transform: scaleX(1);
}

.ba:hover {
  background: rgba(20, 32, 18, .96);
}

.ba-cat {
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .7);
  margin-bottom: 11px;
  font-weight: 300;
}

.ba-title {
  font-family: var(--D);
  font-size: 19px;
  font-weight: 400;
  color: var(--canvas);
  line-height: 1.3;
  margin-bottom: 13px;
  transition: color .2s;
}

.ba:hover .ba-title {
  color: rgba(200, 146, 26, .85);
}

.ba-meta {
  display: flex;
  justify-content: space-between;
  padding-top: 11px;
  border-top: 1px solid rgba(248, 242, 230, .05);
}

.ba-time {
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(248, 242, 230, .2);
  font-weight: 300;
}

.ba-arr {
  font-size: 14px;
  color: rgba(200, 146, 26, .35);
  transition: all .2s;
}

.ba:hover .ba-arr {
  transform: translateX(4px);
  color: rgba(200, 146, 26, .7);
}

/* ── BLOG ── */
.blog-wrap {
  background: var(--canvas);
  max-width: 820px;
  margin: 0 auto;
  padding: 80px 40px 120px;
}

.blog-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--S);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold);
  cursor: pointer;
  margin-bottom: 48px;
  transition: gap .2s;
}

.blog-back:hover {
  gap: 12px;
}

.blog-cat-tag {
  font-size: 11px;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.blog-cat-tag::before {
  content: '';
  width: 20px;
  height: 1px;
  background: var(--gold);
  display: block;
}

.blog-h1 {
  font-family: var(--D);
  font-size: clamp(38px, 5.5vw, 68px);
  font-weight: 300;
  color: var(--ink);
  line-height: .96;
  margin-bottom: 24px;
}

.blog-h1 em {
  font-style: italic;
  color: var(--gold2);
}

.blog-deck {
  font-family: var(--S);
  font-size: 19px;
  color: var(--ink3);
  line-height: 1.8;
  margin-bottom: 32px;
  max-width: 680px;
  border-left: 2px solid var(--gold);
  padding-left: 20px;
}

.blog-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 20px 0;
  border-top: 1px solid var(--gold-line);
  border-bottom: 1px solid var(--gold-line);
  margin-bottom: 52px;
}

.blog-author-img {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--gold-pale);
  border: 1.5px solid var(--gold-line);
  overflow: hidden;
}

.blog-author-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.blog-author-name {
  font-family: var(--S);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
}

.blog-author-role {
  font-size: 12px;
  color: var(--ink3);
  letter-spacing: .06em;
}

.blog-meta-right {
  margin-left: auto;
  display: flex;
  gap: 20px;
}

.blog-meta-item {
  font-size: 12px;
  color: var(--ink3);
  letter-spacing: .08em;
  display: flex;
  align-items: center;
  gap: 5px;
}

.blog-hero-img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  margin-bottom: 16px;
  border-radius: 2px;
}

.blog-img-cap {
  font-size: 12px;
  color: var(--ink3);
  letter-spacing: .08em;
  text-align: center;
  margin-bottom: 52px;
  font-style: italic;
}

.blog-body h2 {
  font-family: var(--D);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 300;
  color: var(--ink);
  margin: 56px 0 20px;
  line-height: 1.1;
}

.blog-body h2 em {
  font-style: italic;
  color: var(--gold2);
}

.blog-body h3 {
  font-family: var(--D);
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 400;
  color: var(--ink);
  margin: 40px 0 14px;
}

.blog-body p {
  font-family: var(--S);
  font-size: 17px;
  color: var(--ink3);
  line-height: 1.95;
  margin-bottom: 24px;
}

.blog-body strong {
  color: var(--ink);
  font-weight: 500;
}

.blog-body em {
  color: var(--gold2);
  font-style: italic;
}

.blog-pullquote {
  background: var(--canvas2);
  border-left: 3px solid var(--gold);
  padding: 32px 36px;
  margin: 48px 0;
}

.blog-pullquote p {
  font-family: var(--D);
  font-size: clamp(20px, 2.4vw, 28px);
  font-style: italic;
  color: var(--ink);
  line-height: 1.4;
  margin: 0 0 10px;
}

.blog-pullquote cite {
  font-family: var(--S);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  font-style: normal;
}

.blog-callout {
  background: var(--jungle2);
  padding: 36px 40px;
  margin: 48px 0;
  border-radius: 2px;
}

.blog-callout-title {
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .7);
  margin-bottom: 16px;
  font-weight: 300;
}

.blog-callout ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.blog-callout ul li {
  font-family: var(--S);
  font-size: 15px;
  color: var(--canvas);
  line-height: 1.7;
  padding: 7px 0;
  border-bottom: 1px solid rgba(200, 146, 26, .08);
  display: flex;
  gap: 10px;
}

.blog-callout ul li::before {
  content: '◆';
  color: rgba(200, 146, 26, .5);
  font-size: 8px;
  margin-top: 5px;
  flex-shrink: 0;
}

.blog-ingredient-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--gold-line);
  margin: 48px 0;
}

.blog-ing {
  background: var(--canvas);
  padding: 28px 24px;
}

.blog-ing-name {
  font-family: var(--D);
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 6px;
}

.blog-ing-sanskriт {
  font-family: var(--D);
  font-size: 13px;
  color: var(--gold);
  font-style: italic;
  margin-bottom: 10px;
}

.blog-ing p {
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.7;
  margin: 0;
}

.blog-ritual-steps {
  counter-reset: steps;
  margin: 48px 0;
}

.blog-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 20px;
  margin-bottom: 32px;
  align-items: start;
}

.blog-step-n {
  font-family: var(--D);
  font-size: 42px;
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
  opacity: .4;
}

.blog-step-body h4 {
  font-family: var(--D);
  font-size: 20px;
  color: var(--ink);
  margin: 0 0 8px;
  font-weight: 400;
}

.blog-step-body p {
  font-size: 15px;
  color: var(--ink3);
  line-height: 1.8;
  margin: 0;
}

.blog-science-table {
  width: 100%;
  border-collapse: collapse;
  margin: 40px 0;
  font-family: var(--S);
  font-size: 14px;
}

.blog-science-table th {
  background: var(--jungle2);
  color: var(--canvas);
  padding: 12px 16px;
  text-align: left;
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 300;
}

.blog-science-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--gold-line);
  color: var(--ink3);
  line-height: 1.6;
}

.blog-science-table tr:nth-child(even) td {
  background: var(--canvas2);
}

.blog-science-table td:first-child {
  color: var(--ink);
  font-weight: 500;
}

.blog-cta-box {
  background: linear-gradient(135deg, var(--jungle2), rgba(26, 18, 6, .95));
  padding: 52px 48px;
  margin: 64px 0 0;
  text-align: center;
  border: 1px solid rgba(200, 146, 26, .15);
}

.blog-cta-box h3 {
  font-family: var(--D);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 300;
  color: var(--canvas);
  margin-bottom: 12px;
}

.blog-cta-box h3 em {
  color: rgba(200, 146, 26, .9);
  font-style: italic;
}

.blog-cta-box p {
  font-family: var(--S);
  font-size: 15px;
  color: rgba(248, 242, 230, .5);
  margin-bottom: 28px;
  line-height: 1.8;
}

.blog-ref {
  margin-top: 64px;
  padding-top: 32px;
  border-top: 1px solid var(--gold-line);
}

.blog-ref h4 {
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 16px;
}

.blog-ref ol {
  padding-left: 18px;
}

.blog-ref li {
  font-size: 12px;
  color: var(--ink3);
  line-height: 1.9;
  font-family: var(--S);
}

/* email strip */
.email-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.email-dk {
  background: var(--jungle);
  padding: 64px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 1px solid rgba(200, 146, 26, .06);
}

.email-lt {
  background: var(--canvas2);
  padding: 64px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.e-h3 {
  font-family: var(--D);
  font-size: clamp(24px, 2.5vw, 38px);
  font-weight: 300;
  color: var(--canvas);
  line-height: 1.2;
  margin-bottom: 12px;
}

.e-h3 em {
  font-style: italic;
  color: rgba(200, 146, 26, .8);
}

.e-p {
  font-family: var(--S);
  font-size: 15px;
  color: rgba(248, 242, 230, .36);
  max-width: 340px;
  line-height: 1.9;
  margin-bottom: 24px;
}

.sub-h {
  font-family: var(--D);
  font-size: clamp(22px, 2.3vw, 34px);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 11px;
}

.sub-p {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.85;
  margin-bottom: 20px;
}

/* ════════════════════════════════════════
   PAGE 2 — ABOUT US
════════════════════════════════════════ */
.about-hero {
  min-height: 88vh;
  padding-top: 68px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  background: var(--jungle);
}

.about-hero-bg {
  position: absolute;
  inset: 0;
}

.about-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 25%;
  filter: brightness(.62) saturate(1.1);
}

.about-hero-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(13, 20, 12, .25) 0%, rgba(13, 20, 12, .88) 100%);
}

.about-hero-txt {
  position: relative;
  z-index: 2;
  padding: 0 80px 88px;
  max-width: 860px;
}

.about-hero-kicker {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}

.about-hero-h1 {
  font-family: var(--D);
  font-size: clamp(52px, 7vw, 100px);
  font-weight: 300;
  color: white;
  line-height: .92;
  margin-bottom: 26px;
}

.about-hero-h1 em {
  font-style: italic;
  color: rgba(200, 146, 26, .85);
}

.about-hero-p {
  font-family: var(--S);
  font-size: 19px;
  line-height: 1.82;
  color: rgba(248, 242, 230, .7);
  max-width: 560px;
}

/* origin story */
.origin {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 560px;
}

.origin-img {
  position: relative;
  overflow: hidden;
}

.origin-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 5s ease;
}

.origin-img:hover img {
  transform: scale(1.04);
}

.origin-img-ov {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(248, 242, 230, .06));
}

.origin-copy {
  padding: 80px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--canvas2);
  border-left: 1px solid var(--gold-line);
}

.o-pull {
  font-family: var(--D);
  font-size: clamp(26px, 2.8vw, 42px);
  font-style: italic;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.35;
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--gold-line);
}

.o-pull em {
  color: var(--gold2);
  font-style: normal;
}

.o-p {
  font-family: var(--S);
  font-size: 16px;
  line-height: 1.95;
  color: var(--ink3);
  margin-bottom: 16px;
}

/* values */
.values {
  background: var(--canvas);
  padding: 88px 80px;
}

.val-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.val {
  background: var(--canvas);
  padding: 44px 36px;
}

.val:hover {
  background: var(--canvas2);
}

.val-num {
  font-family: var(--D);
  font-size: 52px;
  font-weight: 300;
  color: rgba(168, 104, 26, .12);
  line-height: 1;
  margin-bottom: 12px;
}

.val-title {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 10px;
  line-height: 1.2;
}

.val-p {
  font-family: var(--S);
  font-size: 15px;
  line-height: 1.85;
  color: var(--ink3);
}

/* ingredients */
.ingredients {
  background: var(--canvas2);
  padding: 88px 80px;
}

.ing-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.ing {
  background: var(--canvas2);
  padding: 36px 28px;
  text-align: center;
  transition: background .3s;
}

.ing:hover {
  background: var(--canvas);
}

.ing-glyph {
  font-size: 28px;
  margin-bottom: 12px;
  opacity: .6;
}

.ing-name {
  font-family: var(--D);
  font-size: 24px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
}

.ing-origin {
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
  font-weight: 300;
}

.ing-p {
  font-family: var(--S);
  font-size: 14px;
  line-height: 1.8;
  color: var(--ink3);
}

/* prabha timeline */
.timeline {
  background: var(--jungle);
  padding: 88px 80px;
}

.tl-grid {
  display: grid;
  grid-template-columns: 1fr 2px 1fr;
  gap: 0;
  margin-top: 52px;
}

.tl-line {
  background: rgba(200, 146, 26, .2);
  position: relative;
}

.tl-line::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--h, 0%);
  background: var(--gold);
  transition: height 1s ease;
}

.tl-item {
  padding: 28px 40px 28px 0;
  border-bottom: 1px solid rgba(200, 146, 26, .1);
}

.tl-item.r {
  padding: 28px 0 28px 40px;
  text-align: right;
}

.tl-item:last-child,
.tl-item.r:last-child {
  border: none;
}

.tl-year {
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .6);
  margin-bottom: 8px;
  font-weight: 300;
}

.tl-event {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 400;
  color: var(--canvas);
  margin-bottom: 6px;
  line-height: 1.25;
}

.tl-desc {
  font-family: var(--S);
  font-size: 14px;
  color: rgba(248, 242, 230, .38);
  line-height: 1.82;
}

.tl-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--gold);
  margin: 28px auto;
  border: 2px solid rgba(200, 146, 26, .3);
  box-shadow: 0 0 12px rgba(200, 146, 26, .35);
}

/* press */
.press {
  background: var(--canvas2);
  padding: 64px 80px;
}

.press-grid {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 28px;
  margin-top: 36px;
  padding-top: 36px;
  border-top: 1px solid var(--gold-line);
}

.press-item {
  font-family: var(--D);
  font-size: clamp(18px, 2vw, 26px);
  font-weight: 300;
  color: var(--ink4);
  letter-spacing: .08em;
  transition: color .2s;
}

.press-item:hover {
  color: var(--ink);
}

/* ════════════════════════════════════════
   PAGE 3 — SPA PARTNERSHIP
════════════════════════════════════════ */
.spa-hero {
  min-height: 72vh;
  padding-top: 68px;
  background: var(--jungle);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  text-align: center;
}

.spa-hero-bg {
  position: absolute;
  inset: 0;
}

.spa-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(.5) saturate(1.1);
}

.spa-hero-ov {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 80% at 50% 50%, rgba(13, 20, 12, .5), rgba(13, 20, 12, .85));
}

.spa-hero-txt {
  position: relative;
  z-index: 2;
  padding: 0 40px;
  max-width: 760px;
}

.spa-hero-h1 {
  font-family: var(--D);
  font-size: clamp(48px, 6.5vw, 88px);
  font-weight: 300;
  color: white;
  line-height: .93;
  margin-bottom: 22px;
}

.spa-hero-h1 em {
  font-style: italic;
  color: rgba(200, 146, 26, .85);
}

.spa-hero-p {
  font-family: var(--S);
  font-size: 18px;
  line-height: 1.82;
  color: rgba(248, 242, 230, .62);
  max-width: 520px;
  margin: 0 auto 32px;
}

/* spa pillars */
.spa-pillars {
  background: var(--canvas2);
  padding: 88px 80px;
}

.sp-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.sp {
  background: var(--canvas2);
  padding: 44px 36px;
  position: relative;
  overflow: hidden;
  transition: background .3s;
}

.sp:hover {
  background: var(--canvas);
}

.sp-ico {
  font-size: 24px;
  margin-bottom: 18px;
  opacity: .5;
}

.sp-title {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 10px;
  line-height: 1.2;
}

.sp-p {
  font-family: var(--S);
  font-size: 15px;
  line-height: 1.85;
  color: var(--ink3);
}

.sp-tag {
  display: inline-block;
  margin-top: 14px;
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  border: 1px solid var(--gold-line);
  padding: 4px 11px;
  font-weight: 300;
}

/* how it works */
.spa-how {
  background: var(--canvas);
  padding: 88px 80px;
}

.how-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.hw {
  background: var(--canvas);
  padding: 36px 28px;
  position: relative;
}

.hw::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gold-line);
}

.hw-n {
  font-family: var(--D);
  font-size: 48px;
  font-weight: 300;
  color: rgba(168, 104, 26, .14);
  line-height: 1;
  margin-bottom: 10px;
}

.hw-title {
  font-family: var(--D);
  font-size: 21px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
}

.hw-p {
  font-family: var(--S);
  font-size: 14px;
  line-height: 1.8;
  color: var(--ink3);
}

/* partner tiers */
.spa-tiers {
  background: var(--canvas2);
  padding: 88px 80px;
  border-top: 1px solid var(--gold-line);
}

.tier-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.tier {
  background: var(--canvas2);
  padding: 44px 36px;
  text-align: center;
  transition: background .28s;
  position: relative;
}

.tier::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--gold-line);
  transition: background .28s;
}

.tier:hover::before {
  background: var(--gold);
}

.tier.featured {
  background: var(--ink);
}

.tier.featured::before {
  background: var(--gold);
}

.tier-badge {
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
  font-weight: 300;
}

.tier-name {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 10px;
}

.tier.featured .tier-name {
  color: var(--canvas);
}

.tier-price {
  font-family: var(--D);
  font-size: 42px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 4px;
}

.tier.featured .tier-price {
  color: var(--gold2);
}

.tier-period {
  font-size: 12px;
  color: var(--ink4);
  letter-spacing: .08em;
  margin-bottom: 22px;
}

.tier.featured .tier-period {
  color: rgba(248, 242, 230, .3);
}

.tier-features {
  list-style: none;
  text-align: left;
  margin-bottom: 28px;
}

.tier-features li {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  padding: 8px 0;
  border-bottom: 1px solid var(--canvas-dk);
  display: flex;
  align-items: center;
  gap: 10px;
}

.tier.featured .tier-features li {
  color: rgba(248, 242, 230, .55);
  border-bottom-color: rgba(248, 242, 230, .05);
}

.tier-features li::before {
  content: '✦';
  color: var(--gold);
  font-size: 8px;
  flex-shrink: 0;
}

/* spa form */
.spa-form {
  background: var(--canvas);
  padding: 88px 80px;
}

.sf-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}

.sf-left {}

.sf-right {
  background: var(--canvas2);
  padding: 48px 44px;
  border: 1px solid var(--gold-line);
}

.sf-title {
  font-family: var(--D);
  font-size: clamp(30px, 3vw, 46px);
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 16px;
  line-height: 1.08;
}

.sf-p {
  font-family: var(--S);
  font-size: 16px;
  line-height: 1.88;
  color: var(--ink3);
  margin-bottom: 28px;
  max-width: 420px;
}

.sf-contacts {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 28px;
}

.sf-contact {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sf-c-ico {
  width: 32px;
  height: 32px;
  border: 1px solid var(--gold-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--gold);
  flex-shrink: 0;
}

.sf-c-lbl {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink4);
  margin-bottom: 2px;
  font-weight: 300;
}

.sf-c-val {
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink);
}

.form-field {
  margin-bottom: 18px;
}

.form-label {
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink4);
  display: block;
  margin-bottom: 7px;
  font-weight: 300;
}

.form-input {
  width: 100%;
  border: 1px solid var(--canvas-dk);
  padding: 11px 14px;
  font-size: 14px;
  font-family: var(--U);
  color: var(--ink);
  background: var(--canvas);
  outline: none;
  transition: border-color .2s;
}

.form-input:focus {
  border-color: var(--gold);
  background: white;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

select.form-input {
  appearance: none;
  cursor: pointer;
}

textarea.form-input {
  resize: vertical;
  min-height: 96px;
}

.form-submit {
  width: 100%;
}

/* current partners */
.spa-partners {
  background: var(--canvas2);
  padding: 64px 80px;
  border-top: 1px solid var(--gold-line);
}

.partner-logos {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 40px;
}

.partner-logo {
  background: var(--canvas2);
  padding: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .25s;
}

.partner-logo:hover {
  background: var(--canvas);
}

.partner-name {
  font-family: var(--D);
  font-size: 15px;
  font-weight: 300;
  color: var(--ink4);
  letter-spacing: .12em;
  text-transform: uppercase;
  text-align: center;
}

/* ════════════════════════════════════════
   PAGE 4 — PDP (PRODUCT DETAIL PAGE)
════════════════════════════════════════ */


/* PDP hero */
.pdp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - 68px);
}

/* gallery */
.pdp-gallery {
  background: var(--canvas2);
  position: relative;
  overflow: hidden;
}

.pdp-main-img {
  width: 100%;
  height: 100%;
  position: relative;
  display: flex;
}

/* .pdp-main-img img { width:598px; height:100%; object-fit:contain; padding: 40px; transition:transform .6s ease; } */
.pdp-main-img.contain img {
  object-fit: contain;
  padding: 60px;
}

.pdp-main-img:hover img {
  transform: scale(1);
}

.pdp-thumbs {
  position: absolute;
  bottom: 24px;
  left: 24px;
  display: flex;
  gap: 8px;
}

.pdp-thumb {
  width: 52px;
  height: 52px;
  border: 2px solid transparent;
  overflow: hidden;
  cursor: pointer;
  transition: border-color .2s;
  opacity: .6;
}

.pdp-thumb.on,
.pdp-thumb:hover {
  border-color: var(--gold);
  opacity: 1;
}

.pdp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* gallery image indicator */
.pdp-img-label {
  display: none;
  position: absolute;
  top: 24px;
  right: 24px;
  background: rgba(248, 242, 230, .9);
  border: 1px solid var(--gold-line);
  padding: 6px 14px;
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  backdrop-filter: blur(8px);
}

/* image placeholders for demo */
.img-ph {
  width: 100%;
  height: 100%;
  min-height: 460px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* PDP info panel */
.pdp-info {
  padding: 64px 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--canvas);
  overflow-y: auto;
}

.pdp-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 24px;
  font-size: 14px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink5);
  font-weight: 300;
}

.pdp-breadcrumb a {
  color: var(--gold);
}

.pdp-breadcrumb span {
  opacity: .4;
}

.pdp-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--gold-pale);
  border: 1px solid var(--gold-line);
  padding: 5px 13px;
  margin-bottom: 18px;
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
}

.pdp-name {
  font-family: var(--D);
  font-size: clamp(34px, 4vw, 56px);
  font-weight: 300;
  color: var(--ink);
  line-height: .96;
  margin-bottom: 10px;
}

.pdp-name em {
  font-style: italic;
  color: var(--gold2);
}

.pdp-tagline {
  font-family: var(--S);
  font-size: 17px;
  font-style: italic;
  color: var(--ink3);
  line-height: 1.65;
  margin-bottom: 22px;
  max-width: 440px;
}

.pdp-stars {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 22px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--canvas-dk);
}

.pdp-s {
  color: var(--gold);
  font-size: 14px;
  letter-spacing: 2px;
}

.pdp-sr {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
}

.pdp-sr strong {
  color: var(--ink);
}

.pdp-price-row {
  display: flex;
  align-items: flex-end;
  gap: 16px;
  margin-bottom: 20px;
}

.pdp-price {
  font-family: var(--D);
  font-size: 44px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}

.pdp-sub-price {
  font-size: 13px;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 5px;
}

/* subscribe toggle */
.sub-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--canvas-dk);
  margin-bottom: 22px;
}

.sub-opt {
  padding: 12px 16px;
  cursor: pointer;
  transition: all .22s;
  text-align: center;
}

.sub-opt.on {
  background: var(--gold-pale);
}

.sub-opt-label {
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink3);
  font-weight: 400;
}

.sub-opt-price {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 300;
  color: var(--ink);
  margin-top: 2px;
}

.sub-opt-save {
  font-size: 11px;
  color: var(--gold);
  margin-top: 2px;
}

.sub-opt.on .sub-opt-label {
  color: var(--ink);
}




.qty-val {
  width: 44px;
  text-align: center;
  font-family: var(--D);
  font-size: 20px;
  font-weight: 300;
  color: var(--ink);
}


/* trust mini-bar */
.pdp-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-bottom: 28px;
}

.pt {
  padding: 10px 14px;
  background: var(--canvas);
  text-align: center;
}

.pt-ico {
  font-size: 11px;
  color: var(--gold);
  opacity: .7;
  margin-bottom: 3px;
}

.pt-lbl {
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink4);
  font-weight: 300;
}

/* accordion */
.accord {
  border-top: 1px solid var(--canvas-dk);
}

.accord-item {
  border-bottom: 1px solid var(--canvas-dk);
}

.accord-hd {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 0;
  cursor: pointer;
  font-size: 13px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink3);
  font-weight: 400;
}

.accord-hd:hover {
  color: var(--ink);
}

.accord-ico {
  font-size: 14px;
  color: var(--gold);
  transition: transform .25s;
  font-weight: 300;
}

.accord-body {
  display: none;
  padding-bottom: 18px;
}

.accord-body.open {
  display: block;
}

.accord-hd.open .accord-ico {
  transform: rotate(45deg);
}

.accord-body p {
  font-family: var(--S);
  font-size: 15px;
  line-height: 1.88;
  color: var(--ink3);
  margin-bottom: 12px;
}

.accord-body ul {
  list-style: none;
}

.accord-body ul li {
  font-family: var(--S);
  font-size: 14.5px;
  color: var(--ink3);
  padding: 5px 0;
  border-bottom: 1px solid var(--canvas-dk);
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.accord-body ul li::before {
  content: '—';
  color: var(--gold);
  font-family: var(--D);
  flex-shrink: 0;
}

/* PDP ingredient showcase */
.pdp-ingredients {
  background: var(--canvas2);
  padding: 80px 80px;
}

.pi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.pi {
  background: var(--canvas2);
  padding: 32px 28px;
  transition: background .3s;
}

.pi:hover {
  background: var(--canvas);
}

.pi-name {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 4px;
}

.pi-origin {
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
  font-weight: 300;
}

.pi-p {
  font-family: var(--S);
  font-size: 14px;
  line-height: 1.82;
  color: var(--ink3);
}

/* before/after */
.pdp-before-after {
  background: var(--canvas);
  padding: 80px 80px;
}

.ba-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.ba-card {
  background: var(--canvas);
  padding: 40px 36px;
}

.ba-card-label {
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
  font-weight: 300;
  display: flex;
  align-items: center;
  gap: 10px;
}

.ba-card-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--gold-line);
}

.ba-stat {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px 20px;
  align-items: center;
  margin-bottom: 14px;
}

.ba-pct {
  font-family: var(--D);
  font-size: 38px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}

.ba-stat-p {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.7;
}

.ba-source {
  font-size: 11px;
  color: var(--ink5);
  font-weight: 300;
  margin-top: 14px;
}

/* reviews */
.pdp-reviews {
  background: var(--canvas2);
  padding: 80px 80px;
}

.rev-summary {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 48px;
  align-items: center;
  margin-top: 52px;
  margin-bottom: 52px;
  padding-bottom: 52px;
  border-bottom: 1px solid var(--gold-line);
}

.rev-big {
  text-align: center;
}

.rev-score {
  font-family: var(--D);
  font-size: 72px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}

.rev-max {
  font-size: 12px;
  color: var(--ink4);
  letter-spacing: .1em;
}

.rev-stars-big {
  color: var(--gold);
  font-size: 18px;
  letter-spacing: 3px;
  margin: 8px 0;
}

.rev-count {
  font-size: 12px;
  color: var(--ink5);
  font-weight: 300;
  letter-spacing: .1em;
}

.rev-bars {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rev-bar-row {
  display: grid;
  grid-template-columns: 20px 1fr 32px;
  gap: 10px;
  align-items: center;
}

.rev-bar-lbl {
  font-size: 12px;
  color: var(--ink4);
  text-align: right;
}

.rev-bar-track {
  height: 4px;
  background: var(--canvas-dk);
  border-radius: 2px;
  overflow: hidden;
}

.rev-bar-fill {
  height: 100%;
  background: var(--gold);
  border-radius: 2px;
}

.rev-bar-pct {
  font-size: 11px;
  color: var(--ink5);
}

.rev-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
}

.rv {
  background: var(--canvas2);
  padding: 32px 28px;
}

.rv-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}

.rv-stars {
  color: var(--gold);
  font-size: 13px;
  letter-spacing: 1.5px;
}

.rv-date {
  font-size: 11px;
  color: var(--ink5);
  font-weight: 300;
}

.rv-title {
  font-family: var(--D);
  font-size: 17px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
}

.rv-body {
  font-family: var(--S);
  font-size: 14.5px;
  color: var(--ink3);
  line-height: 1.78;
  margin-bottom: 12px;
}

.rv-author {
  font-size: 12px;
  color: var(--ink4);
  text-transform: uppercase;
  letter-spacing: .12em;
}

.rv-verified {
  font-size: 11px;
  color: var(--gold);
  letter-spacing: .1em;
  margin-top: 3px;
}

/* also love */
.pdp-also-love {
  background: var(--canvas);
  padding: 80px 80px;
  border-top: 1px solid var(--gold-line);
}

.al-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

/* video placeholder sections */
.vid-placeholder {
  background: var(--ink);
  height: 360px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  border: 1px dashed rgba(200, 146, 26, .2);
  position: relative;
  overflow: hidden;
}

.vid-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(168, 104, 26, .06), transparent);
}

.vid-play {
  width: 60px;
  height: 60px;
  border: 1.5px solid rgba(200, 146, 26, .4);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vid-play::after {
  content: '▶';
  font-size: 16px;
  color: rgba(200, 146, 26, .7);
  margin-left: 3px;
}

.vid-label {
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .5);
  font-weight: 300;
}

.vid-note {
  font-size: 10px;
  color: rgba(248, 242, 230, .18);
  font-weight: 300;
  font-family: var(--S);
  font-style: italic;
}



/* concern filter */
.concern-tab {
  padding: 8px 20px;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 300;
  border: 1px solid var(--canvas-dk);
  background: var(--canvas2);
  color: var(--ink4);
  font-family: var(--U);
  cursor: pointer;
  transition: all .22s;
}

.concern-tab:hover {
  border-color: var(--gold);
  color: var(--gold2);
}

.concern-tab.on {
  background: var(--ink);
  color: var(--canvas);
  border-color: var(--ink);
}

.concern-card {
  transition: opacity .35s ease, transform .35s ease;
}

.concern-card.hidden {
  opacity: 0;
  pointer-events: none;
  position: absolute;
  visibility: hidden;
}

.concern-pill {
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 3px 9px;
  border: 1px solid var(--canvas-dk);
  color: var(--ink4);
  font-weight: 300;
  font-family: var(--U);
}

/* pairs well with */
.pairs-section {
  background: var(--canvas);
  padding: 64px 80px;
  border-top: 1px solid var(--gold-line);
}

.pairs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 40px;
}

.pair-card {
  background: var(--canvas);
  padding: 28px 26px;
  display: flex;
  align-items: center;
  gap: 18px;
  cursor: pointer;
  transition: background .25s;
}

.pair-card:hover {
  background: var(--canvas2);
}

.pair-img {
  width: 72px;
  height: 72px;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid var(--canvas-dk);
}

.pair-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pair-img.contain img {
  object-fit: contain;
  padding: 8px;
}

.pair-body {}

.pair-reason {
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 5px;
}

.pair-name {
  font-family: var(--D);
  font-size: 17px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 4px;
  line-height: 1.2;
}

.pair-price {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 300;
  color: var(--ink3);
}

.pair-arrow {
  margin-left: auto;
  font-size: 14px;
  color: var(--gold-line);
  transition: all .22s;
  flex-shrink: 0;
}

.pair-card:hover .pair-arrow {
  color: var(--gold);
  transform: translateX(3px);
}



/* ── SHOP PAGE ── */
.shop-hero {
  background: var(--canvas2);
  padding: 80px 80px 60px;
  border-bottom: 1px solid var(--gold-line);
  text-align: center;
}

.shop-hero-sub-sanskrit {
  font-family: var(--D);
  font-size: 18px;
  font-weight: 300;
  font-style: italic;
  color: var(--gold2);
  margin-bottom: 10px;
  letter-spacing: .02em;
}

.rtab-sub {
  display: block;
  font-family: var(--S);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink4);
  font-weight: 300;
  margin-top: 3px;
  font-style: normal;
}

.shop-hero-rule {
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 16px;
}

.shop-hero h1 {
  font-family: var(--D);
  font-size: 52px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: 14px;
}

.shop-hero p {
  font-family: var(--S);
  font-size: 17px;
  color: var(--ink3);
  line-height: 1.85;
  max-width: 500px;
  margin: 0 auto;
}

/* ritual filter tabs */
.shop-tabs {
  display: flex;
  justify-content: center;
  gap: 0;
  border-bottom: 1px solid var(--canvas-dk);
  background: var(--canvas);
  position: sticky;
  top: 72px;
  z-index: 100;
}

.shop-tab {
  padding: 16px 28px;
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-family: var(--U);
  font-weight: 300;
  color: var(--ink4);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all .22s;
  background: none;
  border-top: none;
  border-left: none;
  border-right: none;
}

.shop-tab.on {
  color: var(--ink);
  border-bottom-color: var(--gold);
}

.shop-tab:hover {
  color: var(--ink);
}

/* ritual section */
.ritual-section {
  padding: 72px 80px;
  border-bottom: 1px solid var(--gold-line);
}

.ritual-section:last-child {
  border: none;
}

.ritual-header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  margin-bottom: 48px;
}

.ritual-sutra-meaning {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 300;
  color: var(--gold2);
  font-style: italic;
  margin-bottom: 14px;
  line-height: 1.3;
}

.ritual-sutra-body {
  font-family: var(--S);
  font-size: 16px;
  line-height: 1.9;
  color: var(--ink3);
  margin-bottom: 16px;
  max-width: 600px;
}

.ritual-desc {
  font-family: var(--D);
  font-size: 16px;
  font-weight: 300;
  font-style: italic;
  color: var(--ink2);
  line-height: 1.65;
  margin-bottom: 0;
}

.ritual-badge {
  font-size: 12px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 10px;
}

.ritual-title {
  font-family: var(--D);
  font-size: 38px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: 8px;
}

.ritual-desc {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.85;
  max-width: 520px;
}

.ritual-total {
  font-family: var(--D);
  font-size: 16px;
  color: var(--ink4);
  text-align: right;
}

.ritual-total span {
  display: block;
  font-size: 26px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}

/* step-based ritual product list */
.ritual-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
}

.ritual-steps.steps-2 {
  grid-template-columns: repeat(2, 1fr);
}

.ritual-steps.steps-3 {
  grid-template-columns: repeat(3, 1fr);
}

.ritual-step {
  background: var(--canvas);
  position: relative;
  transition: background .25s;
}

.ritual-step:hover {
  background: var(--canvas2);
}

.step-num {
  position: absolute;
  top: 16px;
  left: 16px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--gold-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--D);
  font-size: 15px;
  font-weight: 300;
  color: var(--gold);
  background: var(--canvas);
  z-index: 2;
}

.step-connector {
  position: absolute;
  top: 32px;
  left: 48px;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--gold-line), transparent);
  z-index: 1;
}

.ritual-step:last-child .step-connector {
  display: none;
}

.step-img {
  height: 260px;
  overflow: hidden;
  cursor: pointer;
}

.step-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 24px;
  transition: transform .5s;
}

.ritual-step:hover .step-img img {
  transform: scale(1.04);
}

.step-body {
  padding: 16px 20px 22px;
}

.step-label {
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 5px;
}

.step-name {
  font-family: var(--D);
  font-size: 18px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 3px;
  line-height: 1.2;
}

.step-tag {
  font-family: var(--S);
  font-size: 12.5px;
  font-style: italic;
  color: var(--ink3);
  margin-bottom: 10px;
  line-height: 1.6;
}

.step-price {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 300;
  color: var(--ink);
}

.step-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--canvas-dk);
}

.step-atc {
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family: var(--U);
  font-weight: 300;
  color: var(--ink4);
  padding: 7px 14px;
  border: 1px solid var(--canvas-dk);
  background: none;
  transition: all .22s;
  cursor: pointer;
}

.step-atc:hover {
  background: var(--ink);
  color: var(--canvas);
  border-color: var(--ink);
}

.step-view {
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family: var(--U);
  color: var(--gold);
  cursor: pointer;
  font-weight: 300;
}

.step-view:hover {
  text-decoration: underline;
}

.set-bundle-hero {
  width: 100%;
  height: 220px;
  overflow: hidden;
  margin-bottom: 16px;
}

.set-bundle-hero img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  transition: transform .6s ease;
}

.set-card.has-bundle:hover .set-bundle-hero img {
  transform: scale(1.04);
}

.set-card.has-bundle {
  padding-top: 0;
  overflow: hidden;
}

.set-card.has-bundle .set-badge,
.set-card.has-bundle .set-name,
.set-card.has-bundle .set-includes,
.set-card.has-bundle .set-foot {
  padding: 0 32px;
}

.set-card.has-bundle .set-badge {
  margin-top: 20px;
}

.set-card.has-bundle .set-foot {
  padding-bottom: 28px;
}

/* ── TRUST STRIPS ── */
.pdp-trust-strip {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink3);
  margin-bottom: 20px;
  padding: 12px 16px;
  background: rgba(168, 104, 26, .07);
  border-radius: 4px;
  border: 1px solid rgba(168, 104, 26, .15);
}

.pdp-trust-strip span:nth-child(even) {
  color: var(--gold);
  opacity: .4;
}

.shop-trust-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink3);
  margin-top: 16px;
}

.shop-trust-row span:nth-child(even) {
  color: var(--gold);
  opacity: .4;
}

.saffron-spotlight {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 640px;
  background: var(--canvas);
  border-top: 1px solid var(--gold-line);
  border-bottom: 1px solid var(--gold-line);
}

.ss-left {
  padding: 80px 64px 80px 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.ss-badge {
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 18px;
  font-family: var(--U);
}

.ss-title {
  font-family: var(--D);
  font-size: 62px;
  font-weight: 300;
  line-height: 1.05;
  color: var(--ink);
  margin-bottom: 20px;
}

.ss-title em {
  color: var(--gold2);
  font-style: italic;
}

.ss-reviews {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}

.ss-stars {
  color: var(--gold);
  font-size: 20px;
  letter-spacing: 2px;
}

.ss-rcount {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
}

.ss-price {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 300;
  color: var(--ink);
  margin-left: auto;
}

.ss-tejas-line {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 300;
  font-style: italic;
  color: var(--gold2);
  margin-bottom: 16px;
  line-height: 1.5;
}

.ss-body {
  font-family: var(--S);
  font-size: 17px;
  line-height: 1.9;
  color: var(--ink3);
  margin-bottom: 16px;
  max-width: 440px;
}

.ss-result {
  font-family: var(--S);
  font-size: 17px;
  font-style: italic;
  color: var(--ink2);
  margin-bottom: 32px;
}

.ss-btns {
  display: flex;
  gap: 14px;
  margin-bottom: 36px;
  flex-wrap: wrap;
}

.ss-trio {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-top: 28px;
  border-top: 1px solid var(--canvas-dk);
}

.ss-trio-item {
  display: flex;
  flex-direction: column;
}

.ss-trio-num {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
}

.ss-trio-label {
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink4);
  font-family: var(--U);
  margin-top: 3px;
}

.ss-trio-sep {
  color: var(--gold-line);
  font-size: 20px;
}

.ss-right {
  position: relative;
  overflow: hidden;
  background: radial-gradient(ellipse at 60% 40%, #3A1A08 0%, #1A0A04 60%, #0D0502 100%);
}

.ss-img-wrap {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ss-glow-ring {
  position: absolute;
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(168, 104, 26, .22) 0%, transparent 70%);
  pointer-events: none;
}

.ss-img {
  height: 78%;
  max-height: 480px;
  width: auto;
  object-fit: contain;
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 24px 48px rgba(0, 0, 0, .5));
}

@media(max-width:768px) {
  .saffron-spotlight {
    grid-template-columns: 1fr;
  }

  .ss-left {
    padding: 56px 32px;
  }

  .ss-right {
    min-height: 420px;
  }

  .ss-title {
    font-size: 46px;
  }
}

.sc2-sanskrit {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 5px;
}

.sc2-pronounce {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink5);
  letter-spacing: .06em;
  font-style: italic;
  margin-bottom: 16px;
}

.sc2-meaning {
  font-family: var(--D);
  font-size: 30px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.15;
  margin-bottom: 6px;
}

.sc2-eng {
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--ink4);
  font-weight: 300;
  margin-bottom: 20px;
  font-family: var(--U);
}

.sc2-divider {
  width: 32px;
  height: 1px;
  background: var(--gold);
  opacity: .5;
  margin-bottom: 18px;
}

.sc2-ayurveda {
  font-family: var(--S);
  font-size: 13px;
  line-height: 1.9;
  color: var(--ink3);
  margin-bottom: 14px;
}

.sc2-desc {
  font-family: var(--D);
  font-size: 16px;
  font-weight: 300;
  font-style: italic;
  color: var(--gold2);
  line-height: 1.6;
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--canvas-dk);
}

.sc2-includes-label {
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink5);
  margin-bottom: 12px;
  font-family: var(--U);
}

.set-card.sig {
  grid-column: 1/-1;
}

.set-card.sig .sc2-meaning {
  font-size: 38px;
}

.set-card.sig .sc2-ayurveda {
  font-size: 14px;
  max-width: 680px;
}

.sc-sanskrit-sub {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink4);
  font-style: italic;
  margin-top: -4px;
  margin-bottom: 12px;
  letter-spacing: .04em;
}

/* ritual bundle bar */
.ritual-bundle {
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  padding: 22px 28px;
  margin-top: 1px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.rb-left {
  display: flex;
  align-items: center;
  gap: 14px;
}

.rb-icon {
  font-size: 16px;
  opacity: .5;
}

.rb-text {}

.rb-label {
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 3px;
}

.rb-name {
  font-family: var(--D);
  font-size: 18px;
  color: var(--ink);
  font-weight: 400;
}

.rb-saving {
  font-family: var(--S);
  font-size: 16px;
  font-style: italic;
  color: var(--ink3);
  margin-top: 2px;
}

.rb-price {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 300;
  color: var(--ink);
  flex-shrink: 0;
}

.rb-atc {
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family: var(--U);
  font-weight: 300;
  color: var(--canvas);
  padding: 12px 24px;
  background: var(--ink);
  border: none;
  cursor: pointer;
  transition: background .22s;
  flex-shrink: 0;
}

.rb-atc:hover {
  background: var(--gold);
}

/* ritual sets grid */
.sets-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 52px;
}

.set-card.sig {
  grid-column: 1/-1;
}

.set-card.sig .set-meaning {
  font-size: 36px;
}

.set-card {
  background: var(--canvas);
  padding: 36px 32px;
  transition: background .25s;
  cursor: pointer;
}

.set-card:hover {
  background: var(--canvas2);
}

.set-badge {
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 10px;
}

.set-name {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.15;
}

.set-includes {
  font-family: var(--S);
  font-size: 13.5px;
  font-style: italic;
  color: var(--ink3);
  margin-bottom: 16px;
  line-height: 1.75;
}

.set-imgs {
  display: flex;
  gap: 8px;
  margin-bottom: 18px;
}

.set-img {
  width: 64px;
  height: 64px;
  overflow: hidden;
  border: 1px solid var(--canvas-dk);
  flex-shrink: 0;
}

.set-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
}

.set-foot {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  padding-top: 16px;
  border-top: 1px solid var(--canvas-dk);
}

.set-price {
  font-family: var(--D);
  font-size: 32px;
  font-weight: 300;
  color: var(--ink);
}

.set-was {
  font-size: 12px;
  color: var(--ink4);
  text-decoration: line-through;
  margin-bottom: 3px;
}

.set-saving {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: .06em;
}

.set-shop {
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-family: var(--U);
  font-weight: 300;
  color: var(--ink4);
  padding: 10px 20px;
  border: 1px solid var(--canvas-dk);
  background: none;
  cursor: pointer;
  transition: all .22s;
}

.set-card:hover .set-shop {
  background: var(--ink);
  color: var(--canvas);
  border-color: var(--ink);
}

/* featured set — signature */
.set-card.signature {
  grid-column: 1/-1;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 32px;
}

.set-card.signature .set-name {
  font-size: 34px;
}

.set-imgs-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

@media(max-width:900px) {
  .ritual-steps {
    grid-template-columns: repeat(2, 1fr);
  }

  .sets-grid {
    grid-template-columns: 1fr;
  }

  .set-card.signature {
    grid-template-columns: 1fr;
  }

  .ritual-section {
    padding: 56px 32px;
  }

  .shop-hero {
    padding: 56px 32px;
  }

  .shop-tabs {
    overflow-x: auto;
    justify-content: flex-start;
  }
}

/* ── HOW TO USE ── */
.htu-section {
  background: var(--canvas2);
  padding: 80px 80px;
  border-top: 1px solid var(--gold-line);
}

.htu-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
  margin-top: 52px;
}

.htu-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.htu-step {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 16px;
  padding: 24px 0;
  border-bottom: 1px solid var(--canvas-dk);
  position: relative;
}

.htu-step:last-child {
  border: none;
}

/* connector line between steps */
.htu-step::before {
  content: '';
  position: absolute;
  left: 25px;
  top: 52px;
  bottom: -24px;
  width: 1px;
  background: linear-gradient(180deg, var(--gold-line), transparent);
}

.htu-step:last-child::before {
  display: none;
}

.htu-num {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1px solid var(--gold-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--D);
  font-size: 20px;
  font-weight: 300;
  color: var(--gold);
  background: var(--canvas);
  flex-shrink: 0;
  position: relative;
  z-index: 1;
  transition: all .25s;
}

.htu-step:hover .htu-num {
  background: var(--gold);
  color: var(--canvas);
  border-color: var(--gold);
}

.htu-content {}

.htu-step-label {
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
  margin-bottom: 5px;
}

.htu-step-title {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.2;
}

.htu-step-desc {
  font-family: var(--S);
  font-size: 14.5px;
  line-height: 1.82;
  color: var(--ink3);
}

.htu-tip {
  margin-top: 10px;
  padding: 10px 14px;
  background: var(--gold-pale);
  border-left: 2px solid var(--gold);
  font-family: var(--S);
  font-size: 13px;
  font-style: italic;
  color: var(--ink3);
  line-height: 1.7;
}

.htu-visual {
  position: sticky;
  top: 96px;
}

.htu-product-card {
  background: var(--canvas);
  border: 1px solid var(--gold-line);
  padding: 32px 28px;
  margin-bottom: 1px;
}

.htu-prod-img {
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--canvas2);
}

.htu-prod-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 24px;
}

.htu-timing {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--canvas-dk);
  margin-top: 18px;
}

.htu-time {
  background: var(--canvas);
  padding: 14px 16px;
  text-align: center;
}

.htu-time-icon {
  font-size: 16px;
  margin-bottom: 5px;
  opacity: .5;
}

.htu-time-label {
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink4);
  font-weight: 300;
  margin-bottom: 2px;
}

.htu-time-val {
  font-family: var(--D);
  font-size: 18px;
  font-weight: 300;
  color: var(--ink);
}

.htu-warnings {
  margin-top: 1px;
  background: var(--canvas);
  border: 1px solid var(--canvas-dk);
  padding: 16px 18px;
}

.htu-warn-title {
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--ink4);
  margin-bottom: 10px;
  font-weight: 400;
}

.htu-warn-item {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  margin-bottom: 7px;
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
  line-height: 1.65;
}

.htu-warn-item:last-child {
  margin: 0;
}

.htu-warn-ico {
  color: var(--gold);
  font-size: 11px;
  margin-top: 3px;
  flex-shrink: 0;
}

/* ── BUILD YOUR ROUTINE ── */
.routine-section {
  background: var(--canvas);
  padding: 80px 80px;
  border-top: 1px solid var(--gold-line);
}

.routine-toggle {
  display: flex;
  justify-content: center;
  gap: 0;
  border: 1px solid var(--canvas-dk);
  width: fit-content;
  margin: 40px auto 52px;
}

.routine-opt {
  padding: 11px 32px;
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 300;
  cursor: pointer;
  transition: all .22s;
  font-family: var(--U);
  background: none;
  border: none;
  color: var(--ink4);
}

.routine-opt.on {
  background: var(--ink);
  color: var(--canvas);
}

.routine-timeline {
  display: none;
}

.routine-timeline.on {
  display: block;
}

.rt-steps {
  display: flex;
  align-items: stretch;
  gap: 0;
  background: var(--canvas-dk);
  border: 1px solid var(--canvas-dk);
}

.rt-step {
  flex: 1;
  background: var(--canvas2);
  padding: 28px 22px;
  position: relative;
  border-right: 1px solid var(--canvas-dk);
  transition: background .25s;
}

.rt-step:last-child {
  border: none;
}

.rt-step:hover {
  background: var(--canvas);
}

.rt-step.current {
  background: var(--gold-pale);
  border-bottom: 2px solid var(--gold);
}

.rt-step.current .rt-step-name {
  color: var(--gold2);
}

.rt-arrow {
  position: absolute;
  right: -10px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: var(--canvas-dk);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--ink5);
  z-index: 2;
  clip-path: polygon(0 50%, 100% 0, 100% 100%);
}

.rt-step-num {
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--ink5);
  margin-bottom: 8px;
  font-weight: 300;
}

.rt-step-name {
  font-family: var(--D);
  font-size: 18px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 5px;
  line-height: 1.2;
}

.rt-step-timing {
  font-size: 11px;
  color: var(--gold);
  letter-spacing: .1em;
  margin-bottom: 8px;
}

.rt-step-note {
  font-family: var(--S);
  font-size: 12.5px;
  color: var(--ink4);
  line-height: 1.65;
}

.rt-step-img {
  width: 48px;
  height: 48px;
  overflow: hidden;
  margin-bottom: 10px;
  border: 1px solid var(--canvas-dk);
}

.rt-step-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.rt-current-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 300;
}

.rt-current-label::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold);
}

.routine-note {
  margin-top: 28px;
  padding: 18px 24px;
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.rn-ico {
  font-size: 16px;
  color: var(--gold);
  opacity: .6;
  flex-shrink: 0;
  margin-top: 2px;
}

.rn-txt {
  font-family: var(--S);
  font-size: 14.5px;
  color: var(--ink3);
  line-height: 1.8;
  font-style: italic;
}

/* sec header shared */
.sec-hd {
  text-align: center;
}

.sec-hd-rule {
  margin-bottom: 18px;
}


/* ── CART SYSTEM ── */
:root {
  --cd-w: 480px;
}

.cart-overlay {
  position: fixed;
  inset: 0;
  background: rgba(26, 18, 6, .52);
  z-index: 1100;
  opacity: 0;
  pointer-events: none;
  transition: opacity .32s;
}

.cart-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.cart-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: var(--cd-w);
  height: 100vh;
  background: var(--canvas);
  z-index: 1200;
  transform: translateX(100%);
  transition: transform .38s cubic-bezier(.22, .9, .36, 1);
  display: flex;
  flex-direction: column;
  box-shadow: -6px 0 60px rgba(26, 18, 6, .13);
}

.cart-drawer.open {
  transform: translateX(0);
}

/* Head */
.cd-head {
  padding: 26px 32px 22px;
  border-bottom: 1px solid var(--gold-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.cd-head-left {
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.cd-title {
  font-family: var(--D);
  font-size: 21px;
  font-weight: 400;
  color: var(--ink);
  letter-spacing: .04em;
}

.cd-count {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
}

.cd-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--ink4);
  font-size: 18px;
  padding: 4px 6px;
  line-height: 1;
  transition: color .2s;
  font-family: var(--U);
}

.cd-close:hover {
  color: var(--ink);
}

/* Scroll body */
.cd-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
}

.cd-body::-webkit-scrollbar {
  width: 2px;
}

.cd-body::-webkit-scrollbar-thumb {
  background: var(--gold-line);
}

/* Empty */
.cd-empty {
  padding: 72px 32px;
  text-align: center;
}

.cd-empty-ornament {
  font-family: var(--D);
  font-size: 48px;
  font-weight: 300;
  color: rgba(168, 104, 26, .15);
  line-height: 1;
  margin-bottom: 16px;
  letter-spacing: .1em;
}

.cd-empty-title {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 8px;
}

.cd-empty-sub {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink4);
  line-height: 1.75;
  margin-bottom: 28px;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}

.cd-empty-cta {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 14px 28px;
  cursor: pointer;
  transition: background .22s;
}

.cd-empty-cta:hover {
  background: var(--gold);
}

/* Free shipping bar */
.cd-ship-bar {
  padding: 14px 32px;
  background: rgba(168, 104, 26, .05);
  border-bottom: 1px solid var(--gold-line);
}

.cd-ship-text {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink3);
  margin-bottom: 7px;
}

.cd-ship-text b {
  color: var(--gold);
}

.cd-ship-track {
  height: 2px;
  background: var(--canvas-dk);
  overflow: hidden;
}

.cd-ship-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold), #C8881E);
  transition: width .5s cubic-bezier(.22, .9, .36, 1);
}

/* Cart items */
.cd-items {}

.cd-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 16px;
  padding: 20px 32px;
  border-bottom: 1px solid rgba(168, 104, 26, .07);
  align-items: start;
  transition: background .18s;
}

.cd-item:hover {
  background: rgba(168, 104, 26, .02);
}

.cd-img {
  width: 80px;
  height: 96px;
  overflow: hidden;
  background: var(--canvas2);
  flex-shrink: 0;
  border: 1px solid var(--canvas-dk);
}

.cd-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cd-info {}

.cd-item-collection {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 3px;
}

.cd-item-name {
  font-family: var(--D);
  font-size: 16px;
  font-weight: 400;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 3px;
}

.cd-item-sub {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink4);
  margin-bottom: 11px;
}

.cd-item-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cd-qty {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cd-qty-btn {
  background: none;
  border: 1px solid var(--canvas-dk);
  width: 26px;
  height: 26px;
  cursor: pointer;
  color: var(--ink3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  transition: all .18s;
  line-height: 1;
}

.cd-qty-btn:hover {
  border-color: var(--ink);
  color: var(--ink);
}

.cd-qty-n {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--ink);
  width: 20px;
  text-align: center;
}

.cd-item-price {
  font-family: var(--D);
  font-size: 17px;
  font-weight: 300;
  color: var(--ink);
}

.cd-remove {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink4);
  cursor: pointer;
  margin-top: 8px;
  display: inline-block;
  transition: color .18s;
  border-bottom: 1px solid transparent;
}

.cd-remove:hover {
  color: var(--ink);
  border-color: var(--ink4);
}

/* Upsell */
.cd-upsell {
  padding: 20px 32px 0;
  border-bottom: 1px solid var(--gold-line);
}

.cd-upsell-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 14px;
}

.cd-upsell-scroll {
  display: flex;
  gap: 10px;
  padding-bottom: 20px;
  overflow-x: auto;
}

.cd-upsell-scroll::-webkit-scrollbar {
  display: none;
}

.cd-up-card {
  flex-shrink: 0;
  width: 116px;
  border: 1px solid var(--canvas-dk);
  padding: 10px;
  cursor: pointer;
  transition: all .2s;
  background: var(--canvas);
}

.cd-up-card:hover {
  border-color: var(--gold);
  background: rgba(168, 104, 26, .03);
}

.cd-up-img {
  width: 100%;
  height: 68px;
  overflow: hidden;
  margin-bottom: 8px;
  background: var(--canvas2);
}

.cd-up-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cd-up-name {
  font-family: var(--D);
  font-size: 12px;
  color: var(--ink);
  line-height: 1.25;
  margin-bottom: 3px;
}

.cd-up-price {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--gold);
}

.cd-up-add {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .14em;
  color: var(--ink4);
  margin-top: 5px;
  text-transform: uppercase;
}

/* Summary */
.cd-summary {
  padding: 18px 32px 0;
}

.cd-sum-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0;
  font-family: var(--S);
  font-size: 13px;
}

.cd-sum-label {
  color: var(--ink3);
}

.cd-sum-val {
  color: var(--ink);
}

.cd-sum-val.free {
  color: var(--gold);
  font-style: italic;
}

.cd-sum-val.save {
  color: var(--gold);
}

.cd-total-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 14px 0 0;
  border-top: 1px solid var(--gold-line);
  margin-top: 10px;
}

.cd-total-label {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink);
}

.cd-total-val {
  font-family: var(--D);
  font-size: 30px;
  font-weight: 300;
  color: var(--ink);
}

/* ── CHECKOUT OVERLAY ── */
.co-overlay {
  position: fixed;
  inset: 0;
  background: var(--canvas);
  z-index: 1400;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform .4s cubic-bezier(.22, .9, .36, 1);
}

.co-overlay.open {
  transform: translateY(0);
}

.co-bar {
  padding: 22px 48px;
  border-bottom: 1px solid var(--gold-line);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}

.co-logo {
  font-family: var(--D);
  font-size: 18px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--ink);
}

.co-steps {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink4);
}

.co-step {
  padding: 4px 10px;
  transition: color .2s;
}

.co-step.active {
  color: var(--gold);
}

.co-sep {
  color: var(--canvas-dk);
}

.co-back {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink4);
  background: none;
  border: none;
  cursor: pointer;
  transition: color .2s;
}

.co-back:hover {
  color: var(--ink);
}

.co-body {
  flex: 1;
  overflow-y: auto;
  display: grid;
  grid-template-columns: 1fr 400px;
}

/* Left form panel */
.co-form {
  padding: 48px 52px;
  border-right: 1px solid var(--gold-line);
}

.co-section {
  margin-bottom: 32px;
}

.co-section-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 18px;
  display: block;
}

.co-field {
  margin-bottom: 14px;
}

.co-label {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
  display: block;
  margin-bottom: 5px;
}

.co-input {
  width: 100%;
  border: none;
  border-bottom: 1px solid var(--canvas-dk);
  background: transparent;
  padding: 10px 2px;
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink);
  outline: none;
  transition: border-color .22s;
  box-sizing: border-box;
}

.co-input:focus {
  border-color: var(--gold);
}

.co-input::placeholder {
  color: var(--ink4);
  font-size: 13px;
}

.co-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.co-pay-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
}

.co-pay-method {
  flex: 1;
  border: 1px solid var(--canvas-dk);
  padding: 11px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
  transition: all .2s;
}

.co-pay-method.on {
  border-color: var(--gold);
  color: var(--ink);
  background: rgba(168, 104, 26, .03);
}

.co-submit {
  width: 100%;
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 18px;
  cursor: pointer;
  transition: background .25s;
  margin-top: 28px;
}

.co-submit:hover {
  background: var(--gold);
}

/* Right order summary */
.co-aside {
  padding: 48px 44px;
  background: var(--canvas2);
  overflow-y: auto;
}

.co-aside-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
  display: block;
}

.co-line {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(168, 104, 26, .08);
}

.co-line-img {
  width: 54px;
  height: 62px;
  overflow: hidden;
  background: var(--canvas);
  flex-shrink: 0;
  border: 1px solid var(--canvas-dk);
}

.co-line-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.co-line-name {
  font-family: var(--D);
  font-size: 14px;
  color: var(--ink);
  flex: 1;
  line-height: 1.2;
}

.co-line-qty {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--ink4);
}

.co-line-price {
  font-family: var(--D);
  font-size: 14px;
  color: var(--ink);
  font-weight: 300;
}

.co-sum-block {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--gold-line);
}

.co-sum-r {
  display: flex;
  justify-content: space-between;
  padding: 4px 0;
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
}

.co-sum-r.total {
  padding-top: 12px;
  border-top: 1px solid var(--gold-line);
  margin-top: 8px;
}

.co-sum-r.total .co-sum-lab {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink);
}

.co-sum-r.total .co-sum-v {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 300;
  color: var(--ink);
}

.co-sum-r .co-sum-v.free {
  color: var(--gold);
  font-style: italic;
}

.co-promise {
  margin-top: 24px;
  padding: 16px;
  background: rgba(168, 104, 26, .05);
  border: 1px solid rgba(168, 104, 26, .12);
}

.co-promise-label {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}

.co-promise-text {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink3);
  line-height: 1.7;
}

/* Confirmation screen */
.co-confirm {
  padding: 72px 52px;
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}

.co-confirm-check {
  width: 56px;
  height: 56px;
  background: var(--ink);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 24px;
  color: var(--canvas);
  font-size: 22px;
}

.co-confirm-title {
  font-family: var(--D);
  font-size: 40px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 8px;
}

.co-confirm-sub {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.75;
  margin-bottom: 32px;
}

.co-confirm-btn {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 14px 32px;
  cursor: pointer;
  transition: background .22s;
}

.co-confirm-btn:hover {
  background: var(--gold);
}

/* Qty bump animation */
@keyframes bumpUp {

  0%,
  100% {
    transform: scale(1)
  }

  50% {
    transform: scale(1.22)
  }
}

.bump {
  animation: bumpUp .3s ease;
}


/* ── SUTRA DETAIL PAGES ── */
.sutra-banner {
  /*position:relative;*/
  width: 100%;
  height: 100%;
  background: var(--canvas2);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.sutra-image-with-action .content-right {
    display: grid;
    justify-content: end;
}
.sutra-imgs{
  display:flex;
  gap:12px;
  margin:16px 0;
  flex-wrap:wrap;
}
.sutra-img-box {
    width: 100px;
    height: 100px;
    background: var(--canvas);
    border-radius: 4px;
    overflow: hidden;
    border: 1px solid var(--heading-color);
}
.sutra-product-img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.sutra-banner-img {
  /*position:absolute;*/
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.sutra-banner-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 2px dashed rgba(168, 104, 26, .25);
  background: var(--canvas2);
  cursor: pointer;
  transition: background .2s;
}

.sutra-banner-placeholder:hover {
  background: rgba(168, 104, 26, .04);
}

.sutra-banner-placeholder-label {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.sutra-banner-placeholder-sub {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink4);
}

.sutra-banner-upload {
  position: absolute;
  top: 20px;
  right: 20px;
  background: rgba(248, 242, 230, .9);
  border: 1px solid var(--gold-line);
  padding: 8px 16px;
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
  cursor: pointer;
  z-index: 10;
  transition: all .2s;
  backdrop-filter: blur(4px);
}

.sutra-banner-upload:hover {
  background: var(--canvas);
  color: var(--ink);
}

.sutra-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(26, 18, 6, .62) 0%, rgba(26, 18, 6, .2) 50%, transparent 100%);
  z-index: 2;
}

.sutra-banner-text {
  position: relative;
  z-index: 3;
  padding: 48px 80px;
  width: 100%;
}

.sutra-banner-eyebrow {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(232, 170, 56, .9);
  margin-bottom: 12px;
}

.sutra-banner-sanskrit {
  font-family: var(--D);
  font-size: 72px;
  font-weight: 300;
  color: #F8F2E6;
  line-height: 1;
  letter-spacing: .06em;
  margin-bottom: 6px;
}

.sutra-banner-meaning {
  font-family: var(--S);
  font-size: 18px;
  color: rgba(248, 242, 230, .75);
  font-style: italic;
}

/* Proof bar */
.sutra-proof-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    align-items: center;
}
.sutra-proof-bar-main{
    background: linear-gradient(90deg, #813850 0%, #461324 100%);
}
.sp-item {
    padding: 19px;
    height: 100%;
    border-right: 1px solid #CB9646;
}
.sp-item:last-child{
  border-right:0;
}
.sp-num {
    font-weight: 400;
    font-size: 23px;
    line-height: 29px;
    letter-spacing: 0%;
    text-align: center;
    color: white;
}
.sp-lbl {
    font-size: 21px;
    opacity: 1;
    color: white;
    text-align: center;
    text-transform: capitalize;
}



/* Aside pricing panel */
.sutra-aside-label span{
  font-size: 12px;
  text-transform: capitalize;
  color: var(--link);
}
.sutra-aside-header {
    display: flex;
    gap:10px;
    align-items: center;
}
.sutra-aside-label h3 {
    color: var(--heading-color);
    font-size: 21px;
    padding: 12px 0 17px 0;
}
.sutra-aside-products {
  display: flex;
  flex-direction: column;
  gap: 14px;
  width: 100%;
  margin-bottom: 28px;
}

.sutra-product-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 12px;
  border-radius:5px;
  background: var(--canvas);
  border: 1px solid var(--heading-color);
  transition: border-color .2s;
  cursor: pointer;
}

.sutra-product-row:hover {
  border-color: var(--gold);
}
.sutra-image-with-action {
    display: grid;
    width:100%;
    align-items: center;
    justify-content: space-between;
    grid-template-columns: 1fr 1fr;
    gap:70px;
}
.sutra-product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sutra-product-name {
  font-family: var(--D);
  font-size: 18px;
  color: var(--ink);
  flex: 1;
  line-height: 1.2;
}

.sutra-product-price {
  font-family: var(--D);
  font-size: 18px;
  color: var(--ink);
  font-weight: 300;
}
.sutra-was {
    font-family: var(--S);
    font-size: 16px;
    color: var(--ink3);
    text-decoration: line-through;
    line-height: normal;
}
.sutra-set-price {
    font-family: var(--D);
    font-size: 38px;
    font-weight: 300;
    color: var(--ink);
    line-height: normal;
    padding-bottom: 10px;
}
.sutra-save-badge {
    font-family: var(--U);
    font-size: 12px;
    background: #E3C39F;
    color: var(--gold);
    padding: 4px 10px;
    display: inline-block;
    border-radius: 3px;
}
.sutra-atc-btn {
    width: 100%;
    font-size: 12px;
    letter-spacing: .22em;
    text-transform: uppercase;
    background: var(--ink);
    color: var(--canvas);
    border: none;
    padding: 11px;
    cursor: pointer;
    transition: background .22s;
    border-radius: 4px;
}

.sutra-atc-btn:hover {
  background: var(--gold);
}
.sutra-view-all {
    width: 100%;
    font-family: var(--U);
    font-size:13px;
    text-transform: uppercase;
    background: var(--gold);
    color:white;
    padding: 12px;
    cursor: pointer;
    transition: all .2s;
    text-align: center;
    display: block;
    border-radius:5px;
    margin-top: 8px;
}

.sutra-view-all:hover {
  background:var(--ink);
  color:white;
}

/* Ritual steps section */
.sutra-ritual {
  padding:50px 0;
}
.sutra-ritual-label {
    font-size: 16px;
    color: var(--ink3);
    display: flex;
    align-items: center;
    gap: 16px;
}
.sutra-steps {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 20px;
    margin-top: 26px;
}
.sutra-step.reveal{
    background: #E3C39F;
    box-shadow: 0px -3px 4px 0px #D3B18A80 inset;
    border-radius: 8px;
}
.sutra-step-content {
    padding: 15px;
}
.sutra-step-num {
    padding: 5px 15px;
    color: white;
    background: var(--heading-color);
    width: fit-content;
    position: absolute;
    font-size: 17px;
    top: 13px;
    text-align: center;
    border-radius: 0 10px 10px 0;
    z-index:3;
}
.sutra-step:last-child {
  border: none;
  padding-bottom: 0;
}
a.sutra-step-img-wrap{
  position:relative;
}
.sutra-step-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    background: #F3E4CD;
    box-shadow: 0px 2px 4px 0px #4613244D;
    border: 0.5px solid #461324;
    border-radius:8px;
}

.sutra-step-tag {
    font-size: 15px;
    color: var(--ink3);
    margin-bottom: 6px;
}
.sutra-step-name {
    font-size: 23px;
    font-weight: 400;
    color: var(--heading-color);
    line-height: 1.1;
    margin-bottom: 14px;
}
.sutra-step-benefit {
    font-size: 16px;
    color: var(--ink3);
    line-height: 19px;
    margin: 7px 0;
}
.sutra-step-instruction-label, .sutra-step-why-label {
    font-size: 21px;
    color: var(--ink3);
    margin-bottom: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 16px;
    border-bottom: 1px solid var(--gold);
    padding-bottom: 5px;
}
.sutra-step-instruction {
    font-family: var(--S);
    font-size: 16px;
    color: var(--ink3);
    line-height: 21px;
    padding-top: 10px;
}
.sutra-step-why {
    font-size: 16px;
    color: var(--ink3);
    line-height: 21px;
    padding-top: 10px;
}
.sutra-step-aside {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: space-between;
    margin-top: 22px;
}
.sutra-step-price {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 300;
  color: var(--ink);
}
.sutra-step-view {
    border: 1px solid #461324;
    font-size: 13px;
    text-transform: capitalize;
    color:var(--link3);
    cursor: pointer;
    transition: border-color .2s;
    background: var(--canvas);
    padding: 4px 5px;
    border-radius: 5px;
    transition:ease-in-out 0.5s;
}
.sutra-step-view:hover{
  background:var(--heading-color);
  color:white;
}
.sutra-action {
    display: flex;
    align-items: center;
    gap: 11px;
}
.sutra-step-atc {
    font-size: 15px;
    text-transform: capitalize;
    background: var(--gold);
    color: var(--canvas);
    border: none;
    padding: 7px 16px;
    cursor: pointer;
    transition: background .22s;
    white-space: nowrap;
    border-radius: 5px;
}
.sutra-step-atc:hover {
  background:var(--heading-color);
}
/* Back nav */
.sutra-back {
  font-family: var(--U);
  font-size: 12px;
  text-transform: capitalize;
  color: var(--ink4);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color .2s;
  padding: 20px 0px;
  border-bottom: 1px solid var(--gold-line);
  display: block;
}

.sutra-back:hover {
  color: var(--gold);
}

/* Nav sutra active */
.sutra-nav-cards {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--gold-line);
    padding: 20px 0;
}
.sutra-nav-card {
    font-size: 16px;
    color: var(--heading-color);
    padding: 7px 14px;
    cursor: pointer;
    transition: all 0.5s;
    border-radius: 2px;
    background: #E3C39F;
    text-transform: capitalize;
}
.sutra-nav-card.active{
  background: var(--heading-color);
  color:white;
}
.sutra-nav-card:hover,
.sutra-nav-card.on {
  background: var(--heading-color);
  color:white;
}

/* ── ABHYANGA SIG CARD ── */
.set-card.sig {
  grid-column: 1/-1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.sig-ticker {
  background: var(--ink);
  color: var(--canvas);
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  padding: 10px 0;
  overflow: hidden;
  white-space: nowrap;
}

.sig-ticker-track {
  display: inline-block;
  animation: tickerScroll 22s linear infinite;
}

@keyframes tickerScroll {
  from {
    transform: translateX(0)
  }

  to {
    transform: translateX(-50%)
  }
}

.sig-ticker-text {
  display: inline-block;
  padding: 0 56px;
}

.sig-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 420px;
}

.sig-left {
  padding: 60px 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--canvas);
}

.sig-right {
  background: var(--canvas2);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  padding: 48px;
}

.sig-pframe {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.sig-pimg {
  width: 108px;
  height: 140px;
  overflow: hidden;
  border: 1px solid var(--canvas-dk);
  background: var(--canvas);
}

.sig-pimg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sig-plabel {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink4);
  text-align: center;
  max-width: 90px;
  line-height: 1.4;
}

.sig-card-btns {
  display: flex;
  gap: 12px;
  margin-top: 28px;
}

.sig-btn-primary {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 14px 28px;
  cursor: pointer;
  transition: background .22s;
}

.sig-btn-primary:hover {
  background: var(--gold);
}

.sig-btn-secondary {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink3);
  border: 1px solid var(--canvas-dk);
  padding: 14px 24px;
  cursor: pointer;
  transition: all .22s;
}

.sig-btn-secondary:hover {
  border-color: var(--ink);
  color: var(--ink);
}

/* ══════════════════════════════════════
   CRO PDP — COMPLETE REBUILD
══════════════════════════════════════ */
/* Tags */
.pdp-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding: 20px 80px 0;
}

.pdp-tag {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: rgba(168, 104, 26, .08);
  color: var(--gold);
  border: 1px solid rgba(168, 104, 26, .2);
  padding: 5px 12px;
  cursor: pointer;
  transition: all .2s;
}

.pdp-tag:hover,
.pdp-tag.on {
  background: var(--gold);
  color: var(--canvas);
}

/* Breadcrumb */
.pdp-breadcrumb {
  padding: 12px 80px 0;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink5);
}

.pdp-breadcrumb a {
  color: var(--gold);
  cursor: pointer;
}

/* Hero grid */
.pdp-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: 700px;
}

/* Gallery */
.pdp-gallery {
  background: var(--canvas2);
  display: flex;
  flex-direction: column;
  gap: 0;
  position: sticky;
  top: 72px;
}

/* .pdp-main-img { width:100%; height:580px; overflow:hidden; display:flex; align-items:center; justify-content:center; background:var(--canvas2); } */
/* .pdp-main-img img { width:598px; height:100%; object-fit:contain; padding: 40px; transition:opacity .3s; } */
.pdp-main-img.contain img {
  object-fit: contain;
  padding: 40px;
}

.pdp-thumbs {
  display: flex;
  gap: 8px;
  padding: 16px 24px;
  background: var(--canvas2);
}

.pdp-thumb {
  width: 72px;
  height: 88px;
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color .2s;
  flex-shrink: 0;
}

.pdp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pdp-thumb.on {
  border-color: var(--gold);
}

/* Info column */
.pdp-info {
  padding: 48px 56px 64px;
  overflow-y: auto;
}

.pdp-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.pip {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}

.pdp-name {
  font-family: var(--D);
  font-size: 46px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.05;
  margin-bottom: 10px;
  letter-spacing: .02em;
}

.pdp-stars {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.pdp-s {
  color: #C8881E;
  font-size: 15px;
  letter-spacing: 2px;
}

.pdp-sr {
  font-family: var(--S);
  font-size: 17px;
  color: var(--ink3);
}

.pdp-review-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
}

.pdp-rb-fill {
  height: 3px;
  background: linear-gradient(90deg, #C8881E, #E8AA38);
  border-radius: 2px;
}

.pdp-size {
  font-family: var(--U);
  font-size: 15px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink4);
  margin-bottom: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--canvas-dk);
}

/* Complete your ritual CTA (top) */
.pdp-ritual-cta {
  background: rgba(168, 104, 26, .05);
  border: 1px solid rgba(168, 104, 26, .15);
  padding: 16px 20px;
  margin-bottom: 24px;
  cursor: pointer;
  transition: background .2s;
}

.pdp-ritual-cta:hover {
  background: rgba(168, 104, 26, .1);
}

.pdp-ritual-cta-label {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.pdp-ritual-cta-products {
  display: flex;
  align-items: center;
  gap: 8px;
}

.pdp-rcp-img {
  width: 36px;
  height: 44px;
  overflow: hidden;
  border: 1px solid var(--canvas-dk);
  background: var(--canvas);
  flex-shrink: 0;
}

.pdp-rcp-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pdp-rcp-arrow {
  color: var(--gold);
  font-size: 12px;
}

.pdp-rcp-total {
  font-family: var(--D);
  font-size: 15px;
  color: var(--ink);
  margin-left: auto;
}

.pdp-rcp-save {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .16em;
  color: var(--gold);
  text-transform: uppercase;
}

/* Purchase toggle */
.sub-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border: 1px solid var(--canvas-dk);
  margin-bottom: 20px;
}

.sub-opt {
  padding: 14px 18px;
  cursor: pointer;
  transition: background .2s;
  text-align: center;
}

.sub-opt.on {
  background: var(--ink);
}

.sub-opt.on .sub-opt-label,
.sub-opt.on .sub-opt-price {
  color: var(--canvas);
}

.sub-opt-label {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 4px;
}

.sub-opt-price {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 300;
  color: var(--ink);
}



/* Trust strip */
.pdp-trust {
  display: flex;
  gap: 0;
  border: 1px solid var(--canvas-dk);
  border-top: none;
  margin-bottom: 28px;
}

.pdp-trust-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px 8px;
  text-align: center;
  border-right: 1px solid var(--canvas-dk);
  gap: 4px;
}

.pdp-trust-item:last-child {
  border: none;
}

.pdp-trust-icon {
  font-size: 16px;
}

.pdp-trust-label {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
}

/* Accordion */
.pdp-acc {
  border-top: 1px solid var(--canvas-dk);
}

.pdp-acc-item {
  border-bottom: 1px solid var(--canvas-dk);
}

.pdp-acc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0;
  cursor: pointer;
}

.pdp-acc-title {
  font-family: var(--U);
  font-size: 17px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink);
}

.pdp-acc-icon {
  font-size: 18px;
  color: var(--gold);
  transition: transform .2s;
}

.pdp-acc-body {
  display: none;
  padding-bottom: 20px;
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.82;
}

.pdp-acc-body.open {
  display: block;
}

.pdp-acc-body ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.pdp-acc-body li {
  padding: 5px 0;
  border-bottom: 1px solid rgba(168, 104, 26, .06);
  font-size: 13px;
}

.pdp-acc-body li::before {
  content: '· ';
  color: var(--gold);
}

/* HOW TO USE — video section */
.pdp-htu {
  padding: 72px 80px;
  background: var(--canvas);
  border-top: 1px solid var(--gold-line);
}

.pdp-htu-label {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.pdp-htu-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--gold-line);
}

.pdp-htu-headline {
  font-family: var(--D);
  font-size: 42px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.05;
  margin-bottom: 52px;
}

.pdp-htu-headline em {
  color: var(--gold2);
}

.pdp-htu-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 72px;
  align-items: start;
}

.pdp-htu-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.pdp-htu-step {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 0;
  align-items: start;
  padding: 28px 0;
  border-bottom: 1px solid var(--gold-line);
}

.pdp-htu-step:last-child {
  border-bottom: none;
}

.pdp-htu-num {
  font-family: var(--D);
  font-size: 52px;
  font-weight: 300;
  color: rgba(168, 104, 26, .12);
  line-height: 1;
  padding-top: 4px;
}

.pdp-htu-step-content {}

.pdp-htu-step-title {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
  line-height: 1.1;
}

.pdp-htu-step-text {
  font-family: var(--S);
  font-size: 20px;
  color: var(--ink3);
  line-height: 1.85;
}

.pdp-htu-video {
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  aspect-ratio: 9/16;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 16px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.pdp-htu-video-ph {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.pdp-htu-play {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(168, 104, 26, .12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  color: var(--gold);
  border: 1px solid rgba(168, 104, 26, .25);
  transition: all .28s;
}

.pdp-htu-video:hover .pdp-htu-play {
  background: var(--gold);
  color: var(--canvas);
  transform: scale(1.06);
}

.pdp-htu-video-label {
  font-family: var(--U);
  text-align: center;
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink4);
}

/* Key Ingredients */
.pdp-ing {
  padding: 80px;
  border-top: 1px solid var(--gold-line);
}

.pdp-ing-label {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.pdp-ing-subtitle {
  font-family: var(--D);
  font-size: 40px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 48px;
  line-height: 1.1;
}

.pdp-ing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 40px;
}

.pdp-ing-card {
  background: var(--canvas2);
  padding: 32px 28px;
}

.pdp-ing-origin {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}

.pdp-ing-name {
  font-family: var(--D);
  font-size: 22px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
}

.pdp-ing-latin {
  font-family: var(--S);
  font-size: 12px;
  font-style: italic;
  color: var(--ink4);
  margin-bottom: 14px;
}

.pdp-ing-desc {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.78;
}

.pdp-ing-benefit {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 12px;
  border-top: 1px solid rgba(168, 104, 26, .1);
  padding-top: 10px;
}

/* Clinical / Results bar */
.pdp-clinical {
  padding: 60px 80px;
  background: var(--ink);
  border-top: 1px solid var(--gold-line);
}

.pdp-clinical-label {
  font-family: var(--U);
  font-size: 15px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(232, 170, 56, .7);
  margin-bottom: 40px;
  text-align: center;
}

.pdp-clin-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255, 255, 255, .06);
}

.pdp-clin-stat {
  background: var(--ink);
  padding: 36px 28px;
  text-align: center;
}

.pdp-clin-num {
  font-family: var(--D);
  font-size: 56px;
  font-weight: 300;
  color: #E8AA38;
  line-height: 1;
  margin-bottom: 6px;
}

.pdp-clin-unit {
  font-family: var(--D);
  font-size: 22px;
  color: rgba(248, 242, 230, .4);
}

.pdp-clin-desc {
  font-family: var(--S);
  font-size: 18px;
  color: rgba(248, 242, 230, .6);
  line-height: 1.6;
  margin-top: 8px;
}

.pdp-clin-note {
  text-align: center;
  font-family: var(--S);
  font-size: 18px;
  color: rgba(248, 242, 230, .3);
  margin-top: 28px;
  font-style: italic;
}

/* Complete Your Ritual — mid-page full set upsell */
.pdp-complete {
  padding: 80px;
  background: var(--canvas2);
  border-top: 1px solid var(--gold-line);
}

.pdp-complete-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.pdp-complete-title {
  font-family: var(--D);
  font-size: 40px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 48px;
}

.pdp-complete-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

.pdp-cp-card {
  background: var(--canvas);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  cursor: pointer;
  transition: background .2s;
  border: 2px solid transparent;
}

.pdp-cp-card:hover {
  border-color: var(--gold);
}

.pdp-cp-card.current {
  border-color: var(--ink);
}

.pdp-cp-check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--ink);
  color: var(--canvas);
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: flex-end;
  margin-bottom: -10px;
  position: relative;
  z-index: 2;
}

.pdp-cp-img {
  width: 80px;
  height: 100px;
  overflow: hidden;
  margin-bottom: 16px;
}

.pdp-cp-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pdp-cp-name {
  font-family: var(--D);
  font-size: 16px;
  color: var(--ink);
  margin-bottom: 4px;
}

.pdp-cp-price {
  font-family: var(--D);
  font-size: 14px;
  color: var(--ink3);
  margin-bottom: 12px;
}

.pdp-cp-add {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  cursor: pointer;
}

.pdp-complete-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--gold-line);
}

.pdp-complete-total {
  font-family: var(--D);
  font-size: 32px;
  color: var(--ink);
}

.pdp-complete-save {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
}

/* Reviews */
.pdp-reviews {
  padding: 80px;
  border-top: 1px solid var(--gold-line);
}

.pdp-rev-header {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 60px;
  margin-bottom: 56px;
}

.pdp-rev-score {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.pdp-rev-big {
  font-family: var(--D);
  font-size: 88px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}

.pdp-rev-stars-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 8px 0;
}

.pdp-rev-star {
  color: #C8881E;
  font-size: 20px;
}

.pdp-rev-count {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  margin-top: 4px;
}

.pdp-rev-bars {
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
}

.pdp-rev-bar-row {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
}

.pdp-rev-bar-track {
  flex: 1;
  height: 6px;
  background: var(--canvas2);
  border-radius: 3px;
  overflow: hidden;
}

.pdp-rev-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #C8881E, #E8AA38);
  border-radius: 3px;
  transition: width .6s ease;
}

.pdp-rev-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  margin-bottom: 32px;
}

.pdp-rev-card {
  background: var(--canvas2);
  padding: 28px 24px;
}

.pdp-rev-card-stars {
  color: #C8881E;
  font-size: 12px;
  letter-spacing: 2px;
  margin-bottom: 10px;
}

.pdp-rev-card-title {
  font-family: var(--D);
  font-size: 17px;
  font-weight: 400;
  color: var(--ink);
  margin-bottom: 8px;
}

.pdp-rev-card-body {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.78;
  margin-bottom: 14px;
}

.pdp-rev-card-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pdp-rev-card-name {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
}

.pdp-rev-card-date {
  font-family: var(--S);
  font-size: 11px;
  color: var(--ink5);
}

.pdp-rev-card-badge {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .16em;
  text-transform: uppercase;
  background: rgba(168, 104, 26, .08);
  color: var(--gold);
  padding: 3px 8px;
}

.pdp-rev-load {
  display: flex;
  justify-content: center;
  margin-top: 32px;
}

.pdp-rev-load-btn {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink3);
  border: 1px solid var(--canvas-dk);
  padding: 14px 40px;
  cursor: pointer;
  transition: all .2s;
}

.pdp-rev-load-btn:hover {
  border-color: var(--ink);
  color: var(--ink);
}

/* You May Also Like */
.pdp-also {
  padding: 80px;
  border-top: 1px solid var(--gold-line);
  background: var(--canvas2);
}

.pdp-also-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.pdp-also-title {
  font-family: var(--D);
  font-size: 40px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 40px;
}

.pdp-also-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

.pdp-also-card {
  background: var(--canvas);
  cursor: pointer;
  transition: background .2s;
}

.pdp-also-card:hover {
  background: var(--canvas2);
}

.pdp-also-img {
  width: 100%;
  overflow: hidden;
}

.pdp-also-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s;
}

.pdp-also-card:hover .pdp-also-img img {
  transform: scale(1.03);
}

.pdp-also-body {
  padding: 20px 22px;
}

.pdp-also-name {
  font-family: var(--D);
  font-size: 20px;
  color: var(--ink);
  margin-bottom: 4px;
}

.pdp-also-price {
  font-family: var(--D);
  font-size: 16px;
  color: var(--ink3);
  margin-bottom: 12px;
}

.pdp-also-atc {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  cursor: pointer;
}

/* ═══════════════════════════════════════════════════════════════
   PRANA — MOBILE RESPONSIVE SYSTEM
   Breakpoints: 768px (tablet), 480px (mobile)
   Strategy: stack all grids, reduce padding, scale typography
═══════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {

  /* ── GLOBAL ── */
  body {
    font-size: 15px;
  }

  /* ── NAV ── */
  .nav-inner {
    padding: 0 20px;
    height: 56px;
  }

  .nav-logo {
    font-size: 18px;
    letter-spacing: .12em;
  }

  .nav-logo-sub {
    font-size: 7px;
    letter-spacing: .22em;
  }

  .nav-left,
  .nav-right {
    gap: 12px;
  }

  .nav-link {
    display: none;
  }

  .nav-link.always {
    display: flex;
  }

  .nav-cart-badge {
    width: 16px;
    height: 16px;
    font-size: 8px;
    top: -4px;
    right: -4px;
  }

  /* Hamburger — show on mobile */
  .nav-hamburger {
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    padding: 8px;
  }

  .nav-hamburger span {
    width: 22px;
    height: 2px;
    background: var(--ink);
    display: block;
    transition: all .2s;
  }

  /* Mobile nav dropdown */
  .nav-mobile-menu {
    display: none;
    position: fixed;
    top: 56px;
    left: 0;
    right: 0;
    background: var(--canvas);
    border-bottom: 1px solid var(--gold-line);
    z-index: 999;
    padding: 20px;
    flex-direction: column;
    gap: 0;
  }

  .nav-mobile-menu.open {
    display: flex;
  }

  .nav-mobile-link {
    font-family: var(--U);
    font-size: 11px;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--ink);
    padding: 14px 0;
    border-bottom: 1px solid var(--canvas-dk);
    cursor: pointer;
  }


  /* ── HOMEPAGE HERO ── */
  .hero {
    min-height: 100svh;
  }

  .hero-content {
    padding: 100px 24px 60px;
  }

  .hero-eyebrow {
    font-size: 9px;
    letter-spacing: .24em;
  }

  .hero-h1 {
    font-size: 52px;
    line-height: 1.0;
  }

  .hero-sub {
    font-size: 15px;
    max-width: 100%;
  }

  .hero-cta-row {
    flex-direction: column;
    gap: 10px;
  }

  .hero-cta-row .btn-gold,
  .hero-cta-row .btn-ghost {
    width: 100%;
    text-align: center;
  }

  /* ── PROOF BAR ── */



  /* ── MARQUEE ── */
  .marquee-track {
    animation-duration: 20s;
  }

  /* ── PRODUCT CAROUSEL ── */
  .pcaro-track {
    gap: 12px;
  }

  .pcaro-card {
    min-width: 220px;
  }

  .pcaro-img {
    height: 260px;
  }

  .pcaro-name {
    font-size: 17px;
  }

  .pcaro-price {
    font-size: 15px;
  }

  /* ── HOMEPAGE RITUAL TABS ── */
  .ritual {
    padding: 60px 20px;
  }

  .rtabs {
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
    flex-wrap: nowrap;
    scrollbar-width: none;
  }

  .rtabs::-webkit-scrollbar {
    display: none;
  }

  .rtab {
    min-width: auto;
    padding: 14px 16px;
    font-size: 9px;
    white-space: nowrap;
  }

  .rc.on {
    grid-template-columns: 1fr !important;
    gap: 40px;
  }

  .rstep {
    grid-template-columns: 40px 1fr;
  }

  .rn {
    font-size: 32px;
  }

  .rname {
    font-size: 17px;
  }

  .rdesc {
    font-size: 14px;
  }

  .rvis {
    padding: 28px 24px;
  }

  .rvis-title {
    font-size: 26px;
  }

  .rvis-products {
    gap: 10px;
  }

  .rvis-img {
    width: 72px !important;
    height: 90px !important;
  }

  .rvis-cta-stack {
    flex-direction: column;
  }

  .rvis-btn-primary,
  .rvis-btn-secondary {
    width: 100%;
    text-align: center;
  }

  /* ── WEEKLY RITUAL FULL WIDTH ── */
  #t-wk>div:first-child {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }

  #t-wk .rvis-img {
    width: 80px !important;
    height: 104px !important;
  }

  /* ── SAFFRON SPOTLIGHT ── */
  .saffron-spotlight {
    grid-template-columns: 1fr !important;
  }

  .saffron-spotlight>div:first-child {
    padding: 48px 24px;
  }

  .saffron-spotlight .spotlight-img {
    height: 340px;
  }

  /* ── FOUNDER STRIP ── */
  .founder-strip,
  .founder-section {
    grid-template-columns: 1fr !important;
  }

  .founder-img {
    height: 320px;
    order: -1;
  }

  .founder-copy {
    padding: 40px 24px;
  }

  /* ── SETS GRID ── */
  .sets-grid {
    grid-template-columns: 1fr !important;
    gap: 2px;
  }
  
  .set-card {
    padding: 28px 24px;
  }

  .set-card.signature {
    grid-template-columns: 1fr !important;
  }

  .sig-left {
    padding: 40px 24px;
  }

  .sig-right {
    display: none;
  }

  /* ── TESTIMONIALS ── */
  .testi-grid,
  .reviews-grid {
    grid-template-columns: 1fr !important;
    gap: 2px;
  }

  /* ── BENEFITS BAR ── */
  .benefits-bar {
    padding: 32px 20px;
    grid-template-columns: 1fr 1fr !important;
    gap: 20px 16px;
  }

  .bene {
    padding: 20px 12px;
  }

  .bene-title {
    font-size: 11px;
  }
  .section.hero {
    display: none;
  }
  .bene-desc {
    font-size: 11px;
  }

  /* ── RITUAL SETS SECTION ── */
  .ritual-sets {
    padding: 60px 20px;
  }

  /* .ritual-steps { grid-template-columns:1fr !important; } */

  /* ── PRANA BOOK ── */
  .prana-book {
    grid-template-columns: 1fr !important;
    min-height: auto;
  }

  .prana-book-img {
    height: 280px;
    order: -1;
  }

  .prana-book-copy {
    padding: 48px 24px;
  }

  .prana-book-copy h2 {
    font-size: 40px;
  }

  /* ── EMAIL / SPA CTA ── */
  .email-section,
  .spa-cta {
    padding: 60px 24px;
  }

  .email-form {
    flex-direction: column;
    gap: 10px;
  }

  .email-form input,
  .email-form button {
    width: 100%;
  }

  .two-cta {
    grid-template-columns: 1fr !important;
    gap: 2px;
  }

  .two-cta>div {
    padding: 48px 24px;
    min-height: 200px;
  }



  /* ── SHOP PAGE ── */
  .shop-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
    flex-wrap: nowrap;
    padding: 0 20px;
    scrollbar-width: none;
  }

  .shop-tabs::-webkit-scrollbar {
    display: none;
  }

  .shop-tab {
    white-space: nowrap;
    font-size: 9px;
    padding: 12px 14px;
  }

  .shop-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 2px;
    padding: 0 20px;
  }

  .shop-card-img {
    height: 200px;
  }

  .shop-card-name {
    font-size: 15px;
  }

  .shop-card-price {
    font-size: 14px;
  }

  /* ── PRANA SUTRAS SHOP TAB ── */
  .sets-shop-grid {
    grid-template-columns: 1fr !important;
    gap: 2px;
    padding: 0 20px;
  }

  .rvis-badge {
    font-size: 8px;
  }

  /* ── PDP ── */
  .pdp-tags {
    padding: 0px 20px 0;
    gap: 6px;
  }

  .pdp-tag {
    font-size: 8px;
    padding: 4px 10px;
  }

  .pdp-breadcrumb {
    padding: 10px 20px 0;
    font-size: 9px;
  }

  .pdp-hero {
    grid-template-columns: 1fr !important;
    min-height: auto;
  }

  .pdp-gallery {
    position: static;
  }

  .pdp-main-img {
    height: 380px;
  }

  .pdp-thumbs {
    padding: 10px 16px;
  }

  .pdp-thumb {
    width: 56px;
    height: 68px;
  }

  .pdp-info {
    padding: 28px 20px 48px;
  }

  .pdp-name {
    font-size: 34px;
  }

  .pdp-tagline {
    font-size: 15px;
  }

  .pdp-size {
    font-size: 10px;
    margin-bottom: 18px;
    padding-bottom: 18px;
  }

  .pdp-ritual-cta {
    padding: 14px 16px;
  }

  .sub-toggle {
    margin-bottom: 16px;
  }

  .sub-opt {
    padding: 12px 12px;
  }

  .sub-opt-price {
    font-size: 19px;
  }

  .pdp-qty-row {
    gap: 8px;
  }



  .pdp-trust {
    flex-wrap: wrap;
  }

  .pdp-trust-item {
    width: 50%;
    flex: none;
    border-bottom: 1px solid var(--canvas-dk);
  }

  .pdp-trust-item:nth-child(odd) {
    border-right: 1px solid var(--canvas-dk);
  }

  .pdp-trust-label {
    font-size: 7px;
  }

  /* PDP How To Use */
  .pdp-htu {
    padding: 48px 20px;
  }

  .pdp-htu-headline {
    font-size: 30px;
    margin-bottom: 36px;
  }

  .pdp-htu-grid {
    grid-template-columns: 1fr !important;
    gap: 36px;
  }

  .pdp-htu-video {
    aspect-ratio: 16/9;
    max-height: 240px;
  }

  .pdp-htu-num {
    font-size: 36px;
  }

  .pdp-htu-step {
    grid-template-columns: 44px 1fr;
    padding: 22px 0;
  }

  .pdp-htu-step-title {
    font-size: 18px;
  }

  .pdp-htu-step-text {
    font-size: 14px;
  }

  /* PDP Ingredients */
  .pdp-ing {
    padding: 48px 20px;
  }

  .pdp-ing-subtitle {
    font-size: 30px;
  }

  .pdp-ing-grid {
    grid-template-columns: 1fr !important;
    gap: 2px;
  }

  .pdp-ing-card {
    padding: 24px 20px;
  }

  .pdp-ing-name {
    font-size: 19px;
  }

  /* PDP Clinical */
  .pdp-clinical {
    padding: 40px 20px;
  }

  .pdp-clin-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 1px;
  }

  .pdp-clin-num {
    font-size: 40px;
  }

  .pdp-clin-desc {
    font-size: 12px;
  }

  /* PDP Complete Ritual */
  .pdp-complete {
    padding: 48px 20px;
  }

  .pdp-complete-title {
    font-size: 30px;
  }

  .pdp-complete-grid {
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 2px;
  }

  .pdp-cp-card {
    padding: 18px 12px;
  }

  .pdp-cp-img {
    width: 60px;
    height: 76px;
  }

  .pdp-cp-name {
    font-size: 13px;
  }

  .pdp-complete-footer {
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
  }

  .pdp-complete-footer button {
    width: 100%;
  }

  .pdp-complete-total {
    font-size: 24px;
  }

  /* PDP Reviews */
  .pdp-reviews {
    padding: 48px 20px;
  }

  .pdp-rev-header {
    grid-template-columns: 1fr !important;
    gap: 28px;
  }

  .pdp-rev-big {
    font-size: 64px;
  }

  .pdp-rev-grid {
    grid-template-columns: 1fr !important;
    gap: 2px;
  }

  .pdp-rev-card {
    padding: 22px 18px;
  }

  /* PDP Also Like */
  .pdp-also {
    padding: 48px 20px;
  }

  .pdp-also-title {
    font-size: 30px;
  }

  .pdp-also-grid {
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 2px;
  }

  /* .pdp-also-img { height:160px; } */
  .pdp-also-name {
    font-size: 14px;
  }

  .pdp-also-price {
    font-size: 13px;
    margin-bottom: 8px;
  }

  /* ── ABOUT PAGE ── */
  .about-hero {
    min-height: 60svh;
    padding: 80px 24px 48px;
  }

  .about-hero h1 {
    font-size: 48px;
  }

  .about-origin {
    grid-template-columns: 1fr !important;
    padding: 48px 24px;
    gap: 32px;
  }

  .about-founder {
    grid-template-columns: 1fr !important;
    padding: 48px 24px;
    gap: 32px;
  }

  .about-founder-img {
    height: 320px;
    order: -1;
  }

  .about-values {
    grid-template-columns: 1fr 1fr !important;
    padding: 48px 24px;
    gap: 20px;
  }

  .about-ingredients {
    padding: 48px 24px;
  }

  .about-ing-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 16px;
  }

  .about-timeline {
    padding: 48px 24px;
  }

  .about-tl-item {
    grid-template-columns: 60px 1fr !important;
  }

  .about-press {
    padding: 48px 24px;
  }

  .about-press-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 12px;
  }

  /* ── SPA PAGE ── */
  .spa-hero {
    min-height: 60svh;
    padding: 80px 24px 48px;
  }

  .spa-hero h1 {
    font-size: 44px;
  }

  .spa-pillars {
    grid-template-columns: 1fr 1fr !important;
    padding: 48px 24px;
    gap: 20px;
  }

  .spa-process {
    padding: 48px 24px;
  }

  .spa-tiers {
    grid-template-columns: 1fr !important;
    padding: 48px 24px;
    gap: 16px;
  }

  .spa-form {
    padding: 48px 24px;
  }

  .spa-form-grid {
    grid-template-columns: 1fr !important;
    gap: 12px;
  }

  /* ── PRANA SUTRAS DETAIL PAGE ── */
  .sutra-hero {
    min-height: 40svh;
    padding: 80px 24px 40px;
  }

  .sutra-nav {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding: 0 20px;
    flex-wrap: nowrap;
    scrollbar-width: none;
  }

  .sutra-nav::-webkit-scrollbar {
    display: none;
  }

  .sutra-nav-item {
    white-space: nowrap;
    font-size: 9px;
    padding: 10px 12px;
  }

  .sutra-purchase {
    grid-template-columns: 1fr !important;
    padding: 40px 24px;
    gap: 32px;
  }

  .sutra-step {
    grid-template-columns: 48px 1fr !important;
    gap: 16px;
  }

  /* ── BLOG PAGES ── */
  .blog-hero {
    padding: 80px 24px 40px;
    min-height: 40svh;
  }

  .blog-hero h1 {
    font-size: 36px;
  }

  .blog-content {
    padding: 40px 24px;
    max-width: 100%;
  }

  .blog-grid {
    grid-template-columns: 1fr !important;
    gap: 24px;
    padding: 0 24px;
  }

  /* ── CART DRAWER ── */
  .cart-drawer {
    width: 100% !important;
  }

  /* ── SECTION HEADINGS ── */
  .sec-sub {
    font-size: 15px !important;
    padding: 0 20px;
  }

  .rule {
    margin: 0 20px;
  }

  /* ── AI SCAN ── */
  .scan-section {
    padding: 60px 24px;
    grid-template-columns: 1fr !important;
  }

  .scan-phone {
    display: none;
  }

  .scan-copy {
    padding: 0;
  }

  /* ── PRANA BOOK SECTION ── */
  .book-section {
    grid-template-columns: 1fr !important;
  }

  .book-img-panel {
    height: 260px;
  }

  .book-copy {
    padding: 48px 24px;
  }

  .book-copy h2 {
    font-size: 36px;
  }

  /* ── VIDEO ZONE ── */
  .video-zone {
    padding: 60px 20px;
  }

  .video-placeholder {
    height: 220px;
  }

  /* Inline grids that need mobile override — targeted by parent ID */
  #page-home [style*="grid-template-columns:1fr 1fr"],
  #page-home [style*="grid-template-columns:repeat(2"],
  #page-home [style*="grid-template-columns:repeat(3"],
  #page-home [style*="grid-template-columns:repeat(4"],
  #page-about [style*="grid-template-columns:1fr 1fr"],
  #page-about [style*="grid-template-columns:repeat("],
  #page-spa [style*="grid-template-columns:1fr 1fr"],
  #page-spa [style*="grid-template-columns:repeat("],
  #page-pdp [style*="grid-template-columns:1fr 1fr"],
  #page-sutra [style*="grid-template-columns:1fr 1fr"],
  #page-sutra [style*="grid-template-columns:repeat("] {
    grid-template-columns: 1fr !important;
  }

  /* Exception: keep 2-col for small card grids */
  .pdp-complete-grid,
  .pdp-clin-grid,
  .pdp-also-grid,
  .about-values,
  .about-ing-grid,
  .about-press-grid,
  .spa-pillars,
  .benefits-bar {
    grid-template-columns: 1fr 1fr !important;
  }

  /* ── INLINE PADDING OVERRIDES ── */
  [style*="padding:80px"],
  [style*="padding: 80px"] {
    padding: 48px 20px !important;
  }

  [style*="padding:100px"],
  [style*="padding: 100px"] {
    padding: 60px 20px !important;
  }

  [style*="padding:60px 80px"],
  [style*="padding:64px 80px"],
  [style*="padding:72px 80px"],
  [style*="padding:88px 80px"] {
    padding: 40px 20px !important;
  }

  [style*="padding:56px 80px"],
  [style*="padding:48px 80px"],
  [style*="padding:40px 80px"] {
    padding: 32px 20px !important;
  }

  /* ── MAX-WIDTH TEXT CONTAINERS ── */
  [style*="max-width:600px"],
  [style*="max-width:700px"],
  [style*="max-width:800px"],
  [style*="max-width:900px"] {
    max-width: 100% !important;
    padding-left: 20px;
    padding-right: 20px;
  }
}

@media screen and (max-width:767px) {
  .pcaro-card {
    background: #e3c39f;
    border-radius: 8px;
    flex: 0 0 calc(100% - 9px);
  }

  .pcaro-card .pcaro-body {
    border: none;
  }
}


/* ── SMOOTH SCROLLING + TOUCH ── */
@media (max-width: 768px) {
  html {
    scroll-behavior: smooth;
    -webkit-tap-highlight-color: transparent;
  }

  button,
  .btn-gold,
  .btn-ghost,
  .rvis-btn-primary {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  /* Prevent horizontal overflow */
  .page {
    overflow-x: hidden;
  }

  img {
    max-width: 100%;
    height: auto;
  }
}


.mob-nav-link {
  display: block;
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink);
  padding: 14px 24px;
  border-bottom: 1px solid var(--canvas-dk);
  cursor: pointer;
  text-decoration: none;
  transition: background .15s;
}

.mob-nav-link:hover {
  background: var(--canvas2);
}

@media(max-width:768px) {
  #navHamburger {
    display: flex !important;
  }

  .nav-scan-btn {
    display: none;
  }

  header .nav-left {
    display: none;
  }

  header .nav-right nav {
    display: none;
  }

  header nav ul li:not(.cart-li) a:not(.always) {}


  .logo {
    font-size: 16px;
  }

  .logo-main {
    font-size: 20px;
    letter-spacing: .14em;
  }

  .logo-sub {
    font-size: 7px;
    letter-spacing: .22em;
  }
}


/* ═══════════════════════════════════════════════════════
   NEW HOMEPAGE SECTIONS CSS
   Press · Before/After · Ingredient Story · Testimonials
   UGC Strip · Quiz · Sticky ATC · Hero fixes
═══════════════════════════════════════════════════════ */

/* ── HERO FIXES ── */
/* Single dominant primary CTA */
.hero-actions .btn-ink {
    background: var(--gold);
    color: var(--canvas);
    padding: 12px 36px;
    font-family: var(--U);
    font-size: 12px;
    letter-spacing: .22em;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    border-radius: 5px;
    transition: background .22s;
}

.hero-actions .btn-ink:hover {
  background: var(--heading-color);
}

/* Ghost CTA demoted to text link style */
.hero-actions .btn-ghost-sm {
  background: none;
  border: none;
  padding: 0;
  font-family: var(--U);
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink3);
  cursor: pointer;
  text-decoration: underline;
  text-decoration-color: rgba(168, 104, 26, .3);
  text-underline-offset: 4px;
}

/* Hero product visible on mobile — override */
.hero-product-mobile {
  display: none;
}

/* ── PRESS BAR ── */
.hp-press {
  background: var(--ink);
  padding: 20px 80px;
  display: flex;
  align-items: center;
  gap: 32px;
  justify-content: center;
  flex-wrap: wrap;
  border-bottom: 1px solid rgba(248, 242, 230, .04);
}

.hp-press-label {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .5);
  white-space: nowrap;
  flex-shrink: 0;
}

.hp-press-logos {
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: nowrap;
}

.hp-press-item {
  padding: 0 20px;
}

.hp-press-name {
  font-family: var(--D);
  font-size: 18px;
  font-weight: 300;
  font-style: italic;
  color: rgba(248, 242, 230, .45);
  letter-spacing: .04em;
  white-space: nowrap;
  transition: color .2s;
  cursor: default;
}

.hp-press-item:hover .hp-press-name {
  color: rgba(248, 242, 230, .75);
}

.hp-press-sep {
  color: rgba(200, 146, 26, .25);
  font-size: 10px;
}

.hp-press-quote {
  font-family: var(--S);
  font-size: 12px;
  color: rgba(248, 242, 230, .35);
  font-style: italic;
  white-space: nowrap;
  padding-left: 20px;
  border-left: 1px solid rgba(200, 146, 26, .15);
  flex-shrink: 0;
  display: none;
}

@media(min-width:1100px) {
  .hp-press-quote {
    display: block;
  }
}

/* ── BEFORE / AFTER ── */
.hp-ba {
  background: var(--canvas);
  padding: 88px 80px;
}

.hp-ba-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
  margin-bottom: 1px;
}

.hp-ba-card {
  background: #ede5d1;
  padding: 0;
  overflow: hidden;
}

.hp-ba-imgs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  position: relative;
}

.hp-ba-side {
  position: relative;
}

.hp-ba-img {
  height: 280px;
  position: relative;
  overflow: hidden;
}

.hp-ba-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, var(--canvas-dk) 0%, var(--canvas) 100%);
}

.hp-ba-placeholder-after {
  background: linear-gradient(180deg, rgba(200, 146, 26, .08) 0%, rgba(168, 104, 26, .04) 100%);
}

.hp-ba-ph-inner {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink4);
}

.hp-ba-label-tag {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  padding: 4px 12px;
  white-space: nowrap;
}

.hp-ba-label-after {
  background: var(--gold);
  color: var(--canvas);
}

.hp-ba-divider-line {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 2px;
  background: var(--canvas);
  z-index: 3;
  transform: translateX(-50%);
}

.hp-ba-info {
  padding: 24px 28px 28px;
}

.hp-ba-name {
  font-family: var(--U);
  font-size: 13px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink3);
  margin-bottom: 4px;
}

.hp-ba-product {
  font-family: var(--S);
  font-size: 15px;
  color: var(--gold);
  margin-bottom: 10px;
  font-style: italic;
}

.hp-ba-quote {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.75;
  font-style: italic;
}

.hp-ba-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--ink);
}

.hp-ba-stat {
  padding: 32px 28px;
  text-align: center;
}

.hp-ba-stat-num {
  font-family: var(--D);
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 8px;
}

.hp-ba-stat-lbl {
  font-family: var(--S);
  font-size: 13px;
  color: rgba(248, 242, 230, .55);
  line-height: 1.5;
}

.hp-ba-stat-sep {
  width: 1px;
  background: rgba(248, 242, 230, .06);
}

/* ── INGREDIENT STORY ── */
.hp-ing-story {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 560px;
  background: var(--jungle);
}

.hp-ing-left {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 2px;
  background: var(--canvas-dk);
}

.hp-ing-img-wrap {
  position: relative;
  overflow: hidden;
}

.hp-ing-img-ph {
  height: 100%;
  min-height: 300px;
  background: linear-gradient(135deg, rgba(200, 146, 26, .12), rgba(168, 104, 26, .06));
  display: flex;
  align-items: flex-end;
  padding: 24px;
}

.hp-ing-img-ph-sm {
  min-height: 180px;
}

.hp-ing-img-label {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(248, 242, 230, .5);
  line-height: 1.7;
}

.hp-ing-img-label span {
  color: rgba(248, 242, 230, .3);
}

.hp-ing-right {
  padding: 72px 76px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.hp-ing-eyebrow {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 18px;
}

.hp-ing-h2 {
  font-family: var(--D);
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 300;
  color: var(--canvas);
  line-height: 1.05;
  margin-bottom: 24px;
}

.hp-ing-body {
  font-family: var(--S);
  font-size: 16px;
  color: rgba(248, 242, 230, .65);
  line-height: 1.85;
  margin-bottom: 32px;
}

.hp-ing-facts {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.hp-ing-fact {
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.hp-ing-fact-ico {
  font-size: 18px;
  color: var(--gold);
  flex-shrink: 0;
  margin-top: 2px;
}

.hp-ing-fact-title {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--canvas);
  margin-bottom: 4px;
}

.hp-ing-fact-desc {
  font-family: var(--S);
  font-size: 13px;
  color: rgba(248, 242, 230, .5);
  line-height: 1.65;
}

/* ── ENHANCED TESTIMONIALS ── */
.hp-testi {
  background: var(--canvas);
  padding: 88px 80px;
}

.hp-testi-agg {
  display: flex;
  align-items: center;
  gap: 48px;
  padding: 32px 40px;
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  margin-bottom: 48px;
  flex-wrap: wrap;
}

.hp-testi-big-star {
  font-family: var(--D);
  font-size: 72px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
}

.hp-testi-bars {
  flex: 1;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.hp-tbar-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.hp-tbar-lbl {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .1em;
  color: var(--ink4);
  width: 18px;
  flex-shrink: 0;
}

.hp-tbar-track {
  flex: 1;
  height: 6px;
  background: var(--canvas-dk);
  border-radius: 0;
}

.hp-tbar-fill {
  height: 100%;
  background: var(--gold);
  transition: width .8s ease;
}

.hp-tbar-pct {
  font-family: var(--U);
  font-size: 9px;
  color: var(--ink4);
  width: 28px;
  text-align: right;
  flex-shrink: 0;
}

.hp-testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--canvas-dk);
}

.hp-tc {
  background: var(--canvas2);
  padding: 34px 30px;
  transition: background .25s;
}

.hp-tc:hover {
  background: var(--canvas);
}

.hp-tc-top {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.hp-tc-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .08em;
  color: #fff;
  flex-shrink: 0;
}

.hp-tc-name {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 2px;
}

.hp-tc-meta {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink4);
}

.hp-tc-stars {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--gold);
  margin-left: auto;
  flex-shrink: 0;
}

.hp-tc-product {
  font-family: var(--S);
  font-size: 12px;
  color: var(--gold);
  font-style: italic;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--gold-line);
}

.hp-tc-text {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink2);
  line-height: 1.8;
  font-style: italic;
  margin-bottom: 14px;
}

.hp-tc-verified {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink5);
}

/* ── UGC STRIP ── */
.hp-ugc {
  background: var(--canvas2);
  padding: 72px 80px;
}

.hp-ugc-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 36px;
  flex-wrap: wrap;
  gap: 16px;
}

.hp-ugc-follow {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(168, 104, 26, .3);
  transition: border-color .2s;
}

.hp-ugc-follow:hover {
  border-color: var(--gold);
}

.hp-ugc-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 3px;
}

.hp-ugc-item {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 1;
}

.hp-ugc-ph {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .4s;
}

.hp-ugc-item:hover .hp-ugc-ph {
  transform: scale(1.04);
}

.hp-ugc-ph-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.hp-ugc-icon {
  font-size: 28px;
  color: rgba(168, 104, 26, .3);
}

.hp-ugc-overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 10px 12px;
  background: linear-gradient(transparent, rgba(26, 18, 6, .7));
  opacity: 0;
  transition: opacity .25s;
}

.hp-ugc-item:hover .hp-ugc-overlay {
  opacity: 1;
}

.hp-ugc-handle {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .12em;
  color: rgba(248, 242, 230, .9);
}

/* ── QUIZ ── */
.hp-quiz {
  background: var(--ink);
  padding: 88px 80px;
}

.hp-quiz-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}

.hp-quiz-eyebrow {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
}

.hp-quiz-h2 {
  font-family: var(--D);
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 300;
  color: var(--canvas);
  line-height: 1.05;
  margin-bottom: 18px;
}

.hp-quiz-sub {
  font-family: var(--S);
  font-size: 16px;
  color: rgba(248, 242, 230, .6);
  line-height: 1.85;
  margin-bottom: 24px;
}

.hp-quiz-trust {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.hp-quiz-trust span {
  font-family: var(--S);
  font-size: 13px;
  color: rgba(248, 242, 230, .4);
}

.hp-quiz-right {
  background: rgba(248, 242, 230, .04);
  border: 1px solid rgba(200, 146, 26, .15);
  padding: 40px;
}

.hp-quiz-step-label {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .5);
  margin-bottom: 16px;
}

.hp-quiz-q {
  font-family: var(--D);
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 300;
  color: var(--canvas);
  line-height: 1.2;
  margin-bottom: 24px;
}

.hp-quiz-opts {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.hp-quiz-opt {
  background: transparent;
  border: 1px solid rgba(248, 242, 230, .12);
  color: rgba(248, 242, 230, .75);
  font-family: var(--S);
  font-size: 14px;
  padding: 14px 18px;
  text-align: left;
  cursor: pointer;
  transition: all .2s;
}

.hp-quiz-opt:hover,
.hp-quiz-opt.selected {
  background: rgba(200, 146, 26, .12);
  border-color: rgba(200, 146, 26, .4);
  color: var(--canvas);
}

.hp-quiz-result-badge {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
}

.hp-quiz-result-name {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 300;
  color: var(--canvas);
  margin-bottom: 8px;
}

.hp-quiz-result-desc {
  font-family: var(--S);
  font-size: 14px;
  color: rgba(248, 242, 230, .6);
  line-height: 1.7;
  margin-bottom: 20px;
}

.hp-quiz-result-products {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.hp-quiz-result-product-tag {
    font-size: 9px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #fff;
    background: rgba(248, 242, 230, .06);
    padding: 6px 12px;
    border: 1px solid rgba(248, 242, 230, .1);
}

.hp-quiz-result-price {
  font-family: var(--D);
  font-size: 32px;
  color: var(--gold);
  margin-bottom: 6px;
}

.hp-quiz-result-save {
  font-family: var(--S);
  font-size: 13px;
  color: rgba(200, 146, 26, .6);
  margin-bottom: 20px;
}

.hp-quiz-result-cta {
  width: 100%;
  background: var(--gold);
  color: var(--canvas);
  border: none;
  padding: 16px 24px;
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s;
  margin-bottom: 10px;
}

.hp-quiz-result-cta:hover {
  background: #C8881E;
}
.hp-quiz-restart {
    width: 100%;
    background: transparent;
    border: 1px solid rgb(248 242 230);
    color: white;
    font-family: var(--U);
    font-size: 17px;
    padding: 8px;
    cursor: pointer;
    transition: all .2s;
    border-radius: 5px;
}


/* ── STICKY ATC BAR ── */
.hp-sticky-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--ink);
  border-top: 1px solid rgba(200, 146, 26, .2);
  z-index: 990;
  padding: 12px 40px;
  box-shadow: 0 -8px 40px rgba(26, 18, 6, .3);
  animation: slideUp .3s ease;
}

@keyframes slideUp {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

.hp-sticky-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1400px;
  margin: 0 auto;
  gap: 20px;
}

.hp-sticky-left {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 1;
  min-width: 0;
}

.hp-sticky-img {
  width: 44px;
  height: 56px;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid rgba(200, 146, 26, .2);
  background: #f8f2e6;
}

.hp-sticky-name {
  font-family: var(--U);
  font-size: 13px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--canvas);
  overflow: hidden;
  text-overflow: ellipsis;
}

.hp-sticky-sub {
  font-family: var(--S);
  font-size: 14px;
  color: rgba(248, 242, 230, .4);
  margin-top: 2px;
  white-space: nowrap;
}

.hp-sticky-right {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}

.hp-sticky-price {
  font-family: var(--D);
  font-size: 24px;
  font-weight: 300;
  color: var(--gold);
}

.hp-sticky-close {
  background: none;
  border: none;
  color: rgba(248, 242, 230, .3);
  font-size: 16px;
  cursor: pointer;
  padding: 8px;
  transition: color .2s;
  flex-shrink: 0;
}

.hp-sticky-close:hover {
  color: var(--canvas);
}

/* ── URGENCY SIGNALS ── */
.hp-urgency {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  opacity: 0;
  animation: fadeUp .6s ease 1.5s forwards;
}

.hp-urgency-dot {
  width: 6px;
  height: 6px;
  background: #4CAF50;
  border-radius: 50%;
  animation: pulse-green 2s ease infinite;
}

@keyframes pulse-green {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: .4;
  }
}

.hp-urgency-txt {
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink3);
}

.hp-urgency-txt strong {
  color: var(--ink);
}

/* ── FOUNDER STORY ENHANCEMENT ── */
.f-moment {
  background: rgba(200, 146, 26, .06);
  border-left: 2px solid var(--gold);
  padding: 16px 20px;
  margin-bottom: 20px;
}

.f-moment-label {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.f-moment-text {
  font-family: var(--S);
  font-size: 14px;
  color: rgba(248, 242, 230, .75);
  line-height: 1.75;
  font-style: italic;
}

/* ── BENEFITS BAR UPGRADE (differentiators) ── */
.bene-upgrade {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  background: var(--ink);
}

.benu {
  padding: 28px 30px;
  border-right: 1px solid rgba(248, 242, 230, .04);
  transition: background .2s;
}

.benu:hover {
  background: rgba(248, 242, 230, .02);
}

.benu-num {
  font-family: var(--D);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 300;
  color: var(--gold);
  line-height: 1;
  margin-bottom: 6px;
}

.benu-title {
  font-family: var(--U);
  font-size: 13px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--canvas);
  margin-bottom: 6px;
}

.benu-desc {
  font-family: var(--S);
  font-size: 15px;
  color: rgba(248, 242, 230, .45);
  line-height: 1.6;
}

/* ── EMAIL CAPTURE UPGRADE ── */
.hp-email-upgrade {
  background: var(--canvas2);
  padding: 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

.hp-email-left h2 {
  font-family: var(--D);
  font-size: clamp(32px, 3.5vw, 48px);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.1;
  margin-bottom: 14px;
}

.hp-email-offer {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(168, 104, 26, .08);
  border: 1px solid var(--gold-line);
  padding: 10px 18px;
  margin-bottom: 20px;
}

.hp-email-offer-txt {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold);
}

.hp-email-sub {
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink3);
  line-height: 1.75;
}

.hp-email-right form,
.hp-email-right {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.hp-email-field {
  border: 1px solid var(--canvas-dk);
  background: var(--canvas);
  padding: 15px 20px;
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink);
  outline: none;
  transition: border-color .2s;
  width: 100%;
  box-sizing: border-box;
}

.hp-email-field:focus {
  border-color: var(--gold);
}

.hp-email-submit {
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 16px 24px;
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s;
}

.hp-email-submit:hover {
  background: var(--gold);
}

.hp-email-note {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink5);
}

.hp-email-perks {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}

.hp-email-perk {
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.hp-email-perk-check {
  color: var(--gold);
  flex-shrink: 0;
}

/* ═══ MOBILE ══════════════════════════════════════════ */
@media(max-width:768px) {

  /* Hero product image on mobile — show compact above fold */
  .hero-product-mobile {
    display: flex;
    justify-content: center;
    padding: 20px 0 0;
  }

  .hero-product-mobile img {
    width: 120px;
  }

  /* Press bar */
  .hp-press {
    padding: 16px 20px;
    gap: 16px;
    flex-direction: column;
    text-align: center;
  }

  .hp-press-logos {
    flex-wrap: wrap;
    justify-content: center;
    gap: 0;
  }

  .hp-press-item {
    padding: 0 12px;
  }

  .hp-press-name {
    font-size: 15px;
  }

  .hp-press-sep {
    display: none;
  }

  /* Before/After */
  .hp-ba {
    padding: 48px 20px;
  }

  .hp-ba-grid {
    grid-template-columns: 1fr;
  }

  .hp-ba-img {
    height: 200px;
  }

  .hp-ba-stats {
    grid-template-columns: 1fr 1fr;
  }

  .hp-ba-stat-sep {
    display: none;
  }

  .hp-ba-stat {
    padding: 20px 16px;
  }

  .hp-ba-stat-num {
    font-size: 32px;
  }

  /* Ingredient story */
  .hp-ing-story {
    grid-template-columns: 1fr;
  }

  .hp-ing-left {
    grid-template-rows: auto auto;
  }

  .hp-ing-img-ph {
    min-height: 200px;
  }

  .hp-ing-img-ph-sm {
    min-height: 140px;
  }

  .hp-ing-right {
    padding: 48px 24px;
  }

  .hp-ing-h2 {
    font-size: 36px;
  }

  /* Testimonials */
  .hp-testi {
    padding: 48px 20px;
  }

  .hp-testi-agg {
    flex-direction: column;
    gap: 20px;
    padding: 24px 20px;
  }

  .hp-testi-big-star {
    font-size: 56px;
  }

  .hp-testi-grid {
    grid-template-columns: 1fr;
  }

  .hp-tc {
    padding: 24px 20px;
  }

  /* UGC */
  .hp-ugc {
    padding: 48px 20px;
  }

  .hp-ugc-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .hp-ugc-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Quiz */
  .hp-quiz {
    padding: 48px 20px;
  }

  .hp-quiz-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .hp-quiz-h2 {
    font-size: 32px;
  }

  .hp-quiz-right {
    padding: 24px 20px;
  }

  .hp-quiz-q {
    font-size: 20px;
  }

  /* Sticky ATC */
  .hp-sticky-bar {
    padding: 10px 16px;
  }

  .hp-sticky-img {
    display: none;
  }

  .hp-sticky-name {
    font-size: 10px;
  }

  .hp-sticky-sub {
    display: none;
  }

  .hp-sticky-price {
    font-size: 18px;
  }

  .hp-sticky-atc {
    padding: 10px 18px;
    font-size: 10px;
  }

  /* Benefits upgrade */
  .bene-upgrade {
    grid-template-columns: 1fr 1fr;
  }

  .benu {
    border-right: none;
    border-bottom: 1px solid rgba(248, 242, 230, .04);
    padding: 24px 20px;
  }

  /* Email upgrade */
  .hp-email-upgrade {
    grid-template-columns: 1fr;
    padding: 48px 24px;
    gap: 32px;
  }

  .hp-email-left h2 {
    font-size: 32px;
  }

  /* Founder */
  .f-moment {
    margin-bottom: 16px;
  }
}

@media(max-width:480px) {
  .hp-ba-stats {
    grid-template-columns: 1fr;
  }

  .hp-ugc-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .hp-testi-agg {
    gap: 16px;
  }
}



/* Brand video */
.hp-video-section {
  background: var(--ink);
  position: relative;
  overflow: hidden;
}



/* ── PDP REVIEW CARDS ── */
.pdp-rev-bars {
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
}

.pdp-rbar-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.pdp-rbar-lbl {
  font-family: var(--S);
  font-size: 12px;
  color: var(--ink3);
  width: 24px;
  flex-shrink: 0;
}

.pdp-rbar-track {
  flex: 1;
  height: 6px;
  background: var(--canvas-dk);
  border-radius: 0;
  overflow: hidden;
}

.pdp-rbar-fill {
  height: 100%;
  background: var(--gold);
  transition: width .6s ease;
}

.pdp-rbar-pct {
  font-family: var(--S);
  font-size: 11px;
  color: var(--ink4);
  width: 32px;
  text-align: right;
  flex-shrink: 0;
}

.pdp-rev-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
}

.pdp-rc {
  background: var(--canvas2);
  padding: 28px 24px;
  border: 1px solid var(--gold-line);
}

.pdp-rc-top {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.pdp-rc-av {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--S);
  font-size: 11px;
  font-weight: 600;
  color: white;
  flex-shrink: 0;
}

.pdp-rc-name {
  font-family: var(--S);
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
}

.pdp-rc-meta {
  font-family: var(--S);
  font-size: 11px;
  color: var(--ink5);
  line-height: 1.5;
}

.pdp-rc-stars {
  margin-left: auto;
  color: var(--gold);
  font-size: 12px;
  letter-spacing: 1px;
  flex-shrink: 0;
}

.pdp-rc-title {
  font-family: var(--D);
  font-size: 16px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 8px;
}

.pdp-rc-text {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.75;
}

.pdp-rc-verified {
  font-family: var(--S);
  font-size: 11px;
  color: var(--ink5);
  margin-top: 14px;
}

@media(max-width:768px) {
  .pdp-rev-grid {
    grid-template-columns: 1fr;
  }
}







/* ── ALL ATC BUTTONS GOLD (homepage) ── */


.rvis-btn-primary,
.r-atc {
  background: var(--gold) !important;
  color: var(--canvas) !important;
  border-color: var(--gold) !important;
}

.rvis-btn-primary:hover,
.r-atc:hover {
  background: #b87818 !important;
}




/* ── PRANA SUTRAS LINK STRIP ── */
.hp-sutras-link {
  background: var(--ink);
  padding: 48px 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hp-sutras-link-inner {
  text-align: center;
  max-width: 560px;
}

.hp-sutras-eyebrow {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: rgba(200, 146, 26, .5);
  display: block;
  margin-bottom: 10px;
}

.hp-sutras-text {
  font-family: var(--D);
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 300;
  color: var(--canvas);
  line-height: 1.15;
  margin-bottom: 22px;
}

.hp-sutras-btn {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  background: transparent;
  color: var(--gold);
  border: 1px solid rgba(200, 146, 26, .4);
  padding: 13px 36px;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
}

.hp-sutras-btn:hover {
  background: var(--gold);
  color: var(--canvas);
  border-color: var(--gold);
}

@media(max-width:768px) {
  .hp-sutras-link {
    padding: 40px 20px;
  }
}



/* ══════════════════════════════════════════
   EMAIL SLIDE-IN MODAL
══════════════════════════════════════════ */
.email-slide-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(26, 18, 6, .6);
  z-index: 9998;
  backdrop-filter: blur(3px);
  animation: fadeIn .25s ease;
}

.email-slide {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  background: var(--canvas);
  border-top: 2px solid var(--gold);
  box-shadow: 0 -8px 48px rgba(26, 18, 6, .18);
  animation: slideUp .4s cubic-bezier(.2, 0, .2, 1);
  max-height: 90vh;
  overflow-y: auto;
}

@keyframes slideUp {
  from {
    transform: translateY(100%);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

.esi-inner {
  display: grid;
  grid-template-columns: 1fr 280px;
  max-width: 900px;
  margin: 0 auto;
  padding: 44px 40px;
  gap: 48px;
  align-items: center;
}

.esi-close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: none;
  border: none;
  font-size: 18px;
  color: var(--ink4);
  cursor: pointer;
  padding: 4px 8px;
  transition: color .15s;
}

.esi-close:hover {
  color: var(--ink);
}

.esi-offer {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}

.esi-star {
  color: var(--gold);
  font-size: 12px;
}

.esi-offer-txt {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--gold);
}

.esi-headline {
  font-family: var(--D);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.05;
  margin-bottom: 20px;
}

.esi-headline em {
  color: var(--gold);
  font-style: italic;
}

.esi-perks {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 24px;
}

.esi-perk {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink3);
}

.esi-check {
  color: var(--gold);
  font-size: 11px;
  flex-shrink: 0;
}

.esi-input {
  display: block;
  width: 100%;
  border: 1px solid var(--canvas-dk);
  background: var(--canvas2);
  padding: 13px 16px;
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink);
  margin-bottom: 8px;
  outline: none;
  transition: border-color .15s;
  box-sizing: border-box;
}

.esi-input:focus {
  border-color: var(--gold);
}

.esi-submit {
  width: 100%;
  background: var(--gold);
  color: var(--canvas);
  border: none;
  padding: 15px 24px;
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .18s;
  margin-bottom: 8px;
}

.esi-submit:hover {
  background: #b87818;
}

.esi-note {
  font-family: var(--S);
  font-size: 11px;
  color: var(--ink5);
  text-align: center;
}

.esi-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.esi-img {
  width: 100%;
  max-width: 180px;
  object-fit: contain;
}

.esi-img-caption {
  font-family: var(--S);
  font-size: 11px;
  color: var(--ink5);
  text-align: center;
}

.esi-confirm {
  text-align: center;
  padding: 20px 0;
}

.esi-confirm-icon {
  font-size: 28px;
  color: var(--gold);
  margin-bottom: 12px;
}

.esi-confirm-title {
  font-family: var(--D);
  font-size: 28px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 8px;
}

.esi-confirm-sub {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.7;
}

div#account-popover {
  top: 60px !important;
}

dialog.search-modal__content.dialog-modal {
  margin: 0 auto;
  top: 20px;
}

.header-actions__cart-icon {
  --cart-bubble-size: 0 !important;
}

@media(max-width:680px) {
  .esi-inner {
    grid-template-columns: 1fr;
    padding: 32px 20px 24px;
    gap: 24px;
  }

  .esi-right {
    display: none;
  }

  .esi-headline {
    font-size: 28px;
  }
}


/* ── FAQ ─────────────────────────────────────────────────────────── */
.pdp-faq {
  padding: 80px;
  border-top: 1px solid var(--gold-line);
}

.pdp-faq-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 14px;
}

.pdp-faq-title {
  font-family: var(--D);
  font-size: 40px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 40px;
  line-height: 1.1;
}

.pdp-faq-item {
  border-bottom: 1px solid var(--gold-line);
}

.pdp-faq-item:first-of-type {
  border-top: 1px solid var(--gold-line);
}

.pdp-faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 0;
  cursor: pointer;
  gap: 20px;
  font-family: var(--S);
  font-size: 18px;
  font-weight: 600;
  color: var(--ink1);
  list-style: none;
  user-select: none;
}

.pdp-faq-q:hover {
  color: var(--gold);
}

.pdp-faq-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--gold-line);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
  color: var(--gold);
  transition: transform .25s, background .2s, border-color .2s;
  background: transparent;
}

.pdp-faq-q:hover .pdp-faq-icon {
  background: var(--gold);
  color: var(--canvas);
  border-color: var(--gold);
}

.pdp-faq-icon.open {
  transform: rotate(45deg);
  background: var(--gold);
  color: var(--canvas);
  border-color: var(--gold);
}

.pdp-faq-a {
  overflow: hidden;
  max-height: 0;
  transition: max-height .38s cubic-bezier(.4, 0, .2, 1), opacity .3s ease;
  opacity: 0;
}

.pdp-faq-a.open {
  max-height: 800px;
  opacity: 1;
}

.pdp-faq-a-inner {
  font-family: var(--S);
  font-size: 16px;
  color: var(--ink3);
  line-height: 1.85;
  padding: 4px 0 22px;
  border-left: 3px solid var(--gold);
  padding-left: 18px;
  margin-left: 2px;
}

@media(max-width:768px) {
  .pdp-faq {
    padding: 40px 20px;
  }

  .pdp-faq-title {
    font-size: 26px;
  }

  .pdp-faq-q {
    font-size: 14px;
    padding: 16px 0;
  }
}

/* You May Also Like */
.pdp-also {
  padding: 80px;
  border-top: 1px solid var(--gold-line);
  background: var(--canvas);
}

.pdp-also-label {
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.pdp-also-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--gold-line);
}

.pdp-also-title {
  font-family: var(--D);
  font-size: 40px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 48px;
  line-height: 1.05;
}

.pdp-also-title em {
  color: var(--gold2);
}

.pdp-also-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
}

/* Sutra cards inside also-grid */
.pdp-also-card {
  background: var(--canvas2);
  cursor: pointer;
  transition: background .22s, border-color .22s;
  border: 1px solid var(--gold-line);
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

.pdp-also-card:hover {
  background: var(--canvas);
  border-color: var(--gold);
}

.pdp-also-img {
  width: 100%;
  overflow: hidden;
  background: var(--canvas-dk);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
}

.pdp-also-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: var(--canvas2);
  padding: 12px;
  transition: transform .4s;
}

.pdp-also-card:hover .pdp-also-img img {
  transform: scale(1.03);
}

.pdp-also-body {
  padding: 28px 24px 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.pdp-also-sutra-eyebrow {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 8px;
}

.pdp-also-name {
  font-family: var(--D);
  font-size: 26px;
  font-weight: 300;
  color: var(--ink);
  margin-bottom: 4px;
  line-height: 1.1;
}

.pdp-also-sub {
  font-family: var(--S);
  font-size: 14px;
  font-style: italic;
  color: var(--ink4);
  margin-bottom: 10px;
}

.pdp-also-meaning {
  font-family: var(--S);
  font-size: 14px;
  color: var(--ink3);
  line-height: 1.7;
  margin-bottom: 20px;
  flex: 1;
}

.pdp-also-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--gold-line);
  padding-top: 16px;
  margin-top: auto;
}

.pdp-also-price {
  font-family: var(--D);
  font-size: 22px;
  color: var(--ink);
  font-weight: 300;
}

.pdp-also-atc {
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 11px 20px;
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s;
  white-space: nowrap;
}

.pdp-also-atc:hover {
  background: var(--gold);
}

/* ── Compact Ingredient Carousel ─────────────────────────────── */
.ingc-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
}

.ingc-track-wrap {
  overflow: hidden;
  flex: 1;
}

.ingc-track {
  display: flex;
  gap: 16px;
  transition: transform .38s cubic-bezier(.4, 0, .2, 1);
}

.ingc-card {
  flex-shrink: 0;
  width: calc(20% - 13px);
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  border-radius: 3px;
  cursor: pointer;
  transition: border-color .2s, box-shadow .2s;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.ingc-card:hover,
.ingc-card.on {
  border-color: var(--gold);
  box-shadow: 0 4px 20px rgba(168, 104, 26, .12);
}

.ingc-img-box {
  width: 100%;
  aspect-ratio: 3/2;
  background: linear-gradient(135deg, var(--canvas), var(--canvas-dk));
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--gold-line);
  position: relative;
  overflow: hidden;
}

.ingc-img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ingc-img-ph {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 100%;
  height: 100%;
}

.ingc-img-ph-icon {
  font-size: 20px;
  color: var(--gold);
  opacity: .3;
}

.ingc-img-ph-label {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .14em;
  color: var(--ink5);
}

.ingc-card-body {
  padding: 12px 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.ingc-num {
  font-family: var(--U);
  font-size: 18px;
  letter-spacing: .18em;
  color: var(--gold);
  margin-bottom: 2px;
}

.ingc-name {
  font-family: var(--D);
  font-size: 24px;
  color: var(--ink1);
  line-height: 1.2;
}

.ingc-latin {
  font-family: var(--S);
  font-size: 18px;
  font-style: italic;
  color: var(--ink5);
  line-height: 1.3;
}

.ingc-benefit {
  font-family: var(--U);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 6px;
  border-top: 1px solid var(--gold-line);
  padding-top: 5px;
}

.ingc-arrow {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--canvas);
  border: 1px solid var(--gold-line);
  color: var(--ink);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  transition: all .2s;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .06);
}

div#pdp-ing-carousel {
  padding: 60px 0;
}

.ingc-arrow:hover {
  background: var(--gold);
  color: var(--canvas);
  border-color: var(--gold);
}

.ingc-arrow:disabled {
  opacity: .3;
  cursor: default;
}

/* Detail panel */
.ingc-detail {
  margin-top: 16px;
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  border-radius: 3px;
  padding: 28px;
  position: relative;
}

.ingc-detail-inner {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 24px;
  align-items: start;
}

.ingc-detail-ph {
  font-size: 36px;
  color: var(--gold);
  opacity: .35;
  text-align: center;
  padding-top: 4px;
}

.ingc-detail-origin {
  font-family: var(--U);
  font-size: 14px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 6px;
}

.ingc-detail-name {
  font-family: var(--D);
  font-size: 30px;
  color: var(--ink1);
  margin-bottom: 4px;
}

.ingc-detail-latin {
  font-family: var(--S);
  font-size: 16px;
  font-style: italic;
  color: var(--ink4);
  margin-bottom: 12px;
}

.ingc-detail-desc {
  font-family: var(--S);
  font-size: 18px;
  color: var(--ink3);
  line-height: 1.8;
}

.ingc-detail-benefit {
  font-family: var(--U);
  font-size: 14px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--gold-line);
}

.ingc-close {
  position: absolute;
  top: 12px;
  right: 14px;
  background: none;
  border: none;
  font-size: 22px;
  color: var(--ink4);
  cursor: pointer;
  line-height: 1;
}

.ingc-close:hover {
  color: var(--ink1);
}

@media(max-width:768px) {
  .ingc-card {
    width: 140px;
    padding: 16px 12px;
  }

  .ingc-card {
    width: calc(100% - 8px);
  }

  .ingc-detail-inner {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .ingc-detail-ph {
    display: none;
  }
}

/* ── Toner Single-Ingredient Spotlight ─────────────────────────── */
.pdp-ing-single-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: 480px;
  border: 1px solid var(--gold-line);
  overflow: hidden;
}

.pdp-ing-single-img {
  position: relative;
  background: linear-gradient(135deg, #f0e6d8, #e6d4c0);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  min-height: 480px;
}

.pdp-ing-single-img-ornament {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
}

.pdp-ing-single-petal-ring {
  width: 260px;
  height: 260px;
  border-radius: 50%;
  border: 1px solid rgba(168, 104, 26, .18);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.pdp-ing-single-petal-ring::before {
  content: '';
  position: absolute;
  inset: 18px;
  border-radius: 50%;
  border: 1px solid rgba(168, 104, 26, .12);
}

.pdp-ing-single-petal-ring::after {
  content: '✦';
  font-size: 28px;
  color: var(--gold);
  opacity: .35;
}

.pdp-ing-single-petals {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.pdp-ing-single-petal {
  position: absolute;
  font-size: 22px;
  animation: rg 6s ease-in-out infinite;
  color: rgba(168, 104, 26, .22);
}

.pdp-ing-single-label {
  position: absolute;
  bottom: 28px;
  left: 0;
  right: 0;
  text-align: center;
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--ink4);
}

.pdp-ing-single-body {
  background: var(--canvas);
  padding: 56px 52px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-left: 1px solid var(--gold-line);
}

.pdp-ing-single-kicker {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.pdp-ing-single-kicker::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--gold-line);
}

.pdp-ing-single-name {
  font-family: var(--D);
  font-size: 38px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1.05;
  margin-bottom: 6px;
}

.pdp-ing-single-latin {
  font-family: var(--S);
  font-size: 13px;
  font-style: italic;
  color: var(--ink4);
  margin-bottom: 28px;
}

.pdp-ing-single-origin {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink4);
  background: var(--canvas2);
  border: 1px solid var(--gold-line);
  padding: 7px 14px;
  margin-bottom: 28px;
  width: fit-content;
}

.pdp-ing-single-origin::before {
  content: '⊕';
  color: var(--gold);
  font-size: 10px;
}

.pdp-ing-single-divider {
  width: 40px;
  height: 1px;
  background: var(--gold-line);
  margin-bottom: 24px;
}

.pdp-ing-single-desc {
  font-family: var(--S);
  font-size: 15px;
  color: var(--ink3);
  line-height: 1.85;
  margin-bottom: 28px;
}

.pdp-ing-single-facts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--gold-line);
  border: 1px solid var(--gold-line);
  margin-bottom: 28px;
}

.pdp-ing-single-fact {
  background: var(--canvas2);
  padding: 14px 16px;
}

.pdp-ing-single-fact-label {
  font-family: var(--U);
  font-size: 8px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink5);
  margin-bottom: 4px;
}

.pdp-ing-single-fact-val {
  font-family: var(--S);
  font-size: 13px;
  color: var(--ink2);
  line-height: 1.4;
}

.pdp-ing-single-benefit {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  border-top: 1px solid var(--gold-line);
  padding-top: 18px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.pdp-ing-single-benefit span {
  background: var(--gold-pale);
  padding: 5px 10px;
}

@media(max-width:768px) {
  .pdp-ing-single-inner {
    grid-template-columns: 1fr;
  }

  .pdp-ing-single-img {
    min-height: 280px;
  }

  .pdp-ing-single-body {
    padding: 32px 24px;
  }

  .pdp-ing-single-name {
    font-size: 28px;
  }

  .pdp-ing-single-facts {
    grid-template-columns: 1fr;
  }
}

/* Sutra page body */
.sutra-page {
    background: radial-gradient(100.75% 105.17% at 95.4% 0%, #cb964675 0%, #e3c39f2e 100%);
}
.fv-cap-line {
    width: 70px;
    height: 0.5px;
    background: var(--gold);
    flex-shrink: 0;
}
.sutra-intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-bottom: 1px solid var(--gold);
}

.sutra-intro-copy {
  padding:50px 50px 50px 0;
}

.sutra-intro-aside {
  padding:60px;
  border-left: 1px solid var(--gold);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.sutra-breadcrumb {
    gap: 10px;
    display: flex;
    align-items: center;
    text-transform: uppercase;
    color: var(--ink3);
    margin-bottom: 20px;
    cursor: pointer;
}

.sutra-breadcrumb:hover {
  text-decoration: underline;
}

.sutra-sanskrit-big {
  font-family: var(--D);
  font-size: 54px;
  font-weight: 300;
  color: var(--ink);
  line-height: 1;
  margin-bottom: 6px;
  letter-spacing: .04em;
}

.sutra-pronounce {
  font-size: 12px;
  color: var(--ink3);
  text-transform: capitalize;
  margin-bottom: 6px;
}

.sutra-meaning {
  font-family: var(--D);
  font-size: 20px;
  font-weight: 300;
  color: var(--gold);
  margin-bottom: 24px;
}
.sutra-body-text {
    font-family: var(--S);
    font-size: 17px;
    color: var(--ink3);
    line-height: normal;
    margin-bottom: 20px;
}
.sutra-ayurveda-block {
    background: #E3C39F;
    border-radius: 8px;
    padding:11px;
}
.sutra-ayurveda-label {
    font-size: 15px;
    text-transform: capitalize;
    color: white;
    background: var(--heading-color);
    width: fit-content;
    padding: 6px 11px;
    border-radius: 0 10px 10px 0;
    margin-left:-11px;
}
.sutra-ayurveda-text {
    font-family: var(--S);
    font-size: 16px;
    color: var(--ink3);
    line-height: normal;
    padding: 9px 0;
}

/* Meta pills */
.sutra-meta-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}
.s-pill {
    font-size: 15px;
    color: var(--link);
    border: 1px solid var(--heading-color);
    padding: 6px 12px;
    background: #F8F0E5;
    border-radius: 5px;
    display: flex;
    gap: 9px;
    align-items: center;
    justify-content: center;
}
/* Or row */
.sutra-or-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 10px 0 8px;
    justify-content: center;
    width: 100%;
}
.sutra-or-row::before,
.sutra-or-row::after {
  content: '';
  flex: 1;
  height: 0.5px;
  background: var(--gold);
}
.sutra-or-row span {
    font-size: 16px;
    color: var(--ink3);
    white-space: nowrap;
    text-align: center;
}

/* Trust badges */
.sutra-trust {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.sutra-trust-item {
    font-size: 16px;
    color: var(--ink3);
    margin-left: 20px;
}
/* Also explore section */

.s-also-card .box-innered {
    display: flex;
    align-items: center;
    gap: 10px;
}
.sutra-also-label {
  font-family: var(--U);
  font-size: 14px;
  color:var(--ink3);
  display: flex;
  align-items: center;
  gap: 16px;
}
.sutra-also-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 22px;
}
.s-also-card {
    background: var(--canvas);
    padding: 16px;
    cursor: pointer;
    transition: background .2s;
    display: flex;
    border-radius: 5px;
    justify-content: space-between;
    border: 1px solid var(--heading-color);
    box-shadow: 0px 2px 4px 0px #4613244D;
}
.s-also-name {
    font-family: var(--D);
    font-size: 28px;
    font-weight: 300;
    color: var(--ink);
    line-height: normal;
}
.s-also-sub {
  font-family: var(--S);
  font-size: 17px;
  color: var(--ink3);
}
.surtas-details {
    padding-bottom:50px;
}
.s-also-price {
  font-family: var(--D);
  font-size: 24px;
  font-weight: 300;
  color: var(--ink);
}
.s-also-arrow {
    font-size: 14px;
    text-transform: capitalize;
    background: var(--gold);
    color: var(--canvas);
    border: none;
    padding: 6px 11px;
    cursor: pointer;
    border-radius: 4px;
    transition: background .15s, transform .1s;
}

.s-also-arrow:hover{
  background: var(--heading-color);
  border-color: var(--gold);
}

/* ── ABHYANGA SIG CARD ── */
.set-card.sig {
  grid-column: 1/-1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.sig-ticker {
  background: var(--ink);
  color: var(--canvas);
  font-family: var(--U);
  font-size: 10px;
  letter-spacing: .3em;
  text-transform: uppercase;
  padding: 10px 0;
  overflow: hidden;
  white-space: nowrap;
}

.sig-ticker-track {
  display: inline-block;
  animation: tickerScroll 22s linear infinite;
}

@keyframes tickerScroll {
  from {
    transform: translateX(0)
  }

  to {
    transform: translateX(-50%)
  }
}

.sig-ticker-text {
  display: inline-block;
  padding: 0 56px;
}

.sig-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 420px;
}

.sig-left {
  padding: 60px 72px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--canvas);
}

.sig-right {
  background: var(--canvas2);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  padding: 48px;
}

.sig-pframe {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

.sig-pimg {
  width: 108px;
  height: 140px;
  overflow: hidden;
  border: 1px solid var(--canvas-dk);
  background: var(--canvas);
}

.sig-pimg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sig-plabel {
  font-family: var(--U);
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink4);
  text-align: center;
  max-width: 90px;
  line-height: 1.4;
}

.sig-card-btns {
  display: flex;
  gap: 12px;
  margin-top: 28px;
}

.sig-btn-primary {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--canvas);
  border: none;
  padding: 14px 28px;
  cursor: pointer;
  transition: background .22s;
}

.sig-btn-primary:hover {
  background: var(--gold);
}

.sig-btn-secondary {
  font-family: var(--U);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink3);
  border: 1px solid var(--canvas-dk);
  padding: 14px 24px;
  cursor: pointer;
  transition: all .22s;
}

.sig-btn-secondary:hover {
  border-color: var(--ink);
  color: var(--ink);
}



@media all and (max-width:768px){
  .sutra-steps{
    grid-template-columns: 1fr 1fr;
    gap:10px;
  }
  .sutra-breadcrumb {
    margin-bottom: 12px;
  }
}

/* ── 480px — SMALL MOBILE ── */
@media (max-width: 575px) {
  .sutra-steps{
    grid-template-columns:1fr;
    margin-top: 19px;
  }
  .hero-h1 {
    font-size: 42px;
  }
  .sutra-step-tag {
    font-size: 14px;
  }
  .sp-item{
    padding:10px;
  }

  .s-also-arrow {
    font-size: 15px;
    padding: 5px 11px;
  }
  .surtas-details {
    padding-bottom: 45px;
  }
  .sutra-step-img-wrap img {
    height: 205px;
    object-fit: contain;
  }
  .sutra-step-num {
    padding: 3px 10px;
    font-size: 15px;
    border-radius: 0 5px 5px 0;
  }
  .pdp-name {
    font-size: 28px;
  }

  .pdp-clin-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .pdp-complete-grid {
    grid-template-columns: 1fr !important;
  }

  .pdp-also-grid {
    grid-template-columns: 1fr !important;
  }

  .shop-grid {
    grid-template-columns: 1fr !important;
  }

  .benefits-bar {
    grid-template-columns: 1fr !important;
  }

  .about-values {
    grid-template-columns: 1fr !important;
  }

  .spa-pillars {
    grid-template-columns: 1fr !important;
  }

  .about-ing-grid {
    grid-template-columns: 1fr !important;
  }

  .about-press-grid {
    grid-template-columns: 1fr !important;
  }

  .pdp-complete-total {
    font-size: 20px;
  }

  .pdp-rev-big {
    font-size: 52px;
  }

  .rvis-title {
    font-size: 22px;
  }

  .pdp-ing-subtitle {
    font-size: 26px;
  }

  .pdp-complete-title {
    font-size: 24px;
  }

  .pdp-also-title {
    font-size: 26px;
  }

  .pcaro-card {
    min-width: 180px;
    display: flex;
    flex-direction: column;
    background:#E3C39F;
  }
  .pcaro-card{
    background:#E3C39F;
  }
  .pcaro-card .pcaro-img {
    height: 100%;
    background:var(--canvas);
    border-radius: 8px;
    box-shadow: 2px 2px 4px #4613244d;
    border: .5px solid #461324;
    border-bottom: 0;
  }

  #productsSection .pscroll-hd h2 {
    font-size: 18px;
    line-height: normal;
  }


  #productsSection .pscroll-hd {
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;

  }

  .pcaro-card .pcaro-accent {
    display: none;
  }

  .fv-founder-img {
    opacity: 1;
  }

  .hp-sticky-right {
    gap: 5px;
  }

  .hp-sticky-close {
    color: #fff;
    font-size: 13px;
    padding: 0;

  }
  header .header-inner {
    grid-template-columns: 1fr auto 1fr;
  }
  .pcaro-img {
    height: 220px;
  }

  .pdp-rev-card-title {
    font-size: 15px;
  }
  .sl-txt{
    font-size:13px;
    color: var(--ink3);
    letter-spacing: normal;
  }
  .pdp-rev-card-body {
    font-size: 13px;
  }
  header.fixed{
    height:73px;
  }
  body header.scrolled+div#mobileNavMenu {
    top: 73px;
  }
  .scan-live {
    padding-bottom: 5px;
  }
}