/* ============================================================
   GRACEFUL AGING — Birmingham, AL
   Palette: deep navy + sky/steel blue + warm cream
   ============================================================ */

:root{
  --navy:        #1d3a52;   /* deep ink navy */
  --navy-deep:   #142a3d;   /* darkest band */
  --blue:        #3f7fb0;   /* mid steel blue */
  --blue-bright: #5BA3D0;   /* sky / light blue accent */
  --blue-soft:   #cfe0ee;   /* pale blue wash */
  --cream:       #F4ECE2;   /* warm cream */
  --cream-deep:  #E9DCCB;
  --coral:       #E8917C;   /* from logo heart/hand */
  --paper:       #FBF8F2;
  --white:       #ffffff;
  --text:        #29333b;
  --text-soft:   #5a6a74;

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Mulish", -apple-system, BlinkMacSystemFont, sans-serif;

  --maxw: 1200px;
  --radius: 18px;
  --shadow-soft: 0 18px 50px -22px rgba(20,42,61,.35);
  --shadow-card: 0 24px 60px -30px rgba(20,42,61,.45);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans); color:var(--text); background:var(--paper);
  line-height:1.65; font-size:18px; overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px; }

.skip{ position:absolute; left:-999px; top:0; background:var(--navy); color:#fff; padding:12px 18px; z-index:200; border-radius:0 0 8px 0; }
.skip:focus{ left:0; }

/* ---------- Typography ---------- */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; line-height:1.08; color:var(--navy); letter-spacing:-.01em; }
h1{ font-size:clamp(2.5rem,6vw,4.4rem); font-weight:300; }
h1 em{ font-style:italic; color:var(--blue); font-weight:400; }
h2{ font-size:clamp(1.95rem,4vw,3rem); font-weight:300; }
h3{ font-size:1.5rem; }
p{ font-size:1.06rem; }

.section-eyebrow{ font-family:var(--sans); font-size:.78rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--blue); margin-bottom:14px; }
.section-eyebrow.light{ color:var(--blue-bright); }
.eyebrow{ font-family:var(--sans); font-size:.82rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin-bottom:22px; }
.section-head{ max-width:740px; }
.section-head.center{ margin:0 auto; text-align:center; }
.section-sub{ color:var(--text-soft); margin-top:18px; font-size:1.1rem; }
.section-head h2{ margin-top:6px; }

