/* =========================================================
   NECORA Landing — 12-benefits.css
   EXTRAÍDO DESDE landing.css v30.5
   Scope:
   - benefits mini
   - head
   - mobile overlap
   - mini cards
   - proof + CTA
   - fillout embed
   ========================================================= */

/* =========================================================
   @benefits
   13) BENEFITS MINI — CLEAR PRO v7 (menos texto, más entendible)
   ========================================================= */

.nl-benefitsMini__seo{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip: rect(0,0,0,0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  border:0 !important;
}

.nl-benefitsMini{
  position: relative;
  padding-top: clamp(18px, 3.4vw, 42px);
  padding-bottom: clamp(18px, 3.6vw, 44px);
  overflow: visible;
  isolation: isolate;
}

/* Head: más simple y directo */
.nl-benefitsMini__head{
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}

/* (Si todavía dejas kicker en PHP, lo bajamos para que no estorbe) */
.nl-benefitsMini .nl-kicker{
  margin:0 0 8px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:11px;
  font-weight: 1000;
  color: rgba(0,161,223,.78);
  position: relative;
  opacity: .95;
}

.nl-benefitsMini .nl-kicker::after{
  content:"";
  display:block;
  width: 38px;
  height: 2px;
  border-radius: 999px;
  margin: 10px auto 0;
  background: rgba(0,161,223,.28);
}

.nl-benefitsMini .nl-h2{
  margin:0;
  letter-spacing: -0.028em;
  color: rgba(12,18,28,.94);
  text-shadow: none !important;
  line-height: 1.08;
}

.nl-benefitsMini .nl-sub{
  margin-top:8px;
  max-width: 54ch;
  margin-left: auto;
  margin-right: auto;
  font-size: 15px;
  line-height: 1.45;
  color: rgba(12,18,28,.62);
}

/* Rail blanco arriba (lo dejamos pero más sutil) */
.nl-benefitsMini::before{
  content:"";
  position:absolute;
  left: 50%;
  transform: translateX(-50%);
  top: clamp(10px, 2.2vw, 16px);
  width: var(--nl-bf-rail-w);
  height: var(--nl-bf-rail-h);
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92));
  border: 0 !important;
  box-shadow: 0 10px 22px rgba(10,20,35,.06);
  opacity: .96;
  pointer-events:none;
  z-index: 2;
}

.nl-benefitsMini > *{
  position: relative;
  z-index: 3;
}

/* Grid */
.nl-benefitsMini__row{
  margin-top: 16px;
  display:grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0,1fr));
  align-items: stretch;
}

@media (min-width:860px){
  .nl-benefitsMini__row{
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 14px;
    margin-top: 18px;
  }
}

@media (max-width:859px){
  .nl-miniCard--wide{ grid-column: 1 / -1; }
}

/* Mobile overlap (lo respetamos) */
@media (max-width: 1023px){
  .nl-heroFrame{ position: relative; z-index: 1; }
  #necora-landing.nl{ position: relative; z-index: 2; }

  section#beneficios.nl-benefitsMini,
  .nl-benefitsMini#beneficios{
    position: relative;
    z-index: 5;

    margin-top: calc(var(--nl-mobileLift) * -1);
    padding-top: calc(var(--nl-mobileLift) + clamp(14px, 3.6vw, 20px));
    padding-bottom: clamp(18px, 4.2vw, 28px);

    border-radius: calc(var(--nl-appRadius) - 6px);
    border: 1px solid rgba(12,18,28,.06);
    background: var(--nl-bf-card);
    box-shadow: var(--nl-bf-shadow);
    overflow: hidden;
  }

  section#beneficios.nl-benefitsMini::before,
  .nl-benefitsMini#beneficios::before{
    top: calc(var(--nl-mobileLift) - 18px);
    width: calc(100% - 36px);
    height: 5px;
    opacity: .96;
  }

  section#beneficios.nl-benefitsMini hr,
  .nl-benefitsMini#beneficios hr{
    display:none !important;
  }
}

@media (max-width: 420px){
  :root{ --nl-mobileLift: 44px; }

  .nl-benefitsMini__row{
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 16px;
  }

  section#beneficios.nl-benefitsMini,
  .nl-benefitsMini#beneficios{
    border-radius: 26px;
  }

  section#beneficios.nl-benefitsMini::before,
  .nl-benefitsMini#beneficios::before{
    width: calc(100% - 24px);
    height: 4px;
  }
}

/* =========================================================
   13.1) BENEFITS MINI — Center pills on small phones (REAL FIX)
   - 331–451px: centra el pill completo (icon + texto) sin romper desktop
   - <=320px: se va a columna (perfecto en mini móviles)
   ========================================================= */

/* 331–451: centra TODO el contenido del pill (fila centrada) */
@media (min-width: 331px) and (max-width: 451px){
  .nl-benefitsMini .nl-miniCard{
    justify-content: center;
  }

  .nl-benefitsMini .nl-miniCard__in{
    justify-content: center;
    align-items: center;
    text-align: center;
  }

  .nl-benefitsMini .nl-miniCard__copy{
    text-align: center;
    align-items: center;
  }

  .nl-benefitsMini .nl-miniCard__title,
  .nl-benefitsMini .nl-miniCard__sub{
    text-align: center;
  }

  .nl-benefitsMini .nl-miniCard__copy{
    margin-left: 0;
  }
}

