:root {
  --saffron: #e8650a;
  --saffron2: #f0820d;
  --turmeric: #f5a623;
  --lotus: #c94b6e;
  --lotus2: #e06a87;
  --sage: #3d6b4f;
  --sage2: #559268;
  --pearl: #fdf6ee;
  --parchment: #f7edd8;
  --copper: #8b4513;
  --ink: #1a1208;
  --muted: #6b5745;
  --smoke: #f0e8da;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  font-family: 'Outfit', sans-serif;
  background: var(--pearl);
  color: var(--ink);
  overflow-x: hidden
}

/* ── CUSTOM SCROLLBAR ── */
::-webkit-scrollbar {
  width: 6px
}

::-webkit-scrollbar-track {
  background: var(--parchment)
}

::-webkit-scrollbar-thumb {
  background: var(--saffron);
  border-radius: 3px
}

/* ── TOP BAR ── */
.topbar {
  background: var(--saffron);
  color: #fff;
  font-size: .72rem;
  letter-spacing: .12em;
  padding: .42rem 0;
  text-align: center
}

.topbar span {
  margin: 0 1.5rem;
  opacity: .9
}

.topbar i {
  margin-right: .4rem
}

/* ── NAVBAR ── */
.navbar {
  background: #fff;
  border-bottom: 2px solid var(--turmeric);
  padding: 0;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 4px 24px rgba(232, 101, 10, .1)
}

.navbar-brand-wrap {
  display: flex;
  align-items: center;
  gap: .7rem
}

.brand-om {
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: #fff;
  flex-shrink: 0
}

.brand-name {
  font-family: 'Yeseva One', serif;
  font-size: 1.45rem;
  color: var(--saffron);
  line-height: 1.1
}

.brand-tag {
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--muted);
  display: block
}

.nav-link {
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink) !important;
  padding: 25px 0;
  position: relative;
  transition: color .3s
}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: .7rem;
  right: .7rem;
  height: 2px;
  background: var(--saffron);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s
}

.nav-link:hover {
  color: var(--saffron) !important
}

.nav-link:hover::after {
  transform: scaleX(1)
}

.has-mega {
  position: relative
}

.mega-menu {
  position: absolute;
  top: calc(100% + 0px);
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border: 1px solid #f0e0cc;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .12);
  padding: 1.5rem;
  min-width: 680px;
  display: none;
  z-index: 999
}

.has-mega:hover .mega-menu {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem
}

.mega-col-title {
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: .7rem;
  font-weight: 600
}

.mega-link {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  color: var(--muted);
  text-decoration: none;
  padding: .28rem 0;
  transition: color .3s
}

.mega-link i {
  width: 16px;
  color: var(--turmeric);
  font-size: .75rem
}

.mega-link:hover {
  color: var(--saffron)
}

.btn-book {
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff !important;
  border-radius: 2rem;
  padding: .45rem 1.2rem !important;
  font-size: .75rem !important;
  letter-spacing: .12em;
  box-shadow: 0 4px 16px rgba(232, 101, 10, .3);
  transition: all .3s
}

.btn-book:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(232, 101, 10, .4)
}

/* ── HERO SLIDER ── */
#heroSlider {
  position: relative;
  height: 92vh;
  min-height: 600px;
  overflow: hidden
}

.slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease
}

.slide.active {
  opacity: 1
}

.slide-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.05);
  transition: transform 8s ease
}

.slide.active .slide-bg {
  transform: scale(1)
}

.slide-overlay {
  position: absolute;
  inset: 0
}

.slide-content {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center
}

.slide-tag {
  font-size: .72rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .8);
  margin-bottom: .8rem;
  display: block
}

.slide-title {
  font-family: 'Yeseva One', serif;
  font-size: clamp(2.6rem, 5.5vw, 5rem);
  color: #fff;
  line-height: 1.08;
  margin-bottom: 1rem;
  text-shadow: 0 2px 20px rgba(0, 0, 0, .3)
}

.slide-sub {
  font-family: 'Crimson Pro', serif;
  font-size: 1.25rem;
  font-style: italic;
  color: rgba(255, 255, 255, .85);
  max-width: 480px;
  line-height: 1.65;
  margin-bottom: 2rem
}

.btn-hero-primary {
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  padding: .85rem 2.2rem;
  border-radius: 3rem;
  font-size: .8rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: all .3s;
  text-decoration: none;
  display: inline-block;
  box-shadow: 0 8px 30px rgba(232, 101, 10, .4)
}

.btn-hero-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 40px rgba(232, 101, 10, .5);
  color: #fff
}

.btn-hero-outline {
  background: transparent;
  color: #fff;
  padding: .82rem 2.2rem;
  border-radius: 3rem;
  font-size: .8rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  border: 1.5px solid rgba(255, 255, 255, .7);
  cursor: pointer;
  transition: all .3s;
  text-decoration: none;
  display: inline-block;
  margin-left: .8rem
}

.btn-hero-outline:hover {
  background: rgba(255, 255, 255, .15);
  color: #fff
}

.slide-controls {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 1rem;
  z-index: 10
}

.slide-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .4);
  cursor: pointer;
  transition: all .3s
}

.slide-dot.active {
  background: #fff;
  width: 28px;
  border-radius: 4px
}

.slide-arr {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  background: rgba(255, 255, 255, .15);
  border: 1px solid rgba(255, 255, 255, .3);
  color: #fff;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .3s;
  backdrop-filter: blur(6px)
}

.slide-arr:hover {
  background: rgba(255, 255, 255, .3)
}

.slide-arr.prev {
  left: 1.5rem
}

.slide-arr.next {
  right: 1.5rem
}

.btn-ds{background:linear-gradient(135deg,var(--saffron),var(--turmeric));color:#fff;border:none;padding:.7rem 1.8rem;border-radius:2.5rem;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .3s;display:inline-block;text-decoration:none}
.btn-ds:hover{transform:translateY(-3px);color:#fff}
.card-ds{background:#fff;border-radius:18px;padding:2rem;border:1.5px solid var(--smoke);height:100%;transition:all .3s}
.card-ds:hover{border-color:var(--turmeric);box-shadow:0 12px 40px rgba(232,101,10,.1);transform:translateY(-4px)}
.card-icon{font-size:2.2rem;margin-bottom:1rem}
.card-title-ds{font-family:'Yeseva One',serif;font-size:1.05rem;color:var(--ink);margin-bottom:.5rem}
.card-text-ds{font-size:.84rem;color:var(--muted);line-height:1.7}


/* ── MARQUEE ── */
.marquee-bar {
  background: linear-gradient(90deg, var(--saffron), var(--lotus), var(--saffron));
  padding: .7rem 0;
  overflow: hidden
}

.marquee-track {
  display: flex;
  white-space: nowrap;
  animation: marqueeAnim 35s linear infinite
}

.marquee-track span {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1rem;
  color: #fff;
  margin: 0 2rem
}

.marquee-track i {
  color: rgba(255, 255, 255, .5);
  font-size: .55rem;
  vertical-align: middle
}

@keyframes marqueeAnim {
  0% {
    transform: translateX(0)
  }

  100% {
    transform: translateX(-50%)
  }
}

/* ── SECTION COMMON ── */
.section-tag {
  font-size: .7rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--saffron);
  display: block;
  margin-bottom: .7rem
}

.section-title {
  font-family: 'Yeseva One', serif;
  font-size: clamp(1.9rem, 3.5vw, 2.9rem);
  color: var(--ink);
  line-height: 1.15
}

.section-sub {
  font-family: 'Crimson Pro', serif;
  font-size: 1.1rem;
  color: var(--muted);
  line-height: 1.75
}

.divider-lotus {
  text-align: center;
  font-size: 1.6rem;
  color: var(--turmeric);
  opacity: .5;
  margin: 2.5rem 0
}

/* ── PILLARS GRID ── */
#pillars {
  padding: 5.5rem 0;
  background: var(--pearl)
}

.pillar-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem 1.6rem;
  text-align: center;
  border: 1.5px solid transparent;
  transition: all .35s;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  height: 100%
}

