/* ============================================================
   Self-hosted fonts (Fraunces + Inter)
   font-display: swap → no FOIT, sub-100ms LCP
   ============================================================ */

/* Fraunces — variable font, weight axis 300..600 */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 600;
  font-display: swap;
  src: url('/assets/fonts/fraunces-300600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 600;
  font-display: swap;
  src: url('/assets/fonts/fraunces-300600-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Inter — Google now serves one variable file covering 400..700 */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/inter-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/inter-400-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* =============================================================
   fasciamia.com — design system
   Editorial, female-first, fascia-centric. Serif + sans pairing.
   ============================================================= */

:root {
  /* Palette — warm anatomical neutrals */
  --c-clay:       #c44536;   /* primary, fascia */
  --c-clay-deep:  #8e2f24;
  --c-sage:       #7a9683;   /* secondary */
  --c-sage-deep:  #4f6b58;
  --c-gold:       #c89b56;   /* accent */
  --c-cream:      #faf6f0;
  --c-cream-2:    #f1ead8;
  --c-ink:        #1a1612;
  --c-ink-2:      #3a342c;
  --c-mute:       #807467;
  --c-line:       #e6dfd0;
  --c-white:      #ffffff;
  --c-rose:       #efd9d0;

  /* Fluid type */
  --fs-1: clamp(2.6rem, 5.5vw + 1rem, 5.4rem);
  --fs-2: clamp(2rem, 3.2vw + 1rem, 3.6rem);
  --fs-3: clamp(1.5rem, 1.6vw + 1rem, 2.25rem);
  --fs-4: clamp(1.2rem, 0.6vw + 1rem, 1.5rem);
  --fs-body: 1.0625rem;
  --fs-small: 0.875rem;
  --fs-mono: 0.8125rem;

  /* Rhythm */
  --sp-1: 0.5rem;
  --sp-2: 1rem;
  --sp-3: 1.5rem;
  --sp-4: 2rem;
  --sp-5: 3rem;
  --sp-6: 4.5rem;
  --sp-7: 6.5rem;

  --radius: 14px;
  --radius-lg: 22px;
  --shadow-1: 0 1px 2px rgba(26,22,18,.04), 0 4px 14px rgba(26,22,18,.06);
  --shadow-2: 0 6px 24px rgba(26,22,18,.10), 0 24px 60px rgba(26,22,18,.10);
  --maxw: 1240px;
  --maxw-prose: 68ch;

  --ff-serif: "Fraunces", "Cormorant Garamond", "Iowan Old Style", "Apple Garamond", Georgia, serif;
  --ff-sans:  "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --ff-mono:  ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;
}

@media (prefers-color-scheme: dark) {
  :root {
    --c-cream: #14110d;
    --c-cream-2: #1c1813;
    --c-ink: #f5efe5;
    --c-ink-2: #d8d0c2;
    --c-line: #2c261d;
    --c-white: #1a1611;
    --c-mute: #9a8e7d;
  }
}

* { box-sizing: border-box; }
*::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}

body {
  margin: 0;
  background: var(--c-cream);
  color: var(--c-ink);
  font-family: var(--ff-sans);
  font-size: var(--fs-body);
  line-height: 1.6;
  font-feature-settings: "ss01", "kern", "liga";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg, video { max-width: 100%; height: auto; display: block; }
figure { margin: 0; }
a { color: var(--c-clay-deep); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; transition: color .2s; }
a:hover { color: var(--c-clay); }
button { font: inherit; cursor: pointer; }
hr { border: 0; height: 1px; background: var(--c-line); margin: var(--sp-5) 0; }
small { color: var(--c-mute); }

/* Typography */
h1, h2, h3, h4 {
  font-family: var(--ff-serif);
  font-weight: 480;
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--c-ink);
  margin: 0 0 var(--sp-3);
  font-variation-settings: "opsz" 144, "SOFT" 30;
}
h1 { font-size: var(--fs-1); font-weight: 380; }
h2 { font-size: var(--fs-2); line-height: 1.12; margin-top: var(--sp-6); }
h3 { font-size: var(--fs-3); line-height: 1.2; margin-top: var(--sp-5); }
h4 { font-size: var(--fs-4); line-height: 1.3; margin-top: var(--sp-4); }
p  { margin: 0 0 1em; }

.eyebrow {
  font-family: var(--ff-sans);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-clay);
  font-weight: 600;
  margin: 0 0 var(--sp-2);
  display: inline-flex;
  align-items: center;
  gap: 0.6em;
}
.eyebrow::before {
  content: "";
  width: 1.6em; height: 1px;
  background: currentColor;
  display: inline-block;
}

.lede {
  font-family: var(--ff-serif);
  font-weight: 360;
  font-size: clamp(1.25rem, 1.2vw + 1rem, 1.65rem);
  line-height: 1.4;
  color: var(--c-ink-2);
  letter-spacing: -0.005em;
}

/* Skip link */
.skip-link {
  position: absolute; left: -9999px;
  background: var(--c-ink); color: var(--c-cream);
  padding: .75rem 1rem; border-radius: 8px; z-index: 1000;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* Layout */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--sp-3); }
.wrap-narrow { max-width: 880px; margin: 0 auto; padding: 0 var(--sp-3); }
.prose { max-width: var(--maxw-prose); }

section { padding: var(--sp-6) 0; position: relative; }
section.tight { padding: var(--sp-5) 0; }

/* Header */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(250,246,240,0.82);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--c-line);
}
.site-header__inner {
  display: flex; align-items: center; gap: var(--sp-4);
  height: 72px;
  max-width: var(--maxw); margin: 0 auto; padding: 0 var(--sp-3);
}
.brand {
  display: inline-flex; align-items: baseline; gap: .35rem;
  font-family: var(--ff-serif); font-size: 1.6rem; font-weight: 420;
  letter-spacing: -0.025em; text-decoration: none; color: var(--c-ink);
}
.brand b { font-weight: 480; color: var(--c-clay); font-style: italic; }
.brand i { color: var(--c-clay); font-style: normal; }
.brand-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--c-clay); display: inline-block; }

.nav { margin-left: auto; display: flex; align-items: center; gap: var(--sp-3); }
.nav-list { display: flex; gap: 1.5rem; list-style: none; padding: 0; margin: 0; }
.nav-list a {
  font-size: .94rem; color: var(--c-ink-2); text-decoration: none; font-weight: 500;
  padding: .4rem .2rem; border-bottom: 1px solid transparent;
}
.nav-list a:hover { color: var(--c-clay); border-color: var(--c-clay); }
@media (max-width: 900px) {
  .nav-list { display: none; position: absolute; top: 72px; left: 0; right: 0; background: var(--c-cream); border-bottom: 1px solid var(--c-line); flex-direction: column; padding: 1rem 1.5rem; }
  .nav-list.open { display: flex; }
  .nav-toggle { display: inline-flex !important; }
}
.nav-toggle {
  display: none; align-items: center; justify-content: center;
  width: 42px; height: 42px; border-radius: 10px;
  background: transparent; border: 1px solid var(--c-line); color: var(--c-ink);
}
.nav-cta {
  background: var(--c-ink); color: var(--c-cream); text-decoration: none;
  padding: .6rem 1rem; border-radius: 999px; font-size: .88rem; font-weight: 600;
}
.nav-cta:hover { background: var(--c-clay); color: var(--c-cream); }

.nav-search {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  margin-right: .25rem;
  border-radius: 999px;
  color: var(--c-ink);
  text-decoration: none;
  transition: background-color .15s, color .15s;
}
.nav-search:hover { background: var(--c-cream-2); color: var(--c-clay); }
.nav-search:focus-visible { outline: 2px solid var(--c-clay); outline-offset: 2px; }

.lang-toggle {
  display: inline-flex; align-items: center;
  padding: 3px; border: 1px solid var(--c-line); border-radius: 999px;
  background: var(--c-cream-2);
  margin-right: .4rem;
}
.lang-toggle__btn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 28px;
  padding: 0 .55rem; border-radius: 999px;
  font: 700 .72rem/1 var(--ff-sans);
  letter-spacing: 0.06em; color: var(--c-mute);
  text-decoration: none; transition: background-color .15s, color .15s;
}
.lang-toggle__btn:hover { color: var(--c-ink); }
.lang-toggle__btn.is-active { background: var(--c-ink); color: var(--c-cream); }
@media (max-width: 900px) { .lang-toggle { display: none; } }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: .55rem; padding: .85rem 1.4rem;
  font: 600 .94rem/1 var(--ff-sans);
  border-radius: 999px; text-decoration: none;
  transition: transform .15s, background-color .2s, color .2s, box-shadow .2s;
  border: 1px solid transparent; white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--c-clay); color: var(--c-cream); }
