/*
 * Canopath — Component styles
 * Reusable UI primitives: buttons, cards, badges, navigation, footer.
 */

/* ============================================================
 * BUTTONS
 * ============================================================ */

.cn-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--cn-space-2);
	min-height: 44px;
	padding: 0 var(--cn-space-5);
	font-family: var(--cn-font-body);
	font-size: var(--cn-text-base);
	font-weight: 500;
	line-height: 1;
	text-decoration: none;
	border-radius: var(--cn-radius-pill);
	transition: transform var(--cn-dur-fast) var(--cn-ease-out),
	            background var(--cn-dur-fast) var(--cn-ease-out),
	            box-shadow var(--cn-dur-fast) var(--cn-ease-out),
	            color var(--cn-dur-fast) var(--cn-ease-out);
	white-space: nowrap;
}
.cn-btn:hover { transform: translateY(-1px); }
.cn-btn:active { transform: translateY(0); }

.cn-btn--primary {
	background: var(--cn-ink-800);
	color: var(--cn-cream);
}
.cn-btn--primary:hover {
	background: var(--cn-ink-700);
	color: var(--cn-cream);
	box-shadow: var(--cn-shadow-md);
}

.cn-btn--accent {
	background: var(--cn-coral-500);
	color: var(--cn-paper);
}
.cn-btn--accent:hover {
	background: var(--cn-coral-600);
	color: var(--cn-paper);
	box-shadow: var(--cn-shadow-md);
}

.cn-btn--ghost {
	background: transparent;
	color: var(--cn-ink-800);
	border: 1px solid var(--cn-ink-200);
}
.cn-btn--ghost:hover {
	background: var(--cn-paper);
	border-color: var(--cn-ink-800);
	color: var(--cn-ink-800);
}

.cn-btn--lg {
	min-height: 52px;
	padding: 0 var(--cn-space-6);
	font-size: var(--cn-text-lg);
}

.cn-btn--sm {
	min-height: 36px;
	padding: 0 var(--cn-space-4);
	font-size: var(--cn-text-sm);
}

.cn-btn--block {
	width: 100%;
}

/* ============================================================
 * BADGES & PILLS
 * ============================================================ */

.cn-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--cn-space-2);
	padding: 0.375rem 0.75rem;
	font-size: var(--cn-text-sm);
	font-weight: 500;
	border-radius: var(--cn-radius-pill);
	background: var(--cn-paper);
	color: var(--cn-ink-700);
	border: 1px solid var(--cn-ink-100);
}
.cn-badge--accent {
	background: var(--cn-coral-100);
	color: var(--cn-coral-800);
	border-color: var(--cn-coral-200);
}
.cn-badge--brand {
	background: var(--cn-teal-50);
	color: var(--cn-teal-700);
	border-color: var(--cn-teal-100);
}
.cn-badge::before {
	content: "";
	width: 6px; height: 6px;
	border-radius: 50%;
	background: currentColor;
	opacity: 0.6;
}

/* ============================================================
 * CARDS
 * ============================================================ */

.cn-card {
	background: var(--cn-paper);
	border-radius: var(--cn-radius-lg);
	padding: var(--cn-space-6);
	border: 1px solid var(--cn-ink-100);
	transition: transform var(--cn-dur-base) var(--cn-ease-out),
	            box-shadow var(--cn-dur-base) var(--cn-ease-out),
	            border-color var(--cn-dur-base) var(--cn-ease-out);
}
.cn-card--interactive:hover {
	transform: translateY(-3px);
	box-shadow: var(--cn-shadow-lg);
	border-color: var(--cn-ink-200);
}
.cn-card--featured {
	background: var(--cn-ink-800);
	color: var(--cn-cream);
	border-color: var(--cn-ink-800);
}
.cn-card--featured h3,
.cn-card--featured h4 {
	color: var(--cn-paper);
}

/* ============================================================
 * MARKETING NAV (HEADER)
 * ============================================================ */

.cn-nav {
	position: sticky;
	top: 0;
	z-index: var(--cn-z-sticky);
	background: rgba(250, 246, 239, 0.85);
	backdrop-filter: saturate(160%) blur(12px);
	-webkit-backdrop-filter: saturate(160%) blur(12px);
	border-bottom: 1px solid transparent;
	transition: border-color var(--cn-dur-fast) var(--cn-ease-out);
}
.cn-nav.is-scrolled {
	border-bottom-color: var(--cn-ink-100);
}

.cn-nav__shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--cn-space-6);
	padding: var(--cn-space-4) var(--cn-gutter-mobile);
	max-width: var(--cn-container-max);
	margin: 0 auto;
}
@media (min-width: 768px) {
	.cn-nav__shell { padding-left: var(--cn-gutter-desktop); padding-right: var(--cn-gutter-desktop); }
}

.cn-nav__brand {
	display: flex;
	align-items: center;
	gap: 0.625rem;
	font-family: var(--cn-font-display);
	font-size: 1.5rem;
	color: var(--cn-ink-800);
	text-decoration: none;
	letter-spacing: -0.02em;
}
.cn-nav__brand:hover { color: var(--cn-ink-800); }
.cn-nav__brand-mark {
	width: 28px; height: 28px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--cn-teal-600), var(--cn-coral-500) 130%);
	flex-shrink: 0;
}

