:root{
  --p1:#6a7fdb; /* azul */
  --p2:#5ec6b8; /* turquesa */
  --p3:#ff8c78; /* coral */
  --ink:#0f172a;
  --muted:#64748b;
  --bg:#ffffff;
  --soft:#f4ede3;
  --line:#e5e7eb;
  --card:#ffffffcc;
  --shadow: 0 10px 30px rgba(15,23,42,.12);
  --radius:18px;
  --container: 1100px;
  --pad: 18px;
}




*{ box-sizing:border-box; }

body{
  margin: 0;
  font-family: system-ui, "Segoe UI Variable", "SF Pro Display", "SF Pro Text", Roboto, Arial, sans-serif;
  color: var(--ink);
  background: var(--bg);
  width: 100%;
}




@media (max-width: 920px){
  body{
    margin: 0;
    width: 100vw;          /* usa todo el viewport */   
    overflow-x: hidden;   /* evita desbordes horizontales */
    font-family: system-ui, "Segoe UI Variable", "SF Pro Display", "SF Pro Text", Roboto, Arial, sans-serif;
    color: var(--ink);
    background: var(--bg);
  }

  .header{
  width: 100%;
  z-index: 1000;

  background: linear-gradient(
    to bottom,
    rgba(106,127,219,.85),
    rgba(37,84,116,.35)
  );

  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255,255,255,0.18);
  transition: background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
}

.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;   /* un poco más alto */
  gap:16px;
}


}


.container{
  width:min(var(--container), calc(100% - 2*var(--pad)));
  margin-inline:auto;
}

.muted{ color:var(--muted); }
.center{ text-align:center; }

/* =========================
   HEADER / NAV (LIMPIO)
   ========================= */
.header{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;

  background: linear-gradient(
    to bottom,
    rgba(106,127,219,.85),
    rgba(37,84,116,.35)
  );

  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(255,255,255,0.18);
  transition: background .3s ease, border-color .3s ease, backdrop-filter .3s ease;
}

/* Header cuando scrolleas */
.header.scrolled{
  background: linear-gradient(
    to bottom,
    rgba(106,127,219,.92),
    rgba(37,84,116,.45)
  );
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,0.28);
}

.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;   /* un poco más alto */
  gap:16px;
}


/* Marca */
.brand{ text-decoration:none; color:#fff; }
.brand__logo{
  color:#fff;
  font-weight:900;
  letter-spacing:.5px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  color:#fff;
}

.brand__img{
  height: 44px;           /* tamaño “normal” header */
  width: auto;
  display:block;
  object-fit: contain;
}

@media (max-width: 920px){
  .brand__img{ height: 38px; }
}





/* Nav */
.nav{
  display:flex;
  gap:18px;
  align-items:center;
}

.header .nav a{
  position: relative;
  text-decoration:none;
  color:#fff;
  font-weight:600;
  font-size:14px;
  padding: 8px 12px;
  border-radius: 999px;
  opacity: .95;
  transition: opacity .25s ease, transform .25s ease;
}

.header .nav a:hover{
  opacity: 1;
  transform: translateY(-1px);
}

/* Glow tipo “portal” en hover */
.header .nav a::before{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255,255,255,.55), transparent 65%);
  opacity: 0;
  filter: blur(12px);
  transition: opacity .25s ease, transform .25s ease;
  pointer-events:none;
}

.header .nav a:hover::before{
  opacity: 1;
  transform: scale(1.05);
}

/* CTA (Contacto) estilo glass */
.header .nav__cta{
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.32);
  color:#fff !important;
  backdrop-filter: blur(8px);
}

.header .nav__cta:hover{
  background: rgba(255,255,255,.28);
}

/* Toggle mobile */
.nav__toggle{
  display:none;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.14);
  color:#fff;
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
}


/* HERO */
.hero{
  position: relative;
  min-height: 520px;
  border-bottom:1px solid var(--line);
  padding-top: 72px; /* para que el contenido (login) no quede debajo del header */
}
.hero__bg{
  position: absolute;
  inset: 0;

  background-image: url("../landpage.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  z-index: 0;
}
.hero__bg::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.2); /* overlay suave */
  pointer-events: none;
  z-index: 1;
}



.hero__inner{
  position: relative;
  min-height: 520px;

  display: flex;
  justify-content: center;   /* centra horizontal */
  align-items: center;       /* centra vertical */

  z-index: 2;
}


