/*******************************
Desplegable
*******************************/
.desplegables {
    display: grid;
    overflow: hidden;
    position: relative;
    transition: 1s;
}
.desplegables:not(.--expanded) {
    margin: 0 0 1.25rem;
}
.desplegables > div {
    min-height: 0;
    grid-row: 1 / -1;
}

.desplegables + .button {
    background: var(--primary);
    color: var(--primary-invert);
    height: 38px;
    display: inline-flex;
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
    transition: transform 500ms ease, opacity 500ms ease, 800ms height 0ms ease, 800ms margin 0ms ease;
}
.desplegables:has(~ p .button) + .button {
    height:32px;
    background:none;
    border-bottom:1px solid;
    color:var(--primary);
    border-radius:0;
    padding:0 0.25rem;
    text-transform:uppercase;
    font-size:0.9rem;
}
.desplegables + .button:not(:last-child) {
    margin-bottom: 1.25rem;
}
.desplegables[style*="--heightmobile: 0"] {
    margin: 0;
}

.desplegables + .button:after {
    content: '\2b';
    font-weight: 300;
    font-family: var(--awesome);
    margin-left: 0.5rem;
}

.desplegables.--expanded + .button {
    transform: scale(0);
    opacity: 0;
    height: 0;
    margin: 0;
}

