@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/fraunces-600.woff2') format('woff2')}@font-face{font-family:'Fraunces';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/fraunces-500.woff2') format('woff2')}@font-face{font-family:'Fraunces';font-style:italic;font-weight:500;font-display:swap;src:url('fonts/fraunces-500-italic.woff2') format('woff2')}@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/hanken-400.woff2') format('woff2')}@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/hanken-600.woff2') format('woff2')}@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/hanken-700.woff2') format('woff2')}:root{--bird:url('bird.webp')}

/* ============ Tokens ============ */
:root{
  --paper:#FCF7F2;
  --paper-2:#F7EBE1;
  --paper-3:#F1DFD2;
  --ink:#331E26;
  --ink-2:#50353E;
  --dark:#361722;      /* deep wine, hue-matched to magenta — for dark section backgrounds */
  --dark-2:#250E16;     /* deeper corner shade, same hue family, for gradients */
  --dark-hover:#512435;
  --muted:#6D5A60;
  --line:rgba(51,30,38,.13);
  --line-2:rgba(51,30,38,.07);
  --magenta:#BC4A78;
  --magenta-700:#B23F70;
  --magenta-deep:#992E5B;   /* small text / links — AA on cream */
  --coral:#DD8C76;
  --gold:#E3B768;
  --peach:#F6E0CE;
  --link:#992E5B;

  --grad:linear-gradient(100deg,#BC4A78 0%,#D77A78 52%,#E3B768 100%);
  --grad-soft:linear-gradient(120deg,#F7D9D0,#F6E6D0);

  --maxw:1200px;
  --gutter:clamp(1.1rem,4vw,2.6rem);
  --radius:20px;
  --radius-lg:34px;

  --display:"Fraunces",Georgia,"Times New Roman",serif;
  --body:"Hanken Grotesk",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;

  --step-2:clamp(2.7rem,1.7rem + 4.6vw,4.9rem);
  --step-1:clamp(2rem,1.45rem + 2.6vw,3.2rem);
  --step0:clamp(1.55rem,1.25rem + 1.5vw,2.25rem);
  --step-sm:clamp(1.2rem,1.06rem + .6vw,1.45rem);
  --body-lg:clamp(1.06rem,1rem + .3vw,1.18rem);
}

/* ============ Reset ============ */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:var(--body-lg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:var(--link);text-underline-offset:.18em;text-decoration-thickness:.07em}
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-.015em;color:var(--ink)}
button{font:inherit;color:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--magenta);outline-offset:3px;border-radius:5px}
::selection{background:#F4CBD6;color:var(--ink)}

.skip{position:absolute;left:-9999px;top:0;z-index:200;background:var(--dark);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 10px 0}
.skip:focus{left:0}

/* ============ Layout ============ */
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(3.8rem,2.5rem + 5vw,7rem)}
.eyebrow{font-family:var(--body);font-weight:700;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--magenta-deep);display:inline-flex;align-items:center;gap:.6rem}
.eyebrow::before{content:"";width:1.8rem;height:2px;background:var(--grad);border-radius:2px}
.lead{font-size:var(--step-sm);color:var(--ink-2);line-height:1.5;max-width:36ch}
.muted{color:var(--muted)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--body);font-weight:700;font-size:1.02rem;border:0;border-radius:100px;padding:.9rem 1.55rem;text-decoration:none;transition:transform .18s ease,box-shadow .18s ease,background .18s ease;white-space:nowrap}
.btn svg{width:1.1em;height:1.1em}
.btn-primary{background:var(--magenta-700);color:#fff;box-shadow:0 12px 26px -12px rgba(178,63,112,.85)}
.btn-primary:hover{background:#A2356A;transform:translateY(-2px);box-shadow:0 18px 34px -14px rgba(178,63,112,.95)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:#EAC079;transform:translateY(-2px)}
.btn-dark{background:var(--dark);color:var(--paper)}
.btn-dark:hover{background:var(--dark-hover);transform:translateY(-2px)}
.btn-lg{padding:1.02rem 1.85rem;font-size:1.08rem}

/* ============ Header ============ */
.head{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 84%,transparent);backdrop-filter:saturate(1.5) blur(12px);border-bottom:1px solid transparent;transition:border-color .3s ease,background .3s ease}
.head.scrolled{border-color:var(--line);background:color-mix(in srgb,var(--paper) 94%,transparent)}
.head .wrap{display:flex;align-items:center;gap:1.5rem;min-height:76px}
.brand{display:inline-flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink)}
.brand img{width:42px;height:auto;flex:0 0 auto}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:var(--display);font-weight:600;font-size:1.42rem;letter-spacing:.02em}
.brand .wm small{font-family:var(--body);font-weight:700;font-size:.6rem;letter-spacing:.22em;color:var(--magenta-deep);margin-top:.18rem}
.nav{margin-left:auto;display:flex;align-items:center;gap:.25rem}
.nav a{font-family:var(--body);font-weight:600;font-size:.97rem;color:var(--ink);text-decoration:none;padding:.5rem .8rem;border-radius:9px;transition:background .15s ease}
.nav a:hover{background:var(--paper-2)}
.nav .nav-cta{margin-left:.45rem}
.menu-btn{display:none;margin-left:auto;background:var(--paper-2);border:1px solid var(--line);border-radius:11px;width:48px;height:48px;align-items:center;justify-content:center}
.menu-btn svg{width:22px;height:22px}

