/* ===========================================================
   Beyond Emotions Solutions — shared stylesheet
   =========================================================== */
*{margin:0;padding:0;box-sizing:border-box;}

:root{
  --chestnut:#7A4A3E;
  --chestnut-deep:#5E3328;
  --ballgown:#8FAEC4;
  --glass:#C7D3DC;
  --maple:#E2734D;
  --pumpkin:#E5A24A;
  --feather:#EAE5DF;
  --cream:#FAF6F1;
  --white:#FFFFFF;
  --ink:#3B2A23;
  --muted:#8a756c;
  --nav-h:74px;
  --bar-h:38px;
}

html{scroll-behavior:smooth;}
body{
  font-family:'Lato',sans-serif;
  color:var(--ink);
  background:var(--cream);
  overflow-x:hidden;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.display{font-family:'Playfair Display',serif;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}

/* ───────── ANNOUNCEMENT BAR ───────── */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:1100;
  height:var(--bar-h);
  background:linear-gradient(90deg,var(--maple),var(--pumpkin));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:700;letter-spacing:.3px;
  padding:0 16px;text-align:center;
}
.topbar span{opacity:.95;}
.topbar .dot{margin:0 10px;opacity:.6;}

/* ───────── NAV ───────── */
header{
  position:fixed;top:var(--bar-h);left:0;right:0;z-index:1000;
  height:var(--nav-h);
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(18px,4vw,48px);
  border-bottom:1px solid rgba(122,74,62,.08);
  transition:box-shadow .3s, background .3s;
}
header.scrolled{box-shadow:0 8px 30px rgba(94,51,40,.08);background:rgba(255,255,255,.95);}

.brand{display:flex;align-items:center;gap:12px;cursor:pointer;}
.brand .logo{flex-shrink:0;transition:transform .4s cubic-bezier(.2,.7,.2,1);}
.brand:hover .logo{transform:rotate(-8deg) scale(1.05);}
.brand-text{line-height:1;}
.brand-text b{
  font-family:'Playfair Display',serif;font-weight:800;
  font-size:1.18rem;color:var(--chestnut);display:block;letter-spacing:.2px;
}
.brand-text span{
  font-size:.58rem;font-weight:900;letter-spacing:3px;
  color:var(--maple);text-transform:uppercase;display:block;margin-top:3px;
}

nav ul{list-style:none;display:flex;align-items:center;gap:clamp(14px,1.8vw,28px);}
nav a.navlink{
  font-size:.9rem;font-weight:700;color:var(--ink);
  position:relative;padding:6px 2px;cursor:pointer;transition:color .2s;white-space:nowrap;
}
nav a.navlink::after{
  content:'';position:absolute;left:0;bottom:0;height:2.5px;width:0;
  background:linear-gradient(90deg,var(--maple),var(--pumpkin));
  border-radius:2px;transition:width .3s cubic-bezier(.2,.7,.2,1);
}
nav a.navlink:hover{color:var(--maple);}
nav a.navlink:hover::after,nav a.navlink.current::after{width:100%;}
nav a.navlink.current{color:var(--chestnut);}

