/* ── Variables ──────────────────────── */

:root {
  --bg:      #e9e9e9;
  --fg:      #000000;
  --padding: 2rem;
}

/* ── Base ───────────────────────────── */

html {
  background: var(--bg);
  color: var(--fg);
  font-family: 'Focal Web', sans-serif;
  font-size: clamp(15px, 0.25vw + 13.4px, 16px);
  line-height: 1.15;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
}

body {
  padding: var(--padding);
  max-width: 560px;
  margin: 0 auto;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
  text-underline-offset: 3px;
}

em {
  font-style: italic;
}


p {
  margin-bottom: 1rem;
  line-height: 1.15;
}

h1, h2, h3, h4 {
  font-family: inherit;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
  margin-bottom: 1rem;
}

.mb-1 {
  margin-bottom: 1rem !important;
}

/* ── Header ─────────────────────────── */

header {
  padding-top: 2rem;
  padding-bottom: 6rem;
  text-align: center;
}

header img {
  width: 50%;
  margin: 0 auto;
}

/* ── Figure ─────────────────────────── */

figure img {
  width: 100%;
}

figcaption {
  display: grid;
  grid-template-columns: 25% 75%;
  padding: 0.5rem 0 0;
  font-size: clamp(0.5rem, 0.3vw + 0.43rem, 0.65rem);
  font-weight: 500;
  line-height: 1.3;
}

/* ── Intro ───────────────────────────── */

.intro {
  padding-top: 4rem;
  text-align: center;
}

.intro h2 {
  font-size: 1.5rem;
  line-height: 1;
  margin-bottom: 2rem;
}

/* ── Description ────────────────────── */

.description {
  padding-top: 5rem;
  padding-bottom: 2rem;
  text-align: center;
  font-size: 1.5rem;
}

/* ── Info ────────────────────────────── */

.info {
  padding-top: 4rem;
  text-align: center;
  font-weight: 500;
}

.info-block {
  margin-bottom: 4rem;
}

.info h2,
.info p {
  font-size: 1.5rem;
}

.info h2 {
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}

/* ── Contact ─────────────────────────── */

.contact {
  padding-top: 4rem;
  text-align: center;
  font-size: 1.5rem;
}

.contact a {
  font-weight: 500;
}

/* ── Legal ───────────────────────────── */

.legal figure {
  padding-top: 6rem;
  padding-bottom: 4rem;
}

.legal h2 {
  margin-bottom: 0;
}

.legal h3 {
  margin-top: 1.5rem;
  margin-bottom: 0;
  line-height: 1.15;
}

.legal a {
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* ── Splash ──────────────────────────── */


body.splash {
  background: transparent url('../img/05_KW_Bravo_background.webp') center/cover no-repeat;
  background-size: cover;
  background-position: center;
  min-height: 120vh; /* fallback für alte Browser */
  min-height: 120dvh; /* dynamic viewport height */
  max-width: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  position: relative;
  color: #F5F5F5;
}

@media (min-width: 600px) {
  body.splash {
  min-height: 100vh; /* fallback für alte Browser */
  min-height: 100dvh; /* dynamic viewport height */
  }
}

.splash-content {
  flex: 1;
}

.masthead {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  padding: 0 var(--padding);
  text-align: center;
}

body.splash header {
  padding-top: 0;
  padding-bottom: 3rem;
  text-align: center;
}

body.splash header img {
  margin: 0 auto;
  filter: invert(96%);
}

body.splash .intro {
  padding-top: 0;
  text-align: center;
}

body.splash footer {
  padding: 0 var(--padding) 2rem;
}

@media (min-width: 600px) {
  .splash-content {
    justify-content: center;
  }

  body.splash header img {
    max-width: 200px;
  }
}

/* ── Desktop ─────────────────────────── */

@media (min-width: 600px) {
  header {
    padding-top: 4rem;
  }
}

/* ── Footer ─────────────────────────── */

footer {
  padding-top: 4rem;
  padding-bottom: 2rem;
  text-align: center;
  font-size: 0.85rem;
}
