/*
Theme Name: AB Psychiatry Group
Theme URI: https://www.abpsychgroup.com
Author: AB Psychiatry Group
Author URI: https://www.abpsychgroup.com
Description: Custom theme for AB Psychiatry Group. Atlas Navy / Warm Sand / Sage palette, Playfair Display + Inter. Built to match the practice brand guidelines.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: ab-psychiatry-group
*/

/* ============================================================
   AB Psychiatry Group — Brand Stylesheet
   Palette + type per Brand Guidelines v1.0
   Atlas Navy #1B2A47 · Warm Sand #F5F1EA · Sage #8FA68E
   Playfair Display (display) + Inter (body)
   ============================================================ */

:root{
  --navy:#1B2A47;        /* Atlas Navy  — primary */
  --navy-deep:#0F1B33;   /* Deep Navy   — dark surfaces */
  --navy-mid:#3A4A6B;    /* Mid Navy    — subheads, captions */
  --sand:#F5F1EA;        /* Warm Sand   — primary background */
  --stone:#C9C2B6;       /* Stone       — dividers, borders */
  --charcoal:#2A2A2A;    /* Charcoal    — body type */
  --sage:#8FA68E;        /* Sage        — single accent */
  --white:#FFFFFF;
  --soft-gray:#6B6B6B;

  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;

  --maxw:1140px;
  --gut:clamp(20px,5vw,48px);
  --radius:4px;
  --shadow:0 1px 3px rgba(27,42,71,.06),0 8px 28px rgba(27,42,71,.06);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--charcoal);
  background:var(--sand);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:var(--navy);text-decoration:none;transition:color .18s ease;}
a:hover{color:var(--navy-mid);}

h1,h2,h3{font-family:var(--serif);color:var(--navy);font-weight:600;line-height:1.12;margin:0 0 .5em;letter-spacing:-0.01em;}
h1{font-size:clamp(2.4rem,5.4vw,3.75rem);}
h2{font-size:clamp(1.8rem,3.6vw,2.5rem);}
h3{font-size:1.3rem;line-height:1.25;}
p{margin:0 0 1.1em;}
p:last-child{margin-bottom:0;}

