/* latin-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/roboto/v29/KFOlCnqEu92Fr1MmSU5fChc4EsA.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/roboto/v29/KFOlCnqEu92Fr1MmSU5fBBc4.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/roboto/v29/KFOmCnqEu92Fr1Mu7GxKOzY.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/roboto/v29/KFOmCnqEu92Fr1Mu4mxK.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/rubik/v19/iJWZBXyIfDnIV5PNhY1KTN7Z-Yh-4I-FWUU1Z4Y.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Rubik';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/rubik/v19/iJWZBXyIfDnIV5PNhY1KTN7Z-Yh-4I-FV0U1.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wdhyzbi.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 300;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wlhyw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wdhyzbi.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wlhyw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wdhyzbi.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wlhyw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wdhyzbi.woff2) format('woff2');
  unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  src: url(https://fonts.gstatic.com/s/montserrat/v23/JTUSjIg1_i6t8kCHKm459Wlhyw.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

.col {
  box-sizing: border-box;
  flex: 0 0 auto;
  /*padding-right: 0.5rem;
  padding-left: 0.5rem;*/
  padding-right: 0;
  padding-left: 0;
  flex-basis: 100%;
  max-width: 100%;
}
.row {
  box-sizing: border-box;
  display: flex;
  flex: 0 1 auto;
  flex-direction: row;
  flex-wrap: wrap;
}
.visible_mobile {
  display: none !important;
}
h3 {
  font-size: 1.666rem;
}
small {
  font-size: 0.8em;
  color: grey;
}
body {
  font-size: 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100vh;
  color: #212121;
  font-family: "Montserrat", Arial, sans-serif;
  font-weight: 300;
  line-height: 1.6;
}
@media (max-width: 49.99em) {
  body {
      font-size: 1.25rem;
  }
}
@media (max-width: 25em) {
  body {
      font-size: 1.1rem;
  }
}
strong {
  font-weight: 600;
}
a {
  transition: color 0.2s ease-out;
  text-decoration: none;
}
a img {
  border: 0;
}
a:hover {
  color: #000000;
}
img {
  display: inline-block;
  max-width: 100%;
  vertical-align: middle;
}
ul,
ol {
  margin-bottom: 2rem;
}
ul li,
ol li {
  margin-left: 1.25em;
}
ul li {
  list-style-type: disc;
}
.show {
  transition: opacity 600ms;
}
.hide {
  opacity: 0;
}
.modal {
  display: flex;
  visibility: hidden;
  position: fixed;
  z-index: -1000;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  overflow-x: hidden;
  transition: opacity 0.1s ease-out;
  background-color: rgba(33, 33, 33, 0.75);
}
.modal.active {
  visibility: visible;
  z-index: 1000;
}
.modal a:hover {
  color: #82243a;
}
.modal-box {
  position: relative;
  width: 80%;
  max-width: 1000px;
  max-height: 85vh;
  margin: auto;
  border-radius: 9px;
  background-color: #f7f7f7;
  box-shadow: 0 0 50px 0 #212121;
}
.modal-container {
  overflow: hidden;
  border-radius: 7px;
}
.modal-header {
  height: 20vh;
  border-radius: 7px;
}
.modal-header-img-container {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 40px;
}
.modal-header-img-container img {
  max-height: 100%;
}
.modal-content {
  max-height: calc(80vh - 20vh);
  padding: 30px;
  overflow-y: auto;
}
img.lazyload:not([src]) {
  visibility: hidden;
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  color: inherit;
  vertical-align: baseline;
}
*::before,
*::after {
  box-sizing: border-box;
}
html {
  box-sizing: inherit;
  overflow-x: hidden;
  scroll-behavior: smooth;
}
footer .icon {
  margin-top: 1em;
  margin-bottom: 1em;
  font-size: 2em;
}
footer a > .icon {
  color: #fff;
}
nav {
  z-index: 100;
  top: 0;
  width: 100%;
  background-color: #fff;
  text-align: center;
  justify-content: space-around;
  /*max-width: 1366px;*/
  margin-left: auto;
  margin-right: auto;
}
nav div.logo {
  width: 40%;
  display: flex;
  padding-left: 4%;
}
nav div.logo a {
  width: 100%;
}
nav div.guixols_logo {
  width: 100%;
  display: block;
  float: left;
  margin-left: auto;
  margin-right: auto;
  padding-top: 0.9%;
  padding-bottom: 0.9%;
  background-color: #ffffff;
}

