@import url("https://fonts.googleapis.com/css?family=Playfair+Display:400,900");
.display-block {
  display: block; }

.display-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex; }
  .display-flex.display-flex--row {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row; }
    .display-flex.display-flex--row.flex-dir-reverse {
      -webkit-box-orient: horizontal;
      -webkit-box-direction: reverse;
          -ms-flex-direction: row-reverse;
              flex-direction: row-reverse; }
  .display-flex.display-flex--column {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column; }
    .display-flex.display-flex--column.flex-dir-reverse {
      -webkit-box-orient: vertical;
      -webkit-box-direction: reverse;
          -ms-flex-direction: column-reverse;
              flex-direction: column-reverse; }

.flex-grow--1 {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1; }

.pos-rel {
  position: relative; }

.pos-absolute {
  position: absolute; }

.pos-fixed {
  position: fixed; }

.top-left-0 {
  top: 0;
  left: 0; }

.margin-center {
  margin: 0 auto; }

.colour-primary {
  color: #333; }

.colour-accent {
  color: #777; }

.text-colour--default {
  color: #777; }

.is-white {
  color: #fff; }

.is-black {
  color: #000; }

.text-upper {
  text-transform: uppercase; }

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

.height--100 {
  height: 100%; }
  .height--100-is-vh {
    height: 100vh; }

.width--100 {
  width: 100%; }
  .width--100-is-vw {
    width: 100vw; }

.layout-m-r--1 {
  margin-right: 8px; }

.layout-m-r--2 {
  margin-right: 16px; }

.layout-m-r--3 {
  margin-right: 32px; }

.layout-m-r--4 {
  margin-right: 64px; }

.layout-m-r--5 {
  margin-right: 128px; }

.layout-m-l--1 {
  margin-left: 8px; }

.layout-m-l--2 {
  margin-left: 16px; }

.layout-m-l--3 {
  margin-left: 32px; }

.layout-m-l--4 {
  margin-left: 64px; }

.layout-m-l--5 {
  margin-left: 128px; }

.layout-m-b--1 {
  margin-bottom: 8px; }

.layout-m-b--2 {
  margin-bottom: 16px; }

.layout-m-b--3 {
  margin-bottom: 32px; }

.layout-m-b--4 {
  margin-bottom: 64px; }

.layout-m-b--5 {
  margin-bottom: 128px; }

.layout-m-t--1 {
  margin-top: 8px; }

.layout-m-t--2 {
  margin-top: 16px; }

.layout-m-t--3 {
  margin-top: 32px; }

.layout-m-t--4 {
  margin-top: 64px; }

.layout-m-t--5 {
  margin-top: 128px; }

.layout-p-r--1 {
  padding-right: 8px; }

.layout-p-r--2 {
  padding-right: 16px; }

.layout-p-r--3 {
  padding-right: 32px; }

.layout-p-r--4 {
  padding-right: 64px; }

.layout-p-r--5 {
  padding-right: 128px; }

.layout-p-l--1 {
  padding-left: 8px; }

.layout-p-l--2 {
  padding-left: 16px; }

.layout-p-l--3 {
  padding-left: 32px; }

.layout-p-l--4 {
  padding-left: 64px; }

.layout-p-l--5 {
  padding-left: 128px; }

.layout-p-b--1 {
  padding-bottom: 8px; }

.layout-p-b--2 {
  padding-bottom: 16px; }

.layout-p-b--3 {
  padding-bottom: 32px; }

.layout-p-b--4 {
  padding-bottom: 64px; }

.layout-p-b--5 {
  padding-bottom: 128px; }

.layout-p-t--1 {
  padding-top: 8px; }

.layout-p-t--2 {
  padding-top: 16px; }

.layout-p-t--3 {
  padding-top: 32px; }

.layout-p-t--4 {
  padding-top: 64px; }

.layout-p-t--5 {
  padding-top: 128px; }

.hidden {
  display: none; }
  @media screen and (max-width: 3839px) {
    .hidden--lt-xl {
      display: none; } }
  @media screen and (min-width: 3839px) {
    .hidden--gt-xl {
      display: none; } }
  @media screen and (max-width: 1919px) {
    .hidden--lt-lg {
      display: none; } }
  @media screen and (min-width: 1919px) {
    .hidden--gt-lg {
      display: none; } }
  @media screen and (max-width: 1279px) {
    .hidden--lt-md {
      display: none; } }
  @media screen and (min-width: 1279px) {
    .hidden--gt-md {
      display: none; } }
  @media screen and (max-width: 959px) {
    .hidden--lt-sm {
      display: none; } }
  @media screen and (min-width: 959px) {
    .hidden--gt-sm {
      display: none; } }
  @media screen and (max-width: 319px) {
    .hidden--lt-xs {
      display: none; } }
  @media screen and (min-width: 319px) {
    .hidden--gt-xs {
      display: none; } }

.container .showcase {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 100%; }
  .container .showcase .showcase-item {
    width: 25%;
    padding: 8px; }
    .container .showcase .showcase-item .showitem-img {
      border-radius: 8px; }
      .container .showcase .showcase-item .showitem-img img {
        padding: 16px;
        width: 100%; }
  .container .showcase .showitem-desc {
    font-size: 16px;
    line-height: 1.5;
    margin: 16px 0; }

.container .section-title {
  font-size: 48px; }

.container .section-desc {
  font-size: 20px;
  font-weight: 300;
  line-height: 30px;
  margin: 24px 0; }

.container .overlay-black {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background: transparent;
  opacity: 0.7;
  transition: background 0.5s ease; }
  .container .overlay-black.show {
    display: block;
    background: #111; }

.container #profileOverlay {
  -webkit-transform: scale(0);
          transform: scale(0);
  min-height: 60vh;
  width: 100%;
  top: 12%;
  transition: all 0.5s ease;
  z-index: 999; }
  .container #profileOverlay .profile-wrapper {
    width: 40vw;
    background: #fff;
    padding: 16px 24px;
    margin: 0 auto;
    position: relative;
    border-radius: 4px; }
    .container #profileOverlay .profile-wrapper section {
      padding: 16px 0; }
      .container #profileOverlay .profile-wrapper section#profileTop {
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center; }
        .container #profileOverlay .profile-wrapper section#profileTop .profile-image {
          background: url("../images/profile_picture_SMALL.jpg") top no-repeat;
          background-size: cover;
          height: 100px;
          width: 100px;
          border-radius: 3rem; }
      .container #profileOverlay .profile-wrapper section#profileMiddle .section-desc {
        margin: 0; }
        .container #profileOverlay .profile-wrapper section#profileMiddle .section-desc .tech-pics {
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center; }
          .container #profileOverlay .profile-wrapper section#profileMiddle .section-desc .tech-pics img {
            height: 40px;
            margin: 0 4px; }
      .container #profileOverlay .profile-wrapper section#profileBottom .profile-links {
        text-align: right; }
        .container #profileOverlay .profile-wrapper section#profileBottom .profile-links a {
          color: #194e93; }
    .container #profileOverlay .profile-wrapper .overlay-close {
      position: absolute;
      top: 16px;
      right: 24px;
      color: #333;
      padding: 8px;
      cursor: default; }
  .container #profileOverlay.overlay-shown {
    -webkit-transform: scale(1);
            transform: scale(1); }

