@font-face {
    font-family: 'garetbook';
    src: url('../fonts/garet/garet-book-webfont.woff2') format('woff2'),
         url('../fonts/garet/garet-book-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

@font-face {
    font-family: 'garetheavy';
    src: url('../fonts/garet/garet-heavy-webfont.woff2') format('woff2'),
         url('../fonts/garet/garet-heavy-webfont.woff') format('woff');
    font-weight: normal;
    font-style: normal;

}

body{
	overflow-x: hidden;
	font-family: 'Helvetica', 'Arial', sans-serif;
	border-top: 100px solid #1e98c3!important;
}

h1, h2, h3, h4, h5{
	font-family: 'garetheavy';
}

#menu a {
		color: #fff;
	}

#menu .sf-menu>li>a:hover, #menu li li a{
	color: #00a0c6!important;
}

.page-portada h1, .page-portada h2, .page-portada h3, .page-portada h4, .page-portada h5{
	font-family: 'Helvetica', 'Arial', sans-serif;
}

.portada #cos h1, .portada #cos h2, .portada #cos h3, .portada #cos h4, .portada #cos h5{
	font-family: 'Helvetica', 'Arial', sans-serif;
}

#footer-new h1, #footer-new h2, #footer-new h3, #footer-new h4, #footer-new h5{
	font-family: 'Helvetica', 'Arial', sans-serif;
}

#logo{
	/*background: red;*/
}

.header-lliures{
	height: 20vh;
	background-position: center center!important;
  background-size: 100% auto!important;
}

#menu_home{
	display: none;
}

.portada #top{
	background: #00000059;
	background: #000;
}

.portada #menu_home{
	display: block;
	position: relative;
}

.portada #menu_home .btn-menu{
	width: 60px;
}

.portada #menu_home .btn-menu .menu-off{
	display: none;
	margin-right: -1px;
}

.portada #menu_home .menu-vert{
	display: none;
	position: absolute;
	top: 79px;
	right: 0px;
	width: 300px;
}

.portada .collapsed #menu_home .menu-vert{
	top: 64px;
}

.portada #menu_home .menu-vert ul{
	list-style-type: none;
	background: #1e98c3;
	padding: 20px;
}

.portada #menu_home .menu-vert ul li{
	
}

.portada #menu_home .menu-vert ul li a{
	color: #000;
  font-size: 35px;
  font-weight: 600;
}

.portada #menu{
	display: none;
}

.portada #cos{
	overflow: unset;
	padding-bottom: 0px;
  margin-bottom: 0px;
}

.portada #top #logo{
	bottom: -148px;
	left: 200px;
}

.portada #top #logo .logo-head{
	height: 350px;
	margin-left: -85px;
}

.portada #top #logo .franges-head{
	height: 45px;
	position: absolute;
    top: 102px;
    left: -195px;

}

.portada{

}

.page-portada{
	margin-top: -100px;
}

h2.titol {
	font-size: 40px;
}

h2.titol-destacat{
	margin-top: 40px;
	font-size: 40px;
}

#contingut .bg-light.py-4.wow.fadeInUp.animated{
	padding-bottom: 60px!important;
}


.cont-sli{
	position: absolute;
	display: block;
	left: 0px;
	top: 14vh;
	width: 100%;
}

.slider {
  width: 100%;
  height: 85vh;
  overflow: hidden;
  position: relative;
}

.slide {
  width: 100%;
  height: 100vh;
  background-size: cover;
  background-position: center;
  position: absolute;
  top: 0;
  left: 0;
  /*display: none;*/
}

.slide .back-sli{
  width: 100%;
  height: 100vh;
  background-size: cover;
  background-position: center center;
  position: absolute;
  top: 0;
  left: 0;
  /*display: none;*/
  filter:brightness(0.4);
  background-color: rgba(0,0,0,0.8);
}

.slide.active {
	/*display: block;*/
}

.slide-content {
	/*
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-10%, -10%);
  color: white;
  text-align: center;
  */
  margin-top: 45vh;
}

.slide-content h1 {
  font-size: 3em;
  color: #d5dfdd;
}

.slide-content p {
  font-size: 1.5em;
  color: #d8e5e3;
}

.slide .container{
	position: static;
}

.slide .container .row{
	text-align: left;
}

.slide {
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
}

.slide.active {
  opacity: 1;
}

.prev{
	position: absolute;
	bottom: 50%;
	left: 15px;
	font-size: 20px;
	color: yellow;
}

.next{
	position: absolute;
	bottom: 50%;
	right: 40px;
	font-size: 20px;
	color: yellow;
}

