@charset "UTF-8";

/* =================================
   Variables
================================= */

:root {
	--base-font-family: -apple-system, system-ui, BlinkMacSystemFont, "Montserrat", "Helvetica Neue", "Segoe UI", Arial, sans-serif;
	--base-font-serif: "EB Garamond", serif;
	--base-font-size: 2.3rem;
	--base-font-weight: 400;
	--base-max-width: 120.0rem;
	--base-trans: .1s;
	--brand-color-rgb: rgb(0, 188, 212);
	--background-color: rgb(27, 27, 38);
	--font-size-m: 1.4rem;
	--small-font-size: calc( 1.4rem * 0.875);
	--strong-color: rgb(155, 162, 217);
	--text-color: rgb(175, 191, 205);
	--title-color: rgb(242, 250, 251);
}


/* =================================
   Base
================================= */

* {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
	width: 100%;
	font-size: 62.5%
}

blockquote,
body,
dd,
dl,
figure,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
ol,
p,
pre,
ul {
	margin: 0;
	padding: 0
}

img {
	max-width: 100%
}

body {
	font: var(--base-font-weight) var(--base-font-size) var(--base-font-family);
	color: var(--text-color);
	background-color: var(--background-color);
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-kerning: normal;
	scroll-behavior: smooth
}

::selection {
	color: var(--title-color);
	background: var(--strong-color);
}

::-moz-selection {
	color: var(--title-color);
	background: var(--strong-color);
}


body {
	--body-padding: 5.6rem;
	padding: 0 var(--body-padding);
}


/* =================================
   Layout
================================= */

#root {
    min-height: 100vh;
    display: grid;
    grid-template-rows: 1fr auto;
    grid-template-columns: 100%;
}

.flex-grid-wrap {
	padding: 2rem;
}

.flex-grid {
    display: flex;
    justify-content: center;
    align-items: center;
}

.flex-grid > * {
    flex: 0 1 100%;
}

.flex-grid > *:not(:first-child) {
	margin-left: 2rem;
}


/* =================================
   Intro
================================= */

.home main {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

#intro {
    max-width: var(--base-max-width);
    margin: 0 auto;
	font-size: 1.6rem;
    line-height: 2.4rem;    
}

#intro .wrapper {
	padding-top: 0;
	min-height: 100vh;
	display: flex;
	align-items: center;
}

#intro .block-cont {
	max-width: 69rem;
	top: -6.5vh;
	position: relative;
}

#intro .block-cont h1 {
	font-size: 3.2rem;
	line-height: 4.2rem;
	font-weight: 500;
    margin-bottom: .2rem;
    color: #fff;
}

#intro .block-cont h2 {
	font-size: 2.5rem;
    line-height: 3.2rem;
    color: rgb(0, 188, 212);
    margin-bottom: 2.2rem;
    font-family: var(--base-font-serif);
    font-style: normal;
    font-weight: 400;
}

#intro .block-cont h2 em {
    font-family: "Libre Baskerville", "EB Garamond", serif;
    font-style: italic;
    font-size: 80%;	
}

#intro .block-cont a {
	text-decoration: none;
	color: #fff;
}

#intro .block-cont p {
    line-height: 2.8rem;
    margin-bottom: 1.8rem;
    font-weight: 300;
}


/* =================================
   Case studies
================================= */

section.case-study {
    padding: 0 8rem;
    margin: 0rem 4rem 9rem;
    overflow: hidden;
}

section.case-study .wrapper {
	align-items: center;
	display: flex;
	min-height: 40vh;
    padding: 6rem 0 5rem;	
}

section.case-study:nth-child(odd) .block-cont > div:nth-child(1) {
	order: 2;
}

section.case-study:nth-child(odd) .block-cont > div:nth-child(2) {
	order: 1;
}

section.case-study .featured-img.align-bottom {
	margin-bottom: -27%;
    margin-top: -6rem;
    flex-basis: 120%;
}

