/* ============================================================
   THE VIVI FREQUENCY v10 — Hybrid Design System
   Blue-Turquoise + Warm Sand palette
   ============================================================ */
:root{
  --deep-indigo:#2E8EAE;--night-bloom:#0D3B66;--midnight:#082A4A;
  --indigo-light:#4ABBD0;--night-mid:#2E8EAE;--lavender-mist:#EDF5FA;--lavender-wash:#D8EBF5;--pale-lavender:#F4F9FC;
  --warm-coral:#E8735A;--sunset-pink:#D4697A;--coral-light:#F4A999;--sunset-sand:#C4956A;
  --soft-pink:#E8A0B8;--pink-dark:#C05070;
  --gold:#C9A84C;--gold-bright:#D4AF37;--gold-light:#E8CC6E;--gold-pale:#F5E6B8;
  --cream-white:#FFF8F0;--cream-light:#FDF5ED;--lavender-warm:#EDF5FA;--lavender-deep:#D8EBF5;
  --text-primary:#5E4A3A;--text-secondary:#746252;--text-light:#F4EDE4;--text-muted:#6A9AB5;
  /* Sand/Warm (from v6, restored) */
  --sand-white:#FFF8F0;--sand-light:#FDF5ED;--sand-warm:#F5EDE0;--sand-deep:#EDE3D4;
  /* Pink highlights (Viviana's fix - deeper, readable) */
  --highlight-pink:#B86A96;
  /* Buttons (sunlight on sand) */
  --btn-primary-color:#E6C7A1;--btn-hover-color:#DDB892;
  /* Text (warm, readable) */
  --text-warm-white:#F4EDE4;--text-main:#5E4A3A;--text-secondary-warm:#746252;
  /* Content section backgrounds */
  --section-sand:#F5EFE8;--section-sand-warm:#F1E7DD;--card-border:#D8C7B8;--card-bg:#F8F4EE;
  /* Nav (unified teal glass) */
  --nav-teal:rgba(47,164,169,0.7);--nav-gradient-start:#2FA4A9;--nav-gradient-end:#6ED3CF;
  --gradient-celestial:linear-gradient(135deg,#1A6B8A 0%,#2E8EAE 25%,#2FA4A9 50%,#4ABBD0 70%,#7DD4E4 85%,#B8EBF2 100%);
  --gradient-gold:linear-gradient(135deg,#E6C7A1 0%,#DDB892 50%,#D4A87A 100%);
  --gradient-indigo-glow:radial-gradient(ellipse at center,rgba(125,212,228,.15) 0%,transparent 70%);
  --font-display:'Playfair Display',Georgia,serif;
  --font-accent:'Cormorant',Georgia,serif;
  --font-body:'Nunito Sans',system-ui,sans-serif;
  --fs-hero:clamp(2.8rem,6vw,5.5rem);--fs-h1:clamp(2.2rem,4.5vw,4rem);--fs-h2:clamp(1.8rem,3.5vw,3rem);
  --fs-h3:clamp(1.3rem,2vw,1.75rem);--fs-h4:clamp(1.1rem,1.5vw,1.35rem);--fs-body:clamp(1rem,1.1vw,1.125rem);
  --fs-small:clamp(.85rem,.95vw,.95rem);--fs-accent:clamp(1.15rem,1.4vw,1.4rem);
  --lh-tight:1.15;--lh-snug:1.3;--lh-normal:1.7;--lh-relaxed:1.85;
  --ls-wide:.08em;--ls-ultra:.18em;
  --space-xs:.5rem;--space-sm:1rem;--space-md:1.5rem;--space-lg:2.5rem;--space-xl:4rem;--space-2xl:6rem;--space-3xl:9rem;
  --section-pad:clamp(5rem,10vh,9rem);--container:min(1200px,90vw);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --r-sm:6px;--r-md:12px;--r-lg:20px;--r-xl:32px;--r-full:9999px;
  --sh-sm:0 2px 8px rgba(13,59,102,.06);--sh-md:0 4px 20px rgba(13,59,102,.1);
  --sh-lg:0 8px 40px rgba(13,59,102,.14);--sh-glow:0 0 30px rgba(74,187,208,.25);
  --sh-gold:0 4px 20px rgba(201,168,76,.25);--sh-coral:0 4px 20px rgba(232,116,97,.25);
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:80px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
body{font-family:var(--font-body);font-size:var(--fs-body);line-height:var(--lh-normal);color:var(--text-main);background:var(--sand-white);overflow-x:hidden;-webkit-font-smoothing:antialiased;font-weight:300}
body::before{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}ul,ol{list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:var(--lh-snug)}
::selection{background:rgba(74,187,208,.3);color:#5E4A3A}
.container{width:var(--container);margin:0 auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.text-center{text-align:center}

/* Sections */
.section{padding:var(--section-pad) var(--space-md);position:relative}
.section-eyebrow{font-size:var(--fs-small);font-weight:600;letter-spacing:var(--ls-ultra);text-transform:uppercase;color:#2FA4A9;margin-bottom:var(--space-sm)}
.section-title{font-size:var(--fs-h2);color:#5E4A3A;margin-bottom:var(--space-md)}
.section-title em{font-style:italic;color:var(--highlight-pink)}
.section-lead{font-size:var(--fs-body);color:var(--text-secondary);max-width:640px;margin:0 auto var(--space-xl);line-height:var(--lh-relaxed)}
.section-ocean{background:var(--gradient-celestial);color:var(--text-primary)}
.section-ocean .section-eyebrow{color:var(--gold)}
.section-ocean .section-title{color:#F4EDE4}
.section-ocean .section-title em{color:var(--highlight-pink)}
.section-ocean .section-lead{color:rgba(255,253,247,.85)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.9rem 2rem;border-radius:var(--r-full);font-size:var(--fs-small);font-weight:600;letter-spacing:.04em;transition:all .4s var(--ease-out)}
.btn-primary{background:linear-gradient(135deg,#E6C7A1 0%,#DDB892 100%);color:#5E4A3A;box-shadow:0 4px 15px rgba(230,199,161,.3)}
.btn-primary:hover{transform:translateY(-3px);background:linear-gradient(135deg,#DDB892 0%,#D4A87A 100%);box-shadow:0 8px 25px rgba(230,199,161,0.4),0 0 15px rgba(230,199,161,0.15)}
.btn-secondary{background:transparent;color:var(--text-primary);border:1.5px solid rgba(30,74,122,.3)}
.btn-secondary:hover{background:rgba(30,74,122,.08);border-color:rgba(30,74,122,.5)}
.btn-coral{background:linear-gradient(135deg,#E8735A 0%,#D4697A 50%,#E8735A 100%);color:var(--cream-white);box-shadow:0 4px 15px rgba(232,115,90,.3),0 0 15px rgba(232,115,90,.1)}
.btn-coral:hover{transform:translateY(-3px);box-shadow:0 6px 25px rgba(232,115,90,.4),0 0 30px rgba(232,115,90,.15)}
.btn-aqua{background:linear-gradient(135deg,#2E8EAE 0%,#4ABBD0 50%,#7DD4E4 100%);color:#FFFDF7;box-shadow:0 4px 15px rgba(74,187,208,.3),0 0 15px rgba(125,212,228,.15)}
.btn-aqua:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(47,164,169,0.3),0 0 15px rgba(47,164,169,0.1)}

/* Reveals */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),transform 0.8s cubic-bezier(0.22, 1, 0.36, 1),filter 0.8s cubic-bezier(0.22, 1, 0.36, 1);filter:blur(1.5px)}
.reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}
.reveal-delay-1{transition-delay:.15s}.reveal-delay-2{transition-delay:.3s}.reveal-delay-3{transition-delay:.45s}

/* Navigation — Teal glass */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:.6rem 0;background:linear-gradient(135deg,#2FA4A9,#6ED3CF);backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);border-bottom:1px solid rgba(110,211,207,.25);box-shadow:0 4px 30px rgba(0,0,0,.06)}
.site-nav.scrolled{background:rgba(47,164,169,.85)}
.nav-inner{width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.nav-logo{font-family:var(--font-accent);font-size:1.4rem;color:var(--cream-white);font-style:italic;font-weight:600;letter-spacing:.06em}
.nav-links{display:flex;align-items:center;gap:var(--space-lg)}
.nav-links a{font-size:var(--fs-small);color:rgba(255,253,247,.9);transition:color .2s;position:relative;font-weight:500}
.nav-links a:hover,.nav-links a.active{color:var(--cream-white)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1.5px;background:var(--highlight-pink);transform:scaleX(0);transition:transform .4s var(--ease-out)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{background:linear-gradient(135deg,#E6C7A1 0%,#DDB892 100%)!important;color:#5E4A3A!important;padding:.5rem 1.2rem!important;border-radius:var(--r-full)!important;font-weight:600!important}
.nav-cta::after{display:none!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:22px;height:2px;background:var(--cream-white);transition:all .3s}
@media(max-width:900px){.nav-links{display:none}.nav-toggle{display:flex}}

/* Nav Dropdowns */
.nav-dropdown{position:relative}
.nav-dropdown>button{background:none;border:none;cursor:pointer;font:inherit;font-size:var(--fs-small);color:rgba(255,253,247,.9);font-weight:500;padding:0;display:inline-flex;align-items:center;gap:.35rem;position:relative;transition:color .2s}
.nav-dropdown>button:hover,.nav-dropdown.open>button,.nav-dropdown>button.active{color:var(--cream-white)}
.nav-dropdown>button::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1.5px;background:var(--highlight-pink);transform:scaleX(0);transition:transform .4s var(--ease-out)}
.nav-dropdown>button:hover::after,.nav-dropdown.open>button::after,.nav-dropdown>button.active::after{transform:scaleX(1)}
.nav-dropdown>button .caret{font-size:.7rem;line-height:1;transition:transform .3s var(--ease-out);opacity:.8}
.nav-dropdown.open>button .caret{transform:rotate(180deg)}
.nav-dropdown-menu{position:absolute;top:calc(100% + .85rem);left:50%;transform:translateX(-50%) translateY(-6px);min-width:200px;background:var(--cream-white);border:1px solid rgba(212,199,184,.5);border-radius:var(--r-md);padding:.6rem;box-shadow:0 12px 40px rgba(26,58,74,.18),0 2px 8px rgba(26,58,74,.06);opacity:0;visibility:hidden;transition:opacity .3s var(--ease-out),transform .3s var(--ease-out),visibility .3s;display:flex;flex-direction:column;gap:.1rem}
.nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown-menu a{display:block;padding:.6rem .85rem;font-size:var(--fs-small);color:#5E4A3A;font-weight:500;border-radius:var(--r-sm);transition:background .2s,color .2s;white-space:nowrap}
.nav-dropdown-menu a::after{display:none}
.nav-dropdown-menu a:hover,.nav-dropdown-menu a.active{background:rgba(47,164,169,.08);color:#2FA4A9}

/* Mobile overlay */
.mobile-overlay{position:fixed;inset:0;z-index:999;background:rgba(47,164,169,.95);backdrop-filter:blur(24px) saturate(1.6);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);opacity:0;visibility:hidden;transition:all .8s var(--ease-out)}
.mobile-overlay.active{opacity:1;visibility:visible}
.mobile-link{font-family:var(--font-display);font-size:1.5rem;color:var(--cream-white)}
.mobile-link:hover{color:var(--highlight-pink)}

/* Page Hero (non-home pages) */
.page-hero{padding:calc(80px + var(--space-2xl)) var(--space-md) var(--space-xl);background:linear-gradient(135deg,#1A6B8A 0%,#2E8EAE 25%,#2FA4A9 50%,#4ABBD0 75%,#6ED3CF 100%);position:relative;overflow:hidden;text-align:center}
.page-hero .section-title{color:#F4EDE4;margin-bottom:var(--space-sm);font-weight:600}
.page-hero .section-lead{color:rgba(255,255,255,0.9);font-weight:400}
.page-hero .starfield{position:absolute;inset:0}

/* Hero (home) */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#1A6B8A 0%,#2E8EAE 25%,#2FA4A9 50%,#4ABBD0 70%,#7DD4E4 85%,#B8EBF2 100%)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(255,255,255,0.03) 0%,transparent 60%);z-index:1;pointer-events:none}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 50% at 20% 80%,rgba(106,220,196,.12) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 20%,rgba(180,230,255,.1) 0%,transparent 50%),radial-gradient(ellipse 50% 30% at 50% 50%,rgba(232,115,90,.05) 0%,transparent 50%);animation:auroraShift 15s ease-in-out infinite alternate;pointer-events:none;z-index:1}
@keyframes auroraShift{0%{opacity:.5;transform:scale(1) rotate(0deg)}50%{opacity:.8;transform:scale(1.05) rotate(1deg)}100%{opacity:.6;transform:scale(1.02) rotate(-1deg)}}
.starfield{position:absolute;inset:0}.hero-aurora{position:absolute;inset:0;background:radial-gradient(ellipse 120% 60% at 30% 80%,rgba(106,220,196,.15) 0%,transparent 50%),radial-gradient(ellipse 80% 50% at 70% 20%,rgba(232,115,90,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 50% 60%,rgba(200,240,255,.12) 0%,transparent 40%);pointer-events:none;animation:as 20s ease-in-out infinite alternate}
@keyframes as{0%{opacity:.6}50%{opacity:1}100%{opacity:.7}}
.constellation-canvas{position:absolute;inset:0;z-index:1}.particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 var(--space-md);max-width:860px}
.hero-eyebrow{font-size:var(--fs-small);font-weight:600;letter-spacing:var(--ls-ultra);text-transform:uppercase;color:var(--gold-light);margin-bottom:var(--space-md);opacity:0;animation:fu 1s var(--ease-out) 1.2s forwards}
.hero-title{font-size:var(--fs-hero);color:#F4EDE4;font-weight:400;line-height:var(--lh-tight);margin-bottom:var(--space-md);text-shadow:0 2px 12px rgba(0,0,0,.15);opacity:0;animation:fu 1.2s var(--ease-out) 1.5s forwards}
.hero-title em{font-style:italic;color:#D4699B;font-weight:600;text-shadow:none}
.hero-subtitle{font-family:var(--font-accent);font-size:clamp(1.2rem,2vw,1.6rem);font-style:italic;color:#F4EDE4;margin-bottom:var(--space-xl);opacity:0;animation:fu 1s var(--ease-out) 1.8s forwards}
.hero-ctas{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;opacity:0;animation:fu 1s var(--ease-out) 2.1s forwards}
.hero-trust{display:flex;gap:var(--space-lg);justify-content:center;flex-wrap:wrap;margin-top:var(--space-xl);opacity:0;animation:fu 1s var(--ease-out) 2.4s forwards}
.hero-trust span{font-size:var(--fs-small);color:var(--cream-white);display:flex;align-items:center;gap:.4rem;font-weight:600}
.trust-dot{width:6px;height:6px;border-radius:50%;background:var(--sunset-coral);box-shadow:0 0 8px rgba(232,116,97,.4)}
.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;opacity:0;animation:fu 1s var(--ease-out) 2.8s forwards}
.hero-scroll span{font-size:.7rem;font-weight:600;letter-spacing:var(--ls-ultra);text-transform:uppercase;color:rgba(255,253,247,.7)}
.scroll-line{width:1px;height:40px;background:linear-gradient(180deg,rgba(125,212,228,.5),rgba(74,187,208,.2),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(1.2)}}
@keyframes fu{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.wave-divider{position:absolute;bottom:-1px;left:0;right:0;z-index:3}.wave-divider svg{display:block;width:100%;height:auto;transition:transform 0.6s ease}

/* Proof Bar */
.proof-bar{background:linear-gradient(90deg,#F5EFE8,#F8F4EE,#F5EFE8);padding:var(--space-lg) var(--space-md)}
.proof-inner{width:var(--container);margin:0 auto;display:flex;align-items:center;justify-content:center;gap:var(--space-xl);flex-wrap:wrap}
.proof-item{text-align:center}.proof-number{font-family:var(--font-display);font-size:var(--fs-h3);font-weight:600;color:#5E4A3A;display:block;text-shadow:0 0 20px rgba(47,164,169,0.12)}
.proof-stars{font-size:1.2rem;color:var(--gold);display:block}
.proof-label{font-size:var(--fs-small);color:#746252;display:block;margin-top:.2rem}
.proof-divider{width:1px;height:40px;background:rgba(30,74,122,.12)}
@media(max-width:600px){.proof-divider{display:none}.proof-inner{gap:var(--space-lg)}}

/* About */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2xl);align-items:start}
.about-narrative{max-width:560px}
.about-narrative p{margin-bottom:var(--space-md);line-height:var(--lh-relaxed);color:var(--text-secondary)}
.about-narrative p:first-of-type{font-size:clamp(1.05rem,1.2vw,1.2rem);color:var(--text-primary)}
.about-pull-quote{font-family:var(--font-accent);font-size:clamp(1.4rem,2vw,1.8rem);font-style:italic;color:#5E4A3A;line-height:var(--lh-snug);padding:var(--space-lg) 0;border-top:2px solid var(--btn-primary-color);border-bottom:1px solid rgba(216,199,184,.3);margin:var(--space-lg) 0}
.about-pull-quote::before{content:'\201C';font-family:var(--font-display);font-size:4rem;color:var(--indigo-light);line-height:.5;display:block;margin-bottom:var(--space-sm);opacity:.4}
.about-sidebar{position:sticky;top:120px}
.about-sidebar img{margin-bottom:var(--space-xl)}
.credentials{display:flex;flex-direction:column;gap:var(--space-md)}
.credential{display:flex;gap:var(--space-sm);align-items:flex-start;transition:transform .4s var(--ease-out)}
.credential:hover{transform:translateX(4px)}
.credential-dot{width:8px;height:8px;min-width:8px;background:var(--indigo-light);border-radius:50%;margin-top:8px}
.credential-text{font-size:var(--fs-small);color:var(--text-secondary);line-height:var(--lh-normal)}
.credential-text strong{display:block;color:var(--text-primary);font-weight:600}
@media(max-width:1024px){.about-grid{grid-template-columns:1fr;gap:var(--space-xl)}.about-sidebar{position:static;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg)}}
@media(max-width:600px){.about-sidebar{grid-template-columns:1fr}}

/* Bridge Quote Panel */
.section-bridge-quote{background:#EAF6F4}
.bridge-quote-panel{background:#F5EFE8;border:1px solid #D8C7B8;box-shadow:0 2px 12px rgba(94,74,58,0.08);backdrop-filter:blur(10px);border-radius:var(--r-lg);padding:var(--space-xl);max-width:800px;margin:var(--space-xl) auto;text-align:center;font-family:var(--font-accent);font-size:var(--fs-accent);font-style:italic;color:#746252;line-height:1.9;position:relative}
.bridge-quote-panel::before{content:'\201C';font-family:var(--font-display);font-size:5rem;color:var(--indigo-light);opacity:.2;position:absolute;top:.5rem;left:1.5rem;line-height:.5}

/* Reading Experience */
.reading-experience{position:relative;overflow:hidden}
.reading-act{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-md);position:relative;text-align:center}
.reading-act-1{background:linear-gradient(180deg,#FFF8F0 0%,#FDF5ED 30%,#F5EDE0 100%)}
.reading-act-2{background:linear-gradient(180deg,#FFE8D6 0%,#E8A87C 15%,#D4836B 35%,#3AA0A0 55%,#20A0A0 70%,#1A8A8A 100%)}
.reading-act-3{background:linear-gradient(180deg,#20A0A0 0%,#2BC4B4 25%,#4ABBD0 55%,#7DD4E4 100%)}
.act-content{position:relative;z-index:2;max-width:640px}
.act-number{font-size:var(--fs-small);font-weight:700;letter-spacing:var(--ls-ultra);text-transform:uppercase;margin-bottom:var(--space-sm)}
.reading-act-1 .act-number{color:var(--sunset-coral)}.reading-act-2 .act-number{color:var(--cream-white)}.reading-act-3 .act-number{color:var(--gold)}
.act-title{font-size:var(--fs-h1);font-weight:400;margin-bottom:var(--space-md);line-height:var(--lh-tight)}
.reading-act-1 .act-title{color:var(--deep-indigo)}.reading-act-2 .act-title{color:var(--cream-white);text-shadow:none}.reading-act-3 .act-title{color:var(--cream-white);text-shadow:none}
.act-description{font-family:var(--font-accent);font-size:var(--fs-accent);font-style:italic;line-height:var(--lh-relaxed);margin-bottom:var(--space-lg)}
.reading-act-1 .act-description{color:var(--text-secondary)}.reading-act-2 .act-description{color:rgba(255,253,247,.85)}.reading-act-3 .act-description{color:rgba(255,253,247,.85)}
.act-detail{font-size:var(--fs-body);line-height:var(--lh-relaxed);max-width:520px;margin:0 auto}
.reading-act-1 .act-detail{color:var(--text-secondary)}.reading-act-2 .act-detail{color:rgba(255,253,247,.8)}.reading-act-3 .act-detail{color:rgba(255,253,247,.8)}
.act-glow{position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(80px);opacity:.3;pointer-events:none;animation:gf 10s ease-in-out infinite alternate}
.reading-act-1 .act-glow{background:var(--sunset-coral);bottom:-100px;right:10%}
.reading-act-2 .act-glow{background:var(--gold);top:20%;left:5%}
.reading-act-3 .act-glow{background:var(--indigo-light);bottom:20%;right:10%}
@keyframes gf{0%{transform:translate(0,0) scale(1)}100%{transform:translate(20px,-15px) scale(1.15)}}
.reading-act-3 .star-scatter{position:absolute;inset:0;overflow:hidden}

/* Approach Cards */
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-top:var(--space-xl)}
.approach-card{background:#F8F4EE;border-radius:var(--r-lg);padding:var(--space-xl) var(--space-lg);box-shadow:0 2px 8px rgba(94,74,58,.06);border:1px solid #D8C7B8;transition:all .4s var(--ease-out);position:relative;overflow:hidden}
.approach-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#4ABBD0,#7DD4E4,#B8EBF2);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.approach-card:hover::before{transform:scaleX(1)}
.approach-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(42,142,174,.12),0 0 20px rgba(125,212,228,.08);border-color:rgba(74,187,208,.25)}
.approach-icon{font-size:1.8rem;margin-bottom:var(--space-md)}
.approach-title{font-family:var(--font-display);font-size:var(--fs-h4);font-weight:600;color:#5E4A3A;margin-bottom:var(--space-xs)}
.approach-text{font-size:var(--fs-body);color:#746252;line-height:var(--lh-relaxed)}
@media(max-width:900px){.approach-grid{grid-template-columns:1fr}}

/* Service Cards */
.services-duo{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl);margin-top:var(--space-xl);align-items:start}
.service-card{background:#F8F4EE;border-radius:var(--r-xl);padding:var(--space-2xl) var(--space-xl);box-shadow:0 2px 8px rgba(94,74,58,.06);border:1px solid #D8C7B8;transition:all .4s var(--ease-out);display:flex;flex-direction:column;position:relative;overflow:hidden;text-align:center}
.service-card:hover{transform:translateY(-8px);box-shadow:0 16px 48px rgba(74,187,208,.18),0 0 20px rgba(125,212,228,.08);border-color:rgba(74,187,208,.25)}
.service-badge{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:var(--ls-ultra);text-transform:uppercase;padding:.4rem 1rem;border-radius:var(--r-full);margin-bottom:var(--space-lg)}
.service-badge--aqua{background:rgba(106,174,214,.1);color:var(--night-mid)}.service-badge--gold{background:rgba(201,168,76,.1);color:var(--gold)}
.service-icon-lg{font-size:2.5rem;margin-bottom:var(--space-md)}
.service-name{font-family:var(--font-display);font-size:var(--fs-h3);font-weight:600;color:#5E4A3A;margin-bottom:var(--space-sm)}
.service-outcome{font-family:var(--font-accent);font-size:var(--fs-accent);font-style:italic;color:var(--highlight-pink);margin-bottom:var(--space-lg)}
.service-desc{font-size:var(--fs-body);color:#746252;line-height:var(--lh-relaxed);margin-bottom:var(--space-lg);flex-grow:1}
.service-price-block{padding:var(--space-lg) 0;border-top:1px solid rgba(106,174,214,.1);margin-bottom:var(--space-lg)}
.service-price{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:600;color:#5E4A3A}
.service-duration{font-size:var(--fs-small);color:var(--text-muted);margin-top:.3rem}
.service-includes{text-align:left;margin-bottom:var(--space-lg)}
.service-includes li{font-size:var(--fs-small);color:var(--text-secondary);padding:.5rem 0;border-bottom:1px solid rgba(106,174,214,.06);display:flex;align-items:center;gap:.5rem}
.service-includes li::before{content:'✦';color:var(--indigo-light);font-size:.7rem}
.service-card .btn{width:100%;justify-content:center;margin-top:auto}
@media(max-width:768px){.services-duo{grid-template-columns:1fr}}

/* Stories */
.stories-featured{background:linear-gradient(135deg,#1A8A8E 0%,#2FA4A9 30%,#4ABBD0 60%,#6ED3CF 100%);border-radius:var(--r-lg);padding:var(--space-2xl);margin-bottom:var(--space-xl);color:#F4EDE4;position:relative;overflow:hidden;box-shadow:0 8px 32px rgba(47,164,169,.15)}
.stories-featured::before{content:'\201C';font-family:var(--font-display);font-size:12rem;color:rgba(106,174,214,.08);position:absolute;top:-2rem;left:1rem;line-height:1}
.stories-featured::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(47,164,169,0.08) 0%,transparent 50%);pointer-events:none}
.featured-quote{font-family:var(--font-accent);font-size:clamp(1.3rem,2.2vw,1.8rem);font-style:italic;line-height:var(--lh-snug);margin-bottom:var(--space-lg);position:relative;z-index:1;font-weight:400;color:#FFFFFF;text-shadow:0 1px 3px rgba(0,0,0,0.2)}
.featured-attribution{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--fs-small);color:rgba(255,253,247,.85)}
.featured-attribution strong{color:var(--highlight-pink);font-weight:600}
.stories-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg)}
.story-card{background:#F8F4EE;border-radius:var(--r-md);padding:var(--space-lg);box-shadow:0 2px 8px rgba(94,74,58,.06);border:1px solid #D8C7B8;transition:all .4s var(--ease-out);position:relative;overflow:hidden}
.story-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(42,142,174,.12),0 0 20px rgba(125,212,228,.08);border-color:rgba(74,187,208,.25)}
.story-card::before{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--indigo-light),var(--sunset-coral));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease-out)}
.story-card:hover::before{transform:scaleX(1)}
.story-quote-mark{font-family:var(--font-display);font-size:3rem;color:var(--lavender-wash);line-height:.8;margin-bottom:var(--space-sm)}
.story-text{font-size:var(--fs-body);color:#5E4A3A;line-height:var(--lh-relaxed);margin-bottom:var(--space-md)}
.story-attribution{font-size:var(--fs-small);color:var(--text-muted)}
.story-attribution strong{color:#5E4A3A;font-weight:600}
@media(max-width:900px){.stories-grid{grid-template-columns:1fr}}

/* Grief — image left, copy right */
.section-grief{background:linear-gradient(180deg,var(--section-sand) 0%,var(--section-sand-warm) 50%,var(--section-sand) 100%)}
.grief-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--space-xl);align-items:start}
.grief-layout img{border-radius:var(--r-lg);width:100%;object-fit:cover}
.grief-content{max-width:720px}
.grief-icon{font-size:2.5rem;margin-bottom:var(--space-md)}
.grief-title{font-size:var(--fs-h2);color:#5E4A3A;margin-bottom:var(--space-lg)}
.grief-title em{color:var(--highlight-pink);font-style:italic}
.grief-text{font-family:var(--font-accent);font-size:var(--fs-accent);font-style:italic;color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-md)}
.grief-body{font-size:var(--fs-body);color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-md)}
.grief-offerings{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin:var(--space-xl) 0;text-align:left}
.grief-offering{padding:var(--space-lg);border-radius:var(--r-md);background:rgba(255,255,255,.7);border:1px solid rgba(106,174,214,.08)}
.grief-offering h4{font-family:var(--font-display);font-size:var(--fs-h4);color:#5E4A3A;margin-bottom:var(--space-sm)}
.grief-offering p{font-size:var(--fs-small);color:var(--text-secondary);line-height:var(--lh-relaxed)}
@media(max-width:768px){.grief-layout{grid-template-columns:1fr}.grief-offerings{grid-template-columns:1fr}}

/* Trust/Sceptic — DARK TEXT on light turquoise */
.trust-section{background:linear-gradient(135deg,#1A8A8E 0%,#2FA4A9 30%,#4ABBD0 60%,#6ED3CF 100%);position:relative;overflow:hidden}
.trust-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);margin-top:var(--space-xl)}
.trust-card{background:rgba(255,255,255,.5);border:1px solid #D8C7B8;border-radius:var(--r-lg);padding:var(--space-xl);transition:all .4s var(--ease-out);box-shadow:0 2px 8px rgba(94,74,58,.06)}
.trust-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(47,164,169,0.12),0 4px 12px rgba(0,0,0,0.06);border-color:rgba(74,187,208,.25)}
.trust-card-number{font-family:var(--font-display);font-size:var(--fs-h1);font-weight:700;color:var(--indigo-light);opacity:.3;margin-bottom:var(--space-sm)}
.trust-card-title{font-family:var(--font-display);font-size:var(--fs-h4);color:#5E4A3A;margin-bottom:var(--space-sm)}
.trust-card-text{font-size:var(--fs-body);color:#746252;line-height:var(--lh-relaxed)}
@media(max-width:768px){.trust-cards{grid-template-columns:1fr}}

/* Bridge */
.bridge-inner{display:grid;grid-template-columns:1fr;max-width:800px;margin:0 auto}
.bridge-highlight{font-family:var(--font-accent);font-size:var(--fs-accent);font-style:italic;color:var(--highlight-pink);line-height:var(--lh-snug);margin-bottom:var(--space-md)}
.bridge-text p{font-size:var(--fs-body);color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-md)}
.bridge-stats{display:flex;gap:var(--space-xl);margin-top:var(--space-lg);justify-content:center}
.bridge-stat{text-align:center}
.bridge-stat-number{font-family:var(--font-display);font-size:var(--fs-h2);font-weight:600;color:#5E4A3A}
.bridge-stat-label{font-size:var(--fs-small);color:var(--text-muted)}

/* Support Panel (darker) */
.support-panel{background:#F5EFE8;border:1px solid #D8C7B8;box-shadow:0 2px 12px rgba(94,74,58,0.08);border-radius:var(--r-lg);padding:var(--space-xl);max-width:700px;margin:0 auto var(--space-2xl)}

/* FAQ */
.faq-list{max-width:800px;margin:var(--space-xl) auto 0}
.faq-item{border-bottom:1px solid rgba(106,174,214,.1)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg) 0;text-align:left;font-family:var(--font-display);font-size:var(--fs-h4);font-weight:500;color:#5E4A3A;transition:color .2s}
.faq-question:hover{color:#4ABBD0}
.faq-icon{width:24px;height:24px;position:relative;flex-shrink:0}
.faq-icon::before,.faq-icon::after{content:'';position:absolute;background:#4ABBD0;border-radius:2px;transition:transform .4s var(--ease-out)}
.faq-icon::before{width:16px;height:2px;top:11px;left:4px}
.faq-icon::after{width:2px;height:16px;top:4px;left:11px}
.faq-question[aria-expanded="true"] .faq-icon::after{transform:rotate(90deg);opacity:0}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .8s var(--ease-out)}
.faq-answer-inner{padding:0 0 var(--space-lg);font-size:var(--fs-body);color:var(--text-secondary);line-height:var(--lh-relaxed)}

/* Lead Magnet */
.lead-magnet{background:linear-gradient(135deg,#1A8A8E 0%,#2FA4A9 30%,#4ABBD0 60%,#6ED3CF 100%);border-radius:var(--r-xl);padding:var(--space-2xl);text-align:center;position:relative;overflow:hidden;box-shadow:inset 0 0 80px rgba(110,211,207,.08)}
.lead-magnet::before{content:'';position:absolute;inset:0;background:var(--gradient-indigo-glow);pointer-events:none}
.lead-magnet-title{font-size:var(--fs-h2);color:#F4EDE4;position:relative;z-index:1;margin-bottom:var(--space-sm)}
.lead-magnet-subtitle{font-family:var(--font-accent);font-size:var(--fs-accent);font-style:italic;color:rgba(255,253,247,.85);position:relative;z-index:1;margin-bottom:var(--space-lg)}
.lead-magnet-benefits{display:flex;gap:var(--space-lg);justify-content:center;flex-wrap:wrap;margin-bottom:var(--space-xl);position:relative;z-index:1}
.lead-benefit{font-size:var(--fs-small);color:rgba(255,253,247,.85);display:flex;align-items:center;gap:.4rem}
.lead-benefit-dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.lead-magnet-form{max-width:500px;margin:0 auto;position:relative;z-index:1}
.lead-magnet-fields{display:flex;gap:.5rem;margin-bottom:.5rem}
.lead-magnet-fields input{flex:1;padding:.85rem 1.2rem;border-radius:var(--r-full);border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.15);color:var(--cream-white);font-size:var(--fs-small);font-family:var(--font-body)}
.lead-magnet-fields input::placeholder{color:rgba(255,253,247,.5)}
.lead-magnet-fields input:focus{outline:none;border-color:var(--indigo-light)}
.lead-magnet-form button{width:100%;padding:.85rem;border-radius:var(--r-full);background:var(--gradient-gold);color:var(--deep-indigo);font-weight:700;font-size:var(--fs-small);transition:all .4s var(--ease-out)}
.lead-magnet-form button:hover{transform:translateY(-2px);box-shadow:var(--sh-gold)}
.lead-magnet-msg{margin-top:var(--space-sm);font-size:var(--fs-small);position:relative;z-index:1}
.lead-magnet-fine{font-size:.75rem;color:rgba(255,253,247,.4);margin-top:var(--space-sm);position:relative;z-index:1}
@media(max-width:600px){.lead-magnet-fields{flex-direction:column}}

/* Booking Badge */
.booking-badge{display:inline-flex;align-items:center;gap:.5rem;font-size:var(--fs-small);font-weight:500;color:#2E8EAE;background:rgba(74,187,208,.08);padding:.5rem 1rem;border-radius:var(--r-full);margin-bottom:var(--space-md);border:1px solid rgba(74,187,208,.2)}
.booking-badge-dot{width:8px;height:8px;border-radius:50%;background:#4ABBD0;box-shadow:0 0 8px rgba(74,187,208,.6);animation:dp 2s ease-in-out infinite}
@keyframes dp{0%,100%{opacity:1;box-shadow:0 0 8px rgba(74,187,208,.6)}50%{opacity:.7;box-shadow:0 0 8px rgba(74,187,208,.3),0 0 0 6px rgba(74,187,208,0)}}

/* Ornament */
.ornament{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl) 0}
.ornament-line{width:80px;height:1px;background:linear-gradient(90deg,transparent,rgba(74,187,208,.4),rgba(125,212,228,.5),rgba(74,187,208,.4),transparent)}
.ornament-diamond{width:8px;height:8px;background:#4ABBD0;transform:rotate(45deg);opacity:.5;box-shadow:0 0 6px rgba(74,187,208,.3)}

/* Footer */
.site-footer{background:linear-gradient(135deg,#1A8A8E 0%,#2FA4A9 25%,#4ABBD0 50%,#6ED3CF 75%,#8DE0DC 100%);color:var(--text-warm-white);padding:var(--space-2xl) var(--space-md) var(--space-lg);position:relative;overflow:hidden}
.footer-stars{position:absolute;inset:0;opacity:.4}
.footer-grid{width:var(--container);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:var(--space-xl);position:relative;z-index:1;align-items:start}
@media(max-width:1024px){.footer-grid{grid-template-columns:1.3fr 1fr 1fr 1fr;gap:var(--space-lg)}}
.footer-brand-name{font-family:var(--font-accent);font-size:1.6rem;font-style:italic;margin-bottom:var(--space-sm);color:var(--cream-white)}
.footer-brand-tagline{font-family:var(--font-accent);font-style:italic;color:rgba(255,253,247,.85);margin-bottom:var(--space-md)}
.footer-brand-text{font-size:var(--fs-small);color:#FFFFFF;font-weight:400;line-height:var(--lh-relaxed);max-width:280px;text-shadow:0 1px 2px rgba(0,0,0,0.12)}
.footer-social{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}
.footer-social a{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:.85rem;color:rgba(255,253,247,.8);transition:all .2s}
.footer-social a:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.4);color:var(--cream-white)}
.footer-heading{font-size:var(--fs-small);font-weight:600;letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--highlight-pink);margin-bottom:var(--space-md);text-shadow:0 1px 2px rgba(0,0,0,0.12)}
.footer-links{display:flex;flex-direction:column;gap:var(--space-sm)}
.footer-links a{font-size:var(--fs-small);color:#FFFFFF;font-weight:400;transition:color .2s;text-shadow:0 1px 2px rgba(0,0,0,0.12)}
.footer-links a:hover{color:var(--cream-white)}
.footer-bottom{width:var(--container);margin:var(--space-xl) auto 0;padding-top:var(--space-lg);border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md);position:relative;z-index:1}
.footer-copy{font-size:.75rem;color:rgba(255,253,247,.5)}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr}}

/* Bolder text on dark backgrounds for readability */
.site-footer, .section-ocean, .trust-section, .page-hero {
  font-weight: 400;
}
.site-footer .footer-heading,
.site-footer .footer-brand-name,
.trust-section .trust-card-title,
.page-hero .section-title {
  font-weight: 600;
}

/* Progress Bar */
.reading-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:1001}
.reading-progress-bar{height:100%;width:0;background:linear-gradient(90deg,#2FA4A9,#6ED3CF,#E6C7A1,#B86A96);transition:width .1s linear}

/* Cursor Glow */
.cursor-glow{position:fixed;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(74,187,208,.08) 0%,transparent 70%);pointer-events:none;z-index:9998;transform:translate(-50%,-50%)}
@media(max-width:768px){.cursor-glow{display:none}}

/* Retreat panels — dark text for readability */
.retreat-panel{background:rgba(255,253,247,.92);border-radius:var(--r-lg);padding:var(--space-xl);border:1px solid rgba(106,174,214,.12)}
.retreat-panel h3,.retreat-panel h4{color:#5E4A3A}
.retreat-panel p{color:var(--text-secondary)}

/* Academy with horse background */
.academy-hero{position:relative;background:url('images/viviana-horses.jpg') center/cover no-repeat;border-radius:var(--r-lg);overflow:hidden;padding:var(--space-2xl);margin-bottom:var(--space-xl)}
.academy-hero::before{content:'';position:absolute;inset:0;background:rgba(59,124,184,.75);backdrop-filter:blur(2px)}
.academy-hero *{position:relative;z-index:1}
.academy-hero .section-eyebrow{color:var(--gold-light);font-size:var(--fs-h4)}
.academy-hero .section-title{color:#F4EDE4}

/* Twinkling animation */
@keyframes tw{0%,100%{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
