html{
	background: var(--white);
    height: 100%;
    overflow-y: scroll;
	scroll-behavior: smooth;	
}

body{
	margin: 0;
	overflow: hidden;
	font-family: 'Roboto', sans-serif;
	color: var(--black);
	-webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;	
}

:root{
	--blue: #00b6ff;
	--white: #fff;
	--text-light: #f5f5f7;
	--dark: #000;	
	--black: #222;
	--gray: #B4BCD0;
	--gray-light: #f5f5f7;	
	--accent: #673FD7;
	--blue: #0073E6;
	--blue-light: #1981e8;
	--blue-hover: rgb(206, 210, 250);
	--border: #e0e0e3;
	--dark-gray: #161618;
	--dark-gray-2: #1c1c1f;
	--border-dark: #2e2e32;

}

:focus {
    outline: 10px auto #2f2fa2;
    outline-offset: 2px;
}

#work:focus, #contact:focus, #hamburger_setter:focus{
	outline: none;
}

/*
::-webkit-scrollbar {
	width: 10px;
}.inner_section_title h2

::-webkit-scrollbar-track {
	background: #fff;
}

::-webkit-scrollbar-thumb {
	background: #ccc;
	height: 20vh;
	border-radius: 3px; 
}

::-webkit-scrollbar-thumb:hover {
	background: #888;
}
	
*/


/*General rules*/

.main{
	display: flex;
    flex-direction: column;	
    overflow: hidden;
    position: relative;	
}


.container{
	max-width: 1920px;
	margin: auto;	
	z-index: 9;
	width: 100%;	
}

.container > .element:first-of-type {
	padding-top: var(--XL);
}

/*

.container > .element:last-of-type {
	padding-bottom: 0;
}
*/

.element{
	padding-left: var(--Margin);
	padding-right: var(--Margin);
	background: transparent;
    transition: all 0.8s ease-out;	
}

.transform{
	opacity: 0;
	scale: 0.95;
	transform: rotateX(-22.5deg);	
}

.content > *:first-child{
	margin-top: 0;
}


.content > *:last-child{
	margin-bottom: 0;
}

.theme_dark{
	background: var(--dark);
}

.theme_dark_gray{
	background: var(--dark-gray);
}


.theme_dark h1, .theme_dark h2, .theme_dark h3, .theme_dark_gray h1, .theme_dark_gray h2, .theme_dark_gray h3{
	color: var(--white);
}

.theme_dark b, .theme_dark_gray b{
	color: var(--white);
}


.theme_dark p, .theme_dark_gray p{
	color: var(--gray);	
}

a{
	transition: all 0.25s;	
}

.theme_gray{
	background: var(--gray-light);
	border-top: solid 1px var(--border);
}

.baseline{
	margin-top: 0;
}

.baseline_img{
	margin-top: 0;
	margin-bottom: 0;
}

