* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--kc-template-page-bg);
	color: var(--kc-color-ink);
	font-family: var(--kc-font-body);
	font-size: 16px;
	line-height: 1.6;
}

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

a {
	color: inherit;
}

.skip-link {
	position: absolute;
	left: var(--kc-space-4);
	top: -100px;
	z-index: 20;
	padding: var(--kc-space-3) var(--kc-space-4);
	background: var(--kc-color-red);
	color: var(--kc-color-white);
}

.skip-link:focus {
	top: var(--kc-space-4);
}

.shell {
	width: min(var(--kc-shell), calc(100% - 32px));
	margin: 0 auto;
}

.hero .shell {
	width: min(var(--kc-shell-wide), calc(100% - 32px));
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 10;
	border-bottom: 1px solid rgba(217, 236, 247, 0.16);
	background: rgba(7, 25, 35, 0.9);
	color: var(--kc-color-white);
	backdrop-filter: blur(16px);
}

.nav-shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--kc-space-5);
	min-height: 82px;
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: var(--kc-space-3);
	text-decoration: none;
}

.brand img {
	width: 56px;
	height: 56px;
}

.brand strong,
.brand small {
	display: block;
	letter-spacing: 0;
}

.brand strong {
	font-family: var(--kc-font-display);
	font-size: 1.2rem;
	line-height: 1;
}

.brand small {
	color: var(--kc-color-sky);
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
}

.nav {
	display: flex;
	align-items: center;
	gap: var(--kc-space-4);
	font-size: 0.88rem;
	font-weight: 800;
	text-transform: uppercase;
}

.nav a {
	position: relative;
	color: var(--kc-color-sky);
	text-decoration: none;
}

.nav a::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -8px;
	height: 3px;
	background: var(--kc-color-red);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 160ms ease;
}

.nav a:hover,
.nav a:focus-visible {
	color: var(--kc-color-white);
}

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

.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 var(--kc-space-5);
	border: 2px solid var(--kc-color-red);
	border-radius: var(--kc-radius-sm);
	background: var(--kc-color-red);
	color: var(--kc-color-white);
	font-weight: 900;
	text-decoration: none;
	transition:
		transform 160ms ease,
		box-shadow 160ms ease,
		background-color 160ms ease,
		border-color 160ms ease;
}

.button:hover,
.button:focus-visible {
	box-shadow: 5px 5px 0 var(--kc-color-ink);
	transform: translate(-2px, -2px);
}

.button-small {
	min-height: 38px;
	padding: 0 var(--kc-space-4);
	font-size: 0.86rem;
	white-space: nowrap;
}

.button-secondary {
	border-color: var(--kc-color-white);
	background: var(--kc-color-white);
	color: var(--kc-color-navy);
}

.button-outline {
	border-color: var(--kc-color-ink);
	background: var(--kc-color-white);
	color: var(--kc-color-ink);
}

.hero {
	position: relative;
	overflow: hidden;
	padding: clamp(64px, 7vw, 112px) 0 clamp(64px, 8vw, 120px);
	background:
		radial-gradient(circle at 78% 18%, rgba(217, 236, 247, 0.22), transparent 24%),
		linear-gradient(
			110deg,
			rgba(7, 25, 35, 0.94) 0%,
			rgba(9, 35, 55, 0.86) 46%,
			rgba(33, 109, 165, 0.5) 100%
		),
		url("/images/kendalls-canines/academy-puppy-closeup.jpg") center / cover;
	color: var(--kc-color-white);
}

.hero-main {
	background:
		radial-gradient(circle at 78% 18%, rgba(217, 236, 247, 0.2), transparent 24%),
		linear-gradient(
			110deg,
			rgba(7, 25, 35, 0.95) 0%,
			rgba(9, 35, 55, 0.88) 50%,
			rgba(33, 109, 165, 0.42) 100%
		),
		url("/images/kendalls-canines/working-dog-training.jpg") center / cover;
}

.hero::after {
	content: "";
	position: absolute;
	right: -10vw;
	bottom: -120px;
	width: 46vw;
	height: 220px;
	border-top: 18px solid var(--kc-color-red);
	transform: rotate(-7deg);
	opacity: 0.9;
}

.hero-grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(340px, 470px);
	gap: clamp(32px, 6vw, 72px);
	align-items: center;
}

.hero-copy {
	max-width: 720px;
}

.eyebrow {
	margin: 0 0 var(--kc-space-3);
	color: var(--kc-color-blue-soft);
	font-size: 0.78rem;
	font-weight: 900;
	letter-spacing: 0;
	text-transform: uppercase;
}

.hero .eyebrow {
	color: #a9daf8;
}

h1,
h2,
h3,
p {
	margin-top: 0;
}

h1,
h2,
h3 {
	font-family: var(--kc-font-display);
	line-height: 1.04;
	letter-spacing: 0;
}

h1 {
	max-width: 760px;
	margin-bottom: var(--kc-space-5);
	font-size: clamp(3rem, 7vw, 6.35rem);
}

