/*
Theme Name: Custom Theme
Theme URI: Custom Theme
Author: Custom Theme
Author URI: Custom Theme
Description: Custom Theme
Version: 1.0
Tags: Custom Theme
Text Domain: Custom Theme
*/

@charset "utf-8";
/* CSS Document */

:root{
  --color1:#000;
  --text:#000;
  --border:#AAAAAA;
  --background:#DBDCDE;
  --lightgray:#F0F0F0;
  --gray:#7C7C7C;

  --borderradius:30px;
  --sectionmargin:8.5vw;
  --paddings:30px;
  --paddingsdouble:calc(var(--paddings) * 2) ;
  --paddingsmid:calc(var(--paddings) / 2) ;
  --cardpaddings:calc(var(--paddings) * 1.3) ;

  --stroke:#F1F1F1;

  --font:20px;
  --fontm:16px;
  --fontxs:14px;
  --fontxl:23px;
}

.scolor1{color: var(--color1);}
.scolor2{color: var(--color2);}
.scolor2{color: var(--color3);}

/*scroll*/
*::-webkit-scrollbar {
    width: 8px;
}

*::-webkit-scrollbar-track {
    border-radius: 0px;
    background-color: var(--lightgray);
}

*::-webkit-scrollbar-thumb {
    height: 56px;
    border-radius:0px;
    border: 0px solid transparent;
    background-clip: content-box;
    background-color: var(--color1);;
}

*::-webkit-scrollbar-thumb:hover {
    background-color: #555;
}
.nicescroll-cursors{
background: var(--color1)!important;
border-radius: 0px!important;
}
.nicescroll-rails{
background: var(--stroke);
}
.rowmarginbot{}


.ccookiepopupwrapbanner *{
font-size: 14px!important;
}
.ccookiepopupwrapbanner .cta{
padding: 10px;
padding-left: 18px;
padding-right: 18px;
margin-right: 5px;
font-size: 12px!important;
}
.cinnertextcookies {
    padding-bottom: 15px!important;
    padding-top: 5px!important;
    }
.cbannercookiescodeinner {
    padding: 20px!important;
}
.cbannercookiescode {
    max-width: 800px!important;
    }

/*jqswa*/
.jqswaitem,.jqswaitemer > *{
-webkit-transition:all 0.7s ease-in-out;
-moz-transition:all 0.7s ease-in-out;
-o-transition:all 0.7s ease-in-out;
transition:all 0.7s ease-in-out;
}
.jqswa .jqswaitem,.jqswaitemer > *{
transform: translateY(-30px);
}
.jqswa .jqswaitem.jqswalight{
transform: translateY(-10px);
}
.jqswa .jqswa-notranslate{
transform: translateY(0px);
}
.jqswa .jqswaitem,.jqswaitemer > *{
opacity: 0;
}
.jqswa .jqswaitem{
opacity: 0;
}
.jqswa .jqswaleftright{
transform: translateX(-30px);
}
.jqswa .jqswarightleft{
transform: translateX(30px);
}
.jqswa.scrollingwayfinish .jqswaitem,.jqswa.scrollingwayfinish .jqswaitemer > *{
transform: translateY(0px) translateX(0px);
}
.jqswa.scrollingwayfinish .jqswaitem,.jqswa.scrollingwayfinish .jqswaitemer > *{
opacity: 1;
}
.jqswa .jqswabg{
opacity: 0;
overflow: hidden;
transform: scale(1.02);
-webkit-transition:all 0.7s ease-in-out;
-moz-transition:all 0.7s ease-in-out;
-o-transition:all 0.7s ease-in-out;
transition:all 0.7s ease-in-out;
    height: 100%;
}
.jqswa.scrollingwayfinish .jqswabg{
opacity: 1;
transform: scale(1);
}


.cursor-outline,
.cursor-dot {
  opacity: 0;
  z-index: 999;
}

.cursor-outline {
  border-radius: 50px;
  position: absolute;
  width: 30px;
  height: 30px;
  border: solid 1px black;
  /* mix-blend-mode: difference; */
  pointer-events: none;
}

/* Visible when running fancy.js */
.cursor-dot {
  border-radius: 100%;
  position: absolute;
  width: 8px;
  height: 8px;
  background-color: black;
  pointer-events: none;

}

.cursor-outline,
.cursor-dot {
  /* needed for target (shared) */
  top: 50%;
  left: 10%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transform: translate(-50%, -50%) rotate(0deg);
  transform: translate(-50%, -50%) rotate(0deg);
transform-origin: center center;
}

.cmedia {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
}
.cmedia iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.cmedialock::before {
content: "";
display: block;
position: absolute;
top: 0px;
width: 100%;
height: 45%;
background: black;
z-index: 10;
opacity: 0;
}
.cmedialock::after {
z-index: 10;
content: "";
display: block;
position: absolute;
bottom: 50px;
width: 100%;
height: 42%;
background: black;
opacity: 0;
}




.loadingpage::before{
content: "";
display: block;
position:fixed;
top:0px;
left:0px;
height:100%;
width:100%;
background: white;
z-index: 9000;
-webkit-transition:all 0.2s ease-in-out;
-moz-transition:all 0.2s ease-in-out;
-o-transition:all 0.2s ease-in-out;
transition:all 0.2s ease-in-out;
}
.domloaded.loadingpage::before{
opacity: 0;
pointer-events: none;
}
.loadingpageout.domloaded.loadingpage::before{
opacity: 1;
pointer-events: all;
}

.cbotonalert{
margin-top: 10px;
}



/*slick*/



.cslickwrap{
overflow: hidden;
}
.cslickwrap{
position: relative;
}
.cslickcontrol{
position: absolute;
top: 50%;
transform: translateY(-50%);
z-index: 300;
cursor: pointer;
}
.cslicknext{
right: 20px;
}
.cslickprev{
left: 20px;
}
.cslickcontrol rect{
-webkit-transition:all 0.2s ease-in-out;
-moz-transition:all 0.2s ease-in-out;
-o-transition:all 0.2s ease-in-out;
transition:all 0.2s ease-in-out;

}
.cslickcontrol:hover rect{
fill:black;
}

/*
aspect-ratio: 1 / 1;
object-fit: cover;
*/

/*jqswa*/