/* Scrolling */
nav.has_scrolled div.logo img {
  filter: brightness(0) invert(1);
}
nav.has_scrolled div.guixols_logo {
  display: none;
}
nav.has_scrolled {
  color: #ffffff;
  background: rgba(0, 0, 0, 0.5);
}
nav.has_scrolled .max_width_menu {
  padding-top: 0.5%;
  padding-bottom: 0.5%;
}

nav div.guixols_logo img {
  max-width: 140px;
}
nav div.menu_wrapper {
  width: 60%;
  font-size: 1.4em;
}
nav .menu_wrapper {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-content: center;
  flex-wrap: wrap;
}
nav span.category_menu {
  margin: 0;
  /*font-family: "Montserrat-Regular", Arial, sans-serif;*/
  font-weight: 700;
  /*letter-spacing: 2px;*/
  text-transform: inherit;
  font-size: 14px;
  padding-top: 5px;
  padding-bottom: 9px;
}
nav span.category_menu:hover {
  text-decoration: underline;
  color: #ffffff;
}
nav .sub-item-level span.category_menu {
  margin: 0;
  text-transform: inherit;
  font-size: 12px;
  padding-top: 1px;
  padding-bottom: 1px;
  /*margin-left: 7%;*/
  font-weight: 300;
  margin-bottom: .5em;
  display: block;
}
nav div.logo img {
  display: inline-block;
  max-width: 10em;
  max-height: 2.5em;
  vertical-align: middle;
  padding: 1%;
}
nav .nav-toggle {
  visibility: hidden;
}
nav .nav-toggle a {
  display: none;
}
nav .nav-item {
  line-height: 1;
  padding-bottom: 2%;
}
nav .nav-item a:hover {
  color: #ffffff;
}
.nav-item.sub-item-level {
  line-height: 12px;
  padding-bottom: 0;
}
nav .nav-item-active a {
  color: #000000;
}
.nav-shadow {
  box-shadow: 0 3px 4px rgba(0, 0, 0, 0.2);
}
.nav-fixed {
  position: fixed;
  top: 0;
  bottom: auto;
  z-index: 9999;
  transition: 0.8s ease-out;
  background-color: transparent;
}
.nav-full {
  position: fixed;
  top: 0;
  right: -100vw;
  bottom: 0;
  width: 100vw;
  height: 100%;
  transform: translate(0, 0);
  transition: 0.3s ease-out;
  background-color: #212121;
  z-index: 998;
}
.nav-full a,
.nav-full .icon {
  color: #fff;
}
.nav-full a:hover,
.nav-full .icon:hover {
  color: #000000;
}
.nav-full.active {
  transform: translate(-100vw, 0);
}
main {
  transition: 0.3s ease-in;
  background-color: #ffffff;
}
main.active {
  transform: translate(-100vw, 0);
}
.container {
  max-width: 43.75rem;
  margin: auto;
  padding: 8rem 0 8rem;
}
p {
  margin-bottom: 0.5rem;
}
h1,
h2,
h3 {
  /*font-family: "Montserrat-Bold", Georgia, serif;*/
  /*letter-spacing: 1.2px;*/
  letter-spacing: 0.2px;
  line-height: 1.2;
  font-weight: 700;
  /*text-transform: uppercase;*/
}
h1 a,
h2 a,
h3 a {
  text-decoration: none;
}
a > .icon {
  color: #212121;
  transition: color 0.2s ease-out;
}
a > .icon:not(.icon-menu):hover,
a > .icon:not(.icon-menu):focus {
  color: #82243a;
}
.contact form {
  margin-top: 2rem;
}
.contact .contact-submit {
  position: relative;
}
.contact #form-submit {
  display: block;
  width: 50%;
  margin: 0 auto;
}
.contact #form-thankyou,
.contact #form-sending,
.contact #form-error {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
input,
textarea,
button,
select {
  width: 100%;
  margin: 8px 0;
  padding: 10px;
  border-width: 1px;
  border-style: solid;
  border-radius: 3px;
  border-color: #014265;
  background-color: #fff;
  color: #212121;
}
input[type="submit"],
textarea[type="submit"],
button[type="submit"],
select[type="submit"] {
  transition: 0.4s ease-out;
  background-color: #014265;
  color: #fff !important;
}
input[type="submit"]:hover,
textarea[type="submit"]:hover,
button[type="submit"]:hover,
select[type="submit"]:hover {
  background-color: #212121;
  color: #fff;
  cursor: pointer;
}
input .icon,
textarea .icon,
button .icon,
select .icon {
  color: #fff;
}
button {
  white-space: nowrap;
}
textarea {
  min-height: 8rem;
  overflow: auto;
}
.icon {
  font: normal normal normal 14px/1 icons;
  display: inline-block;
  font-size: inherit;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-menu:before {
  content: "\f0c9";
  font-size: 28px;
}
a.nav-icon {
  width: inherit;
  margin-top: 8px;
}



/* FLEX PROPERTIES */
.flex_center {
  display: flex;
  justify-content: center;
  flex-direction: row;
  align-content: center;
  flex-wrap: wrap;
}
.flex_start {
  display: flex;
  justify-content: flex-start;
  flex-direction: row;
  align-content: center;
  flex-wrap: wrap;
}
.flex_left_wrap {
  display: flex;
  align-content: center;
  flex-wrap: wrap;
}
.flex_center_wrap {
  display: flex;
  align-content: center;
  flex-wrap: wrap;
  justify-content: center;
}
.flex_row {
  display: flex;
  flex-direction: row;
}
.flex_end {
  display: flex;
  justify-content: flex-end;
  align-content: flex-end;
  flex-wrap: wrap;
  flex-direction: row;
}

/* GRADIENTS PROPERTIES & BACKGROUNDS */
.gradient_background {
  background: rgb(176,11,0);
  background: -moz-linear-gradient(90deg, rgba(176,11,0,1) 0%, rgba(201,90,0,1) 20%, rgba(236,212,2,1) 36%, rgba(122,207,59,1) 50%, rgba(36,128,215,1) 70%, rgba(193,11,123,1) 100%);
  background: -webkit-linear-gradient(90deg, rgba(176,11,0,1) 0%, rgba(201,90,0,1) 20%, rgba(236,212,2,1) 36%, rgba(122,207,59,1) 50%, rgba(36,128,215,1) 70%, rgba(193,11,123,1) 100%);
  background: linear-gradient(90deg, rgba(176,11,0,1) 0%, rgba(201,90,0,1) 20%, rgba(236,212,2,1) 36%, rgba(122,207,59,1) 50%, rgba(36,128,215,1) 70%, rgba(193,11,123,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#b00b00",endColorstr="#c10b7b",GradientType=1);
}
.gradient_background_revert {
  background: rgb(176,11,0);
  background: -moz-linear-gradient(-90deg, rgba(176,11,0,1) 0%, rgba(201,90,0,1) 20%, rgba(236,212,2,1) 36%, rgba(122,207,59,1) 50%, rgba(36,128,215,1) 70%, rgba(193,11,123,1) 100%);
  background: -webkit-linear-gradient(-90deg, rgba(176,11,0,1) 0%, rgba(201,90,0,1) 20%, rgba(236,212,2,1) 36%, rgba(122,207,59,1) 50%, rgba(36,128,215,1) 70%, rgba(193,11,123,1) 100%);
  background: linear-gradient(-90deg, rgba(176,11,0,1) 0%, rgba(201,90,0,1) 20%, rgba(236,212,2,1) 36%, rgba(122,207,59,1) 50%, rgba(36,128,215,1) 70%, rgba(193,11,123,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#b00b00",endColorstr="#c10b7b",GradientType=1);
}
.gray_gradient_background {
  background: rgb(249,249,249);
  background: -moz-linear-gradient(54deg, rgba(249,249,249,1) 0%, rgba(239,239,239,1) 100%);
  background: -webkit-linear-gradient(54deg, rgba(249,249,249,1) 0%, rgba(239,239,239,1) 100%);
  background: linear-gradient(54deg, rgba(249,249,249,1) 0%, rgba(239,239,239,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#f9f9f9",endColorstr="#efefef",GradientType=1);
}
.gradient_line {
  height: 20px;
}
.gray_background {
  background-color: #efefef;
}

/* PADDINGS PROPERTIES */
/*.padding_5_desktop > div {
  margin-top: 5%;
  margin-bottom: 5%;
}*/
.padding_1_desktop  {
  padding-top: 8%;
  padding-bottom: 5%;
  float: left;
}

/* WIDTH PROPERTIES */
.width_30_desktop {
  width: 30%;
  float: left;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.width_70_desktop {
  width: 70%;
  float: left;
  line-height: 1.6rem;
}


/* ITEMS */
.info_item {
  border: 2px solid #ffffff;
  /*margin: 5%;*/
  padding: 5%;
  text-align: left;
  float: left;
}
.info_item a {
  /*float: left;
  width: 100%;*/
}
.info_item h3 {
  font-size: 1.4rem;
}
.info_item:nth-child(2) h3 {
  font-size: 1.2rem;
}
#inaugural .width_30_desktop  .info_item .padding_1_desktop,
#la-ciutat-del-color .width_30_desktop  .info_item .padding_1_desktop {
  padding-top: 4%;
  padding-bottom: 5%;
  float: left;
}
#inaugural .width_30_desktop .info_item a {
  width: fit-content;
  margin-right: 5%;
  min-width: 30px;
}
.width_30_desktop .info_item > div {
  width: 100%;
}
.width_30_desktop .info_item {
  /*padding-bottom: 16%;*/
  margin-right: 8%;
  height: 48%;
  font-size: 1.2rem;
}
section.section_llum_artista .width_70_desktop,
section.section_llum_artista .width_30_desktop {
  z-index: 2;
}
.width_70_desktop .info_item {
  padding: 4%;
  /*min-height: 454px;
  max-height: 454px;*/
  min-height: 590px;
  max-height: 590px;
  height: 100%;
  overflow-y: scroll;
}
.width_70_desktop * {
  scrollbar-width: auto;
  scrollbar-color: #bababa transparent;
}
.width_70_desktop *::-webkit-scrollbar {
  width: 22px; /* 10 */
}

.width_70_desktop *::-webkit-scrollbar-track {
  background: transparent;
}

.width_70_desktop *::-webkit-scrollbar-thumb {
  /*background-color: #bababa;
  border-radius: 10px;
  border: 2px solid transparent;*/
  background-color: #ffffff;
  border: 2px solid #014265;
  border-right: 10px solid #014265;
  margin-top: 2%;
}
}
.width_70_desktop .info_item::after {
  background-image: url(./img/icons/camera.png);
}

/* HEADER TEXTS */
div.header_title h2 {
  text-align: center;
}
div.header_text {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  font-size: 24px;
  text-transform: uppercase;
  color: white;
  width: 96%;
  text-align: center;
  background-color: rgba(0,0,0,0.7);
  padding-top: 2%;
  padding-bottom: 2%;
  padding-left: 18%;
  line-height: 26px;
  padding-right: 18%;
}


/* SECTIONS */
section {
  width: 100%;
}
.wrapper_maxwidth {
  /*max-width: 1366px;*/
  max-width: 1028px;
  margin-left: auto;
  margin-right: auto;
}
/*section.presentacion_gama {
  color: #ffffff;
}
section.presentacion_gama h2 {
  width: 42%;
  padding-bottom: 2%;
  color: #ffffff;
}*/
section.section_presentacio {
  height: 100vh;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  text-align: center;
  color: #014265;
}
section.section_presentacio .wrapper_maxwidth {
  max-width: 640px;
}
section.section_presentacio h3 {
  margin-bottom: 7%;
  /*font-family: 'Montserrat-Black';*/
  font-weight: 900;
}
section.contacto {
  /*background-color: #014265;*/
  color: #014265;
  padding-top: 5%;
  padding-bottom: 5%;
}
section.contacto .flex_left_wrap {
  padding-left: 10%;
  padding-top: 7.28%;
}

section.contacto h3 {
  font-weight: 900;
  color: #014265;
}

section.section_presentacio p {
  margin-bottom: 4%;
}
section.background_image {
  height: 100vh;
  background-size: cover;
  background-position: center center;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  filter: grayscale(100%);
  transition: filter 0.5s ease;
}
@media screen and (max-width: 768px) {
  section.background_image {
    filter: grayscale(0%);
  }
}

section.background_image::before {
  content: '';
  display: block;
  position: absolute;
  background-color: #000;
  opacity: 0.5;
  width: 100%;
  height: 100%;
  transition: background-color 0.5s ease;
}
section.view_artist {
  filter: grayscale(0%);
}
section.view_artist.background_image::before {
  background-color: transparent;
}
section.background_image > div {
  position: absolute;
}
@media (max-width: 768px) {
  section.background_image > div {
  position: initial;
  padding-top:50px;
  padding-bottom:50px;
}
}
section.empresa p, section.contacto p {
  font-size: 1rem;
  line-height: 1.8rem;
  color: #898989;
  padding-top: 2%;
}
.white {
  color:#FFF;
}
.e-cover {
  object-fit: cover;
}
.e-btn {
  border:2px solid #FFF;
}
.e-btn:hover {
  background-color:#FFF;
}
.e-btn span {
  display: block;
  padding:10px 16px;
  font-size: .85em;
}
.e-container {
  max-width:1280px;
  margin:0 auto;
  padding-right:1.5em;
  padding-left :1.5em;
}
.bg-black {
  background-color:#000;
}
.e-relative {
  position: relative;
}
.e-flex-wrap {
  flex-wrap: wrap;
}

.vh-100 {
  height:100vh;
}
.w-100 {
  width:100%;
}
.z-10 {
  z-index: 10;
}
.db {
  display: block;
}
.dn {
  display: none;
}
.m1 {
  margin-bottom:.2em;
}
.m2 {
  margin-bottom:.4em;
}
.dim {
  opacity: 1;
  transition: opacity .15s ease-in;
}
.dim:hover,
.dim:focus {
  opacity: .5;
  transition: opacity .15s ease-in;
}
.dim:active {
  opacity: .8; transition: opacity .15s ease-out;
}
@media (min-width: 768px){
  .db-ns {
    display: block;
  }
  .dn-ns {
    display: none;
  }
}
.clip {
  position: fixed !important;
  _position: absolute !important;
  clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
}
@media (min-width: 768px){
.js-extra-info {
  display: none;
}
}
@media (min-width: 768px){
.view_artist > .js-extra-info {
  display: block !important;
 }
}
.c-extra-info {
  border:1px solid #fff;
  max-width:300px;
  padding:30px;
  position: relative;
  margin:1.5em 1.5em;
  margin-left:auto;
  background: rgba(0, 0, 0, 0.5);
}
.c-extra-info .close {
  transform: scale(1.2) translateY(-10px);
}
.c-extra-info h3 {
  margin-bottom:.6em;
  font-size: 1.5em;
}
.c-extra-info__item {
  overflow: hidden;
}

.c-grid-projects {
  width:100%;
  right:0;
  left:0;
  margin:2em auto;
  position: relative

}
.c-grid-projects__play-video {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 48px;
  color: white;
  opacity: .8;
}
@media (max-width: 600px) {
  .c-grid-projects__play-video {
  font-size: 30px;
}
}
.c-grid-projects__link img {
  box-sizing: border-box;
  border:2px solid #000;
}
.c-grid-projects__link {

}
.c-grid-projects__link:hover img {
  border:2px solid #FFF;
}
body.is-active .c-grid-projects {
  display: block;
}

.c-grid-projects__column {
  width:100%;
}
.c-grid-projects__article {
  width:calc( 33.33% - 16px);
  margin-right:12px;
  margin-left :12px;
  position:relative;
  display: inline-block;
}
@media (max-width: 600px){
  .c-grid-projects__article {
    width:calc( 50% - 15px);
  }
}
[style*="--aspect-ratio"] > :first-child {
  width: 100%;
}
[style*="--aspect-ratio"] > img {
  height: auto;
}
@supports (--custom:property) {
  [style*="--aspect-ratio"] {
    position: relative;
  }
  [style*="--aspect-ratio"]::before {
    content: "";
    display: block;
    padding-bottom: calc(100% / (var(--aspect-ratio)));
  }
  [style*="--aspect-ratio"] > :first-child {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
  }
}

.flickity-prev-next-button {
  opacity: 1;
  border-radius: 0;

}
.flickity-prev-next-button.previous {
  left:-60px;
  background:no-repeat url('../img/svg/btn-left.svg') center center;
}
.flickity-prev-next-button.next {
  background:no-repeat url('../img/svg/btn-right.svg') center center;
  right:-60px;
}
.flickity-prev-next-button.previous svg {
  display: none;
}
.flickity-prev-next-button.next svg {
  display: none;
}

* {
  /*outline: 1px solid yellow;*/
}





section p {
  /*max-width: 348px;*/
  font-size: 1rem;
  line-height: 1.4rem;
}
section.contacto div form > div:nth-child(1) {
  width: 50%;
  float: left;
}
section.contacto div form > div:nth-child(2) {
  width: 50%;
  padding-left: 10%;
  float: left;
}
img.section_icon.clickable.view_background {
  max-width: 78px;
}
img.section_icon {
  max-width: 33px;
}
#inicio {
  color: #ffffff;
  text-align: center;
}
#inicio h3 {
  text-transform: inherit;
}
#inicio .main_slider {
  height: calc(100vh - 29vh);
}
#inicio .main_slider img {
  object-fit: cover;
  object-position: center center;
  width: 100%;
  height: 100%;
  display: block;
}
#inicio .gradient_background {
  /*height: 29vh;*/
  padding-top:120px;
  padding-bottom:120px;
}
#inicio h3 {
  text-transform: inherit;
  font-weight: 900;
  /*font-family: 'Montserrat-Black';*/
  font-size: 1.8rem;
  width: 100%;
}
#inicio .gradient_background p {
  width: 60%;
  font-size: 1.6rem;
  line-height: 1;
}
div.arrow_wrapper {
  width: 100%;
}
section.section_llum_artista div.arrow_wrapper {
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  padding-bottom: 8%;
  z-index: 1;
}

