/* ============================================================
   AUREMIND STUDIO — Oxblood Atelier editorial system
   Palette: primary #831843 · secondary #F4D9DF · accent #B0892F
            background #FBF6F1 · foreground #2A1118
   Fonts: GFS Didot (display) · Darker Grotesque (body) · B612 Mono
   ============================================================ */

:root{
  --primary:#831843;
  --secondary:#F4D9DF;
  --accent:#B0892F;
  --bg:#FBF6F1;
  --fg:#2A1118;

  --primary-12:rgba(131,24,67,.12);
  --primary-22:rgba(131,24,67,.22);
  --accent-30:rgba(176,137,47,.30);
  --fg-60:rgba(42,17,24,.60);
  --fg-45:rgba(42,17,24,.45);
  --fg-12:rgba(42,17,24,.12);

  --display:"GFS Didot",Georgia,"Times New Roman",serif;
  --body:"Darker Grotesque",-apple-system,Segoe UI,sans-serif;
  --mono:"B612 Mono",ui-monospace,Menlo,monospace;

  --radius:3px;            /* ONE corner-radius system: tight, editorial */
  --rule:1px solid var(--accent);
  --hair:1px solid var(--fg-12);

  --measure:68ch;
  --maxw:1240px;
  --pad:clamp(20px,5vw,72px);
}

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

body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family:var(--body);
  font-size:clamp(18px,1.15vw,21px);
  font-weight:500;
  line-height:1.45;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* warm layered ground */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(120% 90% at 88% -10%,rgba(244,217,223,.55),transparent 55%),
    radial-gradient(90% 70% at -8% 10%,rgba(176,137,47,.08),transparent 50%),
    linear-gradient(180deg,#FCF8F3 0%,var(--bg) 38%,#F7EFE6 100%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(42,17,24,.045) 1px,transparent 1.1px);
  background-size:4px 4px;
  mix-blend-mode:multiply;
}

img{max-width:100%;display:block}
a{color:inherit}

/* ---------- type ---------- */
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.04;margin:0;letter-spacing:.002em}
h1{font-size:clamp(2.9rem,7.2vw,6.1rem)}
h2{font-size:clamp(2rem,4.4vw,3.5rem)}
h3{font-size:clamp(1.45rem,2.4vw,2.05rem)}
p{margin:0 0 1.05em}

.kicker{
  font-family:var(--mono);
  font-size:.7rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:700;
  display:inline-flex;align-items:center;gap:.7em;
}
.kicker::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block}

.lede{font-size:clamp(1.2rem,1.7vw,1.5rem);line-height:1.4;color:var(--fg);font-weight:550}
.muted{color:var(--fg-60)}
/* non-uppercase editorial section label (restraint: not every section gets a kicker) */
.label{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--primary);display:inline-flex;align-items:center;gap:.6em}
.label::before{content:"";width:22px;height:1px;background:var(--accent);display:inline-block}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,128px)}
.section--tight{padding-block:clamp(44px,6vw,80px)}
.divider{height:1px;background:var(--accent-30);max-width:var(--maxw);margin:0 auto}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--primary);color:#fff;padding:12px 18px;z-index:200;border-radius:var(--radius)}
.skip:focus{left:12px;top:12px}

/* ---------- header / nav ---------- */
.masthead{
  position:sticky;top:0;z-index:100;
  background:rgba(251,246,241,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:var(--hair);
}
.masthead__row{
  max-width:var(--maxw);margin:0 auto;padding:14px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:baseline;gap:.55rem;text-decoration:none;color:var(--fg)}
.brand__mark{font-family:var(--display);font-size:1.7rem;letter-spacing:.01em;line-height:1}
.brand__dot{color:var(--accent)}
.brand__sub{font-family:var(--mono);font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--fg-60)}
.nav{display:flex;align-items:center;gap:clamp(14px,2vw,30px)}
.nav a{
  text-decoration:none;color:var(--fg);font-weight:650;font-size:1rem;
  letter-spacing:.01em;padding:6px 2px;border-bottom:2px solid transparent;
  transition:color .2s,border-color .2s;
}
.nav a:hover{color:var(--primary)}
.nav a[aria-current="page"]{color:var(--primary);border-bottom-color:var(--accent)}
.nav__cta{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid var(--primary)!important;color:var(--primary);border-radius:var(--radius);
  padding:9px 16px!important;font-weight:700;
}
.nav__cta:hover{background:var(--primary);color:var(--bg)}
.nav__toggle{display:none;background:none;border:1px solid var(--fg-12);border-radius:var(--radius);
  width:44px;height:40px;cursor:pointer;color:var(--fg)}