.container #navbar {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 32px 0; }
  .container #navbar #siteLogo svg {
    width: 4.4vw; }
  .container #navbar #menuList .menu-link {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.2px;
    transition: color 0.3s ease; }
    .container #navbar #menuList .menu-link.menu-link--about {
      padding-bottom: 8px;
      border-bottom: 2px solid; }
    .container #navbar #menuList .menu-link:hover {
      color: #777777; }

.container #main #sectionTopBanner .section-desc {
  max-width: 42vw;
  margin: 16px auto 0; }

.container #main #sectionWinBanner {
  margin: 0 -64px;
  background: #f4f4f4; }
  .container #main #sectionWinBanner .win-image img {
    width: 80%; }
  .container #main #sectionWinBanner .win-desc {
    max-width: 40%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center; }

.container #main #sectionWork .showcase .showcase-item.work-io .showitem-img {
  background: #941B80; }

.container #main #sectionWork .showcase .showcase-item.work-doppio .showitem-img {
  background: #4373DF; }

.container #main #sectionWork .showcase .showcase-item.work-localgusto .showitem-img {
  background: #F88B69; }

.container #main #sectionWork .showcase .showcase-item.work-mila .showitem-img {
  background: #56AFEA; }

.container #main #sectionWork .showcase .showcase-item .showitem-img img {
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out; }

.container #main #sectionWork .showcase .showcase-item .showitem-img:hover img, .container #main #sectionWork .showcase .showcase-item .showitem-img:focus img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1); }

.container #main #sectionCustomer .showcase .showcase-item {
  width: calc(100% / 3); }
  .container #main #sectionCustomer .showcase .showcase-item .showitem-img {
    min-height: 256px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    text-align: center;
    background: #f4f4f4; }
    .container #main #sectionCustomer .showcase .showcase-item .showitem-img img {
      width: 50%; }

.container #main #sectionCareers .showcase .showcase-item {
  width: calc(100% / 3 - 16px);
  background: #f4f4f4;
  margin: 8px;
  padding: 32px;
  border-radius: 8px;
  transition: background 0.3s ease-in-out; }
  .container #main #sectionCareers .showcase .showcase-item .job-post {
    font-size: 24px;
    margin-bottom: 16px;
    color: #357edd; }
  .container #main #sectionCareers .showcase .showcase-item .job-time {
    color: #999;
    margin-bottom: 8px; }
  .container #main #sectionCareers .showcase .showcase-item .job-loc {
    color: #777; }
  .container #main #sectionCareers .showcase .showcase-item:hover {
    background: rgba(0, 0, 0, 0.1); }

.container #main #sectionAbout .about-us-content {
  margin-top: 24px; }
  .container #main #sectionAbout .about-us-content .section-desc {
    min-width: 50%;
    margin: 0; }
  .container #main #sectionAbout .about-us-content .address-info {
    margin-bottom: 32px; }
    .container #main #sectionAbout .about-us-content .address-info .address, .container #main #sectionAbout .about-us-content .address-info .directions {
      margin: 16px 0;
      font-size: 16px;
      color: #777;
      line-height: 1.5; }

.container #main #sectionAbout #officeMap .overlay-maps {
  background: transparent;
  position: relative;
  height: 400px;
  width: 100%;
  top: 400px;
  margin-top: -400px; }

.container footer {
  margin: 0 -64px;
  background: #f4f4f4; }
  .container footer .social-links {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center; }
    .container footer .social-links .social-link {
      color: #c4c4c4;
      transition: color 0.3s ease; }
      .container footer .social-links .social-link[title="LinkedIn"]:hover {
        color: #2386BB; }
      .container footer .social-links .social-link[title="Facebook"]:hover {
        color: #3B5B97; }
      .container footer .social-links .social-link[title="Twitter"]:hover {
        color: #28A3F1; }
