/**
 * Global base styles.
 *
 * @package Fundamento
 */

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

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

body {
	margin: 0;
	min-height: 100vh;
	font-family: var(--font-family-body);
	font-size: var(--text-body-md-size);
	font-weight: 400;
	line-height: var(--text-body-md-lh);
	letter-spacing: var(--text-body-md-ls);
	color: var(--color-text-default);
	background-color: var(--color-bg-default);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

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

input,
button,
textarea,
select {
	font: inherit;
	color: inherit;
}

a {
	color: var(--color-brand-default);
	text-decoration-thickness: 1px;
	text-underline-offset: 0.15em;
}

a:hover {
	color: var(--color-brand-hover);
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	font-family: var(--font-family-display);
	font-weight: 400;
	line-height: var(--text-display-h2-lh);
}

h1 {
	font-size: var(--text-display-h1-alt-size);
	line-height: var(--text-display-h1-alt-lh);
	letter-spacing: var(--text-display-h1-alt-ls);
}

h2 {
	font-size: var(--text-display-h2-size);
	line-height: var(--text-display-h2-lh);
	letter-spacing: var(--text-display-h2-ls);
}

h3 {
	font-size: var(--text-display-h3-size);
	line-height: var(--text-display-h3-lh);
	letter-spacing: var(--text-display-h3-ls);
}

h4 {
	font-size: var(--text-display-h4-size);
	line-height: var(--text-display-h4-lh);
	letter-spacing: var(--text-display-h4-ls);
}

h5 {
	font-size: var(--text-display-h5-size);
	line-height: var(--text-display-h5-lh);
	letter-spacing: var(--text-display-h5-ls);
}

h6 {
	font-size: var(--text-display-h6-size);
	line-height: var(--text-display-h6-lh);
	letter-spacing: var(--text-display-h6-ls);
}

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

p:last-child {
	margin-bottom: 0;
}

ul,
ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

.site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.site-main {
	flex: 1;
}

/* -------------------------------------------------------------------------
   Bootstrap container overrides — align with design tokens
   ------------------------------------------------------------------------- */

.container {
	max-width: var(--container-max-width);
	padding-right: var(--container-padding-inline);
	padding-left: var(--container-padding-inline);
}

@media (min-width: 64rem) {
	.container {
		padding-right: var(--container-padding-inline-lg);
		padding-left: var(--container-padding-inline-lg);
	}
}

/* -------------------------------------------------------------------------
   Section spacing
   ------------------------------------------------------------------------- */

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

.section--sm {
	padding-block: var(--space-48);
}

.section--lg {
	padding-block: var(--space-128);
}

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
	word-wrap: normal;
}

.screen-reader-text:focus {
	background-color: var(--color-surface-default);
	border-radius: var(--radius-xs);
	clip: auto;
	clip-path: none;
	color: var(--color-text-default);
	display: block;
	font-size: var(--text-body-sm-size);
	height: auto;
	left: var(--space-8);
	line-height: normal;
	padding: var(--space-12) var(--space-16);
	text-decoration: none;
	top: var(--space-8);
	width: auto;
	z-index: 100000;
}
