/* ============================================================
   PAGE: HOMEPAGE — charisa-munroe-homepage.html
   Only styles unique to this page. Global styles in global.css.
   ============================================================ */

/* ── HERO ────────────────────────────────────────────────── */
.hero {
  min-height: 100svh;
  display: grid; grid-template-columns: 55% 45%;
  position: relative; overflow: hidden;
  background: var(--navy-dk);
}
.hero-atm {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 60% 55% at 72% 40%, rgba(45,107,116,.20) 0%, transparent 65%),
    radial-gradient(ellipse 42% 42% at 10% 80%, rgba(125,31,46,.15) 0%, transparent 55%),
    radial-gradient(ellipse 35% 35% at 88% 8%,  rgba(201,168,76,.07) 0%, transparent 50%);
}
.hero-gt {
  position: absolute; inset: 0; pointer-events: none; opacity: .035;
  background-image:
    linear-gradient(rgba(201,168,76,1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,76,1) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: linear-gradient(to bottom, transparent 0%, black 18%, black 82%, transparent 100%);
}

/* Orbs — positioning */
.hero-orb-1 { width:580px; height:580px; top:-140px; right:-120px; animation: floatA 14s ease-in-out infinite; }
.hero-orb-2 { width:320px; height:320px; bottom:-80px; left:-80px;  animation: floatB 11s ease-in-out infinite 2s; }
.hero-orb-3 { width:200px; height:200px; top:30%; right:20%;        animation: pulseRing 9s ease-in-out infinite 1s; }
.hero-orb-4 { width:120px; height:120px; top:60%; left:45%;         animation: floatC 12s ease-in-out infinite 3s; background: transparent; border: 1px solid rgba(201,168,76,.06); border-radius: 50%; }

/* Dot accents */
.dot-accent { position: absolute; width: 6px; height: 6px; border-radius: 50%; background: var(--gold); opacity: .25; pointer-events: none; }
.dot-1 { top:18%; left:14%; animation: floatC 8s ease-in-out infinite; }
.dot-2 { top:65%; right:18%; animation: floatA 11s ease-in-out infinite 2s; }
.dot-3 { top:40%; left:3%;  animation: floatB 9s ease-in-out infinite 4s; }
.dot-4 { bottom:20%; right:5%; animation: floatC 12s ease-in-out infinite 1s; }
.dot-5 { top:80%; left:45%; animation: pulseRing 7s ease-in-out infinite 3s; width: 8px; height: 8px; }

.hero-c {
  display: flex; flex-direction: column; justify-content: center;
  padding: clamp(100px,14vh,140px) clamp(28px,6vw,80px) 80px clamp(28px,7vw,10vw);
  position: relative; z-index: 2;
}
.hero-ey {
  display: inline-flex; align-items: center; gap: 14px;
  font-size: .62rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 30px;
  opacity: 0; animation: riseIn .9s cubic-bezier(.22,1,.36,1) .15s forwards;
}
.hero-ey::before { content: ''; width: 30px; height: 1px; background: var(--gold); flex-shrink: 0; }
.hero-h1 {
  font-family: var(--serif);
  font-size: clamp(2.8rem, 5.2vw, 5rem);
  font-weight: 400; line-height: 1.08; color: #fff; margin-bottom: 30px;
  opacity: 0; animation: riseIn .95s cubic-bezier(.22,1,.36,1) .3s forwards;
}
.hero-h1 em                    { color: var(--gold); font-style: italic; }
.hero-h1 .tm                   { font-size: .38em; vertical-align: super; color: var(--gold); font-style: normal; }
.hero-sub {
  font-size: clamp(.78rem, 1.2vw, .9rem); font-weight: 400;
  letter-spacing: .07em; text-transform: uppercase;
  color: rgba(255,255,255,.42); max-width: 440px; line-height: 1.72; margin-bottom: 50px;
  opacity: 0; animation: riseIn .95s cubic-bezier(.22,1,.36,1) .45s forwards;
}
.hero-btns {
  display: flex; flex-wrap: wrap; gap: 14px;
  opacity: 0; animation: riseIn .95s cubic-bezier(.22,1,.36,1) .6s forwards;
}
/* Ghost light outline button only used in hero */
.bgl {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid rgba(255,255,255,.35); color: rgba(255,255,255,.82);
  padding: 15px 32px; border-radius: 1px;
  font-size: .67rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase;
  transition: all .22s; white-space: nowrap;
}
.bgl:hover                     { border-color: var(--gold); color: var(--gold); }
.hero-tag {
  margin-top: 50px; font-size: .62rem; letter-spacing: .18em;
  text-transform: uppercase; color: rgba(255,255,255,.2);
  opacity: 0; animation: riseIn .9s cubic-bezier(.22,1,.36,1) .8s forwards;
}

/* Right column image */
.hero-vis { position: relative; overflow: hidden; }
.hero-vis::before {
  content: ''; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to right, var(--navy-dk) 0%, rgba(13,27,42,.25) 40%, transparent 65%),
    linear-gradient(to top, var(--navy-dk) 0%, transparent 28%);
}
.hero-img {
  width: 100%; height: 100%; min-height: 100svh;
  background: linear-gradient(155deg, #0d1b2a 0%, #0d1b2a 100%);
  display: flex; align-items: center; justify-content: center;
}
.hero-ph {
  position: relative; z-index: 2;
  font-family: var(--serif); font-size: clamp(.8rem,1.2vw,.9rem);
  color: rgba(201,168,76,.16); letter-spacing: .22em; text-transform: uppercase;
  text-align: center; padding: 0 32px; line-height: 1.9;
}

/* ── SECTION: RECOGNITION ────────────────────────────────── */
.s-rec {
  background: var(--warm);
  padding: clamp(80px,11vw,130px) 0;
  border-bottom: 1px solid var(--rule);
}
.rec-g { display: grid; grid-template-columns: 1fr 1.55fr; gap: clamp(48px,8vw,110px); align-items: start; }
.rec-stick { position: sticky; top: 100px; }
.rec-bq { font-family: var(--serif); font-size: clamp(1.75rem,3vw,2.6rem); font-style: italic; color: var(--navy); line-height: 1.22; border-left: 3px solid var(--gold); padding-left: 26px; margin-top: 14px; }
.rec-b p { font-size: clamp(.95rem,1.4vw,1.05rem); line-height: 1.92; color: var(--text-md); margin-bottom: 22px; }
.rec-pull { font-family: var(--serif); font-size: clamp(1.1rem,1.8vw,1.35rem); font-style: italic; color: var(--navy); border-left: 3px solid var(--burg); padding: 18px 0 18px 26px; margin: 36px 0; line-height: 1.5; }

/* ── SECTION: CONFRONTATION ──────────────────────────────── */
.s-conf {
  background: var(--sand);
  padding: clamp(80px,12vw,140px) clamp(20px,5vw,64px);
  text-align: center; position: relative; overflow: hidden;
  border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);
}
.s-conf::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 60% at 50% 50%, rgba(201,168,76,.06) 0%, transparent 65%);
}
.conf-t {
  font-family: var(--serif); font-size: clamp(1.8rem,3.8vw,3.4rem); line-height: 1.28;
  position: relative; z-index: 1; max-width: 800px; margin: 0 auto;
  background: #fff; border: 1px solid var(--rule); border-left: 4px solid var(--burg);
  padding: clamp(36px,5vw,60px) clamp(32px,5vw,64px);
  box-shadow: 0 4px 32px rgba(13,27,42,.06);
}
.conf-t b                      { color: var(--navy); font-weight: 400; }
.conf-t em                     { color: var(--gold); font-style: italic; }