/* Cards / Buttons */
.card{
  background: var(--card);
  border:1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.login{
  padding: 18px;
  background: rgba(15,23,42,.65);
  color:#fff;
  border: 0;
  width: 360px;
  max-width: 90%;
}

.login h2{ margin:0 0 12px; }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 10px 14px;
  border-radius: 12px;
  border:1px solid transparent;
  cursor:pointer;
  font-weight:700;
  text-decoration:none;
}
.btn--primary{
  background: var(--p3);
  color:#fff;
}
.btn--primary:hover{ filter:brightness(.98); }
.btn--ghost{
  background: transparent;
  border-color: var(--line);
  color: var(--ink);
}

.form{ display:grid; gap:10px; }
.form__label{ display:grid; gap:6px; font-size:13px; }
.form__input{
  width:100%;
  border-radius:12px;
  border:1px solid var(--line);
  padding: 10px 12px;
  outline:none;
  font-size:14px;
}
.login .form__input{
  border:0;
  background:#fff;
}
.form__textarea{ resize:vertical; }
.form__hint{ margin:0; font-size:13px; opacity:.9; min-height:18px; }

/* Sections */
.section{
  padding: 48px 0;
  border-bottom:1px solid var(--line);
  scroll-margin-top: 84px; /* para que los anchors no queden bajo el header */
}

/* Variantes de sección */
.section--tight{
  padding: 32px 0;   /* menos aire (ideal para video) */
}

