/**
 * KG Instructional Design Theme — Main Stylesheet
 * Premium instructional design portfolio — Olive Garden Feast palette
 */

:root {
	/* Olive Garden Feast — Coolors palette */
	--color-olive: #606c38;
	--color-forest: #283618;
	--color-cream: #fefae0;
	--color-tan: #d4a373;
	--color-terracotta: #bc6c25;
	--color-terracotta-hover: #a35a1f;

	--color-bg: #ffffff;
	--color-bg-subtle: #f7f7f5;
	--color-bg-muted: #f0f0ec;
	--color-bg-dark: var(--color-forest);
	--color-surface: #ffffff;
	--color-blue: var(--color-olive);
	--color-blue-dark: #4a5530;
	--color-orange: var(--color-terracotta);
	--color-orange-hover: var(--color-terracotta-hover);
	--color-text: var(--color-forest);
	--color-text-muted: #4a5530;
	--color-text-light: var(--color-olive);
	--color-border: #e6e2da;
	--color-accent: var(--color-terracotta);
	--color-accent-hover: var(--color-terracotta-hover);
	--font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--font-serif: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--container-width: 1180px;
	--container-narrow: 720px;
	--section-padding: clamp(4rem, 8vw, 6.5rem);
	--header-height: 72px;
	--radius: 2px;
	--radius-pill: 999px;
	--shadow-sm: 0 4px 20px rgba(0, 0, 0, 0.06);
	--shadow-md: 0 16px 40px rgba(0, 0, 0, 0.1);
	--shadow-card: 0 10px 30px rgba(0, 0, 0, 0.08);
	--transition: 0.3s ease;
}

*, *::before, *::after { box-sizing: border-box; }

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.75;
	color: var(--color-text);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.kg-homepage .site-main {
	overflow-x: hidden;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: inherit;
	text-decoration: none;
	transition: color var(--transition), opacity var(--transition), transform var(--transition);
	-webkit-tap-highlight-color: transparent;
}

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
	outline: 2px solid var(--color-orange);
	outline-offset: 3px;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-sans);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1rem;
	letter-spacing: -0.01em;
}

p { margin: 0 0 1.25rem; }

ul, ol { margin: 0 0 1.25rem; padding-left: 1.25rem; }

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

.screen-reader-text:focus {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100000;
	width: auto;
	height: auto;
	padding: 1rem 1.5rem;
	margin: 0;
	overflow: visible;
	clip: auto;
	background: var(--color-bg-dark);
	color: #fff;
}

/* Layout */
.container {
	width: 100%;
	max-width: var(--container-width);
	margin: 0 auto;
	padding: 0 clamp(1.5rem, 5vw, 3rem);
}

.container--narrow { max-width: var(--container-narrow); }

.section { padding: var(--section-padding) 0; }
.section--gray { background: var(--color-bg-subtle); }
.section--cta { text-align: center; }

.section__cta { margin-top: 3rem; text-align: center; }
.section__cta--left { text-align: left; }

/* Section labels — large editorial headings */
.section-label {
	font-family: var(--font-sans);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	line-height: 1.15;
	margin: 0 0 1rem;
	color: var(--color-text);
}

.section-label--center { text-align: center; }

.section-header { margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-header--center { text-align: center; }
.section-header--left { text-align: left; }

.section-header__title {
	font-size: clamp(2rem, 4vw, 2.75rem);
	margin-bottom: 0.75rem;
}

.section-header__subtitle {
	font-size: 1.0625rem;
	color: var(--color-text-muted);
	max-width: 34rem;
	margin: 0;
	line-height: 1.8;
}

.section-header--center .section-header__subtitle { margin: 0 auto; }

.text-link {
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-text);
	padding-bottom: 2px;
}

.text-link:hover {
	color: var(--color-text-muted);
	border-color: var(--color-text-muted);
}

/* Scroll reveal */
.reveal {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.7s var(--transition), transform 0.7s var(--transition);
}

.reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Header — robertgid style */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: var(--color-surface);
	border-bottom: 1px solid var(--color-border);
	transition: box-shadow var(--transition);
}

.site-header.is-scrolled {
	box-shadow: var(--shadow-sm);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: var(--header-height);
	gap: 2rem;
}

.site-logo {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
}

.site-logo__mark {
	display: block;
	width: 28px;
	height: 28px;
	background: var(--color-orange);
	flex-shrink: 0;
}

.site-logo__text-wrap {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.site-logo__text {
	font-family: var(--font-sans);
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--color-text);
	line-height: 1.2;
}

.site-logo__subtitle {
	font-size: 0.6875rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
}

.custom-logo-link {
	display: inline-flex;
	align-items: center;
}

.custom-logo-link img {
	max-height: 42px;
	width: auto;
}

.site-branding__text { display: none; }

.site-nav__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.25rem 1.75rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-nav__list a {
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-text);
	padding: 0.25rem 0;
	transition: color var(--transition);
}

.site-nav__list a:hover,
.site-nav__list a.is-active,
.site-nav__list .current-menu-item > a,
.site-nav__list .current_page_item > a,
.site-nav__list .current-menu-ancestor > a {
	color: var(--color-orange);
}

.site-nav__list a.is-active {
	font-weight: 600;
}

.site-nav__list a::after { display: none; }

.nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 44px;
	height: 44px;
	padding: 0;
	border: none;
	background: transparent;
	cursor: pointer;
}

.nav-toggle__bar {
	display: block;
	width: 22px;
	height: 1.5px;
	background: var(--color-text);
	transition: transform var(--transition), opacity var(--transition);
}

@media (max-width: 900px) {
	.nav-toggle { display: flex; z-index: 1002; }

	.site-nav {
		position: fixed;
		top: var(--header-height);
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 1001;
		background: var(--color-bg);
		border-bottom: 1px solid var(--color-border);
		padding: 1rem max(1.5rem, env(safe-area-inset-right)) max(2rem, env(safe-area-inset-bottom)) max(1.5rem, env(safe-area-inset-left));
		max-height: calc(100vh - var(--header-height));
		max-height: calc(100dvh - var(--header-height));
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		transform: translateY(-110%);
		opacity: 0;
		visibility: hidden;
		transition: transform var(--transition), opacity var(--transition), visibility var(--transition);
		box-shadow: var(--shadow-md);
	}

	.site-nav.is-open {
		transform: translateY(0);
		opacity: 1;
		visibility: visible;
	}

	.site-nav__list {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
	}

	.site-nav__list li {
		border-bottom: 1px solid var(--color-border);
	}

	.site-nav__list li:last-child {
		border-bottom: none;
	}

	.site-nav__list a {
		display: block;
		padding: 1rem 0.25rem;
		font-size: 0.875rem;
		min-height: 48px;
		line-height: 1.4;
	}

	.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
	.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; }
	.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
}

.nav-backdrop {
	display: none;
	position: fixed;
	inset: 0;
	top: var(--header-height);
	z-index: 1000;
	border: none;
	padding: 0;
	margin: 0;
	background: rgba(40, 54, 24, 0.5);
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--transition), visibility var(--transition);
}

.nav-backdrop.is-visible {
	display: block;
	opacity: 1;
	visibility: visible;
}

body.nav-open {
	overflow: hidden;
}

/* Hero — robertgid split layout */
.hero--split {
	position: relative;
	padding: 2.5rem 0 4.5rem;
	overflow: hidden;
}

.hero__blue-block {
	position: absolute;
	top: 0;
	left: 0;
	width: min(46vw, 520px);
	height: clamp(280px, 42vw, 420px);
	background: var(--color-blue);
	z-index: 0;
}

.hero__layout {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(260px, 300px) 1fr;
	align-items: center;
	gap: clamp(2rem, 6vw, 5rem);
	min-height: clamp(360px, 38vw, 440px);
}

.hero__card {
	background: var(--color-cream);
	padding: 2.75rem 2rem 2.5rem;
	box-shadow: var(--shadow-card);
	text-align: center;
	max-width: 300px;
	width: 100%;
	margin-left: clamp(0px, 4vw, 48px);
}

.hero__photo {
	width: 148px;
	height: 148px;
	margin: 0 auto 1.75rem;
	border-radius: 50%;
	overflow: hidden;
	background: var(--color-surface);
	border: 4px solid var(--color-surface);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.hero__photo-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero__photo-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-blue);
	background: #e8ead9;
}

.hero__card-name {
	font-size: 1.375rem;
	font-weight: 700;
	margin: 0 0 1rem;
	color: var(--color-text);
}

.hero__card-line {
	display: block;
	width: 42px;
	height: 3px;
	margin: 0 auto 1rem;
	background: var(--color-orange);
}

.hero__pitch {
	padding-right: clamp(0px, 4vw, 2rem);
}

.hero__headline {
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-weight: 700;
	line-height: 1.15;
	margin: 0 0 1.25rem;
	color: var(--color-text);
}

.hero__subtitle {
	font-size: clamp(1rem, 1.8vw, 1.25rem);
	font-weight: 400;
	line-height: 1.65;
	color: var(--color-text-muted);
	max-width: 34rem;
	margin: 0 0 2rem;
}

.hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: center;
}

.hero__card-role {
	font-size: 0.6875rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--color-text-muted);
	margin: 0;
	max-width: 240px;
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 900px) {
	.hero__blue-block {
		width: 100%;
		height: 220px;
	}

	.hero__layout {
		grid-template-columns: 1fr;
		gap: 2rem;
		min-height: auto;
		padding-top: 180px;
	}

	.hero__card {
		margin: 0 auto;
		max-width: 320px;
	}

	.hero__pitch {
		text-align: center;
		padding-right: 0;
	}

	.hero__subtitle {
		margin-left: auto;
		margin-right: auto;
	}

	.hero__actions {
		justify-content: center;
	}
}

@media (max-width: 480px) {
	.hero--split {
		padding-bottom: 3rem;
	}

	.hero__card {
		padding: 2rem 1.5rem;
	}
}

/* Legacy hero (other pages) */
.hero {
	padding: clamp(4rem, 8vw, 6rem) 0;
}

.hero--home:not(.hero--split) { text-align: center; }

/* Buttons */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 1rem 2.25rem;
	font-family: var(--font-sans);
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	border: 1px solid transparent;
	border-radius: var(--radius);
	cursor: pointer;
	transition: background var(--transition), color var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.btn:hover { transform: translateY(-2px); }

.btn--primary {
	background: var(--color-orange);
	color: #fff;
	border-color: var(--color-orange);
}

.btn--primary:hover {
	background: var(--color-orange-hover);
	border-color: var(--color-orange-hover);
	color: #fff;
	box-shadow: var(--shadow-sm);
}

.btn--orange {
	background: var(--color-orange);
	color: #fff;
	border-color: var(--color-orange);
}

.btn--orange:hover {
	background: var(--color-orange-hover);
	border-color: var(--color-orange-hover);
	color: #fff;
}

.btn--pill {
	border-radius: var(--radius-pill);
	padding: 0.9375rem 2.5rem;
	font-size: 0.75rem;
	letter-spacing: 0.12em;
}

.btn--outline,
.btn--ghost {
	background: transparent;
	color: var(--color-text);
	border-color: var(--color-border);
}

.btn--outline:hover,
.btn--ghost:hover {
	border-color: var(--color-text);
	color: var(--color-text);
}

.btn--light { background: var(--color-surface); color: var(--color-text); }
.btn--sm { padding: 0.625rem 1.25rem; font-size: 0.6875rem; }

/* About Me section */
.section--about-me {
	position: relative;
	overflow: hidden;
	background: var(--color-bg);
}

.about-me__wash {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(96, 108, 56, 0.04) 0%, transparent 42%),
		linear-gradient(180deg, #ffffff 0%, #fafafa 100%);
	pointer-events: none;
}

.about-me__wrap {
	position: relative;
	z-index: 1;
}

.about-me__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2.5rem, 6vw, 4rem);
	align-items: center;
}

.about-me__content {
	max-width: 36rem;
}

.about-me__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1.25rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.about-me__eyebrow-line {
	display: block;
	width: 36px;
	height: 2px;
	background: var(--color-terracotta);
	flex-shrink: 0;
}

.about-me__heading {
	font-size: clamp(2rem, 4.5vw, 2.875rem);
	font-weight: 700;
	line-height: 1.1;
	margin: 0 0 1.75rem;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.about-me__intro {
	margin: 0 0 1.75rem;
	padding: 0 0 0 1.375rem;
	border: 0;
	border-left: 3px solid var(--color-terracotta);
	quotes: none;
}

.about-me__intro p {
	margin: 0;
	font-size: clamp(1.125rem, 2.2vw, 1.3125rem);
	font-weight: 500;
	line-height: 1.65;
	color: var(--color-forest);
}

.about-me__body p {
	margin: 0;
	font-size: 1rem;
	line-height: 1.9;
	color: var(--color-text-muted);
}

.about-me__frame {
	position: relative;
	width: min(100%, 400px);
	margin: 0 auto;
}

.about-me__frame-accent {
	position: absolute;
	z-index: 0;
	pointer-events: none;
}

.about-me__frame-accent--tan {
	inset: -14px -14px 18px 18px;
	background: var(--color-tan);
	opacity: 0.45;
}

.about-me__frame-accent--olive {
	bottom: -28px;
	left: -28px;
	width: 48%;
	height: 48%;
	background: var(--color-olive);
	opacity: 0.22;
}

.about-me__figure {
	position: relative;
	z-index: 1;
	margin: 0;
	box-shadow: var(--shadow-card);
	background: var(--color-surface);
}

.about-me__image {
	width: 100%;
	height: auto;
	display: block;
	object-fit: cover;
	aspect-ratio: 4 / 5;
	max-height: 520px;
	border: 6px solid var(--color-surface);
}

.about-me__image-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 360px;
	padding: 2rem;
	background: var(--color-bg-muted);
	border: 6px solid var(--color-surface);
	text-align: center;
	color: var(--color-text-muted);
	font-size: 0.9375rem;
	line-height: 1.6;
	box-shadow: var(--shadow-card);
}

.about-me__content.reveal { transition-delay: 0.05s; }
.about-me__media.reveal { transition-delay: 0.18s; }

@media (min-width: 900px) {
	.about-me__grid {
		grid-template-columns: 1.08fr 0.92fr;
		gap: clamp(3.5rem, 7vw, 6rem);
	}

	.about-me__content {
		padding-right: 1rem;
	}

	.about-me__frame {
		margin: 0 0 0 auto;
		width: min(100%, 420px);
	}
}

@media (max-width: 640px) {
	.about-me__intro {
		padding-left: 1rem;
	}

	.about-me__frame-accent--olive {
		bottom: -18px;
		left: -18px;
		width: 42%;
		height: 42%;
	}
}


/* Portfolio grid */
.portfolio-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2.5rem, 5vw, 4rem);
}

.portfolio-grid--home {
	max-width: 960px;
}

@media (min-width: 768px) {
	.portfolio-grid:not(.portfolio-grid--home) {
		grid-template-columns: repeat(2, 1fr);
		gap: 2rem;
	}
}

@media (min-width: 1024px) {
	.portfolio-grid:not(.portfolio-grid--home) {
		grid-template-columns: repeat(3, 1fr);
	}
}

.portfolio-card { opacity: 1; transition: opacity var(--transition); }
.portfolio-card.is-hidden { display: none; }

.portfolio-card__link { display: block; height: 100%; }

.portfolio-card__media {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius);
	background: var(--color-bg-muted);
	aspect-ratio: 16 / 10;
}

.portfolio-grid--home .portfolio-card__media { aspect-ratio: 16 / 9; }

.portfolio-card__image,
.portfolio-card__placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.portfolio-card__placeholder {
	background: linear-gradient(145deg, #f0f0ec 0%, #f7f7f5 100%);
}

.portfolio-card__overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(20, 20, 24, 0.5);
	opacity: 0;
	transition: opacity var(--transition);
}

.portfolio-card:hover .portfolio-card__image { transform: scale(1.04); }
.portfolio-card:hover .portfolio-card__overlay { opacity: 1; }

.portfolio-card__body { padding: 1.75rem 0 0; }

.portfolio-card__category {
	display: inline-block;
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-text-light);
	margin-bottom: 0.625rem;
}

.portfolio-card__title {
	font-family: var(--font-serif);
	font-size: clamp(1.375rem, 2.5vw, 1.75rem);
	margin-bottom: 0.625rem;
	transition: color var(--transition);
}

.portfolio-card:hover .portfolio-card__title { color: var(--color-text-muted); }

.portfolio-card__excerpt {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	margin: 0;
	line-height: 1.7;
	max-width: 52ch;
}

/* Portfolio filters */
.portfolio-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	justify-content: center;
	margin-bottom: 3.5rem;
}

.portfolio-filter {
	padding: 0.625rem 1.375rem;
	font-family: var(--font-sans);
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-muted);
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	cursor: pointer;
	transition: all var(--transition);
}

.portfolio-filter:hover,
.portfolio-filter.is-active {
	background: var(--color-orange);
	border-color: var(--color-orange);
	color: #fff;
}

/* Services */
.services-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.services-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
	.services-grid--detailed { grid-template-columns: repeat(2, 1fr); }
}

.service-card {
	padding: 2rem 2rem 2.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	transition: box-shadow var(--transition), transform var(--transition), border-color var(--transition);
}

.section--gray .service-card { background: var(--color-surface); }

.service-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-6px);
	border-color: transparent;
}

.service-card__title {
	font-size: 1.25rem;
	margin-bottom: 0.875rem;
}

.service-card__text {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	margin: 0;
	line-height: 1.75;
}

.service-card--detailed { padding: 2.5rem; }
.service-card--detailed .service-card__title { font-size: 1.5rem; }

/* Testimonials carousel */
.section--testimonials-carousel {
	background: linear-gradient(180deg, rgba(247, 247, 245, 0.95) 0%, #ffffff 100%);
}

.testimonials-carousel__header {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: clamp(2rem, 4vw, 2.75rem);
}

.testimonials-carousel__eyebrow {
	margin: 0 0 0.65rem;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-olive);
}