/* ---------- Buttons ---------- */
.btn{ display:inline-flex; align-items:center; gap:9px; justify-content:center; font-family:var(--sans); font-weight:700; font-size:.98rem; padding:15px 30px; border-radius:50px; cursor:pointer; border:2px solid transparent; transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease; white-space:nowrap; }
.btn-primary{ background:var(--blue); color:#fff; box-shadow:0 12px 28px -12px rgba(63,127,176,.7); }
.btn-primary:hover{ background:var(--navy); transform:translateY(-3px); box-shadow:0 18px 34px -14px rgba(20,42,61,.6); }
.btn-primary.big{ font-size:1.15rem; padding:19px 40px; }
.btn-ghost{ background:transparent; color:var(--navy); border-color:rgba(63,127,176,.45); }
.btn-ghost:hover{ border-color:var(--blue); background:rgba(63,127,176,.08); transform:translateY(-3px); }
.btn-call{ background:var(--cream-deep); color:var(--navy); padding:11px 22px; font-size:.95rem; }
.btn-call:hover{ background:var(--blue); color:#fff; }
.btn-call.full{ width:100%; margin-top:10px; }
.phone-ico{ font-size:1.1rem; }

/* ============================================================
   HEADER
   ============================================================ */
header{ position:sticky; top:0; z-index:100; background:transparent; transition:background .35s ease, box-shadow .35s ease; padding:10px 0; }
header.scrolled{ background:rgba(20,42,61,.97); backdrop-filter:blur(8px); box-shadow:0 8px 30px -16px rgba(0,0,0,.6); }
.nav-wrap{ max-width:var(--maxw); margin:0 auto; padding:0 26px; display:flex; align-items:center; gap:28px; }
.brand{ flex:0 0 auto; display:flex; align-items:center; }
.brand img{ height:52px; width:auto; transition:filter .35s ease; }
.brand .logo-dark{ display:block; }
.brand .logo-light{ display:none; }
header.scrolled .brand .logo-dark{ display:none; }
header.scrolled .brand .logo-light{ display:block; }
.nav{ display:flex; gap:24px; margin-left:auto; align-items:center; }
.nav a{ font-weight:600; font-size:.96rem; color:var(--cream); padding:6px 2px; position:relative; transition:color .2s; }
header:not(.scrolled) .nav a{ color:var(--navy); }
/* Inner pages with a dark hero: light nav + light logo from the top */
header.on-dark:not(.scrolled) .nav a{ color:var(--cream); }
header.on-dark:not(.scrolled) .nav a:hover{ color:var(--blue-bright); }
header.on-dark:not(.scrolled) .brand .logo-dark{ display:none; }
header.on-dark:not(.scrolled) .brand .logo-light{ display:block; }
header.on-dark:not(.scrolled) .hamburger span{ background:var(--cream); }
header.on-dark:not(.scrolled) .btn-call{ background:rgba(255,255,255,.14); color:var(--cream); }
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--blue-bright); transition:width .25s ease; }
.nav a:hover{ color:var(--blue-bright); }
header:not(.scrolled) .nav a:hover{ color:var(--blue); }
.nav a:hover::after{ width:100%; }
.has-drop{ position:relative; }
.has-drop > a::before{ content:""; }
.dropdown{ position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(8px); background:#fff; border-radius:14px; box-shadow:var(--shadow-card); padding:10px; min-width:240px; opacity:0; visibility:hidden; transition:.25s; display:flex; flex-direction:column; gap:2px; }
.has-drop:hover .dropdown, .has-drop:focus-within .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(4px); }
.dropdown a{ color:var(--navy) !important; padding:11px 14px; border-radius:9px; font-size:.92rem; font-weight:600; }
.dropdown a::after{ display:none; }
.dropdown a:hover{ background:var(--blue-soft); color:var(--navy) !important; }
.btn-call{ flex:0 0 auto; }
.hamburger{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; margin-left:auto; }
.hamburger span{ width:26px; height:2px; background:var(--navy); transition:.3s; border-radius:2px; }
header.scrolled .hamburger span{ background:var(--cream); }
.mobile-menu{ display:flex; flex-direction:column; gap:2px; padding:18px 26px 24px; background:rgba(20,42,61,.98); backdrop-filter:blur(8px); }
.mobile-menu[hidden]{ display:none; }
.mobile-menu a{ color:var(--cream); font-weight:600; padding:13px 4px; border-bottom:1px solid rgba(255,255,255,.08); }
.mobile-menu a.sub{ padding-left:18px; font-size:.92rem; color:var(--blue-soft); }
.mobile-menu .btn{ border-bottom:none; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding:60px 0 30px; overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(900px 600px at 80% 6%, rgba(91,163,208,.20), transparent 60%),
    radial-gradient(800px 700px at 6% 72%, rgba(63,127,176,.16), transparent 60%),
    linear-gradient(180deg, var(--cream) 0%, var(--paper) 100%); }