.pillar-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(232, 101, 10, .04), rgba(245, 166, 35, .06));
  opacity: 0;
  transition: opacity .3s
}

.pillar-card:hover::before {
  opacity: 1
}

.pillar-card:hover {
  border-color: var(--turmeric);
  transform: translateY(-8px);
  box-shadow: 0 20px 50px rgba(232, 101, 10, .12)
}

.pillar-icon {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  margin: 0 auto 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  transition: all .3s
}

.pillar-card:hover .pillar-icon {
  transform: scale(1.1)
}

.pillar-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.2rem;
  color: var(--ink);
  margin-bottom: .5rem
}

.pillar-desc {
  font-size: .85rem;
  color: var(--muted);
  line-height: 1.65
}

.pillar-link {
  font-size: .72rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--saffron);
  text-decoration: none;
  display: inline-block;
  margin-top: .8rem;
  transition: letter-spacing .3s
}

.pillar-link:hover {
  letter-spacing: .22em
}

.cat-tags {
  margin-top: .8rem;
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  justify-content: center
}

.cat-tag {
  font-size: .65rem;
  padding: .22rem .6rem;
  border-radius: 2rem;
  background: var(--smoke);
  color: var(--muted)
}

/* Icon color themes */
.icon-mind {
  background: linear-gradient(135deg, #e8f4fd, #c8e6f9);
  color: #2e7db8
}

.icon-soul {
  background: linear-gradient(135deg, #f5e6ff, #e8ccf8);
  color: #7b3fb5
}

.icon-mantra {
  background: linear-gradient(135deg, #fff3e0, #ffe0b2);
  color: var(--saffron)
}

.icon-jyotish {
  background: linear-gradient(135deg, #fffde7, #fff9c4);
  color: #f9a825
}

.icon-body {
  background: linear-gradient(135deg, #e8f5e9, #c8e6c9);
  color: var(--sage)
}

.icon-food {
  background: linear-gradient(135deg, #fce4ec, #f8bbd0);
  color: var(--lotus)
}

.icon-healing {
  background: linear-gradient(135deg, #e0f7fa, #b2ebf2);
  color: #00838f
}

.icon-relation {
  background: linear-gradient(135deg, #fbe9e7, #ffccbc);
  color: #e64a19
}

.icon-lifestyle {
  background: linear-gradient(135deg, #f9fbe7, #f0f4c3);
  color: #689f38
}

.icon-culture {
  background: linear-gradient(135deg, #fff8e1, #ffecb3);
  color: #ff8f00
}

/* ── FEATURED CONTENT CARDS ── */
#featured {
  padding: 5.5rem 0;
  background: var(--parchment)
}

.feat-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
  gap: 1rem
}

.tab-pills {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap
}

.tab-pill {
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .42rem 1rem;
  border-radius: 2rem;
  border: 1.5px solid var(--saffron);
  color: var(--saffron);
  background: transparent;
  cursor: pointer;
  transition: all .3s
}

.tab-pill.active,
.tab-pill:hover {
  background: var(--saffron);
  color: #fff
}

.content-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  transition: all .35s;
  height: 100%
}

.content-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(0, 0, 0, .1)
}

.card-img-wrap {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden
}

.card-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s
}

.content-card:hover .card-img-wrap img {
  transform: scale(1.06)
}

.card-badge {
  position: absolute;
  top: .75rem;
  left: .75rem;
  padding: .3rem .8rem;
  border-radius: 2rem;
  font-size: .64rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
  color: #fff
}

.card-body-inner {
  padding: 1.4rem
}

.card-cat {
  font-size: .67rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: .4rem
}

.card-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.12rem;
  color: var(--ink);
  line-height: 1.3;
  margin-bottom: .5rem
}

.card-desc {
  font-size: .84rem;
  color: var(--muted);
  line-height: 1.65
}

.card-footer-bar {
  padding: .9rem 1.4rem;
  border-top: 1px solid var(--smoke);
  display: flex;
  align-items: center;
  justify-content: space-between
}

.card-meta {
  font-size: .72rem;
  color: var(--muted)
}

.card-meta i {
  color: var(--turmeric);
  margin-right: .3rem
}

.btn-card {
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--saffron);
  text-decoration: none;
  border: 1px solid var(--saffron);
  padding: .32rem .9rem;
  border-radius: 2rem;
  transition: all .3s
}

.btn-card:hover {
  background: var(--saffron);
  color: #fff
}

/* ── MANTRA SECTION ── */
#mantra-sec {
  padding: 5.5rem 0;
  background: linear-gradient(160deg, #1a1208 0%, #2d1a08 40%, #1a0f0a 100%);
  position: relative;
  overflow: hidden
}

#mantra-sec::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(232, 101, 10, .15), transparent)
}

.mantra-bg-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: 'Yeseva One', serif;
  font-size: 30vw;
  color: rgba(255, 255, 255, .02);
  white-space: nowrap;
  pointer-events: none;
  user-select: none
}

.mantra-tab-wrap {
  display: flex;
  gap: .6rem;
  flex-wrap: wrap;
  margin-bottom: 2.5rem
}

.mantra-tab {
  padding: .45rem 1.2rem;
  border-radius: 2rem;
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  border: 1px solid rgba(232, 101, 10, .4);
  color: rgba(255, 255, 255, .5);
  cursor: pointer;
  transition: all .3s
}

.mantra-tab.active,
.mantra-tab:hover {
  background: var(--saffron);
  border-color: var(--saffron);
  color: #fff
}

.mantra-hero-text {
  font-family: 'Yeseva One', serif;
  font-size: clamp(2rem, 5vw, 4rem);
  color: var(--turmeric);
  line-height: 1.1;
  text-shadow: 0 0 60px rgba(245, 166, 35, .3)
}

.mantra-roman {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1.3rem;
  color: rgba(255, 255, 255, .5);
  margin-top: .5rem
}

.mantra-meaning {
  font-size: .92rem;
  color: rgba(255, 255, 255, .55);
  line-height: 1.8;
  margin-top: 1.2rem;
  max-width: 420px
}

.mantra-grid-card {
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(232, 101, 10, .2);
  border-radius: 12px;
  padding: 1.6rem;
  transition: all .3s;
  cursor: pointer
}

.mantra-grid-card:hover {
  background: rgba(232, 101, 10, .12);
  border-color: rgba(232, 101, 10, .5);
  transform: translateY(-4px)
}

.mg-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.25rem;
  color: var(--turmeric);
  margin-bottom: .3rem
}