.testimonials-carousel__heading {
	margin: 0;
	font-size: clamp(1.875rem, 3.5vw, 2.625rem);
	font-weight: 700;
	line-height: 1.15;
	color: var(--color-forest);
	letter-spacing: -0.02em;
}

.testimonials-carousel__nav {
	display: flex;
	gap: 0.75rem;
	flex-shrink: 0;
}

.testimonials-carousel__btn {
	display: grid;
	place-items: center;
	width: 46px;
	height: 46px;
	border: 1px solid var(--color-border);
	border-radius: 12px;
	background: #fff;
	color: var(--color-forest);
	box-shadow: 0 8px 20px rgba(40, 54, 24, 0.06);
	transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.testimonials-carousel__btn svg {
	width: 18px;
	height: 18px;
}

.testimonials-carousel__btn:hover:not(:disabled) {
	transform: translateY(-1px);
	border-color: rgba(96, 108, 56, 0.35);
	color: var(--color-olive);
}

.testimonials-carousel__btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
}

.testimonials-carousel__viewport {
	overflow: hidden;
}

.testimonials-carousel__track {
	display: flex;
	gap: 1.5rem;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 0.35rem;
	scrollbar-width: none;
}

.testimonials-carousel__track::-webkit-scrollbar {
	display: none;
}

.testimonial-slide {
	flex: 0 0 calc(100% - 0.5rem);
	scroll-snap-align: start;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	padding: 1.5rem;
	border: 1px solid rgba(40, 54, 24, 0.06);
	border-radius: calc(var(--radius) + 4px);
	background: #fff;
	box-shadow: 0 16px 40px rgba(40, 54, 24, 0.07);
}

.testimonial-slide__head {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.25rem;
}

.testimonial-slide__avatar {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	border-radius: 14px;
	overflow: hidden;
	background: linear-gradient(145deg, rgba(96, 108, 56, 0.16), rgba(254, 250, 224, 0.95));
	display: grid;
	place-items: center;
}

.testimonial-slide__avatar-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.testimonial-slide__avatar-fallback {
	font-size: 0.9375rem;
	font-weight: 700;
	color: var(--color-forest);
}

.testimonial-slide__name {
	display: block;
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-forest);
	margin-bottom: 0.2rem;
}

.testimonial-slide__role {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.5;
	color: var(--color-text-muted);
}

.testimonial-slide__role-sep {
	margin: 0 0.25rem;
}

.testimonial-slide__company {
	color: var(--color-olive);
	font-weight: 600;
}

.testimonial-slide__quote {
	margin: 0 0 1.5rem;
	flex: 1;
}

.testimonial-slide__quote p {
	margin: 0;
	font-size: 0.96875rem;
	line-height: 1.8;
	color: var(--color-text-muted);
}

.testimonial-slide__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	margin-top: auto;
	padding-top: 1rem;
	border-top: 1px solid rgba(40, 54, 24, 0.06);
}

.testimonial-slide__stars {
	display: inline-flex;
	gap: 0.2rem;
	color: var(--color-terracotta);
}

.testimonial-slide__stars svg {
	width: 16px;
	height: 16px;
}

.testimonial-slide__brand {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	min-width: 0;
}

.testimonial-slide__brand-mark {
	display: grid;
	place-items: center;
	width: 28px;
	height: 28px;
	border-radius: 8px;
	background: rgba(96, 108, 56, 0.1);
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-forest);
	flex-shrink: 0;
}

.testimonial-slide__brand-name {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-forest);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

@media (min-width: 768px) {
	.testimonial-slide {
		flex-basis: calc(50% - 0.75rem);
	}
}

@media (min-width: 1100px) {
	.testimonial-slide {
		flex-basis: calc(33.333% - 1rem);
	}
}

@media (max-width: 767px) {
	.testimonials-carousel__header {
		flex-direction: column;
		align-items: flex-start;
	}

	.testimonials-carousel__nav {
		align-self: flex-end;
	}
}

/* Testimonials legacy grid */
.section--testimonials { background: var(--color-bg); }

.testimonials-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
	max-width: 960px;
	margin: 0 auto;
}

@media (min-width: 900px) {
	.testimonials-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; }
}

.testimonial-card {
	margin: 0;
	padding: 0;
	border: none;
	background: none;
}

.testimonial-card__quote {
	font-family: var(--font-serif);
	font-size: clamp(1rem, 1.8vw, 1.125rem);
	font-style: italic;
	font-weight: 400;
	color: var(--color-text-muted);
	line-height: 1.85;
	margin: 0 0 1.5rem;
}

.testimonial-card__quote::before {
	content: '\201C';
	display: block;
	font-size: 2.5rem;
	line-height: 1;
	color: var(--color-border);
	margin-bottom: 0.75rem;
	font-style: normal;
}

.testimonial-card__author {
	display: block;
	font-family: var(--font-sans);
	font-size: 0.75rem;
	font-style: normal;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text);
}

/* CTA */
.cta-subtext {
	font-size: 1.125rem;
	color: var(--color-text-muted);
	margin-bottom: 2.5rem;
	line-height: 1.8;
}

/* Page templates */
.page-hero {
	padding: clamp(4rem, 8vw, 6rem) 0 2rem;
	text-align: center;
}

.page-title {
	font-size: clamp(2.5rem, 5vw, 3.75rem);
	margin-bottom: 0.75rem;
}

.page-subtitle {
	font-size: 1.0625rem;
	color: var(--color-text-muted);
	max-width: 32rem;
	margin: 0 auto;
}

.entry-content { font-size: 1rem; color: var(--color-text-muted); }
.entry-content h2, .entry-content h3 { color: var(--color-text); margin-top: 2rem; }

.about-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}

@media (min-width: 900px) {
	.about-layout { grid-template-columns: 2fr 1fr; align-items: start; }
}

.info-card {
	padding: 2rem;
	background: var(--color-bg-subtle);
	border-radius: var(--radius);
}

.info-card h3 { font-size: 1.125rem; margin-bottom: 1rem; }
.info-card ul { list-style: none; padding: 0; margin: 0; }

.info-card li {
	padding: 0.625rem 0;
	border-bottom: 1px solid var(--color-border);
	font-size: 0.9375rem;
	color: var(--color-text-muted);
}

.info-card li:last-child { border-bottom: none; }

.process-timeline { display: grid; gap: 0; margin-bottom: 3rem; }

.process-step {
	display: grid;
	grid-template-columns: 4rem 1fr;
	gap: 1.5rem;
	padding: 2.5rem 0;
	border-bottom: 1px solid var(--color-border);
}

.process-step:last-child { border-bottom: none; }

.process-step__number {
	font-family: var(--font-serif);
	font-size: 2rem;
	font-weight: 600;
	color: var(--color-text-light);
	line-height: 1;
}

.process-step__title { font-size: 1.5rem; margin-bottom: 0.5rem; }
.process-step__text { font-size: 0.9375rem; color: var(--color-text-muted); margin: 0; }

.contact-layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}

@media (min-width: 900px) {
	.contact-layout { grid-template-columns: 1fr 1fr; align-items: start; }
}

.contact-layout__info h2 { font-size: 1.75rem; }
.contact-details { margin: 2rem 0; }
.contact-details p { font-size: 0.9375rem; }

.contact-form__notice {
	padding: 1rem 1.25rem;
	margin-bottom: 1.5rem;
	background: var(--color-bg-subtle);
	border-left: 3px solid var(--color-accent);
	font-size: 0.9375rem;
}

.contact-form__hp {
	position: absolute;
	left: -9999px;
	width: 1px;
	height: 1px;
	overflow: hidden;
}

.form-row { display: grid; gap: 1.25rem; margin-bottom: 1.25rem; }

@media (min-width: 600px) {
	.form-row--half { grid-template-columns: 1fr 1fr; }
}

.form-field { margin-bottom: 1.25rem; }

.form-field label {
	display: block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-bottom: 0.5rem;
	color: var(--color-text-muted);
}

.form-field input,
.form-field textarea {
	width: 100%;
	padding: 0.9375rem 1rem;
	font-family: var(--font-sans);
	font-size: 1rem;
	color: var(--color-text);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	transition: border-color var(--transition), box-shadow var(--transition);
}

.form-field input:focus,
.form-field textarea:focus {
	outline: none;
	border-color: var(--color-olive);
	box-shadow: 0 0 0 4px rgba(96, 108, 56, 0.12);
}

.form-field textarea { resize: vertical; min-height: 150px; }

/* Single project */
.project-hero { position: relative; }

.project-hero__banner {
	position: relative;
	max-height: 520px;
	overflow: hidden;
}

.project-hero__image { width: 100%; height: 520px; object-fit: cover; }

.project-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(20, 20, 24, 0.75) 0%, transparent 55%);
}

.project-hero__content {
	position: relative;
	padding: 3rem 0;
	text-align: center;
}

.project-hero__banner + .project-hero__content {
	margin-top: -9rem;
	color: #fff;
	z-index: 1;
}

