/* ============================================================
   Marginnote Studio  —  votecowwow.com
   Ink-Navy & Butter Paper  ·  editorial wellbeing journal
   Palette (locked):
     primary   #2E3A55  ink-navy
     secondary #E7BFC2  blush  (structural tint only)
     accent    #F2C14E  butter-yellow  (the ONLY pop)
     background#FBF7F0  warm paper
     foreground#1C2333  near-ink text
   ============================================================ */

:root{
  --ink:#1C2333;
  --navy:#2E3A55;
  --navy-deep:#222B40;
  --blush:#E7BFC2;
  --blush-soft:#F4DEE0;
  --accent:#F2C14E;
  --accent-ink:#3a2c05;          /* readable text sat on accent */
  --paper:#FBF7F0;
  --paper-deep:#F4ECDD;
  --surface:#FFFFFF;
  --line:#E4DACB;                /* hairline on paper */
  --line-soft:#EFE7D8;
  --body:#33384A;               /* slightly lifted ink for long body runs */
  --muted:#5A6072;

  --maxw:1200px;
  --readw:68ch;
  --radius:14px;
  --radius-sm:9px;

  --font-display:"Piazzolla",Georgia,"Times New Roman",serif;
  --font-body:"Anek Latin",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-mono:"Commit Mono",ui-monospace,"SFMono-Regular",Menlo,monospace;

  --shadow-soft:0 1px 0 rgba(28,35,51,.03), 0 18px 40px -28px rgba(34,43,64,.30);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:1.075rem;
  line-height:1.7;
  font-weight:420;
  letter-spacing:.002em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);font-weight:600;line-height:1.12;letter-spacing:-.012em;margin:0}
h1{font-size:clamp(2.5rem,6vw,4.4rem);font-weight:580}
h2{font-size:clamp(1.85rem,3.6vw,2.7rem)}
h3{font-size:clamp(1.25rem,2vw,1.55rem);line-height:1.2}
p{margin:0 0 1.15em}
a{color:inherit}

img{display:block;max-width:100%;height:auto}

.shell{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.25rem,5vw,3rem)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 var(--radius-sm) 0;z-index:200}
.skip-link:focus{left:0}

/* ---- focus visibility (AAA-aware audience) ---- */
:where(a,button,input,textarea,[tabindex]):focus-visible{
  outline:3px solid var(--navy);
  outline-offset:3px;
  border-radius:4px;
}
.btn:focus-visible,.cta:focus-visible{outline-color:var(--ink)}

/* ============================================================
   Eyebrow label (quiet text rule, restrained use)
   ============================================================ */
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 1.1rem;
  display:inline-flex;
  align-items:center;
  gap:.6rem;
}
.eyebrow::before{content:"";width:1.8rem;height:1px;background:var(--navy);opacity:.55}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  font-family:var(--font-body);
  font-weight:600;
  font-size:1rem;
  letter-spacing:.005em;
  border:0;cursor:pointer;
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.92rem 1.6rem;
  border-radius:var(--radius-sm);
  text-decoration:none;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background-color .35s var(--ease);
  will-change:transform;
}
.btn svg{flex:none}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 10px 24px -12px rgba(242,193,78,.85)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 30px -12px rgba(242,193,78,.9)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--navy)}
.btn-ghost:hover{background:var(--navy);color:var(--paper);transform:translateY(-2px)}
.btn-on-navy{background:var(--accent);color:var(--accent-ink)}
.btn-on-navy:hover{transform:translateY(-2px)}

/* text link with accent underline */
.tlink{
  color:var(--navy);font-weight:600;text-decoration:none;
  display:inline-flex;align-items:center;gap:.4rem;
  background-image:linear-gradient(var(--accent),var(--accent));
  background-size:100% 2px;background-position:0 100%;background-repeat:no-repeat;
  padding-bottom:2px;
  transition:background-size .3s var(--ease), gap .3s var(--ease);
}
.tlink:hover{gap:.65rem}
.tlink svg{transition:transform .3s var(--ease)}
.tlink:hover svg{transform:translateX(3px)}

/* ============================================================
   Header
   ============================================================ */
