/* ============================================================
   Parcelas de Chile — main.css v2.0
   ============================================================ */

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

:root {
  --orange:      #d47c2e;
  --orange-btn:  #c97b30;
  --orange-dark: #b56a20;
  --text-dark:   #2d2d2d;
  --text-gray:   #6b6b6b;
  --bg-white:    #ffffff;
  --bg-card:     #f2f2f2;
  --chile-blue:  #1a3f8c;
  --chile-red:   #c0392b;
  --chile-green: #2e7d32;
  --serif:       'Playfair Display', Georgia, serif;
  --sans:        'DM Sans', sans-serif;
  --btn-color:      #c97b30;
  --btn-hover:      #b56a20;
  --btn-text-color: #ffffff;
  --btn-radius:     50px;
  --accent-color:   #d47c2e;
  --navbar-bg:      rgba(255,255,255,0.97);
  --navbar-link:    #2d2d2d;
  --navbar-radius:  14px;
}


html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  color: var(--text-dark);
  background: var(--bg-white);
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
.img-placeholder { width: 100%; height: 100%; }

/* ─── NAVBAR ─── */
.site-header { position: relative; }

/* Logo imagen real */
.logo-img-wrap {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}
.logo-img {
  height: 56px;
  width: auto;
  display: block;
  object-fit: contain;
  /* Los iconos son PNG sobre fondo negro — invertimos para que se vean bien en navbar blanco */
}

/* Logo blanco en footer */
.footer-logo-img-wrap {
  display: flex;
  align-items: center;
  text-decoration: none;
}
.footer-logo-img {
  height: 56px;
  width: auto;
  display: block;
  object-fit: contain;
}

.navbar {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 80px);
  max-width: 1400px;
  background: var(--navbar-bg);
  border-radius: var(--navbar-radius);
  padding: 18px 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  z-index: 100;
  box-shadow: 0 2px 20px rgba(0,0,0,0.08);
  transition: box-shadow .3s;
}

.logo {
  display: flex; flex-direction: column; gap: 4px;
  text-decoration: none;
}
.logo-text {
  font-family: var(--sans); font-weight: 700; font-size: 18px;
  letter-spacing: .05em; color: var(--text-dark);
  text-decoration: underline; text-decoration-color: var(--text-dark);
  text-underline-offset: 3px;
}
.logo-stripe { display: flex; height: 3px; width: 100%; gap: 2px; }
.logo-stripe span { flex: 1; border-radius: 2px; }
.logo-stripe .s1 { background: var(--chile-blue); }
.logo-stripe .s2 { background: var(--chile-red); }
.logo-stripe .s3 { background: var(--bg-white); border: 1px solid #ddd; }
.logo-stripe .s4 { background: var(--chile-green); }
.logo-sub { font-family: var(--sans); font-size: 10px; letter-spacing: .15em; color: var(--text-gray); text-align: center; }

.nav-links, .navbar .menu { display: flex; gap: var(--navbar-menu-gap, 44px); list-style: none; margin: 0; padding: 0; }
.nav-links a, .navbar .menu a {
  font-family: var(--sans); font-size: var(--navbar-menu-size, 20px); font-weight: 500;
  color: var(--navbar-link); text-decoration: none; transition: color .2s;
}
.nav-links a:hover, .navbar .menu a:hover { color: var(--btn-color); }

.nav-toggle {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.nav-toggle span { display: block; width: 26px; height: 2px; background: var(--text-dark); border-radius: 2px; transition: all .3s; }
.nav-toggle.is-open span:nth-child(1) { transform: rotate(45deg) translate(5px,5px); }
.nav-toggle.is-open span:nth-child(2) { opacity: 0; }
.nav-toggle.is-open span:nth-child(3) { transform: rotate(-45deg) translate(5px,-5px); }

/* ─── HERO ─── */
.hero {
  position: relative; width: 100%;
  height: 85vh; min-height: 560px;
  overflow: hidden; background: #5a7a8b;
}
.hero-video {
  position: absolute; top:0; left:0;
  width:100%; height:100%;
  object-fit: cover; object-position: center;
  z-index: 0;
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,.30) 40%, rgba(0,0,0,0) 80%);
  z-index: 1;
}
.hero-content {
  position: absolute;
  bottom: 80px; left: 80px;
  color: #fff; max-width: 640px; z-index: 2;
}
.hero-sub   { font-family: var(--sans); font-size: 22px; font-weight: 300; opacity: .92; margin-bottom: 4px; }
.hero-mid   { font-family: var(--sans); font-size: 44px; font-weight: 600; line-height: 1.1; }
.hero-big   { font-family: var(--serif); font-size: 92px; font-weight: 900; font-style: italic; line-height: .9; letter-spacing: -.02em; text-transform: uppercase; margin-bottom: 18px; display: block; }
.hero-price { font-family: var(--sans); font-size: 20px; font-weight: 600; opacity: .9; margin-bottom: 28px; }
.btn-hero   { font-size: 16px !important; padding: 16px 48px !important; }

/* ─── BTN NARANJA ─── */
.btn-orange {
  display: inline-block;
  background: var(--btn-color);
  color: var(--btn-text-color);
  font-family: var(--sans); font-size: 15px; font-weight: 600;
  padding: 15px 40px;
  border-radius: var(--btn-radius);
  text-decoration: none; border: none; cursor: pointer;
  transition: background .2s, transform .15s;
  white-space: nowrap; line-height: 1;
}
.btn-orange:hover { background: var(--btn-hover); color: var(--btn-text-color); transform: translateY(-1px); text-decoration: none; }

