/*
* 1. Variables
* 2. Setup
	2.1. Resets
	2.2. Basic settings
* 3. Blocks
	3.1 Wraps
	3.2 Grids and flexboxes
	3.3 Content placement
	3.4 Content flow
* 4. Elements
	4.1 Buttons
	4.2 Inputs
	4.3 Checkboxes
	4.4 Images
	4.5 Videos
	4.6 Icons
	4.7 Modals
* 5. Utilities
	5.1. Generic
	5.2. Size
	5.3. Paddings and margins
	5.4. Placement
	5.5. Animations
	5.6. Responsivity
* 6. Typography
	6.1 Basic settings
	6.2 Elements
	6.3 Modifiers
*/

/*
* 1. Variables
*/
:root {
	--wrap-outer-width: calc(var(--wrap-width) + var(--wrap-padding) * 2);

	/* colors */
	--clr-primary-100: hsl(var(--clr-primary-hsl-100));
	--clr-primary-200: hsl(var(--clr-primary-hsl-200));
	--clr-primary-300: hsl(var(--clr-primary-hsl-300));
	--clr-primary-400: hsl(var(--clr-primary-hsl-400));
	--clr-primary-500: hsl(var(--clr-primary-hsl-500));
	--clr-primary-700: hsl(var(--clr-primary-hsl-700));
	--clr-primary-800: hsl(var(--clr-primary-hsl-800));
	--clr-secondary-100: hsl(var(--clr-secondary-hsl-100));
	--clr-secondary-200: hsl(var(--clr-secondary-hsl-200));
	--clr-secondary-300: hsl(var(--clr-secondary-hsl-300));
	--clr-secondary-400: hsl(var(--clr-secondary-hsl-400));
	--clr-secondary-500: hsl(var(--clr-secondary-hsl-500));
	--clr-secondary-700: hsl(var(--clr-secondary-hsl-700));
	--clr-secondary-800: hsl(var(--clr-secondary-hsl-800));
	--clr-tertiary-100: hsl(var(--clr-tertiary-hsl-100));
	--clr-tertiary-200: hsl(var(--clr-tertiary-hsl-200));
	--clr-tertiary-300: hsl(var(--clr-tertiary-hsl-300));
	--clr-tertiary-400: hsl(var(--clr-tertiary-hsl-400));
	--clr-tertiary-500: hsl(var(--clr-tertiary-hsl-500));
	--clr-tertiary-700: hsl(var(--clr-tertiary-hsl-700));
	--clr-tertiary-800: hsl(var(--clr-tertiary-hsl-800));

	--clr-neutral-100: hsl(var(--clr-neutral-hsl-100));
	--clr-neutral-150: hsl(var(--clr-neutral-hsl-150));
	--clr-neutral-200: hsl(var(--clr-neutral-hsl-200));
	--clr-neutral-300: hsl(var(--clr-neutral-hsl-300));
	--clr-neutral-400: hsl(var(--clr-neutral-hsl-400));
	--clr-neutral-500: hsl(var(--clr-neutral-hsl-500));
	--clr-neutral-600: hsl(var(--clr-neutral-hsl-600));
	--clr-neutral-700: hsl(var(--clr-neutral-hsl-700));
	--clr-neutral-800: hsl(var(--clr-neutral-hsl-800));
	--clr-neutral-900: hsl(var(--clr-neutral-hsl-900));

	--clr-background: hsl(var(--clr-background-hsl));
}

@media (max-width: 480px) {
	:root {
		--wrap-padding: 1rem;
	}
}

/*
* 2. Setup
*/
/* 2.1. Resets */
* {
	padding: 0;
	margin: 0;
	box-sizing: border-box;
	background-repeat: no-repeat;
	outline: none;
	font: inherit;
	-webkit-tap-highlight-color: rgba(255, 255, 255, 0);
}

html {
	font-size: 100%;
}

ul {
	list-style-type: none;
}

img,
svg {
	display: block;
	max-width: 100%;
}

a {
	color: unset;
	text-decoration: none;
}

