/*
 * Layout base do tema.
 *
 * Responsabilidade: fornecer container, grid e espacamentos estruturais sem
 * criar layouts de paginas especificas.
 */

body {
	background: var(--rnen-color-background);
}

.rnen-container {
	width: min(100% - (var(--rnen-container-padding) * 2), var(--rnen-container-max-width));
	margin-inline: auto;
}

.rnen-container--narrow {
	width: min(100% - (var(--rnen-container-padding) * 2), var(--rnen-container-narrow-width));
}

.rnen-container--wide {
	width: min(100% - (var(--rnen-container-padding) * 2), var(--rnen-container-wide-width));
}

.rnen-section {
	padding-block: var(--rnen-space-12);
}

.rnen-section--compact {
	padding-block: var(--rnen-space-8);
}

.rnen-section--spacious {
	padding-block: var(--rnen-space-16);
}

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

.rnen-grid > * {
	min-width: 0;
}

.rnen-stack {
	display: flex;
	flex-direction: column;
	gap: var(--rnen-space-4);
}

.rnen-cluster {
	display: flex;
	flex-wrap: wrap;
	gap: var(--rnen-space-4);
	align-items: center;
}

@media (max-width: 47.9375rem) {
	:root {
		--rnen-container-padding: var(--rnen-space-4);
		--rnen-grid-gap: var(--rnen-space-4);
	}

	.rnen-section {
		padding-block: var(--rnen-space-8);
	}

	.rnen-section--spacious {
		padding-block: var(--rnen-space-12);
	}

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

@media (min-width: 48rem) {
	:root {
		--rnen-container-padding: var(--rnen-space-6);
	}
}