h2 {
	margin-bottom: var(--kc-space-4);
	font-size: clamp(2rem, 4vw, 4rem);
}

h3 {
	margin-bottom: var(--kc-space-3);
	font-size: 1.55rem;
}

.lede {
	max-width: 650px;
	color: #edf8ff;
	font-size: clamp(1.1rem, 2vw, 1.35rem);
}

.hero-proof {
	display: flex;
	flex-wrap: wrap;
	gap: var(--kc-space-2);
	margin-top: var(--kc-space-5);
}

.hero-proof span {
	padding: var(--kc-space-2) var(--kc-space-3);
	border: 1px solid rgba(217, 236, 247, 0.3);
	border-radius: 999px;
	background: rgba(7, 25, 35, 0.38);
	color: var(--kc-color-sky);
	font-size: 0.86rem;
	font-weight: 850;
}

.actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--kc-space-3);
	margin-top: var(--kc-space-6);
}

.hero-card {
	position: relative;
	border: 4px solid var(--kc-color-white);
	background: var(--kc-color-white);
	box-shadow: var(--kc-shadow-float);
	transform: rotate(1.2deg);
}

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

.hero-card-panel {
	position: absolute;
	left: var(--kc-space-4);
	right: var(--kc-space-4);
	bottom: var(--kc-space-4);
	padding: var(--kc-space-4);
	border: 1px solid rgba(255, 255, 255, 0.18);
	background: rgba(7, 25, 35, 0.86);
	color: var(--kc-color-white);
	backdrop-filter: blur(12px);
}

.hero-card-panel strong,
.hero-card-panel span {
	display: block;
}

.hero-card-panel strong {
	font-family: var(--kc-font-display);
	font-size: 1.35rem;
}

.section {
	padding: clamp(64px, 8vw, 104px) 0;
	background: var(--kc-template-surface);
}

.section-light {
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0)), var(--kc-color-cream);
}

.section-dark {
	background: var(--kc-color-navy);
	color: var(--kc-color-white);
}

.split,
.trainer-grid,
.lead-card,
.footer-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.85fr) minmax(320px, 1fr);
	gap: clamp(28px, 5vw, 64px);
	align-items: start;
}

.stack {
	display: grid;
	gap: var(--kc-space-5);
	max-width: 650px;
}

.check-list {
	display: grid;
	gap: var(--kc-space-3);
	margin: 0;
	padding: 0;
	list-style: none;
}

.check-list li {
	position: relative;
	padding-left: 30px;
	font-weight: 750;
}

.check-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.65em;
	width: 16px;
	height: 4px;
	background: var(--kc-color-red);
}

.section-heading {
	max-width: 720px;
	margin-bottom: var(--kc-space-7);
}

.course-grid {
	display: grid;
	grid-template-columns: minmax(280px, 1.25fr) repeat(3, minmax(0, 1fr));
	gap: var(--kc-space-5);
}

.service-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--kc-space-4);
}

.course-card,
.service-card {
	display: flex;
	flex-direction: column;
	min-height: 280px;
	overflow: hidden;
	border: 1px solid var(--kc-color-line);
	border-radius: var(--kc-radius-md);
	background: var(--kc-color-cream-2);
	box-shadow: 0 12px 36px rgba(7, 25, 35, 0.08);
	transition:
		transform 160ms ease,
		box-shadow 160ms ease,
		border-color 160ms ease;
}

.service-card {
	padding: var(--kc-space-5);
}

.course-card-featured,
.service-card-featured {
	border: 2px solid var(--kc-color-ink);
	background: var(--kc-color-sky);
	box-shadow: var(--kc-shadow-hard);
}

.course-card:hover,
.service-card:hover {
	border-color: var(--kc-color-line-strong);
	box-shadow: var(--kc-shadow-soft);
	transform: translateY(-4px);
}

.course-card img {
	aspect-ratio: 16 / 10;
	width: 100%;
	object-fit: cover;
}

.status {
	display: inline-flex;
	margin-bottom: var(--kc-space-4);
	padding: var(--kc-space-1) var(--kc-space-3);
	border-radius: 999px;
	background: var(--kc-color-red);
	color: var(--kc-color-white);
	font-size: 0.75rem;
	font-weight: 900;
	text-transform: uppercase;
}

.status-muted {
	background: var(--kc-color-navy);
}

.course-card .status,
.course-card h3,
.course-card p,
.course-card a {
	margin-left: var(--kc-space-5);
	margin-right: var(--kc-space-5);
}

.course-card .status {
	align-self: flex-start;
	margin-top: var(--kc-space-5);
}

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

.service-card p,
.service-card li {
	color: var(--kc-color-muted);
}

.service-card ul {
	display: grid;
	gap: var(--kc-space-2);
	margin: auto 0 0;
	padding: var(--kc-space-4) 0 0;
	list-style: none;
}