/* Conference photo strip */
.conf-ph-strip { display: grid; grid-template-columns: 1fr 2.5fr 1fr; gap: 16px; max-width: 900px; margin: clamp(48px,6vw,72px) auto 0; position: relative; z-index: 2; }
.conf-ph-main  { aspect-ratio: 16/9; }
.conf-ph-side  { aspect-ratio: 3/4; }

/* ── SECTION: UNIFIED OFFERINGS ──────────────────────────── */
.s-offers {
  background: var(--navy);
  padding: clamp(80px,11vw,140px) 0;
  position: relative; overflow: hidden;
}
.s-offers::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(201,168,76,.04) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 90% 80%, rgba(45,107,116,.07) 0%, transparent 55%);
}
/* Offering orbs */
.off-orb-1 { width:560px; height:560px; top:-120px; right:-120px; animation: floatA 16s ease-in-out infinite; }
.off-orb-2 { width:320px; height:320px; bottom:-80px; left:-80px;  animation: floatB 13s ease-in-out infinite 3s; }
.off-orb-3 { width:200px; height:200px; top:40%; left:10%;         animation: pulseRing 11s ease-in-out infinite; }
.off-orb-4 { width:140px; height:140px; top:20%; right:8%;         animation: floatC 10s ease-in-out infinite 2s; background: transparent; border: 1px solid rgba(45,107,116,.1); border-radius: 50%; }

