@import url(bootstrap-grid.min.css);
.flex {
  display: flex; }

.flex-1 {
  flex: 1; }

.row-grid {
  margin-top: -15px;
  margin-bottom: -15px; }
  .row-grid > * {
    padding-top: 15px;
    padding-bottom: 15px; }

.row-small {
  margin-left: -7.5px;
  margin-right: -7.5px; }
  .row-small > * {
    padding-left: 7.5px;
    padding-right: 7.5px; }

.row-grid-small {
  margin-top: -7.5px;
  margin-bottom: -7.5px;
  margin-left: -7.5px;
  margin-right: -7.5px; }
  .row-grid-small > * {
    padding-top: 7.5px;
    padding-bottom: 7.5px;
    padding-left: 7.5px;
    padding-right: 7.5px; }

.row-grid-big {
  margin-top: -30px;
  margin-bottom: -30px;
  margin-left: -30px;
  margin-right: -30px; }
  .row-grid-big > * {
    padding-top: 30px;
    padding-bottom: 30px;
    padding-left: 30px;
    padding-right: 30px; }

ul:not(.unstyled) {
  list-style-type: none;
  margin: 0;
  padding: 0; }
  ul:not(.unstyled) > li {
    padding-left: 1em;
    position: relative; }
    ul:not(.unstyled) > li::before {
      content: '-';
      position: absolute;
      top: 0;
      left: 0; }

.image-responsive {
  width: 100%;
  display: block; }
  .image-responsive:not(:first-child) {
    margin-top: 30px; }

.image-block {
  margin: auto; }

