/*
Theme Name: Escoland Talent Connect
Theme URI: https://deportes.datxale.com/
Template: hello-elementor
Author: Datxale
Description: Child theme de Hello Elementor con landing one-page replicando 1:1 escoland-talent-flow.base44.app
Version: 2.0.1
Text Domain: escoland-child
*/

/* ============ TOKENS ============ */
:root {
  --navy: #1A2A4A;
  --navy-deep: #0F1F3D;
  --cyan: #1A9FC1;
  --cyan-soft: #4FB8D4;
  --ink: #1C2B40;
  --muted: #5B6B82;
  --bg-soft: #F7FBFD;
  --bg-white: #FFFFFF;
  --border: #E0E6EB;
}

/* ============ RESET / BASE ============ */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: clip; }
body { overflow-x: clip; max-width: 100vw; }
img, video, iframe { max-width: 100%; }
/* Compensar header sticky cuando se hace anchor scroll */
.escoland section[id] { scroll-margin-top: 110px; }
@media (max-width: 860px) {
  .escoland section[id] { scroll-margin-top: 80px; }
}
body.escoland {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--ink);
  background: var(--bg-white);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
.escoland img { max-width: 100%; height: auto; display: block; }
.escoland a { color: inherit; text-decoration: none; }

/* Layout container */
.escoland .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ============ BUSCAMOS GRID 2x2 ============ */
.escoland .buscamos-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}
.escoland .b-card {
  background: #FFFFFF;
  border: 0.8px solid #E8EEF7;
  border-radius: 16px;
  overflow: hidden;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.escoland .b-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 48px -16px rgba(26, 42, 74, 0.12);
  border-color: rgba(26, 159, 193, 0.4);
}
.escoland .b-card-inner {
  position: relative;
  padding: 32px;
  min-height: 200px;
  overflow: hidden;
}
.escoland .b-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: rgba(26, 159, 193, 0.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1A9FC1;
  margin-bottom: 20px;
}
.escoland .b-icon svg { width: 22px !important; height: 22px !important; max-width: 22px; max-height: 22px; }
.escoland .b-num {
  position: absolute;
  top: 24px;
  right: 32px;
  font-family: 'Archivo Black', sans-serif;
  font-size: 120px;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(26, 159, 193, 0.3);
  text-stroke: 1.5px rgba(26, 159, 193, 0.3);
  letter-spacing: -0.04em;
  pointer-events: none;
  user-select: none;
}
.escoland .b-h3 {
  font-family: 'Inter Tight', sans-serif;
  font-weight: 700;
  font-size: 22px;
  line-height: 1.25;
  color: #1A2A4A;
  margin: 0 0 12px;
}
.escoland .b-p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.625;
  color: #4A5568;
  margin: 0;
  max-width: 80%;
}

/* ============ OFRECEMOS GRID 3-col ============ */
.escoland .ofrecemos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1200px;
  margin: 0 auto;
}
.escoland .o-card {
  background: #FFFFFF;
  border: 0.8px solid #E8EEF7;
  border-radius: 16px;
  padding: 32px;
  transition: transform .3s, box-shadow .3s;
}
.escoland .o-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 48px -16px rgba(26, 42, 74, 0.12);
}
.escoland .o-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.escoland .o-big {
  font-family: 'Archivo Black', sans-serif;
  font-size: 32px;
  line-height: 1.1;
  color: #1A9FC1;
  letter-spacing: -0.02em;
}
.escoland .o-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: rgba(26, 42, 74, 0.06);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1A2A4A;
  flex: 0 0 auto;
}
.escoland .o-icon svg { width: 18px !important; height: 18px !important; max-width: 18px; max-height: 18px; }
.escoland .o-divider {
  height: 1px;
  background: #E8EEF7;
  margin: 0 0 16px;
}
.escoland .o-chip {
  display: inline-block;
  background: rgba(26, 159, 193, 0.12);
  color: #1A2A4A;
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.1em;
  padding: 5px 12px;
  border-radius: 999px;
  margin-bottom: 16px;
}
.escoland .o-h3 {
  font-family: 'Inter Tight', sans-serif;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.25;
  color: #1A2A4A;
  margin: 0 0 12px;
}
.escoland .o-p {
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  line-height: 1.625;
  color: #4A5568;
  margin: 0;
}

/* ============ RESPONSIVE BREAKPOINTS ============ */
/* Tablet landscape — 1024px */
@media (max-width: 1024px) {
  .escoland .ofrecemos-grid { grid-template-columns: 1fr 1fr; gap: 20px; }
  .escoland .buscamos-grid { gap: 20px; }
  .escoland .b-num { font-size: 100px; }
  .escoland .elementor-section.elementor-top-section:nth-of-type(4)::before {
    width: 760px; height: 760px;
  }
  /* Section paddings reducidos */
  .escoland .elementor-18 .elementor-section.elementor-top-section { padding-top: 96px !important; padding-bottom: 96px !important; }
  .escoland .elementor-18 .elementor-section:first-of-type { padding-top: 48px !important; padding-bottom: 64px !important; }
}

/* Tablet portrait — 768px */
@media (max-width: 768px) {
  .escoland .buscamos-grid { grid-template-columns: 1fr; gap: 18px; }
  .escoland .ofrecemos-grid { grid-template-columns: 1fr; gap: 18px; }
  .escoland .b-num { font-size: 88px; right: 20px; top: 18px; }
  .escoland .b-card-inner { padding: 26px; min-height: auto; }
  .escoland .o-card { padding: 26px; }
  .escoland .o-big { font-size: 28px; }

  /* Hero columnas stack */
  .escoland .elementor-18 .elementor-section:first-of-type > .elementor-container { flex-wrap: wrap; }
  .escoland .elementor-18 .elementor-section:first-of-type > .elementor-container > .elementor-column {
    width: 100% !important;
    min-width: 100% !important;
    flex: 1 1 100% !important;
    max-width: 100% !important;
  }
  .escoland .elementor-18 .elementor-section:first-of-type .elementor-column:nth-child(2) {
    margin-top: 32px;
  }

  /* Círculos CTA más pequeños */
  .escoland .elementor-section.elementor-top-section:nth-of-type(4)::before {
    width: 540px; height: 540px;
  }

  /* Section paddings */
  .escoland .elementor-18 .elementor-section.elementor-top-section { padding-top: 72px !important; padding-bottom: 72px !important; }
}