.eyebrow{
  font-family:var(--sans);font-weight:700;font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--sage);
  margin:0 0 1rem;display:inline-block;
}
.eyebrow.on-navy{color:var(--sage);}
.lead{font-size:clamp(1.05rem,1.8vw,1.22rem);color:var(--navy-mid);line-height:1.6;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}
section{padding:clamp(56px,8vw,104px) 0;}
.section-sand{background:var(--sand);}
.section-white{background:var(--white);}
.section-navy{background:var(--navy);color:rgba(255,255,255,.86);}
.section-navy h1,.section-navy h2,.section-navy h3{color:#fff;}
.center{text-align:center;}
.measure{max-width:62ch;}
.measure.center{margin-left:auto;margin-right:auto;}

.hairline{height:1px;background:var(--stone);border:0;margin:0;}
.accent-rule{width:54px;height:2px;background:var(--sage);border:0;margin:0 0 1.6rem;}
.center .accent-rule{margin-left:auto;margin-right:auto;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--sans);font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.85em 1.6em;border-radius:var(--radius);border:1.5px solid var(--navy);
  background:var(--navy);color:#fff;cursor:pointer;transition:all .18s ease;
}
.btn:hover{background:var(--navy-deep);border-color:var(--navy-deep);color:#fff;transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--navy);}
.btn-outline:hover{background:var(--navy);color:#fff;}
.btn-on-navy{background:#fff;border-color:#fff;color:var(--navy);}
.btn-on-navy:hover{background:var(--sand);border-color:var(--sand);color:var(--navy);}
.btn-on-navy-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.btn-on-navy-outline:hover{background:#fff;color:var(--navy);border-color:#fff;}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.8rem;}
.center .btn-row,.btn-row.center{justify-content:center;}

/* ---------- header / nav ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(245,241,234,.86);backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--stone);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px;}
.brand img{height:38px;width:auto;}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0;}
.nav-links a{
  font-family:var(--sans);font-weight:500;font-size:.95rem;color:var(--navy);
  position:relative;padding:4px 0;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--sage);transition:width .22s ease;}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-cta{display:flex;align-items:center;gap:14px;}
.nav-cta .btn{padding:.62em 1.25em;font-size:.9rem;}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.25s;}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--sand);padding:clamp(64px,10vw,128px) 0 clamp(56px,8vw,104px);}
.hero .wrap{position:relative;z-index:2;}
.hero h1{max-width:16ch;}
.hero .lead{max-width:54ch;margin-top:.6rem;}
.hero-watermark{
  position:absolute;right:2%;top:50%;transform:translateY(-50%);
  width:min(520px,46vw);opacity:.06;pointer-events:none;z-index:1;
}
.hero-sub{font-size:.95rem;color:var(--soft-gray);margin-top:1.6rem;}

/* ---------- grids / cards ---------- */
.grid{display:grid;gap:28px;}
.grid-2{grid-template-columns:repeat(2,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}

.card{
  background:var(--white);border:1px solid var(--stone);border-radius:var(--radius);
  padding:34px 30px;box-shadow:var(--shadow);height:100%;
}
.section-white .card{background:var(--sand);}
.card h3{margin-bottom:.4em;}
.card p{font-size:.98rem;color:var(--charcoal);}

.icon-circle{
  width:54px;height:54px;border-radius:50%;border:1.5px solid var(--navy);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.icon-circle svg{width:26px;height:26px;stroke:var(--navy);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round;}

/* pillars */
.pillar h3{font-size:1.15rem;letter-spacing:.02em;}
.pillar .num{font-family:var(--serif);font-size:1rem;color:var(--sage);display:block;margin-bottom:.4rem;}

/* condition chips */
.chips{display:flex;flex-wrap:wrap;gap:12px;margin-top:.5rem;}
.chip{
  font-family:var(--sans);font-size:.92rem;color:var(--navy);
  background:var(--white);border:1px solid var(--stone);border-radius:100px;
  padding:.5em 1.15em;
}
.section-white .chip{background:var(--sand);}
.section-navy .chip{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.22);color:#fff;}

/* split intro */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,72px);align-items:center;}
.split.narrow-left{grid-template-columns:.85fr 1.15fr;}

/* service detail block */
.svc{display:grid;grid-template-columns:64px 1fr;gap:26px;align-items:start;padding:34px 0;border-bottom:1px solid var(--stone);}
.svc:last-child{border-bottom:0;}
.svc .icon-circle{margin-bottom:0;}
.svc .meta{font-size:.85rem;color:var(--sage);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.4rem;}

/* provider */
.provider{display:grid;grid-template-columns:230px 1fr;gap:44px;align-items:start;}
.avatar{
  width:230px;height:280px;border-radius:var(--radius);
  background:linear-gradient(160deg,#22355A,#0F1B33);
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--stone);overflow:hidden;
}
.avatar .mono{font-family:var(--serif);font-size:4.2rem;color:var(--sand);letter-spacing:.04em;}
.avatar img{width:100%;height:100%;object-fit:cover;}
.provider .cred{font-family:var(--sans);font-weight:600;color:var(--sage);font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;margin:.2rem 0 1.1rem;}

/* CTA band */
.cta-band{background:var(--navy-deep);color:#fff;text-align:center;}
.cta-band img{height:54px;margin:0 auto 26px;}
.cta-band h2{color:#fff;max-width:20ch;margin-left:auto;margin-right:auto;}
.cta-band p{color:rgba(255,255,255,.8);max-width:52ch;margin-left:auto;margin-right:auto;}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,64px);align-items:start;}
.info-list{list-style:none;margin:0;padding:0;}
.info-list li{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--stone);}
.info-list li:last-child{border-bottom:0;}
.info-list .ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1.5px solid var(--navy);display:flex;align-items:center;justify-content:center;}
.info-list .ic svg{width:19px;height:19px;stroke:var(--navy);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.info-list .lbl{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage);font-weight:700;}
.info-list .val{color:var(--charcoal);}
.info-list a.val{color:var(--navy);}

form .field{margin-bottom:18px;}
form label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.04em;color:var(--navy);margin-bottom:6px;}
form input,form textarea{
  width:100%;font-family:var(--sans);font-size:1rem;color:var(--charcoal);
  padding:12px 14px;border:1px solid var(--stone);border-radius:var(--radius);background:#fff;
}
form input:focus,form textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(143,166,142,.25);}
.form-note{font-size:.82rem;color:var(--soft-gray);margin-top:8px;}

.notice{
  background:rgba(143,166,142,.12);border:1px solid var(--sage);
  border-radius:var(--radius);padding:18px 22px;font-size:.92rem;color:var(--navy);
}
.notice strong{color:var(--navy);}

