/*
Main Style:
- Header completo (Datos + Navegación).
- Sector Hero.
- Footer.

Media Queries
- Móvil - Tablet 760 - 1024 - Escritorio.
*/

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');

/* Variables */
:root{
    --colorAzul: #033880;
    --colorVerde: #04919d;
    --colorCeleste: #1aacc1;
    --colorBlanco: #fff;
    --colorClaro: #f4f4f4;
    --bordesRadio: 8px;
    --colorHover: ;
    --colorGris:#ccc;
    --sizeTextoMovil: 1.12rem;
    --sizeTextoTablet: 1.059rem;
    --sizeTextoDesktop: 1.05rem;}

*{box-sizing: border-box;}

#construccion{
    width: 100vw;
    padding: 18px;
    top: 275px;
    left: 0px;
    z-index: 101;
    position: fixed;
    box-shadow: 0 3px 15px rgba(0, 0, 0, 0.5);
    background-color: rgba(255, 255, 255, 0.95);}

#construccion p{
    font-size: 30px;
    text-align: center;
    margin: 0;
    font-weight: 700;}


/* Títulos */
h1, h2, h3, h4, h5, h6{font-family: "Roboto", sans-serif; font-size: 1.75rem; text-align: center; margin-top: 0;}

body, nav, header, main, footer{width: 100%;}

/* ///////////////////////////////////////// */

body{margin: 0 auto; background-color: var(--colorClaro);}

/* Marcador */
#up{scroll-margin-top: 157px;}

/*WhatsApp*/
#ws{
    width: 72px;
    right: 40px;
    bottom: 70px;
    z-index: 200;
    position: fixed;
    cursor: pointer;}

#ws img{width: 100%;}

/*Flecha Arriba*/
#flecha{
    width: 48px;
    right: 51px;
    bottom: 15px;
    position: fixed;
    cursor: pointer;
    display: none;
    z-index: 100;}

#flecha img{width: 100%;}

/* Header */
header{
    height: 157px; 
    position: fixed; 
    z-index: 200;
    top: 0;
    left: 0;}

#cardDatos{
    width: 100%;
    height: auto;
    padding: 15px 8px;
    background-color: var(--colorAzul);}

#cardDatos .mainWrapper{
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;}    

#dir1, #dir2{display: none;}  

#dir1 img, #dir2 img{width: 21px; margin: -4px -3px 0 0;}

#telTop{display: none;}

#telTop img{
    width: 22px;
    margin: -2px 0 0 0;} 

#correoTop{margin:auto;}

#correoTop img{
    width: 28px;
    margin: -5px 1px 0 4px;}

#cardDatos span{
    color: #fff;
    font-size: var(--sizeTextoMovil);}

#redesUno{width: auto; display: none;} 
#redesUno a{text-decoration: none;}

/* Menú de navegación */
.mainWrapperNav{
  width: 100%;
  background-color:var(--colorBlanco) !important;
  margin: 0 auto;}

.navbar-brand{width: 240px;}
#loguito{width: 100%; margin-left: 5px;}

.navbar{
    width: 100%;
    max-width: 1920px;
    min-height: 100px;
    margin: auto;   
    box-shadow: 0 5px 8px rgba(0, 0, 0, 0.5);
    padding-top: 20px;
    padding-bottom: 20px;
    position: relative;
    background-color: var(--colorBlanco) !important;}

.navbar .mainWrapper{
  max-width: 1920px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;}      

.navbar .nav-link{
    color: var(--colorAzul) !important;
    text-align: right;
    margin-right: 15px;
    font-weight: 600;
    height: 50px;}

.navbar-nav .nav-item{
    border-bottom: 1px solid rgba(3, 56, 128, 0.2) !important;
    padding: 20px 0 8px 0;}

.navbar-nav .nav-item:last-child{margin-bottom: 10px;}

