@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,100..900;1,100..900&family=Merriweather:ital,opsz,wght@0,18..144,300..900;1,18..144,300..900&display=swap");
/* Correccions generals */
body header .navbar-default .navbar-collapse .navbar-nav li a {
  text-transform: uppercase;
  font-size: 16px;
}
body header .navbar-default .navbar-collapse .navbar-nav li a:hover {
  color: #005AA7 !important;
}
body header .navbar-default .navbar-collapse .navbar-nav li.active a {
  color: #DC332A !important;
}
body header .right_nav .navbar-nav .search-dropdown {
  display: none;
}
body .main_container .breadcrumb {
  display: none;
}

.btn-custom {
  border-radius: 10px;
  background: #005AA7;
  transition: all 0.4s ease-in-out;
  color: white;
  padding: 10px 15px;
}
.btn-custom:hover {
  color: white;
  background: #DC332A;
}

.btn-success {
  background-color: #356b32;
  padding: 10px;
  border-radius: 10px;
  transition: all 0.4s ease-in-out;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
  display: block;
  width: 90px;
  text-align: center;
  margin-bottom: 15px;
  color: white !important;
}
.btn-success:hover {
  background-color: #275325;
  transition: all 0.4s ease-in-out;
  transform: translateY(-5px);
}

/* Footer general */
footer .site_footer li, footer .site_footer a, footer .site_footer h4 {
  color: white;
}
footer .site_footer .fa-fw {
  display: none;
}
footer #widget_logos-kit img {
  width: 60%;
}
@media (max-width: 768px) {
  footer #widget_logos-kit {
    display: flex;
    margin-top: 10px;
  }
  footer #widget_logos-kit img {
    width: 40%;
  }
}

/* Pàgina Contacte */
body.contact .main_container #contact_text {
  display: none;
}
@media (min-width: 768px) {
  body.contact .main_container #container-spage_contact_innerfooter {
    display: flex;
  }
}
@media (min-width: 768px) {
  body.contact .main_container #container-spage_contact_innerfooter > div {
    width: 49%;
  }
}
body.contact .main_container #container-spage_contact_innerfooter > div .form-group > div [id^=contact] {
  border-radius: 10px;
}
body.contact .main_container #container-spage_contact_innerfooter > div iframe {
  border-radius: 10px;
  width: 95%;
}

body.page-12 .form-control {
  border-radius: 10px;
}

/* Pàgina principal */
.composition-1 #container-comp1_galeria .widget {
  display: flex;
  gap: 25px;
  justify-content: center;
}
.composition-1 #container-comp1_galeria .widget img {
  width: 15%;
}
.composition-1 #container-comp1_treballem-amb .widgetsContainer_title {
  text-align: center;
  font-weight: 500;
}
.composition-1 #container-comp1_treballem-amb .widget {
  display: flex;
  justify-content: center;
}
.composition-1 #container-comp1_treballem-amb .widget img {
  width: 30%;
}
.composition-1 #container-comp1_serveis .widgetsContainer .widget img {
  width: 65% !important;
}
.composition-1 #container-comp1_serveis .widgetsContainer h3 {
  font-weight: 600;
}
@media (min-width: 769px) {
  .composition-1 #container-comp1_serveis .widgetsContainer h3 {
    font-size: 1.8vw;
  }
}
.composition-1 #carousel_8 .carousel-caption {
  font-size: 3.5vw;
  font-weight: 600;
  line-height: 1.2;
  text-shadow: 0 0 6px #222;
  top: 25%;
  left: 18%;
}

.page-8 .main_container .row #container-page8_innerfooter img {
  width: 100%;
}