.gradient-text{
	color: transparent !important;
    -webkit-background-clip: text;
    background-clip: text;
    background-image: linear-gradient(120deg,#2ca2b4,#5598de 24%,#7f87ff 45%,#f65aad 76%,#ec3d43);	
}

.inner-shadow{
    background-color: var(--white);
    color: transparent !important;
    text-shadow: 4px 8px 12px rgba(0 0 0 / 16%);
    -webkit-background-clip: text;
    -moz-background-clip: text;
    background-clip: text;	
}

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.setter{
	position: relative
}

.set_left{
    left: 0;
    margin-left: calc(var(--Margin) * -1.5);
    position: relative;
    width: calc(100% + var(--Margin)*1.5);
}

.set_right{
    right: 0;
    /*margin-right: calc(var(--Margin) * -1.5);*/
    position: relative;
    width: calc(100% + var(--Margin)*1.15);
}


.aspect_one{
    aspect-ratio: 4/3;
	object-fit: cover;	
}

.column-wide{
	width: 64%;
	margin-left: auto;
	margin-right: auto;	
}

.column{
	width: 50%;
	margin-left: auto;
	margin-right: auto;	
}

.img_limit{
	max-width: 480px;
}

.img_limit_large{
	max-width: 720px;
}

.img_limit_extra_large{
    max-width: unset;
    width: 100%;	
}

.img_set_left{
	margin-left: 0;
    margin-right: auto;
}

.img_set_right{
	margin-left: auto;
    margin-right: 0;
}

.img_space_large{
	margin-bottom: calc(var(--XXL)* 2) !important;
}

.gray-bg{
	background-color: var(--gray-light);
}

.rounded{
	border-radius: .875rem;
}

.image-crop{
    aspect-ratio: 16/9;
    object-fit: cover;
    object-position: 50% 50%;	
}


/*Background effects*/

.bg_effects{
	height: 100%;
    width: 100%;
	position: absolute;
	pointer-events: none;
}

.bg_alt{
	background: -webkit-radial-gradient(center top, ellipse cover, rgba(103, 63, 215, .16) 0%, rgba(0, 101, 242, .0) 64%);	
	background: radial-gradient(ellipse at center bottom, rgba(103, 63, 215, .16) 0%, rgba(0, 101, 242, .0) 64%);
    padding-bottom: 75vh;
    position: fixed;
    bottom: 0;
    left: -50%;		
    top: unset;
    width: 200%;
}

.gradient_glow{
	padding-bottom: 50vh;
    width: 100%;
    position: absolute;
    top: 0;
	background: -webkit-radial-gradient(center top, ellipse cover, rgba(0, 101, 242, .32) 0%, rgba(0, 101, 242, .0) 64%);
	background: radial-gradient(ellipse at center top,rgba(0, 101, 242, .32) 0%, rgba(0, 101, 242, .0) 64%);
}

.theme_light .bg_effects .gradient_glow{
	background: -webkit-radial-gradient(center top, ellipse cover, rgba(0, 101, 242, .16) 0%, rgba(0, 101, 242, .0) 64%);
	background: radial-gradient(ellipse at center top,rgba(0, 101, 242, .16) 0%, rgba(0, 101, 242, .0) 64%);
}	

.bg_graphic{
	padding-left: var(--Margin);
    padding-right: var(--Margin);	
	height: 100%;
	margin-top: -10vh;
}

.bg_graphic img{
	margin-top: 0;
	margin-bottom: 0;	
	position: absolute;
    margin: 0 auto;
	will-change: transform;
	transform: translateZ(0);
}

.bg_offset{
	position: absolute;
    top: 0;
    right: 0;
    margin: 0 auto;
    aspect-ratio: 1/1;
    width: calc(100% - var(--Margin)*2);
}

.bg_offset_last{
    position: absolute;
    bottom: 0;
    left: 0;
    margin: 0 auto;
    aspect-ratio: 1/1;
    width: calc(100% - var(--Margin)*2);	
}

.pile{
	position: relative;
    width: 100%;
    aspect-ratio: 1/1;
}

.bg_offset .pile{
	margin-left: var(--Margin);
    margin-top: calc(var(--Margin)*-1);
}

/*BG position and style*/

.bg_opacity_one{
	opacity: .16;
}

.bg_opacity_two{
	opacity: .32;
}

.bg_opacity_three{
	opacity: .48;
}

.bg_opacity_four{
	opacity: .64;
}

.bg_size_one{
	width: 100%;
}

.bg_size_two{
	width: 64%;
}


.bg_size_three{
	width: 48%;
}


.bg_size_four{
	width: 32%;
}


.bg_position_one{
	top: 0;
    left: 0;
    right: 0;
}
	
.bg_position_two{
	right: calc(var(--Margin)*-2);
    top: calc(var(--Margin)*-1);
}

.bg_position_three{
	left: 0;
    right: 0;
    bottom: 5%;	
	z-index: 1;
}

.bg_position_four{
	left: 0;
    right: 0;
    bottom: 10%;	
	z-index: 2;
}

.bg_position_five{
    right: calc(var(--Margin)*-0.25);
    top: calc(var(--Margin)*0.1);	
	z-index: 1;
}

.bg_position_six{
    right: 0;
    top: calc(var(--XXL)*-2);	
}

.bg_position_seven{
    right: calc(var(--Margin)*-2);
    bottom: 0;	
}

.bg_position_eight{
	bottom: calc(var(--XXL)*1.5);
    left: calc(var(--XXL)*-1);
}

/* Background animation */ 

@-webkit-keyframes rotating {
  0% {
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
	scale: 1;
	margin-top: 0;
  }
  50% {
    -webkit-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
	scale: 1.075;
	margin-top: 1rem;	
  }
   100% {
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
	scale: 1;
	margin-top: 0;
  } 
}
@keyframes rotating {
  0% {
    -ms-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -webkit-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
	scale: 1;
	margin-top: 0;	
  }
  50% {
    -ms-transform: rotate(180deg);
    -moz-transform: rotate(180deg);
    -webkit-transform: rotate(180deg);
    -o-transform: rotate(180deg);
    transform: rotate(180deg);
	scale: 1.075;
	margin-top: 1rem;	
  }
   100% {
    -ms-transform: rotate(360deg);
    -moz-transform: rotate(360deg);
    -webkit-transform: rotate(360deg);
    -o-transform: rotate(360deg);
    transform: rotate(360deg);
	scale: 1;
	margin-top: 0;	
  } 
}

@-webkit-keyframes rotating_alt {
  0% {
    -webkit-transform: rotate(-0deg);
    -o-transform: rotate(-0deg);
    transform: rotate(-0deg);
	scale: 1;
	margin-top: 0;
  }
  50% {
    -webkit-transform: rotate(-180deg);
    -o-transform: rotate(-180deg);
    transform: rotate(-180deg);
	scale: 1.075;
	margin-top: 1rem;	
  }
   100% {
    -webkit-transform: rotate(-360deg);
    -o-transform: rotate(-360deg);
    transform: rotate(-360deg);
	scale: 1;
	margin-top: 0;
  } 
}
@keyframes rotating_alt {
  0% {
    -ms-transform: rotate(-0deg);
    -moz-transform: rotate(-0deg);
    -webkit-transform: rotate(-0deg);
    -o-transform: rotate(-0deg);
    transform: rotate(-0deg);
	scale: 1;
	margin-top: 0;	
  }
  50% {
    -ms-transform: rotate(-180deg);
    -moz-transform: rotate(-180deg);
    -webkit-transform: rotate(-180deg);
    -o-transform: rotate(-180deg);
    transform: rotate(-180deg);
	scale: 1.075;
	margin-top: 1rem;	
  }
   100% {
    -ms-transform: rotate(-360deg);
    -moz-transform: rotate(-360deg);
    -webkit-transform: rotate(-360deg);
    -o-transform: rotate(-360deg);
    transform: rotate(-360deg);
	scale: 1;
	margin-top: 0;	
  } 
}
.rotating {
  -webkit-animation: rotating 30s linear infinite;
  -moz-animation: rotating 30s linear infinite;
  -ms-animation: rotating 30s linear infinite;
  -o-animation: rotating 30s linear infinite;
  animation: rotating 30s linear infinite;
}

.rotating_alt {
  -webkit-animation: rotating_alt 30s linear infinite;
  -moz-animation: rotating_alt 30s linear infinite;
  -ms-animation: rotating_alt 30s linear infinite;
  -o-animation: rotating_alt 30s linear infinite;
  animation: rotating_alt 30s linear infinite;
}


.border{
	color: var(--black);
	border: solid 2px var(--blue);
}

.center{
	text-align: center;	
}

/*Element style*/

.main_nav{
    width: 100%;
    position: fixed;
    z-index: 999;
    transition: background-color 0.5s cubic-bezier(0.28, 0.11, 0.32, 1);	
}

.bg_blur{
    background: rgba(0,0,0,.72);	
    backdrop-filter: saturate(180%) blur(20px);	
}

.bg_change{
	background: rgba(255,255,255,.82) !important;	
}

.nav_container{
	max-width: 1920px;
    margin: auto;
    width: 100%;	
}

.nav_container .element{
	padding-left: var(--Margin);
    padding-right: var(--Margin);
    background: transparent;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;	
    padding-top: var(--XS);
    padding-bottom: var(--XS);
}

.mobile_menu_trigger{
	display: none;
}

.main_navigation{
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    gap: 1.5rem;
}

.main_navigation a{
    color: var(--white);
    line-height: 1;
    font-size: 0.875rem;
    font-weight: 500;
    opacity: .82;
    text-decoration: none;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

.navigation_theme_light a{
	color: var(--black);
}

.main_navigation a:hover{
	opacity: 1;
}

.tier_parent{
    display: flex;
    flex-direction: column;
    padding-inline-start: 0;	
	margin-block: 0;
}

.tier_parent a:first-of-type{
	z-index: 9;
}

.tier_inner{
    position: absolute;
    padding-top: var(--M);
    margin-left: -1.25rem;	
}

.tier_list{
    display: none;
    top: var(--S);	
	min-width: var(--XL);
    flex-direction: column;
    align-content: flex-start;
    align-items: flex-start;
    gap: 0.25rem;
    padding: 0.5rem;
    background: var(--dark-gray);
	border: solid 1px var(--border-dark);
    border-radius: 0.5rem;
	box-shadow: 4px 8px 32px rgb(0 0 0 / 10%);.tier_inner
}

.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner .tier_list{
	background: var(--white);	
	border: solid 1px var(--gray-light);
}

.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner .tier_list a p{
	color: var(--dark);	
}

.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner a:hover{
	background: var(--blue);	
}

.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner a:hover p{
	color: var(--white);	
}

.tier_inner a{
	display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    gap: 1rem;
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    padding-left: 0.875rem;
    padding-right: 0.875rem;
    width: 100%;
    width: -webkit-fill-available;
    background: unset;
    transition: all 0.1s;
    border-radius: 0.25rem;
    justify-content: space-between;
	margin: 0 !important;
}

.tier_inner a p{
    color: var(--white);
    line-height: 1;
    font-size: 0.875rem;
    font-weight: 500;
    opacity: .82;
    text-decoration: none;
	margin: 0;
}

.tier_list a img{
    aspect-ratio: 1 / 1;
    width: 1rem;
    margin: 0;
	opacity: 0;
	margin-left: -1rem;
	margin-right: 1rem;
	transition: all 0.2s ease-out;
}

.tier_inner a:hover{
	background: var(--border-dark);
}

.tier_inner a:hover p{
	opacity: 1;
}

.tier_list a:hover img{
	opacity: 1;
	margin-left: 0;
	margin-right: 0;
}


.tier_parent:hover > .tier_inner > .tier_list{
	display: flex;
}

.contact{
	margin-left: auto;	
	transition: all 0.3s ease-in-out;	
	z-index: 99;
}

.contact a{
    padding: 0.75rem;	
	font-size: 1rem;	
    font-weight: 500;
    text-decoration: none;
    border-radius: 999px;
	opacity: 1;
    background-image: linear-gradient(90deg,#414CE0,#673FD7 100%);
    color: var(--white) !important;
}

.contact:hover{
	transform: scale(1.05);
}

.logo a, .footer_logo a{
	color: var(--white);
	display: inline-block;
	margin-right: auto;
	font-size: 1.5rem;
	line-height: 1;
	font-weight: 600;
	opacity: 1;
	text-decoration: none;
}

.bg_change .nav_container .element .logo a, .bg_change .nav_container .element .main_navigation a{
	color: var(--black);
}

.anchor{
	display: inline;
}

.anchor_offset{
	display: block;
    position: relative;
    visibility: hidden;
    top: -8rem;
}

.image{
	margin-bottom: var(--XL);
	display: flex;
    flex-direction: column;	
	gap: var(--XS);
}

.image_row{
    margin-bottom: var(--XL);
    display: flex;
    flex-direction: row;
    gap: 1rem;
    justify-content: center;
}

.image_layout{
	margin-bottom: var(--XL);
	display: flex;
    flex-direction: row;	
	gap: 0;	
}

.last_of_type{
	margin-bottom: var(--XXL);
}


.layout_tooltip{
	width: 20%;
	position: relative;
}

.tooltip{
	position: absolute;
	width: 100%;
}

.tooltip_right .tooltip{
	right: 0;
}

.tooltip_left .tooltip{
	left: 0;
}

.tooltip_copy{
	width: 90%;
	max-width: 12rem;
	font-size: 1rem;
	margin-bottom: 0;
}

.copy_left{
	margin-right: auto;
	text-align: left;
}


.copy_right{
	text-align: right;
	margin-left: auto;
}


.pointer{
    display: flex;
    align-content: center;
    flex-direction: row;
    align-items: center;	
	width: 105%;
}

.tooltip_right .tooltip > .pointer{
	flex-direction: row-reverse;
	margin-left: -5%;
}

.tooltip_left .tooltip > .pointer{
	flex-direction: row;
	margin-right: -5%;
}

.pointer_handle{
    height: 0.2rem;
	width: 100%;
}

.tooltip_right .tooltip .pointer > .pointer_handle{
  background: linear-gradient(90deg, #414CE0, #673FD7 100%);		
}

.tooltip_left .tooltip .pointer > .pointer_handle{
  background: linear-gradient(90deg, #673FD7, #414CE0 100%);		
}

.pointer_thumb{
    width: 1.5rem;
	aspect-ratio: 1/1;
    border: solid 0.2rem #414CE0;
    border-radius: 99px;	
}

.thumb_icon{
	display: none;
}
	
.white_space_limit{
	margin-bottom: var(--XL) !important;
}

.image img, .image_row img,.image_layout img{
	height: auto;
	margin-bottom: 0;
	margin-top: 0;
}

.image_link{
    transition: all 0.3s ease-in-out;	
}

.image_link:hover{
	transform: scale(1.015);
}

	
.device_shadow a{
	margin: 0 var(--S);
	border-radius: 1rem;
	border: solid 1px var(--border);
	overflow: hidden;
	line-height: 0;
	box-shadow: 10px 20px 40px -10px rgba(0, 0, 0, 0.1);
}

.image_row img {
	width: 33%;
}

.image_row a img{
	width: 100%;
}

.image_layout img{
	width: 60%;
	margin: auto;
	box-shadow: 4px 8px 96px rgba(0 0 0 / 16%);
}

.image_layout .rounded{
	border-radius: 0.5rem;
}

.chain{
	margin-bottom: var(--M) !important;
}

.full-widht-img{
	height: auto;
	width: 100%;
	margin-bottom: 0;
	margin-top: 0;
}

.hero-container{ 
	margin-left: auto;
	margin-right: auto;
	padding-bottom: var(--XL);	
}

.content-area{
	margin-left: auto;
	margin-right: auto;
	margin-bottom: var(--XL);
}

.text_colum_left{
	width: 64%;
    margin-right: auto;	
}

.text_colum_left P{
	width: 80%;
    margin-right: auto;	
}

.img_title p{
	font-size: 1rem;
	line-height: 1.6;
	margin: 0;
	font-weight: 300;
}

.columns{
	display: flex;
    flex-direction: row;
	gap: var(--L);	
}

.columns_center{
    align-items: center;		
}

.columns > .content {
    margin-bottom: var(--XXL);	
}

.list{
	display: flex;
    flex-direction: column;
    gap: var(--S);
}

.list > .card_row:first-of-type{
    margin-top: var(--L);		
}

.list > .content:last-of-type {
    margin-bottom: var(--XXL);	
}

.card_row > .card{
	border: solid 1px rgba(103,63,215,0.6); 
	background: linear-gradient(120deg, rgba(103,63,215,0.1) 0%, rgba(103,63,215,0.25) 100%);
    display: flex;
    flex-direction: column;
    justify-content: center;	
	width: 25%;
	transition: all 0.3s ease-in-out;	
}

.card_row > .card_link{
    display: flex;
    flex-direction: column;
    justify-content: center;	
	width: 33%;
	transition: all 0.3s ease-in-out;	
	background-size: cover;
}

.card_row > .card:hover{
	background: linear-gradient(120deg, rgba(103,63,215,0.3) 0%, rgba(103,63,215,0.25) 100%);
	transform: scale(1.05);	
}

.card_row > .card_link:hover{
	transform: scale(1.05);	
}

.card_row_content{
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    gap: var(--S);	
}

.card .icon{
    margin-left: auto;
    margin-right: auto;
    width: var(--L);
}

.icon_name{
	text-align: center;
    color: var(--gray) !important;	
	margin-bottom: 0;
	font-size: 1rem !important;
}

.card_row_content .card_content{
	border: solid 1px var(--border-dark);
    background: linear-gradient(120deg, rgba(46, 46, 50, 1) 0%, rgba(22, 22, 24, 1) 100%);
    border-radius: 1.25rem;
    box-shadow: 5px 5px 10px rgb(0 0 0 / 5%);
    transition: transform 0.3s ease-out;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: calc(33% - 1.5rem);
    gap: 1.5rem;	
    aspect-ratio: 16 / 9;	
	text-decoration: none;
}

.card_content:hover{
	transform: scale(1.05);	
	/*background: linear-gradient(120deg, rgba(46, 46, 50, 1) 75%, rgba(22, 22, 24, 1) 100%);	*/
}

.card_content_holder{
	display: flex;
    flex-direction: row;
    align-items: flex-start;
    align-content: flex-start;
    gap: 1rem;	
	padding: var(--XS);	
}

.card_content img{
	width: 100%;
	margin:0;
	aspect-ratio: 16/10;
	border-top-left-radius: 1.25rem;
	border-top-right-radius: 1.25rem;
}

.card_content_holder img{
	width: 1.75rem;
    margin: 0;
    aspect-ratio: 1 / 1;
    border: solid 1px var(--border-dark);
    border-radius: 0.75rem;
    background: var(--dark-gray-2);
}

.card_content_copy{
	display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-content: flex-start;
    gap: 0.25rem;	
}

.card_content_copy h3{
	font-size: 1rem;
    line-height: 1.35;	
	margin: 0;
}

.card_content_copy p{
	font-size: 0.875rem;
    line-height: 1.35;	
	margin: 0;
}

.reverse{
	flex-direction: row-reverse;
}

.column_left{
    width: 48%;	
}

.column_right{
    margin-left: auto;	
	width: 38%;
}

.highlight{
	margin-bottom: var(--M);	
}

.highlight h3{
    margin-top: 0;
	font-size: 3.75rem;
	line-height: 1.075;
	font-weight: 800;	
	margin-bottom: .5rem;
	display: inline-block;
}


.highlight p{
	margin: 0;
}

.cards{
	display: flex;
    flex-direction: row;
    justify-content: space-between;	
    margin-top: var(--L);	
    gap: var(--S);
}

.card{
	background: var(--white);
    border-radius: 1.25rem;
    width: 33%;
    padding: var(--M);
    box-shadow: 5px 5px 10px rgb(0 0 0 / 5%);
    aspect-ratio: 1/1;
}

.card img{
	width: var(--M);
    margin-right: auto;
    margin-top: 0;
}

.card p {
    font-size: 1.25rem;
    color: var(--black);
    margin-top: 0;
    font-weight: 600;
}

.card b {
    color: transparent !important;
    -webkit-background-clip: text;
    background-clip: text;
    background-image: linear-gradient(90deg,#2ca2b4,#5598de 24%,#7f87ff 45%,#f65aad 76%,#ec3d43);
}

.card_row{
	display: flex;
    flex-direction: row;
    justify-content: space-between;
    gap: var(--S);	
}


.card_link {
	aspect-ratio: 1/1;
	border-radius: 1.25rem;
}

.card_theme_dark{
    border: solid 1px var(--border-dark);
    background: var(--dark-gray);	
}

.card_theme_dark p{
    color: var(--gray);	
}

.no_style{
    text-decoration: none;
	color: var(--blue);
    font-weight: 600;
}

.target:hover{
	text-decoration: underline;
}

.list_master{
	display: flex;
    flex-direction: column;
    gap: 1.5rem;	
}

.list_item_row{
	display: flex;
    flex-direction: row;	
	gap: 1.5rem;
}
	
.list_item_row a{
    width: 50%;
    border: solid 1px var(--border-dark);
    background: var(--dark-gray);
    border-radius: 1.25rem;
    padding: 1.5rem;
    box-shadow: 5px 5px 10px rgb(0 0 0 / 5%);
	transition: all 0.15s ease-out;
}
	
.list_item_large{
	width: 100%;
}

.list_item_row a .list_item_large img{
	margin-top: 0;
}

.list_item_large:hover{
	transform: scale(1.01);
}
.list_item_row a{
    text-decoration: none;
}

.list_item_row a .list_item_large .img_title{
	display: flex;
    justify-content: flex-start;
    flex-direction: column;
    gap: 0.25rem;
    margin-bottom: 0.5rem;
	width: 80%;
}

.list_item_row a .list_item_large .img_title h3{
	font-size: 1.25rem;
	line-height: 1.35;
    margin: 0;
	opacity: 0.92;
}

.list_item_row a .list_item_large .img_title p{
    font-weight: 400;
    font-size: 0.875rem;
}

.list_item_row a .list_item_large .img_title img, .list_item img{
    width: 2rem;
	border-radius: 999px;
	border: solid 2px var(--border-dark);
	margin-bottom: 0.5rem;
}

.list_item img{
	margin: 0;
}

.list_small{
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-content: flex-start;	
	gap: 0;
}

.list_item{
	width: 100%;
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;	
    padding-top: 2rem;
    padding-bottom: 2rem;
	border-top: solid 1px var(--dark-gray-2);
	transition: all 0s;
	text-decoration: none;
}

.list_item:first-of-type{
	border-top: 1px solid rgba(0, 0, 0, 0);
}

.list_item:hover{
    border-radius: 0.875rem;
	border-top: 1px solid rgba(0, 0, 0, 0);
    background: var(--dark-gray-2);
    padding-left: 1rem;
    padding-right: 1rem;
    margin-left: -1rem;
}

.list_item h3{
	width: 50%;
	font-size: 1rem;
	line-height: 1.35;
    margin: 0;
    opacity: 0.92;	
}

.list_item p{
	width: 25%;
    font-weight: 400;
    font-size: 0.875rem;
    margin: 0;
    opacity: 0.92;	
}

.title_small{
	font-size: 1.5rem;
	line-height: 1.35;
}

.title_extra_small{
    width: 100%;
    font-size: 1.25rem;
    line-height: 1.35;
    color: var(--gray) !important;
    font-weight: 500;
    padding-top: 1rem;
    padding-bottom: 1rem;
    border-bottom: solid 1px var(--dark-gray-2);
    margin-bottom: 0.5rem;
}

.project_client_small{
	width: 25%;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
}

.project_client_small p{
	width: unset;
}


footer{
	padding-bottom: var(--XS);
	padding-top: var(--S);
    border-top: solid 1px var(--border);	
    background: var(--gray-light);
	width: 100%;
}

.footer_element .copy{
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    gap: 0.25rem;	
}

.footer_element .copy p{
	font-size: .875rem;
	opacity: .72;
	margin: 0;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}

.footer_element{
    padding-left: var(--Margin);
    padding-right: var(--Margin);
	display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 1rem;	
}

.footer_logo a{
	display: flex;
    flex-direction: row;
    align-items: center;
	gap: 0.5rem;
}

.logo{
	transition: all ease-in-out 0.2s;
}

.logo:hover{
	opacity: .8;
}

.footer_logo a img{
	width: 2rem;	
	margin: 0;
}

.footer_logo p{
	color: var(--black);
	margin-bottom: 0;
}

.footer_navigation{
	display: flex;
    flex-direction: row;
    align-content: flex-start;
    align-items: center;
    gap: 1rem;	
	width: 100%;
}

.footer_navigation a{
	color: var(--black);
    text-decoration: none;	
	font-size: .875rem;
	transition: all ease-in-out 0.2s;
}

.footer_navigation a:hover{
    text-decoration: underline;	
}

.navigation_main{
	font-weight: bold;
	color: var(--black);
}
.mobile{
	display: none;
}

/*Content page format*/

.container_scroll{
	max-width: 1920px;
    margin: auto;
    z-index: 9;
    width: 100%;
}

.scroll_container{
	overflow: initial;
}

.grid{
    position: relative;
    display: grid;
    grid-template-columns: 20% auto;
    column-gap: 1.5rem;
    align-items: flex-start;
}

.grid .column_left, .grid .column_right{
	margin-top: var(--XL);	
	margin-bottom: var(--XL);	
	z-index: 9;
}

.columns_content{
}

.side_navigation{
	width: 100%;
	position: sticky;
    top: var(--XL);
    overscroll-behavior: contain;	
}

.side_navigation_holder{
    display: flex;
    flex-direction: column;
    align-content: flex-start;
    gap: 1rem;	
	overflow-y: auto;	
	max-height: calc(100vh - var(--XL) - 1.5rem);
    padding-bottom: var(--L);	
}

.side_navigation_holder::-webkit-scrollbar {
	width: 0.25rem;
}

/* Track */
.side_navigation_holder::-webkit-scrollbar-track {
	background: unset;
}

/* Handle */
.side_navigation_holder::-webkit-scrollbar-thumb {
	background: rgba(0,0,0,0);
	border-radius: 999px !important;
	transition: all 0.3s ease-in-out;
}

/* Handle on hover */
.side_navigation_holder:hover::-webkit-scrollbar-thumb {
	background: #333;
}

/*
.side_navigation::after{
	content: "";
    display: block;
    width: 100%;
    z-index: 1;
    height: var(--L);
    position: sticky;
    bottom: 0;
    margin-top: calc(-1* var(--L));
    background-image: linear-gradient(var(--dark-gray) 0%, var(--dark-gray));
}
*/

.side_navigation_parent{
	display: none !important;
}

.side_navigation_holder a{
	display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    gap: 1rem;
	text-decoration: none;	
}

.side_navigation_holder a img{
	width: 2rem;
    margin: 0;
    aspect-ratio: 1 / 1;
    border: solid 1px var(--border-dark);
    border-radius: 0.75rem;
	background: linear-gradient(120deg, var(--border-dark) 0%, var(--dark-gray-2) 100%);
}

.side_navigation_main p{
	font-size: 1rem !important;	
    line-height: 1.35;
    font-weight: bold !important;
    color: var(--white);	
}

.side_navigation_main p:hover{
    color: var(--gray) !important;	
}

.side_nav_section_active p{
	color: var(--white);
}

.side_navigation_holder a p{
    margin: 0;	
	font-size: 0.875rem;
	font-weight: 500;
}

.side_navigation a p:hover{
    color: var(--white);	
}

.columns_content .column_right{
	width: 100%;
}

.main_section{
    margin-bottom: var(--L);
}

.main_section h1{
	font-size: 2.75rem;
    line-height: 1.2;
	margin-top: 0;
}

.inner_section{
    position: relative;
    display: grid;
    grid-template-columns: 30% auto;
    column-gap: 1.5rem;
    align-items: flex-start;
    flex-direction: row;
    gap: 1.5rem;
    border-top: solid 1px var(--border-dark);
}

.inner_section_title{
    width: 100%;
    position: sticky;
    overflow-y: auto;
    top: 0;
    overscroll-behavior: contain;
	padding-top: var(--M);
    padding-bottom: var(--M);	
}

.inner_section_content{
	width: 100%;
    padding-top: var(--M);
    padding-bottom: var(--M);
    margin-bottom: var(--S);	
}

.inner_section_title h2{
	padding-top: var(--S);
    margin: 0;
}

.inner_section_title .title_small{
	font-size: 1.25rem;	
}

.inner_section_content h3{
	font-size: 1.15rem;
	line-height: 1.35;
	margin-bottom: 1rem;
}
.inner_section_content h3:first-of-type{
	padding-top: var(--S);	
}

.inner_section_content p a{
	text-decoration: none;
}

.inner_section_content p a:hover{
	text-decoration: underline;
}

.content_image_setter{
    margin-top: var(--M);
    margin-bottom: var(--S);
}

.content_image_setter img{
    margin: 0;
}

.content_image_setter .img_title{
	line-height: 1.45;
}

.image_frame{
	padding: 0.5rem;
	border: solid 1px var(--border-dark);
    background: linear-gradient(120deg, var(--border-dark) 0%, var(--dark-gray-2) 100%);
	line-height: 0;
}

.image_frame img{
	border-radius: 0.5rem !important;
	box-shadow: 5px 5px 10px rgb(0 0 0 / 20%);
}

.content_image_setter .img_title{
    margin-top: 0.75rem;
}

.copy_list{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-content: flex-start;
    gap: var(--S);	
	margin-top: var(--L);
	padding-top: var(--S);
}

.copy_list_intro h2{
	font-size: 2rem;
    line-height: 1.2;	
	margin-bottom: 1rem;
	margin-top: 0;
}

.copy_list_item{
	border-top: solid 1px var(--border-dark);
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-content: flex-start;
    gap: 0.5rem;
    padding-top: 1.5rem;	
}

.copy_list_title{
	font-size: 1.25rem;
    line-height: 1.35;
	color: var(--white) !important;
	font-weight: bold;
	margin: 0;
	text-decoration: none;
}

.copy_list_item a{
	color: var(--blue-light);
	transition: all 0s;
	text-decoration: none;
}

.copy_list_title:hover {
    color: var(--gray) !important;
	text-decoration: none !important;	
}

.copy_list_item a:hover{
	color: var(--blue);
	text-decoration: underline;
}

.call_to_action{
    border-top: solid 1px var(--border-dark);	
	padding-bottom: var(--XXL);
	padding-top: var(--XL);
}

.call_to_action img{
    width: calc(var(--L)*1.5);
    margin: 0;	
}

.call_to_action h3{
	font-size: 2.75rem;
    line-height: 1.2;	
	margin-top: var(--XS);
    margin-bottom: 0.5rem;	
}

.relative{
	position: relative;
	overflow: hidden;
    margin: auto;
    z-index: 9;
    width: 100%;	
}

.side_navigation_trigger, .side_navigation_close{
	display: none;
}

/*
.call_to_action::after{
	content: "";
    display: block;
    position: absolute;	
    width: 100%;
    z-index: -1;	
	bottom: 0;
    left: 0;
    right: 0;
    height: 100%;
    background: radial-gradient(ellipse at center bottom, rgba(0, 101, 242, .32) 0%, rgba(0, 101, 242, .0) 80%);	
}
*/

/*General formating*/


h1{
	font-size: 4rem;
	line-height: 1.1;
	margin-bottom: var(--XS);
	font-weight: 800;
}

h2{
	font-size: 4rem;
	line-height: 1.15;
	margin-bottom: var(--XS);
	font-weight: 800;
}

h3{
	font-size: 3.5rem;
    font-weight: 600;
    line-height: 1.1;
	margin-bottom: var(--XS);	
}

p{
	font-size: 1.25rem;
	line-height: 1.5;
	margin-bottom: var(--XS);
	margin-top: 0;
}

p a{
	color: var(--blue);
    font-weight: 600;	
}

img{
	width: 100%;
    margin-top: var(--M);
    margin-bottom: var(--S);	
}

.strong{
	font-size: 1.5rem;
	line-height: 1.6;
	margin-bottom: var(--XS);
	color: var(--gray);
	font-weight: 500;
}

.eyebrow_gradient{
    display: inline-block;
    font-weight: bold;
	margin-bottom: 0.5rem;
}

.theme_light_copy{
	color: var(--black);
}

.eyebrow{
	color: var(--accent) !important;
	margin-bottom: .5rem;
}

.button{
	margin-top: var(--S);
	transition: all 0.3s ease-in-out;		
}

.button a:hover{
	transform: scale(1.05);
}

.button a{
	display: inline-flex;
	font-weight: 500;
	text-decoration: none;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
	border-radius: 4px;	
}

.link{
	font-size: 1.25rem;
    line-height: 1.6;
    color: var(--blue);
    font-weight: 600;
    text-decoration: none;
	display: inline-flex;
    align-items: center;
}

.link i{
    margin-left: 0.5rem;
    font-size: 1rem;	
}

.link:hover .link-copy{
		text-decoration: underline;
}

.button .filled{
	background-color: var(--blue);
	color: var(--white);
	box-shadow: 0 3px 10px rgb(0 0 0 / 0.2);	
}

.button .filled-gradient{
	background-image: linear-gradient(90deg,#414CE0,#673FD7 100%);	
	color: var(--white);
	box-shadow: 0 3px 10px rgb(0 0 0 / 0.2);		
}

@media (min-width: 1441px) {
  :root{
	--Margin: 16rem;	
	--XXL: 14rem;
	--XL: 8rem;
	--L: 4rem;
	--M: 3rem;	
	--S: 2rem;
	--XS: 1.5rem;
  }
}

@media only screen and (max-width: 463px)  {

	:root{
		--Margin: 1.5rem;	
		--XXL: 6rem;
		--XL: 4rem;
		--L: 3rem;
		--M: 2rem;	
		--S: 1.5rem;
		--XS: 1rem;
	}
	
	.scroll_lock{
		overflow-y: hidden;
	}
	
	.container > .element:first-of-type {
		padding-top: var(--XXL);
	}	
	
	.column-wide, .column, .column_left, .text_colum_left{
		width: 100%;
	}	
	
	.columns{
		flex-direction: column;
	}
	
	.column_right {
		margin-left: auto;
		width: 100%;
		margin-right: auto;
	}	

	.text_colum_left P {
		width: 100%;
		margin-right: auto;
		margin-left: auto;
	}
	
	.nav_container .element {
		padding-top: 1.25rem;
		padding-bottom: 1.25rem;	
	}

	.logo a, .footer_logo a{
		font-size: 1rem;
	}
	
	.footer_element{
		padding-left: 0;
		padding-right: 0;
	}
	
	.footer_logo, .footer_navigation a, .footer_element .copy{
		padding-left: var(--Margin);
		padding-right: var(--Margin);
	}
	
	.color_fix .element .logo a, .bg_change .color_fix .element .main_navigation a{
		color: var(--white) !important;
	}
	
	.mobile_menu_trigger{
		display: block;
		font-weight: 500;
		text-decoration: none;
		border-radius: 999px;
		opacity: 1;
		background-image: linear-gradient(90deg, #414CE0, #673FD7 100%);
		color: var(--white) !important;
		padding-top: 0.5rem;
		padding-bottom: 0.5rem;
		padding-left: 0.75rem;
		padding-right: 0.75rem;
		font-size: .875rem;
		border: unset;		
		z-index: 999;
	}
	
	.logo{
		z-index: 999;
	}
	
	.main_navigation{
		display: none;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		min-height: 100vh;
		background: #000;
		padding: var(--Margin);	
		gap: 1rem;
	}
	
	.navigation_active{
		display: flex;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;
		justify-content: flex-start;
		overflow-y: scroll;
	}

	.main_navigation a{
		opacity: 0;
		padding-top: 0.25rem;
		padding-bottom: 0.25rem;
	}	
	
	.main_navigation a:first-of-type{
		margin-top: var(--XXL);
	}
	
	.tier_parent a:first-of-type{
		margin-top: 0 !important;
	}
	
	.navigation_active a{
		opacity: 1;
	}
	
	.tier_wrapper{
		margin-top: 1rem;
	}
	
	.tier_inner{
		position: initial;
		margin: 0;
		padding-top: 0;
		margin-top: var(--Margin);
		margin-bottom: 1rem;
	}
	
	.tier_list{
		display: flex;
		padding: 0;
		background: unset;
		border: unset;
		gap: var(--S);
	}
	
	.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner .tier_list{
		background: unset;
		border: unset;
	}
	
	.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner .tier_list a p{
		color: var(--white);
	}
	
	.tier_list a img{
		display: none;
	}
	
	.tier_inner a{
		padding: 0;
		background: unset;
		width: auto;
	}
	
	.tier_inner a p{
		font-size: 1rem;
	}
	
	.tier_inner a:hover{
		background: unset;
	}
	
	.fade_in_one{
		transition: all 0.2s ease-in-out;
	}

	.fade_in_two{
		transition: all 0.4s ease-in-out;
	}

	.fade_in_three{
		transition: all 0.6s ease-in-out;
	}

	.fade_in_four{
		transition: all 0.8s ease-in-out;
	}

	.fade_in_five{
		transition: all 1s ease-in-out;
	}	
	
	.main_navigation a {
		color: var(--white);
		font-size: 1.75rem;
		font-weight: bold;
	}

	.contact{
		margin-top: var(--S);
		margin-left: 0;
		margin-bottom: var(--XXL);
	}
	
	.contact a {
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		padding-top: 1rem;
		padding-bottom: 1rem;
		font-size: 1rem;
	}
	
	.button a {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 0.75rem;
		padding-bottom: 0.75rem;
		font-size: .875rem;		
	}	
	
	.link{
		font-size: 1.125rem;
	}
	
	.link i {
		margin-left: 0.5rem;
		font-size: .875rem;
	}

	.img_title p {
		font-size: .875rem;
	}
	
	.columns > .content:first-of-type {
		margin-bottom: var(--XL);
	}

	.columns{
		gap: 0;
	}
	.set_large {
		width: calc(100% + (var(--XXL)));
	}

	.highlight h3 {
		font-size: 2.5rem;
	}	
	
	.highlight p{
	}
	
	.flex-direction{
		flex-direction: column-reverse;
	}
	
	.image_row{
		flex-direction: column;	
		gap: var(--XL);
	}
	
	.image_row img{
		width: 100%;
	}
	
	.image_layout img{
		width: 90%;
	}
	
	.bg_graphic{
		padding: 0;
		margin-top: var(--XXL);
	}
		
	.pile {
		position: relative;
		width: 200%;
		aspect-ratio: 1/1;
		margin-left: -50%;
	}
	
	.bg_offset{
		display:none;
	}

	.bg_position_one {
		bottom: 0;
		top: unset;
	}

	.bg_size_one {
		width: 70%;
	}
	
	.bg_opacity_one {
		opacity: .24;
	}

	.bg_size_two {
		width: 48%;
	}
	
	.bg_opacity_two {
		opacity: .32;
	}

	.bg_size_four {
		width: 32%;
	}
	
	.bg_opacity_four {
		opacity: .64;
	}
	
	.bg_position_six {
		right: 0;
		top: var(--XXL);
	}	

	.bg_position_seven {
		right: auto;
		bottom: 0;
		width: 32%;
	}
	
	.bg_position_eight {
		left: unset;
		right: calc(var(--XXL)*-1);
	}
	
	.bg_hero{
		width: 200%;
	}	
	
	.list .content{
		text-align: left;
	}
	
	.card p, .card a{
		font-size: 1rem;	
		font-weight: 500;
	}

	.cards {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
	    width: 92%;
		margin-left: auto;
		margin-right: auto;	
		margin-top: var(--XL);		
	}
	
	.card{
		width: auto;
	}
	
	.card img{
	    width: var(--L);	
	}
	.card_row {
		flex-direction: column;
	}
	
	.card_row > .card{
		width: unset;
		aspect-ratio: 6/4;
	}
	
	.card .icon {
		width: var(--XL);
	}	
	
	.list_item_row {
		flex-direction: column;
	}
	
	.title_small {
		font-size: 1.25rem;
	}
	
	.list_item_row a {
		width: calc(100% - 2rem);
		padding: 1rem;
	}
	
	.list_item_row a .list_item_large .img_title h3 {
		font-size: 1rem;
		line-height: 1.35;
	}
	
	.list_item{
	    display: flex;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;	
		gap: 0.5rem;
	}
	
	.list_item:hover {
		border-radius: 0.875rem;
		border-top: 1px solid rgba(0, 0, 0, 0);
		background: var(--dark-gray-2);
		padding-left: var(--Margin);
		padding-right: var(--Margin);
		margin-left: calc(-1* var(--Margin));
		border-radius: 0;
	}
	
	.list_item h3, .list_item p{
		width: 100%;
	}
	
	.project_client_small {
		width: 100%;
		margin-top: 0.5rem;
	}
	
	.list_item img{
		margin-left: auto;
	}
	
	.img_limit_large {
		max-width: 75%;
		border-radius: 0.5rem;
	}
	
	footer{	
		padding-left: 0;
		padding-right: 0;
		padding-top: var(--M);
		gap: 1.5rem;
	}
	
	footer .copy p {
		flex-direction: column;
		gap: 0.5rem;
	}	
	
	.footer_navigation {
		width: 100%;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;
		padding-bottom: var(--S);
		border-bottom: solid 1px var(--border);
	}

	.gradient_glow, .theme_light .bg_effects .gradient_glow{
		background: -webkit-radial-gradient(center top, ellipse cover, rgba(0, 101, 242, .24) 0%, rgba(0, 101, 242, .0) 80%);
		background: radial-gradient(ellipse at center top, rgba(0, 101, 242, .24) 0%, rgba(0, 101, 242, .0) 80%);	
	}
	
	/*Content page*/
	
	.grid{
		position: relative;
		display: flex;
		grid-template-columns: 20% auto;
		column-gap: 1.5rem;
		align-items: flex-start;
		flex-direction: column-reverse;
		justify-content: flex-start;
	}

	.grid .column_right {
		margin-top: var(--XS);
		padding-top: unset;
		padding-bottom: unset;
		width: 100%;
	}

	.side_navigation_holder a {
		gap: 0.5rem;
		margin-right: 0.5rem;
	}
	.side_navigation_holder a p {
		font-size: 1rem;
	}
	
	.side_navigation_parent{
		display: flex !important;
	}

	.side_navigation_main p{
		font-size: 1.5rem !important;
	}
	
	.side_navigation_main:last-of-type{
		margin-bottom: var(--XXL);
	}
	
	.side_navigation::after {
		display:none;
	}

	.grid .column_left {
		width: 100%;
		overflow-x: hidden;
		margin-top: 0;
		margin-bottom: 0;
		position: sticky;
		top: 0;
		bottom: 0;
		z-index: 99;
		pointer-events: none;
		height: calc(100dvh - 6rem);
	}	
	
	.copy_list:last-of-type{
		margin-bottom: calc(-1*(100dvh - 6rem));
	}
	
	.main_section {
		padding-left: var(--Margin);
		padding-right: var(--Margin);
		padding-bottom: var(--S);			
	}
	
	.inner_section {
		display: flex;
		flex-direction: column;
		padding-left: var(--Margin);
		padding-right: var(--Margin);	
		padding-top: var(--S);
		padding-bottom: var(--S);		
	}
	
	.inner_section_title{
		padding-bottom: 0;
		position: unset;
		overflow: hidden;
	}

	.inner_section_title h2{
		padding-top: var(--M);
		font-size: 2rem;
	}
	
	.inner_section_content {
		width: 85%;
		margin-left: auto;
		padding-top: 0;
		margin-bottom: var(--M);
	}
	
	.section_last{
		margin-bottom: 1rem;
	}
	
	.inner_section_content h3:first-of-type {
		padding-top: 0;
	}
	
	.call_to_action h3 {
		font-size: 2.25rem;
	}
	
	.image_frame{
		padding: 0.5rem;
		border: solid 1px var(--dark-gray);
		background: var(--border-dark);
	}
	
	.image_frame img {
		border-radius: 0.4rem !important;
	}

	.effects_alt{
		top: 0;
		z-index: -1;
	}
	
	.full_width .inner_section_content{
		width: 100%;
	}
	
	.copy_list_title {
		margin-bottom: 0.5rem;
	}
	
	.copy_list_item a {
		transition: all 0s;
		margin-left: 15%;
	}
	
	.copy_list_intro p:last-of-type{
		margin-bottom: 0;
	}
	
	.side_nav_close_copy, .side_nav_trigger_copy{
		display: none;
	}
	
	.copy_visible{
		display: block;
	}
	
	.side_navigation_trigger, .side_navigation_close{
		position: absolute;
		bottom: var(--M);
		pointer-events: all;
		display: block;
		text-decoration: none;
		border-radius: 999px;
		opacity: 1;
		font-weight: 600;
		background: var(--dark);
		border: solid 2px var(--white);
		color: var(--white) !important;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		padding-top: 1rem;
		padding-bottom: 1rem;
		font-size: 1rem;
		z-index: 99;
		box-shadow: 4px 6px 21px rgb(0 0 0 / 10%);
	}
	
	.side_navigation_close{
		display: block;
		position: fixed;
	}
	
	.grid{
		grid-template-columns: 100%;
		padding-top: var(--XL);
		padding-left: 0;
		padding-right: 0;
	}
	
	.hidden{
		display: none !important;
	}
	
	.side_navigation{
		padding-left: var(--Margin);
		padding-right: var(--Margin);
		max-width: calc(100vw - var(--Margin)* 2);
		margin-top: 0;
		transition: all 0.3s ease-out;
	}	

	.side_navigation_holder{	
		display: none;
		position: fixed;
		top: 0;
		bottom: 0;
		left: 0;
		background: var(--dark);
		width: 100%;
		max-height: unset;
		gap: 0;
		padding: var(--Margin);
		overflow-y: scroll;
		pointer-events: all;
	}
	
	.side_navigation_active{
		display: flex;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;
		gap: 1rem;
		padding-top: var(--L);
	}
	
	.side_navigation_main{
	}
	
	.side_navigation::-webkit-scrollbar {
		display: none;
	}
	
	.side_navigation_holder a{	
		gap: 1rem;
	}
		
	@-webkit-keyframes rotating {
	  0% {
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		transform: rotate(0deg);
		scale: 1;
		margin-top: 0;
	  }
	  50% {
		-webkit-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		transform: rotate(180deg);
		scale: 1.25;
		margin-top: 3rem;	
	  }
	   100% {
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		transform: rotate(360deg);
		scale: 1;
		margin-top: 0;
	  } 
	}
	@keyframes rotating {
	  0% {
		-ms-transform: rotate(0deg);
		-moz-transform: rotate(0deg);
		-webkit-transform: rotate(0deg);
		-o-transform: rotate(0deg);
		transform: rotate(0deg);
		scale: 1;
		margin-top: 0;	
	  }
	  50% {
		-ms-transform: rotate(180deg);
		-moz-transform: rotate(180deg);
		-webkit-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		transform: rotate(180deg);
		scale: 1.25;
		margin-top: 3rem;	
	  }
	   100% {
		-ms-transform: rotate(360deg);
		-moz-transform: rotate(360deg);
		-webkit-transform: rotate(360deg);
		-o-transform: rotate(360deg);
		transform: rotate(360deg);
		scale: 1;
		margin-top: 0;	
	  } 
	}

	@-webkit-keyframes rotating_alt {
	  0% {
		-webkit-transform: rotate(-0deg);
		-o-transform: rotate(-0deg);
		transform: rotate(-0deg);
		scale: 1;
		margin-top: 0;
	  }
	  50% {
		-webkit-transform: rotate(-180deg);
		-o-transform: rotate(-180deg);
		transform: rotate(-180deg);
		scale: 1.25;
		margin-top: 3rem;	
	  }
	   100% {
		-webkit-transform: rotate(-360deg);
		-o-transform: rotate(-360deg);
		transform: rotate(-360deg);
		scale: 1;
		margin-top: 0;
	  } 
	}	
	@keyframes rotating_alt {
	  0% {
		-ms-transform: rotate(-0deg);
		-moz-transform: rotate(-0deg);
		-webkit-transform: rotate(-0deg);
		-o-transform: rotate(-0deg);
		transform: rotate(-0deg);
		scale: 1;
		margin-top: 0;	
	  }
	  50% {
		-ms-transform: rotate(-180deg);
		-moz-transform: rotate(-180deg);
		-webkit-transform: rotate(-180deg);
		-o-transform: rotate(-180deg);
		transform: rotate(-180deg);
		scale: 1.25;
		margin-top: 3rem;	
	  }
	   100% {
		-ms-transform: rotate(-360deg);
		-moz-transform: rotate(-360deg);
		-webkit-transform: rotate(-360deg);
		-o-transform: rotate(-360deg);
		transform: rotate(-360deg);
		scale: 1;
		margin-top: 0;	
	  } 
	}
	
	.rotating {
	  -webkit-animation: rotating 20s linear infinite;
	  -moz-animation: rotating 20s linear infinite;
	  -ms-animation: rotating 20s linear infinite;
	  -o-animation: rotating 20s linear infinite;
	  animation: rotating 20s linear infinite;
	}

	.rotating_alt {
	  -webkit-animation: rotating_alt 20s linear infinite;
	  -moz-animation: rotating_alt 20s linear infinite;
	  -ms-animation: rotating_alt 20s linear infinite;
	  -o-animation: rotating_alt 20s linear infinite;
	  animation: rotating_alt 20s linear infinite;
	}
		
	.mobile{
		display: block;
	}
	
	.desktop{
		display: none;
	}

  /* Formating */
	h1{
		font-size: 2.75rem;
		line-height: 1.1;
	}
 
	h2{
		font-size: 2.75rem;
		line-height: 1.1;
	}
	
	h3{
    font-size: 2.25rem;
    line-height: 1.1;
	}		

	p{
		font-size: 1.125rem;
	}
	
	.strong{
		font-size: 1.25rem;
	}

	.tooltip{
		width: unset;
	}

	.tooltip_copy{
		display: none;
		margin-bottom: 0;
		position: absolute;
		bottom: 2.5rem;
		padding: 0.5rem;
		background: #121423;		
		border-radius: 0.25rem;
		border: solid 1px #252734;
		width: 50vw;
		font-size: 0.875rem;
		line-height: 1.35;			
		color: #fff;
		text-align: left;
	}
		
	.tooltip_visible .tooltip_copy{
		display: block;
	}
	
	
	.pointer_handle{
		display: none;
	}
	
	.pointer_thumb{
		display: flex;
		align-content: center;
		justify-content: center;		
		width: 2rem;
		background: #121423;	
	}
	
	.thumb_icon{
		height: 1rem !important;
		margin: auto;
		display: block;
	}
	
	.tooltip_right .tooltip{
		left: -0.75rem;
		right: unset;
	}
	
	.tooltip_left .tooltip{
		right: -0.75rem;
		left: unset;
	}
	
	.copy_right{
		right: 1rem;		
	}
	
	.copy_left{
		left: 1rem;		
	}
	
		
}

@media only screen and (min-width: 463px) and (max-width: 768px) {

	:root{
		--Margin: 1.5rem;	
		--XXL: 6rem;
		--XL: 4rem;
		--L: 3rem;
		--M: 2rem;	
		--S: 1.5rem;
		--XS: 1rem;
	}
	
	.container > .element:first-of-type {
		padding-top: var(--XXL);
	}	
	
	.color_fix .element .logo a, .bg_change .color_fix .element .main_navigation a{
		color: var(--white) !important;
	}

	.mobile_menu_trigger{
		display: block;
		font-weight: 500;
		text-decoration: none;
		border-radius: 999px;
		opacity: 1;
		background-image: linear-gradient(90deg, #414CE0, #673FD7 100%);
		color: var(--white) !important;
		padding-top: 0.5rem;
		padding-bottom: 0.5rem;
		padding-left: 0.75rem;
		padding-right: 0.75rem;
		font-size: .875rem;
		border: unset;		
		z-index: 999;
	}
	
	.logo{
		z-index: 999;
	}
	
	.main_navigation{
		display: none;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		min-height: 100vh;
		background: #000;
		padding: var(--Margin);	
		gap: 1rem;
	}
	
	.navigation_active{
		display: flex;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;
		justify-content: flex-start;	
		overflow-y: scroll;
	}
	
	.main_navigation a:first-of-type{
		margin-top: var(--XXL);
	}
	
	.tier_parent a:first-of-type{
		margin-top: 0 !important;
	}
	
	.tier_inner{
		position: initial;
		margin: 0;
		padding-top: 0;
		margin-top: var(--Margin);
		margin-bottom: 1rem;
	}
	
	.tier_list{
		display: flex;
		padding: 0;
		background: unset;
		border: unset;
		gap: var(--S);
	}
	
	.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner .tier_list{
		background: unset;
		border: unset;
	}
	
	.bg_change .nav_container .element .main_navigation .tier_wrapper .tier_parent .tier_inner .tier_list a p{
		color: var(--white);
	}
	
	.tier_wrapper{
		margin-top: 1rem;
	}
	
	.tier_list a img{
		display: none;
	}
	
	.tier_inner a{
		padding: 0;
		background: unset;
		width: auto;
	}

	.tier_inner a p{
		font-size: 1rem;
	}	

	.main_navigation a{
		opacity: 0;
		padding-top: 0.25rem;
		padding-bottom: 0.25rem;
	}	
	.navigation_active a{
		opacity: 1;
	}
	
	.fade_in_one{
		transition: all 0.2s ease-in-out;
	}

	.fade_in_two{
		transition: all 0.4s ease-in-out;
	}

	.fade_in_three{
		transition: all 0.6s ease-in-out;
	}

	.fade_in_four{
		transition: all 0.8s ease-in-out;
	}

	.fade_in_five{
		transition: all 1s ease-in-out;
	}	
	
	.main_navigation a {
		color: var(--white);
		font-size: 1.75rem;
		font-weight: bold;
	}

	.contact{
		margin-top: var(--S);
		margin-left: 0;
		margin-bottom: var(--XXL);
	}
	
	.contact a {
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		padding-top: 1rem;
		padding-bottom: 1rem;
		font-size: 1rem;
	}
	
	.button a {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 0.75rem;
		padding-bottom: 0.75rem;
		font-size: .875rem;		
	}

	
	.nav_container .element {
		padding-top: 1.25rem;
		padding-bottom: 1.25rem;	
	}

	.logo a, .footer_logo a{
		font-size: 1rem;
	}
	
	.img_title p {
		font-size: .875rem;
	}
	
	.columns{
		gap: 0;
	}

	.highlight h3 {
		font-size: 2.75rem;
	}	
	
	.highlight p{
		margin-top: .5rem;
	}	
	
	.bg_position_one {
		bottom: 0;
		left: 0;
		right: 0;
		top: unset;
	}
	
	.bg_size_two {
		width: 72%;
	}
	
	.bg_offset{
		display: none;
	}
	
	.bg_size_four {
		width: 48%;
	}
	
	.bg_opacity_four {
		opacity: .48;
	}	
	
	
	.bg_position_six {
		right: 0;
		top: calc(var(--XXL)*-2);
		width: 48% !important;
	}
	
	.bg_position_seven {
		top: calc(var(--XXL)*2);
		right: calc(var(--Margin)*-2);
		width: 32%;
	}
	
	
	.card p, .card a{
		font-size: 1rem	
	}	
	
	.column_right, .column_left{
		width: 40%;
	}
	
	.set_left{
		margin-left: 0;
	}
	
	.set_right{
		width: calc(100% + var(--Margin)*1.5);
	}
	.cards {
		flex-direction: column;
		justify-content: space-between;
		width: 100%;
	}
	
	.card{
		margin: auto;
		width: 64%
	}

	footer{		
		padding-top: var(--M);		
	}
	
	footer .copy p {
		flex-direction: column;
		gap: 0.5rem;
	}	
	
	.footer_navigation {
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;
		margin-bottom: var(--S);
	}

	/*Content page*/
	
	.grid{
		position: relative;
		display: flex;
		grid-template-columns: 20% auto;
		column-gap: 1.5rem;
		align-items: flex-start;
		flex-direction: column-reverse;
		justify-content: flex-start;
	}

	.grid .column_right {
		margin-top: var(--XS);
		padding-top: unset;
		padding-bottom: unset;
		width: 100%;
	}

	.side_navigation_holder a {
		gap: 0.5rem;
		margin-right: 0.5rem;
	}
	.side_navigation_holder a p {
		font-size: 1rem;
	}
	
	.side_navigation_parent{
		display: flex !important;
	}

	.side_navigation_main p{
		font-size: 1.5rem !important;
	}
	
	.side_navigation::after {
		display:none;
	}

	.grid .column_left {
		width: 100%;
		overflow-x: hidden;
		margin-top: 0;
		margin-bottom: 0;
		position: sticky;
		top: 0;
		bottom: 0;
		z-index: 99;
		pointer-events: none;
		height: calc(100dvh - 6rem);
	}	
	
	.copy_list:last-of-type{
		margin-bottom: calc(-1*(100dvh - 6rem));
	}
	
	.main_section {
		padding-left: var(--Margin);
		padding-right: var(--Margin);
		padding-bottom: var(--S);			
	}
	
	.inner_section {
		display: flex;
		flex-direction: column;
		padding-left: var(--Margin);
		padding-right: var(--Margin);	
		padding-top: var(--S);
		padding-bottom: var(--S);		
	}
	
	.inner_section_title{
		padding-bottom: 0;
		position: unset;
		overflow: hidden;
	}

	.inner_section_title h2{
		padding-top: var(--M);
		font-size: 2rem;
	}
	
	.inner_section_content {
		width: 85%;
		margin-left: auto;
		padding-top: 0;
		margin-bottom: var(--M);
	}
	
	.section_last{
		margin-bottom: 1rem;
	}
	
	.inner_section_content h3:first-of-type {
		padding-top: 0;
	}
	
	.call_to_action h3 {
		font-size: 2.25rem;
	}
	
	.image_frame{
		padding: 0.5rem;
		border: solid 1px var(--dark-gray);
		background: var(--border-dark);
	}
	
	.image_frame img {
		border-radius: 0.4rem !important;
	}

	.effects_alt{
		top: 0;
		z-index: -1;
	}
	
	.full_width .inner_section_content{
		width: 100%;
	}
	
	.copy_list_title {
		margin-bottom: 0.5rem;
	}
	
	.copy_list_item a {
		transition: all 0s;
		margin-left: 15%;
	}
	
	.copy_list_intro p:last-of-type{
		margin-bottom: 0;
	}
	
	.side_nav_close_copy, .side_nav_trigger_copy{
		display: none;
	}
	
	.copy_visible{
		display: block;
	}
	
	.side_navigation_trigger, .side_navigation_close{
		position: absolute;
		bottom: var(--M);
		pointer-events: all;
		display: block;
		text-decoration: none;
		border-radius: 999px;
		opacity: 1;
		font-weight: 600;
		background: var(--dark);
		border: solid 2px var(--white);
		color: var(--white) !important;
		padding-left: 1.5rem;
		padding-right: 1.5rem;
		padding-top: 1rem;
		padding-bottom: 1rem;
		font-size: 1rem;
		z-index: 99;
		box-shadow: 4px 6px 21px rgb(0 0 0 / 10%);
	}
	
	.side_navigation_close{
		display: block;
	}
	
	.grid{
		grid-template-columns: 100%;
		padding-top: var(--XL);
		padding-left: 0;
		padding-right: 0;
	}
	
	.hidden{
		display: none !important;
	}
	
	.side_navigation{
		padding-left: var(--Margin);
		padding-right: var(--Margin);
		max-width: calc(100vw - var(--Margin)* 2);
		margin-top: 0;
		transition: all 0.3s ease-out;
	}	

	.side_navigation_holder{	
		display: none;
		position: fixed;
		top: 0;
		bottom: 0;
		left: 0;
		background: var(--dark);
		width: 100%;
		max-height: unset;
		gap: 0;
		padding: var(--Margin);
		overflow-y: scroll;
		pointer-events: all;
	}
	
	.side_navigation_active{
		display: flex;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;
		gap: 1rem;
		padding-top: var(--L);
	}
	
	.side_navigation_main{
	}
	
	.side_navigation::-webkit-scrollbar {
		display: none;
	}
	
	.side_navigation_holder a{	
		gap: 1rem;
	}

  /* Formating */
	h1{
		font-size: 2.75rem;
		line-height: 1.1;
	}
 
	h2{
		font-size: 2.75rem;
		line-height: 1.1;
	}

	p{
		font-size: 1.125rem;
	}
	
	.strong{
		font-size: 1.25rem;
	}	
	
	.eyebrow {
		font-weight: 600;
		font-size: 1.25rem;
	}	

	.tooltip{
		width: unset;
	}

	.tooltip_copy{
		display: none;
		margin-bottom: 0;
		position: absolute;
		bottom: 2.5rem;
		padding: 0.5rem;
		background: #121423;		
		border-radius: 0.25rem;
		border: solid 1px #252734;
		width: 50vw;
		font-size: 0.875rem;
		line-height: 1.35;			
		color: #fff;
		text-align: left;
	}
		
	.tooltip_visible .tooltip_copy{
		display: block;
	}
	
	
	.pointer_handle{
		display: none;
	}
	
	.pointer_thumb{
		display: flex;
		align-content: center;
		justify-content: center;		
		width: 2rem;
		background: #121423;	
	}
	
	.thumb_icon{
		height: 1rem !important;
		margin: auto;
		display: block;
	}
	
	.tooltip_right .tooltip{
		left: -0.75rem;
		right: unset;
	}
	
	.tooltip_left .tooltip{
		right: -0.75rem;
		left: unset;
	}
	
	.copy_right{
		right: 1rem;		
	}
	
	.copy_left{
		left: 1rem;		
	}
	
	.list_item{
	    display: flex;
		flex-direction: column;
		align-content: flex-start;
		align-items: flex-start;	
		gap: 0.5rem;
	}	
	.list_item:hover {
		border-radius: 0.875rem;
		border-top: 1px solid rgba(0, 0, 0, 0);
		background: var(--dark-gray-2);
		padding-left: var(--Margin);
		padding-right: var(--Margin);
		margin-left: calc(-1* var(--Margin));
		border-radius: 0;
	}

	.list_item h3, .list_item p{
		width: 100%;
	}

	.project_client_small {
		width: 100%;
		margin-top: 0.5rem;
	}	
	
	.list_item img{
		margin-left: auto;
	}
		
}


@media only screen and (min-width: 769px) and (max-width: 1024px) {

	:root{
		--Margin: 3rem;	
		--XXL: 8rem;
		--XL: 6rem;
		--L: 4rem;
		--M: 2rem;	
		--S: 1.5rem;
		--XS: 1rem;
	}
	
	.container > .element:first-of-type {
		padding-top: var(--XXL);
	}	
	
	
	.nav_container .element {
		padding-top: 1.25rem;
		padding-bottom: 1.25rem;	
	}

	.logo a, .footer_logo a{
		font-size: 1rem;
	}
	
	.contact a {
		padding: 0.5rem;
		font-size: .875rem;
	}
	
	.button a {
		padding-left: 1rem;
		padding-right: 1rem;
		padding-top: 0.75rem;
		padding-bottom: 0.75rem;
		font-size: .875rem;		
	}	
	
	.img_title p {
		font-size: .875rem;
	}
	
	.columns{
		gap: 0;
	}

	.highlight h3 {
		font-size: 2.75rem;
	}	
	
	.highlight p{
		margin-top: .5rem;
	}	
	
	.bg_position_one {
		bottom: 0;
		left: 0;
		right: 0;
		top: unset;
	}
	
	.bg_size_two {
		width: 72%;
	}
	
	.bg_offset{
		display: none;
	}
	
	.bg_size_four {
		width: 48%;
	}
	
	.bg_opacity_four {
		opacity: .48;
	}	
	
	
	.bg_position_six {
		right: 0;
		top: calc(var(--XXL)*-2);
		width: 48% !important;
	}
	
	.bg_position_seven {
		top: calc(var(--XXL)*2);
		right: calc(var(--Margin)*-2);
		width: 32%;
	}
	
	.card p, .card a{
		font-size: 1rem	
	}	
	
	.column_right, .column_left{
		width: 40%;
	}
	
	.set_left{
		margin-left: 0;
	}
	
	.set_right{
		width: calc(100% + var(--Margin)*1.5);
	}

	.side_navigation {
		display: none;
	}
	
	.grid {
		grid-template-columns: 100%;
	}

  /* Formating */
	h1{
		font-size: 2.75rem;
		line-height: 1.1;
	}
 
	h2{
		font-size: 2.75rem;
		line-height: 1.1;
	}

	p{
		font-size: 1rem;
	}
	
	.strong{
		font-size: 1.25rem;
	}
 
}


@media only screen and (min-width: 1025px) and (max-width: 1440px)  {

	
	:root{
		--Margin: 8rem;	
		--XXL: 12rem;
		--XL: 6rem;
		--L: 4rem;
		--M: 3rem;	
		--S: 2rem;
		--XS: 1.5rem;
	}
	
	.bg_position_one {
		bottom: 0;
		left: 0;
		right: 0;
		top: unset;
	}
	
	.bg_size_two {
		width: 72%;
	}
	
	.bg_position_two{
		display: none;
	}
	
	.bg_size_four {
		width: 48%;
	}
	
	.bg_opacity_four {
		opacity: .48;
	}	
	
	.bg_position_five {
		right: calc(var(--Margin)*-3);
		top: calc(var(--Margin)*-3);
		z-index: 1;
	}	
	
	.bg_position_six {
		right: 0;
		top: calc(var(--XXL)*-2);
		width: 48% !important;
	}
	
	.bg_position_seven {
		top: calc(var(--XXL)*2);
		right: calc(var(--Margin)*-2);
		width: 32%;
	}
	
	.card p, .card a{
		font-size: 1.125rem	
	}
	
	.set_right {
		width: calc(100% + var(--Margin)*2);
	}	
	
  /* Formating */
  
	h1{

	}
 
	h2{

	}
	
	P{
		font-size: 1.15rem;
	}

	.strong{
		font-size: 1.25rem;
	}
	
	.highlight h3{
		font-size: 3rem;
	}


}

@media only screen and (min-width: 1366px) and (max-width: 1440px)  {
	.highlight h3{
		font-size: 3.5rem;
	}
}

@media only screen and (min-width: 1441px) and (max-width: 1600px)  {
	:root{
		--Margin: 8rem;	
	}
}

@media only screen and (min-width: 1921px) {
	.pile {
		width: calc(1920px - 2* var(--Margin));
		margin: auto;
	}
	
	.bg_offset{
		width: calc(100vw - 1920px);	
	}
	
	.bg_offset .pile {
		margin-left: 0;
		margin-right; 0;
	}

	.bg_position_two {
		right: calc((100vw - 1920px)*-.5);
		top: calc((100vw - 1920px)*-.5);
	}	
	
	.bg_postition_five{
		right: calc((100vw - 1920px)*-.2);
		top: calc((100vw - 1920px)*-.25);	
	}

	.bg_position_six {
		right: calc((100vw - 1920px)*-.5);
		top: calc(var(--XXL)*-2);
	}	

	.bg_position_seven {
		right: calc((100vw - 1920px)*-.75);
	}
	
	.bg_offset_last .pile{
		display: none;
	}	

}