@keyframes bounce {
    0% {
        transform: translateY(1px);

    }
    50% {
        transform: translateY(6px);
    }
    100% {
        transform: translateY(1px);
    }
}


.loadingajax{
display: none;
}
.jqloadingajax .loadingajax{
display: block;
}

.loadingajax .loader{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
z-index: 999;
}
.loadingajaxfixed  .loader{
position:fixed;
}

.loadingajax .loaderinner{
position: relative;
height: 100%;
}
.loader::before{
content: "";
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
background: black;
opacity: 0.2;
}
.lds-ripple {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: 80px;
  height: 80px;
}
.lds-ripple div {
  position: absolute;
  border: 4px solid #fff;
  opacity: 1;
  border-radius: 50%;
  animation: lds-ripple 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;
}
.lds-ripple div:nth-child(2) {
  animation-delay: -0.5s;
}
@keyframes lds-ripple {
  0% {
    top: 36px;
    left: 36px;
    width: 0;
    height: 0;
    opacity: 0;
  }
  4.9% {
    top: 36px;
    left: 36px;
    width: 0;
    height: 0;
    opacity: 0;
  }
  5% {
    top: 36px;
    left: 36px;
    width: 0;
    height: 0;
    opacity: 1;
  }
  100% {
    top: 0px;
    left: 0px;
    width: 72px;
    height: 72px;
    opacity: 0;
  }
}



.marginTop10{margin-top: 10px;}.marginTop20{margin-top: 20px;}.marginTop30{margin-top: 30px;}.marginTop40{margin-top: 40px;}.marginTop50{margin-top: 50px;}.marginTop60{margin-top: 60px;}.marginTop70{margin-top: 70px;}.marginTop80{margin-top: 80px;}
.marginBottom10{margin-top: 10px;}.marginBottom20{margin-bottom: 20px;}.marginBottom30{margin-bottom: 30px;}.marginBottom40{margin-bottom: 40px;}.marginBottom50{margin-bottom: 50px;}.marginBottom60{margin-bottom: 60px;}.marginBottom70{margin-bottom: 70px;}.marginBottom80{margin-bottom: 80px;}.paddingTop10{padding-top: 10px;}.paddingTop20{padding-top: 20px;}.paddingTop30{padding-top: 30px;}.paddingTop40{padding-top: 40px;}.paddingTop50{padding-top: 50px;}.paddingTop60{padding-top: 60px;}.paddingTop70{padding-top: 70px;}.paddingTop80{padding-top: 80px;}
.paddingBottom10{padding-bottom: 10px;}.paddingBottom20{padding-bottom: 20px;}.paddingBottom30{padding-bottom: 30px;}.paddingBottom40{padding-bottom: 40px;}.paddingBottom50{padding-bottom: 50px;}.paddingBottom60{padding-bottom: 60px;}.paddingBottom70{padding-bottom: 70px;}.paddingBottom80{padding-bottom: 80px;}


.textleft{text-align: left;}
.textcenter{text-align: center;}
.textright{text-align: right;}


/*estandards*/
.cvcenter{
	display:table;
	height:100%;
	width: 100%;
}
.cvcenterinner{
	display:table-cell;
	vertical-align:middle;
}
.nicescroll-rails {
z-index: 999!important;

}
/*//estandards*/
.clear{clear:both;}
.clear{width: 100%;}
.overflowhidden{overflow: hidden;}
.overflowxhidden{overflow-x: hidden;}

/*general*/
body {
  margin: 0;
}
body,input,textarea,a,.jqsavestring input,h5{
	font-size: 18px;
  line-height: 1.4;
	font-weight:300;
	font-family: 'Poppins', sans serif;
}
.clineheightlow{
line-height: 30px;
}
textarea:focus, input:focus{
    outline: none;
}

img {border: 0 none;}
a {
  text-decoration: none;
}
a:hover {text-decoration:none;}

body,a,.iinputdefault,.iinputdefault::placeholder,input,textarea{
color: var(--text);
}
.ssline span,.ssline.sline,.sline{
position: relative;
}
.ssline span::before,.ssline.sline::before,.sline::before{
position: absolute;
bottom: 1px;
left: 0px;
width: 100%;
border-bottom: 1px solid #191919;
content: "";
}
.slinewhite span::before,
.sline.slinewhite::before{
border-color: white;
}
.zoominout{
overflow: hidden;
}
.zoominout .cimagesentinellimg{
animation: zoominout 20s infinite;
animation-timing-function: linear;
}
@keyframes zoominout {
  0% {
		transform: scale(1);
  }
  50% {
    transform: scale(1.1);
  }

  100% {
    transform: scale(1);
  }
}

.iinputdefault{
background: transparent;
border: 0px;
width: 100%;
box-sizing: border-box;
color: white;
padding: calc(var(--paddingsmid) * 1);
border: 1px solid white;
margin-bottom: var(--paddingsmid);
border-radius: 15px;

}
.iinputdefault::placeholder{
color: white;
}

.csectionmargin{
height: var(--sectionmargin);
}
.csectionmargin-negativo{
margin-top: calc(var(--sectionmargin) * -1);
}
.csectionmarginmid{
height: calc(var(--sectionmargin)/2);
}
.csectionmarginmmsmall{
height: calc(var(--sectionmargin)/2.5);
}
.csectionmarginmsmall{
height: calc(var(--sectionmargin)/3);
}
.csectionmarginsmall{
height: calc(var(--sectionmargin)/4);
}
.csectionmarginmini{
height: calc(var(--sectionmargin)/8);
}
.cnomarginbot .csectionmargin{
display: none;
}

.scoma:last-child{
display: none;
}
/*
aspect-ratio:500 / 700;
-o-object-fit: cover;
   object-fit: cover;
*/
.cimagesentinell{
position: relative;
}
.cimagesentinell svg{
width: 100%!important;
height: auto!important;
opacity: 0;
display: block;
}
.cimagesentinellimg{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
background-position: center;
background-size: cover;
background-repeat: no-repeat;
}

