/* ═══════════════════════════════════════════════════════════════════════════
   SKOOL OF DROOL v7 — "Morning Mist"
   A premium wellness aesthetic: watercolor washes, organic shapes,
   breathing animations, and a pastel rainbow that flows through nature.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Tokens ────────────────────────────────────────────────────────────── */
:root{
  --sea:#7DBCB3;--sea-deep:#5A9E94;--sea-mid:#92CEC4;--sea-light:#B5DFD8;--sea-wash:#E8F5F2;
  --peach:#F0B088;--peach-warm:#E89870;--peach-glow:#FCC8A0;--peach-pale:#FDE8D4;
  --cream:#FDF8F0;--cream-warm:#FAF0E0;--white:#fff;
  --ink:#3B2A1A;--ink-mid:#5C4A38;--ink-soft:#8B7355;--ink-faint:#C4B8A8;
  --sky:#8AB4D0;--sky-light:#C0DAF0;--heather:#C4A0D4;--heather-lt:#E8D8F0;
  --blush:#E8B0A8;--blush-lt:#F8E0D8;--sage:#A8C686;--sage-lt:#D4ECC8;
  --sunrise:#FFD4A0;--sunset:#E88060;--dusk:#6A4A78;--night:#1E1C24;
  --chakra-root:#E8A0A0;--chakra-sacral:#F0B888;--chakra-solar:#F0D488;
  --chakra-heart:#A0D8A0;--chakra-throat:#A0C8E8;--chakra-eye:#B8A0D8;
  --chakra-crown:#D8B0D0;--chakra-bond:#E0D8C8;
  --font-d:'Playfair Display',Georgia,serif;--font-b:'DM Sans',system-ui,sans-serif;
  --mw:1280px;--nh:72px;
  --ease:cubic-bezier(.16,1,.3,1);--ease-back:cubic-bezier(.34,1.56,.64,1);
  --ease-s:cubic-bezier(.22,1,.36,1);
  --sh-s:0 2px 12px rgba(90,158,148,.06);--sh-m:0 8px 32px rgba(90,158,148,.08);
  --sh-l:0 20px 60px rgba(90,158,148,.1);--sh-xl:0 32px 80px rgba(90,158,148,.12);
  --r-s:10px;--r-m:18px;--r-l:28px;--r-xl:40px;--r-pill:9999px;
}

/* ─── Reset ─────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);font-size:16px;line-height:1.75;color:var(--ink);background:var(--cream);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video,svg{max-width:100%;display:block}a{color:inherit;text-decoration:none}ul,ol{list-style:none}
button{border:none;background:none;cursor:pointer;font:inherit;color:inherit}input{font:inherit;color:inherit}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.container{max-width:var(--mw);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)}

/* Film grain */
body::after{content:'';position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.018;mix-blend-mode:overlay;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E")}

/* ─── Typography ────────────────────────────────────────────────────────── */
h1,h2,h3,h4{font-family:var(--font-d);font-weight:400;line-height:1.15}
h1{font-size:clamp(2.8rem,6vw,4.8rem);letter-spacing:-.03em}
h2{font-size:clamp(2rem,4.2vw,3.4rem);letter-spacing:-.02em}
h3{font-size:clamp(1.25rem,2.2vw,1.65rem)}
h4{font-size:1.05rem;font-weight:500}
h1 em,h2 em,h3 em{font-style:italic;color:var(--sky)}
p{max-width:65ch}

/* ─── Scroll Progress ───────────────────────────────────────────────────── */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:10002;background:linear-gradient(90deg,var(--sea-mid),var(--sky),var(--heather),var(--peach-glow));box-shadow:0 0 8px rgba(125,188,179,.3);transition:none}

/* ─── Loader ────────────────────────────────────────────────────────────── */
.page-loader{position:fixed;inset:0;z-index:10000;background:var(--cream);display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease-s),visibility .6s}
.page-loader.loaded{opacity:0;visibility:hidden;pointer-events:none}
.page-loader__content{text-align:center}
.paw-trail{display:flex;gap:.5rem;margin-bottom:1.5rem;justify-content:center;align-items:center;height:3.5rem}
.paw{opacity:0;display:inline-block}
.paw--left{margin-top:-.4rem;transform:rotate(90deg)}
.paw--right{margin-top:.4rem;transform:rotate(90deg) scaleX(-1)}
/* 6 paws, each visible for ~0.5s, total cycle = 3.6s. Each paw gets 1/6 = 16.7% of the cycle */
.paw--1{animation:paw1 3.6s ease-in-out infinite}
.paw--2{animation:paw2 3.6s ease-in-out infinite}
.paw--3{animation:paw3 3.6s ease-in-out infinite}
.paw--4{animation:paw4 3.6s ease-in-out infinite}
.paw--5{animation:paw5 3.6s ease-in-out infinite}
.paw--6{animation:paw6 3.6s ease-in-out infinite}
@keyframes paw1{0%{opacity:0}4%{opacity:1}12%{opacity:1}16%{opacity:0}100%{opacity:0}}
@keyframes paw2{0%,16%{opacity:0}20%{opacity:1}28%{opacity:1}32%{opacity:0}100%{opacity:0}}
@keyframes paw3{0%,32%{opacity:0}36%{opacity:1}44%{opacity:1}48%{opacity:0}100%{opacity:0}}
@keyframes paw4{0%,48%{opacity:0}52%{opacity:1}60%{opacity:1}64%{opacity:0}100%{opacity:0}}
@keyframes paw5{0%,64%{opacity:0}68%{opacity:1}76%{opacity:1}80%{opacity:0}100%{opacity:0}}
@keyframes paw6{0%,80%{opacity:0}84%{opacity:1}92%{opacity:1}96%{opacity:0}100%{opacity:0}}
.page-loader__text{font-family:var(--font-d);font-size:1.3rem;color:var(--ink);letter-spacing:.05em;margin-bottom:1.2rem;opacity:.7}
.page-loader__bar{width:160px;height:3px;border-radius:3px;background:rgba(125,188,179,.15);margin:0 auto;overflow:hidden}
.page-loader__fill{height:100%;width:0;border-radius:3px;background:linear-gradient(90deg,var(--sea-mid),var(--peach),var(--heather),var(--sky));animation:loaderFill 2.5s ease-in-out infinite}
@keyframes loaderFill{0%{width:0}50%{width:100%}100%{width:100%;opacity:0}}
@keyframes ldot{0%,80%,100%{transform:scale(.5);opacity:.3}40%{transform:scale(1.3);opacity:1}}

