
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --g: #3d6b10;
  --g-mid: #5b9320;
  --g-light: #eaf3de;
  --g-dark: #2a4b0a;
  --g-paper: #f3f6ec;
  --ink: #141714;
  --soft: #5a5a55;
  --faint: #8f8e88;
  --line: rgba(20,23,20,0.09);
  --line-strong: rgba(20,23,20,0.16);
  --bg: #ffffff;
  --cream: #f6f3ec;
  --cream-2: #ece7dc;
}
html { scroll-behavior: smooth; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a, a:visited, a:hover, a:focus, a:active { color: inherit; text-decoration: none; }

/* ---------- Layout helpers ---------- */
.wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
.eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px; font-weight: 500;
  letter-spacing: 1.8px; text-transform: uppercase;
  color: var(--g);
  display: inline-flex; align-items: center; gap: 8px;
  margin-bottom: 14px;
}
.eyebrow::before {
  content: ''; width: 18px; height: 1px; background: var(--g);
}
.section-title {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(30px, 3.4vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-wrap: balance;
}
.section-title em { font-style: italic; font-weight: 400; color: var(--g); }
.section-sub {
  font-size: 16px;
  color: var(--soft);
  line-height: 1.65;
  max-width: 540px;
  margin-top: 14px;
  text-wrap: pretty;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Inter', sans-serif;
  font-size: 14px; font-weight: 500;
  padding: 12px 22px;
  border-radius: 999px;
  border: none; cursor: pointer;
  text-decoration: none; white-space: nowrap;
  transition: transform .15s ease, background .2s, color .2s, box-shadow .2s;
}
.btn-green, a.btn-green, a.btn-green:visited { background: var(--g); color: #fff !important; }
.btn-green:hover, a.btn-green:hover { background: var(--g-dark); transform: translateY(-1px); color: #fff !important; }
.btn-ghost, a.btn-ghost, a.btn-ghost:visited { background: transparent; color: var(--ink) !important; border: 1px solid var(--line-strong); }
.btn-ghost:hover, a.btn-ghost:hover { background: var(--ink); color: #fff !important; border-color: var(--ink); }
.btn-light, a.btn-light, a.btn-light:visited { background: #fff; color: var(--ink) !important; }
.btn-light:hover, a.btn-light:hover { background: var(--cream); color: var(--ink) !important; }
.btn-arrow::after {
  content: '→'; font-size: 16px; transition: transform .2s;
}
.btn:hover .btn-arrow::after, .btn-arrow:hover::after { transform: translateX(3px); }

/* ---------- NAV ---------- */
.topbar {
  background: var(--ink); color: #c4c4be;
  font-size: 12px; padding: 8px 0; letter-spacing: 0.2px;
}
.topbar .wrap { display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap; }
.topbar a { color: #d8d8d2; }
.topbar a:hover { color: #fff; }
.topbar-left { display: flex; gap: 18px; align-items: center; }
.topbar-left span { display: inline-flex; align-items: center; gap: 6px; }
.topbar-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--g-mid); display: inline-block; }

nav.site-nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
  transition: padding .2s ease;
}
.nav-inner {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 0;
}
.nav-logo img { height: 56px; width: auto; }
.nav-links { display: flex; gap: 4px; list-style: none; align-items: center; }
.nav-links > li { position: relative; }
.nav-links > li > a {
  font-size: 14px; color: var(--ink);
  padding: 9px 14px; border-radius: 8px; display: block;
  transition: background .15s, color .15s;
  font-weight: 400;
}
.nav-links > li > a:hover { background: var(--cream); }
.nav-links > li > a.has-drop { display: flex; align-items: center; gap: 5px; }
.nav-links > li > a.has-drop::after {
  content: ''; width: 6px; height: 6px;
  border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg) translate(-2px,-1px); opacity: .55;
  transition: transform .2s;
}
.nav-links > li:hover > a.has-drop::after { transform: rotate(225deg) translate(-1px,-1px); }
.dropdown {
  position: absolute; top: 100%; left: 50%;
  transform: translateX(-50%) translateY(-8px) scale(.98);
  transform-origin: top center;
  margin-top: 10px;
  background: #fff; border: 1px solid var(--line);
  border-radius: 16px; padding: 10px;
  width: 320px;
  box-shadow: 0 24px 56px -14px rgba(20,23,20,.24), 0 2px 6px rgba(20,23,20,.05);
  opacity: 0; pointer-events: none;
  transition: opacity .18s ease, transform .18s ease;
}
/* Invisible bridge so the cursor can move from the trigger to the dropdown without closing it */
.dropdown::before {
  content: ''; position: absolute;
  top: -12px; left: 0; right: 0; height: 14px;
  background: transparent;
}
/* Caret pointer */
.dropdown::after {
  content: ''; position: absolute;
  top: -6px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 10px; height: 10px;
  background: #fff;
  border-left: 1px solid var(--line);
  border-top: 1px solid var(--line);
  border-radius: 2px 0 0 0;
}
.nav-links > li:hover .dropdown,
.nav-links > li:focus-within .dropdown { opacity: 1; pointer-events: all; transform: translateX(-50%) translateY(0) scale(1); }
.nav-links > li > a.is-active,
.nav-links > li.current-menu-item > a,
.nav-links > li > a[aria-current="page"] { color: var(--g-dark); background: var(--g-light); font-weight: 500; }
.dropdown a.is-active,
.dropdown a[aria-current="page"] { background: var(--g-light); color: var(--g-dark); }
.dropdown a {
  display: block;
  padding: 11px 14px;
  font-size: 14px; font-weight: 500; color: var(--ink);
  border-radius: 10px; transition: background .14s, color .14s, transform .14s;
  line-height: 1.25;
}
.dropdown a:hover { background: var(--g-paper); color: var(--g-dark); }
.dropdown a small { display: block; font-size: 12px; color: var(--faint); margin-top: 3px; font-weight: 400; letter-spacing: 0; }
.dropdown-divider { height: 1px; background: var(--line); margin: 8px 6px; }
.dropdown a.dropdown-cta {
  background: var(--ink); color: #fff;
  text-align: left;
  padding: 11px 14px;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  font-size: 13.5px; font-weight: 500;
}
.dropdown a.dropdown-cta::after {
  content: '→'; font-size: 14px; opacity: .8;
  transition: transform .18s;
}
.dropdown a.dropdown-cta:hover { background: var(--g-dark); color: #fff; }
.dropdown a.dropdown-cta:hover::after { transform: translateX(3px); }
.dropdown a.dropdown-cta small { color: rgba(255,255,255,.6); margin-top: 2px; }

.nav-actions { display: flex; gap: 10px; align-items: center; }
.nav-phone { display: none; }

/* ---------- MOBILE NAV / HAMBURGER ---------- */
.nav-burger {
  display: none;
  width: 44px; height: 44px;
  border: 1px solid var(--line);
  background: #fff; border-radius: 12px;
  cursor: pointer;
  align-items: center; justify-content: center;
  flex-direction: column; gap: 5px;
  padding: 0;
  transition: background .15s;
}
.nav-burger:hover { background: var(--cream); }
.nav-burger span {
  width: 18px; height: 1.5px; background: var(--ink);
  border-radius: 2px;
  transition: transform .25s, opacity .2s;
}
body.nav-open .nav-burger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
body.nav-open .nav-burger span:nth-child(2) { opacity: 0; }
body.nav-open .nav-burger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.nav-mobile-backdrop {
  position: fixed; inset: 0;
  background: rgba(20,23,20,.4);
  opacity: 0; pointer-events: none;
  transition: opacity .25s;
  z-index: 90;
  backdrop-filter: blur(2px);
}
body.nav-open .nav-mobile-backdrop { opacity: 1; pointer-events: all; }

@media (max-width: 980px) {
  .nav-links, .nav-actions .btn-green, .nav-phone { display: none; }
  .nav-burger { display: inline-flex; }
  .nav-inner { padding: 14px 0; }

  .site-nav .nav-links {
    display: flex; flex-direction: column;
    align-items: stretch; gap: 0;
    position: fixed;
    top: 0; right: 0;
    width: min(360px, 88vw); height: 100dvh;
    background: #fff;
    padding: 96px 24px 32px;
    box-shadow: -16px 0 40px -12px rgba(20,23,20,.18);
    transform: translateX(100%);
    transition: transform .3s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    z-index: 95;
  }
  body.nav-open .site-nav .nav-links { transform: translateX(0); }
  .site-nav .nav-links > li { width: 100%; border-bottom: 1px solid var(--line); }
  .site-nav .nav-links > li:last-child { border-bottom: none; }
  .site-nav .nav-links > li > a {
    padding: 16px 6px; font-size: 16px; font-weight: 500;
    border-radius: 0;
  }
  .site-nav .nav-links > li > a:hover { background: transparent; color: var(--g); }
  .site-nav .nav-links > li > a.has-drop::after { margin-left: auto; }
  .site-nav .dropdown {
    position: static; transform: none; opacity: 1; pointer-events: all;
    width: 100%; box-shadow: none; border: none;
    padding: 0 0 12px 8px;
    background: transparent;
    margin: 0;
  }
  .site-nav .dropdown::before, .site-nav .dropdown::after { display: none; }
  .site-nav .dropdown a {
    padding: 10px 8px; font-size: 14px; font-weight: 400;
    color: var(--soft);
  }
  .site-nav .dropdown a small { font-size: 11.5px; }
  .nav-mobile-cta {
    display: block !important;
    margin-top: 24px;
    text-align: center;
    background: var(--g); color: #fff !important;
    padding: 14px 18px !important;
    border-radius: 12px !important;
    font-weight: 500;
  }
  .nav-mobile-phone {
    display: block;
    margin-top: 14px;
    text-align: center;
    font-family: 'Fraunces', serif;
    font-size: 22px;
    color: var(--ink);
    font-weight: 500;
    padding: 8px;
  }
  .nav-mobile-phone small {
    display: block;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    color: var(--soft);
    letter-spacing: .4px;
    text-transform: uppercase;
    margin-top: 2px;
    font-weight: 400;
  }
}
@media (min-width: 981px) {
  .nav-mobile-cta, .nav-mobile-phone, .nav-mobile-backdrop { display: none !important; }
}

/* ---------- HERO ---------- */
.hero {
  position: relative;
  padding: 56px 0 64px;
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 50% at 85% 0%, rgba(91,147,32,.08), transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--cream) 100%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px; align-items: stretch;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 12px; font-weight: 500;
  color: var(--g-dark);
  background: #fff;
  border: 1px solid var(--g-light);
  padding: 6px 14px 6px 8px;
  border-radius: 999px;
  margin-bottom: 28px;
  box-shadow: 0 1px 2px rgba(0,0,0,.03);
}
.hero-badge-dot {
  display: inline-block;
  width: 18px; height: 18px;
  border-radius: 50%; background: var(--g);
  color: #fff; font-size: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600;
}
.hero h1 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(42px, 5.4vw, 72px);
  line-height: 0.98;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin-bottom: 26px;
  text-wrap: balance;
}
.hero h1 em {
  font-style: italic;
  font-weight: 400;
  color: var(--g);
}
.hero-desc {
  font-size: 18px;
  line-height: 1.6;
  color: var(--soft);
  margin-bottom: 36px;
  max-width: 480px;
  text-wrap: pretty;
}
.hero-ctas { display: flex; gap: 12px; align-items: center; margin-bottom: 48px; }
.hero-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
}
.hero-meta-item { font-size: 13px; }
.hero-meta-item-num {
  font-family: 'Fraunces', serif;
  font-size: 32px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 4px;
}
.hero-meta-item-num span { color: var(--g); font-weight: 400; }
.hero-meta-item-label { color: var(--faint); font-size: 12px; letter-spacing: 0.2px; }

.hero-visual {
  position: absolute;
  inset: 0;
  border-radius: 24px;
  overflow: hidden;
  background-color: var(--cream-2);
  background-image: linear-gradient(135deg, var(--g-paper), var(--cream-2));
  background-size: cover;
  background-position: center bottom;
  border: 1px solid var(--line);
  box-shadow: 0 30px 80px -20px rgba(20,23,20,.18);
}
/* Striped placeholder */
.hero-visual::before {
  content: '';
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg,
    rgba(61,107,16,.08) 0px,
    rgba(61,107,16,.08) 1px,
    transparent 1px,
    transparent 14px);
}
.hero-visual-label {
  position: absolute; bottom: 22px; left: 22px; right: 22px;
  display: flex; justify-content: space-between; align-items: end;
  font-family: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 11px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--soft);
}
.hero-visual-label-tag {
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(6px);
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid var(--line);
}
.hero-visual-card {
  position: absolute;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  box-shadow: 0 12px 32px -10px rgba(20,23,20,.18);
  display: flex; align-items: center; gap: 14px;
}
.hero-card-1 {
  top: 32px; left: -28px;
  width: 240px;
}
.hero-card-1 .dot {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--g-light);
  display: flex; align-items: center; justify-content: center;
  color: var(--g); font-weight: 700;
  flex-shrink: 0;
}
.hero-card-1 .lab { font-size: 11px; color: var(--faint); margin-bottom: 1px; letter-spacing: .3px; }
.hero-card-1 .val { font-size: 14px; font-weight: 500; }

.hero-card-2 {
  bottom: 36px; right: -32px;
  width: 232px;
  flex-direction: column; align-items: flex-start; gap: 6px;
}
.hero-card-2 .top-row {
  display: flex; justify-content: space-between; width: 100%; align-items: baseline;
}
.hero-card-2 .price {
  font-family: 'Fraunces', serif; font-size: 22px; font-weight: 600;
  letter-spacing: -.02em;
}
.hero-card-2 .pct {
  font-size: 11px; padding: 2px 8px; background: var(--g-light); color: var(--g-dark);
  border-radius: 999px; font-weight: 500;
}
.hero-card-2 .desc { font-size: 12px; color: var(--soft); }

/* ---------- LOGOS / TRUST ---------- */
.trust {
  background: var(--cream);
  padding: 28px 0;
  border-bottom: 1px solid var(--line);
}
.trust-row {
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; flex-wrap: wrap;
}
.trust-label {
  font-size: 12px; color: var(--faint);
  letter-spacing: 1.4px; text-transform: uppercase;
  flex-shrink: 0;
}
.trust-items {
  display: flex; gap: 38px; flex-wrap: wrap;
  font-family: 'Fraunces', serif; font-weight: 500;
  color: var(--soft); font-size: 18px;
  letter-spacing: -0.01em;
  opacity: .85;
}
.trust-items span { white-space: nowrap; }

