/* Asegurar que el body tenga altura completa y respete el footer */
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
}

/* Para cualquier body con fondo personalizado y footer al fondo */
#indexbody,
#bodycontacto {
  position: relative;
  min-height: 100%;
  padding-bottom: 60px; /* igual o mayor al alto del footer */
}

/* Contenedor general si se usa en algunas páginas */
#contenido {
  padding-bottom: 60px;
}

/* Cards con fondo blanco traslúcido */
#test {
  background-color: rgba(255, 255, 255, 0.541);
  border-radius: 20px;
}

/* Footer con altura fija */
footer {
  height: 50px;
  line-height: 50px;
  width: 100%;
  background-color: black;
  color: white;
  text-align: center;
}