/* ─── Navigation ────────────────────────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nh);z-index:1000;display:flex;align-items:center;transition:all .4s var(--ease);background:rgba(253,248,240,.4);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.nav.scrolled{background:rgba(253,248,240,.92);backdrop-filter:blur(20px) saturate(1.6);-webkit-backdrop-filter:blur(20px) saturate(1.6);box-shadow:0 1px 0 rgba(90,158,148,.08),0 4px 24px rgba(90,158,148,.04);height:62px}
.nav__inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--mw);margin:0 auto;padding:0 clamp(1.5rem,4vw,3rem)}
.nav__logo{font-family:var(--font-d);font-size:1.35rem;font-weight:600;color:var(--sea-deep);letter-spacing:.01em;transition:color .3s;display:flex;align-items:center;gap:.6rem}
.nav__logo-img{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.nav__links{display:flex;gap:2.5rem;align-items:center}
.nav__links a{font-size:.84rem;font-weight:500;color:var(--ink-mid);letter-spacing:.015em;position:relative;transition:color .25s}
.nav__links a::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:1.5px;background:var(--sea);border-radius:2px;transition:width .35s var(--ease),left .35s var(--ease)}
.nav__links a:hover{color:var(--sea-deep)}
.nav__links a:hover::after,.nav__links a[aria-current="page"]::after{width:100%;left:0}
.nav__links a[aria-current="page"]{color:var(--sea-deep)}
.nav__cta{margin-left:.5rem}
.nav__hamburger{display:none;flex-direction:column;gap:5px;width:26px;height:26px;justify-content:center;z-index:1001}
.nav__hamburger span{height:1.5px;background:var(--ink);border-radius:2px;transition:all .35s var(--ease);display:block;width:22px}
.nav__hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav__hamburger.open span:nth-child(2){opacity:0}
.nav__hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}
.nav__mobile-menu{position:fixed;inset:0;z-index:999;background:rgba(253,248,240,.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.nav__mobile-menu.open{opacity:1;pointer-events:all}
.nav__mobile-menu a{font-family:var(--font-d);font-size:1.8rem;color:var(--ink);transition:color .2s}
.nav__mobile-menu a:hover{color:var(--sea-deep)}

/* ─── Buttons ───────────────────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 2.2rem;border-radius:var(--r-pill);font-weight:600;font-size:.9rem;letter-spacing:.01em;transition:all .35s var(--ease);position:relative;overflow:hidden;white-space:nowrap}
.btn::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,0) 30%,rgba(255,255,255,.2) 50%,rgba(255,255,255,0) 70%);transform:translateX(-100%);transition:transform .6s}
.btn:hover::before{transform:translateX(100%)}
.btn--primary{background:var(--peach);color:var(--ink);box-shadow:0 4px 16px rgba(240,176,136,.25)}
.btn--primary:hover{background:var(--peach-warm);transform:translateY(-2px);box-shadow:0 8px 28px rgba(240,176,136,.35)}
.btn--ghost{border:2px solid var(--ink);color:var(--ink);background:rgba(255,255,255,.6);backdrop-filter:blur(8px);font-weight:600}
.btn--ghost:hover{background:rgba(255,255,255,.85);border-color:var(--sea-deep);color:var(--sea-deep);transform:translateY(-2px)}
.btn--outline{border:1.5px solid var(--sea-mid);color:var(--sea-deep);background:transparent}
.btn--outline:hover{background:var(--sea-deep);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(90,158,148,.2)}
.btn--sm{padding:.6rem 1.4rem;font-size:.8rem}

/* ─── Section label ─────────────────────────────────────────────────────── */
.label,.section-label{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--sea-deep);margin-bottom:1.2rem}
.label::before,.section-label::before{content:'';width:24px;height:1.5px;background:var(--peach);border-radius:2px}

/* ─── Reveal ────────────────────────────────────────────────────────────── */
.rv{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.on{opacity:1;transform:none}
.stagger .rv:nth-child(1){transition-delay:0s}.stagger .rv:nth-child(2){transition-delay:.08s}
.stagger .rv:nth-child(3){transition-delay:.16s}.stagger .rv:nth-child(4){transition-delay:.24s}
.stagger .rv:nth-child(5){transition-delay:.32s}.stagger .rv:nth-child(6){transition-delay:.4s}
.stagger .rv:nth-child(7){transition-delay:.48s}.stagger .rv:nth-child(8){transition-delay:.56s}

/* ═══════════════════════════════════════════════════════════════════════════
   HERO — Watercolor wash with breathing organic blobs
   ═══════════════════════════════════════════════════════════════════════════ */
.hero{position:relative;min-height:auto;display:flex;align-items:center;overflow:hidden;background:var(--cream)}
.hero-bg{position:absolute;inset:0}

/* Animated watercolor blobs */
.hero-blob{position:absolute;border-radius:50%;filter:blur(100px);will-change:transform;mix-blend-mode:multiply}
.hero-blob--1{width:min(700px,80vw);height:min(700px,80vw);top:-15%;right:-10%;background:var(--sea-wash);opacity:.7;animation:blobA 16s ease-in-out infinite}
.hero-blob--2{width:min(550px,60vw);height:min(550px,60vw);bottom:-10%;left:-8%;background:var(--peach-pale);opacity:.6;animation:blobB 20s ease-in-out infinite}
.hero-blob--3{width:min(400px,50vw);height:min(400px,50vw);top:30%;left:40%;background:var(--heather-lt);opacity:.4;animation:blobC 14s ease-in-out infinite}
@keyframes blobA{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,40px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.97)}}
@keyframes blobB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-25px,-35px) scale(1.04)}}
@keyframes blobC{0%,100%{transform:translate(0,0) scale(1) rotate(0deg)}50%{transform:translate(20px,-25px) scale(1.08) rotate(5deg)}}

/* Subtle dot texture over hero */
.hero::before{content:'';position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.4;background-image:radial-gradient(circle,var(--sea-light) .5px,transparent .5px);background-size:32px 32px}

/* Wave divider at hero bottom */
.hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:80px;z-index:3;background:var(--cream);-webkit-mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 1440 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 40c240-40 480 40 720 0s480 40 720 0v40H0z' fill='%23fff'/%3E%3C/svg%3E") no-repeat bottom/100% 100%;mask:url("data:image/svg+xml,%3Csvg viewBox='0 0 1440 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 40c240-40 480 40 720 0s480 40 720 0v40H0z' fill='%23fff'/%3E%3C/svg%3E") no-repeat bottom/100% 100%}

.hero-content{position:relative;z-index:2;text-align:center;padding:calc(var(--nh) + 4rem) 0 8rem;max-width:820px;margin:0 auto}

/* Staggered reveal */
.hero-tagline{font-size:.78rem;font-weight:600;color:var(--sea-deep);letter-spacing:.15em;text-transform:uppercase;margin-bottom:1.8rem;opacity:0;animation:heroIn .8s var(--ease) .6s forwards}
.hero-headline{color:var(--ink);margin-bottom:2rem;text-shadow:0 1px 2px rgba(90,158,148,.05);opacity:0;animation:heroIn 1s var(--ease) .8s forwards}
.hero-headline em{font-style:italic;color:var(--sky);text-shadow:none}
.hero-description{font-size:1.1rem;color:var(--ink-mid);line-height:1.9;margin:0 auto 2.5rem;max-width:640px;opacity:0;animation:heroIn .8s var(--ease) 1.1s forwards}
.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem;opacity:0;animation:heroIn .8s var(--ease) 1.3s forwards}
@keyframes heroIn{to{opacity:1;transform:none}}

/* Trust badges */
.hero-trust{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3.5rem;opacity:0;animation:heroIn .7s var(--ease) 1.5s forwards}
.trust-badge{display:flex;align-items:center;gap:.5rem;font-size:.76rem;font-weight:500;color:var(--ink-mid);padding:.5rem 1.1rem;border-radius:var(--r-pill);background:rgba(255,255,255,.7);border:1px solid rgba(181,223,216,.25);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:var(--sh-s);transition:transform .3s var(--ease),box-shadow .3s}
.trust-badge:hover{transform:translateY(-2px);box-shadow:var(--sh-m)}
.trust-badge-icon{font-size:.95rem}

/* ─── Hero Photo Showcase ──────────────────────────────────────────────── */
.hero-showcase{display:grid;grid-template-columns:1.2fr 1fr;gap:1rem;max-width:960px;margin:0 auto 2rem;opacity:0;animation:heroIn 1s var(--ease) 1.6s forwards}
.hero-showcase__main{position:relative;border-radius:var(--r-l);overflow:hidden;box-shadow:var(--sh-xl);grid-row:span 2;max-height:500px}
.hero-showcase__main img{width:100%;height:100%;object-fit:cover;object-position:center 25%;transition:transform 6s var(--ease)}
.hero-showcase__main:hover img{transform:scale(1.06)}
.hero-showcase__side{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:1rem}
.hero-showcase__card--3{grid-column:span 2}
.hero-showcase__card{position:relative;border-radius:var(--r-m);overflow:hidden;box-shadow:var(--sh-l);flex:1;min-height:0}
.hero-showcase__card img{width:100%;height:100%;object-fit:cover;object-position:center 25%;transition:transform .8s var(--ease)}
.hero-showcase__card:hover img{transform:scale(1.08)}