.mg-sub {
  font-size: .7rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .35)
}

.mg-desc {
  font-size: .84rem;
  color: rgba(255, 255, 255, .5);
  margin-top: .7rem;
  line-height: 1.65
}

.mg-play {
  width: 38px;
  height: 38px;
  background: var(--saffron);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1rem;
  cursor: pointer;
  transition: transform .3s
}

.mg-play:hover {
  transform: scale(1.15)
}

.mg-play i {
  color: #fff;
  font-size: .8rem;
  margin-left: 2px
}

.day-mantra-strip {
  background: rgba(232, 101, 10, .12);
  border: 1px solid rgba(232, 101, 10, .3);
  border-radius: 12px;
  padding: 1.4rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 2rem
}

.dms-label {
  font-size: .68rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .4)
}

.dms-mantra {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1.5rem;
  color: var(--turmeric)
}

/* ── JYOTISH ── */
#jyotish {
  padding: 5.5rem 0;
  background: linear-gradient(180deg, var(--pearl) 0%, var(--parchment) 100%);
  position: relative;
  overflow: hidden
}

.zodiac-strip {
  display: flex;
  gap: .5rem;
  overflow-x: auto;
  padding-bottom: .5rem;
  scrollbar-width: none
}

.zodiac-strip::-webkit-scrollbar {
  display: none
}

.rashi-card {
  min-width: 90px;
  background: #fff;
  border: 1.5px solid var(--smoke);
  border-radius: 12px;
  padding: .8rem .5rem;
  text-align: center;
  cursor: pointer;
  transition: all .3s;
  flex-shrink: 0
}

.rashi-card:hover,
.rashi-card.active {
  border-color: var(--turmeric);
  background: linear-gradient(135deg, #fff8ed, #fff3d6)
}

.rashi-symbol {
  font-size: 1.6rem;
  margin-bottom: .3rem
}

.rashi-name {
  font-size: .7rem;
  font-weight: 500;
  color: var(--muted)
}

.jyotish-feature {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  transition: all .35s
}

.jyotish-feature:hover {
  border-color: var(--turmeric);
  box-shadow: 0 12px 40px rgba(232, 101, 10, .1)
}

.jf-icon {
  font-size: 2rem;
  margin-bottom: .8rem
}

.jf-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.15rem;
  color: var(--ink);
  margin-bottom: .4rem
}

.jf-desc {
  font-size: .84rem;
  color: var(--muted);
  line-height: 1.65
}

.planet-card {
  background: #fff;
  border-radius: 12px;
  padding: 1.2rem;
  border: 1px solid var(--smoke);
  text-align: center;
  transition: all .3s;
  cursor: pointer
}

.planet-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, .08);
  border-color: var(--turmeric)
}

.planet-sym {
  font-size: 2rem;
  margin-bottom: .4rem
}

.planet-name {
  font-size: .78rem;
  font-weight: 500;
  color: var(--muted)
}

/* ── YOGA SECTION ── */
#yoga-sec {
  padding: 5.5rem 0;
  background: linear-gradient(135deg, #f0faf2 0%, #e8f5ea 100%)
}

.yoga-big-card {
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 3/4;
  cursor: pointer
}

.yoga-big-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s
}

.yoga-big-card:hover img {
  transform: scale(1.05)
}

.yoga-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, .75))
}

.yoga-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.8rem
}

.yoga-label {
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .7);
  margin-bottom: .4rem
}

.yoga-name {
  font-family: 'Yeseva One', serif;
  font-size: 1.4rem;
  color: #fff;
  margin-bottom: .3rem
}

.yoga-level {
  font-size: .75rem;
  color: rgba(255, 255, 255, .65)
}

.yoga-small-card {
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 16/10;
  cursor: pointer
}

.yoga-small-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s
}

.yoga-small-card:hover img {
  transform: scale(1.06)
}

.yoga-small-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 30%, rgba(0, 0, 0, .7))
}

.yoga-small-info {
  position: absolute;
  bottom: 0;
  padding: 1.1rem
}

.yoga-small-info .label {
  font-size: .64rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .65)
}

.yoga-small-info .name {
  font-family: 'Yeseva One', serif;
  font-size: 1rem;
  color: #fff
}

.pranayama-list {
  background: #fff;
  border-radius: 16px;
  padding: 1.8rem;
  border: 1.5px solid #d4e8d6
}

.prana-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .9rem 0;
  border-bottom: 1px solid #f0f5f1
}

.prana-item:last-child {
  border-bottom: none
}

.prana-icon {
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, #e8f5e9, #c8e6c9);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--sage);
  font-size: 1rem;
  flex-shrink: 0
}

.prana-name {
  font-weight: 500;
  font-size: .88rem;
  color: var(--ink)
}

.prana-benefit {
  font-size: .76rem;
  color: var(--muted)
}

/* ── EVENTS ── */
#events-sec {
  padding: 5.5rem 0;
  background: var(--pearl)
}

.event-big {
  border-radius: 20px;
  overflow: hidden;
  position: relative;
  min-height: 420px;
  cursor: pointer
}

.event-big img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  transition: transform .6s
}

.event-big:hover img {
  transform: scale(1.04)
}

.event-big-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(26, 18, 8, .7) 0%, rgba(26, 18, 8, .2) 100%)
}

.event-big-content {
  position: absolute;
  inset: 0;
  padding: 2.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end
}

.event-featured-tag {
  background: var(--saffron);
  color: #fff;
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .3rem .8rem;
  border-radius: 2rem;
  display: inline-block;
  margin-bottom: 1rem;
  align-self: flex-start
}

.event-big-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.8rem;
  color: #fff;
  line-height: 1.2;
  margin-bottom: .6rem
}

.event-big-meta {
  font-size: .82rem;
  color: rgba(255, 255, 255, .7)
}

.event-big-meta i {
  color: var(--turmeric);
  margin-right: .35rem
}

.event-list-card {
  background: #fff;
  border-radius: 14px;
  padding: 1.5rem;
  border: 1.5px solid var(--smoke);
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
  transition: all .3s;
  cursor: pointer
}

.event-list-card:hover {
  border-color: var(--turmeric);
  box-shadow: 0 8px 30px rgba(232, 101, 10, .1);
  transform: translateX(4px)
}

.event-date-box {
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  border-radius: 10px;
  min-width: 58px;
  text-align: center;
  padding: .6rem .4rem
}

.edb-day {
  font-family: 'Yeseva One', serif;
  font-size: 1.6rem;
  line-height: 1;
  display: block
}

.edb-mon {
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  opacity: .85
}

.event-type-tag {
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: .3rem
}

.event-name {
  font-family: 'Yeseva One', serif;
  font-size: 1.05rem;
  color: var(--ink);
  margin-bottom: .3rem
}

.event-info {
  font-size: .78rem;
  color: var(--muted)
}

.event-info i {
  color: var(--turmeric);
  margin-right: .3rem
}

/* ── CONSULTING ── */
#consulting {
  padding: 5.5rem 0;
  background: linear-gradient(135deg, #1a1208, #2a180a, #1a0f0a)
}

