html {
	/* Primary colors */
	/* OLD */
	--c-primary__h: 227;
	--c-primary__s: 52%;
	--c-primary__l: 32%;
	/* --c-primary__h: 216;
	--c-primary__s: 65%;
	--c-primary__l: 11%; */
	--c-primary: hsl( var( --c-primary__h ), var( --c-primary__s ), var( --c-primary__l ) );

	--c-lightest-primary: hsl( var( --c-primary__h ), 50%, 95% );
	--c-lighter-primary: hsl( var( --c-primary__h ), 50%, 75% );
	--c-medium-primary: hsl( var( --c-primary__h ), 50%, 45% );
	--c-dark-primary: hsl( var( --c-primary__h ), 50%, 30% );
	--c-darker-primary: hsl( var( --c-primary__h ), 50%, 15% );
	--c-darkest-primary: hsl( var( --c-primary__h ), 50%, 10% );

	/* OLD */
	/* --c-secondary__h: 0;
	--c-secondary__s: 62%;
	--c-secondary__l: 50%; */
	--c-secondary__h: 7;
	--c-secondary__s: 93%;
	--c-secondary__l: 52%;
	--c-secondary: hsl( var( --c-secondary__h ), var( --c-secondary__s ), var( --c-secondary__l ) );

	/* Common colors */
	--c-light: #FFF;
	--c-lightest-gray: hsl( 0, 0%, 87% );
	--c-lighter-gray: hsl( 0, 0%, 75% );
	--c-medium-gray: hsl( 0, 0%, 45% );
	--c-dark-gray: hsl( 0, 0%, 30% );
	--c-darker-gray: hsl( 0, 0%, 15% );
	--c-darkest-gray: hsl( 0, 0%, 10% );
	--c-dark:#000;

	--c-secondary--light: hsl( var( --c-secondary__h ), var( --c-secondary__s ), 60% );
	--c-forbidden: var( --c-secondary );

	/* Transparent colors */
	--c-dark--transparent: rgba( 0, 0, 0, 0.2 );

	/* Global */
	--g-animation-duration: 0.2s;
	--g-border-radius: 0.5rem;

	--g-block-width-max: 25rem;
	--g-card-width-max: 18rem;
	--g-content-width-max: 75rem;

	--g-spacing: 0.25rem;
	--g-spacing-x2: 0.5rem;
	--g-spacing-x4: 1rem;
	--g-spacing-x8: 2rem;
	--g-spacing-x16: 4rem;

	font-size: clamp( 16px, 1vmax, 24px );
}

* {
	box-sizing: border-box;
	margin: 0;
	outline: none;
	padding: 0;
}
::before, ::after {
	box-sizing: border-box;
}

a {
	transition: color var( --g-animation-duration ) ease;
}

button {
	background-color: transparent;
	border: none;
	color: inherit;
	cursor: pointer;
}

body,
html {
	-webkit-text-size-adjust: none;
	height: 100%;
	width: 100%;
}

body {
	background-color: var( --t-body__background-color );
	color: var( --t-page__foreground-color );
	display: grid;
	font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
	grid-template-rows: max-content auto;
	overflow: hidden;
	scrollbar-gutter: stable;
	text-rendering: optimizeLegibility;
}

img {
	color: transparent;
}
img::before {
	display: none;
}
img::after {
	align-items: center;
	background-color: var( --t-image--broken__background-color );
	color: var( --t-image--broken__foreground-color );
	content: attr( alt );
	display: flex;
	height: 100%;
	justify-content: center;
	margin: auto;
	width: 100%;
}

.wrapper {
	display: grid;
	grid-template-rows: auto max-content;
	min-height: 100%;
	overflow-x: hidden;
	scroll-behavior: smooth;
	scroll-padding: var( --g-spacing-x8 );
	width: 100%;
}