/* Staggered entrance */
.hero-showcase__card--1{animation:showcaseSlide .7s var(--ease-back) 1.9s both}
.hero-showcase__card--2{animation:showcaseSlide .7s var(--ease-back) 2.1s both}
.hero-showcase__card--3{animation:showcaseSlide .7s var(--ease-back) 2.3s both}
.hero-showcase__card--4{animation:showcaseSlide .7s var(--ease-back) 2.5s both}
@keyframes showcaseSlide{from{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:none}}

/* Glassmorphic overlay */
.hero-showcase__overlay{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.2rem;background:linear-gradient(0deg,rgba(0,0,0,.45) 0%,transparent 100%);display:flex;align-items:flex-end}
.hero-showcase__tag{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--white);background:rgba(255,255,255,.15);padding:.4rem .9rem;border-radius:var(--r-pill);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);transition:background .3s,transform .3s}
.hero-showcase__card:hover .hero-showcase__tag,.hero-showcase__main:hover .hero-showcase__tag{background:rgba(255,255,255,.25);transform:translateY(-2px)}

/* Subtle colored border glow on each card */
.hero-showcase__main{border:1px solid rgba(125,188,179,.15)}
.hero-showcase__card--1{border:1px solid rgba(168,203,228,.2)}
.hero-showcase__card--2{border:1px solid rgba(168,200,134,.2)}
.hero-showcase__card--3{border:1px solid rgba(240,176,136,.2)}
.hero-showcase__card--4{border:1px solid rgba(196,160,212,.2)}

/* ─── Proof Bar ─────────────────────────────────────────────────────────── */
.proof-bar{background:linear-gradient(90deg,var(--sea-deep),var(--sea),var(--sea-deep));padding:.85rem 0;overflow:hidden;position:relative}
.proof-bar::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.08),rgba(255,255,255,.02),rgba(255,255,255,.08));animation:shimmer 3s linear infinite;background-size:200% 100%}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.proof-bar-track{overflow:hidden}
.proof-bar-scroll{display:flex;gap:3rem;white-space:nowrap;animation:marquee 40s linear infinite;width:max-content}
.proof-item{font-size:.78rem;font-weight:500;color:rgba(255,255,255,.88);letter-spacing:.03em;flex-shrink:0}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ─── About Intro ───────────────────────────────────────────────────────── */
.about-intro{padding:clamp(5rem,8vw,8rem) 0;background:var(--white);text-align:center}
.section-heading{margin-bottom:1rem}.section-heading em{color:var(--sky)}
.about-intro-text{font-size:1.1rem;color:var(--ink-mid);line-height:1.9;max-width:660px;margin:0 auto 1.5rem}
.text-link{font-size:.88rem;font-weight:600;color:var(--sea-deep);display:inline-flex;align-items:center;gap:.35rem;margin-bottom:3.5rem;transition:gap .3s}
.text-link:hover{gap:.7rem}
.pillars-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;max-width:920px;margin:0 auto}
.pillars-grid .pillar-card{background:var(--cream);border:1px solid rgba(181,223,216,.12);border-radius:var(--r-m);padding:1.8rem 1.5rem;text-align:center;transition:transform .45s var(--ease),box-shadow .45s;border-top:2px solid transparent}
.pillars-grid .pillar-card:nth-child(1){border-top-color:var(--sea-mid)}
.pillars-grid .pillar-card:nth-child(2){border-top-color:var(--sky)}
.pillars-grid .pillar-card:nth-child(3){border-top-color:var(--peach)}
.pillars-grid .pillar-card:nth-child(4){border-top-color:var(--heather)}
.pillars-grid .pillar-card:hover{transform:translateY(-6px);box-shadow:var(--sh-l)}
.pillar-icon{font-size:1.6rem;display:block;margin-bottom:.8rem}
.pillar-title{font-family:var(--font-d);font-size:1.1rem;color:var(--ink);margin-bottom:.4rem}
.pillar-text{font-size:.85rem;color:var(--ink-mid);line-height:1.7}

/* ─── Love Banner ───────────────────────────────────────────────────────── */
.love-banner{text-align:center;padding:clamp(5rem,8vw,8rem) 0;position:relative;overflow:hidden;background:linear-gradient(135deg,rgba(200,168,228,.12) 0%,rgba(192,218,240,.12) 20%,var(--sea-wash) 40%,rgba(252,200,160,.1) 60%,rgba(255,212,160,.12) 80%,rgba(232,176,168,.08) 100%);background-size:200% 200%;animation:loveShift 12s ease-in-out infinite}
@keyframes loveShift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.love-banner .container{position:relative;z-index:1}
.love-banner-heading,.love-banner h2,.love-banner h3{font-family:var(--font-d);font-size:clamp(1.8rem,3.8vw,2.8rem);font-weight:400;font-style:italic;color:var(--ink);margin-bottom:1.5rem}
.love-banner-heading em{color:var(--sky)}
.love-banner-text,.love-banner p{font-size:1.05rem;color:var(--ink-mid);max-width:600px;margin:0 auto 1rem;line-height:1.9}
.love-banner-closing{font-size:1.05rem;color:var(--sea-deep);font-style:italic;font-family:var(--font-d)}
/* Inline love banner on services page */
.section .love-banner{background:linear-gradient(135deg,rgba(192,218,240,.08),var(--sea-wash),rgba(252,200,160,.06));border:1px solid rgba(181,223,216,.12);border-radius:var(--r-l);padding:2.5rem 3rem;max-width:680px;margin-left:auto;margin-right:auto;animation:none;overflow:visible;transition:transform .4s var(--ease),box-shadow .4s}
.section .love-banner:hover{transform:translateY(-3px);box-shadow:var(--sh-l)}
.section .love-banner h3{color:var(--ink);font-size:1.25rem;margin-bottom:.8rem}
.section .love-banner p{font-size:.9rem;color:var(--ink-mid);line-height:1.8}

/* ─── Reviews ───────────────────────────────────────────────────────────── */
.reviews{padding:clamp(5rem,8vw,8rem) 0;background:var(--cream);text-align:center}
.reviews-grid{columns:3;column-gap:1.2rem;text-align:left;margin-top:3rem}
.review-card{break-inside:avoid;margin-bottom:1.2rem;background:var(--white);border:1px solid rgba(181,223,216,.08);border-radius:var(--r-l);padding:1.8rem;transition:transform .4s var(--ease),box-shadow .4s}
.review-card:hover{transform:translateY(-5px);box-shadow:var(--sh-l)}
.review-card:nth-child(3n+1){border-top:2px solid var(--sea-light)}.review-card:nth-child(3n+2){border-top:2px solid var(--peach-pale)}.review-card:nth-child(3n+3){border-top:2px solid var(--heather-lt)}
.review-stars{color:var(--peach);font-size:.9rem;margin-bottom:.8rem;letter-spacing:3px}
.review-quote{font-size:.92rem;line-height:1.85;color:var(--ink);margin-bottom:1rem;font-style:italic;font-family:var(--font-d);font-weight:400}
.review-source{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);font-style:normal;font-family:var(--font-b)}