.hero-bg::before{ content:""; position:absolute; inset:0; background-image:radial-gradient(rgba(20,42,61,.05) 1px, transparent 1px); background-size:22px 22px; opacity:.5; }
.hero-grid{ position:relative; z-index:1; max-width:var(--maxw); margin:0 auto; padding:0 26px; display:grid; grid-template-columns:1.05fr .95fr; gap:54px; align-items:center; }
.hero-copy{ padding:30px 0; }
.lede{ font-size:1.22rem; color:var(--text-soft); max-width:540px; margin:26px 0 32px; line-height:1.6; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-trust{ list-style:none; margin-top:40px; display:flex; flex-direction:column; gap:12px; border-top:1px solid rgba(20,42,61,.12); padding-top:26px; max-width:520px; }
.hero-trust li{ font-size:.98rem; color:var(--text-soft); padding-left:26px; position:relative; }
.hero-trust li::before{ content:""; position:absolute; left:0; top:.55em; width:11px; height:11px; border-radius:50%; background:var(--blue); }
.hero-trust strong{ color:var(--navy); font-weight:700; }
.hero-photo{ position:relative; }
.hero-photo img{ border-radius:var(--radius); box-shadow:var(--shadow-card); aspect-ratio:1066/1300; object-fit:cover; object-position:center 22%; width:100%; }
.hero-photo::after{ content:""; position:absolute; inset:0; border-radius:var(--radius); box-shadow:inset 0 0 0 1px rgba(255,255,255,.25); pointer-events:none; }
.hero-photo-tag{ position:absolute; left:18px; bottom:18px; right:18px; background:rgba(20,42,61,.84); color:var(--cream); backdrop-filter:blur(4px); font-size:.82rem; font-weight:600; padding:11px 16px; border-radius:12px; }

/* ---------- Marquee ---------- */
.marquee{ background:var(--navy); color:var(--cream); overflow:hidden; padding:16px 0; font-family:var(--serif); font-style:italic; font-size:1.4rem; }
.marquee-track{ display:flex; gap:26px; white-space:nowrap; width:max-content; animation:scroll 28s linear infinite; }
.marquee-track span{ font-weight:300; }
.marquee .dot{ color:var(--blue-bright); }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ============================================================
   GENERIC SECTIONS
   ============================================================ */
.intro{ padding:96px 0; }
.intro-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:60px; align-items:center; }
.intro-text p{ color:var(--text-soft); margin-top:20px; font-size:1.1rem; }
.intro-text h2{ margin-top:6px; }
.intro-photo img{ border-radius:var(--radius); box-shadow:var(--shadow-soft); aspect-ratio:4/4.6; object-fit:cover; object-position:center 30%; width:100%; }