.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Lato',sans-serif;font-weight:900;font-size:.95rem;
  padding:13px 28px;border-radius:50px;cursor:pointer;border:none;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, filter .3s;
  white-space:nowrap;
}
.btn .arr{transition:transform .3s;}
.btn:hover .arr{transform:translateX(5px);}
.btn-primary{
  background:linear-gradient(90deg,var(--maple),var(--pumpkin));
  color:#fff;box-shadow:0 10px 26px rgba(226,115,77,.34);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(226,115,77,.42);}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(6px);}
.btn-ghost:hover{background:rgba(255,255,255,.24);transform:translateY(-3px);}
.btn-white{background:#fff;color:var(--maple);box-shadow:0 10px 30px rgba(0,0,0,.16);}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,.22);}
.btn-nav{padding:11px 22px;}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;}
.hamburger span{width:25px;height:2.5px;background:var(--chestnut);border-radius:3px;transition:.3s;}

/* ───────── LAYOUT ───────── */
main{padding-top:calc(var(--nav-h) + var(--bar-h));}
.section{padding:clamp(60px,8vw,112px) clamp(20px,5vw,40px);position:relative;}
.wrap{max-width:1180px;margin:0 auto;}
.eyebrow{
  display:inline-block;font-weight:900;font-size:.78rem;letter-spacing:4px;
  text-transform:uppercase;color:var(--maple);margin-bottom:16px;
}
.eyebrow::before,.eyebrow::after{content:'';display:inline-block;width:26px;height:2px;background:var(--pumpkin);vertical-align:middle;margin:0 12px;opacity:.6;}
.center{text-align:center;}
h2.title{font-size:clamp(2.1rem,4.6vw,3.4rem);font-weight:800;color:var(--chestnut);line-height:1.12;letter-spacing:-.5px;}
.lead{font-size:1.12rem;color:var(--muted);max-width:680px;margin:18px auto 0;line-height:1.7;}
.center .lead{margin-left:auto;margin-right:auto;}
.accent{color:var(--maple);}

[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.16,.84,.3,1),transform .7s cubic-bezier(.16,.84,.3,1);}
[data-reveal].in{opacity:1;transform:none;}

/* ───────── HERO (photo background) ───────── */
.hero{
  position:relative;min-height:calc(86vh - var(--nav-h) - var(--bar-h));
  display:flex;align-items:center;justify-content:center;text-align:center;
  padding:70px 24px 90px;color:#fff;overflow:hidden;background:var(--chestnut-deep);
}
.hero.page-hero{min-height:auto;padding:clamp(80px,12vw,150px) 24px;}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transform:scale(1.06);animation:slowZoom 18s ease-out forwards;}
@keyframes slowZoom{to{transform:scale(1);}}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(135deg,rgba(94,51,40,.92) 0%,rgba(122,74,62,.74) 50%,rgba(143,174,196,.5) 100%);}
.hero-overlay.warm{background:linear-gradient(135deg,rgba(122,42,28,.9) 0%,rgba(226,115,77,.72) 55%,rgba(229,162,74,.5) 100%);}
.hero-overlay.cool{background:linear-gradient(135deg,rgba(35,60,78,.9) 0%,rgba(122,74,62,.66) 55%,rgba(143,174,196,.5) 100%);}
.blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.16;pointer-events:none;animation:float 16s ease-in-out infinite;z-index:1;}
.b1{width:240px;height:240px;background:var(--pumpkin);top:8%;left:6%;}
.b2{width:180px;height:180px;background:var(--ballgown);bottom:14%;right:9%;animation-delay:3s;}
.b3{width:130px;height:130px;background:var(--maple);bottom:30%;left:16%;animation-delay:6s;}
@keyframes float{0%,100%{transform:translate(0,0);}33%{transform:translate(26px,-30px);}66%{transform:translate(-20px,18px);}}

.hero-content{position:relative;z-index:3;max-width:960px;}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);padding:9px 22px;border-radius:50px;
  font-size:.85rem;font-weight:700;margin-bottom:26px;
}
.hero-badge .pip{width:8px;height:8px;border-radius:50%;background:var(--pumpkin);box-shadow:0 0 0 4px rgba(229,162,74,.3);animation:pip 2s infinite;}
@keyframes pip{0%,100%{box-shadow:0 0 0 4px rgba(229,162,74,.3);}50%{box-shadow:0 0 0 9px rgba(229,162,74,0);}}