@media (max-width:860px){
  .nav{position:fixed;inset:62px 0 auto 0;flex-direction:column;align-items:flex-start;
    gap:4px;background:var(--bg);border-bottom:var(--rule);padding:14px var(--pad) 22px;
    transform:translateY(-130%);transition:transform .3s ease;box-shadow:0 24px 40px -28px rgba(42,17,24,.4)}
  .nav[data-open="true"]{transform:translateY(0)}
  .nav a{font-size:1.3rem;width:100%}
  .nav__cta{margin-top:6px}
  .nav__toggle{display:inline-flex;align-items:center;justify-content:center}
}

/* ---------- focus visibility ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,summary:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;border-radius:2px;
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;cursor:pointer;text-decoration:none;
  font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;
  padding:15px 26px;border-radius:var(--radius);border:1px solid transparent;transition:.22s;
}
.btn--solid{background:var(--primary);color:var(--bg)}
.btn--solid:hover{background:#6d1338;transform:translateY(-1px)}
.btn--ghost{border-color:var(--primary);color:var(--primary)}
.btn--ghost:hover{background:var(--primary);color:var(--bg)}
/* the one underline-CTA, accent */
.btn-underline{
  display:inline-flex;align-items:center;gap:.5em;font-weight:700;text-decoration:none;color:var(--primary);
  font-size:1.02rem;border-bottom:1px solid var(--accent);padding-bottom:3px;transition:gap .2s,color .2s;
}
.btn-underline:hover{gap:.9em;color:var(--accent)}
.btn-underline .arr{color:var(--accent);transition:transform .2s}
.btn-underline:hover .arr{transform:translateX(3px)}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding-top:clamp(40px,6vw,76px);padding-bottom:clamp(56px,8vw,108px)}
.hero__grid{
  max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad);
  display:grid;grid-template-columns:1.18fr .82fr;gap:clamp(28px,4vw,64px);align-items:end;
}
.hero__eyebrow{margin-bottom:24px}
.hero h1{margin:0 0 22px}
.hero h1 em{font-style:italic;color:var(--primary)}
.hero__sub{max-width:34ch;color:var(--fg);font-size:clamp(1.15rem,1.5vw,1.42rem);font-weight:550;margin:0 0 30px}
.hero__cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.hero__figure{position:relative}
.hero__media{
  position:relative;border-radius:var(--radius);overflow:hidden;
  aspect-ratio:4/5;border:1px solid var(--fg-12);
  box-shadow:0 36px 70px -40px rgba(42,17,24,.6);
}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(42,17,24,.28))}
.hero__rule{height:1px;background:var(--accent);margin:30px 0 0}
.hero__stamp{
  position:absolute;left:-14px;bottom:26px;background:var(--bg);border:var(--rule);
  border-radius:var(--radius);padding:12px 16px;font-family:var(--mono);font-size:.66rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--primary);max-width:190px;line-height:1.5;
  box-shadow:0 18px 30px -22px rgba(42,17,24,.5);
}
.hero__stamp b{color:var(--accent)}
@media (max-width:880px){
  .hero__grid{grid-template-columns:1fr;gap:36px}
  .hero__media{aspect-ratio:16/11}
  .hero__sub{max-width:46ch}
}

/* ---------- ledger / stat strip ---------- */
.ledger{display:grid;grid-template-columns:repeat(4,1fr);border-top:var(--rule);border-bottom:var(--hair)}
.ledger__cell{padding:26px clamp(8px,2vw,24px);border-left:var(--hair)}
.ledger__cell:first-child{border-left:none}
.ledger__num{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.6rem);line-height:1;color:var(--primary)}
.ledger__num small{font-size:.45em;color:var(--accent);vertical-align:super;margin-left:.1em}
.ledger__lbl{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-60);margin-top:12px}
@media (max-width:720px){.ledger{grid-template-columns:repeat(2,1fr)}
  .ledger__cell:nth-child(3){border-left:none}
  .ledger__cell:nth-child(odd){border-left:none}
}

