@import url(font.css);
@import url(fontawesome/all.css);


.bg-blue {
    background-color: #002856;
}
/* Logo con fondo azul diagonal solo en desktop */
.navbar-logo-bg {
    background: #002856;
    position: relative;
    z-index: 1;
}

/* En desktop: logo con forma diagonal */
@media (min-width: 992px) {
    .navbar-logo-bg {
        padding: 20px 80px 20px 30px;
        clip-path: polygon(0 0, 80% 0, 90% 100%, 0 100%);
        margin-left: -15px; /* Ajuste para compensar el padding del container */
    }
    
    .navbar-container {
        position: relative;
        background: linear-gradient(to right, #002856 0%, #002856 100px, transparent 101px);
    }
}
/* Ícono hamburguesa blanco */
.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(255,255,255,1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
}


/* Asegura que todo el fondo del navbar sea azul en móvil */
@media (max-width: 991px) {
    .navbar {
        background-color: #002856 !important;
        padding: 15px 0;
    }

    .navbar-container {
        background-color: #002856 !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    .navbar-logo-bg {
        background-color: #002856 !important;
        padding: 15px 15px;
    }

    .navbar-brand img {
        height: 45px !important;
    }

    .navbar-toggler {
        background-color: #ffffff;
        border: none;
        margin-right: 10px;
    }

    .navbar-collapse {
        background-color: #002856 !important;
        padding: 10px 0;
    }

    .nav-link {
        color: #ffffff !important;
        padding: 12px 20px !important;
    }

    .nav-item:hover .nav-link {
        color: #ffffff !important;
    }
}
  
/* En móvil: fondo azul completo con más padding */
@media (max-width: 991px) {
    .navbar {
        background-color: #002856 !important;
        padding: 15px 0; /* Aumentar padding vertical en móvil */
    }
    
    .navbar-toggler {
        background-color: #fff;
        margin-right: 10px;
    }
    
    .navbar-collapse {
        background-color: #002856;
        padding: 10px 0;
    }
    
    .nav-link {
        color: #fff !important;
        padding: 12px 20px !important; /* Mayor padding para los enlaces en móvil */
    }
    
    .navbar-logo-bg {
        padding: 15px 15px; /* Más padding alrededor del logo en móvil */
    }
    
    .navbar-brand img {
        height: 45px !important; /* Logo ligeramente mayor en móvil */
    }
}

/* Eliminar el borde entre el logo y el resto de la navbar */
.navbar {
    overflow: hidden;
}

/* Ajustes del cuerpo */
body {
    overflow-x: hidden; /* Prevenir scroll horizontal */
}
/* Línea debajo del nav-item al pasar el mouse */
.nav-item:hover .nav-link {
    position: relative;
    color: #002856;
    font-weight: bold;
}
/* Ajustes para la sección de bienvenida */
.hero-section {
    position: relative; /* Contenedor relativo para controlar las imágenes dentro */
    background-color: #002856;
    color: #fff;
    padding: 0;
    margin: 0;
    overflow: hidden; /* Para evitar posibles desbordamientos */
}
.hero-section .container {
    padding: 0; /* Eliminar padding del contenedor */
}

.hero-section .image-container {
    position: relative;
    height: 400px; /* Altura fija para el contenedor de imágenes */
    width: 100%;
}

.hero-section img {
    position: absolute; /* Posición absoluta en lugar de relativa */
    top: 0;
    right: 0;
    width: 60%;
    height: auto;
    object-fit: cover;
    transition: opacity 1s ease-in-out;
    opacity: 0;
    z-index: 1;
}

.hero-section img.active {
    opacity: 1;
    z-index: 2;
}

.floating-icons {
    position: absolute;
    top: 50%;
    left: 10%;
    width: 100%;
    height: 100%;
    z-index: 1; /* Íconos debajo de la imagen pero arriba del fondo azul */
    transform: translateY(-50%);
}
.floating-icons i {
    position: absolute;
    font-size: 20px;
    opacity: 0;
    animation: floatingIcons 6s infinite ease-in-out;
}

@keyframes floatingIcons {
    0% {
        transform: scale(0.3);
        opacity: 0;
    }
    30% {
        opacity: 0.5;
    }
    70% {
        opacity: 0;
    }
    100% {
        transform: scale(10);
        opacity: 0;
    }
}

.floating-icons i:nth-child(1) { top: 10%; left: 15%; animation-delay: 0s; }
.floating-icons i:nth-child(2) { top: 50%; left: 5%; animation-delay: 1.5s; }
.floating-icons i:nth-child(3) { top: 30%; left: 40%; animation-delay: 3s; }
.floating-icons i:nth-child(4) { top: 80%; left: 20%; animation-delay: 4.5s; }
.floating-icons i:nth-child(5) { top: 60%; left: 70%; animation-delay: 6s; }
.floating-icons i:nth-child(6) { top: 15%; left: 85%; animation-delay: 7.5s; }
.floating-icons i:nth-child(7) { top: 70%; left: 50%; animation-delay: 9s; }

/* Contenedor para los textos animados */
.text-container {
    height: 60px;
    position: relative;
    margin-bottom: 20px;
    overflow: hidden;
    display: block;
}

/* Estilo base para los textos */
.texto-animado {
    position: absolute;
    margin: 0;
    width: 100%;  /* Anchura fija para evitar el efecto de escritura */
    color: #ffffff;
    top: 0;
    left: 0;
    opacity: 0;
    visibility: hidden;
}

/* Animación simplificada usando solo opacidad */
@keyframes fadeInOut-6textos {
    /* Cálculo: 100% / 6 textos = 16.67% por texto */
    0% { opacity: 0; visibility: hidden; }
    3% { opacity: 1; visibility: visible; }
    13.67% { opacity: 1; visibility: visible; } /* 16.67% - 3% = 13.67% */
    15.67% { opacity: 0; visibility: hidden; } /* Un poco antes del 16.67% */
    100% { opacity: 0; visibility: hidden; }
}

/* Aplicación (con 2s por texto) */
#texto1 { animation: fadeInOut-6textos 12s linear infinite; animation-delay: 0s; }
#texto2 { animation: fadeInOut-6textos 12s linear infinite; animation-delay: 2s; } /* 16.67% del ciclo */
#texto3 { animation: fadeInOut-6textos 12s linear infinite; animation-delay: 4s; } /* 33.33% del ciclo */
#texto4 { animation: fadeInOut-6textos 12s linear infinite; animation-delay: 6s; } /* 50% del ciclo */
#texto5 { animation: fadeInOut-6textos 12s linear infinite; animation-delay: 8s; } /* 66.67% del ciclo */
#texto6 { animation: fadeInOut-6textos 12s linear infinite; animation-delay: 10s; } /* 83.33% del ciclo */

/* Añadimos efecto de cursor parpadeante independiente */
.cursor-effect {
    position: absolute;
    right: -10px;
    top: 0;
    height: 100%;
    width: 3px;
    background-color: #ffffff;
    animation: blink 0.7s infinite;
}

@keyframes blink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

.icon{
    font-size: 50px;
    color: #002856;
}
.img-container {
    position: relative;
    width: 100%;
    height: 100%;
}
.custom-img {
    width: 100%;
    object-fit: cover;
}
.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 51, 102, 0.7);
}
.content-box {
    background-color: rgba(240, 248, 255, 0.9);
    padding: 20px;
    border-radius: 8px;
}
.text-blue {
    color: #002856;
}
/* Animación para el contenido al aparecer */
.fade-in {
    opacity: 0;
    transform: translateY(-20px);
    animation: fadeInDown 0.6s ease-out forwards;
}