/* Mobile — 480px */
@media (max-width: 480px) {
  .escoland .b-num { font-size: 72px; right: 16px; }
  .escoland .b-card-inner, .escoland .o-card { padding: 22px; }
  .escoland .b-h3, .escoland .o-h3 { font-size: 18px; }
  .escoland .b-p, .escoland .o-p { font-size: 14.5px; }
  .escoland .o-big { font-size: 24px; }

  /* Círculos CTA aún más pequeños */
  .escoland .elementor-section.elementor-top-section:nth-of-type(4)::before {
    width: 380px; height: 380px;
  }

  .escoland .elementor-18 .elementor-section.elementor-top-section { padding-top: 56px !important; padding-bottom: 56px !important; }
}

/* Small mobile — 360px */
@media (max-width: 360px) {
  .escoland .b-num { font-size: 64px; right: 12px; top: 14px; }
  .escoland .b-card-inner, .escoland .o-card { padding: 18px; }
  .escoland .elementor-section.elementor-top-section:nth-of-type(4)::before {
    width: 320px; height: 320px;
  }
}
@media (max-width: 480px) {
  .escoland .b-num { font-size: 72px; right: 16px; }
  .escoland .b-card-inner, .escoland .o-card { padding: 22px; }
  .escoland .b-h3, .escoland .o-h3 { font-size: 18px; }
  .escoland .b-p, .escoland .o-p { font-size: 14.5px; }
  .escoland .o-big { font-size: 24px; }
}

/* ============ TIPOGRAFÍA FLUIDA RESPONSIVE (hero h1/h2 + CTA h2) ============ */
/* Hero h1 ¡ÚNETE AL RUGIDO! */
.escoland .elementor-18 .elementor-section:first-of-type h1.elementor-heading-title {
  font-size: clamp(48px, 13vw, 112px) !important;
  line-height: 0.95 !important;
  word-break: break-word;
  overflow-wrap: break-word;
}
/* Hero h2 MARKETING Y VENTAS */
.escoland .elementor-18 .elementor-section:first-of-type h2.elementor-heading-title {
  font-size: clamp(32px, 8vw, 64px) !important;
  line-height: 0.95 !important;
}

