/* Arbolex webfonts — SELF-HOSTED (no CDN dependency).
   Spectral — serif de autoridad para titulares.
   Inter — sans limpia para cuerpo y UI.
   Binaries in assets/fonts/ (paths are ../assets relative to this file) (latin + latin-ext subsets, weights 400/500/600/700).
   Downloaded from Google Fonts and served locally. */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/cf3eb50fb210.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/f11d729bb0a4.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: 500;
  font-display: swap;
  src: url("/assets/fonts/cf3eb50fb210.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/f11d729bb0a4.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: 600;
  font-display: swap;
  src: url("/assets/fonts/cf3eb50fb210.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/f11d729bb0a4.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: 700;
  font-display: swap;
  src: url("/assets/fonts/cf3eb50fb210.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;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/f11d729bb0a4.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: 'Spectral';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/a4e7b4b529fa.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;
}
@font-face {
  font-family: 'Spectral';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("/assets/fonts/d4877aefbcc2.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: 'Spectral';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/8cac2ecc6de6.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;
}
@font-face {
  font-family: 'Spectral';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("/assets/fonts/df8445200231.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: 'Spectral';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/d53a766710b8.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;
}
@font-face {
  font-family: 'Spectral';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("/assets/fonts/041903c5a54f.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: 'Spectral';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/2487be522452.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;
}
@font-face {
  font-family: 'Spectral';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/assets/fonts/44234f062bee.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;
}

/* Arbolex — color tokens.
   Premium editorial: blanco + hueso, tinta casi negra,
   navy de autoridad legal, bronce de aval/sello, verde savia puntual. */
:root {
  /* ── Base palette ───────────────────────────── */
  --paper: #FFFFFF;          /* fondo principal */
  --bone: #F4F1E8;           /* hueso — secciones alternas */
  --bone-deep: #EAE5D6;      /* hueso oscurecido — bordes/hover sobre hueso */
  --ink: #1A1A1A;            /* texto principal (tinta) */
  --ink-soft: #45443E;       /* texto secundario */
  --ink-faint: #6F6D64;      /* texto terciario / captions */

  --navy: #213251;           /* azul navy — color dominante de marca */
  --navy-deep: #18253D;      /* navy hover / fondos profundos */
  --navy-tint: #E8ECF3;      /* lavado navy para chips/fondos suaves */

  --bronze: #A8853E;         /* bronce — aval, sello, CTA */
  --bronze-deep: #8C6E32;    /* bronce hover */
  --bronze-tint: #F3EBD9;    /* lavado bronce */

  --sage: #7C9473;           /* verde savia — toque vegetal puntual */
  --sage-deep: #5F7858;
  --sage-tint: #EDF1EA;

  --line: #E2DCCB;                       /* borde hairline sobre claro */
  --line-on-navy: rgba(255,255,255,.16); /* borde hairline sobre navy */

  /* ── Semantic aliases ───────────────────────── */
  --surface-page: var(--paper);
  --surface-section: var(--bone);
  --surface-card: var(--paper);
  --surface-inverse: var(--navy);
  --surface-inverse-deep: var(--navy-deep);

  --text-body: var(--ink);
  --text-muted: var(--ink-soft);
  --text-faint: var(--ink-faint);
  --text-inverse: #F6F4ED;
  --text-inverse-muted: rgba(246, 244, 237, .72);
  --text-on-cta: #FFF9EE;

  --accent-cta: var(--bronze);
  --accent-cta-hover: var(--bronze-deep);
  --accent-authority: var(--navy);
  --accent-authority-hover: var(--navy-deep);
  --accent-nature: var(--sage);

  --border-soft: var(--line);
  --focus-ring: rgba(33, 50, 81, .35);
}

/* Arbolex — typography tokens.
   Titulares: Spectral (serif con autoridad).
   Cuerpo y UI: Inter (sans limpia). */
:root {
  --font-serif: "Spectral", Georgia, "Times New Roman", serif;
  --font-sans: "Inter", -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;

  /* ── Scale (mobile-first, fluid) ────────────── */
  --size-display: clamp(2.25rem, 1.4rem + 3.6vw, 3.5rem);   /* H1 hero */
  --size-h2: clamp(1.75rem, 1.3rem + 2vw, 2.5rem);           /* títulos de sección */
  --size-h3: clamp(1.25rem, 1.1rem + .7vw, 1.5rem);          /* subtítulos */
  --size-lead: clamp(1.0625rem, 1rem + .35vw, 1.25rem);      /* entradillas */
  --size-body: 1.0625rem;                                    /* 17px cuerpo */
  --size-small: .875rem;                                     /* 14px captions */
  --size-overline: .75rem;                                   /* 12px etiquetas */

  /* ── Line heights ───────────────────────────── */
  --leading-display: 1.08;
  --leading-heading: 1.15;
  --leading-body: 1.65;
  --leading-tight: 1.35;

  /* ── Weights ────────────────────────────────── */
  --weight-display: 600;   /* Spectral SemiBold */
  --weight-heading: 600;
  --weight-body: 400;
  --weight-medium: 500;
  --weight-strong: 600;

  /* ── Tracking ───────────────────────────────── */
  --tracking-display: -0.015em;
  --tracking-heading: -0.01em;
  --tracking-overline: 0.14em;  /* etiquetas en mayúsculas */
}

/* Arbolex — spacing, radii, shadows, layout. Base 4px; mucho aire. */
:root {
  /* ── Spacing scale ──────────────────────────── */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;

  /* Sección editorial: aire generoso, fluido */
  --section-pad-y: clamp(64px, 5vw + 40px, 128px);
  --section-gap: clamp(40px, 4vw, 72px);

  /* ── Layout ─────────────────────────────────── */
  --container: 1120px;
  --container-narrow: 760px;   /* bloques de prosa */
  --container-pad-x: clamp(20px, 4vw, 40px);

  /* ── Radii ──────────────────────────────────── */
  --radius-s: 6px;     /* chips, badges pequeños */
  --radius-m: 10px;    /* botones, inputs */
  --radius-l: 16px;    /* tarjetas, fotos */
  --radius-pill: 999px;

  /* ── Borders ────────────────────────────────── */
  --border-hairline: 1px solid var(--border-soft);

  /* ── Shadows (suaves, editoriales — nunca duras) ── */
  --shadow-card: 0 1px 2px rgba(26, 26, 26, .05), 0 8px 24px rgba(33, 50, 81, .07);
  --shadow-raised: 0 2px 6px rgba(26, 26, 26, .08), 0 16px 40px rgba(33, 50, 81, .12);
  --shadow-bar: 0 -4px 20px rgba(26, 26, 26, .12);

  /* ── Motion ─────────────────────────────────── */
  --ease-out: cubic-bezier(.22, .61, .36, 1); /* @kind other */
  --duration-fast: 150ms; /* @kind other */
  --duration-base: 250ms; /* @kind other */
}




  * { box-sizing: border-box; }
  body { margin: 0; background: var(--surface-page); color: var(--text-body); font-family: var(--font-sans); font-size: var(--size-body); line-height: var(--leading-body); -webkit-font-smoothing: antialiased; }
  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--container-pad-x); }
  section { padding: var(--section-pad-y) 0; }
  h1, h2, h3 { font-family: var(--font-serif); color: var(--navy); margin: 0; text-wrap: balance; }
  h1 { font-size: var(--size-display); font-weight: var(--weight-display); line-height: var(--leading-display); letter-spacing: var(--tracking-display); }
  h2 { font-size: var(--size-h2); font-weight: var(--weight-heading); line-height: var(--leading-heading); letter-spacing: var(--tracking-heading); }
  h3 { font-size: var(--size-h3); font-weight: var(--weight-heading); line-height: var(--leading-heading); }
  p { margin: 0; text-wrap: pretty; }
  a { color: var(--navy); text-underline-offset: 3px; }

  .overline { display: block; font-size: var(--size-overline); font-weight: 600; letter-spacing: var(--tracking-overline); text-transform: uppercase; color: var(--bronze); margin-bottom: 14px; }
  .lead { font-size: var(--size-lead); line-height: var(--leading-tight); color: var(--text-muted); }

  .btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 48px; padding: 0 26px; border-radius: var(--radius-m); font-weight: 600; font-size: 15.5px; text-decoration: none; border: 1px solid transparent; transition: background-color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out); cursor: pointer; }
  .btn:active { transform: translateY(1px); }
  .btn--primary { background: var(--accent-cta); color: var(--text-on-cta); }
  .btn--primary:hover { background: var(--accent-cta-hover); }
  .btn--outline { color: var(--navy); border-color: var(--navy); }
  .btn--outline:hover { background: var(--navy-tint); }
  .btn--inverse { color: var(--text-inverse); border-color: var(--line-on-navy); }
  .btn--inverse:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.4); }
  .btn svg { flex: none; }

  .ico { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
  .ico--fill { fill: currentColor; stroke: none; }

  /* Header */
  .header { border-bottom: var(--border-hairline); background: var(--surface-page); }
  .header .container { display: flex; align-items: center; justify-content: space-between; min-height: 72px; }
  .wordmark { font-family: var(--font-serif); font-weight: 600; font-size: 26px; color: var(--navy); text-decoration: none; letter-spacing: -0.01em; }
  .wordmark i { font-style: normal; color: var(--bronze); }
  .header__contact { display: none; gap: 12px; }
  @media (min-width: 768px) { .header__contact { display: flex; } }

  /* Migas */
  .crumbs { background: var(--surface-page); border-bottom: var(--border-hairline); }
  .crumbs .container { padding-top: 14px; padding-bottom: 14px; }
  .crumbs ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; font-size: var(--size-small); }
  .crumbs li { display: inline-flex; align-items: center; }
  .crumbs a { color: var(--text-muted); text-decoration: none; }
  .crumbs a:hover { color: var(--navy); text-decoration: underline; }
  .crumbs__txt { color: var(--text-muted); }
  .crumbs [aria-current="page"] { color: var(--navy); font-weight: 600; }
  .crumbs__sep { color: var(--text-faint); }

  /* Hero */
  .hero { background: var(--surface-section); }
  .hero .container { max-width: var(--container-narrow); }
  .hero__sub { margin-top: var(--space-5); max-width: 60ch; }
  .hero__intro { margin-top: var(--space-5); max-width: 64ch; color: var(--text-muted); }
  .hero__ctas { display: flex; flex-wrap: wrap; gap: 12px; margin-top: var(--space-6); }
  .trustbar { display: flex; flex-wrap: wrap; gap: 8px 10px; margin-top: var(--space-6); }
  .pill { display: inline-flex; align-items: center; gap: 7px; padding: 7px 14px; border-radius: var(--radius-pill); background: var(--paper); border: 1px solid var(--bone-deep); font-size: 13px; font-weight: 500; color: var(--ink-soft); line-height: 1; }
  .pill .ico { width: 14px; height: 14px; color: var(--bronze-deep); }

  /* Servicios */
  .svc-grid { display: grid; gap: 18px; margin-top: var(--section-gap); grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
  .svc { display: flex; flex-direction: column; gap: 10px; background: var(--surface-card); border: var(--border-hairline); border-radius: var(--radius-l); box-shadow: var(--shadow-card); padding: 26px; text-decoration: none; color: inherit; transition: box-shadow var(--duration-base) var(--ease-out), transform var(--duration-base) var(--ease-out); }
  a.svc:hover { box-shadow: var(--shadow-raised); transform: translateY(-2px); }
  .svc__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
  .svc__head .ico { width: 22px; height: 22px; color: var(--bronze-deep); flex: none; }
  .svc h3 { font-size: 21px; }
  .svc p { color: var(--text-muted); font-size: var(--size-small); }
  .svc__go { display: inline-flex; align-items: center; gap: 6px; margin-top: auto; padding-top: 10px; font-size: var(--size-small); font-weight: 600; color: var(--bronze-deep); }
  .svc__go .ico { width: 15px; height: 15px; }
  .svc--soon { opacity: .9; }
  .badge-soon { display: inline-flex; align-items: center; margin-top: auto; padding-top: 10px; font-size: 11px; font-weight: 600; letter-spacing: .05em; text-transform: uppercase; color: var(--text-faint); }
  .badge-soon span { background: var(--navy-tint); border: 1px solid var(--bone-deep); border-radius: var(--radius-pill); padding: 4px 11px; }

  /* Cross-link */
  .xlink { background: var(--surface-section); }
  .xlink .container { display: flex; flex-wrap: wrap; gap: var(--space-5); align-items: center; justify-content: space-between; background: var(--surface-card); border: var(--border-hairline); border-radius: var(--radius-l); box-shadow: var(--shadow-card); padding: 28px 32px; }
  .xlink__txt { max-width: 56ch; }
  .xlink__txt .overline { margin-bottom: 8px; }
  .xlink h3 { font-size: 23px; }
  .xlink p { margin-top: 8px; color: var(--text-muted); font-size: var(--size-small); }

  /* Cierre */
  .closing { background: var(--surface-inverse); color: var(--text-inverse); text-align: center; }
  .closing .container { max-width: var(--container-narrow); }
  .closing h2 { color: var(--text-inverse); max-width: 22ch; margin: 0 auto; }
  .closing__ctas { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: var(--space-7); }

  /* Footer */
  .footer { background: var(--surface-inverse-deep); color: var(--text-inverse-muted); padding: var(--space-7) 0; font-size: var(--size-small); }
  .footer .container { display: flex; flex-wrap: wrap; gap: var(--space-5); justify-content: space-between; align-items: center; }
  .footer a { color: var(--text-inverse-muted); }
  .footer nav { display: flex; flex-wrap: wrap; gap: var(--space-4); }
  .footer__soon { color: var(--text-faint); }

  /* Barra móvil */
  .callbar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; display: flex; gap: 10px; background: var(--surface-inverse); box-shadow: var(--shadow-bar); padding: 12px 16px; padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px)); }
  .callbar a { flex: 1; min-height: 48px; font-size: 15px; }
  @media (min-width: 768px) { .callbar { display: none; } body { padding-bottom: 0; } }
  @media (max-width: 767.98px) { body { padding-bottom: 84px; } }

  /* ── Componentes añadidos para Home y hubs (mismos tokens) ───────── */
  /* Prosa editorial */
  .prose { max-width: var(--container-narrow); }
  .prose p + p { margin-top: var(--space-4); }
  .prose p { color: var(--text-muted); }
  .prose strong { color: var(--text-body); font-weight: var(--weight-strong); }
  .section--bone { background: var(--surface-section); }

  /* Nota legal citable */
  .legalnote { max-width: var(--container-narrow); margin-top: var(--space-6); background: var(--navy-tint); border: 1px solid var(--bone-deep); border-left: 3px solid var(--navy); border-radius: var(--radius-m); padding: 20px 24px; }
  .legalnote p { color: var(--ink-soft); font-size: var(--size-small); }
  .legalnote strong { color: var(--navy); }

  /* Lista de método / requisitos */
  .reqs { max-width: var(--container-narrow); margin-top: var(--section-gap); display: grid; gap: 18px; }
  .req { display: flex; gap: 14px; align-items: flex-start; }
  .req .ico { width: 20px; height: 20px; color: var(--bronze-deep); flex: none; margin-top: 3px; }
  .req h3 { font-size: 19px; margin-bottom: 4px; }
  .req p { color: var(--text-muted); font-size: var(--size-small); }

  /* Bloque "quién firma" */
  .signatory { max-width: var(--container-narrow); margin-top: var(--section-gap); background: var(--surface-card); border: var(--border-hairline); border-radius: var(--radius-l); box-shadow: var(--shadow-card); padding: 28px 32px; }
  .signatory h3 { font-size: 21px; margin-bottom: 10px; }
  .signatory p { color: var(--text-muted); font-size: var(--size-small); }

  /* Sello de frescura + fuentes */
  .freshness { display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; border-radius: var(--radius-pill); background: var(--bronze-tint); border: 1px solid var(--bronze); color: var(--bronze-deep); font-size: 13px; font-weight: 600; line-height: 1; }
  .sources { max-width: var(--container-narrow); margin-top: var(--space-6); padding-top: var(--space-5); border-top: var(--border-hairline); }
  .sources h2 { font-size: 15px; color: var(--ink-soft); font-family: var(--font-sans); font-weight: 600; }
  .sources p, .sources li { color: var(--text-faint); font-size: 13px; line-height: 1.6; }
  .sources ul { margin: 10px 0 0; padding-left: 18px; }

  /* Grid de zonas (hub global) */
  .zonas-grid { display: grid; gap: 18px; margin-top: var(--section-gap); grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

  /* Lista de zonas sin enlace (prosa) */
  .zonas-prosa { max-width: var(--container-narrow); margin-top: var(--space-5); color: var(--text-muted); font-size: var(--size-small); }
