/* ============================================================
   Serenity House Assisted Living — Design System
   Locked per homepage-preview.html · WCAG 2.1 AA adjustments:
   --sage is DECORATIVE ONLY (never text); use --sage-deep /
   --sage-text for small text; body text = --ink on light bands.
   ============================================================ */

/* ---------- Fonts (self-hosted, latin subsets) ---------- */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-v21-latin-500.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/cormorant-garamond-v21-latin-600.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('../fonts/cormorant-garamond-v21-latin-italic.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('../fonts/cormorant-garamond-v21-latin-500italic.woff2') format('woff2')}
@font-face{font-family:'Mulish';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/mulish-v18-latin-300.woff2') format('woff2')}
@font-face{font-family:'Mulish';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/mulish-v18-latin-regular.woff2') format('woff2')}
@font-face{font-family:'Mulish';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/mulish-v18-latin-600.woff2') format('woff2')}
@font-face{font-family:'Mulish';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/mulish-v18-latin-700.woff2') format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --white:#FCFCFA; --cream:#F7F3EA; --stone:#F1EFE9;
  --pine:#2C342E;  --ink:#3a423a;   --slate:#525B50;
  --sage:#7C8A70;  --sage-deep:#5F6E55; --sage-text:#5F6B54; --sage-tint:#EBEFE6;
  --line:rgba(44,52,46,.10); --r:12px;
  --shadow:0 30px 60px -45px rgba(44,52,46,.5);
}

/* ---------- Base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--white);color:var(--pine);font-family:'Mulish',sans-serif;font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,.serif{font-family:'Cormorant Garamond',serif;font-weight:500;line-height:1.12;color:var(--pine)}
h1 em,h2 em,h3 em{font-style:italic;color:var(--sage-deep)}
p{color:var(--ink);font-size:15.5px}
ul,ol{color:var(--ink);font-size:15.5px;padding-left:22px}
li{margin-bottom:8px}
strong{font-weight:700;color:var(--pine)}
a{color:var(--sage-text)}
img{display:block;max-width:100%;height:auto}
picture{display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 40px}
:focus-visible{outline:2px solid var(--sage-deep);outline-offset:2px;border-radius:4px}

/* ---------- Skip link ---------- */
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--pine);color:var(--white);padding:12px 22px;border-radius:0 0 var(--r) 0;font-family:'Mulish',sans-serif;font-size:14px;font-weight:600;text-decoration:none}
.skip-link:focus{left:0}

/* ---------- Top banner ---------- */
.topnote{display:block;background:var(--sage-deep);color:#fff;text-align:center;font-size:12.5px;font-weight:400;letter-spacing:.06em;padding:9px 16px;text-decoration:none}
.topnote:hover{background:#54614b}

/* ---------- Header / nav ---------- */
.nav{position:sticky;top:0;z-index:20;background:rgba(252,252,250,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-top:16px;padding-bottom:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--pine)}
.mark{width:36px;height:36px;border:1.4px solid var(--sage);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:15px;letter-spacing:.02em;position:relative;flex:none}
.brand .wm{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:21px;letter-spacing:.04em;line-height:1}
.brand .wm small{display:block;font-family:'Mulish',sans-serif;font-weight:600;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--sage-deep);margin-top:3px}
.nav-links{display:flex;gap:28px;font-size:13.5px;letter-spacing:.02em;list-style:none;padding:0}
.nav-links li{margin:0}
.nav-links a{color:var(--slate);text-decoration:none;padding:6px 2px}
.nav-links a:hover{color:var(--pine)}
.nav-links a[aria-current="page"]{color:var(--pine);font-weight:600;border-bottom:2px solid var(--sage)}
.nav-cta{flex:none}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-family:'Mulish',sans-serif;font-size:13px;font-weight:600;color:var(--pine);cursor:pointer}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-family:'Mulish',sans-serif;font-size:14px;font-weight:600;letter-spacing:.02em;padding:15px 30px;border-radius:var(--r);cursor:pointer;border:1px solid transparent;text-decoration:none;transition:background .2s,border-color .2s;text-align:center}
.btn.primary{background:var(--pine);color:var(--white)}
.btn.primary:hover{background:#1f2621}
.btn.ghost{background:transparent;color:var(--pine);border-color:rgba(44,52,46,.25)}
.btn.ghost:hover{border-color:var(--pine)}
.btn.lg{padding:17px 36px;font-size:15px}
.btn.on-dark{background:var(--white);color:var(--pine)}
.btn.on-dark:hover{background:#ece9df}
.btn.ghost.on-dark{background:transparent;color:var(--white);border-color:rgba(255,255,255,.35)}

/* ---------- Eyebrow / kicker ---------- */
.eyebrow{display:inline-block;font-family:'Mulish',sans-serif;font-size:12px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--sage-deep);margin-bottom:18px}

/* ---------- Sections ---------- */
.band{padding:96px 0}
.band.cream{background:var(--cream)}
.band.stone{background:var(--stone)}
.band.tight{padding:64px 0}
.center{text-align:center}
h1.hero-h{font-size:84px;line-height:1.02;letter-spacing:.005em;margin-bottom:26px}
h2.big{font-size:46px;margin-bottom:18px}
h3.mid{font-size:27px;font-weight:600;margin-bottom:12px}
.lede{font-size:19px;color:var(--slate);line-height:1.75;max-width:560px}
.center .lede{margin-left:auto;margin-right:auto}
.lead2{font-size:17.5px;color:var(--slate);line-height:1.85;max-width:640px;margin:18px auto 0}
.btn-row{display:flex;gap:14px;flex-wrap:wrap}
.center .btn-row{justify-content:center}

/* ---------- Hero ---------- */
.hero{padding:96px 0 56px;text-align:center;background:radial-gradient(70% 55% at 50% -8%,rgba(124,138,112,.10),transparent 60%)}
.hero .eyebrow{margin-bottom:26px}
.showcase{margin-top:56px}
.showcase .frame{border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:0 40px 80px -50px rgba(44,52,46,.55)}

/* ---------- Stat strip ---------- */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--white)}
.stats .wrap{display:flex;justify-content:space-between;gap:30px;padding:46px 40px;flex-wrap:wrap}
.stat{flex:1;min-width:150px;text-align:center}
.stat .n{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:52px;line-height:1;color:var(--pine)}
.stat .n em{font-style:italic;color:var(--sage-deep)}
.stat .l{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate);margin-top:12px}

