/* ===========================================================
   Purpose-Filled Therapy — shared styles
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;500;600;700&display=swap');

:root{
  --teal:#204045;
  --teal-dark:#1c393e;
  --sage:#7e9693;
  --sage-deep:#6f8a86;
  --pale-sage:#d2d8be;
  --blush:#d5b09c;
  --blush-light:#ebcdc4;
  --cream:#fff9f9;
  --tan-band:#d3ad99;
  --gray-band:#eceae5;
  --text:#4a4a4a;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Optima","Optima Nova",Candara,"Gill Sans","Segoe UI","Source Sans Pro",sans-serif;
  color:var(--text);
  font-size:16px;
  line-height:1.7;
  background:#fff;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}

h1,h2,h3,h4{
  font-family:"Cinzel",serif;
  font-weight:600;
  color:var(--teal);
  margin:0 0 .5em;
  line-height:1.2;
}

/* ---------- Top announcement bar ---------- */
.topbar{
  background:var(--sage);
  color:#fff;
  text-align:center;
  font-size:13px;
  letter-spacing:2px;
  padding:9px 10px;
  font-weight:600;
}

/* ---------- Header / nav ---------- */
.site-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 40px;
  background:#fff;
  border-bottom:1px solid #f0f0f0;
  flex-wrap:wrap;
  gap:14px;
}
.site-header .logo img{height:42px;width:auto;}
.main-nav{
  display:flex;
  gap:26px;
  align-items:center;
  flex-wrap:wrap;
}
.main-nav a{
  font-family:"Cinzel",serif;
  font-size:13px;
  font-weight:600;
  letter-spacing:.5px;
  color:var(--teal);
  transition:color .2s;
}
.main-nav a:hover{color:var(--sage);}
.main-nav a.active{color:#c2cac9;cursor:default;}

/* mobile menu toggle (hidden on desktop) */
.nav-toggle{
  display:none;
  background:none;
  border:none;
  font-size:26px;
  line-height:1;
  color:var(--teal);
  cursor:pointer;
  padding:4px 8px;
}

/* accessibility: visually-hidden but readable by screen readers */
.visually-hidden{
  position:absolute!important;
  width:1px;height:1px;
  padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);
  white-space:nowrap;border:0;
}

/* ---------- Hero banners ---------- */
.hero{
  position:relative;
  width:100%;
  background-size:cover;
  background-position:center;
  display:flex;
  align-items:center;
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background:rgba(20,40,44,.28);
}
.hero-inner{position:relative;z-index:2;width:100%;}

/* centered-text hero (Home / Client / Contact) */
.hero-centered{min-height:360px;text-align:center;justify-content:center;}
.hero-centered .hero-inner{padding:40px 20px;}
.hero-centered h1,.hero-centered h2{
  color:#fff;
  font-size:46px;
  letter-spacing:3px;
  text-shadow:0 2px 14px rgba(0,0,0,.4);
  margin-bottom:24px;
}

