/* ============================================================
   Anyse Smith for Desert Healthcare District — Zone 5
   Master stylesheet
   Palette derived from the Anyse Smith logo:
     blue #3A90D9 (primary) + orange #F5832A (primary/CTA).
     All other colors are tints/shades of these two. Pure white space.
   ============================================================ */

/* ---------- Design tokens ---------- */
:root{
  --blue:        #3A90D9;   /* PRIMARY — logo blue             */
  --blue-deep:   #2C72AE;   /* headings / deep blocks          */
  --blue-deeper: #205481;   /* hover on deep                   */
  --blue-soft:   #EAF3FB;   /* tint wash / mist                */
  --blue-pill:   #DCEBF8;   /* pill / chip background          */

  --orange:      #F5832A;   /* PRIMARY — logo orange / CTA     */
  --orange-deep: #DC6E16;
  --orange-soft: #FBC799;   /* light accent from logo          */

  /* legacy token aliases so existing classes keep working */
  --teal:        var(--blue);
  --teal-deep:   var(--blue-deep);
  --teal-deeper: var(--blue-deeper);
  --yellow:      #F5A11E;   /* warm accent (orange family)     */

  --ink:    #16303f;        /* near-black, blue-tinted         */
  --body:   #324653;        /* body copy                       */
  --muted:  #62737f;
  --white:  #ffffff;        /* TRUE white                      */
  --line:   #e3e9ef;        /* hairline on white               */

  --font-display: "Playfair Display", Georgia, "Times New Roman", serif;
  --font-body:    "Mulish", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw: 1200px;
  --gap: clamp(1.25rem, 4vw, 3rem);
  --radius: 14px;
  --shadow: 0 18px 40px -18px rgba(36,16,52,.28);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--body);
  background:var(--white);
  line-height:1.62;
  font-size:1.0625rem;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:var(--teal-deep); text-decoration:none; }
a:hover{ text-decoration:underline; }

h1,h2,h3,h4{
  font-family:var(--font-display);
  color:var(--ink);
  line-height:1.1;
  margin:0 0 .5em;
  font-weight:900;
  letter-spacing:-.005em;
}
h1{ font-size:clamp(2.4rem, 5.5vw, 4rem); }
h2{ font-size:clamp(1.9rem, 4vw, 3rem); }
h3{ 
  font-size:clamp(1.3rem, 2.4vw, 1.7rem);
  font-family:var(--font-body);
  font-weight: normal; 
  text-transform: uppercase;
}
p { 
  margin:0 0 1.15em; 
  font-size:1.35rem;
}
strong{ color:var(--ink); font-weight:800; }



/* ---------- Layout helpers ---------- */
.wrap{ width:min(100% - 2.5rem, var(--maxw)); margin-inline:auto; }
.section{ padding:clamp(3.5rem, 8vw, 6rem) 0; }
.section--tight{ padding:clamp(2.5rem,5vw,3.5rem) 0; }
.center{ text-align:center; }
/*.measure{ max-width:62ch; }*/
.measure-narrow{ max-width:48ch; }