/* ---------- FEATURES STRIP ---------- */
.feats {
  padding: 64px 0 56px;
  background: #ffffff;
}
.feats-head { display: flex; justify-content: space-between; align-items: end; gap: 40px; margin-bottom: 40px; }
.feats-head .right { max-width: 380px; flex-shrink: 0; }
.feats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.feat {
  padding: 32px 28px 36px;
  border-right: 1px solid var(--line);
  position: relative;
}
.feat:last-child { border-right: none; }
.feat-num {
  font-family: 'Fraunces', serif;
  font-size: 13px; color: var(--g);
  margin-bottom: 18px;
  letter-spacing: 0.5px;
}
.feat h3 {
  font-family: 'Fraunces', serif;
  font-weight: 500; font-size: 22px;
  letter-spacing: -0.01em;
  margin-bottom: 10px;
  text-wrap: balance;
}
.feat p {
  font-size: 14px;
  color: var(--soft);
  line-height: 1.6;
}

/* ---------- SERVICES ---------- */
.services {
  padding: 72px 0;
  background: var(--cream);
  position: relative;
}
.services-head { display: flex; justify-content: space-between; align-items: end; gap: 40px; margin-bottom: 40px; }
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.svc-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px 28px 26px;
  display: flex; flex-direction: column;
  transition: transform .25s ease, border-color .25s, box-shadow .25s;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.svc-card-link { position: absolute; inset: 0; z-index: 1; }
.svc-card > *:not(.svc-card-link) { position: relative; z-index: 2; }
.svc-card::after {
  content: '→';
  position: absolute; top: 26px; right: 26px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; color: var(--ink);
  transition: background .2s, color .2s, transform .2s;
}
.svc-card:hover {
  transform: translateY(-3px);
  border-color: var(--g-mid);
  box-shadow: 0 18px 40px -16px rgba(61,107,16,.18);
}
.svc-card:hover::after {
  background: var(--g);
  color: #fff;
  transform: rotate(-45deg);
}
.svc-tag {
  font-family: 'Fraunces', serif;
  font-size: 12px; color: var(--g);
  margin-bottom: 16px;
  letter-spacing: 0.4px;
  font-weight: 500;
}
.svc-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 24px; font-weight: 500;
  letter-spacing: -0.015em;
  margin-bottom: 10px;
  padding-right: 36px;
  line-height: 1.15;
}
.svc-card p {
  font-size: 14px;
  color: var(--soft);
  line-height: 1.6;
  margin-bottom: 22px;
  flex: 1;
}
.svc-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 18px;
  border-top: 1px solid var(--line);
}
.svc-price { font-size: 13px; font-weight: 500; color: var(--ink); }
.svc-price small { display: block; font-size: 11px; color: var(--faint); font-weight: 400; margin-top: 1px; }
.svc-link { font-size: 12px; color: var(--g); font-weight: 500; }

/* ---------- DARK PRICING BAND ---------- */
.pricing {
  background: var(--ink);
  color: #fff;
  padding: 72px 0;
  position: relative;
  overflow: hidden;
}
.pricing-clean { max-width: 880px; margin: 0 auto; text-align: center; position: relative; }
.pricing-clean .eyebrow { justify-content: center; }
.pricing-clean .eyebrow::before { display: none; }
.pricing-clean-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(36px, 4.2vw, 56px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.025em;
  margin-bottom: 22px;
  text-wrap: balance;
}
.pricing-clean-title em { font-style: italic; color: var(--g-mid); font-weight: 400; }
.pricing-clean-lede {
  font-size: 16px;
  color: rgba(255,255,255,0.7);
  line-height: 1.65;
  margin: 0 auto 36px;
  max-width: 560px;
}
.pricing-clean-checks {
  display: grid;
  grid-template-columns: repeat(2, max-content);
  gap: 14px 36px;
  justify-content: center;
}
@media (max-width: 720px) {
  .pricing-clean-checks { grid-template-columns: 1fr; justify-items: start; }
}
.pricing::before {
  content: '';
  position: absolute;
  top: -100px; left: -150px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(91,147,32,.18), transparent 65%);
  pointer-events: none;
}
.pricing-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  gap: 32px;
  align-items: stretch;
  position: relative;
}
.pricing-intro h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(34px, 3.6vw, 48px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.025em;
  margin-bottom: 18px;
  text-wrap: balance;
}
.pricing-intro h2 em { font-style: italic; color: var(--g-mid); font-weight: 400; }
.pricing-intro p {
  font-size: 15px;
  color: rgba(255,255,255,0.65);
  line-height: 1.65;
  margin-bottom: 32px;
  max-width: 360px;
}
.pricing-checks { display: flex; flex-direction: column; gap: 12px; }
.pricing-check {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 14px; color: rgba(255,255,255,.78);
  line-height: 1.45;
}
.pricing-check::before {
  content: '✓';
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(91,147,32,.2);
  color: var(--g-mid);
  font-weight: 700; font-size: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

.pc {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 18px;
  padding: 32px 28px;
  display: flex; flex-direction: column;
  transition: background .2s, transform .2s;
}
.pc:hover { background: rgba(255,255,255,.06); transform: translateY(-2px); }
.pc.featured {
  background: var(--g);
  border-color: transparent;
  box-shadow: 0 30px 60px -20px rgba(91,147,32,.5);
}
.pc.featured:hover { background: var(--g); }
.pc-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.pc-plan {
  font-size: 11px; font-weight: 500;
  letter-spacing: 1.4px; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}
.pc.featured .pc-plan { color: rgba(255,255,255,0.85); }
.pc-tag {
  font-size: 10px; font-weight: 500;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--g-mid);
  background: rgba(91,147,32,.15);
  padding: 3px 9px; border-radius: 999px;
}
.pc.featured .pc-tag { color: #fff; background: rgba(255,255,255,.18); }
.pc-price {
  font-family: 'Fraunces', serif;
  font-size: 48px; font-weight: 500;
  letter-spacing: -0.03em; line-height: 1;
  color: #fff;
  margin-bottom: 4px;
  display: flex; align-items: baseline;
}
.pc-price-cents { font-size: 22px; opacity: .7; margin-left: 2px; }
.pc-period {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  margin-bottom: 24px;
}
.pc.featured .pc-period { color: rgba(255,255,255,0.75); }
.pc-feats { list-style: none; display: flex; flex-direction: column; gap: 10px; flex: 1; margin-bottom: 24px; }
.pc-feats li {
  font-size: 13px; color: rgba(255,255,255,0.7);
  display: flex; align-items: flex-start; gap: 10px;
  line-height: 1.45;
}
.pc-feats li::before {
  content: ''; width: 14px; height: 1px; background: var(--g-mid);
  flex-shrink: 0; margin-top: 9px;
}
.pc.featured .pc-feats li { color: rgba(255,255,255,.92); }
.pc.featured .pc-feats li::before { background: rgba(255,255,255,.6); }
.pc-btn {
  font-family: 'Inter', sans-serif;
  font-size: 13.5px; font-weight: 500;
  padding: 12px;
  border-radius: 999px;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.18);
  background: transparent;
  color: #fff;
  width: 100%;
  text-align: center;
  transition: background .2s, border-color .2s;
}
.pc-btn:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.4); }
.pc.featured .pc-btn {
  background: var(--ink);
  border-color: var(--ink);
}
.pc.featured .pc-btn:hover { background: #000; border-color: #000; }

/* ---------- ESPACIOS gallery ---------- */
.espacios { padding: 72px 0; background: #ffffff; }
.gallery {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 280px 240px;
  gap: 14px;
  margin-top: 56px;
}
.gal-item {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: var(--g-paper);
  border: 1px solid var(--line);
  cursor: pointer;
  transition: transform .25s ease;
}
.gal-item:hover { transform: translateY(-2px); }
.gal-item::before {
  content: '';
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(135deg,
    rgba(61,107,16,.08) 0px,
    rgba(61,107,16,.08) 1px,
    transparent 1px,
    transparent 14px);
}
.gal-item:nth-child(1) { grid-row: 1 / 3; }
.gal-item:nth-child(2),
.gal-item:nth-child(4) { background: linear-gradient(135deg, var(--cream-2), var(--cream)); }
.gal-item:nth-child(3) { background: linear-gradient(135deg, #e3eddc, var(--g-paper)); }
.gal-item:nth-child(5) { background: linear-gradient(135deg, #efece4, var(--cream-2)); }

.gal-meta {
  position: absolute;
  bottom: 16px; left: 18px; right: 18px;
  display: flex; justify-content: space-between; align-items: end;
}
.gal-tag {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  padding: 6px 12px;
  border-radius: 999px;
  color: var(--ink);
  font-weight: 500;
  border: 1px solid var(--line);
}
.gal-cap {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  color: var(--soft);
  letter-spacing: 0.4px;
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  text-align: right;
  background: rgba(255,255,255,.92);
  padding: 4px 8px;
  border-radius: 6px;
}
.gal-corner {
  position: absolute; top: 18px; left: 18px;
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: 10px; color: var(--soft);
  letter-spacing: 0.4px;
  text-transform: uppercase;
}

/* ---------- TESTIMONIAL ---------- */
.testimonial {
  background: var(--g);
  color: #fff;
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}
.testimonial::after {
  content: '"';
  position: absolute;
  font-family: 'Fraunces', serif;
  font-size: 760px;
  font-weight: 700;
  line-height: 0.8;
  bottom: -200px; right: -50px;
  opacity: .07;
  pointer-events: none;
}
.testimonial-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  position: relative;
}
.testimonial blockquote {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.2;
  letter-spacing: -0.018em;
  text-wrap: balance;
}
.testimonial blockquote em { font-style: italic; }
.testimonial-cite {
  display: flex; align-items: center; gap: 16px;
  margin-top: 36px;
}
.testimonial-avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,.2);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-size: 18px; font-weight: 500;
  border: 1px solid rgba(255,255,255,.3);
}
.testimonial-cite-name { font-size: 15px; font-weight: 500; }
.testimonial-cite-role { font-size: 13px; opacity: .75; margin-top: 2px; }
.testimonial-stats { display: flex; flex-direction: column; gap: 28px; }
.tstat {
  display: flex; align-items: baseline; gap: 18px;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255,255,255,.18);
}
.tstat:last-child { border-bottom: none; padding-bottom: 0; }
.tstat-num {
  font-family: 'Fraunces', serif;
  font-size: 56px; font-weight: 500;
  letter-spacing: -0.025em; line-height: 1;
  flex-shrink: 0;
  min-width: 110px;
}
.tstat-num span { font-size: 28px; opacity: .65; }
.tstat-text { font-size: 14px; line-height: 1.55; opacity: .85; }
.tstat-text strong { display: block; font-weight: 500; opacity: 1; margin-bottom: 2px; font-size: 15px; }

/* ---------- FAQ ---------- */
.faq { padding: 72px 0; background: var(--bg); }
.faq-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 80px; align-items: center; }
.faq-list { display: flex; flex-direction: column; }
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 22px 0;
  cursor: pointer;
}
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-q {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 24px;
  font-family: 'Fraunces', serif;
  font-size: 19px; font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.faq-toggle {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  position: relative;
  transition: background .2s, border-color .2s;
}
.faq-toggle::before, .faq-toggle::after {
  content: ''; position: absolute;
  background: var(--ink);
  transition: transform .25s;
}
.faq-toggle::before { width: 10px; height: 1.5px; }
.faq-toggle::after { width: 1.5px; height: 10px; }
.faq-item[open] .faq-toggle { background: var(--ink); border-color: var(--ink); }
.faq-item[open] .faq-toggle::before,
.faq-item[open] .faq-toggle::after { background: #fff; }
.faq-item[open] .faq-toggle::after { transform: scaleY(0); }
.faq-a {
  font-weight: 400;
  font-size: 14.5px; line-height: 1.65;
  color: var(--soft);
  margin-top: 14px;
  max-width: 580px;
}
.faq-side h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(32px, 3.4vw, 44px);
  font-weight: 500;
  letter-spacing: -0.022em;
  line-height: 1.05;
  margin-bottom: 18px;
  text-wrap: balance;
}
.faq-side h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.faq-side p {
  font-size: 16px; color: var(--soft);
  line-height: 1.65;
  margin-bottom: 28px;
  max-width: 360px;
}

/* ---------- CONTACT / VISIT ---------- */
.visit {
  background: var(--cream);
  padding: 72px 0;
  position: relative;
}
.visit-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.visit-info { display: flex; flex-direction: column; justify-content: center; }
.visit-info h2 {
  font-family: 'Fraunces', serif;
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 0.98;
  margin-bottom: 20px;
  text-wrap: balance;
}
.visit-info h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.visit-info p { font-size: 16px; color: var(--soft); margin-bottom: 32px; max-width: 420px; line-height: 1.6; }
.visit-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 36px; max-width: 460px; }
.visit-meta-item .lab {
  font-size: 11px; letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--faint); margin-bottom: 8px;
}
.visit-meta-item .val {
  font-family: 'Fraunces', serif;
  font-size: 17px; font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.3;
  word-break: break-word;
}
.visit-meta-item .val small { display: block; font-family: 'Inter', sans-serif; font-size: 13px; color: var(--soft); font-weight: 400; margin-top: 4px; }

.visit-actions { display: flex; gap: 12px; flex-wrap: wrap; }

.visit-map {
  background: linear-gradient(135deg, var(--cream-2), var(--cream));
  border: 1px solid var(--line);
  border-radius: 24px;
  position: relative;
  overflow: hidden;
  min-height: 380px;
  background-image:
    linear-gradient(135deg, var(--cream-2), var(--cream)),
    repeating-linear-gradient(0deg, rgba(20,23,20,.06) 0px, rgba(20,23,20,.06) 1px, transparent 1px, transparent 28px),
    repeating-linear-gradient(90deg, rgba(20,23,20,.06) 0px, rgba(20,23,20,.06) 1px, transparent 1px, transparent 28px);
}
.map-pin {
  position: absolute;
  top: 47%; left: 50%;
  transform: translate(-50%, -100%);
}
.map-pin-bubble {
  background: var(--ink);
  color: #fff;
  padding: 12px 16px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 500;
  box-shadow: 0 18px 40px -12px rgba(20,23,20,.4);
  position: relative;
  white-space: nowrap;
}
.map-pin-bubble small { display: block; font-weight: 400; opacity: .7; font-size: 11px; margin-top: 2px; }
.map-pin-bubble::after {
  content: '';
  position: absolute;
  bottom: -8px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 14px; height: 14px;
  background: var(--ink);
}
.map-pin-dot {
  position: absolute;
  bottom: -22px; left: 50%; transform: translateX(-50%);
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--g);
  border: 3px solid #fff;
  box-shadow: 0 4px 12px rgba(61,107,16,.4);
}
.map-pin-dot::before {
  content: '';
  position: absolute;
  top: -8px; left: -8px; right: -8px; bottom: -8px;
  border-radius: 50%;
  background: rgba(61,107,16,.18);
  animation: pulse 2.4s ease-out infinite;
}
@keyframes pulse {
  0% { transform: scale(.8); opacity: 1; }
  100% { transform: scale(2.4); opacity: 0; }
}
.map-streets {
  position: absolute; inset: 0;
  pointer-events: none;
}
.map-streets svg { width: 100%; height: 100%; }
.map-corner {
  position: absolute; top: 18px; left: 18px;
  font-family: ui-monospace, monospace;
  font-size: 11px; color: var(--soft);
  background: rgba(255,255,255,.85);
  padding: 6px 10px; border-radius: 8px;
  border: 1px solid var(--line);
}

