/* Fonts (self-hosted Poppins, latin + latin-ext subsets) */

@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("../fonts/poppins-400-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 400;
	font-display: swap;
	src: url("../fonts/poppins-400-latin-ext.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("../fonts/poppins-500-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 500;
	font-display: swap;
	src: url("../fonts/poppins-500-latin-ext.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("../fonts/poppins-600-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 600;
	font-display: swap;
	src: url("../fonts/poppins-600-latin-ext.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url("../fonts/poppins-700-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 700;
	font-display: swap;
	src: url("../fonts/poppins-700-latin-ext.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 800;
	font-display: swap;
	src: url("../fonts/poppins-800-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Poppins";
	font-style: normal;
	font-weight: 800;
	font-display: swap;
	src: url("../fonts/poppins-800-latin-ext.woff2") format("woff2");
	unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Custom properties */

:root {
	--color-primary: #0f766e;
	--color-primary-light: #14b8a6;
	--color-primary-dark: #0c5f58;
	--color-accent: #d97706;
	--color-accent-light: #f59e0b;
	--color-bg: #fafaf9;
	--color-bg-alt: #f5f5f4;
	--color-surface: #ffffff;
	--color-text: #171717;
	--color-text-secondary: #525252;
	--color-text-muted: #737373;
	--color-border: #e5e5e5;
	--color-border-light: #f0f0f0;
	--color-border-strong: #878787;

	--font-family: "Poppins", system-ui, -apple-system, sans-serif;

	--font-size-xs: 0.875rem;
	--font-size-sm: 0.9375rem;
	--font-size-base: 1rem;
	--font-size-md: 1.0625rem;
	--font-size-lg: 1.25rem;
	--font-size-2xl: 2.25rem;
	--font-size-3xl: 3rem;

	--max-width: 1180px;
	--header-height: 80px;

	--section-padding: 100px;
	--section-padding-mobile: 60px;

	--card-pad: 32px;
	--card-pad-lg: 40px;
	--card-pad-mobile: 24px;

	--radius-sm: 6px;
	--radius-md: 10px;
	--radius-lg: 12px;
	--radius-xl: 16px;

	--shadow-sm: 0 1px 8px rgba(0, 0, 0, 0.08);
	--shadow-md: 0 2px 8px rgba(0, 0, 0, 0.04);
	--shadow-lg: 0 4px 12px rgba(0, 0, 0, 0.08);
	--shadow-xl: 0 8px 24px rgba(0, 0, 0, 0.08);

	--duration-fast: 0.15s;
	--duration-base: 0.2s;
	--duration-slow: 0.3s;
}

/* Reset & base */

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

html {
	scroll-behavior: smooth;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

@media (prefers-reduced-motion: reduce) {
	html {
		scroll-behavior: auto;
	}
}

body {
	font-family: var(--font-family);
	font-size: var(--font-size-base);
	font-weight: 400;
	line-height: 1.65;
	color: var(--color-text-secondary);
	background-color: var(--color-bg);
}

h1, h2, h3, h4, h5, h6 {
	color: var(--color-text);
	line-height: 1.3;
}

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--duration-base) ease, text-decoration-color var(--duration-base) ease;
}

a:hover {
	color: var(--color-primary-light);
}

p a {
	text-decoration: underline;
	text-decoration-color: color-mix(in srgb, currentColor 35%, transparent);
	text-underline-offset: 2px;
}

p a:hover {
	text-decoration-color: currentColor;
}

.link-icon {
	display: inline-block;
	width: 0.7em;
	height: 0.7em;
	margin-left: 3px;
	vertical-align: middle;
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

ul {
	list-style: none;
}

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

::selection {
	background: var(--color-primary);
	color: #fff;
}

/* Focus */

:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
	border-radius: 4px;
}

.footer :focus-visible {
	outline-color: var(--color-accent-light);
}

/* Skip link */

.skip-link {
	position: absolute;
	left: -9999px;
	top: 8px;
	z-index: 200;
	padding: 8px 16px;
	background: var(--color-primary);
	color: #fff;
	border-radius: var(--radius-sm);
}

.skip-link:focus {
	left: 8px;
}

/* Visually hidden, but available to assistive technology */

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0 0 0 0);
	clip-path: inset(50%);
	white-space: nowrap;
}

/* Scroll-reveal animation */

.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

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

@media (prefers-reduced-motion: reduce) {
	.reveal {
		transition: none;
		opacity: 1;
		transform: none;
	}
}

/* Buttons */

.cta-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 28px;
	background-color: var(--color-primary);
	color: #fff;
	font-size: var(--font-size-base);
	font-weight: 600;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: background-color var(--duration-base) ease, transform var(--duration-base) ease;
}

.cta-button:hover {
	background-color: var(--color-primary-dark);
	color: #fff;
	transform: translateY(-2px);
}

.cta-button svg {
	flex-shrink: 0;
}

/* Header */

.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	height: var(--header-height);
	display: flex;
	align-items: center;
	border-bottom: 1px solid transparent;
	transition: background-color var(--duration-slow) ease, box-shadow var(--duration-slow) ease, border-bottom-color var(--duration-slow) ease;
}

.header.scrolled {
	background-color: var(--color-surface);
	box-shadow: var(--shadow-sm);
	border-bottom-color: var(--color-border-light);
}

/* Applied by JS only while the initial scroll state is set, so a reload at a
   scrolled position renders the header settled instead of fading it in. */
.header.no-transition {
	transition: none;
}

.header .container {
	max-width: var(--max-width);
	width: 100%;
	margin: 0 auto;
	padding: 0 24px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.logo {
	display: inline-flex;
	align-items: center;
	gap: 14px;
	height: 64px;
	transition: opacity var(--duration-base) ease;
}

.logo img {
	height: 100%;
	width: auto;
	display: block;
}

.logo-name {
	font-size: var(--font-size-lg);
	font-weight: 700;
	line-height: 1;
	letter-spacing: -0.3px;
	color: var(--color-text);
	white-space: nowrap;
}

.logo:hover {
	opacity: 0.7;
}

.nav {
	display: flex;
	align-items: center;
}

.nav-list {
	display: flex;
	gap: 8px;
}

.nav-link {
	display: block;
	padding: 8px 16px;
	font-size: var(--font-size-xs);
	font-weight: 500;
	color: var(--color-text-secondary);
	text-transform: uppercase;
	letter-spacing: 1px;
	border-radius: var(--radius-sm);
	transition: color var(--duration-base) ease, background-color var(--duration-base) ease;
}

.nav-link:hover {
	color: var(--color-primary);
	background-color: var(--color-bg-alt);
}

.nav-link.active {
	color: var(--color-primary);
	font-weight: 600;
}

.menu-toggle {
	display: none;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
	color: var(--color-text);
	border-radius: var(--radius-sm);
	transition: background-color var(--duration-base) ease;
}

.menu-toggle:hover {
	background-color: var(--color-bg-alt);
}

.menu-toggle .icon-close {
	display: none;
}

.menu-toggle[aria-expanded="true"] .icon-menu {
	display: none;
}

.menu-toggle[aria-expanded="true"] .icon-close {
	display: block;
}

@media (max-width: 768px) {
	.header {
		background-color: var(--color-surface);
	}

	.logo {
		height: 52px;
	}

	.logo-name {
		font-size: var(--font-size-md);
	}

	.menu-toggle {
		display: flex;
		align-items: center;
		justify-content: center;
	}

	.nav-list {
		display: none;
		position: absolute;
		top: var(--header-height);
		left: 0;
		right: 0;
		flex-direction: column;
		background-color: var(--color-surface);
		box-shadow: var(--shadow-lg);
		padding: 8px 0;
		gap: 0;
	}

	.nav-list.open {
		display: flex;
	}

	.nav-link {
		padding: 14px 24px;
		border-radius: 0;
	}

	.nav-link:hover {
		background-color: var(--color-bg-alt);
	}
}

/* Hero */

.hero {
	padding: calc(var(--header-height) + 60px) 0 80px;
	overflow: hidden;
	position: relative;
}

.hero .container {
	max-width: var(--max-width);
	width: 100%;
	margin: 0 auto;
	padding: 0 24px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: center;
}

.hero-text {
	z-index: 1;
}

.hero-heading {
	font-size: var(--font-size-3xl);
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 28px;
	letter-spacing: -0.5px;
}

.hero-heading .accent {
	color: var(--color-primary);
}

.hero-bio {
	font-size: var(--font-size-md);
	line-height: 1.7;
	color: var(--color-text-secondary);
	margin-bottom: 24px;
}

.hero-bio:last-child {
	margin-bottom: 0;
}

.hero-text .cta-button {
	margin-top: 16px;
}

.hero-visual {
	position: relative;
	height: 340px;
}

.shape1 {
	position: absolute;
	width: 300px;
	height: 300px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
	opacity: 0.12;
	top: 20px;
	right: 0;
}

.shape2 {
	position: absolute;
	width: 200px;
	height: 200px;
	border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
	background: linear-gradient(135deg, var(--color-accent), var(--color-accent-light));
	opacity: 0.15;
	top: 120px;
	right: 140px;
}

.shape3 {
	position: absolute;
	width: 120px;
	height: 120px;
	border-radius: 50%;
	border: 3px solid var(--color-primary);
	opacity: 0.2;
	top: 0;
	right: 200px;
}

@media (max-width: 1024px) {
	.hero-heading {
		font-size: 2.5rem;
	}
}

@media (max-width: 768px) {
	.hero {
		padding-top: calc(var(--header-height) + 30px);
		padding-bottom: var(--section-padding-mobile);
	}

	.hero .container {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.hero-heading {
		font-size: 2rem;
	}

	.hero-visual {
		height: 220px;
		margin-top: 24px;
	}
}

@media (max-width: 540px) {
	.hero-visual {
		display: none;
	}
}

/* Services */

.services {
	padding: var(--section-padding) 0;
	background-color: var(--color-bg-alt);
}

.services .container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 24px;
}

.services-heading {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	text-align: center;
	margin-bottom: 16px;
}

.services-heading .accent {
	color: var(--color-primary);
}

.services-intro {
	max-width: 60ch;
	margin: 0 auto 56px;
	text-align: center;
	font-size: var(--font-size-md);
	line-height: 1.7;
	color: var(--color-text-secondary);
}

.services-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 340px));
	gap: 32px;
	justify-content: center;
}