/* Section color blocks */
.block-white{  background:var(--white); }
.block-mist{   background:var(--blue-soft); }          /* faint teal mist for separation */
.block-purple{ background:var(--teal-deep); color:#eaf3fb; }
.block-purple h1,.block-purple h2,.block-purple h3{ color:#fff; }
.block-teal{   background:var(--teal); color:#eaf3fb; }
.block-teal h1,.block-teal h2,.block-teal h3{ color:#fff; }

/* ---------- Eyebrow ---------- */
.eyebrow{
  font-family:var(--font-body);
  font-weight:800;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:.9rem;
  color:var(--orange);
  margin:0 0 1rem;
  display:inline-block;
}
.eyebrow::after{
  content:"";
  display:block;
  width:54px; height:4px;
  margin-top:.55rem;
  background:var(--orange);
  border-radius:4px;
}
.eyebrow.center-rule{ display:block; }
.eyebrow.center-rule::after{ margin-inline:auto; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.5rem;
  font-family:var(--font-body); font-weight:800;
  letter-spacing:.04em; text-transform:uppercase;
  font-size:.92rem;
  padding:.85rem 1.7rem;
  border-radius:10px;
  border:3px solid transparent;
  cursor:pointer;
  transition:transform .12s ease, background .15s ease, color .15s ease;
  text-decoration:none;
}
.btn:hover{ text-decoration:none; transform:translateY(-2px); }
.btn-orange{ background:var(--orange); color:#fff!important; }
.btn-orange:hover{ background:var(--orange-deep); color:#fff; }
.btn-purple{ background:var(--teal-deep); color:#fff; }
.btn-purple:hover{ background:var(--teal-deeper); color:#fff; }
.btn-teal{ background:var(--teal); color:#fff; }
.btn-teal:hover{ background:var(--teal-deep); color:#fff; }
.btn-ghost{ background:transparent; border-color:#fff; color:#fff; }
.btn-ghost:hover{ background:#fff; color:var(--teal-deep); }
.btn-lg{ font-size:1rem; padding:1rem 2rem; }

/* link with underline accent */
.link-arrow{
  font-family:var(--font-body); font-weight:800;
  letter-spacing:.08em; text-transform:uppercase;
  font-size:.9rem; color:var(--teal-deep);
  border-bottom:3px solid var(--orange);
  padding-bottom:3px;
}
.link-arrow:hover{ text-decoration:none; color:var(--orange-deep); }

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--white);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex; align-items:center; gap:1.5rem;
  padding:.85rem 0;
}
.brand{ display:flex; align-items:center; gap:.7rem; margin-right:auto; }
.brand:hover{ text-decoration:none; }
.brand-logo{
  height:100px; width:auto; display:block;
}

.nav-links{ display:flex; align-items:center; gap:1.35rem; list-style:none; margin:0; padding:0; }
.nav-links a{
  font-family:var(--font-body); font-weight:800;
  font-size:.9rem; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink);
  padding-bottom:4px;
  border-bottom:3px solid transparent;
}
.nav-links a:hover,.nav-links a[aria-current="page"]{
  text-decoration:none; color:var(--teal-deep); border-bottom-color:var(--orange);
}
.nav-cta{ margin-left:.5rem; }

.nav-toggle{
  display:none; background:none; border:0; cursor:pointer;
  width:46px; height:46px; flex:none;
}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:""; display:block; position:relative;
  width:26px; height:3px; border-radius:3px; background:var(--ink);
  margin:0 auto; transition:.2s;
}
.nav-toggle span::before{ position:absolute; top:-8px; }
.nav-toggle span::after{ position:absolute; top:8px; }

@media(max-width:960px){
  .nav-toggle{ display:block; }
  .nav-links{
    position:absolute; left:0; right:0; top:100%;
    flex-direction:column; align-items:flex-start; gap:0;
    background:var(--white); border-bottom:1px solid var(--line);
    padding:.5rem 1.25rem 1.25rem;
    box-shadow:var(--shadow);
    display:none;
  }
  .nav-links.open{ display:flex; }
  .nav-links li{ width:100%; }
  .nav-links a{ display:block; width:100%; padding:.85rem 0; border-bottom:1px solid var(--line); }
  .nav-links a:hover,.nav-links a[aria-current="page"]{ border-bottom-color:var(--line); }
  .nav-cta{ margin:.75rem 0 0; }
}

/* ============================================================
   HERO — full-bleed portrait, content on the left
   ============================================================ */
.hero{
  position:relative;
  background:var(--blue-soft);
  background-image:
    linear-gradient(90deg,
      rgba(255,255,255, .75) 0%,
      rgba(255,255,255, .50) 34%,
      rgba(255,255,255,.25) 52%,
      rgba(255,255,255,.05) 68%,
      rgba(255,255,255,0) 80%),
    url("../img/anyse-hero.webp");
  background-size:cover, cover;
  background-position:center, center right;
  background-repeat:no-repeat;
  overflow:hidden;
}

.hero-grid{
  display:grid; grid-template-columns:minmax(0,640px);
  padding:clamp(3rem,7vw,6rem) 0 clamp(3.5rem,8vw,6.5rem);
  min-height:min(78vh,720px);
  align-content:center;
}
.hero h1{ 
  color:var(--ink); 
  margin: 0;
  text-shadow:0 1px 0 rgba(255,255,255,.6); 
}
.hero h2{ color:var(--blue-deep); font-size:clamp(2.5rem, 4vw, 3rem); }
.hero .kicker{
  font-family:var(--font-body); font-weight:800;
  letter-spacing:.1em; text-transform:uppercase;
  color:var(--orange-deep);
  font-size:clamp(.82rem,1.4vw,.95rem);
  margin:0 0 1.1rem;
}

p.lede{ 
    font-size: 1.5rem;
    line-height:normal;
    font-weight:normal;
    max-width:46ch; 
}

/* on wide screens, deepen the readability without hiding the portrait */
@media(min-width:1500px){
  .hero{ background-position:top right; }
}

/* mobile portrait: hidden on desktop, shown as its own block below 1100px */
.hero-portrait{ display:none; }

/* signup box — the orange signature block from the reference */
.signup{
  background:var(--orange);
  border-radius:var(--radius);
  padding:1.4rem;
  margin-top:1.6rem;
  max-width:560px;
}
.signup-label{ color:#fff; font-weight:800; margin:0 0 .9rem; font-size:1.05rem; }
.signup-fields{ display:grid; grid-template-columns:1fr 1fr; gap:.7rem; }
.signup input{
  width:100%; border:0; border-radius:9px; padding:.85rem 1rem;
  font-family:var(--font-body); font-size:1rem; font-weight:700;
  color:var(--ink); background:#fff;
}
.signup input::placeholder{ color:var(--muted); font-weight:800; }
.signup .btn{ width:100%; justify-content:center; }
.signup-fine{ color:#fff; opacity:.92; font-size:.72rem; line-height:1.5; margin:.9rem 0 0; }
.signup-fine a{ color:#fff; text-decoration:underline; }

/* headshot placeholder */
.headshot img {
  position:relative;
  display: block;
  width: 500px;
  margin: 0 auto;
}

.headshot--round{ aspect-ratio:1; border-radius:50%; max-width:340px; }
.headshot--wide{ aspect-ratio:16/10; }

@media(max-width:1100px){
  .hero{
    background-image:none;
    background:var(--white);
  }
  .hero-grid{
    grid-template-columns:1fr;
    min-height:auto;
    padding:0 0 clamp(2rem,7vw,3rem);
    gap:0;
  }
  .hero-portrait{
    display:block;
    width:100vw;
    margin-left:calc(50% - 50vw);
    max-width:none;
/*    aspect-ratio:4/3;*/
    object-fit:cover;
    object-position:top right;
    margin-bottom:clamp(1.5rem,5vw,2.25rem);
  }
}





/* funding strip under hero */
.funding-strip{ background:var(--teal); color:#fff; text-align:center; padding:2.4rem 0; }
.funding-strip .eyebrow{ color:#fff; }
.funding-strip .eyebrow::after{ background:#fff; }
.funding-strip h2{ color:#fff; font-size:clamp(1.4rem,3vw,2rem); margin-bottom:.3em; }
.donate-amounts{ display:flex; flex-wrap:wrap; gap:.8rem; justify-content:center; margin-top:1.6rem; }
.donate-amounts a{
  background:#fff; color:var(--teal-deep);
  font-family:var(--font-display); font-weight:800; font-size:1.4rem;
  padding:.8rem 1.6rem; border-radius:12px; min-width:104px; text-align:center;
  border:3px solid #fff; transition:transform .12s ease;
}
.donate-amounts a:hover{ text-decoration:none; transform:translateY(-3px); }
.donate-amounts a.other{ background:transparent; color:#fff; }

/* ============================================================
   PRIORITIES
   ============================================================ */
.priorities-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(1.5rem,4vw,3.5rem); align-items:start;
}
.check-list{ list-style:none; margin:0; padding:0; }
.check-list li{
  display:flex; gap:1rem; align-items:flex-start;
  padding:1.15rem 0; border-bottom:2px solid var(--line);
}
.check-list li:last-child{ border-bottom:0; }
.check-list .tick{
  flex:none; width:38px; height:38px; border-radius:50%;
  background:var(--teal); color:#fff;
  display:grid; place-items:center; font-size:1.2rem; font-weight:900;
}
.check-list .tick.alt{ background:var(--orange); }
.check-list h3{ margin:.1rem 0 .15rem; font-size:1.25rem; }
.check-list p{ margin:0; font-size:.98rem; color:var(--body); }

/* numbered priority cards (01 / 02 / 03 — a real ordered set of platform planks) */
.planks{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.plank{
  background:var(--white); border:2px solid var(--line);
  border-radius:var(--radius); padding:1.8rem 1.6rem;
  border-top:8px solid var(--orange);
}
.plank:nth-child(2){ border-top-color:var(--teal); }
.plank:nth-child(3){ border-top-color:var(--teal-deep); }
.plank .num{
  font-family:var(--font-display); font-weight:800; font-size:2.4rem;
  color:var(--orange); line-height:1; margin-bottom:.4rem;
}
.plank:nth-child(2) .num{ color:var(--teal); }
.plank:nth-child(3) .num{ color:var(--teal-deep); }
.plank h3{ font-size:1.2rem; }
.plank p{ margin:0; font-size:1.15rem; }

@media(max-width:820px){
  .priorities-grid{ grid-template-columns:1fr; }
  .planks{ grid-template-columns:1fr; }
}

/* ============================================================
   STATS CALLOUT CARD ("the numbers behind it")
   ============================================================ */
.stat-card{
  background:var(--teal-deep); color:#eaf3fb;
  border-radius:var(--radius); padding:2rem 1.9rem;
  border-top:10px solid var(--orange);
  box-shadow:var(--shadow);
}
.stat-card h3{ color:#fff; margin-bottom:1.2rem; }
.stat-card ul{ list-style:none; margin:0; padding:0; }
.stat-card li{ display:flex; gap:.8rem; padding:.7rem 0; align-items:flex-start; }
.stat-card li + li{ border-top:1px solid rgba(255,255,255,.16); }
.stat-card .tick{ color:var(--yellow); font-weight:900; flex:none; }
.stat-card strong{ color:#fff; }

.split{
  display:grid; grid-template-columns:1.1fr .9fr;
  gap:clamp(1.5rem,4vw,3rem); align-items:center;
}
@media(max-width:820px){ .split{ grid-template-columns:1fr; } }

/* ============================================================
   PULL QUOTE (carousel-style card from reference)
   ============================================================ */
.pullquote{
  background:var(--teal-deep); color:#fff;
  border-radius:var(--radius);
  border-bottom:8px solid var(--orange);
  padding:clamp(2rem,5vw,3.5rem);
  text-align:center;
}
.pullquote p{
  font-family:var(--font-display); font-weight:800;
  font-size:clamp(1.5rem,3.4vw,2.3rem); line-height:1.18;
  color:#fff; margin:0 auto; max-width:24ch;
}
.pullquote .by{ font-family:var(--font-body); font-weight:800; letter-spacing:.1em; text-transform:uppercase; font-size:.82rem; margin-top:1.4rem; opacity:.9; }

/* ============================================================
   BIO / TIMELINE / GIVING-BACK
   ============================================================ */
.creds{ display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin:0 0 1.6rem; }
.creds .pill{
  background:var(--blue-soft); color:var(--teal-deep);
  font-weight:800; font-size:.82rem; letter-spacing:.04em;
  padding:.45rem 1rem; border-radius:999px;
}

.giving-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; }
.give-card{
  border:2px solid var(--line); border-radius:var(--radius);
  padding:1.5rem; background:#fff;
  border-left:8px solid var(--teal-deep);
}
.give-card:nth-child(3n+2){ border-left-color:var(--teal); }
.give-card:nth-child(3n+3){ border-left-color:var(--orange); }
.give-card h3{ font-size:1.2rem; margin-bottom:.1rem; }
.give-card .role{ font-style:italic; color:var(--teal-deep); font-weight:700; margin:0 0 .6rem; }
.give-card p{ margin:0; font-size:.96rem; }
@media(max-width:700px){ .giving-grid{ grid-template-columns:1fr; } }

/* page hero (interior pages) */
.page-hero{ background:var(--teal-deep); color:#eaf3fb; padding:clamp(2.5rem,6vw,4.5rem) 0; }
.page-hero h1{ color:#fff; margin-bottom:.3em; }
.page-hero p{ max-width:60ch; color:#eaf3fb; margin:0; }
.page-hero .eyebrow{ color:var(--yellow); }
.page-hero .eyebrow::after{ background:var(--yellow); }

/* simple prose region */
.prose h2{ margin-top:2rem; }
.prose ul{ padding-left:1.2rem; }
.prose li{ margin-bottom:.5rem; }

/* endorsement list */
.endorse-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:1rem; }
.endorse{
  border:2px solid var(--line); border-radius:12px; padding:1.2rem 1.3rem;
  border-top:6px solid var(--teal); background:#fff;
}
.endorse strong{ display:block; font-family:var(--font-display); font-size:1.1rem; color:var(--ink); }
.endorse span{ color:var(--muted); font-size:.9rem; }

/* news cards */
.news-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.news-card{ border:2px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#fff; }
.news-card .thumb{ aspect-ratio:16/9; background:repeating-linear-gradient(135deg,#dcebf8 0 18px,#cfe3f6 18px 36px); }
.news-card .body{ padding:1.3rem 1.4rem; }
.news-card .date{ color:var(--orange); font-weight:800; font-size:.8rem; letter-spacing:.06em; text-transform:uppercase; }
.news-card h3{ font-size:1.2rem; margin:.4rem 0 .5rem; }

/* map tab */
.map-frame{
  border:3px solid var(--line); border-radius:var(--radius); overflow:hidden;
  aspect-ratio:16/9; background:var(--blue-soft);
  display:grid; place-items:center; color:var(--teal-deep); text-align:center;
}
.map-frame span{ font-family:var(--font-display); font-weight:800; letter-spacing:.1em; text-transform:uppercase; opacity:.6; }

/* verify note (editorial, shown faint; remove before publish) */
.verify{
  background:#fff8e6; border:2px dashed var(--yellow);
  border-radius:10px; padding:.8rem 1.1rem; margin:1rem 0;
  font-size:.85rem; color:#7a5c00;
}
.verify strong{ color:#7a5c00; }


/* ============================================================
   FRAMED PHOTO (white border + shadow, like the headshot)
   ============================================================ */
.photo-frame{
  display:block;
  width:100%;
  border-radius:var(--radius);
  border:6px solid #fff;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.photo-frame img{ width:100%; height:auto; display:block; }
/* keep a consistent crop for wide group photos */
.photo-frame.is-wide img{ aspect-ratio:16/9; object-fit:cover; }

/* placeholder version, until the real photo is dropped in */
.photo-frame.is-placeholder{
  aspect-ratio:16/9;
  display:grid; place-items:center; text-align:center;
  background:repeating-linear-gradient(135deg,#dcebf8 0 22px,#cfe3f6 22px 44px);
  color:var(--blue-deep);
}
.photo-frame.is-placeholder span{
  font-family:var(--font-body); font-weight:800; letter-spacing:.1em;
  text-transform:uppercase; font-size:.9rem; opacity:.75;
}
p.figure-caption { 
  font-size: .85rem;
  text-align: center;
  color:var(--muted);
}


/* ============================================================
   KEY-FACTS GRID (the LPA numbers)
   ============================================================ */
.facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.fact{
  background:var(--blue-soft); border-radius:var(--radius);
  padding:1.5rem 1.3rem; border-top:6px solid var(--orange);
}
.fact:nth-child(2){ border-top-color:var(--blue); }
.fact:nth-child(3){ border-top-color:var(--blue-deep); }
.fact:nth-child(4){ border-top-color:var(--orange); }
.fact .big{
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(1.7rem,3vw,2.3rem); color:var(--blue-deep); line-height:1;
}
.fact p{ margin:.5rem 0 0; font-size:.92rem; color:var(--body); }
@media(max-width:860px){ .facts{ grid-template-columns:1fr 1fr; } }
@media(max-width:480px){ .facts{ grid-template-columns:1fr; } }

/* ============================================================
   FAQ ACCORDION (native <details>)
   ============================================================ */
.faq{ border-top:2px solid var(--line); margin-top:1.5rem; }
.faq details{ border-bottom:2px solid var(--line); }
.faq summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; gap:1rem;
  padding:1.15rem 0;
  font-family:var(--font-display); font-weight:800;
  font-size:1.12rem; color:var(--ink);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{
  content:"+"; margin-left:auto; flex:none;
  font-family:var(--font-body); font-weight:800; font-size:1.5rem;
  color:var(--orange); line-height:1; transition:transform .2s ease;
}
.faq details[open] summary::after{ content:"\2013"; }
.faq summary:hover{ color:var(--blue-deep); }
.faq .answer{ padding:0 0 1.3rem; color:var(--body); }
.faq .answer p:last-child{ margin-bottom:0; }


/* ============================================================
   FOOTER
   ============================================================ */

.site-footer{ background:var(--blue-soft); padding:3rem 0 1.5rem; text-align:center; border-top:1px solid var(--line); }
.socials{ display:flex; gap:.7rem; justify-content:center; margin:0 0 1.4rem; }
.socials a{
  width:42px; height:42px; border-radius:50%;
  background:var(--orange); color:#fff;
  display:grid; place-items:center; font-weight:900; font-size:1.5rem;
  transition:transform .12s ease, background .15s ease;
}
.socials a:hover{ text-decoration:none; transform:translateY(-2px); background:var(--orange-deep); }
.footer-email{ font-weight:800; color:var(--teal-deep); }
.disclaimer{
  max-width:640px; margin:1.5rem auto 0; padding:.9rem 1.2rem;
  border:1px solid var(--line); border-radius:10px;
  font-size:1rem; color:var(--body); background:#fff;
}

/* accessibility */
:focus-visible{ outline:3px solid var(--orange); outline-offset:2px; border-radius:4px; }
.skip{ position:absolute; left:-9999px; }
.skip:focus{ left:1rem; top:1rem; background:#fff; padding:.6rem 1rem; border-radius:8px; z-index:100; }

@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
}



/* Add to css/style.css — signup status + confirmation state */
.signup-status{
  margin:.7rem 0 0;
  font-size:.85rem; font-weight:700;
  color:#fff; min-height:1em;
}
.signup-status.is-error{ color:#fff5e9; }   /* readable on the orange box */

.signup-submit[disabled]{ opacity:.7; cursor:default; }

.signup-thanks{ color:#fff; padding:.4rem 0; }
.signup-thanks-title{
  font-family:var(--font-display); font-weight:900;
  font-size:1.25rem; color:#fff; margin:0 0 .4rem;
}
.signup-thanks p{ color:#fff; margin:0 0 .4rem; }
