@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Dancing+Script:wght@400;500;600&family=Lato:wght@300;400;700&display=swap');

:root{
  --mauve:#b469ad;
  --soft-mauve:#f2e2ef;
  --deep-plum:#7a4e75;
  --gold:#e8bb66;
  --text:#3a2c36;
  --muted:#5a4956;
  --line:rgba(122,78,117,.12);
  --shadow:0 12px 36px rgba(83,44,80,.06);
  --shadow-hover:0 16px 44px rgba(83,44,80,.12);
  --radius:22px;
  --max:1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Lato',Georgia,serif;
  font-weight:400;
  color:var(--text);
  background:linear-gradient(180deg,#fdf8fc 0%,#fffefe 100%);
  line-height:1.75;
  font-size:1.05rem
}
img{max-width:100%;display:block}
a{color:var(--deep-plum);text-decoration:none;transition:opacity .2s}
a:hover{opacity:.78}
.container{width:min(calc(100% - 2rem),var(--max));margin:0 auto}

/* ── Header / Navigation ── */
header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(242,226,239,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line)
}
.nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  padding:.6rem 0;
  flex-wrap:wrap
}
.brand{display:flex;align-items:flex-start;gap:.4rem;flex-shrink:0}
.brand-orb{width:68px;height:68px;object-fit:contain;margin:-8px -6px -8px 0;filter:drop-shadow(0 3px 8px rgba(122,78,117,.22))}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-wordmark{display:flex;align-items:baseline;gap:.3rem}
.brand-script{font-family:'Dancing Script',cursive;font-size:1.65rem;font-weight:500;color:var(--deep-plum)}
.brand-healing{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.3rem;font-weight:700;letter-spacing:.04em;color:var(--deep-plum)}
.brand-sub{font-size:.82rem;color:var(--muted);letter-spacing:.02em;margin-top:.1rem;text-align:center}
.nav-links{display:flex;gap:.9rem;flex-wrap:wrap;font-size:1rem;letter-spacing:.01em}
.nav-links a{padding:.35rem .55rem;border-radius:8px;transition:background .2s,opacity .2s}
.nav-links a:hover{background:var(--soft-mauve);opacity:1}

/* ── Typography ── */
h1,h2,h3{font-family:'Cormorant Garamond',Georgia,serif;margin:0 0 1rem;line-height:1.15;font-weight:500;color:var(--text)}
h1{font-size:clamp(1.8rem,3vw,2.6rem);max-width:36ch}
h2{font-size:clamp(1.7rem,2.8vw,2.4rem)}
h3{font-size:1.35rem;font-weight:600}
.lead{font-size:1.15rem;color:var(--text);max-width:62ch;line-height:1.8}
.eyebrow,.badge{
  display:inline-block;
  padding:.38rem .75rem;
  border-radius:999px;
  background:var(--soft-mauve);
  color:var(--deep-plum);
  font-size:.78rem;
  font-weight:400;
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:.8rem
}
.badge.alt{
  background:#fff5e0;
  color:#96610e;
  border:1px solid rgba(232,187,102,.35)
}

