/****** MASTER CSS *******/

/****** RESET *******/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
	/* ADD DEFAULT FONT SETTINGS HERE */
	font-family: sofia-pro, sans-serif;
}
ol, ul {
	list-style: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/*micro clear fix */
.grouping:before,
.grouping:after {
	content: " ";
	display: table;
}
.grouping:after {
	clear: both;
}
img, iframe, video, object {
	max-width: 100%;
	overflow:hidden;
}
a {
	text-decoration:none;
	color:#ffffff;
	font-size: 16px; 
	margin-bottom: 10px;	
}

h1 {	
	font-size: 30px; 
	margin-bottom: 10px;	
	line-height:120%;
}

h2 {	
	font-size: 25px; 
	margin-bottom: 10px;	
}

h3 {	
	font-size: 20px; 
	margin-bottom: 10px;	
}

p {	
	font-size: 18px;
	line-height: 1.8;
	margin-bottom: 10px;
	font-weight: 100;
	letter-spacing: 1.6px;
	text-align:justify;
}
strong, b {
	font-weight: bold;
}

body {
	background-color: #050283;
}

video::-internal-media-controls-download-button {
    display:none;
}

video::-webkit-media-controls-enclosure {
    overflow:hidden;
}

video::-webkit-media-controls-panel {
    width: calc(100% + 30px); /* Adjust as needed */
}

.clickable {
	cursor:pointer;
}

.p-white {
	color:#fff;
}

.line_through {
	text-decoration: line-through;
}

/****** 404 styles ******/

#lost {
	max-width:400px !important;
}

/****** SEO ******/

.seo_title {
	visibility:hidden;
	opacity:0;
	height:1px;
	width:1px;
	overflow:hidden;
}

/****** DISCLAIMER ******/

#disclaimer {
	position:fixed;
	bottom:0;
	padding:10px;
	font-size:12px;
	text-align:center;
	opacity:0.5;
	color:#ffffff;
}

/****** SVGs ******/

.st0{
	fill:#FFFFFF;

}

.st1{
	fill:none;
	stroke:#FFFFFF;
	stroke-width:5;
	stroke-miterlimit:10;
} 

.st2{
	fill:#FFFFFF;
}

.st3{
	opacity:0.3;
	fill:#FFFFFF;
	enable-background:new ;
}
.st4{
	fill:none;
	stroke:#FFFFFF;
	stroke-width:5;
	stroke-miterlimit:10;
}

/****** MODULAR ******/

.float-left {
	float: left;
}

.float-right {
	float: right;
}

.hide {
	display: none;
}

.section-thin {
	margin-left: auto;
	margin-right: auto;
	max-width:960px;
}

.section-full {
	width: 100%;
  height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin-top: 79px;
  padding-bottom: 0;
}

/****** MAIN CONTAINER ******/

.main-container {
	position:absolute;
	width:100%;
	height:100%;
	top:0;
	overflow-x:hidden;
}

.container-left {
	width: 8%;
	margin: 10px 1% 0;
	display: block;
	text-align:right;
}

.container-right {
	max-width: 81%;
	margin:0 8% 0 1%;
	display: block;
}

.grid_container_outer {	
	display: table;
	position: absolute;
  height: 100%;
  width: 100%;
  padding-top: 65px;
}

.grid_container_inner {
	margin-left: auto;
	margin-right: auto;
	max-width:100%;
}

.grid_container_middle {
	display: table-cell;
	vertical-align: middle;
}

.spacer {
	width:100%;
	height:20px;
	position:relative;
	clear:both;
}

.portfolio-container {
	text-align: center;
  margin: auto;
	clear:both;  
}

/****** TOP NAV ******/


.top_nav {
	display:block;
	position:fixed;
	top:0;
	left:0;
	right:0;
	width:100%;
	border-bottom:3px solid #fff;
	background-color:#050283;
	z-index:999;
}

#burger_icon {
	padding:20px;
	display:none;
}

.nav_list_container {
	width:100%;
	float: left;
}

.nav_list {
		display:inline-block;
		vertical-align: middle;
    text-align: center;
}

.nav_list div {
	padding:30px 10px;
}

#logo_copy,
#studio_copy {
	display:auto;
}

#logo_stacked {
	display:none;
	height: 69px;
	width: 160px;
}

.nav_list {
	color:#fff;
	background-color:rgba(0,0,0,0);
	transition:background-color 0.25s;
}

.nav_list:hover {
	background-color:rgba(0,0,0,0.3);
	transition:background-color 0.25s;
}

.nav {
	cursor:pointer;
}

.burger_line {
	height:5px;
	width:30px;
	background-color:#fff;
	margin:5px 0;
}