.mobile-button {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 50px;
  line-height: 50px;
  font-size: 25px;
  text-align: center;
  display: none;
  color: #fe001a; }
  .mobile-button:hover {
    background: #fe001a;
    color: #fff; }

.wrapper {
  overflow: hidden;
  position: relative; }

.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.95);
  color: #fe001a;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10000;
  line-height: 1;
  visibility: hidden;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.25);
  animation-duration: .3s;
  font-weight: bold;
  flex-direction: column; }
  .mobile-menu.animated {
    visibility: visible; }
  .mobile-menu .mobile-nav ul {
    margin: 0 30px; }
    .mobile-menu .mobile-nav ul li {
      margin: 1em 0; }
      .mobile-menu .mobile-nav ul li.active > a {
        color: #000; }
      .mobile-menu .mobile-nav ul li a {
        font-size: 2em; }
        .mobile-menu .mobile-nav ul li a:hover {
          color: #000; }
      .mobile-menu .mobile-nav ul li .fa {
        color: rgba(255, 255, 255, 0.5);
        font-size: 1.5em;
        margin-right: .5em;
        width: 1em;
        text-align: center; }
  .mobile-menu .close {
    position: absolute;
    top: .5em;
    right: .5em;
    font-size: 2em; }
    .mobile-menu .close:hover {
      color: #000; }
  .mobile-menu .tag {
    max-width: 240px;
    margin: 30px auto; }
  .mobile-menu .social {
    font-size: 1.5em; }
    .mobile-menu .social a + a {
      margin-left: .25em; }

.loader {
  position: fixed;
  z-index: 100000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center; }
  .loader img {
    margin: auto; }
  .loader .spin {
    max-width: 50px; }

@-webkit-keyframes rotating /* Safari and Chrome */ {
  from {
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
  to {
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
@keyframes rotating {
  from {
    -ms-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg); }
  to {
    -ms-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg); } }
.rotating {
  -webkit-animation: rotating 2s linear infinite;
  -moz-animation: rotating 2s linear infinite;
  -ms-animation: rotating 2s linear infinite;
  -o-animation: rotating 2s linear infinite;
  animation: rotating 2s linear infinite; }

@font-face {
  font-family: NouvelleVague;
  src: url("../fonts/NouvelleVague.eot");
  src: url("../fonts/NouvelleVague.eot?#iefix") format("embedded-opentype"), url("../fonts/NouvelleVague.woff2") format("woff2"), url("../fonts/NouvelleVague.woff") format("woff"), url("../fonts/NouvelleVague.ttf") format("truetype"), url("../fonts/NouvelleVague.svg#NouvelleVague") format("svg");
  font-weight: 900;
  font-style: normal; }
@font-face {
  font-family: PlayfairDisplay;
  src: url("../fonts/PlayfairDisplay.eot");
  src: url("../fonts/PlayfairDisplay.eot?#iefix") format("embedded-opentype"), url("../fonts/PlayfairDisplay.woff2") format("woff2"), url("../fonts/PlayfairDisplay.woff") format("woff"), url("../fonts/PlayfairDisplay.ttf") format("truetype"), url("../fonts/PlayfairDisplay.svg#PlayfairDisplay") format("svg");
  font-weight: normal;
  font-style: normal; }
@font-face {
  font-family: HelveticaNeue;
  src: url("../fonts/HelveticaNeue.eot");
  src: url("../fonts/HelveticaNeue.eot?#iefix") format("embedded-opentype"), url("../fonts/HelveticaNeue.woff2") format("woff2"), url("../fonts/HelveticaNeue.woff") format("woff"), url("../fonts/HelveticaNeue.ttf") format("truetype"), url("../fonts/HelveticaNeue.svg#HelveticaNeue") format("svg");
  font-weight: normal;
  font-style: normal; }
body {
  font-family: HelveticaNeue, sans-serif;
  font-size: 16px;
  line-height: 1;
  color: #000;
  font-weight: normal; }
  body.menu-active {
    overflow: hidden; }

.row + .row {
  padding-top: 30px; }

.header {
  background: #fff;
  position: relative;
  z-index: 10000;
  font-size: 13px; }
  .header .logo {
    max-height: 70px;
    margin-bottom: -20px;
    margin-top: 20px; }
  .header .clock {
    width: 100px;
    height: 100px;
    right: -50px;
    bottom: -50px;
    position: absolute; }
    .header .clock::before {
      content: '';
      border-radius: 50%;
      border: 4px solid #fe001a;
      position: absolute;
      background: #fff;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0; }
    .header .clock::after {
      content: '';
      width: 4%;
      height: 4%;
      background: #fe001a;
      border-radius: 50%;
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
      margin: auto; }
    .header .clock .minutes-container, .header .clock .hours-container, .header .clock .seconds-container {
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0; }
    .header .clock .hours {
      background: #fe001a;
      height: 20%;
      left: 48%;
      position: absolute;
      top: 30%;
      transform-origin: 50% 100%;
      width: 4%; }
    .header .clock .minutes {
      background: #fe001a;
      height: 40%;
      left: 48%;
      position: absolute;
      top: 10%;
      transform-origin: 50% 100%;
      width: 4%; }
@keyframes rotate {
  100% {
    transform: rotateZ(360deg); } }
    .header .clock .hours-container {
      animation: rotate 43200s infinite steps(60); }
    .header .clock .minutes-container {
      animation: rotate 3600s infinite steps(60); }
    .header .clock .tag {
      height: 35px;
      max-width: initial;
      position: absolute;
      left: calc(100% + 15px);
      top: -5px; }
  .header .inner-container {
    width: 100%;
    max-width: 50%;
    position: relative; }
  .header .nav {
    height: 100%;
    margin-left: 2em; }
    .header .nav ul {
      height: 100%; }
      .header .nav ul li {
        height: 100%; }
        .header .nav ul li.active a {
          background: #f5f4f4; }
        .header .nav ul li a {
          display: flex;
          height: 100%;
          padding: 0 1em;
          align-items: center; }
          .header .nav ul li a:hover {
            background: #f5f4f4; }
  .header .social {
    min-height: 100%;
    font-size: 2em; }
    .header .social a:hover {
      color: #fe001a; }
    .header .social a + a {
      margin-left: .25em; }

.footer {
  background: #f2efeb;
  padding-bottom: 60px;
  font-size: 1.5em; }
  .footer .divider {
    margin: auto;
    transform: translateY(-15px); }
  .footer h2 {
    font-family: PlayfairDisplay;
    font-size: 2em;
    margin: 0;
    color: #fe001a; }
  .footer p {
    margin-bottom: 0; }

.slider {
  min-height: calc(100vh - 70px);
  background-image: radial-gradient(ellipse, #fff, #fff); }

.img-container {
  padding-bottom: 56.25%;
  position: relative; }
  .img-container img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    max-width: 90%;
    max-height: 90%; }

.container {
  position: relative; }

.text-justify {
  text-align: justify; }

.text-right {
  text-align: right; }

.content {
  position: relative;
  padding: 6em 0; }
  .content h3 {
    font-family: NouvelleVague;
    color: #fe001a;
    font-size: 1.5em;
    line-height: .8; }
  .content .row h3 {
    margin: 0; }
    .content .row h3:not(:first-child) {
      margin-top: 1em; }
  .content p {
    line-height: 1.5;
    margin: .5em auto 0; }
  .content h1 {
    font-size: 3em;
    text-align: center;
    position: relative;
    font-family: PlayfairDisplay;
    margin-bottom: 1em; }
    .content h1 strong, .content h1 b {
      display: block;
      font-family: NouvelleVague;
      letter-spacing: -.025em;
      color: #fe001a;
      font-size: 2em; }
    .content h1 small {
      display: block;
      line-height: 1.5; }
  .content.clientes {
    background: #dfdbd5; }
    .content.clientes h1 {
      margin-bottom: 2em; }
  .content.estrategia {
    padding-bottom: 0;
    margin-bottom: -30px;
    z-index: 1; }
    .content.estrategia h1 {
      text-align: left;
      font-size: 2.25em; }
    .content.estrategia p {
      position: absolute;
      top: 10%;
      right: 0;
      line-height: 1.5;
      width: 100%;
      max-width: 240px; }
  .content.redes {
    background: url("../img/arrow-right.png") 0 35% no-repeat #f5f4f4; }
    .content.redes h1 {
      margin-top: 1em; }
      .content.redes h1 strong, .content.redes h1 b {
        font-size: 1.5em; }
    .content.redes .absolute {
      position: absolute;
      left: 0;
      right: 0;
      top: calc(100% - 16px);
      z-index: 1; }
      .content.redes .absolute p {
        font-size: .75em; }
  .content.web {
    padding-top: 12em; }
    .content.web .inner-container {
      max-width: 768px;
      margin: auto; }
    .content.web p {
      margin: 0; }
    .content.web .row {
      padding-top: 15px; }
  .content .background {
    position: absolute;
    bottom: 6em;
    left: 3em; }

.btn-container {
  margin-top: 45px; }

.btn {
  background: #fe001a;
  color: #fff;
  padding: .75em;
  width: 100%;
  display: block;
  text-align: center;
  border-radius: 1em;
  font-family: NouvelleVague;
  font-size: 1.5em;
  cursor: pointer; }

#servicios {
  background: url("../img/long-arrow-left.png") right 50% no-repeat, url("../img/big-arrow-right.png") 10% 70% no-repeat; }
  #servicios::before {
    background: rgba(254, 0, 26, 0.5);
    content: '';
    min-height: 100vh;
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    z-index: -1; }
  #servicios blockquote {
    max-width: 240px;
    margin-left: auto;
    position: relative;
    text-align: right; }
    #servicios blockquote .caret-down {
      position: absolute;
      right: 0;
      margin-top: 5px; }
  #servicios .inner-container {
    max-width: 992px;
    margin: auto;
    margin-top: 60px; }
    #servicios .inner-container .featured-image {
      margin-top: -100px;
      position: relative; }

.box-alt {
  transform: translateY(-21px); }

.box {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 60px;
  font-size: 1.25em;
  overflow: hidden; }
  .box h3 {
    font-family: PlayfairDisplay, sans-serif;
    color: #000;
    line-height: 1;
    margin-bottom: .5em !important; }

.alert {
  padding: 1em;
  border: 2px solid;
  background: #fff;
  text-align: center;
  color: #fe001a;
  font-weight: bold;
  margin-top: 1em; }

#nosotros .inner-container {
  background: rgba(254, 0, 26, 0.5);
  font-size: 1.5em;
  padding: 3em;
  position: relative; }
  #nosotros .inner-container .arrow-right {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% - 44px);
    margin: auto; }
#nosotros .team {
  text-align: center;
  font-size: 1.25em; }
  #nosotros .team .img-container img {
    max-width: 100%;
    max-height: 100%; }
  #nosotros .team h3 {
    font-family: PlayfairDisplay, sans-serif;
    color: #000;
    line-height: 1;
    margin: 0 !important; }
  #nosotros .team h4 {
    line-height: 1;
    margin: 0; }