/* ---------- Cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px;text-align:left}
.card{background:var(--white);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.card .ph{overflow:hidden;aspect-ratio:1/1}
.card .ph picture{height:100%}
.card .ph img{width:100%;height:100%;object-fit:cover;object-position:center 35%;transition:transform .8s ease}
.card:hover .ph img{transform:scale(1.04)}
.card .body{padding:30px 30px 34px}
.chip{display:inline-block;font-family:'Mulish',sans-serif;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-deep);background:var(--sage-tint);padding:6px 13px;border-radius:999px;margin-bottom:16px}
.card h3{font-size:26px;font-weight:600;margin-bottom:10px}
.card p{font-size:15px;color:var(--slate);line-height:1.75}

/* ---------- Numbered steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:60px;text-align:left}
.step .num{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--sage-deep);width:48px;height:48px;border:1.4px solid var(--sage);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.step h3{font-size:24px;font-weight:600;margin-bottom:10px}
.step p{font-size:15px;color:var(--slate);line-height:1.75}

/* ---------- Split feature ---------- */
.split{display:grid;grid-template-columns:1.02fr .98fr;gap:64px;align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
.split .pic{border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.split .pic img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:40px;margin-bottom:16px}
.split p{font-size:16px;color:var(--slate);line-height:1.8;margin-bottom:14px}
.li{display:flex;gap:12px;align-items:flex-start;margin-top:13px;font-size:15px;color:var(--pine)}
.li::before{content:"\2014";color:var(--sage-deep);font-weight:700;flex:none}

/* ---------- Comparison table ---------- */
.compare{margin:56px auto 0;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--white);max-width:920px;text-align:left}
.compare .row{display:grid;grid-template-columns:1.3fr 1fr 1fr}
.compare .row + .row{border-top:1px solid var(--line)}
.compare .cell{padding:19px 26px;font-size:15px;color:var(--slate)}
.compare .head .cell{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--pine);font-weight:600;padding-top:25px;padding-bottom:25px}
.compare .head .ours{background:var(--sage-tint);color:var(--sage-deep)}
.compare .cell.ours{background:rgba(235,239,230,.45);color:var(--pine);font-weight:600}
.compare .cell.feat{color:var(--pine);font-weight:600;font-family:'Mulish',sans-serif}
.compare .yes{color:var(--sage-text);font-weight:700}
.compare .no{color:var(--slate)}

/* ---------- Quote ---------- */
.quote-q{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:36px;line-height:1.4;font-weight:500;color:var(--pine)}
.quote-cite{margin-top:24px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--sage-deep);font-weight:600}
.quote-note{margin-top:9px;font-size:12px;color:var(--slate);font-style:italic}

/* ---------- Photo bands & grading ---------- */
.img-grade{filter:saturate(.92) sepia(.06) brightness(1.02)}
.pic-frame{border-radius:20px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.photo-band{position:relative;overflow:hidden}
.photo-band img{width:100%;object-fit:cover}
.photo-band .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,52,46,0) 30%,rgba(44,52,46,.45));pointer-events:none}
.gallery-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
.gallery-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.gallery-2 .pic-frame,.gallery-3 .pic-frame{aspect-ratio:4/3}
.gallery-2 .pic-frame picture,.gallery-3 .pic-frame picture{height:100%}
.gallery-2 .pic-frame img,.gallery-3 .pic-frame img{width:100%;height:100%;object-fit:cover}
.caption{font-size:12.5px;color:var(--slate);margin-top:10px;font-style:italic}

/* ---------- FAQ (details/summary) ---------- */
.faq-list{max-width:820px;margin:48px auto 0;text-align:left}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:16px;margin-bottom:14px;overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 26px;font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--pine)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:'Mulish',sans-serif;font-size:20px;font-weight:300;color:var(--sage-deep);flex:none;transition:transform .25s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-a{padding:0 26px 24px;font-size:15.5px;color:var(--ink);line-height:1.8}
.faq-a p{margin-bottom:12px}
.faq-a p:last-child{margin-bottom:0}

