/*! HTML5 Boilerplate v5.0 | MIT License | http://h5bp.com/ */
/* Template */ ::-moz-selection {background: #b3d4fc;text-shadow: none;} ::selection {background: #b3d4fc;text-shadow: none;} hr {display: block;height: 1px;border: 0;border-top: 1px solid #ccc;margin: 1em 0;padding: 0;} audio,canvas,iframe,img,svg,video {vertical-align: middle;} fieldset {border: 0;margin: 0;padding: 0;} textarea {resize: vertical;} .browserupgrade {margin: 0.2em 0;background: #ccc;color: #000;padding: 0.2em 0;}
/* Helper classes */ .hidden {display: none !important;visibility: hidden;} .visuallyhidden {border: 0;clip: rect(0 0 0 0);height: 1px;margin: -1px;overflow: hidden;padding: 0;position: absolute;width: 1px;} .visuallyhidden.focusable:active,.visuallyhidden.focusable:focus {clip: auto;height: auto;margin: 0;overflow: visible;position: static;width: auto;} .invisible {visibility: hidden;} .clearfix:before,.clearfix:after {content: " ";display: table;} .clearfix:after {clear: both;} .clearfix {*zoom: 1;}
/* Custom ========================================================================== */

* {box-sizing:border-box !important;}
body{
    font-family: sans-serif;
    box-sizing:border-box !important;
    margin: 0;
    padding-top: 80px;
    overflow-x: hidden;
}
:root {
    --primario: #00BCD4;
    --secundario:#333;
    --texto:#333;
    --texto2:#fff;
}
.container {position:relative;}

/*///////////////////////////////
/// FUNCTIONS
///////////////////////////////*/

/* Header */
#head {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 80px;
    background: transparent;
    z-index: 20;
    transition: 0.2s;
    background-color:var(--primario);
}
#head .container {
    height:100%;
}
#head #logo {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    max-width:200px;
    max-height: 60%;
    width:auto;
    height:auto;
}
#head #logo-text {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    color:var(--texto2);
    font-weight:bold;
    font-size:20px;
}
#head #menu {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
}
#head #menu ul{
    margin:0;
}
#head #menu li {
    margin: 0 0.8em;
    list-style: none;
    display: inline-block;
}
#head #menu li a{
    text-decoration: none;
    color: white;
    font-weight: bold;
    font-size: 15px;
}
#head #hamburguesa {display:none;}


/* Slider */
.slider {margin: 0px;position: relative;width: 100vw;height: 480px;padding: 0px;}
.slider .slide {position: absolute;opacity: 0;transition: opacity 0.3s;z-index: 1;bottom: 0;width: 100%;height: 100%;background-repeat: no-repeat;background-position: center;background-size: cover;}
.slider .slide.on {opacity: 1; z-index: 2; }
.slider .btns {position: absolute;z-index: 10;display:  inline-block;text-align: center;left: 50%;transform: translateX(-50%);bottom: 10px;}
.slider .btn {
    border: solid thin #ADADAD;
    width: 11px;
    height: 11px;
    padding: 0;
    display: inline-block;
    border-radius: 10px;
    margin: 0 4px;
    transition: background 0.5s;
    background: #fff;
}
.slider .btn.on {background: #434344;}
.slider .shadow {
    width: 100%;
    position: absolute;
    bottom: 0px;
    left: 0px;
    height: 250px;
    background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.9) 100%);
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(0,0,0,0)), color-stop(100%,rgba(0,0,0,0.9)));
    background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.9) 100%);
    background: -o-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.9) 100%);
    background: -ms-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.9) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.9) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00333333', endColorstr='#e6333333',GradientType=0 );
}
.slider h2.text1 {position:absolute;bottom: 27%;left:50%;transform:translateX(-50%);font-weight: bold;color:white;line-height: 1.05;text-align: center;text-shadow: 2px 2px 15px rgba(0,0,0,0.9);font-size: 30px;z-index: 10;}
.slider h3.text2 {position:absolute;bottom: 26%;left:50%;transform:translateX(-50%);font-weight: normal;color:white;text-align: center;width: 70%;text-shadow: 2px 2px 10px rgba(0,0,0,0.8);font-size: 16px;margin: 0;max-width: 900px;z-index: 10;}
.slider a.slider-cta {position: absolute;bottom: 12%;left: 50%;transform:translateX(-50%);font-weight:bold;color: white;background-color:var(--primario);padding: 10px 40px;border-radius: 30px;text-decoration: none;}
.slider a.slider-cta:hover {opacity:0.9;}