section.case-study:nth-child(even) .block-cont .excerpt {
    margin-left: 2rem;
    margin-right: 0;
}

section.case-study:nth-child(odd) .block-cont .excerpt {
    order: 1;
    margin-left: 0;
    margin-right: 2rem;
}

section.case-study .excerpt {
    flex-basis: 80%;
}

section.case-study:nth-child(even) .block-cont > div:nth-child(2) {
	text-align: right;
}

section.case-study:nth-child(even) .block-cont > div:nth-child(1) {
    margin-right: 4rem;
}

section.case-study:nth-child(odd) .block-cont > div:nth-child(1) {
    margin-left: 4rem;
}

section.case-study .block-cont > div:nth-child(2) a:last-of-type {
	margin-right: 0;
}

section.case-study .buttons .btn {
	margin-right: 0;
}

section.case-study .excerpt h3,
section.case-study .excerpt p {
	/* font-family: 'Montserrat', sans-serif; */
}

section.case-study .excerpt h3 {
    font-size: 3.25rem;
    font-weight: 500;
    line-height: 6rem;
    margin-bottom: 1.25rem;
}

section.case-study .excerpt p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 2.5rem;
    margin-bottom: 1.8rem;
}

section.case-study .buttons {
	padding: 1rem 0;
}

section.case-study .buttons .btn{
	margin-right: 10px;
}


/* =================================
   Buttons
================================= */

.btn {
    display: inline-block;
    padding: 0.375rem 2.75rem;
    margin-bottom: 0;
    font-weight: 500;
    touch-action: manipulation;
    cursor: pointer;
    user-select: none;
    background-image: none;
    text-decoration: none;
    font-size: 1.35rem;
    line-height: 3rem;
    border: 2px solid rgba(108, 89, 179, 1);
    color: rgba(108, 88, 179, 0.75);
    border-radius: 40px;
    background: transparent;
    transition: all 0.3s ease 0s;
}


/* =================================
   Case study specifics
================================= */

/* ==== SHA === */
.brand-sha {
	background-color: #FDFDFE;
}

.brand-sha h3,
.brand-sha p {
	color: #757575;
}

.brand-sha .btn {
	border-color: #757575;
	color: #757575;
}

.brand-sha .btn-outline:hover {
  border: 2px solid rgba(117, 117, 117, 0.5);
  color: rgba(117, 117, 117, 0.75);
}

.brand-sha .btn-filled {
	background-color: #757575;
	color: #fff;
}

.brand-sha .btn.btn-filled:hover {
  background: rgba(117, 117, 117, 0.75);
  border: 2px solid rgba(117, 117, 117, 0.25);
}

/* ==== TVN === */
.brand-tvn {
	background-color: #00edc1;
}

.brand-tvn h3,
.brand-tvn p {
	color: #fff;
}

.brand-tvn .btn {
	border-color: #fff;
	color: #fff;
}

.brand-tvn .btn-outline:hover {
  border: 2px solid rgba(255, 255, 255, 0.75);
  color: rgba(255, 255, 255, 0.95);
}

.brand-tvn .btn-filled {
	background-color: #fff;
	color: #00edc1;
}

.brand-tvn .btn.btn-filled:hover {
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid rgba(255, 255, 255, 0.25);
}

/* ==== 1D+ === */
.brand-oneid {
	background-color: #144B9F;
}

.brand-oneid h3,
.brand-oneid p {
	color: #fff;
}

.brand-oneid .btn {
	border-color: #fff;
	color: #fff;
}

.brand-oneid .btn-outline:hover {
  border: 2px solid rgba(255, 255, 255, 0.75);
  color: rgba(255, 255, 255, 0.95);
}

.brand-oneid .btn-filled {
	background-color: #fff;
	color: #144B9F;
}

.brand-oneid .btn.btn-filled:hover {
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid rgba(255, 255, 255, 0.25);
}

/* ==== BAT === */
.brand-bat {
	background-color: #6641EF;
}