.section--soft{
  background: linear-gradient(180deg, #fff, #f8fafc);
}

.section__title{
  text-align: center;
  margin: 0 0 22px;
  font-size: clamp(26px, 2.4vw, 36px);
  letter-spacing: -.3px;
}


/* About */
.about{
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 32px;
  align-items: center;
}


.about__badge{
  display: flex;
  justify-content: center;
  align-items: center;
}

.about__graphic{
  width: 300px;       /* ajusta si quieres más grande */
  max-width: 100%;
  height: auto;
  display: block;
}

.lead{ margin:0; line-height:1.6; color: #0b1220; }

/* Grids */
.grid{ display:grid; gap:16px; }
.grid--3{ grid-template-columns: repeat(3, 1fr); }
.grid--2{ grid-template-columns: repeat(2, 1fr); }

.feature h3{ margin:0 0 8px; }
.feature p{ margin:0; color:var(--muted); line-height:1.5; }

/* === NUESTRA PROPUESTA: portales (PNG con todo adentro) === */

/* contenedor SIN look de tarjeta */
.feature.feature--portal{
  position: relative;
  display: block;
  padding: 0;                 /* QUITA padding para que no parezca bloque */
  background: transparent;     /* QUITA fondo blanco */
  border: 0;                  /* QUITA borde */
  box-shadow: none;           /* QUITA sombra */
  border-radius: 0;           /* opcional: la imagen ya trae su forma */
  cursor: pointer;
  overflow: visible;          /* para que el glow se vea afuera */
  text-decoration: none;      /* por si lo conviertes en <a> */
}

/* la imagen del portal: que ocupe el ancho real */
.portal__img{
  width: 100%;
  height: auto;               /* MUY importante: no la forces a 170px */
  display: block;
  transform: translateZ(0);   /* mejora suavidad */
  transition: filter .25s ease, transform .25s ease;
}

/* Glow “apagado” detrás del portal */
.feature.feature--portal::before{
  content:"";
  position:absolute;
  left:50%;
  top: 55%;                   /* centrado relativo al PNG */
  width: 92%;
  height: 70%;
  transform: translate(-50%, -50%) scale(.98);
  filter: blur(22px);
  opacity: 0;
  transition: opacity .25s ease, transform .25s ease;
  pointer-events:none;
}

/* Hover: NO se levanta un bloque, se activa el portal */
.feature.feature--portal:hover{
  transform: none;
}

/* Hover: glow aparece + imagen gana “vida” */
.feature.feature--portal:hover::before{
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.02);
}

.feature.feature--portal:hover .portal__img{
  transform: translateY(-2px);  /* micro movimiento, nada de “tarjeta flotante” */
  filter:
    drop-shadow(0 18px 35px rgba(106,127,219,.25))
    brightness(1.06)
    saturate(1.18);
}

/* Colores por portal */
.portal--green::before{
  background: radial-gradient(circle, rgba(34,197,94,.45), transparent 65%);
}
.portal--purple::before{
  background: radial-gradient(circle, rgba(106,127,219,.45), transparent 65%);
}
.portal--cyan::before{
  background: radial-gradient(circle, rgba(94,198,184,.50), transparent 65%);
}



/* Video button */
.video{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 18px 22px;
  border-radius: 18px;
  border:1px solid var(--line);
  background:#fff;
  box-shadow: var(--shadow);
  cursor:pointer;
}
.video__icon{
  width:44px; height:44px;
  border-radius:999px;
  display:grid; place-items:center;
  background: var(--p3);
  color:#fff;
  font-weight:900;
}

.video-wrapper{
  position: relative;
  width: 100%;
  max-width: 860px;
  aspect-ratio: 16 / 9;
  margin: 0 auto;
}

.video-wrapper iframe{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}


/* Wellbeing */
.wellbeing{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:18px;
  align-items:center;
}
.mock{
  position:relative;
  height: 220px;
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.mock__screen{
  height:100%;
  display:grid;
  place-items:center;
  color:var(--muted);
  font-weight:700;
}
.mock__next{
  position:absolute;
  right:10px; top:50%;
  transform: translateY(-50%);
  width:38px; height:38px;
  border-radius:999px;
  border:1px solid var(--line);
  background:#fff;
  cursor:pointer;
}

/* Purpose */
.purpose{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:16px;
  align-items:center;
}
.purpose__image{
  height: 180px;
  border-radius: var(--radius);
  border:1px solid var(--line);
  background:
    radial-gradient(600px 200px at 40% 40%, rgba(106,127,219,.25), transparent 60%),
    linear-gradient(135deg, #fff, #eef2ff);
  box-shadow: var(--shadow);
}

/* Contact */
.contact{
  display:grid;
  grid-template-columns: 1fr 1.2fr;
  gap:18px;
  align-items:start;
}
.stat{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding: 14px;
  border-radius: var(--radius);
  border:1px solid var(--line);
  background:#fff;
  box-shadow: 0 8px 22px rgba(15,23,42,.06);
  margin-bottom:12px;
}
.stat__icon{ font-size:22px; }

/* Footer */
.footer{
  background: #5b73db;
  color:#fff;
  padding: 22px 0 60px;
  position:relative;
}
.footer__inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
}
.footer__link{
  color:#fff;
  opacity:.9;
  text-decoration:none;
  font-size:17px;
}
.social{
  display:inline-grid;
  place-items:center;
  width:34px; height:34px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
  text-decoration:none;
  margin-left:8px;
  opacity:.95;
}
.whatsapp{
  position:fixed;
  right:16px;
  bottom:16px;
  background:#22c55e;
  color:#fff;
  padding: 12px 14px;
  border-radius:999px;
  text-decoration:none;
  box-shadow: var(--shadow);
  font-weight:800;
  display: inline-flex;      /* asegura alineación */
  align-items: center;       /* centra vertical texto + icono */
  gap: 8px;                  /* espacio limpio entre icono y texto */
}

/* Animación sutil tipo “respiración” */
@keyframes whatsapp-breathe{
  0%, 100%{
    box-shadow: var(--shadow);
  }
  50%{
    box-shadow: 0 12px 26px rgba(34,197,94,.45);
  }
}

.whatsapp{
  animation: whatsapp-breathe 4.5s ease-in-out infinite;
  transition: filter .25s ease;
}

/* Hover: feedback mínimo */
.whatsapp:hover{
  filter: brightness(1.05);
}

/* Click: casi imperceptible */
.whatsapp:active{
  filter: brightness(.95);
}

/* Respeta accesibilidad */
@media (prefers-reduced-motion: reduce){
  .whatsapp{
    animation: none;
  }
}

.whatsapp{
  transition:
    transform .18s ease,
    box-shadow .18s ease;
}

/* ÍCONO WHATSAPP DESDE IMAGEN */
.whatsapp::before{
  content:"";
  width: 18px;
  height: 18px;
  flex-shrink: 0;            /* evita que se deforme */
  background-image: url("../WhatsApp.svg.webp"); /* ajusta ruta si es necesario */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transform: translateY(-0.5px); /* micro-ajuste óptico */
}

/* Hover: movimiento mínimo */
.whatsapp:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 22px rgba(34,197,94,.35);
}

/* Click */
.whatsapp:active{
  transform: translateY(0);
}




/* Modal */
.modal{
  position:fixed;
  inset:0;
  display:none;
}
.modal[aria-hidden="false"]{ display:block; }
.modal__overlay{
  position:absolute;
  inset:0;
  background: rgba(15,23,42,.62);
}
.modal__content{
  position:relative;
  width:min(920px, calc(100% - 32px));
  margin: 8vh auto 0;
  background:#fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.modal__close{
  position:absolute;
  right:12px; top:12px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:12px;
  padding:8px 10px;
  cursor:pointer;
  z-index:2;
}
.modal__frame{
  padding: 32px;
  display:grid;
  place-items:center;
}
.modal__placeholder{
  color:var(--muted);
  font-weight:700;
}

/* Responsive */
@media (max-width: 920px){
  .hero__inner{ grid-template-columns: 1fr; padding: 18px 0; }
  .login{ max-width: 420px; }
  .about{ grid-template-columns: 1fr; text-align:center; }
  .about__graphic{
  width: 240px;
  margin: 0 auto;
}
  .grid--3{ grid-template-columns: 1fr; }
  .wellbeing{ grid-template-columns: 1fr; }
  .purpose{ grid-template-columns: 1fr; }
  .contact{ grid-template-columns: 1fr; }
.nav__toggle{ display:block; }

  .nav{
    position:absolute;
    right: var(--pad);
    top: 56px;
    background: rgba(106,127,219,.92);
    border:1px solid rgba(255,255,255,.22);
    border-radius: 16px;
    padding: 10px;
    flex-direction:column;
    align-items:stretch;
    display:none;
    backdrop-filter: blur(10px);
    box-shadow: 0 18px 45px rgba(15,23,42,.18);
  }

  .nav.is-open{ display:flex; }

}

/* =========================
   BIENESTAR: CARRUSEL PORTAL
   ========================= */

.wellbeing-section{
  overflow: hidden; /* para que nada se “escape” */
}

.wb-carousel{
  position: relative;
  margin-top: 12px;
}

/* Botones nav (código, no imagen) */
.wb-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 26px rgba(15,23,42,.10);
  display: grid;
  place-items: center;
  cursor: pointer;
  z-index: 5;
  transition: transform .15s ease, background .2s ease;
}