/****** TOP LOGO ******/

.top_logo_container {
    position: absolute;
    right: 10px;
    display: block;
    top:10px;
}

.top_copy_container {
	margin-left: 12px;
}

#top_logo {
	width:80px;
}

#top_logo_copy {
    position: relative;
    height: 31px;
    width: 280px;
}

#top_logo_studio {
  bottom: 0;
  width: 281px;
  height: 12px;
  position: absolute;
}

#top_logo_stacked {
	height:52px;
	width: 122px;
}

#top_logo_copy,
#top_logo_studio {
	display:block;
}

#top_logo_stacked {
	display:none;
}

/****** PAGE ELEMENTS ******/

.inactive-section {
	display:none;
	visibility: hidden;
}

/****** ICONS ******/

.icon-container {
	height:155px;
	margin: 15px;
	box-sizing: border-box;
	text-align: center;
	display: inline-block;
	background-color:rgba(0,0,0,0);
}

.icon-top {
	vertical-align: baseline;
}

.icon-bottom {
	vertical-align: middle;
}

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

.icon-text {
	text-align: center;
  position: relative;
  top: -100px;
  opacity:0;
  visibility:hidden;
}

.icon-animation:hover > .icon-text {
	opacity:1;
  visibility:visible;

  transition: opacity 0.5s;
	-webkit-transition: opacity 0.5s;
	-moz-transition: opacity 0.5s;
}

.thick-line {
	height:20px;
	width:100%;
	background-color:#ffffff;
}

.thin-line {
	height:7px;
	width:100%;
	background-color:#ffffff;
}

/****** SLICK ******/

/* PLUG IN */

/* Slider */
.slick-slider
{
    position: relative;

    display: block;
    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}
.slick-list:focus
{
    outline: none;
}
.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
         -o-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
}
.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}
.slick-track:after
{
    clear: both;
}
.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}
[dir='rtl'] .slick-slide
{
    float: right;
}
.slick-slide img
{
    display: block;
}
.slick-slide.slick-loading img
{
    display: none;
}
.slick-slide.dragging img
{
    pointer-events: none;
}
.slick-initialized .slick-slide
{
    display: block;
}
.slick-loading .slick-slide
{
    visibility: hidden;
}
.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
    display: none;
}

/****** KEYFRAMES ******/

/* Safari 4.0 - 8.0 */
@-webkit-keyframes nextarrow {
	0%, 20%, 50%, 80%, 100% {	
    left:0;
  }
	40% {
    left:14px;
  }
	60% {
    left:7px;
  }
} 

/* Standard syntax */ 
@keyframes nextarrow {
	0%, 20%, 50%, 80%, 100% {	
    left:0;
  }
	40% {
    left:14px;
  }
	60% {
    left:7px;
  }
}

/* Safari 4.0 - 8.0 */
@-webkit-keyframes prevarrow {
	0%, 20%, 50%, 80%, 100% {	
    left:0;
  }
	40% {
    left:-14px;
  }
	60% {
    left:-7px;
  }
}

/* Standard syntax */ 
@keyframes prevarrow {
	0%, 20%, 50%, 80%, 100% {	
    left:0;
  }
	40% {
    left:-14px;
  }
	60% {
    left:-7px;
  }
}

/* CUSTOM */

.slick-slide, .slick-slide *{ outline: none !important; }

.slick-list {
		height: 100%;
    width: 100%;
}

.slick-prev,
.slick-next {
	display:inline-block;
	color:#fff;
	font-size:2em;
	line-height:1em;
	padding:10px;
	margin:10px;	
	cursor: pointer;
	background-color:rgba(255,255,255,0);
	width:30px;
	height:30px;
	position: relative;
}

.slick-prev img,
.slick-next img {
	width:inherit;
	height:inherit;
}

.slick-prev {
	-webkit-animation: prevarrow 1s infinite;
  animation: prevarrow 1s infinite;
}

.slick-next {
	-moz-transform: scaleX(-1);
	-o-transform: scaleX(-1);
	-webkit-transform: scaleX(-1);
	transform: scaleX(-1);
	filter: FlipH;
	-ms-filter: "FlipH";

	-webkit-animation: nextarrow 1s infinite;
  animation: nextarrow 1s infinite;
}

.slick-prev:hover,
.slick-next:hover {

	background-color:rgba(255,255,255,0.2);
	transition:background-color 0.25s;
}

.instructions {
    padding: 10px;
    margin: 10px;
    display: inline-block;
    vertical-align: baseline;
    color: #fff;
}

.instructions-top {
	display:none;
}

.overflow_settings {
	overflow:hidden;
}