h1.hero-h{font-size:clamp(2.2rem,5.2vw,4rem);font-weight:900;line-height:1.08;letter-spacing:-1px;margin-bottom:10px;}
.hero-h .conf{background:linear-gradient(100deg,var(--pumpkin),var(--maple));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-sub{font-size:clamp(1.05rem,2vw,1.4rem);font-weight:400;opacity:.95;margin:22px auto 38px;letter-spacing:.3px;max-width:760px;}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* ───────── THREE WAYS / VALUES ───────── */
.path-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;margin-top:56px;text-align:left;}
.path-card{
  background:#fff;border-radius:24px;padding:38px 32px 34px;
  box-shadow:0 14px 44px rgba(94,51,40,.09);border-top:4px solid var(--ballgown);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;display:flex;flex-direction:column;
}
.path-card:hover{transform:translateY(-10px);box-shadow:0 30px 60px rgba(94,51,40,.16);}
.path-card:nth-child(1){border-top-color:var(--maple);}
.path-card:nth-child(2){border-top-color:var(--ballgown);}
.path-card:nth-child(3){border-top-color:var(--pumpkin);}
.path-ico{width:62px;height:62px;border-radius:18px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;}
.path-card:nth-child(1) .path-ico{background:linear-gradient(135deg,var(--maple),var(--pumpkin));}
.path-card:nth-child(2) .path-ico{background:linear-gradient(135deg,var(--ballgown),#6f93ad);}
.path-card:nth-child(3) .path-ico{background:linear-gradient(135deg,var(--pumpkin),var(--maple));}
.path-ico svg{width:30px;height:30px;stroke:#fff;fill:none;stroke-width:2.2;}
.path-card h3{font-size:1.5rem;color:var(--chestnut);margin-bottom:12px;font-weight:700;}
.path-card p{color:var(--muted);font-size:1rem;line-height:1.65;flex-grow:1;}
.path-link{margin-top:22px;display:inline-flex;align-items:center;gap:8px;font-weight:900;color:var(--maple);cursor:pointer;font-size:.95rem;}
.path-link .arr{transition:transform .3s;}
.path-link:hover .arr{transform:translateX(5px);}

.value-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px;margin-top:54px;}
.value-card{background:var(--white);border:1px solid var(--feather);border-radius:20px;padding:34px 28px;text-align:left;transition:transform .35s,box-shadow .35s;}
.value-card:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(94,51,40,.1);}
.value-dot{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-family:'Playfair Display',serif;font-weight:800;font-size:1.4rem;color:#fff;}
.value-card:nth-child(1) .value-dot{background:linear-gradient(135deg,var(--maple),var(--pumpkin));}
.value-card:nth-child(2) .value-dot{background:linear-gradient(135deg,var(--ballgown),#6f93ad);}
.value-card:nth-child(3) .value-dot{background:linear-gradient(135deg,var(--chestnut),var(--chestnut-deep));}
.value-card h4{font-size:1.25rem;color:var(--chestnut);margin-bottom:8px;font-weight:700;}
.value-card p{color:var(--muted);font-size:.97rem;line-height:1.6;}

/* ───────── SPLIT / FEATURE (photo) ───────── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center;}
.media{border-radius:26px;overflow:hidden;box-shadow:0 26px 60px rgba(94,51,40,.16);aspect-ratio:5/4;position:relative;}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.media-badge{
  position:absolute;right:22px;bottom:22px;z-index:3;
  background:rgba(255,255,255,.96);backdrop-filter:blur(6px);
  border-radius:18px;padding:16px 22px;display:flex;align-items:center;gap:14px;
  box-shadow:0 16px 40px rgba(0,0,0,.18);animation:bob 4s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
.media-badge .big{font-family:'Playfair Display',serif;font-weight:900;font-size:2.2rem;color:var(--maple);line-height:1;}
.media-badge .sm b{display:block;font-weight:900;font-size:.9rem;color:var(--chestnut);}
.media-badge .sm span{font-size:.72rem;color:var(--muted);}
.split h2.title{text-align:left;}
.split .lead{margin-left:0;text-align:left;}

/* ───────── SERVICE AREA CARDS (with photo) ───────── */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:26px;margin-top:54px;text-align:left;}
.svc-card{background:#fff;border-radius:22px;overflow:hidden;box-shadow:0 12px 40px rgba(94,51,40,.08);transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;}
.svc-card:hover{transform:translateY(-8px);box-shadow:0 26px 56px rgba(94,51,40,.15);}
.svc-photo{height:190px;position:relative;overflow:hidden;}
.svc-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s;}
.svc-card:hover .svc-photo img{transform:scale(1.06);}
.svc-body{padding:28px 28px 30px;border-top:4px solid var(--ballgown);}
.svc-card:nth-child(odd) .svc-body{border-top-color:var(--maple);}
.svc-body.plain{border-top:none;padding-top:30px;}
.svc-ico{width:50px;height:50px;border-radius:14px;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.svc-ico svg{width:26px;height:26px;stroke:var(--maple);fill:none;stroke-width:2.2;}
.svc-body h3{font-size:1.3rem;color:var(--chestnut);margin-bottom:8px;font-weight:700;}
.svc-body p{color:var(--muted);font-size:.97rem;line-height:1.6;}

/* ───────── S.A.F.E. / C.A.L.M. ───────── */
.calm-feature{position:relative;background:var(--white);border-radius:30px;padding:clamp(36px,5vw,64px);box-shadow:0 30px 70px rgba(94,51,40,.1);overflow:hidden;margin-top:54px;text-align:left;}
.popular-badge{
  position:absolute;top:-6px;left:30px;z-index:4;width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,var(--ballgown),#6f93ad);color:#fff;display:flex;align-items:center;justify-content:center;text-align:center;
  font-weight:900;font-size:.78rem;line-height:1.1;box-shadow:0 12px 30px rgba(143,174,196,.5);transform:rotate(-8deg);
}
.calm-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:14px;}
.calm-card{display:flex;gap:20px;align-items:flex-start;background:var(--cream);border:1px solid var(--feather);border-radius:20px;padding:28px 26px;transition:transform .35s,box-shadow .35s;}
.calm-card:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(94,51,40,.12);}
.calm-letter{flex-shrink:0;width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:800;font-size:2.1rem;color:#fff;}
.calm-card:nth-child(1) .calm-letter{background:linear-gradient(135deg,var(--maple),var(--pumpkin));}
.calm-card:nth-child(2) .calm-letter{background:linear-gradient(135deg,var(--ballgown),#6f93ad);}
.calm-card:nth-child(3) .calm-letter{background:linear-gradient(135deg,var(--pumpkin),var(--maple));}
.calm-card:nth-child(4) .calm-letter{background:linear-gradient(135deg,var(--chestnut),var(--chestnut-deep));}
.calm-card h4{font-size:1.18rem;color:var(--chestnut);margin-bottom:6px;font-weight:700;}
.calm-card p{font-size:.95rem;color:var(--muted);line-height:1.6;}

/* ───────── OUTCOMES ───────── */
.outcomes-wrap{background:var(--white);border-radius:28px;padding:clamp(36px,5vw,60px);box-shadow:0 24px 60px rgba(94,51,40,.1);max-width:920px;margin:48px auto 0;text-align:left;}
.outcomes{list-style:none;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px 32px;}
.outcomes li{display:flex;align-items:flex-start;gap:14px;font-size:1.05rem;font-weight:600;color:var(--ink);}
.outcomes .check{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--maple),var(--pumpkin));display:flex;align-items:center;justify-content:center;margin-top:1px;}
.outcomes .check svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:3;}

/* ───────── FAQ ───────── */
.faq-wrap{max-width:860px;margin:46px auto 0;}
.faq{background:#fff;border-radius:16px;margin-bottom:14px;border:1px solid var(--feather);border-left:4px solid var(--maple);overflow:hidden;transition:box-shadow .3s;}
.faq:hover{box-shadow:0 12px 32px rgba(94,51,40,.1);}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:24px 26px;cursor:pointer;font-weight:700;font-size:1.08rem;color:var(--chestnut);}
.faq-icon{flex-shrink:0;width:30px;height:30px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;color:var(--maple);font-size:1.3rem;transition:transform .3s,background .3s;}
.faq.open .faq-icon{transform:rotate(45deg);background:var(--maple);color:#fff;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .4s ease;padding:0 26px;}
.faq.open .faq-a{max-height:260px;padding:0 26px 24px;}
.faq-a p{color:var(--muted);font-size:.98rem;line-height:1.7;}

/* ───────── FINAL CTA ───────── */
.final{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--maple),var(--pumpkin));color:#fff;text-align:center;padding:clamp(66px,9vw,110px) 24px;}
.final::before{content:'';position:absolute;width:520px;height:520px;background:rgba(255,255,255,.1);border-radius:50%;top:-220px;right:-160px;}
.final::after{content:'';position:absolute;width:320px;height:320px;background:rgba(255,255,255,.08);border-radius:50%;bottom:-130px;left:-80px;}
.final-in{position:relative;z-index:2;max-width:740px;margin:0 auto;}
.final h2{color:#fff;font-size:clamp(2rem,4.8vw,3.2rem);font-weight:800;line-height:1.1;}
.final p{font-size:1.16rem;opacity:.96;margin:18px auto 34px;}

/* ───────── BOOK PAGE ───────── */
.book-card{max-width:640px;margin:48px auto 0;background:#fff;border-radius:28px;padding:clamp(36px,5vw,60px);box-shadow:0 26px 64px rgba(94,51,40,.12);text-align:center;}
.book-card .icon-ring{width:84px;height:84px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;}
.book-card .icon-ring svg{width:40px;height:40px;stroke:var(--maple);fill:none;stroke-width:2;}
.book-opts{display:flex;flex-direction:column;gap:12px;margin-top:30px;text-align:left;}
.book-opt{display:flex;align-items:center;gap:14px;background:var(--cream);border:1px solid var(--feather);border-radius:16px;padding:18px 20px;}
.book-opt .b-ico{width:42px;height:42px;border-radius:11px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 6px 18px rgba(94,51,40,.08);}
.book-opt .b-ico svg{width:22px;height:22px;stroke:var(--maple);fill:none;stroke-width:2.2;}
.book-opt b{display:block;color:var(--chestnut);font-size:1.02rem;}
.book-opt span{color:var(--muted);font-size:.9rem;}

/* ───────── FOOTER ───────── */
footer{background:var(--chestnut-deep);color:#fff;padding:62px 24px 30px;}
.foot-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;}
.foot-brand p{font-size:.92rem;opacity:.7;line-height:1.7;margin-top:14px;max-width:300px;}
.foot-contact{margin-top:18px;display:flex;flex-direction:column;gap:6px;}
.foot-contact a{font-size:.9rem;opacity:.78;transition:opacity .2s;}
.foot-contact a:hover{opacity:1;}
.foot-col h5{font-size:.72rem;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:var(--pumpkin);margin-bottom:18px;}
.foot-col ul{list-style:none;}
.foot-col li{margin-bottom:11px;}
.foot-col a{font-size:.92rem;opacity:.72;cursor:pointer;transition:opacity .2s,color .2s;}
.foot-col a:hover{opacity:1;color:var(--pumpkin);}
.foot-bottom{max-width:1180px;margin:44px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.foot-bottom p{font-size:.82rem;opacity:.55;}

/* ───────── RESPONSIVE ───────── */
@media(max-width:920px){
  .calm-grid{grid-template-columns:1fr;}
  .split{grid-template-columns:1fr;}
  .split .media{order:-1;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:860px){
  nav ul{
    display:none;position:fixed;top:calc(var(--nav-h) + var(--bar-h));left:0;right:0;
    flex-direction:column;background:rgba(255,255,255,.98);padding:24px;gap:20px;
    box-shadow:0 20px 40px rgba(94,51,40,.14);border-bottom:1px solid var(--feather);max-height:80vh;overflow-y:auto;
  }
  nav ul.open{display:flex;}
  .hamburger{display:flex;}
  .foot-grid{grid-template-columns:1fr;gap:30px;}
  .foot-bottom{flex-direction:column;text-align:center;}
  .hero-cta{flex-direction:column;align-items:stretch;}
}
