/* ============================================================
   Seniors Living Hub — website stylesheet (self-contained)
   Brand: cream canvas · terracotta (action) · sage (calm/safe) ·
   forest (bands). Bitter headings + Atkinson Hyperlegible body.
   Built for older readers: large type, big targets, high contrast.
   ------------------------------------------------------------
   This single file is all the CSS the site needs. Transfer the
   whole /site folder by FTP and it works as-is.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:ital,wght@0,400;0,700;1,400;1,700&family=Bitter:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ---------------- Tokens ---------------- */
:root {
  --cream:#F6EFE2; --cream-deep:#ECE1CD; --linen:#FBF6EC; --card:#FFFDF8; --paper:#FFFFFF;
  --terracotta-50:#FBEDE4; --terracotta-100:#F4D7C6; --terracotta-200:#E9B79C; --terracotta-300:#DD9772;
  --terracotta-400:#CC7950; --terracotta-500:#BD6038; --terracotta-600:#B5562F; --terracotta-700:#94421F; --terracotta-800:#75331A;
  --sage-50:#ECEFE6; --sage-100:#DBE2CF; --sage-200:#C0CBAD; --sage-300:#A2B188; --sage-400:#84956A;
  --sage-500:#6E7F54; --sage-600:#5C6C45; --sage-700:#46522F; --forest:#36402A; --forest-deep:#29311F;
  --honey:#C2912F; --honey-soft:#F3E4C2;
  --ink:#2C271F; --ink-soft:#574F43; --ink-muted:#837A6B;
  --on-dark:#FAF4E8; --on-dark-soft:rgba(250,244,232,0.78);
  --border:#E6DBC7; --border-strong:#D6C8AD; --border-ondark:rgba(250,244,232,0.28);
  --success:#4F7A4E; --success-soft:#E2EDDC; --caution:#B5772A; --caution-soft:#F6E7C9;
  --alert:#B23A2C; --alert-soft:#F6DAD3; --info:#3F6E72; --info-soft:#DBEAEA;
  --focus-ring:rgba(181,86,47,0.55);
  --brand:var(--terracotta-600); --brand-hover:var(--terracotta-700); --accent:var(--sage-600); --link:var(--terracotta-700);

  --font-display:"Bitter",Georgia,"Times New Roman",serif;
  --font-body:"Atkinson Hyperlegible","Segoe UI",system-ui,-apple-system,sans-serif;

  --maxw:1140px; --prose:680px;
  --radius-md:12px; --radius-lg:16px; --radius-xl:24px; --radius-pill:999px;
  --shadow-xs:0 1px 2px rgba(60,45,30,0.07);
  --shadow-sm:0 1px 2px rgba(60,45,30,0.06),0 2px 6px rgba(60,45,30,0.07);
  --shadow-md:0 2px 4px rgba(60,45,30,0.06),0 8px 20px rgba(60,45,30,0.10);
  --shadow-lg:0 4px 10px rgba(60,45,30,0.08),0 18px 40px rgba(60,45,30,0.14);
  --ease:cubic-bezier(0.22,0.61,0.36,1);

  --fs-body:1.1875rem;   /* 19px */
}
html.large-text { --fs-body:1.375rem; }   /* 22px — the header "A+" toggle */

/* ---------------- Base ---------------- */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--font-body);font-size:var(--fs-body);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.18;margin:0 0 .5em;letter-spacing:-0.01em;color:var(--ink);text-wrap:balance;}
h1{font-size:clamp(2.1rem,4.4vw,3.3rem);line-height:1.14;}
h2{font-size:clamp(1.7rem,3.2vw,2.3rem);}
h3{font-size:1.5rem;font-weight:600;}
h4{font-size:1.2rem;font-weight:600;}
p{margin:0 0 1em;text-wrap:pretty;}
a{color:var(--link);text-underline-offset:.18em;text-decoration-thickness:.08em;}
a:hover{color:var(--terracotta-800);}
img{max-width:100%;display:block;}
strong{font-weight:700;}
:focus-visible{outline:3px solid var(--brand);outline-offset:3px;border-radius:8px;}
::selection{background:var(--terracotta-100);color:var(--terracotta-800);}

