/*
-----------------------------------------------
	www.hmt-rostock.de/staeko26
 by Christina Schmid www.christinaschmid.de
and Simon Malz www.lichtsignale.de
----------------------------------------------- */


/*		R E S E T
----------------------------------------------- */

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    font-variant-ligatures: none;
}

html {
	height: 100%;
	-ms-text-size-adjust: none;
	-webkit-text-size-adjust: none;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section { 
    display: block;
}

blockquote, q {
    quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content: "";
    content: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    outline: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

input, select {
    vertical-align: middle;
}

em, i {
	font-style: normal;
}


/*		W E B F O N T S
----------------------------------------------- */

/**
 * @license
 * MyFonts Webfont Build ID 3867246, 2020-12-16T11:57:38-0500
 * 
 * The fonts listed in this notice are subject to the End User License
 * Agreement(s) entered into by the website owner. All other parties are 
 * explicitly restricted from using the Licensed Webfonts(s).
 * 
 * You may obtain a valid license at the URLs below.
 * 
 * Webfont: Galano Grotesque Regular by René Bieder
 * URL: https://www.myfonts.com/collections/rene-bieder-foundry

 * Webfont: Galano Grotesque Medium by René Bieder
 * URL: https://www.myfonts.com/collections/rene-bieder-foundry
 
 * © 2025 MyFonts Inc. */


@font-face {
	font-family: "STK Galano";
	src: url("regular.woff2") format("woff2"),
	url("regular.woff") format("woff");
	font-weight: normal;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "STK Galano";
	src: url("medium.woff2") format("woff2"),
	url("medium.woff") format("woff");
	font-weight: bold;
	font-style: normal;
	font-display: swap;
}


/*		B A S I C S
----------------------------------------------- */

:root {
	--color-text: #000;
	--color-blue: #0056ff;
	--spacing: 1.35em;
}

body {
	color: var(--color-text);
	background: #fff;
	font-family: "STK Galano", "Helvetica Neue", Helvetica, "Roboto", Arial, sans-serif;
	font-size: 17px;
	line-height: var(--spacing);
	letter-spacing: 0.02em;
	text-align: left;
}

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

a:hover, a:active {
	color: var(--color-blue);
}

footer a:link, footer a:visited {
	color: #fff;
}

footer a:hover, footer a:active {
	color: var(--color-text);
}

img, video {
	max-inline-size: 100%;
	block-size: auto;
	object-fit: contain;
	object-position: center center;
	height: auto;
}

b, strong {
	font-weight: bold;
}

i, em {
	font-style: italic;
}

h2 {
	font-size: 200%;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

h3, h4, h5 {
	font-size: 150%;
	letter-spacing: -0.01em;
	line-height: 1.25;
}

h1, h2, h3, h4, h5, p, main ul {
	margin-bottom: 1rem;
	font-weight: normal;
}


/*		B A S I C S
----------------------------------------------- */

.wrapper {
	margin-top: calc(var(--spacing) * 0.75);
	padding: 0 var(--spacing) 0 var(--spacing);
}

header {
	background-image: url("la-forme.svg");
	background-repeat: no-repeat;
	background-size: contain;
	background-position-x: right;
	width: calc(100% + var(--spacing));
	padding-top: calc(var(--spacing) * 3);
}

.p1 {
	position: relative;
	top: -0.3em;
}

.p2 {
	position: relative;
	top: -0.6em;
}

.p3 {
	position: relative;
	top: -1em;
}

.p4 {
	position: relative;
	top: -1.1em;
}

#menu {
	margin-bottom: calc(var(--spacing) * 2);
}

#menu li {
	list-style: none;
}

#menu .active a {
	color: #fff;
	background: var(--color-blue);
}

#menu .active a:hover {
	color: #fff;
	background: var(--color-text);
}

section a:link, section a:visited {
	border-bottom: 1px solid var(--color-blue);
}

main ul {
	margin-left: calc(var(--spacing) * 1);
}

main section li {
	list-style: none;
	padding-left: 10px;
	position: relative;
	margin-bottom: calc(var(--spacing) * 0.5);
}

main section li:before {
	content: "";
	display: block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--color-blue);
	position: absolute;
	left: -10px;
	top: 6px;
}

#idee span, #programm time, #anfahrt span, #unterkunft span {
	color: #fff;
	background: var(--color-blue);
}

#anfahrt span {
	font-weight: bold;
}

#programm {
	margin-top: calc(var(--spacing) * 2.5);
	padding-top: calc(var(--spacing) * 4.5);
	background-image: url("la-programme.svg");
	background-repeat: no-repeat;
	background-size: 33%;
	background-position-x: right;
}

#programm span {
	color: var(--color-blue);
}