.project-hero__banner + .project-hero__content .project-hero__excerpt { color: rgba(255, 255, 255, 0.88); }

.project-hero__category {
	display: inline-block;
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	margin-bottom: 1rem;
	opacity: 0.9;
}

.project-hero__title { font-size: clamp(2rem, 5vw, 3.25rem); margin-bottom: 0.75rem; }
.project-hero__excerpt { font-size: 1.0625rem; max-width: 40rem; margin: 0 auto; }

.project-details {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}

@media (min-width: 900px) {
	.project-details { grid-template-columns: 320px 1fr; }
}

.project-details__meta h2 { font-size: 1.5rem; margin-bottom: 1.5rem; }
.detail-list { margin: 0 0 2rem; }

.detail-list__item {
	padding: 1rem 0;
	border-bottom: 1px solid var(--color-border);
}

.detail-list__item:last-child { border-bottom: none; }

.detail-list dt {
	font-size: 0.6875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
	margin-bottom: 0.375rem;
}

.detail-list dd { margin: 0; font-size: 0.9375rem; line-height: 1.65; }

.project-actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }

.storyline-embed {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	background: var(--color-bg-muted);
	border-radius: var(--radius);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}

.storyline-embed iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

/* Footer */
.site-footer {
	position: relative;
	overflow: hidden;
	padding: clamp(4rem, 7vw, 5.5rem) 0 0;
	background: linear-gradient(180deg, #1f2814 0%, #171d10 100%);
	color: rgba(255, 255, 255, 0.72);
}

.site-footer__decor {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}

.site-footer__decor--one {
	top: -120px;
	right: -80px;
	width: 280px;
	height: 280px;
	background: radial-gradient(circle, rgba(96, 108, 56, 0.18) 0%, transparent 70%);
}

.site-footer__decor--two {
	bottom: 80px;
	left: -100px;
	width: 240px;
	height: 240px;
	background: radial-gradient(circle, rgba(188, 108, 37, 0.12) 0%, transparent 70%);
}

.site-footer__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: 1.35fr repeat(3, minmax(0, 1fr));
	gap: clamp(2rem, 4vw, 3rem);
	padding-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.site-footer__brand {
	max-width: 22rem;
}

.site-footer__logo {
	display: inline-flex;
	align-items: center;
	gap: 0.85rem;
	margin-bottom: 1.25rem;
	text-decoration: none;
}

.site-footer__logo-mark {
	display: block;
	width: 42px;
	height: 42px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--color-terracotta), var(--color-olive));
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
	flex-shrink: 0;
}

.site-footer__logo-text {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.site-footer__logo-name {
	font-size: 1.0625rem;
	font-weight: 700;
	line-height: 1.2;
	color: #fff;
}

.site-footer__logo-role {
	font-size: 0.6875rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.58);
}

.site-footer__desc {
	margin: 0 0 1.5rem;
	font-size: 0.9375rem;
	line-height: 1.75;
	color: rgba(255, 255, 255, 0.62);
}

.site-footer__social {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.site-footer__social-link {
	display: grid;
	place-items: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.82);
	transition: transform 0.2s ease, background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.site-footer__social-link svg {
	width: 17px;
	height: 17px;
}

.site-footer__social-link:hover {
	transform: translateY(-2px);
	background: var(--color-terracotta);
	border-color: var(--color-terracotta);
	color: #fff;
}

.site-footer__col-title {
	margin: 0 0 1.25rem;
	font-size: 1.0625rem;
	font-weight: 700;
	color: #fff;
}

.site-footer__links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 0.85rem;
}

.site-footer__links a {
	font-size: 0.9375rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.62);
	text-decoration: none;
	transition: color 0.2s ease, transform 0.2s ease;
}

.site-footer__links a:hover {
	color: var(--color-tan);
}

.site-footer__bottom {
	position: relative;
	z-index: 1;
	padding: 1.35rem 0;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.site-footer__copyright {
	margin: 0;
	font-size: 0.875rem;
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.48);
	text-align: center;
}

.site-footer__copyright-sep {
	margin: 0 0.5rem;
	color: rgba(255, 255, 255, 0.28);
}

.site-footer__developer {
	color: rgba(255, 255, 255, 0.72);
	font-weight: 600;
}

.back-to-top {
	position: fixed;
	right: clamp(1rem, 3vw, 1.75rem);
	bottom: clamp(1rem, 3vw, 1.75rem);
	z-index: 900;
	display: grid;
	place-items: center;
	width: 48px;
	height: 48px;
	border: 0;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-terracotta), #a35a1f);
	color: #fff;
	box-shadow: 0 14px 30px rgba(188, 108, 37, 0.32);
	opacity: 0;
	visibility: hidden;
	transform: translateY(12px);
	transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease, background 0.2s ease;
}

.back-to-top svg {
	width: 20px;
	height: 20px;
}

.back-to-top.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.back-to-top:hover {
	background: linear-gradient(135deg, var(--color-olive), var(--color-forest));
}

@media (max-width: 1024px) {
	.site-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.site-footer__brand {
		grid-column: 1 / -1;
		max-width: none;
	}
}

@media (max-width: 640px) {
	.site-footer__grid {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
}

/* Utilities */
.empty-state {
	text-align: center;
	color: var(--color-text-muted);
	padding: 3rem 2rem;
	background: var(--color-bg-subtle);
	border-radius: var(--radius);
	border: 1px dashed var(--color-border);
}

.navigation.pagination {
	display: flex;
	justify-content: center;
	gap: 0.5rem;
	margin-top: 3rem;
}

.navigation.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.5rem;
	height: 2.5rem;
	padding: 0 0.75rem;
	font-size: 0.875rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius);
	transition: all var(--transition);
}

.navigation.pagination .page-numbers.current,
.navigation.pagination .page-numbers:hover {
	background: var(--color-orange);
	border-color: var(--color-orange);
	color: #fff;
}

.blog-list__item {
	padding: 2rem 0;
	border-bottom: 1px solid var(--color-border);
}

.blog-list__title { font-size: 1.5rem; margin-bottom: 0.5rem; }

/* Offerings — PPT Slide 3 (after About Me) */
.section--offerings {
	background: #ffffff;
}

.offerings-solutions {
	margin-bottom: clamp(3.5rem, 7vw, 5rem);
}

.offerings-solutions__header {
	margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
	max-width: 40rem;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

.offerings-solutions__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.offerings-solutions__eyebrow-line {
	display: block;
	width: 36px;
	height: 2px;
	background: var(--color-terracotta);
	flex-shrink: 0;
}

.offerings-solutions__title {
	font-size: clamp(1.75rem, 3.5vw, 2.375rem);
	font-weight: 700;
	line-height: 1.12;
	margin: 0;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.solutions-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

.solution-card-wrap {
	height: 100%;
	filter: drop-shadow(0 10px 28px rgba(40, 54, 24, 0.07));
	transition: filter var(--transition), transform var(--transition);
}

.solution-card-wrap:hover {
	filter: drop-shadow(0 18px 40px rgba(40, 54, 24, 0.12));
	transform: translateY(-8px);
}

.solution-card-wrap.reveal {
	transition-delay: var(--reveal-delay, 0s);
}

.solution-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	height: 100%;
	padding: clamp(2rem, 3vw, 2.25rem) clamp(1.25rem, 2.5vw, 1.5rem) clamp(1.75rem, 3vw, 2rem);
	text-align: center;
	background: #ffffff;
	border: 1px solid rgba(230, 226, 218, 0.9);
	clip-path: polygon(0 26px, 26px 0, 100% 0, 100% 100%, 0 100%);
	transition: border-color var(--transition);
}

.solution-card-wrap:hover .solution-card {
	border-color: rgba(188, 108, 37, 0.35);
}

.solution-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	margin-bottom: 1.25rem;
	color: var(--color-forest);
	background: rgba(96, 108, 56, 0.1);
	border-radius: 50%;
	transition: background var(--transition), color var(--transition), transform var(--transition);
}

.solution-card__icon svg {
	width: 34px;
	height: 34px;
}

.solution-card-wrap:hover .solution-card__icon {
	background: var(--color-forest);
	color: #ffffff;
	transform: scale(1.05);
}

.solution-card__title {
	margin: 0 0 1rem;
}

.solution-card__index {
	display: block;
	margin-bottom: 0.375rem;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1;
	color: var(--color-terracotta);
	letter-spacing: 0.02em;
}

.solution-card__name {
	display: block;
	font-size: clamp(0.9375rem, 1.8vw, 1rem);
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-forest);
}

.solution-card__text {
	margin: 0;
	font-size: 0.8125rem;
	line-height: 1.75;
	color: var(--color-text-muted);
	flex: 1;
}

@media (min-width: 640px) {
	.solutions-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.25rem;
	}
}

@media (min-width: 1024px) {
	.solutions-grid {
		grid-template-columns: repeat(4, 1fr);
		gap: 1.125rem;
	}

	.solution-card {
		padding-left: 1.125rem;
		padding-right: 1.125rem;
	}
}

.formats-block {
	margin-top: clamp(3.5rem, 7vw, 5rem);
	padding-top: clamp(3rem, 6vw, 4rem);
	border-top: 1px solid var(--color-border);
}