.wb-nav svg{ width: 22px; height: 22px; color: rgba(15,23,42,.75); }

.wb-nav:hover{
  background: rgba(255,255,255,.90);
  transform: translateY(-50%) scale(1.03);
}

.wb-nav--prev{ left: 10px; }
.wb-nav--next{ right: 10px; }

.wb-viewport{
  overflow: hidden;
  border-radius: 22px;
}

/* Track */
.wb-track{
  display: flex;
  width: 100%;
  transition: transform .45s ease;
  will-change: transform;
}

/* Cada slide ocupa 100% */
.wb-slide{
  flex: 0 0 100%;
  padding: 18px 16px;
}

/* El “portal stage” */
.wb-stage{
  position: relative;
  border-radius: 22px;
  min-height: 280px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  border: 1px solid rgba(15,23,42,.10);
  box-shadow: 0 18px 40px rgba(15,23,42,.10);
  overflow: hidden;
}

/* Portal arriba / abajo */
.wb-portal{
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: min(720px, 92%);
  height: auto;
  opacity: .95;
  pointer-events: none;
  filter: blur(.0px) drop-shadow(0 18px 35px rgba(106,127,219,.18));
}

.wb-portal--top{ top: 14px; }
.wb-portal--bottom{ bottom: 14px; }

/* Contenido central */
.wb-content{
  position: relative;
  z-index: 2;
  display: grid;

  /* columnas más equilibradas => menos “vacío” */
  grid-template-columns: 1fr 1fr;

  /* menos separación */
  gap: 10px;

  align-items: center;

  /* un poco menos de padding lateral */
  padding: 54px 24px;
}


.wb-content--flip{
  grid-template-columns: .85fr 1.15fr;
}

.wb-text h3{
  margin: 0 0 10px;
  margin-left: 30px;
  font-size: clamp(20px, 2vw, 28px);
  letter-spacing: -.2px;
}

