@font-face { font-family: 'material'; src: url('material.woff2') format('woff2'); }
@font-face { font-family: 'title'; font-style: normal; font-weight: 300; font-display: swap; src: url(title.woff2) format('woff2'); }
@font-face { font-family: 'body'; font-style: normal; font-weight: 300; font-display: swap; src: url(doc300.woff2) format('woff2'); }
@font-face { font-family: 'body'; font-style: normal; font-weight: 400; font-display: swap; src: url(doc400.woff2) format('woff2'); }
@font-face { font-family: 'body'; font-style: normal; font-weight: 600; font-display: swap; src: url(doc600.woff2) format('woff2'); }

:root {
	--background: #0a0b10;
	--foreground-hot: #fffa; --foreground-warm: #af9b8d; --foreground-cold: #8d9baf;
	font-size: 16px;
	font-family: body, Verdana, sans-serif;
	font-weight: 300;
	color: var(--foreground-hot);
	background-color: var(--background);
	text-align: left;
}

html, body { width: 100%; height: 100%; margin: 0; padding: 0; }
* { box-sizing: border-box; margin: 0; }
.gt { color: transparent; background-clip: text; background-image: linear-gradient(135deg, #FF4500 0%, #FFA500 100%); }
.gt2 { color: transparent; background-clip: text; background-image: linear-gradient(135deg, #88FF00 0%, #FFFF00 100%); }
.hc, .vc > * { max-width: 72rem; margin: 0 auto; padding: 1rem 2rem; }
.vc { text-align: center; min-height: 100vh; display: flex; align-items: center; justify-content: center; flex-flow: column; }
.icon { font-family: material !important; font-feature-settings: "liga" 1; text-transform: none !important; }
a { text-decoration: none; color: inherit; }
a:hover { color: #FF8000; }
	
header {
	position: fixed; top: 0; left: 0; right: 0; z-index: 50; text-align: center;
	background-color: #0a0b1080; border-bottom: 1px solid #8883; backdrop-filter: blur(12px);
}
header div { max-width: 72rem; margin: 0 auto; padding: 1rem 2rem; display: flex; align-items: center; justify-content: space-between; }
header h1 {
	display: inline-block;
	font-size: 1.5rem; font-weight: 600;
}
header nav {
	display: flex; gap: 2rem;
}
header nav a { color: var(--foreground-hot); text-decoration: none; font-size: 0.85rem; transition: all cubic-bezier(.4,0,.2,1) .15s; }
header nav a:hover { color: #fff; }

section + section { margin-top: 10vh; }

section.hero {
	background-image: url(bg.jpg); background-size: cover; background-position: center center; background-repeat: no-repeat;
	position: relative; z-index: 0; padding: 4rem 0;
	min-height: 100vh; display: flex; align-items: center; justify-content: center; flex-flow: column;
}
section.hero::before { 
	content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, #0a0b10 0%, #0a0b1097 30%, #0a0b1097 70%, #0a0b10 90%);
	z-index: -1;
}
section.hero h1 {
	font-size: 4.5rem; font-weight: 600; text-align: center;
}
section.hero p:first-of-type {
	font-size: 1.5rem; color: #fff; font-weight: 400;
}
section.hero p:last-of-type {
	font-size: 1rem; color: #fffa; font-weight: 300; letter-spacing: 1px; margin-top: 0;
}
section.hero .dot { margin: 0 1rem; color: #fffa; font-size: .875rem; line-height: 1.25rem; display: inline-block; white-space: nowrap; }
section.hero .dot::before { 
	content: ''; vertical-align: middle; width: .5rem; height: .5rem; border-radius: 2rem; 
	background-color: #FFA500; display: inline-block; margin-right: 0.5rem;
}
section.hero .dot:first-child::before { background-color: #88FF00; }
section.hero .dot:last-child::before { background-color: #FFFF00; }

section.features h1 { font-size: 2rem; }
section.features ul { list-style: none; display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 1.5rem; margin: 3rem 0; }
section.features li { 
	border-radius: 1rem; background-color: #0002; border: 1px solid #8883; padding: 1.5rem; line-height: 1.6rem;
	transition: all cubic-bezier(.4,0,.2,1) .3s; box-shadow: 0 0 40px transparent; text-align: left;
	overflow: hidden;
}
section.features li:nth-child(even):hover { box-shadow: 0 0 40px #FFFF0048; }
section.features li:nth-child(odd):hover { box-shadow: 0 0 40px #FFBB0048; }
section.features li h2 { color: #fff; font-weight: 400; font-size: 1.5rem; margin-bottom: 1rem; }
section.features li div {
	width: 3rem; height: 3rem; border-radius: 0.5rem; margin-bottom: 1rem; text-align: center; color: #0a0b10e0;
	font-size: 2rem; line-height: 3rem;
}
section.features li:nth-child(even) div { background-image: linear-gradient(135deg, #88FF00 0%, #FFFF00 100%); }
section.features li:nth-child(odd) div { background-image: linear-gradient(45deg, #FF6500 0%, #FFBB00 100%); }
section.features > :last-child { margin-bottom: 20vh; }

section.solutions { }
section.solutions h1 { color: #fff; font-weight: 600; font-size: 3.5rem; }
section.solutions .gt { font-size: 1.5rem; }
section.solutions ul { list-style: none; display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 2rem; margin: 3rem 0; }
section.solutions li { 
	border-radius: 1rem; border: 0px solid #8883; line-height: 1.6rem;
	transition: all cubic-bezier(.4,0,.2,1) .3s; box-shadow: 0 0 40px transparent; text-align: left;
	overflow: hidden;
}
section.solutions li div.pic { position: relative; }
section.solutions li div.pic::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, #0a0b1000 70%, #0a0b10 95%); }
section.solutions li img { width: 100%; opacity: 0.9; }
section.solutions li div.txt { padding: 1.5rem; padding-top: 0.5rem; }
section.solutions li h2 { color: #fff; font-weight: 400; font-size: 1.5rem; margin-bottom: 1rem; }
section.solutions li p.tag { text-align: right; }
section.solutions li p.tag span { font-size: 0.7rem; display: inline-block; padding: 0.1rem 0.7rem; margin-right: 0.3rem; border-radius: 1rem; letter-spacing: 1px; }
section.solutions li p.tag span::before { content: '#'; }
section.solutions li p.tag span:nth-child(4n+1) { background-color: #88FF0020; color: #88FF00c0;}
section.solutions li p.tag span:nth-child(4n+2) { background-color: #FFA50020; color: #FFA500c0; }
section.solutions li p.tag span:nth-child(4n+3) { background-color: #FFFF0020; color: #FFFF00c0; }
section.solutions li p.tag span:nth-child(4n+4) { background-color: #FF450020; color: #FF4500c0; }
section.solutions li p { font-size: 1rem; line-height: 1.6rem; }
section.solutions li:hover { box-shadow: 0 0 40px #FF650060; }
section.solutions > p { padding: 0.25rem 2rem; }
section.solutions .gt2 { font-size: 1.5rem; letter-spacing: 1px; }
section.solutions > :last-child { margin-bottom: 20vh; color: #fff; letter-spacing: 1px; font-size: 1rem; }
section.solutions a { display: inline-block; font-size: 0.9rem; font-weight: 400; color: #FF8000; text-align: right; }
section.solutions a:hover { color: #FF4500; }

section.howitworks { }
section.howitworks h1 { color: #fff; font-weight: 600; font-size: 3.5rem; }
section.howitworks h1 + p { font-size: 1.3rem; margin-bottom: 3rem; color: #fff; letter-spacing: 1px; }
section.howitworks {
	background-image: url(bg2.jpg); background-size: cover; background-position: center center; background-repeat: no-repeat;
	position: relative; z-index: 0;
	min-height: 100vh; display: flex; align-items: center; justify-content: center; flex-flow: column;
}
section.howitworks::before { 
	content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, #0a0b10 10%, #0a0b1097 30%, #0a0b1097 70%, #0a0b10 90%);
	z-index: -1;
}
section.howitworks .steps { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 2rem; line-height: 1.5rem; }
section.howitworks .steps span { 
	width: 4rem; line-height: 4rem; text-align: center; color: #0a0b10e0; font-size: 1.5rem; display: inline-block; border-radius: 10rem;
	font-weight: 600;
}
section.howitworks .steps div:nth-child(even) span { background-image: linear-gradient(135deg, #88FF00 0%, #FFFF00 100%); box-shadow: 0 0 4rem #FFFF0060; }
section.howitworks .steps div:nth-child(odd) span  { background-image: linear-gradient(45deg, #FF6500 0%, #FFBB00 100%);  box-shadow: 0 0 4rem #FFBB0060; }
section.howitworks .steps h2 { color: #fff; font-weight: 400; font-size: 1.5rem; margin: 1.5rem 0; }
section.howitworks .steps p { font-size: 0.9rem; }
section.howitworks .steps p + p { margin-top: 1rem; }
section.howitworks .steps div { 
	border-radius: 1.5rem; padding: 1.5rem; transition: all cubic-bezier(.4,0,.2,1) .3s; border: 1px solid #8880; background-color: #0a0b1000; }
section.howitworks .steps div { background-color: #0a0b10; border: 1px solid #8883; }

section.cta { }
section.cta h1 { font-weight: 600; font-size: 3.5rem; }
section.cta p { font-size: 1.2rem; letter-spacing: 1px; line-height: 1.8rem; }
section.cta .cta { 
	display: inline-block; padding: 0.8rem 1.5rem; border-radius: 0.8rem; margin: 2rem 0.5rem; font-weight: 400; font-size: 1rem;
	transition: all cubic-bezier(.4,0,.2,1) .3s; cursor: pointer;
}
section.cta .cta:hover { box-shadow: 0 0 2.5rem 0.5rem #FFFF0060; }
section.cta .cta svg { height: 1rem; vertical-align: -0.15rem; }
section.cta .cta:first-of-type { background-image: linear-gradient(135deg, #88FF00 0%, #FFFF00 100%); color: #000; }
section.cta .cta:last-of-type { color: #fff; }
section.cta .cta:last-of-type:hover { color: #FFFF00; }
section.cta .flip { display: inline-block; transform: scaleX(-1); }

footer { background-color: #000; min-height: 40vh; border-top: 1px solid #fff3; font-size: 0.9rem; }
footer > div { padding-top: 3rem !important; }
footer .footer { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 2rem; line-height: 1.3rem; }
footer .footer > :first-child { grid-column: span 2 / span 2; }
footer .footer h3 { color: #fff; margin-bottom: 1rem; font-size: 1.2rem; font-weight: 400; }
footer .footer a { display: block; line-height: 1.8rem; }
footer .gt { font-size: 1.5rem; font-weight: 600; padding-bottom: 1rem; display: inline-block; }
footer .eof { border-top: 1px solid #fff3; margin-top: 2rem; padding: 2rem 0; display: flex; }
footer .eof > :first-child { flex: 1; }
footer .eof a { margin-left: 0.5rem; }
footer .eof svg { height: 1.5rem; }

section.contact { }
section.contact h1 { font-weight: 600; font-size: 3.5rem; color: #fff; }
section.contact p { font-size: 1.2rem; letter-spacing: 1px; line-height: 1.8rem; }
section.contact .e { margin: 3rem; font-size: 1.2rem; letter-spacing: 1px; }
section.contact .e span:nth-child(even) { display: none; }

section.about { }
section.about h1 { font-weight: 600; font-size: 3.5rem; color: #fff; }
section.about h2 { margin-top: 2rem; margin-bottom: 1rem; font-weight: 400; font-size: 1.5rem; }
section.about > div { text-align: left; width: 100%; }
section.about p { font-size: 1rem; letter-spacing: 1px; line-height: 1.8rem; padding-left: 3rem; }
section.about span { color: #fff; margin-right: 1.5rem; display: inline-block; }

@media (max-width: 642px) {
	:root { font-size: 10px; }
	.vc { min-height: 70vh; }
	.hc, .vc > * { max-width: 95vw; }
	section.features ul { grid-template-columns: repeat(1,minmax(0,1fr)); }
	section.features li:nth-child(even) { box-shadow: 0 0 40px #FFFF0048; }
	section.features li:nth-child(odd) { box-shadow: 0 0 40px #FFBB0048; }
	section.solutions ul { grid-template-columns: repeat(1,minmax(0,1fr)); }
	section.howitworks .steps { grid-template-columns: repeat(1,minmax(0,1fr)); }
}