@font-face {
  font-family: 'Pragmatica';
  src: url('fonts/subset-Pragmatica-Black.eot');
  src: url('fonts/subset-Pragmatica-Black.eot?#iefix') format('embedded-opentype'), url('fonts/subset-Pragmatica-Black.woff2') format('woff2'), url('fonts/subset-Pragmatica-Black.woff') format('woff'), url('fonts/subset-Pragmatica-Black.ttf') format('truetype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Pragmatica';
  src: url('fonts/subset-Pragmatica-Bold.eot');
  src: url('fonts/subset-Pragmatica-Bold.eot?#iefix') format('embedded-opentype'), url('fonts/subset-Pragmatica-Bold.woff2') format('woff2'), url('fonts/subset-Pragmatica-Bold.woff') format('woff'), url('fonts/subset-Pragmatica-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Pragmatica';
  src: url('fonts/subset-Pragmatica-Medium.eot');
  src: url('fonts/subset-Pragmatica-Medium.eot?#iefix') format('embedded-opentype'), url('fonts/subset-Pragmatica-Medium.woff2') format('woff2'), url('fonts/subset-Pragmatica-Medium.woff') format('woff'), url('fonts/subset-Pragmatica-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'PalmerLakePrint';
  src: url('fonts/PalmerLakePrint-Regular.eot');
  src: url('fonts/PalmerLakePrint-Regular.eot?#iefix') format('embedded-opentype'), url('fonts/PalmerLakePrint-Regular.woff2') format('woff2'), url('fonts/PalmerLakePrint-Regular.woff') format('woff'), url('fonts/PalmerLakePrint-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
/* Typography */
/* Paleta */
/* Generales */
.c1 {
  color: #000;
}
.c2 {
  color: #fff200;
}
.c3 {
  color: #787d7e;
}
.c4 {
  color: #171151;
}
.c5 {
  color: #171151;
}
.bg-c1 {
  background-color: #000;
  color: #FFF;
}
.bg-c2 {
  background-color: #fff200;
  color: #FFF;
}
.bg-c3 {
  background-color: #787d7e;
  color: #FFF;
}
.bg-c4 {
  background-color: #171151;
  color: #FFF;
}
.bg-c5 {
  background-color: #171151;
  color: #FFF;
}
[x-cloak] {
  display: none !important;
}
html {
  font-size: 100%;
}
.main-content {
  overflow: hidden;
}
body {
  font-family: 'Roboto', sans-serif;
  color: #474747;
}
p {
  font-size: 1.1rem;
  line-height: 1.8rem;
  font-weight: 400;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Pragmatica', sans-serif;
  font-weight: 900;
}
h1 a,
h2 a,
h3 a,
h4 a,
h5 a,
h6 a {
  color: inherit;
  font-weight: inherit;
}
h1 a:hover,
h2 a:hover,
h3 a:hover,
h4 a:hover,
h5 a:hover,
h6 a:hover {
  text-decoration: none;
}
h2 {
  font-size: 3rem;
  line-height: 3rem;
  padding-bottom: 1rem;
}
/* Generales */
.link {
  color: #000;
  text-decoration: none;
  font-weight: 400;
  display: inline-block;
  font-size: 20px;
  margin-top: 20px;
  border-bottom: 2px solid #000;
  padding: 0px 0px 5px;
}
.link.small {
  font-size: 17px;
  font-weight: 500;
}
.link.nmt {
  margin-top: 5px;
}
.link i {
  margin-left: 10px;
}
.specialfont {
  font-family: 'Pragmatica', sans-serif;
  font-weight: normal;
}
.ptb {
  padding-top: 90px;
  padding-bottom: 90px;
}
.pt {
  padding-top: 90px;
}
.pb {
  padding-bottom: 90px;
}
.extralarge {
  font-size: 37px;
  line-height: 42px;
  letter-spacing: 1px;
}
.ttu {
  text-transform: uppercase;
}
.boton {
  text-transform: uppercase;
  text-decoration: none;
  display: inline-block;
  font-size: 15px;
  letter-spacing: 1px;
  padding: 12px 25px 10px;
  background-color: #000;
  color: #FFF;
  transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
}
.boton:hover {
  color: #FFF;
}
.boton.c2 {
  background-color: #fff200;
  color: #FFF;
}
.boton.c2:hover {
  color: #FFF;
}
.boton.c3 {
  background-color: #787d7e;
  color: #FFF;
}
.boton.c3:hover {
  color: #FFF;
}
.boton.c4 {
  background-color: #171151;
  color: #FFF;
}
.boton.c4:hover {
  color: #FFF;
}
.boton.c5 {
  background-color: #171151;
  color: #FFF;
}
.boton.c5:hover {
  color: #FFF;
}
.boton.outline {
  background-color: transparent;
  color: #000;
  border: 1px solid #000;
}
.boton.outline:hover {
  color: #000;
}
.boton.outline.c2 {
  color: #fff200;
  border: 2px solid #fff200;
}
.boton.outline.c2:hover {
  color: #fff200;
}
.boton.outline.c3 {
  color: #787d7e;
  border: 2px solid #787d7e;
}
.boton.outline.c3:hover {
  color: #787d7e;
}
.boton.outline.c4 {
  color: #171151;
  border: 2px solid #171151;
}
.boton.outline.c4:hover {
  color: #171151;
}
.boton.outline.c5 {
  color: #171151;
  border: 2px solid #171151;
}
.boton.outline.c5:hover {
  color: #171151;
}
.boton:hover {
  text-decoration: none;
}
.boton:hover.grow {
  transform: scale(1.07);
}
.boton.white {
  color: #fff;
  border: 1px solid #fff;
}
.boton.inverted {
  background-color: #fff;
  color: #222;
  border: none;
}
.boton.outline.white:hover {
  color: #FFF;
}
.sticker {
  color: #fff200;
  font-family: 'PalmerLakePrint', sans-serif;
  text-transform: uppercase;
  font-size: 3.5rem;
  line-height: 1.8rem;
  font-weight: 300;
  text-shadow: 0 0 10px #000;
}
.sticker.right-down {
  position: absolute;
  display: inline-block;
  right: 14px;
  bottom: 26px;
  z-index: 10;
  transform: translateX(100%) rotate(-6deg);
}
.tac {
  text-align: center;
}
h2.section-title {
  text-transform: uppercase;
  font-weight: 300;
  margin-bottom: 20px;
}
body {
  background-color: #FFF;
  /* &::before{
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      // mix-blend-mode: luminosity;
      opacity: 0.02;
      z-index: -1;
      background: url(images/favicon.png) left center;
   } */
}
:root {
  --swiper-theme-color: #FFF;
}
/* HEADER */
#site-header {
  position: absolute;
  width: 100%;
  left: 0;
  top: 0;
  z-index: 100;
}
#site-header .wrap {
  padding: 10px 60px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#site-header .logo img {
  width: 270px;
  padding-top: 20px;
  padding-bottom: 20px;
  transition: all 0.7s;
}
.header-wrapper:not(.openedmenu) #site-header.white #open-menu .line {
  stroke: #FFF;
}
.header-wrapper:not(.openedmenu) #site-header.white .logo img {
  -webkit-filter: invert();
  filter: invert();
}
.header-wrapper.openedmenu #open-menu .line {
  stroke: #FFF;
}
.header-wrapper.openedmenu .logo img {
  -webkit-filter: invert();
  filter: invert();
}
.menu-responsive {
  background-color: #000;
  position: fixed;
  width: 100%;
  height: 100vh;
  z-index: 99;
  display: flex;
  align-items: center;
  justify-content: center;
}
.menu-responsive ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  text-align: center;
}
.menu-responsive ul li a {
  visibility: none;
  font-family: 'Pragmatica', sans-serif;
  color: #FFF;
  text-decoration: none;
  font-size: 3.5rem;
  line-height: 4rem;
  font-weight: 400;
  text-transform: uppercase;
  padding: 6px 0;
  display: inline-block;
  transition: all 0.2s;
}
.menu-responsive ul li:hover a {
  margin-left: -15px;
}
.menu-responsive li {
  display: block;
  position: relative;
}
.menu-responsive li img {
  position: absolute;
  z-index: 10;
  width: 110%;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  opacity: 0;
  transition: all 0.15s;
}
.menu-responsive li.li-portfolio img {
  width: 120%;
}
.menu-responsive li.li-servicios img {
  width: 106%;
}
.menu-responsive li.li-nosotros img {
  width: 115%;
}
.menu-responsive li.li-contacto img {
  width: 113%;
}
.menu-responsive li:hover img {
  opacity: 1;
}
.hero {
  height: 100vh;
}
/********* Slider *************/
.swiper {
  width: 100%;
  height: 100%;
}
.swiper-slide-prev,
.swiper-slide-next {
  transition: opacity 0.3s;
  opacity: 0.1;
}
.swiper-slide {
  font-size: 18px;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
}
.presentacion {
  padding-top: 150px;
  padding-bottom: 150px;
  position: relative;
  z-index: 1;
  /* &::before{
    content: "";
    position: absolute;
    left: -50px;
    top: 0;
    width: 100%;
    height: 100%;
    background: url(images/favicon.png) left center no-repeat;
    background-size: contain;
    opacity: 0.07;
    z-index: -1;
  } */
}
.swiper-container.slider-dinamico {
  width: 100%;
  height: 100vh;
}
.swiper-container.slider-dinamico .slider-overlay {
  width: 100%;
  height: 100%;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  background-color: #222222;
  mix-blend-mode: multiply;
  opacity: 0.1;
}
.swiper-container.slider-dinamico .swiper-slide {
  position: relative;
  z-index: 1;
}
.swiper-container.slider-dinamico .swiper-slide h2 {
  text-transform: uppercase;
  font-size: 5rem;
  line-height: 5rem;
  letter-spacing: -2px;
  color: #000000;
}
.swiper-container.slider-dinamico .swiper-slide p {
  color: #000000;
}
.swiper-container.slider-dinamico .swiper-slide .boton-slider {
  color: #000000;
  margin-top: 15px;
  display: inline-block;
  background: transparent;
  border: 2px solid #222222;
  text-decoration: none;
  padding: 15px 30px;
  font-family: 'Pragmatica', sans-serif;
  font-weight: 800;
}
.swiper-container.slider-dinamico .swiper-slide.white h2,
.swiper-container.slider-dinamico .swiper-slide.white p {
  color: #FFF;
}
.swiper-container.slider-dinamico .swiper-slide.white .boton-slider {
  color: #FFF;
  background: transparent;
  border-color: #FFF;
}
.swiper-container.slider-dinamico .swiper-slide-cover {
  width: 100%;
  height: 100%;
  z-index: 1;
  position: relative;
}
.swiper-container.slider-dinamico .swiper-slide {
  overflow: hidden;
}
.swiper-container.slider-dinamico .swiper-slide-cover {
  transition: 10s ease-out;
  transform: scale(1);
}
.swiper-container.slider-dinamico .swiper-slide.swiper-slide-active .swiper-slide-cover {
  transform: scale(1.1);
}
/*********** FOTOS HOME *******************/
.galeria {
  display: grid;
  height: 1000px;
  grid-template-areas: "f1 f2 f2" "f4 f4 f3";
  grid-gap: 10px;
}
.galeria .foto {
  filter: saturate(0);
  transition: all 0.3s ease-in-out;
}
.galeria .foto:hover {
  filter: saturate(1);
}
.galeria .foto1 {
  background: url(images/fotos/1.jpg) center center;
  background-size: cover;
  grid-area: f1;
}
.galeria .foto2 {
  background: url(images/fotos/2.jpg) center center;
  background-size: cover;
  grid-area: f2;
}
.galeria .foto3 {
  background: url(images/fotos/3.jpg) center center;
  background-size: cover;
  grid-area: f3;
}
.galeria .foto4 {
  background: url(images/fotos/4.jpg) center center;
  background-size: cover;
  grid-area: f4;
}
/**** Proyectos Home ***/
.proyectos-home {
  position: relative;
  z-index: 1;
  color: #FFF;
  background-color: #000;
  padding-top: 150px;
  padding-bottom: 150px;
  /* &::before{
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      // mix-blend-mode: luminosity;
      opacity: 0.1;
      z-index: -1;
      background: url(images/favicon.png) left center;
   }  */
}
.more-gutter {
  --bs-gutter-x: 8rem;
}
.main-section {
  background-color: #000;
  padding-top: 240px;
  padding-bottom: 80px;
  color: #FFF;
}
.main-section span.pretitle {
  text-transform: uppercase;
  font-weight: 300;
  padding-left: 5px;
  padding-bottom: 10px;
  display: inline-block;
  letter-spacing: 2px;
  font-size: 1.2rem;
}
.main-section .h1-wrapper {
  margin-bottom: 80px;
}
.main-section .h1-wrapper p {
  margin-top: 30px;
}
.main-section h1 {
  display: inline;
  position: relative;
  font-weight: 800;
  text-transform: uppercase;
  font-size: 6.5rem;
  line-height: 5.8rem;
}
.main-section h1.not-so-big {
  text-transform: none;
  font-size: 3.9rem;
  line-height: 4.2rem;
}
/*********** Servicios Home ***************/
.servicios-home {
  padding-top: 3px;
  display: flex;
  gap: 3px;
  height: 500px;
  align-items: stretch;
}
.servicios-home .item-servicio-home {
  background: #474747;
  color: #FFF;
  flex: 50%;
  display: flex;
  align-items: flex-end;
  position: relative;
  z-index: 1;
}
.servicios-home .item-servicio-home .wrap {
  padding: 50px;
}
.servicios-home .item-servicio-home h2 {
  text-transform: uppercase;
  font-weight: 800;
  font-size: 56px;
  color: #272727;
  background: #FFF;
  display: inline-block;
  padding: 5px 10px 3px;
}
.servicios-home .item-servicio-home span {
  display: block;
  font-weight: 300;
  padding-top: 5px;
  font-size: 26px;
}
.servicios-home .item-servicio-home i {
  font-size: 30px;
  display: inline-block;
  padding-top: 20px;
}
.servicios-home .item-servicio-home::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.servicios-home .item-servicio-home.branding::before {
  background: url(images/bg-branding.jpg) left top;
  background-size: cover;
  mix-blend-mode: multiply;
}
.servicios-home .item-servicio-home.comunicacion::before {
  background: url(images/bg-comunicacion.jpg) center top;
  background-size: cover;
  mix-blend-mode: multiply;
  opacity: 0.7;
}
/******* Nosotros *********/
.slick-slide {
  margin: 30px;
}
.banderin {
  padding-bottom: 70px;
}
.row-staff {
  --bs-gutter-x: 3rem;
  align-items: stretch;
}
.integrante {
  margin-bottom: 20px;
}
.integrante h3 {
  padding-top: 30px;
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 2.6rem;
  border-bottom: 1px solid #999999;
  padding-bottom: 15px;
  margin-bottom: 15px;
}
.integrante span {
  display: block;
  text-transform: uppercase;
  font-size: 0.9rem;
  color: #8b8b8b;
}
.integrante .redes-integrante {
  padding-top: 30px;
}
.integrante .redes-integrante a {
  color: inherit;
  text-decoration: none;
}
.integrante .redes-integrante a:hover {
  font-weight: 800;
}
/* .container-expanded{
  max-width: 1500px;
  margin: 0 auto;
} */
.galeria-nosotros {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 5px;
}
.wrap-carousel {
  position: relative;
  padding-left: 40px;
  padding-right: 40px;
}
.slick-next,
.slick-prev,
.carousel-next,
.carousel-prev {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 50;
  font-size: 3rem;
  cursor: pointer;
}
.slick-next,
.carousel-next {
  right: 15px !important;
}
.slick-prev,
.carousel-prev {
  left: 15px !important;
}
/************** Portfolio ****************/
.portfolio-main-section {
  padding-bottom: 240px;
  margin-bottom: -126px;
}
.portfolio-main-section .sticker.right-down {
  bottom: 40px;
}
.filtros {
  list-style-type: none;
  padding-left: 0;
}
.filtros li a {
  color: #FFF;
  font-weight: 300;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  font-size: 1.2rem;
}
.filtros li a.is-checked {
  color: #fff200;
}
.item-proyecto {
  margin-bottom: 25px;
  visibility: none;
}
.filter-button-group {
  display: flex;
  justify-content: space-evenly;
  margin-top: 30px;
  margin-bottom: 30px;
  padding: 0px 3px 0px 0;
  box-shadow: 0 11px 13px -10px rgba(0, 0, 0, 0.3);
}
.filter-button-group button {
  display: block;
  font-family: 'Pragmatica', sans-serif;
  width: 100%;
  border: 1px solid #646464;
  border-right: none;
  padding: 15px 10px 11px;
  text-transform: uppercase;
  font-size: 16px;
  background: transparent;
  color: #c2c2c2;
  transition: all 0.3s ease-in-out;
}
.filter-button-group button:last-child {
  border-right: 1px solid #646464;
}
.filter-button-group button.is-checked {
  color: #222;
  background: #FFF;
}
/*********** Heading ****************/
.heading {
  padding-top: 150px;
  padding-bottom: 20px;
  position: relative;
  z-index: 1;
  text-align: center;
}
.heading .pretitle {
  position: absolute;
  top: -197px;
  left: 50%;
  font-size: 500px;
  line-height: 400px;
  font-weight: 900;
  white-space: nowrap;
  letter-spacing: -20px;
  z-index: -1;
  color: #f8f8f8;
  transform: translate(-50%, 0px);
}
.heading h1 {
  letter-spacing: -1px;
  text-transform: uppercase;
  font-size: 60px;
  font-weight: 300;
  color: #474747;
}
.heading.white {
  background-color: #000;
}
.heading.white h1 {
  color: #FFF;
  font-weight: 200;
}
.heading.white .pretitle {
  color: #2a2a2a;
}
.gracias {
  padding: 200px 0;
}
/************** Single Porfolio ***************/
.single-portfolio-main-section h1 {
  font-size: 4rem;
  line-height: 4rem;
}
.single-portfolio-main-section p {
  font-size: 1rem;
}
.row-descripcion-proyecto {
  --bs-gutter-x: 6rem;
  padding-top: 40px;
}
.row-descripcion-proyecto p {
  color: #e6e6e6;
}
.row-descripcion-proyecto h6,
.row-descripcion-proyecto span.year {
  color: #787d7e;
  font-weight: 400;
}
.advancedcontent {
  background-color: #000;
  color: #e6e6e6;
}
.advancedcontent .row {
  --bs-gutter-x: 6rem;
}
.advancedcontent .tituloytexto,
.advancedcontent .texto2col,
.advancedcontent .frase,
.advancedcontent .textolink {
  padding-top: 120px;
  padding-bottom: 120px;
}
.advancedcontent .frase h3,
.advancedcontent .tituloytexto h2 {
  text-transform: uppercase;
  padding: 0;
  margin: 0;
  font-size: 3rem;
  line-height: 3rem;
}
.advancedcontent span.autor {
  color: #787d7e;
  font-style: italic;
  display: block;
  margin-top: 20px;
}
.advancedcontent p {
  margin-bottom: 0;
  font-size: 1rem;
}
.advancedcontent .video-vimeo {
  position: relative;
}
.advancedcontent .video-vimeo .play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  transform: translate(-50%, -50%);
  color: #FFF;
  width: 100px;
  height: 100px;
  cursor: pointer;
  transition: all 0.6s;
}
.navegacion-posts {
  position: relative;
  padding-top: 40px;
  padding-bottom: 28px;
  display: flex;
  justify-content: space-between;
}
.navegacion-posts a {
  color: inherit;
  text-decoration: none;
}
.navegacion-posts a:hover {
  color: #000;
}
.navegacion-posts .next {
  text-align: right;
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  padding-left: 30px;
  position: relative;
}
.navegacion-posts .next i {
  padding-left: 20px;
  color: #000;
}
.navegacion-posts .previous {
  text-align: left;
  display: flex;
  align-items: center;
  padding-right: 30px;
  position: relative;
}
.navegacion-posts .previous i {
  padding-right: 20px;
  color: #000;
}
/************ Contacto **************/
.section-contacto {
  background-color: #fff200;
  color: #000;
  min-height: 100vh;
  padding-top: 240px;
  padding-bottom: 140px;
}
.h3-email {
  margin-bottom: 40px;
  font-weight: 300;
  font-size: 2.5rem;
}
.link-telefono {
  text-decoration: none;
  font-weight: 600;
  font-size: 1.2rem;
}
/**** FORMULARIOS ****/
span.validate-error {
  color: #e24f4f;
}
.form-group {
  margin-bottom: 30px;
}
span.requerido {
  color: #e24f4f;
  font-size: 19px;
  padding-left: 3px;
  line-height: 10px;
}
.form-dark form {
  padding-top: 40px;
}
.form-dark .form-control {
  background-color: transparent;
  border: none;
  border-bottom: 2px solid #000;
  border-radius: 0;
  padding-left: 0;
  font-size: 1.5rem;
  font-weight: 500;
  /* Change the white to any color */
}
.form-dark .form-control[type=text] {
  height: 50px;
}
.form-dark .form-control:-internal-autofill-selected {
  background: #fff200 !important;
}
.form-dark .form-control:-webkit-autofill,
.form-dark .form-control:-webkit-autofill:hover,
.form-dark .form-control:-webkit-autofill:focus,
.form-dark .form-control:-webkit-autofill:active {
  box-shadow: 0 0 0 60px #fff200 inset !important;
  -webkit-box-shadow: 0 0 0 60px #fff200 inset !important;
  background-color: #fff200 !important;
}
.form-dark .form-control::placeholder {
  font-size: 1.1rem;
  color: #000;
  font-weight: 400;
}
.form-dark .form-control:focus {
  box-shadow: none !important;
  outline: none;
}
.form-dark .form-control:focus::placeholder {
  opacity: 0.2;
}
.form-dark label {
  color: #fbfbfb;
}
.form-dark button {
  margin-top: 2rem;
  border: none;
  padding: 15px 30px;
  font-family: 'Pragmatica', sans-serif;
}
.col-formulario {
  padding-right: 90px;
}
.col-contacto h5 {
  padding-bottom: 15px;
}
.col-contacto ul {
  list-style-type: none;
  padding-left: 1px;
}
.col-contacto ul li a {
  padding: 3px 0;
  display: inline-block;
}
.col-contacto a {
  color: inherit;
}
.col-ultima .wrap {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
/********** Servicios *****************/
/***** Accordion *****/
.lista-servicios .item-servicio-lista {
  background-color: #fff;
  border: 1px solid #e3e3e3;
  border-radius: 7px;
  margin-bottom: 18px;
}
.lista-servicios .item-servicio-lista .item-titulo {
  padding: 10px 40px 10px 20px;
  position: relative;
}
.lista-servicios .item-servicio-lista .item-titulo::after {
  content: "";
  font-family: 'FontAwesome';
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%) rotate(0);
  font-size: 2rem;
  transition: all 0.4s;
}
.lista-servicios .item-servicio-lista.opened .item-titulo::after {
  transform: translateY(-50%) rotate(180deg);
}
.lista-servicios .item-servicio-lista .item-texto {
  padding-left: 20px;
  padding-right: 20px;
  padding-bottom: 20px;
}
.lista-servicios .item-servicio-lista ul {
  padding-left: 0;
  margin: 0;
  list-style-type: none;
}
.lista-servicios .item-servicio-lista h2 {
  font-size: 1.7rem;
  font-weight: 800;
  margin: 0;
  padding: 0;
}
.lista-servicios .item-servicio-lista p {
  margin-bottom: 0;
}
.lista-servicios .item-titulo {
  cursor: pointer;
}
.lista-servicios .respuesta {
  padding: 0 20px 20px;
}
.servicios .col-texto {
  padding-top: 20px;
  padding-right: 80px;
}
.section-servicios {
  padding-top: 40px;
}
.item-servicio {
  display: flex;
  visibility: none;
  padding: 40px;
}
.item-servicio .bignumber {
  font-size: 180px;
  padding-top: 30px;
  letter-spacing: -10px;
  color: #e6e6e6;
  font-weight: 900;
  padding-right: 30px;
}
.item-servicio h2 {
  color: #FFF;
  margin-bottom: 20px;
  background-color: #272727;
  padding: 3px 10px;
  display: inline-block;
  margin-left: -25px;
  text-transform: uppercase;
  font-size: 35px;
  font-weight: 300;
}
.action-bar {
  padding: 200px 60px;
  background: url(images/bg-cta.jpg) center center;
  background-size: cover;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 0;
  color: #FFF;
}
.action-bar::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: -1;
  background-color: #222222;
  mix-blend-mode: multiply;
  opacity: 0.88;
}
.action-bar .frase-cta p {
  font-size: 3.5rem;
  line-height: 4rem;
  font-weight: 800;
  font-family: 'Pragmatica', sans-serif;
}
.action-bar .col-boton {
  text-align: right;
}
.action-bar .boton {
  text-transform: uppercase;
  font-weight: 300;
  padding: 15px 35px;
  font-size: 15px;
  font-family: 'Pragmatica', sans-serif;
  letter-spacing: 2px;
  border-color: rgba(255, 255, 255, 0.644);
}
.action-bar .boton:hover {
  background-color: #FFF;
  color: #272727 !important;
}
/********** clientes ************/
.logos-clientes {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.item-cliente img {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  -webkit-filter: saturate(0);
  filter: saturate(0);
  opacity: 0.6;
  transition: all 0.3s ease;
}
.item-cliente img:hover {
  -webkit-filter: saturate(1);
  filter: saturate(1);
  opacity: 1;
}
.row-clientes {
  padding-bottom: 50px;
}
/********** footer *****************/
#site-footer {
  padding: 70px 60px 40px;
  border-top: 1px solid #e3e3e3;
}
.sitemap {
  margin-bottom: 0;
  padding-left: 0;
}
.copyright {
  display: block;
  color: #797979;
  font-size: 14px;
  line-height: 18px;
  font-style: italic;
  padding-top: 25px;
}
.copyright a {
  color: inherit;
}
.items-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.redes,
.logo-footer {
  flex: 25%;
}
.redes {
  text-align: right;
}
.redes a {
  color: #000;
  font-size: 25px;
  margin-left: 20px;
}
.menu-footer {
  flex: 50%;
  text-align: center;
}
.menu-footer ul li a {
  padding: 10px 15px 7px;
  color: #272727;
  text-decoration: none;
  text-transform: uppercase;
  font-weight: 300;
  display: inline-block;
}
.menu-footer ul li a:not(:last-child) {
  margin-left: 20px;
}
.items-footer {
  justify-content: space-between;
  align-items: center;
}
.logo-footer img {
  width: 250px;
}
.copyright {
  margin-top: 20px;
}
.back-to-top {
  width: 50px;
  height: 50px;
  cursor: pointer;
  border-radius: 50px;
  border: none;
  background-color: #000;
  position: fixed;
  bottom: 30px;
  right: 30px;
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}
.back-to-top:hover {
  transform: scale(1.1);
  box-shadow: 0 0 0 5px rgba(0, 0, 0, 0.1);
}
.back-to-top button {
  outline: none;
  background: none;
  font-size: 22px;
  border: none;
  color: #fff;
}
.menu-footer ul li {
  display: inline;
}
/*********** SPECIAL EFFECTS *************/
.ham {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform 400ms;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.hamRotate.active {
  transform: rotate(45deg);
}
.hamRotate180.active {
  transform: rotate(180deg);
}
.line {
  fill: none;
  transition: stroke-dasharray 400ms, stroke-dashoffset 400ms;
  stroke: #000;
  stroke-width: 5.5;
  stroke-linecap: round;
}
.ham1 .top {
  stroke-dasharray: 40 139;
}
.ham1 .bottom {
  stroke-dasharray: 40 180;
}
.ham1.active .top {
  stroke-dashoffset: -98px;
}
.ham1.active .bottom {
  stroke-dashoffset: -138px;
}
.ham2 .top {
  stroke-dasharray: 40 121;
}
.ham2 .bottom {
  stroke-dasharray: 40 121;
}
.ham2.active .top {
  stroke-dashoffset: -102px;
}
.ham2.active .bottom {
  stroke-dashoffset: -102px;
}
.ham3 .top {
  stroke-dasharray: 40 130;
}
.ham3 .middle {
  stroke-dasharray: 40 140;
}
.ham3 .bottom {
  stroke-dasharray: 40 205;
}
.ham3.active .top {
  stroke-dasharray: 75 130;
  stroke-dashoffset: -63px;
}
.ham3.active .middle {
  stroke-dashoffset: -102px;
}
.ham3.active .bottom {
  stroke-dasharray: 110 205;
  stroke-dashoffset: -86px;
}
.ham4 .top {
  stroke-dasharray: 40 121;
}
.ham4 .bottom {
  stroke-dasharray: 40 121;
}
.ham4.active .top {
  stroke-dashoffset: -68px;
}
.ham4.active .bottom {
  stroke-dashoffset: -68px;
}
.ham5 .top {
  stroke-dasharray: 40 82;
}
.ham5 .bottom {
  stroke-dasharray: 40 82;
}
.ham5.active .top {
  stroke-dasharray: 14 82;
  stroke-dashoffset: -72px;
}
.ham5.active .bottom {
  stroke-dasharray: 14 82;
  stroke-dashoffset: -72px;
}
.ham6 .top {
  stroke-dasharray: 40 172;
}
.ham6 .middle {
  stroke-dasharray: 40 111;
}
.ham6 .bottom {
  stroke-dasharray: 40 172;
}
.ham6.active .top {
  stroke-dashoffset: -132px;
}
.ham6.active .middle {
  stroke-dashoffset: -71px;
}
.ham6.active .bottom {
  stroke-dashoffset: -132px;
}
.ham7 .top {
  stroke-dasharray: 40 82;
}
.ham7 .middle {
  stroke-dasharray: 40 111;
}
.ham7 .bottom {
  stroke-dasharray: 40 161;
}
.ham7.active .top {
  stroke-dasharray: 17 82;
  stroke-dashoffset: -62px;
}
.ham7.active .middle {
  stroke-dashoffset: 23px;
}
.ham7.active .bottom {
  stroke-dashoffset: -83px;
}
.ham8 .top {
  stroke-dasharray: 40 160;
}
.ham8 .middle {
  stroke-dasharray: 40 142;
  transform-origin: 50%;
  transition: transform 400ms;
}
.ham8 .bottom {
  stroke-dasharray: 40 85;
  transform-origin: 50%;
  transition: transform 400ms, stroke-dashoffset 400ms;
}
.ham8.active .top {
  stroke-dashoffset: -64px;
}
.ham8.active .middle {
  transform: rotate(90deg);
}
.ham8.active .bottom {
  stroke-dashoffset: -64px;
}
/*********** MEDIA QUERIES **************/
/* 
// XS (portrait phones, less than 576px)
@media (max-width: 575.98px) {

}

// SM (landscape phones, 576px to 768px)
@media (min-width: 576px) and (max-width: 767.98px) {

} */
@media (max-width: 1199.98px) {
  #site-header .wrap {
    padding: 10px 5px 10px 20px;
  }
  .presentacion {
    padding-top: 70px;
    padding-bottom: 70px;
  }
  h3.extralarge {
    font-size: 30px;
    line-height: 35px;
  }
  .presentacion-texto {
    padding-top: 25px;
  }
  .action-bar {
    padding: 100px 30px;
  }
  .col-formulario {
    padding-right: calc(var(--bs-gutter-x)/2);
  }
  #site-footer {
    padding-left: 20px;
    padding-right: 20px;
  }
  #site-footer .items-footer {
    flex-direction: column;
    text-align: center;
  }
  #site-footer .footer-col.redes a {
    padding-left: 5px;
    padding-right: 5px;
    margin-left: 5px;
    margin-right: 5px;
  }
  .banderin {
    padding-bottom: 36px;
  }
  .servicios .col-texto {
    padding-top: 0;
    padding-right: calc(var(--bs-gutter-x)/2);
  }
  .lista-servicios {
    padding-top: 30px;
  }
  .lista-servicios .item-servicio-lista h2 {
    font-size: 1.3rem;
    font-weight: 800;
    margin: 0;
    padding: 0;
  }
  .lista-servicios .item-servicio-lista {
    margin-bottom: 10px;
  }
  .ultimos-proyectos {
    flex-wrap: wrap;
  }
  .ultimos-proyectos .item-proyecto-servicios {
    flex: 50%;
  }
  form {
    padding-bottom: 40px;
  }
  .form-dark button {
    margin-top: 1rem;
  }
  .col-contacto:not(:last-child) {
    margin-bottom: 20px;
  }
  .year {
    display: block;
    padding-bottom: 40px;
  }
  .row-staff {
    --bs-gutter-x: 1rem;
    align-items: stretch;
  }
}
@media (min-width: 1200px) {
  .img-8bit {
    margin-top: 40px;
    margin-left: -30px;
    margin-bottom: -40px;
    display: block;
  }
}
@media (max-width: 767.98px) {
  body[data-aos-delay],
  [data-aos-delay] {
    transition-delay: 0ms !important;
  }
  .img-8bit {
    margin-top: 60px;
  }
  :root {
    --swiper-navigation-size: 30px;
  }
  .row.iom,
  .container.iom > .row {
    padding-left: 15px;
    padding-right: 15px;
  }
  h2 {
    font-size: 2.4rem;
    line-height: 2.5rem;
  }
  #site-header .logo img {
    width: 200px;
  }
  .ptb {
    padding-top: 70px;
    padding-bottom: 70px;
  }
  .pb {
    padding-bottom: 70px;
  }
  .sticker {
    font-size: 2.8rem;
    line-height: 1.4rem;
  }
  .sticker.right-down {
    right: 4px;
    bottom: 4px;
  }
  .swiper-container.slider-dinamico .swiper-slide {
    padding-left: 40px;
    padding-right: 40px;
  }
  .swiper-container.slider-dinamico .swiper-slide h2 {
    font-size: 2.4rem;
    line-height: 2.4rem;
    letter-spacing: -1px;
  }
  .swiper-container.slider-dinamico .swiper-slide .frase {
    line-height: 1.6rem;
  }
  .swiper-container.slider-dinamico .swiper-slide .boton-slider {
    padding: 10px 20px;
  }
  .item-proyecto {
    margin-bottom: 15px;
  }
  .galeria {
    height: 1500px;
    grid-template-areas: "f1" "f2" "f4" "f3";
  }
  .navegacion-posts {
    display: flex;
    align-items: center;
  }
  .navegacion-posts h5 {
    display: none;
  }
  .navegacion-posts .span-nav span {
    display: none;
  }
  .navegacion-posts .previous,
  .navegacion-posts .next {
    flex: 100%;
  }
  .navegacion-posts .next {
    text-align: left;
    padding-left: 30px;
  }
  .menu-responsive ul li a {
    font-size: 2.5rem;
    line-height: 3.2rem;
    font-weight: 400;
    padding: 6px 0;
  }
  .main-section {
    padding-top: 170px;
    padding-bottom: 50px;
  }
  .main-section h1.not-so-big {
    font-size: 2.6rem;
    line-height: 2.6rem;
  }
  .main-section h1 {
    font-size: 2.6rem;
    line-height: 2.6rem;
  }
  .main-section .h1-wrapper {
    margin-bottom: 20px;
  }
  .section-contacto {
    padding-top: 150px;
  }
  .portfolio-main-section {
    margin-bottom: -40px;
  }
  .filtros {
    padding-top: 20px;
  }
  .portfolio-main-section .sticker.right-down {
    top: -30px;
    left: 0;
    font-size: 2.5rem;
    line-height: 1.2rem;
    bottom: auto;
    right: auto;
    transform: translateX(0%) rotate(-6deg);
  }
  .center-on-phones {
    text-align: center;
  }
  .advancedcontent .frase h3,
  .advancedcontent .tituloytexto h2 {
    text-transform: uppercase;
    padding: 0;
    margin: 0;
    font-size: 2.4rem;
    line-height: 2.4rem;
    margin-bottom: 15px;
  }
  .advancedcontent .tituloytexto,
  .advancedcontent .texto2col,
  .advancedcontent .frase,
  .advancedcontent .textolink {
    padding-top: 70px;
    padding-bottom: 70px;
  }
  .advancedcontent .columna:not(:last-child) {
    padding-bottom: 20px;
  }
  .integrante h3 {
    font-size: 1.6rem;
    line-height: 1.6rem;
  }
  .integrante span {
    font-size: 0.8rem;
  }
  .galeria-nosotros {
    grid-template-columns: 1fr;
  }
  #site-footer .items-footer .sitemap {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  #site-footer .items-footer .sitemap li {
    display: block;
  }
  #site-footer .items-footer .sitemap li a {
    padding-top: 5px;
    padding-bottom: 5px;
  }
}
@media (min-width: 768px) and (max-width: 991.98px) {
  .main-section {
    padding-top: 170px;
    padding-bottom: 50px;
  }
  .nosotros-main-section .sticker.right-down {
    right: 6px;
    bottom: 7px;
  }
  .swiper-container.slider-dinamico .swiper-slide {
    padding-left: 50px;
    padding-right: 50px;
  }
  .swiper-container.slider-dinamico .swiper-slide h2 {
    font-size: 3.4rem;
    line-height: 3.4rem;
    letter-spacing: -1px;
  }
  .swiper-container.slider-dinamico .swiper-slide .frase {
    line-height: 1.6rem;
  }
  .swiper-container.slider-dinamico .swiper-slide .boton-slider {
    padding: 12px 23px;
  }
  .galeria {
    height: 700px;
    grid-template-areas: "f1 f1 f2 f2 f2 f2" "f4 f4 f4 f3 f3";
  }
  .main-section h1.not-so-big {
    font-size: 3.4rem;
    line-height: 3.4rem;
  }
  .banderin {
    max-width: 70%;
    margin-top: 40px;
    margin-left: auto;
    margin-right: auto;
    /*     text-align: center;
    display: block; */
  }
  .main-section h1 {
    font-size: 4rem;
    line-height: 4rem;
  }
  .main-section .h1-wrapper {
    margin-bottom: 20px;
  }
  .portfolio-main-section {
    margin-bottom: -40px;
  }
  .filtros {
    padding-top: 15px;
  }
  .sitemap {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .slick-slide {
    margin: 0;
  }
  .section-contacto {
    padding-top: 190px;
    padding-bottom: 100px;
  }
  .row-2-col {
    --bs-gutter-x: 3rem !important;
  }
}
@media (min-width: 992px) and (max-width: 1199.98px) {
  .swiper-container.slider-dinamico .swiper-slide {
    padding-left: 70px;
    padding-right: 70px;
  }
  .swiper-container.slider-dinamico .swiper-slide h2 {
    font-size: 3.8rem;
    line-height: 3.8rem;
    letter-spacing: -1.5px;
  }
  .swiper-container.slider-dinamico .swiper-slide .frase {
    line-height: 1.6rem;
  }
  .swiper-container.slider-dinamico .swiper-slide .boton-slider {
    padding: 12px 23px;
  }
  .galeria {
    height: 750px;
  }
  .sitemap {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .main-section h1 {
    font-size: 4.8rem;
    line-height: 4.1rem;
  }
  .col-redes {
    padding-left: 60px;
  }
  .row-staff {
    --bs-gutter-x: 2rem;
    align-items: stretch;
  }
  .integrante h3 {
    font-size: 2rem;
    line-height: 2rem;
  }
}
@media (min-width: 1200px) and (-webkit-device-pixel-ratio: 1.5) {
  :root .swiper-container.slider-dinamico .swiper-slide h2 {
    font-size: 3.5rem;
    line-height: 3.5rem;
  }
}
@media (min-width: 1200px) and (-webkit-device-pixel-ratio: 1.25) {
  :root .swiper-container.slider-dinamico .swiper-slide h2 {
    font-size: 3.5rem;
    line-height: 3.5rem;
  }
}