.wb-text p{
  margin-left: 30px;
  color: var(--muted);
  line-height: 1.55;

  /* deja que el texto use más ancho */
  max-width: 62ch;
}


.wb-media{
  display: flex;
  justify-content: flex-end; /* empuja la imagen hacia el centro (hacia el texto) */
  align-items: center;
}

.wb-content--flip .wb-media{
  justify-content: flex-start; /* empuja la imagen hacia el centro cuando está al lado izquierdo */
}


.wb-media img{
  width: min(420px, 100%);
  height: auto;
  display: block;
  filter: drop-shadow(0 14px 24px rgba(15,23,42,.18));
}

/* Dots */
.wb-dots{
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 14px;
}

.wb-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.22);
  background: rgba(255,255,255,.65);
  cursor: pointer;
  transition: transform .15s ease, background .2s ease;
}

.wb-dot.is-active{
  background: rgba(106,127,219,.85);
  border-color: rgba(106,127,219,.85);
  transform: scale(1.15);
}

/* Responsive */
@media (max-width: 920px){
  .wb-nav--prev{ left: 6px; }
  .wb-nav--next{ right: 6px; }

  .wb-content,
  .wb-content--flip{
    grid-template-columns: 1fr;
    padding: 58px 18px;
    text-align: center;
  }

  .wb-text p{ margin-inline: auto; }

  .wb-text h3{
  margin: 0 0 10px;
  
  font-size: clamp(20px, 2vw, 28px);
  letter-spacing: -.2px;
  }

  .wb-text p{
    
    color: var(--muted);
    line-height: 1.55;

    /* deja que el texto use más ancho */
    max-width: 62ch;
  }

}

/* =========================
   PROPOSITO (purpose2) — FINAL (estable)
   - texto arriba
   - portales siempre abajo (sin absolute)
   - transmisor PNG detrás del CTA visible
   ========================= */

#proposito{ overflow: visible; }
#proposito .container{ position: relative; }

.purpose2{
  display: grid;
  grid-template-columns: 1fr minmax(320px, 420px) 1fr;
  gap: 34px;
  align-items: start;
  padding: 10px 0 6px;
}

/* Centro (foto) */
.purpose2__center{
  display:flex;
  justify-content:center;
  align-items:flex-end;
}

.purpose2__photo{
  width: 100%;
  max-width: 420px;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 16px 38px rgba(15,23,42,.14);
}

/* Columnas laterales: flex para “pegar” portal abajo */
.purpose2__col{
  display: flex;
  flex-direction: column;
  align-items: center;          /* portal centrado */
  gap: 10px;
}

/* Texto arriba */
.purpose2__text{
  margin: 0 0 16px;
  font-size: 20px;
  line-height: 1.55;
  color: #0f172a;
  max-width: 38ch;
  align-self: flex-start;       /* texto alineado a la izquierda */
}

.purpose2__who{
  margin: 0;
  color: #0f172a;
  opacity: .9;
  align-self: flex-start;
}

/* Portal abajo: ya NO es absolute */
.purpose2__portal{
  margin-top: auto;             /* ✅ esto lo empuja al fondo */
  width: min(420px, 92%);
  height: auto;
  pointer-events: none;
  opacity: .98;
  filter: drop-shadow(0 22px 38px rgba(106,127,219,.20)) saturate(1.08);
}

/* Glow (opcional) activado en hover */
.purpose2__col{
  position: relative;
}

.purpose2__col::after{
  content:"";
  position:absolute;
  left:50%;
  bottom: 65px;
  transform: translateX(-50%) scale(.98);
  width: min(360px, 82%);
  height: 140px;
  border-radius: 999px;
  opacity: 0;
  filter: blur(22px);
  pointer-events:none;
  transition: opacity .25s ease, transform .25s ease;
}

.purpose2__col--left::after{
  background: radial-gradient(circle, rgba(106,127,219,.45), transparent 70%);
}
.purpose2__col--right::after{
  background: radial-gradient(circle, rgba(94,198,184,.50), transparent 70%);
}

.purpose2__col:hover::after{
  opacity: 1;
  transform: translateX(-50%) scale(1.02);
}
.purpose2__col:hover .purpose2__portal{
  transform: translateY(-2px) scale(1.02);
  filter: drop-shadow(0 28px 46px rgba(106,127,219,.22)) brightness(1.05) saturate(1.18);
}