/* ---------- Forms ---------- */
.form-card{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:38px;box-shadow:var(--shadow);text-align:left}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-family:'Mulish',sans-serif;font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--pine);margin-bottom:7px}
.field .opt{font-weight:400;color:var(--slate)}
.field input,.field select,.field textarea{width:100%;font-family:'Mulish',sans-serif;font-size:15px;font-weight:400;color:var(--pine);background:var(--white);border:1px solid rgba(44,52,46,.22);border-radius:10px;padding:13px 15px}
.field textarea{min-height:110px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--sage-deep);outline-offset:1px;border-color:var(--sage-deep)}
.field .err{display:none;font-size:13px;color:#8a3b2e;margin-top:6px}
.consent{font-size:12.5px;color:var(--slate);line-height:1.6;margin-top:14px}
.consent a{color:var(--sage-text)}
.disclaimer{font-size:12.5px;color:var(--slate);line-height:1.65;margin-top:12px;padding:14px 16px;background:var(--cream);border-left:3px solid var(--sage);border-radius:0 10px 10px 0}
.hp-field{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}

/* ---------- Map facade ---------- */
.map-facade{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:var(--sage-tint);text-align:center;padding:44px 24px}
.map-facade .addr{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:600;color:var(--pine);margin-bottom:6px}
.map-facade p{font-size:14px;color:var(--slate);margin-bottom:18px}
.map-live{border:1px solid var(--line);border-radius:20px;overflow:hidden}
.map-live iframe{display:block;width:100%;height:420px;border:0}


/* ---------- Final CTA band ---------- */
.final{background:#222a25;color:var(--white);text-align:center;padding:104px 0 96px}
.final h2{font-size:48px;color:var(--white);margin-bottom:18px}
.final h2 em{color:#b9c4ad}
.final p{font-size:18px;color:#c4ccbf;max-width:560px;margin:0 auto 34px;line-height:1.7}
.final .micro{margin-top:22px;font-size:13px;color:#9aa492;letter-spacing:.04em}

/* ---------- Footer ---------- */
body > footer{background:#222a25;color:#aeb6a8;font-size:14px}
body > footer .wrap{display:flex;justify-content:space-between;gap:44px;flex-wrap:wrap;padding-top:60px;padding-bottom:28px}
body > footer .fwm{font-family:'Cormorant Garamond',serif;font-size:22px;color:#f3f1e9;font-weight:600;margin-bottom:4px}
body > footer .fsub{font-family:'Mulish',sans-serif;font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:#8d9787;margin-bottom:16px}
body > footer h2.fh{font-family:'Mulish',sans-serif;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#d9dccf;margin-bottom:4px}
body > footer a{color:#aeb6a8;text-decoration:none;display:block;margin-top:10px}
body > footer a:hover{color:#f3f1e9}
body > footer address{font-style:normal;line-height:1.8}
.f-legal{border-top:1px solid rgba(255,255,255,.08)}
.f-legal .wrap{display:block;padding-top:22px;padding-bottom:34px}
.f-legal p{font-size:12.5px;color:#98a193;line-height:1.7;max-width:880px;margin-bottom:8px}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{display:none}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .card .ph img{transition:none}
}

/* ---------- Utility ---------- */
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.maxw{max-width:760px;margin-left:auto;margin-right:auto}
.mt-0{margin-top:0}.mt-24{margin-top:24px}.mt-48{margin-top:48px}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .hero-h br{display:none}
  .wrap{padding:0 24px}
  h1.hero-h{font-size:50px}
  h2.big{font-size:33px}
  .split h2{font-size:30px}
  .final h2{font-size:33px}
  .quote-q{font-size:26px}
  .hero{padding:64px 0 40px}
  .band{padding:64px 0}
  .cards,.steps,.gallery-3{grid-template-columns:1fr}
  .gallery-2{grid-template-columns:1fr}
  .split,.split.rev{grid-template-columns:1fr;gap:30px;direction:ltr}
  .form-row{grid-template-columns:1fr}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--white);border-bottom:1px solid var(--line);flex-direction:column;gap:0;padding:10px 24px 16px}
  .nav-links li{margin:0}
  .nav-links a{display:block;padding:12px 0;font-size:15px}
  .nav.menu-open .nav-links{display:flex}
  .nav-toggle{display:inline-block}
  .nav-cta{display:none}
  .compare .row{grid-template-columns:1.2fr .9fr .9fr}
  .compare .cell{padding:14px 14px;font-size:13.5px}
  .compare .head .cell{font-size:17px}
  .sticky-cta{display:flex;gap:10px;position:fixed;left:0;right:0;bottom:0;z-index:30;background:rgba(252,252,250,.95);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:10px 16px calc(10px + env(safe-area-inset-bottom))}
  .sticky-cta .btn{display:block;flex:1 1 0;min-height:48px;text-align:center;padding-left:12px;padding-right:12px}
  body{padding-bottom:74px}
}