/* SERVICES cards */
.services{ padding:96px 0; background:linear-gradient(180deg,var(--cream) 0%, var(--paper) 100%); }
.service-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:60px; }
.card{ position:relative; background:var(--white); border-radius:var(--radius); padding:40px 32px 36px; box-shadow:var(--shadow-soft); border:1px solid rgba(20,42,61,.06); transition:transform .3s ease, box-shadow .3s ease; display:flex; flex-direction:column; }
.card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-card); }
.card-feature{ background:var(--navy); color:var(--cream); }
.card-feature h3,.card-feature .card-num{ color:var(--white); }
.card-feature .card-best{ color:rgba(244,236,226,.7); border-color:rgba(255,255,255,.15); }
.card-num{ font-family:var(--serif); font-size:2.4rem; font-weight:300; color:var(--blue); line-height:1; margin-bottom:18px; }
.card h3{ margin-bottom:14px; line-height:1.15; }
.card p{ color:var(--text-soft); font-size:1rem; }
.card-feature p{ color:rgba(244,236,226,.85); }
.card-list{ list-style:none; margin:20px 0; display:flex; flex-direction:column; gap:9px; }
.card-list li{ font-size:.96rem; padding-left:24px; position:relative; font-weight:600; color:var(--navy); }
.card-feature .card-list li{ color:var(--cream); }
.card-list li::before{ content:"\2713"; position:absolute; left:0; color:var(--blue); font-weight:700; }
.card-feature .card-list li::before{ color:var(--blue-bright); }
.card-best{ margin-top:auto; padding-top:18px; border-top:1px solid rgba(20,42,61,.1); font-size:.88rem; font-style:italic; color:var(--text-soft); }
.card-flag{ position:absolute; top:18px; right:18px; background:var(--coral); color:#fff; font-family:var(--sans); font-size:.7rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; padding:5px 12px; border-radius:50px; }
.card-link{ margin-top:20px; font-weight:700; color:var(--blue); font-size:.95rem; display:inline-flex; align-items:center; gap:6px; }
.card-feature .card-link{ color:var(--blue-bright); }
.card-link:hover{ gap:11px; }

/* VIRTUAL */
.virtual{ padding:96px 0; background:var(--navy); color:var(--cream); position:relative; overflow:hidden; }
.virtual::before{ content:""; position:absolute; top:-120px; right:-120px; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle, rgba(91,163,208,.25), transparent 70%); }
.virtual-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:60px; align-items:center; position:relative; z-index:1; }
.virtual-photo img{ border-radius:var(--radius); box-shadow:0 30px 70px -30px rgba(0,0,0,.6); aspect-ratio:4/5; object-fit:cover; object-position:center 25%; width:100%; }
.virtual-text h2{ color:var(--white); }
.virtual-text p{ color:rgba(244,236,226,.85); margin:20px 0 28px; font-size:1.1rem; }
.virtual-list{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:14px 24px; margin-bottom:34px; }
.virtual-list li{ font-weight:600; display:flex; align-items:center; gap:11px; color:var(--cream); }
.virtual-list span{ display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:50%; background:var(--blue); color:#fff; font-size:.8rem; flex:0 0 auto; }

/* AREAS */
.areas{ padding:96px 0; }
.area-grid{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin:54px auto 36px; max-width:980px; }
.area-grid li a, .area-grid li{ display:block; }
.area-grid li a{ background:var(--white); border:1px solid rgba(20,42,61,.08); border-radius:12px; padding:18px 16px; text-align:center; font-weight:700; color:var(--navy); font-size:1rem; box-shadow:0 8px 22px -16px rgba(20,42,61,.4); transition:transform .25s, background .25s, color .25s; }
.area-grid li a:hover{ transform:translateY(-4px); background:var(--blue); color:#fff; }
.area-note{ text-align:center; color:var(--text-soft); max-width:760px; margin:0 auto; font-size:1.05rem; }

/* HOW */
.how{ padding:96px 0; background:linear-gradient(180deg,var(--paper) 0%, var(--cream) 100%); }
.steps{ list-style:none; display:grid; grid-template-columns:repeat(3,1fr); gap:30px; margin-top:60px; }
.step{ position:relative; padding:36px 28px; background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow-soft); }
.step-num{ width:56px; height:56px; border-radius:50%; background:var(--blue-soft); color:var(--navy); font-family:var(--serif); font-size:1.6rem; display:flex; align-items:center; justify-content:center; margin-bottom:20px; font-weight:500; }
.step h3{ margin-bottom:12px; }
.step p{ color:var(--text-soft); font-size:1rem; }

/* BENEFITS */
.benefits{ padding:96px 0; }
.benefits-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:60px; align-items:center; }
.benefits-photo img{ border-radius:var(--radius); box-shadow:var(--shadow-soft); aspect-ratio:4/5; object-fit:cover; object-position:center 20%; width:100%; }
.benefits-text p{ color:var(--text-soft); margin:18px 0 26px; font-size:1.1rem; }
.benefit-list{ list-style:none; display:grid; grid-template-columns:repeat(2,1fr); gap:13px 20px; }
.benefit-list li{ position:relative; padding-left:28px; font-weight:600; color:var(--navy); font-size:1rem; }
.benefit-list li::before{ content:""; position:absolute; left:0; top:.45em; width:14px; height:14px; background:var(--blue); border-radius:4px; transform:rotate(45deg); }

/* TEAM */
.team{ padding:96px 0; background:var(--cream); }
.team-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:60px; }
.team-card{ background:var(--white); border-radius:var(--radius); padding:36px 30px; box-shadow:var(--shadow-soft); border-top:4px solid var(--blue); transition:transform .3s, box-shadow .3s; }
.team-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-card); }
.team-card:nth-child(2){ border-top-color:var(--blue-bright); }
.team-card:nth-child(3){ border-top-color:var(--coral); }
.team-card h3{ line-height:1.2; }
.creds{ display:block; font-family:var(--sans); font-size:.78rem; font-weight:700; letter-spacing:.12em; color:var(--blue); margin-top:6px; }
.role{ font-family:var(--sans); font-weight:700; font-size:.8rem; text-transform:uppercase; letter-spacing:.14em; color:var(--blue); margin:12px 0 16px; }
.team-card p:last-child{ color:var(--text-soft); font-size:.98rem; }

