/*
Theme Name: AI Squared Child
Theme URI: https://ai-squared.ai
Description: Divi child theme for the AI Squared (AI²) marketing site.
Author: AI Squared
Template: Divi
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
Text Domain: ai-squared-child
*/

/* Fonts
   --------------------------------------------------------------------------- */

@font-face {
	font-family: "TASA Orbiter";
	src: url("assets/fonts/TASAOrbiter-Regular.ttf") format("truetype");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "TASA Orbiter";
	src: url("assets/fonts/TASAOrbiter-Variable.ttf") format("truetype");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "TASA Orbiter";
	src: url("assets/fonts/TASAOrbiter-Bold.ttf") format("truetype");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Google Sans Flex";
	src: url("assets/fonts/GoogleSansFlex-Regular.ttf") format("truetype");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Google Sans Flex";
	src: url("assets/fonts/GoogleSansFlex-Medium.ttf") format("truetype");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "Google Sans Flex";
	src: url("assets/fonts/GoogleSansFlex-SemiBold.ttf") format("truetype");
	font-weight: 600;
	font-style: normal;
	font-display: swap;
}

/* Tokens
   --------------------------------------------------------------------------- */

:root {
	--ai2-navy: #00313c;
	--ai2-teal: #00968f;
	--ai2-green: #78bd70;
	--ai2-light-teal: #e2f1f2;
	--ai2-light-green: #ebf5e3;
	--ai2-lightest-teal: #f2f9f9;
	--ai2-grey: #d2d5db;
	--ai2-white: #ffffff;

	--ai2-font-display: "TASA Orbiter", "DM Sans", sans-serif;
	--ai2-font-body: "Google Sans Flex", "Inter", sans-serif;

	--ai2-radius-btn: 12px;
	--ai2-radius-card: 15px;
	--ai2-radius-card-lg: 20px;

	--ai2-gutter-inline: 120px;
	--ai2-section-py: 80px;
	--ai2-heading-weight: 600;
}

/* Divi override reset — boost specificity for blank-canvas pages
   --------------------------------------------------------------------------- */

body.ai2-blank-canvas,
body.ai2-blank-canvas * {
	box-sizing: border-box;
}