/* CTA + transmisor detrás */
.purpose2__ctaWrap{
  display:flex;
  justify-content:center;
  margin-top: 10px;
  margin-bottom: 12px;
}

.purpose2__cta{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 18px 26px;
  text-decoration:none;
  color:#0f172a;
  font-weight: 800;
  border-radius: 18px;
  overflow: visible;
}

/* PNG detrás del texto */
.purpose2__ctaBg{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% + 110px);
  height: auto;
  opacity: .95;
  pointer-events: none;
  filter: drop-shadow(0 18px 30px rgba(15,23,42,.10));
  z-index: 0;                  /* ✅ detrás del texto, pero visible */
}

.purpose2__cta span{
  position: relative;
  z-index: 1;                  /* ✅ arriba del PNG */
}

/* Responsive */
@media (max-width: 920px){
  .purpose2{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .purpose2__center{ order: -1; } /* foto arriba */

  .purpose2__col{
    text-align: center;
  }

  .purpose2__text,
  .purpose2__who{
    align-self: center;
    margin-inline: auto;
  }

  .purpose2__portal{
    width: min(440px, 92%);
  }
}




/* =========================
   CONTACTO PRO (contact2) — FINAL
   Objetivo: que se vea como tu mock (Canva)
   ========================= */

.contact2{
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 42px;
  align-items: center;
}

/* Izquierda */
.contact2__left{
  display: grid;
  gap: 44px;
}

.contact2__item{
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 26px;
  align-items: center;
}

.contact2__icon{
  width: 92px;
  height: auto;
  display: block;
}

.contact2__lead{
  margin: 0;
  font-size: 30px;     /* 👈 un poco menor, como el mock */
  line-height: 1.18;
  color: #0f172a;
}

.contact2__lead strong{
  font-weight: 900;
}

/* Derecha: panel grande */
.contact2__panel{
  position: relative;                 /* ✅ clave */
  border-radius: 58px;                /* ✅ look Canva */
  padding: 44px 44px 34px;            /* ✅ espacio interno */
  overflow: hidden;                   /* ✅ nada se “sale” */
  background: linear-gradient(180deg, #9aa0ab, #3b4352);
  box-shadow: 0 18px 40px rgba(15,23,42,.12);
}

/* Si NO tienes PNG de fondo, déjalo apagado así */
.contact2__panelBg{ display:none; }

/* Grid de inputs */
.contact2__grid{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 26px;
  margin-bottom: 18px;
}

.contact2__label{
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  font-weight: 800;
  color: rgba(255,255,255,.92);
}

.contact2__label span{
  font-size: 18px;
}

/* Inputs */
.contact2__input{
  width: 100%;
  height: 56px;
  border-radius: 14px;
  border: 0;
  padding: 0 16px;
  font-size: 18px;
  background: rgba(255,255,255,.92);
  outline: none;
}

/* Textarea full */
.contact2__label--full{
  grid-column: 1 / -1;
  margin-top: 6px;
}

.contact2__textarea{
  width: 100%;
  min-height: 110px;                  /* ✅ altura similar al mock */
  border-radius: 14px;
  border: 0;
  padding: 14px 16px;
  font-size: 18px;
  background: rgba(255,255,255,.92);
  outline: none;
  resize: none;                        /* ✅ como Canva (sin “tirador”) */
}

/* Botón */
.contact2__btn{
  position: relative;
  z-index: 1;
  width: 100%;
  margin-top: 18px;
  height: 58px;
  border-radius: 18px;
  border: 0;
  font-weight: 900;
  font-size: 18px;
  cursor: pointer;
  background: var(--p3);
  color: #fff;
}

/* Responsive */
@media (max-width: 920px){
  .contact2{
    grid-template-columns: 1fr;
    gap: 26px;
    align-items: start;
  }

  .contact2__item{
    grid-template-columns: 76px 1fr;
    gap: 16px;
  }

  .contact2__icon{
    width: 70px;
  }

  .contact2__lead{
    font-size: 24px;
  }

  .contact2__panel{
    padding: 34px 22px 26px;
    border-radius: 32px;
  }

  .contact2__grid{
    grid-template-columns: 1fr;
  }
}



/* =========================
   FOOTER — PAESIA (FINAL)
   ========================= */

.footer{
  background: #6a7fdb; /* mismo azul del mock */
  color:#fff;
  padding: 28px 0;
}

.footer__inner{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap: 32px;
}

/* ===== IZQUIERDA ===== */
/* ===== FOOTER: LEFT centrado (logo arriba + link abajo) ===== */
.footer__left{
  display:flex;
  flex-direction:column;
  align-items:center;     /* ✅ centra todo */
  justify-content:center;
  gap:6px;
  text-align:center;
}

.footer__left .brand{
  display:flex;
  justify-content:center; /* ✅ centra el anchor */
  width:100%;
  height: 105px;
}

.footer__left .brand__img{
  display:block;          /* ✅ quita baseline */
  margin: 0 auto;         /* ✅ centra el PNG */
  height: 100px;           /* ajusta si lo quieres más grande/pequeño */
  width:auto;
}



.footer__privacy{
  font-size:13px;
  opacity:.9;
  text-decoration:none;
  color:#fff;
}

/* ===== CENTRO ===== */
.footer__center{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  font-size:14px;
}

.footer__center a{
  color:#fff;
  text-decoration:none;
  font-weight:600;
}

.footer__center span{
  font-size:20px;
  font-weight:900;   /* thickness */
  opacity:.9;
  color:#f1f1f1;
}


/* ===== DERECHA ===== */
/* ===== FOOTER: socials con color por red ===== */
.footer__right{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
}

.footer__right .social{
  width:38px;
  height:38px;
  border-radius:999px;
  display:grid;
  place-items:center;
  color:#fff;
  text-decoration:none;
  border:0; /* ✅ sin borde blanco */
  box-shadow: 0 10px 20px rgba(0,0,0,.16);
  transition: transform .15s ease, filter .2s ease;
}

.footer__right .social:hover{
  transform: translateY(-1px);
  filter: brightness(1.06);
}

/* Colores por aria-label */
.footer__right .social[aria-label="YouTube"]{   background:#ff0000; }
.footer__right .social[aria-label="LinkedIn"]{  background:#0a66c2; }
.footer__right .social[aria-label="Instagram"]{ background:#e1306c; }
.footer__right .social[aria-label="Facebook"]{  background:#1877f2; }

/* ===== Instagram: icono “real” con CSS (sin unicode) ===== */
.footer__right .social[aria-label="Instagram"]{
  /* círculo con gradiente Instagram */
  background: radial-gradient(circle at 30% 30%,
    #feda75 0%,
    #fa7e1e 35%,
    #d62976 60%,
    #962fbf 78%,
    #4f5bd5 100%
  );

  position: relative;
  overflow: hidden;

  /* oculto el caracter ◎ pero lo dejo en el DOM */
  font-size: 0;
  color: transparent;

  /* “cámara” (cuadrado redondeado) como borde blanco */
  box-shadow: 0 10px 20px rgba(0,0,0,.16), inset 0 0 0 2px rgba(255,255,255,.92);
}

/* lente */
.footer__right .social[aria-label="Instagram"]::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%, -50%);
  width: 14px;
  height: 14px;
  border-radius: 999px;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.92);
}

/* punto arriba-derecha */
.footer__right .social[aria-label="Instagram"]::after{
  content:"";
  position:absolute;
  right: 10px;
  top: 10px;
  width: 4px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
}


/* Redes */
.footer__socials{
  display:flex;
  gap:10px;
}

.social{
  width:36px;
  height:36px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
  text-decoration:none;
  font-size:16px;
}


/* ===== RESPONSIVE ===== */
@media (max-width: 900px){
  .footer__inner{
    grid-template-columns: 1fr;
    text-align:center;
  }

  .footer__brand{
    align-items:center;
  }

  .footer__right{
    justify-content:center;
    flex-wrap:wrap;
  }
}



/* ======================
   VIDEO MODAL PAESIA
====================== */
.video-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;
}

.video-modal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.85);
  backdrop-filter: blur(6px);
}