/* CTA Final h2 TU FUTURO COMIENZA CON UN CLICK — limitado a 720px centrado */
.escoland .elementor-section.elementor-top-section:nth-of-type(4) h2.elementor-heading-title {
  font-size: clamp(36px, 7vw, 76px) !important;
  line-height: 1.05 !important;
  word-break: break-word;
  max-width: 720px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* Headers de section BUSCAMOS / OFRECEMOS h2 */
.escoland .elementor-section.elementor-top-section:nth-of-type(2) h2.elementor-heading-title,
.escoland .elementor-section.elementor-top-section:nth-of-type(3) h2.elementor-heading-title {
  font-size: clamp(36px, 7vw, 64px) !important;
  line-height: 1.05 !important;
}

/* Botón CTA Final no debe wrappear */
.escoland .cta-final-btn {
  white-space: nowrap;
}
@media (max-width: 420px) {
  .escoland .cta-final-btn {
    font-size: 14px;
    padding: 16px 22px;
    gap: 8px;
  }
  .escoland .cta-final-btn svg { width: 14px; height: 14px; }
}
@media (max-width: 360px) {
  .escoland .cta-final-btn {
    font-size: 13px;
    padding: 14px 18px;
    gap: 6px;
    letter-spacing: 0;
  }
}

/* Hero photo container debe NO cortar imagen */
.escoland .elementor-18 .elementor-section:first-of-type .elementor-widget-image img {
  max-width: 100% !important;
  height: auto !important;
}

/* Logo del hero responsive */
@media (max-width: 480px) {
  .escoland .elementor-18 .elementor-section:first-of-type .elementor-column:nth-child(1) .elementor-widget-image:first-of-type img {
    max-width: 160px !important;
    width: 160px !important;
  }
}

/* ============ NATIVE WIDGETS FIXES ============ */
/* PILLS / BADGES — headings con bg que deben ser inline-block, no full width.
   Solo aplica a `.pill-heading`, los demás headings mantienen display block. */
.escoland .elementor-widget-heading.pill-heading > .elementor-widget-container > .elementor-heading-title {
  display: inline-block;
  width: auto;
}
/* Forzar que NO se aplique inline-block a otros heading-title */
.escoland .elementor-widget-heading:not(.pill-heading) > .elementor-widget-container > .elementor-heading-title {
  display: block;
}

/* Hero column 1 no debe expandirse forzado por contenido grande */
.escoland .elementor-18 .elementor-section:first-of-type .elementor-column.elementor-col-55 {
  min-width: 0;
  flex: 0 0 55%;
  max-width: 55%;
}
.escoland .elementor-18 .elementor-section:first-of-type .elementor-column.elementor-col-45 {
  min-width: 0;
  flex: 0 0 45%;
  max-width: 45%;
}
/* Permitir wrap del título h1 si es necesario */
.escoland .elementor-18 .elementor-section:first-of-type .elementor-widget-heading h1.elementor-heading-title,
.escoland .elementor-18 .elementor-section:first-of-type .elementor-widget-heading h2.elementor-heading-title {
  word-wrap: break-word;
  overflow-wrap: break-word;
}

/* CTA Final — limitar h2 width a 848px como el original (forzar wrap en 2 líneas) */
.escoland .elementor-element.cta-final h2,
.escoland .elementor-section[style*="background-color:#1A2A4A"] h2,
body.escoland section.elementor-section h2.elementor-heading-title {
  /* nothing global */
}
/* Apuntar a la última section (CTA Final navy) */
.escoland .elementor-section.elementor-top-section:nth-of-type(4) .elementor-widget-heading .elementor-heading-title {
  max-width: 848px;
  margin-left: auto;
  margin-right: auto;
}
.escoland .elementor-section.elementor-top-section:nth-of-type(4) .elementor-widget-text-editor .elementor-widget-container {
  max-width: 576px;
  margin-left: auto;
  margin-right: auto;
}
/* Y por si el selector :nth-of-type no calza por header en main, también via bg color */
.escoland section[data-element_type="section"] .elementor-container [style*="background"][style*="rgb(26, 42, 74)"] h2 {
  max-width: 848px;
}

/* =========================================================
   CONTAINERS GLOBAL — TODAS las top-sections a max-width 1200px
   Sin padding acumulado (section=0 lateral, container=responsive, widget-wrap=0)
   ========================================================= */
.escoland .elementor-section.elementor-top-section {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.escoland .elementor-section.elementor-top-section > .elementor-container {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 32px;
  padding-right: 32px;
}
/* Hero foto se permite expandir a 100% del column */
.escoland .elementor-18 .elementor-section:first-of-type > .elementor-container {
  max-width: 1280px !important;
}
/* Elementor agrega 10px padding al .elementor-element-populated por default — quitarlo */
.escoland .elementor-section.elementor-top-section .elementor-element-populated {
  padding: 0 !important;
}

@media (max-width: 1024px) {
  .escoland .elementor-section.elementor-top-section > .elementor-container {
    padding-left: 24px;
    padding-right: 24px;
  }
}
@media (max-width: 640px) {
  .escoland .elementor-section.elementor-top-section > .elementor-container {
    padding-left: 18px;
    padding-right: 18px;
  }
}
@media (max-width: 380px) {
  .escoland .elementor-section.elementor-top-section > .elementor-container {
    padding-left: 14px;
    padding-right: 14px;
  }
}

/* Buscamos / Ofrecemos grids también limitados a 1200px */
.escoland .buscamos-grid,
.escoland .ofrecemos-grid {
  max-width: 1200px !important;
}

/* Hero column 1 (left) — logo limitado a 195px width como el original */
.escoland .elementor-18 .elementor-section:first-of-type .elementor-column:nth-child(1) .elementor-widget-image:first-of-type img {
  max-width: 195px;
  width: 195px;
  height: auto;
  display: block;
}

/* Foto del equipo (column 2) — SIN radius, SIN shadow, ancho del column hasta 592px */
.escoland .elementor-18 .elementor-section:first-of-type .elementor-column:nth-child(2) .elementor-widget-image {
  text-align: center;
}
.escoland .elementor-18 .elementor-section:first-of-type .elementor-column:nth-child(2) .elementor-widget-image img {
  border-radius: 0;
  box-shadow: none;
  width: 100%;
  max-width: 592px;
  height: auto;
}

/* Icon widgets STACKED (contacto) — círculo redondeado + tamaño consistente */
.escoland .elementor-widget-icon .elementor-icon.elementor-view-stacked {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.escoland .elementor-widget-icon .elementor-icon.elementor-view-stacked i {
  font-size: 22px;
}

/* Headings con background inline (pills) — vertical-align nice */
.escoland .elementor-widget-heading .elementor-heading-title {
  display: inline-block;
}
.escoland .elementor-widget-heading {
  text-align: inherit;
}

/* Card hover effect: translateY -6px */
.escoland .elementor-column[data-element_type="column"]:has(> .elementor-element-populated[style*="border"]):hover,
.escoland section.elementor-inner-section .elementor-column:hover .elementor-element-populated {
  transform: translateY(-6px);
  transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, border-color .3s;
}
.escoland .elementor-inner-section .elementor-column .elementor-element-populated {
  transition: transform .3s cubic-bezier(.2,.7,.2,1), box-shadow .3s, border-color .3s;
}

/* Botones Elementor — radius consistente + transición */
.escoland .elementor-widget-button .elementor-button {
  transition: transform .2s, background .2s, box-shadow .2s;
}
.escoland .elementor-widget-button .elementor-button:hover {
  transform: translateY(-2px);
}

/* Strong dentro de Text Editor en hero */
.escoland .elementor-widget-text-editor strong {
  color: var(--navy);
  font-weight: 700;
}

/* Hero image alignment fix */
.escoland .elementor-element[data-element_type="section"]:first-of-type .elementor-column:nth-child(2) .elementor-widget-image {
  text-align: center;
}

/* ============ HERO ============ */
.escoland .hero,
.escoland .elementor-element.hero {
  background: var(--bg-white);
  overflow: hidden;
}
.escoland .elementor-element.hero { padding-top: 80px; padding-bottom: 96px; }
.escoland .elementor-element.hero > .elementor-container {
  max-width: 1200px;
  align-items: center;
}
.escoland .hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 64px;
  align-items: center;
}
/* Override Elementor heading default size/margins for hero h1/h2 */
.escoland .elementor-element.hero-left .elementor-heading-title {
  margin: 0 0 24px;
}
.escoland .elementor-element.hero-left .elementor-widget-heading h1.elementor-heading-title {
  font-family: 'Archivo Black', sans-serif;
  font-weight: 400;
  font-size: clamp(56px, 8vw, 112px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--navy);
}
.escoland .elementor-element.hero-left .elementor-widget-heading h2.elementor-heading-title {
  font-family: 'Archivo Black', sans-serif;
  font-weight: 400;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.01em;
  color: var(--navy);
  margin: 0 0 16px;
}
.escoland .elementor-element.hero-left .hero-lede .elementor-widget-container {
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 460px;
  margin-bottom: 28px;
}
.escoland .elementor-element.hero-left .hero-lede strong { color: var(--navy); font-weight: 700; }
.escoland .elementor-element.hero-left .hero-eyebrow .elementor-widget-container {
  font-size: 16px;
  color: var(--muted);
  margin-bottom: 12px;
}
.escoland .elementor-element.hero-left .hero-sub .elementor-widget-container {
  font-size: 16px;
  color: var(--muted);
  max-width: 420px;
  margin-bottom: 36px;
}
.escoland .elementor-element.hero-logo .elementor-widget-container {
  margin-bottom: 32px;
}
.escoland .hero-logo {
  width: 240px;
  margin-bottom: 32px;
}
.escoland .hero-h1 {
  font-family: 'Archivo Black', sans-serif;
  font-weight: 400;
  font-size: clamp(56px, 8vw, 112px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  color: var(--navy);
  margin: 0 0 24px;
}
.escoland .hero-h1 span { display: block; }
.escoland .hero-h1 .accent { color: var(--navy); }
.escoland .hero-lede {
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink);
  max-width: 460px;
  margin: 0 0 28px;
}
.escoland .hero-lede strong { color: var(--navy); font-weight: 700; }
.escoland .hero-eyebrow {
  font-size: 16px;
  color: var(--muted);
  margin: 0 0 12px;
}
.escoland .hero-pill {
  display: inline-block;
  background: var(--cyan);
  color: var(--navy);
  font-family: 'Archivo Black', sans-serif;
  padding: 8px 18px;
  border-radius: 8px;
  letter-spacing: 0.04em;
  font-size: 14px;
  margin-bottom: 16px;
}
.escoland .hero-h2 {
  font-family: 'Archivo Black', sans-serif;
  font-weight: 400;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 0.95;
  letter-spacing: -0.01em;
  color: var(--navy);
  margin: 0 0 16px;
}
.escoland .hero-h2 span { display: block; }
.escoland .hero-sub {
  font-size: 16px;
  color: var(--muted);
  max-width: 420px;
  margin: 0 0 36px;
}
.escoland .cta-outline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1.6px solid var(--navy);
  color: var(--navy);
  font-family: 'Archivo Black', sans-serif;
  padding: 16px 40px;
  border-radius: 8px;
  font-size: 15px;
  letter-spacing: 0.04em;
  transition: background .2s, color .2s, transform .2s;
}
.escoland .cta-outline:hover {
  background: var(--navy);
  color: #fff;
  transform: translateY(-2px);
}
.escoland .cta-outline svg { width: 18px; height: 18px; }

.escoland .hero-photo-wrap {
  position: relative;
  display: flex;
  justify-content: center;
}
.escoland .hero-photo {
  width: 100%;
  max-width: 520px;
  border-radius: 24px;
  box-shadow: 0 30px 60px -20px rgba(26, 42, 74, 0.25);
}

/* ============ SECTION HEADER ============ */
.escoland .sec-header { text-align: center; margin-bottom: 64px; }
.escoland .sec-eyebrow {
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--cyan);
  font-weight: 600;
  margin: 0 0 12px;
}
.escoland .sec-h2 {
  font-family: 'Archivo Black', sans-serif;
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.01em;
  color: var(--navy);
  margin: 0;
}