/* ============================================================
   EDITORIAL COLUMNS (justified, drop-cap)
   ============================================================ */
.editorial{display:grid;grid-template-columns:.34fr .66fr;gap:clamp(24px,4vw,60px);align-items:start}
.editorial__aside{position:sticky;top:96px}
.editorial__aside .kicker{margin-bottom:18px}
.editorial__aside h2{margin-bottom:18px}
.editorial__cols{columns:2;column-gap:42px;column-rule:var(--hair);text-align:justify;hyphens:auto}
.editorial__cols p{break-inside:avoid}
.editorial__cols p:first-of-type:first-letter{
  font-family:var(--display);float:left;font-size:4.1em;line-height:.72;
  padding:.06em .12em 0 0;color:var(--primary);
}
@media (max-width:880px){
  .editorial{grid-template-columns:1fr}
  .editorial__aside{position:static}
  .editorial__cols{columns:1}
}

/* ---------- pull quote break ---------- */
.pullquote{border-top:var(--rule);border-bottom:var(--rule);padding:clamp(30px,5vw,56px) 0;margin:0}
.pullquote blockquote{margin:0;max-width:24ch}
.pullquote q{font-family:var(--display);font-size:clamp(1.9rem,4.4vw,3.4rem);line-height:1.08;quotes:none}
.pullquote q::before{content:"\201C";color:var(--accent)}
.pullquote q::after{content:"\201D";color:var(--accent)}
.pullquote cite{display:block;margin-top:22px;font-style:normal;font-family:var(--mono);
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-60)}

/* ============================================================
   SERVICES
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--fg-12);border:var(--hair)}
.svc{
  background:var(--bg);padding:clamp(26px,3vw,40px);display:flex;flex-direction:column;gap:14px;
  position:relative;transition:background .3s;
}
.svc:hover{background:#FCF8F3}
.svc__idx{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--accent);font-weight:700}
.svc h3{font-size:clamp(1.5rem,2.2vw,2rem)}
.svc p{margin:0;color:var(--fg-60);font-size:1.02rem;line-height:1.42}
.svc__meta{margin-top:auto;padding-top:14px;border-top:var(--hair);font-family:var(--mono);
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}
@media (max-width:720px){.svc-grid{grid-template-columns:1fr}}

/* ============================================================
   JOURNAL BENTO (article tiles)
   ============================================================ */
.bento{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(16px,2vw,24px)}
.tile{
  position:relative;display:flex;flex-direction:column;text-decoration:none;color:var(--fg);
  background:#FCF8F3;border:1px solid var(--fg-12);border-radius:var(--radius);overflow:hidden;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.tile:hover{transform:translateY(-4px);box-shadow:0 30px 50px -34px rgba(42,17,24,.5);border-color:var(--accent-30)}
.tile--lg{grid-column:span 4}
.tile--sm{grid-column:span 2}
.tile--wide{grid-column:span 3}
.tile__media{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;background:var(--secondary)}
.tile--lg .tile__media{aspect-ratio:16/9}
.tile__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.tile:hover .tile__media img{transform:scale(1.04)}
.tile__body{padding:20px clamp(18px,2vw,26px) 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.tile__cat{font-family:var(--mono);font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700}
.tile h3{font-size:clamp(1.3rem,1.9vw,1.7rem);line-height:1.08}
.tile--lg h3{font-size:clamp(1.7rem,2.6vw,2.3rem)}
.tile__excerpt{color:var(--fg-60);font-size:.98rem;line-height:1.4;margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tile--lg .tile__excerpt{-webkit-line-clamp:3}
.tile__foot{margin-top:auto;padding-top:14px;display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-45);
  border-top:var(--hair)}
.tile__foot .arr{color:var(--accent)}
[dir="rtl"]{direction:rtl}
@media (max-width:900px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .tile--lg,.tile--sm,.tile--wide{grid-column:span 1}
}
@media (max-width:560px){.bento{grid-template-columns:1fr}}

/* ============================================================
   RESOURCES blogroll
   ============================================================ */
.resources{border-top:var(--rule)}
.resource-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:clamp(14px,3vw,40px);
  padding:24px 0;border-bottom:var(--hair);transition:padding-left .25s;
}
.resource-row:hover{padding-left:10px}
.resource-row__idx{font-family:var(--mono);font-size:.78rem;color:var(--accent);font-weight:700}
.resource-row__main{display:flex;flex-direction:column;gap:6px}
.resource-row__main h3{font-size:clamp(1.3rem,2vw,1.85rem)}
.resource-row__note{color:var(--fg-60);font-size:.98rem}
.resource-row a.resource-link{font-weight:700;color:var(--primary);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:2px}
.resource-row a.resource-link:hover{color:var(--accent)}
@media (max-width:680px){.resource-row{grid-template-columns:auto 1fr}.resource-row__cta{grid-column:1/-1;padding-left:34px}}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px)}
.qcard{
  background:#FCF8F3;border:1px solid var(--fg-12);border-radius:var(--radius);padding:clamp(24px,2.6vw,34px);
  display:flex;flex-direction:column;gap:18px;
}
.qcard__mark{font-family:var(--display);font-size:3rem;line-height:.4;color:var(--accent);height:.5em}
.qcard p{font-size:1.08rem;line-height:1.42;color:var(--fg);margin:0;flex:1}
.qcard__who{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:var(--hair)}
.qcard__av{width:42px;height:42px;border-radius:50%;background:var(--primary);color:var(--bg);
  display:grid;place-items:center;font-family:var(--display);font-size:1.1rem}