@media (max-width:920px){
  .menu-btn{display:inline-flex}
  .nav{position:fixed;inset:76px 0 auto 0;flex-direction:column;align-items:stretch;gap:.2rem;background:var(--paper);border-bottom:1px solid var(--line);padding:1rem var(--gutter) 1.5rem;margin:0;transform:translateY(-130%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:0 22px 44px -26px rgba(51,30,38,.45)}
  .nav.open{transform:translateY(0)}
  .nav a{padding:.9rem .6rem;font-size:1.1rem;border-bottom:1px solid var(--line-2)}
  .nav .nav-cta{margin:.7rem 0 0;justify-content:center}
}

/* ============ Hero ============ */
.hero{position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-35% -15% auto;height:130%;background:
  radial-gradient(54% 56% at 74% 26%,rgba(221,140,118,.34),transparent 62%),
  radial-gradient(46% 50% at 90% 8%,rgba(227,183,104,.34),transparent 64%),
  radial-gradient(52% 60% at 16% 92%,rgba(188,74,120,.12),transparent 60%);
  pointer-events:none;z-index:0}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(2rem,4vw,4.5rem);align-items:center;padding-block:clamp(2.4rem,2rem + 4vw,4.6rem)}
.hero h1{font-size:var(--step-2);font-weight:600;max-width:15ch;letter-spacing:-.025em}
.hero h1 .hl{position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-.04em;right:-.04em;bottom:.04em;height:.36em;background:var(--grad);opacity:.42;border-radius:.25em;z-index:-1}
.hero p.lead{margin-top:1.5rem;max-width:48ch}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2.1rem}
.hero-note{margin-top:1.5rem;font-size:.93rem;color:var(--muted);display:flex;align-items:center;gap:.5rem}
.hero-note svg{width:1.15rem;height:1.15rem;color:var(--magenta)}

/* hero medallion */

@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero-art{max-width:380px}
}

