/* ============================================
   Om Sacred Space — v2 Professional Redesign
   Design System: Unified spiritual aesthetic
   Palette: Deep indigo + warm gold accents
   ============================================ */

/* --- RESET & TOKENS --- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  /* Color palette — cohesive indigo/gold spiritual theme */
  --bg-deep:    #0c0a1d;
  --bg-dark:    #110e2a;
  --bg-card:    rgba(255,255,255,0.04);
  --bg-cream:   #f7f4ef;
  --bg-accent:  #1a1145;

  --text-primary:   #f0ece4;
  --text-secondary: #a8a0b8;
  --text-dark:      #2a2540;
  --text-muted:     #7a7290;

  --gold:       #c9a96e;
  --gold-light: #e8d5a8;
  --gold-glow:  rgba(201,169,110,0.15);
  --accent:     #8b6cc1;
  --accent-soft: rgba(139,108,193,0.12);

  --radius:     16px;
  --radius-sm:  10px;
  --radius-lg:  24px;
  --radius-xl:  32px;

  --font-heading: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Inter', -apple-system, sans-serif;

  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 48px;
  --space-xl: 80px;
  --space-2xl: 120px;

  --transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --glow-intensity: 0.5;
}

html { scroll-behavior: smooth; scroll-padding-top: 80px; }
body {
  font-family: var(--font-body); color: var(--text-primary);
  background: var(--bg-deep); line-height: 1.6; font-size: 16px;
  -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
body.no-scroll { overflow: hidden; }
a { color: var(--gold); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--gold-light); }
img { max-width: 100%; display: block; }
ul { list-style: none; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.rounded-img { border-radius: var(--radius-lg); }

/* --- TYPOGRAPHY --- */
h1, h2, h3, h4, h5 { font-family: var(--font-heading); font-weight: 600; line-height: 1.2; }
h1 { font-size: clamp(48px, 7vw, 88px); letter-spacing: -0.02em; }
h1 em { font-style: italic; font-weight: 400; color: var(--gold); }
h2 { font-size: clamp(32px, 4vw, 52px); letter-spacing: -0.01em; margin-bottom: var(--space-md); }
h3 { font-size: clamp(20px, 2.5vw, 28px); }
.eyebrow {
  font-family: var(--font-body); font-size: 13px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.15em; color: var(--gold);
  margin-bottom: var(--space-sm);
}
.eyebrow--light { color: var(--gold-light); }

/* --- SCROLL REVEAL --- */
.reveal {
  opacity: 0; transform: translateY(40px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.revealed { opacity: 1; transform: translateY(0); }

/* --- BUTTONS --- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  padding: 14px 32px; border-radius: 999px; cursor: pointer;
  transition: all var(--transition); border: none; text-decoration: none;
}
.btn--primary {
  background: var(--gold); color: var(--bg-deep);
}
.btn--primary:hover { background: var(--gold-light); color: var(--bg-deep); transform: translateY(-2px); box-shadow: 0 8px 30px var(--gold-glow); }
.btn--ghost {
  background: transparent; color: var(--text-primary);
  border: 1px solid rgba(255,255,255,0.2);
}
.btn--ghost:hover { border-color: var(--gold); color: var(--gold); }
.btn--sm { padding: 10px 24px; font-size: 13px; }
.btn--full { width: 100%; }

/* --- HEADER --- */
.header {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 1000;
  background: transparent; transition: all var(--transition);
}
.header--scrolled {
  background: rgba(12,10,29,0.92); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.header--hidden { transform: translateY(-100%); }
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px; gap: 32px;
}
.nav__logo {
  font-family: var(--font-heading); font-size: 22px; font-weight: 700;
  color: var(--text-primary); white-space: nowrap; letter-spacing: -0.01em;
}
.nav__logo:hover { color: var(--gold); }
.nav__links { display: flex; gap: 32px; }
.nav__link {
  font-size: 14px; color: var(--text-secondary); font-weight: 400;
  position: relative; padding: 4px 0;
}
.nav__link::after {
  content: ''; position: absolute; bottom: -2px; left: 0; width: 0; height: 1px;
  background: var(--gold); transition: width var(--transition);
}
.nav__link:hover, .nav__link--active { color: var(--text-primary); }
.nav__link:hover::after, .nav__link--active::after { width: 100%; }
.nav__link--book { color: var(--gold); font-weight: 500; }
.nav__link--book:hover { color: var(--gold-light); }
.nav__link--yt { display: inline-flex; align-items: center; color: #ff0000; transition: all var(--transition); }
.nav__link--yt:hover { color: #ff0000; filter: drop-shadow(0 0 6px #ff0000) drop-shadow(0 0 12px #ff6b00) drop-shadow(0 0 18px #ffdd00); }
.nav__link--yt::after { display: none; }
.nav__cta {
  font-size: 13px; font-weight: 500; padding: 10px 24px; border-radius: 999px;
  background: var(--gold); color: var(--bg-deep); white-space: nowrap;
  transition: all var(--transition);
}
.nav__cta:hover { background: var(--gold-light); color: var(--bg-deep); transform: translateY(-1px); }
.burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.burger span { width: 22px; height: 1.5px; background: var(--text-primary); transition: all var(--transition); transform-origin: center; }
.burger--open span:nth-child(1) { transform: rotate(45deg) translate(4.5px, 4.5px); }
.burger--open span:nth-child(2) { opacity: 0; }
.burger--open span:nth-child(3) { transform: rotate(-45deg) translate(4.5px, -4.5px); }

/* --- HERO --- */
.hero {
  position: relative; min-height: 100vh; display: flex; align-items: center;
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center 58%;
}
.hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(12,10,29,0.3) 0%, rgba(12,10,29,0.7) 60%, var(--bg-deep) 100%);
}
.hero__content { position: relative; z-index: 2; padding: var(--space-2xl) 0; }
.hero__eyebrow {
  font-size: 14px; font-weight: 400; letter-spacing: 0.12em;
  color: var(--gold); margin-bottom: var(--space-md);
}
.hero__sub {
  font-family: var(--font-heading); font-size: clamp(18px, 2.5vw, 24px);
  font-style: italic; font-weight: 400; color: var(--text-secondary);
  margin: var(--space-md) 0 var(--space-lg); max-width: 500px;
}
.hero__actions { display: flex; gap: 16px; flex-wrap: wrap; }

/* --- SECTIONS --- */
.section { padding: var(--space-2xl) 0; }
.section--dark { background: var(--bg-dark); }
.section--cream { background: var(--bg-cream); color: var(--text-dark); }
.section--cream .eyebrow { color: var(--accent); }
.section--cream h2 { color: var(--text-dark); }
.section--cream p { color: var(--text-muted); }
.section--accent { background: var(--bg-accent); }
.section-header { text-align: center; max-width: 640px; margin: 0 auto var(--space-xl); }
.section-header__sub { color: var(--text-secondary); font-size: 16px; margin-top: var(--space-sm); }
.section--cream .section-header__sub { color: var(--text-muted); }

/* --- SPLIT LAYOUT --- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); align-items: center; }
.split--reverse { direction: rtl; }
.split--reverse > * { direction: ltr; }
.split__text p { color: var(--text-secondary); margin-bottom: var(--space-sm); font-size: 15px; }
.split__text h2 { margin-bottom: var(--space-md); }

/* --- VIDEO --- */
.video-wrap { aspect-ratio: 16/9; border-radius: var(--radius-lg); overflow: hidden; }
.yt-thumb { position: relative; cursor: pointer; width: 100%; height: 100%; }
.yt-thumb img { width: 100%; height: 100%; object-fit: cover; }
.play-btn {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 72px; height: 72px; border-radius: 50%;
  background: rgba(255,255,255,0.15); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-primary); transition: all var(--transition);
}
.play-btn svg { width: 28px; height: 28px; margin-left: 3px; }
.yt-thumb:hover .play-btn { background: var(--gold); color: var(--bg-deep); transform: translate(-50%,-50%) scale(1.1); }

/* --- MARQUEE --- */
.marquee {
  background: var(--gold); color: var(--bg-deep); padding: 14px 0;
  overflow: hidden; white-space: nowrap;
}
.marquee__track {
  display: inline-flex; gap: 48px;
  animation: marquee 30s linear infinite;
  font-family: var(--font-heading); font-size: 18px; font-weight: 600;
}
.marquee__track span { flex-shrink: 0; }
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* --- CARDS (Distance Healing) --- */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: var(--space-xl); }
.card {
  background: var(--text-primary); border-radius: var(--radius-lg); overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition);
  position: relative;
}
.card:hover { transform: translateY(-6px); box-shadow: 0 20px 60px rgba(0,0,0,0.15); }
.card--featured { border: 2px solid var(--accent); }
.card__badge {
  position: absolute; top: 16px; right: 16px; z-index: 2;
  background: var(--accent); color: white; font-size: 11px; font-weight: 600;
  padding: 5px 14px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.08em;
}
.card__img { height: 200px; overflow: hidden; }
.card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.card:hover .card__img img { transform: scale(1.05); }
.card__body { padding: var(--space-md); }
.card__body h3 { color: var(--text-dark); margin-bottom: var(--space-xs); }
.card__price { font-size: 22px; font-weight: 600; color: var(--text-dark); margin-bottom: var(--space-sm); font-family: var(--font-heading); }
.card__price span { font-size: 14px; font-weight: 400; color: var(--text-muted); }
.card__body ul { font-size: 14px; color: var(--text-muted); }
.card__body li { padding: 6px 0; border-bottom: 1px solid rgba(0,0,0,0.06); padding-left: 16px; position: relative; }
.card__body li::before { content: '·'; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.card__body li:last-child { border-bottom: none; }

/* --- DONATION BANNER --- */
.donation-banner {
  display: flex; align-items: center; gap: var(--space-lg);
  background: white; border-radius: var(--radius-lg); padding: var(--space-md);
  margin-bottom: var(--space-lg);
}
.donation-banner img { width: 200px; height: 140px; object-fit: cover; border-radius: var(--radius); flex-shrink: 0; }
.donation-banner h3 { color: var(--text-dark); margin-bottom: var(--space-xs); }
.donation-banner p { color: var(--text-muted); font-size: 15px; margin-bottom: var(--space-sm); }
.fine-print { text-align: center; font-size: 13px; color: var(--text-muted); }
.section--cream .fine-print a { color: var(--accent); }

/* --- PRICING INFO --- */
.pricing-info {
  display: flex; justify-content: center; align-items: center; gap: var(--space-lg);
  margin-bottom: var(--space-xl); padding: var(--space-md) var(--space-lg);
  background: var(--bg-card); border: 1px solid rgba(255,255,255,0.06);
  border-radius: var(--radius-lg);
}
.pricing-info__item { text-align: center; }
.pricing-info__item span { display: block; font-size: 13px; color: var(--text-secondary); margin-bottom: 4px; }
.pricing-info__item strong { font-family: var(--font-heading); font-size: 24px; color: var(--gold); }
.pricing-info__item small { display: block; font-size: 12px; color: var(--text-muted); margin-top: 2px; }
.pricing-info__divider { width: 1px; height: 48px; background: rgba(255,255,255,0.08); }

/* --- COMPARE TABS --- */
.compare-tabs { display: flex; gap: 8px; justify-content: center; margin-bottom: var(--space-lg); flex-wrap: wrap; }
.compare-tab {
  font-family: var(--font-body); font-size: 13px; font-weight: 500;
  padding: 8px 20px; border-radius: 999px; cursor: pointer;
  background: var(--bg-card); border: 1px solid rgba(255,255,255,0.08);
  color: var(--text-secondary); transition: all var(--transition);
}
.compare-tab:hover { border-color: var(--gold); color: var(--text-primary); }
.compare-tab--active { background: var(--gold); color: var(--bg-deep); border-color: var(--gold); }

/* --- COMPARE TABLE --- */
.compare-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; margin-bottom: var(--space-lg); border-radius: var(--radius-lg); }
.compare__table {
  width: 100%; min-width: 900px; border-collapse: separate; border-spacing: 0;
  font-size: 14px; background: var(--bg-card); border-radius: var(--radius-lg);
  border: 1px solid rgba(255,255,255,0.06);
}
.compare__table thead { position: sticky; top: 0; z-index: 2; }
.compare__table th {
  padding: 20px 14px; text-align: center; vertical-align: bottom;
  background: var(--bg-accent); border-bottom: 1px solid rgba(255,255,255,0.08);
  font-weight: 400;
}
.compare__corner {
  text-align: left !important; font-weight: 600; color: var(--text-muted);
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.1em;
  position: sticky; left: 0; z-index: 3; background: var(--bg-accent); min-width: 180px;
}
.compare__icon { display: block; font-size: 28px; margin-bottom: 6px; }
.compare__name { display: block; font-family: var(--font-heading); font-size: 16px; font-weight: 600; color: var(--text-primary); margin-bottom: 2px; }
.compare__for { display: block; font-size: 11px; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.compare__recommended { background: rgba(180,120,255,0.08) !important; }
.compare__rec-badge {
  display: inline-block; font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.08em; padding: 3px 10px; border-radius: 999px; margin-bottom: 8px;
  background: linear-gradient(135deg, #b478ff, #64c8ff); color: var(--bg-deep);
}
.compare__table tbody td {
  padding: 12px 14px; text-align: center; border-bottom: 1px solid rgba(255,255,255,0.04);
  color: var(--text-muted); transition: background 0.2s;
}
.compare__table tbody td:first-child {
  text-align: left; font-weight: 500; color: var(--text-secondary);
  position: sticky; left: 0; background: var(--bg-dark); z-index: 1; min-width: 180px;
}
.compare__table tbody tr:hover td { background: rgba(255,255,255,0.02); }
.compare__table tbody tr:hover td:first-child { background: var(--bg-accent); }
.compare__group-row td {
  font-size: 11px !important; font-weight: 600 !important; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--gold) !important; text-align: left !important;
  padding: 16px 14px 8px !important; background: var(--bg-dark) !important;
  border-bottom: 1px solid rgba(201,169,110,0.1) !important;
}
.compare__table tfoot td {
  padding: 20px 14px; text-align: center; background: var(--bg-accent);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.compare__table tfoot td:first-child { position: sticky; left: 0; z-index: 1; }

/* Checkmark styling */
.compare__table tbody td:not(:first-child) { font-size: 15px; }
.compare__table tbody td:not(:first-child):not(.compare__recommended) { color: var(--text-muted); }

/* --- PROGRAMS GRID (kept for other themes) --- */
.programs-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.program {
  background: var(--bg-card); border: 1px solid rgba(255,255,255,0.06);
  border-radius: var(--radius-lg); padding: var(--space-md);
  transition: all var(--transition);
}
.program:hover { border-color: rgba(201,169,110,0.2); background: rgba(255,255,255,0.06); }
.program--wide { grid-column: 1 / -1; }
.program__icon { font-size: 28px; margin-bottom: var(--space-sm); }
.program h3 { color: var(--text-primary); margin-bottom: var(--space-sm); font-size: 20px; }
.program ul { font-size: 14px; color: var(--text-secondary); }
.program li { padding: 5px 0 5px 20px; position: relative; }
.program li::before { content: '—'; position: absolute; left: 0; color: var(--gold); font-size: 12px; }
.program__list--inline { columns: 2; column-gap: var(--space-lg); }

/* --- BENEFITS LIST --- */
.benefits-list { margin-top: var(--space-sm); }
.benefits-list li {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; font-size: 15px; color: var(--text-secondary);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.benefits-list li:last-child { border-bottom: none; }
.benefit-icon { color: var(--gold); font-size: 12px; flex-shrink: 0; }

/* --- FAQ --- */
.faq { max-width: 800px; margin: 0 auto; }
.faq__item {
  border-bottom: 1px solid rgba(42,37,64,0.1);
}
.faq__item summary {
  padding: 22px 0; cursor: pointer; font-size: 17px; font-weight: 500;
  font-family: var(--font-heading); color: var(--text-dark);
  list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq__item summary::after {
  content: '+'; font-size: 22px; color: var(--accent); flex-shrink: 0;
  width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: var(--accent-soft); transition: all var(--transition);
}
.faq__item[open] summary::after { content: '\2212'; background: var(--accent); color: white; }
.faq__item summary::-webkit-details-marker { display: none; }
.faq__answer {
  padding: 0 0 22px; font-size: 15px; color: var(--text-muted); line-height: 1.7;
  animation: fadeIn 0.3s ease;
}
@keyframes fadeIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }

/* --- CONTACT --- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); }
.contact-info img { border-radius: var(--radius-lg); margin-bottom: var(--space-md); }
.contact-info__details p { margin-bottom: var(--space-sm); font-size: 15px; color: var(--text-secondary); }
.contact-info__details a { color: var(--gold); }
.contact-info__details strong { color: var(--text-primary); }
.social-links { display: flex; gap: 16px; margin-top: var(--space-xs); }
.social-links a {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--bg-card); border: 1px solid rgba(255,255,255,0.08);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary); transition: all var(--transition);
}
.social-links a:hover { background: var(--gold); color: var(--bg-deep); border-color: var(--gold); }

/* --- FORM --- */
.form {
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-xl); padding: var(--space-lg);
}
.form__group { margin-bottom: var(--space-md); }
.form__group label {
  display: block; font-size: 13px; font-weight: 500; color: var(--text-secondary);
  margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.05em;
}
.form__group input, .form__group textarea {
  width: 100%; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-sm); padding: 14px 16px; font-size: 15px;
  font-family: var(--font-body); color: var(--text-primary); outline: none;
  transition: all var(--transition);
}
.form__group input::placeholder, .form__group textarea::placeholder { color: var(--text-muted); }
.form__group input:focus, .form__group textarea:focus { border-color: var(--gold); background: rgba(201,169,110,0.04); }
.form__group textarea { min-height: 140px; resize: vertical; }
.form__success {
  display: none; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: var(--space-xl) 0; gap: var(--space-sm);
}
.form__success-icon { font-size: 40px; color: var(--gold); }
.form__success h3 { color: var(--text-primary); }
.form__success p { color: var(--text-secondary); }

/* --- FOOTER --- */
.footer {
  background: var(--bg-deep); padding: var(--space-lg) 0;
  border-top: 1px solid rgba(255,255,255,0.05);
}
.footer__inner {
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: var(--space-md);
}
.footer__logo { font-family: var(--font-heading); font-size: 20px; font-weight: 700; color: var(--text-primary); }
.footer__tagline { font-size: 13px; color: var(--text-muted); }
.footer__links { display: flex; gap: 24px; }
.footer__links a { font-size: 13px; color: var(--text-secondary); }
.footer__links a:hover { color: var(--gold); }
.footer__legal { text-align: right; }
.footer__legal p { font-size: 12px; color: var(--text-muted); }

/* --- THEME PANEL TRIGGER --- */
.theme-panel-trigger {
  width: 32px; height: 32px; border-radius: 50%; cursor: pointer; flex-shrink: 0;
  border: 2px solid rgba(255,255,255,0.15); padding: 0;
  background: conic-gradient(#c9a96e, #5a9e6e, #4a8ab0, #8b6cc1, #b06a88, #a08050, #c9a96e);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  animation: triggerSpin 8s linear infinite;
}
.theme-panel-trigger:hover { transform: scale(1.15); border-color: #fff; box-shadow: 0 0 16px rgba(201,169,110,0.3); }
@keyframes triggerSpin { from { filter: hue-rotate(0deg); } to { filter: hue-rotate(360deg); } }
[data-theme="light"] .theme-panel-trigger,
[data-theme="sand"] .theme-panel-trigger { border-color: rgba(0,0,0,0.15); }
[data-theme="light"] .theme-panel-trigger:hover,
[data-theme="sand"] .theme-panel-trigger:hover { border-color: rgba(0,0,0,0.4); box-shadow: 0 0 16px rgba(0,0,0,0.1); }

/* --- THEME PANEL --- */
.tp {
  position: fixed; top: 0; right: -380px; width: 360px; height: 100vh;
  background: #18152e; border-left: 1px solid rgba(255,255,255,0.08);
  z-index: 2000; padding: 24px; overflow-y: auto;
  transition: right 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  font-family: var(--font-body);
}
.tp--open { right: 0; }
.tp__backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 1999; opacity: 0; pointer-events: none; transition: opacity 0.3s; }
.tp__backdrop--open { opacity: 1; pointer-events: auto; }
.tp__header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 28px; }
.tp__header h4 { font-family: var(--font-heading); font-size: 22px; color: #f0ece4; }
.tp__close { background: none; border: none; color: #a8a0b8; font-size: 28px; cursor: pointer; padding: 0; line-height: 1; transition: color 0.2s; }
.tp__close:hover { color: #f0ece4; }
.tp__section { margin-bottom: 28px; }
.tp__label { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: #a8a0b8; margin-bottom: 12px; display: flex; justify-content: space-between; align-items: center; }

.tp__presets { display: flex; flex-direction: column; gap: 6px; }
.tp__preset {
  display: flex; align-items: center; gap: 12px; padding: 10px 14px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; cursor: pointer; color: #a8a0b8; font-size: 14px;
  font-family: var(--font-body); transition: all 0.2s; text-align: left; width: 100%;
}
.tp__preset:hover { background: rgba(255,255,255,0.06); color: #f0ece4; }
.tp__preset--active { border-color: #c9a96e; color: #c9a96e; background: rgba(201,169,110,0.08); }
.tp__swatch { width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0; border: 1px solid rgba(255,255,255,0.1); }
.tp__swatch--sm { width: 20px; height: 20px; border-radius: 6px; }

.tp__slider-wrap { display: flex; align-items: center; gap: 12px; }
.tp__slider {
  flex: 1; -webkit-appearance: none; appearance: none; height: 4px;
  background: rgba(255,255,255,0.1); border-radius: 4px; outline: none;
}
.tp__slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 16px; height: 16px; border-radius: 50%;
  background: #c9a96e; cursor: pointer; border: 2px solid #18152e;
}
.tp__slider::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: #c9a96e; cursor: pointer; border: 2px solid #18152e;
}
.tp__slider-val { font-size: 13px; color: #c9a96e; min-width: 36px; text-align: right; }


/* ============================================
   THEME: LIGHT (Sacred Light)
   ============================================ */
[data-theme="light"] {
  --bg-deep:#faf8f5;--bg-dark:#f2efe9;--bg-card:rgba(0,0,0,0.03);--bg-cream:#ffffff;--bg-accent:#eee9f5;
  --text-primary:#2a2540;--text-secondary:#5a5270;--text-dark:#1a1530;--text-muted:#8a8498;
  --gold:#9a7b4f;--gold-light:#7a6040;--gold-glow:rgba(154,123,79,0.12);--accent:#7b5ea8;--accent-soft:rgba(123,94,168,0.1);
}

/* ============================================
   THEME: FOREST TEMPLE
   ============================================ */
[data-theme="forest"] {
  --bg-deep:#0a1a12;--bg-dark:#0f2618;--bg-card:rgba(255,255,255,0.04);--bg-cream:#f0f5f1;--bg-accent:#122e1c;
  --text-primary:#e0ece4;--text-secondary:#8aab96;--text-dark:#1a3024;--text-muted:#6a8a76;
  --gold:#a8c47a;--gold-light:#c4dc9e;--gold-glow:rgba(168,196,122,0.15);--accent:#5a9e6e;--accent-soft:rgba(90,158,110,0.12);
}

/* ============================================
   THEME: OCEAN DEPTH
   ============================================ */
[data-theme="ocean"] {
  --bg-deep:#0a1520;--bg-dark:#0c1e2e;--bg-card:rgba(255,255,255,0.04);--bg-cream:#eef4f8;--bg-accent:#102a3e;
  --text-primary:#dce8f0;--text-secondary:#7aa0b8;--text-dark:#142838;--text-muted:#5a8098;
  --gold:#6ab0d4;--gold-light:#92c8e4;--gold-glow:rgba(106,176,212,0.15);--accent:#4a8ab0;--accent-soft:rgba(74,138,176,0.12);
}

/* ============================================
   THEME: ROSE QUARTZ
   ============================================ */
[data-theme="rose"] {
  --bg-deep:#1d0f18;--bg-dark:#2a1520;--bg-card:rgba(255,255,255,0.04);--bg-cream:#f8f0f3;--bg-accent:#321a28;
  --text-primary:#f0dce4;--text-secondary:#b88a9e;--text-dark:#3a1a28;--text-muted:#987080;
  --gold:#d4a0b4;--gold-light:#e4b8c8;--gold-glow:rgba(212,160,180,0.15);--accent:#b06a88;--accent-soft:rgba(176,106,136,0.12);
}

/* ============================================
   THEME: DESERT SAND
   ============================================ */
[data-theme="sand"] {
  --bg-deep:#f5f0e8;--bg-dark:#ebe4d8;--bg-card:rgba(0,0,0,0.03);--bg-cream:#ffffff;--bg-accent:#e8e0d0;
  --text-primary:#3a3020;--text-secondary:#6a5e4a;--text-dark:#2a2418;--text-muted:#8a7e6a;
  --gold:#a08050;--gold-light:#806540;--gold-glow:rgba(160,128,80,0.12);--accent:#8a6a3a;--accent-soft:rgba(138,106,58,0.1);
}

/* ============================================
   THEME: DIVINE LIGHTS
   ============================================ */
[data-theme="divine"] {
  --bg-deep:#0a0818;--bg-dark:#0e0c20;--bg-card:rgba(255,255,255,0.03);--bg-cream:#0f0d22;--bg-accent:#110e28;
  --text-primary:#e8e0f8;--text-secondary:#a898c8;--text-dark:#e0d8f0;--text-muted:#8878a8;
  --gold:#d4a8ff;--gold-light:#e8c8ff;--gold-glow:rgba(180,120,255,0.2);--accent:#80b8ff;--accent-soft:rgba(128,184,255,0.1);
}

/* Divine Lights — deep glow backgrounds */
[data-theme="divine"] .section--dark {
  background: radial-gradient(ellipse at 20% 50%, rgba(100,60,180,0.08) 0%, transparent 60%),
              radial-gradient(ellipse at 80% 50%, rgba(60,140,220,0.06) 0%, transparent 60%),
              var(--bg-dark);
}
[data-theme="divine"] .section--cream {
  background: radial-gradient(ellipse at 30% 30%, rgba(180,120,255,0.06) 0%, transparent 50%),
              radial-gradient(ellipse at 70% 70%, rgba(100,200,255,0.05) 0%, transparent 50%),
              var(--bg-cream);
  color: var(--text-primary);
}
[data-theme="divine"] .section--cream .eyebrow { color: var(--gold); }
[data-theme="divine"] .section--cream h2 { color: var(--text-primary); }
[data-theme="divine"] .section--cream p { color: var(--text-secondary); }
[data-theme="divine"] .section--cream .section-header__sub { color: var(--text-secondary); }
[data-theme="divine"] .section--accent {
  background: radial-gradient(ellipse at 50% 0%, rgba(180,120,255,0.1) 0%, transparent 50%),
              radial-gradient(ellipse at 50% 100%, rgba(100,200,255,0.08) 0%, transparent 50%),
              var(--bg-accent);
}

/* Divine Lights — spinning LED behind cards */
@property --angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}
@keyframes spinGlow { to { --angle: 360deg; } }

[data-theme="divine"] .cards { overflow: visible; }
[data-theme="divine"] .card {
  --angle: 0deg;
  background: rgba(12,8,28,1);
  border: none; position: relative;
  box-shadow: 0 0 0 transparent;
  overflow: hidden;
}

/* The LED glow — behind the card as a shadow */
[data-theme="divine"] .card:hover {
  box-shadow:
    0 0 15px 2px rgba(255,107,107,0.3),
    0 0 15px 2px rgba(255,217,61,0.3),
    0 0 15px 2px rgba(107,255,107,0.3),
    0 0 15px 2px rgba(107,212,255,0.3),
    0 0 15px 2px rgba(180,107,255,0.3),
    0 0 15px 2px rgba(255,107,180,0.3);
  animation: shadowSpin 2.5s linear infinite;
}
[data-theme="divine"] .card--featured {
  box-shadow:
    0 0 10px 1px rgba(180,107,255,0.15),
    0 0 10px 1px rgba(107,212,255,0.1);
  animation: shadowSpin 4s linear infinite;
}
[data-theme="divine"] .card--featured:hover {
  box-shadow:
    0 0 15px 2px rgba(255,107,107,0.3),
    0 0 15px 2px rgba(255,217,61,0.3),
    0 0 15px 2px rgba(107,255,107,0.3),
    0 0 15px 2px rgba(107,212,255,0.3),
    0 0 15px 2px rgba(180,107,255,0.3),
    0 0 15px 2px rgba(255,107,180,0.3);
  animation-duration: 2.5s;
}
@keyframes shadowSpin {
  0%   { box-shadow: 0 -8px 15px -3px rgba(255,107,107,var(--glow-intensity)), 8px 0 15px -3px rgba(255,217,61,var(--glow-intensity)), 0 8px 15px -3px rgba(107,255,107,var(--glow-intensity)), -8px 0 15px -3px rgba(107,212,255,var(--glow-intensity)); }
  25%  { box-shadow: 0 -8px 15px -3px rgba(255,217,61,var(--glow-intensity)), 8px 0 15px -3px rgba(107,255,107,var(--glow-intensity)), 0 8px 15px -3px rgba(107,212,255,var(--glow-intensity)), -8px 0 15px -3px rgba(180,107,255,var(--glow-intensity)); }
  50%  { box-shadow: 0 -8px 15px -3px rgba(107,255,107,var(--glow-intensity)), 8px 0 15px -3px rgba(107,212,255,var(--glow-intensity)), 0 8px 15px -3px rgba(180,107,255,var(--glow-intensity)), -8px 0 15px -3px rgba(255,107,180,var(--glow-intensity)); }
  75%  { box-shadow: 0 -8px 15px -3px rgba(107,212,255,var(--glow-intensity)), 8px 0 15px -3px rgba(180,107,255,var(--glow-intensity)), 0 8px 15px -3px rgba(255,107,180,var(--glow-intensity)), -8px 0 15px -3px rgba(255,107,107,var(--glow-intensity)); }
  100% { box-shadow: 0 -8px 15px -3px rgba(255,107,107,var(--glow-intensity)), 8px 0 15px -3px rgba(255,217,61,var(--glow-intensity)), 0 8px 15px -3px rgba(107,255,107,var(--glow-intensity)), -8px 0 15px -3px rgba(107,212,255,var(--glow-intensity)); }
}

[data-theme="divine"] .card__body h3 { color: var(--text-primary); }
[data-theme="divine"] .card__price { color: var(--gold); }
[data-theme="divine"] .card__price span { color: var(--text-muted); }
[data-theme="divine"] .card__body ul { color: var(--text-secondary); }
[data-theme="divine"] .card__body li { border-bottom-color: rgba(255,255,255,0.05); }
[data-theme="divine"] .card__body li::before { color: var(--accent); }
[data-theme="divine"] .card__badge { background: linear-gradient(135deg, #b478ff, #64c8ff); color: #0a0818; }

/* Divine Lights — donation banner */
[data-theme="divine"] .donation-banner {
  background: rgba(12,8,28,1); border: none;
  box-shadow: none; transition: box-shadow 0.4s;
}
[data-theme="divine"] .donation-banner:hover {
  animation: shadowSpin 2.5s linear infinite;
}
[data-theme="divine"] .donation-banner h3 { color: var(--text-primary); }
[data-theme="divine"] .donation-banner p { color: var(--text-secondary); }
[data-theme="divine"] .fine-print { color: var(--text-muted); }
[data-theme="divine"] .fine-print a { color: var(--gold); }

/* Divine Lights — pricing */
[data-theme="divine"] .pricing-info {
  background: rgba(12,8,28,1); border-color: transparent;
  box-shadow: none; transition: box-shadow 0.4s;
}
[data-theme="divine"] .pricing-info:hover {
  animation: shadowSpin 2.5s linear infinite;
}
[data-theme="divine"] .pricing-info__item strong { color: var(--gold); }
[data-theme="divine"] .pricing-info__divider { background: rgba(180,120,255,0.15); }

/* Divine Lights — programs */
[data-theme="divine"] .program {
  background: rgba(12,8,28,1); border-color: transparent;
  transition: box-shadow 0.4s;
}
[data-theme="divine"] .program:hover {
  animation: shadowSpin 2.5s linear infinite;
}
[data-theme="divine"] .program h3 { color: var(--text-primary); }
[data-theme="divine"] .program li::before { color: var(--gold); }

/* Divine Lights — benefits */
[data-theme="divine"] .benefits-list li { border-bottom-color: rgba(180,120,255,0.08); }
[data-theme="divine"] .benefit-icon { color: var(--gold); }

/* Divine Lights — FAQ */
[data-theme="divine"] .faq__item { border-bottom-color: rgba(180,120,255,0.1); }
[data-theme="divine"] .faq__item summary { color: var(--text-primary); }
[data-theme="divine"] .faq__item summary::after { background: rgba(180,120,255,0.1); color: var(--gold); }
[data-theme="divine"] .faq__item[open] summary::after { background: linear-gradient(135deg, #b478ff, #64c8ff); color: #0a0818; }
[data-theme="divine"] .faq__answer { color: var(--text-secondary); }

/* Divine Lights — form */
[data-theme="divine"] .form {
  background: rgba(180,120,255,0.03); border-color: rgba(180,120,255,0.1);
  box-shadow: 0 0 40px rgba(180,120,255,0.04);
  transition: box-shadow 0.4s;
}
[data-theme="divine"] .form:hover {
  box-shadow:
    0 0 30px rgba(180,120,255,0.08),
    0 0 60px rgba(100,200,255,0.05);
}
[data-theme="divine"] .form__group label { color: var(--text-muted); }
[data-theme="divine"] .form__group input,
[data-theme="divine"] .form__group textarea {
  background: rgba(255,255,255,0.03); border-color: rgba(180,120,255,0.12); color: var(--text-primary);
}
[data-theme="divine"] .form__group input:focus,
[data-theme="divine"] .form__group textarea:focus {
  border-color: var(--gold); background: rgba(180,120,255,0.04);
  box-shadow: 0 0 20px rgba(180,120,255,0.08);
}
[data-theme="divine"] .btn--primary { background: linear-gradient(135deg, #b478ff, #64c8ff); color: #0a0818; transition: all 0.3s; }
[data-theme="divine"] .btn--primary:hover {
  box-shadow:
    0 0 15px rgba(180,120,255,0.4),
    0 0 30px rgba(100,200,255,0.25),
    0 0 45px rgba(255,100,180,0.15);
  transform: translateY(-2px);
}
[data-theme="divine"] .btn--ghost { border-color: rgba(180,120,255,0.2); color: var(--text-primary); }
[data-theme="divine"] .btn--ghost:hover { border-color: var(--gold); color: var(--gold); }

/* Divine Lights — social & footer */
[data-theme="divine"] .social-links a {
  background: rgba(180,120,255,0.06); border-color: rgba(180,120,255,0.12); color: var(--text-secondary);
  transition: all 0.3s;
}
[data-theme="divine"] .social-links a:hover {
  background: linear-gradient(135deg, #b478ff, #64c8ff); color: #0a0818; border-color: transparent;
  box-shadow:
    0 0 12px rgba(180,120,255,0.3),
    0 0 24px rgba(100,200,255,0.2);
}
[data-theme="divine"] .footer { background: var(--bg-deep); border-top-color: rgba(180,120,255,0.08); }

/* Divine Lights — marquee */
[data-theme="divine"] .marquee {
  background: linear-gradient(90deg, #b478ff, #64c8ff, #ff78b4, #b478ff);
  background-size: 200% 100%; color: #0a0818;
  animation: marquee-bg 6s linear infinite;
}
@keyframes marquee-bg { 0% { background-position: 0% 50%; } 100% { background-position: 200% 50%; } }

/* Divine Lights — header */
[data-theme="divine"] .header--scrolled {
  background: rgba(10,8,24,0.92); backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(180,120,255,0.08);
}
[data-theme="divine"] .nav__cta { background: linear-gradient(135deg, #b478ff, #64c8ff); color: #0a0818; }
[data-theme="divine"] .nav__cta:hover { box-shadow: 0 4px 20px rgba(180,120,255,0.3); }
[data-theme="divine"] .nav__link--book { color: var(--gold); }

/* Divine Lights — nav link hover glow */
[data-theme="divine"] .nav__link:hover {
  text-shadow: 0 0 8px rgba(180,120,255,0.4), 0 0 16px rgba(100,200,255,0.2);
}
[data-theme="divine"] .nav__link::after { background: linear-gradient(90deg, #b478ff, #64c8ff, #ff78b4); }
[data-theme="divine"] .nav__link--book:hover {
  text-shadow: 0 0 8px rgba(212,168,255,0.5), 0 0 16px rgba(100,200,255,0.3);
}

/* Divine Lights — hero */
[data-theme="divine"] .hero__overlay {
  background: linear-gradient(180deg, rgba(10,8,24,0.2) 0%, rgba(10,8,24,0.6) 50%,
    rgba(10,8,24,0.95) 85%, var(--bg-deep) 100%),
    radial-gradient(ellipse at 30% 80%, rgba(180,120,255,0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 80%, rgba(100,200,255,0.06) 0%, transparent 50%);
}


[data-theme="light"] .header--scrolled,
[data-theme="sand"] .header--scrolled {
  background: rgba(250,248,245,0.92); backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
[data-theme="light"] .nav__logo, [data-theme="sand"] .nav__logo { color: var(--text-primary); }
[data-theme="light"] .nav__link, [data-theme="sand"] .nav__link { color: var(--text-muted); }
[data-theme="light"] .nav__link:hover, [data-theme="light"] .nav__link--active,
[data-theme="sand"] .nav__link:hover, [data-theme="sand"] .nav__link--active { color: var(--text-primary); }
[data-theme="light"] .nav__cta, [data-theme="sand"] .nav__cta { background: var(--accent); color: #fff; }
[data-theme="light"] .nav__cta:hover, [data-theme="sand"] .nav__cta:hover { background: var(--gold-light); color: #fff; }
[data-theme="light"] .burger span, [data-theme="sand"] .burger span { background: var(--text-primary); }

[data-theme="light"] .hero__overlay, [data-theme="sand"] .hero__overlay {
  background: linear-gradient(180deg, rgba(250,248,245,0.15) 0%, rgba(250,248,245,0.5) 60%, var(--bg-deep) 100%);
}

[data-theme="light"] .marquee, [data-theme="sand"] .marquee { background: var(--accent); color: #fff; }

[data-theme="light"] .card, [data-theme="sand"] .card { background: #fff; box-shadow: 0 2px 20px rgba(0,0,0,0.06); }
[data-theme="light"] .card:hover, [data-theme="sand"] .card:hover { box-shadow: 0 12px 40px rgba(0,0,0,0.1); }
[data-theme="light"] .card--featured, [data-theme="sand"] .card--featured { border-color: var(--accent); }
[data-theme="light"] .card__badge, [data-theme="sand"] .card__badge { background: var(--accent); }

[data-theme="light"] .donation-banner, [data-theme="sand"] .donation-banner { background: #fff; box-shadow: 0 2px 20px rgba(0,0,0,0.06); }

[data-theme="light"] .pricing-info, [data-theme="sand"] .pricing-info { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.08); }
[data-theme="light"] .pricing-info__item strong, [data-theme="sand"] .pricing-info__item strong { color: var(--accent); }
[data-theme="light"] .pricing-info__divider, [data-theme="sand"] .pricing-info__divider { background: rgba(0,0,0,0.08); }

[data-theme="light"] .program, [data-theme="sand"] .program { background: rgba(0,0,0,0.02); border-color: rgba(0,0,0,0.06); }
[data-theme="light"] .program:hover, [data-theme="sand"] .program:hover { background: rgba(0,0,0,0.04); border-color: rgba(var(--accent),0.2); }
[data-theme="light"] .program h3, [data-theme="sand"] .program h3 { color: var(--text-primary); }
[data-theme="light"] .program li::before, [data-theme="sand"] .program li::before { color: var(--accent); }

[data-theme="light"] .benefits-list li, [data-theme="sand"] .benefits-list li { border-bottom-color: rgba(0,0,0,0.06); }
[data-theme="light"] .benefit-icon, [data-theme="sand"] .benefit-icon { color: var(--accent); }

[data-theme="light"] .faq__item, [data-theme="sand"] .faq__item { border-bottom-color: rgba(0,0,0,0.08); }
[data-theme="light"] .faq__item summary, [data-theme="sand"] .faq__item summary { color: var(--text-dark); }
[data-theme="light"] .faq__item summary::after, [data-theme="sand"] .faq__item summary::after { background: var(--accent-soft); color: var(--accent); }
[data-theme="light"] .faq__item[open] summary::after, [data-theme="sand"] .faq__item[open] summary::after { background: var(--accent); color: #fff; }

[data-theme="light"] .form, [data-theme="sand"] .form { background: rgba(0,0,0,0.02); border-color: rgba(0,0,0,0.08); }
[data-theme="light"] .form__group label, [data-theme="sand"] .form__group label { color: var(--text-muted); }
[data-theme="light"] .form__group input, [data-theme="light"] .form__group textarea,
[data-theme="sand"] .form__group input, [data-theme="sand"] .form__group textarea {
  background: #fff; border-color: rgba(0,0,0,0.12); color: var(--text-primary);
}
[data-theme="light"] .form__group input:focus, [data-theme="light"] .form__group textarea:focus,
[data-theme="sand"] .form__group input:focus, [data-theme="sand"] .form__group textarea:focus { border-color: var(--accent); background: rgba(0,0,0,0.01); }
[data-theme="light"] .btn--primary, [data-theme="sand"] .btn--primary { background: var(--accent); color: #fff; }
[data-theme="light"] .btn--primary:hover, [data-theme="sand"] .btn--primary:hover { background: var(--gold-light); color: #fff; }
[data-theme="light"] .btn--ghost, [data-theme="sand"] .btn--ghost { border-color: rgba(0,0,0,0.15); color: var(--text-primary); }
[data-theme="light"] .btn--ghost:hover, [data-theme="sand"] .btn--ghost:hover { border-color: var(--accent); color: var(--accent); }

[data-theme="light"] .social-links a, [data-theme="sand"] .social-links a { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.08); color: var(--text-muted); }
[data-theme="light"] .social-links a:hover, [data-theme="sand"] .social-links a:hover { background: var(--accent); color: #fff; border-color: var(--accent); }

[data-theme="light"] .footer, [data-theme="sand"] .footer { background: var(--bg-dark); border-top-color: rgba(0,0,0,0.06); }

[data-theme="light"] .nav__links, [data-theme="sand"] .nav__links {
  background: rgba(250,248,245,0.97);
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
  .programs-grid { grid-template-columns: repeat(2, 1fr); }
  .program--wide { grid-column: 1 / -1; }
  .program__list--inline { columns: 1; }
}

@media (max-width: 768px) {
  :root { --space-xl: 56px; --space-2xl: 80px; }

  /* Nav */
  .nav__links {
    display: none; position: fixed; inset: 0; z-index: 999;
    background: rgba(12,10,29,0.97); backdrop-filter: blur(20px);
    flex-direction: column; align-items: center; justify-content: center; gap: 32px;
  }
  .nav__links--open { display: flex; }
  .nav__link { font-size: 24px; font-family: var(--font-heading); }
  .nav__cta { display: none; }
  .theme-toggle { order: -1; }
  .burger { display: flex; z-index: 1001; }

  /* Hero */
  .hero { min-height: 85vh; }
  .hero__content { padding: 140px 0 var(--space-xl); }

  /* Layouts */
  .split, .split--reverse { grid-template-columns: 1fr; gap: var(--space-lg); }
  .cards { grid-template-columns: 1fr; }
  .programs-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }

  /* Pricing */
  .pricing-info { flex-direction: column; gap: var(--space-md); }
  .pricing-info__divider { width: 48px; height: 1px; }

  /* Donation */
  .donation-banner { flex-direction: column; text-align: center; }
  .donation-banner img { width: 100%; height: 180px; }

  /* Footer */
  .footer__inner { flex-direction: column; text-align: center; }
  .footer__links { flex-wrap: wrap; justify-content: center; }
  .footer__legal { text-align: center; }
}

@media (max-width: 480px) {
  .hero__actions { flex-direction: column; }
  .hero__actions .btn { width: 100%; }
}