/* ─── FRANJA CHILE ─── */
.chile-stripe { display: none !important; } /* eliminada v2.5.63 */
.chile-stripe span { flex: 1; }
.chile-stripe .cs1 { background: var(--chile-blue); }
.chile-stripe .cs2 { background: var(--chile-red); }
.chile-stripe .cs3 { background: var(--bg-white); border-top: 1px solid #e8e8e8; }
.chile-stripe .cs4 { background: var(--chile-green); }

/* ─── MISSION ─── */
.mission { padding: 80px 80px 60px; background: var(--bg-white); text-align: center; }
.mission-tagline { font-family: var(--sans); font-size: 26px; font-weight: 400; color: var(--text-gray); line-height: 1.5; margin-bottom: 12px; }
.mission-tagline .highlight { font-family: var(--serif); font-style: italic; color: var(--accent-color); font-size: 30px; font-weight: 700; }
.mission-parcela-title { font-family: var(--sans); font-size: 38px; font-weight: 400; color: var(--text-dark); margin-top: 48px; }
.mission-parcela-title strong { font-family: var(--serif); font-style: italic; font-weight: 900; }

/* ─── PARCELA ─── */
.parcela-section { padding: 10px 80px 60px; }
.parcela-img-wrap { position: relative; border-radius: 20px; overflow: hidden; width: 100%; height: 420px; }
.parcela-img-wrap img, .parcela-img-wrap .img-placeholder { width: 100%; height: 100%; object-fit: cover; }
.parcela-overlay-text { position: absolute; bottom: 30px; right: 40px; color: #fff; text-align: right; }
.parcela-overlay-text .m2   { font-family: var(--sans); font-size: 18px; font-weight: 400; opacity: .9; }
.parcela-overlay-text .solo { font-family: var(--serif); font-size: 36px; font-style: italic; font-weight: 700; text-shadow: 0 2px 8px rgba(0,0,0,.4); }

/* ─── FEATURES ─── */
.features-section { padding: 30px 80px 20px; }
.features-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 24px; align-items: start; }
.feat-card { position: relative; border-radius: 18px; overflow: hidden; }
.feat-card img { width: 100%; height: 360px; object-fit: cover; display: block; }
.feat-text { position: absolute; bottom: 28px; left: 28px; color: #fff; }
.feat-text .label { font-family: var(--sans); font-size: 16px; font-weight: 400; opacity: .9; }
.feat-text .big   { font-family: var(--serif); font-size: 36px; font-weight: 700; line-height: 1.1; text-shadow: 0 2px 6px rgba(0,0,0,.3); }
.feat-overlay-right { position: absolute; bottom: 28px; right: 28px; color: #fff; text-align: right; }
.feat-overlay-right .label { font-family: var(--sans); font-size: 16px; font-weight: 400; opacity: .9; }
.feat-overlay-right .big   { font-family: var(--serif); font-size: 36px; font-weight: 700; text-shadow: 0 2px 6px rgba(0,0,0,.3); }
.feat-cta { margin-top: 22px; text-align: center; display: flex; justify-content: center; }

/* ─── INCLUYE ─── */
.incluye-section { padding: 60px 80px; }
.incluye-section h2 { font-family: var(--serif); font-style: italic; font-size: 52px; font-weight: 900; margin-bottom: 36px; color: var(--text-dark); }
.incluye-grid { display: grid; grid-template-columns: repeat(5,1fr); gap: 16px; }
.incluye-grid .inc-img { position: relative; border-radius: 16px; overflow: hidden; aspect-ratio: 3/4; min-height: 260px; background: #111; }
.incluye-grid .inc-img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform .4s; display: block; opacity: 1; visibility: visible; }
.incluye-grid .inc-img.has-text::after { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,.34); opacity: 0; z-index: 1; pointer-events: none; transition: opacity .28s ease; }
.incluye-grid .inc-img:hover img, .incluye-grid .inc-img:focus img, .incluye-grid .inc-img.is-active img, .incluye-grid .inc-img.is-auto-active img { transform: scale(1.04); }
.incluye-grid .inc-overlay { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: #fff; padding: 24px; line-height: 1.08; text-shadow: 0 2px 8px rgba(0,0,0,.35); pointer-events: none; opacity: 0; transform: translateY(12px); transition: opacity .28s ease, transform .28s ease; }
.incluye-grid .inc-overlay-title { font-family: var(--serif); font-size: clamp(24px, 1.85vw, 38px); font-weight: 900; letter-spacing: .01em; }
.incluye-grid .inc-overlay-body { font-family: var(--sans); font-size: clamp(21px, 1.55vw, 31px); font-weight: 400; letter-spacing: .02em; margin-top: 2px; }
.incluye-grid .inc-img-5 .inc-overlay-body { font-size: clamp(19px, 1.35vw, 28px); }
.incluye-grid .inc-img.has-text:hover::after,
.incluye-grid .inc-img.has-text:focus::after,
.incluye-grid .inc-img.has-text:focus-within::after,
.incluye-grid .inc-img.has-text.is-active::after,
.incluye-grid .inc-img.has-text.is-auto-active::after { opacity: 1; }
.incluye-grid .inc-img.has-text:hover .inc-overlay,
.incluye-grid .inc-img.has-text:focus .inc-overlay,
.incluye-grid .inc-img.has-text:focus-within .inc-overlay,
.incluye-grid .inc-img.has-text.is-active .inc-overlay,
.incluye-grid .inc-img.has-text.is-auto-active .inc-overlay { opacity: 1; transform: translateY(0); }
.incluye-grid .inc-img.has-text:focus { outline: 2px solid rgba(201,123,48,.75); outline-offset: 4px; }


/* ─── SEGURIDAD ─── */
.seguridad-section { padding: 70px 80px 60px; }
.seguridad-section > h2 { font-family: var(--sans); font-size: 52px; font-weight: 300; margin-bottom: 48px; }
.seguridad-section > h2 strong { font-family: var(--serif); font-style: italic; font-weight: 900; }
.seguridad-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 48px; }
.seg-card { background: var(--bg-card); border-radius: 16px; padding: 36px 36px 28px; }
.seg-card h3 { font-family: var(--sans); font-size: 22px; font-weight: 400; color: #888; margin-bottom: 18px; line-height: 1.35; }
.seg-card h3 em { font-family: var(--serif); font-style: italic; color: #888; }
.seg-card p   { font-family: var(--sans); font-size: 14px; line-height: 1.7; color: #888; margin-bottom: 24px; }
.seg-card p strong { color: #666; }
.seg-stripe { display: flex; height: 3px; gap: 3px; width: 60%; }
.seg-stripe span { flex: 1; border-radius: 2px; }
.seg-stripe .ss1 { background: var(--chile-blue); }
.seg-stripe .ss2 { background: var(--chile-red); }
.seg-stripe .ss3 { background: #e0e0e0; }
.seg-stripe .ss4 { background: var(--chile-green); }
.seguridad-btns { display: flex; justify-content: center; gap: 40px; flex-wrap: wrap; }

/* ─── PASOS ─── */
.pasos-section { padding: 70px 80px; }
.pasos-section > h2 { font-family: var(--sans); font-size: 52px; font-weight: 300; margin-bottom: 60px; }
.pasos-section > h2 strong { font-family: var(--serif); font-style: italic; font-weight: 900; }
.pasos-numbers { display: grid; grid-template-columns: repeat(5,1fr); margin-bottom: 8px; }
.paso-num { text-align: center; font-family: var(--serif); font-style: italic; font-size: 52px; font-weight: 400; color: #d8d8d8; line-height: 1; }
.pasos-labels { display: grid; grid-template-columns: repeat(5,1fr); margin-bottom: 20px; }
.paso-label { text-align: center; font-family: var(--serif); font-style: italic; font-size: 18px; color: #c0c0c0; line-height: 1.2; padding: 0 10px; }
.pasos-timeline { position: relative; height: 20px; display: flex; align-items: center; margin-bottom: 28px; }
.timeline-line { position: absolute; left: 10%; right: 10%; height: 2px; background: var(--btn-color); border-radius: 2px; }
.pasos-dots { position: absolute; left: 0; right: 0; display: grid; grid-template-columns: repeat(5,1fr); }
.paso-dot-col { display: flex; justify-content: center; }
.paso-dot { width: 14px; height: 14px; background: var(--btn-color); border-radius: 50%; z-index: 2; }
.pasos-texts { display: grid; grid-template-columns: repeat(5,1fr); }
.paso-text { padding: 0 16px 0 0; font-family: var(--sans); font-size: 13px; line-height: 1.65; color: var(--text-dark); }
.paso-text strong { font-weight: 600; }

/* ─── CTA HERO FINAL ─── */
.cta-hero { position: relative; width: 100%; height: 80vh; min-height: 520px; overflow: hidden; background: #2a3a22; }
.cta-hero-video { position: absolute; top:0; left:0; width:100%; height:100%; object-fit: cover; z-index: 0; }
.cta-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom,rgba(0,0,0,0) 10%,rgba(0,0,0,.70) 100%); z-index: 1; }
.cta-hero-content { position: absolute; bottom:0; left:0; right:0; padding: 60px 80px 70px; color: #fff; z-index: 2; }
.cta-eyebrow { font-family: var(--sans); font-size: 22px; font-weight: 400; opacity: .9; margin-bottom: 4px; }
.cta-big     { font-family: var(--serif); font-style: italic; font-size: 72px; font-weight: 900; line-height: 1; margin-bottom: 20px; letter-spacing: -.01em; }
.cta-sub     { font-family: var(--sans); font-size: 16px; opacity: .85; max-width: 440px; line-height: 1.5; margin-bottom: 32px; }

/* ─── FOOTER ─── */
.site-footer { background: #1a1a1a; padding: 60px 80px 40px; color: #fff; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 40px; }
.footer-logo { display: flex; flex-direction: column; gap: 4px; text-decoration: none; }
.footer-logo .logo-text { color: #fff; text-decoration-color: #fff; }
.footer-logo .logo-sub  { color: #aaa; }
.footer-social { display: flex; flex-direction: column; align-items: center; gap: 20px; }
.footer-icons  { display: flex; gap: 20px; }
.footer-icons a {
  display: flex; align-items: center; justify-content: center;
  width: var(--footer-icon-size, 52px);
  height: var(--footer-icon-size, 52px);
  border-radius: 0;
  text-decoration: none;
  transition: transform .2s, opacity .2s;
  overflow: visible;
}
.footer-icons a img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  transition: transform .2s;
}
.footer-icons a:hover { transform: scale(1.1); opacity: .88; }
.footer-links { font-family: var(--sans); font-size: 13px; color: #aaa; text-align: center; }
.footer-links a { color: #aaa; text-decoration: none; transition: color .2s; }
.footer-links a:hover { color: #fff; }
.footer-wa a {
  display: flex; align-items: center; justify-content: center;
  width: var(--footer-wa-size, 64px);
  height: var(--footer-wa-size, 64px);
  border-radius: 0;
  text-decoration: none;
  transition: transform .2s, opacity .2s;
  overflow: visible;
}
.footer-wa a img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}
.footer-wa a:hover { transform: scale(1.1); opacity: .88; }


.logo-img-wrap--empty,
.footer-logo-img-wrap--empty,
.footer-wa--empty { min-width: 1px; min-height: 1px; }
.footer-icons:empty { display: none; }

/* ─── ADMIN BAR ─── */
#wpadminbar { position: fixed !important; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .navbar { width: calc(100% - 40px); padding: 16px 24px; }
  .nav-links, .navbar .menu { gap: 28px; }
  .hero-content { left: 40px; bottom: 60px; }
  .hero-mid { font-size: 34px; }
  .hero-big { font-size: 72px; }
  .mission, .parcela-section, .features-section,
  .incluye-section, .seguridad-section, .pasos-section { padding-left: 40px !important; padding-right: 40px !important; }
  .cta-hero-content { padding: 40px 40px 50px !important; }
  .cta-big { font-size: 54px !important; }
  .site-footer { padding: 50px 40px !important; }
}

@media (max-width: 768px) {
  .nav-links, .navbar .menu {
    display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: #fff; flex-direction: column;
    padding: 20px 24px; border-radius: 0 0 14px 14px;
    box-shadow: 0 8px 20px rgba(0,0,0,.1); gap: 16px;
  }
  .nav-links.open, .navbar .menu.open { display: flex; }
  .nav-toggle { display: flex; }

  .hero-content { left: 24px !important; right: 24px; bottom: 40px !important; max-width: 100%; }
  .hero-sub  { font-size: 16px !important; }
  .hero-mid  { font-size: 26px !important; }
  .hero-big  { font-size: 52px !important; }
  .hero-price{ font-size: 15px !important; }

  .mission { padding: 50px 24px 36px !important; }
  .mission-tagline { font-size: 20px !important; }
  .mission-tagline .highlight { font-size: 24px !important; }
  .mission-parcela-title { font-size: 28px !important; }

  .parcela-section { padding: 10px 24px 40px !important; }
  .parcela-img-wrap { height: 260px !important; }

  .features-section { padding: 20px 24px !important; }
  .features-grid { grid-template-columns: 1fr; }
  .feat-card img { height: 260px !important; }

  .incluye-section { padding: 40px 24px !important; }
  .incluye-section h2 { font-size: 36px !important; }
  .incluye-grid { grid-template-columns: repeat(2,1fr); gap: 12px; }
  .incluye-grid .inc-img:last-child { grid-column: span 2; aspect-ratio: 16/9; }
  .incluye-grid .inc-overlay { padding: 16px; }
  .incluye-grid .inc-overlay-title { font-size: 24px; }
  .incluye-grid .inc-overlay-body { font-size: 20px; }
  .incluye-grid .inc-img-5 .inc-overlay-body { font-size: 18px; }

  .seguridad-section { padding: 50px 24px 40px !important; }
  .seguridad-section > h2 { font-size: 36px !important; }
  .seguridad-grid { grid-template-columns: 1fr; }

  .pasos-section { padding: 50px 24px !important; }
  .pasos-section > h2 { font-size: 36px !important; }
  .pasos-numbers, .pasos-labels, .pasos-texts { grid-template-columns: 1fr; }
  .pasos-timeline { display: none; }
  .pasos-texts { gap: 24px; margin-top: 16px; }
  .paso-num, .paso-label { text-align: left; padding-left: 0; }

  .cta-hero-content { padding: 30px 24px 40px !important; }
  .cta-eyebrow { font-size: 16px !important; }
  .cta-big { font-size: 38px !important; }
  .cta-sub { font-size: 14px !important; max-width: 100%; }

  .site-footer { grid-template-columns: 1fr; text-align: center; padding: 40px 24px !important; }
  .footer-wa { justify-content: center; }
}

/* ─── POPUP BASES LEGALES ─── */
.pdc-legal-modal {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.pdc-legal-modal.is-open { display: flex; }
.pdc-legal-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.42);
  backdrop-filter: blur(2px);
}
.pdc-legal-modal__dialog {
  position: relative;
  z-index: 1;
  width: auto;
  min-width: min(320px, calc(100vw - 48px));
  max-width: min(540px, calc(100vw - 48px));
  height: auto;
  max-height: min(82vh, 680px);
  background: #dfa151;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(28px, 4vw, 46px) clamp(22px, 4vw, 40px) clamp(26px, 3vw, 38px);
  overflow-y: auto;
  border-radius: 28px;
  box-shadow: 0 24px 80px rgba(0,0,0,.28);
}
.pdc-legal-modal__close {
  position: absolute;
  top: 10px;
  right: 12px;
  width: 34px;
  height: 34px;
  border: 0;
  background: transparent;
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 38px;
  font-weight: 300;
  line-height: .75;
  cursor: pointer;
  transition: transform .18s ease, opacity .18s ease;
}
.pdc-legal-modal__close:hover { transform: scale(1.06); opacity: .9; }
.pdc-legal-modal__content {
  width: 100%;
  text-align: center;
  margin: 0 auto;
}
.pdc-legal-modal__content h2 {
  margin: 0 0 18px;
  font-family: var(--serif, 'Playfair Display', serif);
  font-size: clamp(24px, 2vw, 34px);
  line-height: 1.16;
  letter-spacing: .02em;
  font-weight: 700;
  color: #fff;
}
.pdc-legal-modal__content p {
  margin: 0 auto;
  max-width: 100%;
  font-family: var(--sans, 'DM Sans', sans-serif);
  font-size: clamp(14px, 1.05vw, 17px);
  line-height: 1.52;
  letter-spacing: .01em;
  font-weight: 400;
  color: #fff;
}
.pdc-legal-modal__emphasis {
  margin-top: 18px !important;
  font-weight: 700 !important;
  font-size: clamp(15px, 1.14vw, 19px) !important;
}
.pdc-legal-modal__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: min(280px, 100%);
  max-width: 100%;
  min-height: 46px;
  margin-top: 24px;
  padding: 13px 26px;
  border-radius: 999px;
  background: #fff;
  color: #d8893f;
  font-family: var(--sans, 'DM Sans', sans-serif);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .01em;
  text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease;
}
.pdc-legal-modal__button:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.14);
}
body.pdc-modal-open { overflow: hidden; }

@media (max-width: 768px) {
  .pdc-legal-modal { padding: 18px; align-items: center; }
  .pdc-legal-modal__dialog {
    width: auto;
    min-width: 0;
    max-width: min(88vw, 380px);
    max-height: 78vh;
    padding: 36px 22px 28px;
    border-radius: 22px;
  }
  .pdc-legal-modal__close {
    top: 8px;
    right: 10px;
    font-size: 34px;
    width: 32px;
    height: 32px;
  }
  .pdc-legal-modal__content h2 {
    margin-bottom: 14px;
    font-size: clamp(20px, 6vw, 26px);
    letter-spacing: .01em;
  }
  .pdc-legal-modal__content p {
    font-size: 14px;
    line-height: 1.44;
    letter-spacing: 0;
  }
  .pdc-legal-modal__emphasis {
    margin-top: 16px !important;
    font-size: 15px !important;
  }
  .pdc-legal-modal__button {
    margin-top: 20px;
    min-width: 0;
    width: 100%;
    min-height: 44px;
    padding: 12px 18px;
    font-size: 13.5px;
  }
}

/* ─── OPTIMIZACIÓN RESPONSIVE v2.1.8 ─── */
html, body { max-width: 100%; overflow-x: hidden; }
img, video { max-width: 100%; }

.pasos-mobile-timeline { display: none; }

@media (min-width: 769px) and (max-width: 1180px) {
  .navbar {
    width: calc(100% - 48px);
    top: 24px;
    padding: 16px 28px;
  }

  .logo-img {
    max-width: 190px;
    height: auto;
    object-fit: contain;
  }

  .nav-links,
  .navbar .menu {
    gap: 24px;
  }

  .hero {
    min-height: 620px;
    height: 82vh;
  }

  .hero-content {
    left: 48px !important;
    right: 48px;
    bottom: 64px !important;
  }

  .hero-big {
    font-size: clamp(64px, 8vw, 82px) !important;
  }

  .mission,
  .parcela-section,
  .features-section,
  .incluye-section,
  .seguridad-section,
  .pasos-section {
    padding-left: 48px !important;
    padding-right: 48px !important;
  }

  .features-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .feat-card img,
  .feat-card > div:first-child {
    height: 420px !important;
  }

  .incluye-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }

  .incluye-grid .inc-img {
    aspect-ratio: 4 / 3;
  }

  .incluye-grid .inc-overlay-title {
    font-size: clamp(28px, 3vw, 38px) !important;
  }

  .incluye-grid .inc-overlay-body {
    font-size: clamp(20px, 2.25vw, 28px) !important;
  }

  .seguridad-grid {
    gap: 20px;
  }

  .seg-card {
    padding: 30px 28px 26px;
  }

  .pasos-section {
    padding-top: 64px !important;
    padding-bottom: 64px !important;
  }

  .pasos-section > h2 {
    font-size: 48px !important;
    margin-bottom: 52px;
  }

  .paso-num {
    font-size: 46px;
  }

  .paso-label {
    font-size: 16px;
    padding: 0 8px;
  }

  .paso-text {
    font-size: 12.8px;
    line-height: 1.58;
    padding-right: 12px;
  }

  .site-footer {
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    gap: 28px;
  }

  .footer-social {
    order: 2;
  }
}

@media (max-width: 768px) {
  .site-header {
    min-height: auto;
  }

  .navbar {
    width: calc(100% - 28px);
    top: 14px;
    padding: 14px 18px;
    border-radius: 18px;
  }

  .logo-img {
    max-width: 150px;
    max-height: 58px;
    height: auto;
    object-fit: contain;
  }

  .nav-toggle {
    width: 38px;
    min-width: 38px;
  }

  .nav-links,
  .navbar .menu {
    top: calc(100% + 10px);
    border-radius: 18px;
    padding: 18px;
  }

  .hero {
    height: 78vh;
    min-height: 560px;
  }

  .hero-overlay {
    background: linear-gradient(to bottom, rgba(0,0,0,.12) 0%, rgba(0,0,0,.72) 100%) !important;
  }

  .hero-content {
    left: 22px !important;
    right: 22px !important;
    bottom: 38px !important;
  }

  .hero-big {
    font-size: clamp(46px, 16vw, 64px) !important;
  }

  .hero-mid {
    font-size: clamp(24px, 8vw, 34px) !important;
  }

  .btn-orange {
    white-space: normal;
    text-align: center;
  }

  .mission,
  .parcela-section,
  .features-section,
  .incluye-section,
  .seguridad-section,
  .pasos-section {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  .mission {
    padding-top: 54px !important;
  }

  .mission-tagline {
    line-height: 1.42;
  }

  .parcela-img-wrap {
    height: 300px !important;
    border-radius: 18px !important;
  }

  .parcela-overlay-text {
    left: 22px !important;
    right: 22px !important;
    bottom: 24px !important;
    text-align: left !important;
  }

  .features-section {
    padding-top: 28px !important;
    padding-bottom: 34px !important;
  }

  .features-grid {
    grid-template-columns: 1fr !important;
    gap: 24px;
  }

  .feat-card {
    border-radius: 18px;
  }

  .feat-card img,
  .feat-card > div:first-child {
    height: 310px !important;
  }

  .feat-text,
  .feat-overlay-right {
    left: 22px;
    right: 22px;
    bottom: 24px;
  }

  .feat-cta .btn-orange {
    width: min(100%, 340px);
  }

  .incluye-section {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }

  .incluye-section h2 {
    font-size: clamp(52px, 19vw, 84px) !important;
    margin-bottom: 30px;
  }

  .incluye-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }

  .incluye-grid .inc-img,
  .incluye-grid .inc-img:last-child {
    grid-column: auto !important;
    aspect-ratio: 3 / 4 !important;
    border-radius: 18px;
  }

  .incluye-grid .inc-overlay {
    padding: 18px;
  }

  .incluye-grid .inc-overlay-title {
    font-size: clamp(24px, 8vw, 34px) !important;
    line-height: 1.05;
  }

  .incluye-grid .inc-overlay-body {
    font-size: clamp(17px, 6vw, 26px) !important;
    line-height: 1.12;
  }

  .seguridad-section {
    padding-top: 54px !important;
  }

  .seguridad-grid {
    grid-template-columns: 1fr !important;
    gap: 18px;
  }

  .seg-card {
    padding: 28px 22px 24px;
    border-radius: 18px;
  }

  .seguridad-btns {
    gap: 14px;
  }

  .seguridad-btns .btn-orange {
    width: min(100%, 340px);
  }

  .pasos-section {
    padding-top: 56px !important;
    padding-bottom: 60px !important;
  }

  .pasos-section > h2 {
    font-size: clamp(42px, 12vw, 54px) !important;
    line-height: 1.04;
    margin-bottom: 48px !important;
  }

  .pasos-desktop {
    display: none !important;
  }

  .pasos-mobile-timeline {
    position: relative;
    display: flex !important;
    flex-direction: column;
    gap: 34px;
  }

  .pasos-mobile-timeline::before {
    content: "";
    position: absolute;
    left: 17px;
    top: 28px;
    bottom: 26px;
    width: 2px;
    background: var(--btn-color);
    border-radius: 999px;
  }

  .paso-mobile-item {
    position: relative;
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr);
    column-gap: 8px;
    align-items: start;
  }

  .paso-mobile-dot {
    width: 18px;
    height: 18px;
    border-radius: 999px;
    background: var(--btn-color);
    margin-left: 9px;
    margin-top: 28px;
    position: relative;
    z-index: 2;
    box-shadow: 0 0 0 8px var(--bg-white);
  }

  .paso-mobile-num {
    display: block;
    font-family: var(--serif);
    font-size: 52px;
    font-style: italic;
    font-weight: 900;
    line-height: .82;
    letter-spacing: -.06em;
    color: rgba(45,45,45,.22);
    margin-bottom: 4px;
  }

  .paso-mobile-name {
    display: block;
    font-family: var(--serif);
    font-size: 22px;
    font-style: italic;
    font-weight: 700;
    line-height: 1.1;
    color: rgba(45,45,45,.52);
    margin-bottom: 18px;
  }

  .paso-mobile-text {
    margin: 0;
    font-family: var(--sans);
    font-size: 15.5px;
    line-height: 1.72;
    color: var(--text-dark);
    max-width: 330px;
  }

  .paso-mobile-text strong {
    font-weight: 700;
  }

  .cta-hero {
    height: 70vh;
    min-height: 480px;
  }

  .cta-hero-content {
    padding: 30px 22px 42px !important;
  }

  .cta-big {
    font-size: clamp(38px, 13vw, 56px) !important;
  }

  .cta-sub {
    max-width: 100%;
  }

  .site-footer {
    grid-template-columns: 1fr !important;
    justify-items: center;
    text-align: center;
    gap: 26px;
    padding: 42px 22px 34px !important;
  }

  .footer-icons {
    justify-content: center;
    flex-wrap: wrap;
  }

  .footer-wa {
    display: flex;
    justify-content: center;
  }
}

@media (max-width: 560px) {
  .incluye-grid {
    grid-template-columns: 1fr !important;
  }

  .incluye-grid .inc-img,
  .incluye-grid .inc-img:last-child {
    aspect-ratio: 4 / 3 !important;
  }

  .incluye-grid .inc-overlay-title {
    font-size: clamp(30px, 10vw, 42px) !important;
  }

  .incluye-grid .inc-overlay-body {
    font-size: clamp(22px, 7vw, 30px) !important;
  }

  .pasos-mobile-timeline {
    gap: 32px;
  }

  .paso-mobile-item {
    grid-template-columns: 46px minmax(0, 1fr);
  }

  .pasos-mobile-timeline::before {
    left: 15px;
  }

  .paso-mobile-dot {
    margin-left: 7px;
  }

  .paso-mobile-num {
    font-size: 48px;
  }

  .paso-mobile-name {
    font-size: 21px;
  }

  .paso-mobile-text {
    font-size: 15px;
    line-height: 1.68;
  }
}

@media (max-width: 380px) {
  .navbar {
    width: calc(100% - 20px);
    padding: 12px 14px;
  }

  .logo-img {
    max-width: 132px;
  }

  .hero {
    min-height: 520px;
  }

  .mission,
  .parcela-section,
  .features-section,
  .incluye-section,
  .seguridad-section,
  .pasos-section {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .pasos-section > h2 {
    font-size: 40px !important;
  }

  .paso-mobile-text {
    font-size: 14.5px;
  }
}


/* ─── FIX v2.1.9: carga visible de fotos/iconos en mobile y tablet ─── */
.incluye-grid .inc-img,
.incluye-grid .inc-img img {
  backface-visibility: hidden;
}

.footer-logo-img,
.footer-icons img,
.footer-wa img {
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
}

.footer-icons a,
.footer-wa a {
  flex: 0 0 auto;
}

@media (min-width: 769px) and (max-width: 1180px) {
  .incluye-grid .inc-img {
    min-height: 250px !important;
  }

  .footer-icons {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 18px;
  }

  .footer-icons a {
    width: var(--footer-icon-size, 52px) !important;
    height: var(--footer-icon-size, 52px) !important;
  }

  .footer-wa a {
    width: var(--footer-wa-size, 64px) !important;
    height: var(--footer-wa-size, 64px) !important;
  }
}

@media (max-width: 768px) {
  .incluye-grid .inc-img {
    width: 100% !important;
    min-height: 260px !important;
  }

  .incluye-grid .inc-img img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  .footer-icons {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 18px;
    flex-wrap: wrap;
  }

  .footer-icons a {
    width: var(--footer-icon-size, 52px) !important;
    height: var(--footer-icon-size, 52px) !important;
  }

  .footer-wa {
    display: flex !important;
    justify-content: center;
  }

  .footer-wa a {
    width: var(--footer-wa-size, 64px) !important;
    height: var(--footer-wa-size, 64px) !important;
  }
}

@media (max-width: 560px) {
  .incluye-grid .inc-img,
  .incluye-grid .inc-img:last-child {
    min-height: 250px !important;
    aspect-ratio: 4 / 3 !important;
  }
}



/* ============================================================
   Rediseño Home / Landing — v2.3.0
   Referencia: maqueta Verde y Tierra / rifa parcelas
   ============================================================ */
:root {
  --serif: 'Libre Bodoni', 'Bodoni 72', 'Bodoni MT', Georgia, serif;
  --sans: 'Montserrat', Arial, Helvetica, sans-serif;
  --pdc-container: 1180px;
  --pdc-green: #214438;
  --pdc-green-soft: #5d716a;
  --pdc-olive: #a5aa78;
  --pdc-terracotta: #ad4f35;
  --pdc-terracotta-dark: #8f3f2b;
  --pdc-black: #111111;
  --btn-color: #ad4f35;
  --btn-hover: #8f3f2b;
  --accent-color: #a5aa78;
  --text-dark: #28473d;
  --text-gray: #40574f;
  --bg-card: #214438;
}

body {
  font-family: var(--sans);
  color: var(--text-dark);
  background: #fff;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

.site-header {
  position: relative;
  isolation: isolate;
}

.navbar {
  top: 44px !important;
  width: min(calc(100% - 48px), 1120px) !important;
  max-width: 1120px !important;
  padding: 12px 38px !important;
  min-height: 62px;
  border-radius: 10px !important;
  background: rgba(255,255,255,.96) !important;
  box-shadow: 0 10px 35px rgba(16, 35, 29, .09) !important;
  backdrop-filter: blur(10px);
}

.logo-img {
  height: 42px !important;
  max-width: 175px !important;
  object-fit: contain;
}

.nav-links,
.navbar .menu {
  align-items: center;
  gap: var(--navbar-menu-gap, 58px) !important;
}

.nav-links a,
.navbar .menu a {
  font-family: var(--sans);
  font-size: var(--navbar-menu-size, 20px) !important;
  font-weight: 500 !important;
  letter-spacing: -.015em;
  color: #222 !important;
  padding: 8px 0;
}

.nav-links a:hover,
.navbar .menu a:hover {
  color: var(--pdc-terracotta) !important;
}

.hero {
  /* altura controlada por panel admin - ver dynamic CSS en wp_head */
  background: #6d8b6c;
}

.hero-video {
  object-position: center 45%;
  filter: saturate(.92) contrast(1.02);
}

/* Overlay: oscuro izquierda → transparente derecha, igual al PDF */
.hero-overlay {
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.15) 55%, rgba(0,0,0,.55) 100%),
    linear-gradient(90deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.28) 50%, rgba(0,0,0,.08) 100%) !important;
}

/* Bloque de texto: esquina inferior izquierda */
.hero-content {
  position: absolute;
  left: clamp(28px, 6vw, 80px);
  bottom: clamp(40px, 7.5vh, 120px);
  max-width: 640px;
  z-index: 20;
  color: #fff;
  text-align: left;
  pointer-events: none;
}
.hero-content a,
.hero-content .btn-orange {
  pointer-events: auto;
}

/* "Tu parcela propia" — línea pequeña */
.hero-sub {
  display: block;
  font-family: var(--sans) !important;
  font-size: clamp(16px, 1.6vw, 22px) !important;
  font-weight: 400 !important;
  letter-spacing: .02em;
  line-height: 1.2;
  color: rgba(255,255,255,.90);
  margin: 0 0 2px;
  text-shadow: 0 1px 6px rgba(0,0,0,.4);
}

/* "con un solo" — línea media */
.hero-mid {
  display: block;
  font-family: var(--sans) !important;
  font-size: clamp(28px, 3.2vw, 48px) !important;
  font-weight: 500 !important;
  letter-spacing: .01em;
  line-height: 1.05 !important;
  color: #fff;
  margin: 0;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* "BILLETE" — línea grande italic */
.hero-big {
  display: block;
  font-family: var(--serif) !important;
  font-size: clamp(72px, 8.5vw, 120px) !important;
  font-weight: 700 !important;
  font-style: italic !important;
  letter-spacing: -.03em;
  line-height: .88 !important;
  color: #fff;
  text-transform: uppercase;
  margin: 0 0 10px;
  text-shadow: 0 4px 20px rgba(0,0,0,.22);
}

/* "Participa por solo $10.000 pesos" */
.hero-price {
  font-family: var(--sans) !important;
  font-size: clamp(14px, 1.3vw, 18px) !important;
  font-weight: 400 !important;
  color: rgba(255,255,255,.90);
  line-height: 1.3;
  margin: 0 0 22px;
  text-shadow: 0 1px 6px rgba(0,0,0,.4);
}

/* Botón naranja hero */
.btn-orange {
  background: var(--pdc-terracotta) !important;
  color: #fff !important;
  font-family: var(--sans) !important;
  font-weight: 700 !important;
  letter-spacing: .01em;
  border-radius: 999px !important;
  padding: 14px 32px !important;
  font-size: 16px !important;
  box-shadow: none;
}
.btn-orange:hover {
  background: var(--pdc-terracotta-dark) !important;
  transform: translateY(-2px);
}
.btn-hero {
  font-size: 16px !important;
  padding: 14px 34px !important;
}


.chile-stripe {
  height: 14px;
}

.chile-stripe .cs1 { flex: .9; background: #273783; }
.chile-stripe .cs2 { flex: .9; background: #e0322e; }
.chile-stripe .cs3 { flex: .9; background: #fff; border-top: 0; }
.chile-stripe .cs4 { flex: .9; background: #247836; }

.mission,
.parcela-section,
.features-section,
.incluye-section,
.seguridad-section,
.pasos-section {
  max-width: calc(var(--pdc-container) + 160px);
  margin-left: auto;
  margin-right: auto;
  padding-left: 80px !important;
  padding-right: 80px !important;
}

.mission {
  padding-top: 82px !important;
  padding-bottom: 30px !important;
  text-align: center !important;
}

.mission-tagline {
  font-size: clamp(28px, 2.5vw, 42px) !important;
  font-weight: 700 !important;
  line-height: 1.45 !important;
  color: var(--pdc-green) !important;
  letter-spacing: .02em;
  margin-bottom: 76px;
}

.mission-tagline .highlight {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-size: clamp(38px, 4.1vw, 64px) !important;
  font-weight: 500 !important;
  color: var(--pdc-olive) !important;
  letter-spacing: -.035em;
}

.mission-parcela-title {
  font-size: clamp(42px, 4.2vw, 68px) !important;
  line-height: 1.05;
  font-weight: 400 !important;
  color: var(--pdc-green-soft) !important;
  text-align: left !important;
  margin-top: 0 !important;
  margin-bottom: 30px !important;
  letter-spacing: .02em;
}

.mission-parcela-title strong {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 700 !important;
  color: var(--pdc-green) !important;
  letter-spacing: -.04em;
}

.parcela-section {
  padding-top: 0 !important;
  padding-bottom: 44px !important;
}

.parcela-img-wrap {
  height: clamp(360px, 33vw, 460px) !important;
  border-radius: 18px !important;
  box-shadow: none;
}

.parcela-img-wrap::after,
.feat-card::after,
.plusvalia-image-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,.58) 100%);
  pointer-events: none;
  z-index: 1;
}

.parcela-img-wrap img {
  object-position: center;
}

.parcela-overlay-text {
  z-index: 2;
  bottom: 48px !important;
  right: 88px !important;
  color: #fff !important;
}

.parcela-overlay-text .m2 {
  font-family: var(--sans) !important;
  font-size: clamp(26px, 3.1vw, 48px) !important;
  font-weight: 500 !important;
  letter-spacing: .04em;
  line-height: .9;
}

.parcela-overlay-text .solo {
  font-family: var(--serif) !important;
  font-size: clamp(36px, 4vw, 64px) !important;
  font-weight: 500 !important;
  font-style: italic !important;
  letter-spacing: -.02em;
  color: #fff;
}

.features-section {
  padding-top: 0 !important;
  padding-bottom: 72px !important;
}

.features-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(330px, .82fr) !important;
  gap: 36px !important;
  align-items: stretch !important;
}

.feat-main-col {
  display: flex;
  flex-direction: column;
}

.feat-card {
  border-radius: 18px !important;
  position: relative;
  overflow: hidden;
  background: #111;
}

.feat-card img {
  height: 330px !important;
  width: 100%;
  object-fit: cover;
}

.feat-card-mar img {
  object-position: center;
}

.feat-text,
.feat-overlay-right {
  z-index: 2;
  left: auto !important;
  right: 58px !important;
  bottom: 48px !important;
  text-align: right !important;
  color: #fff !important;
}

.feat-text .label,
.feat-overlay-right .label,
.plusvalia-overlay .label {
  font-family: var(--sans) !important;
  font-size: clamp(28px, 2.5vw, 40px) !important;
  font-weight: 400 !important;
  letter-spacing: .04em;
  line-height: .9;
}

.feat-text .big,
.feat-overlay-right .big,
.plusvalia-overlay .big {
  display: block;
  font-family: var(--serif) !important;
  font-size: clamp(38px, 3.4vw, 60px) !important;
  font-weight: 500 !important;
  font-style: normal;
  letter-spacing: -.025em;
  line-height: .9;
  color: #fff;
}

.feat-cta {
  margin-top: 40px !important;
  justify-content: flex-start !important;
}

.plusvalia-card {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 100%;
  border: 1.5px solid rgba(17,17,17,.76);
  border-radius: 18px;
  overflow: hidden;
  color: #1e2528;
  text-decoration: none;
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease;
}

.plusvalia-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 45px rgba(26, 33, 30, .10);
  color: #1e2528;
  text-decoration: none;
}

.plusvalia-copy {
  padding: 28px 30px 20px;
}

.plusvalia-copy h3 {
  font-family: var(--sans);
  font-size: clamp(24px, 2.2vw, 36px);
  line-height: 1.12;
  font-weight: 800;
  color: #202a2c;
  margin: 0 0 12px;
  letter-spacing: -.03em;
}

.plusvalia-copy p {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.45;
  font-weight: 600;
  color: #333;
  margin: 0 0 12px;
}

.plusvalia-source {
  display: inline-block;
  font-family: var(--sans);
  font-size: 21px;
  font-weight: 800;
  color: #404647;
  letter-spacing: -.03em;
}

.plusvalia-source b {
  color: #c6453d;
  font-weight: 800;
}

.plusvalia-image-wrap {
  position: relative;
  min-height: 210px;
  background: #111;
  overflow: hidden;
}

.plusvalia-image-wrap img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.plusvalia-icon {
  position: absolute;
  left: 22px;      /* default; inline style del Customizer sobrescribe */
  bottom: 28px;    /* default; inline style del Customizer sobrescribe */
  z-index: 3;
  width: 42px;     /* default; inline style del Customizer sobrescribe */
  height: 42px;    /* default; inline style del Customizer sobrescribe */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 4px solid #fff;
  border-radius: 12px;
  color: #fff;
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
}

.plusvalia-overlay {
  position: absolute;
  right: 24px;
  bottom: 38px;
  z-index: 3;
  color: #fff;
  text-align: right;
  text-shadow: 0 2px 12px rgba(0,0,0,.22);
}

.incluye-section {
  padding-top: 24px !important;
  padding-bottom: 88px !important;
}

.incluye-section h2 {
  font-family: var(--serif) !important;
  font-size: clamp(58px, 5.6vw, 88px) !important;
  font-weight: 600 !important;
  font-style: italic !important;
  color: var(--pdc-green) !important;
  line-height: 1;
  margin: 0 0 48px !important;
  letter-spacing: .02em;
}

.incluye-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

.incluye-grid .inc-img {
  border-radius: 12px !important;
  min-height: 260px !important;
  aspect-ratio: 1 / 1.25 !important;
  background: #dde4df;
}

.incluye-grid .inc-img img {
  object-position: center;
}

.incluye-grid .inc-overlay-title,
.incluye-grid .inc-overlay-body {
  color: #fff;
}

.seguridad-section {
  padding-top: 32px !important;
  padding-bottom: 78px !important;
}

.seguridad-section > h2,
.pasos-section > h2 {
  font-family: var(--sans) !important;
  font-size: clamp(48px, 5vw, 78px) !important;
  font-weight: 400 !important;
  line-height: 1;
  color: var(--pdc-green-soft) !important;
  letter-spacing: .01em;
}

.seguridad-section > h2 {
  margin-bottom: 50px !important;
}

.seguridad-section > h2 strong,
.pasos-section > h2 strong {
  font-family: var(--serif) !important;
  font-weight: 600 !important;
  font-style: italic !important;
  color: var(--pdc-green) !important;
  letter-spacing: -.04em;
}

.seguridad-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 36px !important;
  margin-bottom: 44px !important;
}

.seg-card {
  background: #f4f4ee !important;
  color: var(--pdc-black) !important;
  border-radius: 12px !important;
  padding: 40px 44px 36px !important;
  min-height: 225px;
  border: 1px solid rgba(0,0,0,.06) !important;
}

.seg-card h3 {
  font-family: var(--sans) !important;
  font-size: clamp(20px, 1.8vw, 28px) !important;
  line-height: 1.26 !important;
  color: var(--pdc-black) !important;
  font-weight: 600 !important;
  margin: 0 0 18px !important;
  letter-spacing: .01em;
}

.seg-card h3 em {
  font-family: var(--serif) !important;
  font-size: 1.1em;
  font-weight: 700 !important;
  font-style: italic !important;
  color: var(--pdc-black) !important;
}

.seg-card p {
  font-family: var(--sans) !important;
  font-size: clamp(14px, 1.1vw, 17px) !important;
  line-height: 1.6 !important;
  font-weight: 400 !important;
  color: #444 !important;
  margin: 0 !important;
  letter-spacing: .01em;
}

.seg-card p strong {
  color: var(--pdc-black) !important;
  font-weight: 700 !important;
}

.seg-stripe {
  display: flex !important;
  height: 6px;
  width: 100%;
  margin-top: 24px;
  gap: 0;
  border-radius: 0 0 8px 8px;
  overflow: hidden;
  margin-left: -44px;
  margin-right: -44px;
  width: calc(100% + 88px);
}

.seguridad-btns {
  justify-content: center !important;
  gap: clamp(28px, 12vw, 300px) !important;
}

.seguridad-btns .btn-orange {
  min-width: 230px;
}

.pasos-section {
  padding-top: 56px !important;
  padding-bottom: 98px !important;
}

.pasos-section > h2 {
  text-align: center !important;
  margin: 0 0 70px !important;
}

.pasos-numbers,
.pasos-labels,
.pasos-texts,
.pasos-dots {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.paso-num {
  font-family: var(--serif) !important;
  font-size: clamp(52px, 4.7vw, 72px) !important;
  font-weight: 600 !important;
  font-style: italic !important;
  color: rgba(40,71,61,.72) !important;
  letter-spacing: -.05em;
}

.paso-label {
  font-family: var(--serif) !important;
  font-size: clamp(26px, 2.5vw, 40px) !important;
  font-weight: 600 !important;
  font-style: italic !important;
  color: var(--pdc-green) !important;
  line-height: 1.08 !important;
  letter-spacing: -.04em;
}

.pasos-labels {
  margin-bottom: 42px !important;
}

.pasos-timeline {
  margin-bottom: 42px !important;
}

.timeline-line {
  height: 4px !important;
  left: 7% !important;
  right: 7% !important;
  background: rgba(173,79,53,.82) !important;
}

.paso-dot {
  width: 18px !important;
  height: 18px !important;
  background: var(--pdc-terracotta) !important;
}

.paso-text {
  font-family: var(--sans) !important;
  font-size: clamp(15px, 1.15vw, 19px) !important;
  line-height: 1.45 !important;
  color: var(--pdc-green-soft) !important;
  padding: 0 22px 0 0 !important;
  letter-spacing: .01em;
}

.paso-text strong {
  color: var(--pdc-green) !important;
  font-weight: 800 !important;
}

/* v2.3.7 — Ajuste fino sección Pasos a seguir según maqueta */
.pasos-section {
  padding-top: 56px !important;
  padding-bottom: 98px !important;
}

.pasos-section > h2 {
  font-family: var(--sans) !important;
  font-size: 65px !important;
  font-weight: 500 !important;
  line-height: .95 !important;
  color: var(--pdc-green-soft) !important;
  text-align: left !important;
  letter-spacing: .015em !important;
  width: 100% !important;
  max-width: 1500px !important;
  margin: 0 auto 76px !important;
}

.pasos-section > h2 strong {
  font-family: var(--serif) !important;
  font-size: 85px !important;
  font-weight: 700 !important;
  font-style: italic !important;
  color: var(--pdc-green) !important;
  letter-spacing: -.045em !important;
}

.pasos-wrapper {
  width: 100% !important;
  max-width: 1500px !important;
  margin: 0 auto !important;
}

.pasos-numbers,
.pasos-labels,
.pasos-texts,
.pasos-dots {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

.pasos-numbers {
  margin-bottom: 18px !important;
}

.paso-num {
  font-family: var(--serif) !important;
  font-size: 65px !important;
  font-weight: 600 !important;
  font-style: italic !important;
  line-height: .9 !important;
  color: rgba(40,71,61,.70) !important;
  text-align: center !important;
  letter-spacing: -.045em !important;
}

.paso-label {
  font-family: var(--serif) !important;
  font-size: 40px !important;
  font-weight: 600 !important;
  font-style: italic !important;
  color: var(--pdc-green) !important;
  line-height: 1.02 !important;
  text-align: center !important;
  letter-spacing: -.04em !important;
}

.pasos-labels {
  margin-bottom: 48px !important;
}

.pasos-timeline {
  height: 24px !important;
  margin-bottom: 42px !important;
}

.timeline-line {
  height: 4px !important;
  left: 10% !important;
  right: 10% !important;
  background: rgba(173,79,53,.82) !important;
  border-radius: 999px !important;
}

.paso-dot {
  width: 18px !important;
  height: 18px !important;
  background: var(--pdc-terracotta) !important;
}

.paso-dot-col {
  display: flex !important;
  justify-content: center !important;
}

.paso-text {
  font-family: var(--sans) !important;
  font-size: 20px !important;
  font-weight: 400 !important;
  line-height: 1.28 !important;
  color: var(--pdc-green-soft) !important;
  padding: 0 26px 0 0 !important;
  letter-spacing: .01em !important;
}

.paso-text strong {
  color: var(--pdc-green) !important;
  font-weight: 700 !important;
}

.cta-hero {
  height: min(78vh, 760px) !important;
  min-height: 610px !important;
  background: var(--pdc-black);
}

.cta-hero-video {
  object-position: center 45%;
  filter: saturate(.96) contrast(1.02);
}

.cta-hero-overlay {
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.06) 18%, rgba(0,0,0,.72) 75%, #111 100%) !important;
}

.cta-hero-content {
  left: max(28px, calc((100vw - var(--pdc-container)) / 2)) !important;
  right: max(28px, calc((100vw - var(--pdc-container)) / 2)) !important;
  bottom: 130px !important;
  padding: 0 !important;
  max-width: 820px;
  text-align: left !important;
}

.cta-eyebrow {
  font-family: var(--sans) !important;
  font-size: clamp(26px, 3vw, 44px) !important;
  font-weight: 500 !important;
  color: #fff !important;
  letter-spacing: .08em;
  line-height: 1.05;
}

.cta-big {
  font-family: var(--serif) !important;
  font-size: clamp(50px, 6vw, 96px) !important;
  font-weight: 700 !important;
  font-style: italic !important;
  line-height: .92 !important;
  color: #fff !important;
  letter-spacing: -.04em;
  margin-bottom: 22px !important;
}

.cta-sub {
  font-family: var(--sans) !important;
  font-size: clamp(18px, 1.8vw, 27px) !important;
  font-weight: 500 !important;
  line-height: 1.25 !important;
  color: rgba(255,255,255,.93) !important;
  max-width: 650px !important;
  margin-bottom: 34px !important;
}

.site-footer {
  background: #111 !important;
  min-height: 165px;
  padding: 40px max(28px, calc((100vw - var(--pdc-container)) / 2)) 34px !important;
  grid-template-columns: minmax(160px, 1fr) auto minmax(160px, 1fr) !important;
  gap: 60px !important;
  margin-top: 0;
  color: #fff;
}

.footer-logo-img {
  height: 66px !important;
}

.footer-icons {
  gap: 52px !important;
}

.footer-icons a {
  width: 52px !important;
  height: 52px !important;
}

.footer-wa {
  justify-self: end;
}

.footer-wa a {
  width: 84px !important;
  height: 84px !important;
}

.footer-links {
  font-size: 15px !important;
  color: rgba(255,255,255,.70) !important;
  margin-top: 8px;
}

.footer-links a {
  color: rgba(255,255,255,.70) !important;
}

.footer-links a:hover {
  color: #fff !important;
}

.pdc-legal-modal__dialog {
  background: #b5664c !important;
  border-radius: 0 !important;
  max-width: min(520px, calc(100vw - 48px)) !important;
}

.pdc-legal-modal__content h2 {
  font-family: var(--serif) !important;
  font-weight: 700 !important;
}

.pdc-legal-modal__button {
  color: #b5664c !important;
}

@media (max-width: 1180px) {
  :root { --pdc-container: calc(100vw - 96px); }

  .features-grid {
    grid-template-columns: 1fr !important;
  }

  .plusvalia-card {
    grid-template-columns: .85fr 1fr;
    grid-template-rows: auto;
  }

  .plusvalia-image-wrap {
    min-height: 320px;
  }
}

@media (max-width: 768px) {
  :root { --pdc-container: calc(100vw - 44px); }

  .navbar {
    top: 14px !important;
    width: calc(100% - 28px) !important;
    padding: 12px 18px !important;
    min-height: 58px;
    border-radius: 16px !important;
  }

  .logo-img {
    height: 38px !important;
    max-width: 142px !important;
  }

  .nav-links,
  .navbar .menu {
    gap: 16px !important;
    top: calc(100% + 10px) !important;
  }

  .nav-links a,
  .navbar .menu a {
    font-size: 15px !important;
  }

  .hero {
    /* height controlled by panel admin dynamic CSS */
  }

  .hero-content {
    left: 22px !important;
    right: 22px !important;
    bottom: 54px !important;
  }

  .hero-sub { font-size: 22px !important; }
  .hero-mid { font-size: clamp(34px, 12vw, 48px) !important; }
  .hero-big { font-size: clamp(58px, 20vw, 82px) !important; }
  .hero-price { font-size: 18px !important; margin-bottom: 24px !important; }

  .btn-orange,
  .btn-hero {
    font-size: 15px !important;
    padding: 14px 24px !important;
  }

  .mission,
  .parcela-section,
  .features-section,
  .incluye-section,
  .seguridad-section,
  .pasos-section {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }

  .mission {
    padding-top: 54px !important;
    padding-bottom: 18px !important;
  }

  .mission-tagline {
    font-size: 22px !important;
    margin-bottom: 46px !important;
  }

  .mission-tagline .highlight {
    font-size: 30px !important;
  }

  .mission-parcela-title,
  .seguridad-section > h2,
  .pasos-section > h2 {
    font-size: clamp(40px, 13vw, 56px) !important;
  }

  .parcela-img-wrap,
  .feat-card img {
    height: 300px !important;
  }

  .parcela-overlay-text,
  .feat-text,
  .feat-overlay-right {
    left: 22px !important;
    right: 22px !important;
    bottom: 26px !important;
    text-align: right !important;
  }

  .parcela-overlay-text .m2,
  .feat-text .label,
  .plusvalia-overlay .label {
    font-size: 25px !important;
  }

  .parcela-overlay-text .solo,
  .feat-text .big,
  .plusvalia-overlay .big {
    font-size: 36px !important;
  }

  .feat-cta {
    justify-content: center !important;
    margin-top: 24px !important;
  }

  .plusvalia-card {
    grid-template-columns: 1fr;
  }

  .plusvalia-copy {
    padding: 22px 22px 18px;
  }

  .plusvalia-copy h3 {
    font-size: 24px;
  }

  .incluye-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }

  .incluye-section h2 {
    font-size: 56px !important;
  }

  .incluye-grid .inc-img {
    min-height: 230px !important;
  }

  .seguridad-grid {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  .seg-card {
    padding: 30px 24px !important;
  }

  .seg-card h3 { font-size: 24px !important; }
  .seg-card p { font-size: 15.5px !important; }

  .seguridad-btns {
    gap: 14px !important;
  }

  .seguridad-btns .btn-orange {
    width: min(100%, 340px);
  }

  .pasos-section > h2 {
    text-align: left !important;
  }

  .paso-mobile-num {
    font-family: var(--serif) !important;
    color: rgba(40,71,61,.70) !important;
  }

  .paso-mobile-name {
    font-family: var(--serif) !important;
    color: var(--pdc-green) !important;
  }

  .paso-mobile-text {
    color: var(--pdc-green-soft) !important;
  }

  .cta-hero {
    min-height: 560px !important;
    height: 74vh !important;
  }

  .cta-hero-content {
    left: 22px !important;
    right: 22px !important;
    bottom: 54px !important;
  }

  .cta-eyebrow { font-size: 24px !important; }
  .cta-big { font-size: clamp(44px, 15vw, 62px) !important; }
  .cta-sub { font-size: 16px !important; max-width: 100% !important; }

  .site-footer {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    text-align: center;
    gap: 24px !important;
    padding: 42px 22px 36px !important;
  }

  .footer-icons { gap: 26px !important; }
  .footer-wa { justify-self: center; }
  .footer-wa a { width: 72px !important; height: 72px !important; }
}

@media (max-width: 520px) {
  .incluye-grid {
    grid-template-columns: 1fr !important;
  }

  .incluye-grid .inc-img,
  .incluye-grid .inc-img:last-child {
    min-height: 260px !important;
    aspect-ratio: 4 / 3 !important;
  }
}

/* ============================================================
   Ajuste fino v2.3.2 — sección editorial + parcela
   Referencia Figma: fuentes, colores, tamaño y posición
   ============================================================ */
@media (min-width: 1025px) {
  .mission {
    padding-top: 88px !important;
    padding-bottom: 36px !important;
  }

  .mission-tagline {
    font-family: var(--sans) !important;
    font-size: 40px !important;
    font-weight: 600 !important;
    line-height: 1.34 !important;
    color: var(--pdc-green) !important;
    letter-spacing: .018em !important;
    margin-bottom: 92px !important;
  }

  .mission-tagline .highlight {
    font-family: var(--serif) !important;
    font-size: 64px !important;
    font-weight: 600 !important;
    font-style: italic !important;
    color: var(--pdc-olive) !important;
    letter-spacing: -.035em !important;
    line-height: .92 !important;
  }

  .mission-parcela-title {
    font-family: var(--sans) !important;
    font-size: 65px !important;
    font-weight: 500 !important;
    line-height: 1.02 !important;
    color: var(--pdc-green-soft) !important;
    letter-spacing: .012em !important;
    margin-bottom: 42px !important;
    text-align: left !important;
  }

  .mission-parcela-title strong {
    font-family: var(--serif) !important;
    font-size: 85px !important;
    font-weight: 700 !important;
    font-style: italic !important;
    color: var(--pdc-green) !important;
    letter-spacing: -.045em !important;
    line-height: .86 !important;
  }

  .parcela-section {
    padding-bottom: 56px !important;
  }

  .parcela-img-wrap {
    height: 460px !important;
    border-radius: 20px !important;
  }

  .parcela-overlay-text {
    right: 96px !important;
    bottom: 82px !important;
    text-align: right !important;
  }

  .parcela-overlay-text .m2 {
    font-family: var(--sans) !important;
    font-size: 48px !important;
    font-weight: 500 !important;
    line-height: .92 !important;
    letter-spacing: .055em !important;
    color: #fff !important;
  }

  .parcela-overlay-text .solo {
    font-family: var(--serif) !important;
    font-size: 64px !important;
    font-weight: 500 !important;
    font-style: italic !important;
    line-height: .96 !important;
    letter-spacing: -.025em !important;
    color: #fff !important;
  }
}

/* ============================================================
   Ajuste sección características/noticia — v2.3.3
   Referencia: imagen cercana enviada por cliente
   ============================================================ */
@media (min-width: 769px) {
  .features-section {
    padding-top: 0 !important;
    padding-bottom: 86px !important;
  }

  .features-grid {
    grid-template-columns: minmax(0, 1.18fr) minmax(380px, .82fr) !important;
    gap: 38px !important;
    align-items: stretch !important;
  }

  .feat-main-col {
    justify-content: flex-start !important;
  }

  .feat-card,
  .feat-card-mar {
    border-radius: 20px !important;
  }

  .feat-card img,
  .feat-card-mar img {
    height: 330px !important;
    object-position: center center !important;
  }

  .feat-text,
  .feat-overlay-right {
    right: 74px !important;
    bottom: 52px !important;
    left: auto !important;
    text-align: right !important;
    color: #ffffff !important;
    text-shadow: 0 2px 14px rgba(0,0,0,.20);
  }

  .feat-text .label,
  .feat-overlay-right .label {
    font-family: var(--sans) !important;
    font-size: 40px !important;
    font-weight: 500 !important;
    font-style: normal !important;
    color: #ffffff !important;
    letter-spacing: .04em !important;
    line-height: .92 !important;
  }

  .feat-text .big,
  .feat-overlay-right .big {
    font-family: var(--serif) !important;
    font-size: 60px !important;
    font-weight: 400 !important;
    font-style: normal !important;
    color: #ffffff !important;
    letter-spacing: -.02em !important;
    line-height: .88 !important;
  }

  .feat-cta {
    margin-top: 42px !important;
    justify-content: flex-start !important;
  }

  .features-section .feat-cta .btn-orange {
    font-family: var(--sans) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    padding: 16px 34px !important;
    min-width: 252px !important;
    text-align: center !important;
  }

  .plusvalia-card {
    border: 1.5px solid rgba(17,17,17,.88) !important;
    border-radius: 22px !important;
    min-height: 456px !important;
    align-self: stretch !important;
    overflow: hidden !important;
    background: #ffffff !important;
  }

  .plusvalia-copy {
    padding: 28px 28px 16px !important;
  }

  .plusvalia-copy h3 {
    font-family: var(--sans) !important;
    font-size: 35px !important;
    font-weight: 400 !important;
    line-height: 1.08 !important;
    color: #20252a !important;
    letter-spacing: -.03em !important;
    margin: 0 0 14px !important;
  }

  .plusvalia-copy p {
    font-family: var(--sans) !important;
    font-size: 17px !important;
    font-weight: 400 !important;
    line-height: 1.30 !important;
    color: #111111 !important;
    margin: 0 0 14px !important;
  }

  .plusvalia-source {
    font-family: var(--sans) !important;
    font-size: 27px !important;
    font-weight: 700 !important;
    color: #404647 !important;
    letter-spacing: -.03em !important;
  }

  .plusvalia-source b {
    color: #c6453d !important;
    font-weight: 700 !important;
  }

  .plusvalia-image-wrap {
    min-height: 230px !important;
  }

  .plusvalia-icon {
    border-width: 4px !important;
    border-radius: 12px !important;
    font-size: 28px !important;
    color: #ffffff !important;
    /* left/bottom/width/height vienen del inline style (Customizer) */
  }

  .plusvalia-overlay {
    right: 28px !important;
    bottom: 40px !important;
    text-align: right !important;
    color: #ffffff !important;
    text-shadow: 0 2px 14px rgba(0,0,0,.28);
  }

  .plusvalia-overlay .label {
    font-family: var(--sans) !important;
    font-size: 40px !important;
    font-weight: 500 !important;
    font-style: normal !important;
    color: #ffffff !important;
    letter-spacing: .04em !important;
    line-height: .92 !important;
  }

  .plusvalia-overlay .big {
    font-family: var(--serif) !important;
    font-size: 60px !important;
    font-weight: 400 !important;
    font-style: normal !important;
    color: #ffffff !important;
    letter-spacing: -.02em !important;
    line-height: .88 !important;
  }
}

/* ============================================================
   Ajuste sección Incluye — v2.3.4
   Referencia: imagen cercana enviada por cliente
   ============================================================ */
@media (min-width: 769px) {
  .incluye-section {
    max-width: 1560px !important;
    padding-left: 48px !important;
    padding-right: 48px !important;
    padding-top: 10px !important;
    padding-bottom: 96px !important;
  }

  .incluye-section h2 {
    font-family: var(--serif) !important;
    font-size: 75px !important;
    font-weight: 700 !important;
    font-style: italic !important;
    color: var(--pdc-green) !important;
    line-height: .92 !important;
    letter-spacing: .015em !important;
    text-align: left !important;
    margin: 0 0 50px !important;
  }

  .incluye-grid {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: 22px !important;
    align-items: stretch !important;
  }

  .incluye-grid .inc-img {
    border-radius: 12px !important;
    aspect-ratio: 1 / 1.23 !important;
    min-height: 318px !important;
    overflow: hidden !important;
    background: #dde4df !important;
  }

  .incluye-grid .inc-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
  }
}


/* ============================================================
   Ajuste textos sobre fotos Incluye — v2.3.5
   Referencia: Montserrat Medium 20 + Libre Bodoni Bold 24
   ============================================================ */
.incluye-grid .inc-overlay {
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
  padding: 18px !important;
  line-height: 1.05 !important;
  color: #ffffff !important;
  text-shadow: 0 2px 10px rgba(0,0,0,.42) !important;
}

.incluye-grid .inc-overlay-title {
  font-family: var(--serif) !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  font-style: normal !important;
  line-height: 1.08 !important;
  letter-spacing: .015em !important;
  color: #ffffff !important;
  margin: 0 !important;
}

.incluye-grid .inc-overlay-body {
  font-family: var(--sans) !important;
  font-size: 20px !important;
  font-weight: 500 !important;
  font-style: normal !important;
  line-height: 1.12 !important;
  letter-spacing: .01em !important;
  color: #ffffff !important;
  margin: 1px 0 0 !important;
}

.incluye-grid .inc-img-5 .inc-overlay-body {
  font-size: 20px !important;
}

@media (max-width: 768px) {
  .incluye-grid .inc-overlay-title {
    font-size: 22px !important;
  }
  .incluye-grid .inc-overlay-body,
  .incluye-grid .inc-img-5 .inc-overlay-body {
    font-size: 18px !important;
  }
}

/* ============================================================
   Ajuste sección Tu seguridad — v2.3.6
   Referencia: Montserrat Medium 65/32/20 + Libre Bodoni Bold Italic 85/40
   ============================================================ */
@media (min-width: 769px) {
  .seguridad-section {
    max-width: 1560px !important;
    padding-left: 48px !important;
    padding-right: 48px !important;
    padding-top: 42px !important;
    padding-bottom: 88px !important;
  }

  .seguridad-section > h2 {
    font-family: var(--sans) !important;
    font-size: 65px !important;
    font-weight: 500 !important;
    font-style: normal !important;
    line-height: .96 !important;
    letter-spacing: -.02em !important;
    color: var(--pdc-green-soft) !important;
    text-align: left !important;
    margin: 0 0 74px !important;
  }

  .seguridad-section > h2 strong {
    font-family: var(--serif) !important;
    font-size: 85px !important;
    font-weight: 700 !important;
    font-style: italic !important;
    line-height: .86 !important;
    letter-spacing: -.04em !important;
    color: var(--pdc-green) !important;
  }

  .seguridad-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 40px !important;
    margin: 0 0 48px !important;
    align-items: stretch !important;
  }

  .seg-card {
    background: #f4f4ee !important;
    color: var(--pdc-black) !important;
    border-radius: 12px !important;
    min-height: 260px !important;
    padding: 40px 44px 36px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    border: 1px solid rgba(0,0,0,.06) !important;
  }

  .seg-card h3 {
    font-family: var(--sans) !important;
    font-size: 26px !important;
    font-weight: 600 !important;
    font-style: normal !important;
    line-height: 1.20 !important;
    letter-spacing: .01em !important;
    color: var(--pdc-black) !important;
    margin: 0 0 18px !important;
  }

  .seg-card h3 em {
    font-family: var(--serif) !important;
    font-size: 32px !important;
    font-weight: 700 !important;
    font-style: italic !important;
    line-height: .96 !important;
    letter-spacing: -.035em !important;
    color: var(--pdc-black) !important;
  }

  .seg-card p {
    font-family: var(--sans) !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    font-style: normal !important;
    line-height: 1.6 !important;
    letter-spacing: .01em !important;
    color: #444 !important;
    margin: 0 !important;
  }

  .seg-card p strong {
    font-family: var(--sans) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--pdc-black) !important;
  }

  .seguridad-btns {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: clamp(56px, 16vw, 360px) !important;
    margin-top: 0 !important;
  }

  .seguridad-btns .btn-orange {
    font-family: var(--sans) !important;
    font-size: 21px !important;
    font-weight: 700 !important;
    line-height: 1.08 !important;
    letter-spacing: .01em !important;
    color: #ffffff !important;
    background: var(--pdc-terracotta) !important;
    border-radius: 999px !important;
    padding: 16px 36px !important;
    min-width: 250px !important;
    text-align: center !important;
    box-shadow: none !important;
  }

  .seguridad-btns .btn-orange:first-child {
    max-width: 270px !important;
    white-space: normal !important;
  }
}

@media (max-width: 768px) {
  .seguridad-section > h2 {
    font-weight: 500 !important;
  }

  .seguridad-section > h2 strong {
    font-weight: 700 !important;
  }

  .seg-card h3 {
    font-weight: 500 !important;
  }

  .seg-card h3 em {
    font-weight: 700 !important;
  }
}

/* ============================================================
   v2.3.8 - Ajuste CTA final / footer hero
   Referencia: Montserrat Medium 64/27, Libre Bodoni Bold Italic 96,
   botón Montserrat Bold 27
   ============================================================ */
.cta-hero {
  height: min(78vh, 780px) !important;
  min-height: 660px !important;
  background: var(--pdc-black) !important;
}

.cta-hero-video {
  object-position: center 43% !important;
  filter: saturate(.96) contrast(1.02) !important;
}

.cta-hero-overlay {
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.04) 22%, rgba(0,0,0,.50) 68%, #111 100%) !important;
}

.cta-hero-content {
  left: clamp(64px, 8.5vw, 150px) !important;
  right: clamp(40px, 7vw, 120px) !important;
  bottom: 118px !important;
  max-width: 1180px !important;
  padding: 0 !important;
  color: #ffffff !important;
  text-align: left !important;
}

.cta-eyebrow {
  font-family: var(--sans) !important;
  font-size: 64px !important;
  font-weight: 500 !important;
  line-height: .98 !important;
  letter-spacing: .075em !important;
  color: #ffffff !important;
  margin: 0 0 8px !important;
  opacity: 1 !important;
}

.cta-big {
  font-family: var(--serif) !important;
  font-size: 96px !important;
  font-weight: 700 !important;
  font-style: italic !important;
  line-height: .92 !important;
  letter-spacing: -.045em !important;
  color: #ffffff !important;
  margin: 0 0 28px !important;
  white-space: nowrap !important;
}

.cta-sub {
  font-family: var(--sans) !important;
  font-size: 27px !important;
  font-weight: 500 !important;
  line-height: 1.24 !important;
  letter-spacing: .045em !important;
  color: rgba(255,255,255,.94) !important;
  max-width: 760px !important;
  margin: 0 0 42px !important;
  opacity: 1 !important;
}

.cta-hero .btn-orange {
  font-family: var(--sans) !important;
  font-size: 27px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: .01em !important;
  color: #ffffff !important;
  background: var(--pdc-terracotta) !important;
  border-radius: 999px !important;
  padding: 18px 32px !important;
  min-height: 62px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: none !important;
  text-transform: none !important;
}

@media (max-width: 1180px) {
  .cta-hero-content {
    left: clamp(42px, 6vw, 78px) !important;
    right: clamp(32px, 5vw, 68px) !important;
    bottom: 90px !important;
    max-width: 92vw !important;
  }
  .cta-eyebrow { font-size: clamp(38px, 5.8vw, 64px) !important; }
  .cta-big { font-size: clamp(56px, 8.8vw, 96px) !important; }
  .cta-sub { font-size: clamp(18px, 2.4vw, 27px) !important; max-width: 680px !important; }
  .cta-hero .btn-orange { font-size: clamp(18px, 2.2vw, 27px) !important; }
}

@media (max-width: 768px) {
  .cta-hero {
    min-height: 560px !important;
    height: 72vh !important;
  }
  .cta-hero-content {
    left: 22px !important;
    right: 22px !important;
    bottom: 50px !important;
  }
  .cta-eyebrow {
    font-size: clamp(24px, 8vw, 36px) !important;
    letter-spacing: .035em !important;
    line-height: 1.05 !important;
  }
  .cta-big {
    font-size: clamp(40px, 13vw, 58px) !important;
    white-space: normal !important;
    line-height: .96 !important;
    margin-bottom: 20px !important;
  }
  .cta-sub {
    font-size: 16px !important;
    letter-spacing: .015em !important;
    max-width: 100% !important;
    margin-bottom: 26px !important;
  }
  .cta-hero .btn-orange {
    font-size: 17px !important;
    min-height: 52px !important;
    padding: 15px 24px !important;
  }
}

/* ============================================================
   v2.3.9 — Hover botones tipo maqueta
   Estado normal: terracota sólido. Estado hover: fondo blanco,
   borde terracota y texto terracota, sin salto de layout.
   ============================================================ */
.btn-orange,
button.btn-orange,
a.btn-orange {
  background: var(--pdc-terracotta, var(--btn-color, #ad4f35)) !important;
  color: #ffffff !important;
  border: 0 !important;
  box-shadow: inset 0 0 0 0 var(--pdc-terracotta, var(--btn-color, #ad4f35)) !important;
  transition: background-color .22s ease, color .22s ease, box-shadow .22s ease, transform .22s ease !important;
}

.btn-orange:hover,
.btn-orange:focus-visible,
button.btn-orange:hover,
button.btn-orange:focus-visible,
a.btn-orange:hover,
a.btn-orange:focus-visible {
  background: #ffffff !important;
  color: var(--pdc-terracotta, var(--btn-color, #ad4f35)) !important;
  box-shadow: inset 0 0 0 3px var(--pdc-terracotta, var(--btn-color, #ad4f35)) !important;
  transform: none !important;
  text-decoration: none !important;
}


/* v2.4.0 - Título Pasos alineado a la izquierda */
@media (min-width: 769px) {
  .pasos-section > h2 {
    text-align: left !important;
    width: 100% !important;
    max-width: 1500px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}


/* ─── POPUP BASES LEGALES v2.4.1 — referencia Figma ─── */
.pdc-legal-modal {
  padding: 32px !important;
  align-items: center !important;
  justify-content: center !important;
}

.pdc-legal-modal__backdrop {
  background: rgba(255,255,255,.72) !important;
  backdrop-filter: none !important;
}

.pdc-legal-modal__dialog {
  width: min(1090px, calc(100vw - 64px)) !important;
  min-width: 0 !important;
  max-width: min(1090px, calc(100vw - 64px)) !important;
  min-height: min(570px, calc(100vh - 64px)) !important;
  max-height: min(86vh, 720px) !important;
  background: #b5664c !important;
  color: #fff !important;
  border-radius: 10px !important;
  padding: clamp(96px, 13vh, 150px) clamp(42px, 7vw, 104px) clamp(70px, 8vh, 92px) !important;
  box-shadow: none !important;
  overflow-y: auto !important;
}

.pdc-legal-modal__close {
  top: 28px !important;
  right: 34px !important;
  width: 68px !important;
  height: 68px !important;
  color: #fff !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 76px !important;
  font-weight: 300 !important;
  line-height: .72 !important;
}

.pdc-legal-modal__content {
  width: 100% !important;
  max-width: 760px !important;
  text-align: center !important;
  margin: 0 auto !important;
}

.pdc-legal-modal__content h2 {
  margin: 0 0 44px !important;
  font-family: var(--serif) !important;
  font-size: 40px !important;
  font-style: normal !important;
  font-weight: 500 !important;
  line-height: 1.18 !important;
  letter-spacing: .03em !important;
  color: #fff !important;
}

.pdc-legal-modal__content p {
  max-width: 720px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  font-family: var(--sans) !important;
  font-size: 24px !important;
  font-weight: 500 !important;
  line-height: 1.34 !important;
  letter-spacing: .045em !important;
  color: #fff !important;
}

.pdc-legal-modal__emphasis {
  margin-top: 46px !important;
  font-family: var(--sans) !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: .04em !important;
}

.pdc-legal-modal__emphasis-serif {
  font-family: var(--serif) !important;
  font-size: 40px !important;
  font-style: italic !important;
  font-weight: 500 !important;
  letter-spacing: .02em !important;
  line-height: .9 !important;
  color: #fff !important;
  display: inline-block !important;
  transform: translateY(3px);
}

.pdc-legal-modal__button {
  min-width: min(390px, 100%) !important;
  min-height: 72px !important;
  margin-top: 58px !important;
  padding: 18px 40px !important;
  border-radius: 999px !important;
  border: 2px solid #fff !important;
  background: #fff !important;
  color: #b5664c !important;
  font-family: var(--sans) !important;
  font-size: 21px !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
  letter-spacing: .03em !important;
  box-shadow: none !important;
}

.pdc-legal-modal__button:hover {
  transform: translateY(-2px) !important;
  background: transparent !important;
  color: #fff !important;
  box-shadow: none !important;
}

@media (max-width: 900px) {
  .pdc-legal-modal { padding: 18px !important; }
  .pdc-legal-modal__dialog {
    width: min(100%, 620px) !important;
    max-width: calc(100vw - 36px) !important;
    min-height: 0 !important;
    padding: 74px 24px 42px !important;
    border-radius: 10px !important;
  }
  .pdc-legal-modal__close {
    top: 18px !important;
    right: 20px !important;
    width: 44px !important;
    height: 44px !important;
    font-size: 52px !important;
  }
  .pdc-legal-modal__content h2 {
    margin-bottom: 26px !important;
    font-size: clamp(28px, 8vw, 40px) !important;
  }
  .pdc-legal-modal__content p {
    font-size: clamp(17px, 4.7vw, 24px) !important;
    line-height: 1.35 !important;
    letter-spacing: .02em !important;
  }
  .pdc-legal-modal__emphasis {
    margin-top: 30px !important;
    font-size: clamp(17px, 4.7vw, 24px) !important;
  }
  .pdc-legal-modal__emphasis-serif {
    font-size: clamp(28px, 8vw, 40px) !important;
  }
  .pdc-legal-modal__button {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 390px !important;
    min-height: 60px !important;
    margin-top: 36px !important;
    font-size: 18px !important;
  }
}



/* ============================================================
   v2.4.4 - Hero HOME altura: controlada desde panel admin
   (functions.php genera el CSS dinámico con hero_home_height)
   ============================================================ */

/* La altura se inyecta vía wp_head desde functions.php */

.hero-video,
.hero-overlay {
  height: 100% !important;
}

@media (max-width: 768px) {
  .hero {
    /* min-height controlled by panel admin dynamic CSS */
  }
}


/* ============================================================
   v2.4.5 - Hero HOME PNG manual movible (hero-content restaurado en v2.5.6)
   ============================================================ */

.hero-manual-png-wrap {
  position: absolute !important;
  z-index: 3 !important;
  display: block !important;
  max-width: none !important;
  pointer-events: none;
}

.hero-manual-png-wrap--link {
  pointer-events: auto;
}

.hero-manual-png {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
}


/* ============================================================
   v2.4.7 - Botón CTA movible en hero HOME
   ============================================================ */
.hero-manual-btn {
  position: absolute !important;
  z-index: 4 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  max-width: none !important;
  min-height: 46px !important;
  text-align: center !important;
  white-space: nowrap !important;
}

@media (max-width: 768px) {
  .hero-manual-btn {
    width: auto !important;
    max-width: calc(100% - 40px) !important;
    left: 20px !important;
    top: auto !important;
    bottom: 44px !important;
  }
}


/* ============================================================
   v2.4.8 - Edición visual con mouse en Customizer
   ============================================================ */
body.pdc-hero-drag-enabled .hero-manual-png-wrap,
body.pdc-hero-drag-enabled .hero-manual-btn {
  pointer-events: auto !important;
  cursor: move !important;
}


/* ============================================================
   v2.5.0 - Capas PNG ilimitadas + edición visual
   ============================================================ */
.hero,
.tickets-hero {
  position: relative !important;
}

.pdc-hero-layers {
  position: absolute !important;
  inset: 0 !important;
  z-index: 3 !important;
  pointer-events: none;
}

.pdc-hero-layer {
  position: absolute !important;
  display: block !important;
  max-width: none !important;
  transform: none !important;
  box-sizing: border-box !important;
}

.pdc-hero-layer-img {
  height: auto !important;
  pointer-events: none;
  user-select: none;
}

.pdc-hero-button-layer,
.hero-manual-btn {
  z-index: 4 !important;
  pointer-events: auto;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 46px !important;
  max-width: none !important;
  white-space: nowrap !important;
  text-align: center !important;
}

/* Solo dentro del Customizer */
body.pdc-hero-editor-enabled .pdc-hero-layers {
  pointer-events: auto !important;
}

body.pdc-hero-editor-enabled .pdc-hero-layer,
body.pdc-hero-editor-enabled .hero-manual-btn {
  pointer-events: auto !important;
  cursor: move !important;
  user-select: none !important;
  outline: 2px dashed rgba(255,255,255,.75);
  outline-offset: 4px;
}

body.pdc-hero-editor-enabled .pdc-hero-layer.is-selected {
  outline: 3px solid #2D5BFF !important;
  outline-offset: 6px !important;
  box-shadow: 0 0 0 3px rgba(45,91,255,.25) !important;
}

.pdc-hero-resize-handle {
  display: none;
}

body.pdc-hero-editor-enabled .pdc-hero-layer.is-selected .pdc-hero-resize-handle,
body.pdc-hero-editor-enabled .hero-manual-btn.is-selected .pdc-hero-resize-handle {
  display: block;
  position: absolute;
  right: -12px;
  bottom: -12px;
  width: 22px;
  height: 22px;
  background: #2D5BFF;
  border: 2px solid #fff;
  border-radius: 999px;
  cursor: nwse-resize;
  z-index: 2147483646;
}


/* ============================================================
   v2.5.1 - Visibilidad reforzada de capas PNG
   ============================================================ */
.pdc-hero-layers {
  z-index: 20 !important;
}

.pdc-hero-layer-img {
  visibility: visible !important;
  object-fit: contain !important;
  object-position: center !important;
}

.hero-manual-btn,
.pdc-hero-button-layer {
  z-index: 21 !important;
}


/* ============================================================
   v2.5.2 - Fix definitivo: PNG visible en lienzo
   ============================================================ */
.pdc-hero-layers {
  z-index: 50 !important;
  overflow: visible !important;
}

.pdc-hero-layer-img {
  z-index: 51 !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1;
}

body.pdc-hero-editor-enabled .pdc-hero-layers {
  pointer-events: auto !important;
}

.pdc-hero-drop-active {
  box-shadow: inset 0 0 0 5px rgba(45,91,255,.55) !important;
}


/* ============================================================
   v2.5.5 - Editor de textos in-place: posicionamiento base
   ============================================================ */
.hero,
.mission,
.parcela-section,
.features-section,
.incluye-section,
.seguridad-section,
.pasos-section,
.cta-hero,
.tickets-hero {
  position: relative !important;
  overflow: visible;  /* permite que los overlays de texto salgan del borde si es necesario */
}

/* Overlays de texto libre: visibles sobre el contenido */
.pdc-te-overlay-text {
  pointer-events: none;
  z-index: 60;
}

/* ============================================================
   v2.5.17 - Capas de texto posicionables en heroes
   ============================================================ */
.pdc-hero-layer-text {
  position: absolute !important;
  display: block !important;
  pointer-events: none;
  user-select: none;
  max-width: none !important;
  box-sizing: border-box;
  z-index: 10;
  text-transform: uppercase;
}

/* En modo edición: seleccionables */
body.pdc-te-mode .pdc-hero-layer-text,
body.pdc-hero-editor-enabled .pdc-hero-layer-text {
  pointer-events: auto !important;
  cursor: move !important;
  outline: 2px dashed rgba(255,255,255,.55);
  outline-offset: 4px;
}
body.pdc-te-mode .pdc-hero-layer-text:hover {
  outline: 2px solid #2D5BFF;
}
body.pdc-te-mode .pdc-hero-layer-text.pdc-te-layer-selected {
  outline: 3px solid #2D5BFF !important;
  box-shadow: 0 0 0 3px rgba(45,91,255,.25) !important;
}


/* ============================================================
   v2.5.50 - Mismo marco visual editor/front para capas hero
   Las capas se guardan en px sobre un diseño base de 1280px.
   En el front se centra ese mismo marco, evitando desfase por pantalla full width.
   ============================================================ */
.hero .pdc-hero-layers,
.tickets-hero .pdc-hero-layers {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  left: 50% !important;
  right: auto !important;
  width: 1280px !important;
  max-width: 100vw !important;
  height: 100% !important;
  transform: translateX(-50%) !important;
  overflow: visible !important;
  z-index: 50 !important;
}

.hero .pdc-hero-layer,
.tickets-hero .pdc-hero-layer {
  position: absolute !important;
  transform: none !important;
}

.pdc-tickets-title-group {
  display: none !important;
}


/* ============================================================
   v2.5.51 - Home: botón CTA en mismo marco editor/front
   ============================================================ */
.hero .pdc-home-hero-button-frame {
  z-index: 52 !important;
  pointer-events: none !important;
}

.hero .pdc-home-hero-button-frame .pdc-hero-button-layer {
  pointer-events: auto !important;
  z-index: 53 !important;
}

.hero .pdc-home-hero-button-frame .hero-manual-btn {
  position: absolute !important;
  transform: none !important;
}

/* ============================================================
   v2.5.53 - Heroes responsivos
   Mantiene el marco editable de 1280px, pero lo escala en pantallas menores.
   Así textos, imágenes y botones conservan proporción y posición relativa.
   ============================================================ */
.hero,
.tickets-hero {
  --pdc-hero-design-width: 1280px;
  --pdc-hero-layer-scale: min(1, calc(100vw / 1280px));
  overflow: hidden !important;
}

.hero .pdc-hero-layers,
.tickets-hero .pdc-hero-layers {
  width: 1280px !important;
  max-width: none !important;
  left: 50% !important;
  right: auto !important;
  transform: translateX(-50%) scale(var(--pdc-hero-layer-scale)) !important;
  transform-origin: top center !important;
  will-change: transform;
}

.hero .pdc-hero-layer,
.tickets-hero .pdc-hero-layer {
  transform: none !important;
}

@media (min-width: 1281px) {
  .hero,
  .tickets-hero {
    --pdc-hero-layer-scale: 1;
  }
}

/* Fallback para navegadores sin división en calc() */
@media (max-width: 1180px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .92; }
}
@media (max-width: 1024px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .80; }
}
@media (max-width: 900px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .70; }
}
@media (max-width: 768px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .60; }
}
@media (max-width: 640px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .50; }
}
@media (max-width: 520px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .42; }
}
@media (max-width: 420px) {
  .hero,
  .tickets-hero { --pdc-hero-layer-scale: .36; }
}

@media (max-width: 768px) {
  .hero .pdc-hero-button-layer,
  .tickets-hero .pdc-hero-button-layer,
  .hero .hero-manual-btn,
  .tickets-hero .hero-manual-btn {
    min-height: 44px !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
  }
}


/* ============================================================
   v2.5.55 - Fix definitivo: lienzos por dispositivo sin heredar
   el escalado global 1280px de v2.5.53.
   Cada layout usa su propio marco: desktop 1280, tablet 768, mobile 390.
   ============================================================ */
.hero .pdc-hero-layers-views,
.tickets-hero .pdc-hero-layers-views {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  z-index: 60 !important;
  overflow: visible !important;
}

.hero .pdc-hero-layers-views .pdc-hero-layers,
.tickets-hero .pdc-hero-layers-views .pdc-hero-layers {
  position: absolute !important;
  top: 0 !important;
  bottom: 0 !important;
  right: auto !important;
  height: 100% !important;
  max-width: none !important;
  overflow: visible !important;
  pointer-events: none !important;
  z-index: 61 !important;
  will-change: transform !important;
}

.hero .pdc-hero-layers-views .pdc-hero-layer,
.tickets-hero .pdc-hero-layers-views .pdc-hero-layer {
  position: absolute !important;
  transform: none !important;
  pointer-events: auto !important;
}

.hero .pdc-hero-layers--desktop,
.tickets-hero .pdc-hero-layers--desktop {
  display: block !important;
  left: 50% !important;
  width: 1280px !important;
  transform: translateX(-50%) !important;
  transform-origin: top center !important;
}

.hero .pdc-hero-layers--tablet,
.hero .pdc-hero-layers--mobile,
.tickets-hero .pdc-hero-layers--tablet,
.tickets-hero .pdc-hero-layers--mobile {
  display: none !important;
}

@media (max-width: 900px) {
  .hero .pdc-hero-layers--desktop,
  .tickets-hero .pdc-hero-layers--desktop {
    display: none !important;
  }
  .hero .pdc-hero-layers--tablet,
  .tickets-hero .pdc-hero-layers--tablet {
    display: block !important;
    left: 50% !important;
    width: 768px !important;
    transform: translateX(-50%) !important;
    transform-origin: top center !important;
  }
  .hero .pdc-hero-layers--mobile,
  .tickets-hero .pdc-hero-layers--mobile {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .hero .pdc-hero-layers--desktop,
  .hero .pdc-hero-layers--tablet,
  .tickets-hero .pdc-hero-layers--desktop,
  .tickets-hero .pdc-hero-layers--tablet {
    display: none !important;
  }
  .hero .pdc-hero-layers--mobile,
  .tickets-hero .pdc-hero-layers--mobile {
    display: block !important;
    left: 50% !important;
    width: 390px !important;
    transform: translateX(-50%) !important;
    transform-origin: top center !important;
  }
}

/* v2.5.55 - ajuste fino para teléfonos menores a 390px */
@media (max-width: 389px) {
  .hero .pdc-hero-layers--mobile,
  .tickets-hero .pdc-hero-layers--mobile {
    transform: translateX(-50%) scale(.96) !important;
    transform-origin: top center !important;
  }
}
@media (max-width: 374px) {
  .hero .pdc-hero-layers--mobile,
  .tickets-hero .pdc-hero-layers--mobile {
    transform: translateX(-50%) scale(.92) !important;
    transform-origin: top center !important;
  }
}


/* v2.5.56 — Logo visible y editable en navbar */
.logo-img-wrap {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex: 0 0 auto !important;
  min-width: min(var(--navbar-logo-max-width, 175px), 28vw) !important;
  text-decoration: none !important;
}
.logo-img-wrap--empty { display: none !important; }
.logo-img {
  height: var(--navbar-logo-height, 42px) !important;
  max-width: var(--navbar-logo-max-width, 175px) !important;
  width: auto !important;
  object-fit: contain !important;
}
.logo-text-fallback {
  font-family: var(--sans);
  font-size: 18px;
  font-weight: 700;
  color: var(--navbar-link, #28473d);
  white-space: nowrap;
}
@media (min-width: 769px) {
  .navbar { gap: 28px !important; }
  .nav-links, .navbar .menu { flex: 1 1 auto; justify-content: center; }
}
@media (max-width: 768px) {
  .logo-img-wrap {
    min-width: min(var(--navbar-logo-max-width, 175px), 45vw) !important;
  }
  .logo-img {
    height: var(--navbar-logo-mobile-height, 34px) !important;
    max-width: min(var(--navbar-logo-max-width, 175px), 45vw) !important;
  }
  .navbar { justify-content: space-between !important; }
}


/* ============================================================
   v2.5.58 - Precisión editor/front: override final anti-desfase
   ============================================================ */
html body .hero .pdc-hero-layers-views,
html body .tickets-hero .pdc-hero-layers-views { position:absolute!important; inset:0!important; width:100%!important; height:100%!important; overflow:hidden!important; pointer-events:none!important; z-index:80!important; }
html body .hero .pdc-hero-layers-views .pdc-hero-layers,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers { position:absolute!important; top:0!important; bottom:auto!important; height:100%!important; max-width:none!important; margin:0!important; padding:0!important; overflow:visible!important; pointer-events:none!important; transform-origin:top center!important; zoom:1!important; }
html body .hero .pdc-hero-layers-views .pdc-hero-layers--desktop,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--desktop { display:block!important; left:50%!important; width:1280px!important; transform:translateX(-50%)!important; }
html body .hero .pdc-hero-layers-views .pdc-hero-layers--tablet,
html body .hero .pdc-hero-layers-views .pdc-hero-layers--mobile,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--tablet,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--mobile { display:none!important; }
@media (max-width:900px){
  html body .hero .pdc-hero-layers-views .pdc-hero-layers--desktop,
  html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--desktop { display:none!important; }
  html body .hero .pdc-hero-layers-views .pdc-hero-layers--tablet,
  html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--tablet { display:block!important; left:50%!important; width:768px!important; transform:translateX(-50%)!important; }
}
@media (max-width:640px){
  html body .hero .pdc-hero-layers-views .pdc-hero-layers--desktop,
  html body .hero .pdc-hero-layers-views .pdc-hero-layers--tablet,
  html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--desktop,
  html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--tablet { display:none!important; }
  html body .hero .pdc-hero-layers-views .pdc-hero-layers--mobile,
  html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--mobile { display:block!important; left:50%!important; width:390px!important; transform:translateX(-50%)!important; }
}
@media (max-width:389px), (max-width:374px){
  html body .hero .pdc-hero-layers-views .pdc-hero-layers--mobile,
  html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layers--mobile { transform:translateX(-50%)!important; }
}
html body .hero .pdc-hero-layers-views .pdc-hero-layer,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layer { position:absolute!important; transform:none!important; margin:0!important; box-sizing:border-box!important; pointer-events:auto!important; }
html body .hero .pdc-hero-layers-views .pdc-hero-layer-text,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-layer-text { display:block!important; padding:0!important; max-width:none!important; letter-spacing:normal!important; }
html body .hero .pdc-hero-layers-views .pdc-hero-button-layer,
html body .tickets-hero .pdc-hero-layers-views .pdc-hero-button-layer { display:inline-flex!important; align-items:center!important; justify-content:center!important; min-height:46px!important; padding:12px 24px!important; border-radius:50px!important; line-height:1.2!important; white-space:nowrap!important; bottom:auto!important; max-width:none!important; }

/* v2.5.59 — Footer icons: remove black boxes / force transparent buttons */
.site-footer .footer-icons a,
.site-footer .footer-wa a {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  outline: 0 !important;
}
.site-footer .footer-icons a::before,
.site-footer .footer-icons a::after,
.site-footer .footer-wa a::before,
.site-footer .footer-wa a::after {
  background: transparent !important;
  box-shadow: none !important;
}
.site-footer .footer-icons a img,
.site-footer .footer-wa a img {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  mix-blend-mode: screen;
}

/* ── plusvalia-card--img-only: imagen completa sin bloque de texto ── */
.plusvalia-card--img-only {
  display: block !important;           /* no grid, altura libre */
  min-height: unset !important;
  height: auto !important;
}
.plusvalia-card--img-only .plusvalia-image-wrap {
  position: relative;
  width: 100%;
  height: auto !important;
  min-height: unset !important;
  overflow: hidden;
}
.plusvalia-card--img-only .plusvalia-image-wrap > img {
  position: static !important;         /* fluye naturalmente */
  inset: unset !important;
  width: 100% !important;
  height: auto !important;
  object-fit: unset !important;
  display: block;
}
.plusvalia-card--img-only .plusvalia-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #1a77d4 !important;
  border-radius: 12px !important;
  border: none !important;
  padding: 8px !important;
  /* posición y tamaño vienen del inline style generado por PHP/Customizer */
}
.plusvalia-card--img-only .plusvalia-icon img {
  position: static !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  inset: unset !important;
}
/* Neutralizar overrides responsive que afectan --img-only */
@media (max-width: 1024px) {
  .plusvalia-card--img-only { min-height: unset !important; }
  .plusvalia-card--img-only .plusvalia-image-wrap { min-height: unset !important; }
}
@media (max-width: 768px) {
  .plusvalia-card--img-only { min-height: unset !important; }
  .plusvalia-card--img-only .plusvalia-image-wrap { min-height: unset !important; }
}
