/*
 * Canopath — Base styles
 * Reset + element defaults. Loaded after tokens.css.
 */

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

html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	margin: 0;
	font-family: var(--cn-font-body);
	font-size: var(--cn-text-base);
	line-height: var(--cn-leading-normal);
	color: var(--cn-ink-700);
	background: var(--cn-cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

/* Headings — Instrument Serif for display, Inter for utility */
h1, h2, h3, h4, h5, h6 {
	margin: 0 0 var(--cn-space-4);
	font-family: var(--cn-font-display);
	font-weight: 400;        /* serif looks cleaner at 400 */
	line-height: var(--cn-leading-tight);
	color: var(--cn-ink-800);
	letter-spacing: -0.01em;
}

h1 { font-size: var(--cn-text-5xl); }
h2 { font-size: var(--cn-text-4xl); }
h3 { font-size: var(--cn-text-3xl); }
h4 {
	font-size: var(--cn-text-xl);
	font-family: var(--cn-font-body);
	font-weight: 600;
	letter-spacing: -0.005em;
}
h5 {
	font-size: var(--cn-text-lg);
	font-family: var(--cn-font-body);
	font-weight: 600;
}
h6 {
	font-size: var(--cn-text-base);
	font-family: var(--cn-font-body);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-transform: uppercase;
}

p { margin: 0 0 var(--cn-space-4); }

a {
	color: var(--cn-teal-600);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 0.18em;
	transition: color var(--cn-dur-fast) var(--cn-ease-out);
}
a:hover {
	color: var(--cn-teal-500);
}

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

/* Forms — base */
input, textarea, select, button {
	font: inherit;
	color: inherit;
}

input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
textarea,
select {
	width: 100%;
	padding: 0.75rem 1rem;
	font-size: var(--cn-text-base);    /* must be ≥16px to prevent iOS zoom */
	background: var(--cn-paper);
	border: 1px solid var(--cn-ink-100);
	border-radius: var(--cn-radius-md);
	transition: border-color var(--cn-dur-fast) var(--cn-ease-out),
	            box-shadow var(--cn-dur-fast) var(--cn-ease-out);
}
input:focus, textarea:focus, select:focus {
	outline: none;
	border-color: var(--cn-teal-500);
	box-shadow: 0 0 0 3px rgba(42, 138, 130, 0.18);
}

button {
	cursor: pointer;
	border: 0;
	background: transparent;
}

/* Selection */
::selection {
	background: var(--cn-coral-200);
	color: var(--cn-ink-800);
}

/* Layout primitives */
.cn-shell {
	max-width: var(--cn-container-max);
	margin: 0 auto;
	padding-left: var(--cn-gutter-mobile);
	padding-right: var(--cn-gutter-mobile);
}
@media (min-width: 768px) {
	.cn-shell {
		padding-left: var(--cn-gutter-desktop);
		padding-right: var(--cn-gutter-desktop);
	}
}
.cn-shell--narrow {
	max-width: var(--cn-container-narrow);
}

.cn-section {
	padding: clamp(3rem, 6vw, 6rem) 0;
}

/* Skip link */
.cn-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	background: var(--cn-ink-800);
	color: var(--cn-cream);
	padding: var(--cn-space-3) var(--cn-space-4);
	z-index: var(--cn-z-toast);
	border-radius: 0 0 var(--cn-radius-md) 0;
}
.cn-skip-link:focus {
	left: 0;
	color: var(--cn-cream);
}

/* Visually-hidden utility (for accessibility) */
.cn-sr-only {
	position: absolute;
	width: 1px; height: 1px;
	padding: 0; margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}
