/* Estilos generales (sin cambios) */
html, body {
    height: 100%;
}

body {
    display: flex;
    flex-direction: column;
}

main {
    flex-grow: 1;
}

.header-custom {
    border-bottom: 10px solid #005d99;
}

.header-logo-text {
    color: #005d99;
}

.main-hero {
    background-image: url('../../pix/Bg-Campus.jpg');
    background-size: cover;
    background-position: center center;
    padding-top: 5rem;
    padding-bottom: 9rem;
}

.login-card {
    background-image: url('../../pix/trama-fondo.png');
    background-size: cover;
    max-width: 35rem;
    width: 100%;
}

.login-card-title-light {
    color: #4c4c4b;
}

.login-card-title-bold {
    color: #005d99;
}

.btn-microsoft {
    background-color: #005d99;
}

.btn-microsoft:hover {
    background-color: #004d7d;
}

.toggle-manual-login {
    font-size: 0.8rem;
    color: #4c4c4b;
    text-decoration: none;
}

.toggle-manual-login:hover {
    text-decoration: underline;
}

.info-cards-section {
    margin-top: -85px;
    margin-bottom: 85px;
}

.footer-custom {
    background-color: #005d99;
    color: white;
}

.footer-custom a {
    color: white;
    text-decoration: none;
}

.footer-custom a:hover {
    text-decoration: underline;
}

.footer-social-box {
    background-color: white;
    border-radius: 10px;
}

.footer-social-box h5 {
    color: #005d99;
}

.footer-social-box i {
    color: #005d99;
    font-size: 18px;
}

.footer-legal-text {
    border-left: 5px solid #a3cc33;
}

.info-card {
    /* ...otros estilos... */
    /* Añade una transición suave para las propiedades transform y box-shadow */
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}

/* Ajustes 29 sep 2025*/

/* Se aplica a pantallas de 768px de ancho en adelante (tabletas y escritorios) */
@media (min-width: 768px) {
    .info-card {
        /* Aumentamos el ancho para que las tarjetas se acerquen */
        max-width: 8rem;
        /* ... otros estilos ... */
    }

    .info-card img {
        /* Hacemos la imagen un poco más pequeña */
        /*width: 42px; !* Un tamaño fijo funciona bien para íconos *!*/
        /*height: 42px;*/
        object-fit: contain;
    }

    .info-card .card-text {
        /* Reducimos el tamaño de la fuente para que encaje mejor */
        font-size: 0.75rem;
    }

    .col-md-2 {
        width: 14%;
    }
}

@media (min-width: 768px) {
    .info-card {
        /* Hacemos la tarjeta un poco más ancha para que se vea bien en horizontal
           y para reducir el espacio entre ellas, como pediste. */
        max-width: 10.5rem;
    }
}

@media (min-width: 992px) {
    .col-md-2 {
        width: 12%;
    }
}

.info-card {
    max-width: 10rem; /* Un tamaño máximo compacto para la vista móvil */
    margin-left: auto;
    margin-right: auto;
    padding: 0.75rem; /* Un relleno interno más ajustado */
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}

.info-card:hover {
    transform: scale(1.05);
    box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .20) !important;
}

.info-card img {
    width: 50px; /* Tamaño fijo para que los íconos se vean nítidos y uniformes */
    height: 50px;
    object-fit: contain;
    margin: 0 auto 0.5rem auto; /* Centrado y con margen inferior */
}

.info-card .card-text {
    font-size: 0.8rem; /* Texto más pequeño para no saturar la vista */
    line-height: 1.3;
}

.card-link {
    text-decoration: none;
    color: inherit;
}

.card-link:hover {
    color: inherit;
}