.formats-block__header {
	max-width: 36rem;
	margin: 0 auto clamp(2.5rem, 5vw, 3.25rem);
	text-align: center;
}

.formats-block__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.formats-block__eyebrow-line {
	display: block;
	width: 36px;
	height: 2px;
	background: var(--color-olive);
	flex-shrink: 0;
}

.formats-block__title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	line-height: 1.15;
	margin: 0 0 0.75rem;
	color: var(--color-forest);
	letter-spacing: -0.02em;
}

.formats-block__intro {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.7;
	color: var(--color-text-muted);
}

.formats-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1.25rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.format-card-wrap {
	height: 100%;
	filter: drop-shadow(0 8px 22px rgba(40, 54, 24, 0.06));
	transition: filter var(--transition), transform var(--transition);
}

.format-card-wrap:hover {
	filter: drop-shadow(0 14px 32px rgba(40, 54, 24, 0.11));
	transform: translateY(-6px);
}

.format-card-wrap.reveal {
	transition-delay: var(--reveal-delay, 0s);
}

.format-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	min-height: 148px;
	height: 100%;
	padding: 1.75rem 1rem 1.5rem;
	text-align: center;
	background: #ffffff;
	border: 1px solid rgba(230, 226, 218, 0.9);
	clip-path: polygon(0 22px, 22px 0, 100% 0, 100% 100%, 0 100%);
	transition: border-color var(--transition);
}

.format-card-wrap:hover .format-card {
	border-color: rgba(96, 108, 56, 0.35);
}

.format-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	color: var(--color-forest);
	background: rgba(96, 108, 56, 0.1);
	border-radius: 50%;
	transition: background var(--transition), color var(--transition), transform var(--transition);
}

.format-card__icon svg {
	width: 30px;
	height: 30px;
}

.format-card-wrap:hover .format-card__icon {
	background: var(--color-olive);
	color: #ffffff;
	transform: scale(1.06);
}

.format-card__label {
	font-size: 0.8125rem;
	font-weight: 600;
	line-height: 1.45;
	color: var(--color-forest);
	max-width: 11rem;
}

@media (min-width: 640px) {
	.formats-grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 1.125rem;
	}

	.format-card {
		min-height: 156px;
		padding-left: 0.875rem;
		padding-right: 0.875rem;
	}
}

@media (min-width: 1024px) {
	.formats-grid {
		gap: 1.25rem;
	}

	.format-card__label {
		font-size: 0.875rem;
	}
}

/* Learning process — PPT Slide 4 */
.section--process {
	background: #ffffff;
}

.process-hero {
	max-width: 40rem;
	margin: 0 auto clamp(2.5rem, 5vw, 3.5rem);
	text-align: center;
}

.process-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.process-hero__eyebrow-line {
	display: block;
	width: 36px;
	height: 2px;
	background: var(--color-terracotta);
	flex-shrink: 0;
}

.process-hero__title {
	font-size: clamp(1.75rem, 3.5vw, 2.375rem);
	font-weight: 700;
	line-height: 1.12;
	margin: 0;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.process-module {
	margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.process-module__title {
	font-size: clamp(1.0625rem, 2vw, 1.25rem);
	font-weight: 700;
	margin: 0 0 clamp(1.5rem, 3vw, 2rem);
	color: var(--color-forest);
	letter-spacing: -0.01em;
}

.complexity-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

.complexity-card-wrap {
	height: 100%;
	filter: drop-shadow(0 10px 28px rgba(40, 54, 24, 0.07));
	transition: filter var(--transition), transform var(--transition);
}

.complexity-card-wrap:hover {
	filter: drop-shadow(0 16px 36px rgba(40, 54, 24, 0.11));
	transform: translateY(-6px);
}

.complexity-card-wrap.reveal {
	transition-delay: var(--reveal-delay, 0s);
}

.complexity-card--modern {
	display: flex;
	flex-direction: column;
	height: 100%;
	padding: clamp(1.75rem, 3vw, 2.25rem);
	background: #ffffff;
	border: 1px solid rgba(230, 226, 218, 0.9);
	clip-path: polygon(0 24px, 24px 0, 100% 0, 100% 100%, 0 100%);
	transition: border-color var(--transition);
}

.complexity-card-wrap:hover .complexity-card--modern {
	border-color: rgba(188, 108, 37, 0.35);
}

.complexity-card__badge {
	display: inline-flex;
	align-self: flex-start;
	padding: 0.3125rem 0.75rem;
	margin-bottom: 1rem;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-terracotta);
	background: rgba(188, 108, 37, 0.1);
	border-radius: var(--radius-pill);
}

.complexity-card__name {
	font-size: clamp(1.0625rem, 2vw, 1.1875rem);
	font-weight: 700;
	line-height: 1.35;
	margin: 0 0 0.75rem;
	color: var(--color-forest);
}

.complexity-card__text {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.8;
	color: var(--color-text-muted);
	flex: 1;
}

.process-module__title--center {
	text-align: center;
}

.process-flow-wrap {
	position: relative;
	overflow-x: auto;
	padding: 0.5rem 0 1rem;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: thin;
}

.process-flow-track {
	position: absolute;
	top: calc(0.5rem + 44px);
	left: 6%;
	right: 6%;
	height: 0;
	border-top: 2px dashed rgba(96, 108, 56, 0.45);
	pointer-events: none;
	z-index: 0;
}

.process-flow {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 0.5rem;
	min-width: 960px;
	list-style: none;
	margin: 0;
	padding: 0 0.5rem;
	position: relative;
	z-index: 1;
}

.process-flow__item {
	flex: 1;
	min-width: 108px;
	max-width: 132px;
	text-align: center;
}

.process-flow__item.reveal {
	transition-delay: var(--reveal-delay, 0s);
}

.process-flow__title {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	margin: 1rem 0 0;
	padding: 0 0.25rem;
	font-size: 0.8125rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--color-forest);
}

.process-flow__node {
	position: relative;
	width: 88px;
	height: 88px;
	margin: 0 auto;
}

.process-flow__ring {
	position: absolute;
	inset: 0;
	border: 2px dashed rgba(96, 108, 56, 0.55);
	border-radius: 50%;
	transition: border-color var(--transition), transform var(--transition);
}

.process-flow__circle {
	position: absolute;
	inset: 13px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-forest);
	border-radius: 50%;
	color: #ffffff;
	box-shadow: 0 8px 20px rgba(40, 54, 24, 0.15);
	transition: transform var(--transition), background var(--transition);
}

.process-flow__circle svg {
	width: 28px;
	height: 28px;
}

.process-flow__item:hover .process-flow__ring {
	border-color: var(--color-terracotta);
	transform: scale(1.04);
}

.process-flow__item:hover .process-flow__circle {
	transform: scale(1.06);
	background: var(--color-olive);
	color: #ffffff;
}

.process-flow__text {
	margin: 1rem 0 0;
	font-size: 0.75rem;
	line-height: 1.65;
	color: var(--color-text-muted);
}

.process-callout {
	padding: clamp(1.25rem, 2.5vw, 1.625rem) clamp(1.5rem, 3vw, 2rem);
	background: linear-gradient(135deg, rgba(96, 108, 56, 0.05) 0%, rgba(188, 108, 37, 0.04) 100%);
	border: 1px solid var(--color-border);
	border-radius: 10px;
	text-align: center;
}

.process-callout__text {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.75;
	color: var(--color-text-muted);
	max-width: 52rem;
	margin-left: auto;
	margin-right: auto;
}

@media (min-width: 768px) {
	.complexity-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 1.5rem;
	}
}

@media (max-width: 767px) {
	.process-flow-wrap {
		overflow: visible;
		padding-bottom: 0;
	}

	.process-flow-track {
		display: none;
	}

	.process-flow {
		flex-direction: column;
		min-width: 0;
		gap: 1.75rem;
		padding: 0;
	}

	.process-flow__item {
		display: flex;
		flex-direction: column;
		align-items: center;
		max-width: none;
		min-width: 0;
		text-align: center;
	}

	.process-flow__title {
		margin: 1rem 0 0;
		font-size: 0.9375rem;
	}

	.process-flow__text {
		margin: 0.5rem 0 0;
	}
}

/* Legacy services split (inner pages) */
.services-split {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}

@media (min-width: 900px) {
	.services-split { grid-template-columns: 1fr 1fr; gap: 3rem; }
}

.services-split__title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 0 1.25rem;
	color: var(--color-text);
}

.card-grid {
	display: grid;
	gap: 0.875rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.card-grid--services {
	grid-template-columns: 1fr;
}

@media (min-width: 600px) {
	.card-grid--services { grid-template-columns: repeat(2, 1fr); }
}

.card-grid--two {
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.card-grid--two { grid-template-columns: repeat(2, 1fr); }
}

.service-card {
	padding: 1.125rem 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--color-text);
	transition: border-color var(--transition), box-shadow var(--transition), transform var(--transition);
}

.service-card:hover {
	border-color: var(--color-orange);
	box-shadow: var(--shadow-sm);
	transform: translateY(-2px);
}