/* ---------- FOOTER ---------- */
.wrap {
  max-width: 1140px !important;
  margin: 0 auto !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.site-footer {
  background: var(--ink);
  color: rgba(255,255,255,.6);
  font-family: 'Inter', sans-serif;
  width: 100vw !important;
  max-width: 100vw !important;
  position: relative !important;
  left: 50% !important;
  right: 50% !important;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
}
.footer-top {
  padding: 80px 0 60px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 56px;
}
.footer-brand .footer-logo-pill {
  display: inline-block;
  background: #fff;
  padding: 12px 18px;
  border-radius: 12px;
  margin-bottom: 22px;
}
.footer-brand .footer-logo-pill img {
  height: 38px; width: auto; display: block;
}
.footer-brand p {
  font-size: 14px;
  line-height: 1.65;
  max-width: 320px;
  margin-bottom: 22px;
}
.footer-social { display: flex; gap: 8px; }
.footer-social a {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.14);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.7);
  transition: background .2s, color .2s, border-color .2s;
}
.footer-social a:hover { background: var(--g); border-color: var(--g); color: #fff; }
.footer-social svg { width: 16px; height: 16px; }

.footer-col h4 {
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 18px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col a {
  font-size: 14px;
  color: rgba(255,255,255,.72);
  transition: color .15s;
}
.footer-col a:hover { color: #fff; }
.footer-contact-line { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.5; }
.footer-contact-line strong { color: rgba(255,255,255,.92); font-weight: 500; }

.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding: 22px 0;
  gap: 24px;
  flex-wrap: wrap;
}
.footer-copy { font-size: 12.5px; color: rgba(255,255,255,.35); }
.footer-legal { display: flex; gap: 22px; flex-wrap: wrap; }
.footer-legal a {
  font-size: 12.5px; color: rgba(255,255,255,.45);
  transition: color .15s;
}
.footer-legal a:hover { color: #fff; }

/* ---------- Mobile ---------- */
@media (max-width: 980px) {
  .hero-grid, .testimonial-grid, .visit-grid, .faq-grid, .feats-head, .services-head { grid-template-columns: 1fr; gap: 40px; }
  .feats-grid, .services-grid, .pricing-grid { grid-template-columns: 1fr; }
  .feat { border-right: none; border-bottom: 1px solid var(--line); }
  .feat:last-child { border-bottom: none; }
  .gallery { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px 200px; }
  .gal-item:nth-child(1) { grid-row: auto; grid-column: 1 / 3; }
  .nav-links, .nav-phone, .topbar { display: none; }
  .hero-card-1, .hero-card-2 { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
  .footer-brand { grid-column: 1 / 3; }
  .visit-meta { grid-template-columns: 1fr; }
  .wrap { padding: 0 20px; }
}

/* ===========================================================
   PAGE: DOMICILIACIONES
   =========================================================== */

/* Page hero — título amplio, lede debajo, mismo tratamiento que Espacios/PorQueCBC */
.page-hero {
  position: relative;
  padding: 40px 0 56px;
  overflow: hidden;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.page-hero-grid {
  display: block;
  max-width: 920px;
}
.page-hero-crumb {
  font-size: 12px;
  color: var(--faint);
  letter-spacing: 0.2px;
  margin-bottom: 24px;
}
.page-hero-crumb a { color: var(--soft); }
.page-hero-crumb a:hover { color: var(--ink); }
.page-hero-crumb .sep { margin: 0 10px; opacity: .5; }
.page-hero h1 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--ink);
  text-wrap: balance;
  margin-top: 4px;
}
.page-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
.page-hero .lede {
  font-size: 17px;
  line-height: 1.6;
  color: var(--soft);
  max-width: 620px;
  margin: 20px 0 0;
  text-wrap: pretty;
}

/* Comparison block: gestoría vs web vs CBC */
.compare {
  padding: 72px 0;
  background: var(--bg);
}
.compare-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 48px;
}
.compare-head .eyebrow { justify-content: center; }
.compare-head .eyebrow::before { display: none; }
.compare-head h2 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(32px, 3.6vw, 46px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  text-wrap: balance;
}
.compare-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.compare-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: stretch;
}
.compare-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 32px 28px 28px;
  display: flex; flex-direction: column;
  position: relative;
}
.compare-card.highlight {
  background: var(--ink);
  border-color: var(--ink);
  color: #fff;
  box-shadow: 0 30px 60px -22px rgba(20,23,20,.45);
}
.compare-card.highlight .compare-tag { color: var(--g-mid); background: rgba(91,147,32,.18); }
.compare-card.highlight h3 { color: #fff; }
.compare-card.highlight p { color: rgba(255,255,255,.75); }
.compare-card.highlight ul li { color: rgba(255,255,255,.85); }
.compare-card.highlight ul li::before { background: var(--g-mid); }
.compare-tag {
  display: inline-block;
  align-self: flex-start;
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--soft);
  background: var(--cream);
  padding: 5px 11px;
  border-radius: 999px;
  margin-bottom: 22px;
}
.compare-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 24px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin-bottom: 12px;
  line-height: 1.15;
  text-wrap: balance;
}
.compare-card p {
  font-size: 14.5px;
  color: var(--soft);
  line-height: 1.6;
  margin-bottom: 22px;
  flex: 1;
}
.compare-card ul {
  list-style: none;
  display: flex; flex-direction: column;
  gap: 10px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
}
.compare-card.highlight ul { border-color: rgba(255,255,255,.12); }
.compare-card ul li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--ink);
}
.compare-card ul li::before {
  content: ''; width: 12px; height: 1px;
  background: var(--g);
  flex-shrink: 0;
  margin-top: 9px;
}

/* Editorial argument block — magazine layout, columna única centrada */
.editorial {
  background: var(--cream);
  padding: 80px 0 88px;
}
.editorial-grid {
  display: block;
  max-width: 760px;
  margin: 0 auto;
}
.editorial-side {
  position: relative;
  margin-bottom: 36px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--line-strong);
}
.editorial-side h2 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  text-wrap: balance;
  margin-bottom: 16px;
}
.editorial-side h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.editorial-side p {
  font-size: 16px;
  color: var(--soft);
  line-height: 1.65;
  max-width: none;
}
.editorial-body {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.editorial-body p {
  margin-bottom: 24px;
  text-wrap: pretty;
}
.editorial-body p:last-child { margin-bottom: 0; }
.editorial-body strong { font-weight: 500; color: var(--g-dark); }
.editorial-body em { font-style: italic; color: var(--g); }
.editorial-divider {
  height: 1px;
  background: var(--line-strong);
  margin: 32px 0;
  width: 80px;
}

/* AEAT seal */
.aeat-seal {
  background: linear-gradient(135deg, #fff 0%, var(--g-paper) 100%);
  border: 1px solid var(--g-light);
  border-radius: 18px;
  padding: 28px;
  margin-top: 32px;
  display: flex;
  gap: 22px;
  align-items: center;
}
.aeat-seal-mark {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--g);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif;
  font-size: 28px;
  font-weight: 600;
  flex-shrink: 0;
  box-shadow: 0 8px 20px -6px rgba(61,107,16,.4);
}
.aeat-seal-text {
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  line-height: 1.55;
  color: var(--soft);
}
.aeat-seal-text strong {
  display: block;
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 4px;
}

/* Process steps — numbered horizontal */
.process {
  padding: 72px 0;
  background: var(--bg);
}
.process-head {
  display: flex; justify-content: space-between; align-items: end;
  gap: 40px;
  margin-bottom: 48px;
}
.process-head .right { max-width: 380px; flex-shrink: 0; }
.process-track {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}
.process-track::before {
  content: '';
  position: absolute;
  top: 28px; left: 0; right: 0;
  height: 1px;
  background: var(--line);
  z-index: 0;
}
.process-step {
  position: relative;
  padding: 0 24px 0 0;
  z-index: 1;
}
.process-num {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--line-strong);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 22px;
  position: relative;
}
.process-step.active .process-num {
  background: var(--g);
  border-color: var(--g);
  color: #fff;
}
.process-step h4 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: 19px;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
  text-wrap: balance;
}
.process-step p {
  font-size: 13.5px;
  color: var(--soft);
  line-height: 1.55;
  max-width: 220px;
}

/* Domiciliación-specific pricing — three plans */
.dpricing { padding: 72px 0; background: var(--ink); color: #fff; position: relative; overflow: hidden; }
.dpricing::before {
  content: '';
  position: absolute;
  top: -120px; right: -180px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(91,147,32,.18), transparent 65%);
  pointer-events: none;
}
.dpricing-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
  position: relative;
}
.dpricing-head .eyebrow {
  color: var(--g-mid);
  justify-content: center;
}
.dpricing-head .eyebrow::before { display: none; }
.dpricing-head h2 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(34px, 4vw, 52px);
  line-height: 1;
  letter-spacing: -0.025em;
  margin-bottom: 18px;
  text-wrap: balance;
}
.dpricing-head h2 em { font-style: italic; color: var(--g-mid); font-weight: 400; }
.dpricing-head p {
  font-size: 16px;
  color: rgba(255,255,255,.7);
  line-height: 1.6;
  max-width: 520px;
  margin: 0 auto;
}
.dpricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  position: relative;
}

/* Reuse .pc styles but allow non-featured to be lighter */
.pc-period-large {
  font-size: 13px;
  color: rgba(255,255,255,0.5);
  margin-bottom: 28px;
}

@media (max-width: 980px) {
  .page-hero-grid { display: block; }
  .compare-grid, .dpricing-grid { grid-template-columns: 1fr; }
  .editorial-grid { grid-template-columns: 1fr; gap: 40px; }
  .editorial-side { position: static; }
  .editorial-body { font-size: 19px; }
  .process-track { grid-template-columns: 1fr 1fr; gap: 32px 0; }
  .process-track::before { display: none; }
  .process-head { flex-direction: column; align-items: flex-start; }
}

/* ===========================================================
   PAGE: POR QUÉ CBC
   =========================================================== */
.why-intro { padding: 40px 0 32px; background: var(--bg); border-bottom: 1px solid var(--line); }
.why-intro-grid {
  display: block;
  max-width: 920px;
}
.why-intro h1 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  color: var(--ink);
  text-wrap: balance;
  margin-top: 4px;
}
.why-intro h1 em { font-style: italic; font-weight: 400; color: var(--g); }
.why-intro .lede {
  font-size: 17px;
  line-height: 1.6;
  color: var(--soft);
  max-width: 620px;
  margin: 20px 0 0;
  text-wrap: pretty;
}

.why-prose { padding: 32px 0 56px; background: var(--bg); }
.why-prose-inner {
  max-width: 760px; margin: 0 auto;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 22px; line-height: 1.45;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.why-prose-inner p { margin-bottom: 22px; text-wrap: pretty; }
.why-prose-inner p:last-child { margin-bottom: 0; }
.why-prose-inner em { font-style: italic; color: var(--g); }
.why-prose-inner strong { font-weight: 500; color: var(--g-dark); }
.why-prose-pull {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 32px;
  line-height: 1.15;
  color: var(--g);
  letter-spacing: -0.02em;
  margin: 28px 0 28px;
  padding-left: 22px;
  border-left: 3px solid var(--g);
}

/* Cost tables */
.costs { padding: 64px 0; background: var(--cream); }
.costs-head {
  max-width: 760px; margin: 0 auto 36px;
  text-align: center;
}
.costs-head .eyebrow { justify-content: center; }
.costs-head .eyebrow::before { display: none; }
.costs-head h2 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 38px);
  line-height: 1.05;
  letter-spacing: -0.022em;
  color: var(--ink);
}
.cost-table-wrap {
  max-width: 880px; margin: 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 30px 60px -28px rgba(20,23,20,.18);
}
.cost-table { width: 100%; border-collapse: collapse; font-family: 'Inter', sans-serif; }
.cost-table thead th {
  text-align: left;
  font-size: 11px; font-weight: 500;
  letter-spacing: 1.4px; text-transform: uppercase;
  color: var(--faint);
  padding: 20px 24px 16px;
  background: var(--cream);
  border-bottom: 1px solid var(--line);
}
.cost-table thead th.col-cbc { color: var(--g); background: var(--g-paper); }
.cost-table thead th + th { text-align: right; }
.cost-table tbody td {
  padding: 16px 24px;
  font-size: 14.5px;
  color: var(--ink);
  border-top: 1px solid var(--line);
}
.cost-table tbody td + td { text-align: right; font-variant-numeric: tabular-nums; color: var(--soft); }
.cost-table tbody td.col-cbc { color: var(--g-dark); font-weight: 500; background: var(--g-paper); }
.cost-table tbody tr:first-child td { border-top: none; }
.cost-table tfoot td {
  padding: 22px 24px;
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
  border-top: 2px solid var(--ink);
  background: var(--cream);
  font-variant-numeric: tabular-nums;
}
.cost-table tfoot td + td { text-align: right; }
.cost-table tfoot td.col-cbc { color: var(--g); background: var(--g-paper); }
.costs-bridge {
  max-width: 760px; margin: 48px auto 0;
  text-align: center;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-style: italic;
  font-size: 24px;
  line-height: 1.3;
  color: var(--soft);
  letter-spacing: -0.01em;
}
.costs-bridge strong { font-style: normal; color: var(--ink); font-weight: 500; }

/* Big number callout */
.bignum { padding: 80px 0; background: var(--ink); color: #fff; text-align: center; position: relative; overflow: hidden; }
.bignum::before {
  content: ''; position: absolute;
  top: -120px; left: 50%; transform: translateX(-50%);
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(91,147,32,.16), transparent 65%);
  pointer-events: none;
}
.bignum-inner { position: relative; max-width: 720px; margin: 0 auto; }
.bignum-num {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(96px, 14vw, 200px);
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--g-mid);
  margin-bottom: 12px;
}
.bignum-num small { font-size: 0.4em; color: rgba(255,255,255,.6); font-weight: 400; margin-left: 6px; }
.bignum-cap {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: #fff;
  margin-bottom: 24px;
  text-wrap: balance;
}
.bignum-cap em { font-style: italic; color: var(--g-mid); font-weight: 400; }
.bignum-sub {
  font-size: 15px;
  color: rgba(255,255,255,.7);
  line-height: 1.6;
  max-width: 540px;
  margin: 0 auto;
}