/* ─── Gallery ───────────────────────────────────────────────────────────── */
.gallery{padding:clamp(5rem,8vw,8rem) 0;background:var(--white);text-align:center}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:220px;gap:1rem;margin-top:3rem}
.gallery-item{border-radius:var(--r-m);overflow:hidden;transition:transform .5s var(--ease),box-shadow .5s}
.gallery-item:hover{transform:scale(1.02);box-shadow:var(--sh-l)}
.gallery-item:nth-child(1){grid-row:span 2}
.gallery-img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gallery-item:hover .gallery-img{transform:scale(1.05)}

/* ─── Signup ────────────────────────────────────────────────────────────── */
.signup{padding:clamp(5rem,8vw,8rem) 0;text-align:center;background:linear-gradient(135deg,var(--sea-wash) 0%,var(--peach-pale) 40%,var(--heather-lt) 100%);position:relative}
.signup .section-heading em{color:var(--sky)}
.signup-text{font-size:1rem;color:var(--ink-mid);max-width:480px;margin:0 auto 2rem;line-height:1.8}
.signup-form{max-width:520px;margin:0 auto;background:var(--white);border:1px solid rgba(181,223,216,.12);border-radius:var(--r-l);padding:2.5rem;box-shadow:var(--sh-m)}
.signup-fields{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}
.signup-fields .form-group:last-child{grid-column:span 2}
.signup-fields input{width:100%;padding:.8rem 1.1rem;border-radius:var(--r-s);border:1.5px solid rgba(181,223,216,.25);background:var(--cream);font-size:.9rem;transition:border-color .3s,box-shadow .3s}
.signup-fields input:focus{outline:none;border-color:var(--sea-mid);box-shadow:0 0 0 3px var(--sea-wash),0 0 16px rgba(125,188,179,.08)}
.signup-submit{width:100%;padding:.9rem;font-size:.95rem;border-radius:var(--r-s)}
.signup-fine-print{margin-top:.8rem;font-size:.75rem;color:var(--ink-soft)}
.signup-message{margin-top:.8rem;font-size:.85rem;padding:.6rem;border-radius:var(--r-s)}
.signup-message--success{background:var(--sage-lt);color:#4a7a40}
.signup-message--error{background:var(--blush-lt);color:#a05050}

/* ─── Footer ────────────────────────────────────────────────────────────── */
.footer{background:var(--night);color:rgba(253,248,240,.5);padding:4rem 0 2rem;font-size:.88rem;position:relative}
.footer::before{content:'';position:absolute;top:-60px;left:0;right:0;height:60px;background:linear-gradient(to bottom,transparent,var(--night));pointer-events:none}
.footer .nav__logo{color:rgba(253,248,240,.85);font-size:1.3rem;margin-bottom:.8rem}
.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:3rem}
.footer__brand p{font-size:.82rem;line-height:1.7;max-width:280px;color:rgba(253,248,240,.4)}
.footer__col h4{font-size:.68rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(253,248,240,.3);margin-bottom:1rem}
.footer__col a{display:block;font-size:.85rem;padding:.3rem 0;transition:color .2s,transform .2s}
.footer__col a:hover{color:var(--peach-glow);transform:translateX(3px)}
.footer__bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:1.5rem;font-size:.72rem;text-align:center;color:rgba(253,248,240,.25)}

/* ─── Back to Top ───────────────────────────────────────────────────────── */
.btt{position:fixed;bottom:2rem;right:2rem;width:44px;height:44px;border-radius:50%;background:var(--white);color:var(--sea-deep);box-shadow:var(--sh-m);border:1px solid rgba(181,223,216,.15);font-size:1.1rem;display:flex;align-items:center;justify-content:center;z-index:900;opacity:0;transform:translateY(16px);transition:all .35s var(--ease)}
.btt.show{opacity:1;transform:none}
.btt:hover{background:var(--sea-wash);transform:translateY(-3px);box-shadow:var(--sh-l)}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE HERO — Subpages (light pastel gradient)
   ═══════════════════════════════════════════════════════════════════════════ */
.page-hero{padding:calc(var(--nh) + 3.5rem) 0 3.5rem;text-align:center;position:relative;overflow:hidden;background:linear-gradient(180deg,var(--sea-wash) 0%,var(--cream) 100%)}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 30% 40%,rgba(192,218,240,.12) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 70% 60%,rgba(252,200,160,.06) 0%,transparent 50%)}
.page-hero .container{position:relative;z-index:1}
.page-hero h1,.page-hero-heading,.page-hero__heading{color:var(--ink);margin-bottom:1rem;max-width:780px;margin-left:auto;margin-right:auto}
.page-hero h1 em,.page-hero-heading em,.page-hero__heading em{color:var(--sky)}
.page-hero-intro,.page-hero__sub,.page-hero__intro{color:var(--ink-mid);max-width:620px;margin:0 auto;font-size:1.08rem;line-height:1.9}
.page-hero__label{display:inline-flex;align-items:center;gap:.6rem;font-size:.68rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--sea-deep);margin-bottom:1.2rem}
.page-hero__label::before{content:'';width:24px;height:1.5px;background:var(--peach);border-radius:2px}
.page-hero .label,.page-hero .section-label{color:var(--sea-deep)}

/* ═══════════════════════════════════════════════════════════════════════════
   TIMELINE — Cinematic dawn-to-dusk sky
   ═══════════════════════════════════════════════════════════════════════════ */
.timeline-section{position:relative;overflow:hidden;padding:0;background:linear-gradient(180deg,#5A8898 0%,#7AAAB8 10%,#A8CCE0 20%,#C8E0F0 30%,#E8F0E8 40%,#F8F0D8 50%,#FCC8A0 62%,#E8A070 72%,#D08060 80%,#986898 90%,#685888 100%)}
.timeline-section .container{position:relative;z-index:2}
.timeline-section .page-hero{background:transparent;padding-bottom:2rem}
.timeline-section .page-hero::before{display:none}
.timeline-section .page-hero h1,.timeline-section .page-hero .page-hero__heading{color:var(--white);text-shadow:0 2px 20px rgba(0,0,0,.1)}
.timeline-section .page-hero h1 em,.timeline-section .page-hero__heading em{color:rgba(255,255,255,.85)}
.timeline-section .page-hero-intro,.timeline-section .page-hero__intro,.timeline-section .page-hero__sub{color:rgba(255,255,255,.75)}
.timeline-section .page-hero .label,.timeline-section .page-hero .section-label,.timeline-section .page-hero__label{color:rgba(255,255,255,.7)}
.timeline-section .page-hero .label::before,.timeline-section .page-hero .section-label::before,.timeline-section .page-hero__label::before{background:rgba(255,255,255,.4)}

.timeline{position:relative;max-width:860px;margin:0 auto;padding:2rem 0 4rem}
.timeline__line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:rgba(255,255,255,.15);transform:translateX(-50%);border-radius:2px}
.timeline__line-fill{width:100%;height:0;background:linear-gradient(180deg,rgba(255,255,255,.5),var(--peach-glow),var(--peach),var(--sunset),var(--heather));border-radius:2px;box-shadow:0 0 12px rgba(252,200,160,.3);transition:none}

.timeline__item{display:grid;grid-template-columns:1fr 50px 1fr;align-items:start;margin-bottom:3.5rem;position:relative}
.timeline__item--left .timeline__content{grid-column:1;text-align:right;padding-right:1.5rem}
.timeline__item--left .timeline__marker{grid-column:2;justify-self:center;grid-row:1}
.timeline__item--left::after{content:'';grid-column:3}
.timeline__item--right .timeline__content{grid-column:3;padding-left:1.5rem}
.timeline__item--right .timeline__marker{grid-column:2;justify-self:center;grid-row:1}
.timeline__item--right::before{content:'';grid-column:1}

.timeline__marker{width:14px;height:14px;border-radius:50%;background:var(--white);border:2px solid rgba(255,255,255,.4);z-index:3;grid-row:1;transition:transform .4s var(--ease-back),box-shadow .4s}
.timeline__item.on .timeline__marker{transform:scale(1.5);box-shadow:0 0 20px rgba(252,200,160,.5),0 0 40px rgba(252,200,160,.15)}

.timeline__content{background:rgba(255,255,255,.15);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-l);padding:1.8rem 2rem;transition:transform .5s var(--ease),box-shadow .5s,border-color .3s;grid-row:1}
.timeline__content:hover{border-color:rgba(255,255,255,.35);box-shadow:0 12px 40px rgba(0,0,0,.1)}
.timeline__time{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.5rem;display:block}
.timeline__heading{color:var(--white);margin-bottom:.5rem;font-size:1.25rem;text-shadow:0 1px 4px rgba(0,0,0,.05)}
.timeline__content p{color:rgba(255,255,255,.75);font-size:.9rem;line-height:1.8;margin-bottom:.5rem}
.timeline__content p:last-child{margin-bottom:0}
.timeline__list{padding-left:1.1rem;margin:.6rem 0}
.timeline__list li{font-size:.88rem;color:rgba(255,255,255,.7);line-height:1.7;padding:.15rem 0;list-style:disc}
.timeline__quote{margin-top:1rem;padding:1rem 1.2rem;border-left:2px solid rgba(255,255,255,.3);background:rgba(255,255,255,.06);border-radius:0 var(--r-s) var(--r-s) 0;font-family:var(--font-d);font-size:1.15rem;font-style:italic;color:rgba(255,255,255,.85)}