/* Learning process timeline */
.process-timeline--horizontal {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	list-style: none;
	margin: 0 0 2.5rem;
	padding: 0;
	counter-reset: none;
}

@media (min-width: 768px) {
	.process-timeline--horizontal {
		grid-template-columns: repeat(4, 1fr);
	}
}

.process-step-compact {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding: 1.25rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	min-height: 100%;
}

.process-step-compact__num {
	font-size: 0.75rem;
	font-weight: 700;
	color: var(--color-orange);
	letter-spacing: 0.08em;
}

.process-step-compact__label {
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1.45;
	color: var(--color-text);
}

.complexity-cards {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.25rem;
}

@media (min-width: 768px) {
	.complexity-cards { grid-template-columns: repeat(2, 1fr); }
}

/* Legacy complexity card styles (inner pages) */
.complexity-card:not(.complexity-card--modern) {
	padding: 1.5rem;
	background: var(--color-surface);
	border-left: 4px solid var(--color-orange);
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-orange);
}

.complexity-card__level {
	font-size: 0.9375rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--color-forest);
	line-height: 1.4;
}

.complexity-card__label {
	margin: 0;
	color: var(--color-text-muted);
	font-size: 0.9375rem;
}

.scope-block__title {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 1.25rem;
}

.scope-table-wrap {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.scope-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.875rem;
	background: var(--color-surface);
}

.scope-table th,
.scope-table td {
	padding: 0.875rem 1rem;
	border: 1px solid var(--color-border);
	text-align: left;
	vertical-align: top;
}

.scope-table thead th {
	background: var(--color-bg-subtle);
	font-weight: 700;
	font-size: 0.8125rem;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.scope-table tbody th {
	font-weight: 600;
	color: var(--color-text);
}

/* Featured portfolio — homepage */
.section--portfolio-featured {
	background: #ffffff;
}

.portfolio-featured-header {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.portfolio-featured-header__intro {
	max-width: 36rem;
}

.portfolio-featured-header__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0 0 0.75rem;
	font-size: 0.8125rem;
	font-weight: 600;
	color: var(--color-olive);
}

.portfolio-featured-header__eyebrow-mark {
	color: var(--color-terracotta);
	font-size: 0.875rem;
	line-height: 1;
}

.portfolio-featured-header__title {
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 700;
	line-height: 1.12;
	margin: 0;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.btn--featured-portfolio {
	display: inline-flex;
	align-items: center;
	gap: 0.625rem;
	padding: 0.875rem 1.5rem;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: capitalize;
	color: #ffffff;
	background: var(--color-forest);
	border: 1px solid var(--color-forest);
	border-radius: var(--radius-pill);
	transition: background var(--transition), border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.btn--featured-portfolio svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
}

.btn--featured-portfolio:hover {
	background: var(--color-olive);
	border-color: var(--color-olive);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: var(--shadow-sm);
}

.portfolio-featured-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 2.75rem);
}

.featured-project-card.reveal {
	transition-delay: var(--reveal-delay, 0s);
}

.featured-project-card {
	display: block;
	color: inherit;
	text-decoration: none;
}

.featured-project-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	margin-bottom: 1.25rem;
	border-radius: 18px;
	overflow: hidden;
	background: linear-gradient(135deg, rgba(96, 108, 56, 0.07) 0%, rgba(188, 108, 37, 0.05) 45%, #f7f7f5 100%);
	box-shadow: 0 12px 32px rgba(40, 54, 24, 0.06);
	transition: transform var(--transition), box-shadow var(--transition);
}

.featured-project-card:hover .featured-project-card__media {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px rgba(40, 54, 24, 0.1);
}

.featured-project-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.featured-project-card__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
}

.featured-project-card__placeholder-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	color: var(--color-olive);
	opacity: 0.45;
}

.featured-project-card__placeholder-icon svg {
	width: 48px;
	height: 48px;
}

.featured-project-card__meta {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1rem;
}

.featured-project-card__info {
	flex: 1;
	min-width: 0;
}

.featured-project-card__category {
	display: block;
	margin-bottom: 0.375rem;
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.4;
	color: var(--color-text-muted);
}

.featured-project-card__title {
	margin: 0;
	font-size: clamp(1.0625rem, 2vw, 1.25rem);
	font-weight: 700;
	line-height: 1.35;
	color: var(--color-forest);
	letter-spacing: -0.01em;
	transition: color var(--transition);
}

.featured-project-card:hover .featured-project-card__title {
	color: var(--color-olive);
}

.featured-project-card__action {
	display: inline-flex;
	flex-shrink: 0;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	color: var(--color-forest);
	background: #ffffff;
	border: 1px solid rgba(96, 108, 56, 0.35);
	border-radius: 50%;
	transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
}

.featured-project-card__action svg {
	width: 18px;
	height: 18px;
}

.featured-project-card:hover .featured-project-card__action {
	background: var(--color-forest);
	border-color: var(--color-forest);
	color: #ffffff;
	transform: rotate(-4deg) scale(1.05);
}

article.featured-project-card .featured-project-card__action {
	opacity: 0.45;
}

@media (min-width: 768px) {
	.portfolio-featured-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: clamp(2rem, 3.5vw, 2.5rem) clamp(1.5rem, 3vw, 2rem);
	}
}

@media (max-width: 639px) {
	.portfolio-featured-header {
		align-items: flex-start;
		flex-direction: column;
	}

	.btn--featured-portfolio {
		width: 100%;
		justify-content: center;
	}
}

/* Portfolio detail cards (legacy) */
.portfolio-grid--detail {
	grid-template-columns: 1fr;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.portfolio-grid--detail { grid-template-columns: repeat(2, 1fr); }
}

.project-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	padding: 2rem;
	transition: box-shadow var(--transition), transform var(--transition);
}

.project-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.project-card__title {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 1.25rem;
	line-height: 1.35;
}

.project-card__details {
	margin: 0 0 1.5rem;
}

.project-card__detail {
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--color-border);
}

.project-card__detail:last-child { border-bottom: none; }

.project-card__detail dt {
	font-size: 0.6875rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	margin-bottom: 0.25rem;
}

.project-card__detail dd {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.6;
	color: var(--color-text-muted);
}

.btn.is-disabled {
	opacity: 0.55;
	pointer-events: none;
}