.video-modal__content{
  position: relative;
  width: min(900px, 92vw);
  aspect-ratio: 16 / 9;
  margin: auto;
  top: 50%;
  transform: translateY(-50%);
  background: #000;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
}

.video-modal__content iframe{
  width: 100%;
  height: 100%;
}

.video-modal__close{
  position: absolute;
  top: -44px;
  right: 0;
  background: none;
  border: none;
  color: #fff;
  font-size: 28px;
  cursor: pointer;
}


/* ======================
   VIDEO THUMBNAIL
====================== */
.video--thumb{
  position: relative;
  border: none;
  background: none;
  padding: 0;
  cursor: pointer;
  border-radius: 18px;
  overflow: hidden;
  width: min(520px, 92vw);
  box-shadow: 0 16px 40px rgba(15,23,42,.25);
}

.video__thumb{
  width: 100%;
  display: block;
  border-radius: 18px;
}

/* Overlay */
.video__overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(15,23,42,.15),
    rgba(15,23,42,.55)
  );
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: #fff;
  transition: background .25s ease;
}

.video--thumb:hover .video__overlay{
  background: rgba(15,23,42,.65);
}

/* Play icon */
.video__icon{
  font-size: 24px;
  line-height: 1;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.5));
}

/* Texto */
.video__text{
  font-family: system-ui, "Segoe UI Variable", "SF Pro Display", "SF Pro Text", Roboto, Arial, sans-serif;
  font-weight: 700;
  letter-spacing: .4px;
  font-size: 16px;
}