.cpopupwrap{
position:fixed;
top:0px;
left:0px;
height:100%;
width:100%;
z-index:950;
display: none;
}
.cpopupimage .cpopupinner{
padding: 0px;
}
.cpopupimage img,.cgallery video{
display: block;
}
.cgallery video{

}
.cpopupimage img,.cpopupimage video{
max-width: 90vw;
max-height: 90vh;
}
.cpopupimage .cpopup{
max-width: none;
width: auto;
}
.cpopupopa{
position:fixed;
top:0px;
left:0px;
height:100%;
width:100%;
background-color: black;
opacity: 0.7;
z-index: 940;
}

.cpopup{
position: absolute;
background-color: white;
z-index: 960;
max-width: 1200px;
width: 90%;
text-align: center;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
margin-top:-40px;
opacity: 0;
-webkit-transition:all 0.4s ease-in-out;
-moz-transition:all 0.4s ease-in-out;
-o-transition:all 0.4s ease-in-out;
transition:all 0.4s ease-in-out;
}
.cpopupclose{
position: absolute;
top: 0px;
right: 0px;
height: 90px;
width: 90px;
background-image: url(img/elementos/i-popupclose.svg);
background-position: center;
background-repeat: no-repeat;
background-size: 40px;
cursor: pointer;
z-index: 20;
}
.cpopupalert .cpopup{
width: 700px;
}
.cpopupalert .cpopupinner{
padding-top: 79px;
padding-bottom: 50px;
}
.cpopupinner{
position: relative;
padding: 60px;
}
.cpopupcerrar{
	position: absolute;
	top: 25px;
	right: 30px;
	cursor: pointer;
	background-color: #e5e5e5;
    padding: 6px;
    border-radius: 100%;
	font-weight: 700;
	font-size: 12px;
	width: 18px;
    height: 18px;
    line-height: 18px;
}

.showpopup .cpopup{
opacity: 1;
margin-top:0px;
}
.infoicon{
width: 30px;
height: 30px;
line-height: 30px;
border: 2px solid #666;
border-radius: 100%;
text-align: center;
font-weight:700;
position: absolute;
left: 20px;
top: 20px;
font-size: 14px;
color: #666;
}
.infoicon svg{
position: absolute;
left: 50%;
top: 50%;
transform: translateY(-50%) translateX(-50%);

}
.clente{
position: relative;
}
.clenteopa{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
opacity: 0.2;
background: black;
}
.clenteimagebck{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
background-position: center;
background-repeat: no-repeat;
background-size: cover;
}



/*form*/


input,textarea,.sinput{
width: 100%;
display: block;
}
.cinputwrap .cinner{
position: relative;
}
.cinputwrap .cinner input,.cinputwrap .cinner .sinput,.cinputwrap .cinner textarea{
box-sizing: border-box;
    display: block;
    border: 0px;
    padding:21px;
    padding-left:35px;
    padding-right: 35px;
    color: #4f5c69;
    background: white;
}
.cselectdropdown input{
display: none!important;
}
.cinputwrap .cinner input::placeholder,.cinputwrap .cinner textarea::placeholder{
color: #4f5c69;
}
.cinputwrap .cinner textarea{
height: 300px;
}
.cformfooter .csubtitulartext{
display: block;
color: #4f5c69;
}
.cpopupcontact *{
text-align: left;
}
.cpopup .sh3{
margin-bottom: 20px;
}
.cformlegal{
text-align: justify;
color: #4f5c69;
}
.saceptotext{
text-align: left;
}
.cformlegal,.cformlegal a{
font-size: 18px;
line-height: 31px;
}
.ccheckboxes{
border-top: 2px solid #acbbb6;
margin-top: 20px;
padding-top: 20px;
}
/*checkbox*/
.scheck{
display: inline-block;
width: 13px;
height: 13px;
vertical-align: middle;
margin-right: 10px;
border: 2px solid #eaeaea;
margin-top: -4px;
position: relative;
}

.ccheckboxeslegal{
position: relative;
}
.ccheckboxeslegal input{
position: absolute;
left:10px;
top: 50%;
transform: translateY(-50%);
width: 20px;
opacity: 0;
}
.scheckwrap{
position: relative;
display: inline-block;
}
.ccheckboxeslegal{
margin-top: 15px;
margin-bottom: 5px;
}
.scheck:before{
content: "";
display: block;
position: absolute;
top: 52%;
left: 50%;
transform: translateY(-50%) translateX(-50%) rotate(45deg);
width: 80%;
height: 2px;
background: #1A1A1A;
opacity: 0;
}
.scheck:after{
content: "";
display: block;
position: absolute;
top: 52%;
left: 50%;
transform: translateY(-50%) translateX(-50%) rotate(-45deg);
width: 80%;
height:2px;
background: #1A1A1A;
opacity: 0;
}
.icheckbox.selected .scheck:after,
.icheckbox.selected .scheck:before{
opacity: 1;
}
.icheckbox{
display: block;
margin-bottom: 15px;
cursor: pointer;
}
.ccheckboxeslegal,.clegalwrap{
margin-top:0px;
margin-bottom: 15px;
}

.mCSB_scrollTools_vertical {
    transform: scale(0.95) translateX(-3px)  translateY(-2px);
}
#mCSB_1_dragger_vertical {
    transform: scale(0.95) translateY(4px);
}
/*dropdown*/
.cdropsc {
    max-height: 294px;
}
.cselectdropdownvalues{
position: absolute;
top: 0px;
left: 0px;
width: 100%;
}
.cinputwrapdropdown{
position: relative;
z-index:10;
}
.cselectdropdown input{
display: none;
}
.cselectdropdownvalues{}
.jqdropdownvalue{
display: block;
text-align: center;
padding: 10px;
    padding-bottom: 8px;
background: #aaaaaa;
color: #505050;
border-top: 1px solid #ccc;
-webkit-transition:all 0.2s ease-in-out;
-moz-transition:all 0.2s ease-in-out;
-o-transition:all 0.2s ease-in-out;
transition:all 0.2s ease-in-out;
cursor: pointer;
}
.jqdropdownvalue:hover,.jqdropdownvalue.selectedvalue{
background: #505050;
color: #aaaaaa;
}

.cselectdropdown svg {
  position: absolute;
  top: 27px;
  right: 24px;
  z-index: 100;
  width: 33px;
  height: auto;
    -webkit-transition: all 0.2s ease-in-out;
    -moz-transition: all 0.2s ease-in-out;
    -o-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
}