.consulting-card {
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(245, 166, 35, .2);
  border-radius: 16px;
  padding: 2rem;
  transition: all .35s;
  cursor: pointer;
  height: 100%
}

.consulting-card:hover {
  background: rgba(245, 166, 35, .1);
  border-color: rgba(245, 166, 35, .5);
  transform: translateY(-6px)
}

.cc-icon {
  font-size: 2.2rem;
  margin-bottom: 1rem
}

.cc-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.2rem;
  color: var(--turmeric);
  margin-bottom: .5rem
}

.cc-desc {
  font-size: .84rem;
  color: rgba(255, 255, 255, .5);
  line-height: 1.65
}

.cc-list {
  margin-top: 1rem;
  list-style: none;
  padding: 0
}

.cc-list li {
  font-size: .8rem;
  color: rgba(255, 255, 255, .45);
  padding: .25rem 0;
  display: flex;
  align-items: center;
  gap: .5rem
}

.cc-list li::before {
  content: '✦';
  color: var(--saffron);
  font-size: .55rem
}

.btn-consult {
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  border: none;
  padding: .75rem 2rem;
  border-radius: 2.5rem;
  font-size: .78rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .3s;
  box-shadow: 0 6px 24px rgba(232, 101, 10, .35)
}

.btn-consult:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(232, 101, 10, .5)
}

/* ── FESTIVALS ── */
#festivals {
  padding: 5.5rem 0;
  background: var(--parchment)
}

.festival-card {
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 3/4;
  cursor: pointer
}

.festival-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s
}

.festival-card:hover img {
  transform: scale(1.07)
}

.festival-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0, 0, 0, .8))
}

.festival-info {
  position: absolute;
  bottom: 0;
  padding: 1.4rem
}

.festival-date {
  font-size: .68rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--turmeric);
  margin-bottom: .3rem
}

.festival-name {
  font-family: 'Yeseva One', serif;
  font-size: 1.3rem;
  color: #fff
}

.festival-small {
  font-size: .78rem;
  color: rgba(255, 255, 255, .65);
  margin-top: .2rem
}

.festival-upcoming {
  background: #fff;
  border-radius: 14px;
  padding: 1.5rem;
  border: 1.5px solid var(--smoke)
}

.fu-item {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: .8rem 0;
  border-bottom: 1px solid var(--smoke)
}

.fu-item:last-child {
  border-bottom: none
}

.fu-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--saffron);
  flex-shrink: 0
}

.fu-name {
  font-weight: 500;
  font-size: .88rem;
  color: var(--ink)
}

.fu-date {
  font-size: .76rem;
  color: var(--muted)
}

/* ── WELLNESS BLOG ── */
#blog {
  padding: 5.5rem 0;
  background: var(--pearl)
}

.blog-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  transition: all .35s;
  height: 100%
}

.blog-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0, 0, 0, .1)
}

.blog-img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  transition: transform .5s
}

.blog-card:hover .blog-img {
  transform: scale(1.05)
}

.blog-body {
  padding: 1.4rem
}

.blog-cat {
  font-size: .67rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: .4rem
}

.blog-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.1rem;
  color: var(--ink);
  line-height: 1.3;
  margin-bottom: .5rem
}

.blog-desc {
  font-size: .83rem;
  color: var(--muted);
  line-height: 1.65
}

.blog-footer {
  padding: .9rem 1.4rem;
  border-top: 1px solid var(--smoke);
  display: flex;
  justify-content: space-between;
  align-items: center
}

.blog-time {
  font-size: .72rem;
  color: var(--muted)
}

.blog-time i {
  color: var(--turmeric);
  margin-right: .3rem
}

/* ── TESTIMONIALS ── */
#testimonials {
  padding: 5.5rem 0;
  background: var(--parchment)
}

.testi-slider {
  position: relative;
  overflow: hidden
}

.testi-track {
  display: flex;
  transition: transform .5s ease
}

.testi-item {
  min-width: 33.333%;
  padding: 0 .75rem
}

.testi-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  height: 100%;
  transition: all .3s
}

.testi-card:hover {
  border-color: var(--turmeric);
  box-shadow: 0 12px 40px rgba(232, 101, 10, .1)
}

.testi-quote {
  font-size: 3rem;
  font-family: 'Yeseva One', serif;
  color: var(--turmeric);
  opacity: .3;
  line-height: 1;
  margin-bottom: .4rem
}

.testi-stars {
  color: var(--turmeric);
  font-size: .8rem;
  margin-bottom: .8rem
}

.testi-text {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1.1rem;
  color: var(--ink);
  line-height: 1.7;
  margin-bottom: 1.2rem
}

.testi-name {
  font-weight: 600;
  font-size: .85rem;
  color: var(--ink)
}

.testi-role {
  font-size: .75rem;
  color: var(--saffron)
}

.testi-nav {
  display: flex;
  gap: .5rem;
  justify-content: center;
  margin-top: 1.5rem
}

.testi-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(232, 101, 10, .25);
  cursor: pointer;
  transition: all .3s
}

.testi-dot.active {
  background: var(--saffron);
  width: 24px;
  border-radius: 4px
}

/* ── NEWSLETTER ── */
#newsletter {
  padding: 4.5rem 0;
  background: linear-gradient(135deg, var(--saffron) 0%, var(--lotus) 100%);
  position: relative;
  overflow: hidden
}

#newsletter::before {
  content: 'ॐ';
  position: absolute;
  right: -2rem;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'Yeseva One', serif;
  font-size: 18rem;
  color: rgba(255, 255, 255, .06);
  pointer-events: none
}

.nl-title {
  font-family: 'Yeseva One', serif;
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  color: #fff;
  line-height: 1.15
}

.nl-sub {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1.1rem;
  color: rgba(255, 255, 255, .8);
  margin-top: .6rem
}

.nl-form {
  display: flex;
  background: rgba(255, 255, 255, .15);
  border: 1.5px solid rgba(255, 255, 255, .3);
  border-radius: 3rem;
  padding: .45rem .45rem .45rem 1.5rem;
  max-width: 480px;
  backdrop-filter: blur(8px)
}

.nl-input {
  background: transparent;
  border: none;
  outline: none;
  color: #fff;
  font-family: 'Outfit', sans-serif;
  font-size: .88rem;
  flex: 1
}

.nl-input::placeholder {
  color: rgba(255, 255, 255, .5)
}

.nl-btn {
  background: #fff;
  color: var(--saffron);
  border: none;
  border-radius: 2.5rem;
  padding: .65rem 1.5rem;
  font-size: .76rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: all .3s
}

.nl-btn:hover {
  background: var(--ink);
  color: #fff
}

/* ── FOOTER ── */
footer {
  background: var(--ink);
  padding: 4rem 0 2rem
}

.footer-brand {
  font-family: 'Yeseva One', serif;
  font-size: 2rem;
  color: var(--turmeric)
}

.footer-tagline {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1rem;
  color: rgba(255, 255, 255, .4);
  margin-top: .3rem
}

.footer-desc {
  font-size: .84rem;
  color: rgba(255, 255, 255, .4);
  line-height: 1.7;
  max-width: 260px;
  margin-top: .8rem
}

