/* Rainy Day Psychology — staged site stylesheet */
:root{
  --fir:#0B4D12;          /* deep practice green (from logo, darkened for contrast) */
  --fir-deep:#08380D;
  --moss:#9DB394;         /* sage band */
  --moss-pale:#E8EEE5;
  --sky:#DCE7F0;          /* rain-sky mist */
  --sky-deep:#C3D4E2;
  --paper:#FAFBF8;
  --ink:#1F261E;
  --ink-soft:#4C564B;
  --sun:#D9A441;          /* one warm accent per page */
  --rain:#9FB4C4;
  --line:#D9E1D6;
  --maxw:1100px;
  --radius:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:"Avenir Next",Avenir,Mulish,"Segoe UI",system-ui,sans-serif;
  color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.65;
}
img{max-width:100%;display:block}
a{color:var(--fir)}
a:focus-visible,button:focus-visible{outline:3px solid var(--sun);outline-offset:2px;border-radius:2px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.serif{font-family:Fraunces,Georgia,serif}
.eyebrow{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fir);font-weight:600}
h1,h2,h3{font-family:Fraunces,Georgia,serif;font-weight:560;line-height:1.15;color:var(--ink)}
h1{font-size:clamp(2rem,4.5vw,3rem)}
h2{font-size:clamp(1.5rem,3vw,2.05rem);margin:.4rem 0 1rem}
h3{font-size:1.1rem;margin-bottom:.5rem;font-family:inherit;font-weight:600}
p{max-width:64ch}
.lede{font-size:1.08rem;color:var(--ink-soft)}

/* buttons */
.btn{display:inline-block;background:var(--fir);color:#fff;text-decoration:none;
  padding:.7em 1.4em;border-radius:8px;font-weight:500;border:1px solid var(--fir);
  transition:background .18s ease}