.selectactive svg{
   transform: translateZ(0px) rotateX(-180deg);
}
.cselectdropdownvalues {
    display: none;
}
.jqopendropdown{
position: absolute;
width: 100%;
height: 100%;
top: 0px;
left: 0px;
cursor: pointer;
}

/*inputchoice*/
.cinputchoice input{
display: none;
}
.cacepto.selectedvalue .iaceptoinput:before{
content: "";
    display: block;
    width: 100%;
    height: 100%;
    background-repeat: no-repeat;
    background-size: 26px;
    background-image: url(img/elementos/i-cross.svg);
    background-position: center;
    position: absolute;
    top: 0px;
    left: 0px;
    z-index: 3;
}



/*form*/


/*sections*/
.csection {
position: relative;
}
.csectionpaddings{
height: var(--paddings);
}
.csectionnopadding{
padding: 0px;
}
.csectionwhite {
color: white;
}
.jqsectionfull100 {
padding-top: 330px;
}
.csectionwhite h1,.csectionwhite h2,.csectionwhite h3,.csectionwhite h4,.csectionwhite h5,.csectionwhite .sh1,.csectionwhite .sh2,.csectionwhite .sh3,.csectionwhite .sh4,.csectionwhite a{
color: white;
}
.csectionopa,.citemopa{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
z-index: 100;


}
.citemtext{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
z-index: 10;
text-align: center;
opacity: 0;
transform: translateY(-15px);
}
.csectionsentinell .csectionbg svg{
display: block;width: 100%;
height: auto;
}
.csectionsentinell .csectionopa{
display: none;
}
.coltitular{
margin-bottom: 0px!important;
}
.citemopa,.citemtext{
-webkit-transition:all 0.3s ease-in-out;
-moz-transition:all 0.3s ease-in-out;
-o-transition:all 0.3s ease-in-out;
transition:all 0.3s ease-in-out;

}
.citemoverlay .citemtext *{
color: white;
}
.citemopa{
opacity: 0;
z-index: 8;
}
.citemoverlay:hover .citemopa{
opacity: 0.6;
}
.citemoverlay:hover .citemtext{
opacity: 1;
transform: translateY(0px);
}

.citemoverlayinvertido .citemopa{
opacity: 0.3;

}
.citemoverlayinvertido .citemtext{
opacity: 1;
transform: translateY(0px);
}
.citemoverlayinvertido:hover .citemopa{
opacity: 0;

}
.citemoverlayinvertido:hover .citemtext{
opacity: 0;
transform: translateY(-30px);
}

.csectionbg{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
background-position: center;
background-size: cover;
z-index: 90;
}
.scrollingwayfinish .csectionopa{
opacity: 0.8;
}

.csectiontext{
position: relative;
z-index: 150;
}
.csectionfullscreen{
height:100vh;
padding-top: 0px;
padding-bottom: 0px;
}
.csectionfullscreen .csectiontext{
height: 100%;
}
.csectionbgvideo{
overflow: hidden;
}
.csectionbgvideo video{
position: absolute;
top: 0;
left: 0;
display: block;
width: 100%;
height: 100%;
-o-object-fit: cover;
   object-fit: cover;
}

.csectionsentinell{
padding-top: 0px;
padding-bottom: 0px;
}
.csectionsentinell .csectionbg{
position: relative;
}
.csectionsentinell .csectionbg img{
position: relative;
display: block;
width: 100%;
height: auto;
}
.csectionsentinell .csectiontext{
position: absolute;
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
color: white;
}
.csectionwhitebackground{
background: #fff;
}
/*///sections*/




/*acordion*/

.cacordion p{
display: none;
}
.cacordion ul{
padding-left: 0px;
}
.cacordion li{
list-style: none;
}
.cacordion > ul > li{
padding-bottom: 10px;
border-bottom: 1px solid #121212;
padding-top: 11px;
position: relative;
margin-bottom: 0px;
cursor: pointer;
}
.cacordion > ul > li > ul > li:first-child{
padding-top: 30px;
}
.cacordion > ul > li > ul > li:last-child{
padding-bottom: 30px;
}
.cacordion > ul > li:first-child{
border-top: 1px solid #121212;
}
.cacordion li li{
display: none;
}

.cacordion > ul > li::before{
content: "";
display: block;
width:13px;
height: 7px;
background-image: url('img/elementos/i-fldownaccordion.svg');
background-position: center;
background-repeat: no-repeat;
top: 19px;
right: 20px;
position: absolute;
-webkit-transition:all 0.2s ease-in-out;
-moz-transition:all 0.2s ease-in-out;
-o-transition:all 0.2s ease-in-out;
transition:all 0.2s ease-in-out;
}
.liacordionshow::before{
transform: scaleY(-1);
   -moz-transform: scaleY(-1);
   -webkit-transform: scaleY(-1);
   -ms-transform: scaleY(-1);
}

/*///acordion*/


.cvideocover{
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
background: white;
z-index: 10;
background-position: center;
background-size: cover;
}
.cplayvideo{
position: absolute;
top: 50%;
left: 50%;
transform: translateY(-50%) translateX(-50%);
text-align: center;
border-radius: 100%;
cursor: pointer;
}
.csentinellsvg svg{
width: 100%;
height: auto;

}
.csectionrelative{
position: relative;
}

.cburger{
position: absolute;
top: 50%;
right: 0px;
transform: translateY(-50%);
width: 42px;
}
.cburgerinner{
position: relative;
}
.cbar{
width: 100%;
height: 2px;
background: black;
margin-top: 8px;
margin-bottom:8px;
}


p{
margin-top: 0px;
margin-bottom:20px;
}
p:last-child{
margin-bottom: 0px;
}

h1,h2,h3,h4,h5,
.sh1,.sh2,.sh3,.sh34,.sh4,.sh5{
font-family: 'Poppins', sans-serif;
font-weight:500;
margin-top: 0px;
margin-bottom: 0px;
}

.csingleblogredes svg{
height: 50px;
width: auto;
display: inline-block;
}
.relative{
position: relative;
}



/*slider*/
.cwrap,.cpasador,.slide{
	height:100%;
	width:100%;
}
.cwrap{
	position:relative;
	height:66%;
}
.slide{
	background-position:center;
	background-size:cover;
}


