:root{
	/* GENERAL APPEARANCE */
	--color-pure-cyan: #5aebfb;
	--body-bgcolor: #f7f7f7;
	--body-max-width: 1440px;
	--body-font-size: 16px;
	--body-line-height: 1.6;
	--footer-height: var(--nvb-height);
	--scrollbar-track-bgcolor: #b8d6e1; /* #03759f */
	--scrollbar-thumb-bgcolor: #7896a1;
	--scrollbar-thumb-hover-bgcolor: #03759f;
	--max-brand-logo-width: 400px;
	/* LOGO COLOR SCHEME */
	--color-logo-violet-dark: #894bac;
	--color-logo-violet-bright: #bc96d7;
	--color-logo-cyan-dark: #73bdf8;
	--color-logo-cyan-bright: #d9ebfc;
	--color-logo-green-dark: #3b9a7f;
	--color-logo-green-bright: #7dd661;
	--color-logo-blue-deep: #024c67;
	/* COLORS */
	--color-a-category: #9c9c9c;

}

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

html, body{
	width: 100%;
	height: 100%;
}

html{
	-webkit-text-size-adjust: 100%; /* Prevent font scaling in landscape while allowing user zoom */
}

body::-webkit-scrollbar{
	width: 10px;
}
body::-webkit-scrollbar-track{
	background: var(--scrollbar-track-bgcolor);
}
body::-webkit-scrollbar-thumb{
	background: var(--scrollbar-thumb-bgcolor);
}
body::-webkit-scrollbar-thumb:hover{
	background: var(--scrollbar-thumb-hover-bgcolor);
}

a{
	color: var(--color-logo-blue-deep); text-decoration: none;
}
a:hover{
	color: var(--color-logo-violet-dark);
}

.a-ctgr{
	color: var(--color-a-category);
	text-transform: uppercase;
}
.a-ctgr:hover{
	color: var(--color-logo-blue-deep);
}

.body-content{
	width: 100%;
	min-height: calc(100% - var(--nvb-height));
	margin: auto;
	font-family: 'Noto Sans', sans-serif;
	font-size: var(--body-font-size);
	display: flex;
	flex-direction: column;
	justify-content: start;
}

.section-std{
	position: relative;
	width: 100%;
}

.section-backdrop{
	width: 100%;
	aspect-ratio: 1.92;
	max-height: 500px;
	background-color: var(--color-logo-blue-deep);
}

.img-backdrop{
	width: 100%;
	max-height: 500px;
	vertical-align: bottom;
	object-fit: cover;
	opacity: 0.7;
}

.span-pagename{
	position: absolute;
	margin-left: 20px;
	top: 50%;
	left: 5%;
	transform: translate(0, -50%);
	font-family: "Teko", sans-serif;
	font-size: clamp(5rem, calc(10vw + 2rem), 20rem);
    background: linear-gradient(0.5turn, var(--color-logo-green-bright), var(--color-logo-cyan-bright), var(--color-logo-violet-dark));
	background-clip: text;
    color: transparent;
	text-shadow: 0 0 1em cyan;
	-webkit-text-stroke: 1px var(--color-logo-blue-deep);
}

.article-std{
	width: 100%;
	max-width: var(--body-max-width);
	margin: 0 auto;
	padding: 0 5px;
	line-height: var(--body-line-height);
	display: block;
}

.div-footer{
	width: 100%;
	height: var(--footer-height);
	margin-top: auto;
	color: white;
	background-color: var(--nvb-bgcolor);
	box-shadow: 0px 0px 5px 5px var(--nvb-bgcolor-shade);
}

.div-footer-text{
	width: 100%;
	max-width: var(--body-max-width);
	height: 100%;
	font-size: 14px;
	margin: 0 auto;
	padding: 0 5px;
	display: block;
	text-align: center;
}

.div-footer-hr{
	width: 95%;
	max-width: var(--body-max-width);
	margin: auto;
	border: 1px dashed lightgrey;
}

.div-separator{
	width: 100%;
	height: 2rem;
}