/* Menú Hamburguesa */
.navbar-toggler{color: var(--colorResaltado); border:0px solid #fff; background-color: transparent !important; font-size: 26px;}
.navbar-toggler:focus{box-shadow: 0px 0px 10px var(--colorPrincipal);}

.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(3,56,128,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");}

.navbar-nav .nav-item{padding-left: 0; padding-right: 15px;}  
.navbar-nav .nav-link {padding: 10px 0 0 0; padding-bottom: 45px;}

/* Evita que la capa overlay robe los eventos táctiles/clicks */
.carousel-item::before {
  pointer-events: none;}

/* Asegura que los controles queden por encima */
.carousel-control-prev,
.carousel-control-next {
  z-index: 100; /* >1 (overlay) */}

/* Carousel */
#bannerPrincipal{
    width: 100%;
    height: 100vh;
    margin-top: 180px;
    position: relative;
    /* background:rgba(0,0,0,0.6); */
    /* background-blend-mode: darken; */}

.carousel-item .mainWrapper{
    max-width: 1920px;
    margin: 0 auto;
    background-color: #04919d !important;}

#bannerPrincipal .textosBanner{
    width: 100%;
    height: auto;
    position: absolute;
    top: 35px;
    z-index: 100;}    

h1{
    padding: 16px;
    background-color: rgba(0, 0, 0, 0.5);}    

h1, .textosBanner h2{
    color: var(--colorClaro);
    font-size: 48px;
    text-align: center;
    font-weight: 900;
    margin: 0;
    padding: 16px;
    transform: scaleY(1.05);
    transform-origin: center;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.9);}   

#botonTurno{
    width: 200px;
    height: 45px;
    display: block;
    text-decoration: none;
    text-align: center;
    font-weight: 700;
    line-height: 45px;
    color: var(--colorClaro);      
    margin: 85px auto 0 auto;
    border-radius: var(--bordesRadio);
    z-index: 100;    
    background-color: var(--colorAzul);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.7);}

.carousel, .carousel-inner, .carousel-item, .carousel-item img{
    width: 100%;
    height: 100%;}
   
.carousel-item{position: relative;} 
.carousel-item::before{
  content: "";
  position: absolute;
  inset: 0;
  /* background: rgba(0,0,0,0.5); */
  /* mix-blend-mode: darken; */ /* o background-blend-mode: darken; */
  z-index: 1;}   

.carousel-item img{object-fit: cover;}
#banner1{object-position: 82% 0px;}
#banner2{object-position: calc(100% - -250px) 0}
#banner3{object-position: -250px 0px;}

.carousel-inner{border-bottom: 12px solid var(--colorVerde) !important;}
 
/* Footer */
footer{
    height: 900px;
    position: relative;
    padding: 75px 0 24px 0;
    background-color: var(--colorAzul);}

footer .mainWrapper{width: 76%; margin: auto;}    

#logoFooter{
    margin: 0 auto 50px auto;
    width: 150px;
    border-radius: 8px;}

#logoFooter img{width: 100%; border-radius: 8px;}

#redesFooter{
    width: 130px;
    margin: auto;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--colorCeleste);
    display: flex;
    justify-content: space-around;}

#redesFooter a img{width:40px;}

/* Bloque 2 placas Footer */
#placaFooter{
    width: 100%;
    margin: 50px 0;}

#placaFooter h3{
    color: var(--colorClaro);
    text-align: center;
    font-size: 22px;}

#turnosFooter, #cargaCv{
    width: 100%;
    margin-bottom: 50px;
    padding: 28px;
    border-radius: var(--bordesRadio);
    border: 2px solid var(--colorClaro);}

#footerBotonTurno{
    width: 200px;
    height: 45px;
    display: block;
    text-decoration: none;
    text-align: center;
    font-weight: 700;
    font-size: 16px;
    line-height: 45px;
    color: var(--colorAzul);      
    margin: 24px auto 0 auto;
    border-radius: var(--bordesRadio);
    z-index: 100;    
    background-color: var(--colorClaro);
    box-shadow: 0 10px 8px rgba(0, 0, 0, 0.3);}

#cvBoton{
    width: 200px;
    height: 45px;
    display: block;
    text-decoration: none;
    text-align: center;
    font-weight: 700;
    font-size: 16px;
    line-height: 45px;
    color: var(--colorAzul);      
    margin: 24px auto 0 auto;
    border-radius: var(--bordesRadio);
    z-index: 100;    
    background-color: var(--colorBlanco);
    box-shadow: 0 10px 8px rgba(0, 0, 0, 0.3);}

#down{
    width: 100%;
    height: auto;
    padding: 25px 18px 24px;
    margin: 0;
    position: absolute;
    bottom: 0;
    left: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.2);}

#down p{color: #fff; text-align: center; font-size: 1.1rem; margin: 0;}
#down a{color: rgb(255, 255, 255);}
#down a:hover{color: var(--colorCeleste);}

/* /////////////// */