.desplegables:not([data-mode="parrafo"])::after {
    content: '';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0;
    opacity: 0;
    background: linear-gradient(transparent,#fff);
    transition: opacity 800ms ease, 800ms height 0ms ease;
}

.section--light .desplegables::after,
.dual--radius .desplegables::after {
    background: linear-gradient(transparent,var(--light));
}

.desplegables:not(.--expanded)::after {
    opacity: 1;
    height: 90px;
}



@media screen and (max-width: 600px) {

    .desplegables {
        grid-template-rows: var(--heightmobile) 0fr;
    }


    .desplegables.--expanded {
        grid-template-rows: var(--heightmobile) 1fr;
    }
}

@media screen and (min-width: 601px) {

    .desplegables[data-onlymobile="false"] {
        grid-template-rows: var(--heightpc) 0fr;
    }

    .desplegables[data-onlymobile="false"].--expanded {
        grid-template-rows: var(--heightpc) 1fr;
    }

    .desplegables[data-onlymobile="true"] + .button {
        display: none;
    }

    .desplegables[data-onlymobile="true"]::after {
        display: none;
    }
}

/*******************************
Índice
*******************************/
.indice {
    display: grid;
    list-style: none;
    gap: 0.5rem;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.indice li {
    margin: 0;
}

.indice a {
    display: inline-flex;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    background: var(--primary);
    color: var(--primary-invert);
    border-radius: var(--radiusBox);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    height: 100%;
    line-height: 1.2em;
    font-size: 1rem;
    text-transform: uppercase;
    transition: background 300ms ease, color 300ms ease;
}

.indice a:after {
    content: "\f105";
    font-weight: 400;
    font-family: var(--awesome);
    margin-left: 0.25rem;
}

.indice a:hover {
    background: var(--secondary);
    color: var(--secondary-invert);
}

@media screen and (max-width: 600px) {
    .indice {
        display: flex;
        overflow: auto;
        justify-content: flex-start;
        width: calc(100% + var(--padding-h));
        scrollbar-width: thin;
        scrollbar-color: var(--primary) #ddd;
    }

    .scroll-h:after {
        content: '\f07e';
        font-weight: 400;
        font-family: var(--awesome);
        display: block;
        width: 32px;
        font-size: 2rem;
        display: grid;
        place-content: center;
        line-height: 100%;
        margin-left: auto;
        animation: movingIndice 800ms infinite ease-in-out;
    }

    @keyframes movingIndice {
        0% {
            transform: translateX(-0.5rem);
        }

        50% {
            transform: translateX(0rem);
        }

        100% {
            transform: translateX(-0.5rem);
        }
    }

    .indice {
        padding-bottom: 0.5rem;
    }

    .indice > *:last-child {
        margin-right: var(--padding-h);
    }

    .indice span {
        white-space: nowrap;
    }
}

/********
Titles
*******/
.section--primary .title {
    --alt-color: var(--primary-invert);
}

.section--secondary .title {
    --alt-color: var(--secondary-invert);
}

.section--dark .title {
    --alt-color: var(--dark-invert);
}

.section--light .title {
}

.title {
    --alt-color: var(--primary);
}
/* Mask buble */
.title--mask-bubble {
    line-height: 1.5em;
}

.title--mask-bubble span {
    box-decoration-break: clone;
    background: var(--primary);
    padding: 0.25rem 1rem;
    filter: url(/images/title-bubble.svg#goo);
    color: var(--primary-invert);
}

/* Underline 1 */
.title--underline-1 span {
    --color-underline: var(--light);
    --height: 0.35em;
    --space: 0.3em;
    background: linear-gradient(to bottom, transparent calc(100% - var(--height) - var(--space)), var(--color-underline) calc(100% - var(--height) - var(--space)), var(--color-underline) calc(100% - var(--space)), transparent calc(100% - var(--space)), transparent 100%);
    box-decoration-break: clone
}

/* Underline 2 */
.title--underline-2 {
    line-height: 1.5em;
}

.title--underline-2 span {
    --color-underline: var(--primary);
    --height: 0.15em;
    --space: 0.05em;
    padding: 0 0 var(--space);
    background: linear-gradient(to bottom,transparent 0%, transparent calc(100% - var(--height)),var(--color-underline) calc(100% - var(--height)),var(--color-underline) 100%, transparent 100%);
    box-decoration-break: clone;
}

/* Underline 3 */
.title--underline-3 {
    line-height: 1.5em;
}

.title--underline-3 span {
    display:inline-block;
    --skew: 45deg;
    --height: 0.15em;
    --space: 0.05em;
    color: var(--alt-color);
    --_s: calc(var(--height)* cos(var(--skew)));
    background: linear-gradient(var(--skew), #0000 var(--_s), currentColor 0 calc(100% - var(--_s)), #0000 0) bottom / 100% var(--height) no-repeat;
    padding: 0 0 var(--space);
    box-decoration-break: clone;
    transition: .3s;
    cursor: pointer;
}
/* Linebox */
.title--linebox {
    position: relative;
    padding-bottom: 0.75em;
}

.title--linebox::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    height: 5px;
    width: 60px;
    background-color: var(--alt-color);
}

.title--linebox::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 2px;
    height: 1px;
    width: 50%;
    max-width: 180px;
    background-color: var(--alt-color);
}

.font--center .title--linebox::after, .font--center.title--linebox::after,
.font--center .title--linebox::before, .font--center.title--linebox::before {
    right: 0;
    margin-left: auto;
    margin-right: auto;
}

/* DoubleLine down */
.title--doubleline-down::after {
    content: '';
    display: block;
    width: 80px;
    margin-top: 0.35em;
    height: 4px;
    background: linear-gradient(to right,var(--alt-color) 50%, #fff 50%);
    box-shadow: 0 -1px 0px var(--alt-color), 0 1px 0px var(--alt-color);
}

/* DoubleLine up */
.title--doubleline-up::before {
    content: '';
    display: block;
    width: 80px;
    margin-bottom: 0.35em;
    height: 4px;
    background: linear-gradient(to right,var(--alt-color) 50%, #fff 50%);
    box-shadow: 0 -1px 0px var(--alt-color), 0 1px 0px var(--alt-color);
}

.font--center .title--doubleline-down::after, .font--center.title--doubleline-down::after,
.font--center .title--doubleline-up::before, .font--center.title--doubleline-up::before {
    margin-left: auto;
    margin-right: auto;
}

/* Double fineline up */
.title--double-underline {
    position: relative;
    padding-bottom: 1rem;
}

.title--double-underline::before,
.title--double-underline::after {
    content: "";
    display: block;
    position: absolute;
    background-color: var(--primary);
    width: 80px;
    height: 1px;
}

.title--double-underline::before {
    left: 0;
    bottom: 6px;
}

.title--double-underline::after {
    left: 8px;
    bottom: 0;
}

.font--center .title--double-underline::after, .font--center.title--double-underline::after {
    left: 50%;
    transform: translateX(calc(-50% - 4px));
}

.font--center .title--double-underline::before, .font--center.title--double-underline::before {
    left: 50%;
    transform: translateX(calc(-50% + 4px));
}
/* Line down */
.title--line-down::after {
    content: '';
    display: block;
    width: 80px;
    margin-top: 0.35em;
    background: var(--alt-color);
    height: 3px;
}



/* Line up */
.title--line-up::before {
    content: '';
    display: block;
    width: 80px;
    margin-bottom: 0.35em;
    background: var(--alt-color);
    height: 3px;
}

/* Line gradient up */
.title--line-gradient-up::before {
    content: '';
    display: block;
    width: 80px;
    margin-bottom: 0.35em;
    background: linear-gradient(to right, var(--primary), var(--dark));
    height: 4px;
}

.font--center .title--line-gradient-up::after, .font--center.title--line-gradient-up::after,
.font--center .title--line-gradient-up::before, .font--center.title--line-gradient-up::before {
    margin-left: auto;
    margin-right: auto;
}
/* Line gradient down */
.title--line-gradient-down::after {
    content: '';
    display: block;
    width: 80px;
    margin-top: 0.35em;
    background: linear-gradient(to right, var(--primary) 50%, var(--secondary) 50%);
    height: 4px;
}

.font--center .title--line-gradient-down::after, .font--center.title--line-gradient-down::after,
.font--center .title--line-gradient-down::before, .font--center.title--line-gradient-down::before {
    margin-left: auto;
    margin-right: auto;
}
/* Line  */
.title--line {
    --lineWidth: max(var(--padding-h), 32px);
    --lineHeight: 1px;
    --gap: min(var(--padding-h), 1.5rem);
    position: relative;
    display: grid;
    grid-gap: var(--gap);
    grid-template-columns: var(--lineWidth) auto;
    margin-left: calc(min(var(--padding-h),var(--lineWidth)) * -1 );
}

.title--line::before {
    content: '';
    height: var(--lineHeight);
    display: inline-block;
    background: var(--alt-color);
    top: calc(1.25em / 2);
    position: relative;
}

.font--center.title--line,
.font--center .title--line {
    --lineWidth: 48px;
    text-align: center;
    place-content: center;
    grid-template-columns: 1fr;
    grid-template-rows: var(--lineWidth) auto;
    place-items: center;
    margin-left: 0;
}

.font--center.title--line::before,
.font--center .title--line::before {
    content: '';
    height: var(--lineWidth);
    width: var(--lineHeight);
    top: initial;
}

/* Ico down */
.title--ico-down::after {
    content: '';
    display: block;
    width: 28px;
    height: 28px;
    margin-top: 0.15em;
    background-image: url(/images/bell.svg);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

/* Ico up */
.title--ico-up::before {
    content: '';
    display: block;
    width: 28px;
    height: 28px;
    margin-bottom: 0.15em;
    background-image: url(/images/bell.svg);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
}

.font--center .title--ico-down::after, .font--center.title--ico-down::after,
.font--center .title--ico-up::before, .font--center.title--ico-up::before {
    margin-left: auto;
    margin-right: auto;
}
/* Ico fa down */
.title--icofa-down::after {
    content: '\f111  \f111  \f111';
    font-family: var(--awesome);
    display: block;
    font-size: 0.8rem;
    margin-top: 0.15em;
    color: var(--alt-color);
}

/* Ico fa up */
.title--icofa-up::before {
    content: '\f111  \f111  \f111';
    font-weight: 300;
    font-family: var(--awesome);
    display: block;
    font-size: 0.8rem;
    margin-bottom: 0.15em;
    color: var(--alt-color);
}

.font--center .title--icofa-down::after, .font--center.title--icofa-down::after,
.font--center .title--icofa-up::before, .font--center.title--icofa-up::before {
    margin-left: auto;
    margin-right: auto;
}

/* Ico down */
.title--icoline-down {
    position: relative;
    --icoSize: 36px;
}

.title--icoline-down::after {
    content: '';
    display: block;
    width: var(--icoSize);
    height: var(--icoSize);
    margin-top: 0.25em;
    background: #fff url(/images/bell.svg);
    background-size: 60%;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    z-index: 1;
    border-radius: 50%;
}

.title--icoline-down::before {
    content: '';
    position: absolute;
    bottom: 18px;
    left: 0;
    width: 160px;
    height: 1px;
    background: linear-gradient( to right, transparent var(--icoSize), var(--alt-color) var(--icoSize));
}

/* Ico down */
.title--icoline-up {
    position: relative;
    --icoSize: 36px;
    --lineSize: 160px;
}

.title--icoline-up::before {
    content: '';
    display: block;
    width: var(--icoSize);
    height: var(--icoSize);
    margin-bottom: 0.25em;
    background: url(/images/bell.svg);
    background-size: 60%;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    z-index: 1;
    border-radius: 50%;
}

.title--icoline-up::after {
    content: '';
    position: absolute;
    left: 0;
    top: 18px;
    width: var(--lineSize);
    height: 1px;
    background: var(--alt-color);
    background: linear-gradient( to right, transparent var(--icoSize), var(--alt-color) var(--icoSize));
}

.font--center .title--icoline-down::after, .font--center.title--icoline-down::after,
.font--center .title--icoline-down::before, .font--center.title--icoline-down::before,
.font--center .title--icoline-up::before, .font--center.title--icoline-up::before,
.font--center .title--icoline-up::after, .font--center.title--icoline-up::after {
    margin-left: auto;
    margin-right: auto;
}

.font--center .title--icoline-down::before, .font--center.title--icoline-down::before,
.font--center .title--icoline-up::after, .font--center.title--icoline-up::after {
    margin-left: auto;
    left: 0;
    right: 0;
    margin-right: auto;
    background: linear-gradient( to right, var(--alt-color) calc(50% - (var(--icoSize)/2)), transparent calc(50% - (var(--icoSize)/2)), transparent calc(50% + (var(--icoSize)/2)), var(--alt-color) calc(50% + (var(--icoSize)/2)));
}


/* square */
.font--center.title--square,
.font--center .title--square {
    justify-content: center;
}

.title--square {
    --size: 0.5cap;
}

.title--square::before {
    content: '';
    display: inline-block;
    background: var(--alt-color);
    height: var(--size);
    width: var(--size);
    border-radius: var(--radiusBox);
    margin-right: 0.25em;
    margin-bottom: calc(0.5cap - (var(--size) / 2));
}


.font--center.title--square::after,
.font--center .title--square::after {
    content: '';
    display: inline-block;
    background: var(--alt-color);
    height: var(--size);
    width: var(--size);
    border-radius: var(--radiusBox);
    margin-left: 0.25em;
    margin-bottom: calc(0.5cap - (var(--size) / 2));
}

/*******************************
Minivideo
*******************************/
.minivideo {
    flex: 1;
    display: flex;
    flex-direction: column;
    cursor: pointer;
}

@media screen and (min-width: 821px) {
    .minivideo--full {
        height: 100%;
        display: flex;
        flex-direction: column;
        cursor: pointer;
        justify-content: center;
    }

    .minivideo--full iframe,
    .minivideo--full video {
        min-height: 320px;
    }

    .minivideo--full iframe,
    .minivideo--full video {
        width: 100%;
        height: 100%;
    }

    .minivideo:not(.minivideo--full) .minivideo__iframe {
        padding-bottom: 100%;
        position: relative;
    }

    .minivideo:not(.minivideo--full) .minivideo__iframe iframe {
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%
    }
}

.minivideo__inner {
    position: relative;
    flex: 1;
}

.minivideo video {
    width: 100%;
}

.minivideo__inner:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.1);
    transition: background 300ms ease;
    z-index: 0;
}

.minivideo__inner:hover:before {
    background-color: rgba(0,0,0,0.3);
}

.minivideo .play {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    color: white;
    font-size: 2.5rem;
    opacity: 0.86;
    text-shadow: 0px 0px 4px rgba(0,0,0,0.3);
    z-index: 2;
    transition: font-size 300ms ease;
}

.minivideo:hover .play {
    font-size: 4rem;
}

.minivideo__hide {
    display: none;
    flex: 1;
}


.minivideo .minivideo__iframe {
    padding-bottom: 100%;
    position: relative;
}

.minivideo .minivideo__iframe iframe {
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%
}

/* Section image */
.sectionImage {
    position: relative;
}

.sectionImage__img {
    position: relative;
}

.sectionImage__img img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    min-height: 300px;
}

.sectionImage .container {
    position: relative;
}

@media screen and (min-width: 601px) {
    .sectionImage {
        padding: var(--padding-v) var(--padding-h);
        min-height: 40vh;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .sectionImage__img {
        height: 100%;
        width: 100%;
        position: absolute;
        object-fit: cover;
        top: 0;
        left: 0;
        z-index: 0;
    }
}

@media screen and (max-width: 600px) {
    .sectionImage.section--filter:before {
        display: none;
    }
}
/* 1 */
.sectionImage--1 .container:not(:has(.container)) {
    padding: var(--padding-inner);
    border-radius: var(--radiusBox);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    box-shadow: 0px 0px 12px rgba(0,0,0,0.15);
}

.section .sectionImage.container .sectionImage__img img {
    border-radius: var(--radiusBox);
}

@media screen and (max-width: 600px) {
    .sectionImage--1{
        padding: 0 0 var(--padding-v);
    }

    .section .sectionImage--1:not(:last-child) {
        padding-bottom: 0;
    }

    .sectionImage--1 .container:not(:has(.container)) {
        margin: 0 auto;
        margin-bottom: calc(var(--padding-v)*-1);
        transform: translateY(calc(var(--padding-v) * -1)); max-width:100%;
        width: calc(100% - (var(--padding-h))*2);
        padding: var(--padding-inner);
        background: rgb(var(--bgcolor-mv, var(--bgcolor-pc, 255 255 255)) / 75%);
    }

    .sectionImage--1:has(+ .section:not(.section--primary):not(.section--secondary):not(.section--dark):not(.section--bg):not(.sectionImage):not(.section--light)) {
        padding-bottom: 0;
    }
}

@media screen and (min-width: 601px) {
    .sectionImage--1 .container:not(:has(.container)) {
        position: relative;
        z-index: 2;
        background: rgb(var(--bgcolor-pc,var(--bgcolor-mv, 255 255 255)) / 75%);
    }
}
/* 2 */
.sectionImage--2 .container .title {
    color: #fff;
}

.sectionImage--2.container {
    border-radius: var(--radiusBox);
    overflow: hidden;
}

@media screen and (max-width: 600px) {
    .sectionImage--2 {
        padding: 0;
        color: var(--primary-invert);
    }

    .sectionImage--2 .sectionImage__img:before {
        content: "";
        width: 100%;
        height: 50%;
        position: absolute;
        bottom: 0;
        left: 0;
        background: linear-gradient(rgb(var(--bgcolor-mv,var(--bgcolor-pc, 0 0 0)) / 0%),rgb(var(--bgcolor-mv,var(--bgcolor-pc, 0 0 0))));
        z-index: 1;
    }

    .sectionImage--2 .container {
        margin: 0 auto;
        background: rgb(var(--bgcolor-mv,var(--bgcolor-pc, 0 0 0))); max-width:100%;
        padding: var(--padding-h) var(--padding-h) var(--padding-inner);
    }
}

@media screen and (min-width: 601px) {
    .sectionImage--2 {
        color: var(--primary-invert);
        text-shadow: 1px 1px 6px rgba(0,0,0,0.75);
    }

    .sectionImage--2 .button {
        text-shadow: none;
    }

    .sectionImage--2 .sectionImage__img:before {
        content: "";
        width: 100%;
        height: 100%;
        position: absolute;
        bottom: 0;
        left: 0;
        background: rgb(var(--bgcolor-pc,var(--bgcolor-mv, 0 0 0)) / 50%);
        z-index: 1;
    }

    .sectionImage--2 .container {
        position: relative;
        z-index: 2;
    }
}

/*******************************
TIMELINE
*******************************/
.timeline {
     position:relative;
     margin-top:2rem;
     display:flex;
     flex-direction:column;
     gap:2rem;
     --sizeCounter:25px;
}
 .timeline:after {
     content:"";
     position:absolute;
     top:0;
     left:12px;
     height:100%;
     width:2px;
     background:var(--primary);
}
 
 .timeline .timeline__item {
     position:relative;
     left:12px;
     padding:0 0 0 calc(var(--padding-inner) + (var(--sizeCounter)/2));
     counter-increment: number;
     z-index:1;
	view-timeline-name: --subjectReveal;
	animation-timeline: --subjectReveal;
	animation-name: appear;
	animation-fill-mode: both;
	animation-duration: 1ms;
}

@keyframes appear {
	0% {
		opacity: 0;
		transform: translateY(50%);
	}


    20% {
        opacity: 1;
        transform: translateY(0%);
    }
    80% {
        opacity: 1;
        transform: translateY(0%);
    }

    100% {
        opacity: 1;
        transform: translateY(-10%);
    }
}

 .timeline .timeline__item:before {
     content:"";
     position:absolute;
     top:0;
     z-index:1;
     left:1px;
     transform:translateX(-50%);
     height:var(--sizeCounter);
     width:var(--sizeCounter);
     border-radius:50%;
     background:var(--primary);
     display:grid;
     place-content:center;
     border:6px solid rgba(255,255,255,0.2);
}

@media screen and (min-width: 601px){

    .timeline--center:after {
         right:0;
         left:0;
         margin:0 auto;
    }

    .timeline--counters.timeline--center:after {
        left: 0;
        transform: translateX(0%);
    }
    .timeline--box.timeline--center:after {
        left: 0;
        transform: none;
    }
    .timeline--counters.timeline--center .timeline__item {
        left: inherit;
        width: calc(50% - (var(--sizeCounter) / 2) - var(--sizeTriangle, 0px) - var(--sizeSpace, 0px));
    }


    .timeline--box.timeline--center .timeline__item {
        width: calc(50% - (var(--sizeLine,0)/2) - (var(--sizeCounterSmall, 0) / 2));
    }

    .timeline--center .timeline__item:nth-child(2n){
        margin-left: auto;
    }
}

 /* Counters */
.timeline--counters {
    --sizeCounter:32px;
    --sizeTriangle:12px;
    --sizeSpace:8px;
}


.timeline--counters:after {
    left: calc(var(--sizeCounter) / 2);
    transform: translateX(-50%);
}
.timeline--counters .timeline__item:before {
    content: counter(number);
    color: var(--primary-invert);
    left: calc((var(--sizeCounter) + var(--sizeSpace))* -1);
    top: 50%;
    transform: translate(calc(var(--sizeTriangle) * -1),-50%);
    height: var(--sizeCounter);
    width: var(--sizeCounter);
    font-weight: var(--bold1);
    border: 0;
    z-index: 2;
}

.timeline--counters .timeline__item {
    counter-increment: number;
    background: var(--light);
    padding: var(--padding-inner);
    border-radius:var(--radiusBox);
    filter: drop-shadow(-1px 1px 1px rgba(0, 0, 0, 0.15));
    width: calc(100% - var(--sizeCounter) - var(--sizeTriangle) - var(--sizeSpace));
    margin-right: 0;
    margin-left: auto;
    left: inherit;
}
.timeline--counters .timeline__item:after {
    position: absolute;
    left: 0;
    top: 50%;
    transform: translate(-100%, -50%);
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-top: var(--sizeTriangle) solid transparent;
    border-bottom: var(--sizeTriangle) solid transparent;
    border-right: var(--sizeTriangle) solid var(--light);
}

.timeline .timeline__item:last-child {
     margin-bottom:0;
}
 @media screen and (min-width: 601px){
    .timeline--counters.timeline--center .timeline__item:nth-child(odd):after {
        left: inherit;
        right: 0;
        transform: translate(100%, -50%);
        border-right: 0;
        border-left: var(--sizeTriangle) solid var(--light);
    }
    .timeline--counters.timeline--center  .timeline__item:nth-child(odd){
        margin-left:0;
    }
    .timeline--counters.timeline--center .timeline__item:nth-child(odd):before {
        left: inherit;
        right: calc((var(--sizeCounter) + var(--sizeSpace))* -1);
        transform: translate(var(--sizeTriangle),-50%);
    }
}
 /* box */
.timeline--box {
    --sizeCounter: 38px;
    --sizeCounterSmall: 12px;
    --sizeLine: 20px;

}
.timeline--box:after {
    background: var(--dark);
    left: calc(var(--sizeCounterSmall) / 2);
    transform: translateX( -50%)
}
.timeline--box .timeline__item {
    left: calc(var(--sizeCounterSmall) / 2);
    border-radius: var(--radiusBox);
    background: rgba(0,0,0,0.05);
    width: calc(100% - calc((var(--sizeLine) + var(--sizeCounterSmall))));
    padding: var(--padding-inner);
    padding-left: calc(var(--padding-inner) + var(--sizeCounter) + (var(--sizeLine) / 2));
    margin-left: calc((var(--sizeLine) + var(--sizeCounterSmall)) / 2 );
    counter-increment: number;
}
.timeline--box .timeline__item:before {
    height: var(--sizeCounterSmall);
    width: var(--sizeCounterSmall);
    background: #f0f0f0;
    box-shadow:0 0 0px 2px var(--dark);
    left: calc((((var(--sizeLine) / 2 ) + (var(--sizeCounterSmall)))) * -1);
    top: 50%;
    transform: translate(0, -50%);
}
.timeline--box .timeline__item:after {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: block;
    width: var(--sizeLine);
    height: 2px;
    background: var(--dark);
    left: calc((var(--sizeLine) / 2 * -1));
}
.timeline--box .timeline__item .title:after {
    content: counter(number);
    color: var(--dark);
    border-radius: 54%;
    border: 2px solid var(--dark);
    background: #fff;
    display: grid;
    place-content: center;
    left: calc(var(--sizeLine) / 2);
    height: var(--sizeCounter);
    width: var(--sizeCounter);
    font-weight: var(--bold1);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
@media screen and (min-width: 601px){
    .timeline--box.timeline--center .timeline__item{
        left:inherit;
        padding-right:var(--padding-inner);
    }
    .timeline--box.timeline--center .timeline__item:before{
        transform:translate(0%, -50%);
    }

    .timeline--box.timeline--center .timeline__item:nth-child(odd) {
        padding-right: calc(var(--padding-inner) + var(--sizeCounter) + (var(--sizeLine) / 2));
        padding-left: var(--padding-inner);
        margin: 0;
        right: 0;
    }
    .timeline--box.timeline--center .timeline__item:nth-child(odd):before {
        left: inherit;
        right: calc((((var(--sizeLine) / 2 ) + (var(--sizeCounterSmall)))) * -1);
    }
    .timeline--box.timeline--center .timeline__item:nth-child(odd):after {
        left: inherit;
        right: calc((var(--sizeLine) / 2 * -1));
    }
    .timeline--box.timeline--center .timeline__item:nth-child(odd) .title:after {
        left: inherit;
        right: calc(var(--sizeLine) / 2);
    }
}
/* Serpiente */
 .timeline--serpiente{
    padding:0 20px;
    gap:0;
    --sizeCounter:48px;
 }
 .timeline--serpiente:after{
    display:none;
}
 .timeline--serpiente .timeline__item {
    padding:var(--padding-inner) calc(var(--padding-inner) + (var(--sizeCounter)/2)) var(--padding-inner);
     border-top: 3px solid var(--primary);
     margin: 0;
     left:inherit;
     position: relative;
}
 .timeline--serpiente .timeline__item:before{
     content: counter(number);
    background: var(--primary);
    border:4px solid rgba(255,255,255,0.5);
    height: var(--sizeCounter);
     width: var(--sizeCounter);
     top:max(var(--padding-h), 20px) ;
     transform:translateY(-25%);
     font-size: var(--font-s);
     color:#fff;
     display: flex;
    align-items: center;
     justify-content: center
}
 .timeline--serpiente .timeline__item:after {
     display:none;
}
 .timeline--serpiente .timeline__item:nth-child(even) {
    border-right: 3px solid var(--primary);
     text-align:right;
     padding-left:0;
}
 .timeline--serpiente .timeline__item:nth-child(even):before {
     right: 0;
     transform:translateX(50%);
     left:inherit;
}
 .timeline--serpiente .timeline__item:nth-child(odd) {
    border-left: 3px solid var(--primary);
    padding-right:0;
}
 .timeline--serpiente .timeline__item:nth-child(odd):before {
    left:0;
     transform:translateX(-50%);
     right: inherit;
}
 .timeline--serpiente .timeline__item:first-child {
     border-top: 0;
     border-top-right-radius: 0;
     border-top-left-radius: 0;
}
 .timeline--serpiente .timeline__item:last-child {
    border-bottom-right-radius: 0;
     border-bottom-left-radius: 0;
}

/* Numbers */
.timeline--numbers{
    gap:4rem;
    margin-top:5rem;
}
.timeline--numbers .timeline__item:before {
     --sizeCounter:13px;
     background:#fff;
     top:0;
     left:1px;
     border:0;
     transform:translateX(-50%);
     box-shadow:0 0 0px 2px var(--primary);
}
.timeline--numbers .timeline__item .title{
    transform:translateY(-0.3em);
}
.timeline--numbers .timeline__item p{
    border-left:2px solid rgba(0,0,0,0.25);
    padding-left: 1rem;
}
.timeline--numbers .timeline__item {
    counter-increment: number;
}
.timeline--numbers .title:before{
    content:counter(number);
    position:absolute;
    top:0;
    transform:translateY(-50%);
    font-size:5rem;
    line-height:100%;
    color:var(--primary);
    opacity:0.25;
    left:0;
}

/*******************************
OPINIONS
*******************************/
.opinions.swiper-container{
    padding-bottom:30px;
    overflow:hidden;
    position:relative;
}

.opinions__item{
    color:var(--font-color);
    padding: 0 var(--padding-h) var(--padding-h);
}
.opinions__text{
    font-style:italic;
}
.opinions--estilo1 .opinions__title{
    margin: 0 0 0.6rem;
}
.opinions .swiper-pagination{
    line-height:100%;
}
.opinions--estilo2 .swiper-button-prev,
.opinions--estilo2 .swiper-button-next{
    display:none;
}

/* Estilo 1 */

.opinions--estilo1 .opinions__item{
    display:flex;
    flex-direction:column-reverse;
    padding: 1rem 0 0;
}
.opinions--estilo1 .opinions__text{
    font-style:italic;
    position:relative;
    padding: 0 0 1rem;
  
}
.opinions--estilo1 .opinions__title{
    margin: 0;
}
.opinions--estilo1 .opinions__title{
  padding:1rem 0 0;
  border-top:1px solid rgba(0,0,0,0.2);
}

/* Estilo 2 */
.opinions--estilo2.swiper-container{
    padding:56px 0 0;
    overflow:hidden;
    position:relative;
}
.opinions--estilo2  .swiper-pagination{
    display:none;
}
.opinions--estilo2 .swiper-button-next, 
.opinions--estilo2 .swiper-button-prev{
  width:60px;
  height:40px;
  text-align:center;
  background:var(--secondary);
  color:#fff;
  left:inherit;
  top:0;
  left:inherit;
  transform:translate(0);
  margin:0;
}

.opinions--estilo2 .swiper-button-prev{
    right:62px;
    left:inherit;
    border-radius:var(--radiusBox) 0 0 var(--radiusBox);
    display:flex;
}
.opinions--estilo2 .swiper-button-next{
    right:0;
    border-radius:0 var(--radiusBox) var(--radiusBox) 0;
    display:flex;
}
.opinions--estilo2 .swiper-button-next:after,
.opinions--estilo2 .swiper-button-prev:after{
      font-size:20px;
}

.opinions--estilo2 .opinions__item{
    display:flex;
    flex-direction:column;
    background:#f8f8f8;
    border-radius:var(--radiusBox);
    overflow:hidden;
    padding:var(--padding-inner) 0 0;
}
.opinions--estilo2 .opinions__text{
    font-style:italic;
    margin: 0 0 0.75rem;
    position:relative;
    order:1;
    padding:0 var(--padding-inner);
  
}
.opinions--estilo2 .opinions__title{
    margin: 0;
}
.opinions--estilo2 .opinions__text:before{
    font-size:3rem;
    color:var(--primary);
    opacity:0.5;
    content:'\f10d';
    line-height:100%;
    font-weight:900;
    display:block;
    margin:0 0 1rem;
    font-family:var(--awesome);

}

.opinions--estilo2 .opinions__title{
  order:2;
  padding:0 var(--padding-inner) var(--padding-inner);
  margin:0;
}

.opinions--estilo2 .opinions__stars{
order:3;
background:#eee;
padding:1rem var(--padding-inner);
color:#ff8345
}

/*******************************
grid-img
*******************************/
.grid-img.gallery-light:not(.grid-mosaico){
    margin:0;
}
.grid-img {
    position:relative;
    display:grid;
    margin:0;

}
.grid-img > *{
    position:relative;
    z-index:1;
}
/* grid 1 */
.grid-img--1 {
    grid-template-columns:repeat(5, 1fr);
}
.grid-img--1 img:first-child {
    grid-column:1 / 4;  
    grid-row: 1 / 3;

}
.grid-img--1 img:last-child {
    grid-column: 3 / 6;
    grid-row: 2 / 4;
}

/* grid 2 */
.grid-img--2 {
    grid-gap: min(calc(var(--padding-h) / 2), 1rem);
    grid-template-columns:repeat(2, 1fr); 
}

/* grid 3 */
.grid-img--3 {
    grid-template-columns:repeat(6, 1fr);
}
.grid-img--3 img:first-child {
    grid-column:1 / 5;  
    grid-row: 1 / 4;

}
.grid-img--3 img:last-child {
    grid-column: 4 / 7;
    grid-row: 3 / 5;
}

/* grid 4 */
.grid-img--4 {
    grid-template-columns:repeat(7, 1fr);
}
.grid-img--4 img:first-child {
    grid-column:1 / 4;  
    grid-row: 1 / 3;
    position:relative;
    z-index:1;

}
.grid-img--4 img:last-child {
    grid-column: 3 / 8;
    grid-row: 2 / 5;
}

/* grid 5 */
.grid-img--5 {
    grid-template-columns:repeat(8, 1fr);
}
.grid-img--5 img:first-child {
    grid-column: 2 / 9;
    grid-row: 1 / 5;
}
.grid-img--5 img:last-child {
    grid-column:1 / 4;  
    grid-row: 4 / 6;
}

/* grid 6 */
.grid-img--6 {
    grid-template-columns:repeat(8, 1fr);
}
.grid-img--6 img:first-child {
    grid-column: 1 / 7;
    grid-row: 1 / 4;
}
.grid-img--6 img:last-child {
    grid-column:6 / 9;  
    grid-row: 3 / 5;
}

/* grid 7 */
.grid-img--7 {
    grid-column-gap: min(calc(var(--padding-h) / 2), 1rem);
    grid-template-columns:repeat(6, 1fr);
}
.grid-img--7 img:nth-child(1) {
    grid-column:1 / 4;  
    grid-row: 1 / 5;

}
.grid-img--7 img:nth-child(2) {
    grid-column:4 / 7;  
    grid-row: 1 / 5;
}
.grid-img--7 img:nth-child(3) {
    grid-column:2 / 6;  
    grid-row: 4 / 9;

}

/* grid 8 */
.grid-img--8 {
    grid-gap: min(calc(var(--padding-h) / 2), 1rem);
    grid-template-columns:repeat(2, 1fr); 
}
.grid-img--8 img{
    aspect-ratio:4 / 3;
}

/* grid 9 */
.grid-img--9 {
    grid-gap: min(calc(var(--padding-h) / 2), 1rem);
    grid-auto-rows:minmax(1rem,min-content);
        grid-template-areas: ". uno ."
                             "dos uno ."
                             "dos uno tres"
                             "dos seis tres"
                             "cinco seis tres"
                             "cinco seis cuatro"
                             " . seis cuatro"
                             " . seis .";
}
@media screen and (min-width: 601px) {
    .grid-img--9 {
    grid-template-areas: ". . tres ."
                         ". dos tres ."
                         ". dos tres seis"
                         "uno dos tres seis"
                         "uno cinco tres seis"
                         "uno cinco cuatro seis"
                         ". cinco cuatro seis"
                         ". cinco cuatro ."
                         ". . cuatro .";
    }
}
.grid-img--9 > *:nth-child(1) {
    grid-area: uno;

}
.grid-img--9 > *:nth-child(2) {
    grid-area: dos;

}
.grid-img--9 > *:nth-child(3) {
    grid-area: tres;

}
.grid-img--9 > *:nth-child(4) {
    grid-area: cuatro;

}
.grid-img--9 > *:nth-child(5) {
    grid-area: cinco;

}
.grid-img--9 > *:nth-child(6) {
    grid-area: seis;
}

/* grid 10 */
.grid-img--10 {
    grid-gap: min(calc(var(--padding-h) / 2), 1rem);
    grid-auto-rows:minmax(1rem,min-content);
    grid-template-areas: ". dos"
                         ". dos"
                         "uno dos"
                         "uno tres"
                         "uno tres"
                         ". tres";
}
.grid-img--10 > *:nth-child(1) {
    grid-area: uno;
}
.grid-img--10 > *:nth-child(2) {
    grid-area: dos;

}
.grid-img--10 > *:nth-child(3) {
    grid-area: tres;

}

/* grid 11 */
.grid-img--11 {
    grid-gap: min(calc(var(--padding-h) / 2), 1rem);
    grid-auto-rows:minmax(1rem,min-content);
    grid-template-areas: "dos ."
                         "dos uno"
                         "tres uno"
                         "tres uno"
                         "tres .";
}
.grid-img--11 > *:nth-child(1) {
    grid-area: uno;

}
.grid-img--11 > *:nth-child(2) {
    grid-area: dos;
}
.grid-img--11 > *:nth-child(3) {
    grid-area: tres;
}

/*******************************
Tabs
*******************************/
@keyframes moving {
    0%, 40%,80% {
        transform: translateX(0%);
    }

    20%,60% {
        transform: translateX(-30%);
    }


    80% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

.tabs {
    display: grid;
    --padding-inner: clamp(1rem, 4%, 1.5rem);
}

.tabs__buttons {
    overflow-x: auto;
    display: flex;
    gap: 0.75rem;
}

.tabs__buttons::-webkit-scrollbar-track {
    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.1);
    background-color: #F5F5F5;
}

.tabs__buttons::-webkit-scrollbar {
    height: 10px;
    background-color: #F5F5F5;
}

.tabs__buttons::-webkit-scrollbar-thumb {
    background-color: rgba(0,0,0,0.35);
    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.1);
}

.tabs__button {
    flex-shrink: 0;
    padding: 1rem;
    cursor: pointer;
    flex: 1 0 auto;
    min-width: 140px;
    text-align: center;
    border: none;
    display: block;
    cursor: pointer;
    transition: all 300ms linear;
}

.tabs__inner {
    padding: var(--padding-inner);
    position: relative;
}

.tabs:not(.tabs--estilo1):not(.tabs--estilo4) .tabs__inner {
    margin-top: 1px;
}

/* Estilo 1*/
.tabs--estilo1 .tabs {
    background: #fff;
}

.tabs--estilo1 .tabs__button {
    background: rgba(0,0,0,0.05);
}

.tabs--estilo1 .tabs__button {
    border-top-left-radius: var(--radiusBox);
    border-top-right-radius: var(--radiusBox);
}

.tabs--estilo1 .tabs__button:last-child {
    border-top-right-radius: var(--radiusBox);
}

.tabs--estilo1 .tabs__inner {
    background: rgba(0,0,0,0.1);
    border-radius: 0 0 var(--radiusBox) var(--radiusBox);
}

.tabs--estilo1 .tabs__button--active {
    background: rgba(0,0,0,0.1);
    font-weight: var(--bold1);
}

.tabs--estilo1 .tabs__button:hover:not(.tabs__button--active) {
    background: #f5f5f5;
    color: var(--primary);
}

/* Estilo 2*/
.tabs--estilo2 .tabs__buttons {
    padding-bottom: 0.5rem;
}

.tabs--estilo2 .tabs__button {
    border-radius: var(--radiusButton);
    background: #fff;
}

.tabs--estilo2 .tabs__button:last-child {
    margin-right: 0;
}

.tabs--estilo2 .tabs__inner {
    border-radius: var(--radiusBox);
    border: 1px solid #666;
    background: #fff;
}

.tabs--estilo2 .tabs__button--active {
    background: var(--primary);
    opacity: 1;
    color: #fff;
    font-weight: var(--bold1);
}

.tabs--estilo2 .tabs__button:hover:not(.tabs__button--active) {
    background: #ddd;
}

/* Estilo 3 */
.tabs--estilo3 {
    display: flex;
    flex-direction: column;
}

.tabs--estilo3 .tabs__buttons {
    display: flex;
    flex-direction: row;
    padding-bottom: 0.5rem;
}

.tabs--estilo3 .tabs__buttons .tabs__button {
    text-align: center;
    background: var(--light);
    display: flex;
    flex-direction: column;
    justify-content: center;
    border-radius: var(--radiusBox);
}

.tabs--estilo3 .tabs__buttons i {
    background: #fff;
    color: #333;
    font-size: 1.5rem;
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    display: grid;
    place-content: center;
    border-radius: var(--radiusBox);
}

.tabs--estilo3 .tabs__buttons .title {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    align-items: center;
}

.tabs--estilo3 .tabs__inner {
    border: solid 1px #ddd;
}

.tabs--estilo3 .tabs__buttons .tabs__button--active {
    background: var(--secondary);
    color: var(--secondary-invert);
}

/* Estilo 4*/
.tabs--estilo4 .tabs__inner {
    padding: 1rem 0 0;
}

.tabs--estilo4 .tabs__button {
    background: none;
    position: relative;
}

.tabs--estilo4 .tabs__buttons {
    border-bottom:1px solid;
}

.tabs--estilo4 .tabs__button::after {
    content: '';
    display: block;
    position: absolute;
    height: 5px;
    width: 0%;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    transition: all 300ms ease;
}

.tabs--estilo4 .tabs__button:hover:not(.tabs__button--active):after {
    background: #ddd;
    width: 100%
}

.tabs--estilo4 .tabs__button--active:after {
    background: var(--primary);
    width: 100%
}

/* hide content */
.tabs__content {
    display: none;
}

.tabs__content--active {
    display: block;
}

@media screen and (max-width: 600px) {
    .tabs__button {
        width: 75%;
    }

    .tabs__inner.inview::before {
        content: '\f07e';
        font-weight: 400;
        font-family: var(--awesome);
        width: 32px;
        height: 32px;
        background: #fff;
        border-radius: 50%;
        font-size: 1.25rem;
        display: grid;
        place-content: center;
        line-height: 100%;
        margin-left: auto;
        position: absolute;
        top: -20px;
        right: 0;
        box-shadow: 0px 0px 0px 1px #ddd;
        z-index: 1;
        animation: moving 2000ms forwards ease-in-out;
    }


}

@media screen and (max-width: 1024px) {

    .tabs--estilo2 .tabs__buttons,
    .tabs--estilo3 .tabs__buttons {
        margin-left: calc(var(--padding-h) * -1);
        width: calc(100% + var(--padding-h) * 2);
    }

    .tabs--estilo2 .tabs__button:first-child,
    .tabs--estilo3 .tabs__button:first-child {
        margin-left: var(--padding-h);
    }

    .tabs--estilo2 .tabs__button:last-child,
    .tabs--estilo3 .tabs__button:last-child {
        margin-right: var(--padding-h);
    }

    .tabs--estilo2 .tabs__buttons::-webkit-scrollbar-track,
    .tabs--estilo3 .tabs__buttons::-webkit-scrollbar-track {
        margin: 0 var(--padding-h);
    }
}

@media screen and (min-width: 1025px) {


    .tabs--estilo3 {
        align-items: center;
        gap: var(--padding-inner);
        flex-direction: row
    }

    .tabs--estilo3 .tabs__inner {
        width: 65%;
        border-radius: var(--radiusBox)
    }

    .tabs--estilo3 .tabs__buttons {
        flex-direction: column;
        width: 35%;
    }

    .tabs--estilo3 .tabs__buttons .title {
        flex-direction: row;
        gap: 1rem;
    }

    .tabs--estilo3 .tabs__buttons .tabs__button {
        text-align: left;
        max-width: 100%;
    }
}

/*******************************
Acordeon
*******************************/

.acordeon__item > div {
    display: none;
}

.acordeon__item > .title {
    cursor: pointer;
    padding: 1rem;
    text-align: left;
    display: flex;
    justify-content: space-between;
    margin: 0;
    align-items: center;
}

.acordeon__item > .title i {
    margin-left: 1rem;
}


/* Estilo 1 */
.acordeon--estilo1 .acordeon__item:first-child {
    border-top: 1px dotted #dce7eb;
}

.acordeon--estilo1 .acordeon__item {
    border-bottom: 1px dotted #dce7eb;
}

.acordeon--estilo1 .acordeon__item > .title {
    color: var(--primary);
    padding: 1rem 0;
}

.acordeon--estilo1 .acordeon__item > div {
    padding: 0 0 1rem;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 300ms 400ms ease, transform 300ms 400ms ease;
}

.acordeon--estilo1 .acordeon__item.active > div {
    opacity: 1;
    transform: translateY(0);
}

.acordeon--estilo1 .acordeon__item > .title:after {
    content: '\f107';
    font-weight: 300;
    line-height: 100%;
    width: 24px;
    text-align: center;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--awesome);
    margin-left: 1rem;
    transition: transform 600ms ease;
}

.acordeon--estilo1 .acordeon__item.active > .title:after {
    transform: rotate(180deg);
}

/* Estilo 2 */
.acordeon--estilo2 .acordeon__item {
    border-radius: var(--radiusBox);
    overflow: hidden;
}

.acordeon--estilo2 .acordeon__item:not(:last-child) {
    margin-bottom: 0.5rem;
}

.acordeon--estilo2 .acordeon__item > .title {
    background: var(--light);
    justify-content: start;
}

.section--light .acordeon--estilo2 .acordeon__item > .title {
    background: #fff;
}

.acordeon--estilo2 .acordeon__item > .title::before {
    content: '\2b';
    font-weight: 400;
    line-height: 100%;
    width: 24px;
    text-align: center;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--awesome);
    margin-right: 1rem;
}

.acordeon--estilo2 .acordeon__item > div {
    padding: 1rem;
    border-top: 1px dashed rgba(0,0,0,0.1);
    background: #f5f5f5;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 300ms 400ms ease, transform 300ms 400ms ease;
}

.section--light .acordeon--estilo2 .acordeon__item > div {
    background: #fff;
}

.acordeon--estilo2 .acordeon__item.active > div {
    opacity: 1;
    transform: translateY(0);
}

.acordeon--estilo2 .acordeon__item.active > .title:before {
    content: '\f068';
}

/* Estilo 3 */
.acordeon--estilo3 .acordeon__item:not(:last-child) {
    margin-bottom: 1.25rem;
}

.acordeon--estilo3 .acordeon__item > .title {
    color: var(--primary);
    border: 1px solid;
    border-radius: var(--radiusBox);
}

.acordeon--estilo3 .acordeon__item.active > .title {
    color: var(--primary-invert);
    background: var(--primary);
}

.acordeon--estilo3 .acordeon__item > .title:after {
    content: '\2b';
    font-weight: 300;
    line-height: 100%;
    width: 24px;
    text-align: center;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--awesome);
    margin-left: 1rem;
}

