/**
* @license
* MyFonts Webfont Build ID 3867246, 2020-12-16T11:57:38-0500
* 
* The fonts listed in this notice are subject to the End User License
* Agreement(s) entered into by the website owner. All other parties are 
* explicitly restricted from using the Licensed Webfonts(s).
* 
* You may obtain a valid license at the URLs below.
* 
* Webfont: Titling Gothic FB Skyline Medium by Font Bureau
* URL: https://www.myfonts.com/collections/font-bureau-foundry

* © 2026 MyFonts Inc. */

@font-face {
	font-family: "TitlingGothicFBSkylineMedium";
	src:
		url("fonts/TitlingGothicFBSkylineMedium/font.woff2") format("woff2"),
		url("fonts/TitlingGothicFBSkylineMedium/font.woff") format("woff");
	font-display: block;
}


/* CSS RESET ===================================================== */

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

ol,
ul {
	list-style: none;
}

button {
	background: none;
	cursor: pointer;
	font: inherit;
	color: inherit;
}


/* SKIP TO MAIN CONTENT ===================================================== */

.skip {
	position: absolute;
	left: -10000px;
	top: auto;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.skip:focus {
	position: static;
	width: auto;
	height: auto;
	font-size: 2.1rem;
}


/* BASE ===================================================== */

:root {
	--black: rgb(0, 0, 0);
	--white: rgb(255, 255, 255);
	--overlay: rgb(244, 245, 247);
	--dark-grey: rgb(73, 83, 96);
	--grey: rgb(128, 137, 152);
	--light-grey: rgb(192, 192, 192);
}

html {
	font-size: clamp(56.25%, 54.99% + 0.0536vw, 62.5%); /* starts at 2240px ends at 375px 10px to 9px */
}

body {
	font-family: acumin-pro, sans-serif;
	font-variant-ligatures: common-ligatures;
	color: var(--black);
	background-color: var(--white);
	text-rendering: optimizeLegibility;
	padding-bottom: 8rem;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	/* background-image: url("images/column-grid.png");
	background-size: 2112px 512px;
	background-position: center top;
	background-repeat: repeat-y; */
}

a:link, a:visited { color: var(--black); text-decoration: none; }
a:hover, a:active { color: var(--grey); text-decoration: none; }


/* STRUCTURE ===================================================== */

.wrapper {
	width: 100%;
	max-width: 224rem;
	margin: 0 auto;
	padding: 0 clamp(2.4rem, 1.59568rem + 2.1448vw, 6.4rem); /* starts at 2240px ends at 375px */
}

.poster {
	min-height: calc(100vh - 8rem);
	min-height: calc(100svh - 8rem);
	display: flex;
	align-items: flex-end;
	margin-bottom: 16rem;
}

.grid-layout {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	column-gap: clamp(2.6rem, 1.836rem + 2.0375vw, 6.4rem); /* starts at 2240px ends at 375px */
}

.image-content {
	border-top: 1px solid;
	padding: 3.1rem 0 6.4rem 0;
}


/* IMAGES ===================================================== */

img,
video,
picture {
	display: block;
	width: 100%;
	height: auto;
}

video {
	cursor: pointer;
}

.border {
	border: 1px solid var(--light-grey);
}

.portrait {
	padding: 3.2rem 0 6.4rem 0;
	max-width: 20.8rem;
}


/* HEADER ===================================================== */

header {
	background-color: var(--white);
}

header.fixed-to-top {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
}

header.fixed-to-top + main {
	padding-top: 8rem;
}

.header-content {
	height: 8rem;
	border-bottom: 1px solid;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.logo {
	width: 12.8rem;
}

.nav-button {
	display: none;
	border-bottom: 1px solid transparent;
}

.nav-button,
nav ul li {
	font-size: 1.8rem;
}

nav ul {
	display: flex;
	column-gap: 1.6rem;
}

.nav-button:hover, .nav-button:active, nav a:hover, nav a:active { color: var(--black); border-bottom: 1px solid; }

.active-page {
	border-bottom: 1px solid;
}


/* TYPOGRAPHY ===================================================== */

.heading {
	font-size: clamp(3.6rem, 2.33568rem + 2.5287vw, 8rem); /* starts at 2240px ends at 500px */
	font-weight: 500;
	letter-spacing: -0.035em;
	line-height: 1.2em;
	padding: 8rem 0 4.4em 0;
}

.masthead,
.sub-heading,
.running-head {
	font-family: "TitlingGothicFBSkylineMedium", Impact, Haettenschweiler, sans-serif;
	font-weight: 400;
	text-transform: uppercase;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.masthead {
	font-size: clamp(9rem, 4.22992rem + 9.5402vw, 25.6rem); /* starts at 2240px ends at 500px */
	line-height: 0.88em;
	padding: 5vh 0 4vh 0;
}

.running-head {
	font-size: clamp(3.6rem, 3.2552rem + 0.6897vw, 4.8rem); /* starts at 2240px ends at 500px */
	line-height: 1em;
	padding: 4.8rem 0 0.66666667em 0;
}

.sub-heading {
	font-size: clamp(6.4rem, 5.94016rem + 0.9195vw, 8rem); /* starts at 2240px ends at 500px */
	line-height: 9.6rem;
	padding: 12.8rem 0 3.2rem 0;
}

.sub-sub-heading {
	font-size: 2.1rem;
	font-weight: 400;
	line-height: 3.2rem;
	padding-bottom: 3.2rem;
}

p {
	font-size: 2.1rem;
	line-height: 3.2rem;
	padding-bottom: 3.2rem;
}

.body-text {
	grid-column: 2;
	max-width: 96rem;
}

.text-content {
	padding-bottom: 12.7rem;
	border-bottom: 1px solid;
}

.text-content section {
	margin-top: 12.8rem;
	border-top: 1px solid;
	padding-top: 3.1rem;
}

.text-content section:first-of-type {
	margin-top: 0;
}

.caption {
	font-size: 1.6rem;
	padding-bottom: 6.4rem;
}

.text-content ul,
.text-content ol {
	font-size: 2.1rem;
	line-height: 3.2rem;
	list-style-position: outside;
	margin: 0 0 3.2rem 1em;
}

.text-content ul {
	list-style-type: disc;
}

.text-content ol {
	list-style-type: decimal;
}

.services {
	display: inline-block;
	white-space: nowrap;
}

.services:not(:last-child)::after {
	content: " /";
}

.tint {
	color: var(--grey);
}

.masthead .tint {
	color: var(--dark-grey);
}

.text-content a { border-bottom: 1px solid var(--light-grey); }


/* BIG NUMBER COUNTER ===================================================== */

body {
	counter-reset: bigNumber; /* Initialize the counter */
}

.big-numbers::before {
	counter-increment: bigNumber; /* Increment the counter */
	content: counter(bigNumber) "."; /* Display the counter */
}


/* HOMEPAGE ===================================================== */

.registered-symbol {
	width: clamp(1.2rem, 0.8264rem + 0.7471vw, 2.5rem);  /* starts at 2240px ends at 500px */
	display: inline;
	vertical-align: top;
	margin: 0.03em 0 0 0.05em;
	fill: currentColor;
}

.home-poster {
	min-height: 100vh;
}

.homepage .heading {
	border-top: 1px solid;
	padding-top: 4.7rem;
}

.brand-statements {
	border-top: 1px solid;
	padding-top: 3.1rem;
	grid-template-columns: repeat(4, 1fr);
	align-items: baseline;
}

.brand-statements p {
	font-size: clamp(3rem, 2.13792rem + 1.7241vw, 6rem); /* starts at 2240px ends at 500px */
	font-weight: 500;
	letter-spacing: -0.025em;
	line-height: 1.2em;
	padding-bottom: 4.8em;
	grid-column: span 3;
}

.homepage .running-head {
	padding-top: 0;
}


/* TABLES ===================================================== */

table {
	width: 100%;
	border-collapse: collapse;
	margin: 3.2rem 0 6.4rem 0;
}

td,
th {
	font-size: 2.1rem;
	font-weight: 400;
	line-height: 2.4rem;
	padding: 1.9rem 0.8rem 2rem 0.8rem;
	text-align: left;
	border: 1px solid;
}


/* FILTER ===================================================== */

.filter {
	display: flex;
	column-gap: 1.6rem;
	line-height: 3.1rem;
	padding: 1.6rem 0;
	font-size: 1.8rem;
}

.filter button:hover, .filter button:active { border-bottom: 1px solid; }

.filter button[aria-pressed="true"] { border-bottom: 1px solid; }


/* PORTFOLIO LIST ===================================================== */

.portfolio {
	border-top: 1px solid;
}

.portfolio li {
	padding: 3.2rem 0 3.1rem 0;
	border-bottom: 1px solid;
}

.portfolio li:first-of-type {
	padding-top: 3.1rem;
}

.portfolio li a {
	grid-template-columns: repeat(4, 1fr);
	align-items: center;
}

.portfolio p,
.insights-list p {
	font-size: clamp(2.8rem, 2.6392rem + 0.429vw, 3.6rem); /* starts at 2240px ends at 375px */
	letter-spacing: -0.02em;
	line-height: 1.11111111em;
	padding-bottom: 0;
	grid-column: 2 / -1;
}

.portfolio a:hover, .portfolio a:active,
.portfolio-text a:hover, .portfolio-text a:active,
.insights-list a:hover, .insights-list a:active { color: var(--black); background-color: var(--overlay); }


/* PORTFOLIO TEXT LIST ===================================================== */

.portfolio-heading {
	padding-top: 32rem;
}

.portfolio-text a {
	padding: 3.1rem 0 3.2rem 0;
	border-top: 1px solid;
}

.portfolio-text li:last-child a {
	padding-bottom: 3.1rem;
	border-bottom: 1px solid;
}

.portfolio-text p {
	font-size: 2.4rem;
	padding-bottom: 0;
}


/* INSIGHTS LIST ===================================================== */

.insights-list a {
	padding: 4.7rem 0 4.8rem 0;
	border-top: 1px solid;
	display: block;
}

.insights-list li:last-child a {
	padding-bottom: 4.7rem;
	border-bottom: 1px solid;
}


/* FOOTER ===================================================== */

.footer-logo {
	grid-template-columns: repeat(4, 1fr);
	padding: 22.4rem 0 4.8rem 0;
}

.footer-content {
	border-top: 1px solid;
	padding-top: 1.5rem;
}

.footer-content p {
	font-size: 1.8rem;
	line-height: 2.4rem;
	padding-bottom: 2.4rem;
}


/* RESPONSIVE ===================================================== */


@media screen and (max-width: 1023px) {

	.nav-button {
		display: block;
	}

	nav {
		display: none;
	}

	body.nav-shown nav {
		display: block;
		position: fixed;
		top: 8rem;
		left: 0;
		right: 0;
		bottom: 0;
		padding: 0 clamp(2.4rem, 1.59568rem + 2.1448vw, 6.4rem); /* starts at 2240px ends at 375px */
		background-color: var(--white);
		overflow-y: auto;
	}

	nav ul {
		display: block;
		padding: 3.2rem 0 6.4rem 0;
	}

	nav ul li {
		font-family: "TitlingGothicFBSkylineMedium", Impact, Haettenschweiler, sans-serif;
		text-transform: uppercase;
		font-size: clamp(8rem, 21vw, 16rem);
		line-height: 0.9em;
		overflow: hidden;
	}

	nav a:hover, nav a:active { color: var(--grey); border-bottom: none; }
	
	.active-page {
		border-bottom: none;
	}

	.grid-layout {
		display: block;
	}

	.sub-sub-heading {
		font-size: 2.4rem;
	}

	.portfolio-text li p:nth-of-type(2) {
		color: var(--grey);
	}

	.portfolio p {
		padding: 1.6rem 0;
	}

	.caption {
		padding-bottom: 3.2rem;
	}

	.footer-logo {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}
}

@media screen and (max-width: 400px) {

	.filter {
		flex-direction: column;
	}
}