/* Section heading (on dark bg in this page) */
.sh { text-align: center; margin-bottom: clamp(48px,6vw,76px); }
.sh h2 { font-family: var(--serif); font-size: clamp(2rem,4vw,3.5rem); color: var(--navy-dk); margin-top: 14px; line-height: 1.12; }
.sh h2 em { color: var(--gold); font-style: italic; }
.sh p { color: rgba(255,255,255,.45); font-size: clamp(.9rem,1.4vw,1.05rem); max-width: 520px; margin: 18px auto 0; line-height: 1.82; }

/* Offering label rows */
.off-lbl { display: flex; align-items: center; gap: 16px; margin-bottom: clamp(18px,2.5vw,26px); }
.off-lbl span { font-size: .6rem; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: rgba(201,168,76,.55); white-space: nowrap; }
.off-lbl::after { content: ''; flex: 1; height: 1px; background: rgba(255,255,255,.08); }

/* Flagship hero offering */
.off-hero {
  background: linear-gradient(130deg, rgba(201,168,76,.07) 0%, rgba(13,27,42,.6) 100%);
  border: 1px solid rgba(201,168,76,.2);
  padding: clamp(40px,5vw,64px) clamp(32px,5vw,64px);
  display: grid; grid-template-columns: 1fr auto;
  gap: clamp(28px,4vw,56px); align-items: center;
  position: relative; overflow: hidden;
  margin-bottom: clamp(32px,4vw,48px); transition: border-color .3s;
}
.off-hero:hover                { border-color: rgba(201,168,76,.4); }
.off-hero::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(to right, var(--gold), rgba(201,168,76,.3)); }
.off-hero::after  { content: 'RETREAT'; position: absolute; bottom: -14px; right: clamp(60px,8vw,100px); font-family: var(--serif); font-size: 7rem; font-weight: 300; color: rgba(201,168,76,.04); line-height: 1; pointer-events: none; user-select: none; letter-spacing: .1em; }
.off-hero-badge { display: inline-flex; align-items: center; gap: 8px; font-size: .6rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; }
.off-hero-badge::before { content: ''; width: 20px; height: 1px; background: var(--gold); }
.off-hero h3 { font-family: var(--serif); font-size: clamp(2rem,3.8vw,3.2rem); color: #fff; line-height: 1.1; margin-bottom: 16px; }
.off-hero p  { font-size: clamp(.88rem,1.3vw,.98rem); color: rgba(255,255,255,.52); line-height: 1.78; max-width: 560px; margin-bottom: 12px; }
.off-hero-date { font-family: var(--serif); font-size: clamp(.95rem,1.5vw,1.1rem); font-style: italic; color: var(--gold); margin-bottom: 28px; line-height: 1.5; }
.off-hero-cta  { flex-shrink: 0; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.off-hero-price { font-family: var(--serif); font-size: clamp(1.4rem,2.5vw,1.9rem); color: var(--gold); text-align: center; line-height: 1; }
.off-hero-price small { display: block; font-family: var(--sans); font-size: .65rem; color: rgba(255,255,255,.35); letter-spacing: .1em; text-transform: uppercase; margin-top: 4px; }

/* 3-column offering grid */
.off-g3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-bottom: clamp(32px,4vw,48px); }

/* Individual offering card (dark bg) */
.off-c {
  background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.07);
  padding: clamp(28px,3.5vw,44px) clamp(22px,3vw,36px);
  position: relative; overflow: hidden;
  transition: background .3s, border-color .3s, transform .3s;
}
.off-c:hover { background: rgba(201,168,76,.06); border-color: rgba(201,168,76,.22); transform: translateY(-3px); }
.off-c-stripe { height: 2px; width: 100%; margin-bottom: 24px; }
.stripe-burg  { background: var(--burg); }
.stripe-teal  { background: var(--teal); }
.stripe-gold  { background: var(--gold); }
.off-tag { display: inline-block; font-size: .58rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; padding: 4px 11px; border-radius: 20px; margin-bottom: 14px; }
.tag-sig { background: rgba(125,31,46,.18); color: rgba(255,150,150,.8); }
.tag-prog{ background: rgba(45,107,116,.18); color: var(--teal-lt); }
.tag-fw  { background: rgba(201,168,76,.12); color: var(--gold); }
.off-c-bg { position: absolute; top: 16px; right: 18px; font-family: var(--serif); font-size: 4rem; color: rgba(255,255,255,.03); line-height: 1; pointer-events: none; user-select: none; }
.off-c h4 { font-family: var(--serif); font-size: clamp(1.25rem,2vw,1.65rem); color: #fff; margin-bottom: 10px; line-height: 1.2; }
.off-c p  { font-size: clamp(.83rem,1.1vw,.92rem); color: rgba(255,255,255,.45); line-height: 1.75; margin-bottom: 22px; }
.off-c .bo-lt { margin-top: auto; }

/* Retreat photo grid inside hero offering */
.retreat-ph-g { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 28px; }
.retreat-ph-g .ph { aspect-ratio: 3/2; }

/* Photo placeholder (light) */
.ph {
  background: linear-gradient(145deg, var(--navy-md) 0%, var(--navy) 100%);
  border: 1px solid rgba(201,168,76,.12);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 10px; position: relative; overflow: hidden;
}
.ph::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 80% 80% at 50% 40%, rgba(201,168,76,.06) 0%, transparent 65%); }
.ph-icon { font-size: 1.6rem; opacity: .18; position: relative; z-index: 1; }
.ph-lbl  { font-family: var(--serif); font-style: italic; font-size: clamp(.7rem,1.1vw,.82rem); color: rgba(201,168,76,.25); letter-spacing: .12em; text-align: center; position: relative; z-index: 1; line-height: 1.6; padding: 0 16px; }
.off-c-photo { width: 100%; aspect-ratio: 16/9; margin-bottom: 20px; }

