/*
 * Keylink Builder — Base Styles
 * Clean foundation. No framework. No resets beyond what's needed.
 */

/* ─── Reset (minimal) ─── */
*, *::before, *::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

/* ─── Document ─── */
html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: var(--kit-font-body);
	font-size: var(--kit-font-size-base);
	line-height: var(--kit-line-height);
	color: var(--kit-text-dark);
	background-color: var(--kit-bg-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* ─── Typography ─── */
h1, h2, h3, h4, h5, h6 {
	font-family: var(--kit-font-heading);
	font-weight: 700;
	line-height: 1.2;
	color: var(--kit-text-dark);
}

h1 { font-size: var(--kit-text-5xl); }
h2 { font-size: var(--kit-text-4xl); }
h3 { font-size: var(--kit-text-2xl); }
h4 { font-size: var(--kit-text-xl); }

p {
	margin-bottom: var(--kit-space-sm);
}

a {
	color: var(--kit-brand-color);
	text-decoration: none;
	transition: opacity var(--kit-transition-fast);
}

a:hover {
	opacity: 0.8;
}

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

/* ─── Site Header ─── */
.kit-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--kit-bg-white);
	border-bottom: 1px solid var(--kit-border);
}

.kit-header-inner {
	max-width: var(--kit-container-width);
	margin: 0 auto;
	padding: var(--kit-space-sm) var(--kit-container-padding);
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.kit-site-name {
	font-family: var(--kit-font-heading);
	font-size: var(--kit-text-xl);
	font-weight: 700;
	color: var(--kit-text-dark);
	text-decoration: none;
}

.kit-nav-list {
	list-style: none;
	display: flex;
	gap: var(--kit-space-lg);
	align-items: center;
}

.kit-nav-list li a {
	font-size: var(--kit-text-sm);
	font-weight: 500;
	color: var(--kit-text-dark);
	text-decoration: none;
	padding: var(--kit-space-xs) 0;
	transition: color var(--kit-transition-fast);
}

.kit-nav-list li a:hover {
	color: var(--kit-brand-color);
	opacity: 1;
}

/* ─── Main Content ─── */
.kit-site-main {
	min-height: 60vh;
}

/* ─── Section System ─── */
.kit-section {
	position: relative;
}

.kit-section--spacing-tight {
	padding: var(--kit-section-padding-tight);
}

.kit-section--spacing-comfortable {
	padding: var(--kit-section-padding-comfortable);
}

.kit-section--spacing-spacious {
	padding: var(--kit-section-padding-spacious);
}

/* Backgrounds */
.kit-section--bg-white {
	background-color: var(--kit-bg-white);
	color: var(--kit-text-dark);
}

.kit-section--bg-light-gray {
	background-color: var(--kit-bg-light);
	color: var(--kit-text-dark);
}

.kit-section--bg-dark {
	background-color: var(--kit-bg-dark);
	color: var(--kit-text-light);
}

.kit-section--bg-dark h1,
.kit-section--bg-dark h2,
.kit-section--bg-dark h3,
.kit-section--bg-dark h4 {
	color: var(--kit-text-light);
}

.kit-section--bg-brand {
	background-color: var(--kit-brand-color);
	color: var(--kit-text-light);
}

.kit-section--bg-brand h1,
.kit-section--bg-brand h2,
.kit-section--bg-brand h3,
.kit-section--bg-brand h4 {
	color: var(--kit-text-light);
}

/* Width */
.kit-section--contained .kit-section__inner {
	max-width: var(--kit-container-width);
	margin: 0 auto;
	padding-left: var(--kit-container-padding);
	padding-right: var(--kit-container-padding);
}

.kit-section--full-width .kit-section__inner {
	max-width: 100%;
	padding-left: var(--kit-container-padding);
	padding-right: var(--kit-container-padding);
}

/* Text size modifiers */
.kit-section--text-small { font-size: 0.9em; }
.kit-section--text-normal { font-size: 1em; }
.kit-section--text-large { font-size: 1.1em; }

.kit-section--text-small h2 { font-size: var(--kit-text-3xl); }
.kit-section--text-large h2 { font-size: var(--kit-text-5xl); }

/* Mobile visibility */
@media (max-width: 768px) {
	.kit-section--hide-mobile {
		display: none;
	}
}

/* State: placed but not populated */
.kit-section--state-placed {
	border: 2px dashed var(--kit-border);
	min-height: 200px;
}

/* ─── Section Placeholder ─── */
.kit-section__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 200px;
	text-align: center;
	color: var(--kit-text-muted);
	font-size: var(--kit-text-lg);
}

/* ─── Common Section Elements ─── */
.kit-section__heading {
	margin-bottom: var(--kit-space-md);
}

.kit-section__subheading {
	font-size: var(--kit-text-lg);
	color: var(--kit-text-muted);
	margin-bottom: var(--kit-space-lg);
}

.kit-section__body {
	font-size: var(--kit-text-lg);
	line-height: var(--kit-line-height);
	max-width: 720px;
}

/* ─── Buttons ─── */
.kit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.75rem;
	font-family: var(--kit-font-body);
	font-size: var(--kit-text-base);
	font-weight: 600;
	border-radius: var(--kit-radius);
	border: none;
	cursor: pointer;
	transition: all var(--kit-transition);
	text-decoration: none;
}

.kit-btn--primary {
	background-color: var(--kit-brand-color);
	color: var(--kit-text-light);
}

.kit-btn--primary:hover {
	opacity: 0.9;
	transform: translateY(-1px);
}

.kit-btn--secondary {
	background: transparent;
	color: var(--kit-brand-color);
	border: 2px solid var(--kit-brand-color);
}

.kit-btn--secondary:hover {
	background: rgba(var(--kit-brand-color-rgb), 0.05);
}

/* ─── Responsive ─── */
@media (max-width: 768px) {
	h1 { font-size: var(--kit-text-3xl); }
	h2 { font-size: var(--kit-text-2xl); }
	h3 { font-size: var(--kit-text-xl); }

	.kit-header-inner {
		flex-direction: column;
		gap: var(--kit-space-sm);
	}

	.kit-nav-list {
		gap: var(--kit-space-md);
	}

	.kit-section--spacing-spacious {
		padding: var(--kit-section-padding-comfortable);
	}
}