.cn-nav__links {
	display: none;
	gap: var(--cn-space-6);
	font-size: var(--cn-text-base);
}
@media (min-width: 880px) {
	.cn-nav__links { display: flex; }
}

.cn-nav__link {
	color: var(--cn-ink-600);
	text-decoration: none;
	font-weight: 500;
	transition: color var(--cn-dur-fast) var(--cn-ease-out);
}
.cn-nav__link:hover, .cn-nav__link[aria-current="page"] {
	color: var(--cn-ink-800);
}

.cn-nav__actions {
	display: flex;
	align-items: center;
	gap: var(--cn-space-3);
}

.cn-nav__login {
	display: none;
	color: var(--cn-ink-600);
	font-size: var(--cn-text-base);
	font-weight: 500;
	text-decoration: none;
}
.cn-nav__login:hover { color: var(--cn-ink-800); }
@media (min-width: 640px) {
	.cn-nav__login { display: inline-flex; }
}

.cn-nav__burger {
	display: inline-flex;
	align-items: center; justify-content: center;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid var(--cn-ink-200);
	border-radius: var(--cn-radius-pill);
	cursor: pointer;
}
.cn-nav__burger:hover { border-color: var(--cn-ink-800); }
.cn-nav__burger-icon { width: 18px; height: 14px; position: relative; }
.cn-nav__burger-icon::before,
.cn-nav__burger-icon::after,
.cn-nav__burger-icon span {
	content: "";
	position: absolute;
	left: 0; right: 0;
	height: 1.5px;
	background: var(--cn-ink-800);
	border-radius: 1px;
	transition: transform var(--cn-dur-base) var(--cn-ease-out),
	            opacity var(--cn-dur-fast) var(--cn-ease-out);
}
.cn-nav__burger-icon::before { top: 0; }
.cn-nav__burger-icon span { top: 50%; transform: translateY(-50%); }
.cn-nav__burger-icon::after { bottom: 0; }
@media (min-width: 880px) { .cn-nav__burger { display: none; } }

/* Mobile drawer (toggled via JS adding .is-open) */
.cn-nav__drawer {
	display: none;
	position: absolute;
	top: 100%;
	left: 0; right: 0;
	background: var(--cn-cream);
	border-top: 1px solid var(--cn-ink-100);
	padding: var(--cn-space-4) var(--cn-gutter-mobile) var(--cn-space-6);
	box-shadow: var(--cn-shadow-lg);
}
.cn-nav.is-open .cn-nav__drawer { display: block; }
.cn-nav__drawer-list {
	display: flex; flex-direction: column;
	gap: var(--cn-space-4);
	margin: 0 0 var(--cn-space-4);
	padding: 0;
	list-style: none;
}
.cn-nav__drawer-link {
	display: block;
	font-size: var(--cn-text-lg);
	font-weight: 500;
	color: var(--cn-ink-800);
	text-decoration: none;
	padding: var(--cn-space-2) 0;
}
@media (min-width: 880px) { .cn-nav__drawer { display: none !important; } }

/* ============================================================
 * FOOTER
 * ============================================================ */

.cn-footer {
	background: var(--cn-ink-800);
	color: var(--cn-ink-200);
	padding: var(--cn-space-16) 0 var(--cn-space-8);
	margin-top: var(--cn-space-20);
}
.cn-footer a {
	color: var(--cn-ink-100);
	text-decoration: none;
}
.cn-footer a:hover { color: var(--cn-paper); text-decoration: underline; }

.cn-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--cn-space-10);
	margin-bottom: var(--cn-space-12);
}
@media (min-width: 720px) {
	.cn-footer__grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; }
}

.cn-footer__col h6 {
	color: var(--cn-paper);
	margin-bottom: var(--cn-space-4);
	font-size: var(--cn-text-xs);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	opacity: 0.85;
}

.cn-footer__brand {
	display: flex; align-items: center; gap: var(--cn-space-3);
	font-family: var(--cn-font-display);
	font-size: 1.625rem;
	color: var(--cn-paper);
	margin-bottom: var(--cn-space-4);
}
.cn-footer__brand .cn-nav__brand-mark { width: 32px; height: 32px; }

.cn-footer__tag {
	max-width: 360px;
	color: var(--cn-ink-200);
	font-size: var(--cn-text-base);
	line-height: var(--cn-leading-relaxed);
}

.cn-footer__links {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex; flex-direction: column;
	gap: var(--cn-space-3);
}

.cn-footer__legal {
	border-top: 1px solid rgba(250, 246, 239, 0.12);
	padding-top: var(--cn-space-6);
	display: flex; flex-direction: column;
	gap: var(--cn-space-4);
	font-size: var(--cn-text-sm);
	color: var(--cn-ink-300);
	line-height: var(--cn-leading-relaxed);
}
.cn-footer__compliance {
	max-width: 720px;
}
.cn-footer__row {
	display: flex; flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--cn-space-4);
}
.cn-footer__row-links {
	display: flex; flex-wrap: wrap;
	gap: var(--cn-space-5);
	list-style: none;
	padding: 0; margin: 0;
}