@media (min-width: 760px){
    /* Header */ 
    #cardDatos{
    width: 100%;
    height: 50px;
    padding: 10px 52px;
    background-color: var(--colorAzul);}

    #cardDatos .mainWrapper{
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;}   

    #dir1, #dir2{display: none;}  

    #dir1 img, #dir2 img, #telTop img{
    width: 38px;
    margin: -2px -3px 0 0;}

    #telTop{margin-right: 40px; display: block;}

    #telTop img{
    width: 24px;
    margin: -2px 0 0 0;}

    #correoTop{margin:0 32px 0 0;}

    #correoTop img{
    width: 30px;
    margin: -5px 1px 0 4px;}

    #cardDatos span{
    color: #fff;
    font-size: var(--sizeTextoMovil);}

    #redesUno{
    width: 80px; 
    padding: 0;
    display: flex; 
    justify-content: space-between;} 

    #redesUno img{width: 32px; height: 32px;}
    #redesUno a{text-decoration: none;}

    /* Menú de navegación */
    .navbar-brand{width: 275px;}
    #loguito{width: 100%; /* margin-left: 40px; */}

    .navbar{
    width: 100%;
    max-width: 1920px;
    min-height: 100px;
    box-shadow: 0 5px 8px rgba(0, 0, 0, 0.5);
    padding: 20px 28px;    
    position: relative;
    background-color: var(--colorBlanco) !important;}

    .navbar .nav-link{
    color: var(--colorAzul) !important;
    text-align: right;
    margin-right: 15px;
    font-weight: 600;
    height: 50px;}

    .navbar-nav .nav-item{
    border-bottom: 1px solid rgba(3, 56, 128, 0.2) !important;
    padding: 20px 0 8px 0;}

    .navbar-nav .nav-item:last-child{margin-bottom: 10px;}

    /* Menú Hamburguesa */
    .navbar-toggler{color: var(--colorResaltado); border:0px solid #fff; background-color: transparent !important; font-size: 26px;}
    .navbar-toggler:focus{box-shadow: 0px 0px 10px var(--colorPrincipal);}

    .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(3,56,128,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");}

    .navbar-nav .nav-item{padding-left: 0; padding-right: 15px;}  
    .navbar-nav .nav-link {padding: 10px 0 0 0; padding-bottom: 45px;}

    /* Carousel */
    #bannerPrincipal{
    width: 100%;
    height: 100vh;
    background-color: var(--colorGris);}

    .carousel, .carousel-inner, .carousel-item, .carousel-item img{
    width: 100%;
    height: 100%;}

    .carousel-item img{object-fit: cover;}
    #banner1{object-position: center 0;}
    #banner2{object-position: calc(100% - -250px) 0}
    #banner3{object-position: center 0px;}

    .carousel-inner{border-bottom: 12px solid var(--colorVerde) !important;}

    #bannerPrincipal .textosBanner{
    width: 500px;
    height: auto;
    position: absolute;
    top: 132px;
    left: 24px;
    z-index: 100;}    

    h1{
    color: var(--colorClaro);
    font-size: 48px;
    text-align: center;
    font-weight: 900;
    margin: 0;
    padding: 16px;
    transform: scaleY(1.05);
    transform-origin: center;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.9);
    background-color: transparent;}

    #botonTurno{
    width: 200px;
    height: 45px;
    display: block;
    text-decoration: none;
    text-align: center;
    font-weight: 700;
    line-height: 45px;
    color: var(--colorClaro);      
    margin: 24px auto 0 auto;
    border-radius: var(--bordesRadio);
    z-index: 100;    
    background-color: var(--colorAzul);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.7);}

    #turnosFooter, #cargaCv{
    width: 60%;
    margin: 0 auto 50px auto;
    padding: 32px;
    border-radius: var(--bordesRadio);
    border: 2px solid var(--colorClaro);}

    #down{
    width: 100%;
    height: auto;
    padding: 25px 18px 24px;
    margin: 0;
    position: absolute;
    bottom: 0;
    left: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.2);}

    #down p{color: #fff; text-align: center; font-size: 1.1rem; margin: 0;}
    #down a{color: rgb(255, 255, 255);}
    #down a:hover{color: var(--colorCeleste);}
}