/* Why Me section */
.section--why-me {
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(180deg, #ffffff 0%, rgba(254, 250, 224, 0.35) 100%);
}

.why-me__accent {
	position: absolute;
	width: 120px;
	height: 280px;
	border: 2px solid rgba(188, 108, 37, 0.22);
	border-radius: 50%;
	pointer-events: none;
}

.why-me__accent--left {
	top: 12%;
	left: -70px;
	transform: rotate(-18deg);
	border-right: 0;
	border-bottom: 0;
}

.why-me__accent--right {
	bottom: 8%;
	right: -70px;
	transform: rotate(18deg);
	border-left: 0;
	border-top: 0;
}

.why-me__wrap {
	position: relative;
	z-index: 1;
	max-width: 46rem;
	margin: 0 auto;
}

.why-me__header {
	text-align: center;
	margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.why-me__eyebrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.75rem;
	margin: 0 0 1rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.why-me__eyebrow-line {
	display: block;
	width: 32px;
	height: 2px;
	background: var(--color-terracotta);
}

.why-me__heading {
	margin: 0 0 1rem;
	font-size: clamp(2rem, 4.5vw, 2.875rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.why-me__opener {
	margin: 0 auto;
	max-width: 34rem;
	font-size: clamp(1.125rem, 2.2vw, 1.375rem);
	font-weight: 600;
	line-height: 1.55;
	color: var(--color-forest);
}

.why-me__body {
	display: grid;
	gap: 2rem;
}

.why-me__content p {
	margin: 0 0 1.35rem;
	font-size: 1.03125rem;
	line-height: 1.85;
	color: var(--color-text-muted);
}

.why-me__content p:last-child {
	margin-bottom: 0;
}

.why-me__quote {
	margin: 0.5rem 0 0;
	padding: 1.5rem 1.75rem;
	border: 0;
	border-left: 4px solid var(--color-terracotta);
	border-radius: 0 var(--radius) var(--radius) 0;
	background: rgba(254, 250, 224, 0.72);
	box-shadow: 0 14px 36px rgba(40, 54, 24, 0.06);
}

.why-me__quote p {
	margin: 0;
	font-size: clamp(1.0625rem, 2vw, 1.1875rem);
	font-style: italic;
	font-weight: 600;
	line-height: 1.7;
	color: var(--color-forest);
}

@media (max-width: 768px) {
	.why-me__accent {
		display: none;
	}

	.why-me__quote {
		padding: 1.25rem 1.35rem;
	}
}

/* About story (legacy blocks fallback) */
.story-opener {
	font-size: clamp(1.25rem, 2.5vw, 1.625rem);
	font-weight: 600;
	color: var(--color-text);
	margin: 0;
	line-height: 1.5;
}

.story-blocks {
	display: grid;
	gap: 1.5rem;
	margin-top: 2.5rem;
}

.story-block {
	padding: 1.5rem;
	background: var(--color-bg-subtle);
	border-left: 4px solid var(--color-orange);
}

.story-block__title {
	font-size: 1.0625rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
}

.story-block__text {
	margin: 0;
	color: var(--color-text-muted);
	line-height: 1.75;
}

/* Beyond Work section */
.section--beyond-work {
	position: relative;
	overflow: hidden;
	background: var(--color-bg);
}

.beyond-work__wash {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 92% 18%, rgba(212, 163, 115, 0.12) 0%, transparent 28%),
		linear-gradient(180deg, #ffffff 0%, rgba(254, 250, 224, 0.28) 100%);
	pointer-events: none;
}

.beyond-work__header {
	position: relative;
	z-index: 1;
	max-width: 40rem;
	margin-bottom: clamp(2.5rem, 5vw, 3.75rem);
}

.beyond-work__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 1rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.beyond-work__eyebrow-line {
	display: block;
	width: 32px;
	height: 2px;
	background: var(--color-terracotta);
}

.beyond-work__heading {
	margin: 0;
	font-size: clamp(2rem, 4.5vw, 2.875rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.beyond-work__rows {
	position: relative;
	z-index: 1;
	display: grid;
	gap: clamp(2.5rem, 5vw, 4rem);
}

.beyond-work__row {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.95fr);
	gap: clamp(2rem, 4vw, 3.5rem);
	align-items: center;
}

.beyond-work__row--reverse .beyond-work__content {
	order: 2;
}

.beyond-work__row--reverse .beyond-work__media {
	order: 1;
}

.beyond-work__title {
	margin: 0 0 1rem;
	font-size: clamp(1.375rem, 2.5vw, 1.75rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--color-forest);
}

.beyond-work__text {
	margin: 0;
	font-size: 1.03125rem;
	line-height: 1.85;
	color: var(--color-text-muted);
	max-width: 34rem;
}

.beyond-work__media-frame {
	position: relative;
	padding: 0.85rem;
	border-radius: calc(var(--radius) + 6px);
	background: linear-gradient(145deg, rgba(212, 163, 115, 0.28), rgba(254, 250, 224, 0.85));
	box-shadow: 0 18px 42px rgba(40, 54, 24, 0.08);
}

.beyond-work__media-frame::before {
	content: '';
	position: absolute;
	inset: 0.85rem;
	border: 1px solid rgba(40, 54, 24, 0.08);
	border-radius: var(--radius);
	pointer-events: none;
}

.beyond-work__image {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: var(--radius);
	display: block;
}

.beyond-work__placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1rem;
	min-height: 280px;
	padding: 2rem;
	border-radius: var(--radius);
	text-align: center;
	color: var(--color-forest);
}

.beyond-work__placeholder--swimming {
	background: linear-gradient(160deg, rgba(96, 108, 56, 0.14) 0%, rgba(254, 250, 224, 0.95) 100%);
}

.beyond-work__placeholder--art {
	background: linear-gradient(160deg, rgba(188, 108, 37, 0.12) 0%, rgba(254, 250, 224, 0.95) 100%);
}

.beyond-work__placeholder-icon {
	display: grid;
	place-items: center;
	width: 72px;
	height: 72px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.72);
	color: var(--color-olive);
	box-shadow: 0 10px 24px rgba(40, 54, 24, 0.08);
}

.beyond-work__placeholder-icon svg {
	width: 38px;
	height: 38px;
}

.beyond-work__placeholder span {
	font-size: 0.875rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-olive);
}

@media (max-width: 900px) {
	.beyond-work__row,
	.beyond-work__row--reverse {
		grid-template-columns: 1fr;
	}

	.beyond-work__row--reverse .beyond-work__content,
	.beyond-work__row--reverse .beyond-work__media {
		order: initial;
	}

	.beyond-work__media {
		max-width: 34rem;
	}
}

@media (max-width: 768px) {
	.beyond-work__placeholder {
		min-height: 240px;
	}
}

/* Beyond work legacy cards */
.info-card__title {
	font-size: 1.125rem;
	font-weight: 700;
	margin: 0 0 0.75rem;
}

.info-card__text {
	margin: 0;
	color: var(--color-text-muted);
	line-height: 1.75;
}

/* Featured testimonial */
.testimonial-feature {
	margin: 0;
	padding: 2.5rem;
	background: var(--color-bg-subtle);
	border-left: 4px solid var(--color-orange);
}

.testimonial-feature__quote {
	font-size: clamp(1.0625rem, 2vw, 1.25rem);
	line-height: 1.85;
	color: var(--color-text-muted);
	font-style: italic;
	margin: 0 0 1.5rem;
}

.testimonial-feature__cite {
	font-style: normal;
	font-weight: 700;
	font-size: 0.875rem;
	color: var(--color-text);
}

.testimonial-feature__role {
	display: block;
	font-weight: 500;
	color: var(--color-text-muted);
	margin-top: 0.25rem;
}

/* Contact section */
.section--contact {
	position: relative;
	overflow: hidden;
	background: linear-gradient(180deg, rgba(254, 250, 224, 0.22) 0%, #ffffff 100%);
}

.contact-section__wash {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 8% 18%, rgba(96, 108, 56, 0.08) 0%, transparent 28%),
		radial-gradient(circle at 92% 82%, rgba(188, 108, 37, 0.08) 0%, transparent 30%);
	pointer-events: none;
}

.contact-section__header {
	position: relative;
	z-index: 1;
	max-width: 42rem;
	margin: 0 auto clamp(2.5rem, 5vw, 3.5rem);
	text-align: center;
}

.contact-section__eyebrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.65rem;
	margin: 0 0 1rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.contact-section__eyebrow-mark {
	color: var(--color-terracotta);
}

.contact-section__heading {
	margin: 0 0 1rem;
	font-size: clamp(2rem, 4.5vw, 2.875rem);
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-forest);
	letter-spacing: -0.025em;
}

.contact-section__subtext {
	margin: 0 auto;
	max-width: 34rem;
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--color-text-muted);
}

.contact-shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
	gap: clamp(1.5rem, 3vw, 2rem);
	align-items: stretch;
}

.contact-panel {
	height: 100%;
	padding: clamp(1.75rem, 3vw, 2.25rem);
	border-radius: calc(var(--radius) + 8px);
	background: linear-gradient(160deg, var(--color-forest) 0%, #3a4a24 100%);
	color: #fff;
	box-shadow: 0 24px 50px rgba(40, 54, 24, 0.18);
}

.contact-panel__intro {
	margin-bottom: 1.75rem;
}

.contact-panel__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	margin: 0 0 0.85rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.72);
}

.contact-panel__eyebrow-line {
	display: block;
	width: 32px;
	height: 2px;
	background: var(--color-tan);
}

.contact-panel__title {
	margin: 0 0 0.85rem;
	font-size: clamp(1.5rem, 2.5vw, 1.875rem);
	font-weight: 700;
	line-height: 1.2;
	color: #fff;
}

.contact-panel__text {
	margin: 0;
	font-size: 0.9875rem;
	line-height: 1.75;
	color: rgba(255, 255, 255, 0.82);
}

.contact-panel__channels {
	display: grid;
	gap: 0.85rem;
	margin-bottom: 1.5rem;
}

.contact-panel__channel {
	display: flex;
	align-items: flex-start;
	gap: 0.9rem;
	padding: 0.95rem 1rem;
	border-radius: calc(var(--radius) + 2px);
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.contact-panel__icon {
	display: grid;
	place-items: center;
	width: 42px;
	height: 42px;
	border-radius: 12px;
	background: rgba(254, 250, 224, 0.14);
	color: var(--color-tan);
	flex-shrink: 0;
}

.contact-panel__icon svg {
	width: 20px;
	height: 20px;
}

.contact-panel__channel-label {
	display: block;
	margin-bottom: 0.2rem;
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.62);
}

.contact-panel__channel-value {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.55;
	color: #fff;
	text-decoration: none;
}

a.contact-panel__channel-value:hover {
	color: var(--color-tan);
}