.arrow {
  display: block;
  text-align: center;
  -webkit-animation: pulse 2s infinite;
  animation: pulse 2s infinite;
  color: #ffffff;
}
.arrow.arrow_black {
  color: #014265;
  margin-top: 14%;
}
.arrow.bottom:before {
  top: 0;
  -webkit-transform: rotate(135deg);
  -ms-transform: rotate(135deg);
  transform: rotate(135deg);
}
.arrow::before {
  border-style: solid;
  border-width: 0.15em 0.15em 0 0;
  content: '';
  display: inline-block;
  height: 50px;
  position: relative;
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
  vertical-align: top;
  width: 50px;
}
.section_llum_artista {
  color: #ffffff;
}
@media (max-width: 600px) {
.section_llum_artista {
  padding-bottom:20%;
}
}
.section_llum_artista span {
  float: left;
  width: 100%;
  line-height: 1em;
}
.section_llum_artista .extra_info {
  display: none;
}
section.section_llum_artista.view_artist .extra_info {
  display: block;
  margin: 0;
  bottom: -28vh;
  position: relative;
  right: -18vw;
  max-width: 308px;
  background: rgba(0, 0, 0, 0.5);
}
section.section_llum_artista.view_artist > div {
  display: none;
}
.section_llum_artista .extra_info h3 {
  width: min-content;
  padding-bottom: 5%;
}
.section_llum_artista .extra_info .info_item {
  padding: 7%;
}
.section_llum_artista .view_background {
  position: absolute;
  bottom: -55px;
  right: 0px;
}
.close {
  position: absolute;
  right: 0px;
  top: -50px;
  width: 45px;
  height: 45px;
  opacity: 1;
}
.close:hover {
  opacity: 0.5;
}
.close:before, .close:after {
  position: absolute;
  left: 28px;
  content: ' ';
  height: 45px;
  width: 2px;
  background-color: #ffffff;
}
.close:before {
  transform: rotate(45deg);
}
.close:after {
  transform: rotate(-45deg);
}
.clickable:hover {
  cursor: pointer;
}