.services-grid > .reveal {
	display: flex;
}

.service-card {
	flex: 1;
	display: flex;
	flex-direction: column;
	position: relative;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: 48px var(--card-pad) var(--card-pad-lg);
	text-align: center;
	box-shadow: var(--shadow-md);
	transition: box-shadow var(--duration-base) ease, transform var(--duration-base) ease;
}

.service-card:hover {
	box-shadow: var(--shadow-xl);
	transform: translateY(-2px);
}

.service-number {
	position: absolute;
	top: 8px;
	left: 20px;
	font-size: 4rem;
	font-weight: 700;
	color: color-mix(in srgb, var(--color-text) 6%, transparent);
	line-height: 1;
	user-select: none;
}

.service-icon-wrap {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: var(--radius-xl);
	background-color: var(--color-primary);
	color: #fff;
	margin-bottom: 24px;
	position: relative;
	z-index: 1;
}

.service-card-title {
	font-size: var(--font-size-lg);
	font-weight: 600;
	/* Reserve 2 lines (heading line-height 1.3) so single- and multi-line titles
	   share a y-centre and the body text below all starts at the same y. */
	min-height: 2.6em;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 16px;
}

.service-card-text {
	font-size: var(--font-size-sm);
	line-height: 1.7;
	color: var(--color-text-muted);
}