.acordeon--estilo3 .acordeon__item > div {
    padding: 1rem;
    border-left: 1px solid var(--primary);
    border-right: 1px solid var(--primary);
    background: #f5f5f5;
    opacity: 0;
    width: calc(100% - 2rem);
    margin: 0.75rem auto 0;
    transform: translateY(8px);
    transition: opacity 300ms 400ms ease, transform 300ms 400ms ease;
}

.section--light .acordeon--estilo2 .acordeon__item > div {
    background: #fff;
}

.acordeon--estilo3 .acordeon__item.active > div {
    opacity: 1;
    transform: translateY(0);
}

.acordeon--estilo3 .acordeon__item.active > .title:after {
    content: '\f068';
}

/* Estilo 4 */
.acordeon--estilo4 .acordeon__item {
    background: var(--light);
    border-radius: var(--radiusBox);
    overflow: hidden;
}

.acordeon--estilo4 .acordeon__item > .title {
    color: var(--secondary);
    padding: 1rem;
}

.acordeon--estilo4 .acordeon__item > .title:after {
    content: '\f107';
    font-weight: 300;
    line-height: 100%;
    width: 24px;
    text-align: center;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--awesome);
    margin-left: 1rem;
    transition: transform 600ms ease;
}

.acordeon--estilo4 .acordeon__item.active > .title:after {
    transform: rotate(180deg);
}