/* CTA after timeline inherits sky bg */
.cta-section{padding:3rem 0 5rem;text-align:center;position:relative;z-index:2}
.cta-section h2,.cta-section__heading,.cta-heading{color:var(--white);margin-bottom:1.5rem;text-shadow:0 2px 10px rgba(0,0,0,.08)}
.cta-section__actions,.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* Standalone CTA / section--cta (light bg) */
.section--cta{padding:clamp(4rem,6vw,6rem) 0;background:linear-gradient(180deg,var(--cream),var(--sea-wash));text-align:center}
.section--cta h2{color:var(--ink);margin-bottom:1.5rem}
.section--cta h2 em{color:var(--sky)}

/* ═══════════════════════════════════════════════════════════════════════════
   SERVICES — Chakra Pillars
   ═══════════════════════════════════════════════════════════════════════════ */
.section{padding:clamp(5rem,8vw,8rem) 0}
.section--alt{background:var(--white)}
.section__sub{color:var(--ink-mid);max-width:600px;margin:0 auto 3rem;font-size:1.02rem;line-height:1.85;text-align:center}
.section h2{text-align:center;margin-bottom:.8rem}.section h2 em{color:var(--sky)}

.pillar-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:2.5rem}
.pillar-card{position:relative;padding:2rem 1.8rem;border-radius:var(--r-m);background:var(--white);border:1px solid rgba(181,223,216,.08);overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s}
.pillar-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;border-radius:3px 0 0 3px}
.pillar-card:hover{transform:translateY(-5px);box-shadow:var(--sh-l)}
.pillar-card__number{font-size:.68rem;font-weight:600;letter-spacing:.12em;color:var(--ink-faint);text-transform:uppercase;display:block;margin-bottom:.3rem}
.pillar-card__title{font-family:var(--font-d);font-size:1.15rem;color:var(--ink);margin-bottom:.3rem}
.pillar-card__subtitle{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.8rem}
.pillar-card__text{font-size:.88rem;color:var(--ink-mid);line-height:1.75}
.pillar-card__extras{font-size:.8rem;color:var(--ink-soft);font-style:italic;margin-top:.7rem}
.pillar-card--root::before{background:var(--chakra-root)}.pillar-card--root .pillar-card__subtitle{color:#c08080}
.pillar-card--sacral::before{background:var(--chakra-sacral)}.pillar-card--sacral .pillar-card__subtitle{color:#c89060}
.pillar-card--solar::before{background:var(--chakra-solar)}.pillar-card--solar .pillar-card__subtitle{color:#b8a050}
.pillar-card--heart::before{background:var(--chakra-heart)}.pillar-card--heart .pillar-card__subtitle{color:#60a860}
.pillar-card--throat::before{background:var(--chakra-throat)}.pillar-card--throat .pillar-card__subtitle{color:#6090b8}
.pillar-card--third-eye::before{background:var(--chakra-eye)}.pillar-card--third-eye .pillar-card__subtitle{color:#8868b0}
.pillar-card--crown::before{background:var(--chakra-crown)}.pillar-card--crown .pillar-card__subtitle{color:#a880a0}
.pillar-card--bond::before{background:var(--chakra-bond)}.pillar-card--bond .pillar-card__subtitle{color:#a09880}

/* Journey steps */
.journey-step{background:var(--cream);border:1px solid rgba(181,223,216,.1);border-radius:var(--r-l);padding:2.2rem;margin-bottom:1.5rem;transition:transform .4s var(--ease),box-shadow .4s}
.journey-step:hover{transform:translateY(-3px);box-shadow:var(--sh-m)}
.journey-step__number{font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--sea-deep);background:var(--sea-wash);padding:.35rem .9rem;border-radius:var(--r-pill);border:1px solid rgba(181,223,216,.2);display:inline-block;margin-bottom:1rem}
.journey-step__title{font-family:var(--font-d);font-size:1.35rem;color:var(--ink);margin-bottom:.8rem}
.journey-step__text{font-size:.92rem;color:var(--ink-mid);line-height:1.8;margin-bottom:.6rem}
.journey-step__text em{color:var(--sea-deep);font-style:italic}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:920px;margin:0 auto}
.pricing-card{background:linear-gradient(145deg,var(--white) 0%,rgba(232,245,242,.5) 50%,rgba(192,218,240,.15) 100%);border:1px solid rgba(181,223,216,.15);border-radius:var(--r-l);padding:2.2rem 1.8rem;text-align:center;position:relative;transition:transform .45s var(--ease),box-shadow .45s;box-shadow:var(--sh-s)}
.pricing-card:hover{transform:translateY(-6px);box-shadow:var(--sh-xl)}
.pricing-card--featured{background:linear-gradient(160deg,var(--sea) 0%,var(--sea-deep) 100%);color:var(--white);border:none;transform:scale(1.03);box-shadow:var(--sh-l)}
.pricing-card--featured:hover{transform:scale(1.03) translateY(-6px);box-shadow:0 28px 70px rgba(90,158,148,.25)}
.pricing-card--featured .pricing-card__name,.pricing-card--featured .pricing-card__price{color:var(--white)}
.pricing-card--featured .pricing-card__subtitle{color:rgba(255,255,255,.6)}
.pricing-card__badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--peach);color:var(--ink);font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35rem 1rem;border-radius:var(--r-pill);box-shadow:0 4px 12px rgba(240,176,136,.25);white-space:nowrap}
.pricing-card__name{font-family:var(--font-d);font-size:1.3rem;margin-bottom:.2rem}
.pricing-card__subtitle{font-size:.8rem;color:var(--ink-soft);margin-bottom:1.2rem}
.pricing-card__price{font-family:var(--font-d);font-size:2.6rem;letter-spacing:-.02em;margin-bottom:.6rem;color:var(--ink)}
.pricing-card__price span{font-family:var(--font-b);font-size:.82rem;font-weight:400;opacity:.6}
.pricing-card__features{text-align:left;margin-bottom:1.5rem}
.pricing-card__features li{padding:.35rem 0 .35rem 1.2rem;font-size:.84rem;color:var(--ink-mid);line-height:1.6;position:relative;list-style:none}
.pricing-card__features li::before{content:'';position:absolute;left:0;top:.65rem;width:6px;height:6px;border-radius:50%;background:var(--sea-light);opacity:.6}
.pricing-card--featured .pricing-card__features li{color:rgba(255,255,255,.78)}
.pricing-card--featured .pricing-card__features li::before{background:rgba(255,255,255,.35)}
.pricing-note{text-align:center;margin-top:2rem;font-size:.88rem;color:var(--ink-mid)}

/* Difference section */
#difference{background:var(--cream);overflow:hidden;position:relative}
.card-grid{display:grid;gap:1.2rem}.card-grid--3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--white);border:1px solid rgba(181,223,216,.08);border-radius:var(--r-l);padding:2rem;transition:transform .45s var(--ease),box-shadow .45s}
.card:hover{transform:translateY(-5px);box-shadow:var(--sh-l)}
.card--diff{border-top:2px solid var(--sea-light)}
.card--diff:nth-child(1){border-top-color:var(--sky)}.card--diff:nth-child(2){border-top-color:var(--sage)}
.card--diff:nth-child(3){border-top-color:var(--heather)}.card--diff:nth-child(4){border-top-color:var(--peach)}
.card--diff:nth-child(5){border-top-color:var(--blush)}.card--diff:nth-child(6){border-top-color:var(--sunrise)}
.card__icon{font-size:1.8rem;margin-bottom:.8rem;display:block;transition:transform .3s var(--ease-back)}
.card:hover .card__icon{transform:scale(1.12) rotate(-3deg)}
.card__title{font-family:var(--font-d);font-size:1.1rem;color:var(--ink);margin-bottom:.4rem}
.card__text{font-size:.85rem;color:var(--ink-mid);line-height:1.75}

/* ═══════════════════════════════════════════════════════════════════════════
   ABOUT PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.story-section{padding:clamp(4rem,6vw,6rem) 0;background:var(--white)}
.story-section .container{display:grid;grid-template-columns:1.3fr 1fr;gap:4rem;align-items:start}
.story-content p{font-size:1rem;color:var(--ink-mid);line-height:1.9;margin-bottom:1.2rem}
.story-lead{font-size:1.12rem;color:var(--ink)}
.drop-cap{font-family:var(--font-d);font-size:3.6rem;float:left;line-height:.82;margin-right:.4rem;color:var(--sky);font-weight:400}
.story-photo{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--r-l);box-shadow:var(--sh-l);transition:transform .5s var(--ease)}
.story-photo:hover{transform:scale(1.01)}

.pillars-section{padding:clamp(5rem,8vw,8rem) 0;text-align:center}
.section-subtext{color:var(--ink-mid);max-width:520px;margin:0 auto 3rem;font-size:1.02rem;line-height:1.85;text-align:center}

.team-section{padding:clamp(5rem,8vw,8rem) 0;background:var(--white);text-align:center}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.5rem;text-align:left}
.team-card{background:var(--cream);border:1px solid rgba(181,223,216,.08);border-radius:var(--r-l);padding:1.8rem;transition:transform .4s var(--ease),box-shadow .4s}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--sh-l)}
.team-photo-placeholder{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--sea-wash),var(--sky-light));margin-bottom:1rem;display:flex;align-items:center;justify-content:center;border:2px solid rgba(181,223,216,.2)}
.team-photo-label{font-size:.55rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}
.team-name{font-family:var(--font-d);font-size:1.05rem;margin-bottom:.15rem}
.team-role{font-size:.75rem;color:var(--sea-deep);font-weight:600;letter-spacing:.04em;margin-bottom:.6rem}
.team-bio{font-size:.82rem;color:var(--ink-mid);line-height:1.7}

/* ═══════════════════════════════════════════════════════════════════════════
   CONTACT PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.contact-grid-section{padding:clamp(4rem,6vw,6rem) 0;background:var(--white)}
.contact-grid{display:flex;flex-direction:column;gap:2.5rem;max-width:640px;margin:0 auto}
.contact-cta-heading{color:var(--ink);margin-bottom:1rem}
.contact-cta-text{color:var(--ink-mid);margin-bottom:2rem;line-height:1.8}
.contact-cta-buttons{display:flex;gap:.8rem;flex-wrap:wrap}
.contact-details{display:flex;flex-direction:column;gap:1.2rem}
.contact-details-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.contact-item{display:flex;gap:1rem;align-items:start;transition:transform .25s var(--ease)}
.contact-item:hover{transform:translateX(3px)}
.contact-item-icon{width:38px;height:38px;background:var(--sea-wash);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;transition:background .3s}
.contact-item:hover .contact-item-icon{background:var(--peach-pale)}
.contact-item-title{font-family:var(--font-d);font-size:1rem;margin-bottom:.15rem}
.contact-item-text{font-size:.85rem;color:var(--ink-mid);line-height:1.65}
.contact-item-text a{color:var(--sea-deep);border-bottom:1px solid var(--sea-light);transition:border-color .2s}
.contact-item-text a:hover{border-color:var(--sea-deep)}
.van-areas{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.8rem 1rem;background:var(--sea-wash);border:1px solid rgba(181,223,216,.15);border-radius:var(--r-m)}
.van-areas-heading{font-size:.82rem;font-weight:500;color:var(--sea-deep);white-space:nowrap}
.pill{font-size:.7rem;font-weight:600;letter-spacing:.06em;padding:.3rem .75rem;border-radius:var(--r-pill);background:var(--white);color:var(--sea-deep);border:1px solid rgba(181,223,216,.2);transition:background .2s}
.pill:hover{background:var(--cream)}

/* FAQ */
.faq-section{padding:clamp(4rem,6vw,6rem) 0;text-align:center}
.faq-contact-links{display:flex;justify-content:center;gap:1.5rem;flex-wrap:wrap;margin-bottom:2.5rem}
.faq-contact-links a{font-size:.85rem;color:var(--ink-mid);transition:color .2s}
.faq-contact-links a:hover{color:var(--sea-deep)}
.faq-list{max-width:700px;margin:0 auto;text-align:left}
.faq-item{border-bottom:1px solid rgba(181,223,216,.1)}
.faq-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1.2rem 0;font-size:.92rem;font-weight:500;color:var(--ink);text-align:left;transition:color .2s;background:none;border:none;cursor:pointer;font-family:var(--font-b)}
.faq-trigger:hover{color:var(--sea-deep)}
.faq-question{flex:1}
.faq-icon{font-size:1.1rem;color:var(--ink-faint);transition:transform .35s var(--ease),color .2s;flex-shrink:0;margin-left:1rem}
.faq-trigger[aria-expanded="true"] .faq-icon{transform:rotate(45deg);color:var(--sea-deep)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-answer p{font-size:.88rem;color:var(--ink-mid);line-height:1.8;padding:0 0 1.2rem}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media(max-width:960px){
  .nav__links,.nav__cta{display:none}.nav__hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr 1fr;max-width:380px}
  .pillars-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{columns:2}
  .pricing-grid{grid-template-columns:1fr;max-width:380px;margin-left:auto;margin-right:auto}
  .pricing-card--featured{transform:none}.pricing-card--featured:hover{transform:translateY(-6px)}
  .card-grid--3{grid-template-columns:1fr 1fr}
  .pillar-grid{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr 1fr;gap:2rem}
  .story-section .container{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{max-width:100%}
  .contact-details-row{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .gallery-item:nth-child(1){grid-row:span 2}
  .timeline__item,.timeline__item--left,.timeline__item--right{display:flex;flex-direction:column}
  .timeline__item--left .timeline__content,.timeline__item--right .timeline__content{text-align:left;padding:0;grid-column:auto}
  .timeline__item--left::after,.timeline__item--right::before{display:none}
  .timeline__marker{display:none}.timeline__line{left:1rem}
  .timeline__item{padding-left:2.5rem;margin-bottom:2.5rem}
}
@media(max-width:768px){
  .hero-showcase{grid-template-columns:1fr;height:auto;gap:.8rem}
  .hero-showcase__main{height:300px}
  .hero-showcase__main img{object-position:center 20%}
  .hero-showcase__side{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .hero-showcase__card{height:200px}
  .hero-showcase__card img{object-position:center 20%}
  .hero-showcase__card--3{grid-column:span 2;height:220px}
  .pillars-grid{grid-template-columns:1fr}
  .reviews-grid{columns:1}
  .card-grid--3{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .signup-fields{grid-template-columns:1fr}.signup-fields .form-group:last-child{grid-column:auto}
  .footer__grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:200px}.gallery-item:nth-child(1){grid-row:auto}
}
@media(max-width:480px){
  h1{font-size:2.2rem}
  .hero-buttons{flex-direction:column;align-items:center}.hero-buttons .btn{width:100%;max-width:300px}
  .hero-showcase{grid-template-columns:1fr;height:auto;gap:.5rem}
  .hero-showcase__main{height:260px}
  .hero-showcase__main img{object-position:center 20%}
  .hero-showcase__side{grid-template-columns:1fr 1fr}
  .hero-showcase__card{height:180px}
  .hero-showcase__card img{object-position:center 20%}
  .hero-showcase__card--3{grid-column:span 2;height:200px}
  .cta-buttons,.cta-section__actions{flex-direction:column;align-items:center}
}

/* ═══════════════════════════════════════════════════════════════════════════
   CONTACT FORM
   ═══════════════════════════════════════════════════════════════════════════ */
.contact-form-wrap{flex:1}
.contact-form{display:flex;flex-direction:column;gap:1.2rem;margin-top:2rem}
.contact-form .form-group{display:flex;flex-direction:column;gap:.4rem}
.contact-form label{font-size:.82rem;font-weight:500;color:var(--ink-mid);letter-spacing:.02em}
.contact-form label .required{color:var(--peach-warm)}
.contact-form input,.contact-form textarea{padding:.85rem 1.1rem;border:1.5px solid var(--ink-faint);border-radius:var(--r-m);background:var(--white);font-size:.95rem;color:var(--ink);transition:border-color .25s,box-shadow .25s}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--sea);box-shadow:0 0 0 3px rgba(125,188,179,.15)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--ink-faint)}
.contact-form textarea{resize:vertical;min-height:120px;line-height:1.6}
.contact-submit{align-self:flex-start;margin-top:.5rem}
.contact-fine-print{font-size:.78rem;color:var(--ink-soft);margin-top:.5rem}
.contact-form-message{margin-top:1rem;padding:.8rem 1.2rem;border-radius:var(--r-s);font-size:.9rem;display:none}
.contact-form-message--success,.contact-form-message--error{display:block}
.contact-form-message--success{background:var(--sage-lt);color:#2d6a2d;border:1px solid var(--sage)}
.contact-form-message--error{background:var(--blush-lt);color:#8b3a3a;border:1px solid var(--blush)}

/* Phone link — clickable, styled */
.phone-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--sea-deep);font-weight:600;font-size:1.05rem;transition:color .2s}
.phone-link:hover{color:var(--peach-warm)}

/* ═══════════════════════════════════════════════════════════════════════════
   FOUNDATION WEEK — Start Here
   ═══════════════════════════════════════════════════════════════════════════ */
.foundation-hero{background:linear-gradient(180deg,var(--cream) 0%,var(--sea-wash) 100%)}
.foundation-journey{max-width:760px;margin:3rem auto 0;display:flex;flex-direction:column;align-items:center}
.foundation-arrow{color:var(--sea-mid);margin:.5rem 0}
.foundation-step{width:100%;padding:2.5rem;border-radius:var(--r-l);background:var(--white);border:1.5px solid rgba(125,188,179,.12);box-shadow:var(--sh-m);position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.foundation-step:hover{transform:translateY(-2px);box-shadow:var(--sh-l)}
.foundation-step--highlight{border-color:var(--peach);background:linear-gradient(135deg,var(--white) 0%,var(--peach-pale) 100%);box-shadow:var(--sh-l),0 0 0 1px var(--peach-glow)}
.foundation-step--highlight:hover{box-shadow:var(--sh-xl),0 0 0 1px var(--peach)}
.foundation-step__badge{display:inline-flex;padding:.35rem 1rem;border-radius:var(--r-pill);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--sea-wash);color:var(--sea-deep);margin-bottom:1rem}
.foundation-step__badge--primary{background:var(--peach);color:var(--ink)}
.foundation-step__title{font-family:var(--font-d);font-size:clamp(1.4rem,2.5vw,1.8rem);color:var(--ink);margin-bottom:.8rem}
.foundation-step__content p{margin-bottom:.8rem;color:var(--ink-mid);max-width:65ch}
.foundation-price{font-family:var(--font-d);font-size:2.2rem;color:var(--ink);margin-bottom:1rem}
.foundation-price span{font-family:var(--font-b);font-size:.9rem;color:var(--ink-soft);margin-left:.4rem}
.foundation-includes{margin:1.5rem 0;padding:1.5rem;background:rgba(125,188,179,.06);border-radius:var(--r-m);border:1px solid rgba(125,188,179,.1)}
.foundation-includes h4{font-family:var(--font-b);font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--sea-deep);margin-bottom:.8rem}
.foundation-includes ul{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.foundation-includes li{font-size:.88rem;color:var(--ink-mid);padding-left:1.2rem;position:relative}
.foundation-includes li::before{content:'\2713';position:absolute;left:0;color:var(--sea);font-weight:700;font-size:.8rem}
.foundation-cta{margin-top:1rem}
.foundation-note{font-size:.85rem;color:var(--ink-soft);margin-top:.8rem}

/* Full Flow+ premium card */
.fullflow-plus{margin-top:3rem;padding:2.5rem;border-radius:var(--r-l);background:linear-gradient(135deg,var(--heather-lt) 0%,var(--white) 50%,var(--sky-light) 100%);border:1.5px solid rgba(196,160,212,.2);box-shadow:var(--sh-m);position:relative;overflow:hidden;max-width:960px;margin-left:auto;margin-right:auto}
.fullflow-plus::before{content:'';position:absolute;top:-50%;right:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(196,160,212,.08) 0%,transparent 70%);pointer-events:none}
.fullflow-plus__badge{display:inline-flex;padding:.4rem 1.2rem;border-radius:var(--r-pill);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:var(--heather);color:var(--white);margin-bottom:1.2rem}
.fullflow-plus__content h3{font-family:var(--font-d);font-size:clamp(1.4rem,2.5vw,1.8rem);color:var(--ink);margin-bottom:.6rem}
.fullflow-plus__content p{color:var(--ink-mid);margin-bottom:1rem;max-width:65ch}
.fullflow-plus__content .pricing-card__features{margin-bottom:1.5rem}