.service-card-text + .service-card-text {
	margin-top: 12px;
}

@media (max-width: 1024px) {
	.services-grid {
		grid-template-columns: repeat(2, minmax(0, 340px));
	}

	/* Orphan card on the wrapped row spans both columns and centers. */
	.services-grid > .reveal:nth-child(3):last-child {
		grid-column: 1 / -1;
		justify-self: center;
		width: 100%;
		max-width: 340px;
	}
}

@media (max-width: 640px) {
	.services {
		padding: var(--section-padding-mobile) 0;
	}

	.services-grid {
		grid-template-columns: minmax(0, 340px);
	}

	.services-grid > .reveal:nth-child(3):last-child {
		grid-column: auto;
		justify-self: stretch;
		max-width: none;
	}

	.service-card {
		padding: 40px var(--card-pad-mobile) 32px;
	}
}

/* Details */

.details {
	padding: var(--section-padding) 0;
}

.details .container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 24px;
}

.details-heading {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	text-align: center;
	margin-bottom: 56px;
}

.details-heading .accent {
	color: var(--color-primary);
}

.details-tabs {
	max-width: 900px;
	margin: 0 auto;
}

.details-tablist {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-bottom: 24px;
	border: none;
}

.details-tab {
	flex: 0 1 auto;
	min-width: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 14px 18px;
	background-color: var(--color-bg-alt);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	color: var(--color-text-secondary);
	font-family: inherit;
	font-size: var(--font-size-sm);
	font-weight: 600;
	cursor: pointer;
	transition: color var(--duration-fast), background-color var(--duration-fast), border-color var(--duration-fast), transform var(--duration-fast);
}

