::-moz-selection {
	background: #fff;
	color: #000000;
}

::selection {
	background: #000;
	color: #fff;
}

:root {
	--cobalt: #0400E4;
	--graphite: #2B2B3D;
	--light-gray: #EAEAF4;
}

html, body {
	overflow-x: hidden;
	margin:  0;
	padding:  0;
	color: var(--graphite);
	background: #fff;
  	font-family: "Space Grotesk", sans-serif;
  	font-optical-sizing: auto;
	font-style: normal;
}



/*
* Helpers
*/
.no-wrap {
	flex-wrap: nowrap !important;
}
.align-self-center {
	align-self: center;
}
.stretch {
	justify-content: stretch;
}
.p-relative {
	position: relative;
}
.text-center {
	text-align: center;
}
.text-right {
	text-align: right;
}
.max-width {
	max-width: 100%;
}
.width-100 {
	width: 100%;
}
.n-m {
	margin: 0 !important;
}
html .n-p {
	padding: 0 !important;
}
.n-p-l {
	padding-left: 0 !important;
}
.p-16 {
	padding: 0 16px !important;
}
.p-32 {
	padding: 0 32px !important;
}
.m-b-16 {
	margin-bottom: 16px;
}
.m-b-32 {
	margin-bottom: 32px;
}
.m-b-64 {
	margin-bottom: 64px;
}
.m-b-96 {
	margin-bottom: 96px;
}
.m-b-128 {
	margin-bottom: 128px;
}
.m-b-t-64 {
	margin-top: 64px;
}




/*
* Typography
*/
h1 {
	margin: 0;
	font-weight: 600;
	font-size: 80px;
	line-height: 88px;
	text-transform: uppercase;
	color: var(--light-gray);
}
h2 {
	font-weight: 600;
	font-size: 56px;
	line-height: 64px;
	text-transform: uppercase;
	color: var(--cobalt);
	margin: 0;
}
h3 {
	font-weight: 600;
	font-size: 32px;
	line-height: 40px;
	text-transform: uppercase;
	margin: 0;
}
h3.cobalt {
	color: var(--cobalt);
}
p {
	font-size: 24px;
	line-height: 32px;
	margin: 0 0 24px;
}

p.small {
	font-size: 16px;
	line-height: 22px;
}
p.big {
	font-style: normal;
	font-weight: 400;
	font-size: 32px;
	line-height: 40px;
}
p.small.uppercase {
	text-transform: uppercase;
}
p.x-small {
	font-size: 12px;
	line-height: 15px;
	font-weight: 300;
}
p.small.light {
	font-weight: 300;
}


/*
* Bullet list
*/
ul.list li {
	list-style-type: disc;
}


/*
* Menu 
*/
nav {
	padding: 32px 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 3;
	width: 100%;
	transition: transform .4s ease, background .4s ease;
}

.in-position nav {
	position: relative;
	background: var(--graphite);
	margin-bottom: 32px;
}

@media screen and (min-width: 768px){
	.nav-srolled {
		position: fixed;
		transform: translateY(-100%);
		background: var(--graphite);
	}
	.nav-opened {
		top: 0px;
		background-color: var(--graphite);
		transform: translateY(0);
	}
}
.menu {
	padding: 0;
	margin: 0;
}
.menu li {
	display: inline-block;
	list-style: none;
	margin-right: 32px;
}
.menu li:last-child {
	margin-right: 0;
}
.menu li a {
	font-family: 'Space Grotesk';
	font-style: normal;
	font-weight: 500;
	font-size: 16px;
	line-height: 22px;
	color: var(--light-gray);
	text-transform: uppercase;
	text-decoration: none;
}
.menu li a:hover {
	text-decoration: underline;
}

.breadcrumds {
	margin: 0;
	padding: 0;
}
.breadcrumds li {
	display: inline-block;
	margin-right: 8px;
	vertical-align: middle;
	text-transform: uppercase;
	font-weight: 600;
	
	font-size: 16px;
	line-height: 22px;
}
.breadcrumds li a {
	text-decoration: none;
}