/* placeholder flag */
.ph{background:#FBE9C7;color:#7a5a12;padding:0 .35em;border-radius:3px;font-size:.85em;font-style:normal;}

/* ---------- footer ---------- */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.7);padding:64px 0 28px;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;}
.site-footer img.flogo{height:48px;margin-bottom:18px;}
.site-footer h4{font-family:var(--sans);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin:0 0 16px;}
.site-footer ul{list-style:none;margin:0;padding:0;}
.site-footer li{margin-bottom:10px;}
.site-footer a{color:rgba(255,255,255,.72);font-size:.95rem;}
.site-footer a:hover{color:#fff;}
.footer-tagline{font-family:var(--serif);font-style:italic;color:var(--sage);font-size:1.05rem;margin-top:14px;}
.socials{display:flex;gap:14px;margin-top:6px;}
.socials a{width:36px;height:36px;border:1px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;}
.socials svg{width:17px;height:17px;fill:rgba(255,255,255,.8);}
.socials a:hover{border-color:#fff;}
.socials a:hover svg{fill:#fff;}
.footer-bottom{margin-top:48px;padding-top:22px;border-top:1px solid rgba(255,255,255,.14);display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;font-size:.82rem;color:rgba(255,255,255,.55);}
.footer-bottom a{color:rgba(255,255,255,.6);}
.footer-legal{max-width:760px;font-size:.78rem;color:rgba(255,255,255,.42);line-height:1.6;margin-top:18px;}

/* ---------- pricing ---------- */
.price-list{margin-top:8px;}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:22px 0;border-bottom:1px solid var(--stone);}
.price-row:last-child{border-bottom:0;}
.price-row .pr-name{font-family:var(--serif);font-size:1.2rem;color:var(--navy);margin:0;}
.price-row .pr-desc{font-size:.92rem;color:var(--soft-gray);margin:.25rem 0 0;}
.price-row .pr-amt{font-family:var(--serif);font-size:1.45rem;color:var(--navy);white-space:nowrap;}
.price-row .pr-amt small{font-family:var(--sans);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--sage);display:block;text-align:right;font-weight:700;}

/* ---------- steps ---------- */
.steps{list-style:none;counter-reset:step;margin:0;padding:0;}
.steps li{position:relative;padding:0 0 30px 70px;}
.steps li:not(:last-child)::before{content:"";position:absolute;left:23px;top:46px;bottom:0;width:1px;background:var(--stone);}
.steps li .stepnum{position:absolute;left:0;top:0;width:48px;height:48px;border-radius:50%;border:1.5px solid var(--navy);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.25rem;color:var(--navy);background:var(--sand);}
.section-white .steps li .stepnum{background:#fff;}
.steps li h3{margin-bottom:.3em;}

/* ---------- faq ---------- */
.faq-item{border-bottom:1px solid var(--stone);}
.faq-item summary{
  list-style:none;cursor:pointer;padding:22px 44px 22px 0;position:relative;
  font-family:var(--serif);font-size:1.18rem;color:var(--navy);line-height:1.3;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-size:1.6rem;color:var(--sage);font-weight:400;transition:transform .2s ease;}
.faq-item[open] summary::after{content:"\2013";}
.faq-item .faq-a{padding:0 44px 24px 0;color:var(--charcoal);}
.faq-item .faq-a p{font-size:.98rem;}

/* ---------- legal docs ---------- */
.legal-doc{max-width:760px;}
.legal-doc h2{font-size:1.5rem;margin-top:2.2rem;}
.legal-doc h3{font-size:1.12rem;margin-top:1.6rem;}
.legal-doc p,.legal-doc li{font-size:.97rem;color:var(--charcoal);}
.legal-doc ul{padding-left:1.2rem;}
.legal-doc li{margin-bottom:.5rem;}
.review-banner{
  background:#FBE9C7;border:1px solid #E4C77A;border-radius:var(--radius);
  padding:16px 20px;font-size:.92rem;color:#7a5a12;margin-bottom:8px;
}
.review-banner strong{color:#5e450e;}
.legal-meta{font-size:.85rem;color:var(--soft-gray);}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .grid-4{grid-template-columns:repeat(2,1fr);}
  .grid-3{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;}
}
@media(max-width:760px){
  .nav-links,.nav-cta .btn{display:none;}
  .nav-toggle{display:block;}
  .site-header.open .nav-links{
    display:flex;flex-direction:column;position:absolute;top:74px;left:0;right:0;
    background:var(--sand);border-bottom:1px solid var(--stone);padding:18px var(--gut) 26px;gap:6px;
  }
  .site-header.open .nav-links a{padding:10px 0;width:100%;border-bottom:1px solid var(--stone);}
  .split,.split.narrow-left,.contact-grid,.provider{grid-template-columns:1fr;}
  .grid-2{grid-template-columns:1fr;}
  .provider .avatar{width:160px;height:190px;}
  .hero-watermark{opacity:.05;right:1%;width:58vw;}
}
@media(max-width:480px){
  .grid-4,.grid-3{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;}
  .svc{grid-template-columns:1fr;gap:14px;}
  .price-row{flex-direction:column;gap:8px;}
  .price-row .pr-amt small{text-align:left;}
  .steps li{padding-left:60px;}
}


/* ===== WordPress integration ===== */
.nav-links li{list-style:none;}
.nav-links li.current-menu-item>a::after,
.nav-links li.current_page_item>a::after{width:100%;}
.site-header.open .nav-links li{width:100%;}
.admin-bar .site-header{top:32px;}
@media(max-width:782px){.admin-bar .site-header{top:46px;}}
