/*
Theme Name: ClinicCPA
Theme URI: https://cliniccpa.com
Author: JonesCosman
Description: Custom theme for ClinicCPA — accounting for physiotherapists, massage therapists, and clinics across Canada. Warm clinical aesthetic, built for SEO and answer-engine optimization.
Version: 1.0
Tested up to: 6.8
Requires PHP: 8.0
Text Domain: cliniccpa
*/

:root{
  --ink:#33302a;--forest:#284b3e;--forest-2:#37624f;--sage:#7f9d8c;--sage-soft:#cdd9cd;
  --cream:#f4ece0;--cream-2:#faf3e8;--paper:#fffdf8;--clay:#cf7d54;--clay-soft:#ecc3ac;--gold:#c5a253;
  --blush:#dca28c;--petal:#f1ddd2;--rose-deep:#b06b58;
  --maxw:1180px;--r:18px;--rd:18px;
  --shadow:0 24px 60px -28px rgba(30,61,50,.45);--shadow-sm:0 10px 28px -16px rgba(30,61,50,.4);
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--cream);color:var(--ink);line-height:1.68;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:740px;margin:0 auto;padding:0 28px}
h1,h2,h3{font-family:'Fraunces',serif;font-weight:600;line-height:1.06;letter-spacing:-.01em}
.serif-it{font-style:italic;font-weight:500}
.eyebrow{font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--clay);display:inline-block}