.cont-contacta{
	padding-top: 10vh;
	padding-bottom: 10vh;
}

.destacats .card{
	margin-top: 60px;
}

.destacats svg{
	width: 90px;
	height: auto;
}

.btn-estil1{
	padding: 20px 80px;
	border: 1px solid #d5dfdd;
	text-align: center;
	color: #d5dfdd;
	/*text-transform: uppercase;*/
	font-size: 22px;
	font-weight: 100;
	text-decoration: none;
}

.btn-estil1:hover{
	background-color: #d5dfdd;
	color: #1e98c3;
	text-decoration: none;
}

h2.titol-destacat{
	color: #1e98c3;
	font-weight: 600;
	margin-bottom: 40px;
}

.projectes-home{
	background-color: #222831;
	margin-top: -20px;
	padding-top: 0px;
	padding-bottom: 60px;
}

.projectes-home h4{
	color: #dbe5e3;
	font-weight: 600;
	margin-bottom: 40px;
	padding-top: 70px;
	padding-bottom: 50px;
	font-size: 40px;
}

.owl-carousel .owl-item img{
	margin-right: 20px;
	margin-left: 20px;
	padding-right: 40px;
	padding-left: 0px;
}

.owl-carousel .owl-item h4{
	font-size: 18px;
	color: #fff;
	display: block;
	width: 100%;
	margin-top: 0px;
	margin-bottom: 0px;
	padding-top: 20px;
	padding-bottom: 20px;
}

.owl-carousel .owl-item h4.groc{
	color: #dbe5e3;
}

.owl-carousel .owl-item h5{
	font-size: 14px;
	color: #fff;
	display: block;
	width: 100%;
	margin-top: 10px;
	margin-bottom: 10px;
}

.owl-carousel .owl-item h5.groc{
	color: #1e98c3;
}

#projectes .item{
	display: inline-block;
}

.owl-carousel .owl-item .text-proj{
	display: block;
	width: 100%;
	margin-right: 20px;
  margin-left: 20px;
  padding-right: 20px;
  padding-left: 20px;
}

#fletxa_moviment.fletxa_moviment_esq{
	margin-left: 10px;
	animation: MoveUpDown 4s linear infinite;
}

#fletxa_moviment.fletxa_moviment_esq img{
    transform: rotate(90deg);
    left: 10px;
}

#fletxa_moviment.fletxa_moviment_dre{
	margin-right: 10px;
	animation: MoveUpDown 4s linear infinite;
}

#fletxa_moviment.fletxa_moviment_dre img{
    transform: rotate(270deg);
    right: 10px;
}

.pressupost h4{
	  color: #1e98c3;
    font-weight: 600;
    margin-bottom: 40px;
    padding-top: 80px;
    padding-bottom: 60px;
    text-align: center;
    font-size: 40px;
}

.pressupost p{
	text-align: center;
	font-size: 20px;
}

.pressupost a{
	margin-top: 40px;
	display: block;
	width: fit-content;
	margin: 0 auto;
	margin-top: 80px;
	margin-bottom: 120px;
	border: 1px solid #1e98c3;
	color: #1e98c3;
}

.pressupost a:hover{
	border: 1px solid #fff;
	background-color: #1e98c3;
	color: #fff;
}

.diferencia{
	/*position: relative;*/
}

.diferencia .container{
	/*
	position: absolute;
	left: 0px;
	top: 0px;
	*/
}

.diferencia img{
	  width: 100%;
    height: 40px;
    background: #fff;
    z-index: 9;
    display: block;
    position: absolute;
}

.diferencia h4 {
    color: #ffffff;
    font-weight: 600;
    margin-bottom: 40px;
    padding-top: 200px;
    padding-bottom: 100px;
    text-align: center;
    font-size: 40px;
}

.diferencia h5{
	color: #dbe5e3;
	font-weight: bold;
	font-size: 85px;
	text-align: center;
	margin-bottom: 20px;
}

.diferencia p{
	color: #dbe5e3;
	font-weight: bold;
	font-size: 22px;
	line-height: 26px;
	text-align: center;
	padding-bottom: 200px;
}

#opinions{
	background-color: #1e98c3;
	margin-top: -24px;
}

.owl-carousel .owl-item img.linia-opi{
	width: calc(100% + 80px);
	margin-top: 20px;
	margin-right: 0px;
    margin-left: -60px;
    padding-right: 0px;
    padding-left: 0px;
}

.linkedin{
	background-color: grey;
}

.linkedin iframe{
	width: 100%!important;
}

.linkedin-foot iframe{
	width: 100%!important;
}