/* Pàgina Serveis */
.page-11 .main_container {
  margin: 20px 0 0 0;
  padding: 0;
}
.page-11 .main_container .compositionContainer[id^=container-comp7_servicios] .widgetsContainer > div {
  padding-left: 0 !important;
  padding-right: 0 !important;
  align-content: center;
}
.page-11 .main_container .compositionContainer[id^=container-comp7_servicios] .widgetsContainer > div .widget {
  height: 100%;
  align-content: center;
}
.page-11 .main_container .compositionContainer[id^=container-comp7_servicios] .widgetsContainer > div .widget img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-11 .main_container .compositionContainer[id^=container-comp7_servicios] .widgetsContainer > div .widget > div {
  padding: 50px 15%;
}
.page-11 .main_container .compositionContainer[id^=container-comp7_servicios] .widgetsContainer > div .widget > div h3 {
  margin-top: 0;
  font-weight: bold;
}
@media (max-width: 768px) {
  .page-11 .main_container .compositionContainer[id^=container-comp7_servicios] .widgetsContainer > div {
    margin-bottom: 0;
  }
  .page-11 .main_container .compositionContainer[id^=container-comp7_servicios]:nth-child(even) .widgetsContainer > div:nth-child(2) {
    order: -1;
  }
}
.page-11 .main_container #container-comp7_marques .widgetsContainer_title {
  text-align: center;
  font-weight: 500;
}
.page-11 .main_container #container-comp7_marques .widget {
  display: flex;
  justify-content: center;
}
.page-11 .main_container #container-comp7_marques .widget img {
  width: 30%;
}

.page-8 .main_container {
  margin: 20px 0 0 0;
  padding: 0;
}

div[id^=container-comp5_construccions] .widgetsContainer > div {
  padding-left: 0 !important;
  padding-right: 0 !important;
  align-content: center;
}
div[id^=container-comp5_construccions] .widgetsContainer > div .widget {
  height: 100%;
  align-content: center;
}
div[id^=container-comp5_construccions] .widgetsContainer > div .widget img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
div[id^=container-comp5_construccions] .widgetsContainer > div .widget > div {
  padding: 50px 15%;
}
div[id^=container-comp5_construccions] .widgetsContainer > div .widget > div h3 {
  margin-top: 0;
  font-weight: bold;
}
@media (max-width: 768px) {
  div[id^=container-comp5_construccions] .widgetsContainer > div {
    margin-bottom: 0;
  }
  div[id^=container-comp5_construccions]:nth-child(even) .widgetsContainer > div:nth-child(2) {
    order: -1;
  }
}

.category_page_view, .page_view {
  /*     @media (max-width: 768px) {
          padding-top: 0px;
      } */
  /*     .carousel-outercontainer .carousel_container .carousel .carousel-inner .item { 
          @media(min-width: 768px) {
              margin-top: 100px; 
          }
          @media(max-width: 768px) {
              margin-top: 65px; 
          }
      } */
}
.category_page_view > header, .page_view > header {
  background-color: rgba(255, 255, 255, 0.95);
  position: fixed;
  z-index: 100;
}
@media (min-width: 768px) {
  .category_page_view > header, .page_view > header {
    height: 100px;
  }
}
.category_page_view > header .row, .page_view > header .row {
  max-height: 65px;
}
.category_page_view > header .row .header-left .logo, .category_page_view > header .row .header-left .inverted_logo, .page_view > header .row .header-left .logo, .page_view > header .row .header-left .inverted_logo {
  max-height: 80px;
}
.category_page_view > header .row .header-left .logo a, .category_page_view > header .row .header-left .inverted_logo a, .page_view > header .row .header-left .logo a, .page_view > header .row .header-left .inverted_logo a {
  height: 80px;
}
@media (min-width: 768px) {
  .category_page_view > header .row .header-left .logo a img, .category_page_view > header .row .header-left .inverted_logo a img, .page_view > header .row .header-left .logo a img, .page_view > header .row .header-left .inverted_logo a img {
    max-height: 80px;
  }
}
.category_page_view > header .row .header-left .logo, .page_view > header .row .header-left .logo {
  display: none;
}
.category_page_view > header .row .header-left .inverted_logo, .page_view > header .row .header-left .inverted_logo {
  display: block;
}
.category_page_view > header .row .header-right, .page_view > header .row .header-right {
  height: 85px;
}
.category_page_view > header .row .header-right .navbar .navbar-collapse .nav-horitzontal li a, .page_view > header .row .header-right .navbar .navbar-collapse .nav-horitzontal li a {
  color: #222;
}
.category_page_view > header .row .header-right .navbar-collapse .navbar-nav li a, .page_view > header .row .header-right .navbar-collapse .navbar-nav li a {
  color: #222;
}