/* ── Buttons ── */
.actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.4rem}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.8rem 1.3rem;
  border-radius:999px;
  border:1px solid var(--deep-plum);
  font-family:'Lato',sans-serif;
  font-size:.9rem;
  font-weight:400;
  letter-spacing:.03em;
  transition:all .25s ease;
  cursor:pointer
}
.btn.primary{background:var(--deep-plum);color:#fff;box-shadow:var(--shadow)}
.btn.primary:hover{background:#8d5b87;box-shadow:var(--shadow-hover);transform:translateY(-1px)}
.btn.secondary{background:transparent;color:var(--deep-plum)}
.btn.secondary:hover{background:var(--soft-mauve)}

/* ── Intake sub-nav ── */
.hero-simple.no-gap{padding-bottom:0;margin-bottom:0}
.hero-simple+.intake-subnav{margin-top:0}
.intake-subnav{
  position:sticky;top:var(--header-h,60px);z-index:35;
  background:rgba(253,248,252,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:.4rem 0;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;
  scrollbar-width:none
}
.intake-subnav::-webkit-scrollbar{display:none}
.intake-subnav .container{display:flex;gap:.35rem;padding:0 1rem}
.intake-subnav a{
  display:inline-block;padding:.28rem .6rem;border-radius:8px;
  font-size:.8rem;font-weight:400;color:var(--muted);
  transition:background .2s,color .2s;text-decoration:none;flex-shrink:0
}
.intake-subnav a:hover,.intake-subnav a.active{background:var(--soft-mauve);color:var(--deep-plum);font-weight:600;opacity:1}

/* ── Hero (Home page) ── */
.page-hero{
  padding:0;
  position:relative;
  background:url('images/homepage-bg.png') right center/cover no-repeat;
  background-attachment:fixed;
  min-height:min(560px,75vh);
  display:flex;
  align-items:center
}
.page-hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to right,rgba(253,248,252,1) 0%,rgba(253,248,252,.97) 30%,rgba(253,248,252,.4) 55%,rgba(253,248,252,.08) 100%);
  pointer-events:none
}
.page-hero .hero-wrap{
  position:relative;
  z-index:1;
  max-width:520px;
  width:100%;
  margin:0;
  padding:3.5rem 0 3.5rem 3rem
}
/* home visits banner below hero */
.hero-banner{
  background:linear-gradient(135deg,rgba(242,226,239,.5),rgba(255,255,255,.85));
  border-bottom:1px solid var(--line);
  padding:1.2rem 0;
  text-align:center
}
.hero-banner p{margin:0;font-size:.95rem;color:var(--muted);max-width:72ch;margin:0 auto}

/* ── Sections & Layout ── */
section{padding:1rem 0 3rem}
.section-head{max-width:48rem;margin-bottom:1.8rem}
.grid-2,.grid-3,.grid-4{display:grid;gap:1.2rem}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid-5{display:grid;gap:1.2rem;grid-template-columns:repeat(5,minmax(0,1fr))}

/* ── Cards ── */
.card{
  background:rgba(255,255,255,.85);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:1.4rem;
  transition:box-shadow .3s ease,transform .3s ease
}
.card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}
.card.soft{background:linear-gradient(135deg,rgba(242,226,239,.6),rgba(255,255,255,.92))}
.list{margin:0;padding-left:1.1rem;color:var(--muted)}
.list li{margin-bottom:.3rem}
.quote{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-style:italic;
  color:var(--deep-plum);
  font-size:1.1rem;
  border-left:3px solid var(--mauve);
  padding-left:1rem;
  margin-top:1rem
}
.note{font-size:.95rem;color:var(--muted)}

/* ── Banner ── */
.banner{
  background:linear-gradient(135deg,rgba(242,226,239,.6),rgba(255,255,255,.92));
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:var(--shadow);
  padding:1.6rem
}
.hero-simple{padding:2.5rem 0 1.5rem;position:relative;background-size:cover;background-position:center;background-repeat:no-repeat}
.hero-simple::before{content:'';position:absolute;inset:0;background:rgba(253,248,252,.2);pointer-events:none}
.hero-simple .container{position:relative;z-index:1}
.hero-simple .banner{padding:1.8rem 2rem 1.6rem}