.site-head{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--paper) 82%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .4s var(--ease),background-color .4s var(--ease)}
.site-head.is-stuck{border-bottom-color:var(--line);background:color-mix(in srgb,var(--paper) 93%,transparent)}
.head-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:74px}
.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink)}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;flex:none}
.brand-name{font-family:var(--font-display);font-weight:600;font-size:1.32rem;letter-spacing:-.01em}
.brand-name b{font-style:italic;font-weight:600}
.nav{display:flex;align-items:center;gap:.35rem}
.nav a{font-size:.96rem;font-weight:500;color:var(--body);text-decoration:none;padding:.5rem .8rem;border-radius:7px;transition:color .25s,background-color .25s}
.nav a:hover{color:var(--ink);background:var(--paper-deep)}
.nav a[aria-current="page"]{color:var(--ink)}
.nav a[aria-current="page"]::after{content:"";display:block;height:2px;background:var(--accent);margin-top:3px;border-radius:2px}
.head-cta{margin-left:.5rem}
.nav-toggle{display:none;background:transparent;border:1.5px solid var(--line);border-radius:8px;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer}
.nav-toggle svg{display:block}

@media (max-width:880px){
  .nav{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;background:var(--paper);border-bottom:1px solid var(--line);padding:1rem clamp(1.25rem,5vw,3rem) 1.5rem;gap:.2rem;transform:translateY(-12px);opacity:0;pointer-events:none;transition:opacity .3s var(--ease),transform .3s var(--ease)}
  .nav.open{opacity:1;transform:none;pointer-events:auto}
  .nav a{padding:.85rem .4rem;border-bottom:1px solid var(--line-soft)}
  .head-cta{margin:.6rem 0 0}
  .nav-toggle{display:inline-flex}
}

/* ============================================================
   Hero  (curtain reveal + ambient gradient glow)
   ============================================================ */
.hero{position:relative;padding:clamp(3.5rem,8vw,6.5rem) 0 clamp(3rem,6vw,5rem);overflow:hidden}
.glow{position:absolute;inset:-20% -10% auto -10%;height:80vh;z-index:0;pointer-events:none;filter:blur(60px);opacity:.55}
.glow span{position:absolute;border-radius:50%;mix-blend-mode:multiply}
.glow .g1{width:46vw;height:46vw;left:6%;top:0;background:radial-gradient(circle at 30% 30%,rgba(242,193,78,.55),transparent 65%)}
.glow .g2{width:42vw;height:42vw;right:4%;top:8%;background:radial-gradient(circle at 60% 40%,rgba(231,191,194,.6),transparent 64%)}
.glow .g3{width:36vw;height:36vw;left:32%;top:20%;background:radial-gradient(circle at 50% 50%,rgba(242,193,78,.32),transparent 68%)}
@media (prefers-reduced-motion:no-preference){
  .glow .g1{animation:drift1 32s var(--ease) infinite alternate}
  .glow .g2{animation:drift2 38s var(--ease) infinite alternate}
  .glow .g3{animation:drift3 30s var(--ease) infinite alternate}
}
@keyframes drift1{to{transform:translate3d(6%,4%,0) scale(1.08)}}
@keyframes drift2{to{transform:translate3d(-5%,6%,0) scale(1.12)}}
@keyframes drift3{to{transform:translate3d(4%,-5%,0) scale(1.06)}}