/* hummingbird medallion hero */
.hero-art{position:relative;width:100%;max-width:468px;margin-inline:auto;aspect-ratio:1/1;isolation:isolate}
.hero-medallion{position:absolute;inset:0;display:grid;place-items:center}
.hero-medallion .halo{position:absolute;inset:-4%;border-radius:50%;background:radial-gradient(circle at 50% 42%,rgba(227,183,104,.30),rgba(221,140,118,.16) 46%,transparent 68%);z-index:0}
.hero-medallion .frame{position:absolute;width:96%;aspect-ratio:1/1;border-radius:50%;border:1.5px solid rgba(188,74,120,.16);z-index:1}
.hero-medallion .ground{position:absolute;bottom:1%;left:50%;transform:translateX(-50%);width:60%;height:30px;background:radial-gradient(ellipse,rgba(51,30,38,.22),transparent 72%);filter:blur(7px);z-index:0}
.hero-medallion .ring{position:relative;width:86%;aspect-ratio:1/1;border-radius:50%;background:conic-gradient(from 212deg,#BC4A78,#DD8C76 34%,#E3B768 56%,#DD8C76 78%,#BC4A78);padding:13px;box-shadow:0 48px 86px -38px rgba(188,74,120,.6),0 10px 24px -10px rgba(51,30,38,.18);z-index:2}
.hero-medallion .disc{width:100%;height:100%;border-radius:50%;background:radial-gradient(circle at 50% 34%,#fff,#FDF8F3 56%,#F5E5DA);display:grid;place-items:center;overflow:hidden;box-shadow:inset 0 3px 8px rgba(255,255,255,.9),inset 0 -16px 34px rgba(188,74,120,.06)}
.hero-medallion .disc-bird{width:66%;aspect-ratio:734/760;background:var(--bird) center/contain no-repeat;filter:drop-shadow(0 16px 22px rgba(51,30,38,.2));animation:hover-bird 6s ease-in-out infinite}
.hero-medallion .spark{position:absolute;z-index:3;animation:drift 7s ease-in-out infinite}
.hero-medallion .spark svg{display:block;width:100%;height:100%}
.hero-medallion .spark.s1{width:26px;height:26px;top:5%;left:7%;color:var(--coral)}
.hero-medallion .spark.s2{width:17px;height:17px;bottom:13%;right:4%;color:var(--gold);animation-delay:-3.5s}

/* shared hummingbird mark (single inlined asset via --bird) */
.bird-bg{background:var(--bird) center/contain no-repeat}
.brand-bird{width:42px;height:43px;flex:0 0 auto}
.badge-bird{width:26px;height:27px;flex:0 0 auto}

/* ============ Trust strip ============ */
.trust{border-block:1px solid var(--line);background:var(--paper-2)}
.trust .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.1rem 2rem;padding-block:1.25rem}
.trust .ti{display:flex;align-items:center;gap:.6rem;font-family:var(--body);font-weight:600;font-size:.9rem;color:var(--ink-2)}
.trust .ti svg{width:1.4rem;height:1.4rem;color:var(--magenta);flex:0 0 auto}

/* ============ Section heads ============ */
.shead{max-width:48ch}
.shead h2{font-size:var(--step-1);margin-top:.7rem;font-weight:600}
.shead p{margin-top:1rem;color:var(--ink-2);font-size:var(--body-lg)}
.shead.center{margin-inline:auto;text-align:center}
.shead.center .eyebrow{justify-content:center}

/* ============ Approach pillars ============ */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-top:3rem}
.pillar{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.7rem;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}
.pillar:hover{transform:translateY(-5px);box-shadow:0 26px 50px -30px rgba(51,30,38,.5)}
.pillar::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad)}
.pillar .pn{font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--magenta-deep)}
.pillar h3{font-size:1.42rem;margin-top:1rem;letter-spacing:-.01em}
.pillar p{margin-top:.7rem;font-size:1rem;color:var(--muted);line-height:1.55}
@media (max-width:860px){.pillars{grid-template-columns:1fr}}

/* ============ Feature cards (we come to you) ============ */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem;margin-top:2.8rem}
.feat{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem 1.45rem;transition:transform .2s ease,box-shadow .2s ease}
.feat:hover{transform:translateY(-4px);box-shadow:0 22px 44px -30px rgba(51,30,38,.5)}
.feat .ico{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;background:var(--peach);margin-bottom:1.1rem}
.feat .ico svg{width:25px;height:25px;color:var(--magenta)}
.feat h3{font-size:1.2rem;letter-spacing:-.01em}
.feat p{margin-top:.55rem;font-size:.96rem;color:var(--muted);line-height:1.5}
@media (max-width:880px){.feat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.feat-grid{grid-template-columns:1fr}}