body.ai2-blank-canvas {
	margin: 0 !important;
	padding: 0 !important;
	font-family: var(--ai2-font-body) !important;
	font-weight: 400;
	line-height: 1.55;
	color: var(--ai2-navy) !important;
	background-color: var(--ai2-white) !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

body.ai2-blank-canvas .entry-content,
body.ai2-blank-canvas .post-content,
body.ai2-blank-canvas .page-content,
body.ai2-blank-canvas .et_pb_post_content,
body.ai2-blank-canvas #et-main-area,
body.ai2-blank-canvas #main-content,
body.ai2-blank-canvas #page-container,
body.ai2-blank-canvas .container,
body.ai2-blank-canvas .et_builder_inner_content {
	width: 100% !important;
	max-width: 100% !important;
	padding: 0 !important;
	margin: 0 !important;
}

body.ai2-blank-canvas .ai2-header,
body.ai2-blank-canvas .ai2-hero,
body.ai2-blank-canvas .ai2-about,
body.ai2-blank-canvas .ai2-pillars,
body.ai2-blank-canvas .ai2-events,
body.ai2-blank-canvas .ai2-governance,
body.ai2-blank-canvas .ai2-faq,
body.ai2-blank-canvas .ai2-contact,
body.ai2-blank-canvas .ai2-footer-site {
	width: 100vw !important;
	max-width: 100vw !important;
	margin-left: calc(-50vw + 50%) !important;
	margin-right: calc(-50vw + 50%) !important;
}

body.ai2-blank-canvas .ai2-animate {
	opacity: 1 !important;
	transform: none !important;
}

body.ai2-blank-canvas img,
body.ai2-blank-canvas picture,
body.ai2-blank-canvas video,
body.ai2-blank-canvas canvas,
body.ai2-blank-canvas svg {
	display: block;
	max-width: 100%;
	height: auto;
}

body.ai2-blank-canvas h1,
body.ai2-blank-canvas h2,
body.ai2-blank-canvas h3,
body.ai2-blank-canvas h4,
body.ai2-blank-canvas h5,
body.ai2-blank-canvas h6 {
	font-family: var(--ai2-font-display) !important;
	font-weight: var(--ai2-heading-weight);
	line-height: 1.18;
	margin: 0 0 0.45em;
	letter-spacing: -0.02em;
	color: var(--ai2-navy);
	padding: 0;
}

/* Base & reset (non-blank-canvas fallback)
   --------------------------------------------------------------------------- */

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

body {
	font-family: var(--ai2-font-body);
	font-weight: 400;
	line-height: 1.55;
	color: var(--ai2-navy);
	background-color: var(--ai2-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

img,
picture,
video,
canvas,
svg {
	display: block;
	max-width: 100%;
	height: auto;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--ai2-font-display);
	font-weight: var(--ai2-heading-weight);
	line-height: 1.18;
	margin: 0 0 0.45em;
	letter-spacing: -0.02em;
	color: var(--ai2-navy);
}

h1 {
	font-size: clamp(2.25rem, 3.2vw + 1.5rem, 3.75rem);
}

h2 {
	font-size: clamp(1.85rem, 2.2vw + 1.2rem, 3rem);
}

h3 {
	font-size: clamp(1.5rem, 1.4vw + 1.1rem, 2.25rem);
}

h4 {
	font-size: clamp(1.25rem, 0.8vw + 1rem, 1.65rem);
}

h5,
h6 {
	font-size: clamp(1.1rem, 0.4vw + 0.95rem, 1.25rem);
}

p {
	margin: 0 0 1em;
}

p:last-child {
	margin-bottom: 0;
}

a {
	color: var(--ai2-teal);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
}

a:hover {
	color: var(--ai2-navy);
}

a:focus-visible {
	outline: 2px solid var(--ai2-teal);
	outline-offset: 3px;
}

button,
input,
select,
textarea {
	font: inherit;
	color: inherit;
}

/* Layout utilities
   --------------------------------------------------------------------------- */

.ai2-contained,
.et_pb_row.ai2-contained,
.et_pb_section .et_pb_row.ai2-contained {
	width: min(1180px, 100%) !important;
	margin-left: auto !important;
	margin-right: auto !important;
	max-width: 100%;
	padding-inline: var(--ai2-gutter-inline);
}

.ai2-section {
	padding-block: var(--ai2-section-py);
	padding-inline: var(--ai2-gutter-inline);
}

.ai2-section--tight {
	padding-block: calc(var(--ai2-section-py) * 0.65);
}

.ai2-section--flush-bottom {
	padding-bottom: 0;
}

.ai2-page-gutter {
	padding-inline: var(--ai2-gutter-inline);
}

.sr-only:not(:focus):not(:active),
.screen-reader-text:not(:focus):not(:active) {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip-path: inset(50%);
	clip: rect(0 0 0 0);
	white-space: nowrap;
	border: 0;
}

/* Animation utilities
   --------------------------------------------------------------------------- */

.ai2-animate {
	opacity: 0;
	will-change: transform, opacity;
	transition:
		opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.ai2-fade-up {
	transform: translateY(30px);
}

.ai2-fade-left {
	transform: translateX(-40px);
}

.ai2-fade-right {
	transform: translateX(40px);
}

.ai2-scale-in {
	transform: scale(0.95);
}

.ai2-visible {
	opacity: 1;
	transform: none;
}

.ai2-stagger.ai2-visible > .ai2-animate {
	opacity: 1;
	transform: none;
}

.ai2-stagger > * {
	transition:
		opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
		transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.ai2-stagger > *:nth-child(1) {
	transition-delay: 0ms;
}

.ai2-stagger > *:nth-child(2) {
	transition-delay: 100ms;
}

.ai2-stagger > *:nth-child(3) {
	transition-delay: 200ms;
}

.ai2-stagger > *:nth-child(4) {
	transition-delay: 300ms;
}

.ai2-stagger > *:nth-child(5) {
	transition-delay: 400ms;
}

.ai2-stagger > *:nth-child(6) {
	transition-delay: 500ms;
}

.ai2-stagger > *:nth-child(7) {
	transition-delay: 600ms;
}

.ai2-stagger > *:nth-child(8) {
	transition-delay: 700ms;
}

.ai2-stagger > *:nth-child(9) {
	transition-delay: 800ms;
}

.ai2-stagger > *:nth-child(10) {
	transition-delay: 900ms;
}

.ai2-stagger > *:nth-child(11) {
	transition-delay: 1000ms;
}

.ai2-stagger > *:nth-child(12) {
	transition-delay: 1100ms;
}

@media (prefers-reduced-motion: reduce) {
	.ai2-animate,
	.ai2-fade-up,
	.ai2-fade-left,
	.ai2-fade-right,
	.ai2-scale-in,
	.ai2-visible,
	.ai2-stagger > * {
		transition: none !important;
	}

	.ai2-animate {
		opacity: 1 !important;
		will-change: auto !important;
	}

	.ai2-fade-up,
	.ai2-fade-left,
	.ai2-fade-right,
	.ai2-scale-in {
		transform: none !important;
	}

	.ai2-stagger.ai2-visible > .ai2-animate {
		opacity: 1 !important;
		transform: none !important;
	}

	.ai2-stagger > * {
		transition-delay: 0ms !important;
	}
}

/* Responsive scale
   --------------------------------------------------------------------------- */

@media (max-width: 980px) {
	:root {
		--ai2-gutter-inline: 40px;
		--ai2-section-py: 60px;
		--ai2-heading-weight: 600;
	}

	h1 {
		font-size: clamp(2.1rem, 3vw + 1.35rem, 3.15rem);
	}

	h2 {
		font-size: clamp(1.7rem, 2vw + 1.05rem, 2.65rem);
	}

	h3 {
		font-size: clamp(1.4rem, 1.25vw + 1rem, 2rem);
	}
}

@media (max-width: 767px) {
	:root {
		--ai2-gutter-inline: 20px;
		--ai2-section-py: 40px;
	}

	h1 {
		font-size: clamp(1.95rem, 5.5vw + 1rem, 2.75rem);
	}

	h2 {
		font-size: clamp(1.55rem, 4.5vw + 0.85rem, 2.2rem);
	}

	h3 {
		font-size: clamp(1.35rem, 3.5vw + 0.75rem, 1.75rem);
	}

	h4 {
		font-size: clamp(1.15rem, 2.5vw + 0.7rem, 1.4rem);
	}
}

/* Buttons
   --------------------------------------------------------------------------- */

.ai2-btn,
.ai2-btn-outline,
.ai2-btn-clear {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.55em;
	text-decoration: none;
	font-family: var(--ai2-font-body);
	font-weight: 600;
	line-height: 1.25;
	cursor: pointer;
	border-radius: var(--ai2-radius-btn);
	border: 2px solid transparent;
	padding: 0.92em 1.55em;
	min-height: 48px;
	transition:
		background-color 0.2s ease,
		color 0.2s ease,
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		transform 0.18s ease;
}

.ai2-btn {
	background-color: var(--ai2-green);
	color: var(--ai2-navy);
	box-shadow: 0 1px 2px rgb(0 49 60 / 0.08);
}

.ai2-btn:hover {
	background-color: color-mix(in srgb, var(--ai2-green) 88%, var(--ai2-navy));
	color: var(--ai2-white);
	transform: translateY(-1px);
	box-shadow: 0 12px 30px rgb(0 49 60 / 0.12);
}

.ai2-btn:focus-visible {
	outline: 2px solid var(--ai2-teal);
	outline-offset: 3px;
}

.ai2-btn-outline {
	background-color: transparent;
	color: var(--ai2-white);
	border-color: var(--ai2-white);
	box-shadow: none;
}

.ai2-btn-outline:hover {
	background-color: var(--ai2-white);
	color: var(--ai2-navy);
	border-color: var(--ai2-white);
	transform: translateY(-1px);
}

.ai2-btn-clear {
	padding: 0.35em 0;
	min-height: 0;
	background: transparent;
	border: none;
	border-radius: 0;
	box-shadow: none;
	color: var(--ai2-teal);
	font-weight: 600;
	position: relative;
}

.ai2-btn-clear::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 1px;
	background: currentColor;
	opacity: 0;
	transform: translateY(4px);
	transition:
		opacity 0.2s ease,
		transform 0.2s ease;
}

.ai2-btn-clear:hover {
	color: var(--ai2-navy);
	transform: none;
}

.ai2-btn-clear:hover::after {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	.ai2-btn,
	.ai2-btn-outline,
	.ai2-btn-clear {
		transition: none;
	}

	.ai2-btn:hover,
	.ai2-btn-outline:hover {
		transform: none;
	}

	.ai2-btn-clear::after {
		transition: none;
	}
}

/* Cards
   --------------------------------------------------------------------------- */

.ai2-card {
	background: var(--ai2-white);
	border: 1px solid color-mix(in srgb, var(--ai2-grey) 65%, var(--ai2-white));
	border-radius: var(--ai2-radius-card);
	box-shadow: 0 12px 40px rgb(0 49 60 / 0.06);
	padding: clamp(1.25rem, 2vw, 1.75rem);
	transition:
		transform 0.25s ease,
		box-shadow 0.25s ease,
		border-color 0.25s ease;
}

.ai2-card:hover {
	transform: translateY(-6px);
	box-shadow: 0 22px 55px rgb(0 49 60 / 0.12);
	border-color: color-mix(in srgb, var(--ai2-teal) 35%, var(--ai2-grey));
}

@media (prefers-reduced-motion: reduce) {
	.ai2-card {
		transition: none;
	}

	.ai2-card:hover {
		transform: none;
	}
}

/* Accordion
   --------------------------------------------------------------------------- */

.ai2-accordion-item {
	border-bottom: 1px solid var(--ai2-grey);
}

.ai2-accordion-item:first-child {
	border-top: 1px solid var(--ai2-grey);
}

.ai2-accordion-trigger,
.ai2-accordion-header {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	text-align: left;
	padding: 1.15rem 0;
	background: none;
	border: none;
	cursor: pointer;
	font-family: var(--ai2-font-display);
	font-weight: 600;
	font-size: 1.05rem;
	color: var(--ai2-navy);
}

.ai2-accordion-icon {
	flex: 0 0 auto;
	width: 1.25rem;
	height: 1.25rem;
	position: relative;
	transition: transform 0.25s ease;
}

.ai2-accordion-icon::before,
.ai2-accordion-icon::after {
	content: "";
	position: absolute;
	background: var(--ai2-teal);
	border-radius: 1px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

.ai2-accordion-icon::before {
	width: 100%;
	height: 2px;
}

.ai2-accordion-icon::after {
	width: 2px;
	height: 100%;
}

.ai2-accordion-item.is-open .ai2-accordion-icon,
.ai2-accordion-item.ai2-accordion-open .ai2-accordion-icon {
	transform: rotate(45deg);
}

.ai2-accordion-panel {
	overflow: hidden;
	max-height: 0;
	opacity: 0;
	transition:
		max-height 0.35s ease,
		opacity 0.25s ease;
}

.ai2-accordion-item.is-open .ai2-accordion-panel,
.ai2-accordion-item.ai2-accordion-open .ai2-accordion-panel {
	max-height: min(80vh, 1200px);
	opacity: 1;
}

.ai2-accordion-panel-inner {
	padding: 0 0 1.15rem;
	color: color-mix(in srgb, var(--ai2-navy) 78%, var(--ai2-white));
	font-size: 1rem;
}

.ai2-accordion-header__text {
	flex: 1 1 auto;
}

.ai2-accordion-header__icon {
	flex: 0 0 auto;
	display: inline-flex;
	color: var(--ai2-teal);
	align-items: center;
	justify-content: center;
}

.ai2-accordion-header__icon svg {
	display: block;
	transition: transform 0.25s ease;
}

.ai2-accordion-item.ai2-accordion-open .ai2-accordion-header__icon svg {
	transform: rotate(45deg);
}

.ai2-faq-num {
	display: inline-block;
	margin-inline-end: 0.42em;
	color: color-mix(in srgb, var(--ai2-navy) 54%, var(--ai2-grey));
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

@media (prefers-reduced-motion: reduce) {
	.ai2-accordion-icon,
	.ai2-accordion-panel,
	.ai2-accordion-header__icon svg {
		transition: none;
	}
}

/* Header
   --------------------------------------------------------------------------- */

#main-header.ai2-header,
.et_fixed_nav #main-header.ai2-header,
.et_non_fixed_nav #main-header.ai2-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	width: 100%;
	background-color: transparent;
	box-shadow: none;
	border-bottom: 1px solid transparent;
	transition:
		background-color 0.35s ease,
		border-color 0.35s ease,
		box-shadow 0.35s ease,
		backdrop-filter 0.35s ease;
}

.ai2-header .et_mobile_menu-bar,
.ai2-header .logo_container a,
.ai2-header #et-top-navigation nav > ul > li > a {
	transition: color 0.35s ease;
}

.ai2-header.is-scrolled,
body.admin-bar .ai2-header.is-scrolled {
	background-color: color-mix(in srgb, var(--ai2-white) 92%, transparent);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 10px 40px rgb(0 49 60 / 0.08);
	border-bottom-color: color-mix(in srgb, var(--ai2-grey) 45%, transparent);
}

.et_non_fixed_nav #main-header.ai2-header {
	position: sticky;
}

@media (prefers-reduced-motion: reduce) {
	#main-header.ai2-header {
		transition: none;
	}
}

/* Pillar & founder
   --------------------------------------------------------------------------- */

.ai2-pillar-card {
	position: sticky;
	top: max(6rem, 12vh);
	border-radius: var(--ai2-radius-card-lg);
	background: var(--ai2-lightest-teal);
	border: 1px solid color-mix(in srgb, var(--ai2-teal) 18%, var(--ai2-white));
	box-shadow: 0 18px 50px rgb(0 49 60 / 0.08);
	padding: clamp(1.5rem, 2.4vw, 2.25rem);
}

.ai2-founder-card {
	display: grid;
	grid-template-columns: minmax(0, 160px) minmax(0, 1fr);
	gap: clamp(1rem, 2.5vw, 1.75rem);
	align-items: center;
	border-radius: var(--ai2-radius-card);
	background: var(--ai2-white);
	border: 1px solid color-mix(in srgb, var(--ai2-grey) 70%, var(--ai2-white));
	padding: clamp(1.1rem, 2vw, 1.5rem);
	box-shadow: 0 10px 30px rgb(0 49 60 / 0.06);
}

.ai2-founder-card__media {
	border-radius: calc(var(--ai2-radius-card) - 4px);
	overflow: hidden;
	aspect-ratio: 1;
	background: var(--ai2-light-teal);
}

.ai2-founder-card__name {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: 1.15rem;
	margin: 0 0 0.25rem;
}

.ai2-founder-card__role {
	margin: 0;
	font-size: 0.95rem;
	color: color-mix(in srgb, var(--ai2-navy) 72%, var(--ai2-white));
}

@media (max-width: 767px) {
	.ai2-founder-card {
		grid-template-columns: minmax(0, 1fr);
		text-align: center;
	}

	.ai2-founder-card__media {
		max-width: 180px;
		margin-inline: auto;
	}

	.ai2-pillar-card {
		top: 5.25rem;
	}
}

/* Forms
   --------------------------------------------------------------------------- */

.ai2-input,
.ai2-textarea,
.ai2-select {
	width: 100%;
	font-family: var(--ai2-font-body);
	font-size: 1rem;
	line-height: 1.45;
	color: var(--ai2-navy);
	background-color: var(--ai2-white);
	border: 1px solid color-mix(in srgb, var(--ai2-grey) 85%, var(--ai2-navy));
	border-radius: 10px;
	padding: 0.85rem 1rem;
	box-shadow: inset 0 1px 2px rgb(0 49 60 / 0.04);
	transition:
		border-color 0.2s ease,
		box-shadow 0.2s ease,
		background-color 0.2s ease;
}

.ai2-textarea {
	min-height: 160px;
	resize: vertical;
}

.ai2-select {
	appearance: none;
	background-image: linear-gradient(45deg, transparent 50%, var(--ai2-navy) 50%),
		linear-gradient(135deg, var(--ai2-navy) 50%, transparent 50%);
	background-position:
		calc(100% - 1.15rem) calc(50% + 4px),
		calc(100% - 0.76rem) calc(50% + 4px);
	background-size:
		8px 8px,
		8px 8px;
	background-repeat: no-repeat;
	padding-right: 2.5rem;
}

.ai2-input::placeholder,
.ai2-textarea::placeholder {
	color: color-mix(in srgb, var(--ai2-navy) 42%, var(--ai2-grey));
	opacity: 1;
}

.ai2-input:hover,
.ai2-textarea:hover,
.ai2-select:hover {
	border-color: color-mix(in srgb, var(--ai2-teal) 42%, var(--ai2-grey));
}

.ai2-input:focus,
.ai2-textarea:focus,
.ai2-select:focus {
	outline: none;
	border-color: var(--ai2-teal);
	box-shadow:
		inset 0 1px 2px rgb(0 49 60 / 0.05),
		0 0 0 3px color-mix(in srgb, var(--ai2-teal) 22%, transparent);
}

.ai2-input:disabled,
.ai2-textarea:disabled,
.ai2-select:disabled {
	opacity: 0.55;
	cursor: not-allowed;
	background-color: var(--ai2-lightest-teal);
}

/* Footer
   --------------------------------------------------------------------------- */

.ai2-footer {
	background-color: var(--ai2-navy);
	color: color-mix(in srgb, var(--ai2-white) 88%, transparent);
	padding-block: clamp(3rem, 6vw, 4.5rem);
	position: relative;
	overflow: clip;
}

.ai2-footer__inner {
	width: min(1180px, 100%);
	margin-inline: auto;
	padding-inline: var(--ai2-gutter-inline);
}

.ai2-footer a {
	color: color-mix(in srgb, var(--ai2-white) 92%, transparent);
	text-decoration: none;
}

.ai2-footer a:hover {
	color: var(--ai2-green);
}

.ai2-footer__primary {
	display: grid;
	grid-template-columns: minmax(0, 1.5fr) repeat(2, minmax(0, 1fr));
	gap: clamp(1.5rem, 4vw, 3rem);
	padding-bottom: clamp(2rem, 4vw, 2.75rem);
	border-bottom: 1px solid color-mix(in srgb, var(--ai2-white) 16%, transparent);
}

.ai2-footer__brand {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: 1.35rem;
	color: var(--ai2-white);
	margin: 0 0 0.75rem;
}

.ai2-footer__meta {
	margin: 0;
	font-size: 0.95rem;
	max-width: 38ch;
}

.ai2-footer__column-title {
	font-family: var(--ai2-font-display);
	font-weight: 600;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: color-mix(in srgb, var(--ai2-white) 62%, transparent);
	margin: 0 0 1rem;
}

.ai2-footer__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.55rem;
}

