@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@100;200;300;400;500;600;700;800;900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600;700;800;900&display=swap');

a:hover { text-decoration: none;}

body {
    font-weight:500;
    max-width: 100%;
    overflow-x: hidden;
}

#ir_arriba {
    bottom: 30px;
    position: fixed;
    right: 30px;
}

#ir_arriba span {
    background: url("../img/uptotop.png") no-repeat scroll center center;
    display: block;
    height: 48px;
    width: 48px;
    opacity: 0.50;
}

.relleno_ambos { padding-top: 80px; padding-bottom: 80px;}
.zona_redes li { display: inline-block; font-size: 1.7em;}

#menu_superior {
    padding: 0px;
    display: flex;
    align-items: baseline;
}

#menu_principal { padding-top: 10px;}

#menu_principal .nav-item{border-radius: 50px;}
.btn_demo{ font-size:0.9em!important; letter-spacing: 0px;}
#abre-menu{ background-color: #fff; border-radius: 50px;}
.navbar-toggler {  padding: 0;}

#menu_principal .nav-link {    font-weight: 400;
   white-space: nowrap;
    font-size:1.1em;
    padding: 0px;
    margin: 0.7em 0.6em;
    line-height: 100%;
}
.tel_cab{color:#fff; transition: all 1s linear;  white-space: nowrap; }
.tel_cab:hover{color:#fff; font-weight: bolder;}
.logo_cabecero{margin-top: -36px;}


#menu_principal .dropdown-menu {
    padding: 0;
    margin: 0px 0px 0px 1.3em;
    border-radius: 0rem;
}

#menu_principal .dropdown-item a {
    display: block;
    padding: .45rem 1rem;
}

#menu_principal .dropdown-item {
    font-size: 1em;
    padding: 0px;
    font-weight: 300;
    border-bottom: 1px solid #ccc;
}

