/* Colombian City Guides · canonical site styles. Paisa-boutique theme (2026-05-16),
   Shared across medellin.guide, barranquilla.guide, thecartagena.guide. Covers the homepage, all article
   pages, section archives, and utility pages.

   Cache-busted by bumping the ?v=YYYYMMDDx query string in <link
   rel="stylesheet"> across HTML pages. The _headers file ships
   /css/site.css with public, max-age=31536000, immutable. */

/* ─── SELF-HOSTED WEBFONTS ──────────────────────────────────────────
   Inter (sans, body/UI) is self-hosted via the woff2 files generated
   2026-05-15 by scripts/fetch-fonts.py. Fraunces (serif, display)
   loads from Google Fonts CDN in each page's <head> for now; if we
   want to self-host later, add the woff2s here. */

@font-face { font-family: 'Inter'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/inter-300-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; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/inter-300-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: 400; font-display: swap; src: url('/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; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 400; font-display: swap; src: url('/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: 500; font-display: swap; src: url('/fonts/inter-500-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; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 500; font-display: swap; src: url('/fonts/inter-500-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: 600; font-display: swap; src: url('/fonts/inter-600-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; }
@font-face { font-family: 'Inter'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/inter-600-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; }

/* ─── RESET ─────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 5rem; }
body {
  background: var(--pb-bg);
  color: var(--pb-ink);
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 18px;
  line-height: 1.62;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01","cv11";
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
ul { list-style: none; }
p { margin-bottom: 1.2em; }
p:last-child { margin-bottom: 0; }

/* ─── DESIGN TOKENS ──────────────────────────────────────────────── */
:root {
  --pb-bg:         #f6efe2;
  --pb-bg2:        #ede2c9;
  --pb-paper:      #fdfaf2;
  --pb-ink:        #1f1a14;
  --pb-ink-soft:   #5a4a3a;
  --pb-gold:       #c9a84c;
  --pb-gold-deep:  #8c6f24;
  --pb-terra:      #b04a25;
  --pb-terra-deep: #7d2f12;
  --pb-green:      #2d5a3f;
  --pb-green-deep: #173b27;
  --pb-line:       #1f1a141a;

  --pb-max:        1180px;
  --nav-height:    72px;
}

.serif { font-family: 'Fraunces', Georgia, serif; font-feature-settings: "ss01"; }

/* ─── UTILITY ──────────────────────────────────────────────────── */
.pb-skip { position: absolute; left: -9999px; background: var(--pb-ink); color: var(--pb-bg); padding: 10px 14px; border-radius: 6px; font-weight: 700; z-index: 200; }
.pb-skip:focus { left: 14px; top: 14px; }
.pb-wrap { max-width: var(--pb-max); margin: 0 auto; padding: 0 24px; }
@media (min-width: 900px) { .pb-wrap { padding: 0 40px; } }

/* ─── LANGUAGE TOGGLE (mirrors medellin.guide) ──────────────────── */
html.lang-en .pb-es, html.lang-es .pb-en { display: none !important; }
html.lang-en [data-lang="es"] { display: none; }
html.lang-es [data-lang="en"] { display: none; }
.pb-langtog { display: inline-flex; align-items: center; border: 1px solid var(--pb-bg); border-radius: 999px; padding: 2px; font-size: 11px; letter-spacing: .1em; font-weight: 600; text-transform: uppercase; }
.pb-langtog a { padding: 4px 10px; border-radius: 999px; color: var(--pb-bg); transition: all .18s ease; text-decoration: none; }
html.lang-en .pb-langtog a[data-l="en"], html.lang-es .pb-langtog a[data-l="es"] { background: var(--pb-gold); color: var(--pb-ink); }

/* ─── UTILITY BAND ──────────────────────────────────────────────── */
.pb-top { background: var(--pb-ink); color: var(--pb-bg); font-size: 13px; letter-spacing: .02em; padding: 9px 0; }
.pb-top .pb-wrap { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 14px; }
.pb-top .pb-l { display: flex; gap: 14px; align-items: center; }
.pb-top .pb-l:first-child { justify-self: start; }
.pb-top .pb-l:last-child { justify-self: end; }
.pb-top a { opacity: .92; font-weight: 500; }
.pb-top a:hover { color: var(--pb-gold); opacity: 1; }

/* ─── TOP-BAR SEARCH (pipes into Catalina) ────────────────────── */
.pb-search { display: flex; align-items: center; width: min(440px, 60vw); min-width: 0; background: transparent; border: 1.5px solid var(--pb-bg); border-radius: 999px; padding: 3px 6px 3px 16px; transition: border-color .18s ease, background .18s ease, box-shadow .18s ease; }
.pb-search:hover { background: rgba(253,250,242,.06); }
.pb-search:focus-within { border-color: var(--pb-gold); background: rgba(253,250,242,.10); box-shadow: 0 0 0 3px rgba(201,168,76,.18); }
.pb-search input { flex: 1; min-width: 0; background: transparent; border: 0; color: var(--pb-bg); font-family: inherit; font-size: 13.5px; padding: 6px 8px 6px 0; outline: none; }
.pb-search input::placeholder { color: rgba(253,250,242,.78); font-style: italic; }
.pb-search button { background: var(--pb-gold); color: var(--pb-ink); border: 0; border-radius: 999px; width: 30px; height: 30px; padding: 0; cursor: pointer; font-size: 14px; font-weight: 700; line-height: 1; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; transition: background .18s ease, transform .15s ease; }
.pb-search button:hover { background: var(--pb-bg); transform: scale(1.05); }
.pb-search button svg { width: 14px; height: 14px; }
@media (max-width: 899px) {
  .pb-search { order: 3; width: 100%; flex-basis: 100%; max-width: none; margin: 6px 0 0 0; }
}

/* ─── STICKY HEADER ─────────────────────────────────────────────── */
.site-pb { position: sticky; top: 0; z-index: 50; background: rgba(246,239,226,.94); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--pb-line); }
.site-pb .pb-wrap { display: flex; justify-content: space-between; align-items: center; padding: 18px 24px; gap: 18px; }
.pb-brand { font-family: 'Fraunces', serif; font-weight: 500; font-size: 24px; letter-spacing: -.015em; display: flex; align-items: center; color: var(--pb-ink); }
.pb-brand .pb-dot { color: var(--pb-terra); }
/* Circular medallion beside the wordmark, mirrors medellin.guide's logo-m
   pattern. Hosts an <img> of the navy/gold "B" medallion. */
.pb-brand .pb-mark { width: 34px; height: 34px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; overflow: hidden; background: transparent; margin-right: 10px; flex-shrink: 0; }
.pb-brand .pb-mark img { width: 100%; height: 100%; object-fit: contain; display: block; }
@media (max-width: 720px) { .pb-brand .pb-mark { width: 30px; height: 30px; margin-right: 8px; } }
.pb-nav { display: none; gap: 28px; font-size: 14.5px; font-weight: 500; }
.pb-nav a { position: relative; padding: 6px 0; color: var(--pb-ink); }
.pb-nav a:hover { color: var(--pb-terra-deep); }
.pb-nav a:hover::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1.5px; background: var(--pb-gold); }
@media (min-width: 980px) { .pb-nav { display: flex; } }
.pb-headcta { display: flex; align-items: center; gap: 12px; }

/* ─── BUTTONS ───────────────────────────────────────────────────── */
.pb-btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 22px; border-radius: 999px; font-weight: 600; font-size: 15px; border: 1.5px solid var(--pb-ink); background: transparent; color: var(--pb-ink); cursor: pointer; transition: all .15s ease; font-family: 'Inter', sans-serif; }
.pb-btn:hover { transform: translateY(-1px); background: var(--pb-ink); color: var(--pb-bg); }
.pb-btn.pb-gold { background: var(--pb-gold); color: var(--pb-ink); border-color: var(--pb-gold); }
.pb-btn.pb-gold:hover { background: var(--pb-gold-deep); border-color: var(--pb-gold-deep); color: var(--pb-bg); }
.pb-btn.pb-solid { background: var(--pb-ink); color: var(--pb-bg); border-color: var(--pb-ink); }
.pb-btn.pb-solid:hover { background: var(--pb-terra); border-color: var(--pb-terra); }
.pb-btn.pb-ghost-light { background: transparent; color: #fff; border-color: #fff; }
.pb-btn.pb-ghost-light:hover { background: #fff; color: var(--pb-terra); }

/* ─── MOBILE NAV TOGGLE + DRAWER ────────────────────────────────── */
.pb-navtog { display: flex; width: 42px; height: 42px; border: 1.5px solid var(--pb-ink); border-radius: 999px; background: transparent; align-items: center; justify-content: center; cursor: pointer; padding: 0; }
.pb-navtog span { display: block; width: 16px; height: 1.5px; background: var(--pb-ink); position: relative; }
.pb-navtog span::before, .pb-navtog span::after { content: ""; position: absolute; left: 0; width: 16px; height: 1.5px; background: var(--pb-ink); transition: transform .2s ease, top .2s ease; }
.pb-navtog span::before { top: -5px; }
.pb-navtog span::after { top: 5px; }
body.pb-nav-open .pb-navtog span { background: transparent; }
body.pb-nav-open .pb-navtog span::before { top: 0; transform: rotate(45deg); }
body.pb-nav-open .pb-navtog span::after { top: 0; transform: rotate(-45deg); }
@media (min-width: 980px) { .pb-navtog { display: none; } }

.pb-drawer { position: fixed; top: 0; right: -100%; bottom: 0; width: min(360px, 86vw); background: var(--pb-paper); border-left: 1px solid var(--pb-line); padding: 80px 30px 28px; display: flex; flex-direction: column; gap: 18px; transition: right .25s ease; z-index: 60; }
body.pb-nav-open .pb-drawer { right: 0; }
.pb-drawer a { font-family: 'Fraunces', serif; font-size: 24px; font-weight: 500; letter-spacing: -.005em; color: var(--pb-ink); }
.pb-drawer a:hover { color: var(--pb-terra-deep); }
.pb-scrim { position: fixed; inset: 0; background: #1f1a1466; opacity: 0; pointer-events: none; transition: opacity .25s ease; z-index: 55; }
body.pb-nav-open .pb-scrim { opacity: 1; pointer-events: auto; }
@media (min-width: 980px) { .pb-drawer, .pb-scrim { display: none; } }

/* ─── TYPOGRAPHY ────────────────────────────────────────────────── */
.eyebrow, .sec-eyebrow { display: inline-flex; align-items: center; gap: 10px; font-size: 12.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: var(--pb-terra-deep); margin-bottom: 14px; }
.eyebrow::before, .sec-eyebrow::before { content: ""; width: 24px; height: 1.5px; background: var(--pb-gold-deep); }

h1.pb-h1 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(44px, 6.6vw, 86px); line-height: 1.02; letter-spacing: -.025em; margin-bottom: 24px; }
h1.pb-h1 em { font-style: italic; color: var(--pb-terra-deep); font-weight: 400; }
h1.pb-h1 .gold { background: var(--pb-gold); padding: 0 .15em; color: var(--pb-ink); border-radius: 6px; display: inline-block; font-style: normal; }
h2.pb-h2 { font-family: 'Fraunces', serif; font-weight: 400; font-size: clamp(36px, 4.6vw, 58px); line-height: 1.05; letter-spacing: -.02em; margin-bottom: 18px; color: var(--pb-ink); }
h2.pb-h2 em { font-style: italic; color: var(--pb-terra-deep); font-weight: 400; }
h2.pb-h2 a { color: inherit; }

.lede { font-size: clamp(18px, 1.4vw, 21px); line-height: 1.55; color: var(--pb-ink-soft); max-width: 540px; margin-bottom: 32px; }
.lede strong { color: var(--pb-ink); font-weight: 600; background: #ede2c980; padding: 2px 6px; border-radius: 3px; }

/* ─── CATALINA FRAME (hero on homepage) ────────────────────────────── */
.cat-frame { position: relative; background: var(--pb-paper); border: 1.5px solid var(--pb-gold); border-radius: 80px 130px 90px 120px / 110px 90px 130px 80px; padding: 54px 44px 48px; box-shadow: 0 26px 50px -24px #1f1a1438; }
@media (max-width: 700px) { .cat-frame { padding: 44px 26px 32px; border-radius: 50px 80px 60px 80px / 70px 60px 80px 60px; } }
.cat-frame-label { position: absolute; top: -18px; left: 50%; transform: translateX(-50%); background: var(--pb-ink); color: var(--pb-gold); padding: 7px 22px; border-radius: 999px; font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; white-space: nowrap; box-shadow: 0 6px 16px -6px #1f1a1444; }
.cat-portrait { position: relative; display: inline-block; }
.cat-portrait img, .cat-portrait .ph { width: 170px; height: 170px; border-radius: 50%; object-fit: cover; border: 4px solid var(--pb-paper); box-shadow: 0 18px 36px -16px #1f1a1444; background: var(--pb-gold); display: flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-style: italic; font-size: 80px; color: var(--pb-ink); font-weight: 500; }
.cat-portrait .live-dot { position: absolute; bottom: 10px; right: 10px; width: 20px; height: 20px; border-radius: 50%; background: var(--pb-green); border: 4px solid var(--pb-paper); box-shadow: 0 0 0 3px rgba(45,90,63,.18); }
.cat-founder { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.cat-founder img, .cat-founder .ph { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; border: 3px solid var(--pb-paper); box-shadow: 0 8px 18px -10px #1f1a1444; background: var(--pb-bg2); display: flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-style: italic; font-size: 28px; color: var(--pb-ink-soft); font-weight: 500; }
.cat-founder .lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--pb-ink-soft); }
.cat-cta-grid { display: grid; grid-template-columns: 1fr; gap: 12px; }
@media (min-width: 600px) { .cat-cta-grid { grid-template-columns: 1fr 1fr; } }
.cat-cta-card { display: block; text-align: left; background: var(--pb-paper); border: 1.5px solid var(--pb-line); border-radius: 14px; padding: 22px 24px; cursor: pointer; font-family: inherit; color: var(--pb-ink); transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease; width: 100%; }
.cat-cta-card:hover { border-color: var(--pb-gold); transform: translateY(-2px); box-shadow: 0 18px 32px -18px #1f1a1430; text-decoration: none; }
.cat-cta-card .label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: var(--pb-terra-deep); margin-bottom: 8px; }
.cat-cta-card h3 { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 500; line-height: 1.2; letter-spacing: -.005em; margin-bottom: 6px; }
.cat-cta-card p { font-size: 14.5px; color: var(--pb-ink-soft); line-height: 1.5; }
.cat-cta-card .arrow { display: inline-block; margin-top: 10px; color: var(--pb-terra-deep); font-weight: 600; font-size: 13px; }
.cat-cta-card .arrow::after { content: " →"; transition: transform .15s ease; display: inline-block; }
.cat-cta-card:hover .arrow::after { transform: translateX(3px); }

/* ─── HERO-MERGED (homepage) ────────────────────────────────────── */
.hero-merged { padding: 40px 0 64px; background: linear-gradient(180deg, var(--pb-bg) 0%, var(--pb-paper) 100%); }
.hero-merged .cat-frame { padding: 64px 56px 52px; }
@media (max-width: 700px) { .hero-merged .cat-frame { padding: 48px 22px 36px; } }
.hero-merged-top { display: grid; grid-template-columns: 1fr; gap: 36px; align-items: center; margin-bottom: 44px; }
@media (min-width: 980px) { .hero-merged-top { grid-template-columns: 1.08fr .92fr; gap: 56px; margin-bottom: 48px; } }
.hero-merged-copy { display: flex; flex-direction: column; }
.hero-merged-copy h1.pb-h1 { font-size: clamp(40px, 5.4vw, 72px); margin-bottom: 20px; }
.hero-merged-copy .lede { max-width: 520px; margin-bottom: 0; }
.hero-merged-photo { position: relative; border-radius: 18px; overflow: hidden; aspect-ratio: 4/3.4; background: var(--pb-green-deep); box-shadow: 0 32px 64px -22px #1f1a1444; }
@media (min-width: 980px) { .hero-merged-photo { aspect-ratio: 4/4.2; } }
.hero-merged-photo picture, .hero-merged-photo img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-merged-photo .overlay { position: absolute; inset: 0; background: linear-gradient(180deg, #1f1a1400 50%, #1f1a14b3 100%); }
.hero-merged-photo .lbl { position: absolute; left: 22px; bottom: 22px; color: var(--pb-bg); font-weight: 500; font-size: 14px; letter-spacing: .02em; text-shadow: 0 1px 4px #00000080; max-width: 280px; }
.hero-merged-photo .lbl strong { display: block; font-family: 'Fraunces', serif; font-weight: 500; font-size: 20px; letter-spacing: -.005em; margin-bottom: 2px; color: var(--pb-gold); }
.hero-team { display: flex; align-items: flex-end; gap: 16px; margin-top: 28px; flex-wrap: wrap; }
.hero-team .cat-portrait img, .hero-team .cat-portrait .ph { width: 104px; height: 104px; font-size: 56px; }
.hero-team .cat-portrait .live-dot { bottom: 6px; right: 6px; width: 16px; height: 16px; border-width: 3px; }
.hero-team .cat-founder img, .hero-team .cat-founder .ph { width: 56px; height: 56px; font-size: 24px; }
.hero-team-caption { font-family: 'Fraunces', serif; font-size: 15.5px; line-height: 1.4; color: var(--pb-ink-soft); max-width: 220px; margin-left: 6px; font-weight: 400; }
.hero-team-caption strong { color: var(--pb-ink); font-weight: 500; font-style: normal; }
.hero-team-caption em { font-style: italic; color: var(--pb-terra-deep); font-weight: 500; }

/* Catalina-solo variant: no founder avatars, Catalina is the focus */
.hero-team.is-solo { align-items: center; gap: 22px; }
.hero-team.is-solo .cat-portrait { display: inline-block; text-decoration: none; transition: transform .2s ease; }
.hero-team.is-solo .cat-portrait:hover { transform: translateY(-2px); }
.hero-team.is-solo .cat-portrait img, .hero-team.is-solo .cat-portrait .ph { width: 150px; height: 150px; font-size: 78px; border: 5px solid var(--pb-gold); box-shadow: 0 22px 44px -16px rgba(31,26,20,.35), 0 0 0 1px rgba(140,111,36,.18); }
.hero-team.is-solo .cat-portrait .live-dot { bottom: 8px; right: 8px; width: 22px; height: 22px; border: 4px solid var(--pb-paper); box-shadow: 0 0 0 4px rgba(45,90,63,.25); }
.hero-team.is-solo .hero-team-caption { max-width: 320px; font-size: 17.5px; line-height: 1.4; margin-left: 4px; }
.hero-team.is-solo .hero-team-caption strong { font-size: 22px; font-weight: 600; }

.hero-merged-bottom { position: relative; padding-top: 36px; border-top: 1px dashed #c9a84c80; }
@media (max-width: 899px) { .hero-merged-bottom { padding-top: 28px; } }
.hero-merged .cat-cards-hint { display: block; text-align: center; font-family: 'Fraunces', serif; font-style: italic; font-size: 16px; color: var(--pb-terra-deep); margin-bottom: 20px; }
.hero-merged .cat-cta-grid { display: grid; grid-template-columns: 1fr; gap: 14px; }
@media (min-width: 600px) { .hero-merged .cat-cta-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1180px) { .hero-merged .cat-cta-grid { grid-template-columns: repeat(4, 1fr); gap: 16px; } }
.hero-merged .cat-cta-card { padding: 20px 22px; }
.hero-merged .cat-cta-card h3 { font-size: 21px; }
.hero-merged .cat-cta-card p { font-size: 14px; }

/* ─── SECTION SHELL ─────────────────────────────────────────────── */
.pb-section { padding: 104px 0; }
@media (max-width: 720px) { .pb-section { padding: 56px 0; } }
@media (min-width: 721px) and (max-width: 900px) { .pb-section { padding: 72px 0; } }
.sec-head { max-width: 680px; margin-bottom: 56px; }
.sec-head p { font-size: 19px; color: var(--pb-ink-soft); max-width: 580px; }
@media (max-width: 720px) { .sec-head { margin-bottom: 32px; } .sec-head p { font-size: 16px; } }

/* ─── HOMEPAGE: BROWSE / SVC GRID ───────────────────────────────── */
.services-bg { background: var(--pb-paper); }
.svc-grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 700px) { .svc-grid { grid-template-columns: repeat(2, 1fr); } }
.svc { background: var(--pb-bg); border: 1px solid var(--pb-line); border-radius: 14px; overflow: hidden; display: flex; flex-direction: column; transition: transform .18s ease, box-shadow .18s ease; color: var(--pb-ink); }
.svc:hover { transform: translateY(-3px); box-shadow: 0 22px 44px -22px #1f1a1430; }
.svc-photo { aspect-ratio: 16/10; background: var(--pb-green-deep); position: relative; overflow: hidden; }
.svc-photo img { width: 100%; height: 100%; object-fit: cover; }
.svc-photo::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, #1f1a1400 60%, #1f1a1450 100%); }
.svc-body { padding: 28px 28px 30px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.svc .num { font-family: 'Fraunces', serif; font-style: italic; font-size: 14px; color: var(--pb-terra-deep); font-weight: 500; letter-spacing: .02em; }
.svc h3 { font-family: 'Fraunces', serif; font-size: 26px; font-weight: 500; letter-spacing: -.01em; line-height: 1.15; color: var(--pb-ink); }
.svc p { font-size: 16px; line-height: 1.55; color: var(--pb-ink-soft); }
.svc .more { margin-top: auto; padding-top: 6px; font-weight: 600; font-size: 14px; color: var(--pb-terra-deep); display: inline-flex; align-items: center; gap: 6px; }
.svc .more::after { content: "→"; transition: transform .2s ease; }
.svc:hover .more::after { transform: translateX(4px); }
@media (max-width: 720px) { .svc-photo { aspect-ratio: 16/9; } .svc-body { padding: 22px 22px 24px; } .svc h3 { font-size: 22px; } }

/* ─── HOMEPAGE: NEIGHBORHOODS STRIP ─────────────────────────────── */
.nbhd-bg { background: var(--pb-bg); }
.nbhd-strip-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding: 0 0 8px; margin: 0 -24px; }
.nbhd-strip-wrap::-webkit-scrollbar { display: none; }
.nbhd-strip { display: flex; gap: 18px; width: max-content; padding: 4px 24px; }
@media (min-width: 900px) { .nbhd-strip-wrap { margin: 0 -40px; } .nbhd-strip { padding: 4px 40px; } }
.nbhd { position: relative; width: 240px; flex-shrink: 0; border-radius: 14px; overflow: hidden; background: var(--pb-paper); border: 1px solid var(--pb-line); transition: transform .18s ease, box-shadow .18s ease; color: var(--pb-ink); }
.nbhd:hover { transform: translateY(-3px); box-shadow: 0 22px 44px -22px #1f1a1430; }
.nbhd-photo { aspect-ratio: 4/5; background: var(--pb-bg2); overflow: hidden; position: relative; }
.nbhd-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.nbhd:hover .nbhd-photo img { transform: scale(1.04); }
.nbhd-body { padding: 16px 18px 18px; }
.nbhd-body h3 { font-family: 'Fraunces', serif; font-size: 19px; font-weight: 500; letter-spacing: -.005em; margin-bottom: 4px; color: var(--pb-ink); }
.nbhd-body .more { font-size: 13px; font-weight: 600; color: var(--pb-terra-deep); display: inline-flex; align-items: center; gap: 5px; }
.nbhd-body .more::after { content: "→"; display: inline-block; transition: transform .2s ease; }
.nbhd:hover .nbhd-body .more::after { transform: translateX(3px); }
@media (max-width: 720px) { .nbhd { width: 200px; } }

/* ─── GUIDE / GD CARDS ──────────────────────────────────────────── */
.guides .grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 700px) { .guides .grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .guides .grid { grid-template-columns: repeat(4, 1fr); } }
.gd { background: var(--pb-paper); border: 1px solid var(--pb-line); border-radius: 12px; padding: 24px; display: flex; flex-direction: column; gap: 8px; transition: all .18s ease; color: var(--pb-ink); }
.gd:hover { transform: translateY(-3px); border-color: var(--pb-gold); }
.gd .meta { font-size: 12px; text-transform: uppercase; letter-spacing: .14em; color: var(--pb-terra-deep); font-weight: 600; }
.gd h4 { font-family: 'Fraunces', serif; font-size: 21px; font-weight: 500; line-height: 1.2; letter-spacing: -.005em; color: var(--pb-ink); }
.gd p { font-size: 14px; color: var(--pb-ink-soft); line-height: 1.5; }
@media (max-width: 720px) { .gd { padding: 18px 18px 20px; } .gd h4 { font-size: 18px; } }

/* ─── EDITORIAL FEATURE (dark, full-width) ──────────────────────── */
.editorial-bg { background: var(--pb-ink); color: var(--pb-bg); }
.editorial-grid { display: grid; grid-template-columns: 1fr; gap: 48px; align-items: center; }
@media (min-width: 900px) { .editorial-grid { grid-template-columns: 1fr 1fr; gap: 72px; } }
.editorial-photo { aspect-ratio: 4/3; overflow: hidden; border-radius: 18px; background: var(--pb-green-deep); box-shadow: 0 32px 64px -22px #00000080; display: block; }
.editorial-photo img { width: 100%; height: 100%; object-fit: cover; }
.editorial-bg .sec-eyebrow { color: var(--pb-gold); }
.editorial-bg .sec-eyebrow::before { background: var(--pb-gold); }
.editorial-bg h2.pb-h2 { color: var(--pb-bg); margin-bottom: 18px; }
.editorial-bg h2.pb-h2 em { color: var(--pb-gold); }
.editorial-bg h2.pb-h2 a { color: inherit; }
.editorial-excerpt { color: #cbb38a; font-size: 18px; line-height: 1.6; margin-bottom: 28px; max-width: 520px; }
.editorial-byline { display: flex; align-items: center; gap: 14px; margin-bottom: 28px; }
.editorial-byline .ph { width: 44px; height: 44px; border-radius: 50%; background: var(--pb-bg2); display: flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-style: italic; color: var(--pb-ink-soft); font-size: 20px; }
.editorial-byline .nm { font-weight: 600; color: var(--pb-bg); font-size: 14px; }
.editorial-byline .time { font-size: 12.5px; color: #cbb38a; margin-top: 2px; }

/* ─── NOW SECTION (weekly news) ─────────────────────────────────── */
.now-bg { background: var(--pb-bg2); }
.now-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 20px; margin-bottom: 36px; flex-wrap: wrap; }
.now-head-l { max-width: 580px; }
.now-head-l .sec-eyebrow { margin-bottom: 10px; }
.now-head-l h2.pb-h2 { margin-bottom: 0; }
.now-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
@media (min-width: 700px) { .now-grid { grid-template-columns: repeat(3, 1fr); } }
.now-card { background: var(--pb-paper); border: 1px solid var(--pb-line); border-radius: 14px; padding: 22px 24px; display: flex; gap: 18px; align-items: flex-start; transition: transform .18s ease, box-shadow .18s ease; color: var(--pb-ink); }
.now-card:hover { transform: translateY(-3px); box-shadow: 0 22px 44px -22px #1f1a1430; }
.now-date { display: flex; flex-direction: column; align-items: center; flex-shrink: 0; padding-right: 18px; border-right: 2px solid var(--pb-gold-deep); }
.now-date .d { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 500; line-height: 1; color: var(--pb-ink); }
.now-date .m { font-size: 11.5px; text-transform: uppercase; letter-spacing: .12em; color: var(--pb-ink-soft); margin-top: 4px; font-weight: 600; }
.now-card h3 { font-family: 'Fraunces', serif; font-size: 18px; font-weight: 500; line-height: 1.25; margin-bottom: 6px; letter-spacing: -.005em; color: var(--pb-ink); }
.now-card p { font-size: 14px; color: var(--pb-ink-soft); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
@media (max-width: 720px) { .now-grid { gap: 14px; } .now-card { padding: 18px; } }

/* ─── MAGAZINE GRID ─────────────────────────────────────────────── */
.mag-grid { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 700px) { .mag-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .mag-grid { grid-template-columns: repeat(4, 1fr); } }
.mag { display: flex; flex-direction: column; gap: 12px; color: var(--pb-ink); }
.mag-photo { aspect-ratio: 4/3; border-radius: 14px; overflow: hidden; background: var(--pb-bg2); }
.mag-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.mag:hover .mag-photo img { transform: scale(1.04); }
.mag .meta { font-size: 11.5px; text-transform: uppercase; letter-spacing: .14em; color: var(--pb-terra-deep); font-weight: 600; }
.mag h4 { font-family: 'Fraunces', serif; font-size: 19px; font-weight: 500; line-height: 1.25; letter-spacing: -.005em; color: var(--pb-ink); }
.mag .byline { font-size: 12.5px; color: var(--pb-ink-soft); margin-top: auto; }

/* ─── NEWSLETTER ────────────────────────────────────────────────── */
.pb-newsletter { padding: 56px 0; background: var(--pb-paper); border-top: 1px solid var(--pb-line); }
.pb-newsletter .nl-card { max-width: 600px; margin: 0 auto; text-align: center; }
.pb-newsletter .nl-title { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 500; color: var(--pb-ink); margin: 0 0 12px; letter-spacing: -.01em; }
.pb-newsletter .nl-desc { color: var(--pb-ink-soft); margin: 0 0 24px; font-size: 15.5px; line-height: 1.55; }
.pb-newsletter .nl-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: stretch; }
.pb-newsletter .nl-input { flex: 1 1 240px; min-width: 0; padding: 14px 18px; border: 1.5px solid var(--pb-line); background: #fff; color: var(--pb-ink); border-radius: 999px; font-family: 'Inter', sans-serif; font-size: 15px; line-height: 1.4; transition: border-color .15s ease, box-shadow .15s ease; }
.pb-newsletter .nl-input:focus { outline: none; border-color: var(--pb-gold-deep); box-shadow: 0 0 0 3px #c9a84c33; }
.pb-newsletter .nl-submit { padding: 14px 24px; background: var(--pb-ink); color: var(--pb-bg); border: 0; border-radius: 999px; font-weight: 700; font-size: 14px; cursor: pointer; letter-spacing: .02em; font-family: inherit; transition: background .15s ease; flex: 0 0 auto; white-space: nowrap; }
.pb-newsletter .nl-submit:hover { background: var(--pb-terra-deep); }
.pb-newsletter .nl-submit:disabled { opacity: .55; cursor: not-allowed; }
.pb-newsletter .nl-note { margin: 14px 0 0; font-size: 13px; color: var(--pb-ink-soft); min-height: 1.4em; }
.pb-newsletter .nl-note.ok { color: var(--pb-green); }
.pb-newsletter .nl-note.err { color: var(--pb-terra-deep); }

/* ─── FOOTER ────────────────────────────────────────────────────── */
footer.site-pb-foot { background: #15110c; color: #a89677; padding: 64px 0 28px; font-size: 14px; line-height: 1.6; }
footer.site-pb-foot .pb-grid { display: grid; grid-template-columns: 1fr; gap: 40px; margin-bottom: 48px; }
@media (min-width: 800px) { footer.site-pb-foot .pb-grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
footer.site-pb-foot h5 { color: var(--pb-bg); font-family: 'Fraunces', serif; font-size: 18px; font-weight: 500; margin: 0 0 14px; letter-spacing: -.005em; }
footer.site-pb-foot ul { list-style: none; }
footer.site-pb-foot li { margin-bottom: 8px; }
footer.site-pb-foot a { color: #a89677; }
footer.site-pb-foot a:hover { color: var(--pb-gold); }
footer.site-pb-foot p { margin: 0 0 8px; }
footer.site-pb-foot .pb-legal { padding-top: 24px; border-top: 1px solid #2a241b; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px; font-size: 13px; color: #7a6a4f; }
footer.site-pb-foot .pb-legal a { color: #7a6a4f; margin-left: 14px; }
footer.site-pb-foot .pb-pyme { margin-top: 6px; font-size: 12px; color: #7a6a4f; }
footer.site-pb-foot .pb-pyme a { color: var(--pb-gold); }
footer.site-pb-foot .pb-brand { color: var(--pb-bg); margin-bottom: 12px; }
@media (max-width: 720px) { footer.site-pb-foot { padding: 48px 0 24px; } footer.site-pb-foot .pb-grid { gap: 28px; margin-bottom: 32px; } footer.site-pb-foot .pb-legal { flex-direction: column; gap: 8px; align-items: flex-start; } footer.site-pb-foot .pb-legal a { margin-left: 0; margin-right: 14px; } }

/* ─── ARTICLE PAGES ─────────────────────────────────────────────── */
.single-article { padding-top: 0; }
.article-hero { padding-top: 0; }
.article-hero img { width: 100%; height: auto; display: block; border-radius: 12px; box-shadow: 0 12px 28px rgba(0,0,0,0.10); }
.article-hero-image { max-width: 1180px; margin: 32px auto 0; padding: 0 24px; }
.article-hero-image img { width: 100%; height: auto; max-height: 520px; object-fit: cover; border-radius: 18px; box-shadow: 0 32px 64px -22px rgba(31,26,20,0.28); }
@media (max-width: 720px) { .article-hero-image { margin-top: 20px; padding: 0 18px; } .article-hero-image img { max-height: 320px; border-radius: 14px; } }
.article-header { max-width: 740px; margin: 0 auto; padding: 48px 24px 32px; }
.article-header .label { display: inline-block; font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: var(--pb-terra-deep); margin-bottom: 18px; }
.article-header h1 { font-family: 'Fraunces', serif; font-size: clamp(32px, 5vw, 52px); font-weight: 400; color: var(--pb-ink); line-height: 1.08; letter-spacing: -.02em; margin-bottom: 24px; }
.article-header-meta { display: flex; align-items: center; gap: 16px; padding-top: 24px; border-top: 1px dashed var(--pb-line); }
.article-author-img { width: 40px; height: 40px; border-radius: 50%; overflow: hidden; background: var(--pb-bg2); }
.article-author-img img { width: 100%; height: 100%; object-fit: cover; }
.article-author-name { font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 600; color: var(--pb-ink); }
.article-date { font-family: 'Inter', sans-serif; font-size: 13px; color: var(--pb-ink-soft); }
.article-body { max-width: 740px; margin: 0 auto; padding: 0 24px 80px; font-family: 'Inter', sans-serif; font-size: 18px; line-height: 1.62; color: var(--pb-ink); }
.article-body h2 { font-family: 'Fraunces', serif; font-size: 30px; font-weight: 500; color: var(--pb-ink); margin: 48px 0 18px; letter-spacing: -.015em; line-height: 1.15; }
.article-body h3 { font-family: 'Fraunces', serif; font-size: 22px; font-weight: 500; color: var(--pb-ink); margin: 36px 0 12px; letter-spacing: -.01em; }
.article-body p { margin-bottom: 22px; }
.article-body ul, .article-body ol { margin: 0 0 22px 24px; padding-left: 0; }
.article-body ul { list-style: disc; }
.article-body ol { list-style: decimal; }
.article-body li { margin-bottom: 8px; }
.article-body blockquote { font-family: 'Fraunces', serif; font-size: 22px; font-style: italic; color: var(--pb-terra-deep); padding-left: 24px; border-left: 3px solid var(--pb-gold); margin: 36px 0; line-height: 1.5; }
.article-body img { width: 100%; height: auto; border-radius: 14px; margin: 36px 0; box-shadow: 0 22px 44px -22px rgba(31,26,20,0.22); }
.article-body a { color: var(--pb-terra-deep); border-bottom: 1px solid rgba(125,47,18,0.35); }
.article-body a:hover { border-bottom-color: var(--pb-terra-deep); }
.article-body strong { color: var(--pb-ink); font-weight: 600; }
.article-body em { font-style: italic; }
.article-body .guide-intro { font-family: 'Fraunces', serif; font-style: italic; font-size: 19px; color: var(--pb-ink-soft); line-height: 1.55; padding: 24px 28px; background: var(--pb-paper); border-left: 3px solid var(--pb-gold); border-radius: 0 12px 12px 0; margin-bottom: 36px; }
.article-body .highlight-box, .article-body .info-box, .article-body .callout { background: var(--pb-paper); border: 1.5px solid var(--pb-gold); border-radius: 14px; padding: 24px 28px; margin: 32px 0; font-family: 'Inter', sans-serif; color: var(--pb-ink); }
.article-body table { width: 100%; border-collapse: collapse; margin: 28px 0; font-size: 15px; }
.article-body th, .article-body td { padding: 12px 14px; border-bottom: 1px solid var(--pb-line); text-align: left; }
.article-body th { font-family: 'Inter', sans-serif; font-weight: 600; color: var(--pb-ink); background: var(--pb-paper); }
.article-body figure { margin: 36px 0; }
.article-body figcaption { font-size: 13.5px; color: var(--pb-ink-soft); text-align: center; margin-top: 10px; font-style: italic; }

/* Sidebar TOC (auto-generated by main.js, .article-layout wraps both) */
.article-layout { max-width: 1180px; margin: 0 auto; padding: 0 24px 80px; display: grid; grid-template-columns: 240px minmax(0, 740px); gap: 56px; align-items: start; justify-content: center; }
.article-layout > .article-body { max-width: none; margin: 0; padding: 0; }
.article-toc { position: sticky; top: calc(var(--nav-height) + 24px); max-height: calc(100vh - var(--nav-height) - 48px); overflow-y: auto; padding-right: 8px; font-family: 'Inter', sans-serif; }
.article-toc::-webkit-scrollbar { width: 4px; }
.article-toc::-webkit-scrollbar-thumb { background: var(--pb-line); border-radius: 2px; }
.article-toc-title { font-size: 11.5px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--pb-terra-deep); margin-bottom: 18px; }
.article-toc-list { list-style: none; margin: 0; padding: 0; border-left: 1.5px solid var(--pb-line); }
.article-toc-list li { margin: 0; padding: 0; }
.article-toc-list li + li { margin-top: 2px; }
.article-toc-list a { display: block; padding: 6px 0 6px 16px; margin-left: -1.5px; border-left: 1.5px solid transparent; font-size: 13.5px; line-height: 1.45; color: var(--pb-ink-soft); transition: color .15s, border-color .15s; }
.article-toc-list a:hover { color: var(--pb-ink); border-left-color: var(--pb-gold-deep); }
.article-toc-list a.is-active { color: var(--pb-ink); font-weight: 600; border-left-color: var(--pb-gold); }
.article-toc-list .toc-level-3 a { padding-left: 28px; font-size: 12.5px; color: var(--pb-ink-soft); }
.article-toc-list .toc-level-3 a:hover, .article-toc-list .toc-level-3 a.is-active { color: var(--pb-ink); }
/* Hide any legacy inline TOC blocks. JS replaces them with the sidebar. */
.article-body > .toc, .article-body #ez-toc-container, .article-body .ez-toc-v2_0_82_2,
.article-layout .article-body > .toc, .article-layout .article-body > div > #ez-toc-container { display: none !important; }
.article-body h2[id], .article-body h3[id] { scroll-margin-top: calc(var(--nav-height) + 20px); }
@media (max-width: 1024px) {
  .article-layout { grid-template-columns: minmax(0, 740px); max-width: 740px; gap: 24px; padding: 0 24px 60px; }
  .article-toc { position: static; max-height: none; overflow: visible; padding: 0; background: var(--pb-paper); border: 1px solid var(--pb-line); border-radius: 12px; }
  .article-toc-details { padding: 16px 20px; }
  .article-toc-details > summary { cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 12px; color: var(--pb-ink); font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
  .article-toc-details > summary::-webkit-details-marker { display: none; }
  .article-toc-details > summary::after { content: '+'; font-size: 18px; font-weight: 400; color: var(--pb-gold-deep); transition: transform .2s; }
  .article-toc-details[open] > summary::after { content: '–'; }
  .article-toc-details .article-toc-title { display: none; }
  .article-toc-details .article-toc-list { margin-top: 14px; }
}

/* ─── ARCHIVE PAGES (section + category) ────────────────────────── */
.archive-header { background: var(--pb-ink); padding: 96px 0 56px; color: var(--pb-bg); }
.archive-header .container, .archive-header .pb-wrap { max-width: var(--pb-max); margin: 0 auto; padding: 0 24px; }
@media (min-width: 900px) { .archive-header .container, .archive-header .pb-wrap { padding: 0 40px; } }
.archive-header .label { display: inline-block; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .2em; color: var(--pb-gold); margin-bottom: 14px; }
.archive-header h1 { font-family: 'Fraunces', serif; font-size: clamp(40px, 5.5vw, 64px); font-weight: 400; color: var(--pb-bg); letter-spacing: -.025em; line-height: 1.05; }
.archive-header .archive-desc, .archive-header .archive-desc p { color: rgba(255,255,255,0.72); font-size: 17px; line-height: 1.65; max-width: 620px; margin-top: 16px; }
.archive-header::before { background: none !important; }

.archive-grid { padding: 72px 0; background: var(--pb-bg); }
.archive-grid .container { max-width: var(--pb-max); margin: 0 auto; padding: 0 24px; }
@media (min-width: 900px) { .archive-grid .container { padding: 0 40px; } }
.posts-grid { display: grid; grid-template-columns: 1fr; gap: 28px; }
@media (min-width: 700px) { .posts-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .posts-grid { grid-template-columns: repeat(3, 1fr); } }
.posts-grid > .article-card.is-hidden-lazy { display: none; }

/* article-card used in archives + homepage magazine grid */
.article-card { display: flex; flex-direction: column; cursor: pointer; color: var(--pb-ink); }
.article-card-image { aspect-ratio: 4/3; overflow: hidden; border-radius: 14px; margin-bottom: 16px; display: block; background: var(--pb-bg2); }
.article-card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.article-card:hover .article-card-image img { transform: scale(1.04); }
.article-card .label { display: inline-block; font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--pb-terra-deep); margin-bottom: 8px; }
.article-card-title { font-family: 'Fraunces', serif; font-size: 21px; font-weight: 500; line-height: 1.25; letter-spacing: -.005em; margin-bottom: 10px; color: var(--pb-ink); }
.article-card-title a { color: inherit; }
.article-card:hover .article-card-title { color: var(--pb-terra-deep); }
.article-card-meta { display: flex; align-items: center; gap: 8px; font-family: 'Inter', sans-serif; font-size: 12.5px; color: var(--pb-ink-soft); margin-top: auto; padding-top: 8px; }
.meta-dot { width: 3px; height: 3px; background: var(--pb-ink-soft); border-radius: 50%; opacity: 0.55; }

/* Related-articles / archive grid (used on post + section pages) */
.magazine-section { padding: 64px 0; }
.magazine-header { display: flex; flex-direction: column; gap: 6px; }
.magazine-header .label { font-family: 'Inter', sans-serif; font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--pb-terra-deep); }
.magazine-header .section-title { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 500; line-height: 1.2; letter-spacing: -.01em; color: var(--pb-ink); margin: 0; }
.magazine-grid { display: grid; grid-template-columns: 1fr; gap: 32px; }
@media (min-width: 700px) { .magazine-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .magazine-grid { grid-template-columns: repeat(3, 1fr); } }

/* Pagination */
.nav-links { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-top: 48px; }
.nav-links .page-numbers { font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 500; color: var(--pb-ink); padding: 8px 14px; border: 1.5px solid var(--pb-line); border-radius: 999px; transition: all 0.2s; }
.nav-links .page-numbers:hover, .nav-links .page-numbers.current { background: var(--pb-ink); color: var(--pb-bg); border-color: var(--pb-ink); }
.no-posts { font-family: 'Inter', sans-serif; font-size: 16px; color: var(--pb-ink-soft); grid-column: 1 / -1; text-align: center; padding: 60px 0; }

/* ─── PRE-FOOTER NEWSLETTER (legacy .email-capture) ─────────────── */
.email-capture { padding: 80px 0; background: var(--pb-paper); border-top: 1px solid var(--pb-line); }
.email-capture .container { max-width: var(--pb-max); margin: 0 auto; padding: 0 24px; }
@media (min-width: 900px) { .email-capture .container { padding: 0 40px; } }
.email-capture-inner { display: grid; grid-template-columns: 1fr; gap: 32px; align-items: center; }
@media (min-width: 900px) { .email-capture-inner { grid-template-columns: 1fr 1fr; gap: 64px; } }
.email-capture .label { display: inline-block; font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: var(--pb-terra-deep); margin-bottom: 12px; }
.email-capture-title { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 500; color: var(--pb-ink); line-height: 1.15; letter-spacing: -.015em; margin-bottom: 14px; }
.email-capture-desc { font-family: 'Inter', sans-serif; font-size: 16px; color: var(--pb-ink-soft); line-height: 1.6; }
.email-capture-form { display: flex; flex-direction: column; gap: 12px; }
.email-capture-row { display: flex; gap: 0; border: 1.5px solid var(--pb-line); border-radius: 999px; overflow: hidden; background: #fff; transition: border-color 0.2s; padding: 4px 4px 4px 8px; }
.email-capture-row:focus-within { border-color: var(--pb-gold-deep); box-shadow: 0 0 0 3px rgba(201,168,76,0.18); }
.email-capture-input { flex: 1; padding: 12px 16px; font-family: 'Inter', sans-serif; font-size: 15px; color: var(--pb-ink); background: transparent; border: none; outline: none; }
.email-capture-input::placeholder { color: var(--pb-ink-soft); opacity: 0.65; }
.email-capture-submit { padding: 12px 22px; background: var(--pb-ink); color: var(--pb-bg); font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 700; letter-spacing: .02em; border: none; border-radius: 999px; cursor: pointer; white-space: nowrap; transition: background 0.2s; }
.email-capture-submit:hover { background: var(--pb-terra-deep); }
.email-capture-note { font-family: 'Inter', sans-serif; font-size: 12.5px; color: var(--pb-ink-soft); }

/* ─── UTILITY (.container fallback for older markup) ────────────── */
.container { max-width: var(--pb-max); margin: 0 auto; padding: 0 24px; }
@media (min-width: 900px) { .container { padding: 0 40px; } }

/* ─── 404 ───────────────────────────────────────────────────────── */
.error-404 { min-height: 60vh; display: flex; align-items: center; justify-content: center; padding: 96px 24px 64px; text-align: center; flex-direction: column; gap: 12px; }
.error-404 h1 { font-family: 'Fraunces', serif; font-size: clamp(80px, 14vw, 140px); font-weight: 400; color: var(--pb-gold); line-height: 1; }
.error-404 h2 { font-family: 'Fraunces', serif; font-size: 32px; font-weight: 500; color: var(--pb-ink); margin-bottom: 8px; letter-spacing: -.01em; }
.error-404 p { color: var(--pb-ink-soft); margin-bottom: 32px; font-size: 17px; max-width: 480px; }

/* ─── SPONSORED / AD SLOTS ──────────────────────────────────────── */
.ad-slot { display: flex; align-items: center; justify-content: center; margin: 24px auto; overflow: hidden; }
.ad-slot:empty { display: none; }
.ad-slot--leaderboard { width: 100%; max-width: 728px; min-height: 90px; }
.ad-slot--banner { width: 100%; max-width: 970px; min-height: 66px; }
.ad-slot--rectangle { width: 100%; max-width: 336px; min-height: 280px; }
.ad-slot--preview { background: var(--pb-paper); border: 1px dashed var(--pb-mid-gray, #c9bca0); border-radius: 8px; min-height: 80px; color: var(--pb-ink-soft); font-family: 'Inter', sans-serif; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.sponsored-badge { display: inline-block; font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--pb-gold-deep); border: 1px solid rgba(140,111,36,0.45); padding: 2px 8px; border-radius: 999px; }
.sponsored-notice { display: block; font-family: 'Inter', sans-serif; font-size: 12.5px; color: var(--pb-gold-deep); border: 1px solid rgba(140,111,36,0.35); background: rgba(201,168,76,0.08); padding: 10px 18px; border-radius: 12px; margin-bottom: 24px; }

/* ─── LEGACY HELPERS (kept for content-template compatibility) ──── */
.article-photo { width: 100%; height: auto; border-radius: 14px; box-shadow: 0 22px 44px -22px rgba(31,26,20,0.18); }
.fig-meta { margin-top: 0.75rem; font-size: 13px; color: var(--pb-ink-soft); text-align: center; font-style: italic; }
.content-narrow { max-width: 740px; margin: 0 auto; padding: 0 24px; }
.content-narrow--end { padding: 0 24px 40px; }
.related-section { padding-top: 48px; border-top: 1px solid var(--pb-line); }
.related-grid-3 { display: grid; grid-template-columns: 1fr; gap: 24px; }
@media (min-width: 700px) { .related-grid-3 { grid-template-columns: repeat(3, 1fr); } }
.related-card { display: block; padding: 24px; background: var(--pb-paper); border: 1px solid var(--pb-line); border-radius: 14px; text-decoration: none; color: var(--pb-ink); transition: border-color .15s, box-shadow .15s; }
.related-card:hover { border-color: var(--pb-gold); box-shadow: 0 22px 44px -22px rgba(31,26,20,0.18); }
.cta-title { font-weight: 700; font-family: 'Fraunces', serif; }

/* ─── ACCESSIBILITY ─────────────────────────────────────────────── */
.screen-reader-text { clip: rect(1px, 1px, 1px, 1px); height: 1px; overflow: hidden; position: absolute; width: 1px; word-wrap: normal !important; }
@media (prefers-reduced-motion: reduce) { *{transition:none!important;animation:none!important} }

/* ─── MOBILE TUNING ─────────────────────────────────────────────── */
@media (max-width: 720px) {
  body { font-size: 16px; }
  .pb-wrap { padding: 0 18px; }
  .pb-top { padding: 8px 0; font-size: 12px; }
  .pb-top .pb-wrap { display: flex; gap: 6px; flex-direction: column; align-items: stretch; grid-template-columns: none; }
  .pb-top .pb-l { width: 100%; }
  .pb-top .pb-l:first-child { font-size: 11.5px; line-height: 1.3; justify-self: stretch; }
  .pb-search { width: 100%; }
  .pb-top .pb-l:last-child { width: 100%; justify-content: space-between; gap: 10px; }
  .site-pb .pb-wrap { padding: 14px 18px; gap: 10px; }
  .pb-brand { font-size: 21px; }
  .pb-headcta .pb-btn { display: none; }
  .pb-btn { padding: 10px 16px; font-size: 13.5px; }
  h1.pb-h1 { font-size: clamp(38px, 9.5vw, 58px); margin-bottom: 16px; line-height: 1.04; }
  .lede { font-size: 16.5px; margin-bottom: 22px; }
  h2.pb-h2 { font-size: clamp(30px, 6.2vw, 40px); line-height: 1.08; margin-bottom: 14px; }
  .sec-eyebrow { font-size: 11.5px; letter-spacing: .16em; }
  .article-header { padding: 32px 18px 24px; }
  .article-body { padding: 0 18px 56px; }
  .article-layout { padding: 0 18px 56px; }
  .archive-header { padding: 72px 0 40px; }
  .archive-grid { padding: 48px 0; }
  .archive-grid .container { padding: 0 18px; }
  .email-capture { padding: 56px 0; }
  .email-capture .container { padding: 0 18px; }
}

/* ─── SAY-BOX (phrasebook callouts) ────────────────────────────── */
.say-box { background: var(--pb-paper); border: 1px solid var(--pb-bg2); border-left: 4px solid var(--pb-gold); padding: 1.1rem 1.3rem; margin: 1.6rem 0; border-radius: 10px; }
.say-box .say-label { display: block; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--pb-gold-deep); font-weight: 700; margin-bottom: .5rem; }
.say-box p { margin: .4rem 0; color: var(--pb-ink); }
.say-box .es { font-weight: 600; }
.say-box .en { color: var(--pb-ink-soft); font-style: italic; }

/* ─── CATALINA INLINE CTA (article body prompt) ─────────────────── */
.cat-cta-inline { display: flex; flex-wrap: wrap; align-items: center; gap: .75rem; margin: 1.25rem 0; padding: .85rem 1rem; background: var(--pb-paper); border-left: 3px solid var(--pb-gold); border-radius: 6px; font-size: .95rem; line-height: 1.4; }
.cat-cta-inline .cat-cta-text { flex: 1; min-width: 220px; color: var(--pb-ink); }
.cat-cta-inline .cat-cta-btn { display: inline-flex; align-items: center; gap: .4rem; background: var(--pb-ink); color: var(--pb-bg); padding: .5rem .9rem; border-radius: 5px; text-decoration: none; font-weight: 600; font-size: .9rem; white-space: nowrap; transition: background .15s ease; border: none; cursor: pointer; }
.cat-cta-inline .cat-cta-btn:hover { background: var(--pb-terra-deep); }

/* ─── CATALINA MID CTA (dark navy aside) ─────────────────────────── */
.cat-cta-mid { margin: 2rem 0; padding: 1.1rem 1.25rem; background: var(--pb-ink); color: #fff; border-radius: 8px; font-size: .95rem; line-height: 1.55; }
.cat-cta-mid .cat-cta-mid-title { margin: 0 0 .5rem; font-family: 'Fraunces', serif; font-size: 1.15rem; font-weight: 600; color: var(--pb-gold); }
.cat-cta-mid .cat-cta-mid-body { margin: 0 0 .9rem; color: var(--pb-bg); }
.cat-cta-mid .cat-cta-mid-btn { display: inline-flex; align-items: center; gap: .4rem; background: var(--pb-gold); color: var(--pb-ink); padding: .6rem 1rem; border-radius: 5px; text-decoration: none; font-weight: 700; font-size: .92rem; transition: opacity .15s ease; }
.cat-cta-mid .cat-cta-mid-btn:hover { opacity: .85; }

/* ─── CATALINA BOTTOM CTA (pale-gold card) ───────────────────────── */
.cat-cta-bot { margin: 2.5rem 0 1rem; padding: 1.5rem; background: var(--pb-bg); border: 1px solid var(--pb-gold); border-radius: 10px; }
.cat-cta-bot .cat-cta-bot-title { margin: 0 0 .4rem; font-family: 'Fraunces', serif; font-size: 1.35rem; font-weight: 600; color: var(--pb-ink); }
.cat-cta-bot .cat-cta-bot-body { margin: 0 0 1rem; color: var(--pb-ink); font-size: .97rem; line-height: 1.6; }
.cat-cta-bot .cat-cta-bot-btn { display: inline-flex; align-items: center; gap: .45rem; background: var(--pb-ink); color: #fff; padding: .7rem 1.2rem; border-radius: 6px; text-decoration: none; font-weight: 700; font-size: 1rem; transition: background .15s ease; }
.cat-cta-bot .cat-cta-bot-btn:hover { background: var(--pb-terra-deep); }

/* ─── MEDELLIN-COMPAT: ARTICLE CONTENT CLASSES ──────────────────── */
/* Classes used in medellin.guide article HTML (pre-migration). Phase 2
   will update HTML to pb-* markup; these can be dropped then. */

.breadcrumb { font-size: .875rem; color: var(--pb-ink-soft); margin-bottom: 2rem; }
.breadcrumb a { color: var(--pb-gold); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }

.category-tag { display: inline-block; background: var(--pb-paper); color: var(--pb-gold-deep); padding: .4rem .8rem; border-radius: 4px; font-size: .75rem; font-weight: 700; text-transform: uppercase; margin-bottom: 1rem; border: 1px solid rgba(201,168,76,0.3); }

.article-meta { display: flex; gap: 1.5rem; font-size: .875rem; color: var(--pb-ink-soft); margin-bottom: 1rem; flex-wrap: wrap; }

.article-excerpt { font-size: 1.1rem; color: var(--pb-ink-soft); font-style: italic; margin-bottom: 2rem; border-left: 3px solid var(--pb-gold); padding-left: 1.5rem; }

.neighborhood-card { background: var(--pb-paper); border-radius: 8px; padding: 1.5rem; margin: 2rem 0; border-left: 4px solid var(--pb-gold); box-shadow: 0 2px 8px rgba(31,26,20,0.08); }
.neighborhood-card h3 { margin-top: 0; color: var(--pb-ink); }

.neighborhood-highlights { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin: 1.5rem 0; font-size: .95rem; }
@media (max-width: 600px) { .neighborhood-highlights { grid-template-columns: 1fr; } }

.highlight-item { padding: .75rem; background: var(--pb-bg); border-radius: 4px; color: var(--pb-ink-soft); }
.highlight-item strong { color: var(--pb-ink); display: block; margin-bottom: .25rem; }

.best-for { background: var(--pb-bg); padding: 1rem; border-radius: 4px; margin-top: 1rem; font-style: italic; color: var(--pb-ink-soft); }
.best-for strong { color: var(--pb-ink); }

.cta-section { background: var(--pb-paper); border-radius: 8px; padding: 2rem; margin: 3rem 0; text-align: center; box-shadow: 0 2px 8px rgba(31,26,20,0.08); border: 1px solid var(--pb-line); }
.cta-section h3 { margin-top: 0; font-family: 'Fraunces', Georgia, serif; }
.cta-section p { margin-bottom: 1.5rem; }

.cta-buttons { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
@media (max-width: 480px) { .cta-buttons { flex-direction: column; } .cta-buttons a, .cta-buttons button { width: 100%; text-align: center; } }

.btn-primary { display: inline-block; background: var(--pb-gold); color: var(--pb-ink); padding: .8rem 2rem; border-radius: 6px; text-decoration: none; font-weight: 600; transition: background .2s ease; border: none; cursor: pointer; font-family: inherit; }
.btn-primary:hover { background: var(--pb-gold-deep); }

.btn-secondary { display: inline-block; background: transparent; color: var(--pb-gold-deep); padding: .8rem 2rem; border-radius: 6px; text-decoration: none; font-weight: 600; border: 2px solid var(--pb-gold); transition: all .2s ease; cursor: pointer; font-family: inherit; }
.btn-secondary:hover { background: var(--pb-gold); color: var(--pb-ink); }

.related-posts { margin-top: 4rem; padding-top: 2rem; border-top: 2px solid var(--pb-line); }
.related-posts h3 { margin-top: 0; font-family: 'Fraunces', Georgia, serif; }

.related-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; margin-top: 1.5rem; }

.related-card-category { font-size: .75rem; font-weight: 700; text-transform: uppercase; color: var(--pb-ink-soft); margin-bottom: .5rem; letter-spacing: .1em; }

.guide-toc { background: var(--pb-paper); border-left: 4px solid var(--pb-gold); padding: 1.25rem 1.5rem; margin: 2rem 0; border-radius: 8px; box-shadow: 0 2px 8px rgba(31,26,20,0.06); }
.guide-toc h2 { margin-top: 0; font-size: 1.2rem; font-family: 'Fraunces', Georgia, serif; color: var(--pb-ink); }
.guide-toc ol { margin: .5rem 0 0 1.25rem; }
.guide-toc li { margin-bottom: .3rem; }
.guide-toc a { color: var(--pb-ink); text-decoration: none; }
.guide-toc a:hover { color: var(--pb-gold); }