/* Closing argument */
.why-close { padding: 72px 0; background: var(--bg); }
.why-close-inner {
  max-width: 760px; margin: 0 auto;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: 22px; line-height: 1.45;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.why-close-inner p { margin-bottom: 20px; text-wrap: pretty; }
.why-close-inner em { font-style: italic; color: var(--g); }
.why-close-inner strong { font-weight: 500; color: var(--g-dark); }

/* CTA band reused */
.cta-band {
  padding: 72px 0;
  background: var(--g);
  color: #fff;
  text-align: center;
}
.cta-band h2 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(32px, 3.8vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin-bottom: 14px;
  text-wrap: balance;
}
.cta-band h2 em { font-style: italic; font-weight: 400; }
.cta-band p {
  font-size: 16px;
  color: rgba(255,255,255,.85);
  margin-bottom: 28px;
}
.cta-band .btns { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.cta-band .btn-light { background: #fff; color: var(--ink); }
.cta-band .btn-light:hover { background: var(--cream); }
.cta-band .btn-outline { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,.4); }
.cta-band .btn-outline:hover { background: rgba(255,255,255,.1); border-color: #fff; }

@media (max-width: 980px) {
  .why-intro-grid { grid-template-columns: 1fr; gap: 28px; }
  .why-prose-inner, .why-close-inner { font-size: 18px; }
  .cost-table thead th, .cost-table tbody td, .cost-table tfoot td { padding: 14px 16px; font-size: 13px; }
  .cost-table tfoot td { font-size: 17px; }
}

/* ===========================================================
   PAGE: ESPACIOS
   =========================================================== */
.spaces-hero { padding: 40px 0 56px; background: var(--bg); border-bottom: 1px solid var(--line); }
.spaces-hero-grid {
  display: block;
  max-width: 920px;
}
.spaces-hero h1 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02; letter-spacing: -0.025em;
  text-wrap: balance;
  margin-top: 4px;
}
.spaces-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
.spaces-hero .lede {
  font-size: 17px; line-height: 1.6;
  color: var(--soft); max-width: 620px;
  margin: 20px 0 0;
  text-wrap: pretty;
}

/* Big space cards */
.space-cards { padding: 56px 0 72px; background: var(--bg); }
.space-cards-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.space-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
.space-card:hover {
  transform: translateY(-3px);
  border-color: var(--g-mid);
  box-shadow: 0 24px 48px -20px rgba(61,107,16,.22);
}
.space-card-photo {
  aspect-ratio: 4/3;
  background:
    repeating-linear-gradient(135deg, rgba(61,107,16,.08) 0px, rgba(61,107,16,.08) 1px, transparent 1px, transparent 14px),
    linear-gradient(135deg, var(--g-paper), var(--cream-2));
  position: relative;
}
.space-card-photo .ph-tag {
  position: absolute; top: 16px; left: 16px;
  font-family: ui-monospace, monospace;
  font-size: 10px; letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--soft);
  background: rgba(255,255,255,.85);
  padding: 5px 9px; border-radius: 6px;
  border: 1px solid var(--line);
}
.space-card-photo .ph-cap {
  position: absolute; bottom: 16px; right: 16px;
  font-family: ui-monospace, monospace;
  font-size: 10px; color: var(--soft);
  background: rgba(255,255,255,.85);
  padding: 4px 8px; border-radius: 6px;
}
.space-card-body {
  padding: 28px 28px 26px;
  display: flex; flex-direction: column; flex: 1;
}
.space-card .stag {
  font-family: 'Fraunces', serif;
  font-size: 12px; color: var(--g);
  margin-bottom: 12px; letter-spacing: 0.4px;
  font-weight: 500;
}
.space-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 26px; font-weight: 500;
  letter-spacing: -0.018em;
  margin-bottom: 12px; line-height: 1.1;
}
.space-card p {
  font-size: 14.5px; color: var(--soft);
  line-height: 1.6; margin-bottom: 14px;
}
.space-card p:last-of-type { margin-bottom: 22px; flex: 1; }
.space-card-prices {
  padding-top: 18px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.space-card-price-row {
  display: flex; justify-content: space-between;
  font-size: 12.5px; color: var(--soft);
  letter-spacing: .1px;
}
.space-card-price-row.main { color: var(--ink); font-weight: 500; font-size: 13.5px; }
.space-card-price-row b {
  font-family: 'Fraunces', serif; font-weight: 500;
  color: var(--ink); font-size: 14px;
  font-variant-numeric: tabular-nums;
}
.space-card-cta {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 13px 18px;
  border-radius: 999px;
  background: var(--ink); color: #fff;
  font-size: 14px; font-weight: 500;
  text-decoration: none;
  transition: background .2s;
}
.space-card-cta:hover { background: var(--g); }
.space-card-cta::after { content: '→'; transition: transform .2s; }
.space-card-cta:hover::after { transform: translateX(3px); }

/* Equipment strip */
.equip { padding: 64px 0; background: var(--cream); }
.equip-head { text-align: center; max-width: 620px; margin: 0 auto 36px; }
.equip-head .eyebrow { justify-content: center; }
.equip-head .eyebrow::before { display: none; }
.equip-head h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.05; letter-spacing: -0.022em;
  text-wrap: balance;
}
.equip-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.equip-head .equip-lede { font-size: 15px; color: var(--soft); margin-top: 12px; line-height: 1.55; }
.equip-note { text-align:center; font-family: ui-monospace, monospace; font-size:12px; letter-spacing:.3px; color:var(--soft); margin-top:24px; }
.formats-note-inline { display: inline-flex; align-items: center; gap: 8px; margin-left: 8px; font-family: ui-monospace, monospace; font-size: 11px; letter-spacing: .4px; text-transform: uppercase; color: var(--g-dark); background: var(--g-paper); border: 1px solid var(--g-light); padding: 4px 12px; border-radius: 999px; white-space: nowrap; }
.formats-note-inline .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--g); }
.equip-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: #fff; border: 1px solid var(--line);
  border-radius: 18px; overflow: hidden;
}
.equip-item {
  padding: 24px 22px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: center; gap: 14px;
  font-size: 14px; color: var(--ink);
  font-weight: 500;
  line-height: 1.3;
}
.equip-item:nth-child(4n) { border-right: none; }
.equip-item:nth-last-child(-n+4) { border-bottom: none; }
.equip-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--g-paper);
  color: var(--g);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 600;
  flex-shrink: 0;
  font-family: 'Fraunces', serif;
}

/* Reservation note */
.reserve-note { padding: 56px 0; background: var(--bg); }
.reserve-note-inner {
  max-width: 760px; margin: 0 auto;
  background: var(--g-paper);
  border: 1px solid var(--g-light);
  border-radius: 18px;
  padding: 36px 40px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  align-items: start;
}
.reserve-note-mark {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--g);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-size: 20px; font-weight: 600;
  flex-shrink: 0;
}
.reserve-note h3 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.015em;
  margin-bottom: 10px;
}
.reserve-note p {
  font-size: 14.5px; color: var(--soft);
  line-height: 1.6; margin-bottom: 8px;
}
.reserve-note p:last-child { margin-bottom: 0; }
.reserve-note p strong { color: var(--ink); font-weight: 500; }

@media (max-width: 980px) {
  .spaces-hero-grid { display: block; }
  .space-cards-grid { grid-template-columns: 1fr; }
  .equip-grid { grid-template-columns: 1fr 1fr; }
  .equip-item { border-right: 1px solid var(--line); }
  .equip-item:nth-child(2n) { border-right: none; }
  .equip-item:nth-last-child(-n+2) { border-bottom: none; }
  .equip-item:nth-last-child(3) { border-bottom: 1px solid var(--line); }
  .reserve-note-inner { grid-template-columns: 1fr; padding: 28px; }
}

/* ===========================================================
   PAGE: FAQ
   =========================================================== */
.faq-hero { padding: 88px 0 40px; background: var(--bg); }
.faq-hero-grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr;
  gap: 64px; align-items: end;
}
.faq-hero h1 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(42px, 5.4vw, 72px);
  line-height: 0.98; letter-spacing: -0.025em;
  text-wrap: balance;
}
.faq-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
.faq-hero .lede { font-size: 17px; color: var(--soft); line-height: 1.6; max-width: 420px; }

/* sticky category nav */
.faq-cat-nav {
  position: sticky; top: 60px;
  background: rgba(250, 248, 243, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  z-index: 50;
  padding: 14px 0;
}
.faq-cat-nav-inner {
  display: flex; gap: 6px; flex-wrap: wrap;
  align-items: center;
}
.faq-cat-nav-label {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .8px;
  text-transform: uppercase; color: var(--soft);
  margin-right: 14px;
}
.faq-cat-pill {
  padding: 8px 14px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid var(--line);
  font-size: 13px; color: var(--ink);
  text-decoration: none;
  font-weight: 500;
  transition: all .18s;
}
.faq-cat-pill:hover { background: var(--ink); color: #fff; border-color: var(--ink); }

/* sections */
.faq-section { padding: 64px 0 32px; background: var(--bg); scroll-margin-top: 130px; }
.faq-section + .faq-section { padding-top: 24px; }
.faq-section-head {
  display: grid; grid-template-columns: 80px 1fr;
  gap: 24px; align-items: baseline;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 8px;
}
.faq-section-num {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 36px; color: var(--g);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}
.faq-section-title h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.faq-section-title h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.faq-section-title p { font-size: 14px; color: var(--soft); }

.faq-list { border-top: none; }
.faq-q-page {
  border-bottom: 1px solid var(--line);
}
.faq-q-page summary {
  list-style: none;
  padding: 24px 0;
  cursor: pointer;
  display: grid;
  grid-template-columns: 80px 1fr 32px;
  gap: 24px;
  align-items: start;
  transition: color .15s;
}
.faq-q-page summary::-webkit-details-marker { display: none; }
.faq-q-page summary:hover { color: var(--g); }
.faq-q-num {
  font-family: ui-monospace, monospace;
  font-size: 12px; letter-spacing: .4px;
  color: var(--soft);
  padding-top: 4px;
}
.faq-q-text {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 19px; line-height: 1.35;
  letter-spacing: -0.012em;
  color: var(--ink);
  text-wrap: pretty;
}
.faq-q-icon {
  width: 28px; height: 28px;
  border-radius: 999px;
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  position: relative;
  transition: all .25s;
  flex-shrink: 0;
  margin-top: 2px;
}
.faq-q-icon::before, .faq-q-icon::after {
  content: '';
  position: absolute;
  background: var(--ink);
  transition: transform .25s, opacity .25s;
}
.faq-q-icon::before { width: 11px; height: 1.5px; }
.faq-q-icon::after { width: 1.5px; height: 11px; }
.faq-q-page[open] .faq-q-icon { background: var(--ink); border-color: var(--ink); }
.faq-q-page[open] .faq-q-icon::before { background: #fff; }
.faq-q-page[open] .faq-q-icon::after { background: #fff; opacity: 0; transform: rotate(90deg); }
.faq-a {
  font-weight: 400;
  padding: 0 0 28px 104px;
  font-size: 15px; color: var(--soft);
  line-height: 1.7;
  max-width: 760px;
  text-wrap: pretty;
}
.faq-a strong, .faq-a b { color: var(--ink); font-weight: 700; }
.faq-a a { color: var(--g); text-decoration: underline; text-underline-offset: 3px; }

/* contact card at bottom */
.faq-help {
  background: var(--g-paper);
  border: 1px solid var(--g-light);
  border-radius: 22px;
  padding: 44px 48px;
  margin: 56px 0 0;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 28px;
  align-items: center;
}
.faq-help h3 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(24px, 2.6vw, 32px);
  line-height: 1.05; letter-spacing: -0.02em;
  margin-bottom: 10px;
}
.faq-help h3 em { font-style: italic; color: var(--g); font-weight: 400; }
.faq-help p { font-size: 15px; color: var(--soft); max-width: 480px; }
.faq-help-actions { display: flex; gap: 10px; flex-shrink: 0; }

@media (max-width: 980px) {
  .faq-hero-grid { grid-template-columns: 1fr; gap: 24px; }
  .faq-cat-nav { top: 56px; }
  .faq-section-head { grid-template-columns: 1fr; gap: 6px; }
  .faq-section-num { font-size: 28px; }
  .faq-q-page summary { grid-template-columns: 1fr 28px; gap: 16px; }
  .faq-q-num { display: none; }
  .faq-a {
  font-weight: 400; padding-left: 0; }
  .faq-help { grid-template-columns: 1fr; padding: 32px; }
  .faq-help-actions { flex-direction: column; }
  .faq-help-actions .btn { width: 100%; }
}

/* ===========================================================
   PAGE: CONTACTO
   =========================================================== */
.contact-hero { padding: 40px 0 48px; background: var(--bg); border-bottom: 1px solid var(--line); }
.contact-hero-grid {
  display: block;
  max-width: 920px;
}
.contact-hero h1 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.02; letter-spacing: -0.025em;
  text-wrap: balance;
  margin-top: 4px;
}
.contact-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
.contact-hero .lede { font-size: 17px; color: var(--soft); line-height: 1.6; max-width: 620px; margin: 20px 0 0; }

/* Form layout */
.contact-body { padding: 56px 0 88px; background: var(--bg); }
.contact-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  align-items: start;
}

/* Form */
.contact-form {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 44px;
}
.contact-form h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 28px; line-height: 1.05; letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.contact-form h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.contact-form .form-sub {
  font-size: 14px; color: var(--soft);
  margin-bottom: 28px;
}
.form-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-field.full { grid-column: 1 / -1; }
.form-field label {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .8px;
  text-transform: uppercase; color: var(--soft);
  font-weight: 500;
}
.form-field label span.req { color: var(--g); margin-left: 2px; }
.form-field input,
.form-field textarea,
.form-field select {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  color: var(--ink);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 13px 14px;
  outline: none;
  transition: border-color .15s, background .15s;
  width: 100%;
}
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {
  border-color: var(--g);
  background: #fff;
}
.form-field input::placeholder,
.form-field textarea::placeholder { color: #98a39a; }
.form-field textarea {
  resize: vertical;
  min-height: 120px;
  line-height: 1.55;
}

/* Segmented selector for "Me interesa…" */
.form-seg {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 4px;
}
.form-seg input { display: none; }
.form-seg label {
  text-transform: none;
  letter-spacing: 0;
  font-family: 'Inter', sans-serif;
  font-size: 13.5px;
  color: var(--soft);
  font-weight: 500;
  text-align: center;
  padding: 10px 8px;
  border-radius: 8px;
  cursor: pointer;
  transition: all .15s;
}
.form-seg label:hover { color: var(--ink); }
.form-seg input:checked + label {
  background: var(--ink);
  color: #fff;
}

/* Consent */
.form-consent {
  display: flex; gap: 10px; align-items: flex-start;
  margin: 8px 0 22px;
  font-size: 13px; color: var(--soft); line-height: 1.5;
}
.form-consent input { margin-top: 3px; flex-shrink: 0; accent-color: var(--g); }
.form-consent a { color: var(--g); text-decoration: underline; text-underline-offset: 3px; }

.form-submit-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.form-submit-row .btn { padding: 14px 22px; font-size: 14px; }
.form-meta { font-size: 12px; color: var(--soft); }

/* Sidebar */
.contact-side {
  display: flex; flex-direction: column;
  gap: 18px;
}
.contact-card {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 26px 28px;
}
.contact-card.dark {
  background: var(--ink);
  color: #f4f0e8;
  border-color: var(--ink);
}
.contact-card.dark a { color: #fff; }
.contact-card-eyebrow {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .8px;
  text-transform: uppercase;
  opacity: .6;
  margin-bottom: 12px;
  display: block;
}
.contact-card h3 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.018em;
  margin-bottom: 14px;
  line-height: 1.15;
}
.contact-card.dark h3 em { color: var(--g-light); font-style: italic; font-weight: 400; }
.contact-card h3 em { color: var(--g); font-style: italic; font-weight: 400; }
.contact-card-row {
  display: flex; align-items: baseline; gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--line);
  font-size: 14.5px;
}
.contact-card.dark .contact-card-row { border-top-color: rgba(255,255,255,.1); }
.contact-card-row:first-of-type { border-top: none; padding-top: 0; }
.contact-card-row .lbl {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .6px;
  text-transform: uppercase;
  color: var(--soft);
  flex-shrink: 0; width: 64px;
}
.contact-card.dark .contact-card-row .lbl { color: rgba(255,255,255,.5); }
.contact-card-row .val { color: var(--ink); flex: 1; }
.contact-card.dark .contact-card-row .val { color: #fff; }
.contact-card-row a { text-decoration: none; }
.contact-card-row a:hover { color: var(--g); }
.contact-card.dark .contact-card-row a:hover { color: var(--g-light); }

/* Map */
.contact-map {
  margin-top: 8px;
  background: var(--bg);
  padding-bottom: 72px;
}
.contact-map-frame {
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  aspect-ratio: 21/9;
  position: relative;
  background:
    linear-gradient(135deg, var(--cream-2), var(--g-paper));
}
.contact-map-frame iframe {
  width: 100%; height: 100%; border: 0; display: block;
}
.contact-map-pin {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -100%);
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px 20px;
  box-shadow: 0 12px 32px -12px rgba(20,23,20,.18);
  display: flex; align-items: center; gap: 12px;
  pointer-events: none;
  z-index: 2;
}
.contact-map-pin-dot {
  width: 12px; height: 12px; border-radius: 999px;
  background: var(--g); box-shadow: 0 0 0 5px rgba(61,107,16,.18);
  flex-shrink: 0;
}
.contact-map-pin .pin-text { font-size: 13px; color: var(--ink); font-weight: 500; }
.contact-map-pin .pin-text small { display: block; color: var(--soft); font-weight: 400; font-size: 12px; margin-top: 2px; }

@media (max-width: 980px) {
  .contact-hero-grid { display: block; }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .contact-side { position: static; }
  .contact-form { padding: 28px; }
  .form-row { grid-template-columns: 1fr; }
  .contact-map-frame { aspect-ratio: 4/3; }
}

/* ===========================================================
   PAGE: OFICINA VIRTUAL — feature comparison table
   =========================================================== */
.ftable-section { padding: 88px 0; background: var(--bg); }
.ftable-head {
  display: grid; grid-template-columns: 1.05fr 0.95fr;
  gap: 64px; align-items: end;
  margin-bottom: 44px;
}
.ftable-head h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(32px, 4vw, 50px);
  line-height: 1.02; letter-spacing: -0.022em;
  text-wrap: balance;
}
.ftable-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.ftable-head .lede { font-size: 16px; color: var(--soft); line-height: 1.6; max-width: 420px; }