.brand-bat h3,
.brand-bat p {
	color: #fff;
}

.brand-bat .btn {
	border-color: #fff;
	color: #fff;
}

.brand-bat .btn-outline:hover {
  border: 2px solid rgba(255, 255, 255, 0.75);
  color: rgba(255, 255, 255, 0.95);
}

.brand-bat .btn-filled {
	background-color: #fff;
	color: #6641EF;
}

.brand-bat .btn.btn-filled:hover {
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid rgba(255, 255, 255, 0.25);
}

/* ==== EDELSA === */
.brand-edelsa {
	background-color: #FF6B6B;
}

.brand-edelsa h3,
.brand-edelsa p {
	color: #fff;
}

.brand-edelsa .btn {
	border-color: #fff;
	color: #fff;
}

.brand-edelsa .btn-outline:hover {
  border: 2px solid rgba(255, 255, 255, 0.75);
  color: rgba(255, 255, 255, 0.95);
}

.brand-edelsa .btn-filled {
	background-color: #fff;
	color: #FF6B6B;
}

.brand-edelsa .btn.btn-filled:hover {
  background: rgba(255, 255, 255, 0.9);
  border: 2px solid rgba(255, 255, 255, 0.25);
}


/* =================================
   PRIVATE AREA
================================= */

.lock-wr {
	text-align: center;
	margin-bottom: 20px;
}

.lock-wr .hide {
	display: none;
}

.lock-wr p {
    margin: 10px 0;
}

.lock-wr .loadingCircle {
	transform: rotate(60deg);
	transform-origin: 50% 50%;
	fill: #EDEFF3;
	animation: rotation 1.5s infinite linear; 
}