/* Lead Magnet / Form block */
.off-magnet {
  background: var(--cream); border: 1px solid var(--rule); border-left: 4px solid var(--gold);
  padding: clamp(36px,5vw,56px); display: grid; grid-template-columns: 280px 1fr;
  gap: clamp(28px,4vw,52px); align-items: center; position: relative; overflow: hidden;
  box-shadow: 0 4px 40px rgba(13,27,42,.07);
}
.off-magnet::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(to right, var(--gold), rgba(201,168,76,.3), transparent); }
.off-magnet::after  { content: 'L.I.F.E.'; position: absolute; bottom: -20px; right: 32px; font-family: var(--serif); font-size: 5.5rem; font-weight: 300; color: rgba(201,168,76,.1); line-height: 1; pointer-events: none; user-select: none; letter-spacing: .2em; }
.magnet-ph { width: 100%; aspect-ratio: 4/5; }
.magnet-h  { font-family: var(--serif); font-size: clamp(1.6rem,2.8vw,2.4rem); color: var(--navy); line-height: 1.18; margin-bottom: 14px; }
.magnet-h em { color: var(--gold); font-style: italic; }
.magnet-p  { font-size: clamp(.85rem,1.2vw,.95rem); color: var(--text-md); line-height: 1.78; margin-bottom: 28px; max-width: 520px; }

