/* =========================
   VARIABLES + RESET
========================= */
:root{
  --bg:#0b0b10;
  --text:#111827;
  --muted:rgba(17,24,39,.70);
  --white:#fff;
  --line:rgba(255,255,255,.15);
  --accent:#ff4fb9;
  --radius:18px;
  --shadow:0 18px 50px rgba(0,0,0,.25);
  --container:1160px;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:"Montserrat",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:#f6f7fb;
  overflow-x:hidden; /* evita scroll horizontal */
}
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; text-decoration:none; }
video{ max-width:100%; height:auto; }

/* =========================
   ALTURA/ALINEACIÓN SECCIONES
   (solo estructura general)
========================= */
.hero-v1,
.sec2,.sec3,.sec4,.sec5,.sec6,.sec7{
  min-height:100svh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0;
}
.hero-v1{
  height:100vh;
  display:block; /* hero es absoluto (desktop) */
}

/* inner base */
.sec2-inner,
.sec3-inner,
.sec4-inner,
.sec5-inner,
.sec7-inner{
  width:min(1400px, calc(100% - 48px));
  padding:70px 0 90px;
}
.sec3-inner,.sec4-inner,.sec7-inner{ width:min(1200px, calc(100% - 48px)); }
.sec5-inner{ width:min(1260px, calc(100% - 48px)); }

/* si hay mucho contenido, no recortar */
.sec2,.sec3,.sec4,.sec5,.sec6,.sec7{ height:auto; }

/* pantallas bajas */
@media (max-height:760px){
  .sec2-inner,.sec3-inner,.sec4-inner,.sec5-inner,.sec7-inner{ padding:50px 0 60px; }
}

/* =========================
   HERO
========================= */
.hero-v1{
  position:relative;
  width:100%;
  height:100vh;
  background:#000;
  overflow:hidden;
}

/* video */
.hero-card{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  overflow:hidden;
  z-index:1;
}
.hero-card__video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
}
.hero-video-overlay{
  position:absolute;
  inset:0;
  background:rgba(255,255,255,.75);
  backdrop-filter:blur(3px);
  z-index:2;
}

/* persona (desktop) */
.hero-person{
  position:absolute;
  bottom:0;
  right:2%;
  height:90vh;
  width:auto;
  max-height:95%;
  filter:drop-shadow(0 30px 80px rgba(0,0,0,.6));
  z-index:3;
  pointer-events:none;
}

/* texto (desktop) */
.hero-text{
  position:absolute;
  top:13%;
  left:51%;
  transform:translateX(-50%);
  text-align:center;
  width:90%;
  max-width:1100px;
  z-index:4;
}
.hero-name{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(50px, 8vw, 110px);
  color:var(--accent);
  margin:0;
  letter-spacing:2px;
  text-transform:uppercase;
}
.hero-role{
  font-family:"Montserrat",sans-serif;
  font-weight:400;
  letter-spacing:12px;
  font-size:clamp(16px, 1.6vw, 22px);
  color:var(--accent);
  margin-top:10px;
}
.hero-claim{
  margin-top:60px;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(26px, 3.5vw, 52px);
  line-height:1.05;
  text-align:left;
  max-width:900px;
  margin-left:auto;
  margin-right:auto;
  color:#000;
}
.hero-claim span{ color:var(--accent); }

/* =========================
   SECCIÓN 2
========================= */
.sec2{
  position:relative;
  background:#fff;
  overflow:hidden;
  padding:70px 0 90px;
}
.sec2-bg{
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(700px 350px at 20% 35%, rgba(0,0,0,.06), transparent 60%),
    radial-gradient(650px 320px at 70% 70%, rgba(0,0,0,.06), transparent 60%),
    radial-gradient(520px 260px at 50% 92%, rgba(0,0,0,.05), transparent 65%);
}
.sec2-inner{
  margin:0 auto;
  position:relative;
  z-index:2;
}
.sec2-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(28px, 4vw, 50px);
  line-height:1;
  margin:0 0 28px;
  color:#000;
  letter-spacing:1px;
  padding-top:20px;
  text-align:center;
}
.sec2-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:48px;
  align-items:start;
}
.sec2-pink{
  font-family:'Bebas Neue',sans-serif;
  color:var(--accent);
  font-size:clamp(26px, 3.2vw, 48px);
  font-weight:800;
  line-height:1.05;
  margin:0;
  padding-top:110px;
  transform:scaleX(1.05);
  transform-origin:left;
}
.sec2-video{
  display:grid;
  gap:15px;
  justify-items:end;
  padding-top:30px;
}
.sec2-videoBox{
  width:min(1120px, 100%);
  aspect-ratio:16/9;
  background:#000;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.15);
}
.sec2-videoEl{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}
.sec2-cta{
  padding-top:40px;
  margin-top:40px;
  text-align:center;
}
.sec2-ctaBtn{
  display:inline-block;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(22px, 2.5vw, 22px);
  letter-spacing:1px;
  text-transform:uppercase;
  padding:18px 42px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  box-shadow:0 18px 40px rgba(255,79,185,.35);
  transition:all .3s ease;
}
.sec2-ctaBtn:hover{
  background:#000;
  color:var(--accent);
  transform:translateY(-4px);
  box-shadow:0 22px 50px rgba(0,0,0,.25);
}
.sec2-ctaBtn:active{
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(0,0,0,.2);
}