.ai2-footer__bar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding-top: clamp(1.5rem, 3vw, 2rem);
	font-size: 0.9rem;
	color: color-mix(in srgb, var(--ai2-white) 66%, transparent);
}

@media (max-width: 980px) {
	.ai2-footer__primary {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	}
}

@media (max-width: 767px) {
	.ai2-footer__primary {
		grid-template-columns: minmax(0, 1fr);
	}

	.ai2-footer__bar {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* Home layout partials (layouts/sections-top.html)
   --------------------------------------------------------------------------- */

/* Fallback when header is not #main-header (e.g. Code module) */
header.ai2-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	width: 100%;
	background-color: transparent;
	transition:
		background-color 0.35s ease,
		border-color 0.35s ease,
		box-shadow 0.35s ease,
		backdrop-filter 0.35s ease;
}

header.ai2-header.is-scrolled {
	background-color: color-mix(in srgb, var(--ai2-white) 92%, transparent);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	box-shadow: 0 10px 40px rgb(0 49 60 / 0.08);
	border-bottom: 1px solid color-mix(in srgb, var(--ai2-grey) 45%, transparent);
}

.ai2-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.25rem;
	padding-block: 1rem;
	max-width: 100%;
}

.ai2-header__brand {
	display: inline-flex;
	text-decoration: none;
}