/* boxed hero with Sue cutout (About / Therapy) */
.hero-boxed{min-height:440px;overflow:hidden;}
.hero-boxed .hero-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  max-width:1200px;
  margin:0 auto;
  padding:0 40px;
}
.hero-box{
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(3px);
  border-radius:6px;
  padding:42px 48px;
  max-width:430px;
  text-align:center;
}
.hero-box h1{
  color:var(--teal);
  font-size:38px;
  letter-spacing:2px;
  margin-bottom:26px;
}
.hero-figure{align-self:flex-end;}
.hero-figure img{max-height:430px;width:auto;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;
  font-family:"Optima",Candara,"Segoe UI",sans-serif;
  font-size:14px;
  letter-spacing:1px;
  padding:13px 34px;
  border-radius:40px;
  cursor:pointer;
  transition:all .2s;
  border:1px solid transparent;
}
.btn-white{background:#fff;color:var(--teal);}
.btn-white:hover{background:var(--teal);color:#fff;}
.btn-sage{background:var(--sage);color:#fff;}
.btn-sage:hover{background:var(--sage-deep);}
.btn-outline-blush{background:transparent;color:var(--blush);border-color:var(--blush);}
.btn-outline-blush:hover{background:var(--blush);color:#fff;}
.btn-outline-white{background:transparent;color:#fff;border-color:#fff;}
.btn-outline-white:hover{background:#fff;color:var(--sage);}

/* ---------- Generic sections ---------- */
.section{padding:64px 40px;}
.container{max-width:1140px;margin:0 auto;}
.narrow{max-width:820px;margin:0 auto;}
.text-center{text-align:center;}

.band-gray{background:var(--gray-band);}
.band-cream{background:var(--cream);}
.band-sage{background:var(--sage);}
.band-tan{background:var(--tan-band);}

.band-gray p,.band-cream p{color:var(--teal);}
.band-tan p{color:#fff;}
.band-sage h2{color:#fff;}
.band-sage p{color:#fff;}

/* Unified body paragraph size/font across the site (headings & hero excluded) */
p{font-size:21px;line-height:1.6;}
.eyebrow-quote{color:var(--sage);}

/* two-column split */
.split{
  display:flex;
  align-items:center;
  gap:0;
  flex-wrap:wrap;
}
.split>.col{flex:1 1 50%;min-width:300px;}
.split .col-img{display:flex;justify-content:center;align-items:center;padding:48px;}
.split .col-img img{
  width:100%;
  max-width:360px;
  height:auto;
  border-radius:12px;
  box-shadow:0 10px 28px rgba(32,64,69,.18);
}
.split .col-text{padding:56px 7%;}

/* lists */
.brand-list{list-style:none;padding:0;margin:18px 0;}
.brand-list li{
  position:relative;
  padding:6px 0 6px 26px;
  color:var(--teal);
}
.brand-list.list-centered{display:inline-block;text-align:left;margin:18px auto 24px;}
.brand-list li::before{
  content:"";
  position:absolute;left:2px;top:15px;
  width:8px;height:8px;border-radius:50%;
  background:var(--sage);
}

/* ---------- Counseling services (home) ---------- */
.services{
  display:flex;
  gap:60px;
  margin-top:48px;
  flex-wrap:wrap;
  justify-content:center;
}
.service-card{
  flex:1 1 360px;
  max-width:430px;
  text-align:center;
}
.service-card .icon{width:60px;height:60px;margin:0 auto 14px;}
.service-card h3{color:var(--sage);font-size:24px;letter-spacing:1px;}
.service-card p{margin-bottom:26px;}

/* ---------- Contact form ---------- */
.contact-form{max-width:760px;margin:36px auto 0;}
.contact-form input,
.contact-form textarea{
  width:100%;
  background:#ececec;
  border:none;
  border-radius:4px;
  padding:16px 18px;
  margin-bottom:18px;
  font-family:inherit;
  font-size:15px;
  color:#444;
}
.contact-form textarea{min-height:150px;resize:vertical;}
.contact-form .form-actions{text-align:right;}
.cf-status{margin:4px 0 14px;font-size:16px;min-height:1.2em;}
.cf-status.cf-success{color:var(--sage-deep);font-weight:600;}
.cf-status.cf-error{color:#b5533f;}
.contact-form button:disabled{opacity:.6;cursor:default;}

/* rates */
.rates p{margin:4px 0;color:var(--teal);}
.rates h3{color:var(--blush);font-size:26px;margin-top:24px;}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--teal-dark);
  display:flex;
  justify-content:center;
  gap:90px;
  flex-wrap:wrap;
  padding:26px 20px;
}
.site-footer a{
  color:#fff;
  font-family:"Cinzel",serif;
  font-size:15px;
  letter-spacing:2px;
}
.site-footer a:hover{color:var(--pale-sage);}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .site-header{flex-wrap:wrap;}
  .nav-toggle{display:block;}
  .main-nav{
    display:none;
    flex-basis:100%;
    flex-direction:column;
    align-items:center;
    gap:16px;
    padding:8px 0 4px;
  }
  .main-nav.open{display:flex;}
  .hero-boxed .hero-inner{justify-content:center;}
  .hero-figure{display:none;}
  .hero-box{max-width:520px;}
  .split .col-text{padding:40px 8%;}
  .hero-centered h1,.hero-centered h2{font-size:34px;}
}
@media(max-width:560px){
  .section{padding:44px 22px;}
  .site-footer{gap:34px;}
}