.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
@media (max-width:920px){.hero-grid{grid-template-columns:1fr;gap:2.5rem}}
.hero-copy{max-width:38rem}
.hero h1{margin:0 0 1.3rem}
.hero h1 em{font-style:italic;color:var(--navy)}
.hero-sub{font-size:1.18rem;color:var(--body);max-width:32rem;margin:0 0 2rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero-note{margin:1.5rem 0 0;font-size:.92rem;color:var(--muted);display:flex;align-items:center;gap:.6rem}
.hero-note svg{flex:none;color:var(--navy)}

.hero-figure{position:relative}
.hero-figure .frame{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:4/5;background:var(--paper-deep)}
.hero-figure .frame img{width:100%;height:100%;object-fit:cover}
.hero-figure .tag{position:absolute;left:1rem;bottom:1rem;background:var(--paper);color:var(--ink);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;padding:.5rem .8rem;border-radius:7px;box-shadow:var(--shadow-soft)}
.hero-figure .chip{position:absolute;right:-14px;top:1.8rem;background:var(--navy);color:var(--paper);padding:.85rem 1.05rem;border-radius:var(--radius-sm);box-shadow:var(--shadow-soft);max-width:11rem}
.hero-figure .chip b{font-family:var(--font-display);font-size:1.5rem;display:block;line-height:1}
.hero-figure .chip span{font-size:.78rem;color:var(--blush);display:block;margin-top:.3rem}

/* curtain reveal */
.reveal-up{opacity:0;transform:translateY(26px)}
.reveal-curtain{clip-path:inset(0 0 100% 0)}
.is-ready .reveal-up{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.is-ready .reveal-curtain{clip-path:inset(0 0 0 0);transition:clip-path 1.1s var(--ease)}
.hero .reveal-up:nth-child(2){transition-delay:.08s}
@media (prefers-reduced-motion:reduce){
  .reveal-up,.reveal-curtain{opacity:1!important;transform:none!important;clip-path:none!important}
}

/* ============================================================
   Section rhythm + generic
   ============================================================ */
section{position:relative}
.band{padding:clamp(4.5rem,9vw,7.5rem) 0}
.band-paper{background:var(--paper)}
.band-deep{background:var(--paper-deep)}
.band-navy{background:var(--navy);color:var(--blush-soft)}
.band-navy h2,.band-navy h3{color:#fff}
.band-blush{background:linear-gradient(180deg,var(--blush-soft),var(--paper))}

.sec-head{max-width:46rem;margin:0 0 3rem}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head p{color:var(--body);font-size:1.12rem;margin:1rem 0 0}
.band-navy .sec-head p{color:var(--blush-soft)}

.lede{font-size:1.3rem;line-height:1.55;color:var(--body);font-family:var(--font-body);max-width:40rem}

/* hairline divider */
.rule{height:1px;background:var(--line);border:0;margin:0}

/* ============================================================
   Stats strip
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.2rem,3vw,2.5rem)}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr);gap:2rem 1.5rem}}
.stat{padding-left:1.1rem;border-left:2px solid var(--accent)}
.stat b{display:block;font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);line-height:1;color:var(--ink)}
.band-navy .stat b{color:#fff}
.stat span{display:block;margin-top:.5rem;font-size:.92rem;color:var(--muted)}
.band-navy .stat span{color:var(--blush-soft)}

/* ============================================================
   Topics / services  (no card-in-card; hairline grouping)
   ============================================================ */
.topic-list{display:grid;gap:0;border-top:1px solid var(--line)}
.topic{display:grid;grid-template-columns:auto 1fr auto;gap:1.6rem;align-items:start;padding:2.4rem 0;border-bottom:1px solid var(--line)}
@media (max-width:760px){.topic{grid-template-columns:auto 1fr;gap:1.1rem}}
.topic .ico{width:54px;height:54px;border-radius:12px;display:grid;place-items:center;background:var(--paper-deep);color:var(--navy);flex:none}
.band-deep .topic .ico{background:var(--surface)}
.topic .ico svg{display:block}
.topic-body h3{margin:0 0 .55rem}
.topic-body p{margin:0 0 1rem;color:var(--body);max-width:48ch}
.topic-points{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-wrap:wrap;gap:.5rem .9rem}
.topic-points li{font-size:.9rem;color:var(--muted);display:inline-flex;align-items:center;gap:.45rem}
.topic-points svg{color:var(--navy);flex:none}
.topic-cta{align-self:center}
@media (max-width:760px){.topic-cta{grid-column:1/-1}}

/* ============================================================
   Approach / values (quiet 3-up, hairline framed)
   ============================================================ */
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,3vw,2.6rem)}
@media (max-width:820px){.trio{grid-template-columns:1fr}}
.trio .item{display:flex;flex-direction:column;gap:.9rem}
.trio .ico{width:48px;height:48px;border-radius:11px;display:grid;place-items:center;background:var(--paper-deep);color:var(--navy)}
.band-navy .trio .ico{background:rgba(255,255,255,.08);color:var(--accent)}
.trio .ico svg{display:block}
.trio h3{margin:0}
.trio p{margin:0;color:var(--body)}
.band-navy .trio p{color:var(--blush-soft)}

/* ============================================================
   Featured / insights cards
   ============================================================ */
.feature{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media (max-width:900px){.feature{grid-template-columns:1fr;gap:2rem}}
.feature.flip{direction:rtl}
.feature.flip>*{direction:ltr}
.feature-fig{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:16/10;background:var(--paper-deep)}
.feature-fig img{width:100%;height:100%;object-fit:cover}
.feature-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);margin:0 0 .9rem}
.feature h2{margin:0 0 1rem}
.feature .meta{font-size:.86rem;color:var(--muted);margin:0 0 .9rem;font-family:var(--font-mono)}
.feature p{color:var(--body);margin:0 0 1.4rem}

