/* ============================================================
   Landing de captacion de leads — UNA SOLA PANTALLA (sin scroll)
   Marca: fondo #0B0B0C, texto #FFFFFF, acento lima #9CFF2E,
   negativo rojo #FF3B30. Tipografia Inter.
   ============================================================ */

:root {
  --bg: #0B0B0C;
  --fg: #FFFFFF;
  --lime: #9CFF2E;
  --red: #FF3B30;
  --muted: #b8bcc2;
  --card: rgba(18, 19, 21, 0.78);
  --line: rgba(255, 255, 255, 0.14);
  --radius: 16px;
}

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

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--fg);
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}

.hl { color: var(--lime); }
strong { font-weight: 800; }
em { font-style: normal; color: var(--lime); font-weight: 700; }

/* ============================================================
   STAGE: ocupa exactamente la ventana, sin scroll
   ============================================================ */
.stage {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;        /* movil: altura real visible */
  width: 100%;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-image: url('img/bg_abstract.jpg');
  background-size: cover;
  background-position: center;
  background-color: var(--bg); /* fallback de marca si falta la imagen */
}

/* Oscurecido para legibilidad (mas oscuro a la izquierda, donde va el texto) */
.stage__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(11,11,12,0.94) 0%, rgba(11,11,12,0.82) 45%, rgba(11,11,12,0.62) 100%),
    radial-gradient(120% 90% at 80% 20%, rgba(156,255,46,0.10), transparent 60%);
  z-index: 0;
}

.grid {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: 32px 28px;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 48px;
  align-items: center;
}

/* ============================================================
   MENSAJE (columna izquierda)
   ============================================================ */
.eyebrow {
  display: inline-block;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--lime);
  border: 1px solid rgba(156,255,46,0.4);
  border-radius: 999px;
  padding: 6px 12px;
  margin-bottom: 18px;
}

.headline {
  font-size: clamp(30px, 4.4vw, 54px);
  font-weight: 900;
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin-bottom: 18px;
}

.sub {
  font-size: clamp(15px, 1.35vw, 18px);
  line-height: 1.5;
  color: #e9eaec;
  max-width: 36ch;
  margin-bottom: 20px;
}

.points {
  list-style: none;
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}
.points li {
  font-size: 15px;
  line-height: 1.4;
  color: #f1f2f3;
  padding-left: 2px;
}
.tick {
  display: inline-block;
  color: var(--bg);
  background: var(--lime);
  font-weight: 900;
  font-size: 11px;
  width: 18px; height: 18px;
  line-height: 18px;
  text-align: center;
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle;
}

.forall {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--muted);
  max-width: 44ch;
  border-left: 3px solid rgba(156,255,46,0.45);
  padding-left: 12px;
}

/* ============================================================
   FORMULARIO (columna derecha) — lo importante
   ============================================================ */
.form-wrap { display: flex; flex-direction: column; gap: 12px; }

.card {
  background: var(--card);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 26px 24px 22px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}

.card__title {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.01em;
  margin-bottom: 4px;
}
.card__sub {
  font-size: 13.5px;
  color: var(--muted);
  margin-bottom: 18px;
  line-height: 1.4;
}

.field { margin-bottom: 12px; }
.field label {
  display: block;
  font-size: 12.5px;
  font-weight: 700;
  color: #d7d9dc;
  margin-bottom: 6px;
}
.field input {
  width: 100%;
  background: #0e0f11;
  border: 1.5px solid var(--line);
  border-radius: 10px;
  color: var(--fg);
  font-size: 16px;            /* 16px evita zoom automatico en iOS */
  padding: 12px 14px;
  transition: border-color .15s, box-shadow .15s;
}
.field input::placeholder { color: #6b7077; }
.field input:focus {
  outline: none;
  border-color: var(--lime);
  box-shadow: 0 0 0 3px rgba(156,255,46,0.18);
}
.field input.is-invalid { border-color: var(--red); }

.error {
  display: block;
  color: var(--red);
  font-size: 12px;
  margin-top: 5px;
  min-height: 1px;
}

.consent {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  font-size: 12.5px;
  line-height: 1.4;
  color: var(--muted);
  margin: 6px 0 2px;
  cursor: pointer;
}
.consent input {
  width: 17px; height: 17px;
  margin-top: 1px;
  accent-color: var(--lime);
  flex: 0 0 auto;
}
.muted-link { color: var(--muted); text-decoration: underline; }

.btn {
  width: 100%;
  margin-top: 14px;
  background: var(--lime);
  color: #07140a;
  font-family: inherit;
  font-size: 16.5px;
  font-weight: 900;
  letter-spacing: -0.01em;
  border: none;
  border-radius: 12px;
  padding: 15px 18px;
  cursor: pointer;
  transition: transform .08s, filter .15s, box-shadow .15s;
  box-shadow: 0 10px 26px rgba(156,255,46,0.28);
}
.btn:hover { filter: brightness(1.06); box-shadow: 0 12px 30px rgba(156,255,46,0.4); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: .6; cursor: progress; }

.reassure {
  font-size: 12px;
  line-height: 1.45;
  color: var(--muted);
  text-align: center;
  margin-top: 12px;
}

.status {
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 12px;
  font-size: 14.5px;
  line-height: 1.4;
}
.status--ok  { background: rgba(156,255,46,0.12); border: 1px solid rgba(156,255,46,0.5); color: #eafbe1; }
.status--err { background: rgba(255,59,48,0.10); border: 1px solid rgba(255,59,48,0.5); color: #ffd9d6; }

.disclaimer {
  font-size: 10.5px;
  line-height: 1.45;
  color: #7a7e84;
  text-align: center;
  padding: 0 6px;
}

/* ============================================================
   RESPONSIVE — movil: stack compacto, imagen de fondo + form
   ============================================================ */
@media (max-width: 860px) {
  .grid {
    grid-template-columns: 1fr;
    gap: 22px;
    padding: 26px 18px;
    align-content: center;
  }
  .stage__overlay {
    background:
      linear-gradient(180deg, rgba(11,11,12,0.78) 0%, rgba(11,11,12,0.9) 55%, rgba(11,11,12,0.96) 100%);
  }
  .headline { font-size: clamp(26px, 8vw, 38px); }
  .sub { font-size: 15px; max-width: 100%; }
  /* En movil priorizamos el form: ocultamos detalles secundarios para evitar scroll */
  .points li:nth-child(n+2) { display: none; }
  .points { margin-bottom: 14px; }
  .forall { display: none; }
  .card { padding: 20px 16px 18px; }
  .card__sub { margin-bottom: 14px; }
}

/* Pantallas muy bajas: permitir scroll suave en vez de cortar contenido */
@media (max-height: 680px) {
  .stage { min-height: auto; align-items: flex-start; }
  body { overflow-y: auto; }
  .grid { padding-top: 24px; padding-bottom: 24px; }
}
