/* 
font-family: 'Open Sans', sans-serif; 300,300i,400,400i,600,600i,700,700i,800,800i
font-family: 'gothambook';
font-family: 'gothammedium';   
font-family: 'gotham_boldregular';

*/
* {
    padding: 0px;
    margin: 0px;
}

body {
    font-family: 'Open Sans', sans-serif;
    background-color: #fff;
    font-size: 0.9em;
    line-height: 1.6em;
    color: #555;
}

.justify {
    text-align: justify;
}

:root {
    --color1: #2433aa;
    --color2: #DD3567;
}


h1 {
    font-family: 'gotham_boldregular';
    font-size: 4em;
    line-height: 0.9em;
    padding-bottom: 10px;
}

h2 {
    font-family: 'gotham_boldregular';
    font-size: 3em;
    line-height: 0.9em;
    font-weight: normal;
}

h3 {
    font-family: 'gotham_boldregular';
    font-size: 1.8em;
    line-height: 0.9em;
    font-weight: normal;
}

h4 {
    font-family: 'gotham_boldregular';
    font-size: 1.1em;
    line-height: 1.2em;
    font-weight: normal;
    padding: 1.6em 0px 0.4em 0px;
}

.clear {
    clear: both;
}

.supera {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0px;
    left: 0px;
    z-index: 1;
    display: block;
}

.page {
    position: relative;
    width: 100%;
    background-size: cover;
}

.centrado {
    position: relative;
    width: 940px;
    left: 50%;
    transform: translateX(-50%);
}

.centradomax {
    position: relative;
    width: 1090px;
    left: 50%;
    transform: translateX(-50%);
}

.section {
    position: relative;
    width: 100%;
    display: block;
    background-size: cover;
}

.setanimation {
    transition-delay: 0s;
}

.setdelay02s {
    transition-delay: 1s !important;
}

.setduration2s {
    transition: all 2s;
}

.setduration1s {
    transition: all 1s;
}

.setduration075s {
    transition: all 0.75s;
}

.setduration05s {
    transition: all 0.5s;
}

.animatefadeIn {
    opacity: 0;
}

.animateslideRight {
    opacity: 0;
    transform: translateX(-1em);
}

.animateslideLeft {
    opacity: 0;
    transform: translateX(1em);
}

.animateslideUp {
    opacity: 0;
    transform: translateY(1em);
}

.animateslideDown {
    opacity: 0;
    transform: translateY(-1em);
}

.respcol60 {
    float: left;
    width: 60%;
    display: block;
}

.respcol50 {
    float: left;
    width: 50%;
    display: block;
}

.respcol40 {
    float: left;
    width: 40%;
    display: block;
}

.respcol33 {
    float: left;
    width: 33%;
    display: block;
}

.respcol30 {
    float: left;
    width: 30%;
    display: block;
}

.respcol25 {
    float: left;
    width: 25%;
    display: block;
}

.respcol20 {
    float: left;
    width: 20%;
    display: block;
}

.floatright {
    float: right;
}

#menu {
    position: fixed;
    top: 0px;
    width: 100%;
    height: auto;
    z-index: 999;
    padding: 2em 0px;

}

#menu #logo {
    position: relative;
    width: 200px;
}

#menu ul {
    position: absolute;
    right: 0px;
    top: 50%;
    transform: translateY(-50%);
    width: auto;
    color: #fff;
    list-style: none;
}

#menu ul li {
    float: right;
}

#menu ul li a {
    padding: 1em;
    display: block;
    text-decoration: none;
    color: inherit;
}

.menushow {
    background-color: var(--color1);
    box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.3);
}

.linesep {
    width: 50%;
    height: 0.5em;
    margin: 2em 0em;
    display: block;
    background-color: var(--color2);
}

.linesep2 {
    width: 60%;
    height: 1em;
    margin: 2em 0em;
    display: block;
    background-image: url(../assets/svg/rizo.svg);
    background-position: left center;
    background-repeat: repeat-x;
}

.logosep {
    width: 4em;
    height: 4em;
    top: -2em;
    left: 50%;
    transform: translateX(-50%);
    position: absolute;
    background-image: url(../assets/svg/logomini.svg);
    background-size: cover;
}

#top {
    background-color: var(--color1);
    color: #fff;
    padding-top: 10em;
    padding-bottom: 6em;
    background-image: url(../assets/images/gearsback.png);
    background-position: top center;
}

#top p {
    font-size: 1.4em;
    font-family: 'gothammedium';
}