.ai2-header__logo-svg {
	color: var(--ai2-navy);
	width: min(240px, 58vw);
	height: auto;
}

.ai2-hero .ai2-header__logo-svg,
header.ai2-header:not(.is-scrolled) .ai2-header__logo-svg {
	color: var(--ai2-navy);
}

header.ai2-header.is-scrolled .ai2-header__logo-svg {
	color: var(--ai2-navy);
}

.ai2-header__nav {
	display: flex;
}

.ai2-header__nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: clamp(1rem, 2vw, 1.75rem);
}

.ai2-header__link {
	color: var(--ai2-navy);
	text-decoration: none;
	font-family: var(--ai2-font-body);
	font-weight: 600;
	font-size: 0.95rem;
}

.ai2-header__link:hover {
	color: var(--ai2-teal);
}

header.ai2-header.is-scrolled .ai2-header__link {
	color: var(--ai2-navy);
}

header.ai2-header.is-scrolled .ai2-header__link:hover {
	color: var(--ai2-teal);
}

.ai2-header__cta {
	flex: 0 0 auto;
	color: var(--ai2-navy) !important;
	border-color: var(--ai2-navy) !important;
	background: transparent;
}

.ai2-header__cta:hover {
	background: var(--ai2-navy) !important;
	color: var(--ai2-white) !important;
}