.qcard__name{font-weight:700;line-height:1.15}
.qcard__role{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-60)}
@media (max-width:860px){.quotes{grid-template-columns:1fr}}

/* ============================================================
   TEAM
   ============================================================ */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.5vw,32px)}
.member__photo{aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;border:1px solid var(--fg-12);background:var(--secondary)}
.member__photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.92)}
.member h3{font-size:1.5rem;margin:16px 0 4px}
.member__role{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.member p{margin:10px 0 0;color:var(--fg-60);font-size:.98rem;line-height:1.4}
@media (max-width:760px){.team{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.team{grid-template-columns:1fr}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,72px);align-items:start}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.field label{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--primary);font-weight:700}
.field input,.field textarea{
  font-family:var(--body);font-size:1.08rem;font-weight:550;color:var(--fg);
  background:#FCF8F3;border:1px solid var(--fg-12);border-radius:var(--radius);padding:14px 16px;width:100%;
  transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-30);outline:none}
.field textarea{min-height:140px;resize:vertical}
.contact-aside{border-top:var(--rule);padding-top:26px}
.contact-aside dt{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-top:20px}
.contact-aside dd{margin:6px 0 0;font-size:1.1rem}
.contact-aside a{color:var(--primary);text-decoration:none;border-bottom:1px solid var(--accent-30)}
.form-note{font-family:var(--mono);font-size:.7rem;letter-spacing:.05em;color:var(--fg-60);margin-top:6px}
.form-success{display:none;margin-top:18px;padding:14px 18px;border:var(--rule);border-radius:var(--radius);
  background:var(--secondary);color:var(--primary);font-weight:650}
.form-success[data-show="true"]{display:block}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{border-top:var(--rule);margin-top:30px;background:linear-gradient(180deg,transparent,rgba(244,217,223,.32))}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-block:clamp(48px,6vw,80px)}
.foot__brand .brand__mark{font-size:2.1rem}
.foot__brand p{max-width:36ch;color:var(--fg-60);margin-top:16px;font-size:1rem}
.foot h4{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:16px}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot ul a{text-decoration:none;color:var(--fg);font-weight:600}
.foot ul a:hover{color:var(--primary)}
.foot__bar{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;
  padding-block:24px;border-top:var(--hair);font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--fg-60)}
@media (max-width:760px){.foot__top{grid-template-columns:1fr 1fr}.foot__brand{grid-column:1/-1}}

/* ============================================================
   ARTICLE PAGE
   ============================================================ */
.article-head{padding-top:clamp(30px,5vw,60px);padding-bottom:clamp(26px,4vw,46px)}
.article-head .kicker{margin-bottom:20px}
.article-head h1{font-size:clamp(2.3rem,5.4vw,4.4rem);max-width:18ch;margin-bottom:24px}
.article-meta{display:flex;flex-wrap:wrap;gap:22px;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--fg-60);border-top:var(--hair);padding-top:20px}
.article-meta b{color:var(--primary)}
.article-hero{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:16/8;
  border:1px solid var(--fg-12);box-shadow:0 30px 60px -40px rgba(42,17,24,.5);margin-bottom:clamp(30px,5vw,56px)}