/* avioncitos */
.sec2-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 20px rgba(255,79,185,.15));
}
.sec2-plane--tl{ left:26px; top:26px; width:84px; }
.sec2-plane--tr{ right:40px; top:44px; width:26px; }
.sec2-plane--bl{ left:50%; bottom:18px; transform:translateX(-50%); width:26px; opacity:.85; }
.sec2-plane--br{ right:-10px; bottom:-16px; width:240px; }

/* =========================
   SECCIÓN 3
========================= */
.sec3{
  position:relative;
  background:#fff;
  overflow:hidden;
  padding:80px 0 90px;
}
.sec3-inner{
  margin:0 auto;
  position:relative;
  z-index:2;
}
.sec3-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.sec3-left{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:1100px;
}
.sec3-head{
  font-family:'Bebas Neue',sans-serif;
  color:var(--accent);
  font-size:clamp(26px, 3.6vw, 42px);
  line-height:1.15;
  margin:0 0 28px;
  text-transform:uppercase;
  letter-spacing:1px;
  max-width:none;
  width:140%;
}
.sec3-body{
  font-family:"Montserrat",sans-serif;
  font-size:clamp(16px, 1.25vw, 48px);
  line-height:1.5;
  color:#0b0b10;
  margin:0 0 34px;
  max-width:none;
  width:125%;
}
.sec3-body strong{ font-weight:800; }
.sec3-cta{ margin-top:10px; }
.sec3-ctaBtn{
  display:inline-block;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(22px, 2.4vw, 32px);
  letter-spacing:1px;
  text-transform:uppercase;
  padding:18px 42px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  box-shadow:0 18px 40px rgba(255,79,185,.35);
  transition:all .3s ease;
}
.sec3-ctaBtn:hover{
  background:#000;
  color:var(--accent);
  transform:translateY(-4px);
  box-shadow:0 22px 50px rgba(0,0,0,.25);
}
.sec3-ctaBtn:active{
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(0,0,0,.2);
}
.sec3-right{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:650px;
}
.sec3-person{
  position:absolute;
  bottom:0;
  right:0%;
  z-index:1;
  width:1220px;
  max-width:none;
  height:720px;
  pointer-events:none;
}

/* avioncitos */
.sec3-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 20px rgba(255,79,185,.12));
}
.sec3-plane--tl{ left:26px; top:26px; width:84px; }
.sec3-plane--tr{ right:40px; top:44px; width:26px; }
.sec3-plane--bl{ left:46px; bottom:34px; width:26px; opacity:.8; }
.sec3-plane--br{ right:-10px; bottom:-16px; width:240px; }

/* =========================
   SECCIÓN 4
========================= */
.sec4{
  position:relative;
  background:#fff;
  overflow:hidden;
  padding:70px 0 90px;
}
.sec4-inner{
  margin:0 auto;
  position:relative;
  z-index:2;
  text-align:center;
}
.sec4-title{
  font-family:'Bebas Neue',sans-serif;
  color:#0b0b10;
  font-size:clamp(30px, 3.2vw, 52px);
  line-height:1.05;
  margin:0 auto 12px;
  text-transform:uppercase;
  letter-spacing:1px;
  max-width:900px;
}
.sec4-subtitle{
  font-family:'Bebas Neue',sans-serif;
  color:var(--accent);
  font-size:clamp(28px, 3vw, 48px);
  line-height:.90;
  margin:0 0 38px;
  text-transform:uppercase;
  letter-spacing:1px;
}
.sec4-media{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:55px;
  align-items:start;
  justify-items:center;
  margin:0 auto 40px;
}
.sec4-card{
  width:100%;
  max-width:300px;
  aspect-ratio:9/16;
  border-radius:0;
  overflow:hidden;
  background:#111;
  box-shadow:0 18px 50px rgba(0,0,0,.12);
}
.sec4-video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.sec4-bottom{
  font-family:"Montserrat",sans-serif;
  font-size:clamp(16px, 1.25vw, 22px);
  line-height:1.25;
  color:#0b0b10;
  margin:10px auto 0;
  max-width:1100px;
}
.sec4-bottom strong{ font-weight:800; }