.ftable-wrap {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  position: relative;
}
.ftable {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Inter', sans-serif;
}
.ftable thead th {
  background: var(--cream);
  border-bottom: 1px solid var(--line);
  text-align: left;
  padding: 22px 24px;
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.015em;
  color: var(--ink);
  width: 22%;
  vertical-align: bottom;
}
.ftable thead th:first-child {
  width: 34%;
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .8px;
  text-transform: uppercase;
  color: var(--soft);
  font-weight: 500;
}
.ftable thead th .ft-tag {
  display: block;
  font-family: ui-monospace, monospace;
  font-size: 10px; letter-spacing: .6px;
  text-transform: uppercase;
  color: var(--soft);
  font-weight: 500;
  margin-bottom: 6px;
}
.ftable thead th.ft-best {
  background: var(--ink);
  color: #fff;
  position: relative;
}
.ftable thead th.ft-best .ft-tag { color: var(--g-light); }
.ftable thead th.ft-best::before {
  content: '★ Recomendado';
  position: absolute; top: -1px; left: 0; right: 0;
  background: var(--g);
  color: #fff;
  font-family: ui-monospace, monospace;
  font-size: 10px; letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 0;
  text-align: center;
  font-weight: 500;
}
.ftable tbody td {
  padding: 18px 24px;
  border-bottom: 1px solid var(--line);
  font-size: 14.5px;
  color: var(--ink);
  vertical-align: middle;
}
.ftable tbody tr:last-child td { border-bottom: none; }
.ftable tbody tr td:first-child {
  color: var(--soft);
  font-size: 13.5px;
}
.ftable tbody td.ft-best-col {
  background: rgba(20, 23, 20, 0.03);
  font-weight: 500;
}
.ftable .ft-check {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 999px;
  background: var(--g-paper); color: var(--g);
  font-size: 13px; font-weight: 600;
}
.ftable td.ft-best-col .ft-check { background: var(--g); color: #fff; }
.ftable .ft-dash {
  display: inline-block; width: 14px; height: 1.5px;
  background: var(--line);
  vertical-align: middle;
}

/* price rows */
.ftable tr.ft-price-row td {
  padding-top: 22px; padding-bottom: 6px;
  border-bottom: none;
}
.ftable tr.ft-price-row td:first-child {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .6px;
  text-transform: uppercase; color: var(--soft);
}
.ftable tr.ft-price-row td:not(:first-child) {
  font-family: 'Fraunces', serif;
  font-size: 26px;
  font-weight: 500;
  letter-spacing: -0.015em;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
}
.ftable tr.ft-price-row td .ft-currency { font-size: 18px; opacity: .7; }
.ftable tr.ft-price-sub td {
  padding-top: 0;
  border-bottom: 1px solid var(--line);
  font-size: 12px;
  color: var(--soft);
}
.ftable tr.ft-price-sub td:first-child { color: var(--soft); }

.ftable tfoot td {
  padding: 22px 24px;
  background: var(--cream);
  text-align: center;
}
.ftable tfoot td:first-child {
  text-align: left;
  font-size: 12px; color: var(--soft);
  font-family: ui-monospace, monospace;
  letter-spacing: .4px;
}
.ftable tfoot .pc-btn {
  background: var(--ink); color: #fff;
  border: none; border-radius: 999px;
  padding: 11px 18px;
  font-family: 'Inter', sans-serif;
  font-size: 13px; font-weight: 500;
  cursor: pointer;
  transition: background .15s;
}
.ftable tfoot .pc-btn:hover { background: var(--g); }
.ftable tfoot td.ft-best-col .pc-btn { background: var(--g); }
.ftable tfoot td.ft-best-col .pc-btn:hover { background: #2d540f; }

.ftable-foot {
  margin-top: 22px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
}
.ftable-foot .meta {
  font-family: ui-monospace, monospace;
  font-size: 11px; color: var(--soft);
  letter-spacing: .4px;
}

@media (max-width: 980px) {
  .ftable-head { grid-template-columns: 1fr; gap: 18px; }
  .ftable-wrap { overflow-x: auto; }
  .ftable { min-width: 720px; }
}

/* ===========================================================
   PAGE: DESPACHO MENSUAL — format cards
   =========================================================== */
.formats-section { padding: 88px 0 48px; background: var(--bg); }
.formats-head { margin-bottom: 36px; max-width: 720px; }
.formats-head h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(32px, 4vw, 50px);
  line-height: 1.02; letter-spacing: -0.022em;
  text-wrap: balance;
}
.formats-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.formats-head .lede {
  margin-top: 14px;
  font-size: 16px; color: var(--soft); line-height: 1.6;
  max-width: 560px;
}

.formats-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
.format-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .25s, border-color .25s, box-shadow .25s;
}
.format-card:hover {
  transform: translateY(-3px);
  border-color: var(--g-mid);
  box-shadow: 0 24px 48px -20px rgba(61,107,16,.18);
}
.format-card-photo {
  aspect-ratio: 4/3;
  background:
    repeating-linear-gradient(135deg, rgba(61,107,16,.08) 0px, rgba(61,107,16,.08) 1px, transparent 1px, transparent 14px),
    linear-gradient(135deg, var(--g-paper), var(--cream-2));
  position: relative;
}
.format-card-photo .ph-tag {
  position: absolute; top: 16px; left: 16px;
  font-family: ui-monospace, monospace;
  font-size: 10px; letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--soft);
  background: rgba(255,255,255,.85);
  padding: 5px 9px; border-radius: 6px;
  border: 1px solid var(--line);
}
.format-card-photo .ph-cap {
  position: absolute; bottom: 16px; right: 16px;
  font-family: ui-monospace, monospace;
  font-size: 10px; color: var(--soft);
  background: rgba(255,255,255,.85);
  padding: 4px 8px; border-radius: 6px;
}
.format-card-body {
  padding: 28px 28px 26px;
  display: flex; flex-direction: column; flex: 1;
}
.format-card .stag {
  font-family: 'Fraunces', serif;
  font-size: 12px; color: var(--g);
  margin-bottom: 12px; letter-spacing: .4px;
  font-weight: 500;
}
.format-card h3 {
  font-family: 'Fraunces', serif;
  font-size: 26px; font-weight: 500;
  letter-spacing: -0.018em;
  margin-bottom: 12px; line-height: 1.1;
}
.format-card p {
  font-size: 14.5px; color: var(--soft);
  line-height: 1.6; flex: 1; margin-bottom: 22px;
}
.format-card-price {
  padding: 16px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 18px;
}
.format-card-price .num {
  font-family: 'Fraunces', serif;
  font-weight: 500; font-size: 28px;
  letter-spacing: -0.018em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.format-card-price .num small {
  font-size: 14px; color: var(--soft);
  font-family: 'Inter', sans-serif;
  margin-left: 6px;
  font-weight: 400;
}
.format-card-price .from {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .6px;
  text-transform: uppercase;
  color: var(--soft);
}
.format-card-extra {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--g);
  margin-bottom: 18px;
  display: block;
}
.format-card-cta {
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 10px;
  padding: 14px 18px;
  border-radius: 999px;
  background: var(--ink); color: #fff;
  font-size: 13.5px; font-weight: 500;
  text-decoration: none;
  transition: background .2s;
}
.format-card-cta:hover { background: var(--g); }
.format-card-cta::after { content: '→'; transition: transform .2s; }
.format-card-cta:hover::after { transform: translateX(3px); }
.format-card-note {
  font-family: ui-monospace, monospace;
  font-size: 10.5px; letter-spacing: .4px;
  color: var(--soft); text-align: center;
  margin-top: 12px;
}

/* Note bar above the cards */
.formats-note {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px;
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--soft);
  margin-bottom: 22px;
}
.formats-note .dot {
  width: 7px; height: 7px; border-radius: 999px;
  background: var(--g);
  box-shadow: 0 0 0 4px rgba(61,107,16,.15);
}

/* Closing prose */
.closing-prose { padding: 56px 0 24px; background: var(--bg); }
.closing-prose-inner {
  max-width: 760px; margin: 0 auto;
  text-align: center;
}
.closing-prose p {
  font-family: 'Fraunces', serif; font-weight: 400;
  font-size: clamp(20px, 2.4vw, 26px);
  line-height: 1.4; color: var(--ink);
  letter-spacing: -0.012em;
  text-wrap: balance;
}
.closing-prose p + p { margin-top: 18px; }
.closing-prose em { font-style: italic; color: var(--g); }

@media (max-width: 980px) {
  .formats-grid { grid-template-columns: 1fr; }
}