.title-first-description{
	width: 55%;
	padding: 10px;
	color: white;
}

.flex-frame{
	width: 100%;
	min-height: 150px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.flex-title{
	width: 45%;
	padding: 10px;
}

.flex-grid{
	width: 55%;
	padding: 0px;
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	grid-auto-rows: 1fr;
}
.flex-grid::-webkit-scrollbar{width: 10px;}
.flex-grid::-webkit-scrollbar-track{background: var(--scrollbar-track-bgcolor);}
.flex-grid::-webkit-scrollbar-thumb{background: var(--scrollbar-thumb-bgcolor);}
.flex-grid::-webkit-scrollbar-thumb:hover{background: var(--scrollbar-thumb-hover-bgcolor);}

.grid-brand{
	border-radius: 10px;
	background-color: #f7f7f7;
	box-shadow: 2px 2px 2px 2px #efefef;
	cursor: pointer;
	display: table;
	transition: transform 0.5s, background-color 0.5s;
}
.grid-brand:hover{
	transform: scale(1.1);
	background-color: #fdd9ff;
}

.grid-brand-cell{
	width: 100%;
	text-align: center;
	vertical-align: middle;
	display: table-cell;
}

.flex-market{
	width: 100%;
	padding: 5px;
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
}

.flex-market-field{
	height: 150px;
	aspect-ratio: 1/1;
	border-radius: 10px;
	cursor: pointer;
	display: table;
	transition: transform 0.5s, background-color 0.5s;
}
.flex-market-field:hover{
	transform: scale(1.1);
}

.flex-market-field > div{
	text-align: center;
	vertical-align: middle;
	display: table-cell;
}

.flex-logo{
	width: 45%;
	padding: 10px;
	text-align: center;
}

.flex-logo img{
	max-width: calc(var(--max-brand-logo-width) - 20px);
}

.flex-description{
	width: 55%;
	padding: 0px;
}

.flex-description p,
.flex-description li{
	padding-top: 1em;
}

.flex-leftdiv{
	width: 40%;
	padding: 10px;
	text-align: left;
}

.flex-rightdiv{
	width: 60%;
	padding: 10px;
}

.world-background{
	background-image: url("/imgs/backdrops/worldmap.jpg");
	background-position: center;
	background-size: cover;
}

.smooth-edge-filter{
	background: linear-gradient(0deg, rgba(255,255,255,1) 0%, rgba(197,180,216,0) 15%, rgba(165,185,227,0) 85%, rgba(255,255,255,1) 100%);
}

.span-cyan{
	font-weight: bold;
	color: var(--color-logo-blue-deep);
}

.form-text-input,
.form-text-area{
	width: 100%;
	margin: 10px 0;
	padding: 10px;
	font-family: 'Noto Sans', sans-serif;
	font-size: var(--body-font-size);
	font-weight: bold;
}
.form-text-input:invalid,
.form-text-area:invalid{
	border: 2px solid red;
	color: red;
}

.form-submit{
	padding: 5px 20px;
	border-radius: 5px;
	font-family: 'Noto Sans', sans-serif;
	font-size: var(--body-font-size);
	font-weight: bold;
	cursor: pointer;
}
.form-submit:hover{
	background-color: var(--color-logo-violet-bright);
}

.anchor-holder{
	height: calc(var(--nvb-height) + 20px);
}

@media screen and (max-width: 850px){
	.flex-frame{
		display: block;
	}
	
	.flex-title{
		width: 100%;
		display: block;
	}
	
	.flex-grid{
		width: 100%;
		/* max-height: unset; */
	}
	
	.flex-logo,
	.flex-description{
		width: 100%;
		display: block;
	}
	
	.flex-logo{
		text-align: center;
	}
	
	.flex-logo img{
		max-width: 100%;
	}
	
	.flex-description{
		margin-top: 20px;
	}
	
	.title-first-description{
		width: 100%;
		display: block;
	}
	
	.flex-leftdiv,
	.flex-rightdiv{
		width: 100%;
		display: block;
	}
}