@media(max-width:768px){
  .foundation-includes ul{grid-template-columns:1fr}
  .foundation-step{padding:1.8rem}
}

/* ─── Reduced Motion ────────────────────────────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .rv{opacity:1;transform:none}
  .hero-tagline,.hero-headline,.hero-description,.hero-buttons,.hero-trust,.hero-grid,.hero-floating-cards{opacity:1}
  .proof-bar-scroll{animation:none}
}

/* ═══════════════════════════════════════════════════════════════════════════
   v8 ADDITIONS — Hero Video, Team Photos, Friendships, Glass Gallery
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─── Video Banner — Full visible team video ───────────────────────────── */
.video-banner{position:relative;width:100%;height:clamp(280px,38vw,460px);overflow:hidden;margin-top:var(--nh)}
.video-banner__video{width:100%;height:100%;object-fit:cover;image-rendering:high-quality;filter:contrast(1.08) saturate(1.1)}
.video-banner__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05) 0%,rgba(0,0,0,.02) 50%,rgba(0,0,0,.25) 100%);display:flex;align-items:flex-end;justify-content:center;padding:2rem}
.video-banner__tagline{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.15em;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.3)}

/* ─── Team Photo Circles (Chakra Pastel) ───────────────────────────────── */
.team-photo-wrap{width:120px;height:120px;border-radius:50%;overflow:hidden;margin:0 auto 1.2rem;position:relative;box-shadow:0 8px 32px rgba(0,0,0,.08);transition:transform .5s var(--ease),box-shadow .5s}
.team-card:hover .team-photo-wrap{transform:scale(1.08);box-shadow:0 12px 40px rgba(0,0,0,.12)}
.team-photo{width:100%;height:100%;object-fit:cover;object-position:center 20%;transition:transform .6s var(--ease)}
.team-card:hover .team-photo{transform:scale(1.1)}