/* FOOTER */
footer {
  justify-content: center;
  align-items: center;
  height: auto;
  background-color: #014265;
  padding-top: 4%;
  padding-bottom: 4%;
}
footer h4 {
  text-transform: uppercase;
  font-weight: 700;
  font-size: 14px;
  padding-bottom: 5%;
  font-family: 'Rubik';
}
footer p {
  font-size: 12px;
  line-height: 16px;
  font-family: 'Roboto';
  font-weight: 300;
}
footer a {
  float: left;
  display: block;
  font-size: 12px;
  width: 100%;
  line-height: 16px;
}
footer a:hover {
  color: #ffffff;
  text-decoration: underline;
}
footer div,
footer a,
footer .icon {
  color: #fff;
}
footer small, footer small a {
  font-size: 10px;
  float: left;
  color: #ffffff;
  width: 100%;
}
footer > div {
  display: flex;
  justify-content: center;
}
footer > div > div {
  padding-left: 2%;
  padding-right: 2%;
}
footer > div > div:nth-child(1) {
  width: 30%;
}
footer > div > div:nth-child(2) {
  width: 34%;
}
footer > div > div:nth-child(3) {
  width: 18%;
}
footer > div > div:nth-child(4) {
  width: 18%;
}
footer .logo_ajuntament_bottom {
  margin-top: 8%;
  margin-bottom: 4%;
}
footer .footer_social_wrapper {
  width: 100%;
  float: left;
  padding-top: 5%;
}
footer a.footer_social {
  width: auto;
  font-size: 36px;
}
footer a.footer_social:nth-child(1), footer a.footer_social:nth-child(2) {
  margin-right: 2%;
}
footer .avis_legal_bottom a {
  width: auto;
}
footer .avis_legal_bottom a:first-child {
  margin-right: 2%;
}