.ai2-header__hamburger {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	width: 44px;
	height: 44px;
	cursor: pointer;
	border-radius: 10px;
	border: 1px solid color-mix(in srgb, var(--ai2-navy) 25%, var(--ai2-grey));
	background: var(--ai2-white);
}

.ai2-header__hamburger-line {
	display: block;
	height: 2px;
	width: 22px;
	margin-inline: auto;
	background: var(--ai2-navy);
	border-radius: 2px;
}

header.ai2-header.is-scrolled .ai2-header__hamburger {
	border-color: color-mix(in srgb, var(--ai2-navy) 18%, var(--ai2-grey));
	background: var(--ai2-white);
}

header.ai2-header.is-scrolled .ai2-header__hamburger-line {
	background: var(--ai2-navy);
}

.ai2-header__overlay {
	position: fixed;
	inset: 0;
	background: rgb(0 49 60 / 0.45);
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s ease;
	z-index: 1001;
}

.ai2-header__drawer {
	position: fixed;
	top: 0;
	right: 0;
	height: 100dvh;
	width: min(360px, 88vw);
	background: var(--ai2-navy);
	color: var(--ai2-white);
	transform: translateX(100%);
	transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
	z-index: 1002;
	box-shadow: -18px 0 50px rgb(0 0 0 / 0.18);
}

.ai2-header__drawer-inner {
	padding: clamp(1.25rem, 4vw, 2rem);
	display: grid;
	gap: 1.5rem;
	padding-top: 5.5rem;
}

.ai2-header__drawer-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.75rem;
}

.ai2-header__drawer-link {
	color: var(--ai2-white);
	text-decoration: none;
	font-family: var(--ai2-font-display);
	font-weight: 600;
	font-size: 1.2rem;
}

.ai2-header__drawer-link:hover {
	color: var(--ai2-green);
}

.ai2-header__drawer-cta {
	width: 100%;
	text-align: center;
}

#ai2-nav-toggle:checked ~ .ai2-header__overlay {
	opacity: 1;
	pointer-events: auto;
}

#ai2-nav-toggle:checked ~ .ai2-header__drawer {
	transform: translateX(0);
}

@media (max-width: 980px) {
	.ai2-header__nav,
	.ai2-header__cta {
		display: none;
	}

	.ai2-header__hamburger {
		display: inline-flex;
	}
}

@media (min-width: 981px) {
	.ai2-header__overlay,
	.ai2-header__drawer {
		display: none;
	}
}

/* Hero */
.ai2-hero {
	position: relative;
	isolation: isolate;
	overflow: clip;
	color: var(--ai2-white);
	min-height: auto;
	padding-block: clamp(3.5rem, 8vw, 5.5rem);
}

@media (min-width: 981px) {
	.ai2-hero {
		min-height: 810px;
		display: flex;
		align-items: center;
	}
}

.ai2-hero__media {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.ai2-hero__bg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ai2-hero__overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
}

.ai2-hero__overlay--hard-light {
	background: color-mix(in srgb, var(--ai2-navy) 85%, transparent);
	mix-blend-mode: hard-light;
}

.ai2-hero__overlay--multiply {
	background: color-mix(in srgb, var(--ai2-navy) 20%, transparent);
	mix-blend-mode: multiply;
}

.ai2-hero__inner {
	position: relative;
	z-index: 2;
	width: min(1180px, 100%);
	margin-inline: auto;
}

.ai2-hero__title {
	font-family: var(--ai2-font-display);
	font-weight: 600;
	font-size: clamp(2.5rem, 3.5vw + 1.5rem, 4.5rem);
	line-height: 1.08;
	letter-spacing: -0.03em;
	color: var(--ai2-white);
	max-width: 18ch;
	margin-bottom: 0.65em;
}

.ai2-hero__subtitle {
	font-family: var(--ai2-font-display);
	font-weight: 400;
	font-size: clamp(1.05rem, 0.6vw + 0.95rem, 1.5rem);
	line-height: 1.45;
	color: color-mix(in srgb, var(--ai2-white) 92%, transparent);
	max-width: 52ch;
	margin-bottom: 1.75rem;
}

.ai2-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
}

/* About */
.ai2-about {
	background: var(--ai2-white);
}

.ai2-about__grid {
	display: grid;
	grid-template-columns: minmax(0, 0.4fr) minmax(0, 0.55fr);
	gap: clamp(1.75rem, 4vw, 3.5rem);
	align-items: center;
}