.details-tab:hover {
	background-color: var(--color-surface);
	color: var(--color-text);
	border-color: var(--color-primary-light);
	transform: translateY(-1px);
}

.details-tab.is-active {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-surface);
}

.details-tab.is-active:hover {
	background-color: var(--color-primary);
	transform: none;
}

.details-tab:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

.details-tab-icon {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}

.details-panel {
	background-color: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
	padding: var(--card-pad-lg);
	max-width: none;
	margin: 0;
}

.details-panel[hidden] {
	display: none;
}

.detail-banner {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--radius-md);
	margin-bottom: 24px;
	object-fit: cover;
	aspect-ratio: 5 / 1;
}

.detail-title {
	font-size: var(--font-size-lg);
	font-weight: 600;
	margin-bottom: 4px;
}

.detail-text {
	font-size: var(--font-size-sm);
	line-height: 1.65;
	color: var(--color-text-secondary);
}

.detail-text a {
	color: var(--color-primary);
	font-weight: 500;
}

.detail-text a:hover {
	color: var(--color-primary-light);
}

.detail-subheading {
	font-size: var(--font-size-base);
	font-weight: 600;
	color: var(--color-text);
	margin-top: 24px;
	margin-bottom: 6px;
}

.details-panel > .detail-text + .detail-text {
	margin-top: 12px;
}

.detail-tab-link {
	background: none;
	border: none;
	padding: 0;
	color: var(--color-primary);
	font: inherit;
	font-weight: 500;
	cursor: pointer;
	text-decoration: underline;
	text-decoration-color: color-mix(in srgb, currentColor 35%, transparent);
	text-underline-offset: 2px;
	transition: color var(--duration-base) ease, text-decoration-color var(--duration-base) ease;
}

.detail-tab-link:hover {
	color: var(--color-primary-light);
	text-decoration-color: currentColor;
}

.details-cta {
	max-width: 900px;
	margin: 40px auto 0;
	text-align: center;
}

.details-cta-text {
	font-size: var(--font-size-md);
	color: var(--color-text-secondary);
	margin-bottom: 20px;
}

@media (max-width: 640px) {
	.details {
		padding: var(--section-padding-mobile) 0;
	}

	.details-tablist {
		flex-direction: column;
		gap: 6px;
	}

	.details-tab {
		flex: 1 1 auto;
		padding: 12px 14px;
		font-size: var(--font-size-sm);
	}

	.details-tab-icon svg {
		width: 18px;
		height: 18px;
	}

	.details-panel {
		padding: var(--card-pad-mobile) 20px;
	}
}

/* Earlier work */

.work {
	padding: var(--section-padding) 0;
}

.work .container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 24px;
}

.work-heading {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	text-align: center;
	margin-bottom: 16px;
}

.work-heading .accent {
	color: var(--color-primary);
}

@media (max-width: 640px) {
	.work {
		padding: var(--section-padding-mobile) 0;
	}
}

/* Testimonials */

.testimonials {
	padding: var(--section-padding) 0;
	background-color: var(--color-bg-alt);
}

.testimonials .container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 24px;
}

.testimonials-heading {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	text-align: center;
	margin-bottom: 56px;
}

.testimonials-heading .accent {
	color: var(--color-primary);
}

.testimonials-carousel {
	position: relative;
}

.testimonials-viewport {
	overflow: hidden;
}

.testimonials-track {
	display: flex;
	gap: 28px;
	transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
	touch-action: pan-y;
	cursor: grab;
	will-change: transform;
}