.footer-h {
  font-size: .68rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--turmeric);
  margin-bottom: 1.1rem
}

.footer-link {
  display: block;
  font-size: .83rem;
  color: rgba(255, 255, 255, .4);
  text-decoration: none;
  margin-bottom: .5rem;
  transition: color .3s
}

.footer-link:hover {
  color: var(--turmeric)
}

.social-row {
  display: flex;
  gap: .7rem;
  margin-top: 1.2rem
}

.soc {
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(245, 166, 35, .2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, .45);
  font-size: .85rem;
  text-decoration: none;
  transition: all .3s
}

.soc:hover {
  background: var(--saffron);
  border-color: var(--saffron);
  color: #fff
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, .07);
  margin-top: 3rem;
  padding-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .7rem
}

.footer-bottom p {
  font-size: .76rem;
  color: rgba(255, 255, 255, .3)
}

/* ── REVEAL ANIMATIONS ── */
.reveal {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity .75s ease, transform .75s ease
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0)
}

.reveal-left {
  opacity: 0;
  transform: translateX(-36px);
  transition: opacity .75s ease, transform .75s ease
}

.reveal-left.visible {
  opacity: 1;
  transform: translateX(0)
}

.reveal-right {
  opacity: 0;
  transform: translateX(36px);
  transition: opacity .75s ease, transform .75s ease
}

.reveal-right.visible {
  opacity: 1;
  transform: translateX(0)
}

/* ── RESPONSIVE ── */
@media(max-width:991px) {
  .has-mega .mega-menu {
    min-width: 320px;
    grid-template-columns: 1fr 1fr
  }

  .testi-item {
    min-width: 100%
  }
}

@media(max-width:767px) {
  .btn-hero-outline {
    margin-left: 0;
    margin-top: .6rem;
    display: block;
    text-align: center
  }

  .nl-form {
    flex-direction: column;
    border-radius: 12px;
    padding: 1rem;
    gap: .6rem
  }

  .nl-btn {
    border-radius: .6rem
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center
  }

  .has-mega .mega-menu {
    min-width: calc(100vw - 2rem);
    grid-template-columns: 1fr
  }
}

.page-hero {
  padding: 7rem 0 5rem;
  position: relative;
  overflow: hidden
}

.breadcrumb-ds .breadcrumb-item a {
  color: rgba(255, 255, 255, .6);
  text-decoration: none;
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase
}

.breadcrumb-ds .breadcrumb-item.active {
  color: var(--turmeric);
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase
}

.breadcrumb-ds .breadcrumb-item+.breadcrumb-item::before {
  color: rgba(255, 255, 255, .35)
}

.hero-tag {
  font-size: .72rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--turmeric);
  display: block;
  margin-bottom: .8rem
}

.hero-title {
  font-family: 'Yeseva One', serif;
  font-size: clamp(2.2rem, 5vw, 4rem);
  color: #fff;
  line-height: 1.1;
  margin-bottom: 1rem;
  text-shadow: 0 2px 20px rgba(0, 0, 0, .3)
}

.hero-sub {
  font-family: 'Crimson Pro', serif;
  font-size: 1.2rem;
  font-style: italic;
  color: rgba(255, 255, 255, .8);
  max-width: 520px;
  line-height: 1.65;
  margin-bottom: 2rem
}

.page-hero-content {
  position: relative;
  z-index: 2
}

.cta-section {
  padding: 5rem 0;
  background: linear-gradient(135deg, var(--saffron), var(--lotus));
  position: relative;
  overflow: hidden
}

.cta-section::before {
  content: 'ॐ';
  position: absolute;
  right: -2rem;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'Yeseva One', serif;
  font-size: 18rem;
  color: rgba(255, 255, 255, .06);
  pointer-events: none
}

.faq-item {
  background: #fff;
  border-radius: 14px;
  margin-bottom: .8rem;
  border: 1.5px solid var(--smoke);
  overflow: hidden;
  transition: border-color .3s
}

.faq-item.open {
  border-color: var(--turmeric)
}

.faq-q {
  padding: 1.3rem 1.5rem;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 500;
  font-size: .92rem;
  color: var(--ink);
  user-select: none
}

.faq-q i {
  color: var(--saffron);
  transition: transform .3s;
  flex-shrink: 0
}

.faq-item.open .faq-q i {
  transform: rotate(180deg)
}

.faq-a {
  padding: 0 1.5rem;
  max-height: 0;
  overflow: hidden;
  transition: all .35s;
  font-size: .86rem;
  color: var(--muted);
  line-height: 1.7
}

.faq-item.open .faq-a {
  max-height: 500px;
  padding-bottom: 1.3rem
}

.pricing-card {
  background: #fff;
  border-radius: 20px;
  padding: 2.5rem;
  border: 2px solid var(--smoke);
  transition: all .35s;
  height: 100%;
  position: relative
}

.pricing-card.featured {
  border-color: var(--saffron);
  box-shadow: 0 20px 60px rgba(232, 101, 10, .15)
}

.price-badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--saffron);
  color: #fff;
  font-size: .68rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .3rem 1.2rem;
  border-radius: 2rem;
  white-space: nowrap
}

.price-icon {
  font-size: 2.5rem;
  margin-bottom: 1rem
}

.price-name {
  font-family: 'Yeseva One', serif;
  font-size: 1.4rem;
  color: var(--ink);
  margin-bottom: .3rem
}

.price-amount {
  font-family: 'Yeseva One', serif;
  font-size: 2.8rem;
  color: var(--saffron);
  line-height: 1
}

.price-period {
  font-size: .8rem;
  color: var(--muted)
}

.price-features {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0
}

.price-features li {
  font-size: .84rem;
  color: var(--muted);
  padding: .4rem 0;
  display: flex;
  align-items: center;
  gap: .6rem;
  border-bottom: 1px solid var(--smoke)
}

.price-features li:last-child {
  border-bottom: none
}

.price-features li i {
  color: var(--sage);
  font-size: .8rem
}

.booking-form-wrap {
  background: #fff;
  border-radius: 20px;
  padding: 2.5rem;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .08)
}

.form-control-ds {
  width: 100%;
  border: 1.5px solid var(--smoke);
  border-radius: 10px;
  padding: .75rem 1rem;
  font-size: .88rem;
  font-family: 'Outfit', sans-serif;
  transition: border-color .3s;
  outline: none;
  background: #fff
}

.form-control-ds:focus {
  border-color: var(--saffron);
  box-shadow: 0 0 0 3px rgba(232, 101, 10, .1)
}

.form-label-ds {
  font-size: .78rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: .4rem;
  display: block
}

.btn-consult {
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  border: none;
  padding: .75rem 2rem;
  border-radius: 2.5rem;
  font-size: .78rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .3s;
  box-shadow: 0 6px 24px rgba(232, 101, 10, .35);
  display: inline-block;
  text-decoration: none
}

.btn-consult:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(232, 101, 10, .5);
  color: #fff
}

.service-radio-card {
  background: #fff;
  border-radius: 12px;
  padding: 1.2rem;
  border: 1.5px solid var(--smoke);
  cursor: pointer;
  transition: all .3s;
  display: flex;
  align-items: flex-start;
  gap: .8rem
}