.btn:hover{background:var(--fir-deep)}
.btn.ghost{background:transparent;color:var(--fir)}
.btn.ghost:hover{background:var(--moss-pale)}
.btn.light{background:#fff;color:var(--fir);border-color:#fff}
.btn.light:hover{background:var(--moss-pale)}

/* ---------- header ---------- */
header{background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.nav{display:flex;align-items:center;gap:24px;min-height:74px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}
.brand svg{flex:none}
.brand .mark{font-family:Fraunces,Georgia,serif;font-weight:560;font-size:1.22rem;color:var(--fir)}
.brand .tag{display:block;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
nav{margin-left:auto}
nav ul{display:flex;gap:22px;list-style:none;align-items:center}
nav a{text-decoration:none;color:var(--ink);font-size:.95rem}
nav a:hover,nav a[aria-current="page"]{color:var(--fir);text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:2px}
.menu-toggle{display:none;margin-left:auto;background:none;border:1px solid var(--line);
  border-radius:8px;padding:.5em 1em;font:inherit;font-size:.95rem;cursor:pointer;color:var(--ink)}

/* ---------- hero with sheltering umbrella ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--sky) 0%,#EAF1F6 70%,var(--paper) 100%)}
.hero .wrap{position:relative;z-index:3;display:grid;grid-template-columns:1.2fr .8fr;
  gap:40px;align-items:center;padding-top:72px;padding-bottom:64px;min-height:480px}
.hero h1{max-width:16ch}
.hero .lede{margin:1.1rem 0 1.7rem}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.cta-row .phone{font-size:.95rem;color:var(--ink-soft)}
.cta-row .phone a{font-weight:600;text-decoration:none}
.couplet{margin-top:2.6rem;max-width:36ch}
.couplet p{font-family:Fraunces,Georgia,serif;font-style:italic;font-size:1.15rem;line-height:1.55;color:#33502F}
.couplet .sunline{background-image:linear-gradient(transparent 76%,rgba(217,164,65,.55) 76%)}
.couplet cite{display:block;margin-top:.5rem;font-style:normal;font-size:.76rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}

/* rain field: drops fall everywhere except beneath the canopy */
.rainfield{position:absolute;inset:0;z-index:1;pointer-events:none}
.drop{position:absolute;top:-14%;width:1.5px;height:52px;border-radius:2px;
  background:linear-gradient(var(--rain),rgba(159,180,196,0));opacity:.55;
  animation:fall 6.5s linear infinite}
.drop.s{height:34px;opacity:.4;animation-duration:8s}
@keyframes fall{to{transform:translateY(120vh)}}
/* drops aligned with the umbrella stop at the canopy and vanish */
.drop.sheltered{animation-name:fall-stop}
@keyframes fall-stop{
  0%{transform:translateY(0);opacity:.55}
  52%{opacity:.55}
  58%{transform:translateY(31vh);opacity:0}
  100%{transform:translateY(31vh);opacity:0}
}
.umbrella{position:relative;z-index:2;justify-self:center}
.umbrella svg{width:min(300px,60vw);height:auto;display:block;
  filter:drop-shadow(0 14px 24px rgba(31,38,30,.18))}
@media (prefers-reduced-motion:reduce){
  .drop{animation:none;top:auto;bottom:62%;opacity:.3}
  .drop.sheltered{display:none}
}

/* ---------- bands & sections ---------- */
section{padding:72px 0}
.band-moss{background:var(--moss-pale)}
.band-fir{background:var(--fir);color:#EFF4EC}
.band-fir .eyebrow{color:#CBDCC4}
.band-fir h2{color:#fff}
.band-fir p{color:#DCE7D6}
.band-fir a:not(.btn){color:#fff}
.band-sky{background:var(--sky)}

/* scroll reveal (headings only) */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:1.6rem}
.card{background:#fff;border:1px solid var(--line);border-top:3px solid var(--fir);
  border-radius:var(--radius);padding:26px 24px;transition:transform .18s ease,box-shadow .18s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(31,38,30,.08)}
.card p{font-size:.95rem;color:var(--ink-soft)}
.card a{display:inline-block;margin-top:.9rem;font-size:.92rem}

/* pathway list (providers) */
.paths{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;margin-top:1.6rem}
.path{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);padding:24px}
.path h3{color:#fff}
.path p{font-size:.93rem}
.path .meta{margin-top:.8rem;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;color:#CBDCC4}

/* about */
.about-grid{display:grid;grid-template-columns:280px 1fr;gap:44px;align-items:start}
.about-grid figure{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:14px;text-align:center}
.about-grid .photo{aspect-ratio:1/1;border-radius:8px;background:var(--sky-deep);
  display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.85rem}
.about-grid figcaption{font-size:.84rem;color:var(--ink-soft);margin-top:.7rem}
.cred{display:flex;gap:12px;flex-wrap:wrap;margin-top:1.2rem;font-size:.86rem;color:var(--ink-soft)}
.cred span{border:1px solid var(--moss);border-radius:999px;padding:.32em 1em;background:#fff}

/* tables */
.tablewrap{overflow-x:auto;margin:1.2rem 0}
table{border-collapse:collapse;width:100%;max-width:760px;font-size:.95rem;background:#fff;
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
caption{text-align:left;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);padding:0 0 .6em}
th,td{text-align:left;padding:.62em .95em;border-bottom:1px solid var(--line)}
thead th{font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);background:var(--moss-pale)}
tbody tr:last-child td{border-bottom:none}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}

/* poem interlude */
.poem{text-align:center}
.poem blockquote p{font-family:Fraunces,Georgia,serif;font-style:italic;font-size:1.15rem;
  line-height:1.85;color:var(--ink-soft);max-width:40ch;margin:0 auto}
.poem cite{display:block;margin-top:1.1rem;font-style:normal;font-size:.76rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}

/* page hero (inner pages) */
.page-hero{background:linear-gradient(180deg,var(--sky) 0%,var(--paper) 100%);padding:56px 0 40px}
.page-hero h1{max-width:22ch}
.page-hero .lede{margin-top:.9rem}

/* prose blocks on inner pages */
.prose p{margin-bottom:1rem}
.prose ul{margin:0 0 1rem 1.2rem}
.prose li{margin-bottom:.4rem}
.note{border-left:3px solid var(--sun);background:#fff;padding:14px 18px;border-radius:0 8px 8px 0;
  font-size:.95rem;color:var(--ink-soft);max-width:64ch}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px}
.contact-card ul{list-style:none}
.contact-card li{margin-bottom:.7rem}
.contact-card li strong{display:inline-block;min-width:4.4em}

/* footer */
footer{background:var(--ink);color:#C9D2C7;padding:52px 0 36px;font-size:.92rem}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
footer h3{color:#fff;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.8rem;font-family:inherit}
footer a{color:#EDF2EB}
footer ul{list-style:none}
footer li{margin-bottom:.45rem}
.crisis{margin-top:2.2rem;padding-top:1.4rem;border-top:1px solid #394237;color:#EDF2EB}
.crisis strong{color:#fff}
.legal{margin-top:1.4rem;color:#909B8E;font-size:.82rem}

/* ---------- responsive ---------- */
@media (max-width:920px){
  .hero .wrap{grid-template-columns:1fr;min-height:0;padding-top:56px}
  .umbrella{order:-1;justify-self:start}
  .umbrella svg{width:170px}
  .cards,.paths{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr}
  .about-grid figure{max-width:280px}
  .contact-grid{grid-template-columns:1fr}
  footer .cols{grid-template-columns:1fr}
}
@media (max-width:860px){
  nav ul{display:none;position:absolute;top:74px;left:0;right:0;background:var(--paper);
    flex-direction:column;align-items:flex-start;padding:18px 24px;border-bottom:1px solid var(--line);gap:14px}
  nav ul.open{display:flex}
  .menu-toggle{display:inline-block}
  nav{margin-left:0}
  .nav{justify-content:space-between}
}