/* Lead-magnet form */
.mf-note { font-size: .68rem; color: var(--text-lt); margin-top: 14px; font-style: italic; }

/* 2-column courses row */
.off-g2 { display: grid; grid-template-columns: 1fr 1fr; gap: 2px; margin-bottom: clamp(32px,4vw,48px); }

/* DevOtional 31-day block */
.off-dev {
  background: rgba(255,255,255,.03); border: 1px solid rgba(201,168,76,.15);
  padding: clamp(32px,4vw,52px) clamp(28px,4vw,52px);
  display: grid; grid-template-columns: 1fr auto;
  gap: clamp(24px,4vw,52px); align-items: center;
  position: relative; overflow: hidden; transition: border-color .3s;
}
.off-dev:hover                 { border-color: rgba(201,168,76,.32); }
.off-dev::after { content: '31'; position: absolute; bottom: -16px; right: clamp(60px,8vw,120px); font-family: var(--serif); font-size: 8rem; font-weight: 300; color: rgba(201,168,76,.05); line-height: 1; pointer-events: none; user-select: none; }
.dev-tag { display: inline-block; font-size: .58rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; padding: 4px 12px; border-radius: 20px; background: rgba(201,168,76,.12); color: var(--gold); margin-bottom: 14px; }
.off-dev h4 { font-family: var(--serif); font-size: clamp(1.5rem,3vw,2.2rem); color: #fff; line-height: 1.2; margin-bottom: 12px; }
.off-dev .dev-body { font-size: clamp(.88rem,1.3vw,.98rem); color: rgba(255,255,255,.5); line-height: 1.78; max-width: 520px; }
.dev-cta-wrap { flex-shrink: 0; text-align: center; }
.dev-cta-wrap small { display: block; font-size: .7rem; color: rgba(255,255,255,.28); margin-top: 10px; font-style: italic; }

/* ── SECTION: ALIGNMENT MODEL ────────────────────────────── */
.s-ali { background: var(--cream); padding: clamp(80px,11vw,130px) 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); position: relative; overflow: hidden; }
.ali-orb-1 { width:480px; height:480px; top:-100px; left:-100px;    animation: floatA 16s ease-in-out infinite; }
.ali-orb-2 { width:280px; height:280px; bottom:-60px; right:-60px;  animation: pulseRing 11s ease-in-out infinite 2s; }
.ali-orb-3 { width:160px; height:160px; top:35%; right:8%;          animation: floatB 13s ease-in-out infinite 1s; }

