/*
 Theme Name:   Bricks Child Theme
 Theme URI:    https://bricksbuilder.io/
 Description:  Use this child theme to extend Bricks.
 Author:       Bricks
 Author URI:   https://bricksbuilder.io/
 Template:     bricks
 Version:      1.1
 Text Domain:  bricks
*/

:root {
	--ak-ink: #181612;
	--ak-muted: #675f54;
	--ak-line: #d9d0c0;
	--ak-bg: #faf7ef;
	--ak-panel: #eee7d8;
	--ak-primary: #24392f;
	--ak-primary-soft: #4a604f;
	--ak-primary-deep: #16241e;
	--ak-accent: #b89458;
	--ak-rust: #8a4b35;
	--ak-max: 1180px;
	--ak-font-body: "Manrope", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--ak-font-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
}

* {
	box-sizing: border-box;
}

body {
	margin: 0;
	background: var(--ak-bg);
	color: var(--ak-ink);
	font-family: var(--ak-font-body);
	font-size: 16px;
	font-weight: 400;
	line-height: 1.68;
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: inherit;
	text-decoration: none;
}

p {
	margin: 0 0 1rem;
	text-wrap: pretty;
}

h1,
h2,
h3 {
	margin: 0;
	font-family: var(--ak-font-display);
	font-weight: 500;
	line-height: 0.98;
}

h1 {
	font-size: clamp(3.4rem, 8.4vw, 8.6rem);
	font-weight: 500;
}

h2 {
	font-size: clamp(2.25rem, 4.35vw, 4.75rem);
	font-weight: 500;
}

h3 {
	font-size: clamp(1.45rem, 2.25vw, 2.25rem);
	font-weight: 500;
}

.ak-container {
	width: min(var(--ak-max), calc(100% - 40px));
	margin-inline: auto;
}

.ak-site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: 18px clamp(20px, 4vw, 56px);
	background: rgba(251, 250, 247, 0.92);
	border-bottom: 1px solid rgba(25, 22, 19, 0.08);
	backdrop-filter: blur(18px);
}

.ak-brand {
	display: inline-flex;
	align-items: center;
	font-family: var(--ak-font-display);
	font-size: 1.45rem;
	letter-spacing: 0;
}

.ak-brand .custom-logo-link,
.ak-brand .custom-logo {
	display: block;
}

.ak-brand .custom-logo {
	width: auto;
	max-width: clamp(120px, 15vw, 190px);
	max-height: 54px;
	object-fit: contain;
}

.ak-primary-nav {
	display: flex;
	align-items: center;
	gap: clamp(14px, 2.2vw, 30px);
	font-size: clamp(0.8rem, 0.75vw, 0.88rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--ak-muted);
}

.ak-primary-nav a:hover,
.ak-link:hover {
	color: var(--ak-primary);
}

.ak-menu-toggle {
	display: none;
	width: 42px;
	height: 42px;
	border: 1px solid var(--ak-line);
	background: transparent;
	padding: 10px;
}

.ak-menu-toggle span {
	display: block;
	height: 1px;
	background: var(--ak-ink);
	margin: 7px 0;
}

.ak-hero {
	position: relative;
	min-height: calc(100vh - 78px);
	display: grid;
	align-items: end;
	background: var(--ak-primary-deep);
	color: #fffaf2;
	overflow: hidden;
}

.ak-hero-media {
	position: absolute;
	inset: 0;
	opacity: 0.62;
}

.ak-hero-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ak-hero::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(18, 31, 25, 0.84), rgba(18, 31, 25, 0.22) 58%, rgba(18, 31, 25, 0.66));
}

.ak-hero-content {
	position: relative;
	z-index: 1;
	width: min(920px, calc(100% - 40px));
	margin: 0 auto;
	padding: 18vh 0 12vh;
}

.ak-hero-content p {
	max-width: 680px;
	font-size: clamp(1rem, 1.35vw, 1.22rem);
}

.ak-eyebrow {
	margin: 0 0 18px;
	color: var(--ak-primary);
	font-size: clamp(0.76rem, 0.72vw, 0.82rem);
	font-weight: 700;
	line-height: 1.35;
	text-transform: uppercase;
	letter-spacing: 0.14em;
}

.ak-hero .ak-eyebrow,
.ak-detail-hero .ak-eyebrow {
	color: #d8b879;
}