/* GALLERY */
.gallery{ padding:96px 0; background:linear-gradient(180deg,var(--paper),var(--cream)); }
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:54px; }
.gallery-grid img{ border-radius:14px; aspect-ratio:3/4; object-fit:cover; width:100%; box-shadow:var(--shadow-soft); transition:transform .3s; }
.gallery-grid img:hover{ transform:scale(1.03); }
.gallery-grid img.wide{ grid-column:span 2; aspect-ratio:3/2; }

/* QUOTE */
.quote-band{ padding:90px 0; background:var(--navy); color:var(--cream); text-align:center; }
.quote-band blockquote{ max-width:840px; margin:0 auto; }
.quote-band p{ font-family:var(--serif); font-style:italic; font-weight:300; font-size:clamp(1.5rem,3.2vw,2.3rem); line-height:1.35; color:var(--white); }
.quote-band cite{ display:block; margin-top:26px; font-family:var(--sans); font-style:normal; font-weight:700; letter-spacing:.1em; text-transform:uppercase; font-size:.85rem; color:var(--blue-bright); }

/* CTA */
.cta{ padding:100px 0; background:radial-gradient(800px 500px at 50% 0%, rgba(91,163,208,.20), transparent 60%), var(--paper); }
.cta-inner{ text-align:center; max-width:760px; }
.cta h2{ margin:6px 0 22px; }
.cta p{ color:var(--text-soft); font-size:1.15rem; }
.cta-actions{ margin:36px 0 24px; }
.cta-fine{ font-size:.85rem; color:var(--text-soft); }

/* ============================================================
   INNER PAGE HEADER (services / locations)
   ============================================================ */
.page-hero{ position:relative; padding:120px 0 80px; overflow:hidden; background:var(--navy-deep); color:var(--cream); }
.page-hero .hero-bg{ background:
    radial-gradient(800px 500px at 75% 0%, rgba(63,127,176,.4), transparent 60%),
    radial-gradient(700px 600px at 10% 90%, rgba(91,163,208,.25), transparent 60%),
    var(--navy-deep); }