.btn-primary:hover { background: var(--c-clay-deep); color: var(--c-cream); }
.btn-dark { background: var(--c-ink); color: var(--c-cream); }
.btn-dark:hover { background: var(--c-clay); color: var(--c-cream); }
.btn-ghost { background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.btn-ghost:hover { background: var(--c-ink); color: var(--c-cream); }
.btn-cream { background: var(--c-cream); color: var(--c-ink); }
.btn-link { padding: 0; background: transparent; color: var(--c-clay); border: 0; }
.btn-link::after { content: "→"; margin-left: .35em; transition: transform .2s; }
.btn-link:hover::after { transform: translateX(3px); }

/* Hero */
.hero {
  position: relative; overflow: hidden;
  padding: clamp(3rem, 6vw, 7rem) 0 clamp(3rem, 5vw, 5rem);
  background:
    radial-gradient(ellipse 80% 60% at 80% 10%, rgba(196,69,54,0.12), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(122,150,131,0.12), transparent 60%),
    var(--c-cream);
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 800'><defs><pattern id='p' x='0' y='0' width='80' height='80' patternUnits='userSpaceOnUse'><path d='M0 40 Q 20 0 40 40 T 80 40' stroke='%23c4453610' fill='none'/></pattern></defs><rect width='800' height='800' fill='url(%23p)'/></svg>");
  background-size: 600px 600px;
  opacity: .9; pointer-events: none;
}
.hero__inner { position: relative; }
.hero__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--sp-6); align-items: center; }
@media (max-width: 880px) { .hero__grid { grid-template-columns: 1fr; gap: var(--sp-4); } }
.hero h1 .stress { color: var(--c-clay); font-style: italic; font-weight: 360; }
.hero .lede { max-width: 38ch; }
.hero__actions { display: flex; gap: .8rem; flex-wrap: wrap; margin-top: var(--sp-3); }
.hero__meta { display: flex; gap: 1.6rem; margin-top: var(--sp-4); flex-wrap: wrap; }
.hero__meta div { font-size: .85rem; color: var(--c-mute); }
.hero__meta strong { display: block; font-family: var(--ff-serif); font-size: 1.4rem; color: var(--c-ink); font-weight: 480; }

.hero__art {
  aspect-ratio: 4/5; border-radius: var(--radius-lg);
  background:
    linear-gradient(160deg, #f3d3c8 0%, #c89b56 60%, #7a9683 100%);
  position: relative; overflow: hidden;
  box-shadow: var(--shadow-2);
}
.hero__art svg { position: absolute; inset: 0; width: 100%; height: 100%; }

/* Trust strip */
.trust {
  border-block: 1px solid var(--c-line);
  background: var(--c-cream-2);
  padding: var(--sp-3) 0;
}
.trust__inner { display: flex; flex-wrap: wrap; gap: var(--sp-4); align-items: center; justify-content: space-between; }
.trust__label { font-size: .78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-mute); font-weight: 600; }
.trust__logos { display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-4); font-family: var(--ff-serif); font-size: 1.05rem; color: var(--c-ink-2); }
.trust__logos span { opacity: .8; }

/* Cards & grids */
.grid { display: grid; gap: var(--sp-3); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 980px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

.card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-3) var(--sp-4);
  transition: transform .2s, box-shadow .25s, border-color .2s;
  display: flex; flex-direction: column; gap: .6rem;
  text-decoration: none; color: inherit;
  position: relative;
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); border-color: rgba(196,69,54,0.5); }
.card__kicker { font-size: .72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-clay); font-weight: 700; }
.card h3 { font-size: 1.4rem; margin: 0; font-weight: 460; }
.card p { color: var(--c-ink-2); margin: 0; }
.card__tag { font-size: .75rem; color: var(--c-mute); display: inline-flex; gap: .3rem; align-items: center; }
.card__tag::before { content: "·"; }