.image_centro {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.navbar-toggler { text-align: right;}

.fa-bars:before  {color: #000;}

.nav-link .fa-bars { color: #ffffff80; font-size: 1.5em;}

.dropdown-toggle::after { display: none;}
.dropdown-item .dropdown-toggle:hover { background-color: #ddd;}

.alinear_abajo {
    display: flex;
    flex-wrap: wrap;
    align-content: flex-end;
    align-items: flex-end;
}

.alinear_v_centrado {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.alinear_items_v { align-items: center;}

/*------- solo para menu oculto-----------------*/
.icon_cierre {
    display: inline-flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 10px;
}

.logo_oculto img { width: 80%;}

#cerrar-menu { font-size: 1.9em;}

.fa-times:before {
    color: #000;
    content: "\f00d";
}

#item1.show .nav-link { color: #666;}

#accordion1 { margin-top: 10px;}

#menu_oculto.abierto { right: 0;}

#accordion1 .nivel_1 a {   
    font-weight: 400;
    font-size: 1.1em;
    padding: 0.3rem 1rem;
}

#accordion1 .nivel_1 .fas { float: right;}

#accordion1 .nivel_2 a { font-size: 0.8em;}

#menu_oculto {
    width: 297px;
    right: -297px;
    position: fixed;
    top: 0;
    z-index: 100000;
    -webkit-box-shadow: -3px 0px 50px -2px rgba(0, 0, 0, 0.14);
    -moz-box-shadow: -3px 0px 50px -2px rgba(0, 0, 0, 0.14);
    box-shadow: -3px 0px 50px -2px rgba(0, 0, 0, 0.14);
    background: #fff;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

.container_menu_oculto {
    background: linear-gradient(45deg, rgb(240, 45, 110) 10%, rgba(241, 58, 12, 0.9) 60%, rgba(228,56,82,1) 100%);
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
}

/*------------------botones---------------------------*/
.btn_redondo{ 
    border-radius: 50PX!important;  
     -ms-border-radius: 50PX!important;
    -moz-border-radius: 50PX!important;
    -webkit-border-radius: 50PX!important;
    -khtml-border-radius: 50PX!important;

}

.btn_corporativo{
  
    font-weight: 400;
    padding: 10px 30px;
    display: inline-block;
    letter-spacing: 1px;     
    border:none;   
    transition: all 1s linear!important; 
   

}

.btn_transparente, .btn_transparente_gris{
    font-weight: 400;
    padding: 10px 30px;
    letter-spacing: 1px;
    display: inline-block!important;
    transition: all 1s linear!important; 
}

.btn_gris{
    font-weight: 400;
    padding:10px 30px;
    letter-spacing: 1px;  
    display: inline-block!important;   
    border:none;
    background-color: #ddd;
}
.btn_blanco{
    font-weight: 400;
    padding:10px 30px;
    letter-spacing: 1px;  
    display: inline-block!important;   
}

.btn_negro{
    font-weight: 400;
    padding:10px 30px;
    display: inline-block;
    letter-spacing: 1px;  
    display: inline-block!important;   
    
    
}




/*------------------------botn con efecto-------------------------------*/

.efecto_boton {
    display: inline-block;
    vertical-align: middle;
    -webkit-transform: perspective(1px) translateZ(0);
    transform: perspective(1px) translateZ(0);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0);
    position: relative;
    -webkit-transition-property: color;
    transition-property: color;
    -webkit-transition-duration: 0.5s;
    transition-duration: 0.5s;
    margin: .4em;
    cursor: pointer;
    text-decoration: none;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-weight: 600;
}

.efecto_boton::before {
    content: "";
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
    -webkit-transition-property: transform;
    transition-property: transform;
    -webkit-transition-duration: 0.5s;
    transition-duration: 0.5s;
    -webkit-transition-timing-function: ease-out;
    transition-timing-function: ease-out;
}

.efecto_boton:hover::before, .efecto_boton:focus::before, .efecto_boton:active::before {
    -webkit-transform: scaleX(1);
    transform: scaleX(1);
    -webkit-transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
    transition-timing-function: cubic-bezier(0.52, 1.64, 0.37, 0.66);
}

.paginacion { margin-top: 50px;}

/*--------------frase boton---------------------*/
.fondo_color_frase_boton{padding-top: 20px; padding-bottom: 20px;}

.banda_frase_boton .frase span{font-size:clamp(1.25rem, 1.155rem + 0.48vw, 1.75rem); font-weight: 700;  line-height: 110%;}
.banda_frase_boton .frase p{font-size: clamp(1rem, 0.976rem + 0.12vw, 1.125rem); line-height: 110%; padding-top: 8px;}
.banda_frase_boton .btn-secondary {font-weight: 500;}

/*-------------------------------footer------------------------------*/
footer {
    padding-bottom: 30px;
    padding-top: 30px;  
    font-size: 0.9em;
    font-weight: 400;
}

footer p { line-height: 150%;}

.area_pie {
    font-size: 1.8em;
    margin-top: 36px;
    margin-bottom: 30px;
    font-weight: 400;
    line-height: 1.1;
}

.presentacion_pie .area_pie { margin-top: 17px;}

.enlaces_pie li { margin-bottom:15px; text-align: center;}

.distribuidores_pie img { width: 50%;}
.distribuidores_pie li { margin-bottom: 8px;}



.caja_pie .datos_iconos li {  line-height: 150%; text-align: right;}

.caja_pie .datos_iconos{margin-bottom:15px;}

.caja_pie  address { margin-bottom:0px;}


.bloque_calidad {
    text-align: center;
    border-bottom: 1px solid #444;
    border-top: 1px solid #444;
    margin: 20px 5px;
    padding: 20px 5px;
}

.bloque_calidad img { padding: 20px;}

.caja_pie .enlace { font-weight: 600;}
footer .zona_redes li a{padding-right: 8px;}
#bloque_firma{padding-top: 8px; font-size:0.8em;padding-bottom: 10px;}
#bloque_firma a{color:#666;}
#bloque_firma a:hover{color:#000;}
.firma{ text-align: right;}

/*-------------------------------contacto index------------------------------*/
.fondo_contacto_index { padding-top: 30px; padding-bottom: 30px;}
.fondo_contacto_index input, .fondo_contacto_index textarea { background-color: rgba(255, 255, 255, 0.2); border: none;}
.fondo_contacto_index input::placeholder, .fondo_contacto_index textarea::placeholder { color: #fff;}
.fondo_contacto_index input::placeholder { color: #fff;}
.fondo_contacto_index .relleno { padding: 30px 30px 50px 30px;}
.fondo_contacto_index img{ mix-blend-mode: multiply; filter: grayscale(100%);}
.fondo_contacto_index .politica { font-size: 0.8em;}
.fondo_contacto_index .politica:hover { color: #fff;}
.fondo_contacto_index .form-check { margin-bottom: 15px;}
.fondo_contacto_index { background-image: none;}

.fondo_contacto_index .h2 {
    color: #fff;
    font-weight: 700;
    font-size: 2.1em;
    margin-bottom: 20px;
    text-transform: capitalize;
}

.zona_texto_cont { padding-top: 20px;}

.sobre_titulo {
    font-size: 1.2em;
    padding: 0 16px 0 0;
    display: inline-block;
    position: relative;
    color: #e25a2a;
    font-weight: 600;
    text-transform: capitalize;
}

.zona_texto_cont p { color: #ddd;}

.tel_cont a { font-size: 1.1em;}

.tel_cont i { font-size: 1.5em; vertical-align: middle;}

/*----------------------banner publi--------------------------------------*/

.banner_publi {
    /*background-image: linear-gradient( rgba(0, 0, 0, 0.5),
    rgba(0, 0, 0, 0.5) ), url("../img/banner_publi.jpg");*/
    background-position: left top;
    background-repeat: no-repeat;
    background-size: cover;
    padding-top: 10%;
    padding-bottom: 10%;
}

.texto-caption { color: #fff; text-align: center;}

.texto-caption h2 {
    font-size: 5em;
    font-weight: 900;
    line-height: 100%;
}

.texto-caption span {
    font-size: 0.8em;
    font-weight: 900;
    line-height: 100%;
}

.texto-caption p {
    font-weight: 600;
    font-size: 1.6em;
    line-height: 100%;
}

.bloque_logos .slide {
    display: inline-block;
    margin: 30px;
}


/* Extra small devices (portrait phones, less than 576px)*/
@media (max-width: 575.98px) {
    .logo_cabecero{margin-top: 0px;}
    .aviso, .firma { text-align: center;}

    .relleno_ambos { padding-top: 10px; padding-bottom: 10px;}

    #menu_principal { text-align: center;}

    .dropdown-menu { text-align: center;}

    .navbar-toggler {
        margin-left: auto;
        margin-right: auto;
        text-align: right;
        /*display: block;*/
        margin-bottom: 0px;
    }

    .area_pie { margin-bottom: 15px; margin-top: 40px;}
    .enlaces_pie li {text-align: left;}


    .navbar-toggler-icon { display: initial!important;}
    .navbar button:focus { outline: none!important;}

    .btn_demo{ font-size: 0.7em;}
  
    .fondo_contacto_index .h2{font-size: 1.2em;}
    .fondo_contacto_index .relleno { padding: 40px 0;}
}

/* Small devices (landscape phones, 576px and up)*/
@media (min-width: 576px) and (max-width: 767.98px) {
    .logo_cabecero{margin-top: 0px;}
    .relleno_ambos { padding-top: 10px; padding-bottom: 10px;}

    .btn_demo { font-size: 0.7em!important;}
    .aviso, .firma { text-align: center;}
    .enlaces_pie li {text-align: left;}

    #menu_principal { text-align: center;}

    .dropdown-menu { text-align: center;}

    .navbar-toggler {
        text-align: right;
        margin-left: auto;
        margin-right: auto;
        display: block;
        margin-bottom: 5px;
    }

    .navbar-toggler-icon { display: initial!important;}

    .navbar button:focus { outline: none!important;}
    .logo_cabecero {  margin-top: 0px;}

    .fondo_contacto_index .relleno { padding: 40px 0;}
    .fondo_contacto_index .h2{font-size: 1.2em;}

}


/* Medium devices (tablets, 768px and up)*/
@media (min-width: 768px) and (max-width: 991.98px) {
    .logo_cabecero{margin-top:-27px!important;}
    #menu_principal { text-align: center;}
    .btn_demo { font-size: 0.7em!important;}

    .dropdown-menu { text-align: center;}

    .navbar-toggler {
        text-align: right;
        margin-right: auto;
        margin-left: auto;
        display: block;
        margin-bottom: 5px;
    }

    .navbar-toggler-icon { display: initial!important;}
    .navbar button:focus { outline: none!important;}

}

.fondo_contacto_index .h2 {    font-size: 1.5em;}

/* Large devices (desktops, 992px and up)*/
@media (min-width: 992px) and (max-width: 1199.98px) {
    #menu_principal .nav-link { margin: 0.5em 1em;}
    .relleno_vertical{ padding: 0 5%;}
    .btn_demo { font-size: 0.7em!important;}
}

/* Extra large devices (large desktops, 1200px and up)*/
@media (min-width: 1200px) {
    .relleno_vertical{ padding: 0 5%;}

}