@font-face {
	font-family: "Miller Banner";
	src: url("/assets/fonts/Miller_Banner_Regular.otf") format("opentype");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Miller Banner";
	src: url("/assets/fonts/Miller_Banner_Regular.otf") format("opentype");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Miller Banner";
	src: url("/assets/fonts/Miller_Banner_Semi_Bold.otf") format("opentype");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Miller Banner";
	src: url("/assets/fonts/Miller_Banner_Bold.otf") format("opentype");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Miller Banner";
	src: url("/assets/fonts/Miller_Banner_Bold_Italic.otf") format("opentype");
	font-weight: 700;
	font-style: italic;
	font-display: swap;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: #f7f9fb;
	color: #191c1e;
	font-family: "Inter", Arial, sans-serif;
	font-size: 16px;
	line-height: 1.6;
}

a {
	color: inherit;
	text-decoration: none;
}

img,
svg {
	display: block;
	max-width: 100%;
}

button,
input,
textarea {
	font: inherit;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	background: rgba(247, 249, 251, 0.94);
	border-bottom: 1px solid rgba(31, 37, 63, 0.12);
	backdrop-filter: blur(16px);
}

.header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	max-width: 1200px;
	min-height: 76px;
	margin: 0 auto;
	padding: 0 32px;
}

.brand-link {
	display: inline-flex;
	align-items: center;
	gap: 14px;
}

.brand-mark {
	width: 34px;
	height: 34px;
	object-fit: contain;
	padding: 3px;
}

.brand-name {
	font-family: "Miller Banner", "Times New Roman", serif;
	font-size: 20px;
	font-weight: 600;
	letter-spacing: -0.02em;
	color: #1f253f;
	top: 2px;
	position: relative;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 38px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #46464d;
}

.site-nav a {
	position: relative;
	padding: 28px 0 24px;
}

.mobile-nav-link {
	display: none;
}

.site-nav a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 20px;
	width: 0;
	height: 2px;
	background: #1f253f;
	transition: width 180ms ease;
}

.site-nav a:hover::after,
.site-nav a:focus-visible::after,
.site-nav a.is-active::after,
.site-nav a[aria-current="true"]::after {
	width: 100%;
}

.header-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 110px;
	height: 42px;
	padding: 0 22px;
	background: #1f253f;
	border: 1px solid #1f253f;
	color: #ffffff;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.header-cta:hover,
.header-cta:focus-visible {
	background: #0a1029;
	border-color: #0a1029;
}

.mobile-menu-button {
	display: none;
	width: 44px;
	height: 44px;
	background: #ffffff;
	border: 1px solid rgba(31, 37, 63, 0.18);
	color: #1f253f;
	cursor: pointer;
}

.mobile-menu-button span {
	display: block;
	width: 18px;
	height: 2px;
	margin: 4px auto;
	background: #1f253f;
}

.main-content {
	overflow: hidden;
}

.section {
	padding: 128px 0;
}

.section-light {
	background: #ffffff;
}

.section-muted {
	background: #f2f4f6;
}

.section-dark {
	background: #1f253f;
	color: #ffffff;
}

.container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 32px;
}

.hero {
	background: #ffffff;
	padding: 112px 0 104px;
}

.hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 7fr) minmax(260px, 3fr);
	gap: 64px;
	align-items: start;
}

.hero-mark-panel {
	align-self: stretch;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 320px;
	border: 1px solid rgba(31, 37, 63, 0.14);
	background: #f7f9fb;
}

.hero-mark {
	width: min(72%, 220px);
	height: auto;
}

.overline {
	margin: 0 0 22px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.14em;
	line-height: 1.5;
	text-transform: uppercase;
	color: #5d5f5f;
}

.section-dark .overline {
	color: rgba(255, 255, 255, 0.72);
}

h1,
h2,
h3,
p {
	margin-top: 0;
}

h1,
h2,
h3 {
	font-family: "Miller Banner", "Times New Roman", serif;
	color: #1f253f;
	letter-spacing: -0.03em;
}

.section-dark h2,
.section-dark h3 {
	color: #ffffff;
}

