/* ===================================================================
   Per-template stylesheets for the 6 NPH installer page layouts.
   Scoped under body.tpl-{name} so /admin/template can swap them
   without touching public.css.
   =================================================================== */

/* Shared resets that apply across all templates */
body[class^="tpl-"] .tpl-root,
body[class*=" tpl-"] .tpl-root { display: block; max-width: 1280px; margin: 0 auto; padding: 0 24px; }
body[class^="tpl-"] .tpl-portfolio-img,
body[class*=" tpl-"] .tpl-portfolio-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display:block; }
body[class^="tpl-"] .tpl-claim-cta,
body[class*=" tpl-"] .tpl-claim-cta {
  display:flex;align-items:center;gap:16px;padding:18px 22px;border:1px dashed currentColor;
  border-radius:8px;margin:24px 0;font-size:14px;
}

/* ========================================================
   1. EDITORIAL — Architectural Digest profile feel.
   Story-led, drop-cap intro, two-column body, Playfair display
   ======================================================== */
body.tpl-editorial { background: #fafaf6; color: #1a1a1a; font-family: 'Cormorant Garamond', Georgia, serif; }
body.tpl-editorial .tpl-root { max-width: 1080px; padding: 0 32px; }
body.tpl-editorial .ed-kicker {
  font-family: Inter, sans-serif; font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: #8c1d1d; margin: 48px 0 12px;
}
body.tpl-editorial .ed-title { font-size: clamp(38px, 6vw, 72px); font-weight: 500; line-height: 1.05; letter-spacing: -0.01em; margin: 0 0 8px; }
body.tpl-editorial .ed-deck { font-size: 22px; font-weight: 300; font-style: italic; color: #555; max-width: 720px; margin: 0 0 36px; }
body.tpl-editorial .ed-hero { width: 100%; aspect-ratio: 16/9; object-fit: cover; margin: 0 0 8px; border-radius: 2px; }
body.tpl-editorial .ed-hero-cap { font-family: Inter, sans-serif; font-size: 12px; color: #777; margin: 0 0 56px; font-style: italic; }
body.tpl-editorial .ed-body { display: grid; grid-template-columns: 1.6fr 1fr; gap: 64px; }
body.tpl-editorial .ed-prose { font-size: 19px; line-height: 1.65; }
body.tpl-editorial .ed-prose p:first-of-type::first-letter {
  font-size: 78px; float: left; line-height: 0.85; padding: 8px 12px 0 0;
  font-weight: 600; color: #8c1d1d;
}
body.tpl-editorial .ed-prose h2 { font-size: 30px; font-weight: 500; margin: 48px 0 16px; letter-spacing: -0.01em; }
body.tpl-editorial .ed-side {
  font-family: Inter, sans-serif; font-size: 14px; line-height: 1.55;
  border-top: 2px solid #1a1a1a; padding-top: 24px; align-self: start; position: sticky; top: 24px;
}
body.tpl-editorial .ed-side h3 { font-family: 'Cormorant Garamond', serif; font-size: 22px; margin: 0 0 14px; }
body.tpl-editorial .ed-side dl { display: grid; grid-template-columns: 100px 1fr; gap: 6px 18px; margin: 0 0 28px; }
body.tpl-editorial .ed-side dt { color: #777; text-transform: uppercase; font-size: 11px; letter-spacing: 0.1em; }
body.tpl-editorial .ed-side dd { margin: 0; color: #1a1a1a; }
body.tpl-editorial .ed-portfolio { margin-top: 80px; padding-top: 56px; border-top: 2px solid #1a1a1a; }
body.tpl-editorial .ed-portfolio h2 { font-size: 38px; font-weight: 500; margin: 0 0 28px; }
body.tpl-editorial .ed-pf-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 28px; }
body.tpl-editorial .ed-pf-card figcaption { font-family: Inter, sans-serif; font-size: 13px; padding: 12px 0; }
body.tpl-editorial .ed-cta { background: #1a1a1a; color: #fafaf6; padding: 64px 48px; margin: 96px 0 0; text-align: center; }
body.tpl-editorial .ed-cta h2 { font-size: 42px; font-weight: 500; margin: 0 0 24px; }
body.tpl-editorial .btn-ed { display: inline-block; background: #fafaf6; color: #1a1a1a; padding: 16px 36px; font-family: Inter, sans-serif; font-size: 14px; text-decoration: none; letter-spacing: 0.05em; }
@media (max-width: 800px) { body.tpl-editorial .ed-body { grid-template-columns: 1fr; gap: 32px; } }

/* ========================================================
   2. TRADE-PRO — workshop floor / spec-sheet aesthetic.
   Mono + sans, kraft-paper background, technical panel
   ======================================================== */
body.tpl-trade-pro { background: #ede5d3; color: #14110b; font-family: 'JetBrains Mono', 'Courier New', monospace; }
body.tpl-trade-pro .tpl-root { max-width: 1240px; padding: 0 24px; }
body.tpl-trade-pro .tp-banner {
  background: #14110b; color: #ede5d3; padding: 20px 24px; margin: 0 -24px 32px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: Inter, sans-serif; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
}
body.tpl-trade-pro .tp-banner b { color: #ffaa00; }
body.tpl-trade-pro .tp-headerblock { border: 2px solid #14110b; padding: 32px; margin: 0 0 32px; background: #fff8e7; }
body.tpl-trade-pro .tp-job-no { font-size: 11px; color: #6a5e3d; letter-spacing: 0.18em; }
body.tpl-trade-pro .tp-name { font-family: Inter, sans-serif; font-size: 44px; font-weight: 700; margin: 4px 0 12px; letter-spacing: -0.02em; }
body.tpl-trade-pro .tp-meta { font-size: 13px; line-height: 1.7; }
body.tpl-trade-pro .tp-grid { display: grid; grid-template-columns: 2fr 1.2fr; gap: 32px; }
body.tpl-trade-pro .tp-specs { background: #fff8e7; border: 2px solid #14110b; }
body.tpl-trade-pro .tp-specs h3 {
  background: #14110b; color: #ede5d3; margin: 0; padding: 14px 20px; font-size: 12px;
  font-family: Inter, sans-serif; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
}
body.tpl-trade-pro .tp-specs table { width: 100%; border-collapse: collapse; font-size: 13px; }
body.tpl-trade-pro .tp-specs th, body.tpl-trade-pro .tp-specs td { padding: 10px 20px; text-align: left; border-bottom: 1px solid #d4c8a8; }
body.tpl-trade-pro .tp-specs th { color: #6a5e3d; font-weight: 400; width: 40%; text-transform: uppercase; font-size: 11px; letter-spacing: 0.08em; }
body.tpl-trade-pro .tp-bio { padding: 32px; background: #fff8e7; border: 2px solid #14110b; font-family: Inter, sans-serif; font-size: 16px; line-height: 1.6; }
body.tpl-trade-pro .tp-bio h2 { font-size: 14px; letter-spacing: 0.2em; text-transform: uppercase; margin: 0 0 16px; color: #6a5e3d; font-weight: 700; }
body.tpl-trade-pro .tp-detail-row { margin-top: 56px; }
body.tpl-trade-pro .tp-detail-row h2 { font-family: Inter, sans-serif; font-size: 22px; letter-spacing: -0.01em; margin: 0 0 8px; }
body.tpl-trade-pro .tp-detail-row p { font-family: Inter, sans-serif; font-size: 14px; color: #4a3f29; max-width: 640px; margin: 0 0 24px; }
body.tpl-trade-pro .tp-detail-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
body.tpl-trade-pro .tp-detail-card { border: 2px solid #14110b; background: #fff8e7; }
body.tpl-trade-pro .tp-detail-card .label {
  background: #14110b; color: #ede5d3; padding: 8px 14px; font-family: Inter, sans-serif;
  font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase;
  display: flex; justify-content: space-between;
}
body.tpl-trade-pro .tp-detail-card .label .stamp { color: #ffaa00; }
body.tpl-trade-pro .tp-cta { background: #14110b; color: #ede5d3; padding: 48px; margin: 64px 0 0; text-align: center; font-family: Inter, sans-serif; }
body.tpl-trade-pro .tp-cta a { background: #ffaa00; color: #14110b; display: inline-block; padding: 14px 32px; font-weight: 700; text-decoration: none; letter-spacing: 0.05em; }
@media (max-width: 800px) { body.tpl-trade-pro .tp-grid { grid-template-columns: 1fr; } body.tpl-trade-pro .tp-name { font-size: 28px; } }

/* ========================================================
   3. CONCIERGE — black + ivory + brushed gold, by appointment
   ======================================================== */
body.tpl-concierge { background: #0e0e0e; color: #f3ede1; font-family: 'Cormorant Garamond', serif; }
body.tpl-concierge .tpl-root { max-width: 920px; padding: 0 32px; text-align: center; }
body.tpl-concierge .cc-eyebrow { font-family: Inter, sans-serif; font-size: 10px; letter-spacing: 0.4em; text-transform: uppercase; color: #c8a96a; margin: 80px 0 20px; }
body.tpl-concierge .cc-rule { width: 64px; height: 1px; background: #c8a96a; margin: 0 auto 28px; }
body.tpl-concierge .cc-name { font-size: clamp(48px, 7vw, 88px); font-weight: 300; letter-spacing: -0.01em; margin: 0 0 16px; }
body.tpl-concierge .cc-place { font-family: Inter, sans-serif; font-size: 13px; letter-spacing: 0.3em; text-transform: uppercase; color: #aaa097; margin: 0 0 56px; }
body.tpl-concierge .cc-line {
  font-size: 28px; font-weight: 300; font-style: italic; color: #c8a96a;
  max-width: 640px; margin: 0 auto 64px; line-height: 1.4;
}
body.tpl-concierge .cc-hero { width: 100%; aspect-ratio: 21/9; object-fit: cover; filter: grayscale(0.15) contrast(1.05); margin: 0 0 64px; }
body.tpl-concierge .cc-bio { font-size: 19px; line-height: 1.7; max-width: 680px; margin: 0 auto 80px; color: #e6dec8; text-align: left; }
body.tpl-concierge .cc-strip { display: flex; justify-content: center; gap: 64px; padding: 48px 0; border-top: 1px solid #2a2620; border-bottom: 1px solid #2a2620; margin: 0 0 80px; }
body.tpl-concierge .cc-strip div { font-family: Inter, sans-serif; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; color: #aaa097; }
body.tpl-concierge .cc-strip div b { display: block; font-family: 'Cormorant Garamond', serif; font-size: 32px; font-weight: 400; letter-spacing: -0.01em; color: #f3ede1; margin-top: 4px; text-transform: none; }
body.tpl-concierge .cc-portfolio { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin: 0 0 80px; }
body.tpl-concierge .cc-portfolio figure { margin: 0; }
body.tpl-concierge .cc-portfolio figcaption { font-family: Inter, sans-serif; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; padding: 14px 0; color: #aaa097; text-align: left; }
body.tpl-concierge .cc-cta { padding: 80px 0 120px; }
body.tpl-concierge .cc-cta a {
  display: inline-block; padding: 18px 56px; border: 1px solid #c8a96a;
  color: #c8a96a; font-family: Inter, sans-serif; font-size: 13px; letter-spacing: 0.3em;
  text-transform: uppercase; text-decoration: none; transition: all .3s;
}
body.tpl-concierge .cc-cta a:hover { background: #c8a96a; color: #0e0e0e; }
@media (max-width: 700px) { body.tpl-concierge .cc-portfolio { grid-template-columns: 1fr; } body.tpl-concierge .cc-strip { flex-direction: column; gap: 24px; } }

/* ========================================================
   4. STUDIO — modern grid, color blocks, big tiles
   ======================================================== */
body.tpl-studio { background: #fff; color: #0a0a0a; font-family: Inter, system-ui, sans-serif; }
body.tpl-studio .tpl-root { max-width: 1320px; padding: 0; }
body.tpl-studio .st-hero { display: grid; grid-template-columns: 1.1fr 1fr; min-height: 540px; }
body.tpl-studio .st-hero-text { padding: 96px 64px; display: flex; flex-direction: column; justify-content: center; }
body.tpl-studio .st-pill {
  display: inline-flex; align-items: center; gap: 6px; align-self: start;
  background: #efece5; padding: 8px 14px; border-radius: 999px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.02em; margin: 0 0 24px;
}
body.tpl-studio .st-pill::before { content: '●'; color: #16a34a; font-size: 10px; }
body.tpl-studio .st-name { font-size: clamp(40px, 5.5vw, 64px); line-height: 1.02; letter-spacing: -0.025em; font-weight: 700; margin: 0 0 20px; }
body.tpl-studio .st-headline { font-size: 22px; line-height: 1.5; color: #444; max-width: 560px; margin: 0 0 36px; }
body.tpl-studio .st-actions { display: flex; gap: 12px; flex-wrap: wrap; }
body.tpl-studio .st-actions a {
  padding: 14px 24px; border-radius: 12px; text-decoration: none; font-size: 15px; font-weight: 600;
}
body.tpl-studio .st-actions .primary { background: #0a0a0a; color: #fff; }
body.tpl-studio .st-actions .ghost { border: 1px solid #d4d2c8; color: #0a0a0a; }
body.tpl-studio .st-hero-img { background-size: cover; background-position: center; }
body.tpl-studio .st-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: #d4d2c8;
  margin: 0; padding: 1px;
}
body.tpl-studio .st-strip div { background: #fff; padding: 32px; }
body.tpl-studio .st-strip .num { font-size: 36px; font-weight: 700; letter-spacing: -0.02em; }
body.tpl-studio .st-strip .lbl { font-size: 13px; color: #666; margin-top: 4px; }
body.tpl-studio .st-section { padding: 80px 64px; }
body.tpl-studio .st-section h2 { font-size: 36px; line-height: 1.1; letter-spacing: -0.02em; font-weight: 700; margin: 0 0 32px; }
body.tpl-studio .st-bio { display: grid; grid-template-columns: 1fr 1.6fr; gap: 64px; max-width: 1100px; margin: 0; }
body.tpl-studio .st-bio h2 { margin: 0; }
body.tpl-studio .st-bio p { font-size: 18px; line-height: 1.65; color: #2a2a2a; max-width: 720px; }
body.tpl-studio .st-tiles { display: grid; grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); gap: 16px; }
body.tpl-studio .st-tile { border-radius: 16px; overflow: hidden; background: #efece5; }
body.tpl-studio .st-tile img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
body.tpl-studio .st-tile-meta { padding: 18px 22px; }
body.tpl-studio .st-tile-meta h3 { margin: 0 0 4px; font-size: 18px; font-weight: 700; }
body.tpl-studio .st-tile-meta p { margin: 0; font-size: 13px; color: #666; }
body.tpl-studio .st-cta {
  margin: 80px 64px; padding: 64px; border-radius: 24px;
  background: linear-gradient(135deg, #0a0a0a 0%, #1f1f1f 100%); color: #fff; text-align: center;
}
body.tpl-studio .st-cta h2 { color: #fff; }
body.tpl-studio .st-cta a { display: inline-block; background: #fff; color: #0a0a0a; padding: 16px 32px; border-radius: 12px; text-decoration: none; font-weight: 600; font-size: 16px; }
@media (max-width: 900px) {
  body.tpl-studio .st-hero { grid-template-columns: 1fr; }
  body.tpl-studio .st-hero-img { min-height: 320px; }
  body.tpl-studio .st-hero-text { padding: 56px 32px; }
  body.tpl-studio .st-strip { grid-template-columns: repeat(2, 1fr); }
  body.tpl-studio .st-section, body.tpl-studio .st-cta { padding: 48px 32px; margin: 48px 24px; }
  body.tpl-studio .st-bio { grid-template-columns: 1fr; gap: 24px; }
}

/* ========================================================
   5. HERITAGE — sepia, classical serif, "Est. 19XX" emblem
   ======================================================== */
body.tpl-heritage { background: #f7f0e2; color: #2c1f10; font-family: 'Cormorant Garamond', Georgia, serif; }
body.tpl-heritage .tpl-root { max-width: 1100px; padding: 0 32px; }
body.tpl-heritage .hr-emblem {
  text-align: center; margin: 60px auto 0; padding: 24px 32px;
  border-top: 3px double #6b4a1f; border-bottom: 3px double #6b4a1f;
  display: inline-block; min-width: 280px;
}
body.tpl-heritage .hr-emblem-wrap { text-align: center; }
body.tpl-heritage .hr-est {
  font-family: Inter, sans-serif; font-size: 11px; letter-spacing: 0.4em;
  text-transform: uppercase; color: #6b4a1f;
}
body.tpl-heritage .hr-year { font-size: 56px; font-weight: 400; letter-spacing: -0.01em; line-height: 1; margin: 8px 0; }
body.tpl-heritage .hr-name { font-size: clamp(40px, 5.5vw, 64px); font-weight: 400; text-align: center; margin: 32px 0 12px; letter-spacing: -0.005em; }
body.tpl-heritage .hr-place { text-align: center; font-family: Inter, sans-serif; font-size: 13px; letter-spacing: 0.25em; text-transform: uppercase; color: #6b4a1f; margin: 0 0 64px; }
body.tpl-heritage .hr-hero { width: 100%; aspect-ratio: 16/9; object-fit: cover; filter: sepia(0.25) contrast(1.05); border: 8px solid #fff; box-shadow: 0 10px 30px rgba(44,31,16,0.12); margin: 0 0 80px; }
body.tpl-heritage .hr-body { display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; }
body.tpl-heritage .hr-prose { font-size: 19px; line-height: 1.75; }
body.tpl-heritage .hr-prose p:first-of-type::first-letter {
  font-size: 64px; float: left; line-height: 0.9; padding: 6px 12px 0 0;
  color: #6b4a1f; font-weight: 500;
}
body.tpl-heritage .hr-side { font-family: Inter, sans-serif; font-size: 14px; line-height: 1.6; }
body.tpl-heritage .hr-side h3 { font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 500; margin: 0 0 16px; padding-bottom: 8px; border-bottom: 1px solid #6b4a1f; }
body.tpl-heritage .hr-side ul { list-style: none; padding: 0; margin: 0 0 32px; }
body.tpl-heritage .hr-side li { padding: 8px 0; border-bottom: 1px dotted #c9b48c; display: flex; justify-content: space-between; }
body.tpl-heritage .hr-side li::before { content: '◆'; color: #6b4a1f; margin-right: 8px; font-size: 10px; }
body.tpl-heritage .hr-portfolio { margin: 96px 0; }
body.tpl-heritage .hr-portfolio h2 { text-align: center; font-size: 38px; font-weight: 400; margin: 0 0 12px; }
body.tpl-heritage .hr-portfolio-sub { text-align: center; font-style: italic; color: #6b4a1f; margin: 0 0 48px; }
body.tpl-heritage .hr-pf-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 32px; }
body.tpl-heritage .hr-pf-card { background: #fff; padding: 16px; box-shadow: 0 4px 12px rgba(44,31,16,0.08); }
body.tpl-heritage .hr-pf-card img { filter: sepia(0.15); }
body.tpl-heritage .hr-pf-card figcaption { font-family: Inter, sans-serif; font-size: 13px; padding: 12px 4px 4px; color: #4a3520; }
body.tpl-heritage .hr-cta { background: #2c1f10; color: #f7f0e2; padding: 64px 48px; text-align: center; margin: 64px 0; }
body.tpl-heritage .hr-cta h2 { font-size: 38px; font-weight: 400; margin: 0 0 24px; }
body.tpl-heritage .hr-cta a { display: inline-block; background: #c9a662; color: #2c1f10; padding: 14px 32px; text-decoration: none; font-family: Inter, sans-serif; letter-spacing: 0.1em; font-weight: 600; }
@media (max-width: 800px) { body.tpl-heritage .hr-body { grid-template-columns: 1fr; gap: 32px; } }

/* ========================================================
   6. BILINGÜE — EN/ES toggle, warm ochre + terracotta
   ======================================================== */
body.tpl-bilingue { background: #fff7ec; color: #2b1812; font-family: Inter, system-ui, sans-serif; }
body.tpl-bilingue .tpl-root { max-width: 1180px; padding: 0 24px; }
body.tpl-bilingue .bl-langtoggle {
  display: inline-flex; gap: 0; border: 2px solid #2b1812; border-radius: 999px; overflow: hidden;
  font-size: 12px; font-weight: 700; letter-spacing: 0.1em; margin: 32px 0 0;
}
body.tpl-bilingue .bl-langtoggle button {
  background: #fff7ec; color: #2b1812; border: 0; padding: 8px 18px; cursor: pointer; font: inherit;
}
body.tpl-bilingue .bl-langtoggle button.active { background: #2b1812; color: #fff7ec; }
body.tpl-bilingue [data-lang]:not([data-lang="en"]) { display: none; }
body.tpl-bilingue.lang-es [data-lang="en"] { display: none; }
body.tpl-bilingue.lang-es [data-lang="es"] { display: initial; }
body.tpl-bilingue .bl-hero { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; padding: 48px 0 80px; }
body.tpl-bilingue .bl-hero-img { width: 100%; aspect-ratio: 4/5; object-fit: cover; border-radius: 24px; }
body.tpl-bilingue .bl-name { font-size: clamp(40px, 6vw, 68px); line-height: 1.05; letter-spacing: -0.02em; font-weight: 800; margin: 16px 0 12px; color: #b85c2b; }
body.tpl-bilingue .bl-place { font-size: 18px; letter-spacing: 0.05em; margin: 0 0 24px; color: #6a4538; }
body.tpl-bilingue .bl-headline { font-size: 22px; line-height: 1.5; max-width: 520px; margin: 0 0 32px; color: #2b1812; }
body.tpl-bilingue .bl-cta { display: inline-block; background: #b85c2b; color: #fff7ec; padding: 16px 32px; border-radius: 999px; text-decoration: none; font-weight: 700; font-size: 16px; }
body.tpl-bilingue .bl-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
  background: #ecd9b8; padding: 32px; border-radius: 24px; margin: 0 0 80px;
}
body.tpl-bilingue .bl-stats div { text-align: center; }
body.tpl-bilingue .bl-stats .num { font-size: 36px; font-weight: 800; color: #b85c2b; line-height: 1; }
body.tpl-bilingue .bl-stats .lbl { font-size: 13px; color: #6a4538; margin-top: 6px; }
body.tpl-bilingue .bl-section { padding: 48px 0; }
body.tpl-bilingue .bl-section h2 { font-size: 36px; font-weight: 800; letter-spacing: -0.02em; margin: 0 0 24px; color: #2b1812; }
body.tpl-bilingue .bl-callout {
  background: #b85c2b; color: #fff7ec; padding: 24px 32px; border-radius: 16px;
  font-size: 18px; font-weight: 600; margin: 0 0 32px; line-height: 1.5;
}
body.tpl-bilingue .bl-bio { font-size: 18px; line-height: 1.7; color: #2b1812; max-width: 760px; }
body.tpl-bilingue .bl-pf-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
body.tpl-bilingue .bl-pf-card { background: #ecd9b8; border-radius: 16px; overflow: hidden; }
body.tpl-bilingue .bl-pf-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
body.tpl-bilingue .bl-pf-card .meta { padding: 14px 18px; }
body.tpl-bilingue .bl-pf-card h3 { margin: 0 0 4px; font-size: 16px; font-weight: 700; }
body.tpl-bilingue .bl-pf-card p { margin: 0; font-size: 13px; color: #6a4538; }
body.tpl-bilingue .bl-cta-final { background: #2b1812; color: #fff7ec; padding: 64px 48px; border-radius: 24px; text-align: center; margin: 64px 0; }
body.tpl-bilingue .bl-cta-final h2 { color: #fff7ec; font-size: 36px; margin: 0 0 24px; }
body.tpl-bilingue .bl-cta-final a { display: inline-block; background: #b85c2b; color: #fff7ec; padding: 16px 32px; border-radius: 999px; text-decoration: none; font-weight: 700; }
@media (max-width: 800px) {
  body.tpl-bilingue .bl-hero { grid-template-columns: 1fr; gap: 24px; padding: 32px 0 48px; }
  body.tpl-bilingue .bl-stats { grid-template-columns: repeat(2, 1fr); }
}
