:root {
    --pastel-color: #F6F5EC;
    --text-pastel-color: #FADEC6;
    --text-brown-color: #58322C;
    --black-color: #2F2C2A;
    --yellow-color: #FFF065;
    --brown-color: #602F2E;
    --nav-color: #43403D;
    
    
    --section-margin: 2.75vw;
    --work-item-margin: 2vh;

    --plyr-color-main: #ebe9e1;
    --plyr-color-secondary: #ebe9e1;
    
    --mobile-margin: 20px;
}


.v-center{
    align-items: center;
}

*{box-sizing: border-box;}

h1,h2,h3,h4,h5,h6,p{
    padding: 0;
    margin: 0;
}

.image-border{
    border-radius: 4px;
}

.remove-margin{
    margin: auto !important;
}

/* floating */

@keyframes float {
	0% {
		transform: translatey(0px);
	}
	50% {
		transform: translatey(10px);
	}
	100% {
		transform: translatey(0px);
	}
}

.line{
    border-top:1px solid #BAB9B2;
    margin-top: 2vh;
    margin-bottom: 2vh;
}

.line-margin{
    margin-top: 10px;
    height: 3px;
    margin-bottom: 10px;
}

.margin-wrapper{
    margin-left: var(--mobile-margin);
    margin-right: var(--mobile-margin);
}

.center{
    text-align: center;
}

.grid-columns{
    display: flex;
}

.grid-align-top{
    justify-content: top;
}

/* BUTTON */

.button{
    border-radius: 8px;
    padding: 10px var(--mobile-margin);
    font-size: 16px;
    text-decoration: none;
    display: inline-block;
    cursor: pointer;
    transition: 0.35s all;
    color: #F6F5EC;
    background: var(--black-color);
    font-family: "tomato-bold";
}

.button.outline{
    border: 1px solid var(--brown-color);
    color: var(--brown-color);
    background: transparent;
}

.button.outline.white{
    border: 1px solid #FAE4C5;
    color: #FAE4C5;
    background: transparent;
}

.button.outline:hover{
    color: var(--text-pastel-color);
    background: var(--brown-color);

}

.button.fullwidth{
    width: 100%;
    text-align: center;
}

/* HERO HOME */

.hero-home{
    min-height: 100vh;
    color: var(--text-pastel-color);
    background-color: var(--black-color);
    background-image: url(../img/home/header.jpeg);
    background-size: 100% auto;
    background-position: top center;
    background-repeat: no-repeat;
}

.hero-home .text-container{
    margin: auto;
    padding-top: 10vh;
    padding-bottom: 10vh;
    min-height: 90vh;
}
.hero-home .text-container .text-push{
    padding-top: 10vh;
    padding-bottom: 30vh;
}

.hero-home .arrow-down{
    position: absolute;
    left: 50%;
    top: calc(90vh - 60px);
    animation: float 2s infinite;
}

.hero-home .route-peek{
    color: var(--text-brown-color);
}

.hero-home .route-peek h4{
    max-width: 90%;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
}

.hero-home .route-peek p{
    max-width: 60%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
}

.hero-home .route-peek .button{
    margin-bottom: 40vh;
}

.hero-home .sello{
    position: absolute;
    right: 0;
    margin-top: -50px;
}

.hero-home .text-container p,
.hero-home .text-container h3{
    line-height: 90%;
}





#search{
    margin-right: 20px;
    cursor: pointer;
}

/* lazyload */
*[data-lazy-load-src]{
    opacity:0;
    transition: 0.5s opacity;
}
.lazy-loaded{
    opacity: 1;
}


/* divider */

.divider{
    border-top: 1px solid #BAB9B2;
}

/* image-title-link */


.image-title-link {
    margin-top: 20px;
    padding-bottom: 20px;
}
.image-title-link.medium h5{
    font-size: 30px;
}
.image-title-link h5{
    margin-bottom: 20px;
    line-height: 90%;
}

.image-title-link p{
    margin-bottom: 20px;
}

/* image-right-text */
.image-right-text a{
    text-decoration: none;
    color:#2F2C2A; 
}
.image-right-text{
    padding: var(--mobile-margin) 0;
}

.image-right-text .button{
    margin-bottom: 30px;
}

.image-right-text .image-col{
    width: 33%;
    margin-right: 3%;
}

.image-right-text .text-col{
    flex: 1;
}

.image-right-text h6{margin-bottom:10px;}


/* routes-home */

.route-hero{
    background-image: url(../img/rutas-bg.png);
    min-height: calc(100vh - 100px);
    background-position: center -47px;
    background-size: 100%;  
    text-align: center;
    padding-top: 47vh;
    margin-bottom: 20px;
    background-repeat: no-repeat;
}

.route-hero h2{
    color: #43403D;
    font-size: 35px;
    margin-left: 50px;
    margin-right: 50px;
    margin-bottom: 20px;
}

.route-hero p{
    color: #43403D;
    font-size: 20;
    margin-left: 50px;
    margin-right: 50px;
    margin-bottom: 20px;
    padding-bottom: 40px;
}

/* card-photo */
.card-photo{
    margin-top: 30px;
}
.card-photo h3{
    color: #2F2C2A;
    font-size: 30px;
    margin-bottom: 20px;
}

.card-photo a{
    display: block;
    position: relative;
    margin-bottom: 20px;
    color: #F6F5EC;
}

.card-photo a p{
    position: absolute;
    bottom: 20px;
    left: 20px;
}