h1 {
	max-width: 780px;
	margin-bottom: 18px;
	font-size: 72px;
	font-weight: 700;
	line-height: 1.02;
}

.hero-title {
	max-width: 780px;
	margin-bottom: 26px;
	font-family: "Miller Banner", "Times New Roman", serif;
	font-size: 44px;
	font-weight: 500;
	line-height: 1.18;
	letter-spacing: -0.03em;
	color: #191c1e;
}

.hero-copy {
	max-width: 690px;
	margin-bottom: 38px;
	color: #46464d;
	font-size: 18px;
	line-height: 1.7;
}

.button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 14px 30px;
	border: 1px solid #1f253f;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1;
	text-transform: uppercase;
}

.button-primary {
	background: #1f253f;
	color: #ffffff;
}

.button-primary:hover,
.button-primary:focus-visible {
	background: #0a1029;
	border-color: #0a1029;
}

.button-secondary {
	background: transparent;
	color: #1f253f;
}

.button-secondary:hover,
.button-secondary:focus-visible {
	background: #1f253f;
	color: #ffffff;
}

.credibility-strip {
	background: #f2f4f6;
	border-top: 1px solid rgba(31, 37, 63, 0.1);
	border-bottom: 1px solid rgba(31, 37, 63, 0.1);
}

.credibility-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 32px;
	padding: 38px 0;
}

.credibility-item {
	padding-top: 4px;
}

.credibility-value {
	margin-bottom: 2px;
	font-family: "Miller Banner", "Times New Roman", serif;
	font-size: 24px;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: -0.02em;
	color: #1f253f;
}

.credibility-label {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	line-height: 1.45;
	text-transform: uppercase;
	color: #5d5f5f;
}

.section-heading {
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 5fr);
	gap: 64px;
	align-items: end;
	margin-bottom: 64px;
}

.section-heading h2 {
	margin-bottom: 0;
	font-size: 48px;
	font-weight: 600;
	line-height: 1.12;
}

.section-heading p {
	margin-bottom: 0;
	color: #46464d;
	font-size: 17px;
	line-height: 1.7;
}

.expertise-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 32px;
}

.expertise-card {
	padding-top: 28px;
	border-top: 1px solid rgba(31, 37, 63, 0.18);
}

.expertise-card h3 {
	margin-bottom: 12px;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.25;
}

.expertise-card p {
	margin-bottom: 0;
	color: #46464d;
	font-size: 15px;
	line-height: 1.7;
}

.impact-list {
	border-top: 1px solid rgba(255, 255, 255, 0.16);
}

.impact-item {
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
	gap: 72px;
	padding: 48px 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.16);
}

.impact-item h3 {
	margin-bottom: 0;
	font-size: 42px;
	font-style: italic;
	font-weight: 700;
	line-height: 1.08;
}

.impact-content {
	max-width: 620px;
}

.impact-content p {
	margin-bottom: 18px;
	color: rgba(255, 255, 255, 0.78);
	font-size: 16px;
	line-height: 1.7;
}

.impact-meta {
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #ffffff;
}

.principles-grid {
	display: grid;
	grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
	gap: 72px;
}

.principles-title h2 {
	margin-bottom: 0;
	font-size: 48px;
	font-weight: 600;
	line-height: 1.12;
}

.principles-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 42px 56px;
}

.principle {
	padding-top: 20px;
	border-top: 1px solid rgba(31, 37, 63, 0.16);
}

.principle h3 {
	margin-bottom: 12px;
	font-family: "Inter", Arial, sans-serif;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.12em;
	line-height: 1.5;
	text-transform: uppercase;
}

.principle p {
	margin-bottom: 0;
	color: #46464d;
	font-size: 15px;
	line-height: 1.7;
}

.contact-band {
	padding: 104px 0;
	text-align: center;
}

.contact-band h2 {
	max-width: 760px;
	margin: 0 auto 32px;
	font-size: 48px;
	font-weight: 600;
	line-height: 1.12;
}

.contact-band p {
	max-width: 660px;
	margin: 0 auto 34px;
	color: rgba(255, 255, 255, 0.72);
	font-size: 17px;
	line-height: 1.7;
}