/* ============ BUSCAMOS ============ */
.escoland .buscamos,
.escoland .elementor-element.buscamos > .elementor-container {
  background: var(--bg-white);
}
.escoland .elementor-element.buscamos { padding-top: 128px; padding-bottom: 128px; }
.escoland .cards-4,
.escoland .elementor-element.cards-4 > .elementor-container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.escoland .card-num,
.escoland .elementor-element.card-num {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 16px;
  position: relative;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.escoland .elementor-element.card-num > .elementor-widget-wrap,
.escoland .elementor-element.card-num > .elementor-element-populated > .elementor-widget-wrap {
  padding: 32px 28px !important;
  display: block !important;
}
.escoland .card-num:hover,
.escoland .elementor-element.card-num:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px -16px rgba(26, 42, 74, 0.18);
  border-color: var(--cyan);
}
.escoland .card-num .num,
.escoland .elementor-element.card-num .num .elementor-heading-title,
.escoland .elementor-element.card-num .elementor-widget:first-child .elementor-heading-title {
  font-family: 'Archivo Black', sans-serif !important;
  font-size: 48px !important;
  color: var(--cyan) !important;
  line-height: 1 !important;
  margin: 0 0 8px !important;
}
.escoland .elementor-element.card-num .elementor-icon {
  color: var(--navy);
  fill: var(--navy);
  margin-bottom: 20px;
}
.escoland .elementor-element.card-num .elementor-icon svg,
.escoland .elementor-element.card-num .elementor-icon i {
  width: 36px;
  height: 36px;
  font-size: 36px;
}
.escoland .card-num h3,
.escoland .elementor-element.card-num h3,
.escoland .elementor-element.card-num .elementor-heading-title {
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.25;
  color: var(--navy);
  margin: 0 0 12px;
}
.escoland .card-num p,
.escoland .elementor-element.card-num p {
  font-size: 15px;
  line-height: 1.55;
  color: var(--muted);
  margin: 0;
}