/* ---------- TARIFAS INLINE CSS ---------- */

  /* --------- PAGE LAYOUT --------- */
  .tar-hero {
    padding: 88px 0 56px;
    background:
      radial-gradient(ellipse 70% 60% at 92% 0%, rgba(91,147,32,.10), transparent 60%),
      linear-gradient(180deg, #fff 0%, var(--cream) 100%);
    border-bottom: 1px solid var(--line);
  }
  .tar-hero h1 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: clamp(48px, 6.5vw, 84px);
    line-height: 0.96;
    letter-spacing: -0.025em;
    margin: 18px 0 24px;
    max-width: 880px;
  }
  .tar-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
  .tar-hero-meta {
    display: flex; gap: 28px; flex-wrap: wrap; align-items: center;
    margin-top: 28px; padding-top: 26px; border-top: 1px solid var(--line);
    font-size: 13px; color: var(--soft);
  }
  .tar-hero-meta strong { color: var(--ink); font-weight: 500; }
  .tar-hero-meta span { display: inline-flex; align-items: center; gap: 8px; }
  .tar-hero-meta span::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--g-mid);
  }

  /* --------- ANCLAS --------- */
  .tar-anchors {
    background: #fff;
    border-bottom: 1px solid var(--line);
    position: sticky; top: 65px; z-index: 40;
  }
  .tar-anchors-row {
    display: flex; gap: 6px; overflow-x: auto;
    padding: 12px 0; align-items: center;
  }
  .tar-anchors a {
    flex-shrink: 0;
    font-size: 12.5px; font-weight: 500;
    color: var(--soft);
    padding: 8px 14px; border-radius: 999px;
    border: 1px solid var(--line);
    background: #fff;
    transition: all .15s;
    white-space: nowrap;
  }
  .tar-anchors a:hover { background: var(--g-light); border-color: var(--g-light); color: var(--g-dark); }
  .tar-anchors-lab {
    flex-shrink: 0;
    font-family: ui-monospace, monospace;
    font-size: 11px; letter-spacing: .4px; text-transform: uppercase;
    color: var(--faint);
    padding-right: 8px;
  }

  /* --------- BLOQUE PRICING --------- */
  .tar-block { padding: 80px 0 24px; }
  .tar-block.alt { background: var(--cream); }
  .tar-block.dark { background: var(--ink); color: #fff; }
  .tar-block.dark .tar-head h2 { color: #fff; }
  .tar-block.dark .tar-head h2 em { color: var(--g-mid); }
  .tar-block.dark .tar-head-meta { color: rgba(255,255,255,.55); }

  .tar-head {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 40px;
    align-items: end;
    margin-bottom: 44px;
  }
  .tar-head h2 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: clamp(32px, 4vw, 52px);
    line-height: 1;
    letter-spacing: -0.02em;
    margin: 0;
  }
  .tar-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
  .tar-head h2 .num {
    font-family: ui-monospace, monospace;
    font-size: 13px;
    color: var(--soft); font-weight: 400;
    letter-spacing: 0.2px;
    display: block; margin-bottom: 14px;
    text-transform: uppercase;
  }
  .tar-block.dark .tar-head h2 .num { color: rgba(255,255,255,.5); }
  .tar-head-meta {
    font-size: 13px;
    color: var(--soft);
    line-height: 1.6;
    max-width: 360px;
    justify-self: end;
    text-align: right;
  }
  .tar-head-meta strong { color: var(--ink); font-weight: 500; }
  .tar-block.dark .tar-head-meta strong { color: #fff; }

  /* --------- TARIFAS GRID 3 CARDS --------- */
  .tar-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
  }
  .tar-block.alt .tar-grid-3 { background: var(--line); border-color: var(--line); }
  .tar-block.dark .tar-grid-3 { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.1); }
  .tar-card {
    background: #fff;
    padding: 32px 28px 28px;
    display: flex; flex-direction: column;
    min-height: 280px;
    position: relative;
  }
  .tar-block.alt .tar-card { background: #fff; }
  .tar-block.dark .tar-card { background: #1c1f1c; color: #fff; }
  .tar-card.feat { background: var(--g-paper); }
  .tar-block.dark .tar-card.feat { background: #232723; }
  .tar-card-head {
    display: flex; justify-content: space-between; align-items: baseline;
    margin-bottom: 22px; padding-bottom: 18px;
    border-bottom: 1px solid var(--line);
  }
  .tar-block.dark .tar-card-head { border-color: rgba(255,255,255,.1); }
  .tar-card-name {
    font-family: 'Fraunces', serif;
    font-size: 22px; font-weight: 500;
    letter-spacing: -0.012em;
  }
  .tar-card-tag {
    font-family: ui-monospace, monospace;
    font-size: 10px; letter-spacing: .8px; text-transform: uppercase;
    color: var(--soft);
  }
  .tar-block.dark .tar-card-tag { color: rgba(255,255,255,.45); }
  .tar-card.feat .tar-card-tag { color: var(--g); }
  .tar-block.dark .tar-card.feat .tar-card-tag { color: var(--g-mid); }
  .tar-card-price {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 68px;
    line-height: 1;
    letter-spacing: -0.035em;
    color: var(--ink);
    display: flex; align-items: baseline; gap: 4px;
  }
  .tar-block.dark .tar-card-price { color: #fff; }
  .tar-card-price .cents {
    font-size: 38px;
    letter-spacing: -0.02em;
  }
  .tar-card-price .cur {
    font-size: 32px;
    color: var(--g);
    margin-left: 4px;
  }
  .tar-block.dark .tar-card-price .cur { color: var(--g-mid); }
  .tar-card-period {
    font-size: 12px;
    color: var(--soft);
    margin-top: 10px;
    font-family: ui-monospace, monospace;
    letter-spacing: 0.2px;
    text-transform: uppercase;
  }
  .tar-block.dark .tar-card-period { color: rgba(255,255,255,.5); }
  .tar-card-alt {
    margin-top: auto;
    padding-top: 20px;
    border-top: 1px dashed var(--line);
    display: flex; justify-content: space-between; align-items: baseline;
    font-size: 13px;
  }
  .tar-block.dark .tar-card-alt { border-color: rgba(255,255,255,.12); }
  .tar-card-alt-lab { color: var(--soft); }
  .tar-block.dark .tar-card-alt-lab { color: rgba(255,255,255,.55); }
  .tar-card-alt-val {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 22px;
    letter-spacing: -0.01em;
  }
  .tar-card-alt-val small { font-size: 12px; color: var(--g); margin-left: 2px; font-family: 'Fraunces', serif; }
  .tar-block.dark .tar-card-alt-val small { color: var(--g-mid); }

  /* --------- SALAS BLOCK (custom rows, light) --------- */
  .tar-salas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
  }
  .tar-sala {
    background: #fff;
    padding: 32px 28px;
    display: flex; flex-direction: column;
  }
  .tar-block.alt .tar-sala { background: #fff; }
  .tar-sala-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
  .tar-sala-name {
    font-family: 'Fraunces', serif;
    font-size: 24px; font-weight: 500;
    letter-spacing: -0.012em;
    color: var(--ink);
  }
  .tar-sala-cap {
    font-family: ui-monospace, monospace;
    font-size: 11px; color: var(--soft);
    letter-spacing: .3px;
  }
  .tar-sala-hour {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 56px; line-height: 1;
    color: var(--ink);
    margin: 22px 0 6px;
    display: flex; align-items: baseline; gap: 4px;
    letter-spacing: -0.03em;
  }
  .tar-sala-hour .cur { font-size: 28px; color: var(--g); margin-left: 4px; }
  .tar-sala-hour-lab {
    font-family: ui-monospace, monospace;
    font-size: 11px; letter-spacing: 0.4px;
    color: var(--soft);
    text-transform: uppercase;
    margin-bottom: 24px;
  }
  .tar-sala-rows {
    margin-top: auto;
    border-top: 1px solid var(--line);
    padding-top: 16px;
  }
  .tar-sala-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: baseline;
    padding: 8px 0;
    font-size: 13.5px;
    border-bottom: 1px dashed var(--line);
  }
  .tar-sala-row:last-child { border-bottom: none; }
  .tar-sala-row .lab { color: var(--soft); }
  .tar-sala-row .val { font-family: 'Fraunces', serif; font-weight: 500; font-size: 18px; color: var(--ink); letter-spacing: -0.01em; }
  .tar-sala-row .val small { color: var(--g); font-size: 12px; margin-left: 1px; }

  /* --------- DESPACHOS BLOCK --------- */
  .tar-desp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .tar-desp {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 32px 28px;
    position: relative;
    overflow: hidden;
  }
  .tar-desp.feat {
    background: var(--g);
    border-color: var(--g);
    color: #fff;
  }
  .tar-desp-num {
    font-family: ui-monospace, monospace;
    font-size: 11px; letter-spacing: .5px;
    color: var(--faint);
    margin-bottom: 16px;
  }
  .tar-desp.feat .tar-desp-num { color: rgba(255,255,255,.65); }
  .tar-desp-name {
    font-family: 'Fraunces', serif;
    font-size: 22px; font-weight: 500;
    letter-spacing: -0.012em;
    margin-bottom: 6px;
  }
  .tar-desp-cap {
    font-size: 12.5px; color: var(--soft);
    margin-bottom: 28px;
  }
  .tar-desp.feat .tar-desp-cap { color: rgba(255,255,255,.7); }
  .tar-desp-price {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 84px;
    line-height: 0.95;
    letter-spacing: -0.04em;
    display: flex; align-items: baseline; gap: 4px;
  }
  .tar-desp-price .from {
    font-family: 'Inter', sans-serif;
    font-size: 12px; font-weight: 500;
    color: var(--soft);
    letter-spacing: .8px; text-transform: uppercase;
    align-self: flex-start; margin-top: 6px;
    margin-right: 10px;
  }
  .tar-desp.feat .tar-desp-price .from { color: rgba(255,255,255,.7); }
  .tar-desp-price .cur { font-size: 32px; color: var(--g); margin-left: 4px; }
  .tar-desp.feat .tar-desp-price .cur { color: var(--g-light); }
  .tar-desp-period {
    font-size: 12px;
    color: var(--soft);
    margin-top: 12px;
    font-family: ui-monospace, monospace;
    letter-spacing: 0.2px;
    text-transform: uppercase;
  }
  .tar-desp.feat .tar-desp-period { color: rgba(255,255,255,.65); }
  .tar-desp-foot {
    margin-top: 28px;
    padding-top: 18px;
    border-top: 1px solid var(--line);
    font-size: 12.5px;
    color: var(--soft);
    display: flex; gap: 8px; align-items: center;
  }
  .tar-desp.feat .tar-desp-foot { border-color: rgba(255,255,255,.18); color: rgba(255,255,255,.75); }
  .tar-desp-foot::before {
    content: '★';
    color: var(--g-mid);
    font-size: 11px;
  }
  .tar-desp.feat .tar-desp-foot::before { color: var(--g-light); }

  /* --------- BONOS (light) --------- */
  .tar-bonos {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px 32px;
  }
  .tar-bonos-head {
    display: grid;
    grid-template-columns: 1fr 110px 110px;
    gap: 24px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--line);
    font-family: ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--soft);
  }
  .tar-bonos-head .h-right { text-align: right; }
  .tar-bonos-row {
    display: grid;
    grid-template-columns: 1fr 110px 110px;
    gap: 24px;
    align-items: center;
    padding: 18px 0;
    border-bottom: 1px dashed var(--line);
  }
  .tar-bonos-row:last-child { border-bottom: none; }
  .tar-bonos-name {
    font-family: 'Fraunces', serif;
    font-size: 19px; font-weight: 500;
    color: var(--ink);
    letter-spacing: -0.01em;
  }
  .tar-bonos-name small {
    display: block;
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    color: var(--soft);
    font-weight: 400;
    margin-top: 3px;
  }
  .tar-bonos-price {
    font-family: 'Fraunces', serif;
    font-size: 28px; font-weight: 500;
    color: var(--ink);
    text-align: right;
    letter-spacing: -0.02em;
  }
  .tar-bonos-price .cur { color: var(--g); font-size: 16px; margin-left: 2px; }

  /* --------- ANNUAL TOGGLE BANNER (OficinaV) --------- */
  .tar-anual-note {
    display: inline-flex; align-items: center; gap: 12px;
    background: var(--g-light); color: var(--g-dark);
    padding: 8px 14px; border-radius: 999px;
    font-size: 12px; font-weight: 500;
    margin-bottom: 28px;
  }
  .tar-anual-note::before {
    content: '%'; width: 22px; height: 22px;
    background: var(--g); color: #fff;
    border-radius: 50%;
    font-size: 11px; font-weight: 600;
    display: flex; align-items: center; justify-content: center;
  }

  /* --------- PREMIUM BLOCK --------- */
  .tar-prem-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .tar-prem {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 24px 22px;
    display: flex; flex-direction: column;
    gap: 14px;
  }
  .tar-prem-num {
    font-family: ui-monospace, monospace;
    font-size: 11px; color: var(--faint);
    letter-spacing: .3px;
  }
  .tar-prem-name {
    font-family: 'Fraunces', serif;
    font-weight: 500; font-size: 18px;
    letter-spacing: -0.01em;
    color: var(--ink);
  }
  .tar-prem-price {
    font-family: 'Fraunces', serif;
    font-size: 14px;
    color: var(--g);
    font-style: italic;
    margin-top: auto;
  }

  /* --------- LEYENDA / NOTA FINAL (oscuro) --------- */
  .tar-legal {
    background: var(--ink);
    color: #fff;
    padding: 72px 0 88px;
    border-top: 1px solid var(--line);
  }
  .tar-legal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    max-width: 920px;
    margin: 0 auto;
  }
  .tar-legal h3 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 22px;
    margin: 0 0 14px;
    letter-spacing: -0.012em;
    color: #fff;
  }
  .tar-legal h3 em { font-style: italic; color: var(--g-mid); }
  .tar-legal p {
    font-size: 14px;
    color: rgba(255,255,255,.6);
    line-height: 1.6;
  }

  /* --------- CTA --------- */
  .tar-cta {
    background: #fff;
    color: var(--ink);
    padding: 88px 0 96px;
    text-align: center;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .tar-cta h2 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: clamp(36px, 4.5vw, 60px);
    line-height: 1;
    letter-spacing: -0.025em;
    margin-bottom: 18px;
  }
  .tar-cta h2 em { font-style: italic; color: var(--g); font-weight: 400; }
  .tar-cta p {
    color: var(--soft);
    margin-bottom: 28px;
    font-size: 15px;
    max-width: 540px;
    margin-left: auto; margin-right: auto;
  }
  .tar-cta .btns { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
  .tar-cta .btn-outline { border: 1px solid var(--line-strong); color: var(--ink); padding: 12px 22px; border-radius: 999px; font-size: 14px; font-weight: 500; background: transparent; }
  .tar-cta .btn-outline:hover { background: rgba(0,0,0,.04); }

  @media (max-width: 900px) {
    .tar-head { grid-template-columns: 1fr; }
    .tar-head-meta { justify-self: start; text-align: left; }
    .tar-grid-3, .tar-desp-grid, .tar-salas-grid, .tar-prem-grid { grid-template-columns: 1fr; }
    .tar-legal-grid { grid-template-columns: 1fr; }
    .tar-bonos-head, .tar-bonos-row { grid-template-columns: 1fr 80px 80px; gap: 12px; }
    .tar-bonos-price { font-size: 20px; }
    .tar-card-price, .tar-desp-price { font-size: 56px; }
    .tar-anchors { position: static; }
  }

.ftable tr.merged-price-row td { border-bottom: 1px solid var(--line); padding-bottom: 22px; }

/* HOWTO FIX FROM INLINE CSS */

/* Bonos dark band */
.bonos-band { background: var(--ink); color: #fff; padding: 80px 0; position: relative; overflow: hidden; }
.bonos-band::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 0%, rgba(91,147,32,.18), transparent 55%);
  pointer-events: none;
}
.bonos-grid { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 64px; align-items: start; position: relative; }
.bonos-head .eyebrow { color: var(--g-mid); }
.bonos-head .eyebrow::before { background: var(--g-mid); }
.bonos-head h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(36px, 4.2vw, 56px);
  line-height: 1.04; letter-spacing: -0.022em;
  margin: 14px 0 18px; text-wrap: balance;
}
.bonos-head h2 em { font-style: italic; color: var(--g-mid); font-weight: 400; }
.bonos-head p { font-size: 16px; color: rgba(255,255,255,.7); line-height: 1.65; max-width: 460px; }
.bonos-head .meta { display: block; margin-top: 14px; font-family: ui-monospace, monospace; font-size: 11.5px; letter-spacing: .8px; color: rgba(255,255,255,.45); text-transform: uppercase; }
.bonos-table { border: 1px solid rgba(255,255,255,.12); border-radius: 16px; overflow: hidden; }
.bonos-row { display: grid; grid-template-columns: 1.4fr 1fr 1fr; align-items: center; padding: 18px 22px; border-bottom: 1px solid rgba(255,255,255,.08); }
.bonos-row:last-child { border-bottom: none; }
.bonos-row.head { background: rgba(255,255,255,.03); }
.bonos-row.head span { font-family: ui-monospace, monospace; font-size: 11px; letter-spacing: .9px; text-transform: uppercase; color: rgba(255,255,255,.55); }
.bonos-row .name { font-size: 14.5px; color: #fff; font-weight: 500; }
.bonos-row .name small { display: block; font-size: 12px; color: rgba(255,255,255,.5); font-weight: 400; margin-top: 2px; }
.bonos-row .pr {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.01em; color: #fff;
}
.bonos-row .pr small { font-family: 'Inter', sans-serif; font-size: 11.5px; color: rgba(255,255,255,.5); font-weight: 400; margin-left: 4px; }
.bonos-foot { margin-top: 18px; font-size: 13px; color: rgba(255,255,255,.55); }

/* Cómo funciona — 3 pasos */
.howto { padding: 88px 0; background: var(--bg); }
.howto-head { max-width: 720px; margin-bottom: 56px; }
.howto-head .eyebrow { justify-content: flex-start; }
.howto-head h2 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: clamp(32px, 3.8vw, 48px);
  line-height: 1.05; letter-spacing: -0.022em;
  margin-top: 12px; text-wrap: balance;
}
.howto-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.howto-track { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; position: relative; }
.howto-track::before {
  content: ''; position: absolute; left: 4%; right: 4%; top: 28px; height: 1px;
  background: var(--line); z-index: 0;
}
.howto-step { position: relative; z-index: 1; padding-right: 32px; }
.howto-step:last-child { padding-right: 0; }
.howto-num {
  width: 56px; height: 56px; border-radius: 50%;
  background: #fff; border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Fraunces', serif; font-size: 22px; color: var(--ink);
  margin-bottom: 22px;
}
.howto-step.active .howto-num { background: var(--g); border-color: var(--g); color: #fff; }
.howto-step h4 {
  font-family: 'Fraunces', serif; font-weight: 500;
  font-size: 22px; letter-spacing: -0.015em;
  line-height: 1.15; color: var(--ink); margin-bottom: 10px;
  text-wrap: balance;
}
.howto-step p {
  font-size: 14.5px; color: var(--soft); line-height: 1.6;
  max-width: 280px;
}
@media (max-width: 980px) {
  .bonos-grid { grid-template-columns: 1fr; gap: 36px; }
  .howto-track { grid-template-columns: 1fr; gap: 28px; }
  .howto-track::before { display: none; }
  .howto-step { padding-right: 0; }
}

/* PREM GRID FIX FROM INLINE CSS */

  /* Local styles for premium services cards */
  .prem-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
  }
  .prem-card {
    background: #fff;
    padding: 32px 30px 36px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    position: relative;
    transition: background .2s;
  }
  .prem-card:hover { background: var(--g-paper); }
  .prem-num {
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--faint);
    font-weight: 500;
  }
  .prem-card h3 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 24px;
    line-height: 1.15;
    letter-spacing: -0.018em;
    color: var(--ink);
    margin: 0;
  }
  .prem-card h3 em {
    font-style: italic;
    font-weight: 400;
    color: var(--g);
  }
  .prem-card p {
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--soft);
    margin: 0;
  }
  .prem-card.is-new::after {
    content: 'Novedad';
    position: absolute;
    top: 22px; right: 22px;
    background: var(--g);
    color: #fff;
    font-size: 10px;
    letter-spacing: .12em;
    text-transform: uppercase;
    font-weight: 500;
    padding: 4px 9px;
    border-radius: 999px;
  }
  @media (max-width: 960px) {
    .prem-grid { grid-template-columns: repeat(2, 1fr); }
  }
  @media (max-width: 600px) {
    .prem-grid { grid-template-columns: 1fr; }
  }

  /* Pricing note callout */
  .prem-note {
    background: var(--g-light);
    border: 1px solid var(--g-line, #cfe1d4);
    border-radius: 16px;
    padding: 30px 36px;
    display: grid;
    grid-template-columns: 64px 1fr;
    gap: 22px;
    align-items: start;
  }
  .prem-note-mark {
    width: 52px; height: 52px;
    border-radius: 50%;
    background: var(--g);
    color: #fff;
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 24px;
    display: flex; align-items: center; justify-content: center;
  }
  .prem-note h3 {
    font-family: 'Fraunces', serif;
    font-size: 24px;
    font-weight: 500;
    margin: 0 0 8px;
    color: var(--g-dark);
    letter-spacing: -0.012em;
  }
  .prem-note p {
    font-size: 15px;
    line-height: 1.6;
    color: var(--g-dark);
    margin: 0;
    max-width: 720px;
  }
  @media (max-width: 600px) {
    .prem-note { grid-template-columns: 1fr; padding: 24px; }
  }

/* TARIFAS INLINE CSS FIX */

  /* --------- PAGE LAYOUT --------- */
  .tar-hero {
    padding: 88px 0 56px;
    background:
      radial-gradient(ellipse 70% 60% at 92% 0%, rgba(91,147,32,.10), transparent 60%),
      linear-gradient(180deg, #fff 0%, var(--cream) 100%);
    border-bottom: 1px solid var(--line);
  }
  .tar-hero h1 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: clamp(48px, 6.5vw, 84px);
    line-height: 0.96;
    letter-spacing: -0.025em;
    margin: 18px 0 24px;
    max-width: 880px;
  }
  .tar-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
  .tar-hero-meta {
    display: flex; gap: 28px; flex-wrap: wrap; align-items: center;
    margin-top: 28px; padding-top: 26px; border-top: 1px solid var(--line);
    font-size: 13px; color: var(--soft);
  }
  .tar-hero-meta strong { color: var(--ink); font-weight: 500; }
  .tar-hero-meta span { display: inline-flex; align-items: center; gap: 8px; }
  .tar-hero-meta span::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--g-mid);
  }

  /* --------- ANCLAS --------- */
  .tar-anchors {
    background: #fff;
    border-bottom: 1px solid var(--line);
    position: sticky; top: 65px; z-index: 40;
  }
  .tar-anchors-row {
    display: flex; gap: 6px; overflow-x: auto;
    padding: 12px 0; align-items: center;
  }
  .tar-anchors a {
    flex-shrink: 0;
    font-size: 12.5px; font-weight: 500;
    color: var(--soft);
    padding: 8px 14px; border-radius: 999px;
    border: 1px solid var(--line);
    background: #fff;
    transition: all .15s;
    white-space: nowrap;
  }
  .tar-anchors a:hover { background: var(--g-light); border-color: var(--g-light); color: var(--g-dark); }
  .tar-anchors-lab {
    flex-shrink: 0;
    font-family: ui-monospace, monospace;
    font-size: 11px; letter-spacing: .4px; text-transform: uppercase;
    color: var(--faint);
    padding-right: 8px;
  }

  /* --------- BLOQUE PRICING --------- */
  .tar-block { padding: 80px 0 24px; }
  .tar-block.alt { background: var(--cream); }
  .tar-block.dark { background: var(--ink); color: #fff; }
  .tar-block.dark .tar-head h2 { color: #fff; }
  .tar-block.dark .tar-head h2 em { color: var(--g-mid); }
  .tar-block.dark .tar-head-meta { color: rgba(255,255,255,.55); }

  .tar-head {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 40px;
    align-items: end;
    margin-bottom: 44px;
  }
  .tar-head h2 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: clamp(32px, 4vw, 52px);
    line-height: 1;
    letter-spacing: -0.02em;
    margin: 0;
  }
  .tar-head h2 em { font-style: italic; color: var(--g); font-weight: 400; }
  .tar-head h2 .num {
    font-family: ui-monospace, monospace;
    font-size: 13px;
    color: var(--soft); font-weight: 400;
    letter-spacing: 0.2px;
    display: block; margin-bottom: 14px;
    text-transform: uppercase;
  }
  .tar-block.dark .tar-head h2 .num { color: rgba(255,255,255,.5); }
  .tar-head-meta {
    font-size: 13px;
    color: var(--soft);
    line-height: 1.6;
    max-width: 360px;
    justify-self: end;
    text-align: right;
  }
  .tar-head-meta strong { color: var(--ink); font-weight: 500; }
  .tar-block.dark .tar-head-meta strong { color: #fff; }

  /* --------- TARIFAS GRID 3 CARDS --------- */
  .tar-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
  }
  .tar-block.alt .tar-grid-3 { background: var(--line); border-color: var(--line); }
  .tar-block.dark .tar-grid-3 { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.1); }
  .tar-card {
    background: #fff;
    padding: 32px 28px 28px;
    display: flex; flex-direction: column;
    min-height: 280px;
    position: relative;
  }
  .tar-block.alt .tar-card { background: #fff; }
  .tar-block.dark .tar-card { background: #1c1f1c; color: #fff; }
  .tar-card.feat { background: var(--g-paper); }
  .tar-block.dark .tar-card.feat { background: #232723; }
  .tar-card-head {
    display: flex; justify-content: space-between; align-items: baseline;
    margin-bottom: 22px; padding-bottom: 18px;
    border-bottom: 1px solid var(--line);
  }
  .tar-block.dark .tar-card-head { border-color: rgba(255,255,255,.1); }
  .tar-card-name {
    font-family: 'Fraunces', serif;
    font-size: 22px; font-weight: 500;
    letter-spacing: -0.012em;
  }
  .tar-card-tag {
    font-family: ui-monospace, monospace;
    font-size: 10px; letter-spacing: .8px; text-transform: uppercase;
    color: var(--soft);
  }
  .tar-block.dark .tar-card-tag { color: rgba(255,255,255,.45); }
  .tar-card.feat .tar-card-tag { color: var(--g); }
  .tar-block.dark .tar-card.feat .tar-card-tag { color: var(--g-mid); }
  .tar-card-price {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 68px;
    line-height: 1;
    letter-spacing: -0.035em;
    color: var(--ink);
    display: flex; align-items: baseline; gap: 4px;
  }
  .tar-block.dark .tar-card-price { color: #fff; }
  .tar-card-price .cents {
    font-size: 38px;
    letter-spacing: -0.02em;
  }
  .tar-card-price .cur {
    font-size: 32px;
    color: var(--g);
    margin-left: 4px;
  }
  .tar-block.dark .tar-card-price .cur { color: var(--g-mid); }
  .tar-card-period {
    font-size: 12px;
    color: var(--soft);
    margin-top: 10px;
    font-family: ui-monospace, monospace;
    letter-spacing: 0.2px;
    text-transform: uppercase;
  }
  .tar-block.dark .tar-card-period { color: rgba(255,255,255,.5); }
  .tar-card-alt {
    margin-top: auto;
    padding-top: 20px;
    border-top: 1px dashed var(--line);
    display: flex; justify-content: space-between; align-items: baseline;
    font-size: 13px;
  }
  .tar-block.dark .tar-card-alt { border-color: rgba(255,255,255,.12); }
  .tar-card-alt-lab { color: var(--soft); }
  .tar-block.dark .tar-card-alt-lab { color: rgba(255,255,255,.55); }
  .tar-card-alt-val {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 22px;
    letter-spacing: -0.01em;
  }
  .tar-card-alt-val small { font-size: 12px; color: var(--g); margin-left: 2px; font-family: 'Fraunces', serif; }
  .tar-block.dark .tar-card-alt-val small { color: var(--g-mid); }

  /* --------- SALAS BLOCK (custom rows, light) --------- */
  .tar-salas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--line);
    border: 1px solid var(--line);
    border-radius: 18px;
    overflow: hidden;
  }
  .tar-sala {
    background: #fff;
    padding: 32px 28px;
    display: flex; flex-direction: column;
  }
  .tar-block.alt .tar-sala { background: #fff; }
  .tar-sala-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
  .tar-sala-name {
    font-family: 'Fraunces', serif;
    font-size: 24px; font-weight: 500;
    letter-spacing: -0.012em;
    color: var(--ink);
  }
  .tar-sala-cap {
    font-family: ui-monospace, monospace;
    font-size: 11px; color: var(--soft);
    letter-spacing: .3px;
  }
  .tar-sala-hour {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 56px; line-height: 1;
    color: var(--ink);
    margin: 22px 0 6px;
    display: flex; align-items: baseline; gap: 4px;
    letter-spacing: -0.03em;
  }
  .tar-sala-hour .cur { font-size: 28px; color: var(--g); margin-left: 4px; }
  .tar-sala-hour-lab {
    font-family: ui-monospace, monospace;
    font-size: 11px; letter-spacing: 0.4px;
    color: var(--soft);
    text-transform: uppercase;
    margin-bottom: 24px;
  }
  .tar-sala-rows {
    margin-top: auto;
    border-top: 1px solid var(--line);
    padding-top: 16px;
  }
  .tar-sala-row {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: baseline;
    padding: 8px 0;
    font-size: 13.5px;
    border-bottom: 1px dashed var(--line);
  }
  .tar-sala-row:last-child { border-bottom: none; }
  .tar-sala-row .lab { color: var(--soft); }
  .tar-sala-row .val { font-family: 'Fraunces', serif; font-weight: 500; font-size: 18px; color: var(--ink); letter-spacing: -0.01em; }
  .tar-sala-row .val small { color: var(--g); font-size: 12px; margin-left: 1px; }

  /* --------- DESPACHOS BLOCK --------- */
  .tar-desp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }
  .tar-desp {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 32px 28px;
    position: relative;
    overflow: hidden;
  }
  .tar-desp.feat {
    background: var(--g);
    border-color: var(--g);
    color: #fff;
  }
  .tar-desp-num {
    font-family: ui-monospace, monospace;
    font-size: 11px; letter-spacing: .5px;
    color: var(--faint);
    margin-bottom: 16px;
  }
  .tar-desp.feat .tar-desp-num { color: rgba(255,255,255,.65); }
  .tar-desp-name {
    font-family: 'Fraunces', serif;
    font-size: 22px; font-weight: 500;
    letter-spacing: -0.012em;
    margin-bottom: 6px;
  }
  .tar-desp-cap {
    font-size: 12.5px; color: var(--soft);
    margin-bottom: 28px;
  }
  .tar-desp.feat .tar-desp-cap { color: rgba(255,255,255,.7); }
  .tar-desp-price {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 84px;
    line-height: 0.95;
    letter-spacing: -0.04em;
    display: flex; align-items: baseline; gap: 4px;
  }
  .tar-desp-price .from {
    font-family: 'Inter', sans-serif;
    font-size: 12px; font-weight: 500;
    color: var(--soft);
    letter-spacing: .8px; text-transform: uppercase;
    align-self: flex-start; margin-top: 6px;
    margin-right: 10px;
  }
  .tar-desp.feat .tar-desp-price .from { color: rgba(255,255,255,.7); }
  .tar-desp-price .cur { font-size: 32px; color: var(--g); margin-left: 4px; }
  .tar-desp.feat .tar-desp-price .cur { color: var(--g-light); }
  .tar-desp-period {
    font-size: 12px;
    color: var(--soft);
    margin-top: 12px;
    font-family: ui-monospace, monospace;
    letter-spacing: 0.2px;
    text-transform: uppercase;
  }
  .tar-desp.feat .tar-desp-period { color: rgba(255,255,255,.65); }
  .tar-desp-foot {
    margin-top: 28px;
    padding-top: 18px;
    border-top: 1px solid var(--line);
    font-size: 12.5px;
    color: var(--soft);
    display: flex; gap: 8px; align-items: center;
  }
  .tar-desp.feat .tar-desp-foot { border-color: rgba(255,255,255,.18); color: rgba(255,255,255,.75); }
  .tar-desp-foot::before {
    content: '★';
    color: var(--g-mid);
    font-size: 11px;
  }
  .tar-desp.feat .tar-desp-foot::before { color: var(--g-light); }

  /* --------- BONOS (light) --------- */
  .tar-bonos {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 18px;
    padding: 28px 32px;
  }
  .tar-bonos-head {
    display: grid;
    grid-template-columns: 1fr 110px 110px;
    gap: 24px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--line);
    font-family: ui-monospace, monospace;
    font-size: 11px;
    letter-spacing: .5px;
    text-transform: uppercase;
    color: var(--soft);
  }
  .tar-bonos-head .h-right { text-align: right; }
  .tar-bonos-row {
    display: grid;
    grid-template-columns: 1fr 110px 110px;
    gap: 24px;
    align-items: center;
    padding: 18px 0;
    border-bottom: 1px dashed var(--line);
  }
  .tar-bonos-row:last-child { border-bottom: none; }
  .tar-bonos-name {
    font-family: 'Fraunces', serif;
    font-size: 19px; font-weight: 500;
    color: var(--ink);
    letter-spacing: -0.01em;
  }
  .tar-bonos-name small {
    display: block;
    font-family: 'Inter', sans-serif;
    font-size: 12px;
    color: var(--soft);
    font-weight: 400;
    margin-top: 3px;
  }
  .tar-bonos-price {
    font-family: 'Fraunces', serif;
    font-size: 28px; font-weight: 500;
    color: var(--ink);
    text-align: right;
    letter-spacing: -0.02em;
  }
  .tar-bonos-price .cur { color: var(--g); font-size: 16px; margin-left: 2px; }

  /* --------- ANNUAL TOGGLE BANNER (OficinaV) --------- */
  .tar-anual-note {
    display: inline-flex; align-items: center; gap: 12px;
    background: var(--g-light); color: var(--g-dark);
    padding: 8px 14px; border-radius: 999px;
    font-size: 12px; font-weight: 500;
    margin-bottom: 28px;
  }
  .tar-anual-note::before {
    content: '%'; width: 22px; height: 22px;
    background: var(--g); color: #fff;
    border-radius: 50%;
    font-size: 11px; font-weight: 600;
    display: flex; align-items: center; justify-content: center;
  }

  /* --------- PREMIUM BLOCK --------- */
  .tar-prem-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .tar-prem {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 14px;
    padding: 24px 22px;
    display: flex; flex-direction: column;
    gap: 14px;
  }
  .tar-prem-num {
    font-family: ui-monospace, monospace;
    font-size: 11px; color: var(--faint);
    letter-spacing: .3px;
  }
  .tar-prem-name {
    font-family: 'Fraunces', serif;
    font-weight: 500; font-size: 18px;
    letter-spacing: -0.01em;
    color: var(--ink);
  }
  .tar-prem-price {
    font-family: 'Fraunces', serif;
    font-size: 14px;
    color: var(--g);
    font-style: italic;
    margin-top: auto;
  }

  /* --------- LEYENDA / NOTA FINAL (oscuro) --------- */
  .tar-legal {
    background: var(--ink);
    color: #fff;
    padding: 72px 0 88px;
    border-top: 1px solid var(--line);
  }
  .tar-legal-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    max-width: 920px;
    margin: 0 auto;
  }
  .tar-legal h3 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: 22px;
    margin: 0 0 14px;
    letter-spacing: -0.012em;
    color: #fff;
  }
  .tar-legal h3 em { font-style: italic; color: var(--g-mid); }
  .tar-legal p {
    font-size: 14px;
    color: rgba(255,255,255,.6);
    line-height: 1.6;
  }

  /* --------- CTA --------- */
  .tar-cta {
    background: #fff;
    color: var(--ink);
    padding: 88px 0 96px;
    text-align: center;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .tar-cta h2 {
    font-family: 'Fraunces', serif;
    font-weight: 500;
    font-size: clamp(36px, 4.5vw, 60px);
    line-height: 1;
    letter-spacing: -0.025em;
    margin-bottom: 18px;
  }
  .tar-cta h2 em { font-style: italic; color: var(--g); font-weight: 400; }
  .tar-cta p {
    color: var(--soft);
    margin-bottom: 28px;
    font-size: 15px;
    max-width: 540px;
    margin-left: auto; margin-right: auto;
  }
  .tar-cta .btns { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
  .tar-cta .btn-outline { border: 1px solid var(--line-strong); color: var(--ink); padding: 12px 22px; border-radius: 999px; font-size: 14px; font-weight: 500; background: transparent; }
  .tar-cta .btn-outline:hover { background: rgba(0,0,0,.04); }

  @media (max-width: 900px) {
    .tar-head { grid-template-columns: 1fr; }
    .tar-head-meta { justify-self: start; text-align: left; }
    .tar-grid-3, .tar-desp-grid, .tar-salas-grid, .tar-prem-grid { grid-template-columns: 1fr; }
    .tar-legal-grid { grid-template-columns: 1fr; }
    .tar-bonos-head, .tar-bonos-row { grid-template-columns: 1fr 80px 80px; gap: 12px; }
    .tar-bonos-price { font-size: 20px; }
    .tar-card-price, .tar-desp-price { font-size: 56px; }
    .tar-anchors { position: static; }
  }


/* ---------- LEGAL PAGES CSS ---------- */
/* ============ LEGAL PAGES SHARED STYLES ============ */

.legal-hero {
  padding: 80px 0 48px;
  background:
    radial-gradient(ellipse 60% 50% at 92% 0%, rgba(91,147,32,.08), transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--cream) 100%);
  border-bottom: 1px solid var(--line);
}
.legal-hero h1 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: clamp(44px, 5.4vw, 72px);
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin: 18px 0 22px;
  max-width: 820px;
  text-wrap: balance;
}
.legal-hero h1 em { font-style: italic; font-weight: 400; color: var(--g); }
.legal-hero .lede {
  font-size: 16px;
  color: var(--soft);
  line-height: 1.6;
  max-width: 640px;
}
.legal-hero-meta {
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px solid var(--line);
  display: flex; flex-wrap: wrap; gap: 28px;
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--faint);
}
.legal-hero-meta strong { color: var(--ink); font-weight: 500; }