.posts{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.6rem,3vw,2.6rem)}
@media (max-width:760px){.posts{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;border-radius:var(--radius);overflow:hidden;background:var(--surface);border:1px solid var(--line);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.post-card .pfig{aspect-ratio:16/10;overflow:hidden;background:var(--paper-deep)}
.post-card .pfig img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.post-card:hover .pfig img{transform:scale(1.04)}
.post-card .pbody{padding:1.5rem 1.6rem 1.8rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.post-card .pmeta{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--navy)}
.post-card h3{margin:0}
.post-card .pex{color:var(--body);font-size:.98rem;margin:0}
.post-card .pmore{margin-top:auto;padding-top:.6rem;font-weight:600;color:var(--navy);display:inline-flex;align-items:center;gap:.4rem}
.post-card .pmore svg{transition:transform .3s var(--ease)}
.post-card:hover .pmore svg{transform:translateX(3px)}

/* ============================================================
   Resources blogroll
   ============================================================ */
.blogroll{display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(1.5rem,4vw,3rem);border-top:1px solid var(--line)}
@media (max-width:680px){.blogroll{grid-template-columns:1fr}}
.blogroll a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.3rem .2rem;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);transition:padding-left .3s var(--ease)}
.blogroll a:hover{padding-left:.6rem}
.blogroll .ra-text b{display:block;font-family:var(--font-display);font-size:1.12rem;font-weight:600}
.blogroll .ra-text span{font-size:.85rem;color:var(--muted);font-family:var(--font-mono);letter-spacing:.02em}
.blogroll .ra-arrow{color:var(--navy);flex:none}

/* ============================================================
   Testimonials  (no boxes, hairline + quote glyph)
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.8rem,3vw,3rem)}
@media (max-width:860px){.quotes{grid-template-columns:1fr}}
.quote{display:flex;flex-direction:column;gap:1.2rem;padding-top:1.6rem;border-top:2px solid var(--accent)}
.quote .mark{font-family:var(--font-display);font-size:2.6rem;line-height:.6;color:var(--blush);height:1rem}
.band-navy .quote .mark{color:var(--accent)}
.quote blockquote{margin:0;font-family:var(--font-display);font-size:1.22rem;line-height:1.45;color:var(--ink)}
.band-navy .quote blockquote{color:#fff}
.quote .who{margin-top:auto;font-size:.9rem}
.quote .who b{display:block;color:var(--ink)}
.band-navy .quote .who b{color:#fff}
.quote .who span{color:var(--muted)}
.band-navy .quote .who span{color:var(--blush-soft)}

/* ============================================================
   Team
   ============================================================ */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.6rem,3vw,2.6rem)}
@media (max-width:820px){.team{grid-template-columns:1fr}}
.member{display:flex;flex-direction:column;gap:.6rem}
.member .av{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--navy);background:var(--blush-soft);border:1px solid var(--blush)}
.member h3{margin:.4rem 0 0;font-size:1.2rem}
.member .role{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--navy)}
.member p{margin:.3rem 0 0;color:var(--body);font-size:.96rem}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{position:relative;overflow:hidden}
.cta-band .inner{position:relative;z-index:1;display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center}
@media (max-width:820px){.cta-band .inner{grid-template-columns:1fr;gap:1.6rem}}
.cta-band h2{color:#fff}
.cta-band p{color:var(--blush-soft);margin:1rem 0 0;font-size:1.1rem}
.cta-band .actions{display:flex;gap:.9rem;flex-wrap:wrap;justify-content:flex-end}
@media (max-width:820px){.cta-band .actions{justify-content:flex-start}}
.cta-glow{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;filter:blur(70px)}
.cta-glow span{position:absolute;width:30vw;height:30vw;border-radius:50%}
.cta-glow .a{left:-5%;top:-30%;background:radial-gradient(circle,rgba(242,193,78,.5),transparent 65%)}
.cta-glow .b{right:0;bottom:-40%;background:radial-gradient(circle,rgba(231,191,194,.4),transparent 65%)}

/* ============================================================
   Footer
   ============================================================ */
.site-foot{background:var(--navy-deep);color:var(--blush-soft);padding:clamp(3.5rem,6vw,5rem) 0 2.2rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:2.5rem}
@media (max-width:820px){.foot-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-brand .brand-name{color:#fff}
.foot-about{margin:1rem 0 1.4rem;max-width:30ch;color:var(--blush-soft);font-size:.96rem}
.foot-col h4{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin:0 0 1.1rem;font-weight:500}
.foot-col ul{list-style:none;margin:0;padding:0;display:grid;gap:.6rem}
.foot-col a{color:var(--blush-soft);text-decoration:none;font-size:.96rem;transition:color .25s}
.foot-col a:hover{color:#fff}
.foot-contact a{color:#fff;text-decoration:none}
.foot-contact p{margin:0 0 .7rem;font-size:.96rem}
.foot-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);font-size:.85rem;color:var(--blush-soft)}
.foot-social{display:flex;gap:.5rem}
.foot-social a{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.18);color:var(--blush-soft);text-decoration:none;font-family:var(--font-mono);font-size:.74rem;transition:background-color .25s,color .25s}
.foot-social a:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}

/* ============================================================
   Article page
   ============================================================ */
.article-hero{padding:clamp(2.5rem,6vw,4.5rem) 0 0;position:relative;overflow:hidden}
.article-hero .glow{height:46vh;opacity:.4}
.crumbs{position:relative;z-index:1;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;color:var(--muted);margin:0 0 1.6rem;display:flex;gap:.5rem;flex-wrap:wrap}
.crumbs a{color:var(--navy);text-decoration:none}
.crumbs a:hover{text-decoration:underline}
.article-head{position:relative;z-index:1;max-width:var(--readw)}
.article-head .kicker{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);margin:0 0 1.1rem}
.article-head h1{font-size:clamp(2.1rem,4.6vw,3.4rem);margin:0 0 1.2rem}
.article-head .dek{font-size:1.22rem;color:var(--body);line-height:1.5;margin:0}
.article-meta{display:flex;flex-wrap:wrap;gap:1.2rem;align-items:center;margin:1.8rem 0 0;font-size:.9rem;color:var(--muted);font-family:var(--font-mono)}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--blush);display:inline-block}