/* header */
.site-header{position:sticky;top:0;z-index:100;transition:.4s var(--ease)}
.site-header.scrolled{background:rgba(244,239,227,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(30,61,50,.1)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;max-width:var(--maxw);margin:0 auto}
.logo{display:flex;align-items:center;gap:11px;font-family:'Fraunces',serif;font-weight:600;font-size:1.32rem;letter-spacing:-.02em;color:var(--forest)}
.mark{width:34px;height:34px;border-radius:10px;background:var(--forest);position:relative;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.mark::before,.mark::after{content:"";position:absolute;background:var(--clay-soft);border-radius:2px}
.mark::before{width:14px;height:3.4px;top:50%;left:50%;transform:translate(-50%,-50%)}
.mark::after{width:3.4px;height:14px;top:50%;left:50%;transform:translate(-50%,-50%)}
.logo b{color:var(--clay);font-weight:600}
.main-nav ul{display:flex;gap:30px;list-style:none;align-items:center}
.main-nav a{font-size:.93rem;font-weight:500;color:var(--ink);opacity:.78;transition:.2s}
.main-nav a:hover{opacity:1;color:var(--forest)}
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.95rem;background:var(--forest);color:var(--cream-2);padding:13px 22px;border-radius:100px;transition:.25s var(--ease);border:1px solid var(--forest);cursor:pointer}
.btn:hover{background:var(--forest-2);transform:translateY(-2px);box-shadow:var(--shadow-sm);color:var(--cream-2)}
.btn.ghost{background:transparent;color:var(--forest);border-color:rgba(30,61,50,.28)}
.btn.ghost:hover{background:var(--forest);color:var(--cream-2)}
.btn.clay{background:var(--clay);border-color:var(--clay)}
.btn.clay:hover{background:#bd6a44}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2.4px;background:var(--forest);border-radius:2px;transition:.3s}
.mobile-menu{position:fixed;inset:0;z-index:200;background:var(--forest);color:var(--cream-2);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:28px;transform:translateY(-100%);transition:.45s var(--ease)}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:'Fraunces',serif;font-size:1.8rem;color:var(--cream-2)}
.mobile-menu .close{position:absolute;top:24px;right:26px;font-size:2rem;background:none;border:0;color:var(--cream-2);cursor:pointer}

/* hero */
.hero{position:relative;padding:70px 0 90px;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(8px);z-index:0;opacity:.5}
.blob.b1{width:520px;height:520px;background:radial-gradient(circle at 30% 30%,var(--sage-soft),transparent 70%);top:-120px;right:-120px}
.blob.b2{width:420px;height:420px;background:radial-gradient(circle at 50% 50%,var(--clay-soft),transparent 70%);bottom:-160px;left:-140px;opacity:.35}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center;position:relative;z-index:2}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.15rem);margin:22px 0 0}
.hero h1 .u{position:relative;white-space:nowrap}
.hero h1 .u::after{content:"";position:absolute;left:-2%;bottom:.07em;width:104%;height:.34em;background:var(--clay-soft);z-index:-1;border-radius:4px;opacity:.85}
.lede{font-size:1.16rem;color:#46493f;max-width:36ch;margin:24px 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.trust{margin-top:30px;font-size:.86rem;color:#5d6056;display:flex;align-items:flex-start;gap:14px;max-width:40ch}
.trust .dot{width:7px;height:7px;border-radius:50%;background:var(--clay);flex:0 0 auto;margin-top:7px;box-shadow:0 0 0 4px rgba(206,122,82,.18)}
.portrait-stack{position:relative}
.portrait{position:relative;border-radius:26px;overflow:hidden;aspect-ratio:4/5;background:linear-gradient(160deg,var(--forest) 0%,var(--forest-2) 60%,#3d6e58 100%);box-shadow:var(--shadow);border:6px solid var(--paper);display:flex;flex-direction:column;justify-content:flex-end}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.portrait .mono{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:5rem;color:rgba(232,183,149,.5)}
.portrait .namecard{position:relative;z-index:2;margin:0;padding:20px 22px;background:linear-gradient(to top,rgba(20,38,30,.92),transparent);color:var(--cream-2)}
.portrait .namecard strong{font-family:'Fraunces',serif;font-size:1.3rem;display:block;font-weight:600}
.portrait .namecard span{font-size:.86rem;opacity:.82}
.float-card{position:absolute;left:-34px;bottom:54px;z-index:3;background:var(--paper);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);width:226px;border:1px solid rgba(30,61,50,.08);animation:bob 5s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.float-card .fc-top{display:flex;align-items:center;gap:9px;font-family:'DM Mono',monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--clay);margin-bottom:9px}
.float-card .fc-top span{width:8px;height:8px;border-radius:50%;background:var(--clay)}
.float-card .fc-row{display:flex;justify-content:space-between;font-size:.9rem;padding:5px 0;border-bottom:1px dashed rgba(30,61,50,.16)}
.float-card .fc-row:last-child{border:0;font-weight:700;color:var(--forest)}

.strip{border-top:1px solid rgba(30,61,50,.12);border-bottom:1px solid rgba(30,61,50,.12);background:var(--cream-2)}
.strip-in{display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;padding:20px 28px;font-family:'DM Mono',monospace;font-size:.78rem;letter-spacing:.08em;color:#5d6056;text-transform:uppercase}
.strip-in b{color:var(--forest);font-weight:500}
.strip-in .sep{width:5px;height:5px;border-radius:50%;background:var(--sage)}

.sec{padding:96px 0;position:relative}
.sec-head{max-width:60ch}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);margin:18px 0 0}
.sec-head p{color:#50534a;font-size:1.08rem;margin-top:16px;max-width:52ch}

.hst{background:var(--forest);color:var(--cream-2)}
.hst .eyebrow{color:var(--clay-soft)}.hst .eyebrow::before{background:var(--clay-soft)}
.hst h2{color:var(--cream-2)}.hst .sec-head p{color:rgba(244,239,227,.78)}
.split{display:grid;grid-template-columns:1fr auto 1fr;gap:0;margin-top:54px;align-items:stretch}
.pane{padding:40px 38px;position:relative}
.pane h3{font-size:1.7rem;display:flex;align-items:center;gap:12px}
.pane .tag{font-family:'DM Mono',monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border-radius:100px;display:inline-block;margin-bottom:18px}
.pane.exempt .tag{background:rgba(200,215,204,.2);color:var(--sage-soft);border:1px solid rgba(200,215,204,.35)}
.pane.taxed .tag{background:rgba(232,183,149,.16);color:var(--clay-soft);border:1px solid rgba(232,183,149,.4)}
.pane ul{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:15px}
.pane li{display:flex;gap:13px;font-size:1.02rem;color:rgba(244,239,227,.9)}
.pane li .ic{flex:0 0 auto;width:24px;height:24px;border-radius:7px;display:grid;place-items:center;font-size:.8rem;font-weight:700;margin-top:2px}
.pane.exempt li .ic{background:rgba(200,215,204,.18);color:var(--sage-soft)}
.pane.taxed li .ic{background:rgba(232,183,149,.18);color:var(--clay-soft)}
.divider{width:1px;background:linear-gradient(to bottom,transparent,rgba(244,239,227,.28),transparent);position:relative}
.divider .vs{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--clay);color:#fff;font-family:'Fraunces',serif;font-style:italic;font-weight:600;width:50px;height:50px;border-radius:50%;display:grid;place-items:center;font-size:1.05rem;box-shadow:0 8px 20px -8px rgba(0,0,0,.5)}
.hst-foot{margin-top:46px;text-align:center;font-family:'Fraunces',serif;font-size:1.5rem;font-style:italic;color:var(--cream-2);max-width:30ch;margin-left:auto;margin-right:auto;line-height:1.3}
.hst-foot b{color:var(--clay-soft);font-style:normal}

.chips{display:flex;flex-wrap:wrap;gap:13px;margin-top:40px}
.chip{background:var(--paper);border:1px solid rgba(30,61,50,.14);padding:13px 22px;border-radius:100px;font-weight:600;font-size:1rem;color:var(--forest);display:flex;align-items:center;gap:10px;transition:.25s var(--ease)}
.chip:hover{background:var(--forest);color:var(--cream-2);transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.chip .b{width:9px;height:9px;border-radius:50%;background:var(--clay)}
.chip.more{background:transparent;border-style:dashed;color:#6b6e63}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.card{background:var(--paper);border-radius:var(--r);padding:32px 28px;border:1px solid rgba(30,61,50,.1);transition:.3s var(--ease);position:relative;overflow:hidden}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .num{font-family:'DM Mono',monospace;font-size:.78rem;color:var(--clay);letter-spacing:.1em}
.card h3{font-size:1.32rem;margin:16px 0 10px}
.card p{color:#54574d;font-size:.98rem}
.card .ic-box{width:46px;height:46px;border-radius:12px;background:var(--sage-soft);display:grid;place-items:center;margin-bottom:6px;font-size:1.3rem}
.card:nth-child(2) .ic-box{background:var(--clay-soft)}
.card:nth-child(3) .ic-box{background:#dfe7d3}
.card:nth-child(5) .ic-box{background:var(--clay-soft)}

.alt-bg{background:var(--cream-2)}
.marsha-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:56px;align-items:center}
.m-portrait{aspect-ratio:1/1;border-radius:24px;background:linear-gradient(150deg,var(--clay) 0%,#b5673f 100%);position:relative;overflow:hidden;box-shadow:var(--shadow);border:6px solid var(--paper)}
.m-portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.m-portrait .mono{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:5rem;color:rgba(255,255,255,.6)}
.marsha-copy h2{font-size:clamp(2rem,3.6vw,2.8rem);margin:16px 0 0}
.marsha-copy .quote{font-family:'Fraunces',serif;font-style:italic;font-size:1.45rem;line-height:1.4;color:var(--forest);margin:22px 0 24px}
.marsha-copy p{color:#50534a;font-size:1.04rem;margin-bottom:16px;max-width:52ch}
.sign{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--clay);font-style:italic;margin-top:6px}

.magnet .inner{background:var(--forest);border-radius:28px;padding:60px;color:var(--cream-2);position:relative;overflow:hidden;display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:center;box-shadow:var(--shadow)}
.magnet .blob3{position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(206,122,82,.5),transparent 70%);top:-120px;right:-80px}
.magnet .eyebrow{color:var(--clay-soft);position:relative;z-index:2}.magnet .eyebrow::before{background:var(--clay-soft)}
.magnet h2{font-size:clamp(1.8rem,3.2vw,2.5rem);color:var(--cream-2);margin:16px 0 14px;position:relative;z-index:2}
.magnet p{color:rgba(244,239,227,.8);position:relative;z-index:2;max-width:44ch}
.magnet .m-cta{position:relative;z-index:2;margin-top:26px}
.sheet-mock{position:relative;z-index:2;background:var(--paper);border-radius:14px;padding:16px;box-shadow:var(--shadow);transform:rotate(2.5deg)}
.sheet-mock .row{height:11px;background:var(--sage-soft);border-radius:4px;margin:7px 0}
.sheet-mock .row.s{width:60%}.sheet-mock .row.t{background:var(--clay-soft);width:80%}
.sheet-mock .hd{display:flex;gap:6px;margin-bottom:12px}
.sheet-mock .hd i{width:9px;height:9px;border-radius:50%;background:var(--clay);display:block;opacity:.6}

/* faq (shared) */
.faq-grid{margin-top:48px;max-width:820px}
.faq{margin:14px 0}
.faq-item{border-bottom:1px solid rgba(30,61,50,.16)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:22px 0;display:flex;justify-content:space-between;align-items:center;gap:18px;font-family:'Fraunces',serif;font-size:1.18rem;font-weight:600;color:var(--ink)}
.faq-q .pm{flex:0 0 auto;width:29px;height:29px;border-radius:50%;border:1.5px solid var(--clay);position:relative;transition:.3s}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--clay);top:50%;left:50%;transform:translate(-50%,-50%);border-radius:2px}
.faq-q .pm::before{width:12px;height:2px}.faq-q .pm::after{width:2px;height:12px;transition:.3s}
.faq-item.open .pm{background:var(--clay)}
.faq-item.open .pm::before,.faq-item.open .pm::after{background:#fff}
.faq-item.open .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{padding:0 44px 24px 0;color:#50534a;font-size:1.03rem;margin:0}

.final{text-align:center;padding:104px 0}
.final h2{font-size:clamp(2.2rem,4.6vw,3.6rem);max-width:18ch;margin:18px auto 0}
.final p{color:#50534a;font-size:1.1rem;margin:20px auto 34px;max-width:46ch}
.final .hero-cta{justify-content:center}

/* article */
.a-hero{padding:54px 0 30px;position:relative;overflow:hidden}
.a-hero .blob{width:460px;height:460px;background:radial-gradient(circle at 30% 30%,var(--sage-soft),transparent 70%);top:-160px;right:-120px;opacity:.4}
.crumbs{font-family:'DM Mono',monospace;font-size:.76rem;letter-spacing:.06em;color:#6b6e63;margin-bottom:22px;position:relative;z-index:2}
.crumbs a:hover{color:var(--forest)}
.a-hero h1{font-size:clamp(2.1rem,4.6vw,3.3rem);margin:18px 0 0;position:relative;z-index:2;max-width:18ch}
.a-meta{display:flex;align-items:center;gap:16px;margin-top:26px;font-size:.9rem;color:#5d6056;position:relative;z-index:2;flex-wrap:wrap}
.a-meta .who{display:flex;align-items:center;gap:10px}
.a-meta .av{width:38px;height:38px;border-radius:50%;background:linear-gradient(150deg,var(--clay),#b5673f);display:grid;place-items:center;color:#fff;font-family:'Fraunces',serif;font-weight:600}
.a-meta .sep{width:4px;height:4px;border-radius:50%;background:var(--sage)}
.article-body{padding:0 0 30px}
.article-body p{font-size:1.09rem;margin:0 0 22px;color:#36382f}
.article-body h2{font-size:1.7rem;margin:46px 0 16px}
.article-body h3{font-size:1.28rem;margin:34px 0 12px}
.article-body ul,.article-body ol{margin:0 0 24px;padding-left:0;list-style:none}
.article-body li{font-size:1.07rem;color:#36382f;padding:9px 0 9px 34px;position:relative}
.article-body ul li::before{content:"";position:absolute;left:4px;top:18px;width:10px;height:10px;border-radius:50%;background:var(--clay-soft);border:2px solid var(--clay)}
.article-body ol{counter-reset:n}
.article-body ol li::before{content:counter(n);counter-increment:n;background:var(--forest);border:0;color:var(--cream-2);width:22px;height:22px;border-radius:50%;font-family:'DM Mono',monospace;font-size:.72rem;display:grid;place-items:center;position:absolute;left:0;top:12px}
.article-body strong{color:var(--ink);font-weight:700}
.article-body a{color:var(--forest-2);text-decoration:underline;text-decoration-color:var(--clay-soft);text-underline-offset:3px}
.tldr{background:var(--forest);color:var(--cream-2);border-radius:var(--rd);padding:28px 30px;margin:14px 0 40px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.tldr .lab{font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--clay-soft);margin-bottom:10px;display:block}
.tldr p{font-size:1.16rem;font-family:'Fraunces',serif;font-weight:500;line-height:1.45;margin:0;color:var(--cream-2)}
.callout{border-left:3px solid var(--clay);background:var(--cream-2);padding:20px 24px;border-radius:0 12px 12px 0;margin:30px 0;font-size:1.05rem}
.callout b{color:var(--forest)}
.mini{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:34px 0}
.mini .m{background:var(--paper);border:1px solid rgba(30,61,50,.12);border-radius:14px;padding:22px}
.mini .m .t{font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border-radius:100px;display:inline-block;margin-bottom:12px}
.mini .m.ex .t{background:var(--sage-soft);color:var(--forest)}
.mini .m.tx .t{background:var(--clay-soft);color:#9a4e2a}
.mini .m h3{margin:0 0 8px;font-size:1.18rem}
.mini .m p{font-size:.98rem;margin:0;color:#54574d}
.ex-box{background:var(--paper);border:1px dashed rgba(30,61,50,.28);border-radius:14px;padding:26px 28px;margin:32px 0}
.ex-box .lab{font-family:'DM Mono',monospace;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay);margin-bottom:14px;display:block}
.ex-box .line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed rgba(30,61,50,.16);font-size:1.02rem}
.ex-box .line:last-child{border:0;font-weight:700;color:var(--forest);font-size:1.1rem}
.disc{font-size:.86rem;color:#7a7d72;font-style:italic;border-top:1px solid rgba(30,61,50,.14);margin-top:40px;padding-top:22px}
.cta{margin:60px 0 0}
.cta .inner{background:var(--forest);border-radius:24px;padding:48px;text-align:center;color:var(--cream-2);position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cta .b3{position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(206,122,82,.45),transparent 70%);top:-120px;left:-60px}
.cta h2{color:var(--cream-2);font-size:1.9rem;position:relative;z-index:2;max-width:20ch;margin:0 auto 14px}
.cta p{color:rgba(244,239,227,.8);position:relative;z-index:2;max-width:42ch;margin:0 auto 26px}
.cta .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:2}
.related{padding:70px 0;background:var(--cream-2);margin-top:70px;border-top:1px solid rgba(30,61,50,.1)}
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.rel{background:var(--paper);border:1px solid rgba(30,61,50,.1);border-radius:14px;padding:24px;transition:.3s var(--ease)}
.rel:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.rel .k{font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clay)}
.rel h3{font-size:1.18rem;margin:10px 0 0;color:var(--ink)}

/* blog index */
.blog-hero{padding:64px 0 10px}
.blog-hero h1{font-size:clamp(2.2rem,4.4vw,3.2rem);margin:16px 0 0;max-width:20ch}
.blog-hero p{color:#50534a;font-size:1.1rem;margin-top:16px;max-width:54ch}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:50px 0 96px}
.post-card{background:var(--paper);border:1px solid rgba(30,61,50,.1);border-radius:var(--r);padding:30px 28px;transition:.3s var(--ease);display:flex;flex-direction:column;gap:12px}
.post-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.post-card .k{font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clay)}
.post-card h2{font-size:1.34rem;line-height:1.18}
.post-card .ex{color:#54574d;font-size:.98rem;flex:1}
.post-card .more{font-weight:600;color:var(--forest);font-size:.92rem}

/* footer */
.site-footer{background:var(--ink);color:#c9c8c0;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.site-footer .logo{color:var(--cream-2)}.site-footer .logo b{color:var(--clay-soft)}
.site-footer p{font-size:.94rem;color:#9b9a92;margin-top:16px;max-width:36ch}
.site-footer h4{font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-soft);margin-bottom:16px;font-weight:500}
.site-footer ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.site-footer ul a{font-size:.95rem;color:#c9c8c0;opacity:.85;transition:.2s}
.site-footer ul a:hover{opacity:1;color:var(--clay-soft)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:26px;font-size:.84rem;color:#86857d}
.foot-bottom .group{font-family:'DM Mono',monospace;letter-spacing:.04em}
.foot-bottom .group a{color:var(--clay-soft)}

.reveal{opacity:0;transform:translateY(28px);transition:.7s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media(max-width:920px){
  .main-nav,.nav-cta .btn{display:none}
  .burger{display:flex}
  .hero-grid,.marsha-grid,.magnet .inner{grid-template-columns:1fr;gap:40px}
  .portrait-stack{max-width:420px;margin:0 auto}
  .split{grid-template-columns:1fr}
  .divider{height:1px;width:auto;background:linear-gradient(to right,transparent,rgba(244,239,227,.28),transparent);margin:8px 0}
  .divider .vs{position:relative;top:0;left:0;transform:none;margin:0 auto}
  .svc-grid,.post-grid{grid-template-columns:1fr 1fr}
  .foot-grid,.rel-grid{grid-template-columns:1fr 1fr}
  .magnet .inner{padding:40px}
  .mini{grid-template-columns:1fr}
}
@media(max-width:560px){
  .wrap,.narrow{padding:0 20px}
  .nav{padding:16px 20px}
  .sec{padding:70px 0}
  .svc-grid,.foot-grid,.rel-grid,.post-grid{grid-template-columns:1fr}
  .float-card{left:0;bottom:14px}
  .hero h1 .u{white-space:normal}
  .cta .inner{padding:34px 24px}
}

/* logo */
.brand-logo img{height:60px;width:auto;display:block}
@media(max-width:560px){.brand-logo img{height:48px}}
.foot-logo{display:flex;align-items:center;gap:9px;font-family:'Fraunces',serif;font-size:1.4rem;font-weight:600;letter-spacing:.02em}
.foot-logo img{height:26px;width:auto}
.foot-logo .c1{color:var(--cream-2)}.foot-logo .c2{color:var(--blush)}
.sprout-divider{display:block;margin:0 auto 6px;width:38px;height:auto;opacity:.9}

/* contact form */
.contact-wrap{padding:56px 0 96px}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.contact-intro h1{font-size:clamp(2rem,4vw,2.9rem);margin:16px 0 0}
.contact-intro p{color:#50534a;font-size:1.08rem;margin-top:16px;max-width:42ch}
.contact-points{list-style:none;margin:28px 0 0;display:flex;flex-direction:column;gap:14px}
.contact-points li{display:flex;gap:12px;align-items:flex-start;font-size:1.02rem;color:#3c3f36}
.contact-points li::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--clay);margin-top:8px;flex:0 0 auto}
.cform{background:var(--paper);border:1px solid rgba(30,61,50,.12);border-radius:var(--r);padding:34px;box-shadow:var(--shadow-sm)}
.cform label{display:block;font-weight:600;font-size:.9rem;color:var(--forest);margin:0 0 7px}
.cform .fld{margin-bottom:18px}
.cform input,.cform select,.cform textarea{width:100%;padding:13px 15px;border:1px solid rgba(30,61,50,.22);border-radius:11px;background:var(--cream-2);font-family:inherit;font-size:1rem;color:var(--ink);transition:.2s}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 3px rgba(206,122,82,.16);background:#fff}
.cform textarea{min-height:130px;resize:vertical}
.cform .hp{position:absolute;left:-9999px}
.cform button{width:100%;margin-top:6px}
.form-note{font-size:.82rem;color:#7a7d72;margin-top:14px;text-align:center}
.form-alert{padding:16px 20px;border-radius:12px;margin-bottom:24px;font-size:1rem}
.form-alert.ok{background:#dfe9dc;color:#27543f;border:1px solid #b9d0bd}
.form-alert.err{background:#f6ddd2;color:#9a4221;border:1px solid #e8bda8}

/* legal / generic page */
.page-hero{padding:60px 0 8px}
.page-hero h1{font-size:clamp(2rem,4vw,2.9rem);max-width:22ch}
.page-body{padding:24px 0 90px}
.page-body h2{font-size:1.5rem;margin:38px 0 12px}
.page-body h3{font-size:1.2rem;margin:26px 0 10px}
.page-body p,.page-body li{font-size:1.04rem;color:#3c3f36;margin:0 0 16px}
.page-body ul{margin:0 0 20px;padding-left:22px}
.page-body li{margin-bottom:8px}
.page-body a{color:var(--forest-2);text-decoration:underline;text-decoration-color:var(--clay-soft)}
.page-body .updated{font-family:'DM Mono',monospace;font-size:.8rem;color:#7a7d72;letter-spacing:.04em}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:36px}}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px;align-items:stretch}
.price-card{background:var(--paper);border:1px solid rgba(30,61,50,.12);border-radius:var(--r);padding:30px 24px;display:flex;flex-direction:column;position:relative;transition:.3s var(--ease)}
.price-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.price-card.featured{border-color:var(--clay);border-width:2px;box-shadow:var(--shadow);background:var(--cream-2)}
.pc-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--clay);color:#fff;font-family:'DM Mono',monospace;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;padding:6px 14px;border-radius:100px;white-space:nowrap}
.pc-name{font-family:'DM Mono',monospace;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay)}
.pc-price{font-family:'Fraunces',serif;font-size:2.35rem;font-weight:600;color:var(--forest);line-height:1.1;margin:10px 0 2px}
.pc-for{color:#54574d;font-size:.98rem;font-weight:600;margin-bottom:18px;display:block}
.price-card ul{list-style:none;margin:0 0 24px;display:flex;flex-direction:column;gap:11px;flex:1}
.price-card li{position:relative;padding-left:26px;font-size:.97rem;color:#3c3f36}
.price-card li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:12px;border-radius:50%;background:var(--sage-soft);border:2px solid var(--sage)}
.price-card .btn{width:100%;justify-content:center}
.price-addon{text-align:center;margin-top:32px;font-size:1.04rem;color:#50534a}
.price-addon b{color:var(--forest)}
@media(max-width:1000px){.price-grid{grid-template-columns:repeat(2,1fr);gap:20px}}
@media(max-width:520px){.price-grid{grid-template-columns:1fr}}

/* lead form (on dark magnet bg) */
.lead-form{margin-top:24px;position:relative;z-index:2;max-width:430px}
.lead-form .hp{position:absolute;left:-9999px}
.lf-row{display:flex;gap:10px;margin-bottom:12px}
.lf-row input{flex:1;min-width:0}
.lead-form input[type=text],.lead-form input[type=email]{width:100%;padding:13px 15px;border-radius:11px;border:1px solid rgba(244,239,227,.3);background:rgba(255,255,255,.96);font-family:inherit;font-size:1rem;color:var(--ink)}
.lead-form input::placeholder{color:#8a8578}
.lead-form input:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 3px rgba(206,122,82,.3)}
.lf-consent{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:rgba(244,239,227,.85);margin-bottom:16px;line-height:1.45;cursor:pointer}
.lf-consent input{margin-top:3px;flex:0 0 auto;width:16px;height:16px;accent-color:var(--clay)}
.lead-form button{width:100%}
.lead-ok{background:rgba(200,215,204,.2);border:1px solid rgba(200,215,204,.45);color:#e7f0e4;padding:14px 16px;border-radius:11px;margin-bottom:8px;position:relative;z-index:2;font-size:.95rem}
.lead-err{background:rgba(232,183,149,.18);border:1px solid rgba(232,183,149,.55);color:#f3ddca;padding:14px 16px;border-radius:11px;margin-bottom:8px;position:relative;z-index:2;font-size:.95rem}

/* post images */
.a-feat{width:100%;height:auto;aspect-ratio:16/9;object-fit:cover;border-radius:18px;margin:8px 0 36px;box-shadow:var(--shadow-sm);display:block}
.pc-thumb{width:100%;height:auto;aspect-ratio:16/10;object-fit:cover;border-radius:12px;margin-bottom:6px;display:block}
.post-card{overflow:hidden}

.article-body img{max-width:100%;height:auto;border-radius:12px;margin:12px 0 28px;display:block}

/* ---------- Service hub pages ---------- */
.svc-reality{max-width:760px;margin:0 auto;background:var(--paper);border:1px solid rgba(30,61,50,.1);border-radius:var(--r);padding:34px 34px 30px;box-shadow:var(--shadow-sm)}
.svc-reality .tag{display:inline-block;font-family:'DM Mono',monospace;font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--clay);margin-bottom:10px}
.svc-reality h3{font-size:1.5rem;margin:0 0 16px}
.svc-reality ul{list-style:none;margin:0;padding:0}
.svc-reality li{position:relative;padding:10px 0 10px 34px;font-size:1.05rem;color:#36382f;border-top:1px solid rgba(30,61,50,.07)}
.svc-reality li:first-child{border-top:0}
.svc-reality li .ic{position:absolute;left:0;top:11px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:.74rem;color:#fff;background:var(--forest)}
.svc-reality li .ic.warn{background:var(--clay)}
.svc-claim{display:grid;grid-template-columns:1fr 1fr;gap:10px 30px;max-width:820px;margin:0 auto;list-style:none;padding:0}
.svc-claim li{position:relative;padding:9px 0 9px 30px;font-size:1.02rem;color:#36382f}
.svc-claim li::before{content:"✓";position:absolute;left:0;top:9px;color:var(--forest);font-weight:700}
.svc-claim-note{text-align:center;margin:26px auto 0;max-width:680px;color:#54574d}
@media(max-width:680px){.svc-claim{grid-template-columns:1fr}.svc-reality{padding:26px 22px}}