.ak-actions {
	display: flex;
	align-items: center;
	gap: 22px;
	flex-wrap: wrap;
	margin-top: 34px;
}

.ak-button,
.ak-contact-form button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 0 24px;
	border: 1px solid var(--ak-primary);
	background: var(--ak-primary);
	color: #fff;
	font-size: clamp(0.78rem, 0.72vw, 0.86rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	cursor: pointer;
}

.ak-button-light {
	border-color: #fff;
	background: #fff;
	color: var(--ak-ink);
}

.ak-link {
	border-bottom: 1px solid currentColor;
	color: inherit;
	font-size: clamp(0.78rem, 0.72vw, 0.86rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
}

.ak-section {
	padding: clamp(64px, 8vw, 120px) 0;
}

.ak-page-hero {
	padding: clamp(86px, 12vw, 160px) 0 clamp(44px, 6vw, 80px);
}

.ak-page-hero h1 {
	max-width: 980px;
	font-size: clamp(3rem, 6.8vw, 7.2rem);
}

.ak-page-hero p:not(.ak-eyebrow) {
	max-width: 660px;
	font-size: 1.04rem;
	color: var(--ak-muted);
}

.ak-two-col {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
	gap: clamp(32px, 7vw, 96px);
	align-items: start;
}

.ak-richtext {
	color: var(--ak-muted);
	font-size: clamp(1rem, 1.2vw, 1.13rem);
}

.ak-richtext p + p {
	margin-top: 1.1rem;
}

.ak-section-head {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: 34px;
}

.ak-card-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 18px;
}

.ak-card-grid-3 {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ak-card {
	min-height: 230px;
	padding: clamp(22px, 3vw, 34px);
	border: 1px solid var(--ak-line);
	background: #fffdf9;
}

.ak-card a {
	display: grid;
	height: 100%;
	align-content: start;
}

.ak-card p {
	color: var(--ak-muted);
}

.ak-card img {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	margin-bottom: 20px;
}

.ak-project-feature-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: clamp(18px, 3vw, 34px);
}

.ak-project-card {
	background: #fffdf9;
}

.ak-project-card figure {
	margin: 0;
	background: var(--ak-panel);
	overflow: hidden;
}

.ak-project-card img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.ak-project-card a:hover img {
	transform: scale(1.035);
}

.ak-project-card div {
	padding: 22px 0 0;
}

.ak-project-card p:last-child {
	color: var(--ak-muted);
}

.ak-detail-hero {
	display: grid;
	grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
	min-height: calc(100vh - 78px);
	background: var(--ak-primary-deep);
	color: #fffaf2;
}

.ak-detail-copy {
	display: grid;
	align-content: end;
	padding: clamp(40px, 6vw, 84px);
}

.ak-detail-copy h1 {
	font-size: clamp(3.25rem, 7.2vw, 7.8rem);
}

.ak-detail-copy p:not(.ak-eyebrow) {
	max-width: 620px;
	color: #e5d8c8;
}

.ak-detail-hero figure {
	margin: 0;
	min-height: 520px;
}

.ak-detail-hero img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ak-project-meta {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1px;
	background: var(--ak-line);
	margin-top: 1px;
}

.ak-project-meta div {
	padding: 22px;
	background: var(--ak-bg);
}