.article-figure{margin:clamp(2rem,4vw,3rem) 0 0;position:relative;z-index:1}
.article-figure .wrap{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:1024/585;background:var(--paper-deep)}
.article-figure img{width:100%;height:100%;object-fit:cover}
.article-figure figcaption{margin-top:.8rem;font-size:.84rem;color:var(--muted);font-family:var(--font-mono)}

.article-body{max-width:var(--readw);margin:clamp(2.5rem,5vw,3.5rem) auto clamp(3rem,6vw,4.5rem)}
.article-body>*{margin-left:auto;margin-right:auto}
.article-body p{font-size:1.115rem;line-height:1.78;color:var(--body);margin:0 0 1.4em}
.article-body h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:2.4em 0 .7em;color:var(--ink)}
.article-body h3{font-size:clamp(1.2rem,2vw,1.45rem);margin:1.9em 0 .5em;color:var(--ink)}
.article-body h2+p,.article-body h3+p{margin-top:0}
.article-body a{color:var(--navy);font-weight:600;text-decoration:none;background-image:linear-gradient(var(--accent),var(--accent));background-size:100% 2px;background-position:0 100%;background-repeat:no-repeat;padding-bottom:1px;transition:background-size .25s}
.article-body a:hover{background-size:100% 100%;background-color:var(--accent);color:var(--accent-ink)}
.article-body strong{font-weight:680;color:var(--ink)}
.article-body em{font-style:italic}
.article-body ul,.article-body ol{margin:0 0 1.5em;padding-left:1.3em}
.article-body li{margin:0 0 .55em;line-height:1.7;color:var(--body)}
.article-body li::marker{color:var(--navy)}
.article-body img{border-radius:var(--radius);box-shadow:var(--shadow-soft);margin:1.8em auto;width:100%;height:auto;background:var(--paper-deep)}
.article-body p:has(img){margin-bottom:1.8em}
.article-body table{width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.98rem}
.article-body th{text-align:left;font-family:var(--font-body);font-weight:680;color:var(--ink);background:var(--paper-deep);padding:.8rem 1rem;border-bottom:2px solid var(--line)}
.article-body td{padding:.8rem 1rem;border-bottom:1px solid var(--line);color:var(--body)}
.article-body section{margin:0}
.article-body section h2{margin-top:2.4em}
/* FAQ section: render flat sections as readable blocks */
.article-body section h3{margin:1.6em 0 .4em}
.article-body section section{display:block;margin:0 0 1.1em;color:var(--body);font-size:1.08rem;line-height:1.75}
.article-body [itemprop="text"]{color:var(--body)}
.article-body blockquote{margin:2em 0;padding:.4em 0 .4em 1.5rem;border-left:3px solid var(--accent);font-family:var(--font-display);font-size:1.35rem;line-height:1.45;color:var(--ink);font-style:italic}
.article-body figure{margin:2em 0}