#topslider {
    position: absolute;
    top: -2em;
    right: 1em;
    width: 47%;
    height: 150%;
    background-color: #000;
    transform: skew(-1deg, 0deg);
}

#top .swiper-container {
    background-size: cover;
    height: 100%;
}

#top .swiper-slide {
    background-size: cover;
}

.pagtop {
    bottom: 2em !important;
}

.swiper-pagination-bullet {
    width: 1em !important;
    height: 1em !important;
    background-color: #fff !important;
}

.boton {
    position: relative;
    display: inline-block;

    margin-left: -0.6em;
    color: #fff;
    background-color: var(--color2);
    border-radius: 2em;
    font-family: 'gothammedium';
    font-size: 1.5em;
    cursor: pointer;
    transition: all 0.4s;
    white-space: nowrap;
    text-decoration: none;
    overflow: hidden;
}

.bottxt {
    padding: 1em;
}

.botwrap {
    position: relative;
    border-radius: 2em;
    overflow: hidden;
}

.botonshine {
    position: absolute;
    width: 6em;
    height: 6em;
    background-image: url(../assets/svg/botshine.svg);
    background-size: cover;
    top: 50%;
    opacity: 0.8;
    transition: all 0.4s;
    transform: translateX(-10em) translateY(-50%) rotate(20deg);
}

.botonmini {
    padding: 0.8em;
    font-size: 1.2em;
}

.boton:hover {
    transform: scale(1.02);
    background-color: #fff;
    color: var(--color2);
}

.boton:hover .botonshine {
    transform: translateX(20em) translateY(-50%) rotate(20deg);
}

.padh {
    padding: 3em 0px;
}

.padh2 {
    padding: 5em 0px;
}


.showcasecol {
    background-color: var(--color1);
    color: #fff;
}

.showcasepad {
    padding: 2em;
}

.shocaseimg {
    width: 100%;
    background-size: cover;
    height: 15em;
    opacity: 0.5
}

.showcaselogo {
    width: 100%;
    text-align: center;
    position: absolute;
    top: 8em;
    transform: translateY(-50%);
}

.showcaselogo img {
    width: 76%;
}

#section_showcase {
    z-index: 1;
}

#section_showcase h2 {
    color: var(--color1) !important;
}

#section_review {
    background: linear-gradient(180deg, var(--color2) 0%, var(--color1) 96%);
    color: #fff;
    z-index: 0;
    margin-top: -6em;
}

#section_review .respcol60 {
    padding: 12em 0px 5em 0px;
}

.reviewfoto {
    position: absolute;
    width: 25%;
    left:5%;
    bottom: 40%;
    transform: translateY(50%);
    height: 0px;
    padding-top: 25%;
    overflow: hidden;
    border-radius: 20em;
    background-color: #2433aa;
    background-size: cover;
}



.pagshowcase {
    left: 50%;
    transform: translateX(-50%) translateY(1em) !important;
}

.pagshowcase .swiper-pagination-bullet {
    margin: 0.2em;
}

.valores {
    width: 100%;
    padding-bottom: 3em;
    --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    display: flex;
    flex-wrap: wrap;
    margin-top: calc(-1 * var(--bs-gutter-y));
    margin-right: calc(-0.5 * var(--bs-gutter-x));
    margin-left: calc(-0.5 * var(--bs-gutter-x));
    justify-content: center !important;
}


.col-lg-4 {
    text-align: center;

    flex: 0 0 auto;
    width: 33%;
}

.feature-box {
    padding: 1.6em 3.5em;
}

.feature-box img {
    width: 40%;
    margin-bottom: 2em;
}

.feature-box h3 {
    font-size: 1.4em;
    margin-bottom: 0.25em;
}

#section_valores h2 {
    color: var(--color1) !important;
}

#section_valores .respcol60 {
    margin-top: -5em;
}

#section_valores .centradomax {
    background-color: #fff;
    box-shadow: 0px 50px 40px rgba(0, 0, 0, 0.05);
}

#section_valores {
    z-index: 1;
}

#section_howto {
    background-color: #000;
    color: #fff;
    margin-top: -16em;
    padding-top: 18em;
    z-index: 0;
    padding-bottom: 3em;
}

.howtoback {
    background-image: url(../assets/images/empresa.jpg);
    position: absolute;
    width: 100%;
    height: 100%;
    background-size: cover;
    top: 0px;
    left: 0px;
    opacity: 0.35;
}