.ak-project-meta span {
	display: block;
	margin-bottom: 6px;
	color: var(--ak-muted);
	font-size: clamp(0.76rem, 0.72vw, 0.82rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
}

.ak-project-meta strong {
	font-weight: 600;
}

.ak-project-narrative {
	max-width: 860px;
}

.ak-gallery {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
	padding-top: 0;
}

.ak-gallery figure {
	margin: 0;
	background: var(--ak-panel);
	overflow: hidden;
}

.ak-gallery img {
	width: 100%;
	height: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
}

.ak-gallery-wide {
	grid-column: span 2;
}

.ak-gallery-wide img {
	aspect-ratio: 16 / 10;
}

.ak-capability-list {
	display: grid;
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.ak-capability-list li {
	padding: 16px 18px;
	border-left: 3px solid var(--ak-accent);
	background: #fffdf9;
}

.ak-statement {
	padding: clamp(24px, 4vw, 42px);
	background: var(--ak-primary);
	color: #fff;
	font-family: var(--ak-font-display);
	font-size: clamp(1.7rem, 2.8vw, 2.8rem);
	font-weight: 500;
	line-height: 1.08;
}

.ak-contact-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
	gap: clamp(24px, 5vw, 70px);
	padding-top: 0;
}

.ak-contact-panel,
.ak-form-panel,
.ak-empty-state {
	padding: clamp(24px, 4vw, 42px);
	background: #fffdf9;
	border: 1px solid var(--ak-line);
}

.ak-contact-panel address {
	font-style: normal;
	color: var(--ak-muted);
}

.ak-contact-form {
	display: grid;
	gap: 16px;
}

.ak-contact-form label {
	display: grid;
	gap: 7px;
	color: var(--ak-muted);
	font-size: clamp(0.78rem, 0.72vw, 0.86rem);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.13em;
}

.ak-contact-form input,
.ak-contact-form select,
.ak-contact-form textarea {
	width: 100%;
	border: 1px solid var(--ak-line);
	background: var(--ak-bg);
	padding: 13px 14px;
	color: var(--ak-ink);
	font: inherit;
}

.ak-contact-form textarea {
	resize: vertical;
}

.ak-check {
	grid-template-columns: auto 1fr !important;
	align-items: start;
	text-transform: none !important;
	letter-spacing: 0 !important;
	font-weight: 500 !important;
}

.ak-check input {
	width: auto;
	margin-top: 5px;
}

.ak-notice {
	margin-bottom: 20px;
	padding: 14px 16px;
	background: #edf4e9;
	border: 1px solid #c9dfbf;
}

.ak-notice-error {
	background: #f8ece9;
	border-color: #e1bcb3;
}

.ak-map-section {
	padding-bottom: clamp(64px, 8vw, 110px);
}

.map-embed iframe {
	display: block;
}

.map-link {
	padding: 28px;
	background: var(--ak-panel);
}

.ak-site-footer {
	padding: clamp(28px, 4vw, 56px);
	background: var(--ak-primary-deep);
	color: #fffaf2;
}

.ak-footer-cta {
	display: flex;
	align-items: end;
	justify-content: space-between;
	gap: 28px;
	width: min(var(--ak-max), 100%);
	margin: 0 auto;
	padding-bottom: 42px;
	border-bottom: 1px solid rgba(255, 255, 255, 0.18);
}

.ak-footer-cta h2 {
	max-width: 760px;
	font-size: clamp(2.3rem, 4.4vw, 5.1rem);
}

.ak-footer-cta p:not(.ak-eyebrow) {
	max-width: 620px;
	color: #d8d0c5;
}

.ak-footer-meta {
	display: flex;
	justify-content: space-between;
	gap: 20px;
	width: min(var(--ak-max), 100%);
	margin: 24px auto 0;
	color: #d8d0c5;
}

@media (max-width: 840px) {
	.ak-menu-toggle {
		display: block;
	}

	.ak-primary-nav {
		position: absolute;
		top: 100%;
		left: 0;
		right: 0;
		display: none;
		flex-direction: column;
		align-items: stretch;
		padding: 18px 20px 24px;
		background: var(--ak-bg);
		border-bottom: 1px solid var(--ak-line);
	}

	.ak-primary-nav.is-open {
		display: flex;
	}

	.ak-hero {
		min-height: 760px;
	}

	.ak-two-col,
	.ak-detail-hero,
	.ak-contact-grid,
	.ak-project-feature-grid,
	.ak-card-grid,
	.ak-card-grid-3 {
		grid-template-columns: 1fr;
	}

	.ak-detail-hero {
		min-height: auto;
	}

	.ak-detail-copy {
		min-height: 420px;
	}

	.ak-detail-hero figure {
		min-height: 360px;
	}

	.ak-project-meta {
		grid-template-columns: 1fr;
	}

	.ak-gallery {
		grid-template-columns: 1fr 1fr;
	}

	.ak-gallery-wide {
		grid-column: span 2;
	}

	.ak-footer-cta,
	.ak-footer-meta {
		display: grid;
	}
}

@media (max-width: 560px) {
	.ak-container {
		width: min(var(--ak-max), calc(100% - 28px));
	}

	.ak-hero-content {
		width: calc(100% - 28px);
		padding-bottom: 80px;
	}

	.ak-section-head {
		display: grid;
		align-items: start;
	}

	.ak-gallery,
	.ak-gallery-wide {
		grid-template-columns: 1fr;
		grid-column: span 1;
	}

	.ak-card,
	.ak-contact-panel,
	.ak-form-panel,
	.ak-empty-state {
		padding: 22px;
	}
}

/* Frontend polish layer */
html {
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}

::selection {
	background: rgba(184, 148, 88, 0.28);
	color: var(--ak-ink);
}

:focus-visible {
	outline: 2px solid var(--ak-accent);
	outline-offset: 4px;
}

body {
	background:
		linear-gradient(180deg, rgba(255, 253, 249, 0.92), rgba(250, 247, 239, 0.96) 38%, rgba(250, 247, 239, 1)),
		var(--ak-bg);
}

.ak-site-header {
	box-shadow: 0 16px 48px rgba(22, 36, 30, 0.06);
	transition: padding 0.24s ease, background-color 0.24s ease, box-shadow 0.24s ease;
}

.ak-site-header.is-scrolled {
	padding-block: 12px;
	background: rgba(251, 250, 247, 0.97);
	box-shadow: 0 18px 58px rgba(22, 36, 30, 0.1);
}

.ak-brand .custom-logo {
	max-width: clamp(132px, 14vw, 210px);
	max-height: 46px;
	transition: transform 0.24s ease;
}

.ak-brand:hover .custom-logo {
	transform: translateY(-1px);
}

.ak-primary-nav a {
	position: relative;
	padding-block: 8px;
	transition: color 0.22s ease;
}

.ak-primary-nav a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 2px;
	height: 1px;
	background: currentColor;
	transform: scaleX(0);
	transform-origin: right;
	transition: transform 0.26s ease;
}