.acordeon--estilo4 .acordeon__item:not(:last-child) {
    margin-bottom: 1rem;
}

.acordeon--estilo4 .acordeon__item > div {
    background: #fff;
    padding: 1rem;
    margin: 0 1rem 1rem;
    border-radius: var(--radiusBox);
    transition-delay: 0.4s;
    transform: scale(0.75);
    opacity: 0;
    transition: opacity 400ms 400ms ease, transform 400ms 400ms ease;
}

.acordeon--estilo4 .acordeon__item.active > div {
    transition-delay: 0.4s;
    transform: scale(1);
    opacity: 1;
}

/* Estilo 5 */
.acordeon--estilo5 .acordeon__item {
    border-bottom: 1px solid #eee;
    overflow: hidden;
}

.acordeon--estilo5 .acordeon__item:not(:last-child) {
}

.acordeon--estilo5 .acordeon__item > .title {
    justify-content: start;
    padding: 0.75rem 0;
}

.acordeon--estilo5 .acordeon__item > .title:hover {
    color: var(--secondary);
}

.acordeon--estilo5 .acordeon__item > .title::before {
    content: '\2b';
    font-weight: 400;
    line-height: 100%;
    width: 24px;
    border-radius: var(--radiusButton);
    background: var(--primary);
    color: var(--primary-invert);
    font-size: 0.9rem;
    text-align: center;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--awesome);
    margin-right: 1rem;
    flex-shrink: 0;
}

.acordeon--estilo5 .acordeon__item > div {
    padding: 0.25rem 0 0.75rem;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 300ms 400ms ease, transform 300ms 400ms ease;
}


.acordeon--estilo5 .acordeon__item.active > div {
    opacity: 1;
    transform: translateY(0);
}

.acordeon--estilo5 .acordeon__item.active > .title:before {
    content: '\f068';
}

/*******************************
Comp Multiportada
*******************************/
.comp-multiportada{
    --swiper-navigation-color:#fff;
    --swiper-navigation-size: var(--font-l);
}
.comp-multiportada .galeria-portada__item{
    border-radius:var(--radiusBox);
    overflow:hidden;  
    background:var(--light);
}
.comp-multiportada .swiper-button-prev, .comp-multiportada .swiper-button-next{
    text-shadow:0px 1px 3px black;
}
.comp-multiportada .swiper-pagination{
    display:none;
}
.comp-multiportada .galeria-portada__img {
    position: relative;
    overflow: hidden;
}

.comp-multiportada .galeria-portada__img img {
    display: block;
    width: 100%;
    height:100%;
}
.comp-multiportada .galeria-portada__img:not(:last-child):not(first-child) img {
    --polygon:40px;
    --mask-path: polygon(100% 0, 100% calc(100% - var(--polygon)), 50% 100%, 0% calc(100% - var(--polygon)), 0 0);
    --mask-padding: var(--padding-inner) var(--padding-inner) calc(var(--padding-inner) + var(--polygon)) var(--padding-inner);
    clip-path: var(--mask-path, 0);
    border-radius: var(--mask-radius, 0);
    -webkit-mask-image: var(--mask-image);
    -webkit-mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center center;
}


.comp-multiportada .galeria-portada__overlink{
    text-decoration: none;
    color: inherit;
}
.comp-multiportada .galeria-portada__overlink[href="javascript:void(0);"] {
    cursor: auto;
}
 .comp-multiportada .galeria-portada__inner{
    padding:min(var(--padding-h), 2rem);
    width:100%;
    z-index:1;
    margin:0;
}
.comp-multiportada .galeria-portada__info {
    text-align:center;
}
.comp-multiportada .galeria-portada__title:not(:last-child){
    margin: 0 0 0.6rem;
}
.comp-multiportada .galeria-portada__desc:not(:last-child) {
    margin: 0 0 1rem;
}

.comp-multiportada .galeria-portada__title .title {
    margin: 0;
    font-size: var(--font-l);
    font-family:var(--font1);
    font-weight: var(--bold1);
}

.comp-multiportada .galeria-portada__desc {
}

.comp-multiportada .galeria-portada__link .button {
    cursor: pointer; 
    display:inline-block;
    transition:all 300ms ease;
    background: var(--primary);
    color: var(--primary-invert);
    text-transform:uppercase;
    border-radius: var(--radius1, 4px);
    padding: 0.5rem 1.25rem;
    text-decoration:none;
    letter-spacing: 1px;
    font-size:0.95rem;
    box-shadow:0px 1px 6px rgba(0,0,0,0.25);
}
.comp-multiportada .galeria-portada__link .button:after{
   font-family: var(--awesome);
    content:'\f178';
    font-weight:300;
    margin:0 0 0 8px;

}

/*******************************
Kit Digital
*******************************/
.kitDigital {
    font-size: 14px;
    line-height: 140%;
    text-align: center;
}

.kitDigital > .container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    align-items: center;
}

.kitDigital .kitDigital__logo {
    display: block;
    width: 220px;
    max-width: 100%;
}

@media screen and (min-width: 1024px) {
    .kitDigital > .container {
        grid-template-columns: 220px 220px auto;
        text-align: left;
    }
}