.howtocol1 {
    float: left;
    width: 19%;
    text-align: center;
}

.howtocol1 h1 {
    display: inline-block;
    width: 30%;
    height: 30%;
    background-color: var(--color2);
    border-radius: 3em;
    padding: 0.4em;
    margin-bottom: 0.3em;
}

.howtocol1 h3 {
    font-size: 1.3em;
    margin-bottom: 0.5em;
    line-height: 1.2em;
}

.howtocol2 {
    float: left;
    width: 7%;
    text-align: center;
}

.howtocol2 img {
    width: 70%;
    margin-top: 2.8em;
}

/* FIX */
.fixcol1 {
    margin-right: 4em;
}

.cifraspad {
    padding: 2em;
    text-align: center;
}

.cifraspad h2 {
    color: #444 !important;
}

.cifraspad img {
    width: 25%;
    opacity: 0.6;
    margin-bottom: 1em;
}

.cifraspad .linesep {
    position: relative;
    height: 2px;
    width: 40%;
    left: 50% !important;
    transform: translateX(-50%);
}

.escapevideo {
    position: relative;
    width: 100%;
    padding-top: 56.2%;
    height: 0px;
    background-image: url(../assets/images/video.jpg);
    background-size: cover;
    margin: 1em 0px;
    display: block;
}

.botplay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 8em;
    height: 7em;
    background-image: url(../assets/svg/play.svg);
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0.8;
    cursor: pointer;
}

.escapevideo iframe {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0px;
}

.escapevideoplay {
    background-image: none;
}

#section_about {
    z-index: 1;
    background-image: url(../assets/images/gearsback2.png);
    background-position: top center;
}

#section_about h2 {
    color: var(--color1);
}

#section_presupuesto {
    background-color: var(--color1);
    text-align: center;
    color: #fff;
    z-index: 0;
    margin-top: -10em;
}

.prespad {
    padding: 10em 0px 0em 0px;
}

.presuamount {
    font-size: 4em;
    line-height: 1.8em;
    margin-top: 0px;
}
.presuamount sup {font-size: 0.6em; }

.contact {
    padding-top: 3em;
}

.contcol {
    position: relative;
    text-align: center;
}

.contcolpad {
    margin: 1em;
    padding: 2.5em;
    border: 1px solid #444;
}

.formslider {
    margin-top: 2em;
}

input,
textarea {
    font-family: 'Open Sans', sans-serif;
    padding: 1.3em 1.6em;
    border-radius: 1.6em;
    border: none;
    font-size: 1em;
    width: 100%;
    margin: 0.4em 0px;
}

.xtra {
    color: #fff;
    font-size: 1.1em;
    text-align: left;
    padding: 1.2em 2em;
    margin: 0.4em 0px;
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: 2em;
    opacity: 0.8;
    background-position: 95% center;
    background-size: 2.5em;
    background-repeat: no-repeat;
    padding-right: 5em;
    cursor: pointer;
    padding-left: 6em;
    background-image: url(../assets/svg/checkoff.svg);
    position: relative;
    transition: all 0.3s;
}

.xtra strong {
    display: block;
    font-size: 1.2em;
    margin-bottom: 0.12em;
}

.xtraon {
    background-image: url(../assets/svg/checkon.svg);
    background-color: #fff;
    color: #000;
    opacity: 1;

}

.xtraoff {
    background-image: url(../assets/svg/checkon.svg);
}

.xtraicon {
    position: absolute;
    width: 3.4em;
    height: 3.4em;
    left: 1.4em;
    filter: grayscale(100);
    overflow: hidden;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0.8;
}

.xtraicon img {
    width: 100%;
}

.xtraon .xtraicon {
    filter: none !important;
    opacity: 0.9;
}

.conticon {
    position: absolute;
    left: 50%;
    top: -2em;
    width: 5em;
    height: 5em;
    transform: translateX(-50%);
    background-color: #fff;
}

.conticon img {
    filter: brightness(1);
}

.contcol {
    font-style: italic;
}

.contcol strong {
    font-weight: bold;
    display: block;
    font-style: normal;
}


.weblink {
    display: block;
    text-decoration: none;
    width: 100%;
    text-align: center;
    color: #fff;
    font-size: 1.4em;
    margin-top: 1em;
}

.weblink img {
    width: 0.8em;
    margin-right: 0.4em;
}

.padfaq {
    padding: 0em 2em;
}

.clients-grid2 {
    width: 100%;
    list-style: none;
    display: block;
}