.container-left{
	padding-left: 20vw;
}

#footer-new{
	background-color:#222831;
}

#footer-new .logo-petit{
	text-align: left;
	margin-left: -4vw;
}

#footer-new h3{
	color: #dbe5e3;
	margin-bottom: 10px;
}

#footer-new h5{
	color: #fff;
	margin-bottom: 10px;
}

#footer-new h5.groc{
	color: #dbe5e3;
}

#footer-new p{
	color: #fff;
	margin-bottom: 30px;
}

#footer-new .xarxes{
	display: block;
}

#footer-new .xarxes a{
	display: inline-block;
	height: 40px;
	width: 40px;
}

#footer-new .xarxes a img{
	width: 100%;
	height: auto;
}	

#footer-new .linies{
	height: 60px;
}

.footer-mapa{
	border:0; 
	width: 100%; 
	height: 520px;
}

.sota-foot{
	vertical-align: middle;
	color: #b1baba;
	font-size: 20px;
	margin-top: 10px;
}

.sota-foot a{ 
	color: #b1baba;
	font-size: 20px;
	vertical-align: middle;
	font-weight: 400;
	font-size: 18px;
}

#top #logo .logosol{
	height: 200px;
	margin-left: -2vw;
}

#opinions{
	padding-bottom: 80px;
}

#opinions h4 {
  color: #222831;
  font-weight: 600;
  margin-bottom: 40px;
  padding-top: 60px;
  padding-bottom: 60px;
  text-align: center;
  font-size: 40px;
}

#opinions .item{
	border-top: 4px solid #fff;
	/*border-bottom: 4px solid #fff;*/
	margin-left: 10px;
	margin-right: 10px;
}

#opinions .item h4{
	color: #222831;
	font-size: 18px;
	font-weight: 400;
}

#opinions .item h5{
	color: #fff;
	font-size: 18px;
	font-weight: 400;
}

.linkedin{
	background-color: #e3e7ea;
	padding-bottom: 160px;
}

.linkedin h4{
  color: #1e98c3;
  font-weight: 600;
  margin-bottom: 40px;
  padding-top: 80px;
  padding-bottom: 50px;
  text-align: center;
  font-size: 40px;
}

.linkedin-foot{
	background-color: #fff;
	padding-bottom: 80px;
}

.linkedin-foot h4{
	color: #1e98c3;
  font-weight: 600;
  margin-bottom: 40px;
  padding-top: 80px;
  padding-bottom: 10px;
  text-align: left;
}

.quisom{

}

.quisom .grid-item.col-md-9{

}

.quisom .grid-item.col-md-9 p{
	margin-bottom: 15px;
}

.quisom .grid-item.col-md-3 div{
	background-color: #6ec8de;
  padding-top: 40px;
  padding-bottom: 40px;
  padding-left: 28px;
  padding-right: 28px;
}

.quisom .grid-item.col-md-3 p{
	background-color: #6ec8de;
	font-size: 22px;
	font-weight: 600;
}

.quisom2{

}

.jumbotron h1{
	text-align: left;
}

#top .container .align-left.d-flex.align-items-center{
	/*overflow: hidden;
	height: 100px;
	*/
}

.serveis{
	
}

.serveis p, .serveis ul, .serveis ul li{
	font-size: 16px;
}

#cos .serveis ul{
	margin-top: 20px;
	margin-left: 35px;
}

.serveis .serv-cont{
	border-left: 8px solid #373636;
	padding-left: 20px;
	margin-top: 40px;
	margin-bottom: 40px;
}

.serveis img{
	width: 40%;
	height: auto;
	/*margin-top: 60px;*/
}

.serveis .serv-tabl{
	display: table;
}

.serveis .serv-tabl .text-center{
	display: table-cell;
  vertical-align: middle;
}

.serveis .fonsgris{
	padding-top: 60px;
	padding-bottom: 60px;
	background-color: #e5f2f8;
}

.serveis .fonsblanc{
	padding-top: 60px;
	padding-bottom: 60px;
	background-color: #fff;
}

.destacats .card .btn-primary{
	background-color: transparent;
	border: 1px solid transparent;
}

.destacats .card .btn-primary:hover{
	background-color: #1e98c3;
    border-color: #1e98c3;
}

.div-capa{
	position: relative;
}

.capa-fosca {
    position: absolute;
    top: 0;
    left: 15px;
    width: 100%;
    height: calc(100% - 5px);
    background-color: rgba(0, 0, 0, 0.5); /* Ajusta la opacidad según sea necesario */
    z-index: 999; /* Asegura que la capa oscura esté encima del contenido */
}