/* ============ Services ============ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:2.8rem}
.svc{display:block;text-decoration:none;color:inherit;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.7rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.svc:hover{transform:translateY(-4px);box-shadow:0 24px 48px -30px rgba(51,30,38,.5);border-color:transparent}
.svc .tag{font-family:var(--body);font-weight:700;font-size:.74rem;letter-spacing:.09em;text-transform:uppercase;color:var(--magenta-deep)}
.svc h3{font-size:1.34rem;margin-top:.8rem;font-weight:600}
.svc p{margin-top:.6rem;font-size:.97rem;color:var(--muted);line-height:1.5}
.svc .more{display:inline-flex;align-items:center;gap:.4rem;margin-top:1.15rem;font-family:var(--body);font-weight:700;font-size:.95rem;color:var(--magenta-deep)}
.svc .more svg{width:1rem;height:1rem;transition:transform .2s ease}
.svc:hover .more svg{transform:translateX(4px)}
@media (max-width:880px){.svc-grid{grid-template-columns:1fr}}

/* ============ Founder / clinician ============ */
.founder{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.founder-photo{position:relative;max-width:420px}
.founder-photo .blob{position:absolute;inset:-7%;background:var(--grad);border-radius:48% 52% 46% 54%/52% 48% 52% 48%;opacity:.9;z-index:0}
.founder-photo .pf{position:relative;z-index:1;aspect-ratio:1/1;border-radius:24px;overflow:hidden;border:5px solid var(--paper);box-shadow:0 28px 56px -30px rgba(51,30,38,.5)}
.founder-photo .pf img{width:100%;height:100%;object-fit:cover}
.founder-photo .badge{position:absolute;z-index:2;bottom:-18px;left:-18px;background:var(--paper);border:1px solid var(--line);border-radius:15px;padding:.7rem 1rem;box-shadow:0 18px 40px -22px rgba(51,30,38,.5);font-family:var(--body);font-weight:700;font-size:.82rem;display:flex;align-items:center;gap:.55rem}
.founder-photo .badge img{width:26px;height:auto}
.founder .sig{font-family:var(--display);font-weight:500;font-style:italic;font-size:1.7rem;color:var(--magenta-deep);margin-top:1.4rem}
.founder blockquote{font-size:var(--step-sm);line-height:1.5;color:var(--ink-2);margin-top:1.1rem;font-family:var(--display);font-weight:500}
.founder .creds{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.4rem}
.founder .chip{font-family:var(--body);font-weight:600;font-size:.82rem;background:var(--paper-2);border:1px solid var(--line);border-radius:100px;padding:.4rem .9rem;color:var(--ink-2)}
@media (max-width:860px){.founder{grid-template-columns:1fr;gap:3rem}.founder-photo{max-width:340px;margin-inline:auto}}

/* ============ Funding band ============ */
.fund{background:var(--dark);color:var(--paper);position:relative;overflow:hidden}
.fund::after{content:"";position:absolute;right:-8%;top:-30%;width:48%;height:160%;background:radial-gradient(50% 50% at 50% 50%,rgba(221,140,118,.3),transparent 70%);pointer-events:none}
.fund h2,.fund h3{color:var(--paper)}
.fund .eyebrow{color:var(--gold)}
.fund .eyebrow::before{background:var(--gold)}
.fund .fund-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,4vw,4rem);align-items:start;position:relative;z-index:1}
.fund .lead{color:rgba(252,247,242,.84)}
.paths{display:grid;gap:.9rem}
.path{display:flex;gap:1rem;background:rgba(252,247,242,.06);border:1px solid rgba(252,247,242,.15);border-radius:15px;padding:1.15rem 1.25rem}
.path .pico{width:44px;height:44px;border-radius:12px;background:rgba(227,183,104,.16);display:grid;place-items:center;flex:0 0 auto}
.path .pico svg{width:23px;height:23px;color:var(--gold)}
.path h3{font-size:1.14rem;font-weight:600}
.path p{font-size:.93rem;color:rgba(252,247,242,.74);margin-top:.25rem;line-height:1.5}
.fund-cta{margin-top:1.7rem;display:flex;flex-wrap:wrap;gap:.8rem;align-items:center}
@media (max-width:840px){.fund .fund-grid{grid-template-columns:1fr;gap:2rem}}