/* Chakra ring glow */
.team-photo-wrap::after{content:'';position:absolute;inset:-4px;border-radius:50%;z-index:-1;opacity:.6;transition:opacity .4s}
.team-card:hover .team-photo-wrap::after{opacity:1}
.team-photo--violet::after{box-shadow:0 0 20px rgba(200,168,228,.5),0 0 40px rgba(200,168,228,.2)}
.team-photo--blue::after{box-shadow:0 0 20px rgba(160,200,232,.5),0 0 40px rgba(160,200,232,.2)}
.team-photo--green::after{box-shadow:0 0 20px rgba(160,216,160,.5),0 0 40px rgba(160,216,160,.2)}
.team-photo--yellow::after{box-shadow:0 0 20px rgba(240,212,136,.5),0 0 40px rgba(240,212,136,.2)}
.team-photo--orange::after{box-shadow:0 0 20px rgba(240,184,136,.5),0 0 40px rgba(240,184,136,.2)}
.team-photo--red::after{box-shadow:0 0 20px rgba(232,160,160,.5),0 0 40px rgba(232,160,160,.2)}
.team-photo--pink::after{box-shadow:0 0 20px rgba(216,176,208,.5),0 0 40px rgba(216,176,208,.2)}

/* Pastel ring border */
.team-photo--violet{border:3px solid rgba(200,168,228,.5)}
.team-photo--blue{border:3px solid rgba(160,200,232,.5)}
.team-photo--green{border:3px solid rgba(160,216,160,.5)}
.team-photo--yellow{border:3px solid rgba(240,212,136,.5)}
.team-photo--orange{border:3px solid rgba(240,184,136,.5)}
.team-photo--red{border:3px solid rgba(232,160,160,.5)}
.team-photo--pink{border:3px solid rgba(216,176,208,.5)}