.ak-primary-nav a:hover::after,
.ak-primary-nav a:focus-visible::after {
	transform: scaleX(1);
	transform-origin: left;
}

.ak-hero {
	min-height: min(880px, calc(100vh - 70px));
	isolation: isolate;
}

.ak-hero::before {
	content: "";
	position: absolute;
	inset: auto clamp(20px, 4vw, 56px) 32px;
	z-index: 1;
	height: 1px;
	background: linear-gradient(90deg, rgba(255, 250, 242, 0.42), rgba(255, 250, 242, 0));
}

.ak-hero::after {
	background:
		radial-gradient(circle at 18% 70%, rgba(184, 148, 88, 0.18), transparent 30%),
		linear-gradient(90deg, rgba(18, 31, 25, 0.9), rgba(18, 31, 25, 0.34) 56%, rgba(18, 31, 25, 0.72));
}

.ak-hero-media img {
	transform: scale(1.02);
	filter: saturate(0.92) contrast(1.04);
}

.ak-hero-content {
	width: min(980px, calc(100% - 40px));
	padding-bottom: clamp(86px, 12vh, 132px);
}

.ak-hero-content h1 {
	max-width: 940px;
	text-wrap: balance;
}

.ak-hero-content p:not(.ak-eyebrow) {
	margin-top: 22px;
	color: rgba(255, 250, 242, 0.86);
	line-height: 1.78;
}

.ak-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 12px;
}

.ak-eyebrow::before {
	content: "";
	width: 32px;
	height: 1px;
	background: currentColor;
	opacity: 0.72;
}

.ak-section {
	position: relative;
}

.ak-section + .ak-section {
	padding-top: clamp(46px, 7vw, 96px);
}

.ak-page-hero {
	position: relative;
}

.ak-page-hero::after {
	content: "";
	display: block;
	width: min(220px, 44vw);
	height: 1px;
	margin-top: clamp(30px, 5vw, 54px);
	background: var(--ak-line);
}

.ak-page-hero h1,
.ak-section-head h2,
.ak-two-col h2 {
	text-wrap: balance;
}

.ak-section-head {
	margin-bottom: clamp(28px, 4vw, 54px);
	padding-bottom: 18px;
	border-bottom: 1px solid rgba(217, 208, 192, 0.8);
}

.ak-two-col {
	align-items: center;
}

.ak-richtext {
	line-height: 1.9;
}

.ak-card,
.ak-contact-panel,
.ak-form-panel,
.ak-empty-state {
	position: relative;
	border-color: rgba(217, 208, 192, 0.82);
	box-shadow: 0 18px 70px rgba(22, 36, 30, 0.045);
	transition: transform 0.26s ease, box-shadow 0.26s ease, border-color 0.26s ease, background-color 0.26s ease;
}