/****** BRANDS SECTION ******/

.full_grid {
	top:0;
	left:0;
	bottom:0;
	right:0;
	height:100%;
	width:100%;
	display:block;
	position:absolute;
	-webkit-overflow-scrolling: touch;	
}

.full_grid .grid_item {
  display: inline-block;
  padding: 0 2%;
  margin: 0;
  vertical-align: top;
}

.full_grid .grid_item .brand_name {
	text-align: center;
	width:100%;
	height:100%;
  display:table;
  vertical-align: top;
}

.full_grid .grid_item .brand_name span {
	color: #fff;
	font-size:.75em;
	font-weight:100;
	letter-spacing:1.1px;
}

.full_grid .brand_name .vertical_text {
	vertical-align: middle;
	display:table-cell;
}

.full_grid .grid_item:nth-child(odd) {
	background-color:rgba(255,255,255,0.25);
}

.full_grid .grid_item:nth-child(even) {
	background-color:rgba(255,255,255,0.2);
}

/****** BANNERS SECTION ******/

.banner-container {
  min-width: 300px;
  min-height: 250px;
	display:block;
	margin:2% 0;
	z-index: 99;
	cursor:pointer;
	position: relative;
}

.banner-overlay {
    width: 300px;
    height: 250px;
    background-color: rgba(3,1,172,0);
    z-index: 99;
    position: absolute;
    margin-left: 10px;
}

.banner-overlay:hover {
	background-color:rgba(3,1,172,0.4);
	transition:background-color 0.25s;
	z-index: 99;
}

.banner-overlay:active {
	background-color:rgba(3,1,172,0.4);
	transition:background-color 0.25s;
	z-index: 99;
}

.portfolio-banner {
	width:300px;
	height:250px;
	display:block;
}

/****** MULTIMEDIA SECTION ******/

.overflow_settings {
	position:relative;
	padding-bottom:56.25%;
	padding-top:30px;
	height:0;
	overflow:hidden;
}

.overflow_settings iframe, .overflow_settings object, .overflow_settings embed {
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

/****** WEBSITES SECTION ******/

.websites{
	display:none;
}

.site_info_container {
	background-color:rgba(0,0,0,0.3);
	transition:background-color 0.25s;
}

.site-info {
	color:#ffffff;
	text-align:center;
	margin:auto;
	padding:20px;
}

.portfolio-sites {
	position:relative;
}

.site_container {
	  width: 300px !important;
    width: 300px !important;
    height: 250px !important;
    margin: 1% 10px;
	z-index: 99;
	cursor:pointer;
	position: relative; 
	box-sizing:  border-box;
	line-height:140%;
}

.site_info_container {
	width: 300px !important;
  height: 250px;
  position:absolute;
	display:table;
}

.site_info {
	width: 100%;
  height: 100%;
	cursor:pointer;
	display: table-cell;
	vertical-align: middle;
	padding:30px;
}

.site_container img {
	width:300px;
	height:250px;
	display:block;
	position:absolute;
	opacity:0.3;
	transition: opacity 0.25s;
}

.site_container:hover img {
	opacity:0.6;
	transition: opacity 0.25s;
}


/******* EDMs SECTION ******/

.edm_image {
    display: inline-block;
    width: 42%;
    margin: 0 -50px;
}

/****** TILT EFFECT ******/

.above-fold {
	position: relative;
	height: 100vh;
	overflow: hidden;
}

.hero-section {	
	z-index: -1;
}

.hero-section img {
  position: absolute;
  opacity: 0.45;
  margin: auto;
  width: 100%;
	top: -25%; 
  right: -25%; 
  bottom: -25%; 
  left: -25%;
}

/******* INTRO ANIMATION ******/

.intro_hidden {
	visibility:hidden;
	opacity:0;
}

#intro-animation {
	z-index:9999;
}

.logo_line {
	background-color:#FFFFFF;
}

#logo_copy_container {
	-moz-user-select: -moz-none;
   	-khtml-user-select: none;
   	-webkit-user-select: none;
   	-ms-user-select: none;
	user-select: none;

	height:149px;
	width:374px;
	position: fixed;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
	
	pointer-events: none;
	
	opacity:0;
	visibility:hidden;
	
}

#logo_container{	
    height: 149px;
    width: 227px;
    position: relative;
    bottom: 0;
    margin-left: auto;
    margin-right: 0;
    margin-bottom: 20px;
    text-align: right;
}

#logo_container_svg {
    position: absolute;
    top: 0;
    right: 7px;
}

#copy_container {
	position:absolute;
}