.pillar-card {
  min-height: 280px;
  padding: var(--sp-4);
  background:
    linear-gradient(180deg, transparent 65%, rgba(26,22,18,0.85)),
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.15), transparent 50%),
    var(--card-bg, linear-gradient(140deg, #c44536, #8e2f24));
  color: var(--c-cream);
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column; justify-content: space-between;
  text-decoration: none; overflow: hidden;
  position: relative;
}
.pillar-card:hover { color: var(--c-cream); }
.pillar-card__num { font-family: var(--ff-serif); font-size: 2rem; opacity: .8; }
.pillar-card h3 { color: var(--c-cream); font-size: 1.6rem; margin-bottom: .3rem; }
.pillar-card p  { color: rgba(250,246,240,0.85); font-size: .92rem; margin: 0; }
.pillar-card .arrow { position: absolute; top: var(--sp-4); right: var(--sp-4); font-size: 1.2rem; }

.pc-A { --card-bg: linear-gradient(140deg, #c44536 0%, #6d1f17 100%); }
.pc-B { --card-bg: linear-gradient(140deg, #7a9683 0%, #2f4838 100%); }
.pc-C { --card-bg: linear-gradient(140deg, #c89b56 0%, #6e4d1d 100%); }
.pc-D { --card-bg: linear-gradient(140deg, #b9745f 0%, #5e3225 100%); }
.pc-E { --card-bg: linear-gradient(140deg, #8e6f8a 0%, #3e2d3c 100%); }
.pc-F { --card-bg: linear-gradient(140deg, #4f6b58 0%, #1f2e25 100%); }
.pc-G { --card-bg: linear-gradient(140deg, #c25c4a 0%, #6b1f17 100%); }
.pc-H { --card-bg: linear-gradient(140deg, #aa7b50 0%, #4b3413 100%); }
.pc-I { --card-bg: linear-gradient(140deg, #d49a8b 0%, #7c4133 100%); }
.pc-J { --card-bg: linear-gradient(140deg, #5d6e7b 0%, #25313b 100%); }

/* Modality chips */
.chip {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .35rem .7rem; font-size: .78rem;
  background: var(--c-cream-2); border: 1px solid var(--c-line);
  border-radius: 999px; color: var(--c-ink-2); text-decoration: none;
  font-weight: 500;
}
.chip:hover { background: var(--c-ink); color: var(--c-cream); border-color: var(--c-ink); }
.chip-row { display: flex; flex-wrap: wrap; gap: .5rem; }

/* Number callouts */
.stat-row { display: grid; grid-template-columns: repeat(4,1fr); gap: var(--sp-3); }
@media (max-width: 900px) { .stat-row { grid-template-columns: repeat(2,1fr); } }
.stat {
  background: var(--c-white); border: 1px solid var(--c-line);
  border-radius: var(--radius); padding: var(--sp-3);
}
.stat__n { font-family: var(--ff-serif); font-size: clamp(2rem, 3vw, 3rem); color: var(--c-clay); font-weight: 380; line-height: 1; }
.stat__l { font-size: .9rem; color: var(--c-ink-2); margin-top: .4rem; }

/* TOC */
.toc {
  border: 1px solid var(--c-line); border-radius: var(--radius);
  padding: var(--sp-3); background: var(--c-cream-2);
  position: sticky; top: 92px;
}
.toc h4 { font-family: var(--ff-sans); font-size: .78rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-mute); margin: 0 0 1rem; font-weight: 700; }
.toc ol { list-style: none; padding: 0; margin: 0; counter-reset: t; }
.toc li { counter-increment: t; margin-bottom: .55rem; line-height: 1.3; }
.toc li::before { content: counter(t, decimal-leading-zero); display: inline-block; width: 2.2em; font-family: var(--ff-mono); font-size: .72rem; color: var(--c-mute); }
.toc a { text-decoration: none; color: var(--c-ink-2); font-size: .9rem; }
.toc a:hover { color: var(--c-clay); }

/* Article layout */
.article-grid {
  display: grid; grid-template-columns: 280px minmax(0,1fr) 280px; gap: var(--sp-5);
}
@media (max-width: 1100px) { .article-grid { grid-template-columns: 1fr; } .article-grid > aside { position: static; } }

.article-body { max-width: var(--maxw-prose); }
.article-body p:first-of-type::first-letter {
  font-family: var(--ff-serif); float: left; font-size: 4.2rem;
  line-height: .85; padding: .2rem .55rem 0 0; color: var(--c-clay);
  font-weight: 360;
}
.article-body p, .article-body ul, .article-body ol { font-size: 1.075rem; line-height: 1.65; color: var(--c-ink-2); }
.article-body ul, .article-body ol { padding-left: 1.4rem; }
.article-body li { margin-bottom: .55rem; }
.article-body strong { color: var(--c-ink); font-weight: 660; }
.article-body em { color: var(--c-ink); }
.article-body h2 a, .article-body h3 a { color: inherit; text-decoration: none; }

.pull {
  font-family: var(--ff-serif); font-weight: 360;
  font-size: clamp(1.4rem, 1.6vw + 1rem, 2.2rem);
  line-height: 1.2; letter-spacing: -0.01em;
  border-left: 3px solid var(--c-clay); padding: .5rem 0 .5rem 1.5rem;
  margin: var(--sp-5) 0; color: var(--c-ink);
}
.pull cite { display: block; font-family: var(--ff-sans); font-size: .9rem; font-style: normal; color: var(--c-mute); margin-top: .8rem; letter-spacing: 0.05em; text-transform: uppercase; }

.callout {
  background: linear-gradient(180deg, var(--c-cream-2), transparent);
  border: 1px solid var(--c-line);
  border-left: 4px solid var(--c-clay);
  padding: var(--sp-3) var(--sp-4);
  border-radius: 8px;
  margin: var(--sp-4) 0;
}
.callout__label { font-size: .76rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--c-clay); font-weight: 700; margin-bottom: .4rem; }
.callout-warn { border-left-color: var(--c-gold); }
.callout-warn .callout__label { color: var(--c-gold); }

/* FAQ accordion */
.faq { border-top: 1px solid var(--c-line); }
.faq-item { border-bottom: 1px solid var(--c-line); }
.faq-item summary {
  list-style: none; cursor: pointer; padding: 1.2rem 0;
  display: flex; gap: 1rem; align-items: baseline; justify-content: space-between;
  font-family: var(--ff-serif); font-size: 1.25rem; font-weight: 480; color: var(--c-ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+"; font-size: 1.6rem; font-family: var(--ff-sans); font-weight: 300;
  color: var(--c-clay); transition: transform .2s;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item .a { padding-bottom: 1.4rem; color: var(--c-ink-2); }
.faq-item .a p { margin: 0; }

/* Video facade */
.video {
  position: relative; aspect-ratio: 16/9; overflow: hidden;
  border-radius: var(--radius); background: #111; cursor: pointer;
  box-shadow: var(--shadow-2);
}
.video__thumb { width: 100%; height: 100%; object-fit: cover; opacity: .9; transition: opacity .25s; }
.video:hover .video__thumb { opacity: 1; }
.video__play {
  position: absolute; inset: 50% 0 0 50%; transform: translate(-50%, -50%);
  width: 76px; height: 76px; border-radius: 50%;
  background: rgba(196,69,54,0.95); color: white;
  display: grid; place-items: center; box-shadow: 0 8px 30px rgba(0,0,0,0.3);
  pointer-events: none;
}
.video__play svg { width: 30px; height: 30px; margin-left: 4px; }
.video__meta {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 1.1rem 1.2rem 1rem;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
  color: white;
}
.video__meta h4 { color: white; font-size: 1.05rem; margin: 0 0 .25rem; }
.video__meta small { color: rgba(255,255,255,0.75); }

/* Source list */
.sources { columns: 2; column-gap: var(--sp-4); }
@media (max-width: 720px) { .sources { columns: 1; } }
.sources li { break-inside: avoid; margin-bottom: .6rem; font-size: .92rem; }
.sources a { word-break: break-word; }

/* Sidebar (practitioner) */
.practitioner-box {
  background: var(--c-ink); color: var(--c-cream);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
  position: relative; overflow: hidden;
}
.practitioner-box h3 { color: var(--c-cream); margin-top: 0; font-size: 1.5rem; }
.practitioner-box p { color: rgba(250,246,240,0.82); font-size: .96rem; line-height: 1.55; }
.practitioner-box .btn-cream:hover { background: var(--c-clay); color: var(--c-cream); }
.practitioner-box::after {
  content: ""; position: absolute; right: -80px; bottom: -80px;
  width: 220px; height: 220px; border-radius: 50%;
  background: radial-gradient(circle, rgba(196,69,54,0.6), transparent 70%);
  pointer-events: none;
}

/* Newsletter */
.newsletter {
  background:
    radial-gradient(ellipse 60% 60% at 80% 0%, rgba(196,69,54,0.18), transparent 50%),
    var(--c-ink);
  color: var(--c-cream);
  border-radius: var(--radius-lg);
  padding: var(--sp-6) var(--sp-5);
  display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--sp-4);
}
@media (max-width: 800px) { .newsletter { grid-template-columns: 1fr; padding: var(--sp-4); } }
.newsletter h2 { color: var(--c-cream); margin-top: 0; }
.newsletter p { color: rgba(250,246,240,0.78); }
.newsletter form { display: flex; gap: .6rem; flex-wrap: wrap; }
.newsletter input[type=email] {
  flex: 1 1 220px; padding: .9rem 1rem; border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.06); color: white; border-radius: 999px;
  font: 500 1rem var(--ff-sans);
}
.newsletter input::placeholder { color: rgba(255,255,255,0.5); }

/* Footer */
.site-footer {
  background: var(--c-ink); color: var(--c-cream-2);
  padding: var(--sp-6) 0 var(--sp-3);
  margin-top: var(--sp-7);
}
.site-footer a { color: var(--c-cream-2); text-decoration: none; }
.site-footer a:hover { color: var(--c-clay); }
.footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: var(--sp-4);
}
@media (max-width: 900px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-grid h4 { color: var(--c-cream); font-family: var(--ff-sans); font-size: .78rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700; margin: 0 0 1rem; }
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin-bottom: .5rem; font-size: .92rem; }
.footer-legal {
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: var(--sp-5); padding-top: var(--sp-3);
  display: flex; gap: var(--sp-3); justify-content: space-between; flex-wrap: wrap;
  font-size: .82rem; color: rgba(250,246,240,0.6);
}
.footer-brand { font-family: var(--ff-serif); font-size: 1.4rem; color: var(--c-cream); }
.disclaimer-bar {
  background: var(--c-clay-deep);
  color: var(--c-cream);
  font-size: .78rem;
  padding: .4rem 1rem;
  text-align: center;
}
.disclaimer-bar a { color: white; text-decoration: underline; }

/* Breadcrumb */
.breadcrumb {
  display: flex; flex-wrap: wrap; gap: .4rem;
  font-size: .82rem; color: var(--c-mute);
  margin-bottom: var(--sp-3);
}
.breadcrumb a { color: var(--c-mute); text-decoration: none; }
.breadcrumb a:hover { color: var(--c-clay); }
.breadcrumb [aria-current="page"] { color: var(--c-ink); }
.breadcrumb li + li::before { content: "›"; margin-right: .4rem; color: var(--c-line); }
.breadcrumb ol { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: .35rem; }

/* Tag / badge */
.badge {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .25rem .55rem; border-radius: 999px;
  background: var(--c-rose); color: var(--c-clay-deep);
  font-size: .72rem; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase;
}
.badge-sage { background: #d8e3dc; color: var(--c-sage-deep); }
.badge-gold { background: #efe0c4; color: #6b4a1f; }
.badge-ink  { background: var(--c-ink); color: var(--c-cream); }

/* Coming soon */
.coming-soon {
  min-height: 80vh; display: grid; place-items: center;
  text-align: center; padding: var(--sp-6) var(--sp-3);
  background:
    radial-gradient(ellipse 60% 50% at 50% 30%, rgba(196,69,54,0.10), transparent 60%),
    var(--c-cream);
}
.coming-soon h1 { font-size: clamp(2.2rem, 4vw, 4rem); }
.coming-soon .badge { margin-bottom: 1.4rem; }

/* Utilities */
.center { text-align: center; }
.muted { color: var(--c-mute); }
.no-underline { text-decoration: none; }
.flex { display: flex; }
.gap-3 { gap: var(--sp-3); }
.mt-3 { margin-top: var(--sp-3); }
.mt-4 { margin-top: var(--sp-4); }
.mt-5 { margin-top: var(--sp-5); }
.mb-3 { margin-bottom: var(--sp-3); }
.mb-4 { margin-bottom: var(--sp-4); }

.reveal { opacity: 0; transform: translateY(20px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in { opacity: 1; transform: none; }

/* =================================================================
   Image treatments — polaroid, frames, collages, captions
   ================================================================= */

.figure {
  margin: var(--sp-4) 0;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--c-cream-2);
  border: 1px solid var(--c-line);
}
.figure img, .figure svg, .figure picture, .figure object { width: 100%; display: block; }
.figure-caption {
  font-size: .82rem; color: var(--c-mute); padding: .75rem 1rem 1rem;
  line-height: 1.45;
  border-top: 1px solid var(--c-line);
  background: var(--c-cream);
}
.figure-caption strong { color: var(--c-ink); font-weight: 660; }

/* Polaroid-style framed image — for portraits and lifestyle */
.polaroid {
  background: var(--c-white);
  padding: 14px 14px 56px;
  box-shadow: var(--shadow-2);
  border-radius: 4px;
  transform: rotate(-1.2deg);
  position: relative;
  max-width: 380px;
  margin: var(--sp-4) auto;
}
.polaroid img, .polaroid svg, .polaroid object { width: 100%; display: block; border-radius: 2px; }
.polaroid figcaption {
  position: absolute; left: 14px; right: 14px; bottom: 14px;
  font-family: var(--ff-serif); font-style: italic; font-size: 1.05rem;
  color: var(--c-ink); text-align: center;
}
.polaroid.tilt-right { transform: rotate(1.4deg); }
.polaroid.straight { transform: none; }

/* Hero portrait — large editorial frame */
.portrait-card {
  position: relative; border-radius: var(--radius-lg);
  overflow: hidden; aspect-ratio: 4/5;
  box-shadow: var(--shadow-2);
  background: var(--c-ink);
}
.portrait-card svg, .portrait-card img, .portrait-card object { width: 100%; height: 100%; object-fit: cover; display: block; }
.portrait-card__caption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: var(--sp-3) var(--sp-4);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
  color: var(--c-cream);
}
.portrait-card__caption h4 { color: var(--c-cream); margin: 0 0 .2rem; font-size: 1.15rem; }
.portrait-card__caption small { color: rgba(250,246,240,0.78); font-size: .82rem; }

/* Photo grid — 2-up, 3-up, asymmetric */
.photo-grid {
  display: grid; gap: var(--sp-3);
  margin: var(--sp-4) 0;
}
.photo-grid-2 { grid-template-columns: 1fr 1fr; }
.photo-grid-3 { grid-template-columns: 2fr 1fr 1fr; }
.photo-grid-asym {
  grid-template-columns: 2fr 1fr;
  grid-template-rows: auto auto;
}
.photo-grid-asym > :first-child { grid-row: span 2; }
@media (max-width: 700px) {
  .photo-grid-2, .photo-grid-3, .photo-grid-asym { grid-template-columns: 1fr; }
  .photo-grid-asym > :first-child { grid-row: auto; }
}

.photo-grid figure {
  border-radius: var(--radius); overflow: hidden;
  background: var(--c-cream-2);
  position: relative;
}
.photo-grid figure svg, .photo-grid figure img, .photo-grid figure object { width: 100%; height: 100%; display: block; object-fit: cover; min-height: 220px; }
.photo-grid figcaption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: .7rem 1rem;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
  color: var(--c-cream); font-size: .82rem;
}

/* Wide editorial bleed (full-bleed on desktop) */
.bleed {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-top: var(--sp-5); margin-bottom: var(--sp-5);
  position: relative;
}
.bleed-inner {
  max-width: 1480px; margin: 0 auto; padding: 0 var(--sp-3);
}
.bleed-img {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  background: var(--c-cream-2);
}
.bleed-img svg, .bleed-img img, .bleed-img object { width: 100%; display: block; }

/* Diptych — two illustrations side-by-side w/ shared caption */
.diptych {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2px;
  background: var(--c-line);
  border-radius: var(--radius);
  overflow: hidden;
  margin: var(--sp-4) 0;
  box-shadow: var(--shadow-1);
}
.diptych > * { background: var(--c-cream); }
.diptych img, .diptych svg, .diptych object { width: 100%; display: block; }
@media (max-width: 600px) { .diptych { grid-template-columns: 1fr; } }

/* Pull-figure: figure embedded in prose with breakout right margin */
@media (min-width: 1100px) {
  .pull-right {
    float: right; clear: right;
    width: 360px; margin: .4rem -120px .8rem var(--sp-4);
  }
  .pull-left {
    float: left; clear: left;
    width: 360px; margin: .4rem var(--sp-4) .8rem -120px;
  }
}

/* Stat/visual cards with illustration backgrounds */
.visual-stat {
  position: relative;
  background: var(--c-ink);
  color: var(--c-cream);
  border-radius: var(--radius-lg);
  padding: var(--sp-4);
  overflow: hidden;
  min-height: 200px;
}
.visual-stat__svg {
  position: absolute; right: -30px; top: -30px;
  width: 200px; height: 200px;
  opacity: 0.18;
}
.visual-stat h4 { color: var(--c-cream); margin: 0 0 .5rem; font-size: 1.2rem; }
.visual-stat__n {
  font-family: var(--ff-serif); font-weight: 360;
  font-size: clamp(2.6rem, 4vw, 4rem);
  color: var(--c-clay);
  line-height: 1;
}

/* Comparison strip: side-by-side method cards w/ visual chips */
.compare-row {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-3); margin: var(--sp-4) 0;
}
@media (max-width: 880px) { .compare-row { grid-template-columns: 1fr; } }
.compare-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-3) var(--sp-4);
}
.compare-card__icon {
  width: 56px; height: 56px;
  border-radius: 12px;
  background: var(--c-cream-2);
  display: grid; place-items: center;
  margin-bottom: var(--sp-2);
}
.compare-card__icon svg { width: 32px; height: 32px; }
.compare-card h4 { margin: 0 0 .3rem; font-size: 1.2rem; }
.compare-card p { color: var(--c-ink-2); margin: 0; font-size: .94rem; }

/* Timeline visual */
.timeline {
  position: relative; margin: var(--sp-4) 0;
  padding-left: 2rem;
  border-left: 2px solid var(--c-clay);
}
.timeline__item {
  position: relative; padding: 0 0 var(--sp-3) 0;
}
.timeline__item::before {
  content: ""; position: absolute; left: -2.6rem; top: .2rem;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--c-clay); border: 3px solid var(--c-cream);
  box-shadow: 0 0 0 2px var(--c-clay);
}
.timeline__year {
  font-family: var(--ff-mono); font-size: .82rem;
  letter-spacing: .12em; color: var(--c-clay); font-weight: 700;
  text-transform: uppercase; margin-bottom: .2rem;
}
.timeline__title {
  font-family: var(--ff-serif); font-size: 1.25rem;
  font-weight: 460; margin: 0 0 .3rem;
}
.timeline__body { color: var(--c-ink-2); font-size: .96rem; margin: 0; }

/* "Photo as illustration" wrapper for SVG with badge */
.illus {
  position: relative; border-radius: var(--radius);
  overflow: hidden; background: var(--c-cream-2);
  border: 1px solid var(--c-line);
}
.illus svg, .illus img, .illus object { width: 100%; display: block; }
.illus object { min-height: 320px; }
.illus__badge {
  position: absolute; top: 12px; left: 12px;
  background: var(--c-ink); color: var(--c-cream);
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 700; padding: .3rem .6rem; border-radius: 999px;
}
.illus__badge-clay { background: var(--c-clay); }
.illus__badge-sage { background: var(--c-sage-deep); }

/* Inline icon kit */
.ikon {
  width: 24px; height: 24px; display: inline-block; flex-shrink: 0;
  color: var(--c-clay);
}
.ikon-lg { width: 40px; height: 40px; }

/* Big number callout block (for stats sections) */
.big-numbers {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-3);
  margin: var(--sp-4) 0;
}
@media (max-width: 880px) { .big-numbers { grid-template-columns: repeat(2, 1fr); } }
.big-numbers > div {
  border-top: 2px solid var(--c-clay); padding-top: var(--sp-2);
}
.big-numbers .n {
  font-family: var(--ff-serif); font-weight: 360;
  font-size: clamp(2rem, 3.5vw, 3.4rem); color: var(--c-ink);
  line-height: 1; letter-spacing: -0.02em;
}
.big-numbers .l {
  font-size: .82rem; color: var(--c-mute); margin-top: .5rem;
  text-transform: uppercase; letter-spacing: .08em; font-weight: 600;
}

/* =================================================================
   Directorio · search + practitioner cards + country tiles
   ================================================================= */

.search-shell {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-1);
  padding: var(--sp-3);
  margin: var(--sp-3) 0 var(--sp-4);
}
.search-row {
  display: grid; gap: var(--sp-2);
  grid-template-columns: 1.4fr 1fr 1fr auto;
  align-items: end;
}
@media (max-width: 780px) { .search-row { grid-template-columns: 1fr; } }
.search-field { display: flex; flex-direction: column; gap: .35rem; }
.search-field label { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--c-mute); font-weight: 700; }
.search-field input, .search-field select {
  font: 500 .98rem var(--ff-sans);
  padding: .75rem .9rem;
  border: 1px solid var(--c-line);
  border-radius: 10px;
  background: var(--c-cream);
  color: var(--c-ink);
}
.search-field input:focus, .search-field select:focus {
  outline: none; border-color: var(--c-clay);
  box-shadow: 0 0 0 3px rgba(196,69,54,0.15);
}
.search-shell .btn { height: 46px; }

.filter-row {
  display: flex; flex-wrap: wrap; gap: .4rem;
  margin-top: var(--sp-2);
}
.filter-pill {
  background: var(--c-cream-2); color: var(--c-ink);
  border: 1px solid var(--c-line);
  padding: .3rem .7rem;
  border-radius: 999px;
  font-size: .82rem; font-weight: 500;
  display: inline-flex; align-items: center; gap: .35rem;
  cursor: pointer;
}
.filter-pill:hover { background: var(--c-ink); color: var(--c-cream); }
.filter-pill.is-active { background: var(--c-clay); color: var(--c-cream); border-color: var(--c-clay); }
.filter-pill__count {
  font-size: .7rem; opacity: .7; font-variant-numeric: tabular-nums;
}

.country-tile {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  padding: var(--sp-3) var(--sp-3) var(--sp-4);
  display: flex; flex-direction: column;
  gap: .6rem; text-decoration: none; color: inherit;
  transition: transform .2s, box-shadow .25s, border-color .2s;
  min-height: 200px;
}
.country-tile:hover { transform: translateY(-3px); box-shadow: var(--shadow-2); border-color: rgba(196,69,54,0.4); color: inherit; }
.country-tile__flag {
  width: 48px; height: 32px; border-radius: 4px;
  display: grid; place-items: center;
  font-family: var(--ff-mono); font-weight: 700; font-size: .82rem;
  color: var(--c-cream);
  background: var(--c-ink);
  letter-spacing: .14em;
}
.country-tile__flag.mx { background: linear-gradient(90deg, #006847 33%, #ffffff 33% 66%, #ce1126 66%); color: var(--c-ink); }
.country-tile__flag.es { background: linear-gradient(0deg, #c60b1e 25%, #ffc400 25% 75%, #c60b1e 75%); color: var(--c-ink); }
.country-tile__flag.ar { background: linear-gradient(0deg, #74acdf 33%, #ffffff 33% 66%, #74acdf 66%); color: var(--c-ink); }
.country-tile__flag.co { background: linear-gradient(0deg, #ce1126 25%, #003893 25% 50%, #fcd116 50%); color: var(--c-ink); }
.country-tile__flag.cl { background: linear-gradient(0deg, #d52b1e 50%, #ffffff 50% 75%, #ffffff 50% 75%); color: var(--c-ink); }
.country-tile__flag.pe { background: linear-gradient(90deg, #d91023 33%, #ffffff 33% 66%, #d91023 66%); color: var(--c-ink); }
.country-tile__flag.us { background: linear-gradient(0deg, #b22234 50%, #ffffff 50%); color: var(--c-ink); }

.country-tile h3 { font-size: 1.4rem; margin: 0; font-weight: 460; }
.country-tile p { color: var(--c-ink-2); margin: 0; font-size: .92rem; }
.country-tile small { color: var(--c-mute); font-size: .82rem; }

.country-hero {
  background:
    radial-gradient(ellipse 80% 60% at 80% 10%, rgba(196,69,54,0.12), transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(122,150,131,0.12), transparent 60%),
    var(--c-cream);
  padding: clamp(2.5rem, 4vw, 4rem) 0;
  border-bottom: 1px solid var(--c-line);
}

.cta-banner {
  background: linear-gradient(140deg, #c44536 0%, #6d1f17 100%);
  color: var(--c-cream);
  border-radius: var(--radius-lg);
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
  margin: var(--sp-5) 0;
}
.cta-banner h2 { color: var(--c-cream); margin: 0 0 .6rem; }
.cta-banner p { color: rgba(250,246,240,0.85); max-width: 64ch; margin: 0 auto var(--sp-3); }
.cta-banner .btn-cream:hover { background: var(--c-ink); color: var(--c-cream); }

/* =================================================================
   Blog · essay cards, byline, drop cap, masthead
   ================================================================= */

.masthead {
  border-block: 1px solid var(--c-line);
  padding: var(--sp-5) 0 var(--sp-4);
  background:
    radial-gradient(ellipse 70% 40% at 80% 20%, rgba(196,69,54,0.10), transparent 60%),
    var(--c-cream);
}
.masthead__kicker {
  font-family: var(--ff-mono); font-size: .78rem;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--c-clay); font-weight: 700;
  text-align: center; display: block;
  margin-bottom: 1rem;
}
.masthead h1 {
  font-family: var(--ff-serif);
  font-size: clamp(2.8rem, 8vw + 1rem, 6rem);
  font-weight: 300;
  letter-spacing: -0.03em;
  line-height: 0.92;
  text-align: center;
  margin: 0;
}
.masthead h1 em { font-style: italic; color: var(--c-clay); font-weight: 280; }
.masthead__lede {
  font-family: var(--ff-serif); font-weight: 340;
  font-size: clamp(1.15rem, 1vw + 1rem, 1.5rem);
  line-height: 1.45;
  text-align: center;
  max-width: 56ch;
  margin: 1.5rem auto 0;
  color: var(--c-ink-2);
}
.masthead__date {
  text-align: center; font-family: var(--ff-mono);
  font-size: .8rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--c-mute); margin-top: 1.5rem;
}

.essay-card {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--sp-3);
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  padding: var(--sp-3);
  transition: transform .2s, box-shadow .25s, border-color .2s;
  text-decoration: none; color: inherit;
}
.essay-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); border-color: rgba(196,69,54,0.4); color: inherit; }
@media (max-width: 720px) { .essay-card { grid-template-columns: 1fr; } }

.essay-card__thumb {
  border-radius: 8px;
  overflow: hidden;
  background: var(--c-cream-2);
  aspect-ratio: 4/3;
  position: relative;
}
.essay-card__thumb svg, .essay-card__thumb object, .essay-card__thumb img {
  width: 100%; height: 100%; object-fit: cover;
}
.essay-card__num {
  position: absolute; top: 8px; left: 8px;
  background: var(--c-ink); color: var(--c-cream);
  padding: .2rem .55rem; border-radius: 4px;
  font: 700 .68rem/1 var(--ff-mono);
  letter-spacing: 0.06em;
}
.essay-card__cat {
  font: 700 .72rem var(--ff-sans);
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--c-clay);
}
.essay-card__title {
  font-family: var(--ff-serif);
  font-size: 1.6rem;
  font-weight: 420;
  line-height: 1.15;
  letter-spacing: -0.012em;
  margin: .3rem 0 .5rem;
  color: var(--c-ink);
}
.essay-card__excerpt {
  font-family: var(--ff-serif);
  font-weight: 360;
  font-size: 1.05rem;
  line-height: 1.45;
  color: var(--c-ink-2);
  margin: 0;
}
.essay-card__meta {
  margin-top: .8rem;
  font-size: .8rem; color: var(--c-mute);
  font-family: var(--ff-mono); letter-spacing: .08em; text-transform: uppercase;
  display: flex; gap: 1rem; flex-wrap: wrap;
}

.byline {
  display: flex; gap: var(--sp-2); align-items: center;
  padding: var(--sp-2) 0 var(--sp-3);
  border-bottom: 1px solid var(--c-line);
  margin-bottom: var(--sp-4);
}
.byline__avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background: linear-gradient(135deg, var(--c-clay) 0%, var(--c-clay-deep) 100%);
  color: var(--c-cream);
  display: grid; place-items: center;
  font-family: var(--ff-serif); font-size: 1.25rem; font-weight: 480;
  flex-shrink: 0;
}
.byline__meta { line-height: 1.35; }
.byline__name { font-weight: 600; color: var(--c-ink); font-size: .96rem; }
.byline__detail { color: var(--c-mute); font-size: .82rem; }

.essay-body {
  font-family: var(--ff-serif);
  font-weight: 360;
  font-size: 1.18rem;
  line-height: 1.7;
  color: var(--c-ink);
  max-width: var(--maxw-prose);
}
.essay-body p { margin: 0 0 1.4em; }
.essay-body p:first-of-type::first-letter {
  font-family: var(--ff-serif); float: left; font-size: 5rem;
  line-height: .85; padding: .2rem .6rem 0 0; color: var(--c-clay);
  font-weight: 300;
}
.essay-body h2 {
  font-family: var(--ff-serif);
  font-size: 2rem;
  font-weight: 380;
  margin-top: 2em;
  margin-bottom: .6em;
  letter-spacing: -0.015em;
}
.essay-body a {
  color: var(--c-clay-deep);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.essay-body blockquote {
  margin: 1.6em -2rem;
  padding: 0 2rem;
  border-left: 3px solid var(--c-clay);
  font-style: italic;
  color: var(--c-ink);
  font-size: 1.4rem;
  line-height: 1.4;
  font-weight: 340;
}
@media (max-width: 720px) { .essay-body blockquote { margin: 1.6em 0; padding-left: 1rem; } }
.essay-body blockquote cite {
  display: block;
  font-style: normal;
  font-family: var(--ff-mono);
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-mute);
  margin-top: .6rem;
}

.essay-footer {
  border-top: 1px solid var(--c-line);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
}
.essay-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: var(--sp-3) 0; }
.essay-tags a {
  background: var(--c-cream-2);
  color: var(--c-ink-2);
  padding: .3rem .7rem;
  border-radius: 999px;
  font-size: .82rem;
  text-decoration: none;
}
.essay-tags a:hover { background: var(--c-ink); color: var(--c-cream); }

.related-essays {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
}
@media (max-width: 760px) { .related-essays { grid-template-columns: 1fr; } }
.related-essays a {
  display: block; padding: var(--sp-3);
  background: var(--c-cream-2);
  border-radius: var(--radius);
  text-decoration: none; color: var(--c-ink);
  border: 1px solid var(--c-line);
}
.related-essays a:hover { background: var(--c-white); border-color: rgba(196,69,54,0.4); }
.related-essays small {
  font: 700 .7rem var(--ff-mono);
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--c-clay);
}
.related-essays h4 {
  font-family: var(--ff-serif); font-size: 1.05rem;
  font-weight: 460; margin: .3rem 0 0; color: var(--c-ink);
  line-height: 1.25;
}

/* =================================================================
   Aprende · learning tracks, syllabus, lesson cards
   ================================================================= */

.track-card {
  display: grid; grid-template-columns: 120px 1fr;
  gap: var(--sp-3); align-items: stretch;
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  overflow: hidden;
  transition: transform .2s, box-shadow .25s, border-color .2s;
  text-decoration: none; color: inherit;
}
.track-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); border-color: rgba(196,69,54,0.5); color: inherit; }
@media (max-width: 720px) { .track-card { grid-template-columns: 1fr; } }

.track-card__num {
  background: var(--c-ink);
  color: var(--c-cream);
  display: grid; place-items: center;
  font-family: var(--ff-serif);
  font-size: clamp(2.8rem, 4vw, 3.8rem);
  font-weight: 380;
  font-style: italic;
}
.track-card__num.clay { background: linear-gradient(160deg, var(--c-clay), var(--c-clay-deep)); }
.track-card__num.sage { background: linear-gradient(160deg, var(--c-sage), var(--c-sage-deep)); }
.track-card__num.gold { background: linear-gradient(160deg, var(--c-gold), #6e4d1d); }
.track-card__num.plum { background: linear-gradient(160deg, #8e6f8a, #3e2d3c); }

.track-card__body { padding: var(--sp-3); }
.track-card__kicker {
  font: 700 .72rem var(--ff-sans);
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--c-clay);
}
.track-card h3 { margin: .3rem 0 .5rem; font-size: 1.5rem; }
.track-card p { color: var(--c-ink-2); margin: 0 0 .8rem; font-size: .96rem; }
.track-card__meta {
  font: 500 .82rem var(--ff-mono);
  letter-spacing: .06em; color: var(--c-mute);
  display: flex; gap: 1rem; flex-wrap: wrap;
}

/* Syllabus / lesson list */
.syllabus {
  counter-reset: lesson;
  list-style: none; padding: 0;
  border-top: 1px solid var(--c-line);
  margin: var(--sp-4) 0;
}
.syllabus > li {
  counter-increment: lesson;
  border-bottom: 1px solid var(--c-line);
  padding: var(--sp-3) 0;
  display: grid;
  grid-template-columns: 64px 1fr auto;
  gap: var(--sp-3);
  align-items: start;
}
@media (max-width: 720px) {
  .syllabus > li { grid-template-columns: 48px 1fr; }
  .syllabus > li > a:last-child { grid-column: 1 / -1; }
}
.syllabus > li::before {
  content: counter(lesson, decimal-leading-zero);
  font-family: var(--ff-mono);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--c-clay);
  letter-spacing: 0.04em;
}
.syllabus__title {
  font-family: var(--ff-serif);
  font-size: 1.3rem; font-weight: 460;
  line-height: 1.2;
  margin: 0 0 .4rem;
  color: var(--c-ink);
}
.syllabus__abstract {
  color: var(--c-ink-2);
  margin: 0;
  font-size: .96rem;
  line-height: 1.55;
}
.syllabus__tag {
  font-family: var(--ff-mono);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-mute);
  white-space: nowrap;
  padding-top: .4rem;
}
.syllabus__link {
  font-size: .9rem; color: var(--c-clay-deep);
  text-decoration: none; font-weight: 600;
  white-space: nowrap;
  padding-top: .4rem;
}
.syllabus__link::after { content: " →"; }

/* Glossary entries */
.glossary { columns: 2; column-gap: var(--sp-5); margin-top: var(--sp-4); }
@media (max-width: 720px) { .glossary { columns: 1; } }
.glossary dt {
  font-family: var(--ff-serif); font-size: 1.15rem;
  font-weight: 480; color: var(--c-ink);
  margin-top: var(--sp-3);
  break-after: avoid;
}
.glossary dt:first-of-type { margin-top: 0; }
.glossary dt a {
  color: var(--c-ink); text-decoration: none;
  border-bottom: 1px dashed var(--c-clay);
}
.glossary dt a:hover { color: var(--c-clay); }
.glossary dd {
  font-size: .95rem; line-height: 1.55;
  color: var(--c-ink-2);
  margin: .25rem 0 0;
  break-inside: avoid;
}

/* =================================================================
   Pre-launch · podcast episodes, community tiers, products
   ================================================================= */

.prelaunch-tag {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--c-cream-2);
  border: 1px solid var(--c-line);
  padding: .35rem .7rem;
  border-radius: 999px;
  font: 700 .72rem var(--ff-mono);
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--c-clay-deep);
  margin-bottom: 1rem;
}
.prelaunch-tag::before {
  content: ""; width: 8px; height: 8px;
  border-radius: 50%; background: var(--c-clay);
  animation: prelaunch-pulse 2.4s ease-in-out infinite;
}
@keyframes prelaunch-pulse {
  0%, 100% { opacity: 0.4; transform: scale(0.85); }
  50% { opacity: 1; transform: scale(1.15); }
}
@media (prefers-reduced-motion: reduce) {
  .prelaunch-tag::before { animation: none; }
}

/* Podcast episode card */
.episode-card {
  display: grid; grid-template-columns: 80px 1fr auto;
  gap: var(--sp-3); align-items: start;
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--c-line);
}
@media (max-width: 720px) { .episode-card { grid-template-columns: 56px 1fr; } .episode-card__cta { grid-column: 1 / -1; padding-top: .4rem; } }
.episode-card__num {
  width: 80px; height: 80px;
  border-radius: 12px;
  background: linear-gradient(140deg, var(--c-clay), var(--c-clay-deep));
  display: grid; place-items: center;
  color: var(--c-cream);
  font-family: var(--ff-serif); font-style: italic;
  font-size: 2.4rem; font-weight: 380;
  position: relative;
  flex-shrink: 0;
}
@media (max-width: 720px) { .episode-card__num { width: 56px; height: 56px; font-size: 1.6rem; } }
.episode-card__num small {
  position: absolute; bottom: 6px; left: 0; right: 0;
  text-align: center;
  font-family: var(--ff-mono); font-size: .56rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  opacity: 0.7; font-style: normal;
}
.episode-card__title {
  font-family: var(--ff-serif);
  font-size: 1.3rem; font-weight: 460;
  line-height: 1.18;
  margin: 0 0 .35rem;
  color: var(--c-ink);
}
.episode-card__abstract {
  color: var(--c-ink-2); margin: 0 0 .35rem; font-size: .96rem;
  line-height: 1.5;
}
.episode-card__meta {
  font: 500 .78rem var(--ff-mono);
  letter-spacing: .08em; color: var(--c-mute);
  display: flex; gap: 1rem; flex-wrap: wrap;
}
.episode-card__cta {
  white-space: nowrap;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-mute);
  align-self: center;
}

/* Community tier card */
.tier-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  padding: var(--sp-4);
  position: relative;
}
.tier-card.tier-card--featured {
  background: var(--c-ink);
  color: var(--c-cream);
  border-color: var(--c-ink);
}
.tier-card.tier-card--featured h3,
.tier-card.tier-card--featured p { color: var(--c-cream); }
.tier-card.tier-card--featured .tier-card__price strong { color: var(--c-cream); }
.tier-card.tier-card--featured ul { color: rgba(250,246,240,0.85); }
.tier-card__badge {
  position: absolute; top: -12px; right: 16px;
  background: var(--c-clay); color: var(--c-cream);
  font: 700 .68rem var(--ff-mono);
  letter-spacing: .14em; text-transform: uppercase;
  padding: .25rem .7rem; border-radius: 999px;
}
.tier-card__price {
  margin: .6rem 0 1rem;
  font-family: var(--ff-serif);
  font-weight: 380;
}
.tier-card__price strong {
  font-size: 2rem; color: var(--c-ink);
  display: inline-block;
}
.tier-card__price small { color: var(--c-mute); font-size: .82rem; font-family: var(--ff-sans); }
.tier-card ul { padding-left: 1.1rem; margin: 0; line-height: 1.75; font-size: .94rem; }
.tier-card li { margin-bottom: .35rem; }

/* Shop product card */
.product-card {
  background: var(--c-white);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .2s, box-shadow .25s, border-color .2s;
}
.product-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-2); border-color: rgba(196,69,54,0.4); }
.product-card__media {
  aspect-ratio: 4/3;
  background: var(--c-cream-2);
  display: grid; place-items: center;
  position: relative;
}
.product-card__media svg, .product-card__media object {
  width: 60%; height: 60%; object-fit: contain;
}
.product-card__tag {
  position: absolute; top: 10px; left: 10px;
  background: var(--c-ink); color: var(--c-cream);
  font: 700 .66rem var(--ff-mono);
  letter-spacing: .12em; text-transform: uppercase;
  padding: .22rem .55rem; border-radius: 4px;
}
.product-card__tag.tag-soon { background: var(--c-clay); }
.product-card__tag.tag-curado { background: var(--c-sage-deep); }
.product-card__body { padding: var(--sp-3); flex: 1; display: flex; flex-direction: column; }
.product-card__title {
  font-family: var(--ff-serif);
  font-size: 1.2rem; font-weight: 460;
  margin: 0 0 .35rem; color: var(--c-ink);
}
.product-card__abstract {
  font-size: .92rem; color: var(--c-ink-2); margin: 0 0 1rem;
  line-height: 1.5; flex: 1;
}
.product-card__footer {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: .8rem;
}
.product-card__price {
  font-family: var(--ff-serif);
  font-size: 1.2rem; font-weight: 460;
  color: var(--c-clay-deep);
}
.product-card__cta {
  font-size: .82rem; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase;
  color: var(--c-clay);
  text-decoration: none;
}
.product-card__cta::after { content: " →"; }

/* Print */
@media print {
  .site-header, .site-footer, .newsletter, .video, .nav, .practitioner-box { display: none !important; }
  body { background: white; color: black; }
  a { color: black; }
}

/* ============================================================
   SEARCH (/buscar/)
   ============================================================ */

.visually-hidden {
  position: absolute !important;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px; width: 1px;
  overflow: hidden;
  white-space: nowrap;
}

.search-hero {
  padding: 2.5rem 0 1.25rem;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(196, 69, 54, 0.10), transparent 50%),
    radial-gradient(80% 70% at 10% 110%, rgba(122, 150, 131, 0.08), transparent 55%),
    linear-gradient(180deg, var(--c-cream) 0%, transparent 100%);
}

.search-hero__title {
  font-family: var(--ff-serif);
  font-weight: 380;
  font-size: clamp(2rem, 4.2vw, 3.4rem);
  letter-spacing: -0.015em;
  margin: .4rem 0 .6rem;
  color: var(--c-ink);
}

.search-hero__lede {
  max-width: 56ch;
  color: var(--c-ink-2);
  font-size: 1.04rem;
  line-height: 1.55;
  margin: 0 0 1.6rem;
}

.search-form {
  position: relative;
  display: flex;
  align-items: center;
  background: var(--c-cream);
  border: 2px solid rgba(26, 22, 18, 0.10);
  border-radius: 12px;
  padding: .35rem .35rem .35rem 1rem;
  transition: border-color .15s, box-shadow .15s;
  margin: 0 0 1.25rem;
}

.search-form:focus-within {
  border-color: var(--c-clay);
  box-shadow: 0 0 0 4px rgba(196, 69, 54, 0.12);
}

.search-form__icon {
  flex-shrink: 0;
  color: var(--c-clay);
  margin-right: .5rem;
}

.search-form__input {
  flex: 1;
  border: 0;
  background: transparent;
  font-family: inherit;
  font-size: 1.15rem;
  color: var(--c-ink);
  padding: .85rem .5rem;
  outline: none;
  min-width: 0;
}

.search-form__input::-webkit-search-cancel-button { display: none; }

.search-form__input::placeholder {
  color: var(--c-ink-2);
  opacity: .55;
}

.search-form__clear {
  flex-shrink: 0;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 0;
  background: rgba(26, 22, 18, 0.06);
  color: var(--c-ink-2);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: background .15s, color .15s;
}

.search-form__clear:hover {
  background: var(--c-clay);
  color: var(--c-cream);
}

.search-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: 0;
}

.search-chip {
  font-family: inherit;
  font-size: .88rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  border: 1.5px solid rgba(26, 22, 18, 0.14);
  background: transparent;
  color: var(--c-ink-2);
  border-radius: 999px;
  padding: .42rem .85rem;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}

.search-chip:hover {
  border-color: var(--c-clay);
  color: var(--c-clay);
}

.search-chip.is-active {
  background: var(--c-clay);
  border-color: var(--c-clay);
  color: var(--c-cream);
}

.search-meta {
  font-size: .92rem;
  color: var(--c-ink-2);
  margin: 0 0 1rem;
}

.search-meta strong { color: var(--c-ink); }

.search-results {
  display: grid;
  gap: .9rem;
}

.search-result {
  display: block;
  position: relative;
  padding: 1.25rem 1.4rem;
  background: var(--c-cream);
  border: 1px solid rgba(26, 22, 18, 0.08);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: transform .12s ease, box-shadow .15s, border-color .15s;
}

.search-result:hover,
.search-result:focus-visible {
  border-color: var(--c-clay);
  box-shadow: 0 8px 24px -12px rgba(196, 69, 54, 0.25);
  transform: translateY(-1px);
  outline: none;
}

.search-result__pillar {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-clay);
  background: rgba(196, 69, 54, 0.08);
  padding: .26rem .6rem;
  border-radius: 999px;
  margin-bottom: .6rem;
}

.search-result__title {
  font-family: var(--ff-serif);
  font-weight: 440;
  font-size: 1.32rem;
  line-height: 1.25;
  margin: 0 0 .25rem;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}

.search-result__eyebrow {
  font-size: .82rem;
  color: var(--c-ink-2);
  font-weight: 500;
  margin: 0 0 .5rem;
  opacity: .85;
}

.search-result__desc {
  margin: .35rem 0 .6rem;
  font-size: .94rem;
  line-height: 1.55;
  color: var(--c-ink-2);
}

.search-result__url {
  display: block;
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size: .76rem;
  color: var(--c-sage-deep);
  opacity: .8;
  word-break: break-all;
}

.search-result mark {
  background: rgba(196, 69, 54, 0.18);
  color: var(--c-clay-deep);
  padding: 0 .12em;
  border-radius: 3px;
  font-weight: 600;
}

.search-empty {
  text-align: center;
  padding: 2.5rem 1rem;
  border-radius: 14px;
  background: rgba(26, 22, 18, 0.03);
}

.search-empty h2 {
  font-family: var(--ff-serif);
  font-weight: 400;
  font-size: 1.6rem;
  margin: 0 0 .6rem;
  color: var(--c-ink);
}

.search-empty p {
  margin: 0 0 1.25rem;
  color: var(--c-ink-2);
}

.search-suggestions {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  justify-content: center;
}

.search-suggestions li a {
  display: inline-block;
  padding: .42rem .9rem;
  font-size: .88rem;
  border: 1.5px solid rgba(26, 22, 18, 0.14);
  border-radius: 999px;
  text-decoration: none;
  color: var(--c-ink-2);
  transition: border-color .12s, color .12s;
}

.search-suggestions li a:hover {
  border-color: var(--c-clay);
  color: var(--c-clay);
}

@media (max-width: 640px) {
  .search-form__input { font-size: 1rem; padding: .75rem .4rem; }
  .search-result { padding: 1rem 1.1rem; }
  .search-result__title { font-size: 1.15rem; }
}

/* ============================================================
   ANSWER BLOCK (TL;DR at the top of every article)
   ============================================================ */

.answer-block {
  position: relative;
  margin: 1rem 0 1.6rem;
  padding: 1.1rem 1.35rem 1.1rem 1.6rem;
  background: linear-gradient(180deg, rgba(196, 69, 54, 0.05), rgba(196, 69, 54, 0.02));
  border-left: 3px solid var(--c-clay);
  border-radius: 0 8px 8px 0;
}

.answer-block::before {
  content: "En una frase";
  display: block;
  font-family: var(--ff-sans);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-clay);
  opacity: .85;
  margin-bottom: .35rem;
}

.answer-block > .lede,
.answer-block > p.lede {
  margin: 0;
  font-family: var(--ff-serif);
  font-size: 1.18rem;
  line-height: 1.5;
  color: var(--c-ink);
  font-weight: 380;
}

.answer-block > .lede em,
.answer-block > p.lede em {
  font-style: italic;
  color: var(--c-clay-deep);
}

/* ============================================================
   DIRECTORIO · organization browser grid + filter UI
   ============================================================ */

.directorio-banner {
  background: linear-gradient(180deg, rgba(196, 69, 54, 0.06), rgba(196, 69, 54, 0.02));
  border-left: 3px solid var(--c-clay);
  padding: 1rem 1.3rem;
  border-radius: 0 8px 8px 0;
  margin: 0 0 1.5rem;
}

.directorio-banner__title {
  font-family: var(--ff-sans);
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-clay);
  margin: 0 0 .25rem;
}

.directorio-banner p { margin: 0; color: var(--c-ink-2); font-size: .95rem; }

.directorio-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: 0 0 1.25rem;
}

.directorio-filter {
  font-family: inherit;
  font-size: .85rem;
  font-weight: 500;
  border: 1.5px solid rgba(26, 22, 18, 0.14);
  background: transparent;
  color: var(--c-ink-2);
  border-radius: 999px;
  padding: .4rem .9rem;
  cursor: pointer;
  transition: border-color .12s, color .12s, background .12s;
}

.directorio-filter:hover { border-color: var(--c-clay); color: var(--c-clay); }
.directorio-filter.is-active { background: var(--c-clay); border-color: var(--c-clay); color: var(--c-cream); }

.directorio-meta {
  font-size: .92rem;
  color: var(--c-ink-2);
  margin: 0 0 1rem;
}

.directorio-meta strong { color: var(--c-ink); }

.directorio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}

.org-grid {
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  align-items: start;
}

.org-card {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  padding: 1.2rem 1.3rem 1.3rem;
  background: var(--c-cream);
  border: 1px solid rgba(26, 22, 18, 0.08);
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: transform .12s, box-shadow .15s, border-color .15s;
}

.org-card:hover,
.org-card:focus-visible {
  border-color: rgba(196, 69, 54, 0.35);
  box-shadow: 0 8px 22px -14px rgba(196, 69, 54, 0.22);
  transform: translateY(-1px);
  outline: none;
}

.org-card__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: .6rem;
}

.org-card__cat {
  font-size: .66rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--c-clay);
}

.org-card__since {
  font-size: .74rem;
  color: var(--c-ink-2);
  font-variant-numeric: tabular-nums;
}

.org-card__name {
  font-family: var(--ff-serif);
  font-weight: 460;
  font-size: 1.12rem;
  margin: 0;
  color: var(--c-ink);
  letter-spacing: -0.005em;
}

.org-card__meta {
  font-size: .82rem;
  color: var(--c-ink-2);
  margin: 0;
}

.org-card__chips {
  display: flex;
  flex-wrap: wrap;
  gap: .25rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.org-card__chip {
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .02em;
  text-transform: uppercase;
  background: rgba(196, 69, 54, 0.08);
  color: var(--c-clay-deep);
  padding: .15rem .5rem;
  border-radius: 999px;
}

.org-card__desc {
  font-size: .9rem;
  line-height: 1.55;
  color: var(--c-ink);
  margin: 0;
}

.org-card__more {
  font-size: .82rem;
  font-weight: 600;
  color: var(--c-clay);
  margin-top: .35rem;
  padding-top: .6rem;
  border-top: 1px dashed rgba(26, 22, 18, 0.14);
}

.org-card:hover .org-card__more { color: var(--c-clay-deep); }

.directorio-empty {
  text-align: center;
  padding: 2.5rem 1rem;
  border-radius: 14px;
  background: rgba(26, 22, 18, 0.03);
  color: var(--c-ink-2);
}

/* ----- Organization detail page ----- */

.org-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 2.4rem;
  padding-top: 1.5rem;
  align-items: start;
}

@media (max-width: 880px) {
  .org-layout { grid-template-columns: 1fr; gap: 1.6rem; }
}

.org-main h2 {
  font-family: var(--ff-serif);
  font-weight: 420;
  font-size: 1.5rem;
  margin: 2rem 0 .7rem;
  letter-spacing: -0.01em;
  color: var(--c-ink);
}

.org-main h2:first-child { margin-top: 0; }

.org-long {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--c-ink);
  margin: 0 0 .8rem;
}