/* ---------- LAYOUT ---------- */
.legal-body {
  padding: 64px 0 96px;
}
.legal-grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 80px;
  align-items: start;
}
.legal-toc {
  position: sticky;
  top: 96px;
}
.legal-toc-lab {
  font-family: ui-monospace, monospace;
  font-size: 10px; letter-spacing: .8px;
  text-transform: uppercase;
  color: var(--faint);
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.legal-toc ol {
  list-style: none;
  counter-reset: toc;
  padding: 0; margin: 0;
}
.legal-toc li {
  counter-increment: toc;
  margin-bottom: 4px;
}
.legal-toc a {
  display: flex; gap: 12px;
  font-size: 13px;
  color: var(--soft);
  padding: 6px 0;
  line-height: 1.35;
  transition: color .15s;
}
.legal-toc a::before {
  content: counter(toc, decimal-leading-zero);
  font-family: ui-monospace, monospace;
  font-size: 11px;
  color: var(--faint);
  flex-shrink: 0;
  padding-top: 1px;
}
.legal-toc a:hover { color: var(--g-dark); }
.legal-toc a.is-active { color: var(--g); font-weight: 500; }
.legal-toc a.is-active::before { color: var(--g); }

/* ---------- CONTENT ---------- */
.legal-content {
  max-width: 720px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--ink);
}
.legal-content section {
  padding-top: 8px;
  margin-bottom: 56px;
}
.legal-content section:last-child { margin-bottom: 0; }
.legal-content h2 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: 32px;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 20px;
  text-wrap: balance;
}
.legal-content h2 em { font-style: italic; color: var(--g); font-weight: 400; }
.legal-content h2 .num {
  display: block;
  font-family: ui-monospace, monospace;
  font-size: 12px;
  font-style: normal;
  color: var(--g);
  letter-spacing: 0.3px;
  text-transform: uppercase;
  margin-bottom: 10px;
  font-weight: 400;
}
.legal-content h3 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: 19px;
  letter-spacing: -0.012em;
  margin: 32px 0 10px;
}
.legal-content p {
  margin: 0 0 16px;
  color: var(--ink);
}
.legal-content p strong { font-weight: 500; }
.legal-content a { color: var(--g); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.legal-content a:hover { color: var(--g-dark); }
.legal-content ul {
  list-style: none;
  padding: 0; margin: 0 0 16px;
}
.legal-content ul li {
  position: relative;
  padding: 4px 0 4px 22px;
  line-height: 1.6;
}
.legal-content ul li::before {
  content: '';
  position: absolute;
  left: 0; top: 14px;
  width: 12px; height: 1px;
  background: var(--g-mid);
}

/* ---------- INFO CARD (data box) ---------- */
.legal-card {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  margin: 8px 0 20px;
  font-size: 14px;
  line-height: 1.7;
}
.legal-card-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  padding: 6px 0;
  border-bottom: 1px dashed var(--line);
}
.legal-card-row:last-child { border-bottom: none; }
.legal-card-row dt {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .3px;
  text-transform: uppercase;
  color: var(--soft);
  padding-top: 4px;
}
.legal-card-row dd {
  margin: 0;
  font-weight: 500;
  color: var(--ink);
}