a {
	border-radius: var( --g-border-radius );
	color: var( --t-link__foreground-color );
	display: inline-block;
	text-decoration: none;
}
a:focus {
	outline: 0.15rem solid var( --t-link--focus__outline-color );
	outline-offset: 0.15rem;
}

address {
	font-style: normal;
}

b {
	color: var( --t-page--emphasized__foreground-color );
	transition: color var( --g-animation-duration ) ease;
}

dt {
	font-weight: bold;
	margin-block-start: var( --g-spacing-x4 );
}

address, dl, p {
	line-height: 1.5;
	margin-block-end: var( --g-spacing-x2 );
	margin-block-start: var( --g-spacing-x2 );
}

[ data-inline ] {
	visibility: hidden;
}

figure {
	display: flex;
	flex-direction: column;
}

figcaption {
	color: var( --t-page--emphasized__foreground-color );
	font-weight: bold;
	padding-block-start: var( --g-spacing-x4 );
}

h1, h2, h3, h4, h5, h6 {
	color: var( --t-page--emphasized__foreground-color );
	font-weight: bold;
}
h1:first-child,
h2:first-child {
	margin-block-start: 0;
}

h1 {
	font-size: 3rem;
}

h2 {
	font-size: 2.5rem;
}

h3 {
	font-size: 2rem;
}

/* -------------------------------------------------------------------------- */
/* Generic */

.hidden {
	display: none;
}

/* -------------------------------------------------------------------------- */
/* Header */

.header {
	background-color: var( --t-header__background-color );
	color: var( --t-header__foreground-color );
	font-weight: bold;
	overflow: hidden;
}

.header__content {
	align-items: center;
	display: grid;
	grid-gap: var( --g-spacing-x2 );
	grid-template-areas: "logo nav toggle";
	grid-template-columns: max-content auto max-content;
	justify-content: center;
	margin: 0 auto;
	max-width: var( --g-content-width-max );
	overflow: hidden;
	padding-inline: var( --g-spacing-x8 );
}
@media screen and ( max-width: 800px ) {
	.header__content {
		grid-template-areas: "logo toggle nav";
		justify-content: unset;
		justify-items: end;
	}

	.header__logo {
		justify-self: start;
	}

	.nav__wrapper {
		order: 2;
	}
}

.header__top-bar {
	background-color: var( --t-header__top-bar__background-color );
	color: var( --t-header__top-bar__foreground-color );
	margin-block: 0;
	padding-block: var( --g-spacing );
	text-align: center;
}

.header__top-bar a {
	color: inherit;
}
.header__top-bar a:hover {
	color: var( --t-header__top-bar--hover__foreground-color );
}

.header__logo {
	grid-area: logo;
	height: 3.5rem;
	padding-block: var( --g-spacing-x2 );
}
.header__logo:focus {
	outline: none;
}
.header__logo svg {
	height: 100%;
}

.header__link {
	color: var( --t-header__link__foreground-color );
}
.header__link:hover {
	color: var( --t-header__link--hover__foreground-color );
}

/* -------------------------------------------------------------------------- */
/* Main Nav */

.nav__wrapper {
	user-select: none;
}

.nav {
	/* Still need a prefix? Screw you, Chromium! */
	-webkit-mask-image: linear-gradient( 90deg, rgba( 0, 0, 0, 0 ) 0%, rgb( 0, 0, 0 ) var( --g-spacing-x8 ), rgb( 0, 0, 0 ) calc( 100% - var( --g-spacing-x8 ) ), rgba( 0, 0, 0, 0 ) 100% );
	display: flex;
	mask-image: linear-gradient( 90deg, rgba( 0, 0, 0, 0 ) 0%, rgb( 0, 0, 0 ) var( --g-spacing-x8 ), rgb( 0, 0, 0 ) calc( 100% - var( --g-spacing-x8 ) ), rgba( 0, 0, 0, 0 ) 100% );
	opacity: 1;
	overflow-x: auto;
	overflow-y: hidden;
	padding-inline: var( --g-spacing-x8 );
	transition: left var( --g-animation-duration ) ease;
}