/* Circle nodes */
.model-g { display: flex; align-items: start; justify-content: center; gap: 0; margin: clamp(44px,6vw,68px) 0 clamp(44px,6vw,64px); }
.mn { display: flex; flex-direction: column; align-items: center; text-align: center; flex: 0 0 auto; }
.mn-circle {
  width: clamp(160px,18vw,220px); height: clamp(160px,18vw,220px); border-radius: 50%;
  border: 2px solid var(--rule); background: #fff;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px; padding: 20px; box-shadow: 0 4px 28px rgba(13,27,42,.07);
  transition: border-color .3s, box-shadow .3s, transform .3s; position: relative;
}
.mn-circle::before { content: ''; position: absolute; inset: -6px; border-radius: 50%; border: 1px solid transparent; transition: border-color .3s; }
.mn:hover .mn-circle { border-color: var(--gold); box-shadow: 0 8px 40px rgba(201,168,76,.15); transform: translateY(-4px); }
.mn:hover .mn-circle::before   { border-color: rgba(201,168,76,.2); }
.mn h4 { font-family: var(--serif); font-size: clamp(1.1rem,1.8vw,1.5rem); color: var(--navy); line-height: 1.1; margin: 0; }
.mn-role { font-size: .58rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); margin-top: 4px; }
.mn-desc { font-size: clamp(.75rem,1vw,.85rem); color: var(--text-md); line-height: 1.55; margin-top: clamp(12px,1.5vw,18px); max-width: clamp(130px,15vw,180px); text-align: center; }
.m-arr { display: flex; align-items: center; flex-shrink: 0; padding: 0 clamp(8px,1.5vw,24px); color: var(--gold); font-size: clamp(1.2rem,2.2vw,1.8rem); opacity: .6; margin-bottom: clamp(30px,4vw,50px); min-height: stretch;}
.m-cap { text-align: center; max-width: 640px; margin: 0 auto; }
.pq   { font-family: var(--serif); font-size: clamp(1.3rem,2.4vw,2.1rem); font-style: italic; color: var(--navy); line-height: 1.38; }
.pa   { font-size: .72rem; color: var(--text-lt); margin-top: 14px; font-style: italic; }

/* ── SECTION: TESTIMONIALS ───────────────────────────────── */
.s-test { background: #fff; padding: clamp(80px,11vw,130px) 0; border-bottom: 1px solid var(--rule); }
.test-g { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(16px,2.5vw,28px); margin-top: clamp(44px,6vw,68px); }
.tc { background: var(--sand); padding: clamp(28px,4vw,42px) clamp(22px,3.5vw,36px); border-bottom: 3px solid var(--gold); transition: transform .3s, box-shadow .3s; }
.tc:hover { transform: translateY(-3px); box-shadow: 0 12px 40px rgba(13,27,42,.07); }
.tq-open { font-family: var(--serif); font-size: 3.2rem; color: var(--gold); line-height: 0; vertical-align: -0.42em; margin-right: 3px; display: inline; }
.tq { font-family: var(--serif); font-size: clamp(1rem,1.55vw,1.15rem); font-style: italic; color: var(--navy); line-height: 1.68; margin-bottom: 24px; }
.ta { font-size: .68rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--text-lt); }
.test-ph-g { display: grid; grid-template-columns: repeat(2,1fr); gap: 12px; margin-top: clamp(36px,5vw,56px); }
.test-ph-g .ph { aspect-ratio: 4/3; }

/* ── SECTION: STATS ──────────────────────────────────────── */
.s-stats { background: var(--navy); padding: clamp(52px,7vw,76px) 0; position: relative; overflow: hidden; }
.stats-orb-1 { width:380px; height:380px; top:-100px; left:50%; transform: translateX(-50%); animation: pulseRing 10s ease-in-out infinite; }
.stats-g { display: grid; grid-template-columns: repeat(4,1fr); gap: 0; max-width: 1120px; margin: 0 auto; padding: 0 clamp(20px,5vw,64px); }
.sb { text-align: center; padding: 0 clamp(14px,2.5vw,28px); }
.sb + .sb { border-left: 1px solid rgba(255,255,255,.14); }
/* Gold shimmer on numbers */
.sn {
  font-family: var(--serif); font-size: clamp(2.5rem,5.5vw,3.8rem); line-height: 1;
  background: linear-gradient(90deg, var(--gold) 0%, #f0d98a 40%, var(--gold) 60%, #c9a84c 100%);
  background-size: 200% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: shimmer 4s linear infinite;
}
.sl { font-size: .62rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-top: 10px; }

/* ── SECTION: PODCAST ────────────────────────────────────── */
.s-pod { background: var(--warm); padding: clamp(80px,11vw,130px) 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.pod-g { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(48px,7vw,88px); align-items: center; }
.pod-tag { font-size: .62rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--teal); margin-bottom: 18px; }
.pod-g h2 { font-family: var(--serif); font-size: clamp(1.85rem,3.5vw,2.9rem); color: var(--navy); line-height: 1.18; margin-top: 10px; }
.pod-g p  { color: var(--text-md); font-size: clamp(.88rem,1.3vw,.98rem); line-height: 1.82; margin-top: 20px; margin-bottom: 34px; }
.pod-ls   { display: flex; flex-wrap: wrap; gap: 12px; }
.pl { padding: 12px 24px; border: 1.5px solid var(--rule); font-size: .68rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--text-md); border-radius: 1px; transition: border-color .2s, color .2s; }
.pl:hover { border-color: var(--navy); color: var(--navy); }
.pod-ph { width: 100%; aspect-ratio: 4/3; }