/* ─── Friendships Mosaic ───────────────────────────────────────────────── */
.friendships{padding:clamp(5rem,8vw,8rem) 0;background:var(--cream)}
.friendships-mosaic{display:grid;grid-template-columns:repeat(5,1fr);grid-auto-rows:240px;gap:.8rem;max-width:1100px;margin:0 auto}
.friendships-item{border-radius:var(--r-m);overflow:hidden;position:relative;cursor:pointer;transition:transform .5s var(--ease),box-shadow .5s}
.friendships-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .5s;object-position:center 20%}
.friendships-item:hover{transform:scale(1.05);box-shadow:var(--sh-xl);z-index:2}
.friendships-item:hover img{transform:scale(1.1);filter:brightness(1.05)}
@media(max-width:960px){
  .friendships-mosaic{grid-template-columns:repeat(3,1fr);grid-auto-rows:180px}
}
@media(max-width:768px){
  .friendships-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
}
@media(max-width:480px){
  .friendships-mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:140px}
}

/* ─── Glass Gallery — Premium Horizontal Scroll ────────────────────────── */
.glass-gallery{padding:clamp(5rem,8vw,8rem) 0 clamp(3rem,5vw,5rem);background:linear-gradient(180deg,var(--cream) 0%,var(--cream-warm) 50%,var(--cream) 100%);overflow:hidden}
.glass-gallery .container{text-align:center;margin-bottom:3rem}
.glass-gallery__viewport{overflow:hidden;padding:2rem 0 4rem;cursor:grab;-webkit-user-select:none;user-select:none}
.glass-gallery__viewport:active{cursor:grabbing}
.glass-gallery__track{display:flex;gap:1.5rem;padding:0 calc(50vw - 280px);transition:transform .6s var(--ease);will-change:transform}
.glass-gallery__slide{flex:0 0 560px;height:400px;border-radius:var(--r-l);overflow:hidden;position:relative;transition:transform .6s var(--ease),opacity .5s,box-shadow .6s,filter .5s;opacity:.4;transform:scale(.78);box-shadow:0 10px 40px rgba(0,0,0,.08);filter:blur(2px) grayscale(.3)}
.glass-gallery__slide.active{opacity:1;transform:scale(1);box-shadow:0 32px 80px rgba(90,158,148,.2),0 0 0 1px rgba(181,223,216,.25);filter:none}
.glass-gallery__slide img,.glass-gallery__slide video{width:100%;height:100%;object-fit:cover;object-position:center 25%;transition:transform 6s var(--ease)}
.glass-gallery__slide.active:hover img,.glass-gallery__slide.active:hover video{transform:scale(1.06)}

/* Glass reflection overlay */
.glass-gallery__reflection{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.2) 0%,transparent 40%,transparent 60%,rgba(255,255,255,.08) 100%);pointer-events:none;opacity:0;transition:opacity .4s}
.glass-gallery__slide.active .glass-gallery__reflection{opacity:1}

/* Controls */
.glass-gallery__controls{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1rem 0}
.glass-gallery__btn{width:48px;height:48px;border-radius:50%;border:1px solid rgba(181,223,216,.3);background:rgba(255,255,255,.8);backdrop-filter:blur(10px);color:var(--ink);font-size:1.1rem;cursor:pointer;transition:all .3s var(--ease);display:flex;align-items:center;justify-content:center}
.glass-gallery__btn:hover{background:var(--sea-wash);border-color:var(--sea-mid);transform:scale(1.1);box-shadow:var(--sh-m)}
.glass-gallery__dots{display:flex;gap:.5rem}
.glass-gallery__dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--ink-faint);cursor:pointer;transition:all .3s var(--ease);padding:0}
.glass-gallery__dot.active{background:var(--sea);width:24px;border-radius:var(--r-pill)}

@media(max-width:768px){
  .glass-gallery__slide{flex:0 0 320px;height:260px}
  .glass-gallery__track{padding:0 calc(50vw - 160px);gap:1rem}
}
@media(max-width:480px){
  .glass-gallery__slide{flex:0 0 280px;height:220px}
  .glass-gallery__track{padding:0 calc(50vw - 140px)}
}

/* ─── Print ─────────────────────────────────────────────────────────────── */
@media print{
  .nav,.page-loader,.scroll-progress,.btt,.proof-bar,.hero-bg,.hero::before,.hero::after,.hero-video-wrap{display:none}
  body{color:#000;background:#fff}body::after{display:none}
  .hero{min-height:auto;background:#fff;padding:2rem}
  .footer{background:#333}
}