/* ---------- TABLA COOKIES ---------- */
.cookie-table {
  width: 100%;
  border-collapse: collapse;
  margin: 12px 0 24px;
  border: 1px solid var(--line);
  border-radius: 12px;
  overflow: hidden;
  font-size: 13px;
}
.cookie-table th {
  text-align: left;
  background: var(--cream);
  font-family: ui-monospace, monospace;
  font-size: 10.5px; letter-spacing: .5px;
  text-transform: uppercase;
  color: var(--soft);
  font-weight: 500;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
}
.cookie-table td {
  padding: 14px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
  line-height: 1.5;
}
.cookie-table tr:last-child td { border-bottom: none; }
.cookie-table .ck-name {
  font-family: ui-monospace, monospace;
  font-size: 12.5px;
  color: var(--g-dark);
  font-weight: 500;
}
.cookie-table .ck-cat {
  display: inline-block;
  font-family: ui-monospace, monospace;
  font-size: 10px; letter-spacing: .5px;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 999px;
  background: var(--g-light);
  color: var(--g-dark);
}
.cookie-table .ck-cat.third { background: var(--cream-2); color: var(--soft); }

/* ---------- PILLS CATEGORÍA ---------- */
.legal-pill {
  display: inline-block;
  font-family: ui-monospace, monospace;
  font-size: 10.5px; letter-spacing: .5px;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--g-light);
  color: var(--g-dark);
  font-weight: 500;
}

/* ---------- COOKIE PREFS BANNER (in-page) ---------- */
.cookie-prefs {
  background: var(--ink);
  color: #fff;
  border-radius: 16px;
  padding: 28px 32px;
  margin: 12px 0 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 24px;
}
.cookie-prefs h3 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-size: 22px;
  margin: 0 0 6px;
  color: #fff;
  letter-spacing: -0.012em;
}
.cookie-prefs p {
  margin: 0;
  color: rgba(255,255,255,.6);
  font-size: 13.5px;
}
.cookie-prefs .actions { display: flex; gap: 10px; flex-wrap: wrap; }
.cookie-prefs .btn-cp {
  font-size: 13px; font-weight: 500;
  padding: 10px 18px;
  border-radius: 999px;
  cursor: pointer;
  transition: all .15s;
}
.cookie-prefs .btn-cp.primary { background: var(--g-mid); color: #fff; border: none; }
.cookie-prefs .btn-cp.primary:hover { background: var(--g); }
.cookie-prefs .btn-cp.ghost { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,.25); }
.cookie-prefs .btn-cp.ghost:hover { background: rgba(255,255,255,.06); }

/* ---------- LAST UPDATED FOOT ---------- */
.legal-foot {
  margin-top: 64px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
}
.legal-foot-meta {
  font-family: ui-monospace, monospace;
  font-size: 11px; letter-spacing: .4px;
  text-transform: uppercase;
  color: var(--faint);
}
.legal-foot-links {
  display: flex; gap: 18px;
}
.legal-foot-links a {
  font-size: 13px; color: var(--soft);
}
.legal-foot-links a:hover { color: var(--g); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px) {
  .legal-grid { grid-template-columns: 1fr; gap: 40px; }
  .legal-toc { position: static; }
  .legal-toc ol {
    display: flex; flex-wrap: wrap; gap: 6px;
  }
  .legal-toc li { margin: 0; }
  .legal-toc a {
    background: var(--cream);
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
  }
  .legal-card-row { grid-template-columns: 1fr; gap: 2px; }
  .cookie-prefs { grid-template-columns: 1fr; }
}


/* FORCE HIDE GHOST OLD FOOTER FROM PROD THEME */
.bc-global-footer {
    display: none !important;
}

.space-card-photo img { width: 100%; height: 100%; object-fit: cover; display: block; position: absolute; top:0; left:0; border-radius: 14px 14px 0 0; }

.space-card-cta, .space-card-cta:visited, .space-card-cta:active { color: #ffffff !important; }

.format-card-photo { background-size: cover !important; background-position: center !important; background-repeat: no-repeat !important; }

.svc-arrow {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--cream-2);
  display: flex; align-items: center; justify-content: center;
  position: absolute; top: 28px; right: 28px;
  color: var(--ink);
  transition: background .2s, color .2s;
  z-index: 3;
}
.svc-card:hover .svc-arrow { background: var(--line-strong); }
.svc-card.featured { border-color: var(--g); }
.svc-card.featured .svc-arrow { background: var(--g); color: #fff; }
.svc-card.featured:hover .svc-arrow { background: var(--g-mid); }
.svc-tag { color: var(--g) !important; font-weight: 500; font-family: 'Inter', sans-serif; }
.svc-link { color: var(--g) !important; font-weight: 500; }
.eyebrow { color: var(--g) !important; font-weight: 500; }
.section-title em { color: var(--g); font-style: italic; }