.nav__a {
	color: inherit;
	font-weight: bold;
	letter-spacing: 0.05em;
	padding: var( --g-spacing-x2 );
	text-transform: uppercase;
}
.nav__a:focus,
.nav__a:hover {
	color: var( --t-header__link--hover__foreground-color );
	outline: none;
}

.nav__toggle__button {
	cursor: pointer;
	display: none;
	font-size: 0;
	height: 2rem;
	width: 2rem;
}

@media screen and ( max-width: 800px ) {
	.nav {
		-webkit-mask-image: none;
		align-items: center;
		background-color: var( --t-nav-overlay__background-color );
		display: flex;
		flex-direction: column;
		font-size: 2rem;
		inset: 0;
		justify-content: center;
		mask-image: none;
		left: 0;
		position: fixed;
		pointer-events: auto;
		z-index: 1000;
	}

	.nav__toggle__button {
		display: block;
	}

	.nav__burger::after {
		content: '=';
		display: block;
	}

	.nav__toggle:not( :checked ) ~ .nav {
		left: 100vw;
		pointer-events: none;
		right: 0;
	}
}

/* -------------------------------------------------------------------------- */
/* Content */

/* Card Collection */
.card-collection {
	display: grid;
	grid-gap: var( --g-spacing-x4 );
	grid-template-columns: repeat( auto-fit, minmax( var( --g-card-width-max ), 1fr ) );
}

.card-link {
	align-items: center;
	background-color: var( --t-card-link__background-color );
	border-radius: var( --g-border-radius );
	color: var( --t-card-link__foreground-color );
	display: flex;
	font-weight: bold;
	hyphens: auto;
	font-size: 2rem;
	list-style: none;
	margin: 0;
	padding-inline-end: var( --g-spacing-x4 );
	text-transform: uppercase;
	transition: background-color var( --g-animation-duration ) ease,
	            color var( --g-animation-duration ) ease;
}
.card-link:hover {
	background-color: var( --t-card-link--hover__background-color );
}
.card-link:focus {
	outline: 0.15rem solid var( --t-card-link--focus__outline-color );
	outline-offset: 0.15rem;
}

.card-link svg,
.card-link [ data-replace-image ] {
	flex-shrink: 0;
	height: 7rem;
	position: relative;
	transform: scale( 1.5 );
	transition: transform var( --g-animation-duration ) ease;
	transform-origin: center center;
	width: 7rem;
}
.card-link:hover svg {
	transform: scale( 1.75 );
}

/* Article Collection */
.article-collection {
	display: grid;
	grid-gap: var( --g-spacing-x4 );
	grid-template-columns: repeat( auto-fit, minmax( var( --g-card-width-max ), 1fr ) );
}

.article-card {
	background-color: var( --t-article-card__background-color );
	border-radius: var( --g-border-radius );
	color: inherit;
	display: grid;
	grid-gap: var( --g-spacing-x2 );
	grid-template-areas: 'image' 'header' 'description';
	padding: var( --g-spacing-x4 );
}
.article-card__header {
	grid-area: header;
}
.article-card__image {
	grid-area: image;
}
.article-card__description {
	grid-area: description;
	margin: 0;
}

/* Headlines */
h1, h2 {
	margin-block-start: var( --g-spacing-x8 );
	margin-block-end: var( --g-spacing-x4 );
	transition: color var( --g-animation-duration ) ease;
}

/* Profile Image */
.profile-image {
	border-radius: var( --g-border-radius );
	max-width: 100%;
	height: auto;
}

/* Article Image */
.article-image {
	border-radius: var( --g-border-radius );
	max-width: 100%;
	height: auto;
}

/* Slider */
.slider {
	display: block;
	height: 100%;
	max-height: 100%;
	max-width: 100%;
	overflow: hidden;
	position: relative;
}