/* ---------------- Layout ---------------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:64px 0;}
.section--tight{padding:44px 0;}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.95rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--sage-700);background:var(--sage-50);padding:7px 14px;border-radius:var(--radius-pill);}
.lead{font-size:1.375rem;color:var(--ink-soft);line-height:1.65;}
.center{text-align:center;}
.muted{color:var(--ink-muted);}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--forest);color:#fff;padding:12px 18px;border-radius:0 0 12px 0;z-index:100;}
.skip-link:focus{left:0;color:#fff;}

/* ---------------- Buttons ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 26px;border-radius:var(--radius-pill);border:2px solid transparent;
  font-family:var(--font-body);font-size:1.0625rem;font-weight:700;line-height:1;cursor:pointer;
  text-decoration:none;transition:background .15s var(--ease),transform .15s var(--ease),border-color .15s var(--ease);
  -webkit-tap-highlight-color:transparent;}
.btn:active{transform:scale(.97);}
.btn--lg{min-height:60px;padding:0 34px;font-size:1.1875rem;}
.btn--primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-xs);}
.btn--primary:hover{background:var(--brand-hover);color:#fff;}
.btn--secondary{background:var(--accent);color:#fff;box-shadow:var(--shadow-xs);}
.btn--secondary:hover{background:var(--sage-700);color:#fff;}
.btn--outline{background:transparent;color:var(--brand-hover);border-color:var(--brand);}
.btn--outline:hover{background:var(--terracotta-50);color:var(--brand-hover);}
.btn--ghost{background:transparent;color:var(--ink);}
.btn--ghost:hover{background:var(--cream-deep);color:var(--ink);}
.btn--white{background:#fff;color:var(--brand-hover);}
.btn--white:hover{background:var(--linen);color:var(--brand-hover);}
.btn--block{width:100%;}
.btn svg{width:20px;height:20px;}

/* ---------------- Badges ---------------- */
.badge{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:var(--radius-pill);
  font-size:.85rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;}