/* ── SECTION: CLOSE CTA ──────────────────────────────────── */
.s-cta { background: var(--sand); padding: clamp(90px,13vw,150px) clamp(20px,5vw,64px); text-align: center; border-top: 1px solid var(--rule); position: relative; overflow: hidden; }
.s-cta::before { content: ''; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(ellipse 60% 60% at 50% 80%, rgba(201,168,76,.07) 0%, transparent 65%); }
.cta-orb-1 { width:460px; height:460px; top:-100px; left:-80px;    animation: floatA 16s ease-in-out infinite; }
.cta-orb-2 { width:280px; height:280px; bottom:-80px; right:-80px; animation: floatB 14s ease-in-out infinite 5s; }
.cta-orb-3 { width:160px; height:160px; top:30%; right:20%;        animation: pulseRing 9s ease-in-out infinite; }
.cta-in    { max-width: 780px; margin: 0 auto; position: relative; z-index: 1; }
.cta-vl    { width: 1px; height: 56px; background: linear-gradient(to bottom, transparent, var(--gold), transparent); margin: 28px auto; }
.cta-in h2 { font-family: var(--serif); font-size: clamp(2rem,4.5vw,3.7rem); color: var(--navy); line-height: 1.14; margin-bottom: 24px; }
.cta-in p  { color: var(--text-md); font-size: clamp(.9rem,1.35vw,1.05rem); line-height: 1.85; max-width: 500px; margin: 0 auto 50px; }
.cta-in em { color: var(--text-lt); }

/* ── Orb sections that needs Isolation ───────────────────────────── */
.hero,
.s-rec,
.s-conf,
.s-offers,
.s-ali,
.s-test,
.s-pod,
.s-stats,
.s-cta {
  isolation: isolate;
}

/* ── RESPONSIVE: TABLET 960px ───────────────────────────── */
@media (max-width: 960px) {
  .hero          { grid-template-columns: 55% 45%; }
  .hero-c        { padding: 120px clamp(24px,6vw,48px) 80px; min-height: 100svh; justify-content: center; }
  .hero-vis		 { min-height: 220px; max-height: 100%; }
  .hero-img img  { height: 100%; max-width: 100%; object-fit: none; }
  .hero-h1       { font-size: clamp(2.8rem,7vw,4.2rem); }
  .rec-g         { grid-template-columns: 1fr; }
  .rec-stick     { position: static; }
  .conf-t        { padding: clamp(28px,5vw,48px) clamp(24px,5vw,48px); }
  .conf-ph-strip { grid-template-columns: 1fr; }
  .conf-ph-side  { display: none; }
  .conf-ph-main  { aspect-ratio: 16/7; }
  .off-hero      { grid-template-columns: 1fr; }
  .off-hero-cta  { flex-direction: row; justify-content: flex-start; flex-wrap: wrap; gap: 12px; }
  .off-g3        { grid-template-columns: 1fr 1fr; }
  .off-g2        { grid-template-columns: 1fr; }
  .off-dev       { grid-template-columns: 1fr; }
  .off-magnet    { grid-template-columns: 1fr; padding: clamp(28px,5vw,44px); }
  .magnet-left   { display: none; }
  .dev-cta-wrap  { text-align: left; }
  .mf-row        { flex-wrap: wrap; }
  .mf-field      { min-width: 200px; }
  .model-g       { align-items: start; flex-direction: column; gap: 0; }
  .m-arr         { transform: rotate(90deg); padding: clamp(4px,1vw,8px) 0; margin-bottom: 0; }
  .mn-desc       { max-width: 240px; }
  .test-g        { grid-template-columns: 1fr 1fr; }
  .test-ph-g     { grid-template-columns: 1fr; }
  .stats-g       { grid-template-columns: 1fr 1fr; gap: 36px; }
  .off-c-photo   { aspect-ratio: 16/7; }
  .retreat-ph-g  { grid-template-columns: 1fr; }
}

