/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
 html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.25em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{-webkit-appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}

/* ---------------------------------------------------------------------------- */

:root {
	--site-max: 1240px;
	--site-bkgd: rgba(255,255,255,1);
	--main-txt: rgba(15,20,26,1);
	--keyline: rgba(40,52,67,.25);
	--theme-main: rgba(209,160,26,1);
	--theme-secondary: rgba(15,20,26,1);
	--theme-tertiary: rgba(40,52,67,1);
	--theme-extra: rgba(100,130,168,1);
	--theme-bkgd: rgba(248,240,230,1);
	--theme-inverted: rgba(255,255,255,1);

	/* fonts */
	--type-sans: "Gotham SSm A", "Gotham SSm B", Helvetica, sans-serif;
	--type-sans-tabular: "Gotham SSm Tabular A", "Gotham SSm Tabular B", Helvetica, Arial, sans-serif;

	/* font-sizing */
	--fs--2: clamp(0.6944rem, 0.6925rem + 0.0095vw, 0.7035rem);
	--fs--1: clamp(0.8333rem, 0.8114rem + 0.1099vw, 0.9377rem);
	--fs-0: clamp(1rem, 0.9474rem + 0.2632vw, 1.25rem);
	--fs-1: clamp(1.2rem, 1.1018rem + 0.4908vw, 1.6663rem);
	--fs-2: clamp(1.44rem, 1.2756rem + 0.8222vw, 2.2211rem);
	--fs-3: clamp(1.728rem, 1.4685rem + 1.2976vw, 2.9607rem);
	--fs-4: clamp(2.0736rem, 1.6793rem + 1.9717vw, 3.9467rem);
	--fs-5: clamp(2.4883rem, 1.9046rem + 2.9185vw, 5.2609rem);
	--fs-6: clamp(2.986rem, 2.1382rem + 4.2387vw, 7.0128rem);
	--fs-7: clamp(3.5832rem, 2.3695rem + 6.0683vw, 9.3481rem);

	/* spacing */
	--space-3xs: clamp(0.25rem, 0.2283rem + 0.1087vw, 0.3125rem);
	--space-2xs: clamp(0.5rem, 0.4565rem + 0.2174vw, 0.625rem);
	--space-xs: clamp(0.75rem, 0.6848rem + 0.3261vw, 0.9375rem);
	--space-s: clamp(1rem, 0.913rem + 0.4348vw, 1.25rem);
	--space-m: clamp(1.5rem, 1.3696rem + 0.6522vw, 1.875rem);
	--space-l: clamp(2rem, 1.8261rem + 0.8696vw, 2.5rem);
	--space-xl: clamp(3rem, 2.7391rem + 1.3043vw, 3.75rem);
	--space-2xl: clamp(4rem, 3.6522rem + 1.7391vw, 5rem);
	--space-3xl: clamp(6rem, 5.4783rem + 2.6087vw, 7.5rem);
	--space-4xl: clamp(8rem, 7.3043rem + 3.4783vw, 10rem);

	/* spacing: one-up pairs */
	--space-3xs-2xs: clamp(0.25rem, 0.1196rem + 0.6522vw, 0.625rem);
	--space-2xs-xs: clamp(0.5rem, 0.3478rem + 0.7609vw, 0.9375rem);
	--space-xs-s: clamp(0.75rem, 0.5761rem + 0.8696vw, 1.25rem);
	--space-s-m: clamp(1rem, 0.6957rem + 1.5217vw, 1.875rem);
	--space-m-l: clamp(1.5rem, 1.1522rem + 1.7391vw, 2.5rem);
	--space-l-xl: clamp(2rem, 1.3913rem + 3.0435vw, 3.75rem);
	--space-xl-2xl: clamp(3rem, 2.3043rem + 3.4783vw, 5rem);
	--space-2xl-3xl: clamp(4rem, 2.7826rem + 6.087vw, 7.5rem);
	--space-3xl-4xl: clamp(6rem, 4.6087rem + 6.9565vw, 10rem);
}

/* defaults ---------------------------------------------------------------- */
*, *::before, *::after {box-sizing: border-box;}

html {
	-moz-text-size-adjust: none;
	-webkit-text-size-adjust: none;
	text-size-adjust: none;
}

body {
	background-color: var(--site-bkgd);
	color: var(--main-txt);
	font-family: var(--type-sans);
	font-size: var(--fs-0);
	font-style: normal;
	font-weight: 400;
	letter-spacing: -1px;
	line-height: 1.5;
	margin: 0 auto;
	min-height: 100vh;
	overflow-x: hidden;
	position: relative;
	-webkit-font-smoothing: subpixel-antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-align: center;
	text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
	color: var(--main-txt);
  font-family: var(--type-sans);
	line-height: 1;
  margin-top: var(--space-m);
  padding: 0;
	text-wrap: stable;
}

h1 {
	color: var(--theme-main);
	font-size: var(--fs-5);
}

h1 span.h__secondary {
	color: var(--main-txt);
	display: block;
	font-size: var(--fs-1);
	letter-spacing: 0;
	text-transform: uppercase;
}

h2 {
	color: var(--theme-main);
	font-size: var(--fs-3);
  font-weight: 700;
	margin-bottom: var(--space-m);
}

h3 {
	font-size: var(--fs-1);
	margin: 0;
}

p, h1, h2, h3, h4, li {
	font-feature-settings: "liga" on;
	text-wrap: stable;
}