.cfooterkitsinner{
background: var(--lightgray);
padding-left: var(--paddings);
padding-right: var(--paddings);
padding-top: 15px;
padding-bottom: 15px;
}
.cfooterkitsinner svg{
display: block;
max-width: 500px;
width: 100%;
height: auto;
}
.cfooterkitsimg{
position: relative;
display: block;
}
.cfooterkitsimg *{
fill:var(--text);
}
.cfooterkitsimg *[fill='#FEF200']{
fill:var(--lightgray);
}

/*web*/


.jqdrawicon * {
    stroke-dasharray:1200;
    stroke-dashoffset: 1200;
    animation-delay: 1.4s!important;
}

@keyframes dash {
  to {
	stroke-dashoffset:  0;
  }
}
.scrollingwayfinish .jqdrawicon svg *{
animation: dash 2.5s linear forwards;
}

.ccontactoitemmap{
height: 100%;
}

/* font-size: calc(30px + 4.8vw); */

h1,.sh1{
font-size: calc(35px + 5.8vw);
line-height: 0.9;
}
h2,.sh2,.h1toh2 h1{
font-size: calc(30px + 2.4vw);
line-height: 1;
}
h3,.sh3{
font-size: calc(22px + 0.8vw);
line-height: 0.95;

}
h4,.sh4{
font-size: 25px;
line-height: 1.4;
}
h5,.sh5{
font-weight: 300;
}
.cta{
cursor: pointer;
background: black;
color: white;
padding: 20px;
padding-left: 50px;
padding-right: 50px;
display: inline-block;
border-radius: 40px;
font-size: var(--font);
border: 0px;
width: fit-content;
box-sizing: border-box;
-webkit-transition:all 0.2s ease-in-out;
-moz-transition:all 0.2s ease-in-out;
-o-transition:all 0.2s ease-in-out;
transition:all 0.2s ease-in-out;

}
.cta:hover{

}
.ctanaked{

}
.ctanaked:hover{

}
.ctawhite{
background: white;
color: black;
}
.ctawhite:hover{
background: black;
color: white;
}
.cta100{

}
.ctawide{
width: 100%;
text-align: center;
}
.ctasmall{

}

.citembotrightwrap{
position: relative;
}
.citembotright{
position: absolute;
  bottom: 0px;
  right: 0px;
}
.cburger{
display: none;
}