/* avioncitos */
.sec4-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 20px rgba(255,79,185,.12));
}
.sec4-plane--tl{ left:26px; top:26px; width:84px; }
.sec4-plane--tr{ right:40px; top:64px; width:26px; }
.sec4-plane--bl{ left:46px; bottom:36px; width:26px; opacity:.8; }
.sec4-plane--br{ right:-10px; bottom:-16px; width:240px; }

/* =========================
   SECCIÓN 5
========================= */
.sec5{
  position:relative;
  background:#fff;
  overflow:hidden;
  padding:70px 0 90px;
}
.sec5-inner{
  margin:0 auto;
  position:relative;
  z-index:2;
}
.sec5-title{
  text-align:center;
  font-family:'Bebas Neue',sans-serif;
  color:var(--accent);
  font-size:clamp(44px, 6vw, 92px);
  letter-spacing:2px;
  margin:0 0 36px;
  text-transform:uppercase;
}
.sec5-grid{
  display:grid;
  grid-template-columns:1fr 1.25fr;
  gap:46px;
  align-items:start;
}
.sec5-icons{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px 26px;
  align-items:start;
}
.sec5-ico{ margin:0; text-align:center; }
.sec5-ico figcaption{
  font-family:'Bebas Neue',sans-serif;
  color:var(--accent);
  font-size:clamp(16px, 1.4vw, 28px);
  letter-spacing:1px;
  text-transform:uppercase;
}
.sec5-ico--wide{ grid-column:1/-1; margin-top:6px; }

.sec5-img-computador{ width:320px; margin:0 auto 14px; }
.sec5-img-celular{ width:125px; margin:0 auto 14px; }
.sec5-img-pantalla{ width:320px; margin:0 auto 14px; }

.sec5-box{
  background:var(--accent);
  border-radius:42px;
  padding:34px 42px;
  box-shadow:0 22px 60px rgba(255,79,185,.25);
}
.sec5-list{
  margin:0;
  padding-left:26px;
  font-family:'Bebas Neue',sans-serif;
  color:#fff;
  font-size:clamp(20px, 2.4vw, 36px);
  line-height:1.05;
  text-transform:uppercase;
  letter-spacing:1px;
}
.sec5-list li{ margin:10px 0; }

.sec5-cta{ text-align:center; margin-top:34px; }
.sec5-ctaBtn{
  display:inline-block;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(22px, 2.4vw, 34px);
  letter-spacing:1px;
  text-transform:uppercase;
  padding:18px 44px;
  border-radius:999px;
  background:var(--accent);
  color:#fff;
  box-shadow:0 18px 40px rgba(255,79,185,.30);
  transition:all .3s ease;
}
.sec5-ctaBtn:hover{
  background:#000;
  color:var(--accent);
  transform:translateY(-4px);
  box-shadow:0 22px 50px rgba(0,0,0,.22);
}

/* avioncitos */
.sec5-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 20px rgba(255,79,185,.12));
}
.sec5-plane--tl{ left:26px; top:26px; width:84px; }
.sec5-plane--tr{ right:40px; top:64px; width:26px; }
.sec5-plane--bl{ left:46px; bottom:36px; width:26px; opacity:.8; }
.sec5-plane--br{ right:-10px; bottom:-16px; width:240px; }

/* =========================
   SECCIÓN 6 (Comparación)
   ✅ Desktop: imagen centrada
   ✅ Móvil: bloque armado (.sec6-build)
========================= */
.sec6{
  position:relative;
  width:100%;
  background:#fff;
  padding:80px 0;
  display:flex;
  justify-content:center;
  overflow:hidden;
}

/* SWITCH */
.sec6-desktop{ display:block; }
.sec6-mobile{ display:none; }

/* ✅ FIX: centra SIEMPRE el bloque desktop */
.sec6-desktop{
  width:100%;
  display:flex;
  justify-content:center;
}