.navbar-default .navbar-toggle .icon-bar {
  background-color: #005AA7;
}

@media (max-width: 768px) {
  body > header .header-right .navbar-right .navbar-header .navbar-toggle i {
    color: #DC332A;
  }
}
/** carousel home ***/
#carousel_1 .carousel-inner {
  overflow: visible;
}
#carousel_1 .carousel-inner img {
  max-height: calc(100vh - 60px);
}
#carousel_1 .carousel-inner .item::before {
  content: "";
  display: block;
  /*         background: linear-gradient(to bottom, black 60%, transparent 0%); */
  background: linear-gradient(rgba(0, 0, 0, 0.8), transparent);
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  height: 68%;
  z-index: 2;
}
#carousel_1 .carousel-inner .carousel-caption {
  inset: 0;
}
#carousel_1 .carousel-inner .claim-wrapper .animation-fadeInRight {
  animation-delay: 1s;
}
#carousel_1 .carousel-inner .claim-wrapper .claim {
  width: fit-content;
  margin: 0;
  padding: 50px 50px 60px 7%;
  background-color: rgba(0, 0, 0, 0.75);
  animation-delay: 0s;
  /*             &:after{
      content: "";
      width: 40px;
      height: 100%;
      right: -6%;
      bottom: 0;
      position: absolute;
      z-index: 9;
      background: linear-gradient(to right, #005AA7 50%, #E6332A 50%);
  } */
  /*             &:before{
      content: "";
      width: 45px;
      height: 45px;
      right: 6%;
      bottom: -6%;
      position: absolute;
      z-index: 9;
      background: linear-gradient(to right, #005AA7 50%, #E6332A 50%);
  } */
}
#carousel_1 .carousel-inner .claim-wrapper .claim h2 {
  margin-top: 0;
  font-weight: bold;
  margin-bottom: 0;
  font-size: 54px;
  color: #fff;
  animation-delay: 1.25s;
}
#carousel_1 .carousel-inner .claim-wrapper .claim:before {
  content: "";
  width: 114px;
  height: 84px;
  right: 0%;
  bottom: 0%;
  position: absolute;
  z-index: 9;
  background: #005AA7;
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
}
#carousel_1 .carousel-inner .claim-wrapper .claim:after {
  content: "";
  width: 57px;
  height: 42px;
  right: 0%;
  bottom: 0%;
  position: absolute;
  z-index: 9;
  background: #E6332A;
  clip-path: polygon(100% 0, 0 100%, 100% 100%);
}
@media (min-width: 769px) {
  #carousel_1 .carousel-inner .claim-wrapper {
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    bottom: unset;
    padding: 0;
    transform: translateY(-50%);
  }
}
@media (max-width: 768px) {
  #carousel_1 .carousel-inner .carousel-caption {
    top: unset;
    padding-top: 0;
    padding-bottom: 0;
  }
  #carousel_1 .carousel-inner .claim-wrapper .claim {
    width: 100%;
    border-radius: 0;
    padding-top: 10px;
    padding-bottom: 10px;
  }
  #carousel_1 .carousel-inner .claim-wrapper .claim h2 {
    font-size: 28px;
  }
}
#carousel_1 .carousel-inner:after {
  content: "";
  width: 100%;
  height: 10px;
  left: 0;
  bottom: 0;
  position: absolute;
  z-index: 9;
  background: linear-gradient(to right, #005AA7 50%, #DC332A 50%);
}

.carousel-outercontainer .carousel_container .carousel .carousel-inner:after {
  content: "";
  width: 100%;
  height: 10px;
  left: 0;
  bottom: 0;
  position: absolute;
  z-index: 9;
  background: linear-gradient(to right, #005AA7 50%, #DC332A 50%);
}

.animation-fadeIn {
  opacity: 0;
  animation: fadeIn 1.5s forwards;
}

.animation-fadeInRight {
  opacity: 0;
  animation: fadeInRight 1.5s forwards;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeInRight {
  from {
    transform: translateX(-110%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}