/*
* Header & Hero
*/
header {
	padding-top: 256px;
	min-height: 50vh;
	box-sizing: border-box;
	display: flex;
    align-items: center;
}

header p.big {
	font-style: normal;
	font-weight: 400;
	font-size: 32px;
	line-height: 40px;
	color: var(--light-gray);
}

.hero-background {
	width: 100%;
	background-image: url('../images/hero-image.png');
	background-size: cover;
	background-position: top center;
	background-repeat: no-repeat;
	background-attachment: fixed;
	position: relative;
	overflow-y: hidden;
}
.hero-background:before {
	position: absolute;
	width: 50%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 0;
	display: block;
	content: '';
	background: url('../images/cobalt-triangle.svg') no-repeat;
	background-size: contain;
}
.hero-artefacts {
	margin-bottom: 70%;
}
.hero-artefacts-img {
	position: relative;
	transform: translate(32px, -90px);
	z-index: 0;
}
.section-artefacts-1 {
	position: relative;
	transform: translate(-94px, 170px);	
}
.with-white-triangle {
	position: relative;
	z-index: 1;
}
.with-white-triangle:after {
	content: '';
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	top: calc(50vh + 145px);
	right: 0;
	background: url('../images/union-2.svg') no-repeat top right;
	background-size: 100%;
	z-index: -1;
}
/*.with-white {
	position: relative;
}
.with-white:after {
	position: absolute;
	bottom: 0;
	right: 0;
	background: #fff;
	content: '';
	display: block;
	width: 100%;
	height: 20vh;
	z-index: -1;
}*/

.explore-more {
	background: transparent;
	border: none;
	margin: 0;
	padding: 0;
	cursor: pointer;
	display: inline-block;
	position: relative;
	z-index: 1;
}
.explore-more:before {
	position: relative;
	background: url('../images/cobalt-triangle.svg') no-repeat;
	background-size: cover;
	content: '' ;
	z-index: -1;
	width: 100px;
	height: 100px;
	top: 0;
	left: 0;
	display: inline-block;
	vertical-align: middle;
	transform: translate(0px, 0px);
	transition: all .3s ease;
}
.explore-more svg {
	position: absolute;
	top: 17px;
    left: 41px;
	vertical-align: middle;
	transform: translateY(0px);
	transition: all .3s ease;
}
.explore-more:hover svg {
	transform: translateY(20px);
}
.explore-more span {
	font-family: "Space Grotesk", sans-serif;
	font-weight: 600;
	font-size: 16px;
	line-height: 22px;
	text-transform: uppercase;
	text-align: left;
	color: var(--light-gray);
	display: inline-block;
	vertical-align: middle;
}

/*
* Lang menu
*/
.lang-selection {
	width: 60px;
	display: inline-block;
	border: none;
	background: transparent;
	padding: 4px;
	margin: 0 0 0 -5px;
	cursor: pointer;
	font-family: 'Space Grotesk';
	font-style: normal;
	font-weight: 500;
	font-size: 16px;
	line-height: 22px;
	color: var(--light-gray);
}
.lang-selection svg {
	transform: rotate(0);
	transition: all .3s ease;
}
.lang-selection__opened svg {
	transform: rotate(180deg);
}
.lang-selection span {
	margin-right: 4px;
}
.lang-menu {
	padding: 0;
	margin: 0;
	background: var(--cobalt);
	position: absolute;
	top: 35px;
	right: 32px;
	pointer-events: none;
	transform: translateY(-10px);
	opacity: 0;
	transition: all .3s ease;
}
.lang-menu li {
	display: block;
	list-style: none;
	margin: 0;
	padding: 0;
}
.lang-menu li a {
	color: var(--light-gray);
	padding: 8px 16px;
	text-decoration: none;
	display: block;
}
.lang-menu li a:hover,
.lang-menu li a.selected {
	background: var(--light-gray);
	color: var(--cobalt);
}
.lang-selection.lang-selection__opened + ul {
	pointer-events: initial;
	transform: translateY(0px);
	opacity: 1;
}