.ak-card::before,
.ak-contact-panel::before,
.ak-form-panel::before {
	content: "";
	position: absolute;
	inset: 0;
	border-top: 2px solid transparent;
	pointer-events: none;
	transition: border-color 0.26s ease;
}

.ak-card:hover,
.ak-card:focus-within,
.ak-contact-panel:hover,
.ak-form-panel:focus-within {
	transform: translateY(-4px);
	border-color: rgba(184, 148, 88, 0.5);
	box-shadow: 0 28px 86px rgba(22, 36, 30, 0.095);
}

.ak-card:hover::before,
.ak-card:focus-within::before,
.ak-contact-panel:hover::before,
.ak-form-panel:focus-within::before {
	border-color: var(--ak-accent);
}

.ak-card h3 {
	margin-bottom: 16px;
}

.ak-card p {
	font-size: clamp(0.98rem, 0.95vw, 1.06rem);
	line-height: 1.82;
}

.ak-project-feature-grid {
	align-items: start;
}

.ak-project-card {
	position: relative;
	border-bottom: 1px solid rgba(217, 208, 192, 0.85);
	transition: transform 0.28s ease;
}

.ak-project-card:hover,
.ak-project-card:focus-within {
	transform: translateY(-5px);
}

.ak-project-card figure {
	position: relative;
	aspect-ratio: 4 / 3;
	display: grid;
	place-items: center;
}

.ak-project-card figure:empty::before {
	content: "Image forthcoming";
	color: rgba(103, 95, 84, 0.72);
	font-family: var(--ak-font-display);
	font-size: clamp(1.35rem, 2.2vw, 2.35rem);
}

.ak-project-card figure:empty::after {
	content: "";
	position: absolute;
	inset: 18px;
	border: 1px solid rgba(184, 148, 88, 0.38);
}

.ak-project-card div {
	padding: clamp(16px, 1.8vw, 22px) 4px 10px;
}

.ak-project-card h2,
.ak-project-card h3 {
	font-size: clamp(1.7rem, 2vw, 2.18rem);
	line-height: 1.06;
	transition: color 0.22s ease;
}

.ak-project-card .ak-eyebrow {
	margin-bottom: 14px;
}

.ak-project-card p:last-child {
	margin-bottom: 0;
	font-size: clamp(1rem, 1.05vw, 1.12rem);
	line-height: 1.45;
}

.ak-project-card a:hover h2,
.ak-project-card a:hover h3 {
	color: var(--ak-primary);
}

.ak-button,
.ak-contact-form button {
	position: relative;
	overflow: hidden;
	border-radius: 999px;
	box-shadow: 0 12px 32px rgba(22, 36, 30, 0.16);
	transition: transform 0.22s ease, box-shadow 0.22s ease, background-color 0.22s ease, border-color 0.22s ease;
}

.ak-button::after,
.ak-contact-form button::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.22), transparent);
	transform: translateX(-130%);
	transition: transform 0.55s ease;
}

.ak-button:hover,
.ak-contact-form button:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 44px rgba(22, 36, 30, 0.22);
}

.ak-button:hover::after,
.ak-contact-form button:hover::after {
	transform: translateX(130%);
}

.ak-link {
	transition: color 0.22s ease, opacity 0.22s ease;
}

.ak-detail-hero {
	position: relative;
	overflow: hidden;
}

.ak-detail-hero figure {
	position: relative;
}

.ak-detail-hero figure::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent, rgba(22, 36, 30, 0.18));
	pointer-events: none;
}

.ak-project-meta {
	position: relative;
	z-index: 2;
	margin-top: -1px;
	box-shadow: 0 18px 58px rgba(22, 36, 30, 0.06);
}

.ak-project-meta div {
	min-height: 112px;
}

.ak-gallery {
	gap: clamp(10px, 1.6vw, 20px);
}

.ak-gallery figure {
	border: 1px solid rgba(217, 208, 192, 0.55);
}

.ak-gallery img {
	transition: transform 0.7s ease, filter 0.7s ease;
}

.ak-gallery figure:hover img {
	transform: scale(1.035);
	filter: saturate(1.04);
}

.ak-statement {
	box-shadow: 0 24px 76px rgba(22, 36, 30, 0.14);
}

.ak-people-grid {
	display: grid;
	gap: clamp(22px, 4vw, 44px);
}