/* ============ OFRECEMOS ============ */
.escoland .ofrecemos,
.escoland .elementor-element.ofrecemos {
  background: var(--bg-soft);
}
.escoland .elementor-element.ofrecemos { padding-top: 128px; padding-bottom: 128px; }
.escoland .cards-3,
.escoland .elementor-element.cards-3 > .elementor-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.escoland .card-offer,
.escoland .elementor-element.card-offer {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 18px;
  text-align: left;
  transition: transform .3s, box-shadow .3s;
}
.escoland .elementor-element.card-offer > .elementor-widget-wrap,
.escoland .elementor-element.card-offer > .elementor-element-populated > .elementor-widget-wrap {
  padding: 40px 32px !important;
  display: block !important;
}
.escoland .card-offer:hover,
.escoland .elementor-element.card-offer:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px -16px rgba(26, 42, 74, 0.18);
}
.escoland .elementor-element.card-offer h3,
.escoland .elementor-element.card-offer .elementor-heading-title {
  font-family: 'Inter Tight', 'Inter', sans-serif !important;
  font-weight: 700 !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  color: var(--navy) !important;
  margin: 0 0 12px !important;
}
.escoland .elementor-element.card-offer p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--muted);
  margin: 0;
}
.escoland .card-offer .badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--cyan);
  color: var(--navy);
  font-family: 'Archivo Black', sans-serif;
  font-size: 14px;
  padding: 10px 16px;
  border-radius: 10px;
  margin-bottom: 24px;
}
.escoland .card-offer .badge svg { width: 18px; height: 18px; }
.escoland .card-offer .chip {
  display: inline-block;
  background: var(--bg-soft);
  color: var(--navy);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 999px;
  margin-bottom: 16px;
}
.escoland .card-offer h3 {
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.2;
  color: var(--navy);
  margin: 0 0 12px;
}
.escoland .card-offer p {
  font-size: 15px;
  line-height: 1.6;
  color: var(--muted);
  margin: 0;
}

/* ============ CTA FINAL custom button ============ */
.escoland .cta-final-btn-wrap { text-align: center; }
.escoland .cta-final-btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: #1A9FC1;
  color: #1A2A4A;
  font-family: 'Archivo Black', sans-serif;
  font-size: 18px;
  padding: 22px 42px;
  border-radius: 8px;
  text-decoration: none;
  box-shadow: 0 14px 40px -10px rgba(26,159,193,0.55);
  transition: transform .2s, background .2s, box-shadow .2s;
  letter-spacing: 0.02em;
}
.escoland .cta-final-btn:hover {
  transform: translateY(-3px);
  background: #4FB8D4;
  box-shadow: 0 20px 48px -10px rgba(26,159,193,0.7);
  color: #1A2A4A;
}
.escoland .cta-final-btn svg { flex: 0 0 auto; }
@media (max-width: 540px) {
  .escoland .cta-final-btn { font-size: 15px; padding: 18px 28px; gap: 10px; }
  .escoland .cta-final-btn svg { width: 16px; height: 16px; }
}

/* ============ CTA FINAL — pattern decorativo círculos concéntricos visibles ============ */
.escoland .elementor-section.elementor-top-section:nth-of-type(4) {
  position: relative;
  overflow: hidden;
}
.escoland .elementor-section.elementor-top-section:nth-of-type(4)::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 900px;
  height: 900px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 900 900' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='rgba(255,255,255,0.07)' stroke-width='1'%3E%3Ccircle cx='450' cy='450' r='130'/%3E%3Ccircle cx='450' cy='450' r='220'/%3E%3Ccircle cx='450' cy='450' r='310'/%3E%3Ccircle cx='450' cy='450' r='400'/%3E%3Ccircle cx='450' cy='450' r='449'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 0;
}
.escoland .elementor-section.elementor-top-section:nth-of-type(4) > .elementor-container {
  position: relative;
  z-index: 1;
}

/* Lede del CTA Final — 460px centrado, wrap 2 líneas */
.escoland .elementor-section.elementor-top-section:nth-of-type(4) .elementor-widget-text-editor:first-of-type .elementor-widget-container {
  max-width: 460px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.escoland .elementor-section.elementor-top-section:nth-of-type(4) .elementor-widget-text-editor:first-of-type p {
  max-width: 460px;
  margin: 0 auto;
}

/* CTA Final inner: centrado a 760px dentro del container 1200 */
.escoland .elementor-section.elementor-top-section:nth-of-type(4) > .elementor-container > .elementor-column > .elementor-element-populated {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}

/* ============ FINAL CTA (navy) ============ */
.escoland .cta-final,
.escoland .elementor-element.cta-final {
  background: var(--navy);
  color: #fff;
  text-align: center;
}
.escoland .elementor-element.cta-final { padding-top: 144px; padding-bottom: 144px; }
.escoland .cta-final .sec-eyebrow { color: var(--cyan); }
.escoland .cta-final .sec-h2 { color: #fff; }
.escoland .elementor-element.cta-final .elementor-widget-container { text-align: center; }
.escoland .cta-final-lede {
  max-width: 620px;
  margin: 24px auto 48px;
  color: rgba(255,255,255,0.78);
  font-size: 18px;
  line-height: 1.6;
}
.escoland .cta-cyan {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--cyan);
  color: var(--navy);
  font-family: 'Archivo Black', sans-serif;
  padding: 24px 64px;
  border-radius: 12px;
  font-size: 16px;
  letter-spacing: 0.04em;
  box-shadow: 0 14px 40px -10px rgba(26, 159, 193, 0.55);
  transition: transform .2s, box-shadow .2s, background .2s;
}
.escoland .cta-cyan:hover {
  transform: translateY(-3px);
  background: var(--cyan-soft);
  box-shadow: 0 20px 48px -10px rgba(26, 159, 193, 0.7);
}
.escoland .cta-cyan svg { width: 22px; height: 22px; }
.escoland .email-link {
  display: block;
  margin-top: 28px;
  color: var(--cyan);
  font-size: 15px;
  letter-spacing: 0.02em;
}
.escoland .email-link:hover { color: #fff; text-decoration: underline; }

/* ============ CONTACTO ============ */
.escoland .contacto,
.escoland .elementor-element.contacto {
  background: var(--bg-white);
  border-top: 1px solid var(--border);
}
.escoland .elementor-element.contacto { padding-top: 128px; padding-bottom: 128px; }
.escoland .contact-grid,
.escoland .elementor-element.contact-grid > .elementor-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 56px;
}
.escoland .contact-card,
.escoland .elementor-element.contact-card {
  background: var(--bg-soft);
  border: 1px solid var(--border);
  border-radius: 18px;
  text-align: left;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.escoland .elementor-element.contact-card > .elementor-widget-wrap,
.escoland .elementor-element.contact-card > .elementor-element-populated > .elementor-widget-wrap {
  padding: 36px 30px !important;
  display: block !important;
}
.escoland .contact-card:hover,
.escoland .elementor-element.contact-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 48px -16px rgba(26, 42, 74, 0.18);
  border-color: var(--cyan);
}
.escoland .elementor-element.contact-card h3,
.escoland .elementor-element.contact-card .elementor-heading-title {
  font-family: 'Inter Tight', 'Inter', sans-serif !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  color: var(--navy) !important;
  margin: 0 0 10px !important;
}
.escoland .contact-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--cyan);
  color: var(--navy);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.escoland .contact-icon svg { width: 26px; height: 26px; }