.article-hero img{width:100%;height:100%;object-fit:cover}

.prose{max-width:74ch;margin:0 auto;font-size:1.12rem;line-height:1.62}
.prose>p{text-align:justify;hyphens:auto}
.prose[dir="rtl"]>p,.prose[dir="rtl"]{text-align:right}
.prose h2{font-size:clamp(1.7rem,3vw,2.5rem);margin:1.9em 0 .6em;padding-top:.4em;border-top:var(--hair)}
.prose h3{font-size:clamp(1.35rem,2.1vw,1.7rem);margin:1.5em 0 .5em;color:var(--primary)}
.prose a{color:var(--primary);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:1px;font-weight:650}
.prose a:hover{color:var(--accent)}
.prose strong{font-weight:750}
.prose em{font-style:italic}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.3em}
.prose[dir="rtl"] ul,.prose[dir="rtl"] ol{padding-left:0;padding-right:1.3em}
.prose li{margin-bottom:.55em}
.prose li::marker{color:var(--accent)}
.prose img{border-radius:var(--radius);border:1px solid var(--fg-12);margin:1.6em 0;width:100%;height:auto}
.prose figure{margin:1.8em 0}
.prose figure img{margin:0}
.prose figcaption{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--fg-60);margin-top:10px;text-align:center}
.prose table{width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.96rem}
.prose th,.prose td{border:var(--hair);padding:12px 14px;text-align:left;vertical-align:top}
.prose th{background:var(--secondary);font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--primary);font-weight:700}
.prose section h2{border-top:var(--rule)}
.prose [itemprop="name"]{font-family:var(--display);font-size:1.3rem;color:var(--fg);margin:1.2em 0 .35em;font-weight:400}
.prose [itemprop="text"]{color:var(--fg-60);margin-bottom:.4em}

.article-foot{border-top:var(--rule);margin-top:clamp(40px,6vw,72px);padding-top:36px}
.article-cta{background:var(--primary);color:var(--bg);border-radius:var(--radius);padding:clamp(30px,4vw,52px);
  display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center;margin-top:30px}
.article-cta h3{color:var(--bg);max-width:18ch}
.article-cta .btn--solid{background:var(--bg);color:var(--primary)}
.article-cta .btn--solid:hover{background:var(--secondary)}

.read-more{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
@media (max-width:760px){.read-more{grid-template-columns:1fr}}

/* ---------- page hero (sub pages) ---------- */
.page-hero{padding-top:clamp(40px,6vw,80px);padding-bottom:clamp(28px,4vw,52px)}
.page-hero .kicker{margin-bottom:22px}
.page-hero h1{max-width:16ch;margin-bottom:22px}
.page-hero p{max-width:54ch;color:var(--fg-60);font-size:clamp(1.15rem,1.6vw,1.4rem)}

/* feature image band */
.band{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:21/8;border:1px solid var(--fg-12)}
.band img{width:100%;height:100%;object-fit:cover}
.band::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(42,17,24,.4),transparent 60%)}

/* two-up about */
.about-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);align-items:center}
.about-split img{border-radius:var(--radius);border:1px solid var(--fg-12);aspect-ratio:4/5;object-fit:cover;width:100%}
@media (max-width:820px){.about-split{grid-template-columns:1fr}}

.value-list{list-style:none;margin:0;padding:0}
.value-list li{padding:22px 0;border-bottom:var(--hair);display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start}
.value-list .vi{font-family:var(--mono);color:var(--accent);font-weight:700;font-size:.8rem}
.value-list h3{font-size:1.4rem;margin-bottom:6px}
.value-list p{margin:0;color:var(--fg-60);font-size:1rem}

/* ============================================================
   MOTION — reveal + count-up (collapses under reduced-motion)
   ============================================================ */
.reveal{opacity:0;transform:translateY(24px)}
.is-in{opacity:1;transform:none;transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .tile,.tile__media img,.btn--solid{transition:none!important}
  *{scroll-behavior:auto!important}
}