/* LOGO IMAGES */
.\32 _ruedas img.light_gray_logo {
  max-width: 298px;
}
.contacto img.dark_gray_logo {
  max-width: 198px;
  padding-top: 28%;
}
.empresa img.dark_gray_logo {
  max-width: 298px;
}
footer img.footer_logo {
  max-width: 158px;
  position: absolute;
  left: 2%;
}

/* FORM */
section#contacte #submit_button {
  max-width: 200px;
}

div.menu_dropdown, a.nav-icon {
  display: none;
}
section#contacte .captcha {
  width: 100%;
}
section#contacte .captcha button {
  max-width: 60px;
}
section#contacte input#legal {
  float: left !important;
  text-align: left !important;
  width: 14px;
  margin-right: 1%;
}
section#contacte span.legal_text, section#contacte span.legal_text a {
  font-size: 14px;
  margin-top: 1%;
  color: #014265;
}

/* MENU */
.max_width_menu {
  /*max-width: 1024px;*/
  margin-left: auto;
  margin-right: auto;
  padding-top: 1%;
}
div#menu_dropdown {
  /*position: absolute;
  top: 100%;
  background: rgba(0, 43, 88, 0.8);
  left: calc(92vw - 514px);
  width: max-content;
  text-align: left;
  color: #ffffff;
  padding: 0.8% 1.4%;*/
  position: absolute;
  background: rgba(0, 43, 88, 0.8);
  width: max-content;
  text-align: left;
  color: #ffffff;
  padding: 0.8% 1.4%;
  top: 100%;
  width: 100%;
  max-width: 230px;
  opacity: 0;
}
div.menu_dropdown.menu_visible {
  height: max-content;
  transition: 2s ease-out;
  display: block;
  transition: all 0.8s;
  opacity: 1 !important;
}
.menu_social_wrapper {
  padding-right: 7%;
}
div.menu_wrapper .open_menu:hover {
  cursor: pointer;
}
div.menu_wrapper .menu_social_wrapper a:hover {
  color: #003f60;
}
.font-size-8px {
  font-size: 8px;
}
.fw4 {
  font-weight:400;
}
.italic {
  font-style: italic;
}
.mr-left-10px {
  margin-left: 10px
}
.menu-separation {
  border-top:1px dotted;margin-top:.5em; border-bottom:1px dotted;padding-bottom:.5em;
}
.menu_dropdown small {
  font-size: 14px;
   margin:0;
  padding:0;
}
.menu_dropdown small span {
  position: relative;
  margin:0;
  padding:0;

}
.menu_dropdown small p::before {
    content:"-";
    position: absolute;
    left:-10px;
}
/* Contact Alerts */
.alert.alert-danger {
  background-color: #d0342c;
  font-size: 16px;
  width: 100%;
  text-align: center;
}
.alert.alert-danger ul {
  margin-bottom: 0;
  padding: 4%;
}
.alert.alert-danger ul li {
  list-style-type: none;
  margin-left: 0;
}
.alert.alert-success {
  background-color: #8BC34A;
  font-size: 16px;
  width: 100%;
  text-align: center;
}