.card-photo a img{
    border-radius: 3px;
}


/* text-slider */

.text-slider{
    background: #FAE4C5;
    margin-top: 40px;
    margin-bottom: 40px;
    height: 90vh;
    overflow: hidden;
    position: relative;
}

.text-slider h5{
    line-height: 90%;
    margin-top: 30px;
    margin-bottom: 30px;
}

.text-slider .page{
    display: grid;
    grid-template-rows: 1fr auto;
    margin-bottom: 10px;
    break-inside: avoid;
}

.text-slider .pager {
    justify-content: center;
    position: absolute;
    bottom: 30px;
    left: 0;
    width: 100%;
}

.text-slider .pager .item{
    width: 13px;
    height: 13px;
    border: 1px solid #43403D;
    border-radius: 50%;
    margin-right: 9px;
    cursor: pointer;
    transition: 0.33s background;
}

.text-slider .pager .item:hover,
.text-slider .pager .item.active{
    background:#43403D;
}

.text-slider .slider-wrapper{
    transition: 0.5s transform;
}

/* card-photo-text */
.card-photo-text{
    margin-top:30px;
    
}
.card-photo-text h3{
    margin-bottom:30px;
}

.card-photo-text .image-wrapper{
    position: relative;
    
    margin-bottom: 5px;
}

.card-photo-text a{
    display: block; 
    text-decoration: none;
    position: relative;
}
.card-photo-text a > p{
    color:#2F2C2A;
    font-size: 11px;
    text-decoration: none;
    margin-bottom: 25px;
}
.card-photo-text .image-wrapper p{
    position: absolute;
    left: 15px;
    bottom: 15px;
    text-decoration: none;
    color: #F6F5EC;
    line-height: 90%;;
}

/* features-expandible */

.features-expandible .expandible{
    height: 0;
    overflow: hidden;

    transition: 0.33s height;
}

.features-expandible .feature-row-container{
    border-top: 1px solid #BAB9B2;
    border-bottom: 1px solid #BAB9B2;
}

.features-expandible .feature{
    border-bottom: 1px solid #BAB9B2;
}

.features-expandible .feature:last-child{
    border: 0;
}

.features-expandible .row{
    cursor: pointer;
}
.features-expandible .row .km,
.features-expandible .row .feature-name{
    padding-top: 15px;
    padding-bottom: 15px;
} 

.features-expandible .row .km{
    min-width: 50px;
}
.features-expandible .row .feature-name{
    padding-left: 20px;
    border-left: 1px solid #BAB9B2;
}

.features-expandible .row.active .feature-name{
    border:0;
}

/* util-information */

.util-information{
    background: #FAE4C5;
}

.util-information strong,
.util-information b{
    margin-top: 20px;
    margin-bottom: 20px;
    display: block;
}


/* info-card */

.info-card{
    background: #FAE4C5;
    border-radius: 4px;
    align-items: center;
}

.info-card .icon-container{
    width: 230px;
    text-align: center;
}

.info-card p{
    border-left: 1px dashed #645B4F;
    color: #2F2C2A;
    padding-left: 15px;
    padding-right: 15px;
    font-size: 12px;
    padding-top: 20px;
    padding-bottom: 20px;
    
}


/* content-filter-card */

content-filter-card.invisible{
    display: none;
}

.content-filter-card .image-wrapper{
    position: relative
}

.content-filter-card .image-wrapper .w-text{
    position: absolute;
    bottom: 20px;
    left: 20px;
}
 
.content-filter-card a{
    color: #F6F5EC;
    text-decoration: none;
}
.content-filter-card .text-body{
    color: #2F2C2A;
    font-size: 16px;
}

/* select-filter */
.select-filter .selector{
    justify-content: space-between;
}

.select-filter .selected{
    font-family: 'tomato-bold';
}

.select-filter .select-menu-option{
    cursor: pointer;
}

.doc-icon-selector{
    cursor:pointer;
    width: 70px;
    text-align: center;
    margin-right: 10px;
    margin-bottom: 20px;

    font-size: 13px;

    opacity:0.5;
}

.doc-icon-selector.active{
    opacity:1;
}

.doc-icon-border{
    border: 1px solid #000000;
    border-radius: 4px;
    
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 7px;
}

.doc-icon-selector:nth-child(4n){
    margin-right: 0;
}

.doc-icon-selector img{
    width: 60%;
    height: 60%;
}

.doc-icon-container{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.doc-text{
    display: none;
}

.more-doc a{
    color: #000000;
    text-decoration: none;
}
.more-doc .image-wrapper{
    width: 40%;
    margin-right: 20px;

}

.more-doc .image-wrapper img{
    border-radius: 5px;
} 

/* search-section */

#search-section{
    position: fixed;
    top: 100px;
    width: 100%;
    background: #F6F5EC;
    z-index: 10;
    max-width: 400px;
    border-top: 0.7px solid #BAB9B2;
    transform: translateY(-100%) ;
    opacity: 0;
    transition: all 0.43s;
}

#search-section.open{
    transform: translateY(0) scale(1);
    height: auto;
    opacity: 1;
}

#search-section input{
    border-radius: 10px;
    background:#F6F5EC;
    border: 1px solid black;
    width: 100%;
    padding: 10px;
}

#search-section #results-search-wrapper{
    margin-top: 20px;
    margin-bottom: 20px;
}

#search-section #results-search-wrapper a{
    display: block;
    text-decoration: none;
    color: #2F2C2A;
}