@media (max-width: 980px) {
	.ai2-about__grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

.ai2-about__eyebrow {
	font-family: var(--ai2-font-body);
	font-weight: 500;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: color-mix(in srgb, var(--ai2-navy) 62%, var(--ai2-grey));
	margin: 0 0 0.85rem;
}

.ai2-about__title {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 1.8vw + 1.35rem, 2.5rem);
	color: var(--ai2-green);
	margin: 0 0 1rem;
}

.ai2-about__body {
	font-size: 1.05rem;
	color: color-mix(in srgb, var(--ai2-navy) 88%, var(--ai2-white));
}

.ai2-about__learn {
	display: inline-flex;
	align-items: center;
	gap: 0.35em;
	font-family: var(--ai2-font-body);
	font-weight: 600;
	color: var(--ai2-green);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.2em;
}

.ai2-about__learn:hover {
	color: var(--ai2-navy);
}

.ai2-about__figure {
	position: relative;
	margin: 0;
}

.ai2-about__deco {
	position: absolute;
	z-index: 0;
	width: min(65%, 360px);
	left: -6%;
	bottom: -8%;
	pointer-events: none;
}

.ai2-about__image {
	position: relative;
	z-index: 1;
	width: 100%;
	height: auto;
	border-radius: 15px;
	box-shadow: 0 26px 60px rgb(0 49 60 / 0.12);
}

/* Pillars stack */
.ai2-pillars {
	background: var(--ai2-light-green);
}

.ai2-pillars__intro {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
	gap: clamp(1.25rem, 4vw, 3rem);
	align-items: start;
	padding-bottom: clamp(1.5rem, 3vw, 2.75rem);
}

@media (max-width: 767px) {
	.ai2-pillars__intro {
		grid-template-columns: minmax(0, 1fr);
	}
}

.ai2-pillars__title {
	margin: 0;
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 1.6vw + 1.25rem, 2.5rem);
	color: var(--ai2-navy);
}

.ai2-pillars__lede {
	margin: 0;
	font-size: 1.05rem;
	color: color-mix(in srgb, var(--ai2-navy) 82%, var(--ai2-white));
}

.ai2-pillars__stack {
	display: grid;
	gap: 0;
	padding-bottom: clamp(2rem, 5vw, 4rem);
}

.ai2-pillar-slot {
	position: relative;
	display: flex;
	justify-content: center;
	padding-inline: var(--ai2-gutter-inline);
	padding-block: 1rem;
}

.ai2-pillar-card.ai2-pillar-card--home {
	top: 0;
	background: #00313c;
	border: 2px solid #78bd70;
	border-radius: 20px;
	color: color-mix(in srgb, var(--ai2-white) 92%, transparent);
	box-shadow: 0 30px 80px rgb(0 0 0 / 0.22);
	align-self: start;
	padding: clamp(1.65rem, 3vw, 2.75rem);
}

.ai2-pillar-card.ai2-pillar-card--home .ai2-pillar-card__heading {
	color: var(--ai2-white);
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 2.2vw + 1rem, 2.75rem);
	margin: 0 0 0.65rem;
}

.ai2-pillar-card.ai2-pillar-card--home .ai2-pillar-card__label {
	font-family: var(--ai2-font-body);
	font-weight: 600;
	font-size: 0.82rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--ai2-white) 65%, transparent);
	margin: 0 0 0.85rem;
}

.ai2-pillar-card.ai2-pillar-card--home .ai2-pillar-card__copy {
	margin: 0;
	line-height: 1.65;
	font-size: 1.03rem;
}

.ai2-pillar-card.ai2-pillar-card--home .ai2-pillar-card__tagline {
	font-family: var(--ai2-font-display);
	font-weight: 600;
	color: var(--ai2-green);
	margin: 0;
	font-size: clamp(1.05rem, 0.65vw + 0.92rem, 1.35rem);
	line-height: 1.35;
	text-align: right;
}

.ai2-pillar-card__grid {
	display: grid;
	grid-template-columns: minmax(0, 1.25fr) minmax(0, 0.75fr);
	gap: clamp(1.25rem, 3vw, 2rem);
	align-items: start;
}

@media (max-width: 767px) {
	.ai2-pillar-card__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.ai2-pillar-card.ai2-pillar-card--home .ai2-pillar-card__tagline {
		text-align: left;
	}
}

.ai2-pillar-slot--w1 .ai2-pillar-card--home {
	width: min(100%, 1280px);
	margin-inline: auto;
}

.ai2-pillar-slot--w2 .ai2-pillar-card--home {
	width: min(100%, 1300px);
	margin-inline: auto;
}

.ai2-pillar-slot--w3 .ai2-pillar-card--home {
	width: min(100%, 1320px);
	margin-inline: auto;
}

.ai2-pillar-slot--w4 .ai2-pillar-card--home {
	width: min(100%, 1340px);
	margin-inline: auto;
}

@media (prefers-reduced-motion: reduce) {
	.ai2-header__overlay,
	.ai2-header__drawer {
		transition: none;
	}

	header.ai2-header {
		transition: none;
	}
}

/* Home bottom sections (layouts/sections-bottom.html)
   --------------------------------------------------------------------------- */

.ai2-events {
	background-color: #00313c;
	color: var(--ai2-white);
	width: 100%;
	position: relative;
}

@media (min-width: 981px) {
	.ai2-events {
		min-height: 904px;
	}

	.ai2-events__intro {
		font-size: 1.75rem;
		line-height: 1.38;
	}
}

.ai2-events__sticky-bar {
	position: sticky;
	top: 0;
	z-index: 5;
	height: 80px;
	width: 100%;
	background-color: #ebf5e3;
	box-shadow: 0 1px 0 color-mix(in srgb, var(--ai2-navy) 10%, transparent);
}

.ai2-events__inner {
	padding-block: clamp(2rem, 4vw, 3rem);
}

