@font-face {
	font-family: Scratch;
	src: url(scratch-pixel-font.otf.woff2);
}

@media only screen and (max-width: 640px) {
	.body-container {
		margin: 0 8px;
	}
}

@media only screen and (min-width: 641px) {
	.body-container {
		margin: 0 50px;
	}
}

@media only screen and (min-width: 800px) {
	.body-container {
		margin: 0 100px;
	}
}

@media only screen and (min-width: 900px) {
	.body-container {
		margin: 0 150px;
	}
}

@media only screen and (min-width: 1000px) {
	.body-container {
		margin: 0 200px;
	}
}

@media only screen and (min-width: 1200px) {
	.body-container {
		margin: 0 300px;
	}
}

@media only screen and (max-height: 599px) {
	h2 {
		margin: 16px 0 8px 0;
	}
}

@media only screen and (min-height: 600px) {
	h2 {
		margin: 24px 0 12px 0;
	}
}

:root {
	--base-800: oklch(26.8% 0.007 34.298);
	--base-300: oklch(86.9% 0.005 56.366);
	--base-200: oklch(92.3% 0.003 48.717);
	--base-100: oklch(97% 0.001 106.424);
	--accent-700: oklch(53.2% 0.157 131.589);
	--accent-600: oklch(64.8% 0.2 131.684);
	--accent-500: oklch(76.8% 0.233 130.85);
	--accent-400: oklch(84.1% 0.238 128.85);
	--accent-200: oklch(93.8% 0.127 124.321);
	--accent-100: oklch(96.7% 0.067 122.328);
}

* {
	box-sizing: border-box;
	font-size: 16px;
	line-height: 1.5;
	font-family: Scratch, Sans-Serif;
	font-weight: normal;
	margin: 0;
	padding: 0;
}

p, div, h1, h2, input, textarea {
	color: var(--base-800);
}

p {
	margin: 12px 0;
}

h1 {
	font-size: 24px;
	font-weight: normal;
	margin: 24px 0 16px 0;
}

h2 {
	font-weight: normal;
	padding: 8px;
	border-top: 2px solid var(--accent-400);
	border-bottom: 2px solid var(--accent-400);
	background-color: var(--accent-200);
	color: var(--accent-700);
}

ul li {
	list-style-type: none;
}

a:link,
a:visited,
a:focus,
a:hover {
	color: var(--accent-500);
	text-decoration: none;
}

button {
	background-color: var(--base-100);
	padding: 8px;
	border: 2px solid var(--base-200);
	border-radius: 0;
}

button:hover {
	border-color: var(--base-300);
	background-color: var(--base-200);
}

input,
textarea {
	padding: 4px 6px;
	border: 2px solid var(--base-300);
	border-radius: 0;
}

.block {
	display: block;
	margin-bottom: 8px;
}

.body-container {
	max-width: 640px;
}

ul.date-location li {
	padding: 4px;
}

.timeline-container {
	background-image: url('dom-jana.png');
	background-repeat: no-repeat;
	background-position: right bottom;
}

ul.timeline {
	display: table;
}

ul.timeline li {
	display: table-row;
}

ul.timeline li span {
	display: table-cell;
	padding: 4px 0;
}

ul.timeline li span.time {
	color: oklch(53.2% 0.157 131.589);
	text-align: right;
	padding-right: 8px;
}

ul.timeline li.sub-timeslot {
}

ul.entertainment li {
	display: inline;
}

ul.entertainment li::after {
	content: ', ';
}

ul.entertainment li:last-child::after {
	content: '';
}

.hidden, .person.template {
	display: none;
}

.person {
	display: flex;
	flex-direction: row;
	margin-top: 16px;
	padding: 8px;
	border: 2px solid var(--base-300);
}

/* Filepond stuff */

.file-container {
	width: 120px;
	height: 120px;
}

.filepond--drop-label {
	font-size: 16px !important;
}

.filepond--image-preview {
	background: none !important;
}

.filepond--image-preview-overlay-idle {
	color: transparent !important;
}

.filepond--credits,
.filepond--file-info {
	display: none;
}