.escoland .contact-card h3 {
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: var(--navy);
  margin: 0 0 10px;
}
.escoland .contact-card p {
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink);
  margin: 0 0 14px;
}
.escoland .contact-card p a { color: var(--navy); font-weight: 600; }
.escoland .contact-card p a:hover { color: var(--cyan); text-decoration: underline; }
.escoland .contact-link {
  display: inline-block;
  color: var(--cyan);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
}
.escoland .contact-link:hover { color: var(--navy); }
.escoland .email-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.escoland .email-list li {
  font-size: 14px;
  line-height: 1.7;
  color: var(--muted);
}
.escoland .email-list li strong { color: var(--navy); margin-right: 4px; }
.escoland .email-list a { color: var(--navy); font-weight: 500; }
.escoland .email-list a:hover { color: var(--cyan); text-decoration: underline; }
.escoland .map-wrap {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 48px -22px rgba(26, 42, 74, 0.35);
  border: 1px solid var(--border);
}
.escoland .map-wrap iframe { display: block; }

/* ============ FOOTER ============ */
.escoland .site-footer {
  background: var(--navy-deep);
  color: rgba(255,255,255,0.8);
  padding: 56px 0 40px;
  text-align: center;
}
.escoland .footer-logo {
  width: 180px;
  margin: 0 auto 18px;
  filter: brightness(0) invert(1);
  opacity: 0.92;
}
.escoland .footer-tagline {
  font-family: 'Archivo Black', sans-serif;
  font-size: 14px;
  letter-spacing: 0.18em;
  color: #fff;
  margin: 0 0 22px;
}
.escoland .footer-social {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin: 0 0 28px;
}
.escoland .footer-social a {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, transform .2s, color .2s;
}
.escoland .footer-social a:hover {
  background: var(--cyan);
  color: var(--navy);
  transform: translateY(-2px);
}
.escoland .footer-social svg { width: 20px; height: 20px; }
.escoland .footer-legal {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 22px;
  margin-top: 6px;
}
.escoland .footer-legal p {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  margin: 0 0 6px;
}
.escoland .footer-legal strong { color: #fff; letter-spacing: 0.04em; }
.escoland .footer-copy {
  font-size: 12px !important;
  color: rgba(255,255,255,0.45) !important;
  margin: 0 !important;
}

/* ============ THEME BUILDER FOOTER ============ */
.esc-footer-tb {
  color: rgba(255,255,255,0.82);
  font-family: 'Inter', sans-serif;
}
.esc-footer-top {
  padding: 64px 32px 40px;
  max-width: 1280px;
  margin: 0 auto;
}
.esc-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 40px;
  align-items: start;
}
.esc-footer-brand .esc-footer-logo {
  width: 200px;
  margin-bottom: 14px;
  filter: brightness(0) invert(1);
  opacity: 0.95;
  display: block;
}
.esc-footer-brand .esc-footer-tagline {
  font-family: 'Archivo Black', sans-serif;
  font-size: 14px;
  letter-spacing: 0.18em;
  color: #fff;
  margin: 0;
}
.esc-footer-col h4 {
  font-family: 'Archivo Black', sans-serif;
  font-size: 14px;
  letter-spacing: 0.12em;
  color: #fff;
  margin: 0 0 14px;
  text-transform: uppercase;
}
.esc-footer-col p {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.72);
  margin: 0 0 8px;
}
.esc-footer-col a {
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  transition: color .2s;
}
.esc-footer-col a:hover { color: #1A9FC1; }
.esc-footer-col strong { color: #fff; font-weight: 600; margin-right: 4px; }
.esc-footer-social {
  display: flex;
  gap: 12px;
  margin-top: 4px;
}
.esc-footer-social a {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, transform .2s, color .2s;
}
.esc-footer-social a:hover {
  background: #1A9FC1;
  color: #1A2A4A;
  transform: translateY(-3px);
}
.esc-footer-social svg { width: 20px; height: 20px; }
.esc-footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 22px 32px 28px;
  text-align: center;
  max-width: 1280px;
  margin: 0 auto;
}
.esc-footer-bottom p {
  font-size: 13px;
  color: rgba(255,255,255,0.65);
  margin: 0 0 6px;
}
.esc-footer-bottom p strong { color: #fff; letter-spacing: 0.04em; }
.esc-footer-bottom .esc-copy {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  margin: 0;
}
@media (max-width: 900px) {
  .esc-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 560px) {
  .esc-footer-grid { grid-template-columns: 1fr; gap: 28px; text-align: left; }
  .esc-footer-top { padding: 48px 22px 32px; }
  .esc-footer-bottom { padding: 20px 22px 24px; }
}

/* ============ MODERN HEADER FIXED (nunca scroll) ============ */
.elementor-location-header {
  position: fixed !important;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 999;
  margin-top: 0;
  padding-top: 0;
}
/* Compensar espacio del header fixed con padding-top en page 18 */
body .elementor-18 { padding-top: 72px; }
@media (max-width: 480px) { body .elementor-18 { padding-top: 66px; } }
/* Header section/column/widget sin padding extra (forzar 0) */
.elementor-location-header > .elementor,
.elementor-location-header section.elementor-section,
.elementor-location-header section.elementor-section > .elementor-container,
.elementor-location-header .elementor-column,
.elementor-location-header .elementor-element-populated,
.elementor-location-header .elementor-widget,
.elementor-location-header .elementor-widget-container {
  padding: 0 !important;
  margin: 0 !important;
}
/* Cuando WP admin bar está presente, ajustar top del sticky */
body.admin-bar .elementor-location-header { top: 32px; }
@media screen and (max-width: 782px) {
  body.admin-bar .elementor-location-header { top: 46px; }
}
/* Sin espacios fantasma encima del header */
.elementor-location-header,
.elementor-location-header > div,
.elementor-location-header > div > div,
.elementor-location-header > section,
.elementor-location-header section.elementor-section { margin-top: 0 !important; }
/* Body sin margin top extra */
.escoland .elementor-page-wrapper, .escoland #content, .escoland #page {
  margin-top: 0 !important;
  padding-top: 0 !important;
}
.elementor-location-header > .elementor,
.elementor-location-header section,
.elementor-location-header .elementor-section,
.elementor-location-header .elementor-container,
.elementor-location-header .elementor-column-wrap,
.elementor-location-header .elementor-widget-wrap,
.elementor-location-header .elementor-widget-html {
  padding: 0 !important;
  margin: 0 !important;
}

.esc-nav-wrap {
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(26, 42, 74, 0.06);
  box-shadow: 0 1px 0 rgba(26,42,74,0.04), 0 6px 20px -12px rgba(26,42,74,0.18);
  transition: background .25s, box-shadow .25s;
  position: relative;
  z-index: 100;
}
.esc-nav {
  max-width: 1320px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 32px;
}
.esc-nav-logo {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  transition: transform .2s;
}
.esc-nav-logo:hover { transform: translateY(-1px); }
.esc-nav-logo img {
  width: 160px;
  height: auto;
  display: block;
}
.esc-nav-menu {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.esc-nav-menu a {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--navy);
  padding: 10px 16px;
  border-radius: 999px;
  text-decoration: none;
  position: relative;
  transition: color .2s, background .2s;
}
.esc-nav-menu a::before,
.esc-nav-menu a::after { display: none !important; }
.esc-nav-menu a:hover {
  color: var(--cyan);
  background: rgba(26, 159, 193, 0.08);
}
.esc-nav-cta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Archivo Black', sans-serif;
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--navy);
  background: linear-gradient(135deg, var(--cyan) 0%, #14B0D3 100%);
  padding: 12px 22px;
  border-radius: 10px;
  text-decoration: none;
  box-shadow: 0 8px 20px -6px rgba(26, 159, 193, 0.55);
  transition: transform .2s, box-shadow .2s, background .2s;
}
.esc-nav-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px -8px rgba(26, 159, 193, 0.7);
  background: linear-gradient(135deg, #28B5D8 0%, var(--cyan) 100%);
  color: var(--navy);
}
.esc-nav-cta svg { width: 14px; height: 14px; }

