body{font-family: "Inter", serif; font-weight: 400; font-size: .9em; font-style: normal; scroll-behavior: smooth}
h1, h2, h3, h4{font-family: "Kanit", serif; font-weight: normal;}
h1{line-height: 38px; font-size: 2em;}
.logo{height: 44px; margin: 12px 0 12px 20px;}
.btn{background: #DC1F26; color: #FFF; border-radius: 12px; padding: 10px 20px; margin: 0 auto;}
.btn:hover{background: #252525; color: #FFF; cursor: pointer;}

/* form */
input, select, textarea{ border:0; width:100%; background:#FFF; color: #333; clear:both; margin:0 0 5px; float:left; padding:10px 15px; font-family:inherit;   -webkit-border-radius:12px; border-radius:12px; -webkit-appearance: none; -moz-appearance: none; appearance: none}
button, input[type=button]{ background:#FFF; border:0; color: #333;  width:auto; padding:10px 12px; cursor:pointer; clear:both}
button:hover, input[type=button]:hover{background:#333; color:#FFF}
select{background: url(../img/select-cross.png) center right no-repeat #FFF;}
select:focus { outline: none}
label{display: block; float: left; width: 100%;  padding: 10px 0 5px}
.g-recaptcha{display: inline-block; float: left; padding-top: 11px}

/* menu hamburger */
.top-menu{background: #252525; position:fixed; top:0; left: 0; width: 100%; z-index: 1;}
.top-menu ul{float: right; margin: 6px 20px 0 0 }
.top-menu ul li{display: inline-block;}
.top-menu ul li a{color: #FFF; padding: 20px;display: inline-block;}
.top-menu ul li a:hover{color:#DC1F26}
.social{display: none;}

.cotizador{ background-color: #DC1F26; border-radius: 50px; padding: 10px 18px !important;}
.cotizador:hover{ background-color: #da484d; color: #FFF !important;}

.hero{background: url(../img/hero-desktop.jpg) top center no-repeat; background-size: cover; height: 500px;}
.hero div{padding-top: 220px;}
.hero h1{color: #fff; font-size: 5em;}
.hero h2{color: #bcbcbc; font-size: 2em; line-height: 2.5em;}

.hero-section{background: url(../img/hero-desktop.jpg) top center no-repeat; float: left; margin-bottom: 30px; background-size: cover; height: 100px; margin-top: 68px;}
.hero-section h1{padding: 30px 0 0 0; color: #FFF;}

footer{background: url(../img/bg-footer.jpg) right bottom no-repeat #252525; padding: 30px 20px; width: 100%; float: left; position: relative;}
footer ul li{padding: 0 0 10px 0;}
footer ul li a{color: #fff;}
footer ul li a:hover{color:#DC1F26}
.footer-social{background: #DC1F26; position: relative; padding: 0 90px 0 20px; width: 100%; float: left; text-align: right;}
.footer-social img{margin: 8px 0; width: 28px;}

.whatsapp{position: fixed; z-index: 1; bottom: 15px; right: 15px;}
.whatsapp img{width: 65px;}

.wrapper01 .column{margin: -90px 10px 30px; overflow: hidden; position: relative;}
.wrapper01 .column p{padding: 20px 20px 75px;}
.wrapper01 .column a{width: 90%; bottom: 0; display: inline-block; position:absolute; text-align: center; margin: 0 5% 5% 5%}
.img-top-01, .img-top-02, .img-top-03{background: url(../img/rec01.jpg) top center no-repeat; font-size: 2em; line-height: 1.2em;height: 120px; color: #fff; padding: 30px 15px}
.img-top-02{background: url(../img/rec02.jpg) top center no-repeat;}
.img-top-03{background: url(../img/rec03.jpg) top center no-repeat; padding-top: 15px;}

.wrapper02 .columns-container{margin: 0;}
.wrapper02 section{background:#EDEDED; padding:20px; margin: 20px 0; border-radius: 18px; box-shadow: 0px 5px 10px 0px rgba(0,0,0,0.2); -webkit-box-shadow: 0px 5px 10px 0px rgba(0,0,0,0.2); -moz-box-shadow: 0px 5px 10px 0px rgba(0,0,0,0.2);}
.wrapper02 .column{background: #252525; color: #FFF;}
.wrapper02 .column p{text-align: center; padding: 15px;}
.txt-red{color: #DC1F26;}

.wrapper03{float: left}

.wrapper04{min-height: 77vh;}
.wrapper04 .column p{padding: 15px; float: left;}
.wrapper04 p{float: left;}
.fotos{width: 100%;}

.cont-servicios {padding: 25px 0;}
.cont-servicios .column{padding: 24px;}

.wrapper-maps .column{color: #fff; background: #252525; padding: 20px 20px 250px 20px; position: relative;}
.wrapper-maps .column h3{font-size: 1.4em}
.wrapper-maps .column h4{color:#DC1F26;}
.wrapper-maps .column iframe{width:calc(100% - 40px); border-radius: 18px; position: absolute; bottom: 20px; left: 20px;}

.bg-blanco{background: url(../img/bg-blanco.png) bottom right no-repeat #FFF;}

/* Sistema Contenedor con columnas */
.columns-container { display: flex; justify-content: space-between; width: 100%; margin: 20px 0 }
.column { flex: 1; /* Cada columna ocupa el mismo espacio */ margin: 0 10px; /* Espaciado horizontal entre columnas */ background-color: white; padding: 0; background:#EDEDED; border-radius: 18px; box-shadow: 0px 5px 10px 0px rgba(0,0,0,0.2); -webkit-box-shadow: 0px 5px 10px 0px rgba(0,0,0,0.2); -moz-box-shadow: 0px 5px 10px 0px rgba(0,0,0,0.2);}
.column:first-child { margin-left: 0; /* Elimina el margen izquierdo de la primera columna */ }
.column:last-child { margin-right: 0; /* Elimina el margen derecho de la última columna */ }

.bg-no{background: none; box-shadow:0px 0px 0px 0px rgba(0,0,0,0.2); -webkit-box-shadow: 0px 0px 0px 0px rgba(0,0,0,0.2); -moz-box-shadow: 0px 0px 0px 0px rgba(0,0,0,0.2);}

.wrapper-contact .column:first-child{ flex: .4; background: url(../img/bg-cot.jpg) center center no-repeat; background-size: cover; color: #fff; text-align: center; padding: 40px 30px 90px; position: relative; }
.wrapper-contact .column:first-child .btn{width: 80%; position: absolute; bottom: 30px; left: 10%;}
.wrapper-contact .column:last-child{ padding: 30px;}

.wrapper-cotizador .columns-container{max-width: 400px; margin: 0 auto;}
.wrapper-cotizador .column{padding: 20px;}
.wrapper-cotizador .btn{width: 100%; max-width: 100%;}
.tele{display: flex; clear: both;}
.tele input{width: 20%; margin-right: 5px; float: left;}
.tele input:last-child{width: calc(60% - 10px); margin-right: 0;}

.lineas{border-top: 1px solid #252525; display: inline-block; width: 100%; margin: 15px 0 0; padding: 12px 0;}




.sect-contact .column{padding: 30px}
form .btn{width:100%; max-width:300px; margin-top: 20px;}

/* de menos de 1280px*/
@media only screen and (max-width: 1279px) {

}

/* de menos de 1024px*/
@media only screen and (max-width: 1023px) {

    

}

/* de menos de 768px (480)*/
@media only screen and (max-width: 767px) {
        /* Sistema Contenedor con columnas */
        .cols03, .cols04{ flex-direction: column; flex-direction: column; margin: -90px 0 30px 0; }
        .cols03 .column, .cols04 .column{margin: 0 0 20px 0;}
 
        .top-menu ul li{width: 100%}
        .top-menu ul li a{color: #FFF; font-size: 2em; padding: 20px 10px; margin: 0 0 0 20px; display: inline-block;}
        .cotizador {margin-top: 10px;}
        .social{display: inline-block; position: relative; width: 100%; padding-left: 20px;}
        .social a{display: inline-block; padding: 40px 15px 0 0; }

        /* Mostrar el menú cuando está activo */
        body{padding-top:68px}
        .top-menu{height: 68px; overflow: hidden; transition: 0.3s ease;}
        .top-menu.show {width: 100%; height:100%; position:fixed; transition: 0.3s ease;}
        .hamburger{background:url(../img/open.png) center center no-repeat; background-size: cover; width: 35px; height: 35px; position: absolute; right: 20px; top: 16px; cursor: pointer;}
        .hamburger{transition: 0.3s ease;}
        .hamburger.active { background:url(../img/close.png) center center no-repeat; }
        .hamburger.active::before { background:url(../img/open.png) center center no-repeat; }
        .hamburger.active::after {  background:url(../img/close.png) center center no-repeat; }

        .hero div {padding-top: 180px;}
        .hero h1{font-size: 4em; line-height: .9em;}
        .hero h2{font-size: 1.7em;}

        .hero-section{margin:0 0 -15px;}

        .sect-contact .columns-container { display: flex; justify-content: space-between; width: 100%; margin: 20px 0 }
        .sect-contact .column{ flex: .5}

}

/* de menos de 480px, minimo 320px (320)*/
@media only screen and (max-width: 479px) {
        .cols02{ flex-direction: column; flex-direction: column; margin: 30px 0; }
        .cols02 .column{margin: 0 0 15px 0};

}