#nosotros .featured-image {
  transform: translateY(-150px); }

#contacto {
  background: #f2efeb; }
  #contacto form {
    max-width: 576px;
    margin: auto; }
  #contacto .arrow-down {
    margin: auto;
    transform: translateY(-15px); }

.form-group:not(:first-child) {
  margin-top: 15px; }

.form-control {
  width: 100%;
  padding: .5em 1em;
  line-height: 1;
  font-size: 1.25em;
  border: 2px solid; }

.map {
  padding-bottom: 30%;
  position: relative; }
  .map > * {
    position: absolute;
    border: none;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

@media screen and (max-width: 1200px) {
  .header .inner-container {
    max-width: 66.66666666%; }

  .content .background {
    position: static;
    margin: 30px auto; } }
@media screen and (max-width: 992px) {
  .header .inner-container {
    max-width: 66.66666666%; }
  .header .nav {
    margin-left: 1em; }
    .header .nav ul li a {
      padding: 0 .5em; }

  .content.redes {
    background: none; }
  .content h1 {
    font-size: 2.5em; }

  #nosotros .inner-container {
    padding: 2em; }

  .map {
    padding-bottom: 50%; } }
@media screen and (max-width: 768px) {
  .header .inner-container {
    max-width: 50%; }
  .header .clock {
    max-width: 50px;
    max-height: 50px;
    bottom: -25px;
    right: -25px; }
  .header .nav, .header .social {
    display: none; }
  .header .logo {
    max-height: 50px;
    margin-bottom: -15px;
    margin-top: 15px; }

  .slider .row {
    flex-direction: column-reverse; }

  .mobile-button {
    display: block; }

  .wrapper {
    margin-top: 50px; }

  .content.estrategia p {
    position: static; }
  .content h1 {
    font-size: 2em; }
  .content.web {
    padding-top: 0; }
  .content.redes .absolute {
    position: static; }

  #nosotros .inner-container {
    font-size: 1.25em;
    padding: 1.5em;
    margin-bottom: 30px; }
  #nosotros .featured-image {
    transform: none; }

  .content {
    padding: 3em 0; }

  #servicios blockquote {
    margin-bottom: 30px; }

  .map {
    padding-bottom: 75%; } }
@media screen and (max-width: 576px) {
  .content h1 {
    font-size: 1.5em; }

  #nosotros .inner-container {
    font-size: 1em; }

  .map {
    padding-bottom: 100%; }

  .content .background {
    max-width: 240px; } }

/*# sourceMappingURL=main.css.map */