/*
* Expander
*/
.expander {
}
.expander-holder {
	margin: 0 32px;
	padding: 32px 0;
	border-bottom: 4px solid #EAEAF4;
}
.expander-holder > .row {
	margin: 0 -32px;
}
.expander button {
	border: none;
	outline: none;
	border-radius: 0;
	background: transparent;
	padding: 0;
	margin: 0;
	cursor: pointer;
	display: inline-block;
}
.expander button span {
	font-style: normal;
	font-weight: 600;
	font-size: 16px;
	line-height: 22px;
	text-transform: uppercase;
	color: var(--cobalt);
	vertical-align: middle;
}
.expander button span.show,
.expander button span.hide {
	margin-right: 12px;
}
.expander .expander-content {
	display: flex;
	height: 0px;
	overflow-y: hidden;
	box-sizing: border-box;
	transition: all .3s ease;
}


.expander button span.hide {
	display: none;
}
.expander-show button span.show {
	display: none;
}
.expander-show button span.hide {
	display: inline-block;
}
.expander-show button svg .vert-line {
	display: none;
}

.expander-show .expander-content {
	height: auto;
    padding-top: 32px;
}


/*
* Footer
*/
footer {
	padding-top: 128px;
	padding-bottom: 32px;
	background: var(--graphite);
	color: var(--light-gray) !important;
}
footer h2, footer a {
	color: var(--light-gray);
}

.footer-liner {
	margin: -20px 0;
}

.footer-links {
	padding: 0;
	margin: 0;
}
.footer-links li {
	display: inline-block;
	margin-left: 32px;
}
.footer-links li a {
	font-size: 12px;
	line-height: 15px;
}
.x-small {
	display: inline-block;
	vertical-align: middle;
}


/*
* Ciasteczka
*/
.cookies {
	position: fixed;
	bottom:  32px;
	left: 32px;
	background: #fff;
	padding:  32px;
	z-index: 9;
}
.cookies p {
	font-family: 'Space Grotesk';
	font-style: normal;
	font-weight: 400;
	font-size: 16px;
	line-height: 20px;
	color: var(--graphite);
    width: 186px;
	display: inline-block;
    vertical-align: middle;
    margin: 0;
}
.cookies a {
	color: var(--cobalt);
	text-transform: uppercase;
	text-decoration: underline;
	font-weight: 500;
}

.cookies .btn {
	font-size: 16px;
	line-height: 20px;
	padding: 18px 24px;
	text-decoration: none;
	vertical-align: middle;
	border: 2px solid var(--cobalt);
	display: inline-block;
}
.cookies .btn:hover {
	background: var(--cobalt);
	color: #fff;
}

.img-square {
	padding: 64px;
	width: 100%;
	background-image: url(../images/img-square-bg.png);
	background-size: cover;
	aspect-ratio: .5/.5;
}
.img-square h2 {
	color: #fff;
}



.show-mobile {
	display: none;
}

.mobile-menu {
	display: none;
}