.jumbotron{
	padding: 40px 0;
	padding-top: 50px;
}

#cos{
	padding-bottom: 40px;
	margin-bottom: 40px;
}

.clients #lliures h4{
	text-align: left;
	font-size: 34px;
    font-weight: 500;
    font-style: normal;
    margin-top: 120px;

}

.poductes-cli{
	border-top: 10px solid #00a0c6;
}

.poductes-cli h4.titol{
	text-align: left;
	margin-top: 60px;
	margin-bottom: 60px;
}

.nomespc{
	display: block;
}

.nomesmbl{
	display: none;
}

.diferencia2 {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100vh;
}

.parallax2 {
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

.parallax-container {
  position: relative;
  height: 100vh;
  overflow: hidden;
}

.parallax {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-attachment: fixed;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.parallax.parallax3 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-attachment: fixed!important;
  background-repeat: no-repeat!important;
  background-position: center center !important;
  background-size: 100% auto !important;
}

.container {
  position: relative;
  z-index: 1;
  
}

/* Additional styles for text content */
.container h1 {
  font-size: 3em;
  padding-top: 40px;
  padding-bottom: 20px;
}

.container p {
  font-size: 1.2em;
}

.quisom2{
	display: block;
}

.quisom2-mbl{
	display: none;
}

.quisom3{
	display: block;
}

.quisom3-mbl{
	display: none;
}

.btn-primary {
    color: #fff;
    background-color: #1c99c3;
    border-color: #1c99c3;
}

.mailchimp {
    background-color: #fff;
    padding-bottom: 160px;
}

.mailchimp h4 {
    color: #000;
    font-weight: 600;
    margin-bottom: 40px;
    padding-top: 80px;
    padding-bottom: 50px;
    text-align: center;
    font-size: 40px;
}

.mailchimp #mc_embed_shell{
	margin: 0 auto;
}

.mailchimp #mc_embed_shell input{
    background: #edecea;
    border-radius: 0;
    border: none;
}

.mailchimp #mc_embed_shell #mc-embedded-subscribe{
		background-color: #000;
}


@media only screen and (max-width: 992px) {

}

@media only screen and (max-width: 767px) {

	html{
		overflow-x: hidden!important;
		width: 100vw;
		max-width: 100vw;
	}

	body{
		padding-top: 0px;
		overflow-x: hidden!important;
		width: 100vw;
		max-width: 100vw;
		border-top: 100px solid #1e98c3!important;
	}

	#cos{
		overflow-x: hidden!important;
		width: 100vw;
		max-width: 100vw;
	}

	#menu a {
		color: #fff;
	}

	.nomespc{
		display: none;
	}

	.nomesmbl{
		display: block;
	}

	.box_menu, #menu .box_menu{
		background-image: unset!important;
	}

	.slide-content{
		margin-top: 32vh;
		padding-left: 10px;
	}

	.btn-estil1{
		padding: 20px 12px;
	}

	.portada #menu_home .btn-menu{
		float: right;
	}

	#mobnav-btn{
		padding-top: 30px;
		padding-right: 35px;
	}

	.lliure #cos{
		padding-top: 80px;
	}

	.serveis img{
		margin-bottom: 90px;
	}

	#footer-new .container-left{
		padding-left: 0vw;
	}

	#footer-new{
		text-align: center;
	}

	#footer-new .logofooter{
		width: 49.8%!important;
		display: inline-block;
	}

	#footer-new .xarxes{
		margin-bottom: 40px;
	}

	.quisom2{
		display: none;
	}

	.quisom2-mbl{
		display: block;
	}

	.quisom3{
		display: none;
	}

	.quisom3-mbl{
		display: block;
	}

	.quisom3-mbl img{
		width: 90%;
	}

	.parallax-container{
		height: 270vh;
	}

	.btn-estil1{
		display: block;
		width: 100%;
	}

	.portada #top #logo {
    bottom: -202px;
    left: -20px;
    width: 200px;
    display: flex!important;
	}

	.portada #top #logo .logo-head{
		margin-left: 0px;
		padding-top: 20px;
	}

	.portada #menu_home .btn-menu{
		width: 45px;
		padding-top: 16px;
		padding-bottom: 16px;
	}

	#logo_small{
		width: 200px!important;
	}

	#logo_small img {
    width: 200px !important;
    height: auto !important;
    max-height: unset !important;
    position: absolute;
    left: -20px;
    top: -40px;
	}

	#menu{
		height: 80px;
		overflow: visible;
		background: #6ec8de;
	}

	.sf-menu{
		background-color: #fff;
	}

}