/* <=320: columna (icon arriba, texto abajo) */
@media (max-width: 320px){
  .nl-benefitsMini .nl-miniCard{
    justify-content: center;
    text-align:center;
  }

  .nl-benefitsMini .nl-miniCard__in{
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 8px;
  }

  .nl-benefitsMini .nl-miniCard__copy{
    text-align: center;
    align-items: center;
    margin-left: 0;
  }

  .nl-benefitsMini .nl-miniCard__sub{
    max-width: 24ch;
    margin-left: auto;
    margin-right: auto;
  }
}

/* =========================================================
   Mini Cards — más entendibles (icono + título grande + 1 línea)
   ========================================================= */
.nl-miniCard{
  position:relative;
  display:flex;
  gap:12px;
  align-items:center;
  min-width:0;

  padding: 14px 16px;
  border-radius: 22px;

  border: 1px solid rgba(12,18,28,.08) !important;
  background: #fff !important;

  box-shadow:
    0 10px 22px rgba(10,20,35,.06),
    inset 0 1px 0 rgba(255,255,255,.95) !important;

  transition:
    transform .18s ease,
    box-shadow .18s ease,
    border-color .18s ease;
}

.nl-miniCard--wide{
  justify-content: center;
  text-align: center;
  gap:14px;
}

.nl-miniCard--wide .nl-miniCard__body{
  text-align:center;
}

@media (hover:hover){
  .nl-miniCard:hover{
    transform: translateY(-1px);
    border-color: rgba(0,161,223,.22) !important;
    box-shadow:
      0 16px 34px rgba(0,161,223,.10),
      inset 0 1px 0 rgba(255,255,255,1) !important;
  }
}

.nl-miniCard:focus-within{
  border-color: rgba(0,161,223,.30) !important;
}

.nl-miniCard__icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  flex: 0 0 auto;

  border: 1px solid rgba(0,161,223,.18) !important;
  background: rgba(0,161,223,.06) !important;
  font-size: 19px;
  line-height: 1;
}

.nl-miniCard__t{
  margin:0;
  font-size:16px;
  font-weight: 1000;
  color: rgba(12,18,28,.92);
  letter-spacing:-0.012em;
  line-height:1.15;
}

.nl-miniCard__p{
  margin:4px 0 0;
  font-size:13.5px;
  color: rgba(12,18,28,.62);
  line-height:1.25;
}

/* Mobile: aún más claro */
@media (max-width: 520px){
  .nl-miniCard{
    padding: 13px 14px;
    border-radius: 20px;
  }

  .nl-miniCard__icon{
    width: 42px;
    height: 42px;
    border-radius: 13px;
    font-size: 18px;
  }

  .nl-miniCard__t{ font-size: 16px; }
  .nl-miniCard__p{ font-size: 13px; }
}

/* =========================================================
   Proof + CTA — más simple
   ========================================================= */
.nl-miniProof{
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;

  font-size: 13.5px;
  line-height: 1.35;
  color: rgba(12,18,28,.62);
}

.nl-miniProof__badge{
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 1000;
  letter-spacing: .10em;
  text-transform: uppercase;

  background: rgba(0,161,223,.08) !important;
  border: 1px solid rgba(0,161,223,.18) !important;
  color: rgba(0,161,223,.90) !important;
  box-shadow: 0 10px 20px rgba(0,161,223,.10) !important;
}

.nl-miniProof__txt{
  font-size: 13.5px;
  color: rgba(12,18,28,.64);
}

/* CTA: centrado + no tan “ruidoso” */
.nl-benefitsMini__cta{
  margin-top: 12px;
  display:flex;
  justify-content:center;
  gap: 10px;
  flex-wrap: wrap;
}

@media (max-width: 520px){
  .nl-benefitsMini__cta{
    flex-direction: column;
    align-items: stretch;
  }

  .nl-benefitsMini__cta .nl-btn{
    width:100%;
    justify-content:center;
  }
}

/* Fillout embed */
.nl-benefitsMini .fillout-embed,
.nl-benefitsMini iframe[src*="fillout"]{
  width: 100%;
  border: 0 !important;
  border-radius: calc(var(--nl-appRadius) - 10px);
  overflow: hidden;
  box-shadow: 0 14px 34px rgba(10,20,35,.08);
}

.nl-form--embed{
  background: #fff;
  border-radius: 26px;
  padding: 6px;
  box-shadow: 0 26px 70px rgba(10,20,35,.12);
}

/* PATCH FINAL — buffer blanco (más sutil para no “ensuciar”) */
@media (max-width:1023px){
  section#beneficios.nl-benefitsMini::after,
  .nl-benefitsMini#beneficios::after{
    content:"";
    position:absolute;
    left: 50%;
    transform: translateX(-50%);
    top: calc(var(--nl-mobileLift) - 64px);
    width: calc(100% - 18px);
    height: 84px;
    border-radius: 999px;
    background: linear-gradient(
      to bottom,
      rgba(255,255,255,1) 0%,
      rgba(255,255,255,1) 48%,
      rgba(255,255,255,0) 100%
    ) !important;
    box-shadow: none !important;
    z-index: 1;
    pointer-events:none;
  }

  section#beneficios.nl-benefitsMini::before,
  .nl-benefitsMini#beneficios::before{
    z-index: 2;
  }

  .nl-benefitsMini > *{
    position: relative;
    z-index: 3;
  }
}

@media (min-width:1024px){
  .nl-benefitsMini{
    background: linear-gradient(to bottom, #fff 0 86px, transparent 87px);
  }
}