.org-links {
  list-style: none;
  padding: 0;
  margin: .4rem 0 0;
  display: grid;
  gap: .5rem;
}

.org-links li {
  padding-left: 1.1rem;
  position: relative;
}

.org-links li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--c-clay);
}

.org-links a { font-weight: 500; }

.org-aside { display: grid; gap: 1rem; }

@media (max-width: 880px) {
  .org-aside { grid-template-columns: 1fr; }
}

.org-facts dl {
  margin: .6rem 0 0;
  display: grid;
  gap: .55rem;
}

.org-facts dl > div {
  display: grid;
  grid-template-columns: 7.5rem 1fr;
  gap: .2rem .8rem;
  font-size: .9rem;
  padding-bottom: .55rem;
  border-bottom: 1px dashed rgba(26, 22, 18, 0.1);
}

.org-facts dl > div:last-child { border-bottom: 0; padding-bottom: 0; }

.org-facts dt {
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--c-mute);
  align-self: center;
}

.org-facts dd { margin: 0; color: var(--c-ink); }

.org-facts__mods { margin-top: .9rem; }

.org-facts__modlabel {
  display: block;
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--c-mute);
  margin-bottom: .4rem;
}

.org-faq {
  display: grid;
  gap: .9rem;
}

.org-faq__item {
  padding: 1rem 1.2rem;
  background: var(--c-cream);
  border: 1px solid rgba(26, 22, 18, 0.08);
  border-radius: 10px;
}