/* ANIMATIONS */
@-webkit-keyframes pulse {
  0% {
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0); }
  50% {
      -webkit-transform: translate(0, 10px);
              transform: translate(0, 10px); }
  100% {
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0); }
  }

  @keyframes pulse {
  0% {
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0); }
  50% {
      -webkit-transform: translate(0, 10px);
              transform: translate(0, 10px); }
  100% {
      -webkit-transform: translate(0, 0);
              transform: translate(0, 0); }
  }

/*==== MEDIA QUERIES ====*/
@media (max-width: 1070px) {
  .arrow.bottom {
    display: none;
  }
  section.background_image > div {
      flex-direction: column;
      width: 100%;
  }
  section.background_image .width_30_desktop {
      width: 100%;
      flex-direction: row;
      padding: 4%;
  }
  section.background_image .width_70_desktop {
      width: 100%;
      padding: 0 4%;
  }
  section.background_image .width_30_desktop .info_item {
      /*padding-bottom: 6%;*/
      margin-right: 0;
      width: 48%;
      min-height: 252px;
  }
  .width_70_desktop .info_item {
      min-height: auto;
      /*max-height: 410px;*/
      max-height: 24vw;
  }
  section.contacto div > div:nth-child(1) {
      width: 100%;
      float: left;
      padding-left: 10%;
  }
  .section_llum_artista .view_background {
      right: 4%;
  }
  section.section_presentacio .wrapper_maxwidth {
      padding-left: 5%;
      padding-right: 5%;
  }
}
@media (max-width: 1024px) {
  nav div.menu_wrapper {
      padding-right: 4%;
  }
}