.clients-grid2 li {
    float: left;
    width: 16.6%;
}

.clients-grid2 li a {
    display: block;
    padding: 1em;
}

.clients-grid2 li img {
    width: 100%;
}

.grid-item {
    list-style: none;
}

#section_reviews {
    background-image: url(../assets/images/gears.jpg);
    background-position: center;
    background-size: cover;
    color: #fff
}

.testi-image {
    float: left;
    width: 25%;
}

.testi-image img {
    width: 100%;
    border-radius: 4em;
}

.testi-content {
    float: right;
    width: 70%;
    font-size: 0.9em;
    line-height: 1.5em;
}

.testi-meta {
    padding-top: 1em;
    font-weight: bold;
    text-transform: uppercase;
}

.testi-meta span {
    font-size: 0.5em;
    display: block;
    font-weight: normal;
}

.nomobile {}

#section_footer {
    background-color: #343434;
    color: #eee;
}

#section_footer .centradomax {
    padding: 4em 0px;
}

#section_footerbar {
    background-color: #000;
    color: #999;
    font-size: 0.8em;
    ;
}

#section_footerbar .centradomax {
    padding: 1.8em 0px;
}

#section_footerbar a {
    color: #eee;
}

.footercol {
    float: left;
    font-size: 0.9em;
}

address {
    font-style: normal !important;
}

.quote {
    background-image: url(../assets/svg/quote-left.svg);
    background-repeat: no-repeat;
    padding: 1em;
    background-position: left top;
    background-size: 3em;
}

.blockquote-footer {
    padding: 1em;
    color: #666;
}

.footercol1 {
    width: 25%
}

.footercol2 {
    width: 25%
}

.footercol3 {
    width: 25%;
    float: right;
}

.footercol3 .col-lg-3 {
    float: left;
    width: 28%;
    margin-right: 2%;
}

.footercol3 .col-lg-9 {
    float: left;
    width: 70%;
    line-height: 1.2em;
}

.socials {
    position: absolute;
    top: 50%;
    right: 0px;
    transform: translateY(-40%);
}

.social-icon {
    display: inline-block;
    width: 1.8em;
    height: 1.8em;
    margin-right: 0.2em;
    background-size: cover;
    opacity: 0.6;
    transition: all 0.7s;
}

.social-icon:hover {
    opacity: 1;
}

.si-facebook {
    background-image: url(../assets/svg/facebook.svg);
}

.si-instagram {
    background-image: url(../assets/svg/instagram.svg);
}

.si-linkedin {
    background-image: url(../assets/svg/linkedin.svg);
}

.si-youtube {
    background-image: url(../assets/svg/youtube.svg);
}

#section_presupuesto .boton {
    margin-top: 2em;
}

#pressmall a { color:inherit;}

#section_presupuesto small {
    line-height: 1.4em;
    font-style: italic;
}

.prespage {
    width: auto;
    position: relative;
    display: block;
    ;
    padding: 2em 6em 5em 6em;
}

.pagpresu {
    bottom: 0.2em !important;
}

.calendar {
    margin-top: 1em;
}

.presoption {
    cursor: pointer;
    display: inline-block;
    vertical-align: top;
    margin: 6em 0.7em 1em 0.7em;
    opacity: 0.6;
    width: 34%;
    min-height: 28em;
    border-radius: 3em;
    border: 1px solid #fff;
    position: relative;
    transition: all 0.6s;
    background-position: center 90%;

}

.presoption3 {
    width: 24%;
    margin: 6em 0.3em 1em 0.3em;
    min-height: 24em;
}

.presoption:hover {
    opacity: 1;
}

.presoptionpad {
    padding: 3em 3em;
}

.presoption3 .presoptionpad {
    padding: 2em 2em;
}

.selectslider {
    color: #000;
}

.selectslider h3 {
    color: #fff;
    margin-bottom: 0.1em;
    font-size: 1.6em;
}

.custom-select {
    width: 100% !important;
    margin-top: 1em;
}

.sliderscentrado {
    width: 70%;
}

.presoptionimg {
    position: absolute;
    width: 6em;
    height: 6em;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    top: 0em;
    overflow: hidden;
    border-radius: 3em;
    background-color: var(--color1);
    text-align: center;
}

.prespage p {
    color: #fff;
    max-width: 600px;
    display: inline-block;
}

.presoptionimg img {
    width: 100%;
}

.presoption h3 {
    font-size: 1.6em;
    margin-bottom: 0.8em;
    margin-top: 1em;
    font-weight: 100;
}