#programm time {
	display: inline-block;
	font-weight: bold;
	margin-top: calc(var(--spacing) * 1);
}

#programm time + br + strong {
	letter-spacing: 2px;
}

#programm .toggle strong {
	letter-spacing: 0.02em;
}

#programm h4, #programm h5 {
	margin-bottom: calc(var(--spacing) * 2);
}

.toggle {
	position: relative;
	margin-top: calc(var(--spacing) * -0.65);
}

.toggle__header {
	display: flex;
	align-items: center;
	width: 100%;
	cursor: pointer;
	background: none;
	border: 0;
	padding: 0;
	font: inherit;
}

.toggle__icon {
	transition: transform 0.2s ease;
	padding-right: 5px;
}

.toggle__title {
	color: var(--color-text) !important;
	border-bottom: 1px solid var(--color-blue);
}

.toggle__header:hover .toggle__title {
	color: var(--color-blue) !important;
}

.toggle__content {
	padding-top: calc(var(--spacing) * 1);
	padding-left: calc(var(--spacing) * 2);
}


/*		F O O T E R
----------------------------------------------- */

footer {
	margin-top: calc(var(--spacing) * 2);
	padding: calc(var(--spacing) * 0.1) 0 var(--spacing) 0;
	color: #fff;
	background: var(--color-blue);
}

footer small {
	color: var(--color-text);
	font-size: 75%;
	letter-spacing: 0.03em;
}

footer #logos {
	display: flex;
	align-items: baseline;
	gap: var(--spacing);
	margin-bottom: calc(var(--spacing) * 2);
}

footer #logos a {
	flex: 1;
}

footer #logos a:first-child img {
	width: 75%;
}

footer #logos a:last-child img {
	padding-bottom: var(--spacing);
}

footer #kontakt span {
	color: var(--color-text);
}


/*		R E S P O N S I V E
----------------------------------------------- */

@media screen and (min-width: 600px) {

header {
	padding-top: calc(var(--spacing) * 4);
	padding-bottom: calc(var(--spacing) * 3);
}

h1 span {
	display: block;
}

h2 {
	font-size: 400%;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

h3 {
	text-align: right;
	margin-right: var(--spacing);
}

header h4 {
	display: flex;
	gap: var(--spacing);
	margin-right: var(--spacing);
}

header h4 div {
	flex: 1;
}

}


@media screen and (min-width: 800px) {

#intro, main, footer .wrapper {
	display: flex;
	gap: var(--spacing);
}

#intro sidebar, main sidebar, footer .wrapper sidebar, h4 div:first-child {
	flex: 1;
}

#intro section, main section, footer .wrapper section, h4 div:last-child {
	flex: 2;
}

header {
	margin-bottom: calc(var(--spacing) * 4);
	padding-top: calc(var(--spacing) * 3);
	padding-bottom: calc(var(--spacing) * 4);
}

h2 {
	font-size: 10vw;
	text-align: right;
	width: calc(100% - 40px);
}

h3 {
	margin-top: calc(var(--spacing) * 2);
}

h3, h4, h5 {
	font-size: 200%;
	letter-spacing: -0.01em;
	line-height: 1.15;
}

h3, h4 div:last-child {
	color: #fff;
}

h3 span, h4 div:last-child span {
	color: var(--color-text);
}

main ul {
	margin-left: 0;
}

main section ul {
	margin-left: calc(var(--spacing) * 1);
}

}


@media screen and (min-width: 1000px) {

#intro sidebar, main sidebar, footer .wrapper sidebar, h4 div:first-child {
	flex: 3;
}

#intro section, main section, footer .wrapper section, h4 div:last-child {
	flex: 4;
}

header {
	padding-bottom: calc(var(--spacing) * 3);
}

h3 {
	margin-top: calc(var(--spacing) * 1);
}

h3, h4, h5 {
	font-size: 250%;
	letter-spacing: -0.01em;
	line-height: 1.25;
}

footer img {
	max-width: 200px;
}

}


@media screen and (min-width: 1200px) {

body {
	font-size: 22px;
	line-height: var(--spacing);
	letter-spacing: 0.02em;
}

header {
	padding-top: calc(var(--spacing) * 4);
	padding-bottom: calc(var(--spacing) * 3);
}

h3, h4 {
	line-height: 1.1;
}

#programm h4, #programm h5 {
	margin-bottom: calc(var(--spacing) * 0.5);
}

.toggle {
	margin-top: calc(var(--spacing) * -0.5);
}

}


@media screen and (min-width: 1600px) {

body {
	font-size: 25px;
	line-height: var(--spacing);
	letter-spacing: 0.02em;
}

.wrapper {
	width: 1540px;
}

h2 {
	font-size: 160px;
}

}