/*! HTML5 Boilerplate v7.2.0 | MIT License | https://html5boilerplate.com/ */

/* main.css 2.0.0 | MIT License | https://github.com/h5bp/main.css#readme */
/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html {color: #212529; font-size: 1em; line-height: 1.4; background: #212529;}
body {}
img {width: 100%; height: auto;}
a, button {text-decoration: none; transition: all 0.3s;}
a {color: rgba(33,37,41,1);}
a:hover {color: rgba(33,37,41,0.7);}
body.menu-open {overflow: hidden;}

.header-main, .menu, .hero, .services, .work, .page-header, .contact, .fade, .footer {animation-name: main; animation-delay: 0.5s; animation-duration: 1s; animation-fill-mode: both;}

@keyframes main {
    0%   {transform: translate(0,0); opacity: 0;}
    100% {transform: translate(0,0); opacity: 1;}
}

/*
 * Remove text-shadow in selection highlight:
 * https://twitter.com/miketaylr/status/12228805301
 *
 * Vendor-prefixed and regular ::selection selectors cannot be combined:
 * https://stackoverflow.com/a/16982510/7133471
 *
 * Customize the background color to match your design.
 */

::-moz-selection {background: #e5e5e5; text-shadow: none;}
::selection {background: #e5e5e5; text-shadow: none;}

/*
 * A better looking default horizontal rule
 */

hr {display: none;}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers:
 * https://github.com/h5bp/html5-boilerplate/issues/440
 */

audio, canvas, iframe, img, svg, video {vertical-align: middle;}

/*
 * Remove default fieldset styles.
 */

fieldset {border: 0; margin: 0; padding: 0;}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {resize: vertical;}

/* ==========================================================================
   Browser Upgrade Prompt
   ========================================================================== */

.browserupgrade {margin: 0.2em 0; background: #ccc; color: #000; padding: 0.2em 0;}

/* ==========================================================================
   Styles By irwincreative.co.uk
   ========================================================================== */
   
 /* ==========================================================================
   Fonts
   ========================================================================== */
 
 @font-face {
  font-family: 'icomoon';
  src:  url('/fonts/icomoon.eot?e6lrib');
  src:  url('/fonts/icomoon.eot?e6lrib#iefix') format('embedded-opentype'),
    url('/fonts/icomoon.ttf?e6lrib') format('truetype'),
    url('/fonts/icomoon.woff?e6lrib') format('woff'),
    url('/fonts/icomoon.svg?e6lrib#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}

[class^="icon-"], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


.icon-ic-down-arrow:before {
  content: "\e900";
}
.icon-ic-email:before {
  content: "\e901";
}
.icon-ic-phone:before {
  content: "\e902";
}
.icon-ic-play:before {
  content: "\e903";
}


   
/* ==========================================================================
   Default Fonts
   ========================================================================== */
   
h1 {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal; letter-spacing: 0.025em;}
h1 strong {margin: 0; font-family: montserrat, sans-serif; font-weight: 800; font-style: normal; letter-spacing: 0.025em;}
h2 {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal; letter-spacing: 0.05em;}
h3 {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal; letter-spacing: 0.05em;}
h4 {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal;}
h5 {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal;}
h6 {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal;}
p {margin: 0; font-family: montserrat, sans-serif; font-weight: 100; font-style: normal;}
span {margin: 0; font-family: montserrat, sans-serif; font-weight: 100; font-style: normal;}
ul li {margin: 0; font-family: montserrat, sans-serif; font-weight: 100; font-style: normal;}
ol li {margin: 0; font-family: montserrat, sans-serif; font-weight: 100; font-style: normal;}
small {margin: 0; font-family: montserrat, sans-serif; font-weight: 100; font-style: normal;}
label {margin: 0; font-family: montserrat, sans-serif; font-weight: 600; font-style: normal; text-transform: uppercase;}
input {margin: 0; font-family: montserrat, sans-serif; font-weight: 300; font-style: normal; letter-spacing: 0.05em;}
select {margin: 0; font-family: montserrat, sans-serif; font-weight: 300; font-style: normal; letter-spacing: 0.05em;}
textarea {margin: 0; font-family: montserrat, sans-serif; font-weight: 300; font-style: normal;}
.date {margin: 0; display: none;}

/* ==========================================================================
   Margin
   ========================================================================== */

.m-1 {margin: 1em;}
.m-2 {margin: 2em;}
.m-3 {margin: 3em;}
.m-4 {margin: 4em;}
.m-5 {margin: 5em;}
   
.mx-1 {margin-left: 1em; margin-right: 1em;}
.mx-2 {margin-left: 2em; margin-right: 2em;}
.mx-3 {margin-left: 3em; margin-right: 3em;}
.mx-4 {margin-left: 4em; margin-right: 4em;}
.mx-5 {margin-left: 5em; margin-right: 5em;}

.ml-1 {margin-left: 1em;}
.ml-2 {margin-left: 2em;}
.ml-3 {margin-left: 3em;}
.ml-4 {margin-left: 4em;}
.ml-5 {margin-left: 5em;}

.mr-1 {margin-right: 1em;}
.mr-2 {margin-right: 2em;}
.mr-3 {margin-right: 3em;}
.mr-4 {margin-right: 4em;}
.mr-5 {margin-right: 5em;}  
   
.my-1 {margin-top: 1em;  margin-bottom: 1em;}
.my-2 {margin-top: 2em;  margin-bottom: 2em;}
.my-3 {margin-top: 3em;  margin-bottom: 3em;}
.my-4 {margin-top: 4em;  margin-bottom: 4em;}
.my-5 {margin-top: 5em;  margin-bottom: 5em;}

.mt-1 {margin-top: 1em;}
.mt-2 {margin-top: 2em;}
.mt-3 {margin-top: 3em;}
.mt-4 {margin-top: 4em;}
.mt-5 {margin-top: 5em;}

.mb-1 {margin-bottom: 1em;}
.mb-2 {margin-bottom: 2em;}
.mb-3 {margin-bottom: 3em;}
.mb-4 {margin-bottom: 4em;}
.mb-5 {margin-bottom: 5em;}

@media screen and (max-width: 900px) {
	.m-2 {margin: 1em;}
	.m-3 {margin: 1.5em;}
	.m-4 {margin: 2em;}
	.m-5 {margin: 3em;}
	
	.mx-2 {margin-left: 1em; margin-right: 1em;}
	.mx-3 {margin-left: 1.5em; margin-right: 1.5em;}
	.mx-4 {margin-left: 2em; margin-right: 2em;}
	.mx-5 {margin-left: 3em; margin-right: 3em;}
	
	.ml-2 {margin-left: 1em;}
	.ml-3 {margin-left: 1.5em;}
	.ml-4 {margin-left: 2em;}
	.ml-5 {margin-left: 3em;}
	
	.mr-2 {margin-right: 1em;}
	.mr-3 {margin-right: 1.5em;}
	.mr-4 {margin-right: 2em;}
	.mr-5 {margin-right: 3em;}  

	.my-2 {margin-top: 1em; margin-bottom: 1em;}
	.my-3 {margin-top: 1.5em; margin-bottom: 1.5em;}
	.my-4 {margin-top: 2em; margin-bottom: 2em;}
	.my-5 {margin-top: 3em; margin-bottom: 3em;}
	
	.mt-2 {margin-top: 1em}
	.mt-3 {margin-top: 1.5em;}
	.mt-4 {margin-top: 2em;}
	.mt-5 {margin-top: 3em;}
	
	.mb-2 {margin-bottom: 1em;}
	.mb-3 {margin-bottom: 1.5em;}
	.mb-4 {margin-bottom: 2em;}
	.mb-5 {margin-bottom: 3em;}
}

/* ==========================================================================
   Padding
   ========================================================================== */

.p-1 {padding: 1em;}
.p-2 {padding: 2em;}
.p-3 {padding: 3em;}
.p-4 {padding: 4em;}
.p-5 {padding: 5em;}
   
.px-1 {padding-left: 1em; padding-right: 1em;}
.px-2 {padding-left: 2em; padding-right: 2em;}
.px-3 {padding-left: 3em; padding-right: 3em;}
.px-4 {padding-left: 4em; padding-right: 4em;}
.px-5 {padding-left: 5em; padding-right: 5em;}

.pl-1 {padding-left: 1em;}
.pl-2 {padding-left: 2em;}
.pl-3 {padding-left: 3em;}
.pl-4 {padding-left: 4em;}
.pl-5 {padding-left: 5em;}

.pr-1 {padding-right: 1em;}
.pr-2 {padding-right: 2em;}
.pr-3 {padding-right: 3em;}
.pr-4 {padding-right: 4em;}
.pr-5 {padding-right: 5em;}  
   
.py-1 {padding-top: 1em; padding-bottom: 1em;}
.py-2 {padding-top: 2em; padding-bottom: 2em;}
.py-3 {padding-top: 3em; padding-bottom: 3em;}
.py-4 {padding-top: 4em; padding-bottom: 4em;}
.py-5 {padding-top: 5em; padding-bottom: 5em;}

.pt-1 {padding-top: 1em;}
.pt-2 {padding-top: 2em;}
.pt-3 {padding-top: 3em;}
.pt-4 {padding-top: 4em;}
.pt-5 {padding-top: 5em;}

.pb-1 {padding-bottom: 1em;}
.pb-2 {padding-bottom: 2em;}
.pb-3 {padding-bottom: 3em;}
.pb-4 {padding-bottom: 4em;}
.pb-5 {padding-bottom: 5em;}

@media screen and (max-width: 900px) {
	.p-1 {padding: 0.5em;}
	.p-2 {padding: 1em;}
	.p-3 {padding: 1.5em;}
	.p-4 {padding: 2em;}
	.p-5 {padding: 3em;}
	   
	.px-1 {padding-left: 0.5em; padding-right: 0.5;}
	.px-2 {padding-left: 1em; padding-right: 1em;}
	.px-3 {padding-left: 1.5em; padding-right: 1.5em;}
	.px-4 {padding-left: 2em; padding-right: 2em;}
	.px-5 {padding-left: 3em; padding-right: 3em;}
	
	.pl-1 {padding-left: 0.5em;}
	.pl-2 {padding-left: 1em;}
	.pl-3 {padding-left: 1.5em;}
	.pl-4 {padding-left: 2em;}
	.pl-5 {padding-left: 3em;}
	
	.pr-1 {padding-right: 0.5em;}
	.pr-2 {padding-right: 1em;}
	.pr-3 {padding-right: 1.5em;}
	.pr-4 {padding-right: 2em;}
	.pr-5 {padding-right: 3em;}  
	   
	.py-1 {padding-top: 0.5em; padding-bottom: 0.5em;}
	.py-2 {padding-top: 1em; padding-bottom: 1em;}
	.py-3 {padding-top: 1.5em; padding-bottom: 1.5em;}
	.py-4 {padding-top: 2em; padding-bottom: 2em;}
	.py-5 {padding-top: 3em; padding-bottom: 3em;}
	
	.pt-1 {padding-top: 0.5em;}
	.pt-2 {padding-top: 1em}
	.pt-3 {padding-top: 1.5em;}
	.pt-4 {padding-top: 2em;}
	.pt-5 {padding-top: 3em;}
	
	.pb-1 {padding-bottom: 0.5em;}
	.pb-2 {padding-bottom: 1em;}
	.pb-3 {padding-bottom: 1.5em;}
	.pb-4 {padding-bottom: 2em;}
	.pb-5 {padding-bottom: 3em;}

}


/* ==========================================================================
   Page Header
   ========================================================================== */
   
.page-header {padding: 0 0 10vh 0; display: flex; justify-content: center; align-items: flex-end; align-content: flex-end; text-align: center; height: 50vh; position: absolute; top: 0; width: 100%; color: #ffffff; overflow: hidden; box-sizing: border-box;}
.page-header::after {content: ' '; opacity: 0.1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: 1; background-image: url('/img/slash-white.svg'); background-size: contain; background-repeat: no-repeat; background-position: bottom right; height: 100vh;}
.page-header h1 {margin: 0; padding: 0 0 0.25em 0; font-size: 4em; text-align: center; font-weight: 700; line-height: 1.2; text-transform: none; letter-spacing: 0.005em; text-shadow: 2px 2px 2px rgba(33, 18, 58, 0.4);}
.page-header h2 {margin: 0; padding: 0; text-transform: inherit; font-weight: 100; font-size: 1.5em; line-height: 1.2;}
.page-header h2:after {margin: 1em auto 0 auto; content: ''; height: 2px; width: 50px; transition: 0.3s ease-in-out; background: #ffffff; display: flex; justify-content: center;}

.page-header .image {content: ""; opacity: 0.1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-size: cover; background-repeat: no-repeat; background-position: center center;}

@media screen and (max-width: 1024px) {
	.page-header .image.desktop {display: none;}
}

@media screen and (min-width: 1024px) {
	.page-header .image.mobile {display: none;}
	.page-header .image.desktop {display: block;}
}

@media screen and (orientation: portrait) {
	.page-header::after {background-size: cover;}
}

@media screen and (max-width: 1100px) {
	.page-header h1 {font-size: 3em;}
	.page-header h2 {font-weight: 300;}	
}

@media screen and (orientation: landscape) and (max-width: 900px) {
	.page-header {padding: 0 0 15vh 0; height: 80vh;}
}

@media screen and (orientation: portrait) and (max-width: 900px) {
	.page-header {height: 45vh;}
}

@media screen and (orientation: landscape) and (max-width: 700px) {
	.page-header h1 {font-size: 2.5em;}
	.page-header h2 {font-size: 1.25em;}
}

@media screen and (max-width: 640px)  {
	.page-header {padding: 85px 0 0 0; align-items: center;}
	.page-header h1 {font-size: 2.5em;}
	.page-header h2 {font-size: 1.25em;}
}

@media screen and (max-width: 480px) {
	.page-header {font-size: 80%;}
}

/* ==========================================================================
   Section Header
   ========================================================================== */
   
.section-header {margin: 0 0 2em 0; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; width: 100%;}
.section-header h2 {margin: 0; padding: 0 0 0.25em 0; font-size: 3em; line-height: 1;}
.section-header h3 {margin: 0 0 1em 0; padding: 0; text-transform: inherit; font-weight: 300; font-size: 1.5em; line-height: 1.3;}
.section-header h3:after {margin: 20px auto 0 auto; content: ''; height: 2px; width: 50px; transition: 0.3s ease-in-out; background: #343A40; display: flex; justify-content: center;}

.section-header-small {margin: 0 0 2em 0; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; width: 100%;}
.section-header-small h2 {margin: 0; padding: 0 0 0.25em 0; font-size: 2em; line-height: 1;}
.section-header-small h3 {margin: 0; padding: 0; text-transform: inherit; font-weight: 300; font-size: 1.25em; line-height: 1.3;}
.section-header-small h3:after {margin: 15px auto 0 auto; content: ''; height: 2px; width: 50px; transition: 0.3s ease-in-out; background: #343A40; display: flex; justify-content: center;}

@media screen and (max-width: 900px) {
	.section-header {margin: 0 auto 2em auto; font-size: 80%; width: 90%;}
}

@media screen and (max-width: 480px) {
	.section-header {font-size: 70%;}
}

/* ==========================================================================
   Section Header Reverse
   ========================================================================== */

.section-header.reverse {display: flex; flex-direction: column-reverse;}
.section-header.reverse h2 {padding: 0 0 1em 0;}
.section-header.reverse h2:after {margin: 20px auto 0 auto; content: ''; height: 2px; width: 50px; transition: 0.3s ease-in-out; background: #343A40; display: flex;}
.section-header.reverse h3 {margin: 0 0 0 0; padding: 0 0 0.5em 0;}
.section-header.reverse h3:after {display: none;}

/* ==========================================================================
   Section Header Left
   ========================================================================== */
   
.section-header.left {align-items: flex-start; width: 100%; text-align: left;}
.section-header.left h2:after {margin: 20px 0 0 0; justify-content: flex-start;}
.section-header.left h3:after {margin: 20px 0 0 0; justify-content: flex-start;}

.section-header-small.left {align-items: flex-start; width: 100%; text-align: left;}
.section-header-small.left h2:after {margin: 20px 0 0 0; justify-content: flex-start;}
.section-header-small.left h3:after {margin: 20px 0 0 0; justify-content: flex-start;}


/* ==========================================================================
   Article Header
   ========================================================================== */

.article-header {margin: 0 0 2em 0; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; width: 100%;}
.article-header h2 {margin: 0; padding: 0 0 0.25em 0; font-size: 2em; line-height: 1.2;}
.article-header h3 {margin: 0; padding: 0; text-transform: inherit; font-weight: 300; font-size: 1.25em; line-height: 1.3;}
.article-header h3:after {margin: 15px auto 0 auto; content: ''; height: 2px; width: 50px; transition: 0.3s ease-in-out; background: #343A40; display: flex; justify-content: center;}

.article-header-small {margin: 0 0 2em 0; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; width: 100%;}
.article-header-small h2 {margin: 0; padding: 0 0 0.25em 0; font-size: 2em; line-height: 1.2;}
.article-header-small h3 {margin: 0; padding: 0; text-transform: inherit; font-weight: 300; font-size: 1.25em; line-height: 1.3;}
.article-header-small h3:after {margin: 15px auto 0 auto; content: ''; height: 2px; width: 50px; transition: 0.3s ease-in-out; background: #343A40; display: flex; justify-content: center;}

/* ==========================================================================
   Article Header Left
   ========================================================================== */
   
.article-header.left {align-items: flex-start; width: 100%; text-align: left;}
.article-header.left h2:after {margin: 20px 0 0 0; justify-content: flex-start;}
.article-header.left h3:after {margin: 20px 0 0 0; justify-content: flex-start;}

.article-header-small.left {align-items: flex-start; width: 100%; text-align: left;}
.article-header-small.left h2:after {margin: 20px 0 0 0; justify-content: flex-start;}
.article-header-small.left h3:after {margin: 20px 0 0 0; justify-content: flex-start;}

/* ==========================================================================
   Background Colors
   ========================================================================== */
   
.blue {background: #A4CBEC;}
.purple {background: #45278D;}
.green {background: #C7D66F;}
.dark {background: #212529;}
.grey {background: #343A40;}
.purple-dark.gradient {background: rgb(33,18,58); background: linear-gradient(45deg, rgba(33,18,58,1) 25%, rgba(144,89,255,1) 100%);}
.purple.gradient {background: rgb(144,89,255); background: linear-gradient(-45deg, rgba(144,89,255,1) 25%, rgba(255,79,95,1) 75%, rgba(255,135,63,1) 100%);}
.teal.gradient {background: rgb(0,221,233); background: linear-gradient(-45deg, rgba(2,149,166,1) 25%, rgba(7,191,188,1) 75%, rgba(0,221,233,1) 100%);}
.orange.gradient {background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,79,95,1) 25%, rgba(255,135,63,1) 100%);}
.orange-reverse.gradient {background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,135,63,1) 25%, rgba(255,79,95,1) 100%);}
.grey.gradient {background: rgb(52,58,64); background: linear-gradient(-45deg, rgba(52,58,64,1) 0%, rgba(33,37,41,1) 100%);}
.grey-dark.gradient {background: rgb(52,58,64); background: linear-gradient(-45deg, rgba(33,37,41,1) 0%, rgba(33,37,41,1) 100%);}
.lightgrey.gradient {background: rgb(230,230,230); background: linear-gradient(-45deg, rgba(230,230,230,1) 0%, rgba(255,255,255,1) 100%);}
.white.gradient {background: rgb(255,255,255); background: linear-gradient(-45deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 100%);}
.icon-dark {position: relative; overflow: hidden; width: 100vw;}
.icon-dark::before {content: ""; opacity: 0.1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background: url('/img/icon-dark-bg.svg') 0 0 repeat; background-size: 50px;}
.slash-dark-reverse {position: relative; overflow: hidden; width: 100vw;}
.slash-dark-reverse::before {content: ""; opacity: 0.05; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background: url('/img/slash-grey-reverse.svg'); background-size: cover; background-repeat: no-repeat; background-position: top right;}
.dark-slashes {background: #e5e5e5 repeating-linear-gradient(-70deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0) 50px, rgba(33, 37, 41, 0.04) 50px, rgba(33, 37, 41, 0.04) 150px); -webkit-backface-visibility: hidden; outline: 1px solid transparent;}

.hexagon-dark {position: relative; z-index: 9000; content: ' '; top: 0; width: 100%;}
.hexagon-dark::after {content: ' '; opacity: 0.03; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-image: url('/img/hex-dark-bg.svg'); background-size: cover; background-repeat: no-repeat; background-position: right bottom; height: 100%;}

.hexagon-color {position: relative; z-index: 9000; content: ' '; top: 0; width: 100%;}
.hexagon-color::after {content: ' '; opacity: 1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-image: url('/img/hex-grad-bg.svg'); background-size: cover; background-repeat: no-repeat; background-position: right bottom; height: 100%;}

.play-dark {position: relative; z-index: 9000; content: ' '; top: 0; width: 100%;}
.play-dark::after {content: ' '; opacity: 0.075; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-image: url('/img/ic-play.svg'); background-size: cover; background-repeat: no-repeat; background-position: 95% 95%; height: 100%;}

@media screen and (max-width: 640px) {
	.hexagon-dark::after {height: 200vh; background-position: center center;}
}

/* ==========================================================================
   Wrapper
   ========================================================================== */
   
.wrapper {margin: 0 auto; padding: 0;}
.hero .wrapper {display: flex; justify-content: center; align-items: center; width: 70%;}
.key-services .wrapper {width: 70%;}

.narrow {width: 90%;}

@media screen and (min-width: 1600px) {
	.wrapper {margin: 0 auto; font-size: 100%; width: 1500px;}
	.site-header.wrapper {font-size: 100%; width: 100%;}
}

@media screen and (max-width: 1800px) {
	.key-services .wrapper {width: 80%;}
}

@media screen and (max-width: 1600px) {
	.wrapper {margin: 0 auto; width: 90%;}
	.site-header.wrapper {width: 100%;}
	.hero .wrapper {width: 80%;}
	.footer .wrapper {width: 90%}
}

@media screen and (max-width: 1400px) {
	.key-services .wrapper {width: 90%;}
}

@media screen and (max-width: 900px) {
	.footer .wrapper {width: 90%}
}

@media screen and (max-width: 640px) {
	.hero .wrapper {width: 85%;}
	.page-header .wrapper {width: 85%;}
}


 /* ==========================================================================
   Container
   ========================================================================== */
   
@media screen and (max-width: 1400px) {
	.container {margin: 0 auto; width: 90%;}
	.work .container {margin: 0 auto; width: 100%;}
	.services .container {margin: 0 auto; width: 100%;}
} 
   


/* ==========================================================================
   Header
   ========================================================================== */
   
.site-header {margin: 0; padding: 0; height: 100vh; min-height: 100vh; position: relative; width: 100%; overflow: hidden;}
.site-header.global {margin: 0; padding: 0; height: 50vh; min-height: 50vh; position: relative; width: 100%; overflow: hidden;}

@media screen and (orientation: portrait) and (max-width: 900px) {	
	.site-header.global {height: 45vh; min-height: 45vh;}
}

@media screen and (orientation: landscape) and (max-width: 900px) {	
	.site-header.global {height: 80vh; min-height: 80vh;}
}


   
/* ==========================================================================
   Header Main
   ========================================================================== */

.header-main {margin: 0; padding: 0; position: absolute; top: 35px; left: 35px; z-index: 9996;}
.header-main .header-logo-title {display: none;}
.header-main .header-logo-image a {display: block; opacity: 1;}
.header-main .header-logo-image a:hover {display: block; opacity: 0.7;}
.header-main .header-logo-image img {width: auto; height: 80px; max-height: 80px;}

@media screen and (max-width: 900px) {
	.header-main .header-logo-image img {height: 60px; max-height: 60px;}
}

@media screen and (max-width: 480px) {
	.header-main {top: 25px; left: 25px;}
}


/* ==========================================================================
   Flex Area
   ========================================================================== */
   
.flex-area {display: flex; flex-direction: row; justify-content: space-between;}
.flex-area .section-header {width: 65%;}

.work .flex-area {margin: 0 auto; width: 90%;}

@media screen and (max-width: 800px) {
	.flex-area {flex-direction: column; justify-content: flex-start;}
	.flex-area .section-header {width: 100%;}
}


/* ==========================================================================
  Menu
   ========================================================================== */

.menu {position: absolute; top: 25px; right: 35px; z-index: 9999;}
.menu .menu-wrapper {display: flex; flex-direction: row-reverse; justify-content: flex-end; align-items: center;}

@media screen and (max-width: 800px) {	
	body.menu-open .menu .menu-wrapper {margin-left: 25px;}
}

@media screen and (orientation: landscape) and (max-width: 900px) {	
	body.menu-open .menu .menu-wrapper {flex-direction: column;}
}

@media screen and (max-width: 480px) {
	.menu {top: 15px; right: 10px;}
}

/* ==========================================================================
   Menu Button
   ========================================================================== */

.menu .menu-button {margin: 0; padding: 10px; background: none; border: none; display: flex; flex-direction: column; position: relative; width: 50px; height: 50px; overflow: hidden; font-size: 0; top: 0; right: 0; box-sizing: content-box!important; cursor: pointer; transition: 0.5s ease-in-out; z-index: 9999;}
.menu .menu-button:focus {outline: none;}
.menu .menu-button span.menu-button-box {width: 50px; display: block;}
.menu .menu-button span.menu-button-box span.menu-button-inner {display: block; position: absolute; top: 15px; right: 10px; height: 1px; background: #343A40; width: 45px; transition: 0.3s ease-in-out;}
.menu .menu-button span.menu-button-box span.menu-button-inner::before {display: block; position: absolute; top: 19px; right: 0; width: 35px; height: 1px; background: #343A40; content: ''; transition: 0.3s ease-in-out;}
.menu .menu-button span.menu-button-box span.menu-button-inner::after {display: block; position: absolute; top: 38px; right: 0; width: 45px; height: 1px; background: #343A40; content: ''; transition: 0.3s ease-in-out;}

.menu .menu-button:hover span.menu-button-box span.menu-button-inner {width: 50px;}
.menu .menu-button:hover span.menu-button-box span.menu-button-inner::before {width: 50px;}
.menu .menu-button:hover span.menu-button-box span.menu-button-inner::after {width: 50px;}

.menu.light .menu-button span.menu-button-box span.menu-button-inner {background: #ffffff;}
.menu.light .menu-button span.menu-button-box span.menu-button-inner::before {background: #ffffff;}
.menu.light .menu-button span.menu-button-box span.menu-button-inner::after {background: #ffffff;}

.menu.light .menu-button:hover span.menu-button-box span.menu-button-inner {width: 50px;}
.menu.light .menu-button:hover span.menu-button-box span.menu-button-inner::before {width: 50px;}
.menu.light .menu-button:hover span.menu-button-box span.menu-button-inner::after {width: 50px;}

body.menu-open .menu .menu-button.menu-button-x {margin: 0; padding: 10px;}
body.menu-open .menu .menu-button.menu-button-x span.menu-button-box span.menu-button-inner {display: block; position: absolute; top: 35px; right: 10px; height: 0; width: 50px; background: none;}
body.menu-open .menu .menu-button.menu-button-x span.menu-button-box span.menu-button-inner::before {top: 0; width: 50px; height: 2px; transform: rotate(45deg); background: #ffffff;}
body.menu-open .menu .menu-button.menu-button-x span.menu-button-box span.menu-button-inner::after {top: 0; width: 50px; height: 2px; transform: rotate(-45deg); background: #ffffff;}

body.menu-open .menu .menu-button.menu-button-x:hover {opacity: 0.5;}
/* body.menu-open .menu .menu-button.menu-button-x:hover span.menu-button-box span.menu-button-inner {transform: rotate(90deg);} */

#menu-cover {position: fixed; display: none; top: 0; left: 0; right: 0; bottom: 0; z-index: 9997; background: rgba(52,58,64,0); transition: background 1s linear;}
body.menu-open #menu-cover {display: block; cursor: pointer; background: rgba(52,58,64,0.5);}

@media screen and (max-width: 1024px) {	
	body.menu-open .menu .menu-button.menu-button-x:hover {opacity: 1;}
}


/* ==========================================================================
   Menu Nav
   ========================================================================== */
   
.menu-nav {}
body.menu-open .menu-nav {z-index: 9999;}

.menu-nav ul {margin: 0; padding: 0; display: flex; flex-direction: row; align-items: stretch; height: 50px;}
.menu-nav li {margin: 0; padding: 0; list-style: none; display: flex; justify-content: center;}
.menu-nav ul li span {display: none; font-weight: 500;}
.menu-nav ul li a {margin: 0; padding: 0 2em; list-style: none; display: flex; justify-content: center; align-items: center; color: #343A40; border: 1px solid #343A40; border-radius: 0.25em; text-decoration: none; transition: 0.3s ease-in-out; font-weight: 700; text-transform: uppercase;}
.menu-nav ul li a:hover {opacity: 0.5;}
.menu-nav ul li a i {font-size: 2.5em;}
.menu-nav ul li:nth-child(1) {height: 50px;}
.menu-nav ul li:nth-child(1) span {padding: 0 10px 0 0; display: block;}
.menu-nav ul li:nth-child(1) a {padding: 0 1em 0 1.5em;}
.menu-nav ul li:nth-child(2) a {margin-left: 1.5em; padding: 0; border: none; width: 50px;}
.menu-nav ul li:nth-child(3) a {margin-left: 1em; padding: 0; border: none; width: 50px;}
.menu-nav ul li:nth-child(1) a:hover {margin-top: -3px; margin-bottom: 3px;}
.menu-nav ul li:nth-child(2) a:hover {padding-bottom: 5px;}
.menu-nav ul li:nth-child(3) a:hover {padding-bottom: 5px;}

.menu.light .menu-nav ul li a {color: #ffffff; border: 1px solid #ffffff;}
.menu.light .menu-nav ul li:nth-child(2) a {border: none;}
.menu.light .menu-nav ul li:nth-child(3) a {border: none;}

body.menu-open .menu-nav ul li a {color: #ffffff;}
body.menu-open .menu-nav ul li:nth-child(1) a {color: #ffffff; border: 1px solid #ffffff;}

@media screen and (max-width: 800px) {
	.menu-nav ul li:nth-child(1) {display: none; transition: all 0.5s ease-in-out;}
	.menu-nav ul li:nth-child(2) a {margin-left: 1em;}
	.menu-nav ul li:nth-child(3) a {margin-left: 0.5em;}
	body.menu-open .menu-nav ul {animation-name: menu-nav; animation-delay: 0.3s; animation-duration: 1s; animation-fill-mode: both; visibility: inherit;}
	body.menu-open .menu-nav ul li:nth-child(1) {margin-right: 1em; display: flex;}
	body.menu-open .menu-nav ul li:nth-child(2) {display: none;}
	body.menu-open .menu-nav ul li:nth-child(3) {display: none;}
}

@media screen and (orientation: landscape) and (max-width: 900px) {
	body.menu-open .menu-nav ul li:nth-child(1) span {display: none;}
	body.menu-open .menu-nav ul li:nth-child(1) {margin-top: 1em; margin-right: 0;}
	body.menu-open .menu-nav ul li:nth-child(1) a {height: 60px; width: 60px; padding: 0; color: #212529; border: none; background: #ffffff;}
	body.menu-open .menu-nav ul li:nth-child(2) {display: none;}
	body.menu-open .menu-nav ul li:nth-child(3) {display: none;}
}

@media screen and (max-width: 480px) {
	.menu-nav ul li:nth-child(2) {display: none;}
}

@keyframes menu-nav {
    0%   {transform: translate(0,0); opacity: 0;}
    100% {transform: translate(0,0); opacity: 1;}
}

@keyframes menu-nav-email {
    0%   {transform: translate(0,0); opacity: 1;}
    100% {transform: translate(0,0); opacity: 0;}
}

/* ==========================================================================
   Nav
   ========================================================================== */
   
.nav-global {margin: 0; padding: 0; height: 100vh; min-height: 100vh; position: absolute; width: 100%; overflow: hidden; top: 0; right: 0;}
   
.nav {width: 50vw; height: 100vh; transition: 0.3s ease-in-out; position: absolute; top: 0; right: -50vw; -webkit-clip-path: polygon(20% 0%, 100% 0, 100% 100%, 0% 100%); clip-path: polygon(20% 0%, 100% 0, 100% 100%, 0% 100%); display: flex; justify-content: center; flex-direction: column; align-items: center; text-align: left; overflow: hidden; z-index: 9998; overflow: hidden;}
.nav::after {content: ""; opacity: 0.025; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-image: url('/img/slash-white.svg'); background-size: cover; background-repeat: no-repeat; background-position: bottom right;}
body.menu-open .nav {width: 50vw; right: 0;}

.nav ul {margin: 0; padding: 0; list-style: none;}
.nav ul li {position: relative; right: -300px; display: block; color: #ffffff; font-size: 1.5em; font-weight: 700; line-height: 2.5; opacity: 0; transition: all 0.5s ease-in-out;}
.nav ul li:nth-child(1) {transition-delay: 0.5s;}
.nav ul li:nth-child(2) {transition-delay: 0.7s;}
.nav ul li:nth-child(3) {transition-delay: 0.8s;}
.nav ul li:nth-child(4) {transition-delay: 1s;}
.nav ul li:nth-child(5) {transition-delay: 1.2s;}
body.menu-open .nav ul li:nth-child(1) {right: 0; opacity: 1;}
body.menu-open .nav ul li:nth-child(2) {right: 0; opacity: 1;}
body.menu-open .nav ul li:nth-child(3) {right: 0; opacity: 1;}
body.menu-open .nav ul li:nth-child(4) {right: 0; opacity: 1;}
body.menu-open .nav ul li:nth-child(5) {right: 0; opacity: 1;}
.nav ul li a {text-decoration: none; color: #ffffff; display: flex; flex-direction: column;}
.nav ul li a::after {content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,79,95,1) 25%, rgba(255,135,63,1) 100%);}
.nav ul li a:hover::after {width: 50px;}
.nav ul li.selected a::after {width: 50px;}
.nav ul li.selected a::after {background: rgb(255,255,255); background: linear-gradient(45deg, rgba(255,255,255,0.5) 25%, rgba(255,255,255,0.3) 100%);}


@media screen and (max-width: 1400px) {
	.nav {width: 80vw; right: -80vw;}
	body.menu-open .nav {width: 80vw;}	
}

@media screen and (max-width: 900px) {
	.nav {width: 100vw; right: -100vw; -webkit-clip-path: polygon(0 0, 100% 0%, 100% 100%, 0% 100%); clip-path: polygon(0 0, 100% 0%, 100% 100%, 0% 100%);}
	body.menu-open .nav {width: 100vw;}	
}

@media screen and (orientation: portrait) and (max-width: 800px) {
	.nav {text-align: center;}
	.nav ul li a {display: flex; justify-content: center; align-content: center; align-items: center; flex-grow: inherit;}
}

@media screen and (orientation: landscape) and (max-width: 900px) {
	.nav {justify-content: flex-start; align-items: flex-start;}
	body.menu-open .nav {width: 100vw; right: 0;}
	.nav ul {margin-top: 50px; padding-left: 50px;}
	.nav ul li {margin: 0; padding: 0; line-height: 2;}
}

@media screen and (max-width: 480px) {
	.nav {justify-content: flex-start; text-align: center;}
	.nav ul {margin-top: 20vh;}
	.nav ul li {margin: 0; padding: 0; line-height: 2;}
	.nav ul li a {display: flex; justify-content: center; align-content: center; align-items: center; flex-grow: inherit;}
}


/* ==========================================================================
   Nav Social
   ========================================================================== */

.nav-global .social {margin: 0; padding: 2em 0 0 0; position: absolute; bottom: 10vh; right: 50px; z-index: -9999; display: none;}
body.menu-open .nav-global .social {z-index: 9999; display: block;}
body.menu-open .nav-global .social ul {animation-name: social; animation-delay: 1.2s; animation-duration: 1s; animation-fill-mode: both; visibility: inherit;}

.nav-global .social ul {margin: 0; padding: 0; display: flex; flex-direction: row;}
.nav-global .social ul li {margin: 0 0.5em 0 0; padding: 0; list-style: none; font-size: 2em;}
.nav-global .social ul li a {color: rgba(255,255,255,1); display: flex; flex-direction: column;}
.nav-global .social ul li a:hover {color: rgba(255,255,255,0.7);}
.nav-global .social ul li a::after {margin: 0.25em 0 0 0; content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,79,95,1) 25%, rgba(255,135,63,1) 100%);}
.nav-global .social ul li a:hover::after {width: 20px;}

@keyframes social {
    0%   {transform: translate(0,50%); opacity: 0;}
    100% {transform: translate(0,0); opacity: 1;}
}

@media screen and (orientation: portrait) and (max-width: 800px) {
	.nav-global .social {bottom: 100px; right: 0; left: 0;}
	.nav-global .social ul {justify-content: center; align-items: center; text-align: center; width: 100vw;}
	.nav-global .social ul li {margin: 0 0.5em 0 0;}
	.nav-global .social ul li:last-child {margin: 0 0 0 0;}
}

@media screen and (orientation: landscape) and (max-width: 900px) {
	.nav-global .social {right: 25px; bottom: 65px;}
}

@media screen and (max-width: 480px) {
	.nav-global .social {bottom: 20vh; right: 0; left: 0;}
	.nav-global .social ul {justify-content: center; align-items: center; text-align: center; width: 100vw;}
	.nav-global .social ul li {margin: 0 0.5em 0 0;}
	.nav-global .social ul li:last-child {margin: 0 0 0 0;}
}


/* ==========================================================================
   Banner
   ========================================================================== */
   
.hero {margin: 0; padding: 0; display: flex; position: absolute; z-index: 9000; content: ''; top: 0; width: 100%; height: 100vh;}

.hero .image {content: ""; opacity: 0.1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-size: cover; background-repeat: no-repeat; background-position: center center;}

@media screen and (max-width: 1024px) {
	.hero .image.desktop {display: none;}
}

@media screen and (min-width: 1024px) {
	.hero .image.mobile {display: none;}
	.hero .image.desktop {display: block;}
}

.hero .item {margin: 0; padding: 0;}
.hero .item h2 {font-size: 4em; text-align: center; font-weight: 300; line-height: 1.2; text-transform: none; letter-spacing: 0.005em; color: #ffffff; text-shadow: 2px 2px 2px rgba(33, 18, 58, 0.4);}
.hero .item h2 strong {font-weight: 700;}

.hero.slash::after {content: ""; opacity: 0.1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-image: url('/img/slash-white.svg'); background-size: contain; background-repeat: no-repeat; background-position: bottom right;}

@media screen and (max-width: 900px) {
	.hero.slash::after {background-size: cover;}
}

@media screen and (orientation: portrait) {
	.hero.slash::after {background-size: cover;}
}

.hero .next-section {position: absolute; bottom: 10vh; animation-name: next-section; animation-delay: 1.5s; animation-duration: 1s; animation-fill-mode: both; visibility: inherit;}
.hero .next-section span a {position: relative; color: rgba(255,255,255,1); font-size: 4em; transition: 0.3s ease-in-out; font-weight: 700; text-transform: uppercase; animation-name: updown; animation-duration: 1s; animation-timing-function: ease-in-out; animation-iteration-count: infinite;}
.hero .next-section span a:hover {color: rgba(255,255,255,0.5); animation-play-state: paused;}

@keyframes next-section {
    0%   {transform: translate(0,50%); opacity: 0;}
    100% {transform: translate(0,0); opacity: 1;}
}

@keyframes updown {
  0%, 100% {
    bottom: 0;
  }
  50% {
    bottom: 10px;
  }
}

/*
.hero h2 {animation-name: hero; animation-delay: 1s; animation-duration: 1s; animation-fill-mode: both; visibility: inherit;}
@keyframes hero {
    0%   {transform: translate(0,50%); opacity: 0;}
    100% {transform: translate(0,0); opacity: 1;}
}
*/


@media screen and (orientation: portrait) {
	.hero::after {background-size: cover;}
}

@media screen and (max-width: 1100px) {
	.hero .item h2 {font-size: 3em;}	
}

@media screen and (orientation: landscape) and (max-width: 850px) {
	.hero .item {}
	.hero .item h2 {font-size: 2em;}
}

@media screen and (orientation: portrait) and (max-width: 850px) {
	.hero .item {padding: 0 0 85px 0;}
}

@media screen and (max-width: 640px) {
	.hero .item h2 {font-size: 2.25em;}	
	.hero .next-section {bottom: 60px;}
}

@media screen and (max-width: 480px) {
	.hero {align-items: flex-start;}
	.hero h2 {padding-top: 200px;}
}	

/* ==========================================================================
   General
   ========================================================================== */
   
.general {margin: 0; padding: 0; display: flex; position: absolute; z-index: 9000; content: ''; top: 0; width: 100%; height: 50vh;}
.general::after {content: ""; opacity: 0.1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: -1; background-image: url('/img/slash-white.svg'); background-size: contain; background-repeat: no-repeat; background-position: bottom right; height: 100vh;}
.general .item {margin: 0; padding: 0;}
.general .item h2 {font-size: 4em; text-align: center; font-weight: 300; line-height: 1.2; text-transform: none; letter-spacing: 0.005em; color: #ffffff; text-shadow: 2px 2px 2px rgba(33, 18, 58, 0.4);}
.general .item h2 strong {font-weight: 700;}

.general .next-section {position: absolute; bottom: 10vh; animation-name: next-section; animation-delay: 1.5s; animation-duration: 1s; animation-fill-mode: both; visibility: inherit;}
.general .next-section span a {position: relative; color: rgba(255,255,255,1); font-size: 4em; transition: 0.3s ease-in-out; font-weight: 700; text-transform: uppercase; animation-name: updown; animation-duration: 1s; animation-timing-function: ease-in-out; animation-iteration-count: infinite;}
.general .next-section span a:hover {color: rgba(255,255,255,0.5); animation-play-state: paused;}

@keyframes next-section {
    0%   {transform: translate(0,50%); opacity: 0;}
    100% {transform: translate(0,0); opacity: 1;}
}

@keyframes updown {
  0%, 100% {
    bottom: 0;
  }
  50% {
    bottom: 10px;
  }
}


/* ==========================================================================
   Services
   ========================================================================== */


.services {width: 100%; overflow: hidden;}

.services .article {margin: 0 auto; display: flex; justify-content: center; flex-direction: row; align-items: flex-end; flex: 1; box-sizing: border-box; overflow: hidden;}
.services .article .image {width: 40%;}
.services .article .image img {width: 100%; height: 100%;}
.services .article .detail {padding-right: 100px; display: flex; flex-direction: column; width: 60%;}
.services .article .detail p {padding: 0 0 1em 0; font-weight: 300; font-size: 1.6em;}
.services .article .detail p a {font-weight: 500;}

.services .list {display: flex; flex-direction: row; justify-content: space-between; align-content: flex-start; align-items: stretch; flex-wrap: wrap; width: 100%; box-sizing: border-box; background: #ffffff; box-shadow: 0px 15px 10px -10px rgba(33, 37, 41,0.25); overflow: hidden;}
.services .list .item {margin: 0 0 2em 0; display: flex; flex-direction: column; align-items: stretch; width: calc(1/3*100% - (1 - 1/3)*2em); text-align: center; box-sizing: border-box; position: relative;}
.services .list .item a {color:#212529; transition: 0.3s ease-in-out; text-align: left;}
.services .list .item a .image {flex: 1 0 auto;}
.services .list .item a h3,
.services .list .item a p,
.services .list .item a img {color:#212529; transition: 0.3s ease-in-out;}
.services .list .item a:hover h3,
.services .list .item a:hover p,
.services .list .item a:hover img {opacity: 0.5;}
.services .list .item a::before {margin: 0 auto; content: ''; height: 2px; width: 100px; transition: 0.3s ease-in-out; background: #212529; display: flex; flex-direction: column; justify-content: center; position: absolute; bottom: 0; z-index: 1;}
.services .list .item a::after {margin: 0 auto; content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(144,89,255); background: linear-gradient(-45deg, rgba(144,89,255,1) 25%, rgba(255,79,95,1) 75%, rgba(255,135,63,1) 100%); display: flex; flex-direction: column; justify-content: center; position: absolute; bottom: 0; z-index: 2;}
.services .list .item a:hover::after {width: 100px;}
.services .list .item img {height: 100px; max-height: 100px; width: auto;}
.services .list .item h3 {padding: 0 0 0.5em 0; font-size: 1.5em; line-height: 1.25;}
.services .list .item p {font-weight: 300; font-size: 1.15em; line-height: 1.25;}
.services .list .item a .detail {padding-bottom: 2em; display: flex; flex-direction: column; align-content: flex-start; flex: 1 0 auto;}

.services .list .item:nth-child(1) {transition-delay: 250ms;}
.services .list .item:nth-child(2) {transition-delay: 500ms;}
.services .list .item:nth-child(3) {transition-delay: 750ms;}


@media screen and (max-width: 1500px) {
	.services .article .image {width: 50%;}
	.services .article .detail {width: 50%;}
}

@media screen and (max-width: 1400px) {
	.services .article .detail p {font-size: 1.4em;}
}

@media screen and (max-width: 1300px) {
	.services .article .detail p {font-size: 1.25em;}

	.services .list .item p {font-size: 1em;}
}

@media screen and (max-width: 1200px) {
	.services .article .detail {padding-right: 50px;}
	.services .article {margin: 0 0 0 2.5%; width: 97.5%;}
	
	.services .list .item {width: calc(1/3*100% - (1 - 1/3)*1em);}
	.services .list.p-4 {padding: 2em;}
}

@media screen and (max-width: 900px) {
	.services .section-header {margin: auto; justify-content: center; align-items: flex-start; width: 90%; text-align: left;}
	.services .section-header.reverse h2 {padding: 0 0 0.5em 0;}
	.services .section-header.reverse h2:after {margin: 20px 0 0 0; display: flex; justify-content: flex-start; text-align: left;}
	.services .article {margin: auto; flex-direction: column-reverse; justify-content: center; width: 90%}
	.services .article .detail {padding-bottom: 2em; width: 100%; padding-right: 0;}
	.services .article .image {margin-bottom: 2em; display: flex; justify-content: center; flex-grow: 1; width: 100%; border-bottom: 5px solid #212529; box-shadow: 0 10px 5px -5px rgba(33,37,41, .2);}
	.services .article .image img {width: 70%;}
	
	.services .list {flex-direction: column;}
	.services .list .item {width: 100%;}
}

@media screen and (max-width: 640px) {
	.services .section-header.reverse h3 {width: 60%;}
}
	

/* ==========================================================================
   Key Services
   ========================================================================== */
   
.key-services {width: 100%; overflow: hidden; box-sizing: border-box;}
.key-services .container {margin: 0 auto; display: flex; flex-direction: row; flex-wrap: wrap;}

.key-services .section-content {display: flex; flex-direction: row; justify-content: space-between; align-items: flex-start; text-align: left; width: 100%; box-sizing: border-box;}

.key-services .list {width: 55%; box-sizing: border-box;}
.key-services .list ul {margin: 0; padding: 0; width: 100%; box-sizing: border-box; -webkit-columns: 2; columns: 2;}
.key-services .list ul li {margin: 0 0 0.25em 0; padding: 0; display: flex; text-align: left; box-sizing: border-box; list-style: none; font-weight: 500; font-size: 1.5em; line-height: 2; list-style-position: inside; -webkit-column-break-inside: avoid; page-break-inside: avoid; break-inside: avoid;}
.key-services .list ul li a {color: rgba(33,37,41,1); line-height: 1.75; display: flex; flex-direction: column; width: 100%;}
.key-services .list ul li a:hover {color: rgba(33,37,41,0.5); transition: 0.3s ease-in-out;}
.key-services .list ul li a::after {content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(255,79,95); background: linear-gradient(-45deg, rgba(52,58,64,1) 0%, rgba(33,37,41,1) 100%);}
.key-services .list ul li a:hover::after {width: 50px;}

.key-services .get-started {padding-bottom: 20px; width: 45%; margin-right: 40px; position: relative; box-sizing: border-box; display: flex; flex-direction: column;}
.key-services .get-started a {background: #ffffff; box-shadow: 0px 15px 10px -10px rgba(33, 37, 41, .2);}
.key-services .get-started a h3 {font-size: 1.5em;}
.key-services .get-started a h3,
.key-services .get-started a p {color:#212529; transition: 0.3s ease-in-out;}
.key-services .get-started a span i {z-index: 3; font-size: 4em;} 
.key-services .get-started span {background: #212529; height: 80px; width: 80px; position: absolute; right: -40px; bottom: 2em; display: flex; justify-content: center; align-items: center; color: #ffffff;}
.key-services .get-started a span::after {margin: 0 auto; content: ''; height: 80px; width: 0; transition: 0.3s ease-in-out; background: rgb(144,89,255); background: linear-gradient(-45deg, rgba(144,89,255,1) 25%, rgba(255,79,95,1) 75%, rgba(255,135,63,1) 100%); display: flex; flex-direction: column; justify-content: flex-start; position: absolute; bottom: 0; left: 0; z-index: 2;}
.key-services .get-started a:hover span::after {width: 80px;}

.key-services .get-started a:hover {box-shadow: 0px 15px 10px -10px rgba(33, 37, 41,0.5);}
.key-services .get-started a:hover h3,
.key-services .get-started a:hover p {opacity: 0.5;}

@media screen and (max-width: 1600px) {
	.key-services .list ul li {font-size: 1.25em;}
}

@media screen and (max-width: 1300px) {
	.key-services .list {width: 60%;}
	.key-services .get-started {width: 40%;}
}

@media screen and (max-width: 1200px) {
	.key-services .section-content {display: flex; flex-direction: column;}
	.key-services .list {padding: 0; width: 100%;}
	.key-services .list ul {-webkit-columns: 3; columns: 3;}
	.key-services .get-started {margin-top: 3em; width: 60%;}
}

@media screen and (max-width: 1100px) {
	.key-services .list ul {-webkit-columns: 2; columns: 2;}
	.key-services .get-started {margin-top: 2em; width: 80%;}
}

@media screen and (max-width: 900px) {
	.key-services .get-started span {font-weight: 300; bottom: 30px;}
	.key-services .get-started p {font-weight: 300;}
}

@media screen and (max-width: 640px) {
	.key-services .list ul li {font-size: 1em;}
	.key-services .get-started {width: 90%;}
	.key-services .get-started span {height: 60px; width: 60px; position: absolute; right: -30px;}
	.key-services .get-started a span::after {height: 60px;}
	.key-services .get-started a:hover span::after {width: 60px;}
	.key-services .get-started a span i {font-size: 3em;}
}

@media screen and (max-width: 480px) {	
	.key-services .section-header {font-size: 60%;}
	.key-services .section-header h2 {padding-bottom: 5px;}
	.key-services .section-header h2:after {margin: 0.4em auto 0 auto;}
	
	.key-services .get-started {padding-bottom: 20px; width: 95%;}
	.key-services .get-started span {right: -10px; bottom: 10px;}
	
	.key-services .list ul {-webkit-columns: 1; columns: 1;}
	.key-services .list ul li {text-align: center; font-size: 1.2em;}
	.key-services .list ul li a {display: flex; flex-direction: column; justify-content: flex-start; align-content: flex-start; align-items: flex-start;}
}


/* ==========================================================================
   Work
   ========================================================================== */

/*
.work {width: 100%; overflow: hidden; position: relative;}

.work .header {display: none;}

.work .list {display: flex; flex-direction: row; justify-content: space-between; align-content: center; align-items: stretch; flex-wrap: wrap; width: 100%; height: calc(50vh - 1px); border: none; position: relative;}
.work .list .item {margin: 0; display: flex; flex-direction: column; justify-content: center; width: 55%; text-align: center; position: absolute; height: 50vh; box-sizing: border-box;}
.work .list .item > figure {margin: 0; padding: 0; backface-visibility: hidden; background-size: cover; background-position: center center; background-repeat: no-repeat; left: 0px; width: 100%; height: 50vh; min-height: 50vh; position: relative; z-index: 1;}
.work .list .item > figure img {display: none;}
.work .list .item .detail {margin: 0; top: 0; bottom: 0; left: 0; right: 0; position: absolute; z-index: 2; color: #ffffff; text-align: center; text-shadow: 2px 2px 2px rgba(33,37,41,0.4); width: 100%; box-sizing: border-box;}
.work .list .item .detail a {padding: 0 20%; display: flex; flex-direction: column; justify-content: center; height: 100%; width: 100%; box-sizing: border-box; color: #ffffff;}
.work .list .item .detail a:after {margin: 1em auto 0 auto; content: ''; height: 1px; width: 50px; transition: 0.3s ease-in-out; background: rgb(255,255,255); background: #ffffff; display: flex; justify-content: center;}
.work .list .item:nth-child(odd) {-webkit-clip-path: polygon(0 0, 85% 0, 100% 100%, 0 100%); clip-path: polygon(0 0, 85% 0, 100% 100%, 0 100%);}
.work .list .item:nth-child(odd) .detail a {margin-left: -10%;}
.work .list .item:nth-child(even) {right: 0; -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 15% 100%); clip-path: polygon(0 0, 100% 0, 100% 100%, 15% 100%);} 
.work .list .item:nth-child(even) .detail a {margin-right: -10%;}

.work .list .item:after {z-index: 1; content: ''; background: rgb(52,58,64); background: linear-gradient(-45deg, rgba(52,58,64,1) 0%, rgba(33,37,41,1) 100%); position: absolute; top: 0; left: 0; bottom: 0; right: 0; height: 100%; width: 100%; opacity: 0.3; transition: 0.3s ease-in-out;}
.work .list .item:hover:after{opacity: 0.8;}

.work .list .item h3 {padding: 0 0 0.1em 0; font-size: 2em; line-height: 1.25;}
.work .list .item ul {margin: 0; padding: 0; display: flex; flex-direction: row; flex-wrap: wrap; justify-content: center;}
.work .list .item ul li {margin: 0; padding: 0; list-style: none; font-weight: 500; text-transform: uppercase; font-size: 0.8em;}
.work .list .item ul li:after {content: '+'; padding: 0 5px;}
.work .list .item ul li:last-child:after {content: ''; padding: 0 0;}

.work .link {position: absolute; left: 50%; bottom: 40px; margin-left: -100px; z-index: 3; color: #ffffff; text-shadow: 2px 2px 2px rgba(33,37,41,0.4);}
.work .link span {padding: 0 0 0.1em 0; font-size: 1em; line-height: 1.25; font-weight: 300;}
.work .link span a {margin: 0; padding: 0 2em; display: flex; justify-content: center; align-items: center; color: #ffffff; border: 1px solid #ffffff; border-radius: 0.25em; text-decoration: none; transition: 0.3s ease-in-out; font-weight: 700; text-transform: uppercase; height: 50px; width: 200px;}
.work .link span a:hover {opacity: 0.5;}
*/


/* ==========================================================================
   Work
   ========================================================================== */

.work {width: 100%;}

.work .header {display: none;}

.work .list {margin: 0; display: flex; flex-direction: row; justify-content: space-between; align-content: center; align-items: stretch; flex-wrap: wrap; width: 100%; border: none; transition-duration: 2000ms;}
.work .list .item {margin: 0 0 20px 0; display: flex; flex-direction: column; justify-content: center; text-align: center; height: 300px; box-sizing: border-box; position: relative; background: #212529; box-shadow: 0px 15px 10px -10px rgba(33, 37, 41, .5); transition-duration: 1500ms;}
.work .list .item > figure {margin: 0; padding: 0; backface-visibility: hidden; background-size: cover; background-position: center right; background-repeat: no-repeat; left: 0px; width: 100%; height: 100%; position: relative; z-index: 1; position: absolute;}
.work .list .item > figure img {display: none;}
.work .list .item .detail {margin: 0; z-index: 3; color: #ffffff; text-align: left; text-shadow: 2px 2px 2px rgba(33,37,41,0.4); display: flex; flex-direction: column; align-items: stretch; height: 100%; width: 100%; box-sizing: border-box;}
.work .list .item .detail h3 {max-width: 440px;}
.work .list .item .detail a {padding: 30px; display: flex; flex-direction: column; justify-content: flex-end; height: 100%; width: 100%; box-sizing: border-box; color: #ffffff;}
.work .list .item .detail a:after {margin: 1em 0 0 0; content: ''; height: 1px; width: 50px; transition: 0.3s ease-in-out; background: rgb(255,255,255); background: #ffffff; display: flex; justify-content: flex-start;}
.work .list .item .detail a:hover {padding: 40px;}
.work .list .item:nth-child(1) {width: calc(65% - 20px);}
.work .list .item:nth-child(2) {width: 35%; transition-delay: 200ms;}
.work .list .item:nth-child(3) {width: 35%; transition-delay: 200ms;}
.work .list .item:nth-child(4) {width: calc(65% - 20px); transition-delay: 300ms;}
.work .list .item:nth-child(5) {width: calc(65% - 20px); transition-delay: 200ms;}
.work .list .item:nth-child(6) {width: 35%; transition-delay: 300ms;}
.work .list .item:nth-child(7) {width: 35%; transition-delay: 200ms;}
.work .list .item:nth-child(8) {width: calc(65% - 20px); transition-delay: 300ms;}
.work .list .item:nth-child(9) {width: calc(65% - 20px); transition-delay: 200ms;}
.work .list .item:nth-child(10) {width: 35%; transition-delay: 300ms;}
.work .list .item:nth-child(11) {width: 35%; transition-delay: 200ms;}
.work .list .item:nth-child(12) {width: calc(65% - 20px); transition-delay: 300ms;}

.work .list .item:before {z-index: 2; content: ''; background: rgb(144,89,255); background: linear-gradient(rgba(33,37,41,0) 25%, rgba(33,37,41,0.8) 75%); position: absolute; top: 0; left: 0; bottom: 0; right: 0; height: 100%; width: 100%; opacity: 0.5; transition: 0.5s ease-in-out;}
.work .list .item:after {z-index: 2; content: ''; background: rgb(33,18,58); background: linear-gradient(45deg, rgba(33,18,58,1) 25%, rgba(144,89,255,1) 100%); position: absolute; top: 0; left: 0; bottom: 0; right: 0; height: 100%; width: 0; opacity: 0; transition: 0.5s ease-in-out;}
.work .list .item:hover:after{width: 100%; opacity: 0.8;}

.work .list .item h3 {padding: 0 0 0.1em 0; font-size: 2em; line-height: 1.25;}
.work .list .item ul {margin: 0; padding: 0; display: flex; flex-direction: row; flex-wrap: wrap; justify-content: flex-start;}
.work .list .item ul li {margin: 0; padding: 0; list-style: none; font-weight: 500; text-transform: uppercase; font-size: 0.8em;}
.work .list .item ul li:after {content: '+'; padding: 0 5px;}
.work .list .item ul li:last-child:after {content: ''; padding: 0 0;}

.work .link {color: #212529; display: flex; justify-content: center; align-items: center;}
.work .link span {padding: 0 0 0.1em 0; font-size: 1em; line-height: 1.25; font-weight: 300;}
.work .link span a {margin: 0; padding: 0 2em; display: flex; justify-content: center; align-items: center; color: #212529; border: 1px solid #212529; border-radius: 0.25em; text-decoration: none; transition: 0.3s ease-in-out; font-weight: 700; text-transform: uppercase; height: 50px; width: 200px;}
.work .link span a:hover {opacity: 0.5;}

@media screen and (max-width: 1200px) {	
	.work .list .item {justify-content: center;}
	.work .list .item:nth-child(1) {width: calc(55% - 20px);}
	.work .list .item:nth-child(2) {width: 45%;}
	.work .list .item:nth-child(3) {width: 45%;}
	.work .list .item:nth-child(4) {width: calc(55% - 20px);}
	.work .list .item:nth-child(5) {width: calc(55% - 20px);}
	.work .list .item:nth-child(6) {width: 45%;}
	.work .list .item:nth-child(7) {width: 45%;}
	.work .list .item:nth-child(8) {width: calc(55% - 20px);}
	.work .list .item:nth-child(9) {width: calc(55% - 20px);}
	.work .list .item:nth-child(10) {width: 45%;}
	.work .list .item:nth-child(11) {width: 45%;}
	.work .list .item:nth-child(12) {width: calc(55% - 20px);}
	.home .work .list .item:nth-child(3) {width: 100%;}
	.home .work .list .item:nth-child(4) {display: none;}
}

@media screen and (max-width: 800px) {
	.work .list {justify-content: space-between;}
	.work .list .item {margin: 0 0 20px 0; height: 250px; transition-delay: 0ms !important;}
	.work .list .item:nth-child(1) {width: calc(50% - 10px);}
	.work .list .item:nth-child(2) {width: calc(50% - 10px);}
	.work .list .item:nth-child(3) {width: calc(50% - 10px);}
	.work .list .item:nth-child(4) {width: calc(50% - 10px);}
	.work .list .item:nth-child(5) {width: calc(50% - 10px);}
	.work .list .item:nth-child(6) {width: calc(50% - 10px);}
	.work .list .item:nth-child(7) {width: calc(50% - 10px);}
	.work .list .item:nth-child(8) {width: calc(50% - 10px);}
	.work .list .item:nth-child(9) {width: calc(50% - 10px);}
	.work .list .item:nth-child(10) {width: calc(50% - 10px);}
	.work .list .item:nth-child(11) {width: calc(50% - 10px);}
	.work .list .item:nth-child(12) {width: calc(50% - 10px);}
	.home .work .list .item:nth-child(3) {width: 100%;}
	
	.flex-area .link {margin-bottom: 30px; justify-content: flex-start;}
}

@media screen and (max-width: 700px) {
	.work .list {flex-direction: column;}
	.work .list .item:nth-child(1) {width: 100%;}
	.work .list .item:nth-child(2) {width: 100%;}
	.work .list .item:nth-child(3) {width: 100%;}
	.work .list .item:nth-child(4) {width: 100%;}
	.work .list .item:nth-child(5) {width: 100%;}
	.work .list .item:nth-child(6) {width: 100%;}
	.work .list .item:nth-child(7) {width: 100%;}
	.work .list .item:nth-child(8) {width: 100%;}
	.work .list .item:nth-child(9) {width: 100%;}
	.work .list .item:nth-child(10) {width: 100%;}
	.work .list .item:nth-child(11) {width: 100%;}
	.work .list .item:nth-child(12) {width: 100%;}
}

@media screen and (max-width: 480px) {
	.work .list .item .detail {font-size: 80%;}
}


/* ==========================================================================
   Contact
   ========================================================================== */
   


/* ==========================================================================
   Forms
   ========================================================================== */

.contact-form {margin: 0 0 0 0; padding: 0; text-align: left; width: 100%;}
.contact-form a {text-decoration: underline; font-weight: 300;}
.contact-form .section-header a {text-decoration: none; font-weight: 500;}
.contact-form .contact-form-section {margin: 0 0 3em 0; border-bottom: 3px solid #343A40;}
.contact-form .contact-form-section:last-of-type {margin: 0 0 0 0; border-bottom: none;}
.contact-form .contact-form-section .marketing {margin: 0 0 2em 0; background: #f5f5f5; box-shadow: 5px 5px 0 0px rgba(33, 37, 41,0.2); -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}
.contact-form .contact-form-section .marketing:hover {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}
.contact-form .contact-form-section .form-header {margin: 0 0 2em 0;}
.contact-form .contact-form-section .form-header h4 {margin: 0; font-size: 1.5em;}
.contact-form .contact-form-section .form-header p {margin: 0; font-size: 1.2em; font-weight: 300;}
.contact-form .contact-form-section .fields {margin: 0; display: flex; flex-direction: column; width: 100%; justify-content: space-between}
.contact-form .contact-form-section .fields.two,
.contact-form .contact-form-section .fields.three {margin: 0; display: flex; flex-direction: row; width: 100%; justify-content: space-between;}
.contact-form .contact-form-section .fields.two .column {display: flex; flex-direction: column; width: calc(1/2*100% - (1 - 1/2)*2em);}
.contact-form .contact-form-section .fields.three .column {display: flex; flex-direction: column; width: calc(1/3*100% - (1 - 1/3)*2em);}
.contact-form .contact-form-section .fields h5 {margin: 0 0 15px 0; font-size: 1.25em;}
.contact-form .contact-form-section .marketing .fields {flex-direction: column;}

.contact-form label i {padding: 0; color: #212529; font-size: 0.9em; font-weight: 300; font-style: normal;}	

.contact-form .input {position: relative;}
.contact-form .input label {position: absolute; padding: 0; color: rgba(33,37,41,0.5); display: block; font-size: 1em; line-height: 1; top: 10px; left: 10px; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}	
.contact-form .input input {margin: 0 0 25px 0; padding: 25px 10px 10px 10px; height: 80px; width: 100%; border-radius: 0; border: none; display: block; line-height: 1; font-size: 1em; color: #212529; background: #f5f5f5; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear; box-sizing: border-box; box-shadow: 5px 5px 0 0px rgba(33, 37, 41,0.2);}	
.contact-form .input input::-webkit-input-placeholder,
.contact-form .input input::-moz-placeholder,
.contact-form .input input::placeholder-shown {color:#ffffff;}
.contact-form .input.address {display: none;}	
.contact-form .input input:hover {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}
.contact-form .input input:focus {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}
.contact-form .input:hover label {color: rgba(33,37,41,1);}
.contact-form .input:focus-within label {color: rgba(33,37,41,1);}

.contact-form .select {position: relative;}
.contact-form .select label {padding: 0; color: rgba(33,37,41,0.5); display: block; font-size: 1em; line-height: 1; position: absolute; top: 10px; left: 10px; z-index: 2; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}	
.contact-form .select label i {padding: 0; color: #212529; font-size: 0.9em;}	
.contact-form .select .dropdown {margin: 0 0 25px 0; position: relative; background: #f5f5f5; overflow: hidden; border: none; border: none; border-radius: 0; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear; box-shadow: 5px 5px 0 0px rgba(33, 37, 41,0.2); box-sizing: border-box;}
.contact-form .select .dropdown:after {content: '\f078'; font-family: "Font Awesome 5 Free"; font-style: normal; font-variant-caps: normal; font-variant-ligatures: normal; font-size: 1.5em; font-weight: 900; height: 80px; line-height: 80px; text-rendering: auto; width: 1em; -webkit-font-smoothing: antialiased; position: absolute; right: 1em; top: 5px; z-index: 1; pointer-events: none; color: #212529;}
.contact-form .select select {margin: 0; padding: 15px 10px 0 10px; height: 80px; width: 100%; border: none; display: block; font-size: 1.1em; color: #212529; background: transparent; box-shadow: none; background-image: none; -webkit-appearance: none; line-height: 1.2; box-sizing: border-box;}
.contact-form .select .dropdown:hover {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}
.contact-form .select .dropdown:focus {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}
.contact-form .select:hover label {color: rgba(33,37,41,1);}
.contact-form .select:focus-within label {color: rgba(33,37,41,1);}

.contact-form .textarea {position: relative;}
.contact-form .textarea label {padding: 10px 10px 10px 10px; color: rgba(33,37,41,0.5); display: block; font-size: 1em; position: absolute; top: 0; left: 0; z-index: 2; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear; background: #f5f5f5; min-height: 40px; box-sizing: border-box; width: 100%;}	
.contact-form .textarea textarea {margin: 0; padding: 40px 10px 10px 10px; width: 100%; border: none; border: none; display: block; font-size: 1em; color: #212529; background: #f5f5f5; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear; border-radius: 0; height: 250px; position: relative; z-index: 1; box-shadow: 5px 5px 0 0px rgba(33, 37, 41,0.2); box-sizing: border-box;}	
.contact-form .textarea textarea:hover {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}	
.contact-form .textarea textarea:focus {box-shadow: 5px 5px 0 0px rgba(7,191,188,1);}
.contact-form .textarea:hover label,
.contact-form .textarea:focus-within label {color: rgba(33,37,41,1);}

.contact-form .marketing .fields .checkbox {margin: 0 0 10px 0; display: flex; position: relative; padding-left: 60px; cursor: pointer; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; min-height: 40px; box-sizing: border-box;}
.contact-form .marketing .fields .checkbox input {position: absolute; opacity: 0; cursor: pointer; height: 40px; width: 40px; left: 0; z-index: 10; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}
.contact-form .marketing .fields .checkbox label {padding: 0; color: #212529; cursor: pointer; font-weight: 300; font-size: 1.2em; display: block; align-self: center; text-transform: inherit;}	
.contact-form .marketing .fields .checkbox .checkmark {position: absolute; top: 0; left: 0; height: 40px; width: 40px; background-color: #e5e5e5; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}
.contact-form .marketing .fields .checkbox:hover input ~ .checkmark {background-color: #d5d5d5;}
.contact-form .marketing .fields .checkbox input:checked ~ .checkmark {background-color: #212529;}
.contact-form .marketing .fields .checkbox .checkmark:after {content: ""; position: absolute; display: none;}
.contact-form .marketing .fields .checkbox input:checked ~ .checkmark:after {display: block;}
.contact-form .marketing .fields .checkbox .checkmark:after {left: 14px; top: 6px; width: 9px; height: 18px; border: solid white; border-width: 0 4px 4px 0; -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg);}

.contact-form .fields.three .checkbox {margin: 0 0 10px 0; display: flex; position: relative; cursor: pointer; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; min-height: 40px; background: #f5f5f5; border-bottom: 2px solid #e5e5e5; transition: all .3s linear;}
.contact-form .fields.three .checkbox input {position: absolute; opacity: 0; cursor: pointer; height: 40px; width: 40px; left: 10px; z-index: 10; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}
.contact-form .fields.three .checkbox label {padding: 10px 20px 10px 70px; color: rgba(33,37,41,1); cursor: pointer; font-weight: 300; font-size: 1.2em; display: flex; align-self: center; align-items: center; text-transform: inherit; width: 100%; min-height: 40px;  -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}	
.contact-form .fields.three .checkbox .checkmark {position: absolute; top: 10px; left: 10px; height: 40px; width: 40px; background-color: #e5e5e5; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear;}
.contact-form .fields.three .checkbox:hover input ~ .checkmark {background-color: #d5d5d5;}
.contact-form .fields.three .checkbox input:checked ~ .checkmark {background-color: #212529;}
.contact-form .fields.three .checkbox .checkmark:after {content: ""; position: absolute; display: none;}
.contact-form .fields.three .checkbox input:checked ~ .checkmark:after {display: block;}
.contact-form .fields.three .checkbox .checkmark:after {left: 14px; top: 6px; width: 9px; height: 18px; border: solid white; border-width: 0 4px 4px 0; -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg);}
.contact-form .fields.three .checkbox:hover label {color: rgba(33,37,41,0.5);}
.contact-form .fields.three .checkbox:hover {border-bottom: 2px solid #07bfbc;}
.contact-form .fields.three .checkbox:focus-within label {color: rgba(33,37,41,1);}

.contact-form .details {margin: 0 0 2em 0;}
.contact-form .submit input {margin: 0 0 0 0; padding: 0 1.5em 0 1.5em; min-height: 80px; border-radius: 5px; color: #ffffff; background: rgb(0,221,233); background: rgba(7,191,188,1); text-transform: uppercase; font-size: 1.2em; letter-spacing: 0.1em; -webkit-transition: all .3s linear; -moz-transition: all .3s linear; transition: all .3s linear; border: none; cursor: pointer; width: 100%; box-sizing: border-box;}
.contact-form .submit input:hover {background: rgba(7,191,188,0.8);}	
.contact-form .submit input:focus {background: rgba(7,191,188,0.8);}

input:focus,
select:focus,
textarea:focus,
button:focus {outline: none;}

@media screen and (max-width: 1200px) {
	.contact-form .contact-form-section .fields.three {flex-direction: column;}
	.contact-form .contact-form-section .fields.three .column {margin-bottom: 2em; display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-between; width: 100%;}
	.contact-form .contact-form-section .fields.three h5 {width: 100%;}
	.contact-form .contact-form-section .fields.three .checkbox {flex-direction: row; width: calc(1/2*100% - (1 - 1/2)*2em);}
}

@media screen and (max-width: 1000px) {
	.contact-form .contact-form-section .fields.two {flex-direction: column; flex-wrap: wrap;}
	.contact-form .contact-form-section .fields.two .column {width: 100%;}
}

@media screen and (max-width: 640px) {
	.contact-form .contact-form-section {margin-bottom: 2em;}
	.contact-form .contact-form-section .fields.three .checkbox {width: 100%;}
	.contact-form .contact-form-section .form-header {font-size: 80%;}
	.contact-form .marketing {font-size: 80%;}
	.contact-form .contact-form-section .fields h5 {font-size: 90%;}
	.contact-form .contact-form-section .fields .checkbox label {font-size: 90%;}
	.contact-form .contact-form-section .fields.three .column {margin-bottom: 1em;}
}

/* ==========================================================================
   Footer
   ========================================================================== */

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

.footer .content {position: relative; overflow: hidden;}
.footer .content .wrapper {z-index: 1; position: relative;}
.footer .content::after {content: ""; opacity: 1; top: 0; left: 0; bottom: 0; right: 0; position: absolute; z-index: 0; background-image: url('/img/av-dark.svg'); background-size: contain; background-repeat: no-repeat; background-position: bottom right;}
.footer .content h3 {margin: 0; padding: 0; color: #ffffff; text-transform: none; font-size: 1.5em;}
.footer .content h4 {margin: 0; padding: 0; color: #ffffff; text-transform: none; font-weight: 100; font-size: 1.25em;}

.footer .content .address {margin: 0; padding: 0; display: flex; flex-direction: row; flex-wrap: wrap;}
.footer .content .address h4 {margin: 0; padding: 0 0.5em 0 0; color: #ffffff; font-weight: 500; font-size: 1.25em}
.footer .content .address span {margin: 0; padding: 0 0.5em 0 0; color: #ffffff; font-size: 1.25em}

.footer .content .container {display: flex; flex-direction: row; justify-content: space-between; align-items: flex-start;}
.footer .content .container .contact,
.footer .content .container > .social,
.footer .content .container .location {width: 30%; flex-grow: 1;}

.footer .content .contact ul {margin: 1em 0 0 0; padding: 0;}
.footer .content .contact ul li {margin: 0; padding: 0; list-style: none; font-size: 1.25em;}
.footer .content .contact ul li a {color: rgba(255,255,255,1); line-height: 1.75; display: flex; flex-direction: column;}
.footer .content .contact ul li a:hover {color: rgba(255,255,255,0.7);}
.footer .content .contact ul li a::after {content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,79,95,1) 25%, rgba(255,135,63,1) 100%);}
.footer.teal .content .contact ul li a::after {background: rgb(0,221,233); background: linear-gradient(-45deg, rgba(2,149,166,1) 25%, rgba(7,191,188,1) 100%);}
.footer .content .contact ul li a:hover::after {width: 40px;}
.footer .content .contact ul li.tel,
.footer .content .contact ul li.mobile a {color: rgba(255,255,255,1);}
.footer .content .contact ul li.tel,
.footer .content .contact ul li.mobile a:hover {color: rgba(255,255,255,0.7);}

.footer .content .social ul {margin: 1em 0 0 0; padding: 0; display: flex; flex-direction: row;}
.footer .content .social ul li {margin: 0 0.5em 0 0; padding: 0; list-style: none; font-size: 2em;}
.footer .content .social ul li a {color: rgba(255,255,255,1); display: flex; flex-direction: column;}
.footer .content .social ul li a:hover {color: rgba(255,255,255,0.7);}
.footer .content .social ul li a::after {margin: 0.25em 0 0 0; content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,79,95,1) 25%, rgba(255,135,63,1) 100%);}
.footer.teal .content .social ul li a::after {background: rgb(0,221,233); background: linear-gradient(-45deg, rgba(2,149,166,1) 25%, rgba(7,191,188,1) 100%);}
.footer .content .social ul li a:hover::after {width: 20px;}


.footer .copyright {display: flex; flex-direction: row; justify-content: space-between; align-items: center;}
.footer .copyright small {color: #ffffff; font-size: 1em;}
.footer .copyright ul {margin: 0; padding: 0; display: flex; flex-direction: row;}
.footer .copyright ul li {margin: 0 1em; padding: 0; list-style: none; font-size: 1em; text-transform: uppercase;}
.footer .copyright ul li a {padding: 0; color: #ffffff; text-decoration: none; display: flex; flex-direction: column; transition: 0.3s ease-in-out; line-height: 2;}
.footer .copyright ul li a:hover {color: rgba(255,255,255,0.7);}
.footer .copyright ul li a::after {content: ''; height: 2px; width: 0; transition: 0.3s ease-in-out; background: rgb(255,79,95); background: linear-gradient(45deg, rgba(255,79,95,1) 25%, rgba(255,135,63,1) 100%);}
.footer.teal .copyright ul li a::after {background: rgb(0,221,233); background: linear-gradient(-45deg, rgba(2,149,166,1) 25%, rgba(7,191,188,1) 100%);}
.footer .copyright ul li a:hover::after {width: 40px;}
.footer .copyright ul li:last-child {margin-right: 0;}

.footer .copyright .container {display: flex; flex-direction: row; justify-content: space-between; align-items: center;}

@media screen and (orientation: portrait) {
	.footer .content::after {background-size: cover;}
}

@media screen and (max-width: 1400px) {
	.footer .content .container {flex-wrap: wrap;}
	.footer .content .container .contact,
	.footer .content .container > .social {margin-bottom: 2em; width: 45%; flex-grow: inherit;}
	.footer .content .container .location {width: 70%; flex-grow: inherit;}
}

@media screen and (max-width: 900px) {
	.footer .copyright .container {padding: 1em 0; flex-direction: column-reverse; justify-content: center; align-items: flex-start}
	.footer .copyright ul li {margin: 0 1em 0 0;}
	.footer .copyright small {width: 90%;}
	
	.footer .content h4,
	.footer .content .address span,
	.footer .content .contact ul li,
	.footer .copyright small,
	.footer .copyright ul li {font-weight: 300;}
}

@media screen and (max-width: 640px) {
	.footer .content .container {flex-direction: column;}
	.footer .content .container .contact,
	.footer .content .container > .social,
	.footer .content .container .location {width: 90%;}
}

/* ==========================================================================
   AOS Mobile
   ========================================================================== */

@media screen and (max-width: 900px) {
  [data-aos-delay] {
    transition-delay: 0s !important;
  }
}


/* ==========================================================================
   Thumbnails
   ========================================================================== */

.thumbnail > figure img {display: none;}
.thumbnail > figure {margin: 0 0 15px 0; padding: 0; backface-visibility: hidden; background-size: cover; background-position: center center; background-repeat: no-repeat; left: 0px; width: 100%; height: 200px; min-height: 200px;}
   


/* ==========================================================================
   Back to top button
   ========================================================================== */

#back-top a {padding: 0; position: fixed; right: -62px; bottom: 10px; color: #ffffff; z-index: 300; width: 62px; height: 62px; line-height: 62px; display: block; background: rgba(33,37,41,1); border-radius: 31px; text-transform: uppercase; text-align: center; font-size: 2.5em; opacity: 0; z-index: 9000;}
#back-top a:hover {color: #ffffff; background: rgba(33,37,41,0.8);}

body.reveal #back-top a {right: 10px; opacity: 1;}


/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Hide visually and from screen readers
 */

.hidden {display: none !important;}

/*
* Hide only visually, but have it available for screen readers:
* https://snook.ca/archives/html_and_css/hiding-content-for-accessibility
*
* 1. For long content, line feeds are not interpreted as spaces and small width
*    causes content to wrap 1 word per line:
*    https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe
*/

.sr-only {border: 0; clip: rect(0, 0, 0, 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; white-space: nowrap; width: 1px; /* 1 */}

/*
* Extends the .sr-only class to allow the element
* to be focusable when navigated to via the keyboard:
* https://www.drupal.org/node/897638
*/

.sr-only.focusable:active, .sr-only.focusable:focus {clip: auto; height: auto; margin: 0; overflow: visible; position: static; white-space: inherit; width: auto;}

/*
* Hide visually and from screen readers, but maintain layout
*/

.invisible {visibility: hidden;}

/*
* Clearfix: contain floats
*
* For modern browsers
* 1. The space content is one way to avoid an Opera bug when the
*    `contenteditable` attribute is included anywhere else in the document.
*    Otherwise it causes space to appear at the top and bottom of elements
*    that receive the `clearfix` class.
* 2. The use of `table` rather than `block` is only necessary if using
*    `:before` to contain the top-margins of child elements.
*/

.clearfix:before,
.clearfix:after {content: " "; /* 1 */ display: table; /* 2 */}
.clearfix:after {clear: both;}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {/* Style adjustments for viewports that meet the condition */}
@media print, (-webkit-min-device-pixel-ratio: 1.25), (min-resolution: 1.25dppx), (min-resolution: 120dpi) { /* Style adjustments for high resolution devices */}

/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   https://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print {
  *,
  *:before,
  *:after {
    background: transparent !important;
    color: #000 !important;
    /* Black prints faster */
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }
  a,
  a:visited {
    text-decoration: underline;
  }
  a[href]:after {
    content: " (" attr(href) ")";
  }
  abbr[title]:after {
    content: " (" attr(title) ")";
  }
  /*
     * Don't show links that are fragment identifiers,
     * or use the `javascript:` pseudo protocol
     */
  a[href^="#"]:after,
  a[href^="javascript:"]:after {
    content: "";
  }
  pre {
    white-space: pre-wrap !important;
  }
  pre,
  blockquote {
    border: 1px solid #999;
    page-break-inside: avoid;
  }
  /*
     * Printing Tables:
     * https://web.archive.org/web/20180815150934/http://css-discuss.incutio.com/wiki/Printing_Tables
     */
  thead {
    display: table-header-group;
  }
  tr,
  img {
    page-break-inside: avoid;
  }
  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }
  h2,
  h3 {
    page-break-after: avoid;
  }
}