/* Mobile toggle (hamburger) — MODERN, brand colors */
.esc-nav-toggle {
  display: none;
  background: rgba(26, 159, 193, 0.12) !important;
  border: 0 !important;
  padding: 0 !important;
  cursor: pointer;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  position: relative;
  flex: 0 0 auto;
  transition: background .25s, transform .25s !important;
  outline: 0;
  -webkit-tap-highlight-color: transparent;
}
.esc-nav-toggle:hover,
.esc-nav-toggle:focus,
.esc-nav-toggle:active {
  background: rgba(26, 159, 193, 0.22) !important;
  color: inherit !important;
  border-color: transparent !important;
  outline: 0 !important;
}
.esc-nav-toggle span {
  position: absolute;
  left: 50%;
  width: 22px;
  height: 2.6px;
  background: var(--navy);
  border-radius: 4px;
  transform: translateX(-50%);
  transition: transform .35s cubic-bezier(.2,.7,.2,1), opacity .2s, top .35s cubic-bezier(.2,.7,.2,1), background .25s;
}
.esc-nav-toggle span:nth-child(1) { top: 15px; }
.esc-nav-toggle span:nth-child(2) { top: 22px; }
.esc-nav-toggle span:nth-child(3) { top: 29px; }
.esc-nav-wrap.open .esc-nav-toggle {
  background: var(--cyan) !important;
}
.esc-nav-wrap.open .esc-nav-toggle span { background: #fff; }
.esc-nav-wrap.open .esc-nav-toggle span:nth-child(1) { top: 22px; transform: translateX(-50%) rotate(45deg); }
.esc-nav-wrap.open .esc-nav-toggle span:nth-child(2) { opacity: 0; }
.esc-nav-wrap.open .esc-nav-toggle span:nth-child(3) { top: 22px; transform: translateX(-50%) rotate(-45deg); }

/* Mobile menu panel — dark elegant slide-down */
.esc-nav-mobile {
  display: none;
  flex-direction: column;
  background: linear-gradient(180deg, var(--navy) 0%, var(--navy-deep) 100%);
  padding: 22px 22px 28px;
  gap: 2px;
  box-shadow: 0 18px 36px -12px rgba(0,0,0,0.35);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.esc-nav-wrap.open .esc-nav-mobile {
  display: flex;
  animation: navSlideDown .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes navSlideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to { opacity: 1; transform: translateY(0); }
}
.esc-nav-mobile a {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.92);
  padding: 16px 14px;
  border-radius: 12px;
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background .25s, color .25s, padding-left .25s;
  display: flex;
  align-items: center;
}
.esc-nav-mobile a:last-of-type { border-bottom: 0; }
.esc-nav-mobile a:hover,
.esc-nav-mobile a:focus {
  background: rgba(26, 159, 193, 0.16);
  color: var(--cyan);
  padding-left: 24px;
}
.esc-nav-mobile-cta {
  margin-top: 16px !important;
  background: linear-gradient(135deg, var(--cyan) 0%, #14B0D3 100%) !important;
  color: var(--navy) !important;
  font-family: 'Archivo Black', sans-serif !important;
  text-align: center !important;
  justify-content: center !important;
  border-bottom: none !important;
  letter-spacing: 0.08em !important;
  box-shadow: 0 10px 24px -8px rgba(26, 159, 193, 0.55);
  padding: 18px 14px !important;
}
.esc-nav-mobile-cta:hover {
  background: linear-gradient(135deg, #28B5D8 0%, var(--cyan) 100%) !important;
  color: var(--navy) !important;
  padding-left: 14px !important;
}

@media (max-width: 960px) {
  .esc-nav { padding: 12px 18px; gap: 12px; }
  .esc-nav-logo img { width: 130px; }
  .esc-nav-menu { display: none; }
  .esc-nav-cta { display: none; }
  .esc-nav-toggle { display: inline-flex; }
}

/* Hide the (now-deprecated) inline child-theme footer/social/legal since Theme Builder owns these */
.escoland .site-footer { display: none !important; }

/* ============ WHATSAPP FLOATING (modern) ============ */
.escoland .wa-fab {
  position: fixed;
  right: 28px;
  bottom: 28px;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 12px 28px -8px rgba(37, 211, 102, 0.55),
    0 0 0 0 rgba(37, 211, 102, 0.45);
  z-index: 9999;
  transition: transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s;
  text-decoration: none;
}
.escoland .wa-fab:hover {
  transform: translateY(-4px) scale(1.06);
  box-shadow:
    0 20px 40px -10px rgba(37, 211, 102, 0.7),
    0 0 0 8px rgba(37, 211, 102, 0.12);
  color: #fff;
}
.escoland .wa-fab:active { transform: translateY(-2px) scale(1.02); }
.escoland .wa-fab-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}
.escoland .wa-fab-icon svg {
  width: 32px;
  height: 32px;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,0.18));
}
.escoland .wa-fab-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: #25D366;
  z-index: 1;
  animation: wa-pulse 2.4s ease-out infinite;
  pointer-events: none;
}
@keyframes wa-pulse {
  0%   { transform: scale(1);   opacity: 0.55; }
  70%  { transform: scale(1.6); opacity: 0; }
  100% { transform: scale(1.6); opacity: 0; }
}
.escoland .wa-fab-tooltip {
  position: absolute;
  right: calc(100% + 14px);
  top: 50%;
  transform: translateY(-50%) translateX(8px);
  background: var(--navy);
  color: #fff;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.02em;
  padding: 10px 16px;
  border-radius: 10px;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s, transform .2s;
  box-shadow: 0 10px 24px -10px rgba(26, 42, 74, 0.4);
}
.escoland .wa-fab-tooltip::after {
  content: '';
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent;
  border-left-color: var(--navy);
}
.escoland .wa-fab:hover .wa-fab-tooltip {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
@media (max-width: 520px) {
  .escoland .wa-fab { width: 58px; height: 58px; right: 18px; bottom: 18px; }
  .escoland .wa-fab-icon svg { width: 28px; height: 28px; }
  .escoland .wa-fab-tooltip { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .escoland .wa-fab-pulse { animation: none; }
}

/* ============ RESPONSIVE ============ */
@media (max-width: 1024px) {
  .escoland .cards-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
  .escoland .hero { padding: 56px 0 64px; }
  .escoland .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .escoland .hero-photo { max-width: 100%; }
  .escoland .buscamos, .escoland .ofrecemos { padding: 80px 0; }
  .escoland .cta-final { padding: 96px 0; }
  .escoland .cards-3 { grid-template-columns: 1fr; }
  .escoland .contact-grid { grid-template-columns: 1fr; }
  .escoland .contacto { padding: 80px 0; }
  .escoland .sec-header { margin-bottom: 40px; }
  .escoland .cta-cyan { padding: 18px 36px; font-size: 14px; }
  .escoland .map-wrap iframe { height: 280px; }
}
@media (max-width: 520px) {
  .escoland .cards-4 { grid-template-columns: 1fr; }
  .escoland .hero-logo { width: 180px; }
  .escoland .hero-h1 { font-size: clamp(44px, 13vw, 80px); }
  .escoland .hero-h2 { font-size: clamp(32px, 9vw, 52px); }
  .escoland .container { padding: 0 18px; }
  .escoland .cta-outline,
  .escoland .cta-cyan { padding: 14px 22px; font-size: 13px; }
  .escoland .cta-outline svg,
  .escoland .cta-cyan svg { width: 16px; height: 16px; }
  .escoland .sec-h2 { font-size: clamp(28px, 8vw, 44px); }
  .escoland .cta-final { padding: 72px 0; }
  .escoland .map-wrap iframe { height: 240px; }
  .escoland .footer-legal p,
  .esc-footer-bottom p { font-size: 12px; word-break: break-word; }
}
@media (max-width: 360px) {
  .escoland .hero { padding: 40px 0 48px; }
  .escoland .buscamos, .escoland .ofrecemos { padding: 64px 0; }
  .escoland .contacto { padding: 64px 0; }
  .escoland .card-num, .escoland .card-offer, .escoland .contact-card { padding: 26px 22px; }
}

/* Hide Hello Elementor parent header/footer chrome since we use front-page.php as full page */
.escoland .hello-elementor-header,
.escoland .site-header,
.escoland .site-footer-wrapper { display: none !important; }
