html, body {
    height: 100%; /* Asegura que el cuerpo ocupe toda la altura de la ventana */
    margin: 0; /* Elimina márgenes */
}

body {
    display: flex;
    flex-direction: column;
}

main {
    flex: 1; /* Hace que el contenido principal ocupe el espacio disponible */
}

.banner {
   background-color: #00A4D3;
}

.footer {
    background-color: #00A4D3;
    color: white !important;
    padding: 15px;
    text-align: center;
}


.container {
    border: 2px solid #010101; /* Adds a 2px solid blue border */
    border-radius: 5px; /* Optional: Adds rounded corners */
    padding: 10px; /* Optional: Adds padding inside the container */
}

.card {
    border: 2px solid blue !important; /* Cambia el borde a azul */
    border-radius: 5px; /* Opcional: añade esquinas redondeadas */
}
h1, h2, h3, p {
    color: #00355b;
}
select, input, textarea {
    color: #7B7E7E;
}
.app-main {
    background-color: #a5dee9;
}

label {
    color: #555; /* Gris medio en lugar de negro */
    display: block;
    margin-bottom: 5px;
}
input[type="text"],
input[type="tel"],
input[type="email"],
textarea {
    border: 1px solid #ccc;
    border-radius: 4px;
    padding: 10px;
    width: 100%;
    box-sizing: border-box; /* Importante para que el padding no rompa el ancho */
}