/* Desktop imagen */
.sec6-img{
  width:min(1400px, calc(100% - 48px));  /* igual a tus inners */
  height:auto;
  display:block;
  margin:0 auto;
  border-radius:40px;
  box-shadow:0 30px 80px rgba(0,0,0,.08);
}

/* =========================
   BLOQUE ARMADO (SOLO MÓVIL)
========================= */
.sec6-build{
  width:min(1400px, calc(100% - 48px));
  position:relative;
  margin:0 auto;
}

.sec6-build .sec6-card{
  position:relative;
  display:grid;
  grid-template-columns:1fr 1fr;
  border-radius:52px;
  overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.10);
  min-height:520px;
}

/* decor avioncitos */
.sec6-build .sec6-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 22px rgba(255,79,185,.14));
}
.sec6-build .sec6-plane--tl{ left:-8px; top:-6px; width:160px; transform:rotate(-8deg); }
.sec6-build .sec6-plane--tr{ right:18px; top:14px; width:26px; }
.sec6-build .sec6-plane--bl{ left:50%; bottom:-6px; width:26px; transform:translateX(-50%); opacity:.85; }

/* lados */
.sec6-build .sec6-side{
  position:relative;
  padding:64px 64px 54px;
  display:flex;
  flex-direction:column;
  gap:22px;
}

.sec6-build .sec6-side--dark{
  background:#0b0b10;
  color:#fff;
}