.service-radio-card.active,
.service-radio-card:hover {
  border-color: var(--saffron);
  background: #fffbf5
}

.service-radio-card .radio-dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--smoke);
  flex-shrink: 0;
  margin-top: .15rem;
  transition: all .3s
}

.service-radio-card.active .radio-dot {
  border-color: var(--saffron);
  background: var(--saffron);
  box-shadow: 0 0 0 3px rgba(232, 101, 10, .15)
}

.blog-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  transition: all .35s;
  height: 100%
}

.blog-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(0, 0, 0, .1)
}

.blog-cat {
  font-size: .67rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: .4rem
}

.blog-title-card {
  font-family: 'Yeseva One', serif;
  font-size: 1.1rem;
  color: var(--ink);
  line-height: 1.3;
  margin-bottom: .5rem
}

.blog-desc {
  font-size: .83rem;
  color: var(--muted);
  line-height: 1.65
}

.blog-body {
  padding: 1.4rem
}

.blog-footer-bar {
  padding: .9rem 1.4rem;
  border-top: 1px solid var(--smoke);
  display: flex;
  justify-content: space-between;
  align-items: center
}

.blog-content-body {
  font-family: 'Crimson Pro', serif;
  font-size: 1.1rem;
  line-height: 1.85;
  color: var(--ink)
}

.blog-content-body h2 {
  font-family: 'Yeseva One', serif;
  font-size: 1.7rem;
  color: var(--ink);
  margin: 2rem 0 .8rem
}

.blog-content-body h3 {
  font-family: 'Yeseva One', serif;
  font-size: 1.25rem;
  color: var(--saffron);
  margin: 1.5rem 0 .6rem
}

.blog-content-body blockquote {
  border-left: 4px solid var(--saffron);
  padding: 1rem 1.5rem;
  background: var(--parchment);
  border-radius: 0 12px 12px 0;
  font-style: italic;
  font-size: 1.1rem;
  margin: 1.5rem 0
}

.testi-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  height: 100%
}

.testi-card:hover {
  border-color: var(--turmeric);
  box-shadow: 0 12px 40px rgba(232, 101, 10, .1)
}

.testi-quote {
  font-size: 3rem;
  font-family: 'Yeseva One', serif;
  color: var(--turmeric);
  opacity: .3;
  line-height: 1;
  margin-bottom: .4rem
}

.testi-stars {
  color: var(--turmeric);
  font-size: .8rem;
  margin-bottom: .8rem
}

.testi-text {
  font-family: 'Crimson Pro', serif;
  font-style: italic;
  font-size: 1.05rem;
  color: var(--ink);
  line-height: 1.7;
  margin-bottom: 1.2rem
}

.testi-name {
  font-weight: 600;
  font-size: .85rem;
  color: var(--ink)
}

.testi-role {
  font-size: .75rem;
  color: var(--saffron)
}

.contact-info-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
  transition: all .3s;
  height: 100%
}

.contact-info-card:hover {
  border-color: var(--turmeric);
  box-shadow: 0 8px 30px rgba(232, 101, 10, .1)
}

.contact-icon {
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.1rem;
  flex-shrink: 0
}

.about-stat-num {
  font-family: 'Yeseva One', serif;
  font-size: 3rem;
  color: var(--saffron);
  line-height: 1
}

.about-stat-label {
  font-size: .82rem;
  color: var(--muted);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-top: .4rem
}

.step-item {
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--smoke)
}

.step-item:last-child {
  border-bottom: none
}

.step-num {
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Yeseva One', serif;
  font-size: 1.1rem;
  flex-shrink: 0
}

.step-title {
  font-weight: 600;
  font-size: .92rem;
  color: var(--ink);
  margin-bottom: .3rem
}

.step-desc {
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.6
}

.policy-section h2 {
  font-family: 'Yeseva One', serif;
  font-size: 1.5rem;
  color: var(--ink);
  margin: 2.5rem 0 .8rem;
  padding-top: 1rem;
  border-top: 1px solid var(--smoke)
}

.policy-section h2:first-child {
  border-top: none;
  padding-top: 0;
  margin-top: 0
}

.policy-section p,
.policy-section ul {
  font-size: .9rem;
  color: var(--muted);
  line-height: 1.8;
  margin-bottom: 1rem
}

.policy-section ul {
  padding-left: 1.5rem
}

.expert-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  text-align: center;
  transition: all .35s;
  height: 100%
}

.expert-card:hover {
  border-color: var(--turmeric);
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(232, 101, 10, .1)
}

.expert-avatar {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  margin: 0 auto 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem
}

.expert-name {
  font-family: 'Yeseva One', serif;
  font-size: 1.15rem;
  color: var(--ink);
  margin-bottom: .3rem
}

.expert-role {
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--saffron)
}

.expert-bio {
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.6;
  margin-top: .8rem
}

.technique-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  transition: all .35s;
  height: 100%
}

.technique-card:hover {
  border-color: var(--turmeric);
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(232, 101, 10, .1)
}
.t-icon{font-size:1.8rem;margin-bottom:.7rem}
.t-title{font-family:'Yeseva One',serif;font-size:1rem;color:var(--ink);margin-bottom:.4rem}
.t-dur{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--saffron);margin-bottom:.6rem}
.t-text{font-size:.82rem;color:var(--muted);line-height:1.65}
.step-box{background:#fff;border-radius:16px;padding:1.8rem;border:1.5px solid var(--smoke);height:100%;transition:all .3s}
.step-box:hover{border-color:var(--turmeric);transform:translateY(-4px);box-shadow:0 12px 40px rgba(232,101,10,.1)}
.step-num{width:44px;height:44px;background:linear-gradient(135deg,var(--saffron),var(--turmeric));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-family:'Yeseva One',serif;font-size:1.1rem;margin-bottom:1rem}
.pill{background:rgba(232,101,10,.1);color:var(--saffron);border-radius:2rem;padding:.28rem .85rem;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;display:inline-block;margin:.2rem}
.stat-box{background:var(--parchment);border-radius:14px;padding:1.5rem;text-align:center}
.stat-num{font-family:'Yeseva One',serif;font-size:2.5rem;color:var(--saffron);line-height:1}
.stat-label{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.3rem}
.team-card{background:#fff;border-radius:18px;padding:2rem;border:1.5px solid var(--smoke);text-align:center;transition:all .3s;height:100%}
.team-card:hover{border-color:var(--turmeric);box-shadow:0 12px 40px rgba(232,101,10,.1)}


/* ── INNER PAGE SHARED ── */
.page-hero {
  padding: 7rem 0 5rem;
  position: relative;
  overflow: hidden
}

.page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(26, 18, 8, .82) 0%, rgba(45, 26, 8, .65) 100%)
}

.page-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center
}

.page-hero-content {
  position: relative;
  z-index: 2
}

.breadcrumb-ds .breadcrumb-item a {
  color: rgba(255, 255, 255, .6);
  text-decoration: none;
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase
}

.breadcrumb-ds .breadcrumb-item.active {
  color: var(--turmeric);
  font-size: .75rem;
  letter-spacing: .12em;
  text-transform: uppercase
}

