/* ════════════════════════════════════════════════════════════════
   OUR BIRTH TEMPLE — Luxury Refinement Pass
   Sacred · Feminine · Luminous · $100k brand level.
   ════════════════════════════════════════════════════════════════ */

/* ── Design tokens (override main.css defaults) ──────────────── */
:root {
  --c-bg:         #fef9f5;
  --c-pearl:      #fefcf9;
  --c-ivory:      #faf6ee;
  --c-champagne:  #f7ece0;
  --c-blush:      #f2ddd0;
  --c-rose-gold:  #c08468;
  --c-rose-light: #d4997e;
  --c-rose-pale:  #ead4c2;
  --c-burgundy:   #7a2b40;
  --c-wine:       #58172a;
  --c-text:       #2a1912;
  --c-text-mid:   #66403a;
  --c-text-soft:  #956860;
  --c-text-inv:   #fdf5ee;

  --r-sm:   10px;
  --r-md:   18px;
  --r-lg:   28px;
  --r-xl:   44px;
  --r-pill: 100px;

  --sh-sm:  0 2px 14px rgba(192,132,104,0.10);
  --sh-md:  0 6px 32px rgba(122,43,64,0.13), 0 2px 8px rgba(192,132,104,0.08);
  --sh-lg:  0 14px 64px rgba(122,43,64,0.17), 0 4px 16px rgba(192,132,104,0.10);
  --sh-glow: 0 0 48px rgba(192,132,104,0.18), 0 0 96px rgba(237,217,184,0.07);
}