.sec6-build .sec6-side--pink{
  background: radial-gradient(900px 520px at 35% 20%, rgba(255,255,255,.18), transparent 55%),
              linear-gradient(90deg, #ff4fb9 0%, #ff76c7 40%, #ff4fb9 100%);
  color:#fff;
}

/* títulos */
.sec6-build .sec6-title{
  margin:0;
  font-family:"Montserrat", system-ui, sans-serif;
  font-weight:800;
  font-size:clamp(22px, 2.4vw, 40px);
  letter-spacing:-.02em;
}

/* lista */
.sec6-build .sec6-list{
  margin:0;
  padding-left:22px;
  display:grid;
  gap:10px;
  font-family:"Montserrat", system-ui, sans-serif;
  font-size:clamp(14px, 1.25vw, 18px);
  line-height:1.35;
}
.sec6-build .sec6-list li::marker{ color:rgba(255,255,255,.95); }

/* dots */
.sec6-build .sec6-dots{
  margin-top:auto;
  display:flex;
  gap:10px;
  justify-content:center;
  align-items:center;
  padding-top:12px;
}
.sec6-build .sec6-dot{
  width:10px;height:10px;border-radius:999px;
  background:rgba(255,255,255,.75);
  opacity:.9;
}
.sec6-build .sec6-dot.is-active{ background:#fff; opacity:1; }
.sec6-build .sec6-dot--dark{ background:rgba(0,0,0,.65) !important; }
.sec6-build .sec6-dot--dark.is-active{ background:#0b0b10 !important; }

/* avioncito mini */
.sec6-build .sec6-miniPlane{
  position:absolute;
  right:46px;
  bottom:34px;
  width:34px;
  opacity:.95;
  filter:drop-shadow(0 10px 22px rgba(255,79,185,.22));
  pointer-events:none;
}

/* FOTO derecha */
.sec6-build .sec6-person{
  position:absolute;
  right:34px;
  bottom:0;
  width:min(360px, 36%);
  height:auto;
  z-index:5;
  pointer-events:none;
  filter:drop-shadow(0 30px 70px rgba(0,0,0,.25));
}

/* deja espacio para la foto */
.sec6-build .sec6-side--pink .sec6-list,
.sec6-build .sec6-side--pink .sec6-title{
  width:72%;
}

/* =========================
   SECCIÓN 7
========================= */
.sec7{
  position:relative;
  background:#fff;
  overflow:hidden;
  padding:70px 0 110px;
}
.sec7-inner{
  margin:0 auto;
  position:relative;
  z-index:2;
}
.sec7-cards{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:34px;
  align-items:start;
  margin-top:10px;
  margin-bottom:70px;
}
.sec7-card{
  background:rgba(255,255,255,.92);
  border:3px solid var(--accent);
  border-radius:34px;
  padding:28px 26px 22px;
  box-shadow:0 26px 70px rgba(0,0,0,.06);
  min-height:240px;
}
.sec7-text{
  margin:0;
  font-family:"Montserrat",system-ui,sans-serif;
  font-size:15px;
  line-height:1.25;
  color:#111;
}
.sec7-name{
  margin-top:18px;
  font-family:"Montserrat",system-ui,sans-serif;
  font-style:italic;
  font-weight:800;
  font-size:14px;
  color:#000;
}
.sec7-titleWrap{ margin-top:10px; }
.sec7-title{
  margin:0;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(70px, 9vw, 120px);
  line-height:.9;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:1px;
}
.sec7-sub{
  margin-top:8px;
  font-family:"Montserrat",system-ui,sans-serif;
  font-size:12px;
  letter-spacing:.45em;
  color:rgba(255,79,185,.9);
  text-transform:uppercase;
}
.sec7-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:1;
  filter:drop-shadow(0 10px 22px rgba(255,79,185,.12));
}
.sec7-plane--tl{ left:22px; top:18px; width:120px; }
.sec7-plane--br{ right:-14px; bottom:-18px; width:260px; }

/* =========================
   SECCIÓN 8
========================= */
.sec8{
  position:relative;
  background:#fff;
  overflow:hidden;
}
.sec8-inner{
  width:min(1400px, calc(100% - 48px));
  margin:0 auto;
  padding:70px 0 90px;
  position:relative;
  z-index:2;
}
.sec8-title{
  text-align:center;
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(26px, 3.2vw, 44px);
  line-height:1.05;
  letter-spacing:1px;
  text-transform:uppercase;
  margin:0 0 42px;
  color:var(--accent);
}
.sec8-title span{ color:#000; }
.sec8-grid{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:50px;
  align-items:center;
  justify-items:center;
}
.sec8-photo{
  margin:0;
  width:min(420px, 100%);
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 26px 70px rgba(0,0,0,.12);
  background:#f3f4f6;
}
.sec8-photo img{
  width:100%;
  height:650px;
  object-fit:cover;
  display:block;
}
.sec8-arrowWrap{
  width:200px;
  display:flex;
  justify-content:center;
  align-items:center;
  pointer-events:none;
}
.sec8-arrow{
  width:200px;
  height:auto;
  display:block;
  filter:drop-shadow(0 18px 40px rgba(255,79,185,.25));
  pointer-events:none;
}
.sec8-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 20px rgba(255,79,185,.12));
}
.sec8-plane--tl{ left:26px; top:26px; width:84px; }
.sec8-plane--tr{ right:40px; top:64px; width:26px; }
.sec8-plane--bl{ left:46px; bottom:36px; width:26px; opacity:.8; }
.sec8-plane--br{ right:-10px; bottom:-16px; width:240px; }

/* =========================
   SECCIÓN 9 (CONTACTO / FORM)
========================= */
.sec9{
  background:#f6e9e7;
  min-height:100vh;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  padding:70px 0 90px;
}
.sec9-inner{
  width:min(1400px, calc(100% - 48px));
  margin:0 auto;
  position:relative;
  z-index:5;
}
.sec9-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}
.sec9-left{ padding-top:10px; max-width:620px; }
.sec9-chip{
  display:inline-block;
  font-weight:700;
  font-size:12px;
  letter-spacing:.12em;
  color:rgba(0,0,0,.75);
  background:rgba(255,255,255,.65);
  border:1px solid rgba(0,0,0,.08);
  padding:8px 14px;
  border-radius:999px;
  margin-bottom:18px;
}
.sec9-title{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(34px, 4.1vw, 60px);
  line-height:1.02;
  letter-spacing:1px;
  margin:0 0 12px;
  max-width:620px;
  color:#0b0b10;
  text-transform:uppercase;
}
.sec9-sub{
  margin:0 0 22px;
  font-weight:800;
  font-size:14px;
  letter-spacing:.06em;
  color:rgba(0,0,0,.7);
  text-transform:uppercase;
}
.sec9-note{
  margin:14px 0 0;
  font-size:13px;
  line-height:1.35;
  color:rgba(0,0,0,.6);
  max-width:620px;
}
.sec9-right{ display:flex; justify-content:flex-end; }
.sec9-card{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(0,0,0,.06);
  border-radius:22px;
  padding:22px 22px 18px;
  box-shadow:0 26px 70px rgba(0,0,0,.10);
  backdrop-filter:blur(6px);
  width:min(520px, 100%);
}
.sec9-cardTitle{
  margin:0 0 8px;
  font-weight:800;
  font-size:18px;
  color:#1a1a1a;
}
.sec9-cardDesc{
  margin:0 0 18px;
  font-size:14px;
  line-height:1.35;
  color:rgba(0,0,0,.65);
}
.sec9-form{ display:grid; gap:12px; }
.sec9-field label{
  display:block;
  font-weight:700;
  font-size:13px;
  color:rgba(0,0,0,.75);
  margin-bottom:6px;
}
.sec9-field input{
  width:100%;
  height:46px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  padding:0 14px;
  font-size:14px;
  outline:none;
  background:#fff;
}
.sec9-field input:focus{
  border-color:rgba(255,79,185,.65);
  box-shadow:0 0 0 4px rgba(255,79,185,.18);
}
.sec9-fieldset{ border:0; padding:0; margin:6px 0 0; }
.sec9-fieldset legend{
  font-weight:800;
  font-size:13px;
  color:rgba(0,0,0,.8);
  margin-bottom:10px;
}
.sec9-options{ display:flex; gap:14px; flex-wrap:wrap; }