.slider__content {
	-ms-overflow-style: none;
	-webkit-overflow-scrolling: touch;
	display: grid;
	grid-auto-columns: 100%;
	height: 100%;
	overflow-y: hidden;
	scroll-behavior: smooth;
	scroll-padding: 0;
	scroll-snap-type: x mandatory;
	scrollbar-color: transparent transparent; /* thumb and track color */
	scrollbar-width: none;
}
[ has-navigation-by-drag="true" ] .slider__content {
	cursor: grab;
}

/* Get rid of scrollbars */
.slider__content::-webkit-scrollbar {
	width: 0;
}
.slider__content::-webkit-scrollbar-track {
	background: transparent;
}
.slider__content::-webkit-scrollbar-thumb {
	background: transparent;
	border: none;
}

.slider__slide {
	grid-row: 1;
	height: 100%;
	overflow: hidden;
	scroll-snap-align: center;
	width: 100%;
}

.slider__image {
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* Sequential navigation */
.slider__navigation-arrows {
	height: 100%;
	pointer-events: none;
	position: absolute;
	top: 0;
	width: 100%;
}

.slider__navigation-arrows__element {
	cursor: pointer;
	pointer-events: auto;
}

.slider__navigation-arrows__element::before,
.slider__navigation-arrows__element::after {
	content: '';
	display: block;
	height: 100%;
	position: absolute;
	top: 0;
	transition: var( --g-animation-duration ) ease background-color;
	width: 3rem;
}

.slider__navigation-arrows__element:hover::before {
	background-color: var( --t-slider__navigation-arrows__element--hover__background-color );
}
.slider__navigation-arrows__element:hover::after {
	background-color: var( --t-slider__navigation-arrows__element--hover__foreground-color );
}

.slider__navigation-arrows__element::after {
	mask-position: center;
	mask-repeat: no-repeat;
	mask-image: url( 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTIgOC45OWMwLS40MjMuMjA0LS43MjIuNjEtLjg5Ny40MDgtLjE3My43NzItLjEwNCAxLjA5Mi4yMWw3LjAwNiA2Ljk3NGMuMjAyLjIuMjk4LjQzNy4yODcuNzE2IDAgLjI2Ny0uMDk2LjQ5OC0uMjg3LjY5bC03LjAwNiA3Yy0uMzIuMzItLjY4NC4zOS0xLjA5Mi4yMS0uNDA2LS4xNzUtLjYxLS40ODMtLjYxLS45MjNWOC45OXoiIGZpbGw9IiNmZmZmZmYiIG9wYWNpdHk9IjAuOCIgZmlsbC1ydWxlPSJldmVub2RkIi8+PC9zdmc+' );
	transform: rotateZ( 180deg );
}

.slider__navigation-arrows__next::before {
	right: 0;
}
.slider__navigation-arrows__next::after {
	right: 0;
	transform: rotateZ( 0deg );
}

/* Bullet navigation */
.slider__bullet-navigation {
	bottom: var( --g-spacing-x2 );
	display: grid;
	grid-auto-flow: column;
	grid-gap: var( --g-spacing-x2 );
	justify-content: center;
	position: absolute;
	width: 100%;
}
.slider__bullet-navigation__element {
	background-color: var( --t-slider__bullet-navigation__element__foreground-color );
	border-radius: 50%;
	cursor: pointer;
	height: 1rem;
	width: 1rem;
}
.slider__bullet-navigation__element:hover {
	background-color: var( --t-slider__bullet-navigation__element--hover__foreground-color );
}

/* -------------------------------------------------------------------------- */
/* Footer */

.footer {
	background-color: var( --t-footer__background-color );
	color: var( --t-footer__foreground-color );
	display: grid;
	font-size: 0.9rem;
	padding: var( --g-spacing-x8 );
}

.footer a {
	color: var( --t-footer__link__foreground-color );
}

.footer__content {
	margin: 0 auto;
	max-width: var( --g-content-width-max );
}

.footer__headline {
	color: var( --t-footer__headline__foreground-color );
}

.image-thumb {
	margin-block: var( --g-spacing-x8 );
	width: 10rem;
}

/* -------------------------------------------------------------------------- */
/* SVG */

.svg-main-fill {
	fill: currentColor;
	transition: fill var( --g-animation-duration ) ease;
}

.svg-forbidden-border {
	fill: var( --t-svg__forbidden );
	transition: fill var( --g-animation-duration ) ease;
}
.svg-forbidden-content {
	fill: var( --t-svg__foreground );
	transition: fill var( --g-animation-duration ) ease;
}

/* -------------------------------------------------------------------------- */
/* Article */
.article-section {
	margin: 0 auto;
	max-width: var( --g-content-width-max );
	padding-block: var( --g-spacing-x8 );
	padding-inline: var( --g-spacing-x8 );
	position: relative;
	width: 100vw;
	z-index: 2;
}
.article-section--restrict-height {
	height: min( calc( 100vw - var( --g-spacing-x8 ) ), 80vh );
}
.article-section--emphasized::before,
.article-section::before {
	content: '';
	display: block;
	height: 100%;
	left: 50%;
	margin-left: -100vw;
	margin-right: -100vw;
	position: absolute;
	top: 0;
	transition: background-color var( --g-animation-duration ) ease,
	            color var( --g-animation-duration ) ease;
	width: 200vw;
	z-index: -1;
}

@media screen and ( max-width: 1000px ) {
	.article-section--full-width {
		margin-inline: 0;
		max-width: 100vw;
		padding: 0;
	}
}

.article-section::before {
	background-color: var( --t-page__background-color );
}

.article-section--emphasized {
	color: var( --t-article-section--emphasized__foreground-color );
}
.article-section--emphasized::before {
	background-color: var( --t-article-section--emphasized__background-color );
}

/* -------------------------------------------------------------------------- */
/* Columns */
.columns {
	display: grid;
	grid-gap: var( --g-spacing-x8 );
	grid-template-columns: repeat( auto-fit, minmax( min( var( --g-block-width-max ), 100% ), 1fr ) );
	margin-block-end: var( --g-spacing-x8 );
	margin-block-start: var( --g-spacing-x8 );
}

.columns h2 {
	margin-block-start: 0;
}

.col--2-1 {
	/* grid-template-columns: repeat( auto-fit, minmax( var( --g-card-width-max ), 1fr ) ); */
	grid-template-columns: repeat( auto-fit, minmax( var( --g-card-width-max ), 1fr ) );
}
.col--2-1 > :nth-child( odd ) {
	grid-column: span 2;
}
@media screen and ( max-width: 1000px ) {
	.col--2-1 > :nth-child( odd ) {
		grid-column: unset;
	}
}

.column--centered {
	align-self: center;
}

::selection {
	background-color: var( --t-selection__background-color );
	color: var( --t-selection__foreground-color );
}

/* -------------------------------------------------------------------------- */
/* Buttons */

.toggle {
	display: grid;
	height: 1.25rem;
	width: 1.25rem;
}

.toggle-icon {
	color: inherit;
	grid-column: 1;
	grid-row: 1;
	opacity: 1;
	transition: opacity var( --g-animation-duration ) ease,
	            color var( --g-animation-duration ) ease;
}

.toggle {
	grid-area: toggle;
}

.dark-mode .toggle-dark {
	opacity: 0;
}
.light-mode .toggle-light {
	opacity: 0;
}

/* -------------------------------------------------------------------------- */
/* Scrollbars */

::-webkit-scrollbar {
	height: 4px;
	width: 4px;
}

::-webkit-scrollbar-track {
	background-color: transparent;
}
::-webkit-scrollbar-thumb {
	background: var( --c-medium-gray );
	border-radius: 10px;
}

/* Firefox Special */
* {
	scrollbar-color: var( --c-medium-gray ) var( --c-darkest-gray );
	scrollbar-width: thin;
}

/* -------------------------------------------------------------------------- */
/* Animations */