@media (min-width: 992px){
    /* Header */ 
    #cardDatos{
    width: 100%;
    height: 50px;
    padding: 10px 40px;
    background-color: var(--colorAzul);}

    #cardDatos .mainWrapper{
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;} 

    .navbar-brand{width: 245px;}

    /* Ajuste del ancho del menú desplegable */
    .navbar-collapse{
    all: unset;
    display: flex !important;
    flex-basis: auto;
    align-items: center;}

    .navbar{
    width: 100%;
    max-width: 1920px;
    min-height: 100px;
    background-color:var(--colorBlanco) !important;
    box-shadow: 0 5px 8px rgba(0, 0, 0, 0.5);
    padding: 20px 16px;    
    position: relative;}

    .navbar-nav{margin-left: auto;}

    .navbar-nav .nav-item{
    width: auto;    
    border-bottom: none !important;
    border-right: 1px solid rgba(255, 255, 255, 0.2); padding: 20px 0;}

    .navbar-nav .nav-item:last-child{margin-bottom: 0px; border-right: none;}
    .navbar .nav-link{
    margin: 0 !important; 
    position: relative;
    padding: 10px 10px 45px !important;
    margin-left: -1px !important;
    border-right: 1px solid rgba(3, 56, 128, 0.2);
    text-decoration: none;}
   
    .nav-link::after{
    content: '';
    position: absolute;
    bottom: 12px;
    /* left: 0; */
    left: 50%;
    transform: translateX(-50%);
    width: 0%;
    height: 1.3px;
    background-color: var(--colorResaltado);
    transition: width 0.3s ease-in-out;}
      
    .nav-link:hover::after{width: 85%;} 
    
    /* Carousel */
    #bannerPrincipal{
    width: 100%;
    height: 100vh;
    margin-top: 180px;
    position: relative;
    /* background:rgba(0,0,0,0.6); */
    /* background-blend-mode: darken; */}

    #bannerPrincipal{
    width: 100%;
    height: 100vh;
    margin-top: 180px;
    position: relative;
    /* background:rgba(0,0,0,0.6); */
    /* background-blend-mode: darken; */}

    .carousel, .carousel-inner, .carousel-item, .carousel-item img{
    width: 100%;
    height: 100%;}

    .carousel-item img{object-fit: cover;}
    #banner1{object-position: center 0px;}
    #banner2{object-position: center 0px;}
    #banner3{object-position: center -55px;}

    /* Footer */
    footer{
    height: 700px;
    position: relative;
    padding: 75px 0 24px 0;
    background-color: var(--colorAzul);}

    /* Bloque placas Footer */
    #placaFooter{
    width: 100%;
    margin: 75px 0;
    display: flex;
    justify-content: space-between;}

    #turnosFooter, #cargaCv{
    width: 44%;
    margin: 0 auto 50px auto;
    padding: 32px;
    border-radius: var(--bordesRadio);
    border: 2px solid var(--colorClaro);}    
}

@media (min-width: 1024px){}