a {
	text-underline-offset: 4px;
	transition: all .3s cubic-bezier(.42, 0, .58, 1);
}

a:link, a:visited {
	color: var(--theme-secondary);
}

a:hover, a:active {
	color: var(--theme-main);
}

figure {
  margin: 0;
  padding: 0;
}

img {
	display: block;
  height: auto;
	margin: 0;
	max-width: 100%;
  vertical-align: top;
}

figure img {
	margin: 0 auto;
	text-align: center;
  object-fit: cover;
  max-width: 100%;
}

ul {
	list-style-type: none;
	margin: var(--space-m);
}

li {
	line-height: 1;
}

ul > li:last-child {margin-bottom: 0;}

/* structure ---------------------------------------------------------------- */

.full-bleed {
	width: 100vw;
	margin-left: calc(50% - 50vw);
}

.wrapper {
	max-width: 75rem;
	margin-left: auto;
	margin-right: auto;
}

/* hero ---------------------------------------------------------------------- */

#hero {
	padding: var(--space-m) var(--space-m) 0 var(--space-m);
}

#app__icon {
	transition: opacity 500ms ease-in-out, translate 500ms ease-in-out;
	opacity: 1;
	translate: 0 0;

	@starting-style {
		opacity: 0;
		translate: 0 35px;
	}
}

h1 span {
	transition: opacity 750ms, translate 750ms;
	opacity: 1;
	translate: 0 0;

	@starting-style {
		opacity: 0;
		translate: 0 15px;
	}
}

h1 {
	transition: opacity 1000ms, translate 1000ms;
	opacity: 1;
	translate: 0 0;

	@starting-style {
		opacity: 0;
		translate: 0 35px;
	}
}

/* main structure ---------------------------------------------------------- */

main {
  margin-top: 4rem;
	position: relative;
}

.intro {
	font-size: var(--fs-1);
	line-height: var(--fs-2);
	margin-left: auto;
	margin-right: auto;
	margin-bottom: var(--space-xl);
	max-width: 55ch;
}

/* features and requirements ----------------------------------------------- */

#features {
	background: var(--theme-secondary);
	color: var(--theme-inverted);
	padding: var(--space-xl) 0;
}

#features h2,
#requiresments h2 {
	font-size: var(--fs-1);
	letter-spacing: 1px;
	text-transform: uppercase;
}

#features h3 {
	color: var(--theme-inverted);
	line-height: 1.25;
}

.features__wrapper {
	display: flex;
	flex-flow: row wrap;
	justify-content: flex-start;
	align-items: flex-start;
	align-content: flex-start;
	gap: 1rem;
}

.feature {
	color: var(--theme-extra);
	text-align: left;
	padding: 1rem 2rem 1rem 2rem;
	width: calc(50% - .5rem);
}

.feature p {text-wrap: balance;}

.feat__icon {
	fill: var(--theme-main);
	width: 4rem;
	ratio: 1/1;
}

#requirements {
	background: var(--theme-tertiary);
	color: var(--theme-inverted);
	padding: var(--space-xl) 0;
}

#requirements a:link,
#requirements a:visited {
	color: var(--theme-extra);
}

#requirements a:hover,
#requirements a:active {
	color: var(--theme-priamry);
}

#requirements h2 {
	color: var(--theme-primary);
}

#requirements ul {
	padding: 0;
}

#requirements li {
	margin: 0 0 .5rem 0;
}

/* privacy --------------------------------------------------------------- */

#privacy {
	background: rgba(0,0,0,.12);
	border-top: 1px solid var(--keyline);
	font-size: var(--fs--1);
	margin: 0;
	padding: var(--space-l);
}

#privacy h2 {
	color: var(--main-txt);
	margin-top: 0;
}

.policy {
	margin: 0 auto;
	text-align: left;
	max-width: 75ch;
}

/* misc -------------------------------------------------------------------*/

.banner {
	margin-bottom: var(--space-xl);
}

.button {
	background: var(--theme-secondary);
	border-radius: 2rem;
	color: var(--theme-inverted);
	font-weight: 700;
	display: inline-block;

}

a.button {
	padding: 1rem 2rem;
	text-decoration: none;
}

a.button:link,
a.button:visited {
	background: var(--theme-secondary);
	color: var(--theme-inverted);
}

a.button:hover,
a.button:active {
	background: var(--theme-main);
	color: var(--theme-inverted);
}

.beta {
	border-top: 1px solid rgba(255,255,255,.15);
	padding: var(--space-l) 0 0 0;
}

.beta a:link,
.beta a:visited {color: var(--theme-inverted);}

.beta a:hover,
.beta a:active {color: var(--theme-main);}

.external::after {
	content: ' ';
	display: inline-block;
	margin-right: 10px;
	position: relative;
	height: .85rem;
	width: .85rem;
	top: 1px;
	-webkit-mask-image: url(/assets/img/outlink-arrow.svg);
	mask-image: url(/assets/img/outlink-arrow.svg);
	left: 6px;
	transition: all .3s cubic-bezier(.42, 0, .58, 1);
}

.external:link::after,
.external:visited::after {background: var(--theme-extra);}

.external:hover::after,
.external:active::after {background: var(--theme-inverted);}

/* footer ---------------------------------------------------------------- */

footer {
  border-top: 1px solid var(--keyline);
	font-size: var(--fs--1);
  padding: var(--space-m) 0 var(--space-l) 0;
}