@media screen and (max-width: 1023px) {
    .kitDigital .kitDigital__logo.kitDigital__logo--EU {
        grid-area: 1 / 1;
        margin: 0 0 0 auto;
    }

    .kitDigital .kitDigital__logo.kitDigital__logo--TR {
        grid-area: 1 / 2;
        margin: 0 auto 0 0;
    }

    .kitDigital .kitDigital__text {
        grid-area: 2 / 1 / 3 / 3;
    }
}

/*******************************
Triple
*******************************/
.triple{
    display:grid;
    grid-template-columns:1fr;
    grid-gap: 1.5rem;
}

@media screen and (min-width: 821px) {
    .triple{
        grid-template-columns:1fr 1fr;
        grid-column-gap: var(--padding-h);
        grid-row-gap:calc(1rem * var(--ratio));
    }
    .triple > div:not(:nth-child(2)){
        grid-column:1;
    }
    .triple > div:nth-child(2){
        grid-column:2;
        grid-row: span 2;
        position:relative;
    }
    .triple > div:nth-child(2) img{
        height:100%;
        object-fit:cover;
        position:absolute;
    }
}

/*******************************
PORTADA
*******************************/
.portada{
    position:relative;
}
main:has(.section--light:nth-child(2)) .portada{
	background:var(--light);
}

main:has(.section--comp) .portada:not(:has(.portada__info)) .portada__img{
    height:calc(var(--header-height) *2);
    min-height:auto;
}


.portada__img img {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 0;
}
.portada__info{
    max-width:calc(100% - calc(var(--padding-h) * 2));
	width: fit-content;
    margin:0 auto;
    border-radius:var(--radiusBox);
    margin-top:calc(var(--padding-h) * -2);
    background:var(--primary);
    color:var(--primary-invert);
    text-align:center;
    padding: 1rem;
    position:relative;
	z-index:2;
}
.portada__info p:not(:last-child){
    margin: 0 0 1rem;
}

.portada__title {
    --max-size: 32;
    --min-size: 25;
    font-family: var(--font2);
    font-weight: var(--bold2);
    line-height: 1.25em;
    color: var(--primary-invert);
    margin: 0;
}
.portada__title:not(:last-child){
    margin:0 0 0.35em;
}
.portada__button{
	border:1px solid ;
	color: var(--primary-invert);
}
@media screen and (min-width: 768px) {
    main:has(.section--comp) .portada:not(:has(.portada__info)) .portada__img {
        height: calc(var(--header-height) *2);
    }
    .portada__info{
        position:absolute;
        box-shadow:none;
        bottom:var(--padding-h);
        left:50%;
        width:100%;
        transform:translateX(-50%);
        z-index:1;
        padding:1.25rem;
        max-width:560px;
        padding:1.25rem;
        width:fit-content;
    }
    .portada__img img {
        position: absolute;
        
    }
    .portada .portada__img {
        height:65vh;
    }
    .portada--main .portada__img {
        height: 75vh;
    }
    .portada__info p {
        font-size: 1.1125rem;
    }

}

/*
*******************************
DUAL - texto + foto
*******************************/
/*

Propiedades de las columnas -> dual__item

dual__item--center | Columna - Centrar verticalmente el contenido
dual__item--gap-v  | Columna - Padding vertical
dual__item--txt    | Columna - Texto
dual__item--img    | Columna - Imagen completa
dual__item--img-crop | Columna - Imagen con altura del otro dual, absolute
dual__item--full   | Columna - Ancho 100% pantalla
data-order-mv="1"  | Columna - Orden en móvil, posibles valores [1 | 2]

*/
.dual {
    display: flex;
    flex-direction: column;
    --dualgap: clamp(var(--padding-h), 6vw, 3rem);
}

@supports not (padding: clamp(1rem, 1vw, 1rem)) {
    .dual {
        --dualgap: max(var(--padding-h), min(6vw, 3rem))
    }
}

.dual:not(:last-child) {
    margin-bottom: var(--padding-v);
}

.dual__item--center {
    justify-content: center;
}

.dual__item--txt.dual__item--full:first-child {
    padding-left: var(--padding-h);
}

.dual__item--txt.dual__item--full:last-child {
    padding-right: var(--padding-h);
}

.dual__item--box .dual__inner {
    padding: var(--padding-inner);
    background: var(--light);
    border-radius: var(--radiusBox);
}

.dual__item:first-child {
    align-items: flex-end;
}

.dual__item:last-child {
    align-items: flex-start;
}


.dual__inner {
    position: relative;
}

.dual--imgOver .dual__item--txt:not(.dual__item--under) .dual__inner {
    border: 1px solid var(--primary);
    background: #fff;
    padding: var(--padding-inner);
    border-radius: var(--radiusBox);
}

.dual--imgOver .dual__item--under .dual__inner {
    background: var(--light);
    padding: var(--padding-inner);
    border-radius: var(--radiusBox);
}

.dual--imgOver:has(.dual__item--under) .dual__item:not(.dual__item--under) {
    z-index: 1;
}

.dual--imgOver .dual__item--img-crop,
.dual--imgOver .dual__item--img {
    z-index: 1;
}

.dual--txtOver .dual__item--txt:not(.dual__item--under) .dual__inner {
    border:1px solid var(--light);
    background:#fff;
    padding: var(--padding-inner);
    border-radius: var(--radiusBox);
}

.dual--txtOver .dual__item--under .dual__inner {
    background: var(--light);
    padding: var(--padding-inner);
    border-radius: var(--radiusBox);
}

.dual--txtOver .dual__item:not(.dual__item--img):not(.dual__item--img-crop) {
    position: relative;
    z-index: 1;
}

.dual--txtOver .dual__item.dual__item--txt:not(.dual__item--under) {
    z-index: 2;
}

.dual__item--mapa .dual__inner {
    display: flex;
    flex-direction: column;
}

.dual__item--mapa iframe {
    flex: 1;
    min-height: 300px;
}

.dual--radius {
    border-radius: var(--radiusBox);
    overflow: hidden;
}

.dual--radius .dual__item--txt:first-child {
    background: linear-gradient(to right, rgba(248,248,248,1),rgba(238,238,238,1));
}

.dual--radius .dual__item--txt:last-child {
    background: linear-gradient(to left, rgba(248,248,248,1),rgba(238,238,238,1));
}

.dual--radius img {
    border-radius: 0;
}