.ak-person-card {
	display: grid;
	grid-template-columns: minmax(260px, 0.72fr) minmax(0, 1.28fr);
	gap: clamp(24px, 5vw, 70px);
	align-items: end;
	padding: clamp(22px, 4vw, 44px);
	border: 1px solid rgba(217, 208, 192, 0.82);
	background: #fffdf9;
	box-shadow: 0 24px 78px rgba(22, 36, 30, 0.07);
}

.ak-person-card-no-image {
	grid-template-columns: minmax(0, 1fr);
	max-width: 880px;
}

.ak-person-card figure {
	margin: 0;
	background: var(--ak-panel);
	overflow: hidden;
}

.ak-person-card img {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
}

.ak-person-card h3 {
	margin-bottom: 18px;
	font-size: clamp(2.35rem, 4.2vw, 4.35rem);
}

.ak-person-card p:not(.ak-eyebrow) {
	max-width: 680px;
	color: var(--ak-muted);
	font-size: clamp(1rem, 1.16vw, 1.1rem);
	line-height: 1.88;
}

.ak-person-card .ak-link {
	display: inline-flex;
	margin-top: 12px;
}

.ak-contact-panel h2,
.ak-form-panel h2 {
	margin-bottom: 18px;
}

.ak-contact-panel a {
	color: var(--ak-primary);
	font-weight: 700;
}

.ak-contact-form input,
.ak-contact-form select,
.ak-contact-form textarea {
	border-radius: 0;
	transition: border-color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
}

.ak-contact-form input:focus,
.ak-contact-form select:focus,
.ak-contact-form textarea:focus {
	border-color: var(--ak-accent);
	background: #fffdf9;
	box-shadow: 0 0 0 3px rgba(184, 148, 88, 0.14);
	outline: none;
}

.ak-site-footer {
	position: relative;
	overflow: hidden;
}

.ak-site-footer::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(184, 148, 88, 0.12), transparent 36%),
		linear-gradient(0deg, rgba(255, 250, 242, 0.04), transparent);
	pointer-events: none;
}

.ak-footer-cta,
.ak-footer-meta {
	position: relative;
}

.ak-reveal {
	opacity: 0;
	transform: translateY(22px);
	transition: opacity 0.65s ease, transform 0.65s ease;
}

.ak-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		scroll-behavior: auto !important;
		transition-duration: 0.001ms !important;
	}

	.ak-reveal {
		opacity: 1;
		transform: none;
	}
}

@media (max-width: 840px) {
	.ak-site-header {
		padding-block: 14px;
	}

	.ak-brand .custom-logo {
		max-width: 138px;
		max-height: 38px;
	}

	.ak-primary-nav {
		gap: 0;
		box-shadow: 0 24px 58px rgba(22, 36, 30, 0.1);
	}

	.ak-primary-nav a {
		padding: 14px 2px;
		border-bottom: 1px solid rgba(217, 208, 192, 0.7);
	}

	.ak-hero {
		min-height: 720px;
	}

	.ak-hero::after {
		background: linear-gradient(180deg, rgba(18, 31, 25, 0.44), rgba(18, 31, 25, 0.9));
	}

	.ak-section-head {
		display: grid;
		align-items: start;
	}

	.ak-person-card {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 560px) {
	h1 {
		font-size: clamp(3rem, 15vw, 4.7rem);
	}

	h2 {
		font-size: clamp(2.25rem, 10vw, 3.35rem);
	}

	h3 {
		font-size: clamp(1.65rem, 8vw, 2.35rem);
	}

	body {
		font-size: 15.5px;
		line-height: 1.72;
	}

	.ak-site-header {
		gap: 14px;
	}

	.ak-hero {
		min-height: 680px;
	}

	.ak-hero-content {
		padding-top: 120px;
		padding-bottom: 76px;
	}

	.ak-actions {
		align-items: stretch;
		gap: 16px;
	}

	.ak-actions .ak-button {
		width: 100%;
	}

	.ak-card,
	.ak-contact-panel,
	.ak-form-panel,
	.ak-empty-state {
		box-shadow: 0 14px 42px rgba(22, 36, 30, 0.055);
	}

	.ak-project-card:hover,
	.ak-card:hover,
	.ak-card:focus-within,
	.ak-contact-panel:hover,
	.ak-form-panel:focus-within {
		transform: none;
	}
}