/* ============ Process ============ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:3rem;counter-reset:step}
.step{position:relative;padding-top:1.5rem}
.step::before{counter-increment:step;content:"0" counter(step);font-family:var(--display);font-weight:600;font-size:1.05rem;color:var(--magenta-deep);letter-spacing:.03em}
.step::after{content:"";position:absolute;top:2rem;left:2.6rem;right:-.6rem;height:2px;background:repeating-linear-gradient(90deg,var(--line) 0 6px,transparent 6px 12px)}
.step:last-child::after{display:none}
.step h3{font-size:1.16rem;margin-top:.75rem;font-weight:600}
.step p{margin-top:.45rem;font-size:.95rem;color:var(--muted);line-height:1.5}
@media (max-width:880px){.steps{grid-template-columns:repeat(2,1fr)}.step::after{display:none}}
@media (max-width:460px){.steps{grid-template-columns:1fr}}

/* ============ Testimonial ============ */
.quote{background:var(--grad-soft);border-radius:var(--radius-lg);padding:clamp(2.2rem,4vw,3.6rem);position:relative;max-width:64rem;margin-inline:auto;overflow:hidden}
.quote .bird-wm{position:absolute;right:-30px;bottom:-30px;width:200px;height:207px;background:var(--bird) center/contain no-repeat;opacity:.16;z-index:0}
.quote .inner{position:relative;z-index:1}
.quote blockquote{font-family:var(--display);font-weight:500;font-size:var(--step0);line-height:1.32;letter-spacing:-.01em;color:var(--ink)}
.quote .by{margin-top:1.5rem;font-family:var(--body);font-weight:700;color:var(--ink-2)}
.quote .by span{display:block;font-weight:400;color:var(--muted);font-size:.92rem;margin-top:.1rem}

/* ============ Referrers ============ */
.refer{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,3vw,3rem);align-items:center;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.9rem,3.5vw,3.2rem)}
.refer ul{list-style:none;padding:0;margin:1.3rem 0 0;display:grid;gap:.75rem}
.refer li{display:flex;gap:.6rem;align-items:flex-start;font-size:.99rem;color:var(--ink-2)}
.refer li svg{width:1.3rem;height:1.3rem;color:var(--magenta);flex:0 0 auto;margin-top:.12rem}
.refer .turn{display:inline-flex;align-items:center;gap:.5rem;background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:.45rem 1rem;font-family:var(--body);font-weight:700;font-size:.85rem;color:var(--magenta-deep);margin-bottom:1rem}
@media (max-width:780px){.refer{grid-template-columns:1fr}}

/* ============ Blog ============ */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.8rem}
.post{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}
.post:hover{transform:translateY(-4px);box-shadow:0 24px 48px -30px rgba(51,30,38,.5)}
.post .thumb{aspect-ratio:16/10;position:relative;display:grid;place-items:center}
.post .thumb svg{width:100%;height:100%}
.post .body{padding:1.35rem 1.45rem 1.55rem}
.post .meta{font-family:var(--body);font-weight:700;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--magenta-deep)}
.post h3{font-size:1.22rem;margin-top:.6rem;line-height:1.25;font-weight:600}
.post p{margin-top:.55rem;font-size:.94rem;color:var(--muted);line-height:1.5}
.post .read{margin-top:auto;padding-top:1.05rem;font-family:var(--body);font-weight:700;font-size:.9rem;color:var(--magenta-deep);display:inline-flex;align-items:center;gap:.4rem}
@media (max-width:880px){.posts{grid-template-columns:1fr}}

/* ============ CTA band ============ */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--dark),var(--dark-2));color:var(--paper);border-radius:var(--radius-lg)}
.cta-band::before{content:"";position:absolute;inset:0;background:
  radial-gradient(42% 70% at 14% 22%,rgba(221,140,118,.34),transparent 60%),
  radial-gradient(44% 80% at 88% 88%,rgba(188,74,120,.42),transparent 60%),
  radial-gradient(30% 50% at 70% 10%,rgba(227,183,104,.26),transparent 60%);pointer-events:none}
.cta-band .bird-wm{position:absolute;right:4%;top:50%;transform:translateY(-50%);width:150px;height:155px;background:var(--bird) center/contain no-repeat;opacity:.22;z-index:0}
.cta-band .inner{position:relative;z-index:1;padding:clamp(2.6rem,4vw,4.4rem);text-align:center;display:flex;flex-direction:column;align-items:center}
.cta-band h2{color:var(--paper);font-size:var(--step-1);max-width:20ch;font-weight:600}
.cta-band p{margin-top:1rem;color:rgba(252,247,242,.82);max-width:50ch}
.cta-band .hero-actions{justify-content:center;margin-top:2rem}