.org-faq__item h3 {
  font-family: var(--ff-sans);
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 .35rem;
  color: var(--c-ink);
}

.org-faq__item p {
  margin: 0;
  font-size: .94rem;
  line-height: 1.6;
  color: var(--c-ink-2);
}

.org-rel {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: .9rem;
  margin-top: 1.2rem;
}

.org-rel__item {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  padding: 1rem 1.1rem;
  background: var(--c-cream);
  border: 1px solid rgba(26, 22, 18, 0.08);
  border-radius: 10px;
  text-decoration: none;
  color: inherit;
  transition: transform .12s, box-shadow .15s, border-color .15s;
}

.org-rel__item:hover,
.org-rel__item:focus-visible {
  border-color: rgba(196, 69, 54, 0.35);
  box-shadow: 0 8px 22px -14px rgba(196, 69, 54, 0.22);
  transform: translateY(-1px);
  outline: none;
}

.org-rel__name {
  font-family: var(--ff-serif);
  font-weight: 460;
  font-size: 1.02rem;
  color: var(--c-ink);
}

.org-rel__desc {
  font-size: .84rem;
  line-height: 1.5;
  color: var(--c-ink-2);
}

/* ============================================================
   DIRECTORIO · escuelas y asociaciones
   ============================================================ */

.escuelas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1rem;
  margin-top: 1.25rem;
}

.escuela-card {
  padding: 1.3rem 1.4rem;
  background: var(--c-cream);
  border: 1px solid rgba(26, 22, 18, 0.08);
  border-radius: 12px;
  border-top: 3px solid var(--c-sage);
}

.escuela-card__name {
  font-family: var(--ff-serif);
  font-weight: 460;
  font-size: 1.15rem;
  margin: 0 0 .2rem;
  color: var(--c-ink);
  letter-spacing: -0.01em;
}

.escuela-card__modality {
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--c-clay);
  margin: 0 0 .7rem;
}

.escuela-card__desc {
  font-size: .92rem;
  line-height: 1.55;
  color: var(--c-ink-2);
  margin: 0 0 .7rem;
}

.escuela-card__scope {
  font-size: .82rem;
  color: var(--c-sage-deep);
  margin: 0 0 .35rem;
  font-weight: 500;
}

.escuela-card__verify {
  font-size: .86rem;
  line-height: 1.5;
  color: var(--c-ink-2);
  margin: 0;
  padding-top: .6rem;
  border-top: 1px solid rgba(26, 22, 18, 0.08);
}