/* iPad */
@media only screen
and (min-device-width : 768px)
and (max-device-width : 1024px)  {

}
/* iPad landscape */
@media only screen
and (min-device-width : 768px)
and (max-device-width : 1024px)
and (orientation : landscape) {
  .width_70_desktop .info_item {
      min-height: auto;
      max-height: 32vw;
  }
  section.section_presentacio .wrapper_maxwidth {
      padding-left: 5%;
      padding-right: 5%;
  }
}
/* iPad portrait */
@media only screen
and (min-device-width : 768px)
and (max-device-width : 1024px)
and (orientation : portrait) {
  .width_70_desktop .info_item {
      max-height: 64vw;
  }
  footer > div > div:nth-child(1) {
      display: none;
  }
  footer > div > div {
      width: 33% !important;
  }
  section.section_presentacio .wrapper_maxwidth {
      padding-left: 5%;
      padding-right: 5%;
  }
}



/* MOBILE */
@media only screen and (max-width: 768px) {
  main {
      margin-top: 12%;
  }
  .vidible_mobile {
      display: block !important;
  }
  .hidden_mobile {
      display: none !important;
  }
  .visible_mobile {
      display: block !important;
  }
  footer {
      /*height: 12rem;*/
      padding-top: 4%;
      padding-bottom: 4%;
  }
  h3 {
      font-size: 1.4rem;
  }


  /* MENU MOBILE */
  a.nav-icon {
      display: block;
  }
  nav div.menu_wrapper {
      font-size: 2em;
  }
  nav div.logo {
      display: none;
  }
  nav.has_scrolled div.logo {
      display: flex;
      align-items: center;
  }
  nav.has_scrolled div.logo img {
      max-width: 150px;
  }
  nav div.menu_wrapper {
      width: 100%;
  }
  nav.has_scrolled div.menu_wrapper {
      width: 60%;
  }
  #inicio .gradient_background {
      /*height: 50vh;*/
      height: auto;
      padding-top: 40px;
      padding-bottom: 40px;
  }
  nav.has_scrolled .max_width_menu {
      padding-top: 2%;
      padding-bottom: 2%;
  }
  .menu_social_wrapper {
      display: none;
  }
  div#menu_dropdown {
      background: rgba(0, 43, 88, 0.95);
      padding: 5% 10%;
      top: 100%;
      width: 100vw;
      max-width: none;
      right: 0;
      max-height: 90vh;
      padding-bottom: 100px;
      overflow-y: auto;
  }
  nav span.category_menu {
      font-size: 20px;
  }
  nav .sub-item-level span.category_menu {
      font-size: 18px;
      padding-top: 2%;
      padding-bottom: 3%;
      display: block;
      line-height: 1.2;
  }
  /* FI MENU */

  nav div.guixols_logo img {
      max-width: 100px;
      padding-top: 2%;
      padding-bottom: 2%;
  }
  #inicio .main_slider {
      /*height: 26vh;*/
      height: max-content;
      width: 100%;
  }
  #inicio h3 {
      font-size: 1.6rem;
      width: 100%;
  }
  #inicio .gradient_background p {
      width: 90%;
      font-size: 1.2rem;
      line-height: 1.4rem;
  }
  section.section_presentacio .wrapper_maxwidth {
      padding-left: 5%;
      padding-right: 5%;
  }
  div.arrow_wrapper {
      display: none !important;
  }
  .info_item {
      padding: 3%;
      border: 1px solid #ffffff;
  }
  .width_70_desktop .info_item {
      max-height: 100vw;
  }
  .section_llum_artista .view_background {
      /*display: none;*/
  }
  section.contacto div > div {
      width: 90% !important;
  }
  footer > div {
      flex-direction: column;
  }
  footer > div > div {
      padding-left: 5%;
      padding-right: 5%;
      width: 90% !important;
      margin-bottom: 10%;
  }
  section.background_image .width_30_desktop .info_item {
      min-height: 196px;
      height: auto;
  }
  section.section_llum_artista.view_artist .extra_info {
      right: 0;
      max-width: 238px;
  }
  section#contacte {
      padding-top: 20%;
      padding-bottom: 20%;
  }
  section.contacto div form > div:nth-child(2) {
      width: 90%;
      padding-left: 10%;
      float: left;
      display: block;
  }
  .flex_left_wrap {
      width: 90%;
      padding-left: 10%;
  }
  section.background_image {
      background-image: none !important;
      /*height: 100vh;
      padding-bottom: 18% !important;*/
      background-color: #000000;
      display: block;
      height: 100%;
  }
  section.background_image::before {
      background-color: transparent !important;
  }
  section.background_image .width_70_desktop {
      /*padding-bottom: 20%;*/
  }
  section#contacte span.legal_text {
      width: 94%;
  }
  section.background_image > div {
      position: relative;
  }
  .info_item h3 {
      word-break: break-all;
  }
  section.section_presentacio {
      height: 100%;
      padding-top: 9%;
      padding-bottom: 9%;
  }
}



@media screen and (orientation: landscape) and (max-height: 600px) {
  body::before {
    content: "Gira el dispositiu per veure la web en mode vertical.";
    position: fixed;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: white;
    color: black;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 2rem;
    font-size: 1.2rem;
  }

  main {
    display: none;
  }
}