/* ── Info Tooltips ── */
.info-tip{position:relative;display:inline-flex;align-items:center;justify-content:center;width:1.15em;height:1.15em;margin-left:.35em;border-radius:50%;background:var(--soft-mauve);color:var(--deep-plum);font-size:.78rem;font-weight:700;cursor:pointer;vertical-align:middle;line-height:1;flex-shrink:0;border:1px solid rgba(122,78,117,.18);-webkit-user-select:none;user-select:none}
.info-tip:hover{background:var(--deep-plum);color:#fff}
.info-tip .tip-body{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);width:max(220px,min(320px,60vw));padding:.65rem .85rem;background:#fff;color:var(--text);font-size:.85rem;font-weight:400;line-height:1.55;border-radius:10px;box-shadow:0 4px 18px rgba(0,0,0,.13);border:1px solid var(--line);z-index:50;pointer-events:none;transition:opacity .18s,visibility .18s;text-align:left;white-space:normal}
.info-tip .tip-body::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:#fff}
.info-tip:hover .tip-body,.info-tip.open .tip-body{visibility:visible;opacity:1;pointer-events:auto}
@media(max-width:640px){.info-tip .tip-body{left:auto;right:-1rem;transform:none}.info-tip .tip-body::after{left:auto;right:1.2rem;transform:none}}

/* ── Tables & Rows ── */
.table-like{display:grid;gap:.75rem}
.row{border-top:1px solid var(--line);padding-top:.75rem}

/* ── Forms ── */
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}
.field{border:1px solid var(--line);background:#fff;border-radius:14px;padding:.55rem .75rem;transition:border-color .2s}
.field:focus-within{border-color:var(--mauve)}
.field label{display:block;font-size:.92rem;color:var(--muted);margin-bottom:.2rem;letter-spacing:.02em}
.req::after{content:' *';color:#c0392b;font-weight:700}
.field .line{height:1.15rem;border-bottom:1px solid rgba(122,78,117,.18)}
.checkbox-list div{margin:.4rem 0}
.callout{
  border-left:4px solid var(--gold);
  background:#fffaef;
  border-radius:0 16px 16px 0;
  padding:1rem 1rem 1rem 1.1rem;
  color:#7c5a1e
}

/* ── Form inputs ── */
.intake-input{
  width:100%;
  border:none;
  outline:none;
  font-family:inherit;
  font-size:.95rem;
  color:var(--text);
  background:transparent;
  padding:.15rem 0
}
textarea.intake-input{resize:vertical}
select.intake-input{cursor:pointer}
.intake-input:focus{border-bottom:2px solid var(--mauve)}

/* ── Footer ── */
.footer{
  padding:2.5rem 0 3rem;
  border-top:1px solid var(--line);
  color:var(--muted);
  font-size:.88rem;
  text-align:center
}
.footer .container{display:flex;flex-direction:column;align-items:center;gap:.3rem}

/* ── Hamburger button ── */
.menu-toggle{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:.4rem;
  flex-shrink:0
}
.menu-toggle svg{width:26px;height:26px;stroke:var(--deep-plum);stroke-width:2;fill:none;stroke-linecap:round}
.menu-toggle .close-icon{display:none}
.menu-toggle.open .hamburger-icon{display:none}
.menu-toggle.open .close-icon{display:block}

/* ── Desktop view toggle ── */
.view-toggle{
  display:none;
  margin-top:.5rem;
  font-size:.78rem;
  color:var(--muted);
  cursor:pointer;
  background:none;
  border:none;
  font-family:inherit;
  text-decoration:underline;
  text-underline-offset:2px
}
.view-toggle:hover{color:var(--deep-plum)}

/* ── Page transition ── */
.page-transition{
  animation:fadeSlideIn .5s ease both
}
@keyframes fadeSlideIn{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}
.page-leaving main{
  animation:fadeOut .25s ease both
}
@keyframes fadeOut{
  to{opacity:0;transform:translateY(-8px)}
}

/* ── Responsive: Tablet ── */
@media (max-width:980px){
  .grid-3,.grid-4,.grid-5{grid-template-columns:1fr}
  .grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .page-hero{min-height:400px;background-attachment:scroll}
  .page-hero .hero-wrap{max-width:420px;padding:2.5rem 0 2.5rem 2rem}
  .nav{padding:.4rem 0}
  .brand-orb{width:44px;height:44px}
  .brand-script{font-size:1.35rem}
  .brand-healing{font-size:1.05rem}
  .brand-sub{font-size:.72rem}
  .nav-links{font-size:.88rem;gap:.35rem}
}

/* ── Responsive: Mobile ── */
@media (max-width:640px){
  .container{width:calc(100% - 1.4rem)}

  /* Hamburger visible */
  .menu-toggle{display:block}

  /* Nav layout */
  .nav{flex-wrap:wrap;padding:.35rem 0}
  .menu-toggle{order:2;margin-left:auto}
  .nav-links{
    display:none;
    flex-direction:column;
    flex-basis:100%;
    order:3;
    gap:0;
    padding:.6rem 0 .4rem;
    border-top:1px solid var(--line);
    font-size:.92rem
  }
  .nav-links.open{display:flex}
  .nav-links a{
    padding:.65rem .6rem;
    border-radius:10px
  }

  /* Brand compact */
  .brand-orb{width:36px;height:36px}
  .brand-script{font-size:1.1rem}
  .brand-healing{font-size:.82rem;letter-spacing:.04em}
  .brand-sub{font-size:.6rem}

  /* Typography */
  h1{font-size:1.75rem;max-width:none}
  h2{font-size:1.4rem}
  h3{font-size:1.15rem}
  .lead{font-size:1.05rem;line-height:1.7}

  /* Sections */
  section{padding:.6rem 0 1.8rem}
  .page-hero{padding:2rem 0 1.5rem}
  .hero-simple{padding:1.5rem 0 1rem}
  .hero-simple .banner{padding:1.2rem 1rem}
  .section-head{margin-bottom:1.2rem}

  /* Hero */
  .page-hero{min-height:auto;background-attachment:scroll}
  .page-hero::before{background:linear-gradient(to bottom,rgba(253,248,252,.9) 0%,rgba(253,248,252,.7) 100%)}
  .page-hero .hero-wrap{max-width:100%;padding:1.8rem 1rem}

  /* Grids */
  .grid-2,.grid-3,.grid-4,.grid-5{grid-template-columns:1fr;gap:.9rem}
  .form-grid{grid-template-columns:1fr;gap:.7rem}

  /* Cards */
  .card{padding:1.1rem;border-radius:18px}
  .card:hover{transform:none}
  .banner{padding:1.2rem;border-radius:20px}

  /* Buttons */
  .actions{flex-direction:column;gap:.6rem;margin-top:1rem}
  .btn{width:100%;justify-content:center;padding:.75rem 1rem;font-size:.88rem}

  /* Eyebrow/badges */
  .eyebrow,.badge{font-size:.72rem;padding:.3rem .6rem;margin-bottom:.5rem}

  /* Tables */
  .row{font-size:.9rem}

  /* Forms */
  .field{padding:.65rem .75rem;border-radius:12px}
  .field label{font-size:.78rem}
  .intake-input{font-size:.9rem}

  /* Footer */
  .footer{padding:1.8rem 0 2.2rem;font-size:.82rem}
  .view-toggle{display:block}

  /* Callout */
  .callout{font-size:.88rem;padding:.85rem .9rem .85rem 1rem;border-radius:0 12px 12px 0}

  /* Checkbox lists */
  .checkbox-list div{margin:.5rem 0}
  .checkbox-list label{font-size:.88rem}
  .checkbox-list input[type="checkbox"]{width:1.1rem;height:1.1rem;margin-right:.3rem}
}

/* ── Health History Accordions ── */
.hh-accordions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}
.hh-acc{border:1px solid var(--line);border-radius:10px;overflow:hidden}
.hh-acc-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.6rem .9rem;background:var(--soft-mauve);border:none;cursor:pointer;font-family:inherit;font-size:.88rem;font-weight:600;color:var(--deep-plum);text-align:left;transition:background .15s}
.hh-acc-btn:hover{background:rgba(180,105,173,.2)}
.hh-acc-arrow{font-size:.65rem;transition:transform .2s}
.hh-acc.open .hh-acc-arrow{transform:rotate(90deg)}
.hh-acc-body{display:none;padding:.5rem .9rem .6rem}
.hh-acc.open .hh-acc-body{display:block}
@media(max-width:640px){.hh-accordions{grid-template-columns:1fr}}