.overlay{
	width: 100%;
	height: 100%;
	opacity: 0.9;
	top: 0;
	left: 0;
	right: 0;
	left: 0;
	position: fixed;
	background-color: #000000;
}

/* SPEED LINES */

#speed_line_container {	
	width:60px;
	position:absolute;
	left:0;
	bottom:0;
	overflow:hidden;
}

	.speed_line {
		height:15px;
		margin-left:auto;
		margin-right:0;
		width:0;
	}
	
	#speed_line02 {
		margin-top:8px;
	}
	
	#speed_line03 {
		margin-top:8px;
	}

/* PIXEL */

#pixel {
	height:149px;
	width:153px;
	position:absolute;
	right:0;
}

	#pixel div {
		position:absolute;
	}
	
	#pixel_left {
		width:15px;
		height:149px;
		left:0;
	}
	
	#pixel_top {
		height:15px;
		width:153px;
		top:0;
	}
	
	#pixel_right {
		width:15px;
		height:149px;
		right:0;
	}
	
	#pixel_bottom {
		height:15px;
		width:153px;
		bottom:0;
	}

/* PUSHER */

#pusher {
	height:92px;
	width:90px;
	position:absolute;
	left:120px;
	bottom:14px;
}
	
#pusher div {
	position:absolute;
}
		
/* STRAIGHT */

#head_container {
	width:29px;
	height:29px;		
}

#head {
	width:inherit;
	height:inherit;
	top:0;
	left:-5px;
}

#torso {
	width:15px;
	height:48px;
	bottom:0;	
}
	
#arm {
	height: 15px;
    width: 75px;
    top: 44px;
    left: 13px;
}
	
/* LOGO COPY */

#logo_copy {
	height:40px;
	width:367px;
}

#studio_copy {
    margin-top: 10px;
    width: 367px;
    height: 16px;
}

.pp_studio_copy {
	opacity:0;
	visibility:hidden;
}

.pp_copy {
	opacity:0;
	visibility:hidden;
}


/****** RESPONSIVE ELEMENTS ******/

@media screen and (min-width: 768px) {
	.nav_list_container {
		padding: 0 20px;
	}
}

@media screen and (max-width: 900px) {
	.grid_container_inner {
		max-width:600px;
	}
	.icon-container {
		margin: 30px 30px 0px 30px;
	}
	.icon-top {
		vertical-align: top !important;
	}
	.icon-bottom {
		vertical-align: top !important;
	}
}

@media screen and (max-width: 960px) {
	#top_logo_copy,
	#top_logo_studio {
		display:none;
	}

	#top_logo_stacked {
		display:block;
	}

	.site_container {
	    margin: 0px 10px 0 0;
	}

	.edm_image {
    width: 41%;
    margin: 0 -30px;
}

@media screen and (min-width: 601px) and (max-width: 960px) {
	.portfolio-container {
		width:620px;
	}
}

@media screen and (max-width:768px) {
	.full_grid .grid_item {
		width:29.333% !important;
		height: 6% !important;
		padding:2% 2% !important;
	}
}

@media screen and (max-width: 640px) {
	
	.portfolio-container {
		display:none;
		visibility:hidden;
		width:310px;
	}

	.section-thin,
	.section-full {
    margin-top: 75px;
    padding-bottom: 0;
	}

	.sites_sect {
		margin-top:0;
	}

	.container-left {
		float:none;
		margin: 10px 20px 10px;
		width:13%;
	}

	.container-right {
    max-width: 100%;
    margin: 0 20px;
    display: block;
	}

	.top_nav {
		display:block;
	}

	#burger_icon {
		padding:20px;
		display:block;
	}

	.nav_list_container {
		display:none;
	}

	.nav_list {
    display:block;
	}

	.nav_list:nth-child(odd) {
	background-color:#4c33fd;
	}

	.grid_container_outer {
		padding-top:80px;
		padding-bottom:70px;
	}

	.slick-prev,
	.slick-next {
		margin:5px;
	}
	.arrow-controls-banners,
	.arrow-controls-video {
		display:none;
	}
	.instructions-top {
		display:block;
	}
	p {	
	line-height: 1.5;
	}
	.second-nav {
		display:none;
	}

}

@media screen and (max-width: 600px) {
	.grid_container_inner {
		max-width:550px;
	}

	.icon-container {
		margin: 15px 15px 0px 15px;
	}
}

@media screen and (max-width:498px) {
	.full_grid .grid_item {
		width:96% !important;
	}

  .above-fold {
    position:fixed;
    width: 100%;
    height: 100%;
  }
}

@media screen and (max-width: 480px) {
	.icon-container {
		margin: 2px 2px 0px 2px;
	}
}