.page-hero-inner{ position:relative; z-index:1; max-width:860px; }
.page-hero .eyebrow{ color:var(--blue-bright); }
.page-hero h1{ color:#fff; }
.page-hero h1 em{ color:var(--blue-bright); }
.page-hero p{ color:rgba(244,236,226,.85); font-size:1.2rem; margin-top:22px; max-width:640px; }
.breadcrumb{ position:relative; z-index:1; font-size:.85rem; color:var(--blue-soft); margin-bottom:20px; }
.breadcrumb a:hover{ color:#fff; }
.page-hero .hero-cta{ margin-top:32px; }

.prose{ padding:80px 0; }
.prose-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:start; }
.prose-body h2{ margin:36px 0 14px; }
.prose-body h2:first-child{ margin-top:0; }
.prose-body p{ color:var(--text-soft); margin-bottom:18px; }
.prose-body ul{ margin:0 0 24px 0; list-style:none; display:flex; flex-direction:column; gap:10px; }
.prose-body ul li{ padding-left:28px; position:relative; color:var(--text); }
.prose-body ul li::before{ content:"\2713"; position:absolute; left:0; color:var(--blue); font-weight:700; }
.prose-aside{ position:sticky; top:100px; background:var(--white); border-radius:var(--radius); padding:32px; box-shadow:var(--shadow-soft); border-top:4px solid var(--blue); }
.prose-aside img{ border-radius:12px; margin-bottom:22px; aspect-ratio:4/3; object-fit:cover; width:100%; }
.prose-aside h3{ font-size:1.3rem; margin-bottom:14px; }
.prose-aside ul{ list-style:none; margin:14px 0 22px; display:flex; flex-direction:column; gap:9px; }
.prose-aside li{ padding-left:24px; position:relative; font-weight:600; color:var(--navy); font-size:.96rem; }
.prose-aside li::before{ content:""; position:absolute; left:0; top:.5em; width:10px; height:10px; border-radius:50%; background:var(--blue); }
.prose-aside .btn{ width:100%; }

.related{ padding:70px 0 90px; background:var(--cream); }
.related-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px; }
.related-card{ background:#fff; border-radius:14px; padding:28px; box-shadow:var(--shadow-soft); transition:transform .25s; }
.related-card:hover{ transform:translateY(-5px); }
.related-card h3{ font-size:1.2rem; margin-bottom:10px; }
.related-card p{ color:var(--text-soft); font-size:.95rem; margin-bottom:14px; }
.related-card a{ font-weight:700; color:var(--blue); font-size:.92rem; }

/* ============================================================
   FOOTER
   ============================================================ */
footer{ background:var(--navy-deep); color:var(--cream); padding:64px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.4fr; gap:40px; }
.footer-brand img{ height:48px; width:auto; margin-bottom:16px; }.footer-brand p{ font-family:var(--serif); font-style:italic; color:var(--blue-bright); font-size:1.1rem; }
.footer-col h4{ font-family:var(--sans); font-size:.8rem; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--blue-bright); margin-bottom:18px; }
.footer-col a{ display:block; color:rgba(244,236,226,.82); padding:6px 0; font-size:.96rem; transition:color .2s; }
.footer-col a:hover{ color:var(--blue-bright); }
.footer-col p{ color:rgba(244,236,226,.72); font-size:.94rem; line-height:1.6; }
.footer-bottom{ margin-top:54px; border-top:1px solid rgba(255,255,255,.1); padding:24px 0; text-align:center; }
.footer-bottom p{ font-size:.85rem; color:rgba(244,236,226,.6); }

/* REVEAL */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s ease, transform .8s ease; }
.reveal.in{ opacity:1; transform:none; }
.reveal:nth-child(2){ transition-delay:.08s; }
.reveal:nth-child(3){ transition-delay:.16s; }
.reveal:nth-child(4){ transition-delay:.24s; }
.reveal:nth-child(5){ transition-delay:.32s; }

/* RESPONSIVE */
@media (max-width:980px){
  .nav, .btn-call{ display:none; }
  .hamburger{ display:flex; }
  .hero-grid, .intro-grid, .virtual-grid, .benefits-grid, .prose-grid{ grid-template-columns:1fr; gap:42px; }
  .hero-photo, .intro-photo, .virtual-photo, .benefits-photo{ max-width:520px; margin:0 auto; }
  .service-cards, .steps, .team-cards, .related-cards{ grid-template-columns:1fr; }
  .area-grid{ grid-template-columns:repeat(3,1fr); }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid img.wide{ grid-column:span 2; }
  .prose-aside{ position:static; }
}
@media (max-width:640px){
  body{ font-size:17px; }
  .hero{ padding:30px 0 10px; } .hero-copy{ padding:10px 0; }
  .intro,.services,.virtual,.areas,.how,.benefits,.team,.cta,.gallery,.prose,.related{ padding:64px 0; }
  .page-hero{ padding:90px 0 60px; }
  .hero-cta .btn{ flex:1 1 auto; }
  .virtual-list, .benefit-list{ grid-template-columns:1fr; }
  .area-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ grid-template-columns:1fr 1fr; }
  .btn-primary.big{ font-size:1rem; padding:16px 28px; }
  .marquee{ font-size:1.15rem; }
  /* Smaller logo in the mobile nav */
  .brand img{ height:40px; }
  /* Footer: stack into a single column so nothing gets squeezed */
  footer{ padding:48px 0 0; }
  .footer-grid{ grid-template-columns:1fr; gap:32px; text-align:center; }
  .footer-brand img{ height:44px; margin-left:auto; margin-right:auto; }
  .footer-col a{ padding:8px 0; }
}
@media (max-width:380px){
  .brand img{ height:36px; }
  .area-grid{ grid-template-columns:1fr 1fr; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
}