.badge--sage{background:var(--sage-50);color:var(--sage-700);}
.badge--terracotta{background:var(--terracotta-50);color:var(--terracotta-700);}
.badge--honey{background:var(--honey-soft);color:#8A6312;}
.badge--alert{background:var(--alert-soft);color:#7E2419;}
.badge--solid{background:var(--brand);color:#fff;}

/* ---------------- Header / nav ---------------- */
.site-header{position:sticky;top:0;z-index:40;background:rgba(251,246,236,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);}
.nav{display:flex;align-items:center;gap:22px;height:94px;}
.nav__logo{display:inline-flex;flex:0 0 auto;}
.nav__logo img{height:66px;width:auto;}
.nav__links{display:flex;gap:2px;margin-left:8px;list-style:none;padding:0;margin-top:0;margin-bottom:0;}
.nav__links a{font-size:1.0625rem;font-weight:700;color:var(--ink-soft);text-decoration:none;padding:10px 14px;border-radius:var(--radius-pill);}
.nav__links a:hover{color:var(--brand-hover);background:var(--terracotta-50);}
.nav__links a.is-active{color:var(--brand-hover);background:var(--terracotta-50);}
.nav__actions{margin-left:auto;display:flex;align-items:center;gap:12px;}
.iconbtn{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;
  border:1px solid var(--border-strong);background:var(--card);color:var(--ink);cursor:pointer;font-family:var(--font-body);font-weight:700;font-size:1.05rem;}
.iconbtn:hover{background:var(--terracotta-50);}
.nav__toggle{display:none;}
@media(max-width:980px){
  .nav__links{position:fixed;inset:94px 0 auto 0;flex-direction:column;background:var(--linen);border-bottom:1px solid var(--border);
    padding:12px 24px 20px;gap:4px;box-shadow:var(--shadow-md);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.2s var(--ease);}
  .nav__links.open{transform:translateY(0);opacity:1;pointer-events:auto;}
  .nav__links a{padding:14px 12px;font-size:1.15rem;}
  .nav__toggle{display:inline-flex;}
  .nav__cta-text{display:none;}
}

/* ---------------- Hero ---------------- */
.hero{position:relative;overflow:hidden;}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:72px 0 60px;}
.hero h1{margin:18px 0 18px;}
.hero .lead{margin-bottom:0;}
.hero__art{border-radius:var(--radius-xl);min-height:360px;box-shadow:var(--shadow-md);position:relative;overflow:hidden;}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px;}
@media(max-width:880px){.hero__grid{grid-template-columns:1fr;gap:28px;padding:48px 0;}.hero__art{min-height:240px;}}

/* Brand "art" tiles — warm, textured, cohesive stand-ins for photography */
.art{position:relative;border-radius:var(--radius-xl);overflow:hidden;display:flex;align-items:flex-end;padding:20px;color:#fff;}
.art::after{content:"";position:absolute;inset:0;background:
   radial-gradient(120% 80% at 80% 10%,rgba(255,255,255,.22),transparent 60%),
   radial-gradient(90% 70% at 10% 100%,rgba(0,0,0,.18),transparent 55%);}
.art__cap{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;font-size:.95rem;font-weight:700;background:rgba(41,49,31,.46);padding:7px 13px;border-radius:var(--radius-pill);}
/* Real photo layer — sits over the gradient; if it fails to load it
   simply disappears and the warm brand panel shows through. */
.art__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.art::after{z-index:0;}
.art--sage{background:linear-gradient(135deg,var(--sage-400),var(--sage-600));}
.art--terracotta{background:linear-gradient(135deg,var(--terracotta-400),var(--terracotta-600));}
.art--honey{background:linear-gradient(135deg,var(--honey),#A87A1E);}
.art--forest{background:linear-gradient(135deg,var(--sage-500),var(--forest));}
.art--info{background:linear-gradient(135deg,#5E929A,var(--info));}

/* ---------------- Cards & grids ---------------- */
.grid{display:grid;gap:22px;}
.grid--3{grid-template-columns:repeat(3,1fr);}
.grid--2{grid-template-columns:repeat(2,1fr);}
@media(max-width:900px){.grid--3{grid-template-columns:1fr 1fr;}}
@media(max-width:640px){.grid--3,.grid--2{grid-template-columns:1fr;}}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);}
.card--pad{padding:28px;}
a.card{display:block;text-decoration:none;color:var(--ink);transition:transform .24s var(--ease),box-shadow .24s var(--ease);}
a.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.topic{display:block;}
.topic__icon{display:inline-flex;width:56px;height:56px;border-radius:var(--radius-lg);align-items:center;justify-content:center;margin-bottom:14px;}
.topic h3{margin:0 0 6px;}
.topic .go{margin-top:14px;display:inline-flex;align-items:center;gap:6px;color:var(--brand-hover);font-weight:700;font-size:1rem;}
.icon-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);}
.icon-chip svg{width:28px;height:28px;}

/* ---------------- Feature band ---------------- */
.band{background:var(--forest);color:var(--on-dark);}
.band h2{color:var(--on-dark);}
.band p{color:var(--on-dark-soft);}
.band__grid{display:grid;grid-template-columns:1fr .9fr;gap:48px;align-items:center;}
@media(max-width:880px){.band__grid{grid-template-columns:1fr;gap:28px;}}

/* ---------------- Steps / checklist ---------------- */
.checklist{display:flex;flex-direction:column;gap:12px;}
.check-item{display:flex;gap:14px;align-items:flex-start;padding:18px 20px;background:var(--card);border:2px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);transition:.2s var(--ease);box-shadow:var(--shadow-xs);}
.check-item:hover{border-color:var(--border-strong);}
.check-item.done{background:var(--sage-50);border-color:var(--sage-300);}
.check-box{flex:0 0 auto;width:32px;height:32px;border-radius:50%;border:2px solid var(--border-strong);display:grid;place-items:center;margin-top:2px;color:#fff;}
.check-item.done .check-box{background:var(--accent);border-color:var(--accent);}
.check-box svg{width:20px;height:20px;opacity:0;}
.check-item.done .check-box svg{opacity:1;}
.check-item .t{font-family:var(--font-display);font-weight:600;font-size:1.2rem;}
.check-item.done .t{text-decoration:line-through;text-decoration-color:var(--sage-300);}
.check-item .d{color:var(--ink-soft);font-size:1.0625rem;margin-top:3px;}
.progress{height:14px;background:var(--cream-deep);border-radius:var(--radius-pill);overflow:hidden;}
.progress__fill{height:100%;background:var(--accent);border-radius:var(--radius-pill);transition:width .4s var(--ease);}

/* ---------------- Callout ---------------- */
.callout{display:flex;gap:16px;padding:18px 20px;border-radius:var(--radius-lg);}
.callout__ic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:#fff;}
.callout__ic svg{width:22px;height:22px;}
.callout h4{margin:0 0 4px;font-family:var(--font-display);}
.callout p{margin:0;}
.callout--tip{background:var(--sage-50);}.callout--tip .callout__ic{background:var(--accent);}.callout--tip,.callout--tip h4{color:var(--sage-700);}
.callout--caution{background:var(--caution-soft);}.callout--caution .callout__ic{background:var(--caution);}.callout--caution,.callout--caution h4{color:#7A4E14;}
.callout--alert{background:var(--alert-soft);}.callout--alert .callout__ic{background:var(--alert);}.callout--alert,.callout--alert h4{color:#7E2419;}

/* ---------------- Forms ---------------- */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;}
.field label{font-weight:700;font-size:1.0625rem;}
.field .req{color:var(--alert);}
.field input,.field textarea,.field select{
  font-family:var(--font-body);font-size:1.1875rem;color:var(--ink);background:var(--paper);
  border:2px solid var(--border-strong);border-radius:var(--radius-md);padding:14px 16px;min-height:56px;width:100%;}
.field textarea{min-height:140px;resize:vertical;line-height:1.5;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--focus-ring);}
.form-note{font-size:1rem;color:var(--ink-muted);}
.form-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:32px;}
.form-success{display:none;background:var(--success-soft);color:#33602F;border-radius:var(--radius-lg);padding:18px 20px;font-weight:700;}
.form-success.show{display:block;}

/* ---------------- Newsletter band ---------------- */
.newsletter{background:var(--terracotta-50);border-radius:var(--radius-xl);padding:40px;}
.newsletter form{display:flex;gap:12px;flex-wrap:wrap;max-width:520px;}
.newsletter input{flex:1;min-width:220px;margin:0;}
@media(max-width:520px){.newsletter .btn{width:100%;}}

/* ---------------- Downloads ---------------- */
.dl{display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);text-decoration:none;color:var(--ink);transition:box-shadow .2s var(--ease),transform .2s var(--ease);}
.dl:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px);}
.dl__ic{flex:0 0 auto;width:48px;height:48px;border-radius:var(--radius-md);background:var(--terracotta-50);color:var(--terracotta-700);display:grid;place-items:center;}
.dl__ic svg{width:26px;height:26px;}
.dl__meta{flex:1;}
.dl__meta .t{display:block;font-weight:700;font-size:1.15rem;color:var(--ink);}
.dl__meta .s{display:block;color:var(--ink-muted);font-size:1rem;margin-top:2px;}
.dl--locked{opacity:.92;}
.dl--locked .dl__ic{background:var(--cream-deep);color:var(--ink-muted);}