/* ============ Footer ============ */
.foot{background:var(--dark);color:rgba(252,247,242,.72);padding-block:clamp(3.2rem,4vw,4.6rem) 2rem}
.foot a{color:rgba(252,247,242,.72);text-decoration:none}
.foot a:hover{color:var(--paper)}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.25fr;gap:2rem}
.foot .brand{margin-bottom:1rem}
.foot .brand .wm b{color:var(--paper)}
.foot .fabout{font-size:.95rem;max-width:34ch;line-height:1.6}
.foot h4{font-family:var(--body);font-weight:700;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--paper);margin-bottom:1rem}
.foot ul{list-style:none;padding:0;display:grid;gap:.55rem;font-size:.95rem}
.foot .social{display:flex;gap:.6rem;margin-top:1.2rem}
.foot .social a{width:40px;height:40px;border-radius:11px;background:rgba(252,247,242,.08);display:grid;place-items:center;transition:background .15s ease}
.foot .social a:hover{background:rgba(252,247,242,.16)}
.foot .social svg{width:20px;height:20px;color:var(--paper)}
.foot .acks{margin-top:2.5rem;padding-top:1.7rem;border-top:1px solid rgba(252,247,242,.12);font-size:.86rem;line-height:1.6;max-width:72ch}
.foot .legal{margin-top:1.6rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.8rem;font-size:.84rem;color:rgba(252,247,242,.5)}
@media (max-width:780px){.foot-grid{grid-template-columns:1fr 1fr}.foot .fbrandcol{grid-column:1/-1}}
@media (max-width:460px){.foot-grid{grid-template-columns:1fr}}

/* ============ Inner page hero ============ */
.phero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.phero::before{content:"";position:absolute;inset:-40% -10% auto;height:150%;background:radial-gradient(50% 60% at 80% 12%,rgba(221,140,118,.3),transparent 60%),radial-gradient(36% 50% at 8% 100%,rgba(188,74,120,.12),transparent 60%);pointer-events:none}
.phero .wrap{position:relative;z-index:1;padding-block:clamp(2.8rem,2rem + 3vw,4.8rem)}
.phero h1{font-size:var(--step-1);max-width:20ch;margin-top:.7rem;font-weight:600}
.phero p{margin-top:1.1rem;max-width:56ch;color:var(--ink-2);font-size:var(--body-lg)}
.crumbs{font-size:.86rem;color:var(--muted)}
.crumbs a{color:var(--muted)}

/* ============ Prose ============ */
.prose{max-width:44rem}
.prose h2{font-size:var(--step0);margin-top:2.8rem;font-weight:600}
.prose h3{font-size:1.32rem;margin-top:1.9rem;font-weight:600}
.prose p{margin-top:1rem;color:var(--ink-2)}
.prose ul{margin-top:1rem;padding-left:1.2rem;color:var(--ink-2)}
.prose li{margin-top:.5rem}
.prose strong{color:var(--ink)}
.callout{background:var(--grad-soft);border-radius:var(--radius);padding:1.5rem 1.6rem;margin-top:1.9rem;border-left:4px solid var(--magenta)}
.callout strong{color:var(--ink)}