.breadcrumb-ds .breadcrumb-item+.breadcrumb-item::before {
  color: rgba(255, 255, 255, .35)
}

.hero-tag {
  font-size: .72rem;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--turmeric);
  display: block;
  margin-bottom: .8rem
}

.hero-title {
  font-family: 'Yeseva One', serif;
  font-size: clamp(2.2rem, 5vw, 4rem);
  color: #fff;
  line-height: 1.1;
  margin-bottom: 1rem;
  text-shadow: 0 2px 20px rgba(0, 0, 0, .3)
}

.hero-sub {
  font-family: 'Crimson Pro', serif;
  font-size: 1.2rem;
  font-style: italic;
  color: rgba(255, 255, 255, .8);
  max-width: 520px;
  line-height: 1.65;
  margin-bottom: 2rem
}

.problem-box {
  background: var(--parchment);
  border-left: 4px solid var(--saffron);
  border-radius: 0 12px 12px 0;
  padding: 2rem;
  margin-bottom: 1.5rem
}

.solution-box {
  background: linear-gradient(135deg, #e8f5e9, #f1f8e9);
  border-left: 4px solid var(--sage);
  border-radius: 0 12px 12px 0;
  padding: 2rem
}

.technique-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  border: 1.5px solid var(--smoke);
  transition: all .35s;
  height: 100%
}

.technique-card:hover {
  border-color: var(--turmeric);
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(232, 101, 10, .1)
}

.technique-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 1.2rem
}

.technique-title {
  font-family: 'Yeseva One', serif;
  font-size: 1.1rem;
  color: var(--ink);
  margin-bottom: .5rem
}

.technique-desc {
  font-size: .84rem;
  color: var(--muted);
  line-height: 1.65
}

.step-item {
  display: flex;
  gap: 1.2rem;
  align-items: flex-start;
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--smoke)
}

.step-item:last-child {
  border-bottom: none
}

.step-num {
  width: 44px;
  height: 44px;
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Yeseva One', serif;
  font-size: 1.1rem;
  flex-shrink: 0
}

.step-title {
  font-weight: 600;
  font-size: .92rem;
  color: var(--ink);
  margin-bottom: .3rem
}

.step-desc {
  font-size: .82rem;
  color: var(--muted);
  line-height: 1.6
}

.cta-section {
  padding: 5rem 0;
  background: linear-gradient(135deg, var(--saffron), var(--lotus));
  position: relative;
  overflow: hidden
}

.cta-section::before {
  content: 'ॐ';
  position: absolute;
  right: -2rem;
  top: 50%;
  transform: translateY(-50%);
  font-family: 'Yeseva One', serif;
  font-size: 18rem;
  color: rgba(255, 255, 255, .06);
  pointer-events: none
}

.benefit-item {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: .9rem 0
}

.benefit-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--saffron), var(--turmeric));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  flex-shrink: 0
}

.benefit-text h6 {
  font-size: .9rem;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: .2rem
}

.benefit-text p {
  font-size: .8rem;
  color: var(--muted);
  line-height: 1.5;
  margin: 0
}

.pose-card {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  transition: all .35s;
  height: 100%
}

.pose-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(0, 0, 0, .1)
}