@media screen and (max-width: 991px) {
	.hide-mobile {
		display: none !important;
	}
	.show-mobile {
		display: inherit !important;
	}

	html .n-p-m {
		padding: 0 !important;
	}
	.n-m-m-b {
		margin-bottom: 0 !important;
	}
	.m-m-b-32 {
		margin-bottom: 32px;
	}
	.m-m-b-64 {
		margin-bottom: 64px;
	}
	.m-text-left {
		text-align: left !important;
	}
	.column-reverse {
		flex-direction: column-reverse;
	}


	h1 {
		font-size: 40px;
		line-height: 48px;
		margin-bottom: 24px;
	}

	h2 {
		font-size: 32px;
		line-height: 44px;
		margin-bottom: 32px;
	}

	h3 {
		font-size: 24px;
		line-height: 32px;
		margin-bottom: 32px;
	}

	p {
		font-size: 22px;
		line-height: 28px;
	}

	p.big {
		font-size: 24px;
		line-height: 32px;
		font-weight: 300;
	}




	.expander button .show, .expander button .hide {
		display: none !important;
	}
	
	nav {
		padding: 16px 0;
		position: absolute;
	}

	footer {
		padding: 64px 0;
	}

	.footer-links li {
		margin: 0 15px 0 0;
	}
	header {
		padding-top: 100px;
	}
	header p.big {
		font-size: 18px;
		line-height: 24px;
		font-weight: 300;
		margin-bottom: 32px;
	}
	.explore-more span {
		display: none;
	}
	.hero-background:before {
		width: 100%;
	}

	.with-white-triangle:after {
		display: none !important;
	    background: url(../images/mobile-union.svg) no-repeat top right;
	    background-size: 100%;
	}

	.hero-artefacts {
		margin-bottom: 0;
	}

	.with-white {
		background: #fff;
		margin-bottom: 0;
		margin-top: 100vw;
	}
	
	.with-white:before {
	    content: '';
	    display: block;
	    width: 100%;
	    height: 100vw;
	    right: 0;
	    background: url(../images/mobile-union.svg) no-repeat top right;
	    background-size: 100%;
	    z-index: -1;
        transform: translateY(-100%);
        margin-bottom: calc(-100vw + 64px);
	}



	html.show-mobile-menu {
		overflow: hidden;
	}

	html.show-mobile-menu .mobile-menu {
		clip-path: inset(0 0 0 0);
	}

	.mobile-menu {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 99;
		display: block;
		background: var(--cobalt);
		padding: 16px 0;
		clip-path: inset(0 0px calc(100% - 60px) calc(100% - 60px));
		transition: clip-path .3s ease;
	}
	.mobile-menu:before {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		content: '';
		z-index: -1;
		background: url(../images/dark-triangle.svg) no-repeat top right;
	    background-size: 100%;
	}

	.mobile-menu-links {
		padding: 0;
	}
	.mobile-menu-links li a {
		font-style: normal;
		font-weight: 500;
		font-size: 32px;
		line-height: 40px;
		text-transform: uppercase;
		text-decoration: none;
		color: var(--light-gray);
	}
	.mobile-menu-links li {
		display: block;
		margin-bottom: 32px;
	}
	.mobile-menu-links li:last-child {
		margin-bottom: 0;
	}

	.mobile-footer {
		margin: 0;
		padding: 0;
	}
	.mobile-footer li {
		display: block;
		margin-top: 16px;
	}
	.mobile-footer li a {
		font-weight: 400;
		color: var(--light-gray);
		text-transform: uppercase;
	}

	.mobile-menu .container {
		height: 100%;
	}
	.with-flex {
		height: 100%;
	    display: flex;
	    flex-direction: column;
	    justify-content: space-between;
	    padding: 32px 0;
	}

	button.menu-trigger {
		border: none;
		background: transparent;
		padding: 0;
		margin: 0;
		outline: none;
		cursor: pointer;
	}

	.expander-holder {
		margin: 0 16px;
    	padding: 32px 16px;
	}



	.col, .col-1, .col-10, .col-11, .col-12, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-auto, .col-lg, .col-lg-1, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-auto, .col-md, .col-md-1, .col-md-10, .col-md-11, .col-md-12, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-auto, .col-sm, .col-sm-1, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-auto, .col-xl, .col-xl-1, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-auto {
	    position: relative;
	    width: 100%;
	    min-height: 1px;
	    padding-right: 16px !important;
	    padding-left: 16px !important;
	}


	.cookies {
	    bottom: 0px;
	    left: 0px;
	    right: 0px;
	    padding: 16px;
	    max-width: 100%;
	    box-sizing: border-box;
	}

	.cookies p {
		width: auto;
		margin-bottom: 16px;
	}

	.hero-background {
		background-image: url('../images/hero-image-mobile.png');
	}







}