/* ============ Reveal & motion ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@keyframes hover-bird{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-9px) rotate(-3deg)}}
@keyframes drift{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.float{animation:drift 6s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .float,.hero-medallion .spark,.hero-medallion .disc-bird{animation:none!important}
}

/* ============ Article / detail pages ============ */
.article .prose{margin-inline:auto}
.byline{display:flex;align-items:center;gap:.85rem;max-width:44rem;margin:0 auto 2.2rem;color:var(--muted);font-size:.92rem}
.byline .av{width:46px;height:46px;border-radius:50%;overflow:hidden;flex:0 0 auto;border:2px solid var(--paper);box-shadow:0 6px 16px -6px rgba(51,30,38,.45)}
.byline .av img{width:100%;height:100%;object-fit:cover}
.byline b{color:var(--ink-2);font-weight:700}
.sibs{max-width:44rem;margin:2.8rem auto 0;border-top:1px solid var(--line);padding-top:1.9rem}
.sibs h2{font-size:1.18rem;font-weight:600;margin-bottom:1rem}
.sibs .chips{display:flex;flex-wrap:wrap;gap:.6rem}
.sibs .chips a{font-family:var(--body);font-weight:600;font-size:.88rem;background:var(--paper-2);border:1px solid var(--line);border-radius:100px;padding:.55rem 1.05rem;color:var(--ink-2);text-decoration:none;transition:border-color .15s ease,background .15s ease}
.sibs .chips a:hover{border-color:var(--magenta);background:#fff;color:var(--magenta-deep)}
.factbox{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem;margin-top:1.9rem}
.factbox h3{font-size:1.05rem;font-weight:700;font-family:var(--body);letter-spacing:.01em;margin-bottom:.6rem}
.factbox ul{margin:0;padding-left:1.1rem}

/* ============ Thank you ============ */
.thanks{max-width:560px;margin-inline:auto;text-align:center}
.thanks .tick{width:84px;height:84px;border-radius:50%;background:var(--grad);display:grid;place-items:center;margin:0 auto 1.6rem;box-shadow:0 24px 50px -24px rgba(188,74,120,.6)}
.thanks .tick svg{width:42px;height:42px;color:#fff}

/* ============== service detail utilities ============== */
.checklist{list-style:none;padding:0;margin:1.2rem 0 0;display:grid;gap:.7rem}
.checklist li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink-2)}
.checklist li svg{width:1.3rem;height:1.3rem;color:var(--magenta);flex:0 0 auto;margin-top:.18rem}
.related{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.3rem}
.related a{font-family:var(--body);font-weight:600;font-size:.9rem;background:var(--paper);border:1px solid var(--line);border-radius:100px;padding:.5rem 1rem;color:var(--ink-2);text-decoration:none;transition:border-color .15s ease,transform .15s ease,color .15s ease}
.related a:hover{border-color:var(--magenta-700);transform:translateY(-2px);color:var(--magenta-deep)}
.factbar{display:flex;flex-wrap:wrap;gap:1.3rem 2.4rem;padding:1.3rem 1.6rem;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);margin:1.9rem 0}
.factbar div{display:flex;flex-direction:column}
.factbar b{font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--ink);line-height:1.2}
.factbar span{font-size:.83rem;color:var(--muted);margin-top:.15rem}

/* ===================== article ===================== */
.article-meta{display:flex;flex-wrap:wrap;gap:.45rem 1rem;align-items:center;margin-top:.9rem;font-family:var(--body);font-weight:600;font-size:.9rem;color:var(--muted)}
.article-meta .cat{color:var(--magenta-deep);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:700}
.author-card{display:flex;gap:1rem;align-items:center;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem 1.5rem;margin-top:2.8rem}
.author-card .av{width:62px;height:62px;border-radius:50%;overflow:hidden;flex:0 0 auto;border:2px solid var(--paper);box-shadow:0 8px 18px -10px rgba(51,30,38,.4)}
.author-card .av img{width:100%;height:100%;object-fit:cover}
.author-card .nm{font-family:var(--display);font-weight:600;font-size:1.1rem;color:var(--ink)}
.author-card .ro{font-size:.87rem;color:var(--muted);margin-top:.1rem}