/* 2.2. Basic settings */
body {
	background-color: var(--clr-background);
	color: var(--fc-400);
	font-family: var(--ff-default);
	font-size: var(--fs-400);
	font-weight: var(--fs-400);
	line-height: 1.6;
}

body:has(.modal.open),
body.fixed {
	overflow: hidden;
}

/*
* 3. Blocks
*/
/* 3.1 Wraps */
.main-wrap {
	max-width: var(--wrap-outer-width);
	padding-inline: var(--wrap-padding);
	margin-inline: auto;
}

.half-wrap--left {
	padding-left: calc((100vw - var(--wrap-outer-width) - var(--wrap-padding) / 2) / 2);
	margin-left: var(--wrap-padding);
}

.half-wrap--right {
	max-width: calc(var(--wrap-outer-width) / 2);
	padding-right: var(--wrap-padding);
}

/* 3.2 Grids and flexboxes */
.grid-flow {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
}

.grid-flow[data-columns='2'] {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.grid-flow[data-columns='15rem'] {
	grid-template-columns: repeat(auto-fill, minmax(min(15rem, 100%), 1fr));
}

.grid-flow[data-columns='20rem'] {
	grid-template-columns: repeat(auto-fill, minmax(min(20rem, 100%), 1fr));
}

.grid-flow[data-columns='25rem'] {
	grid-template-columns: repeat(auto-fill, minmax(min(25rem, 100%), 1fr));
}

.grid-flow[data-columns='30rem'] {
	grid-template-columns: repeat(auto-fill, minmax(min(30rem, 100%), 1fr));
}

.grid-flow[data-columns='40rem'] {
	grid-template-columns: repeat(auto-fill, minmax(min(40rem, 100%), 1fr));
}

.flex-group {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}

/* 3.3 Content placement */
.center-content {
	text-align: center;
}

.center-content:where(.grid-flow) {
	place-items: center;
	align-content: normal;
}

.center-content:where(.flex-group) {
	place-content: center;
}

.stack-content {
	grid-template-rows: minmax(0, 1fr);
}

.stack-content > * {
	grid-row: 1;
	grid-column: 1;
	position: relative;
}

.grid-flow[data-align='top'],
.flex-group[data-align='top'] {
	align-items: flex-start;
}

.grid-flow[data-justify='left'],
.flex-group[data-justify='left'] {
	justify-content: left;
}

.grid-flow[data-justify='right'],
.flex-group[data-justify='right'] {
	justify-content: right;
}

/* 3.4 Content flow */
.grid-flow:where([data-spacing='100']),
.flex-group:where([data-spacing='100']) {
	gap: 0.25rem;
}

.grid-flow:where([data-spacing='200']),
.flex-group:where([data-spacing='200']) {
	gap: 0.5rem;
}

.grid-flow:where([data-spacing='300']),
.flex-group:where([data-spacing='300']) {
	gap: 0.75rem;
}

.grid-flow:where([data-spacing='400']),
.flex-group:where([data-spacing='400']) {
	gap: 1rem;
}

.grid-flow:where([data-spacing='500']),
.flex-group:where([data-spacing='500']) {
	gap: 1.25rem;
}

.grid-flow:where([data-spacing='600']),
.flex-group:where([data-spacing='600']) {
	gap: 1.5rem;
}

.grid-flow:where([data-spacing='700']),
.flex-group:where([data-spacing='700']) {
	gap: 2rem;
}

.grid-flow:where([data-spacing='750']),
.flex-group:where([data-spacing='750']) {
	gap: 3rem;
}

.grid-flow:where([data-spacing='800']),
.flex-group:where([data-spacing='800']) {
	gap: 4rem;
}

.grid-flow:where([data-spacing='900']),
.flex-group:where([data-spacing='900']) {
	gap: 7rem;
}

.grid-flow:where([data-spacing='1000']),
.flex-group:where([data-spacing='1000']) {
	gap: 10rem;
}

.grid-flow:where([data-column-spacing='200']),
.flex-group:where([data-column-spacing='200']) {
	column-gap: 0.5rem;
}

.grid-flow:where([data-column-spacing='300']),
.flex-group:where([data-column-spacing='300']) {
	column-gap: 0.75rem;
}

.grid-flow:where([data-column-spacing='400']),
.flex-group:where([data-column-spacing='400']) {
	column-gap: 1rem;
}

.grid-flow:where([data-column-spacing='500']),
.flex-group:where([data-column-spacing='500']) {
	column-gap: 1.25rem;
}

.grid-flow:where([data-column-spacing='600']),
.flex-group:where([data-column-spacing='600']) {
	column-gap: 1.5rem;
}

.grid-flow:where([data-column-spacing='700']),
.flex-group:where([data-column-spacing='700']) {
	column-gap: 2rem;
}

.grid-flow:where([data-column-spacing='800']),
.flex-group:where([data-column-spacing='800']) {
	column-gap: 4rem;
}

.grid-flow:where([data-column-spacing='900']),
.flex-group:where([data-column-spacing='900']) {
	column-gap: 7rem;
}

.grid-flow:where([data-column-spacing='1000']),
.flex-group:where([data-column-spacing='1000']) {
	column-gap: 10rem;
}

.grid-flow:where([data-row-spacing='200']),
.flex-group:where([data-row-spacing='200']) {
	row-gap: 0.5rem;
}

.grid-flow:where([data-row-spacing='300']),
.flex-group:where([data-row-spacing='300']) {
	row-gap: 0.75rem;
}

.grid-flow:where([data-row-spacing='400']),
.flex-group:where([data-row-spacing='400']) {
	row-gap: 1rem;
}

.grid-flow:where([data-row-spacing='500']),
.flex-group:where([data-row-spacing='500']) {
	row-gap: 1.25rem;
}

.grid-flow:where([data-row-spacing='600']),
.flex-group:where([data-row-spacing='600']) {
	row-gap: 1.5rem;
}

.grid-flow:where([data-row-spacing='700']),
.flex-group:where([data-row-spacing='700']) {
	row-gap: 2rem;
}

.grid-flow:where([data-row-spacing='800']),
.flex-group:where([data-row-spacing='800']) {
	row-gap: 4rem;
}

.grid-flow:where([data-row-spacing='900']),
.flex-group:where([data-row-spacing='900']) {
	row-gap: 7rem;
}

.grid-flow:where([data-row-spacing='1000']),
.flex-group:where([data-row-spacing='1000']) {
	row-gap: 10rem;
}

/*
* 4. Elements
*/
/* 4.1 Buttons */
.button {
	--_padding-block: 1.1em;
	display: inline-block;
	width: 12.5rem;
	max-width: 100%;
	padding: calc(var(--_padding-block) - var(--_border-width, 0px)) 2.2em;
	background-color: var(--clr-primary-400);
	border-width: var(--_border-width, 0);
	border-style: solid;
	border-radius: var(--border-radius-1000);
	color: var(--button--primary-fc);
	font-family: var(--ff-titles);
	font-size: var(--fs-400);
	font-weight: var(--button-fw);
	line-height: 1;
	text-align: center;
	cursor: pointer;
	transition: background-color 0.3s, border 0.3s, color 0.3s;
}

.button:where(:not(.button--secondary):not(.button--empty)):hover {
	background-color: var(--clr-primary-500);
}

.button:disabled {
	filter: saturate(0);
	pointer-events: none;
}

.button--secondary {
	--_border-width: var(--button--secondary-border-width);
	background-color: transparent;
	color: var(--fc-700);
	border-color: var(--border-clr-700);
}

.button--secondary:hover {
	color: var(--clr-primary-400);
	border-color: var(--clr-primary-400);
}

.button--secondary.button--bad {
	color: var(--clr-bad-400);
	border-color: var(--clr-bad-400);
}

.button--secondary.button--bad:hover {
	color: var(--clr-bad-500);
	border-color: var(--clr-bad-500);
}

.button--empty {
	background-color: transparent;
	color: var(--fc-700);
}

.button--empty:hover {
	color: var(--clr-primary-400);
}

.button--auto-width {
	width: max-content;
	max-width: 100%;
}

.button--full-width {
	width: 100%;
	padding-inline: 0;
}

/* 4.2 Inputs */
.form-field {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: 0.25rem 0.5rem;
}

input,
select,
textarea {
	width: 100%;
	padding-inline: 1em;
	border: var(--inp-border-width) solid transparent;
	border-radius: var(--inp-border-radius);
	background-color: var(--inp-clr-bgr);
	color: var(--inp-fc);
	font-family: var(--ff-default);
	font-size: var(--inp-fs);
	transition: border-color 0.2s;
}

[data-theme='dark'] input::placeholder,
[data-theme='dark'] select::placeholder,
[data-theme='dark'] textarea::placeholder {
	color: var(--fc-400);
}

input:-webkit-autofill,
select:-webkit-autofill,
textarea:-webkit-autofill {
	background-color: var(--inp-clr-bgr);
	border: var(--inp-border-width) solid var(--inp-clr-bgr);
	box-shadow: 0 0 0 1000px var(--inp-clr-bgr) inset !important;
	-webkit-box-shadow: 0 0 0 1000px var(--inp-clr-bgr) inset;
	-webkit-text-fill-color: var(--inp-fc);
	color: var(--inp-fc);
}

input {
	line-height: var(--inp-height);
}

input:focus {
	border-color: var(--inp-clr-accent);
	box-shadow: var(--inp-shadow);
}

select {
	height: var(--inp-height);
}

select optgroup {
	font-family: var(--font-text);
}

textarea {
	min-height: 5em;
	resize: none;
	padding: 0.5em 1em;
	line-height: 1.25;
}

textarea:focus {
	border-color: var(--inp-clr-accent);
	box-shadow: var(--inp-shadow);
}

.price-input {
	position: relative;
}

.price-input input {
	padding-right: 2rem;
}

.price-input::after {
	content: '€';
	position: absolute;
	top: 50%;
	right: 1rem;
	translate: 0 -50%;
	font-weight: var(--fw-semibold);
}

.special-input {
	position: relative;
}

.special-input input {
	--inp-clr-bgr: var(--clr-neutral-100);
	padding-inline: unset;
	font-size: var(--fs-400);
	border: none;
	border-bottom: var(--inp-border-width) solid var(--border-clr-700);
	border-radius: unset;
	box-shadow: unset;
}

.special-input input:focus {
	border-color: var(--inp-clr-accent);
}

.special-input .icon-embed {
	--icon-size: 1.25rem;
	position: absolute;
	inset: 0 0.5rem 0 auto;
	margin-block: auto;
	color: var(--border-clr-700);
}

.special-input:has(:focus) .icon-embed {
	color: var(--inp-clr-accent);
}

.label {
	margin-bottom: 0.25em;
	color: var(--fc-700);
	font-weight: var(--fw-semibold);
}

.label--required::after {
	content: '*';
	color: darkred;
	margin-left: 0.25em;
}

@media (min-width: 481px) {
	.form-field {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.form-field > * {
		grid-column: span 4;
	}

	.form-field [data-size='2'] {
		grid-column: span 2;
	}
}

/* 4.3 Checkboxes */
.checkbox {
	display: grid;
	grid-template-columns: calc(1.25rem + 2px) minmax(0, 1fr);
	align-items: center;
	gap: 0.5rem;
	position: relative;
	width: max-content;
	max-width: 100%;
}

.checkbox input {
	opacity: 0;
	position: absolute;
	pointer-events: none;
}

.checkbox > span {
	display: flex;
	width: 100%;
	aspect-ratio: 1;
	margin-block: 2px;
	margin-left: 2px;
	border: var(--border-width) solid var(--border-clr-400);
	border-radius: 50%;
	cursor: pointer;
	transition: border-color 0.2s;
}

.checkbox input:checked + span {
	border-color: var(--fc-700);
}

.checkbox > span::after {
	content: '';
	width: 8px;
	aspect-ratio: 1;
	margin: auto;
	opacity: 0;
	background-color: var(--clr-primary-400);
	border-radius: inherit;
	transition: opacity 0.2s;
}

.checkbox:hover span::after,
.checkbox input:checked + span::after {
	opacity: 1;
}

@media (hover: none) {
	.checkbox input:not(:checked) + span {
		border-color: var(--border-clr-400);
	}

	.checkbox input:not(:checked) + span::after {
		opacity: 0;
	}
}

.checkbox p {
	line-height: 1;
	cursor: pointer;
}

/* 4.4 Images */
.image-fill {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.image-fit {
	width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.image-cover {
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
	object-fit: cover;
}

:has(> .image-cover) {
	position: relative;
}

.background-fill {
	background-position: center;
	background-size: cover;
}

.background-fit {
	background-position: center;
	background-size: contain;
}

.replace-image {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	place-items: center;
	width: max-content;
	max-width: 100%;
	cursor: pointer;
}

.replace-image input {
	display: none;
}

.replace-image img,
.replace-image::before,
.replace-image::after {
	grid-row: 1;
	grid-column: 1;
}

.replace-image::before {
	content: '';
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	opacity: 0;
	background-color: rgba(0, 0, 0, 0.7);
	transition: opacity 0.2s;
}

.replace-image--fixed::before,
.replace-image:hover::before {
	opacity: 1;
}

.replace-image::after {
	content: '';
	position: relative;
	z-index: 1;
	translate: 0 1rem;
	width: 3rem;
	aspect-ratio: 1;
	opacity: 0;
	background-image: url(../assets/icons/upload.svg);
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	filter: invert(1);
	transition: translate 0.2s, opacity 0.2s;
}

.replace-image--fixed::after,
.replace-image:hover::after {
	translate: 0 0;
	opacity: 1;
}

/* 4.5 Videos */
.playable-video {
	display: grid;
	position: relative;
}

.playable-video > * {
	grid-column: 1;
	grid-row: 1;
}

.playable-video video {
	width: 100%;
	object-fit: cover;
}

.playable-video__overlay {
	display: grid;
	place-items: center;
	position: relative;
	width: 100%;
	height: 100%;
	background-color: hsl(0, 0%, 5%, 0.5);
	cursor: pointer;
	transition: opacity 0.3s;
}

.playable-video.is-playing .playable-video__overlay {
	opacity: 0;
	pointer-events: none;
}

.playable-video__play-button {
	--icon-size: 45%;
	width: 4rem;
	height: 4rem;
	opacity: 0.7;
	background-color: hsl(0, 0%, 100%, 0.9);
	border-radius: 50%;
	color: #202020;
	transition: opacity 0.3s, background-color 0.3s, color 0.3s;
}

.playable-video__overlay:hover .playable-video__play-button {
	opacity: 1;
	background-color: hsl(0, 0%, 100%, 1);
}

.playable-video__play-button .icon-embed {
	translate: 0.2rem 0;
}

/* 4.6 Icons */
.icon-embed {
	width: var(--icon-size, 100%);
	max-width: 100%;
	max-height: 100%;
	aspect-ratio: 1;
	margin: auto;
	fill: currentColor;
	transition: fill 0.3s, color 0.3s;
}

*:has(> .icon-embed) {
	display: flex;
}

.button:has(.icon-embed) {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.5em;
}

.button .icon-embed {
	width: 1em;
	margin: unset;
	transition: unset;
}

/* 4.7 Modals */
.modal {
	display: flex;
	position: fixed;
	inset: 0;
	z-index: 100;
	visibility: hidden;
	opacity: 0;
	transition: opacity 0.3s;
}

.modal::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: -1;
	background-color: rgba(20, 20, 20, 0.6);
	backdrop-filter: saturate(0.5);
}

.modal.open {
	visibility: visible;
	opacity: 1;
}

.modal__close {
	opacity: 1;
	background-image: url(../assets/icons/close.svg);
	background-position: center;
	background-size: contain;
	width: 1.5rem;
	aspect-ratio: 1;
	position: absolute;
	top: 1rem;
	right: 1rem;
	filter: invert(1);
	cursor: pointer;
	transition: background 0.3s;
}

/*
* 5. Utilities
*/
/* 5.1 Generic */
.debug,
.debug * {
	outline: 1px solid red !important;
}

.hidden {
	display: none !important;
}

.smooth-scrolling {
	scroll-behavior: smooth;
}

.text-link {
	color: var(--fc-700);
	font-weight: var(--fw-semibold);
	cursor: pointer;
	transition: color 0.2s;
}

.text-link:hover {
	color: var(--clr-primary-400);
}

.text-link:has(.icon-embed) {
	--icon-size: 1em;
	display: flex;
	align-items: center;
	gap: 0.5em;
}

.text-link .icon-embed {
	transition: unset;
}

.interactive {
	cursor: pointer;
}

/* 5.2 Size */
.fill-all {
	width: 100%;
	height: 100%;
}

/* 5.3 Paddings and margins */
.pad-1 {
	padding: 1rem;
}
.pad-2 {
	padding: 2rem;
}
.pad-3 {
	padding: 3rem;
}
.pad-4 {
	padding: 4rem;
}
.pad-5 {
	padding: 5rem;
}
.pad-6 {
	padding: 6rem;
}
.pad-7 {
	padding: 7rem;
}
.pad-8 {
	padding: 8rem;
}
.pad-9 {
	padding: 9rem;
}
.pad-10 {
	padding: 10rem;
}

.pad-v-1 {
	padding-block: 1rem;
}
.pad-v-2 {
	padding-block: 2rem;
}
.pad-v-3 {
	padding-block: 3rem;
}
.pad-v-4 {
	padding-block: 4rem;
}
.pad-v-5 {
	padding-block: 5rem;
}
.pad-v-6 {
	padding-block: 6rem;
}
.pad-v-7 {
	padding-block: 7rem;
}
.pad-v-8 {
	padding-block: 8rem;
}
.pad-v-9 {
	padding-block: 9rem;
}
.pad-v-10 {
	padding-block: 10rem;
}

.pad-h-1 {
	padding-inline: 1rem;
}
.pad-h-2 {
	padding-inline: 2rem;
}
.pad-h-3 {
	padding-inline: 2rem;
}
.pad-h-4 {
	padding-inline: 4rem;
}
.pad-h-5 {
	padding-inline: 5rem;
}
.pad-h-6 {
	padding-inline: 6rem;
}
.pad-h-7 {
	padding-inline: 7rem;
}
.pad-h-8 {
	padding-inline: 8rem;
}
.pad-h-9 {
	padding-inline: 9rem;
}
.pad-h-10 {
	padding-inline: 10rem;
}

.pad-t-1 {
	padding-top: 1rem;
}
.pad-t-2 {
	padding-top: 2rem;
}
.pad-t-3 {
	padding-top: 3rem;
}
.pad-t-4 {
	padding-top: 4rem;
}
.pad-t-5 {
	padding-top: 5rem;
}
.pad-t-6 {
	padding-top: 6rem;
}
.pad-t-7 {
	padding-top: 7rem;
}
.pad-t-8 {
	padding-top: 8rem;
}
.pad-t-9 {
	padding-top: 9rem;
}
.pad-t-10 {
	padding-top: 10rem;
}

.pad-b-1 {
	padding-bottom: 1rem;
}
.pad-b-2 {
	padding-bottom: 2rem;
}
.pad-b-3 {
	padding-bottom: 3rem;
}
.pad-b-4 {
	padding-bottom: 4rem;
}
.pad-b-5 {
	padding-bottom: 5rem;
}
.pad-b-6 {
	padding-bottom: 6rem;
}
.pad-b-7 {
	padding-bottom: 7rem;
}
.pad-b-8 {
	padding-bottom: 8rem;
}
.pad-b-9 {
	padding-bottom: 9rem;
}
.pad-b-10 {
	padding-bottom: 10rem;
}

.pad-l-1 {
	padding-left: 1rem;
}
.pad-l-2 {
	padding-left: 2rem;
}
.pad-l-3 {
	padding-left: 3rem;
}
.pad-l-4 {
	padding-left: 4rem;
}
.pad-l-5 {
	padding-left: 5rem;
}
.pad-l-6 {
	padding-left: 6rem;
}
.pad-l-7 {
	padding-left: 7rem;
}
.pad-l-8 {
	padding-left: 8rem;
}
.pad-l-9 {
	padding-left: 9rem;
}
.pad-l-10 {
	padding-left: 10rem;
}

.pad-r-1 {
	padding-right: 1rem;
}
.pad-r-2 {
	padding-right: 2rem;
}
.pad-r-3 {
	padding-right: 3rem;
}
.pad-r-4 {
	padding-right: 4rem;
}
.pad-r-5 {
	padding-right: 5rem;
}
.pad-r-6 {
	padding-right: 6rem;
}
.pad-r-7 {
	padding-right: 7rem;
}
.pad-r-8 {
	padding-right: 8rem;
}
.pad-r-9 {
	padding-right: 9rem;
}
.pad-r-10 {
	padding-right: 10rem;
}

.mar-1 {
	margin: 1rem;
}
.mar-2 {
	margin: 2rem;
}
.mar-3 {
	margin: 3rem;
}
.mar-4 {
	margin: 4rem;
}
.mar-5 {
	margin: 5rem;
}

.mar-h-1 {
	margin-inline: 1rem;
}
.mar-h-2 {
	margin-inline: 2rem;
}
.mar-h-3 {
	margin-inline: 3rem;
}
.mar-h-4 {
	margin-inline: 4rem;
}
.mar-h-5 {
	margin-inline: 5rem;
}

.mar-v-1 {
	margin-block: 1rem;
}
.mar-v-2 {
	margin-block: 2rem;
}
.mar-v-3 {
	margin-block: 3rem;
}
.mar-v-4 {
	margin-block: 4rem;
}
.mar-v-5 {
	margin-block: 5rem;
}
.mar-v-6 {
	margin-block: 6rem;
}
.mar-v-7 {
	margin-block: 7rem;
}
.mar-v-8 {
	margin-block: 8rem;
}
.mar-v-9 {
	margin-block: 9rem;
}
.mar-v-10 {
	margin-block: 10rem;
}

.mar-t-1 {
	margin-top: 1rem;
}
.mar-t-2 {
	margin-top: 2rem;
}
.mar-t-3 {
	margin-top: 3rem;
}
.mar-t-4 {
	margin-top: 4rem;
}
.mar-t-5 {
	margin-top: 5rem;
}
.mar-t-6 {
	margin-top: 6rem;
}
.mar-t-7 {
	margin-top: 7rem;
}
.mar-t-8 {
	margin-top: 8rem;
}
.mar-t-9 {
	margin-top: 9rem;
}
.mar-t-10 {
	margin-top: 10rem;
}

.mar-b-1 {
	margin-bottom: 1rem;
}
.mar-b-2 {
	margin-bottom: 2rem;
}
.mar-b-3 {
	margin-bottom: 3rem;
}
.mar-b-4 {
	margin-bottom: 4rem;
}
.mar-b-5 {
	margin-bottom: 5rem;
}
.mar-b-6 {
	margin-bottom: 6rem;
}
.mar-b-7 {
	margin-bottom: 7rem;
}
.mar-b-8 {
	margin-bottom: 8rem;
}
.mar-b-9 {
	margin-bottom: 9rem;
}
.mar-b-10 {
	margin-bottom: 10rem;
}

.mar-l-1 {
	margin-left: 1rem;
}
.mar-l-2 {
	margin-left: 2rem;
}
.mar-l-3 {
	margin-left: 3rem;
}
.mar-l-4 {
	margin-left: 4rem;
}
.mar-l-5 {
	margin-left: 5rem;
}

.mar-r-1 {
	margin-right: 1rem;
}
.mar-r-2 {
	margin-right: 2rem;
}
.mar-r-3 {
	margin-right: 3rem;
}
.mar-r-4 {
	margin-right: 4rem;
}
.mar-r-5 {
	margin-right: 5rem;
}

/* 5.4 Placement */
.place-left {
	margin-right: auto;
}

.place-center {
	margin-inline: auto;
}

.place-right {
	margin-left: auto;
}

/* 5.5 Placement */
.load--fade-in {
	transition: translate var(--animation-duration) ease-out, opacity var(--animation-duration) ease-in;
}

.js-load.load--fade-in {
	opacity: 0 !important;
}

.js-load.load--fade-in[data-direction='left'] {
	translate: calc(var(--animation-movement-intensity) * -1) 0;
}
.js-load.load--fade-in[data-direction='right'] {
	translate: var(--animation-movement-intensity) 0;
}
.js-load.load--fade-in[data-direction='top'] {
	translate: 0 calc(var(--animation-movement-intensity) * -1);
}
.js-load.load--fade-in[data-direction='bottom'] {
	translate: 0 var(--animation-movement-intensity);
}

[data-delay='1'] {
	transition-delay: 0.1s;
}
[data-delay='2'] {
	transition-delay: 0.2s;
}
[data-delay='3'] {
	transition-delay: 0.3s;
}
[data-delay='4'] {
	transition-delay: 0.4s;
}
[data-delay='5'] {
	transition-delay: 0.5s;
}
[data-delay='6'] {
	transition-delay: 0.6s;
}
[data-delay='7'] {
	transition-delay: 0.7s;
}
[data-delay='8'] {
	transition-delay: 0.8s;
}
[data-delay='9'] {
	transition-delay: 0.9s;
}
[data-delay='10'] {
	transition-delay: 1s;
}

/* 5.6 Responsivity */
@media (min-width: 1441px) {
	.responsive-max-1440 {
		display: none !important;
	}
}

@media (min-width: 1281px) {
	.responsive-max-1280 {
		display: none !important;
	}
}

@media (min-width: 1025px) {
	.responsive-max-1024 {
		display: none !important;
	}
}

@media (min-width: 769px) {
	.responsive-max-768 {
		display: none !important;
	}
}

@media (min-width: 481px) {
	.responsive-max-480 {
		display: none !important;
	}
}

@media (max-width: 1440px) {
	.responsive-min-1440 {
		display: none !important;
	}
}

@media (max-width: 1280px) {
	.responsive-min-1280 {
		display: none !important;
	}
}

@media (max-width: 1024px) {
	.responsive-min-1024 {
		display: none !important;
	}
}

@media (max-width: 768px) {
	.responsive-min-768 {
		display: none !important;
	}
}

@media (max-width: 480px) {
	.responsive-min-480 {
		display: none !important;
	}
}

/*
* 6. Typography
*/
/* 6.1 Basic settings */
h1,
h2,
h3 {
	color: var(--fc-700);
	font-family: var(--ff-titles);
}

:where(strong),
:where(.fw-bold),
:where(.fw-black) {
	color: var(--fc-700);
}

/* 6.2 Elements */
.text-block {
	display: inline-block;
}

.error-warning {
	color: var(--clr-bad-400);
	background-color: #ffcfcf;
	font-weight: var(--fw-semibold);
	line-height: var(--inp-height);
	border-radius: var(--inp-border-radius);
	border: var(--border-width) solid var(--clr-bad-400);
	text-align: center;
}

/* 6.3 Modifiers */
.ff-titles {
	font-family: var(--ff-titles);
}
.ff-serif {
	font-family: var(--ff-serif);
}

.fw-light {
	font-weight: var(--fw-light);
}
.fw-regular {
	font-weight: var(--fw-regular);
}
.fw-medium {
	font-weight: var(--fw-medium);
}
.fw-semibold {
	font-weight: var(--fw-semibold);
}
.fw-bold {
	font-weight: var(--fw-bold);
}
.fw-black {
	font-weight: var(--fw-black);
}

.fa-left {
	text-align: left;
}
.fa-center {
	text-align: center;
}
.fa-right {
	text-align: right;
}
.fa-justify {
	text-align: justify;
}

.fc-titles {
	color: var(--fc-700);
}
.fc-primary {
	color: var(--clr-primary-400);
}
.fc-hover-primary {
	transition: color 0.2s;
}
.fc-hover-primary:hover {
	color: var(--clr-primary-400);
}
.fc-warning {
	color: var(--clr-bad-400);
}

.ft-uppercase {
	text-transform: uppercase;
}

.fy-italic {
	font-style: italic;
}