/* Definición de la animación */
@keyframes fadeInDown {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.img-container {
    width: 100%;      /* Hace que el contenedor ocupe el 100% del ancho */
    height: 200px;    /* Establece la altura visible que deseas */
    overflow: hidden; /* Recorta cualquier parte de la imagen que se salga del contenedor */
    position: relative;
}

.img-container img {
    width: 100%;      /* Hace que la imagen ocupe el 100% del ancho del contenedor */
    height: 100%;     /* Ajusta la altura de la imagen al 100% del contenedor */
    object-fit: cover; /* Asegura que la imagen cubra todo el contenedor sin distorsionarse */
    transform: scale(1.5); /* Escala la imagen para que sea más grande de lo que se ve */
    object-position: center; /* Centra la imagen para mostrar la parte más importante */
}
/* Estilos específicos para el formulario de citas */
.form-container-wrapper {
    height: auto;  /* Cambiado de 650px a auto para adaptarse al contenido */
    min-height: 850px; /* Altura mínima para mantener la estética */
    position: relative;
    overflow: visible; /* Cambiado de hidden a visible */
}

.form-background-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}

.form-overlay-blue {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 51, 102, 0.7);
}

.form-content-container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-height: 90%;
    z-index: 10;
    overflow-y: auto;  /* Permite desplazamiento si el formulario es muy largo */
}

.form-input-transparent {
    background-color: transparent !important;
    border: none !important;
    border-bottom: 1px solid white !important;
    color: white !important;
}

.form-input-transparent::placeholder {
    color: rgba(255, 255, 255, 0.7) !important;
}

.form-input-transparent:focus {
    box-shadow: none !important;
    border-bottom: 2px solid white !important;
}

.form-submit-button {
    color: #fff !important;
    border: 2px solid #fff !important;
    background: transparent;
    opacity: 1;
    font-weight: bold;
    font-size: 20px !important;
}

.form-submit-button:hover {
    background-color: #fff;
    color: #002856 !important;
}
.carousel-container {
    display: flex;
    overflow: hidden;
    width: 100%;
    position: relative;
}
.carousel-track {
    display: flex;
    transition: transform 0.5s ease-in-out;
}
.card {
    width: 300px;
    margin: 15px;
    border: none;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
    flex-shrink: 0; /* Evita que las tarjetas se redimensionen */
}
/* Botones de navegación */
.carousel-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: #0d6efd;
    border: none;
    color: white;
    padding: 12px;
    border-radius: 50%;
    cursor: pointer;
    z-index: 10;
    width: 45px;
    height: 45px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    transition: background 0.3s ease-in-out;
}
.carousel-btn:hover {
    background: #002856;
}
.carousel-btn.left { left: 10px; }
.carousel-btn.right { right: 10px; }

.phone-box {
    background-color: #002855;
    width: 100%; /* para ocupar todo el ancho */
    padding: 20px;
    clip-path: none; /* quitar clip-path en móvil */
    box-sizing: border-box; /* para que padding no aumente ancho */
  }
  .phone-glow {
    animation: glow 1.8s infinite alternate;
    color: #ffffff;
    text-shadow: 0 0 5px #00eaff, 0 0 10px #00eaff;
  }
  
  @keyframes glow {
    from {
      opacity: 1;
      text-shadow: 0 0 10px #00eaff;
    }
    to {
      opacity: 0.6;
      text-shadow: 0 0 2px #00eaff;
    }
  }
  @media (min-width: 768px) {
    .phone-icon {
      margin-left: 150px;
    }
    .phone-box {
        background-color: #002855;
        clip-path: polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
        min-width: 270px; /* opcional: fuerza el ancho mínimo para que se vea bien */
        width: auto;
      }
    .ml{
        margin-right: 100px;
    }
  }