/* ---------------- Blog ---------------- */
.post__cover{height:200px;border-radius:0;}
.post__body{padding:24px;}
.post__meta{display:flex;align-items:center;gap:8px;color:var(--ink-muted);font-size:.95rem;margin-top:14px;}

/* ---------------- Accordion (FAQ) ---------------- */
.acc{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden;margin-bottom:12px;}
.acc__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:56px;padding:18px 22px;
  background:none;border:none;cursor:pointer;text-align:left;font-family:var(--font-display);font-weight:600;font-size:1.2rem;color:var(--ink);}
.acc__q svg{flex:0 0 auto;width:24px;height:24px;color:var(--brand);transition:transform .24s var(--ease);}
.acc.open .acc__q svg{transform:rotate(180deg);}
.acc__a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s var(--ease);}
.acc.open .acc__a{grid-template-rows:1fr;}
.acc__a>div{overflow:hidden;}
.acc__a p{margin:0;padding:0 22px 22px;color:var(--ink-soft);line-height:1.7;}

/* ---------------- Page hero (interior) ---------------- */
.page-hero{background:var(--linen);border-bottom:1px solid var(--border);padding:48px 0;}
.page-hero .crumbs{font-size:1rem;color:var(--ink-muted);margin-bottom:14px;}
.page-hero .crumbs a{color:var(--link);text-decoration:none;}

