:root{
  --ink:#2b2a26;
  --deep:#3a4740;
  --green:#46594c;
  --accent:#a9744f;
  --accent-dark:#8c5d3d;
  --cream:#f6f1e9;
  --sand:#ece4d7;
  --line:#ddd2c2;
  --muted:#7c7468;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
html,body{ overflow-x:clip; max-width:100%; }
body{ font:16px/1.75 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif; color:var(--ink); background:var(--cream); }
h1,h2,h3,.serif{ font-family:Georgia,"Times New Roman",serif; font-weight:400; }
.wrap{ max-width:1140px; margin:0 auto; padding:0 28px; }
.eyebrow{ display:inline-block; font-size:.74rem; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:var(--accent); margin-bottom:18px; }

/* ── SCROLL PROGRESS ── */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:200; background:#fff; mix-blend-mode:difference; transition:width .1s linear; }

/* ── HEADER ── */
header{ position:sticky; top:0; background:rgba(246,241,233,.94); backdrop-filter:blur(10px); border-bottom:1px solid var(--line); z-index:100; }
nav{ display:flex; align-items:center; justify-content:space-between; height:78px; }
.brand{ font-family:Georgia,serif; font-size:1.35rem; letter-spacing:.02em; color:var(--green); text-decoration:none; white-space:nowrap; display:inline-flex; align-items:center; }
.brand span{ color:var(--green); }
.brand img{ height:48px; width:auto; display:block; }
.nav-links{ display:flex; align-items:center; gap:4px; }
.nav-links a{ color:var(--ink); text-decoration:none; font-size:.86rem; letter-spacing:.04em; font-weight:600; padding:9px 14px; border-radius:6px; transition:color .2s; }
.nav-links a:hover{ color:var(--accent); }
.nav-links a.active:not(.nav-cta){ color:var(--accent); }
.nav-cta{ border:1.5px solid var(--ink) !important; border-radius:999px !important; padding:9px 22px !important; }
.nav-cta:hover{ background:var(--ink); color:var(--cream) !important; }

/* Mobile menu toggle */
.nav-toggle{ display:none; flex-direction:column; justify-content:center; gap:5px; width:44px; height:44px; padding:0; border:none; background:transparent; cursor:pointer; z-index:120; }
.nav-toggle span{ display:block; width:24px; height:2px; margin:0 auto; background:var(--ink); border-radius:2px; transition:transform .3s ease, opacity .2s ease; }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ── HERO ── */
.hero{ position:relative; min-height:calc(100vh - 78px); display:flex; align-items:center; padding:120px 0; text-align:center; overflow:hidden; background:var(--ink); }
.hero-bg{ position:absolute; left:0; right:0; top:-20%; bottom:-20%; z-index:0; will-change:transform; background:linear-gradient(180deg,rgba(43,42,38,.5) 0%,rgba(43,42,38,.42) 45%,rgba(43,42,38,.72) 100%),url('/assets/hero.png') center/cover no-repeat; }
.hero .wrap{ position:relative; z-index:2; width:100%; }
.hero::before{ content:''; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:680px; height:680px; max-width:120vw; border:1px solid rgba(246,241,233,.3); border-radius:50%; opacity:.6; pointer-events:none; z-index:1; }
.hero::after{ content:''; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:480px; height:480px; max-width:88vw; border:1px solid rgba(246,241,233,.3); border-radius:50%; opacity:.5; pointer-events:none; z-index:1; }
.hero-inner{ position:relative; z-index:1; max-width:760px; margin:0 auto; }
.hero .eyebrow{ color:#e9c9ad; }
.hero h1{ font-size:3.7rem; line-height:1.1; letter-spacing:-.015em; margin-bottom:26px; color:var(--cream); text-shadow:0 2px 30px rgba(0,0,0,.25); }
.hero h1 em{ font-style:italic; color:#e9c9ad; }
.hero p{ font-size:1.18rem; color:rgba(246,241,233,.9); max-width:56ch; margin:0 auto 36px; }
.hero-actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.btn-primary{ display:inline-block; background:var(--ink); color:var(--cream); text-decoration:none; font-weight:700; font-size:.92rem; letter-spacing:.04em; padding:16px 34px; border-radius:999px; transition:background .2s,transform .15s; }
.btn-primary:hover{ background:var(--accent); transform:translateY(-2px); }
.btn-ghost{ display:inline-block; border:1.5px solid var(--ink); color:var(--ink); text-decoration:none; font-weight:700; font-size:.92rem; letter-spacing:.04em; padding:14.5px 32px; border-radius:999px; transition:background .2s,color .2s; }
.btn-ghost:hover{ background:var(--ink); color:var(--cream); }
.hero .btn-primary{ background:var(--cream); color:var(--ink); }
.hero .btn-primary:hover{ background:var(--accent); color:var(--cream); }
.hero .btn-ghost{ border-color:var(--cream); color:var(--cream); }
.hero .btn-ghost:hover{ background:var(--cream); color:var(--ink); }

/* Hero scroll cue */
.hero-scroll{ position:absolute; left:50%; bottom:28px; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:12px; text-decoration:none; animation:scrollBob 3s ease-in-out infinite; transition:opacity .3s ease; }
.hero-scroll:hover{ opacity:1; }
.hero-scroll-text{ font-size:.64rem; letter-spacing:.34em; text-transform:uppercase; color:rgba(246,241,233,.72); transition:color .3s ease,letter-spacing .3s ease; }
.hero-scroll:hover .hero-scroll-text{ color:#e9c9ad; letter-spacing:.4em; }
.hero-scroll-line{ width:1px; height:58px; background:linear-gradient(180deg,rgba(246,241,233,0),rgba(246,241,233,.55)); position:relative; overflow:hidden; }
.hero-scroll-line::before{ content:''; position:absolute; left:50%; top:-20%; width:5px; height:5px; margin-left:-2.5px; border-radius:50%; background:#e9c9ad; box-shadow:0 0 10px 2px rgba(233,201,173,.7); animation:scrollDrop 2.4s cubic-bezier(.4,0,.2,1) infinite; }
.hero-scroll:hover .hero-scroll-line::before{ animation-duration:1.4s; }
.hero-scroll-line::after{ content:''; position:absolute; left:50%; bottom:-4px; width:7px; height:7px; margin-left:-4px; border-right:1px solid rgba(246,241,233,.6); border-bottom:1px solid rgba(246,241,233,.6); transform:rotate(45deg); transition:border-color .3s ease; }
.hero-scroll:hover .hero-scroll-line::after{ border-color:#e9c9ad; }
@keyframes scrollDrop{ 0%{ top:-20%; opacity:0; } 20%{ opacity:1; } 80%{ opacity:1; } 100%{ top:100%; opacity:0; } }
@keyframes scrollBob{ 0%,100%{ transform:translateX(-50%) translateY(0); } 50%{ transform:translateX(-50%) translateY(7px); } }

/* ── SECTIONS ── */
section{ padding:92px 0; }
h2{ font-size:2.5rem; line-height:1.16; letter-spacing:-.01em; }
.section-head{ max-width:640px; }
.section-head.center{ margin:0 auto; text-align:center; }
.section-head h2{ margin-bottom:16px; }
.section-head p{ color:var(--muted); font-size:1.06rem; }

/* ── VALUE PROPS ── */
.props{ position:relative; background:radial-gradient(120% 100% at 50% 0%,#34332e 0%,var(--ink) 60%); color:var(--cream); overflow:hidden; }
.props::before{ content:''; position:absolute; top:-40%; left:50%; transform:translateX(-50%); width:560px; height:560px; max-width:90vw; background:radial-gradient(circle,rgba(169,116,79,.16),transparent 70%); pointer-events:none; }
.props .wrap{ position:relative; z-index:1; }
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; padding-bottom:58px; margin-bottom:10px; border-bottom:1px solid rgba(246,241,233,.14); }
.stat{ text-align:center; }
.stat-num{ font-family:Georgia,serif; font-size:3.2rem; line-height:1; letter-spacing:-.02em; color:#e9c9ad; }
.stat-label{ margin-top:12px; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:rgba(246,241,233,.62); }
.stats-note{ text-align:center; font-size:.74rem; letter-spacing:.04em; color:rgba(246,241,233,.4); margin:18px 0 50px; }

.props-intro{ text-align:center; max-width:620px; margin:0 auto 56px; }
.props-intro .eyebrow{ color:var(--accent); }
.props-intro h2{ color:var(--cream); }
.props-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:48px; }
.prop{ text-align:center; transition:transform .3s ease; }
.prop:hover{ transform:translateY(-4px); }
.prop-num{ font-family:Georgia,serif; font-style:italic; font-size:2.4rem; color:rgba(233,201,173,.85); margin-bottom:8px; }
.prop h3{ font-size:1.5rem; margin-bottom:12px; color:var(--cream); }
.prop p{ color:rgba(246,241,233,.66); font-size:.97rem; }
.prop-divider{ width:36px; height:1px; background:var(--accent); margin:0 auto 18px; }

/* ── APPROACH ── */
.approach-head{ text-align:center; max-width:680px; margin:0 auto 64px; }
.approach-quote{ font-family:Georgia,serif; font-style:italic; font-size:1.45rem; line-height:1.5; color:var(--deep); max-width:680px; margin:0 auto 14px; text-align:center; }
.approach-cite{ text-align:center; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-bottom:64px; }
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:34px; }
.pillar{ position:relative; background:#fff; border:1px solid var(--line); border-radius:6px; padding:40px 34px; transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease; overflow:hidden; }
.pillar::before{ content:''; position:absolute; top:0; left:0; width:100%; height:3px; background:linear-gradient(90deg,var(--accent),#cFa07b); transform:scaleX(0); transform-origin:left; transition:transform .35s ease; }
.pillar:hover{ transform:translateY(-6px); box-shadow:0 24px 60px rgba(43,42,38,.12); border-color:transparent; }
.pillar:hover::before{ transform:scaleX(1); }
.pillar-mark{ font-family:Georgia,serif; font-size:2rem; color:var(--accent); margin-bottom:18px; }
.pillar h3{ font-size:1.3rem; margin-bottom:12px; }
.pillar p{ color:var(--muted); font-size:.95rem; }

/* ── SERVICES ── */
.services{ background:var(--sand); }
.svc{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.svc + .svc{ margin-top:80px; }
.svc-visual{ aspect-ratio:4/3; border-radius:6px; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; padding:24px; text-align:center; background-size:cover; background-position:center; position:relative; overflow:hidden; }
.svc-visual::after{ content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(43,42,38,.45),rgba(43,42,38,.2)); }
.svc-visual.one{ background-image:url('/assets/management.png'); }
.svc-visual.two{ background-image:url('/assets/design.png'); }
.svc-visual span{ position:relative; z-index:1; font-family:Georgia,serif; font-style:italic; font-size:1.5rem; color:#fff; line-height:1.4; text-shadow:0 2px 14px rgba(0,0,0,.4); }
.svc-body .eyebrow{ margin-bottom:14px; }
.svc-body h2{ font-size:2.1rem; margin-bottom:16px; }
.svc-body > p{ color:var(--muted); margin-bottom:24px; }
.svc-list{ list-style:none; margin-bottom:30px; }
.svc-list li{ position:relative; padding-left:28px; padding-bottom:12px; font-size:.97rem; }
.svc-list li::before{ content:''; position:absolute; left:0; top:11px; width:14px; height:1px; background:var(--accent); }
.text-link{ display:inline-flex; align-items:center; gap:8px; color:var(--ink); text-decoration:none; font-weight:700; font-size:.86rem; letter-spacing:.06em; text-transform:uppercase; border-bottom:1.5px solid var(--accent); padding-bottom:4px; transition:gap .15s; }
.text-link:hover{ gap:14px; }

/* ── CTA BAND ── */
.cta-band{ position:relative; background:linear-gradient(rgba(58,71,64,.86),rgba(58,71,64,.9)),url('/assets/feature.png') center/cover fixed no-repeat; color:var(--cream); text-align:center; }
.cta-band h2{ font-size:2.6rem; color:var(--cream); max-width:18ch; margin:0 auto 18px; }
.cta-band p{ color:rgba(246,241,233,.72); max-width:54ch; margin:0 auto 34px; font-size:1.06rem; }
.cta-band .btn-primary{ background:var(--cream); color:var(--ink); }
.cta-band .btn-primary:hover{ background:var(--accent); color:var(--cream); }

/* ── FAQ ── */
.faq-list{ max-width:780px; margin:48px auto 0; }
details.faq{ border-bottom:1px solid var(--line); padding:8px 0; }
details.faq summary{ list-style:none; cursor:pointer; padding:22px 4px; font-family:Georgia,serif; font-size:1.22rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:20px; }
details.faq summary::-webkit-details-marker{ display:none; }
details.faq summary::after{ content:'+'; font-family:Georgia,serif; font-size:1.5rem; color:var(--accent); transition:transform .2s; flex-shrink:0; }
details.faq[open] summary::after{ transform:rotate(45deg); }
details.faq p{ color:var(--muted); padding:0 4px 24px; font-size:.99rem; max-width:64ch; }

/* ── CONTACT ── */
.contact{ position:relative; background:linear-gradient(rgba(43,42,38,.9),rgba(43,42,38,.93)),url('/assets/contact-alt9.png') center/cover fixed no-repeat; color:var(--cream); }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.contact-info .eyebrow{ color:var(--accent); }
.contact-info h2{ color:var(--cream); margin-bottom:18px; }
.contact-info > p{ color:rgba(246,241,233,.66); margin-bottom:36px; max-width:42ch; }
.contact-detail{ padding:20px 0; border-top:1px solid rgba(246,241,233,.14); }
.contact-detail:last-child{ border-bottom:1px solid rgba(246,241,233,.14); }
.contact-detail .label{ font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); margin-bottom:6px; }
.contact-detail a, .contact-detail span{ color:var(--cream); text-decoration:none; font-size:1.06rem; }
.contact-detail a:hover{ color:var(--accent); }

.form-card{ background:var(--cream); border-radius:6px; padding:42px 38px; color:var(--ink); }
.form-card h3{ font-size:1.5rem; margin-bottom:6px; }
.form-card > p{ color:var(--muted); font-size:.92rem; margin-bottom:26px; }
.form-group{ margin-bottom:18px; }
.form-group label{ display:block; font-size:.74rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
.form-group input, .form-group select, .form-group textarea{
  width:100%; padding:13px 16px; border:1px solid var(--line); border-radius:4px;
  font:inherit; font-size:.96rem; color:var(--ink); background:#fff; outline:none; transition:border-color .2s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{ border-color:var(--accent); }
.form-group textarea{ height:108px; resize:vertical; }
.btn-submit{ width:100%; background:var(--ink); color:var(--cream); border:none; font:inherit; font-weight:700; letter-spacing:.04em; font-size:.95rem; padding:16px; border-radius:999px; cursor:pointer; transition:background .2s; }
.btn-submit:hover{ background:var(--accent); }
.form-note{ font-size:.78rem; color:var(--muted); text-align:center; margin-top:12px; }
.thankyou{ display:none; text-align:center; padding:30px 0; }
.thankyou .check{ font-family:Georgia,serif; font-size:2.4rem; color:var(--accent); margin-bottom:10px; }
.thankyou h4{ font-family:Georgia,serif; font-size:1.4rem; margin-bottom:8px; }
.thankyou p{ color:var(--muted); font-size:.94rem; }

/* ── PROPERTIES (embed) ── */
.properties-intro{ background:linear-gradient(180deg,var(--cream) 0%,var(--sand) 100%); text-align:center; padding:80px 0 56px; }
.properties-intro .hero-inner{ max-width:720px; margin:0 auto; }
.properties-intro h1{ font-family:Georgia,serif; font-weight:400; font-size:2.9rem; line-height:1.15; margin-bottom:18px; }
.properties-intro p{ font-size:1.1rem; color:var(--muted); max-width:54ch; margin:0 auto; }
.embed-section{ padding:0; background:var(--sand); }
.embed-frame{ width:100%; height:calc(100vh - 78px); border:0; background:#fff; display:block; }
.embed-fallback{ text-align:center; padding:26px 16px; }
.embed-fallback p{ color:var(--muted); font-size:.95rem; margin-bottom:14px; }

/* ── FOOTER ── */
footer{ background:#ffffff; color:var(--muted); font-size:.9rem; padding:64px 0 28px; border-top:1px solid var(--line); }
.footer-inner{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:48px; margin-bottom:44px; }
.footer-brand .brand{ color:var(--green); }
.footer-brand .brand span{ color:var(--accent); }
.footer-brand .brand img{ filter:none; opacity:1; }
.footer-brand p{ margin-top:16px; line-height:1.7; max-width:38ch; }
.footer-col h4{ font-family:Georgia,serif; color:var(--deep); font-size:1.05rem; font-weight:400; margin-bottom:16px; }
.footer-col ul{ list-style:none; }
.footer-col ul li{ margin-bottom:10px; }
.footer-col ul li a{ color:var(--muted); text-decoration:none; transition:color .15s; }
.footer-col ul li a:hover{ color:var(--accent); }
.footer-bottom{ border-top:1px solid var(--line); padding-top:24px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; font-size:.82rem; letter-spacing:.02em; }

/* ── ANIMATIONS ── */
/* Hero entrance */
@keyframes riseIn{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:translateY(0); } }
@keyframes ringPulse{ 0%{ transform:translate(-50%,-50%) scale(1); opacity:.6; } 50%{ transform:translate(-50%,-50%) scale(1.04); opacity:.35; } 100%{ transform:translate(-50%,-50%) scale(1); opacity:.6; } }
.hero::before{ animation:ringPulse 9s ease-in-out infinite; }
.hero::after{ animation:ringPulse 9s ease-in-out infinite .6s; }
.hero-inner > *{ opacity:0; animation:riseIn .9s cubic-bezier(.22,.61,.36,1) forwards; }
.hero-inner > .eyebrow{ animation-delay:.05s; }
.hero-inner > h1{ animation-delay:.18s; }
.hero-inner > p{ animation-delay:.32s; }
.hero-inner > .hero-actions{ animation-delay:.46s; }
.properties-intro .hero-inner > *{ opacity:0; animation:riseIn .9s cubic-bezier(.22,.61,.36,1) forwards; }
.properties-intro .hero-inner > .eyebrow{ animation-delay:.05s; }
.properties-intro .hero-inner > h1{ animation-delay:.18s; }
.properties-intro .hero-inner > p{ animation-delay:.32s; }

/* Scroll reveal */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1); will-change:opacity,transform; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }
.reveal.delay-1{ transition-delay:.1s; }
.reveal.delay-2{ transition-delay:.2s; }
.reveal.delay-3{ transition-delay:.3s; }
.reveal.from-left{ transform:translateX(-44px); }
.reveal.from-right{ transform:translateX(44px); }
.reveal.from-left.is-visible, .reveal.from-right.is-visible{ transform:translateX(0); }

/* Animated underline accent on quote citation + eyebrow ticks */
.prop-divider{ transition:width .6s ease .15s; }
.reveal .prop-divider{ width:0; }
.reveal.is-visible .prop-divider{ width:36px; }

/* Button shine */
.btn-primary{ position:relative; overflow:hidden; }
.btn-primary::after{ content:''; position:absolute; top:0; left:-120%; width:60%; height:100%; background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent); transform:skewX(-20deg); transition:left .6s ease; }
.btn-primary:hover::after{ left:140%; }

/* Service visual subtle float on hover */
.svc-visual{ transition:transform .4s ease, box-shadow .4s ease; }
.svc-visual:hover{ transform:translateY(-6px); box-shadow:0 22px 50px rgba(43,42,38,.18); }

@media(prefers-reduced-motion:reduce){
  .hero::before, .hero::after,
  .hero-inner > *, .properties-intro .hero-inner > *{ animation:none !important; opacity:1 !important; }
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
  .reveal .prop-divider{ width:36px; }
  .btn-primary::after{ display:none; }
  .hero-scroll, .hero-scroll-line::before, .pillar::before{ animation:none !important; }
  html{ scroll-behavior:auto; }
}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  section{ padding:68px 0; }
  .hero{ padding:84px 0 76px; }
  .hero h1{ font-size:2.5rem; }
  .properties-intro h1{ font-size:2.2rem; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:36px 24px; }
  .stat-num{ font-size:2.7rem; }
  .props-grid{ grid-template-columns:1fr; gap:40px; }
  .pillars{ grid-template-columns:1fr; }
  .svc{ grid-template-columns:1fr; gap:32px; }
  .svc.flip .svc-visual{ order:-1; }
  .contact-grid{ grid-template-columns:1fr; gap:44px; }
  .footer-inner{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
  h2{ font-size:2.1rem; }
  .cta-band h2{ font-size:2.1rem; }
}
@media(max-width:1024px){
  .nav-toggle{ display:flex; }
  .nav-links{
    position:fixed; top:78px; left:0; right:0; flex-direction:column; align-items:stretch; gap:0;
    background:rgba(246,241,233,.98); backdrop-filter:blur(10px); border-bottom:1px solid var(--line);
    padding:12px 22px 26px; transform:translateY(-12px); opacity:0; pointer-events:none;
    transition:opacity .25s ease, transform .25s ease; box-shadow:0 20px 40px rgba(43,42,38,.1);
  }
  .nav-links.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav-links a{ padding:15px 6px; font-size:1rem; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-links a:last-child{ border-bottom:none; }
  .nav-cta{ margin-top:14px; text-align:center; }
}
@media(max-width:600px){
  .wrap{ padding:0 20px; }
  .hero h1{ font-size:2.05rem; }
  .hero p{ font-size:1.05rem; }
  .hero-actions{ flex-direction:column; align-items:stretch; }
  .hero-actions a{ text-align:center; }
  .svc-body h2{ font-size:1.8rem; }
  .form-card{ padding:30px 24px; }
  .form-card h3{ font-size:1.35rem; }
  .contact-detail a, .contact-detail span{ font-size:.98rem; word-break:break-word; }
  .footer-inner{ grid-template-columns:1fr; gap:32px; }
  .footer-bottom{ flex-direction:column; align-items:center; text-align:center; gap:6px; }
  .approach-quote{ font-size:1.2rem; }
  details.faq summary{ font-size:1.08rem; }
}
@media(max-width:400px){
  .wrap{ padding:0 16px; }
  .brand{ font-size:1.2rem; }
  .hero h1{ font-size:1.78rem; }
  .stats{ grid-template-columns:1fr 1fr; gap:28px 16px; }
  .stat-num{ font-size:2.3rem; }
  h2{ font-size:1.85rem; }
  .cta-band h2{ font-size:1.85rem; }
  .form-card{ padding:26px 18px; }
  .pillar{ padding:32px 24px; }
}
