.elementor-258 .elementor-element.elementor-element-9fa89b6{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}/* Start custom CSS for html, class: .elementor-element-8161b21 *//* ================= SECCIÓN ================= */
.terminos-web{
  padding:100px 20px;
  background:
    radial-gradient(circle at 20% 20%, rgba(15,103,208,0.08), transparent 40%),
    radial-gradient(circle at 80% 80%, rgba(0,60,135,0.08), transparent 40%),
    linear-gradient(180deg,#f5f9ff,#ffffff);
  font-family: 'Segoe UI', Arial, sans-serif;
}

/* CONTENEDOR */
.container-terminos{
  max-width:1200px;
  margin:auto;
  position:relative;
  z-index:2;
}

/* ================= HEADER ================= */
.header-terminos{
  text-align:center;
  margin-bottom:70px;

  opacity:0;
  transform:translateY(50px);
  transition:all .8s ease;
}

.header-terminos.active{
  opacity:1;
  transform:translateY(0);
}

/* BADGE */
.badge{
  background:linear-gradient(135deg,#0f67d0,#003C87);
  color:#fff;
  padding:10px 20px;
  border-radius:50px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.5px;
  display:inline-block;
  margin-bottom:20px;
  box-shadow:0 5px 20px rgba(15,103,208,0.3);
}

/* TITULO */
.header-terminos h1{
  font-size:48px;
  font-weight:900;
  background:linear-gradient(135deg,#003C87,#0f67d0);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  margin-bottom:20px;
}

/* TEXTO */
.header-terminos p{
  max-width:800px;
  margin:auto;
  font-size:18px;
  color:#5b6e86;
  line-height:1.7;
}

/* ================= GRID ================= */
.contenido-terminos{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
}

/* ================= BLOQUES ================= */
.bloque{
  position:relative;
  background:rgba(255,255,255,0.75);
  backdrop-filter:blur(12px);
  border:1px solid rgba(0,0,0,0.05);

  padding:28px;
  border-radius:20px;

  box-shadow:0 15px 40px rgba(0,0,0,0.08);

  opacity:0;
  transform:translateY(40px);
  transition:all .5s ease;

  overflow:hidden;
}

/* ANIMACIÓN */
.bloque.active{
  opacity:1;
  transform:translateY(0);
}

/* BORDE GRADIENTE SUTIL */
.bloque::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:20px;
  padding:1px;
  background:linear-gradient(135deg,transparent,#0f67d0,transparent);
  -webkit-mask:
    linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
  mask-composite:exclude;
}

/* HOVER PRO */
.bloque:hover{
  transform:translateY(-10px) scale(1.01);
  box-shadow:0 25px 60px rgba(0,0,0,0.15);
}

/* EFECTO LUZ */
.bloque::after{
  content:"";
  position:absolute;
  top:0;
  left:-120%;
  width:100%;
  height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,0.5),transparent);
  transition:.6s;
}

.bloque:hover::after{
  left:120%;
}

/* TITULO BLOQUE */
.bloque h2{
  font-size:20px;
  color:#003C87;
  margin-bottom:15px;
  font-weight:800;
}

/* TEXTO */
.bloque p{
  font-size:15px;
  color:#555;
  line-height:1.7;
}

/* ================= BOTONES ================= */
.links-legales{
  margin-top:20px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.btn-legal{
  flex:1;
  text-align:center;
  padding:12px 18px;
  border-radius:12px;

  background:linear-gradient(135deg,#0f67d0,#003C87);
  color:#fff;
  font-weight:700;
  text-decoration:none;

  transition:.3s;
  box-shadow:0 10px 25px rgba(15,103,208,0.3);
}

/* HOVER BOTÓN */
.btn-legal:hover{
  transform:translateY(-3px);
  box-shadow:0 15px 35px rgba(0,0,0,0.25);
  background:linear-gradient(135deg,#003C87,#0f67d0);
}

/* ================= RESPONSIVE ================= */
@media(max-width:900px){

  .contenido-terminos{
    grid-template-columns:1fr;
  }

  .header-terminos h1{
    font-size:34px;
  }

}

@media(max-width:600px){

  .terminos-web{
    padding:70px 15px;
  }

  .header-terminos p{
    font-size:16px;
  }

  .btn-legal{
    width:100%;
  }

}/* End custom CSS */