.presoptionbot {
    position: absolute;
    bottom: 2.4em;
    width: 80%;
    left: 50%;
    transform: translateX(-50%);
    padding: 1em 0px;
    border: 1px solid #fff;
    margin-top: 1.6em;
    border-radius: 3em;
}

.presoptionsel {
    opacity: 1;
    background-color: #fff;
    border: 1px solid #fff;
    background-image: url(../assets/svg/checkon.svg);
    background-position: center 90%;
    background-repeat: no-repeat;
    color: #000;
    background-size: 20%;
}

.presoptionsel .presoptionbot {
    background-color: #55b776;
    opacity: 0;
}

.prespageok .boton {
    display: block !important;
}

.prespage .boton {
    transition: all 0.3s;
}

.presbotnext,
.presbotprev {
    background-size: 2em;
    padding: 0.8em 1em;
    font-size: 1.3em;
    display: inline-block;
    position: absolute;
    top: 50%;
    cursor: pointer;
    transition: all 0.3s;
    background-color: var(--color2);
    border-radius: 1em;
    transform: scale(1);
}

#botenviar { background-color: #55b776;}

.presbotnext {
    right: 0.1em;
    background-image: url(../assets/svg/next.svg);
    background-position: 92% center;
    padding-right: 2.3em;
    background-repeat: no-repeat;
}

.presbotprev {
    left: 0.8em;
    background-image: url(../assets/svg/previous.svg);
    background-position: 8% center;
    padding-left: 2.3em;
    background-repeat: no-repeat;
}

.presbotnext:hover {
    padding-right: 2.6em;
}

.presbotprev:hover {
    padding-left: 2.6em;
}

.presbotnext:hover,
.presbotprev:hover {
    background-color: var(--color2);
    color: #fff;
}

.numsliders {
    padding: 3em 0px;
    text-align: center;
    position: relative;
    width: 100%;
}

#standalonepres { position: relative; width: 100%; background-color: var(--color1); height: 900px;}
#standalonepres #section_presupuesto { position: absolute; top:50%; transform: translateY(-50%); margin: 0px !important;}
#standalonepres .prespad { padding: 2em 0px 0em 0px; }
/* RESPOSIVE */

@media screen and (max-width:940px) {
    .centrado {
        position: relative;
        width: 86%;
    }

    .centradomax {
        position: relative;
        width: 90%;
    }
}

@media screen and (min-width:720px) and (max-width:940px) {

    .respcol25 {
        width: 50%;
    }

    #topslider {
        height: 135%;
    }

    .reviewfoto {
        
    }

    #section_valores .respcol30 {
        width: 40%;
    }

    #section_valores .respcol60 {
        margin-top: 1em;
    }
}

@media screen and (max-width:720px) {
    body {
        font-size: 0.75em;
    }

    .nomobile {
        display: none;
    }

    #menu ul {
        display: none;
    }

    .respcol60,
    .respcol50,
    .respcol40,
    .respcol30,
    .respcol33,
    .respcol25,
    .respcol20 {
        width: 100%;
    }

    .howtocol1 {
        width: 50%;
        margin-top: 2em;
    }

    .howtocol2 {
        display: none;
    }

    .clients-grid2 li {
        float: left;
        width: 33.3%;
    }

    #topslider {
        display: none;
    }

    #topslider2 {
        position: relative;
        top: 0em;
        right: inherit;
        width: 100%;
        height: 10em;
        background-color: #000;
        transform: skew(-1deg, 0deg);
    }

    .fixcol1 {
        margin-right: 0em;
        margin-top: -5em;
    }

    .reviewfoto {
        position: relative;
        left:50%;
        width: 40%;
        padding-top: 40%;
        margin-top: 8em;
        bottom: inherit;
        transform: translateX(-50%);
    }

    #section_review .respcol60 {
        padding: 2em 0px 5em 0px;
        text-align: center;
    }

    #section_review {
        margin-top: -6em;
        padding-top: 4em;
    }

    #section_valores .respcol60 {
        margin-top: 1em;
    }

    .boton {
        margin-left: -0.2em;
    }

    .col-lg-4 {
        text-align: center;
        flex: 0 0 auto;
        width: 50%;
    }

    .footercol1 {
        width: 45%
    }

    .footercol2 {
        width: 45%;
        float: right;
    }

    .footercol3 {
        width: 100%;
        float: left;
        margin-top: 3em;
    }
}