/* layout.css — container, grids, section spacing, kicker labels. */

.container {
	width: 100%;
	max-width: var(--max-w);
	margin: 0 auto;
	padding-left: var(--s-24);
	padding-right: var(--s-24);
}

@media (min-width: 768px) {
	.container {
		padding-left: var(--s-32);
		padding-right: var(--s-32);
	}
}

main {
	min-height: 60vh;
	padding-top: var(--header-h);
}

.section {
	padding-top: var(--s-80);
	padding-bottom: var(--s-80);
}

.section--tight {
	padding-top: var(--s-48);
	padding-bottom: var(--s-48);
}

.section--spacious {
	padding-top: var(--s-128);
	padding-bottom: var(--s-128);
}

.section--surface {
	background: var(--c-surface);
}

.section--surface2 {
	background: var(--c-surface2);
}

.section--special {
	background: var(--c-special);
}

/* Two-column layout */
.two-col {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-48);
	align-items: center;
}

.two-col__content,
.two-col__media {
	min-width: 0;
}

@media (min-width: 1024px) {
	.two-col {
		grid-template-columns: 1fr 1fr;
		gap: var(--s-80);
	}
	.two-col--55-45 {
		grid-template-columns: 55fr 45fr;
	}
	.two-col--60-40 {
		grid-template-columns: 60fr 40fr;
	}
	.two-col--reversed .two-col__media {
		order: -1;
	}
}

/* Generic grids */
.grid-2 { display: grid; grid-template-columns: 1fr; gap: var(--s-24); }
.grid-3 { display: grid; grid-template-columns: 1fr; gap: var(--s-24); }
.grid-4 { display: grid; grid-template-columns: 1fr; gap: var(--s-24); }
.grid-5 { display: grid; grid-template-columns: 1fr; gap: var(--s-24); }

@media (min-width: 768px) {
	.grid-2, .grid-3 { grid-template-columns: repeat(2, 1fr); }
	.grid-4, .grid-5 { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
	.grid-3 { grid-template-columns: repeat(3, 1fr); }
	.grid-4 { grid-template-columns: repeat(4, 1fr); }
	.grid-5 { grid-template-columns: repeat(5, 1fr); }
}

/* Kicker label — Inter Tight uppercase, cream */
.kicker {
	font-family: var(--f-body);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 2.25px;
	text-transform: uppercase;
	color: var(--c-accent-sec);
	margin-bottom: var(--s-16);
	display: inline-block;
}

.section-head {
	margin-bottom: var(--s-48);
	max-width: 720px;
}

.section-head h2 {
	margin-bottom: var(--s-16);
}

.section-head p {
	color: var(--c-text-dim);
	font-size: 1.0625rem;
}

.centered {
	text-align: center;
}

.centered .kicker,
.centered .section-head {
	margin-left: auto;
	margin-right: auto;
}

.media-frame {
	position: relative;
	border: 1px solid var(--c-border);
	overflow: hidden;
	border-radius: var(--r-md);
}

.media-frame img {
	width: 100%;
	display: block;
}

/* Align helpers */
.flex { display: flex; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-col { display: flex; flex-direction: column; }
.gap-8 { gap: var(--s-8); }
.gap-16 { gap: var(--s-16); }
.gap-24 { gap: var(--s-24); }

.stack > * + * { margin-top: var(--s-16); }
.stack-lg > * + * { margin-top: var(--s-32); }

/* Feature list (three-tick separators between items) */
.feature-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.feature-list li {
	padding: var(--s-16) 0;
	border-bottom: 1px solid var(--c-border);
	position: relative;
	padding-left: var(--s-32);
}

.feature-list li:last-child {
	border-bottom: 0;
}

.feature-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
	height: 1px;
	background-image: linear-gradient(to right,
		var(--c-accent) 0 6px,
		transparent 6px 8px,
		var(--c-accent) 8px 14px,
		transparent 14px 16px,
		var(--c-accent) 16px 20px
	);
}

.feature-list strong {
	display: block;
	font-family: var(--f-heading);
	font-weight: 500;
	font-size: 1.0625rem;
	color: var(--c-text);
	margin-bottom: var(--s-4);
}