.seccion {
    position: relative;
    overflow-y: auto;
}
.seccion.imagen-texto {}
.seccion.imagen-texto .img{
    position: absolute;
    top: 0;
    height: 100%;
    width: 45%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.seccion.imagen-texto .texto{
    width: 50%;
    position: relative;
    top: 0;
    height: auto;
    padding: 50px 30px;
}

.seccion.texto-centrado {
    text-align: center;
    padding: 60px 0;
}

.seccion.texto-centrado .miti {
    width: 200px;
    display: inline-block;
    vertical-align: top;
    margin: 20px 0;
}

.icon {
    display: inline-block;
    max-width: 25%;
    max-height: 50px;
    margin-bottom: 10px;
}
.tercio {
    width: 270px;
    margin: 10px 20px;
    display:inline-block;
    vertical-align:top;
    padding: 25px;
    /* text-align:left; */
    border-radius: 20px;
    /* border: 2px solid #e5e5e5; */
}
#servicios .tercio {
    cursor:pointer;
}
#servicios .tercio:hover {
    opacity:0.9;
    background-color:#eaeaea;
}
.modal-hidden {
    display: none;
}
.seccion.texto-centrado .foto-perfil {
    border-radius: 50%;
    width: 120px;
    display: inline-block;
    margin: 0 0 15px;
    border: 2px solid hsla(0, 0%, 87%, 1);
}

#servicios .texto {
    padding: 50px 0;
}

#profesionales {
    background-color: #fafafa;
    border-top: 1px solid hsla(240, 3%, 86%, 1);
    border-bottom: 1px solid #ebebeb;
}

.seccion.imagen-texto.izquierda .texto{left: 45%;}
.seccion.imagen-texto.izquierda .img{left: 0;}

.seccion.imagen-texto.derecha .texto{left: 0%;width: 55%;}
.seccion.imagen-texto.derecha .img {right: 0%;width: 45%;}

.seccion.imagen-texto.arriba .texto {
    width: 100%;
    position: relative;
    text-align: center;
}
.seccion.imagen-texto.arriba .img {
    width: 100%;
    height: 250px;
    background-attachment: fixed;
    background-position: top center;
    position: relative;
}

.texto h2,.texto h3,.texto h4 {font-weight: bold;color: #09284d;}

.seccion.container form {width: 60%;margin:0 auto;}

#contacto {padding: 60px 0;overflow: visible;}
#contacto h2 {text-align: center;font-weight: bold;color: #09284d;}

form#formContacto button[type="submit"].cargando{
    cursor:progress;
}
form#formContacto.sent {
    opacity: 0;
    transition:0.5s;
    max-height: 0px;
    margin: 0;
}
#formEnviado {
    max-height: 0px;
    overflow: hidden;
    width: 960px;
    margin: 30px auto 100px;
}
#formEnviado.on {
    max-height: 300px;
    transition:0.3s;
}

#volver {text-decoration: none;font-weight: bold;}

#top-blog {width:100%;background-color: #eee;overflow: auto;text-align: center;padding: 40px 0 50px;margin: 0 0 30px;}
#top-blog h2 {
    font-weight: bold;
}
#blog {width: 820px;}
#volver {margin-top:30px;display: block;}
#blog .entrada {position: relative;/* margin-bottom: 70px; *//* box-shadow: 3px 3px 20px rgba(0,0,0,0.2); *//* padding: 20px 30px; */margin: 30px 0 50px;background-color: white;}
#blog .entrada.blog-list {padding: 20px 0 0px;border-top: 1px solid #ddd;max-height: 500px;overflow: hidden;margin: 70px 0 0;}
#blog .entrada.blog-list:first-child {border:0;margin-top: 0;}
#blog .entrada.blog-list::after {content:"";position:absolute;bottom: 0;width: 100%;left: 0;height: 200px;background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);z-index: 1;}
#blog .entrada h2 {font-weight:bold;}
#blog .entrada h2 a {text-decoration: none;}
#blog .entrada h2 a:hover {text-decoration: none;}
#blog .entrada p {font-size:15px;line-height: 1.5;}
#blog .entrada .fecha {color:#777;font-weight:bold;font-style:italic;}
#blog .entrada+hr {
    border-top: 1px solid #aaa;
    margin: 20px 0 70px;
}
#blog .bulto {
    height: 100px;
}