.ai2-events__intro {
	font-family: var(--ai2-font-display);
	font-weight: 400;
	font-size: clamp(1.15rem, 1.2vw + 0.9rem, 1.75rem);
	line-height: 1.38;
	max-width: 72ch;
	color: var(--ai2-white);
	margin: clamp(1.25rem, 2vw, 1.85rem) 0 clamp(2rem, 3vw, 2.75rem);
}

.ai2-events__grid {
	display: grid;
	grid-template-columns: minmax(0, 55%) minmax(0, 27%);
	justify-content: space-between;
	align-items: stretch;
	gap: clamp(1.75rem, 4vw, 3rem);
}

@media (max-width: 980px) {
	.ai2-events__grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

.ai2-events__figure {
	position: relative;
	border-radius: var(--ai2-radius-card-lg);
	overflow: hidden;
	isolation: isolate;
}

.ai2-events__figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	min-height: min(420px, 55vw);
}

.ai2-events__gradient {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
}

.ai2-events__gradient::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		165deg,
		color-mix(in srgb, var(--ai2-teal) 65%, transparent) 0%,
		color-mix(in srgb, var(--ai2-navy) 70%, transparent) 100%
	);
	mix-blend-mode: multiply;
	opacity: 0.6;
}

.ai2-events__gradient::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		195deg,
		color-mix(in srgb, var(--ai2-teal) 40%, var(--ai2-navy)) 0%,
		transparent 75%
	);
	mix-blend-mode: multiply;
	opacity: 0.4;
}

.ai2-events__poster {
	position: absolute;
	left: clamp(1.25rem, 3vw, 2rem);
	right: clamp(1.25rem, 3vw, 2rem);
	bottom: clamp(1.25rem, 3vw, 2rem);
	z-index: 2;
	max-width: 40ch;
}

.ai2-events__title {
	color: var(--ai2-white);
	font-size: clamp(2rem, 2.4vw + 1rem, 2.85rem);
	margin: 0 0 0.5em;
	font-weight: 700;
}

.ai2-events__desc {
	font-size: clamp(1rem, 0.35vw + 0.92rem, 1.125rem);
	color: color-mix(in srgb, var(--ai2-white) 92%, transparent);
	margin: 0 0 1rem;
	line-height: 1.58;
}

.ai2-events__actions {
	margin: 0;
}

.ai2-btn-teal {
	background-color: var(--ai2-teal);
	color: var(--ai2-white);
	box-shadow: 0 1px 2px rgb(0 49 60 / 0.1);
}

.ai2-btn-teal:hover {
	background-color: color-mix(in srgb, var(--ai2-teal) 78%, var(--ai2-navy));
	color: var(--ai2-white);
	transform: translateY(-1px);
	box-shadow: 0 12px 30px rgb(0 49 60 / 0.14);
}

.ai2-events__aside {
	display: flex;
	align-items: stretch;
}

.ai2-events__aside-inner {
	display: grid;
	gap: clamp(1rem, 2vw, 1.35rem);
	width: 100%;
}

.ai2-events-card {
	border-radius: var(--ai2-radius-card-lg);
	padding: clamp(1.25rem, 2.4vw, 1.85rem);
}

.ai2-events-card__label {
	font-family: var(--ai2-font-body);
	font-weight: 600;
	font-size: 0.82rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin: 0 0 0.75rem;
}

.ai2-events-card__title {
	font-family: var(--ai2-font-display);
	font-weight: 600;
	font-size: clamp(1.05rem, 0.85vw + 0.92rem, 1.38rem);
	line-height: 1.35;
	margin: 0;
}

.ai2-events-card--upcoming {
	background-color: #00968f;
	color: var(--ai2-white);
	border: none;
	box-shadow: 0 14px 40px rgb(0 49 60 / 0.2);
}

.ai2-events-card--upcoming .ai2-events-card__label {
	color: color-mix(in srgb, var(--ai2-white) 76%, transparent);
}

.ai2-events-card--latest {
	background-color: transparent;
	border: 2px solid var(--ai2-teal);
	color: var(--ai2-white);
}

.ai2-events-card--latest .ai2-events-card__label {
	color: color-mix(in srgb, var(--ai2-white) 76%, transparent);
}

/* Governance */

.ai2-governance {
	background-color: var(--ai2-white);
}

.ai2-governance__title {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 1.6vw + 1rem, 2.5rem);
	color: var(--ai2-navy);
	margin-bottom: 0.85rem;
}

.ai2-governance__lead {
	font-size: clamp(1rem, 0.45vw + 0.93rem, 1.125rem);
	font-weight: 400;
	max-width: 68ch;
	color: color-mix(in srgb, var(--ai2-navy) 92%, transparent);
	margin-bottom: clamp(2rem, 4vw, 2.85rem);
}

@media (min-width: 981px) {
	.ai2-governance__title {
		font-size: 2.5rem;
	}

	.ai2-governance__lead {
		font-size: 1.125rem;
		line-height: 1.62;
	}
}

.ai2-governance__founders {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1.25rem, 3vw, 2rem);
}

@media (max-width: 767px) {
	.ai2-governance__founders {
		grid-template-columns: minmax(0, 1fr);
		max-width: 400px;
		margin-inline: auto;
	}
}

.ai2-founder-card--portrait {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	padding: clamp(0.95rem, 2vw, 1.35rem) clamp(0.95rem, 2vw, 1.35rem) 0;
	overflow: hidden;
	border-radius: var(--ai2-radius-card);
	text-align: left;
	background: var(--ai2-white);
	border: 1px solid color-mix(in srgb, var(--ai2-grey) 55%, transparent);
	box-shadow: 0 12px 35px rgb(0 49 60 / 0.07);
}

.ai2-founder-card--portrait .ai2-founder-card__media {
	grid-template-columns: unset;
	display: block;
	aspect-ratio: 1;
	border-radius: 15px;
	overflow: hidden;
	width: 100%;
	margin: 0 0 clamp(0.85rem, 2vw, 1rem);
	background: var(--ai2-light-teal);
	align-self: stretch;
	max-width: none;
}