.contact-panel__highlights {
	display: grid;
	gap: 0.75rem;
	padding-top: 0.35rem;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.contact-panel__highlight {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.contact-panel__highlight strong {
	display: block;
	margin-bottom: 0.15rem;
	font-size: 0.875rem;
	font-weight: 700;
	color: #fff;
}

.contact-panel__highlight p {
	margin: 0;
	font-size: 0.8125rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.72);
}

.contact-form-card {
	height: 100%;
	padding: clamp(1.75rem, 3vw, 2.25rem);
	border: 1px solid rgba(40, 54, 24, 0.08);
	border-radius: calc(var(--radius) + 8px);
	background: #fff;
	box-shadow: 0 22px 48px rgba(40, 54, 24, 0.08);
}

.contact-form-card__head {
	margin-bottom: 1.5rem;
}

.contact-form-card__title {
	margin: 0 0 0.45rem;
	font-size: clamp(1.375rem, 2.5vw, 1.75rem);
	font-weight: 700;
	color: var(--color-forest);
}

.contact-form-card__text {
	margin: 0;
	font-size: 0.9375rem;
	line-height: 1.65;
	color: var(--color-text-muted);
}

.contact-form .form-field label {
	color: var(--color-olive);
}

.contact-form .form-field input,
.contact-form .form-field textarea {
	padding: 0.95rem 1rem;
	background: rgba(254, 250, 224, 0.35);
	border: 1px solid rgba(96, 108, 56, 0.14);
	border-radius: calc(var(--radius) + 2px);
}

.contact-form .form-field input:focus,
.contact-form .form-field textarea:focus {
	border-color: var(--color-olive);
	box-shadow: 0 0 0 4px rgba(96, 108, 56, 0.12);
	background: #fff;
}

.contact-form .form-field input::placeholder,
.contact-form .form-field textarea::placeholder {
	color: rgba(40, 54, 24, 0.38);
}

.btn--contact-submit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.65rem;
	width: 100%;
	min-height: 52px;
	padding: 0.85rem 1.5rem;
	border: 0;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--color-terracotta), #a35a1f);
	color: #fff;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	box-shadow: 0 14px 30px rgba(188, 108, 37, 0.24);
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.btn--contact-submit svg {
	width: 18px;
	height: 18px;
}

.btn--contact-submit:hover {
	transform: translateY(-1px);
	box-shadow: 0 18px 34px rgba(188, 108, 37, 0.28);
	background: linear-gradient(135deg, var(--color-forest), var(--color-olive));
	color: #fff;
}

.contact-page-content {
	margin-top: 1.5rem;
	padding-top: 1.5rem;
	border-top: 1px solid rgba(40, 54, 24, 0.08);
}

@media (max-width: 960px) {
	.contact-shell {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 768px) {
	.contact-panel,
	.contact-form-card {
		padding: 1.35rem;
	}
}

/* Contact legacy */
.contact-info-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.contact-info-list li {
	padding: 0.625rem 0;
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	border-bottom: 1px solid var(--color-border);
}

.contact-info-list li:last-child { border-bottom: none; }

.contact-layout__heading {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 1rem;
}

html { scroll-padding-top: calc(var(--header-height) + 16px); }

/* ==========================================================================
   Responsive & mobile navigation enhancements
   ========================================================================== */

@media (max-width: 900px) {
	:root {
		--section-padding: clamp(3rem, 8vw, 4.5rem);
	}

	.site-header__inner {
		gap: 1rem;
	}

	.site-logo {
		min-width: 0;
		flex: 1;
	}

	.site-logo__text {
		font-size: clamp(0.8125rem, 3.5vw, 0.9375rem);
		line-height: 1.25;
	}

	.site-branding {
		min-width: 0;
	}

	.contact-layout {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.process-timeline--horizontal {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 640px) {
	.container {
		padding-left: max(1.25rem, env(safe-area-inset-left));
		padding-right: max(1.25rem, env(safe-area-inset-right));
	}

	.site-footer {
		padding-bottom: max(2rem, env(safe-area-inset-bottom));
	}

	.back-to-top {
		bottom: max(1rem, env(safe-area-inset-bottom));
	}

	.hero__actions {
		flex-direction: column;
		width: 100%;
	}

	.hero__actions .btn {
		width: 100%;
		justify-content: center;
		min-height: 48px;
	}

	.hero__headline {
		font-size: clamp(1.625rem, 7vw, 2rem);
	}

	.hero__layout {
		padding-top: 160px;
	}

	.hero__blue-block {
		height: 180px;
	}

	.site-logo__subtitle {
		font-size: 0.625rem;
		letter-spacing: 0.08em;
	}

	.process-timeline--horizontal {
		grid-template-columns: 1fr;
	}

	.project-card,
	.testimonial-feature,
	.complexity-card:not(.complexity-card--modern) {
		padding: 1.5rem;
	}

	.scope-table-wrap {
		margin-left: -0.25rem;
		margin-right: -0.25rem;
		border: 1px solid var(--color-border);
		border-radius: var(--radius);
	}

	.scope-table {
		font-size: 0.8125rem;
		min-width: 520px;
	}

	.scope-table th,
	.scope-table td {
		padding: 0.75rem;
	}
}

@media (max-width: 400px) {
	.site-logo__subtitle {
		display: none;
	}

	.site-logo__mark {
		width: 24px;
		height: 24px;
	}
}

/* Touch-friendly form fields (prevents iOS zoom) */
.form-field input,
.form-field textarea,
.btn {
	min-height: 44px;
}

.form-field input,
.form-field textarea {
	font-size: 16px;
}

/* Scope table scroll hint on small screens */
.scope-table-wrap {
	position: relative;
}

@media (max-width: 768px) {
	.scope-table-wrap::after {
		content: '';
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		width: 28px;
		background: linear-gradient(to left, rgba(255, 255, 255, 0.95), transparent);
		pointer-events: none;
	}
}

/* Single portfolio project page */
.project-single {
	padding: calc(var(--header-height) + 2.5rem) 0 5rem;
	background: var(--color-bg);
}

.project-single__top {
	margin-bottom: 1.5rem;
}

.project-single__back {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--color-olive);
	text-decoration: none;
	transition: color 0.2s ease;
}

.project-single__back:hover {
	color: var(--color-forest);
}

.project-single__hero {
	max-width: 760px;
	margin-bottom: 2.75rem;
}

.project-single__context {
	margin: 0 0 0.75rem;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--color-tan);
}

.project-single__title-badge {
	display: inline-block;
	margin: 0 0 1.25rem;
	padding: 0.85rem 1.5rem;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--color-olive), var(--color-forest));
	color: #fff;
	font-size: clamp(1.35rem, 2.5vw, 2rem);
	line-height: 1.25;
	box-shadow: 0 12px 32px rgba(40, 54, 24, 0.14);
}

.project-single__summary {
	margin: 0;
	font-size: 1.0625rem;
	line-height: 1.75;
	color: var(--color-text-muted);
}

.project-single__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
	gap: 2.5rem;
	align-items: start;
}

.project-single__list {
	margin: 0;
	display: grid;
	gap: 1.25rem;
}

.project-single__item {
	margin: 0;
}

.project-single__item dt {
	margin: 0 0 0.35rem;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-olive);
}

.project-single__item dd {
	margin: 0;
	font-size: 0.9875rem;
	line-height: 1.65;
	color: var(--color-text);
}

.project-single__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 2rem;
}

.btn--project-tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	padding: 0.55rem 1.1rem;
	border-radius: 999px;
	background: var(--color-terracotta);
	color: #fff;
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	border: none;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.btn--project-tag:hover {
	background: var(--color-forest);
	color: #fff;
	transform: translateY(-1px);
	box-shadow: 0 8px 20px rgba(188, 108, 37, 0.22);
}

.btn--project-tag--muted {
	background: rgba(212, 163, 115, 0.22);
	color: var(--color-text-muted);
	cursor: default;
}

.project-single__media-label {
	margin: 0 0 0.85rem;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--color-text);
}

.project-single__media {
	padding: 1.25rem;
	border: 1px solid var(--color-border);
	border-radius: calc(var(--radius) + 4px);
	background: rgba(254, 250, 224, 0.35);
	box-shadow: 0 18px 40px rgba(40, 54, 24, 0.06);
}

.project-single__embed {
	position: relative;
	aspect-ratio: 16 / 10;
	border-radius: var(--radius);
	overflow: hidden;
	background: #eef0ea;
}

.project-single__embed iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

.project-single__launch {
	margin-top: 1rem;
	width: 100%;
	justify-content: center;
}

.project-single__media-placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.85rem;
	min-height: 280px;
	padding: 1.5rem;
	border-radius: var(--radius);
	background: linear-gradient(180deg, #f3f4ef 0%, #e8ebe2 100%);
	text-align: center;
	color: var(--color-text-muted);
}

.project-single__media-icon svg {
	width: 56px;
	height: 56px;
	color: var(--color-olive);
	opacity: 0.65;
}

.project-single__media-image {
	width: 100%;
	height: auto;
	border-radius: var(--radius);
}

.project-single__protected-note {
	margin: 0 0 1rem;
	padding: 0.85rem 1rem;
	border-left: 3px solid #c0392b;
	background: rgba(192, 57, 43, 0.06);
	color: #8b2e24;
	font-size: 0.875rem;
	line-height: 1.55;
}

.project-single__protected-box {
	padding: 1.25rem;
	border-radius: var(--radius);
	background: #4a4f57;
	color: #f5f5f5;
}

.project-single__protected-box p {
	margin: 0 0 1rem;
	font-size: 0.875rem;
}

.project-single__protected-form {
	display: flex;
	flex-wrap: wrap;
	gap: 0.65rem;
}

.project-single__protected-form input {
	flex: 1 1 160px;
	min-height: 42px;
	padding: 0.65rem 0.85rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	color: #fff;
}

.project-single__content {
	margin-top: 3rem;
	max-width: 760px;
}

@media (max-width: 960px) {
	.project-single__layout {
		grid-template-columns: 1fr;
	}

	.project-single__media {
		order: -1;
	}
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}

	.reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}

	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}