.sec9-radio,
.sec9-check{
  flex:1;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 18px;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.10);
  background:rgba(255,255,255,.85);
  font-weight:600;
  font-size:13px;
  color:rgba(0,0,0,.75);
  width:100%;
  height:52px;
}
.sec9-radio input,
.sec9-check input{
  width:16px;
  height:16px;
  accent-color:var(--accent);
}
.sec9-checks{ display:grid; gap:10px; }

.sec9-submit{
  margin-top:6px;
  height:46px;
  border:0;
  border-radius:14px;
  background:#0b0b10;
  color:#fff;
  font-family:'Bebas Neue',sans-serif;
  font-size:22px;
  letter-spacing:1px;
  text-transform:uppercase;
  cursor:pointer;
  transition:all .25s ease;
  width:50%;
}
.sec9-submit:hover{
  background:var(--accent);
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(255,79,185,.25);
}
.sec9-submit:active{ transform:translateY(-1px); }

/* avioncitos */
.sec9-plane{
  position:absolute;
  pointer-events:none;
  opacity:.95;
  z-index:3;
  filter:drop-shadow(0 10px 22px rgba(255,79,185,.12));
}
.sec9-plane--tl{ left:22px; top:18px; width:120px; }
.sec9-plane--br{ right:-14px; bottom:-18px; width:260px; }

/* si el form queda muy alto */
@media (max-height:820px){
  .sec9-card{
    max-height:78vh;
    overflow:auto;
    scrollbar-width:thin;
  }
}

/* =========================
   REVEAL / ANIMACIONES
========================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation:none !important; transition:none !important; }
}
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:all .7s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}

/* text base */
.text-anim{
  opacity:0;
  transform:translateY(14px);
  filter:blur(6px);
  transition:opacity .75s ease, transform .75s ease, filter .75s ease;
  will-change:transform, opacity, filter;
}
.text-anim.is-visible{ opacity:1; transform:translateY(0); filter:blur(0); }

.text-fadeUp{ opacity:0; transform:translateY(18px); }
.text-fadeUp.is-visible{
  opacity:1; transform:translateY(0);
  transition:opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1);
}
.text-slideLeft{ opacity:0; transform:translateX(24px); }
.text-slideLeft.is-visible{
  opacity:1; transform:translateX(0);
  transition:opacity .75s ease, transform .75s cubic-bezier(.2,.85,.2,1);
}
.text-zoomIn{ opacity:0; transform:scale(.96); filter:blur(8px); }
.text-zoomIn.is-visible{
  opacity:1; transform:scale(1); filter:blur(0);
  transition:opacity .75s ease, transform .75s cubic-bezier(.2,.9,.2,1), filter .75s ease;
}
.text-pop{ opacity:0; transform:translateY(10px) scale(.98); }
.text-pop.is-visible{
  opacity:1; transform:translateY(0) scale(1);
  transition:opacity .6s ease, transform .6s cubic-bezier(.15,1.15,.25,1);
}
.text-blur{ opacity:0; filter:blur(12px); transform:translateY(6px); }
.text-blur.is-visible{
  opacity:1; filter:blur(0); transform:translateY(0);
  transition:opacity .8s ease, filter .8s ease, transform .8s ease;
}
.text-underline{ position:relative; display:inline-block; }
.text-underline::before{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  height:4px;
  width:100%;
  border-radius:999px;
  background:currentColor;
  transform:scaleX(0);
  transform-origin:left;
  opacity:.25;
}
.text-underline.is-visible::before{
  animation:underlineIn .65s cubic-bezier(.2,.9,.2,1) forwards;
  animation-delay:.15s;
}
@keyframes underlineIn{ to{ transform:scaleX(1); } }