.ai2-founder-card--portrait .ai2-founder-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ai2-founder-card--portrait .ai2-founder-card__caption {
	margin-top: auto;
	margin-inline: calc(-1 * clamp(0.95rem, 2vw, 1.35rem));
	margin-bottom: 0;
	background-color: var(--ai2-light-teal);
	padding: clamp(1rem, 2vw, 1.35rem) clamp(0.95rem, 2vw, 1.35rem);
}

.ai2-founder-card--portrait .ai2-founder-card__name {
	font-family: var(--ai2-font-display);
	font-weight: 600;
	font-size: clamp(1.15rem, 0.85vw + 0.92rem, 1.5rem);
	color: var(--ai2-navy);
	margin: 0 0 0.35rem;
}

.ai2-founder-card--portrait .ai2-founder-card__role {
	font-family: var(--ai2-font-body);
	font-weight: 500;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ai2-navy);
	margin: 0;
	opacity: 0.88;
}

/* FAQ */
.ai2-faq {
	background-color: var(--ai2-white);
}

.ai2-faq__grid {
	display: grid;
	grid-template-columns: minmax(0, 20%) minmax(0, 55%);
	justify-content: space-between;
	column-gap: clamp(2rem, 5vw, 4rem);
	align-items: start;
}

@media (max-width: 980px) {
	.ai2-faq__grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

.ai2-faq__title {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 1.6vw + 1rem, 2.5rem);
	color: var(--ai2-green);
	margin-bottom: 0.85rem;
}

.ai2-faq__lead {
	font-size: clamp(1rem, 0.45vw + 0.93rem, 1.125rem);
	font-weight: 400;
	color: color-mix(in srgb, var(--ai2-navy) 90%, transparent);
	line-height: 1.62;
	max-width: 44ch;
}

/* Contact */
.ai2-contact {
	background-color: var(--ai2-lightest-teal);
}

.ai2-contact__inner {
	display: grid;
	grid-template-columns: minmax(0, 20%) minmax(0, 48%);
	justify-content: space-between;
	column-gap: clamp(2rem, 5vw, 4rem);
	align-items: start;
}

@media (max-width: 980px) {
	.ai2-contact__inner {
		grid-template-columns: minmax(0, 1fr);
	}
}

.ai2-contact__eyebrow {
	font-family: var(--ai2-font-body);
	font-weight: 500;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin: 0 0 0.75rem;
	color: color-mix(in srgb, var(--ai2-navy) 62%, var(--ai2-grey));
}

.ai2-contact__title {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: clamp(2rem, 1.6vw + 1rem, 2.5rem);
	color: var(--ai2-navy);
	margin-bottom: clamp(1rem, 2vw, 1.35rem);
}

.ai2-contact__divider {
	width: 100%;
	border: none;
	border-top: 1px solid color-mix(in srgb, var(--ai2-grey) 70%, var(--ai2-teal));
	margin: 0 0 clamp(1.25rem, 2vw, 1.5rem);
}

.ai2-contact__lead {
	font-size: clamp(1rem, 0.45vw + 0.93rem, 1.125rem);
	font-weight: 400;
	color: color-mix(in srgb, var(--ai2-navy) 92%, transparent);
	max-width: 46ch;
	margin-bottom: 1.25rem;
}

.ai2-contact__social {
	margin: 0;
}

.ai2-contact__linkedin {
	font-weight: 600;
	color: var(--ai2-teal);
}

.ai2-contact__linkedin:hover {
	color: var(--ai2-navy);
}

.ai2-contact-form__fields {
	display: grid;
	gap: 1rem;
}

.ai2-contact-form .ai2-field {
	margin: 0;
}

.ai2-contact-form__submit-row {
	margin: 1.25rem 0 0;
}

.ai2-btn-submit {
	background-color: var(--ai2-navy);
	color: var(--ai2-white);
	border-color: transparent;
	box-shadow: 0 1px 2px rgb(0 49 60 / 0.12);
}

.ai2-btn-submit:hover {
	background-color: color-mix(in srgb, var(--ai2-navy) 82%, var(--ai2-teal));
	color: var(--ai2-white);
	transform: translateY(-1px);
}

/* Footer (light home variant) */
.ai2-footer-site {
	background-color: var(--ai2-white);
	color: var(--ai2-navy);
	padding-block: clamp(2.5rem, 5vw, 3.75rem);
}

.ai2-footer-site__inner {
	width: min(1180px, 100%);
	margin-inline: auto;
}

.ai2-footer-site__rule {
	border: none;
	border-top: 1px solid var(--ai2-grey);
	margin: 0 0 clamp(2rem, 4vw, 2.75rem);
}

.ai2-footer-site__rule--sub {
	margin: clamp(2rem, 4vw, 2.75rem) 0 clamp(1.25rem, 2.5vw, 1.75rem);
}

.ai2-footer-site__primary {
	display: grid;
	gap: clamp(2rem, 4vw, 2.75rem);
}

.ai2-footer-site__logo-link {
	display: inline-flex;
	text-decoration: none;
}

.ai2-footer-site__logo-link:focus-visible {
	outline: 2px solid var(--ai2-teal);
	outline-offset: 4px;
}

.ai2-footer-site__cols {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(1.5rem, 4vw, 3rem);
}

@media (max-width: 767px) {
	.ai2-footer-site__cols {
		grid-template-columns: minmax(0, 1fr);
	}
}

.ai2-footer-site__col-title {
	font-family: var(--ai2-font-display);
	font-weight: 700;
	font-size: 1rem;
	color: var(--ai2-green);
	margin: 0 0 1rem;
}

.ai2-footer-site__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.55rem;
}

.ai2-footer-site__list a {
	font-family: var(--ai2-font-body);
	font-weight: 400;
	color: var(--ai2-navy);
	text-decoration: none;
}

.ai2-footer-site__list a:hover {
	color: var(--ai2-teal);
	text-decoration: underline;
	text-underline-offset: 0.18em;
}

.ai2-footer-site__bar {
	padding-top: 0;
}

.ai2-footer-site__copyright {
	margin: 0;
	font-size: 0.9rem;
	color: color-mix(in srgb, var(--ai2-navy) 72%, var(--ai2-white));
}