.service-card li {
	position: relative;
	padding-left: 22px;
	font-weight: 800;
}

.service-card li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.72em;
	width: 12px;
	height: 3px;
	background: var(--kc-color-red);
}

.course-card a {
	display: inline-block;
	margin-top: var(--kc-space-4);
	margin-bottom: var(--kc-space-5);
	color: var(--kc-color-red-dark);
	font-weight: 900;
}

.service-card a {
	margin-top: auto;
	color: var(--kc-color-red-dark);
	font-weight: 900;
}

.trainer-grid {
	align-items: center;
}

.trainer-grid img {
	border: 4px solid var(--kc-color-white);
	border-radius: var(--kc-radius-md);
	box-shadow: var(--kc-shadow-hard);
}

.section-dark p {
	color: #dbeef9;
}

.proof-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--kc-space-3);
	margin-top: var(--kc-space-6);
}

.proof-row span {
	padding: var(--kc-space-2) var(--kc-space-3);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 999px;
	color: var(--kc-color-sky);
	font-size: 0.85rem;
	font-weight: 800;
}

.lead-card {
	align-items: center;
	padding: var(--kc-space-7);
	border: 2px solid var(--kc-color-ink);
	border-radius: var(--kc-radius-md);
	background: var(--kc-color-white);
	box-shadow: var(--kc-shadow-hard);
}

.cta-panel {
	display: flex;
	flex-wrap: wrap;
	gap: var(--kc-space-3);
}

.area-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--kc-space-3);
}

.area-grid span {
	border: 1px solid var(--kc-color-line);
	border-radius: var(--kc-radius-sm);
	background: var(--kc-color-cream-2);
	padding: var(--kc-space-3) var(--kc-space-4);
	color: var(--kc-color-muted);
	font-weight: 850;
}

.signup-form {
	display: grid;
	gap: var(--kc-space-4);
}

.signup-form label {
	display: grid;
	gap: var(--kc-space-2);
	color: var(--kc-color-muted);
	font-size: 0.86rem;
	font-weight: 900;
	text-transform: uppercase;
}

.signup-form input {
	min-height: 48px;
	border: 2px solid var(--kc-color-ink);
	border-radius: var(--kc-radius-sm);
	padding: 0 var(--kc-space-4);
	font: inherit;
}

.signup-form input:focus {
	outline: 3px solid rgba(33, 109, 165, 0.28);
	outline-offset: 2px;
}

.site-footer {
	padding: var(--kc-space-7) 0;
	background: var(--kc-color-ink);
	color: var(--kc-color-white);
}

.footer-grid {
	grid-template-columns: 1.4fr 1fr 1fr;
}

.site-footer p,
.site-footer span {
	color: var(--kc-color-sky);
}

.site-footer a,
.site-footer strong,
.site-footer span {
	display: block;
}

.site-footer a {
	margin-top: var(--kc-space-2);
	color: var(--kc-color-white);
}

.mobile-cta {
	display: none;
}

@media (max-width: 920px) {
	.nav {
		display: none;
	}

	.hero-grid,
	.split,
	.trainer-grid,
	.lead-card,
	.footer-grid {
		grid-template-columns: 1fr;
	}

	.course-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.service-grid,
	.area-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hero-card {
		max-width: 520px;
		transform: none;
	}
}

@media (max-width: 620px) {
	body {
		padding-bottom: 72px;
	}

	.nav-shell {
		min-height: 72px;
	}

	.brand img {
		width: 46px;
		height: 46px;
	}

	.brand strong {
		font-size: 1rem;
	}

	.button-small {
		display: none;
	}

	.hero {
		padding-top: var(--kc-space-7);
		padding-bottom: var(--kc-space-7);
	}

	.hero-grid {
		gap: var(--kc-space-6);
	}

	h1 {
		font-size: clamp(2.72rem, 15vw, 4.6rem);
	}

	h2 {
		font-size: clamp(2rem, 11vw, 3rem);
	}

	.actions {
		display: grid;
	}

	.actions .button:first-child {
		display: none;
	}

	.course-grid {
		grid-template-columns: 1fr;
	}

	.service-grid,
	.area-grid {
		grid-template-columns: 1fr;
	}

	.course-card {
		min-height: 0;
	}

	.lead-card {
		padding: var(--kc-space-5);
		box-shadow: 5px 5px 0 var(--kc-color-ink);
	}

	.mobile-cta {
		position: fixed;
		left: 12px;
		right: 12px;
		bottom: 12px;
		z-index: 12;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		min-height: 50px;
		border: 2px solid var(--kc-color-red);
		border-radius: var(--kc-radius-sm);
		background: var(--kc-color-red);
		color: var(--kc-color-white);
		box-shadow: 0 16px 36px rgba(7, 25, 35, 0.35);
		font-weight: 900;
		text-decoration: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		scroll-behavior: auto;
		transition-duration: 0.01ms;
		animation-duration: 0.01ms;
		animation-iteration-count: 1;
	}
}