.dual--card {
    --dualgap: clamp(var(--padding-h), 6vw, 2rem);
    background: #fff;
    padding: 1rem;
    border-radius: var(--radiusBox);
    overflow: hidden;
}
/* Estilos <= 820px */
@media screen and (max-width: 820px) {
    .section--gap-v .dual__item--img.dual__item--full[data-order-mv="2"] img,
    .section--gap-v .dual__item--img-crop.dual__item--full[data-order-mv="2"] img {
        border-bottom-right-radius: 0;
        border-bottom-left-radius: 0;
    }

    .section--nogap .dual__item--img.dual__item--full img,
    .section--nogap .dual__item--img-crop.dual__item--full img {
        border-radius: 0;
    }

    .dual--imgOver .dual__item--img[data-order-mv="2"] img,
    .dual--imgOver .dual__item--img-crop[data-order-mv="2"] img {
        border-bottom-right-radius: 0;
        border-top-right-radius: 0;
    }


    .section--gap-v .dual__item--img.dual__item--full[data-order-mv="1"] img,
    .section--gap-v .dual__item--img-crop.dual__item--full[data-order-mv="1"] img {
        border-top-left-radius: 0;
        border-top-right-radius: 0;
    }

    .dual--imgOver .dual__item--img[data-order-mv="1"] img,
    .dual--imgOver .dual__item--img-crop[data-order-mv="1"] img {
        border-bottom-right-radius: 0;
        border-top-right-radius: 0;
    }

    .section--gap-v .dual__item:not(.dual__item--full),
    .section--nogap .dual__item:not(.dual__item--full) {
        padding-left: var(--padding-h);
        padding-right: var(--padding-h);
    }

    .dual__item--txt.dual__item--full:first-child {
        padding-right: var(--padding-h);
    }

    .dual__item[data-order-mv="1"] {
        order: 1;
    }

    .dual__item[data-order-mv="2"] {
        order: 2;
        padding-top: var(--dualgap);
    }

    .dual__item--txt ~ .dual__item--txt[data-order-mv="2"] {
        padding-top: calc(var(--dualgap) * 2);
    }

    .dual__item--txt[data-order-mv="2"] ~ .dual__item--txt {
        padding-bottom: var(--dualgap);
    }

    .dual__item--img-crop img {
        max-height: 50vh;
        min-height: 220px;
    }

    .section--nogap .dual__item--gap-v[data-order-mv="1"] {
        padding-top: var(--padding-v);
    }

    .section--nogap .dual__item--gap-v[data-order-mv="2"] {
        padding-bottom: var(--padding-v);
    }

    .section .container > .dual .dual__item:first-child, .section .container > .dual .dual__item:last-child {
        padding-left: 0;
        padding-right: 0;
    }

    .section .dual--radius .dual__item--txt {
        padding-top: var(--dualgap);
        padding-bottom: var(--dualgap);
    }

    .section .dual--radius .dual__item--img,
    .section .dual--radius .dual__item--img-crop {
        padding: 0;
    }

    .dual--imgOver {
        --translate: 1.5rem;
    }

    .dual--imgOver .dual__item[data-order-mv="1"] {
        width: calc(100% - var(--translate));
        padding: 0;
    }

    .dual--imgOver .dual__item[data-order-mv="2"] {
        width: calc(100% - var(--translate));
        transform: translateX(var(--translate));
        padding: 0;
    }

    .dual--imgOver:not(:has(.dual__item--under)) .dual__item--txt[data-order-mv="2"] .dual__inner {
        margin-top: calc(var(--translate)*-2);
        padding-top: calc(var(--padding-inner) + (var(--translate)*2));
        border-right: 0;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .dual--imgOver:not(:has(.dual__item--under)) .dual__item--txt[data-order-mv="1"] .dual__inner {
        margin-bottom: calc(var(--translate)*-2);
        padding-bottom: calc(var(--padding-inner) + (var(--translate)*2));
        border-left: 0;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    .dual--imgOver:has(.dual__item--under) .dual__item[data-order-mv="1"] .dual__inner {
        border-left: 0;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    .dual--imgOver:has(.dual__item--under) .dual__item[data-order-mv="2"] .dual__inner {
        border-right: 0;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .dual--imgOver:has(.dual__item--under) .dual__item--under[data-order-mv="1"] .dual__inner {
        margin-bottom: calc(var(--translate)*-2);
        padding-bottom: calc(var(--padding-h) + (var(--translate)*2));
    }

    .dual--imgOver:has(.dual__item--under) .dual__item--under[data-order-mv="2"] .dual__inner {
        margin-top: calc(var(--translate)*-2);
        padding-top: calc(var(--padding-h) + (var(--translate)*2));
    }

    .dual--txtOver {
        --translate: 3rem;
        --dualgap: 0;
    }

    .dual--txtOver .dual__item[data-order-mv="2"] {
        padding-top: 0;
    }

    .dual--txtOver:not(:has(.dual__item--under)) .dual__item--txt:not(.dual__item--under)[data-order-mv="2"] .dual__inner {
        margin-top: calc(var(--translate)*-1);
    }

    .dual--txtOver:not(:has(.dual__item--under)) .dual__item--txt:not(.dual__item--under)[data-order-mv="1"] .dual__inner {
        margin-bottom: calc(var(--translate)*-1);
    }

    .dual--txtOver .dual__item--txt:not(.dual__item--under) .dual__inner {
        max-width: calc(100% - 2rem);
        margin-left: auto;
        margin-right: auto;
    }

    .dual--txtOver .dual__item--txt.dual__item--under[data-order-mv="1"] .dual__inner {
        margin-bottom: calc(var(--translate)*-1);
        padding-bottom: calc(var(--padding-inner) + var(--translate));
    }

    .dual--txtOver .dual__item--txt.dual__item--under[data-order-mv="2"] .dual__inner {
        margin-top: calc(var(--translate)*-1);
        padding-top: calc(var(--padding-inner) + var(--translate));
    }
}

/* Estilos >= 821px */
@media screen and (min-width: 821px) {
    .section--gap-v .dual__item--img.dual__item--full:last-child img,
    .section--gap-v .dual__item--img-crop.dual__item--full:last-child img {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .section--nogap .dual__item--img.dual__item--full img,
    .section--nogap .dual__item--img-crop.dual__item--full img {
        border-radius: 0;
    }

    .section--gap-v .dual__item--img.dual__item--full:first-child img,
    .section--gap-v .dual__item--img-crop.dual__item--full:first-child img {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    .dual {
        flex-direction: row;
    }

    .dual__item--full:not(.dual__item--cportada) .dual__inner {
        max-width: 100%;
    }

    .dual__item {
        --dualwidthitem: 0.5;
        --maxWidth: calc(var(--max-width) * var(--dualwidthitem));
        --padding: calc(var(--dualgap)/2);
        width: calc(50% + (var(--max-width) / 2) - (var(--max-width) * (1 - var(--dualwidthitem))));
        min-width: calc(min(100% * var(--dualwidthitem), 50%));
        display: flex;
        flex-direction: column;
    }

    .dual__item:not(.dual__item--center) .dual__inner {
        flex: 1;
    }

    .dual__inner {
        max-width: calc(var(--maxWidth) - var(--padding));
        position: relative;
        width: 100%;
    }


    .dual__item--img .dual__inner {
        width: 100%;
    }

    .dual__item--img-crop .dual__inner {
        width: 100%;
        min-height: 380px;
    }

    .dual__item--img-crop img {
        position: absolute;
    }

    .dual__item:not(.dual__item--img-crop.dual__item--full):not(.dual__item--img.dual__item--full):first-child {
        padding-right: var(--padding);
    }

    .dual__item:not(.dual__item--img-crop.dual__item--full):not(.dual__item--img.dual__item--full):last-child {
        padding-left: var(--padding);
    }

    .dual .dual__item--full.dual__item--img + .dual__item--txt:not(.dual__item--img-crop.dual__item--full):last-child,
    .dual .dual__item--full.dual__item--img-crop + .dual__item--txt:not(.dual__item--img-crop.dual__item--full):last-child {
        padding-left: var(--dualgap);
    }

    .dual:has(.dual__item--full.dual__item--img) .dual__item--txt:not(.dual__item--img-crop.dual__item--full):first-child,
    .dual:has(.dual__item--full.dual__item--img-crop) .dual__item--txt:not(.dual__item--img-crop.dual__item--full):first-child {
        padding-right: var(--dualgap);
    }

    .section--gap-v .dual__item:not(.dual__item--full):first-child,
    .section--nogap .dual__item:not(.dual__item--full):first-child {
        padding-left: var(--padding-h);
    }

    .section--gap-v .dual__item:not(.dual__item--full):last-child,
    .section--nogap .dual__item:not(.dual__item--full):last-child {
        padding-right: var(--padding-h);
    }

    .dual__item--gap-v {
        padding-top: var(--padding-v);
        padding-bottom: var(--padding-v);
    }

    .section:not(.section--nogap) .dual__item--gap-v:not(.dual__item--full) {
        padding-top: var(--dualgap);
        padding-bottom: var(--dualgap);
    }

    .section .container > .dual .dual__item:first-child {
        padding-left: 0;
    }

    .section .container > .dual .dual__item:last-child {
        padding-right: 0;
    }

    .dual--imgOver {
        --translate: 40px;
    }

    .dual--txtOver {
        --translate: 40px;
    }

    .dual--imgOver .dual__item--txt .dual__inner {
        padding: var(--padding-inner);
    }

    .dual--txtOver .dual__item--txt .dual__inner {
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .dual--txtOver .dual__inner {
        max-width: var(--maxWidth);
    }

    .dual--imgOver .dual__inner {
        max-width: var(--maxWidth);
    }

    .dual--imgOver .dual__item:not(.dual__item--img-crop.dual__item--full):not(.dual__item--img.dual__item--full):first-child,
    .dual--txtOver .dual__item:not(.dual__item--img-crop.dual__item--full):not(.dual__item--img.dual__item--full):first-child {
        padding-right: 0;
    }

    .dual--imgOver .dual__item:not(.dual__item--img-crop.dual__item--full):not(.dual__item--img.dual__item--full):last-child,
    .dual--txtOver .dual__item:not(.dual__item--img-crop.dual__item--full):not(.dual__item--img.dual__item--full):last-child {
        padding-left: 0;
    }

    .dual--imgOver .dual__item:last-child .dual__inner {
        margin-top: var(--dualgap);
    }

    .dual--imgOver .dual__item:first-child .dual__inner {
        margin-bottom: var(--dualgap);
    }

    .dual--imgOver .dual__item--txt:not(.dual__item--under) .dual__inner {
        width: calc(100% + var(--translate));
        max-width: calc(var(--maxWidth) + var(--translate))
    }

    .dual--imgOver .dual__item--txt:not(.dual__item--under):first-child .dual__inner {
        transform: translateX(var(--translate));
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .dual--imgOver .dual__item--txt:not(.dual__item--under):last-child .dual__inner {
        transform: translateX(calc(var(--translate) * -1));
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .dual--imgOver:not(:has(.dual__item--under)) .dual__item--txt:first-child .dual__inner {
        padding-right: calc(var(--translate) + var(--padding-inner));
    }

    .dual--imgOver:not(:has(.dual__item--under)) .dual__item--txt:last-child .dual__inner {
        padding-left: calc(var(--translate) + var(--padding-inner));
    }

    .dual--imgOver .dual__item--txt.dual__item--under:first-child .dual__inner {
        padding-right: calc(var(--translate) + var(--padding-inner));
    }

    .dual--imgOver .dual__item--txt.dual__item--under:last-child .dual__inner {
        padding-left: calc(var(--translate) + var(--padding-inner));
    }

    .dual--txtOver .dual__item--txt:not(.dual__item--under) .dual__inner {
        margin: var(--dualgap) 0;
    }

    .dual--txtOver .dual__item--txt:not(.dual__item--under) .dual__inner {
        width: calc(100% + var(--translate));
        max-width: calc(var(--maxWidth) + var(--translate))
    }

    .dual--txtOver .dual__item--txt:not(.dual__item--under):first-child .dual__inner {
        transform: translateX(var(--translate));
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .dual--txtOver .dual__item--txt:not(.dual__item--under):last-child .dual__inner {
        transform: translateX(calc(var(--translate) * -1));
        display: flex;
        flex-direction: column;
        justify-content: center;
    }

    .dual--txtOver .dual__item--txt.dual__item--under:first-child .dual__inner {
        padding-right: calc(var(--translate) + var(--padding-inner));
    }

    .dual--txtOver .dual__item--txt.dual__item--under:last-child .dual__inner {
        padding-left: calc(var(--translate) + var(--padding-inner));
    }

    .dual .dual__item--full.dual__item--img + .dual__item--txt:not(.dual__item--full):last-child .dual__inner,
    .dual .dual__item--full.dual__item--img-crop + .dual__item--txt:not(.dual__item--full):last-child .dual__inner {
        max-width: calc(var(--maxWidth) - var(--dualgap));
    }

    .dual:has(.dual__item--full.dual__item--img) .dual__item--txt:not(.dual__item--full):first-child .dual__inner,
    .dual:has(.dual__item--full.dual__item--img-crop) .dual__item--txt:not(.dual__item--full):first-child .dual__inner {
        max-width: calc(var(--maxWidth) - var(--dualgap));
    }
}

@media screen and (min-width: 1080px) {
    .dual--imgOver {
        --translate: 100px;
    }

    .dual--txtOver {
        --translate: 100px;
    }

    .dual__item {
        --dualwidthitem: var(--dualwidth, 0.5);
        width: calc(50% + (var(--max-width) / 2) - (var(--max-width) * (1 - var(--dualwidthitem))));
        min-width: calc(min(100% * var(--dualwidthitem), 50%));
    }
}



/*******************************
box-txtOverImg- Texto con imagen de fondo
*******************************/
.box-txtOverImg {
    position: relative;
    text-align: center;
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 30vh;
    border-radius: var(--radiusBox);
    overflow: hidden;
}
.box-txtOverImg + .box-txtOverImg {
margin-top:0.5rem;}
.box-txtOverImg--indice {
    min-height: 140px;
}

.box-txtOverImg--indice .box-txtOverImg__info {
    padding:1rem;
}
    .box-txtOverImg a {
    text-decoration: none;
}

.box-txtOverImg__link {
    text-decoration: none;
    color: currentColor;
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
}

.box-txtOverImg__img {
    position: absolute;
    top: 0;
    overflow: hidden;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: var(--radiusBox);
}

.box-txtOverImg__img img {
    transition: .6s ease-out;
    border-radius: var(--radiusBox);
}

.box-txtOverImg:hover .box-txtOverImg__img img {
    transform: scale(1.1);
}


.box-txtOverImg__info {
    position: relative;
    z-index: 1;
    padding: min(var(--padding-h), 1.5rem);
    overflow: hidden;
}

.box-txtOverImg__title {
    color: currentColor;
}

.box-txtOverImg__title:not(:last-child) {
    margin: 0 0 0.5em;
}

.box-txtOverImg__desc:not(:last-child) {
    margin: 0 0 0.75em;
}


/* Estilo 1*/
.box-txtOverImg--style1 .box-txtOverImg__info {
    color: #fff;
    text-shadow: 0px 1px 3px rgba(0,0,0,0.5);
}


.box-txtOverImg--style1 .box-txtOverImg__img:after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.6);
    transition: background 300ms ease;
}

.box-txtOverImg--style1:hover .box-txtOverImg__img:after {
    background: rgba(0, 0, 0, 0.25);
}

.box-txtOverImg--style1 .box-txtOverImg__button .button {
    color: currentColor;
}

/* Estilo 2*/
.box-txtOverImg--style2 {
    align-items: center;
    justify-content: center;
}

.box-txtOverImg--style2 .box-txtOverImg__title {
    margin: 0;
}

.box-txtOverImg--style2 .box-txtOverImg__title:after {
    font-family: var(--awesome);
    content: '\f054';
    font-size: 0.85em;
    font-weight: 300;
    display: inline-block;
    margin-left: 0.2rem;
    line-height: var(--line-height);
}

.box-txtOverImg--style2 .box-txtOverImg__button {
    display: none;
}

.box-txtOverImg--style2 .box-txtOverImg__info {
    margin: 1rem;
    text-align: center;
    background: var(--white-transparent);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);
    font-size: 0.9rem;
    border-radius: max(calc(var(--radiusBox) - 1rem), 4px);
}

@media screen and (min-width: 600px) {
    .box-txtOverImg--style2 .box-txtOverImg__title:not(:last-child) {
        margin: 0 0 0.4em;
    }

    .box-txtOverImg--style2 .box-txtOverImg__button {
        display: block;
    }

    .box-txtOverImg--style2 .box-txtOverImg__title:after {
        display: none;
    }
}
/* Estilo 3 */
.box-txtOverImg--style3 .box-txtOverImg__link {
    justify-content: flex-end
}

.box-txtOverImg--style3 .box-txtOverImg__info {
    position: static;
    font-size: 0.9rem;
}

.box-txtOverImg--style3 .box-txtOverImg__img:after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: linear-gradient(to top, rgba(255,255,255,0.85) 50%, rgba(255,255,255,0.65) 100%);
    transition: background 300ms ease;
}

@media screen and (min-width: 600px) {
    .box-txtOverImg--style3 .box-txtOverImg__link {
        align-items: end;
    }

    .box-txtOverImg--style3 .box-txtOverImg__link {
        justify-content: flex-start
    }

    .box-txtOverImg--style3 .box-txtOverImg__info {
        text-align: right;
        width: 60%
    }

    .box-txtOverImg--style3 .box-txtOverImg__img:after {
        content: "";
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,0.75) 100%);
        transition: background 300ms ease;
    }
}

/* Estilo 4*/
.box-txtOverImg--style4 .box-txtOverImg__link {
    justify-content: flex-end;
}

.box-txtOverImg--style4 .box-txtOverImg__title:after {
    font-family: var(--awesome);
    content: '\f054';
    font-weight: 600;
    display: inline-block;
    font-size: 0.75em;
    margin-left: 0.25rem;
    color: currentColor;
}

.box-txtOverImg--style4 .box-txtOverImg__info {
    text-shadow: 0 0 1rem rgba(0,0,0,0.8);
    color: #fff;
    text-align: left;
    background: linear-gradient( to top, hsla(0, 0%, 0%, 0.8) 0%, hsla(0, 0%, 0%, 0.79) 8.1%, hsla(0, 0%, 0%, 0.761) 15.5%, hsla(0, 0%, 0%, 0.717) 22.5%, hsla(0, 0%, 0%, 0.66) 29%, hsla(0, 0%, 0%, 0.593) 35.3%, hsla(0, 0%, 0%, 0.518) 41.2%, hsla(0, 0%, 0%, 0.44) 47.1%, hsla(0, 0%, 0%, 0.36) 52.9%, hsla(0, 0%, 0%, 0.282) 58.8%, hsla(0, 0%, 0%, 0.207) 64.7%, hsla(0, 0%, 0%, 0.14) 71%, hsla(0, 0%, 0%, 0.083) 77.5%, hsla(0, 0%, 0%, 0.039) 84.5%, hsla(0, 0%, 0%, 0.01) 91.9%, hsla(0, 0%, 0%, 0) 100% );
    width: 100%;
    text-align: left;
}

.box-txtOverImg--style4 .box-txtOverImg__title {
    margin: 0;
    display: flex;
    justify-content: space-between;
}

.box-txtOverImg--style4 .box-txtOverImg__desc {
    display: none;
}

.box-txtOverImg--style4 .box-txtOverImg__button {
    display: none;
}

/* Estilo 5*/
.box-txtOverImg--style5 .box-txtOverImg__info {
    color: #fff;
}

.box-txtOverImg--style5 .box-txtOverImg__img:after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(0, 0, 0, 0.5);
    transition: background 500ms ease;
}



@media screen and (min-width: 1024px) {
    .box-txtOverImg--style5 .box-txtOverImg__img:after {
        background: rgba(0, 0, 0, 0.35);
    }

    .box-txtOverImg--style5:hover .box-txtOverImg__img:after {
        background: rgba(0, 0, 0, 0.75);
    }

    .box-txtOverImg--style5 .box-txtOverImg__info {
        transform: translateY(45px);
        transition: transform 500ms ease;
    }

    .box-txtOverImg--style5:hover .box-txtOverImg__info {
        transform: translateY(0%);
    }

    .box-txtOverImg--style5 .box-txtOverImg__title {
    }

    .box-txtOverImg--style5 .box-txtOverImg__desc,
    .box-txtOverImg--style5 .box-txtOverImg__button {
        opacity: 0;
        transition: opacity 1000ms ease;
    }

    .box-txtOverImg--style5:hover .box-txtOverImg__button,
    .box-txtOverImg--style5:hover .box-txtOverImg__desc {
        opacity: 1;
    }
}



/* Estilo 6 */
.box-txtOverImg--style6 {
    text-align: left;
    border-radius: var(--radiusBox);
    overflow: hidden;
}

.box-txtOverImg--style6 .box-txtOverImg__link {
    justify-content: flex-end;
}

.box-txtOverImg--style6 .box-txtOverImg__info {
    color: #fff;
    text-shadow: 0px 1px 3px rgba(0,0,0,0.5);
}

.box-txtOverImg--style6 .box-txtOverImg__info:after {
    content: '\f178';
    font-family: var(--awesome);
    font-size: 2rem;
    height: 32px;
    line-height: 32px;
    margin-top: 8px;
    display: block;
    transition: all 300ms ease;
}


@media screen and (min-width: 1024px) {

    .box-txtOverImg--style6 .box-txtOverImg__info:after {
        transform: translateY(32px);
        height: 0;
        margin-top: 0;
    }

    .box-txtOverImg--style6:hover .box-txtOverImg__info:after {
        transform: translateY(0%);
        margin-top: 8px;
        height: 32px;
    }
}

.box-txtOverImg--style6 .box-txtOverImg__title {
    margin: 0;
}

.box-txtOverImg--style6 .box-txtOverImg__desc {
    opacity: 0.8;
    margin: 0;
}

.box-txtOverImg--style6 .box-txtOverImg__button {
    display: none;
}

.box-txtOverImg--style6 .box-txtOverImg__img:after {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.75));
}

.box-txtOverImg--style6 .box-txtOverImg__button .button {
    color: currentColor;
}

/* Estilo 7 */
.box-txtOverImg--style7 {
    padding: 0.75rem;
    background: #fff;
}

.box-txtOverImg--style7 .box-txtOverImg__img {
    position: relative;
    border-radius: var(--radiusBox);
}

.box-txtOverImg--style7 .box-txtOverImg__info {
    position: absolute;
    bottom: 0.5rem;
    right: 0.5rem;
    background: #fff;
    padding: 0.5rem 1rem;
    border-top-left-radius: var(--radiusBox);
    overflow: visible;
    max-width: 85%;
}

.box-txtOverImg--style7 .box-txtOverImg__info::before {
    position: absolute;
    content: "";
    bottom: 4px;
    left: 0;
    transform: translateX(-100%);
    z-index: 2;
    background: transparent;
    width: 1.25rem;
    height: 1.25rem;
    border-bottom-right-radius: var(--radiusBox);
    box-shadow: 4px 4px 0 4px #fff;
}

.box-txtOverImg--style7 .box-txtOverImg__info::after {
    position: absolute;
    content: "";
    top: 0;
    right: 4px;
    transform: translateY(-100%);
    z-index: 2;
    background: transparent;
    width: 1.25rem;
    height: 1.25rem;
    border-bottom-right-radius: var(--radiusBox);
    box-shadow: 4px 4px 0 4px #fff;
}

.box-txtOverImg--style7 .box-txtOverImg__link[href] .box-txtOverImg__title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.box-txtOverImg--style7 .box-txtOverImg__link[href] .box-txtOverImg__title::after {
    content: '\f105';
    font-weight: 400;
    display: grid;
    place-content: center;
    font-family: var(--awesome);
    background: var(--primary);
    color: var(--primary-invert);
    height: 20px;
    width: 20px;
    border-radius: 50%;
    font-size: 0.95rem;
    flex-shrink: 0;
}

/*******************************
cols - Dos columnas, de 30-70
*******************************/
.cols:not(.cols--box) {
    border-top: 1px solid;
    padding-top: var(--padding-h);
}

.cols__small {
    margin-bottom: 1.5rem;
}

.cols--box .cols__small {
    min-height: 220px;
    background: linear-gradient(to bottom, #f1dfdf, #ffffff);
    background-size: cover;
    background-position: center center;
    padding: min(var(--padding-inner), 1.25rem);
    border-radius: var(--radiusBox);
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    box-shadow: 0px 0px 16px rgba(0,0,0,0.05);
}

@media screen and (min-width: 821px) {
    .cols {
        display: flex;
    }

    .cols__big {
        flex: 1;
    }

    .cols__small {
        width: 30%;
        min-width: 300px;
        margin-right: 2.5rem;
        margin-bottom: 0;
    }

    .cols--box {
        
    }

    .cols--box .cols__big {
        padding: 1rem 0;
    }

    .cols--box .cols__small {
        min-height: auto;
    }
}

/*******************************
ICON - icono + texto
*******************************/
.grid-auto .icon-txt,
.flex-auto .icon-txt {
    flex: 1;
}

.icon-txt {
    text-align: center;
    margin:0.5rem 0;
}
.icon-txt[href]{
    text-decoration:none;
    color:inherit;
    display:block;
}

.icon-txt__img {
    --sizeIco:3.5rem;
    display: flex;
    align-items:center;
    justify-content:center;
    margin: 0 auto;
    height: var(--sizeIco);
    width: var(--sizeIco);
    margin-bottom: 1rem;
}
.icon-txt__img img{
    width:100%;
	height:100%;
    display:block;
}
.icon-txt__ico {
    --sizeIco:3.5rem;
    line-height:100%;
    font-size: var(--sizeIco);
    display: flex;
    align-items:center;
    justify-content:center;
    width:var(--sizeIco);
    margin: 0 auto;
    text-align:center;
    color:var(--primary);
    margin-bottom: 1rem;
}
.icon-txt__ico:has(.counter-value){
    width:auto;
}
.section--primary .icon-txt__ico{
    color:var(--primary-invert);
}
.section--secondary .icon-txt__ico{
    color:var(--secondary-invert);
}
.section--dark .icon-txt__ico{
color:var(--dark-invert);
}

.icon-txt__ico i{
    font-size:1em;
}



/* Iconos estilos */
.icon-txt__ico--border,
.icon-txt__img--border,
.icon-txt__ico--rounded,
.icon-txt__img--rounded,
.icon-txt__ico--square,
.icon-txt__img--square
{
    --sizeIco:5rem;
    font-size: var(--sizeIco);
    display: flex;
    width:var(--sizeIco);
    height:var(--sizeIco);
    flex-shrink:0;
    align-items:center;
    justify-content:center;
    line-height:100%;
    margin:0 auto 1rem;
    text-align:center;
}
.icon-txt__ico--border i,
.icon-txt__ico--rounded i,
.icon-txt__img--rounded i,
.icon-txt__ico--square i{
    font-size:0.5em;
}
.icon-txt__ico--border,
.icon-txt__img--border{
    border-radius:var(--radiusBox);
    border:2px solid;
    color:var(--primary);
}
.icon-txt__ico--border.icon-txt__ico--rounded{
    background:none;
    border:2px solid;
    color:var(--primary);
}
.icon-txt__ico--rounded,
.icon-txt__img--rounded{
    border-radius:50%;
    background:var(--primary);
    color:var(--primary-invert);
}
.icon-txt__ico--square,
.icon-txt__img--square{
    background:linear-gradient(to bottom, var(--primary), var(--secondary));
    border-radius:var(--radiusBox);
    color:var(--primary-invert);
}

.icon-txt__img--rounded img,
.icon-txt__img--square img,
.icon-txt__img--border img
{
    margin:0 auto;
    max-width:60%;
    height:auto;
    
}
.icon-txt__img--rounded img,
.icon-txt__img--square img{
    /*filter:invert();*/
}
/*******/

.icon-txt__title,.icon-txt:not(.icon-txt--headcols) .icon-txt__head .icon-txt__title{
    margin: 0 0 0.5em;
}


/* Fondo y padding */
.icon-txt--box {
    margin:0;
    color:var(--font-color);
    border-radius:var(--radiusBox);
    padding: var(--padding-inner);
    background:#fff;
    filter: drop-shadow(0px 0px 8px rgba(0, 0, 0, 0.1)); 
}
.icon-txt--box:not(.icon-txt--cols):not(.icon-txt--headcols):has(.icon-txt__ico--over){
    margin-top:2.5rem;
}

/* Translate Ico */
.icon-txt__ico--border.icon-txt__ico--over,
.icon-txt__img--border.icon-txt__ico--over,
.icon-txt__ico--rounded.icon-txt__ico--over,
.icon-txt__img--rounded.icon-txt__ico--over,
.icon-txt__ico--square.icon-txt__ico--over,
.icon-txt__img--square.icon-txt__ico--over{
    margin-top:calc(((var(--sizeIco)/2)*-1) - var(--padding-inner));
}
.icon-txt__ico--border.icon-txt__ico--over,
.icon-txt__ico--border.icon-txt__ico--over{
    background:#fff;
}


/* Ico y title en columnas */
.icon-txt--headcols {
    text-align:left;
    margin:0;
    color:var(--font-color);
}

.icon-txt--headcols .icon-txt__head{
    display:flex;
    align-items:center;
    margin-bottom:1rem;
}
.icon-txt--headcols:not(.icon-txt--box) .icon-txt__head{
    border-bottom:1px solid rgba(0,0,0,0.1);
    padding-bottom:1rem;
}
.icon-txt--headcols.icon-txt--box{
    border-bottom:4px solid var(--primary);
}

.icon-txt--headcols .icon-txt__ico:not(.icon-txt__ico--border):not(.icon-txt__ico--square),
.icon-txt--headcols .icon-txt__img:not(.icon-txt__img--border):not(.icon-txt__img--square)
{
    background:var(--light);
    color:var(--primary);
}
.icon-txt--headcols .icon-txt__ico,
.icon-txt--headcols .icon-txt__img
{
    align-items:center;
    margin: 0 1rem 0 0;
    flex-shrink:0;
}


/* Icono y texto en dos columnas */
.icon-txt--cols {
    display:flex;
    text-align:left;
    align-items:center;
}

.icon-txt--cols .icon-txt__ico,
.icon-txt--cols .icon-txt__img{
    --sizeIco:4rem;
    flex-shrink:0;
    margin:0 1rem 0 0;
}

/*******************************
BOX - img + texto + button
*******************************/
.grid-auto .box,
.flex-auto .box,
.grid-mosaico .box {
    flex: 1;
}

.box {
    display: flex;
    flex-direction: column;
    background: #fff;
    border-radius: var(--radiusBox);
    overflow: hidden;
    --padding-inner: clamp(1rem, 5%, 2rem);
}

.box[class="box"],
.box[class="box box--cols"],
.box[class="box box--reverse"] {
    background: linear-gradient(#eee, #f5f5f5);
}

.section--light .box[class="box"],
.section--light .box[class="box box--cols"],
.section--light .box[class="box box--reverse"] {
    background: #fff;
}


.box[href] {
    text-decoration: none;
    color: inherit;
}

.box__inner {
    padding: var(--padding-inner);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.box__img img {
    border-radius: 0;
}

.box__info {
    flex: 1;
}

.box__info:not(:last-child) {
    margin: 0 0 1.25rem;
}

.box__title {
    margin: 0 0 0.75cap;
}

/* Box dark */
.box.box--dark {
    background: var(--dark);
    color: var(--dark-invert);
}
/* Box light */
.box.box--light {
    background: var(--light);
    color: var(--light-invert);
}
/* Box gradient  */
.box.box--gradient {
    background: var(--primary);
    color: var(--dark-invert);
    position: relative;
}

.box--gradient::after {
    height: 100%;
    width: 100%;
    content: "";
    background: radial-gradient(at right top, rgba(255, 255, 255, 0.3), rgba(0, 0, 0, 0.1));
    position: absolute;
    z-index: 0;
    right: 0;
    top: 0;
}

.box--gradient .box__inner { z-index:1;
    position: relative;
    overflow: hidden;
}

.box--gradient .box__inner::before {
    height: 100%;
    content: "";
    background: rgb(255, 255, 255, 0.1);
    position: absolute;
    z-index: 0;
    border-radius: 50%;
    right: 0;
    top: 0;
    transform: translate(50%, -25%);
    aspect-ratio: 1;
}

/* Box triangle  */
.box--corner {
    position: relative;
    overflow: hidden;
    border: 1px solid var(--primary);
}

.box--corner .box__inner:after {
    content: '';
    display: block;
    width: 0;
    height: 0;
    border-right: 24px solid transparent;
    border-bottom: 24px solid transparent;
    border-top: 24px solid var(--primary);
    position: absolute;
    top: 0;
    left: 0;
}
/* Box triangle  */
.box--triangle {
    transition: 0.7s;
    position: relative;
    box-shadow: 0 0 12px rgba(0, 0, 0, 0.15);
}

.box--triangle[href]:hover,
.box--triangle:has(.button:hover) {
    background: var(--light);
    transform: scale(1.05);
}

.box--triangle .box__inner {
    position: relative;
}

.box--triangle .box__inner:before {
    content: "";
    position: absolute;
    background: linear-gradient(135deg, transparent 50% 50%, var(--primary) 50% 50%);
    aspect-ratio: 1;
    transform: translateX(25%);
    height: 50%;
    opacity: 0.2;
    right: 0;
    bottom: 0;
}

/* Box con padding*/
.box--pad {
    padding: 1rem;
    border-radius: var(--radiusBox);
    border: 1px solid #eee;
    box-shadow: 0px 0px 20px 5px rgb(190 190 190 / 25%);
}

.section--nogap-down:has(.box--pad) {
    position: relative;
    z-index: 1;
}

.box--pad .box__img img {
    border-radius: var(--radiusBox);
}

.box--pad:not(.box--cols) .box__inner {
    padding: 1rem 0 0;
}

.box--pad .box__link:not(:has(.button)) {
    text-align: right;
}

.box--pad .box__link a {
    text-decoration: none;
    display: inline-block;
    font-weight: var(--bold1);
    transition: color 300ms ease;
}

.box--pad .box__link a:last-child {
    margin-left: 0.25rem;
}

.box--pad {
    position: relative;
    transition: transform 500ms ease-out;
}

.box--pad .icon-txt__img--rounded,
.box--pad .icon-txt__ico--rounded {
    margin-top: calc(((var(--sizeIco) / 2) * -1) - (var(--padding-inner)/2))
}

/* box cols */
.box--cols {
}

.box--pad.box--cols {
    background: #fff;
}

.box--pad.box--cols .box__inner {
    padding: 1rem 0 0;
}

.box--cols .box__title {
    border-bottom: 1px solid #ddd;
    padding-bottom: 1rem;
    margin-bottom: 1rem;
}

.box--cols .box__title::after,
.box--cols .box__title::before {
    display: none;
}

@media screen and (max-width: 1023px) {
    .box--pad.box--cols .box__inner[data-order-mv="1"],
    .box--cols2 .box__inner[data-order-mv="1"] {
        padding: 0 0 1rem;
    }

    .box--pad.box--cols .box__inner[data-order-mv="2"],
    .box--cols2 .box__inner[data-order-mv="2"] {
        padding: 1rem 0 0;
    }

    .box--cols .box__img[data-order-mv="1"],
    .box--cols2 .box__img[data-order-mv="1"],
    .box--colsOver .box__img[data-order-mv="1"] {
        order: 1;
    }

    .box--cols .box__img[data-order-mv="2"],
    .box--cols2 .box__img[data-order-mv="2"],
    .box--colsOver .box__img[data-order-mv="2"] {
        order: 2;
    }

    .box--cols .box__inner[data-order-mv="1"],
    .box--cols2 .box__inner[data-order-mv="1"],
    .box--colsOver .box__inner[data-order-mv="1"] {
        order: 1;
    }

    .box--cols .box__inner[data-order-mv="2"],
    .box--cols2 .box__inner[data-order-mv="2"],
    .box--colsOver .box__inner[data-order-mv="2"] {
        order: 2;
    }
}

@media screen and (min-width: 1024px) {
    .box--reverse:not(.box--cols) {
        flex-direction: column-reverse;
    }

    .box--pad.box--reverse:not(.box--cols) .box__inner {
        padding: 0 0 1rem;
    }

    .box--cols {
        flex-direction: row;
        text-align: left;
    }

    .box--cols .box__img {
        width: 30%;
        min-width: 140px;
    }

    .grid-mosaico .box--cols .box__img {
        width: 50%;
    }

    .box--pad.box--cols .box__inner:last-child {
        padding: 0 0 0 1rem;
    }

    .box--pad.box--cols .box__inner:first-child {
        padding: 0 1rem 0 0;
    }
}

/* box cols 2 */
.box--cols2 ~ .box--cols2 {
    margin-top: 2rem;
}

.box--cols2 {
    box-shadow: none;
    background: none;
    border-radius: inherit;
}

.box--cols2 .box__inner {
    padding: 1rem 0 0;
}

.box--cols2 {
    border-top: 1px solid #ddd;
    padding-top: 1.5rem;
}

.box--cols2 .box__title {
    margin: 0 0 0.6em;
}

@media screen and (min-width: 1024px) {

    .box--cols2 {
        flex-direction: row;
        text-align: left;
        border: 0;
        padding: 0;
    }

    .box--cols2 .box__img {
        width: 30%;
    }

    .box--cols2 .box__inner {
        padding: 0 0 0 var(--padding-inner);
    }

    .box--cols2 .box__title {
        border-top: 1px solid #ddd;
        padding-top: 1rem;
    }
}

/* box colsOver */
.box--colsOver {
    box-shadow: none;
    background: none;
    border-radius: 0;
    overflow: visible;
    text-align: left;
    --translate: 2rem;
}

.box--colsOver .box__img {
    width: calc(100% - var(--translate));
}

.box--colsOver .box__img img {
    border-radius: var(--radiusImg, 0);
}

.box--colsOver .box__inner {
    background: #fff;
    color: var(--font-color);
    padding: min(var(--padding-inner), 1.75rem);
    border-radius: var(--radiusBox, 0);
    box-shadow: 0px 1px 16px rgba(0, 0, 0, 0.1);
    margin-left: var(--translate);
}

@media screen and (max-width: 1023px) {
    .box--colsOver .box__inner[data-order-mv="2"] {
        transform: translateY(calc(var(--translate)*-1));
        margin-bottom: calc(var(--translate)*-1);
    }

    .box--colsOver .box__inner[data-order-mv="1"] {
        transform: translateY(var(--translate));
        margin-top: calc(var(--translate)*-1);
    }
}

@media screen and (min-width: 1024px) {
    .box--colsOver {
        flex-direction: row;
        text-align: left;
    }

    .box--colsOver .box__img {
        width: 35%;
        min-width: 140px;
    }

    .box--colsOver .box__inner {
        margin: 2rem 0;
        transform: translate(0);
        width: calc(100% + var(--translate));
        align-self: center;
    }

    .box--colsOver .box__inner:last-child {
        margin-left: calc(var(--translate)*-1);
    }

    .box--colsOver .box__inner:first-child {
        margin-right: calc(var(--translate)*-1);
    }
}

/* Box estilo 2*/
.box--estilo2 {
    box-shadow: none;
    text-align: left;
}

.box--estilo2 .box__inner {
    position: relative;
    padding: 1rem;
    transition: transform 400ms ease;
}

.box--estilo2[href]:hover .box__inner {
    transform: translateY(1.5rem);
}

.box--estilo2 .box__title {
    display: inline-block;
    background: #fff;
    padding: 0.75rem 1.25rem;
    margin: 0;
    top: 1px;
    transform: translate(-1.25rem, -100%);
    max-width: calc(100% - 1rem);
    position: absolute;
    border-top-right-radius: var(--radiusBox, 0);
}

/* Box over */
.box--over {
    box-shadow: none;
    background: none;
    border-radius: 0;
    overflow: visible;
    --translate: 2rem;
}

.box--over .box__img img {
    border-radius: var(--radiusImg, 0);
}

.box--over .box__inner {
    background: #fff;
    color: var(--font-color);
    padding: min(var(--padding-inner), 1.75rem);
    max-width: 90%;
    width: 100%;
    margin: 0 auto;
    box-shadow: 0px 1px 16px rgba(0, 0, 0, 0.1);
    transform: translateY(calc(var(--translate)*-1));
    margin-bottom: calc(var(--translate) * -1);
    border-radius: var(--radiusBox, 0);
}

/* Box imgbg */
.box--imgbg {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    height: 100%;
    width: 100%;
}

.box--imgbg a {
    text-decoration: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    flex: 1;
}

.box--imgbg .box__img {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
}

.box--imgbg .box__img::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: rgb(255,255,255, 0.65);
    border-radius: var(--radiusImg);
    transition: background 0.4s ease-in-out;
}

.box--imgbg .box__img img {
    border-radius: var(--radiusImg);
    height: 100%;
    object-fit: cover;
}



.box--imgbg .box__inner {
    position: relative;
    display: flex;
    padding: var(--padding-inner);
    justify-content: space-between;
    gap: var(--padding-inner);
    align-items: center;
    flex-direction: row;
}


.box--imgbg .box__info {
    position: relative;
    z-index: 1;
    margin: 0;
    transition: color 0.4s ease-in-out;
}

.box--imgbg .box__info .title {
    transition: color 0.4s ease-in-out;
}

.box--imgbg .box__link i {
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--primary);
    color: var(--primary-invert);
    height: 38px;
    width: 38px;
    border-radius: 50%;
    outline: 2px solid var(--primary);
    border: 1px solid #fff;
    box-shadow: 0px 0px 8px 2px rgba(0,0,0,0.25);
    transition: all 0.4s ease-in-out;
}



@media screen and (max-width:600px) {
    .box--imgbg .box__img::before {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        width: 100%;
        height: 100%;
        background: rgb(0,0,0, 0.5);
        border-radius: var(--radiusImg);
        transition: background 0.4s ease-in-out;
    }

    .box--imgbg .box__info,
    .box--imgbg .box__info .title {
        color: #fff;
    }

    .box--imgbg .box__link i {
        outline: 2px solid #fff;
        border: 1px solid var(--primary);
        background: #fff;
        box-shadow: 0px 0px 8px 2px rgba(255,255,255,0.25);
        color: var(--primary)
    }
}

/*efecto hover en PC*/
@media screen and (min-width:1024px) {
    .box--imgbg:hover .box__info,
    .box--imgbg:hover .box__info .title {
        color: #fff;
    }

    .box--imgbg:hover .box__img::before {
        background: rgb(0,0,0, 0.5);
    }

    .box--imgbg:hover .box__link i {
        outline: 2px solid #fff;
        border: 1px solid var(--primary);
        background: #fff;
        box-shadow: 0px 0px 8px 2px rgba(255,255,255,0.25);
        color: var(--primary);
    }
}

/*******************************
CONTACT - banda de texto + button 
*******************************/
.contact {
    text-align:center;
}
.contact__title {
margin:0 0 0.4em;
}
.contact__link {
    flex-shrink: 0;
    margin-top: 1.25rem;
}
.contact__link .button {
    color:#fff;
}
/* Estilos >= 821px */
@media screen and (min-width: 821px) {
    .contact {
        display: flex;
        align-items: center;
        text-align: left;
		justify-content:space-between;
    }

    .contact__link {
        margin: 0 0 0 calc(var(--padding-h) * 2);
    }
}

/*******************************
GALERIA LIGHT
*******************************/
.lg-outer .lg-thumb-item.active, .lg-outer .lg-thumb-item:hover {
    border-color:var(--primary)!important;
}
.gallery-light:not(.grid-mosaico):not(.swiper-wrapper) {
    list-style: none;
    --flex-gap: 0.75rem;
}
.gallery-light:not(:last-child) {
    margin-bottom: 1.25rem;
}

.gallery-light{
    position:relative;
}
.gallery-light a {
    position: relative;
    display: block;
    width:100%;
    height:100%;
    overflow: hidden;
    color: inherit; 
	border-radius:var(--radiusBox);
}
.gallery-light .num {
    position: absolute;
    transform: translate(-50%,-50%);
    font-size: 1.2rem;
    left: 50%;
    top: 50%;
    text-align: center;
    z-index: 2;
    text-shadow: 0px 1px 4px black;
    transition: font-size 300ms ease;
    color: #fff;
    font-weight: var(--bold1);
}

.gallery-light a:hover .num{
    font-size:0;
}
.gallery-light a:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background: rgba(0,0,0,0);
    width: 100%;
    height: 100%;
    transition: background 500ms ease;
    z-index: 2;
}

.gallery-light a:after {
    content: "\f002";
    font-family: var(--awesome);
    font-weight: 300;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
    color: #fff;
    font-size: 0;
    transition: font-size 500ms ease;
    z-index: 2;
}

.gallery-light a:hover:before {
    background: rgba(0,0,0,0.6);
}

.gallery-light a:hover:after {
    font-size: 2rem;
}
.gallery-light img {
    display: block;
    width: 100%;
    height:100%;
    object-fit:cover;
    transform: scale(1);
    transition: transform 500ms ease;
    border-radius:var(--radiusBox);
}
.gallery-light.grid-mosaico img {
	aspect-ratio: 4 / 3;
	object-fit:cover;
}
.gallery-light a:hover img {
    transform: scale(1.1);
}

.gallery-light__more{
    position:absolute;
    z-index:2;
    bottom:8px;
    right:8px;
    padding:4px 8px;
    cursor:pointer;
    background:rgba(255,255,255,0.85);
    transition:background 300ms ease;
    border-radius:var(--radiusBox);
}
.gallery-light__more:hover{
    background:rgba(255,255,255,1);
}

/* Mosaico */
.gallery-light--mosaico{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
     grid-template-rows:100px 100px 100px 100px;
    grid-gap:4px;
    margin:0;
}
.gallery-light--mosaico li{
    padding:0;
}
.gallery-light--mosaico li img{
    height:100%;
    width:100%;
    object-fit:cover;
}

@media screen and (min-width: 600px) {
    .gallery-light--mosaico{
         grid-template-rows:160px 160px 160px 160px;
         grid-gap:8px;
    }
}
@media screen and (max-width: 1023px) {
    .gallery-light--mosaico li:nth-child(1),
    .gallery-light--mosaico li:nth-child(7){
        grid-row: span 2;
    }
    .gallery-light--mosaico li:nth-child(4),
    .gallery-light--mosaico li:nth-child(8){
        grid-column: span 2;
    }
}

@media screen and (min-width: 1024px) {
    .gallery-light--mosaico{
        grid-template-columns:1fr 1fr 1fr 1fr;
         grid-template-rows:220px 220px 220px ;
    }
    .gallery-light--mosaico li:nth-child(1),
    .gallery-light--mosaico li:nth-child(6){
        grid-row: span 2;
    }
    .gallery-light--mosaico li:nth-child(3),
    .gallery-light--mosaico li:nth-child(8){
        grid-column: span 2;
    }
}

/*******************************
Video-gallery
*******************************/
.video-gallery {
    position: relative;
}

.video-gallery video {
    display: block;
    width: 100%;
    object-fit: cover;
    max-height: 480px;
}

.video-gallery .play {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 50px;
    opacity: 0.86;
    text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.3);
    z-index: 2;
    transition: font-size 300ms ease;
}

.video-gallery:hover .play {
    font-size: 60px;
}

/***************************
RESPONSIVE
**************************/
/* Estilos >= 600px */
@media screen and (min-width: 600px) {
}

/* Estilos <= 820px */
@media screen and (max-width: 820px) {
  
}

/* Estilos >= 821px */
@media screen and (min-width: 821px) {


}

/* Estilos >= 1024px */
@media screen and (min-width: 1024px) {
 

}

/* Estilos >= 1200px */
@media screen and (min-width: 1200px) {


}