/* Registrar propiedades para interpolar suavemente */
@property --ang { syntax: '<angle>'; initial-value: 45deg; inherits: true; }
@property --cA  { syntax: '<color>'; initial-value: #002bff; inherits: true; }
@property --cB  { syntax: '<color>'; initial-value: #bf0fff; inherits: true; }

/* Contenedor que activa la animación (heredan las variables sus hijos) */
.g-flow {
  --ang: 45deg;
  --cA: #002bff; /* azul */
  --cB: #bf0fff; /* magenta */

  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;
}

/* Texto con tinta de degradado animado */
.text-gradient {
  background-image: linear-gradient(var(--ang), var(--cA), var(--cB));
  background-size: 200% 200%;
  background-position: 0% 50%;

  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;

  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
}




.csectionopa.bg-gradient {
  mix-blend-mode: hard-light;
  z-index: 100;
  opacity: 1 !important;
}

.csectionbgvideo {
  filter: grayscale(1) blur(20px);
  opacity: 0.5 !important;

    /* lo movemos a un contenedor transformable */
    transform: scale(2.3);
    animation: spin-bg 120s linear infinite; /* rota lento y constante */
    transform-origin: center center; /* gira sobre su centro */
  }

  /* Keyframes para rotación infinita */
  @keyframes spin-bg {
    from { transform: scale(2.3) rotate(0deg); }
    to   { transform: scale(2.3) rotate(360deg); }
  }

/* Fondo de cualquier bloque */
.bg-gradient {
  background-image: linear-gradient(var(--ang), var(--cA), var(--cB));
  background-size: 200% 200%;
  background-position: 0% 50%;
  /* Aseguramos que el propio overlay también anima */
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;
  will-change: background-image;
}

/* ---- Animaciones ---- */
/* Paleta con bucle cerrado y sin negros agresivos */
@keyframes pair-shift {
  /* 0) azul → magenta */
  0%   { --cA:#002bff; --cB:#bf0fff; }
  /* 1) rojo → magenta (suave hacia lila) */
  25%  { --cA:#ff3b30; --cB:#bf0fff; }
  /* 2) verde → azul (cambio frío pero continuo) */
  50%  { --cA:#00e632; --cB:#0044ff; }
  /* 3) azul → rojo (transición cálida) */
  75%  { --cA:#0066ff; --cB:#ff3b30; }
  /* 4) CERRAR EL BUCLE: igual que 0% */
  100% { --cA:#002bff; --cB:#bf0fff; }
}

@keyframes angle-rotate {
  to { --ang: 405deg; } /* 360 + 45 para cerrar ciclo suave */
}

/* Accesibilidad: reduce motion (mantén si quieres desactivar) */
@media (prefers-reduced-motion: reduce) {
  .g-flow { animation: none; }
}

/* Si prefieres no desactivar nada en reduce-motion, usa esta alternativa */
/*
@media (prefers-reduced-motion: reduce) {
  .g-flow { animation: inherit; }
}
*/



/* =========================
   BORDE DEGRADADO ANIMADO
   ========================= */
@property --ang { syntax: '<angle>'; initial-value: 45deg; inherits: true; }
@property --cA  { syntax: '<color>'; initial-value: #002bff; inherits: true; }
@property --cB  { syntax: '<color>'; initial-value: #bf0fff; inherits: true; }

:root{
  --border-w: 2px;
  --radius: 16px;
}

/* Activa animación de colores si no está dentro de .g-flow */
.border-gradient {
  --ang: 45deg;
  --cA: #002bff;
  --cB: #bf0fff;
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
}

/* Capa del borde */
.border-gradient::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: var(--border-w);
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(var(--ang), var(--cA), var(--cB));
  background-size: 200% 200%;
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;

  /* Agujereamos el interior */
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
  z-index: 10;
}

/* Fallback: border-image si no hay mask-composite */
@supports not (mask-composite: exclude) and not (-webkit-mask-composite: xor) {
  .border-gradient {
    border: var(--border-w) solid transparent;
    border-image: linear-gradient(var(--ang), var(--cA), var(--cB)) 1;
    animation:
      pair-shift 16s linear infinite,
      angle-rotate 28s linear infinite;
  }
}

/* ---- Tus animaciones globales ---- */
@keyframes pair-shift {
  0%   { --cA:#002bff; --cB:#bf0fff; }
  25%  { --cA:#ff3b30; --cB:#bf0fff; }
  50%  { --cA:#00e632; --cB:#0044ff; }
  75%  { --cA:#0066ff; --cB:#ff3b30; }
  100% { --cA:#002bff; --cB:#bf0fff; }
}

@keyframes angle-rotate {
  to { --ang: 405deg; }
}

/* ========== VARIABLES ANIMABLES ========== */
@property --ang { syntax: '<angle>'; initial-value: 45deg; inherits: true; }
@property --cA  { syntax: '<color>'; initial-value: #002bff; inherits: true; }
@property --cB  { syntax: '<color>'; initial-value: #bf0fff; inherits: true; }

:root {
  --border-w: 2px;
  --radius: 30px;
}

.csectioncardpile1 .csectioncardpilecontent{
border-radius: var(--radius);
}
/* ========== BASE: g-flow ========== */
.g-flow {
  --ang: 45deg;
  --cA: #002bff;
  --cB: #bf0fff;
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;
}

/* ========== BORDE GRADIENTE SINCRONIZADO ========== */
.border-gradient {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
}

/* El borde toma los colores de su contexto (heredados de .g-flow)
   -> por tanto va al mismo ritmo EXACTO que el fondo */
.border-gradient::before {
  content: "";
  position: absolute;
  inset: 0;
  padding: var(--border-w);
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(var(--ang), var(--cA), var(--cB));
  background-size: 200% 200%;
  /* ya no le aplicamos ninguna animación independiente */
  animation: none;

  /* agujero interior */
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  mask-composite: exclude;
}

/* Si el borde está fuera de g-flow → autoinicia animaciones propias */
.border-gradient:not(.g-flow *) {
  --ang: 45deg;
  --cA: #002bff;
  --cB: #bf0fff;
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;
}
.border-gradient:not(.g-flow *)::before {
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;
}

/* Fallback sin mask-composite */
@supports not (mask-composite: exclude) and not (-webkit-mask-composite: xor) {
  .border-gradient {
    border: var(--border-w) solid transparent;
    border-image: linear-gradient(var(--ang), var(--cA), var(--cB)) 1;
  }
}

/* ========== ANIMACIONES BASE ========== */
@keyframes pair-shift {
  0%   { --cA:#002bff; --cB:#bf0fff; }
  25%  { --cA:#ff3b30; --cB:#bf0fff; }
  50%  { --cA:#00e632; --cB:#0044ff; }
  75%  { --cA:#0066ff; --cB:#ff3b30; }
  100% { --cA:#002bff; --cB:#bf0fff; }
}
@keyframes angle-rotate {
  to { --ang: 405deg; }
}








.csectionbannerdefault{
height: calc(100vh - var(--paddings));

border-radius: var(--borderradius);
margin: var(--paddings);
margin-bottom: 0px;
border-bottom-left-radius: 0px!important;
border-bottom-right-radius: 0px!important;
}



.clogobanner{
position: absolute;
left: var(--paddings);
/* top:var(--paddings); */
bottom: calc(var(--paddings) + 80px);
}
.clogobanner svg{
height: auto;
width: auto;
max-width: 42vw;
display: block;
aspect-ratio:872/792;
object-fit:cover;
}

.cmarquesina{
position: absolute;
bottom: 0px;
left: 0px;
width: 100%;
background: black;
color: white;
z-index: 300;
padding-top: 25px;
padding-bottom: 25px;
}
.csectiontexttext{
position: absolute;
top: 0px;
width: 100%;
height: 100%;
text-align: right;
}
.cbdesc{
text-align: left;
width: fit-content;
display: inline-block;
padding: var(--paddings);
}
.csectiontexttext .cta{
box-sizing: border-box;
text-align: center;
margin-top: 10px;
padding-left: calc(var(--paddings) * 3);
padding-right: calc(var(--paddings) * 3);
transform: translateY(-50%);
opacity: 0;
}
.cmarquesina {
/* opacity: 0; */
}
.col45{
width: 45%;
}
.col47{
width: 47%;
}
.ctopbannermarq{
overflow: hidden;
}
.clogobanner svg path { filter: blur(6px); }

.jqhanim h1,
.jqhanim h2 {
  line-height: 1.2; /* ajusta según tu diseño */
}

.jqhanim h1 .line,
.jqhanim h2 .line {
  display: block;             /* cada línea ocupa todo el ancho */
  overflow: hidden;           /* para que no se vea cuando sube */
}

.jqhanim h1 .line span,
.jqhanim h2 .line span {
  display: inline-block;      /* permite aplicar transform y blur */
  will-change: transform, filter, opacity;
}
.line{
margin-top: -15px;
}
.csectiontext h2{
margin-top: 10px;
margin-bottom: 30px;
}



.cheader{
position: fixed;
width: 100%;
z-index: 600;
background: white;
height: 80px;
transform: translateY(-101%);

}
.cheader,.cheaderlogo svg *,.cheader .cta,.cheader .cta,.cheader .cmenutop{
-webkit-transition:all 0.3s ease-in-out;
-moz-transition:all 0.3s ease-in-out;
-o-transition:all 0.3s ease-in-out;
transition:all 0.3s ease-in-out;
}
.gsapscrolled .cheader{
transform: none;
}
.cheaderinner{
height: 100%;
position: relative;
}
.csuperbar{
height: 2px;
position: absolute;
width: 100%;
bottom: 0px;
left: 0px;
background:
}

.cmenutop span {
font-size: var(--fontxs);
margin-left: var(--paddings);
}
.cheaderlogo svg { width: 24px; height: auto; display: block;}

.cheaderlogo{
position: absolute;
top: 50%;
left: var(--paddings);
transform: translateY(-50%);
}
.cmenutop{
position: absolute;
top: 50%;
right: var(--paddings);
transform: translateY(-50%);
}
.cmenutop .cta{
color: white;
}
.cmenutop .cta,.ctasmall{
padding: 12px;
padding-left: 20px;
    font-size: var(--fontxs);
padding-right: 20px;
}
.csectioncardpile .csectioncardpilecontent .contentxlarge{
padding: var(--paddings);
}
.csectioncardpile{
margin-bottom: var(--paddings);
}
.smini{
font-size: var(--fontxs);
}
.sgray{
color: var(--gray);
}
.csectioncardpile h3{
position: relative;
padding-top: calc(var(--paddings) / 2);
padding-bottom: calc(var(--paddings) / 2);
}
h3 .smini{
position: absolute;
top: 50%;
transform: translateY(-50%);
margin-left: 10px;
}
.smini span{
text-decoration: underline;
}
.csectioncardpile h4{
margin-bottom: 10px;
}
.csectioncardpile .col50 .cinner{
padding-right: 10vw;
}
.ctext{
line-height: 1.5;
}
.sunderline{
text-decoration: underline;
}
.csectioncardpile .col50 .cinner{
margin-bottom: var(--paddings);
margin-top: var(--paddings);
}
.csliderproject,.csuperslider{
padding-left: var(--paddingsmid);
}
.csuperslider{
padding-right: var(--paddings);
margin-top: calc(var(--paddings) * -1);
margin-bottom: calc(var(--paddings) * 2);
}
.csuperslider img{
height: 500px;
width: auto!important;
object-fit:cover;
}
.cprojectstitle .cinner{

}

.cproyectodesc{
padding-top: var(--paddingsmid);
}
.ccoltitle .cinner{
margin-top: 0px!important;
margin-bottom: 0px!important;
}
.cdobleservicio2{
margin-top: calc(var(--paddings) * 2);
}
.cbordermid{
position: absolute;
top: 0px;
left: 50%;
border-left: 1px solid black;
height: 100%;
}
.csectioncardpilecontent .row{
position: inherit;
}
.ccolservice2{
padding-left: var(--paddingsmid);
}
.contentxlarge,.csectioncardpile,.csectionform{
padding-left: var(--paddings);
padding-right: var(--paddings);
}
.csectionform .bg-gradient{
border-radius:var(--radius);
overflow: hidden;
border-bottom-left-radius: 0px;
border-bottom-right-radius: 0px;
}
.csectioncardpilecontent{
padding-left: 0px;
padding-right: 0px;
}
.cmorecode{
margin-top: 13vw;
}
.cmorecode a{
font-weight: 500;
font-size: 22px;
text-decoration: underline;
}
.csectioncode{
margin-bottom: var(--paddings);
}
.ctextform{
padding-right: 15vw;
}
.ctextcode{
max-width: 750px;
}
.cinnerform{
padding-right: calc(var(--paddings) * 1.5);
}
.clegalwrap *{
font-size: 12px;
line-height: 1.1;
}
.scheck,.scheck{
border-color:white;
background: white;
border-radius: 4px;
}
.imensaje{
aspect-ratio:100/20;
}
.ccheckboxeslegal{
margin-top: 20px;
margin-bottom: 30px;
}
footer{
background: black;
}
footer .cmarquesina{
position: relative;
}
.contentxlargefooter{
padding-top: var(--paddings);
padding-bottom: var(--paddings);
}
.cnosotrosmax{
max-width: 500px;
}
footer strong{
font-size: 22px;
}
.clegal{
text-align: right;
}
.clegal a{
margin-left: var(--paddings);
font-size: var(--fontxs);
}
.credesfooter a{
margin-right: var(--paddings);

}
.cfooterlogo svg{
display: block;
width: 100%;
height: auto;
}
.jqlogoanim{
opacity: 0;
}
.scrollingwayfinish .jqlogoanim{
opacity: 1;
}
.contentxlarge{
max-width: none;
}
.csliderprojectinner{
position: relative;
box-sizing: border-box;
}
.csliderprojectinner img{
width: 100%;
display: block;
}
footer{
height: calc(100vh - 80px);
}

.scrollbottomed .cheader{
background: black;
}
.scrollbottomed .cheaderlogo svg *{
fill:white;
}

.scrollbottomed .cheader .cta{
color:black;
background: white;
}
.scrollbottomed .cheader .cmenutop{
color: white;
}
.cmarqueeborder{
height: 2px;
}
.shs2{
display: none;
}
footer{
overflow: hidden;
}
.csectionbannerv2,.ccolb{
height: calc(100vh - 77px);
height: 100vh;
}
.ccolb{
position: relative;
width: 25%;
}
.ccolb video,.ccolb img{
width: 100%;
height: 100%;
display: block;
object-fit:cover;
}
.ctextcol h3{
margin-bottom: var(--paddings);
}
.ctextcol{
position: absolute;
top: 0px;
left: 0px;
width: 100%;
padding: var(--paddings);
padding-top: calc(var(--paddings) * 2);
box-sizing: border-box;
text-align: center;
z-index: 10;
}
.copacol {
    background: linear-gradient(
        to bottom,
        rgba(0, 0, 0, 1) 14%,
        rgba(0, 0, 0, 0) 80%
    );
    position: absolute;
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    opacity: 0.25;
}


.ccolb{
float: left;
}

.ccolb:nth-child(even) .ctextcol{
top: auto;
bottom: 0px;
}
.ccolb:nth-child(even) .copacol {
background: linear-gradient(
    to top,
    rgba(0, 0, 0, 1) 14%,
    rgba(0, 0, 0, 0) 80%
);
}
.hide{
opacity: 0;
position: absolute;
pointer-events: none;
}

.svg-gradient-mask {

  aspect-ratio: 1728 / 224;

  background: linear-gradient(var(--ang), var(--cA), var(--cB));
  background-size: 200% 200%;
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;

  mask: url(#animatedMask) no-repeat center / contain;
  -webkit-mask: url(#animatedMask) no-repeat center / contain;
}
.cleadlogo svg{
display: block;
}
.cleadlogo {
  position: absolute;
  top: 47%;
  left: 0;
  transform: translateY(-50%);
  z-index: 15;
}


.cleadlogo {
pointer-events: none;
}
.colcanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

.csectionbannerv2 h3 {
    font-size: calc(22px + 1.4vw);
    line-height: 0.95;
}
.cleadlogov2{
position: absolute;
top: 47%;
left: 0;
transform: translateY(-50%);
z-index: 15;
pointer-events: none;
}
.logo-mask {
  width: 100%;
  aspect-ratio: 1728 / 224; /* proporción REAL del logo */

  background-size: 200% 200%;
  animation:
    pair-shift 16s linear infinite,
    angle-rotate 28s linear infinite;

  -webkit-mask-image: url('img/elementos/logo-hero2.svg');
  mask-image: url('img/elementos/logo-hero2.svg');

  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;

  -webkit-mask-size: contain;
  mask-size: contain;

  -webkit-mask-position: center;
  mask-position: center;
}
.contenthero{
text-align: center;
padding-top: 5vw;
padding-bottom: 5vw;
max-width: 1300px;
margin: auto;
}
.cwraptextsections{
margin-top: -5px;
}
.cwraptextsections .col50 .cinner{
padding: calc(var(--sectionmargin) / 2) ;
background: var(--lightgray);
border-radius: var(--borderradius);

padding-top: calc(var(--sectionmargin) / 1.3) ;
padding-bottom: calc(var(--sectionmargin) / 1.3) ;
}
.cwraptextsections .csectionfull .contentxlarge{
padding: calc(var(--sectionmargin) / 2) ;
padding-top: calc(var(--sectionmargin) / 1.3) ;
padding-bottom: calc(var(--sectionmargin) / 1.3) ;
background: var(--lightgray);
border-radius: var(--borderradius);
}
.csectionfull{
margin: var(--paddings);
}
.cwraptextsections .csectionfull .contentxlarge .col50 .cinner{
padding: 0px;
padding-right:calc(var(--sectionmargin) / 2) ;
}
strong{
font-weight: 500;
}
.cwraptextsections h4{
margin-bottom: calc(var(--paddings) / 2);
max-width: 540px;
}
.cwraptextsections p{
max-width: 840px;
}
.cgaleriasection .contentxlarge{
padding: 0px;

}
.csectionbannerdefaulthide{
display: none;
}
.csectorwrap .pin-spacer{
display: none!important;
}
.jqflickgallery .cgallery video,.jqflickgallery .cgallery img{
aspect-ratio:30/54;
width: 100%;
height: auto;
display: block;
object-fit:cover;

}
.jqflickgallery .cgallery .cimgwrapinner{
overflow: hidden;
border-radius: var(--borderradius);

}
.jqflickgallery {
pointer-events: none;
}
.jqflickgallery .cimgwrap{
overflow: hidden;
box-sizing: border-box;
}
.jqflickgallery {
margin-bottom: var(--paddings);
}



.jqpanoimage img,.jqpanoimage video{
display: block;
}
.jqpanoimage .contentxlarge{
margin: var(--paddings);
margin-top: 0px;
overflow: hidden;
border-radius: var(--borderradius);
position: relative;
}
.jqpanoimage .cimgwrap:nth-child(1){

}
.jqpanoimage .cimgwrap:nth-child(1) img{
width: 100%;
object-fit:cover;
height: 80vh;
 filter: blur(10px);
 transform: scale(1.05);
}
.jqpanoimage .cimgwrap:nth-child(2){
position: absolute;
z-index: 10;
left: 50%;
transform: translateX(-48%);
bottom: 0px;
height: 65vh;
border-bottom-left-radius: 0px;
border-bottom-right-radius: 0px;
}
.jqpanoimage .cimgwrap:nth-child(2) img{
    border-radius: 3.5vw;
    border: 8px solid #000;
    width: 22vw;
    aspect-ratio: 8 / 16;
    object-fit: cover;
    box-sizing: border-box;

    box-shadow:
        0 0 0 4px #4e5a7f,      /* borde metálico interno */
        0 0 0 5px #444d6b,      /* borde metálico externo */

        /* 🔥 Sombra silueta dura (poca difuminación) */
        -25px 42px 20px rgba(0,0,0,0.55),
        /* -11px 2px 0px rgba(0,0,0,0.48) */
        -11px 2px 0px #616b8d;
        ;
}

.jqpanoimage .cimgwrap:nth-child(2)::before{
content: "";
display: block;
background: black;
height: 28px;
width: 98px;
position: absolute;
top: 25px;
left: 50%;
transform: translateX(-50%);
border-radius: 50px;
}

.cimgwrapinner{
position: relative;
}
.citemdescription{
position: absolute;
z-index: 10;
bottom: 0px;
left: 0px;
padding: 40px;
box-sizing: border-box;
width: 100%;
color: white;
}
.cimgwrapinner::before{
display: block;
content: "";
position:absolute;
top:0px;
left:0px;
height:100%;
width:100%;
background: linear-gradient(
  to top,
  rgba(0,0,0,0.7) 0%,       /* negro sólido abajo */
  rgba(0,0,0,0) 50%     /* totalmente transparente arriba */
);
}

.jqflickgallery .cgallery .slick-slide {
  margin: 0 calc(var(--paddings) / 2);; /* 10px izquierda + 10px derecha = 20px gap real */
}
.jqflickgallery .cgallery {
  padding: 0 calc(var(--paddings) / 2); /* mismo valor que cada lado del margin */
}
.jqpanoimage .citemdescription{
display: none;
}


.jqflickgallery{
pointer-events: all;
}
/*
.jqflickgallery .cgallery video,.jqflickgallery .cgallery img{
aspect-ratio:30/54;
width: 23vw;
height: auto;
display: block;
object-fit:cover;

}
.cimgwrapinner{

margin-left: var(--paddings);
} */
.cmenutop span{
cursor: pointer;
-webkit-transition:all 0.2s ease-in-out;
-moz-transition:all 0.2s ease-in-out;
-o-transition:all 0.2s ease-in-out;
transition:all 0.2s ease-in-out;


}
.cmenutop span:hover{
color:black!important;
}
.cmenutop .cta:hover{
color:white!important;
}
.scrollbottomed .cheader .cmenutop span{
color: white;
}
.cmenutop .cta:hover{
opacity: 0.7!important;
}
.scrollbottomed .cheader .cmenutop .cta{
color: black;
}
.scrollbottomed .cheader .cmenutop .cta:hover{
color: black!important;
}
.scrollbottomed .cheader .cmenutop span:hover{
color: white!important;
opacity: 0.6;
}
.cinnerform{
min-height: 40vh;
}
.ccookiepopupwrapbanner {
display: none!important;

}