/* ============ Visually hidden ============ */
.vh{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* ============ Referral form ============ */
.form-wrap{max-width:720px;margin-inline:auto}
.referral-form{display:grid;gap:2.1rem}
.referral-form fieldset{border:0;margin:0;padding:0}
.referral-form legend{display:flex;align-items:center;gap:.7rem;font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--ink);margin-bottom:1.1rem;padding:0;width:100%}
.referral-form legend .n{width:1.95rem;height:1.95rem;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-family:var(--body);font-weight:700;font-size:.85rem;flex:0 0 auto}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
@media(max-width:560px){.fgrid{grid-template-columns:1fr}}
.field{display:grid;gap:.4rem}
.fgrid+.fgrid{margin-top:1.1rem}
.field label{font-family:var(--body);font-weight:600;font-size:.85rem;color:var(--ink-2)}
.field label .req{color:var(--magenta-deep)}
.field input,.field textarea{font:inherit;font-size:1rem;color:var(--ink);background:var(--paper);border:1.5px solid var(--line);border-radius:14px;padding:.85rem 1.1rem;width:100%;transition:border-color .15s ease,box-shadow .15s ease}
.field textarea{min-height:148px;resize:vertical;line-height:1.55}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 0 4px rgba(188,74,120,.13)}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.62}
.field.bad input,.field.bad textarea{border-color:#C23A3A;box-shadow:0 0 0 4px rgba(194,58,58,.1)}
.field .msg{font-size:.78rem;color:#A92B2B;display:none}
.field.bad .msg{display:block}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
@media(max-width:560px){.checks{grid-template-columns:1fr}}
.check{display:flex;align-items:center;gap:.7rem;background:var(--paper);border:1.5px solid var(--line);border-radius:14px;padding:.85rem 1rem;cursor:pointer;transition:border-color .15s ease,background .15s ease}
.check:hover{border-color:var(--magenta)}
.check input{width:1.2rem;height:1.2rem;accent-color:var(--magenta-700);flex:0 0 auto;cursor:pointer}
.check span{font-family:var(--body);font-weight:600;font-size:.95rem;color:var(--ink-2)}
.check:has(input:checked){border-color:var(--magenta);background:#FBEDF2}
.form-foot{display:flex;flex-wrap:wrap;align-items:center;gap:1.1rem;margin-top:.4rem}
.form-note{font-size:.85rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;max-width:34ch}
.form-note svg{width:1.15rem;height:1.15rem;color:var(--magenta);flex:0 0 auto}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-success{display:none;text-align:center;background:var(--grad-soft);border-radius:var(--radius-lg);padding:clamp(2.6rem,4vw,3.8rem)}
.form-success.show{display:block;animation:rise .5s ease}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.form-success .tick{width:74px;height:74px;border-radius:50%;background:var(--grad);display:grid;place-items:center;margin:0 auto 1.4rem;box-shadow:0 18px 36px -16px rgba(188,74,120,.6)}
.form-success .tick svg{width:38px;height:38px;color:#fff}
.form-success h2{font-size:var(--step0);font-weight:600}
.form-success p{margin-top:.8rem;color:var(--ink-2);max-width:46ch;margin-inline:auto}
.form-error{display:none;margin-top:1.1rem;background:#FBEAE7;border:1px solid #E7B9B1;color:#8E2A1F;border-radius:12px;padding:.9rem 1.1rem;font-size:.92rem}
.form-error.show{display:block}
.form-error a{color:#8E2A1F;font-weight:600}
@media (prefers-reduced-motion:reduce){.form-success.show{animation:none}}

/* ============ FAQ accordions ============ */
.faqs{display:grid;gap:.8rem;margin-top:1.5rem}
.faq{background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1.05rem 1.25rem;font-family:var(--body);font-weight:600;font-size:1.02rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--magenta);transition:transform .2s ease;line-height:1;flex:0 0 auto}
.faq[open] summary::after{transform:rotate(45deg)}
.faq .faq-a{padding:0 1.25rem 1.2rem;color:var(--ink-2);font-size:.98rem;line-height:1.62}
.faq .faq-a p{margin-top:.7rem}
.faq .faq-a p:first-child{margin-top:0}

/* ============ Related cards ============ */
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1.6rem}
.related a{display:block;text-decoration:none;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:1.1rem 1.2rem;color:var(--ink);font-family:var(--body);font-weight:600;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.related a:hover{transform:translateY(-3px);box-shadow:0 18px 36px -26px rgba(51,30,38,.5);border-color:transparent}
.related a small{display:block;font-size:.78rem;color:var(--magenta-deep);font-weight:700;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.3rem}
@media(max-width:680px){.related{grid-template-columns:1fr}}

/* ============ Article meta ============ */
.amate{display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;margin-top:1.3rem;font-family:var(--body);font-size:.9rem;color:var(--muted)}
.amate .av{width:34px;height:34px;border-radius:50%;object-fit:cover;border:2px solid var(--paper);box-shadow:0 2px 8px -2px rgba(51,30,38,.3)}
.amate b{color:var(--ink-2);font-weight:600}
.amate .sep{width:4px;height:4px;border-radius:50%;background:var(--line);display:inline-block}
.prose .lede{font-size:var(--step-sm);line-height:1.5;color:var(--ink-2);font-family:var(--display);font-weight:500}

.nav a[aria-current]{color:var(--magenta-deep);background:var(--paper-2)}