/* ── Card Icons ── */
.card-icon{
  display:block;
  width:38px;height:38px;
  margin-bottom:.6rem;
  color:var(--mauve);
  font-size:1.65rem;
  line-height:38px;
  text-align:center
}
.card-icon i{display:block}
@media(max-width:640px){
  .card-icon{width:32px;height:32px;font-size:1.4rem;line-height:32px;margin-bottom:.45rem}
}

/* ── Eva headshot ── */
.eva-photo{display:block;width:100%;max-width:340px;margin:0 auto 1.5rem;border-radius:16px;box-shadow:0 4px 20px rgba(0,0,0,.1);object-fit:cover}
.about-photo-wrap{text-align:center;margin:0 auto 2rem}
.about-photo-wrap .eva-photo{max-width:480px;border-radius:18px}
.contact-photo-wrap{text-align:center;margin-bottom:1.4rem}
.contact-photo-wrap .eva-photo{max-width:300px;aspect-ratio:3/4;object-position:center top}

/* ── Print ── */
@media print{
  header,.no-print,.footer{display:none!important}
  body{background:#fff;line-height:1.35;font-size:10pt;margin:0;padding:0}
  .container{width:100%;max-width:100%;padding:0 .4rem}
  /* Hero / banner — compact, no full-page waste */
  .hero-simple{padding:0;margin:0;min-height:0;background:none!important}
  .hero-simple::before{display:none}
  .banner{border:none;box-shadow:none;padding:.3rem 0;background:none;margin:0}
  .banner .lead{margin-bottom:.2rem;font-size:9.5pt}
  .eyebrow{margin-bottom:.15rem;font-size:9pt}
  h1{font-size:1.2rem;margin:.2rem 0}
  h2{font-size:1.05rem;margin:.35rem 0 .15rem}
  h3{font-size:.92rem;margin:.25rem 0 .1rem}
  /* Cards — tight padding, allow breaks inside large cards */
  .card{box-shadow:none;border:1px solid #ccc;padding:.4rem .5rem;margin-bottom:.3rem;border-radius:3px}
  .card:hover{transform:none;box-shadow:none}
  section{padding:.05rem 0;margin:0}
  /* Form fields — compact */
  .form-grid{grid-template-columns:repeat(2,1fr);gap:.25rem}
  .field{padding:.2rem .25rem;margin:0;border-radius:3px}
  .field label{font-size:8.5pt;margin-bottom:.05rem}
  .intake-input{border-bottom:1px solid #999;padding:.1rem 0;font-size:9.5pt;min-height:0}
  textarea.intake-input{min-height:1em;resize:none}
  select.intake-input{font-size:9pt;height:auto;padding:.1rem 0}
  /* Two-column health history grid */
  .grid-2{grid-template-columns:repeat(2,1fr);gap:.1rem .6rem}
  .checkbox-list div{margin:.02rem 0}
  .checkbox-list label{font-size:8.5pt}
  .checkbox-list input[type="checkbox"]{width:.65rem;height:.65rem}
  .checkbox-list input[type="text"]{font-size:8.5pt}
  /* Consent section */
  .card.soft{padding:.35rem .5rem}
  .card.soft .note{font-size:8pt;margin-bottom:.15rem;line-height:1.25}
  .card.soft label{font-size:8.5pt}
  /* Allow page breaks inside large sections, avoid inside small groups */
  .card{page-break-inside:auto;break-inside:auto}
  .field{break-inside:avoid;page-break-inside:avoid}
  .form-grid{break-inside:auto}
  .note{font-size:8.5pt;margin-bottom:.15rem}
  /* Expand all accordions for print */
  .hh-acc-body{display:block!important}
  .hh-acc-btn{background:none;padding:.3rem 0;font-size:9pt}
  .hh-acc-arrow{display:none}
  .hh-accordions{grid-template-columns:1fr 1fr;gap:.3rem}
  /* Remove AOS transforms */
  [data-aos]{opacity:1!important;transform:none!important}
}