.hidden {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

.icons {
	display: none;
}

.icon {
	display: inline-block;
	fill: #606468;
	font-size: 16px;
	font-size: 1rem;
	height: 1.5em;
	vertical-align: middle;
	width: 1.5em;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0; 
}

button,
input { 
  overflow: visible;
}

button,
select { /* 1 */
  text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

input {
	background-image: none;
	border: 0;
	color: inherit;
	font: inherit;
	margin: 0;
	outline: 0;
	padding: 0;
	transition: background-color 0.3s;
}

input[type='submit'] {
	cursor: pointer;
}

.form {
	margin: -14px;
	margin: -0.875rem;
}

.form input[type='password'],
.form input[type='submit'] {
	width: 100%;
}

.form__field {
	display: flex;
	margin: 14px;
	margin: 0.875rem;
}

.form__input {
	flex: 1;
}

.login {
	color: #eee;
}

.login label,
.login input[type='password'],
.login input[type='submit'] {
	border-radius: 0.25rem;
	padding: 16px;
	padding: 1rem;
}

.login label {
	background-color: #363b41;
	border-bottom-right-radius: 0;
	border-top-right-radius: 0;
	padding-left: 20px;
	padding-left: 1.25rem;
	padding-right: 20px;
	padding-right: 1.25rem;
}

.login input[type='password'],
.login input[type='text'] {
	background-color: #3b4148;
	border-bottom-left-radius: 0;
	border-top-left-radius: 0;
}

.login input[type='password']:focus,
.login input[type='password']:hover{
	background-color: #434a52;
}

.login input[type='submit'] {
	background-color: #00bcd4;
	color: #eee;
	font-weight: 700;
	text-transform: uppercase;
}

.login input[type='submit']:focus,
.login input[type='submit']:hover {
  background-color: #00a8c2;
}


/* =================================
   FX
================================= */

.fadeup-enter {
	opacity: 0.01;
	transform: translateY(20px);
	transition: opacity 300ms cubic-bezier(0.645, 0.045, 0.355, 1), transform 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

.fadeup-enter-active {
	opacity: 1;
	transform: translateY(0px);
	transition: opacity 300ms cubic-bezier(0.645, 0.045, 0.355, 1), transform 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

.fadedown-enter {
	opacity: 0.01;
	transform: translateY(-20px);
	transition: opacity 300ms cubic-bezier(0.645, 0.045, 0.355, 1), transform 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

.fadedown-enter-active {
	opacity: 1;
	transform: translateY(0px);
	transition: opacity 300ms cubic-bezier(0.645, 0.045, 0.355, 1), transform 300ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

.fade-enter {
	opacity: 0.01;
	transition: opacity 1000ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

.fade-enter-active {
	opacity: 1;
	transition: opacity 1000ms cubic-bezier(0.645, 0.045, 0.355, 1);
}

@keyframes rotation {
  0% {
    transform: rotate(60deg);
  }
  100% {
    transform: rotate(420deg);
  }
}


/* ==== Portfolio Case Study Hover === */
section.case-study {
    transition: transform 400ms cubic-bezier(.215,.61,.355,1);
}

section.case-study .featured-image {
    transform: scale(0.9);
    transition: transform 400ms cubic-bezier(.215,.61,.355,1);
}

section.case-study img {
    transition: transform 400ms cubic-bezier(.215,.61,.355,1);
}

section.case-study:hover {
    transform: scale(0.99);
}

section.case-study:hover .featured-image {
    transform: scale(0.99);
}

section.case-study:hover img {
    transform: scale(1.05);
}


/* =================================
   Media Queries
================================= */

@media screen and (max-width:38.75em) {
	body {
		--body-padding: 3.2rem
	}
}

/* ==== Flexbox Grid === */
@media (max-width: 36rem) {
  .flex-grid {
    flex-wrap: wrap;
  }

  .flex-grid > * {
    margin: 2rem 0 0 !important;
  }
}

@media (min-width: 36rem) {
  .flex-grid + .flex-grid {
    margin-top: 2rem;
  }
}

/* ==== Mobile === */
@media (max-width: 31.25em) {
	body {
	    --body-padding: 3.8rem;
	}

	#root,
	.home main {
    	min-height: auto;
    }

	section .wrapper {
		padding-top: 6rem;
		min-height: 70vh;
	}

	section .block-cont h1 {
		font-size: 3rem;
		margin-bottom: 0.4rem;
	}

	section .block-cont h2 {
	    line-height: 2.8rem;	
	    margin-bottom: 2rem;
	}

	section .block-cont h2 em::after {
		content: "\A";
		white-space: pre;
	}

	section .block-cont p {
		margin-bottom: 1.4rem;
	}

}

@media screen and (max-width:20em) {
	html {
		font-size: 57.25%;
	}
	body {
		--body-padding: 1.6rem;
	}
}

/* ==== Desktop === */
@media (max-width: 1112px) {
	section.case-study .featured-img.align-bottom {
	    margin-bottom: -24%;
	    margin-top: -10rem;
	    flex-basis: 100%;
	}
}

@media (max-width: 1080px) {
	section.case-study {
	    padding: 0 4rem;
	    margin: 0rem 3rem 8rem;
	}
}

/* ==== Tablet === */
@media (max-width: 1024px) {
	section.case-study {
	    margin: 0rem 1rem 6rem;
	}	

	section.case-study .excerpt h3 {
	    font-size: 3rem;
	    line-height: 3rem;
	    margin-bottom: 1.25rem;
	}

	section.case-study .excerpt p {
	    font-size: 1.5rem;
	    line-height: 2.3rem;
	    margin-bottom: 1.4rem;
	}
}

@media (max-width: 940px) {
	section.case-study {
	    margin: 0 0 6rem;
	}	
	
	section.case-study .wrapper {
	    padding: 5rem 0 4rem;
	}	

	section.case-study:nth-child(even) .block-cont .excerpt {
		margin-left: 0;
	}

	section.case-study:nth-child(odd) .block-cont .excerpt {
		margin-right: 0;
	}
	
	section.case-study:nth-child(even) .block-cont > div:nth-child(1) {
	    margin-right: 3rem;
	}	
	section.case-study:nth-child(odd) .block-cont > div:nth-child(1) {
	    margin-left: 3rem;
	}
}

/* ==== Small Tablet === */
@media (max-width: 880px) {
	section.case-study {
	    background: none;
	    margin-bottom: 4rem;
	}

	section.case-study .wrapper {
	    padding: 0 0 3rem;
	}

	section.case-study .featured-img {
	    padding: 5rem 6rem 4rem;
	    margin-bottom: 3rem;
	}	

	section.case-study .block-cont {
	    flex-direction: column;
	}

	section.case-study:nth-child(even) .block-cont > div:nth-child(2) {
	    text-align: left;
	    margin-right: 0;
	}
	section.case-study:nth-child(even) .block-cont > div:nth-child(1) {
		margin-right: 0;
	}
	section.case-study:nth-child(odd) .block-cont > div:nth-child(1) {
		order: initial;
		margin-left: 0;
	}

	section.case-study .excerpt h3 {
	    color: #fff;
	}

	section.case-study .excerpt p {
	    color: #afbfcd;
	   	font-weight: 300;
	}	

	section.case-study .excerpt .buttons .btn.btn-filled {
	    border-color: #fff;
	    background: #fff;
	    color: #1b1b26;
	}

	section.case-study .excerpt .buttons .btn.btn-outline {
	    color: #fff;
	    border-color: #fff;
	}

	section.case-study .featured-img.align-bottom {
	    padding-top: 0;
	    margin-top: 0;
	    margin-bottom: 3rem;
	    flex-basis: initial;
	    overflow: hidden;
	}

	section.case-study .featured-img.align-bottom img {
	    margin-bottom: -34%;
	}	

	/* ==== Brand specifics === */
	section.case-study.brand-sha .featured-img {
		background-color: #FDFDFE;
	}

	section.case-study.brand-tvn .featured-img {
		background-color: #00edc1;
	}

	section.case-study.brand-oneid .featured-img {
		background-color: #144B9F;
	}

	section.case-study.brand-bat .featured-img {
		background-color: #6641EF;
	}

	section.case-study.brand-edelsa .featured-img {
		background-color: #FF6B6B;
	}

	section.case-study.brand-sha .buttons .btn.btn-filled {
    	background-color: #fdfdfe;
    	border-color: #fdfdfe;
    	color: var(--background-color);
	} 

	section.case-study.brand-tvn .buttons .btn.btn-filled {
		border-color: #00edc1;
		background-color: #00edc1;
		color: #fff;
	} 

	section.case-study.brand-oneid .buttons .btn.btn-filled {
		border-color: #144B9F;
		background-color: #144B9F;
		color: #fff;
	} 

	section.case-study.brand-bat .buttons .btn.btn-filled {
		border-color: #6641EF;
		background-color: #6641EF;
		color: #fff;
	} 

	section.case-study.brand-edelsa .buttons .btn.btn-filled {
		border-color: #FF6B6B;
		background-color: #FF6B6B;
		color: #fff;
	} 

	section.case-study.brand-sha .buttons .btn.btn-outline {
		color: #fff;
		border-color: #fff;
	}

	section.case-study.brand-tvn .buttons .btn.btn-outline {
		border-color: #00edc1;
	}

	section.case-study.brand-oneid .buttons .btn.btn-outline {
		color: #fff;
		border-color: #144B9F;
	}

	section.case-study.brand-bat .buttons .btn.btn-outline {
		color: #fff;
		border-color: #6641EF;
	}

	section.case-study.brand-edelsa .buttons .btn.btn-outline {
		color: #fff;
		border-color: #FF6B6B;
	}
}

/* ==== Mobile === */
@media (max-width: 600px) {
	section.case-study {
		margin: 0 0 6rem;
		padding: 0;
	}

	section.case-study .featured-img {
		padding: 2.5rem 2rem 2rem;
	}
}



/* 2024 hide case studies */
section.case-study {
	display: none;
}