@media (min-width: 1200px){
    /*WhatsApp*/
    #ws{
    width: 72px;
    right: 90px;
    bottom: 75px;
    z-index: 200;
    position: fixed;
    cursor: pointer;}

    #ws img{width: 100%;}

    /*Flecha Arriba*/
    #flecha{
    width: 48px;
    right: 101px;
    bottom: 24px;
    position: fixed;
    cursor: pointer;
    display: none;
    z-index: 100;}

    #flecha img{width: 100%;}

    /* Header */ 
    header{
    width: 100%;    
    height: 157px; 
    position: fixed; 
    z-index: 200;
    top: 0;
    left: 0;}

    #cardDatos{
    width: 100%;
    min-width: 1400px;
    height: 50px;
    margin: auto;
    padding: 10px 45px 0 25px;
    background-color: var(--colorAzul);}

    #cardDatos .mainWrapper{
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    display: flex;
    gap: 0;
    justify-content: space-between;
    align-items: center;} 

    #dir1, #dir2{display: block;}

    #dir1 img, #dir2 img{width: 21px; margin: -4px -3px 0 0;}

    #telTop img{
    width: 21px;
    margin: -2px -3px 0 0;}

    #telTop{margin-right: 0;}

    #telTop img{
    width: 24px;
    margin: -2px 0 0 0;}

    #correoTop{margin-right: 0;}

    #correoTop img{
    width: 30px;
    margin: -5px 1px 0 4px;}

    #cardDatos span{
    color: #fff;
    font-size: var(--sizeTextoMovil);}

    #redesUno{
    width: 80px; 
    padding: 0;
    display: flex; 
    justify-content: space-between;} 

    /* Menú de navegación */
    .mainWrapperNav{
    width: 100%;
    background-color:var(--colorBlanco) !important;
    box-shadow: 0 5px 8px rgba(0, 0, 0, 0.5);
    margin: 0 auto;}

    #redesUno img{width: 32px; height: 32px;}
    #redesUno a{text-decoration: none;}

    .navbar{
    width: 100%;
    max-width: 1920px;
    min-height: 100px;
    margin: auto;
    box-shadow: none;
    padding: 6px 56px 6px 68px;    
    position: relative;
    background-color: var(--colorBlanco) !important;}

    .navbar-brand{width: 232px;}

    .navbar-nav{margin-left: auto;}

    .navbar-nav .nav-item{
    width: auto;    
    border-bottom: none !important;
    border-right: 1px solid rgba(255, 255, 255, 0.2); padding: 20px 0;}

    .navbar-nav .nav-item:last-child{margin-bottom: 0px; border-right: none;}
    .navbar .nav-link{
    margin: 0 !important; 
    position: relative;
    padding: 10px 20px 45px !important;
    margin-left: -1px !important;
    border-right: none;
    text-decoration: none;
    font-weight: 700;
    font-size: 15px;}

    .nav-link:hover{color: var(--colorVerde) !important;}
   
    .nav-link::after{
    content: '';
    position: absolute;
    bottom: 12px;
    /* left: 0; */
    left: 50%;
    transform: translateX(-50%);
    width: 0%;
    height: 1.3px;
    background-color: var(--colorVerde);
    transition: width 0.3s ease-in-out;}
      
    .nav-link:hover::after{width: 85%;}

    #bannerPrincipal{
    width: 100%;
    height: 100vh;
    max-height: 1000px;
    margin-top: 157px;
    border-bottom: 12px solid var(--colorVerde);
    background-color: var(--colorGris);}

    /* Carousel */
    #bannerPrincipal{
    width: 100%;
    height: 100vh;
    max-height: 1000px;
    background-color: var(--colorGris);}

   .carousel-item{position: relative;}

    /* wrapper centrado y con tope de 1920px */
    .carousel-item .mainWrapper {
    position: absolute;         /* lo saca del flujo y lo posiciona sobre la imagen */
    left: 50%;                  /* lo centra horizontalmente */
    transform: translateX(-50%);
    width: 100%;                /* para que use todo el ancho posible pero... */
    max-width: 1920px;          /* ...no supere 1920px */
    padding: 0 24px;            /* espacio lateral (ajustalo) */
    z-index: 2;                 /* encima de la img */}

    #bannerPrincipal .textosBanner{
    width: 600px;
    height: auto;
    position: absolute;
    top: 124px;
    left: 50px;
    z-index: 100;}    

    h1{
    color: var(--colorClaro);
    font-size: 48px;
    text-align: center;
    font-weight: 900;
    margin: 0;
    padding: 16px;
    transform: scaleY(1.05);
    transform-origin: center;
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.9);}

    #botonTurno{
    width: 200px;
    height: 45px;
    display: block;
    text-decoration: none;
    text-align: center;
    font-weight: 700;
    line-height: 45px;
    color: var(--colorClaro);      
    margin: 24px auto 0 auto;
    border-radius: var(--bordesRadio);
    z-index: 100;    
    background-color: var(--colorAzul);
    box-shadow: 0 3px 8px rgba(0, 0, 0, 0.7);
    transition: 0.5s;} 
    
    #botonTurno:hover{
    background-color: var(--colorVerde);
    transform: translateY(-3px);}

    .carousel, .carousel-inner, .carousel-item, .carousel-item img{
    width: 100%;
    height: 100%;}

    .carousel-item img{object-fit: cover;}
    #banner1{object-position: center 50%;}
    #banner2{object-position: center 90%;}
    #banner3{object-position: center 70%;}

    /* Bloque placas Footer */
    #placaFooter{
    width: 65%;
    margin: 75px auto;
    display: flex;
    justify-content: space-between;}

    #turnosFooter, #cargaCv{
    width: 44%;
    margin: 0 auto 50px auto;
    padding: 32px;
    border-radius: var(--bordesRadio);
    border: 2px solid var(--colorClaro);} 

    #footerBotonTurno, #cvBoton{transition: 0.3s;}
    #footerBotonTurno:hover, #cvBoton:hover{
    background-color: var(--colorCeleste);
    transform: scale(0.98);
    box-shadow: none;}
}