#whatsapp-link {background-color: #25d366;padding: 15px;border-radius: 50px;position: fixed;right: 30px;bottom: 50px;transition: 0.1s;}
#whatsapp-link img {width: 30px;height: 30px;object-fit: contain;}
#whatsapp-link:hover {scale: 1.1;transition: 0.2s;}
#whatsapp-link:active {background-color: #20b657;transition:0s;}

#footer {
    background-color: #444;
    padding:40px 0;
    text-align: center;
    color: white;
    width: 100%;
}
#footer > .mod {
    display: inline-block;
    vertical-align: middle;
    width: 40%;
    text-align: left;
}

#footer > .mod .vertical-align {
    display: inline-block;
    /* float:left; */
    text-align:left;
    vertical-align: middle;
    max-width: 60%;
    margin-left: 15px;
}
#footer > .mod img.vertical-align {
    width:70px;
}




#modal-bg {
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    height:100%;
    background-color: rgba(0,0,0,0.3);
    visibility: hidden;
    z-index: 1;
    transition:0.3s;
    opacity: 0;
}
#modal-bg.on {
    visibility: visible;
    transition:0.3s;
    opacity: 1;
}
#modal {
    visibility:hidden;
    position:fixed;
    background-color:white;
    width: 780px;
    height: auto;
    min-height: 200px;
    max-height: 80vh;
    overflow-x: hidden;
    padding: 25px 30px 40px;
    overflow-y: auto;
    left: 50%;
    top: 30%;
    transform: translateX(-50%) translateY(-50%);
    border-radius: 20px;
    box-shadow: 5px 5px 20px rgba(0,0,0,0.7);
    transition:0.2s;
    opacity: 0;
    z-index: 10;
}
#modal #titulo {
    font-weight: bold;
}
#modal.on {
    visibility:visible;
    top: 50%;
    transition:0.4s;
    opacity: 1;
}
#modal #cerrar-modal {
    position:absolute;
    right:10px;
    top:10px;
    padding:5px 10px;
    cursor: pointer;
    border-radius: 5px;
    z-index: 51;
}
#modal #cerrar-modal:hover {
    background-color:#ccc;
}








@media screen and (max-width: 768px){
    body{padding-top: 0px;}
    #head {
        position: fixed;
        height: auto;
        text-align: center;
        box-shadow: 0 0px 10px rgba(0,0,0,0.3);
        text-align: left;
    }
    #head .container {padding:0;}
    #slider {
        height:200px;
        margin-top: 60px;
    }
    #head #logo {
        position:relative;
        display: inline-block;
        width: 60%;
        margin: 10px 0 10px 10px;
    }
    #head #menu {
        width:100%;
        height:100vh;
        left:100vw;
        display:block;
        text-align: center;
        background-color: #fff;
        top: 72px;
        transform: unset;
        z-index: 10;
        transition: 0.4s;
        padding-top: 20px;
    }
    #head #menu.active {
        left:0vw;
        transition: 0.4s;
    }
    #head #hamburguesa {display: inline-block;z-index:50;font-size: 22px;position: absolute;top: 50%;transform: translateY(-50%);right: 10px;padding: 10px 15px;color: white;}
    #head #menu ul {padding: 0;}
    #head #menu ul li {display:block;}
    #head #menu ul li a {padding: 15px 10px;color: black;}
    #head #menu a {font-weight:bold;padding: 5px 10px;display:inline-block;}
    #slider .text1 {font-size: 28px;bottom: 50%;left: 10%;width: 80%;transform: translateY(0%) translateY(50%);}
    .slider .shadow {
        height: 100%;
    }
    .slider a.slider-cta {padding: 8px 20px;}
    .seccion.imagen-texto .img {
        display:block;
        position:relative;
        width: 100% !IMPORTANT;
        left:unset;
        right: unset !important;
        height: 200px;
    }
    .seccion.imagen-texto .texto {
        left: unset !important;
        right: unset !important;
        width:100% !important;
    }
    #servicios > .img {
        height:200px;
        background-attachment: initial;
    }
    #servicios > .texto > p {
        margin-bottom:20px;
    }
    #servicios .tercio {
        width: 48%;
        padding: 10px;
        margin: 10px 0;
    }
    #formContacto {width:80%;}
    #modal {
        width: 90vw;
    }
    #footer > .mod {display:block;width:100%;margin-bottom:30px;text-align: center;}
    #footer > .mod img {
        display: block !important;
        margin: 40px auto 15px !important;
    }
    #footer > .mod .vertical-align {text-align:center;}
    #top-blog {
        margin: 70px 0 0px;
    }
    #blog {width: 100%;background-color: white;}
    #volver {
    margin-top: 110px;
}

}