/* ── RESPONSIVE: MOBILE 640px ───────────────────────────── */
@media (max-width: 640px) {
  .hero          { grid-template-columns: 1fr; }
  .hero-c        { padding: 100px 24px 64px; order: 1; }
  .hero-vis		 { order: 0; }
  .hero-img	 	 { min-height: 250px; }
  .hero-img img {
      height: 45vh;
      object-fit: cover;
      width: 100%;
      object-position: 50% 20%; }
  .hero-h1       { font-size: 2.6rem; line-height: 1.1; }
  .hero-sub      { font-size: .75rem; }
  .hero-btns     { flex-direction: column; align-items: stretch; gap: 10px; }
  .bp, .bgl      { width: 100%; justify-content: center; text-align: center; }
  .hero-tag      { margin-top: 36px; }
  .rec-bq        { font-size: 1.6rem; }
  .rec-b p       { font-size: .92rem; }
  .conf-t        { font-size: 1.6rem; padding: 28px 24px; }
  .off-g3        { grid-template-columns: 1fr; }
  .off-c         { padding: clamp(20px,5vw,28px); }
  .off-hero      { padding: clamp(24px,5vw,36px); }
  .off-hero h3   { font-size: 1.8rem; }
  .off-hero-cta  { flex-direction: column; align-items: stretch; }
  .off-hero-price{ font-size: 2rem; }
  .off-hero .bp, .off-hero .bg { width: 100%; justify-content: center; }
  .off-magnet    { padding: 24px; }
  .mf-row        { flex-direction: column; }
  .mf-btn        { width: 100%; justify-content: center; }
  .test-g        { grid-template-columns: 1fr; }
  .tc            { padding: 24px; }
  .stats-g       { grid-template-columns: 1fr 1fr; gap: 28px; }
  .sb            { padding: 0 12px; }
  .sn            { font-size: 2.2rem; }
  .pod-ls        { flex-direction: column; align-items: stretch; }
  .pl            { text-align: center; justify-content: center; }
  .cta-in h2     { font-size: 1.9rem; }
  .cta-in p      { font-size: .88rem; }
  .model-g       { align-items: center }
  .pod-g  { grid-template-columns: 1fr; }
}

/* ── RESPONSIVE: SMALL MOBILE 380px ─────────────────────── */
@media (max-width: 380px) {
  .hero-h1       { font-size: 2.1rem; }
  .conf-t        { font-size: 1.35rem; }
  .sn            { font-size: 1.9rem; }
  .mn-circle     { width: 150px; height: 150px; }
  .off-hero h3   { font-size: 1.5rem; }
  .model-g       { align-items: center }
  .pod-g  { grid-template-columns: 1fr; }
}

/* ── TOUCH DEVICES ───────────────────────────────────────── */
@media (hover: none) {
  .bp, .bgl, .bo, .bg { min-height: 48px; }
  .off-c:hover   { transform: none; }
  .tc:hover      { transform: none; box-shadow: none; }
  .mn:hover .mn-circle { transform: none; }
}