.article-aside{max-width:var(--readw);margin:0 auto;padding:1.8rem 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.article-aside .label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);margin:0 0 .6rem}
.article-aside p{margin:0;color:var(--body)}
.article-aside a{color:var(--navy);font-weight:600}

.article-foot{max-width:var(--readw);margin:clamp(2rem,4vw,3rem) auto 0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center}

/* reveal-on-scroll for article blocks */
.r-stagger{opacity:0;transform:translateY(20px)}
.r-stagger.in{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}
@media (prefers-reduced-motion:reduce){.r-stagger{opacity:1!important;transform:none!important}}

/* ============================================================
   Contact / forms
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:start}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:2.5rem}}
.contact-info h2{margin:0 0 1rem}
.contact-info .lede{margin:0 0 2rem}
.info-list{list-style:none;margin:0;padding:0;display:grid;gap:1.5rem}
.info-list li{display:flex;gap:1rem;align-items:flex-start}
.info-list .ico{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;background:var(--paper-deep);color:var(--navy);flex:none}
.info-list .ico svg{display:block}
.info-list b{display:block;font-family:var(--font-display);font-size:1.08rem}
.info-list a{color:var(--navy);text-decoration:none;font-weight:600}
.info-list span{color:var(--body);font-size:.96rem}

.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-soft)}
.form-card h2{font-size:1.7rem;margin:0 0 .4rem}
.form-card>p{color:var(--body);margin:0 0 1.6rem;font-size:.98rem}
.field{margin:0 0 1.3rem}
.field label{display:block;font-weight:600;font-size:.94rem;color:var(--ink);margin:0 0 .5rem;letter-spacing:.005em}
.field .req{color:var(--navy);font-family:var(--font-mono);font-size:.8rem}
.field input,.field textarea{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  background:var(--paper);border:1.5px solid var(--line);border-radius:var(--radius-sm);
  padding:.85rem 1rem;transition:border-color .25s,box-shadow .25s;
}
.field input::placeholder,.field textarea::placeholder{color:#9a9385}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(46,58,85,.16)}
.field textarea{min-height:140px;resize:vertical}
.field input:user-invalid,.field textarea:user-invalid{border-color:#b4452f}
.form-actions{margin-top:1.6rem}
.form-actions .btn{width:100%;justify-content:center}
.form-note{margin:1rem 0 0;font-size:.84rem;color:var(--muted);display:flex;gap:.5rem;align-items:flex-start}
.form-note svg{flex:none;color:var(--navy);margin-top:1px}
.form-success{display:none;margin-top:1.3rem;padding:1rem 1.2rem;border-radius:var(--radius-sm);background:var(--blush-soft);border:1px solid var(--blush);color:var(--ink);font-size:.96rem;align-items:flex-start;gap:.6rem}
.form-success.show{display:flex}
.form-success svg{flex:none;color:var(--navy);margin-top:2px}

/* ============================================================
   Page hero (interior)
   ============================================================ */
.page-hero{position:relative;overflow:hidden;padding:clamp(3rem,7vw,5rem) 0 clamp(2rem,4vw,3rem)}
.page-hero .glow{height:50vh;opacity:.42}
.page-hero .inner{position:relative;z-index:1;max-width:44rem}
.page-hero h1{margin:0 0 1.2rem}
.page-hero p{font-size:1.2rem;color:var(--body);max-width:38rem;margin:0}

/* misc utility */
.text-primary{color:var(--navy)}
.mono{font-family:var(--font-mono)}
.center{text-align:center}
.mt-0{margin-top:0}
.faq-list{max-width:46rem}
.faq-item{padding:1.6rem 0;border-bottom:1px solid var(--line)}
.faq-item:first-child{border-top:1px solid var(--line)}
.faq-item h3{margin:0 0 .5rem;font-size:1.2rem}
.faq-item p{margin:0;color:var(--body)}

.split-feature{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
@media (max-width:900px){.split-feature{grid-template-columns:1fr}}
.split-feature .sf-fig{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:4/3;background:var(--paper-deep)}
.split-feature .sf-fig img{width:100%;height:100%;object-fit:cover}

.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.4rem,3vw,2.4rem)}
@media (max-width:860px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.values-grid{grid-template-columns:1fr}}
.value{padding-top:1.2rem;border-top:2px solid var(--blush)}
.value h3{margin:0 0 .5rem;font-size:1.15rem}
.value p{margin:0;color:var(--body);font-size:.96rem}