.text-shine{ position:relative; display:inline-block; }
.text-shine::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(
    110deg,
    transparent 0%,
    rgba(255,255,255,0) 35%,
    rgba(255,255,255,.55) 50%,
    rgba(255,255,255,0) 65%,
    transparent 100%
  );
  transform:translateX(-120%);
  opacity:0;
  mix-blend-mode:screen;
}
.text-shine.is-visible::after{
  opacity:1;
  animation:shinePass 1.2s ease forwards;
  animation-delay:.15s;
}
@keyframes shinePass{
  0%{ transform:translateX(-120%); opacity:0; }
  15%{ opacity:1; }
  100%{ transform:translateX(120%); opacity:0; }
}

/* botones */
.btn-anim{
  position:relative;
  transform:translateZ(0);
  will-change:transform, box-shadow;
}
.btn-anim::after{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  background:radial-gradient(120px 60px at 20% 20%, rgba(255,255,255,.35), transparent 60%);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
.btn-anim:hover::after{ opacity:1; }
.btn-anim:hover{ transform:translateY(-4px) scale(1.01); }
.btn-anim:active{ transform:translateY(-1px) scale(.995); }

/* stagger */
.stagger > *{ opacity:0; transform:translateY(14px); filter:blur(6px); }
.stagger.is-visible > *{
  animation:itemIn .7s cubic-bezier(.2,.85,.2,1) forwards;
  animation-delay:calc(var(--d, 0) * 120ms);
}
@keyframes itemIn{ to{ opacity:1; transform:translateY(0); filter:blur(0); } }

/* =========================
   RESPONSIVE (CONSOLIDADO)
========================= */

/* <= 980px */
@media (max-width:980px){
  .sec2-grid{ grid-template-columns:1fr; gap:24px; }
  .sec2-video{ justify-items:start; }
  .sec2-title,.sec2-pink{ text-align:center; }
  .sec2-videoBox{ width:100%; }
  .sec2-plane--br{ width:180px; }

  .sec3-grid{ grid-template-columns:1fr; gap:26px; }
  .sec3-right{ min-height:auto; }
  .sec3-cta{ text-align:center; }

  .sec4-media{ grid-template-columns:1fr; gap:26px; }
  .sec4-card{ max-width:360px; }

  .sec5-grid{ grid-template-columns:1fr; gap:26px; }
  .sec5-icons{ grid-template-columns:1fr; gap:22px; justify-items:center; }
  .sec5-box{ padding:26px 24px; border-radius:28px; }
  .sec5-ico img{ max-width:170px; }
  .sec5-ico--wide img{ max-width:360px; }

  .sec7-cards{ grid-template-columns:1fr; gap:18px; margin-bottom:46px; }
  .sec7-card{ border-radius:26px; }

  .sec8-grid{ grid-template-columns:1fr; gap:22px; }
  .sec8-arrowWrap{ order:2; }
  .sec8-photo img{ height:460px; }
  .sec8-arrow{ width:160px; }

  .sec9{ min-height:auto; display:block; }
  .sec9-grid{ grid-template-columns:1fr; gap:26px; align-items:start; }
  .sec9-right{ justify-content:center; }
  .sec9-left{ max-width:100%; }
  .sec9-card{ width:min(560px, 100%); }
  .sec9-submit{ width:100%; }

  /* ✅ switch sección 6 */
  .sec6-desktop{ display:none; }
  .sec6-mobile{
    display:flex;
    justify-content:center;
    width:100%;
  }
  .sec6{ padding:70px 0; }

  .sec6-build .sec6-card{
    grid-template-columns:1fr;
    min-height:auto;
  }
  .sec6-build .sec6-side{ padding:44px 28px 36px; }

  .sec6-build .sec6-person{
    position:relative;
    right:auto;
    bottom:auto;
    width:min(420px, 92%);
    margin:14px auto 0;
    display:block;
  }

  .sec6-build .sec6-side--pink .sec6-list,
  .sec6-build .sec6-side--pink .sec6-title{
    width:100%;
  }

  .sec6-build .sec6-miniPlane{ right:18px; bottom:18px; }
  .sec6-build .sec6-plane--tl{ width:110px; }
}

/* swap imagen sección 3 (si usas dos tags img con esas clases) */
.sec3-person.is-mobile{ display:none; }
@media (max-width:600px){
  .sec3-person.is-desktop{ display:none; }
  .sec3-person.is-mobile{ display:block; }
}

/* ====== MÓVIL: AJUSTE PRINCIPAL (HERO) ====== */
@media (max-width:600px){

  /* reduce laterales para que respire */
  .sec2-inner,.sec3-inner,.sec4-inner,.sec5-inner,.sec7-inner,.sec8-inner,.sec9-inner{
    width:calc(100% - 28px) !important;
  }

  /* evita scroll por textos anchos (solo móvil) */
  .sec3-head,.sec3-body{ width:100% !important; max-width:100% !important; }

  /* HERO: deja de ser “absoluto” y se organiza como columna */
  .hero-v1{
    height:100svh !important;
    display:flex !important;
    flex-direction:column !important;
    justify-content:flex-start !important;
    align-items:center !important;
    padding:14px 0 10px !important;
  }

  /* para que el video/overlay sigan de fondo */
  .hero-card{ position:absolute !important; inset:0 !important; }
  .hero-video-overlay{
    background:rgba(255,255,255,.84) !important;
    backdrop-filter:blur(2px) !important;
  }

  /* texto arriba */
  .hero-text{
    position:relative !important;
    top:auto !important;
    left:auto !important;
    transform:none !important;
    width:calc(100% - 28px) !important;
    max-width:560px !important;
    text-align:center !important;
    margin-top:6px !important;
    z-index:5 !important;
  }

  .hero-name{
    font-size:clamp(58px, 14vw, 92px) !important;
    letter-spacing:1px !important;
    line-height:.92 !important;
    padding-top:70px !important;
  }

  .hero-role{
    font-size:clamp(14px, 4.2vw, 18px) !important;
    letter-spacing:7px !important;
    margin-top:6px !important;
    padding-top:50px !important;
  }

  .hero-claim{
    margin-top:20px !important;
    text-align:center !important;
    font-size:clamp(26px, 7vw, 45px) !important;
    line-height:1.02 !important;
    max-width:520px !important;
    padding-top:50px !important;
  }

  /* imagen abajo */
  .hero-person{
    position:relative !important;
    right:auto !important;
    bottom:auto !important;
    width:min(660px, 98%) !important;
    height:auto !important;
    max-height:none !important;
    transform:scale(1.4) !important;
    transform-origin:center bottom !important;
    margin-top:50px !important;
    z-index:4 !important;
    opacity:.92 !important;
  }

  /* SECCIÓN 3: imagen centrada */
  .sec3-right{
    display:flex !important;
    justify-content:center !important;
    align-items:center !important;
    margin-top:10px !important;
    min-height:auto !important;
  }
  .sec3-person{
    position:relative !important;
    width:92% !important;
    max-width:520px !important;
    height:auto !important;
    margin:0 auto !important;
    right:auto !important;
    bottom:auto !important;
    object-fit:contain !important;
  }

  /* SECCIÓN 8 */
  .sec8-photo img{ height:420px; }

  /* SECCIÓN 2 */
  .sec2-inner{ padding:54px 0 70px; }
  .sec2-title{ margin-bottom:14px; padding-top:5px; }
  .sec2-pink{
    padding-top:15px;
    margin-top:0;
    transform:none;
    text-align:center;
  }
  .sec2-grid{ gap:16px; }

  /* oculta flecha en móvil */
  .sec8-arrowWrap{ display:none !important; }

  /* sección 6 */
  .sec6{ padding:60px 0; }
  .sec6-build{ width:calc(100% - 28px); }
}

/* <= 480px: botones cómodos + avioncitos más pequeños */
@media (max-width:480px){
  .sec2-ctaBtn,.sec3-ctaBtn,.sec5-ctaBtn,.sec9-submit{
    width:100%;
    max-width:520px;
    padding-left:18px;
    padding-right:18px;
  }
  .sec2-plane--tl,.sec3-plane--tl,.sec4-plane--tl,.sec5-plane--tl,.sec8-plane--tl,.sec9-plane--tl{
    width:46px !important;
  }
  .sec2-plane--br,.sec3-plane--br,.sec4-plane--br,.sec5-plane--br,.sec8-plane--br,.sec9-plane--br{
    width:130px !important;
  }
}

/* ✅ Deja esto al final para que no se pise */
.sec9-submit{ width:auto !important; }