@media (max-width: 920px){
  .purpose2__cta{
    max-width: 100%;
    overflow: hidden; /* 🔑 evita que el fondo se salga */
  }

  .purpose2__ctaBg{
    width: 120%;           /* antes era +110px fijo, eso rompe mobile */
    max-width: 120%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0.9;
  }

  .purpose2__cta span{
    font-size: 16px;       /* un poco más chico para mobile */
    text-align: center;
    padding: 0 12px;
    display: block;
  }
}



/* =========================
   CONTACTO PRO (contact2) — FINAL
   ========================= */

.contact2{
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 42px;
  align-items: center;
}

/* Izquierda */
.contact2__left{
  display: grid;
  gap: 44px;
}

.contact2__item{
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 26px;
  align-items: center;
}

/* ICONOS */
.contact2__icon{
  width: 92px;
  height: auto;
  display: block;
  object-fit: contain;
  flex-shrink: 0;
}

/* Texto */
.contact2__lead{
  margin: 0;
  font-size: 30px;
  line-height: 1.18;
  color: #0f172a;
}

.contact2__lead strong{
  font-weight: 900;
}

/* Derecha: panel grande */
.contact2__panel{
  position: relative;
  border-radius: 58px;
  padding: 44px 44px 34px;
  overflow: hidden;
  background: linear-gradient(180deg, #9aa0ab, #3b4352);
  box-shadow: 0 18px 40px rgba(15,23,42,.12);
}

/* Grid de inputs */
.contact2__grid{
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 26px;
  margin-bottom: 18px;
}

.contact2__label{
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
  font-weight: 800;
  color: rgba(255,255,255,.92);
}

.contact2__label span{
  font-size: 18px;
}

/* Inputs */
.contact2__input{
  width: 100%;
  height: 56px;
  border-radius: 14px;
  border: 0;
  padding: 0 16px;
  font-size: 18px;
  background: rgba(255,255,255,.92);
  outline: none;
}

/* Textarea */
.contact2__label--full{
  grid-column: 1 / -1;
  margin-top: 6px;
}

.contact2__textarea{
  width: 100%;
  min-height: 110px;
  border-radius: 14px;
  border: 0;
  padding: 14px 16px;
  font-size: 18px;
  background: rgba(255,255,255,.92);
  outline: none;
  resize: none;
}

/* Botón */
.contact2__btn{
  position: relative;
  z-index: 1;
  width: 100%;
  margin-top: 18px;
  height: 58px;
  border-radius: 18px;
  border: 0;
  font-weight: 900;
  font-size: 18px;
  cursor: pointer;
  background: var(--p3);
  color: #fff;
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 920px){
  .contact2{
    grid-template-columns: 1fr;
    gap: 26px;
    align-items: start;
  }

  .contact2__item{
    grid-template-columns: auto 1fr;
    gap: 16px;
  }

  .contact2__icon{
    width: 70px;
  }

  .contact2__lead{
    font-size: 24px;
  }

  .contact2__panel{
    padding: 34px 22px 26px;
    border-radius: 32px;
  }

  .contact2__grid{
    grid-template-columns: 1fr;
  }
}