.pose-img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  background: linear-gradient(135deg, var(--smoke), var(--parchment); display:flex; align-items:center; justify-content:center
  }

  .pose-body {
    padding:1.2rem
  }

  .pose-level {
    font-size:.64rem; letter-spacing:.15em; text-transform:uppercase; padding:.25rem .75rem; border-radius:2rem; display:inline-block; margin-bottom:.5rem
  }

  .level-beginner {
    background:#e8f5e9; color:var(--sage)
  }

  .level-intermediate {
    background:#fff3e0; color:#e65100
  }

  .level-advanced {
    background:#fce4ec; color:var(--lotus)
  }

  .pose-name {
    font-family:'Yeseva One', serif; font-size:1.05rem; color:var(--ink); margin-bottom:.3rem
  }

  .pose-sanskrit {
    font-family:'Crimson Pro', serif; font-style:italic; font-size:.9rem; color:var(--muted)
  }

  .audio-player {
    background:rgba(232, 101, 10, .08); border:1.5px solid rgba(232, 101, 10, .2); border-radius:16px; padding:2rem
  }

  .audio-waveform {
    height:48px; background:linear-gradient(90deg, var(--saffron) 30%, var(--smoke) 30%); border-radius:4px; margin:1rem 0; position:relative
  }

  .audio-controls {
    display:flex; align-items:center; gap:1rem
  }

  .btn-play-big {
    width:52px; height:52px; background:linear-gradient(135deg, var(--saffron), var(--turmeric)); border-radius:50%; border:none; color:#fff; font-size:1.1rem; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 6px 20px rgba(232, 101, 10, .35); transition:all .3s
  }

  .btn-play-big:hover {
    transform:scale(1.08); box-shadow:0 10px 28px rgba(232, 101, 10, .5)
  }

  .mantra-detail-box {
    background:linear-gradient(160deg, #1a1208, #2d1a08); border-radius:20px; padding:3rem; border:1px solid rgba(232, 101, 10, .2)
  }

  .mantra-big {
    font-family:'Yeseva One', serif; font-size:clamp(1.8rem, 4vw, 3.2rem); color:var(--turmeric); line-height:1.2; text-shadow:0 0 40px rgba(245, 166, 35, .3)
  }

  .mantra-roman-big {
    font-family:'Crimson Pro', serif; font-style:italic; font-size:1.3rem; color:rgba(255, 255, 255, .55); margin-top:.7rem
  }

  .zodiac-grid {
    display:grid; grid-template-columns:repeat(6, 1fr); gap:.8rem
  }

  @media(max-width:768px) {
    .zodiac-grid {
      grid-template-columns:repeat(4, 1fr)
    }
  }

  @media(max-width:480px) {
    .zodiac-grid {
      grid-template-columns:repeat(3, 1fr)
    }
  }

  .rashi-card-lg {
    background:#fff; border:1.5px solid var(--smoke); border-radius:14px; padding:1rem; text-align:center; cursor:pointer; transition:all .3s
  }

  .rashi-card-lg:hover, .rashi-card-lg.active {
    border-color:var(--turmeric); background:linear-gradient(135deg, #fff8ed, #fff3d6); transform:translateY(-4px)
  }

  .rashi-symbol-lg {
    font-size:2.2rem; margin-bottom:.4rem
  }

  .rashi-name-lg {
    font-size:.78rem; font-weight:500; color:var(--muted)
  }

  .rashi-eng {
    font-size:.65rem; color:var(--saffron)
  }

  .planet-detail-card {
    background:#fff; border-radius:16px; padding:2rem; border:1.5px solid var(--smoke); transition:all .35s; height:100%
  }

  .planet-detail-card:hover {
    border-color:var(--turmeric); transform:translateY(-6px); box-shadow:0 18px 50px rgba(232, 101, 10, .1)
  }

  .planet-sym-lg {
    font-size:3rem; margin-bottom:.8rem
  }

  .remedy-card {
    background:#fff; border-radius:14px; padding:1.8rem; border:1.5px solid var(--smoke); transition:all .3s
  }

  .remedy-card:hover {
    border-color:var(--turmeric); box-shadow:0 10px 30px rgba(232, 101, 10, .1)
  }

  .festival-ritual-step {
    background:var(--parchment); border-radius:12px; padding:1.5rem; margin-bottom:1rem; border-left:4px solid var(--turmeric)
  }

  .pricing-card {
    background:#fff; border-radius:20px; padding:2.5rem; border:2px solid var(--smoke); transition:all .35s; height:100%; position:relative
  }

  .pricing-card.featured {
    border-color:var(--saffron); box-shadow:0 20px 60px rgba(232, 101, 10, .15)
  }

  .pricing-card:hover {
    transform:translateY(-8px); box-shadow:0 24px 64px rgba(232, 101, 10, .12)
  }

  .price-badge {
    position:absolute; top:-14px; left:50%; transform:translateX(-50%); background:var(--saffron); color:#fff; font-size:.68rem; letter-spacing:.15em; text-transform:uppercase; padding:.3rem 1.2rem; border-radius:2rem
  }

  .price-icon {
    font-size:2.5rem; margin-bottom:1rem
  }

  .price-name {
    font-family:'Yeseva One', serif; font-size:1.4rem; color:var(--ink); margin-bottom:.3rem
  }

  .price-amount {
    font-family:'Yeseva One', serif; font-size:2.8rem; color:var(--saffron); line-height:1
  }

  .price-period {
    font-size:.8rem; color:var(--muted)
  }

  .price-features {
    list-style:none; padding:0; margin:1.5rem 0
  }

  .price-features li {
    font-size:.84rem; color:var(--muted); padding:.4rem 0; display:flex; align-items:center; gap:.6rem; border-bottom:1px solid var(--smoke)
  }

  .price-features li:last-child {
    border-bottom:none
  }

  .price-features li i {
    color:var(--sage); font-size:.8rem
  }

  .booking-form-wrap {
    background:#fff; border-radius:20px; padding:2.5rem; box-shadow:0 20px 60px rgba(0, 0, 0, .08)
  }

  .form-control-ds {
    border:1.5px solid var(--smoke); border-radius:10px; padding:.75rem 1rem; font-size:.88rem; font-family:'Outfit', sans-serif; transition:border-color .3s
  }

  .form-control-ds:focus {
    border-color:var(--saffron); box-shadow:0 0 0 3px rgba(232, 101, 10, .1); outline:none
  }

  .form-label-ds {
    font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:.4rem; display:block
  }

  .faq-item {
    background:#fff; border-radius:14px; margin-bottom:.8rem; border:1.5px solid var(--smoke); overflow:hidden; transition:border-color .3s
  }

  .faq-item.open {
    border-color:var(--turmeric)
  }

  .faq-q {
    padding:1.3rem 1.5rem; cursor:pointer; display:flex; justify-content:space-between; align-items:center; font-weight:500; font-size:.92rem; color:var(--ink)
  }

  .faq-q i {
    color:var(--saffron); transition:transform .3s; flex-shrink:0
  }

  .faq-item.open .faq-q i {
    transform:rotate(180deg)
  }

  .faq-a {
    padding:0 1.5rem; max-height:0; overflow:hidden; transition:all .35s; font-size:.86rem; color:var(--muted); line-height:1.7
  }

  .faq-item.open .faq-a {
    max-height:300px; padding-bottom:1.3rem
  }

  .blog-detail-hero {
    padding:8rem 0 5rem; background:linear-gradient(160deg, #1a1208, #2d1a08); position:relative
  }

  .blog-content-body {
    font-family:'Crimson Pro', serif; font-size:1.15rem; line-height:1.85; color:var(--ink)
  }

  .blog-content-body h2 {
    font-family:'Yeseva One', serif; font-size:1.8rem; color:var(--ink); margin:2rem 0 1rem
  }

  .blog-content-body h3 {
    font-family:'Yeseva One', serif; font-size:1.35rem; color:var(--saffron); margin:1.5rem 0 .8rem
  }

  .blog-content-body blockquote {
    border-left:4px solid var(--saffron); padding:1rem 1.5rem; background:var(--parchment); border-radius:0 12px 12px 0; font-style:italic; font-size:1.2rem; margin:1.5rem 0
  }

  .author-box {
    background:var(--parchment); border-radius:16px; padding:2rem; display:flex; gap:1.5rem; align-items:flex-start
  }

  .author-avatar {
    width:80px; height:80px; border-radius:50%; background:linear-gradient(135deg, var(--saffron), var(--turmeric)); display:flex; align-items:center; justify-content:center; font-family:'Yeseva One', serif; font-size:2rem; color:#fff; flex-shrink:0
  }

  .event-schedule-row {
    display:flex; gap:1.5rem; align-items:flex-start; padding:1.2rem 0; border-bottom:1px solid var(--smoke)
  }

  .event-schedule-time {
    min-width:100px; font-family:'Yeseva One', serif; font-size:.95rem; color:var(--saffron)
  }

  .instructor-card {
    background:#fff; border-radius:16px; padding:2rem; border:1.5px solid var(--smoke); text-align:center; transition:all .35s
  }

  .instructor-card:hover {
    border-color:var(--turmeric); transform:translateY(-6px); box-shadow:0 18px 50px rgba(232, 101, 10, .1)
  }

  .instructor-avatar {
    width:90px; height:90px; border-radius:50%; background:linear-gradient(135deg, var(--parchment), var(--smoke)); margin:0 auto 1rem; display:flex; align-items:center; justify-content:center; font-size:2.5rem
  }

  .contact-info-card {
    background:#fff; border-radius:16px; padding:2rem; border:1.5px solid var(--smoke); display:flex; gap:1.2rem; align-items:flex-start; transition:all .3s
  }

  .contact-info-card:hover {
    border-color:var(--turmeric); box-shadow:0 8px 30px rgba(232, 101, 10, .1)
  }

  .contact-icon {
    width:52px; height:52px; background:linear-gradient(135deg, var(--saffron), var(--turmeric)); border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-size:1.1rem; flex-shrink:0
  }

  .about-stat {
    text-align:center; padding:2rem
  }

  .about-stat-num {
    font-family:'Yeseva One', serif; font-size:3rem; color:var(--saffron); line-height:1
  }

  .about-stat-label {
    font-size:.82rem; color:var(--muted); letter-spacing:.12em; text-transform:uppercase; margin-top:.4rem
  }

  .expert-card {
    background:#fff; border-radius:16px; padding:2rem; border:1.5px solid var(--smoke); text-align:center; transition:all .35s
  }

  .expert-card:hover {
    border-color:var(--turmeric); transform:translateY(-6px); box-shadow:0 18px 50px rgba(232, 101, 10, .1)
  }

  .expert-avatar {
    width:100px; height:100px; border-radius:50%; background:linear-gradient(135deg, var(--saffron), var(--turmeric)); margin:0 auto 1.2rem; display:flex; align-items:center; justify-content:center; font-size:3rem
  }

  .expert-name {
    font-family:'Yeseva One', serif; font-size:1.15rem; color:var(--ink); margin-bottom:.3rem
  }

  .expert-role {
    font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--saffron)
  }

  .expert-bio {
    font-size:.82rem; color:var(--muted); line-height:1.6; margin-top:.8rem
  }