.testimonials-track.dragging {
	cursor: grabbing;
	transition: none;
	user-select: none;
}

.testimonial-slide {
	flex-shrink: 0;
	flex-basis: 100%;
	min-width: 0;
}

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

.testimonials-nav {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 24px;
	margin-top: 32px;
}

.testimonials-arrow {
	width: 44px;
	height: 44px;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: transparent;
	border: 1px solid var(--color-border-strong);
	border-radius: 50%;
	color: var(--color-text);
	cursor: pointer;
	transition: color var(--duration-base), border-color var(--duration-base), background-color var(--duration-base);
}

.testimonials-arrow:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.testimonials-arrow:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
	border-color: var(--color-primary);
	color: var(--color-primary);
}

.testimonials-dots {
	display: flex;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
}

.testimonials-dot {
	width: 10px;
	height: 10px;
	padding: 0;
	border: 11px solid transparent;
	border-radius: 50%;
	background-color: var(--color-border-strong);
	background-clip: padding-box;
	box-sizing: content-box;
	cursor: pointer;
	transition: background-color var(--duration-base), transform var(--duration-fast);
}

.testimonials-dot:hover {
	background-color: var(--color-text-secondary);
	transform: scale(1.2);
}

.testimonials-dot.is-active {
	background-color: var(--color-primary);
	transform: scale(1.3);
}

.testimonials-dot:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: -8px;
}

.testimonial-card {
	position: relative;
	max-width: 720px;
	margin: 0 auto;
	background-color: var(--color-surface);
	border: 1px solid var(--color-border-light);
	border-radius: var(--radius-lg);
	padding: var(--card-pad-lg) var(--card-pad) var(--card-pad);
	box-shadow: var(--shadow-md);
}

.testimonial-quote-icon {
	color: var(--color-primary);
	opacity: 0.2;
	margin-bottom: 12px;
}

.testimonial-stars {
	display: flex;
	gap: 3px;
	color: var(--color-accent);
	margin-bottom: 16px;
}

.testimonial-quote {
	font-size: var(--font-size-sm);
	font-style: italic;
	line-height: 1.65;
	color: var(--color-text-secondary);
	margin-bottom: 20px;
}

.testimonial-author {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.testimonial-name {
	font-size: var(--font-size-sm);
	font-weight: 600;
	color: var(--color-text);
}

.testimonial-role {
	font-size: var(--font-size-xs);
	color: var(--color-text-muted);
}

@media (max-width: 768px) {
	.testimonials {
		padding: var(--section-padding-mobile) 0;
	}

	.testimonials-heading {
		margin-bottom: 40px;
	}

	.testimonial-card {
		padding: 28px var(--card-pad-mobile) var(--card-pad-mobile);
	}
}

/* Footer */

.footer {
	background-color: var(--color-text);
	color: #fff;
}

.footer .container {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 24px;
}

.footer-content {
	display: flex;
	gap: 64px;
	padding: var(--section-padding) 0;
}

.footer-main,
.footer-links {
	flex: 1 1 0;
	min-width: 0;
}

.footer-heading {
	font-size: var(--font-size-2xl);
	font-weight: 700;
	color: #fff;
	margin-bottom: 24px;
}

.footer-heading .accent {
	color: var(--color-primary-light);
}

.footer-text {
	color: rgba(255, 255, 255, 0.8);
	margin-bottom: 24px;
}

.footer-main .cta-button {
	margin-bottom: 0;
}

.footer-link-list {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 12px;
}

.footer-link {
	display: flex;
	align-items: center;
	gap: 10px;
	color: rgba(255, 255, 255, 0.8);
}

.footer-link:hover {
	color: #fff;
}

.footer-link .link-icon {
	margin-left: 0;
	flex-shrink: 0;
}

.footer-link-brand {
	flex-shrink: 0;
}

.footer-bar {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding: 24px 0;
}

.copyright {
	font-size: var(--font-size-xs);
	color: rgba(255, 255, 255, 0.5);
	text-align: center;
}

@media (max-width: 768px) {
	.footer-content {
		flex-direction: column;
		gap: 48px;
		padding: var(--section-padding-mobile) 0;
		text-align: center;
	}

	.footer-link-list {
		align-items: center;
	}
}