/* ── Body ────────────────────────────────────────────────────── */
body {
  background-color: var(--c-bg);
  background-image:
    radial-gradient(ellipse 80% 40% at 20% 0%,  rgba(237,217,184,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 100%, rgba(210,140,110,0.05) 0%, transparent 55%);
  background-attachment: fixed;
}

/* ── Typography ──────────────────────────────────────────────── */
h1 { letter-spacing: -0.015em; line-height: 1.00; }
h2 { letter-spacing: -0.008em; line-height: 1.08; }
h3 { letter-spacing: -0.003em; line-height: 1.12; }
p  { line-height: 1.82; }

.offerings__heading,
.testimonials__heading,
.mission__text h2,
.about__text h2,
.philosophy__text h2,
.book__text h2 {
  background: linear-gradient(135deg, var(--c-burgundy) 10%, #9a3055 90%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.label {
  background: linear-gradient(90deg, var(--c-rose-gold) 0%, var(--c-rose-light) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: 0.30em;
}
.divider {
  width: 60px; height: 1.5px;
  background: linear-gradient(90deg,
    transparent 0%, var(--c-rose-gold) 25%,
    rgba(237,217,184,0.85) 60%, transparent 100%);
  margin: 20px auto;
}
.divider--left { margin-left: 0; }

/* ════════════════════════════════════════════════════════════════
   BUTTONS — luxury portals, unified system
   ════════════════════════════════════════════════════════════════ */
.btn {
  padding: 16px 36px;
  min-height: 54px;
  border-radius: var(--r-pill);
  font-family: var(--f-body);
  font-size: 0.60rem;
  font-weight: 700;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  position: relative;
  overflow: hidden;
  transition:
    transform   0.28s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow  0.28s ease,
    background  0.24s ease,
    border-color 0.24s ease;
}
/* Inner shimmer on all buttons */
.btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(160deg, rgba(255,255,255,0.09) 0%, transparent 52%);
  border-radius: inherit;
  pointer-events: none;
}
.btn:hover  { transform: translateY(-3px) scale(1.016); }
.btn:active { transform: translateY(-1px) scale(1.008); transition-duration: 0.10s; }

.btn-primary {
  background: linear-gradient(140deg, #9a3055 0%, var(--c-burgundy) 45%, var(--c-wine) 100%);
  color: #fff; border: none;
  box-shadow: 0 3px 18px rgba(122,43,64,0.24), inset 0 1px 0 rgba(255,255,255,0.10);
}
.btn-primary:hover {
  background: linear-gradient(140deg, #a83560 0%, #8f3050 45%, #4e1626 100%);
  box-shadow: 0 8px 36px rgba(122,43,64,0.34), inset 0 1px 0 rgba(255,255,255,0.10);
  color: #fff; border-color: transparent;
}

.btn-outline {
  background: rgba(254,250,247,0.72);
  border: 1.5px solid rgba(192,132,104,0.36);
  color: var(--c-burgundy);
  backdrop-filter: blur(8px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.50), 0 2px 12px rgba(192,132,104,0.07);
}
.btn-outline:hover {
  background: linear-gradient(140deg, #9a3055 0%, var(--c-burgundy) 50%, var(--c-wine) 100%);
  border-color: transparent; color: #fff;
  box-shadow: 0 8px 32px rgba(122,43,64,0.32);
}

.btn-ghost {
  background: rgba(255,248,242,0.10);
  border: 1.5px solid rgba(237,217,184,0.40);
  color: rgba(255,248,242,0.92);
  backdrop-filter: blur(14px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 2px 0 rgba(0,0,0,0.07);
}
.btn-ghost:hover {
  background: rgba(255,248,242,0.18);
  border-color: rgba(237,217,184,0.68);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.10), 0 0 28px rgba(237,217,184,0.16);
}
.btn-full { width: 100%; }

/* ════════════════════════════════════════════════════════════════
   NAVIGATION
   ════════════════════════════════════════════════════════════════ */
.nav {
  background: rgba(254,252,249,0.94);
  backdrop-filter: blur(18px) saturate(1.4);
  border-bottom: 1px solid rgba(192,132,104,0.09);
  box-shadow: 0 1px 0 rgba(237,217,184,0.16);
}
.nav.scrolled {
  background: rgba(254,252,249,0.97);
  box-shadow: 0 2px 28px rgba(122,43,64,0.08), 0 1px 0 rgba(237,217,184,0.12);
}
.nav__logo {
  font-size: 0.64rem; letter-spacing: 0.26em;
  background: linear-gradient(120deg, var(--c-burgundy) 0%, var(--c-rose-gold) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.nav__links a { transition: color 0.22s ease; position: relative; padding-bottom: 2px; }
.nav__links a::after {
  content: ''; position: absolute; bottom: -1px; left: 0;
  width: 0; height: 1px; background: var(--c-rose-gold);
  transition: width 0.26s ease;
}
.nav__links a:hover { color: var(--c-rose-gold); }
.nav__links a:hover::after { width: 100%; }
.nav__mobile {
  background: radial-gradient(ellipse at 50% 35%,
    #fdf6ee 0%, var(--c-pearl) 55%, var(--c-ivory) 100%);
}
.nav__mobile a { transition: color 0.22s ease; }
.nav__mobile a:hover { color: var(--c-rose-gold); }

/* ════════════════════════════════════════════════════════════════
   HERO — free-floating portrait, no hard rings
   ════════════════════════════════════════════════════════════════ */
.hero {
  background: linear-gradient(152deg,
    #360c18 0%, #5e1c30 22%, var(--c-burgundy) 46%,
    #9a3d5a 70%, #be7282 88%, #d4a090 100%);
}
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 78% 18%, rgba(255,228,212,0.20) 0%, transparent 55%),
    radial-gradient(ellipse 50% 50% at 18% 82%, rgba(237,217,184,0.09) 0%, transparent 50%),
    radial-gradient(ellipse 80% 40% at 50% 100%, rgba(88,23,42,0.40) 0%, transparent 60%);
  pointer-events: none;
}
.hero__image { position: relative; }
/* Ambient glow — diffuse, NO rings, NO box */
.hero__image::before {
  content: '';
  position: absolute; inset: -40px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 45%,
    rgba(237,217,184,0.16) 0%,
    rgba(192,132,104,0.09) 38%,
    transparent 70%);
  pointer-events: none; z-index: 0;
  filter: blur(10px);
}
/* Frame — pure glow, zero border/ring */
.hero__img-frame {
  border: none;
  /* Pure ambient glow — no rings, no border */
  box-shadow:
    0 0 70px rgba(192,132,104,0.20),
    0 0 140px rgba(237,217,184,0.06),
    0 28px 80px rgba(0,0,0,0.36);
}
/* Soft vignette at base of portrait */
.hero__img-frame::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, transparent 52%, rgba(56,12,26,0.20) 100%);
  border-radius: inherit; pointer-events: none;
}

/* ════════════════════════════════════════════════════════════════
   WOMB BLESSING
   ════════════════════════════════════════════════════════════════ */
.womb {
  background: linear-gradient(168deg,
    #6a1e32 0%, var(--c-burgundy) 28%, #7d2e42 55%, #6a1e32 80%, #4a1220 100%);
  position: relative;
}
.womb::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 55% at 50% 35%, rgba(237,217,184,0.09) 0%, transparent 65%);
  pointer-events: none;
}
.womb__card {
  background: rgba(255,250,246,0.07);
  border: 1px solid rgba(237,217,184,0.13);
  border-radius: 52px;
  backdrop-filter: blur(18px) saturate(1.2);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 28px 72px rgba(0,0,0,0.20);
}
.womb__input {
  background: rgba(255,252,250,0.92);
  border: 1.5px solid rgba(237,217,184,0.26);
  border-radius: var(--r-pill);
  box-shadow: inset 0 2px 5px rgba(0,0,0,0.04), 0 1px 0 rgba(255,255,255,0.50);
  transition: border-color 0.24s, box-shadow 0.24s, background 0.24s;
}
.womb__input:focus {
  border-color: rgba(237,217,184,0.62);
  background: rgba(255,253,251,0.97);
  box-shadow: inset 0 2px 5px rgba(0,0,0,0.03), 0 0 0 3px rgba(237,217,184,0.14);
  outline: none;
}
.womb__submit {
  background: linear-gradient(135deg, rgba(237,217,184,0.94), rgba(218,188,145,0.92));
  border-radius: var(--r-pill);
  box-shadow: 0 4px 18px rgba(0,0,0,0.13), inset 0 1px 0 rgba(255,255,255,0.28);
  transition: all 0.28s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.womb__submit:hover {
  background: linear-gradient(135deg, #eddbb8, #dcc090);
  transform: translateY(-3px) scale(1.015);
  box-shadow: 0 8px 28px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.30);
}

/* ════════════════════════════════════════════════════════════════
   OFFERINGS
   ════════════════════════════════════════════════════════════════ */
.offerings {
  background: linear-gradient(172deg,
    var(--c-pearl) 0%, #faf2e7 32%, #f6e9dd 62%, var(--c-champagne) 100%);
  position: relative; overflow: hidden;
}
.offerings::before {
  content: '';
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(900px, 120vw); height: min(600px, 80vw);
  background: radial-gradient(ellipse, rgba(192,132,104,0.07) 0%, transparent 65%);
  pointer-events: none; z-index: 0;
}
.offerings .container { position: relative; z-index: 1; }
.ocard {
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(192,132,104,0.12);
  border-radius: 32px;
  backdrop-filter: blur(8px);
  box-shadow: var(--sh-sm);
  transition: box-shadow 0.32s ease, transform 0.32s ease, background 0.24s;
}
.ocard:hover {
  box-shadow: var(--sh-md), 0 0 36px rgba(192,132,104,0.08);
  transform: translateY(-4px);
}
@media (min-width: 960px) {
  .ocard { background: transparent; border: none; border-radius: 0; backdrop-filter: none; box-shadow: none; }
  .ocard:first-child { border-top: 1px solid rgba(192,132,104,0.13); }
  .ocard            { border-bottom: 1px solid rgba(192,132,104,0.13); }
  .ocard:hover {
    background: linear-gradient(135deg, rgba(192,132,104,0.04), rgba(237,217,184,0.02));
    border-radius: 20px; box-shadow: none; transform: none;
  }
}

/* ════════════════════════════════════════════════════════════════
   MISSION
   ════════════════════════════════════════════════════════════════ */
.mission {
  background: linear-gradient(172deg, var(--c-ivory) 0%, #f7ede0 45%, var(--c-champagne) 100%);
  position: relative; overflow: hidden;
}
.mission::after {
  content: '';
  position: absolute; top: -60px; right: -60px;
  width: 300px; height: 300px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 150 150' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='75' cy='75' r='72' stroke='rgba(192,132,104,0.09)' stroke-width='0.7'/%3E%3Ccircle cx='75' cy='75' r='54' stroke='rgba(192,132,104,0.06)' stroke-width='0.5'/%3E%3Ccircle cx='75' cy='75' r='36' stroke='rgba(192,132,104,0.07)' stroke-width='0.5'/%3E%3Ccircle cx='75' cy='75' r='18' stroke='rgba(192,132,104,0.05)' stroke-width='0.4'/%3E%3C/svg%3E");
  background-size: contain; background-repeat: no-repeat;
  pointer-events: none; z-index: 0;
}
.mission .container { position: relative; z-index: 1; }
.mission__img-wrap {
  border: none;
  box-shadow:
    0 0 64px rgba(192,132,104,0.18),
    0 0 32px rgba(237,217,184,0.08),
    0 14px 48px rgba(0,0,0,0.12);
}
.mission__quote {
  border-left: 2.5px solid var(--c-rose-gold);
  border-radius: 0 22px 22px 0;
  background: linear-gradient(135deg, rgba(192,132,104,0.06) 0%, rgba(237,217,184,0.04) 100%);
  box-shadow: inset 0 0 0 1px rgba(192,132,104,0.06);
  padding: 20px 22px;
}

/* ════════════════════════════════════════════════════════════════
   TESTIMONIALS
   ════════════════════════════════════════════════════════════════ */
.testimonials {
  background: linear-gradient(172deg,
    var(--c-champagne) 0%, #faf4ec 35%, var(--c-pearl) 70%, #fef9f5 100%);
}
.tcard {
  background: rgba(255,255,255,0.76);
  border: 1px solid rgba(192,132,104,0.10);
  border-radius: 30px;
  backdrop-filter: blur(8px);
  box-shadow: var(--sh-sm);
  transition: box-shadow 0.30s ease, transform 0.30s ease;
}
.tcard:hover { box-shadow: var(--sh-md); transform: translateY(-5px); }
.tcard__quote { font-size: 3.2rem; color: rgba(192,132,104,0.17); line-height: 0.82; }
.tcard__avatar {
  background: linear-gradient(135deg, var(--c-rose-pale), var(--c-blush));
  border: 1px solid rgba(192,132,104,0.15);
  box-shadow: 0 2px 8px rgba(192,132,104,0.10);
}

/* ════════════════════════════════════════════════════════════════
   ABOUT
   ════════════════════════════════════════════════════════════════ */
.about {
  background: linear-gradient(172deg, var(--c-pearl) 0%, var(--c-bg) 40%, var(--c-ivory) 100%);
}
.about__img-wrap {
  border: none;
  box-shadow:
    0 0 64px rgba(192,132,104,0.18),
    0 0 32px rgba(237,217,184,0.08),
    0 16px 56px rgba(0,0,0,0.12);
  transition: box-shadow 0.40s ease;
}
.about__img-wrap:hover {
  box-shadow:
    0 0 88px rgba(192,132,104,0.26),
    0 0 44px rgba(237,217,184,0.10),
    0 20px 64px rgba(0,0,0,0.14);
}
.about__badge {
  border-radius: 18px;
  background: linear-gradient(135deg, var(--c-burgundy) 0%, #9a3055 100%);
  box-shadow: var(--sh-md), 0 0 22px rgba(122,43,64,0.20);
}
.tag {
  background: rgba(192,132,104,0.07); border: 1px solid rgba(192,132,104,0.15);
  border-radius: var(--r-pill); color: var(--c-burgundy);
  transition: background 0.22s, box-shadow 0.22s, color 0.22s, border-color 0.22s;
}
.tag:hover {
  background: var(--c-burgundy); border-color: var(--c-burgundy);
  color: #fff; box-shadow: 0 3px 12px rgba(122,43,64,0.18);
}

/* ════════════════════════════════════════════════════════════════
   PHILOSOPHY
   ════════════════════════════════════════════════════════════════ */
.philosophy {
  background: linear-gradient(172deg,
    var(--c-ivory) 0%, #f8ead8 28%, var(--c-blush) 54%,
    #f5eedd 80%, var(--c-ivory) 100%);
  position: relative; overflow: hidden;
}
.philosophy::before {
  content: '';
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(700px, 100vw); height: min(700px, 100vw);
  background: radial-gradient(ellipse, rgba(192,132,104,0.06) 0%, transparent 65%);
  pointer-events: none;
}
.philosophy .container { position: relative; z-index: 1; }
.philosophy__img-wrap {
  border: none;
  box-shadow:
    0 0 64px rgba(192,132,104,0.16),
    0 0 32px rgba(237,217,184,0.07),
    0 14px 48px rgba(0,0,0,0.11);
}
.philosophy__img-wrap::before {
  background: radial-gradient(ellipse, rgba(192,132,104,0.20) 0%, transparent 68%);
}
.philosophy__pullquote {
  border-left: 2.5px solid var(--c-rose-gold);
  border-radius: 0 24px 24px 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.60) 0%, rgba(250,242,234,0.42) 100%);
  box-shadow: inset 0 0 0 1px rgba(192,132,104,0.07), var(--sh-sm);
  backdrop-filter: blur(10px); padding: 22px 24px;
}

/* ════════════════════════════════════════════════════════════════
   COMMUNITY
   ════════════════════════════════════════════════════════════════ */
.community {
  background: linear-gradient(152deg,
    #260b16 0%, var(--c-wine) 28%, var(--c-burgundy) 58%, #9a3d5a 84%, #ae5370 100%);
  position: relative; overflow: hidden;
}
.community::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 15% 20%, rgba(255,225,210,0.09) 0%, transparent 55%),
    radial-gradient(ellipse 60% 50% at 85% 80%, rgba(237,217,184,0.06) 0%, transparent 50%);
  pointer-events: none;
}
.community .container { position: relative; z-index: 1; }
.cvalue {
  background: rgba(255,248,242,0.07); border: 1px solid rgba(237,217,184,0.10);
  border-radius: 22px; backdrop-filter: blur(10px);
  transition: background 0.26s ease, transform 0.26s ease;
}
.cvalue:hover { background: rgba(255,248,242,0.12); transform: translateY(-2px); }
.cstat {
  background: rgba(255,248,242,0.07); border: 1px solid rgba(237,217,184,0.09);
  border-radius: 26px; backdrop-filter: blur(10px);
  transition: background 0.26s ease, transform 0.26s ease;
}
.cstat:hover { background: rgba(255,248,242,0.11); transform: translateY(-2px); }

/* ════════════════════════════════════════════════════════════════
   HATHORA / MUSIC
   ════════════════════════════════════════════════════════════════ */
.hathora {
  background: linear-gradient(152deg,
    #18060e 0%, #340d1c 22%, var(--c-wine) 52%, var(--c-burgundy) 78%, #8a3050 100%);
  position: relative; overflow: hidden;
}
.hathora::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 65% 55% at 72% 12%, rgba(255,212,192,0.12) 0%, transparent 52%),
    radial-gradient(ellipse 55% 45% at 28% 90%, rgba(192,132,104,0.07) 0%, transparent 48%);
  pointer-events: none;
}
.hathora__inner { position: relative; z-index: 1; }
.hathora__name {
  background: linear-gradient(135deg, #fff 0%, rgba(237,217,184,0.92) 55%, rgba(210,155,120,0.85) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hathora__hathor {
  background: rgba(255,248,242,0.06); border: 1px solid rgba(237,217,184,0.12);
  border-radius: 26px; backdrop-filter: blur(14px);
}
.song {
  background: rgba(255,248,242,0.05); border: 1px solid rgba(237,217,184,0.09);
  border-radius: 30px; overflow: hidden;
  transition: background 0.30s ease, transform 0.30s ease, box-shadow 0.30s ease;
}
.song:hover {
  background: rgba(255,248,242,0.09); transform: translateY(-5px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.26), 0 0 28px rgba(192,132,104,0.09);
}
.song__art {
  background: linear-gradient(148deg, #120608, #320d1a 52%, var(--c-wine));
  border-radius: 30px 30px 0 0;
}

/* ════════════════════════════════════════════════════════════════
   BOOK
   ════════════════════════════════════════════════════════════════ */
.book {
  background: linear-gradient(172deg,
    #faeae0 0%, var(--c-champagne) 32%, #f8f0e8 62%, var(--c-ivory) 100%);
  position: relative; overflow: hidden;
}
.book::before {
  content: '';
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(800px, 120vw); height: min(550px, 80vw);
  background: radial-gradient(ellipse, rgba(192,132,104,0.06) 0%, transparent 65%);
  pointer-events: none;
}
.book .container { position: relative; z-index: 1; }
.book__cover {
  background: linear-gradient(148deg, #200810 0%, var(--c-wine) 30%, var(--c-burgundy) 60%, #8a3050 100%);
  border-radius: 8px 26px 26px 8px;
  box-shadow:
    18px 22px 70px rgba(0,0,0,0.36),
    0 0 90px rgba(192,132,104,0.18),
    -5px -5px 24px rgba(255,218,195,0.08),
    inset 0 1px 0 rgba(255,255,255,0.05);
}

/* ════════════════════════════════════════════════════════════════
   MESSAGE / FINAL CTA
   ════════════════════════════════════════════════════════════════ */
.message {
  background: linear-gradient(152deg,
    #240b15 0%, var(--c-wine) 28%, var(--c-burgundy) 58%, #9a3d5a 84%, #b85878 100%);
  position: relative; overflow: hidden;
}
.message::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 65% 50% at 50% 28%, rgba(237,217,184,0.09) 0%, transparent 58%),
    radial-gradient(ellipse 55% 40% at 50% 100%, rgba(192,132,104,0.07) 0%, transparent 50%);
  pointer-events: none;
}
.message .container { position: relative; z-index: 1; }

/* ════════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════════ */
footer {
  background: linear-gradient(172deg, #1a0810 0%, #261410 42%, #1e0e0a 100%);
}
.footer__nl-btn {
  background: linear-gradient(135deg, rgba(237,217,184,0.88) 0%, rgba(216,186,142,0.90) 100%);
  transition: all 0.28s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.footer__nl-btn:hover {
  background: linear-gradient(135deg, #eddbb8 0%, #ddc090 100%);
  transform: translateY(-2px) scale(1.01);
  box-shadow: 0 6px 18px rgba(0,0,0,0.14);
}
.footer__nl-input {
  background: rgba(255,248,242,0.05);
  border: 1px solid rgba(237,217,184,0.11); border-radius: var(--r-pill);
  transition: border-color 0.24s, background 0.24s;
}
.footer__nl-input:focus {
  border-color: rgba(237,217,184,0.28); background: rgba(255,248,242,0.08); outline: none;
}
.footer__links a { transition: color 0.22s ease; }
.footer__links a:hover { color: rgba(237,217,184,0.88); }

/* ════════════════════════════════════════════════════════════════
   SCROLL REVEAL — organic, spring feel
   ════════════════════════════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(22px) scale(0.993);
  transition:
    opacity   0.80s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.80s cubic-bezier(0.22, 1, 0.36, 1);
}
.reveal.visible { opacity: 1; transform: translateY(0) scale(1); }
.reveal.d1 { transition-delay: 0.08s; }
.reveal.d2 { transition-delay: 0.16s; }
.reveal.d3 { transition-delay: 0.24s; }
.reveal.d4 { transition-delay: 0.32s; }

/* ════════════════════════════════════════════════════════════════
   GLOBAL TRANSITIONS
   ════════════════════════════════════════════════════════════════ */
a { transition: color 0.22s ease, opacity 0.22s ease; }

/* ════════════════════════════════════════════════════════════════
   MOBILE POLISH
   ════════════════════════════════════════════════════════════════ */
@media (max-width: 639px) {
  .btn         { min-height: 54px; padding: 15px 28px; font-size: 0.61rem; }
  .womb__card  { border-radius: 40px; padding: 40px 24px; }
  .ocard       { border-radius: 28px; }
  .tcard       { border-radius: 26px; }
  h2           { line-height: 1.10; }
  .label       { margin-bottom: 10px; }
  .hero__image::before { inset: -20px; }
  .hero__img-frame {
    box-shadow:
      0 0 40px rgba(192,132,104,0.18),
      0 18px 56px rgba(0,0,0,0.30);
  }
}

/* ════════════════════════════════════════════════════════════════
   DESKTOP ENHANCEMENTS
   ════════════════════════════════════════════════════════════════ */
@media (min-width: 960px) {
  .hero__img-frame {
    box-shadow:
      0 0 80px rgba(192,132,104,0.24),
      0 0 160px rgba(237,217,184,0.07),
      0 32px 100px rgba(0,0,0,0.40);
  }
  .mission__img-wrap {
    width: 260px;
    box-shadow:
      0 0 80px rgba(192,132,104,0.22),
      0 0 40px rgba(237,217,184,0.09),
      0 18px 60px rgba(0,0,0,0.14);
  }
  .about__img-wrap, .philosophy__img-wrap {
    box-shadow:
      0 0 80px rgba(192,132,104,0.20),
      0 0 40px rgba(237,217,184,0.08),
      0 20px 64px rgba(0,0,0,0.13);
  }
  .song:hover {
    box-shadow: 0 14px 48px rgba(0,0,0,0.30), 0 0 32px rgba(192,132,104,0.12);
    transform: translateY(-6px);
  }
}

/* ════════════════════════════════════════════════════════════════
   OFFERINGS JOIN BUTTONS — minimal, centred, luxury portal
   ════════════════════════════════════════════════════════════════ */
.ocard__btn .btn {
  /* Override to a consistent centred JOIN style */
  letter-spacing: 0.32em;
  padding: 16px 48px;
  min-height: 52px;
  font-size: 0.58rem;
  text-align: center;
}
/* Primary JOIN (Birth + Healing) */
.ocard__btn .btn-primary {
  background: linear-gradient(140deg, #9a3055 0%, var(--c-burgundy) 50%, var(--c-wine) 100%);
  box-shadow: 0 4px 20px rgba(122,43,64,0.20), inset 0 1px 0 rgba(255,255,255,0.09);
}
/* Outline JOIN (Moon + Fertility) */
.ocard__btn .btn-outline {
  border: 1.5px solid rgba(122,43,64,0.32);
  color: var(--c-burgundy);
  background: rgba(254,250,247,0.68);
}
.ocard__btn .btn-outline:hover {
  background: linear-gradient(140deg, #9a3055 0%, var(--c-burgundy) 50%, var(--c-wine) 100%);
  border-color: transparent; color: #fff;
  box-shadow: 0 8px 28px rgba(122,43,64,0.28);
}
/* Mobile — full width, generous height */
@media (max-width: 639px) {
  .ocard__btn .btn {
    padding: 17px 40px;
    min-height: 56px;
    letter-spacing: 0.30em;
  }
}
/* Desktop row layout — auto width, right-aligned */
@media (min-width: 960px) {
  .ocard__btn .btn {
    width: auto;
    padding: 15px 44px;
    min-height: 50px;
  }
}