/* ---------------- Footer ---------------- */
.site-footer{background:var(--forest);color:var(--on-dark-soft);margin-top:0;}
.site-footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding:56px 0 40px;}
.site-footer img{height:46px;}
.site-footer h4{color:var(--on-dark);font-family:var(--font-display);font-weight:600;font-size:1.1rem;margin:0 0 14px;}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.site-footer a{color:var(--on-dark-soft);text-decoration:none;font-size:1.0625rem;}
.site-footer a:hover{color:var(--on-dark);}
.site-footer__bar{border-top:1px solid var(--border-ondark);}
.site-footer__bar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:20px;padding-bottom:20px;font-size:.95rem;}
@media(max-width:820px){.site-footer__top{grid-template-columns:1fr 1fr;gap:28px;}}
@media(max-width:480px){.site-footer__top{grid-template-columns:1fr;}}

/* ---------------- Article (blog post) ---------------- */
.article{max-width:var(--prose);margin:0 auto;}
.article>h1{font-size:clamp(1.85rem,3.6vw,2.6rem);line-height:1.2;margin:14px 0 26px !important;text-wrap:balance;}
.article>p,.article>ul li{font-size:1.1875rem;line-height:1.75;color:var(--ink);}
.article>p.lead{font-size:1.375rem;color:var(--ink-soft);line-height:1.6;}
.article h2{font-size:1.7rem;margin:42px 0 12px;}
.article h3{font-size:1.3rem;margin:28px 0 8px;}
.article ul{padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px;margin:0 0 1.2em;}
.article ul li{display:flex;gap:12px;align-items:flex-start;}
.article ul li svg{flex:0 0 auto;width:24px;height:24px;color:var(--accent);margin-top:3px;}
.article .callout{margin:26px 0;}
.post-hero{width:100%;height:clamp(220px,38vw,420px);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;}
.byline{display:flex;align-items:center;gap:14px;margin:26px 0 30px;}
.avatar{width:54px;height:54px;border-radius:50%;background:var(--sage-100);color:var(--sage-700);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:1.35rem;flex:0 0 auto;}
.byline__photo{width:56px;height:56px;border-radius:50%;object-fit:cover;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(60,45,30,.12);}

/* ---------------- Utility ---------------- */
.stack-sm>*+*{margin-top:10px;}
.mt-0{margin-top:0;}
.feature-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px;}
.feature-list li{display:flex;gap:12px;align-items:flex-start;font-size:1.0625rem;}
.feature-list svg{flex:0 0 auto;width:24px;height:24px;color:var(--accent);margin-top:2px;}
.divider{border:none;border-top:1px solid var(--border);margin:0;}