.contact-band .button-secondary {
	border-color: #ffffff;
	color: #ffffff;
}

.contact-band .button-secondary:hover,
.contact-band .button-secondary:focus-visible {
	background: #ffffff;
	color: #1f253f;
}

.site-footer {
	background: #ffffff;
	border-top: 1px solid rgba(31, 37, 63, 0.1);
	padding: 74px 0;
}

.footer-inner {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 48px;
}

.footer-brand {
	display: flex;
	align-items: center;
	gap: 18px;
	margin-bottom: 16px;
}

.footer-brand .brand-mark {
	width: 42px;
	height: 42px;
	padding: 4px;
}

.footer-name {
	font-family: "Miller Banner", "Times New Roman", serif;
	font-size: 22px;
	font-weight: 600;
	letter-spacing: -0.02em;
	color: #1f253f;
	top: 2px;
	position: relative;
}

.footer-copy {
	margin: 0;
	color: #5d5f5f;
	font-size: 13px;
}

.footer-links {
	display: flex;
	gap: 28px;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: #46464d;
}

.footer-links a:hover,
.footer-links a:focus-visible {
	color: #1f253f;
	text-decoration: underline;
	text-underline-offset: 5px;
}

@media (max-width: 980px) {
	.header-inner {
		padding: 0 24px;
	}

	.site-nav,
	.header-cta {
		display: none;
	}

	.mobile-menu-button {
		display: block;
	}

	.site-header.menu-open .site-nav {
		display: grid;
		position: absolute;
		top: 76px;
		left: 0;
		right: 0;
		gap: 0;
		padding: 12px 24px 24px;
		background: #ffffff;
		border-bottom: 1px solid rgba(31, 37, 63, 0.12);
	}

	.site-header.menu-open .site-nav a {
		padding: 16px 0;
		border-bottom: 1px solid rgba(31, 37, 63, 0.08);
	}

	.site-header.menu-open .site-nav a::after {
		display: none;
	}

	.site-header.menu-open .site-nav .mobile-nav-link {
		display: block;
	}

	.container {
		padding: 0 24px;
	}

	.section {
		padding: 96px 0;
	}

	.hero {
		padding: 86px 0 88px;
	}

	.hero-grid,
	.section-heading,
	.principles-grid,
	.impact-item {
		grid-template-columns: 1fr;
		gap: 42px;
	}

	.hero-mark-panel {
		min-height: 240px;
	}

	.hero-mark {
		font-size: 104px;
	}

	h1 {
		font-size: 54px;
	}

	.hero-title {
		font-size: 34px;
	}

	.section-heading h2,
	.principles-title h2,
	.contact-band h2 {
		font-size: 38px;
	}

	.credibility-grid,
	.expertise-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.impact-item h3 {
		font-size: 34px;
	}
}

@media (max-width: 640px) {
	.header-inner {
		min-height: 68px;
	}

	.site-header.menu-open .site-nav {
		top: 68px;
	}

	.brand-name {
		font-size: 18px;
	}

	.hero {
		padding: 68px 0 72px;
	}

	h1 {
		font-size: 42px;
	}

	.hero-title {
		font-size: 29px;
	}

	.hero-copy,
	.section-heading p,
	.contact-band p {
		font-size: 16px;
	}

	.button-row,
	.button {
		width: 100%;
	}

	.credibility-grid,
	.expertise-grid,
	.principles-list {
		grid-template-columns: 1fr;
	}

	.credibility-grid {
		gap: 0;
	}

	.credibility-item {
		padding: 22px 0;
		border-bottom: 1px solid rgba(31, 37, 63, 0.1);
	}

	.credibility-item:last-child {
		border-bottom: 0;
	}

	.section-heading h2,
	.principles-title h2,
	.contact-band h2 {
		font-size: 32px;
	}

	.impact-item h3 {
		font-size: 30px;
	}

	.footer-inner {
		align-items: flex-start;
		flex-direction: column;
	}

	.footer-links {
		flex-wrap: wrap;
		gap: 18px 24px;
	}
}
