@charset "UTF-8";
/*!
Theme Name: FKKB v2
Author: Rene Meyer
Author URI: https://fkkb.de
Description: Wordpress Theme für den Freiluft Kunst Klub: https://fkkb.de
Version: 2.0
*/
:root {
  /* Base */
  --bg: oklch(0.97 0 0);
  --ink: oklab(0.24 0.01 0);
  --white: oklab(100% 0 -0.00011);
  /* Neutraltöne — blau-getönt */
  --warm-50: oklch(96.8% 0.004 60);
  --warm-100: oklch(93.2% 0.005 55);
  --warm-200: oklch(87.5% 0.006 55);
  --warm-300: oklch(78.0% 0.006 50);
  --warm-400: oklch(64.0% 0.006 45);
  --warm-500: oklch(48.0% 0.006 40);
  --warm-600: oklch(34.0% 0.006 35);
  --warm-700: oklch(22.0% 0.006 30);
  /* Semantik — 10% Akzente */
  --success: oklch(34% 0.090 155); /* #1a5e34 */
  --success-bg: oklch(91% 0.040 155); /* #d4edd9 */
  --success-dark: oklch(23% 0.070 155); /* #0d3a1f */
  --warning: oklch(36% 0.110 60); /* #8a4d00 */
  --warning-bg: oklch(95% 0.050 80); /* #fdf0db */
  --warning-dark: oklch(24% 0.090 60); /* #5a3200 */
  --error: oklch(39% 0.170 25); /* #b91c1c */
  --error-bg: oklch(94% 0.040 25); /* #fde8e8 */
  --error-dark: oklch(28% 0.120 25); /* #7f1212 */
  --info: oklch(32% 0.070 240); /* #1a4b6b */
  --info-bg: oklch(91% 0.030 240); /* #dceef8 */
  --info-dark: oklch(21% 0.060 240); /* #0d2e43 */
  /* UI-Aliase */
  --text: var(--ink);
  --text-muted: var(--warm-400);
  --text-subtle: var(--warm-500);
  --rule: oklch(85% 0.005 55);
}

:root {
  /* ── Fluider Anker (Single Anchor – Latin) ───────────── */
  /* slope = (19-16)/(1440-375) = 0.002817 → ×100 = 0.2817vw */
  /* intercept = 16 - 0.002817×375 = 14.943px → /16 = 0.934rem */
  /* (19-16)/(1920-375) = 0.001941747573 → ×100 = 0.19417476vw */
  /* intercept = 16 - 0.0019417476×375 = 15.272px → /16 = 0.954rem */
  --fs-base: clamp(1rem, 0.2817vw + 0.9343rem, 2.1875rem);
  /* ── Zeilenhöhen ───────────────────────────────────────── */
  --lh-body: 1.5; /* Latin: 1.3–1.6 | Baranov: ≥1.3 | WCAG 1.4.8: ≥1.5 */
  --lh-heading: 1.20; /* Überschrieben pro Heading-Größe (Baranov) */
  /* Grundlage aller vertikalen Abstände im Fließtext */
  --lh-unit: calc(var(--fs-base) * var(--lh-body));
  /* ── Typografische Skala – Ratio 1.333 (Perfect Fourth) ── */
  /* h1: base × 1.333⁴ ≈ ×3.16  */
  /* h2: base × 1.333³ ≈ ×2.37  */
  /* h3: base × 1.333² ≈ ×1.78  */
  /* h4: base × 1.333¹ ≈ ×1.33  */
  /* h5: base × 1.333⁰·⁵ ≈ ×1.15 */
  --fs-h1: calc(var(--fs-base) * 2.5);
  --fs-h2: calc(var(--fs-base) * 2);
  --fs-h3: calc(var(--fs-base) * 1.75);
  --fs-h4: calc(var(--fs-base) * 1.33);
  --fs-h5: calc(var(--fs-base) * 1.15);
  --fs-body: var(--fs-base);
  --fs-caption: calc(var(--fs-base) * 0.800);
  --fs-small: calc(var(--fs-base) * 0.675);
  --fs-th: calc(var(--fs-base) * 0.875);
  /* ── Hero-Überschrift (eigene Kurve für Marketing/Hero) ─── */
  /* Startet bei ~28px (375px VP), endet bei ~72px (1440px VP) */
  --fs-hero: clamp(1.75rem, 5vw + 0.5rem, 6rem);
  /* ── Zeilenlänge (Latin: 45–75 Zeichen ≈ 33em) ────────── */
  --line-length: 33em;
  --space-1: calc(0.25rem / 1.5); /*  4px */
  --space-2: calc(0.5rem / 1.5); /*  8px */
  --space-3: calc(0.75rem / 1.5); /* 12px */
  --space-4: calc(1rem / 1.5); /* 16px */
  --space-5: calc(1.25rem / 1.5); /* 18px */
  --space-6: calc(1.5rem / 1.5); /* 24px */
  --space-7: calc(1.75rem / 1.5); /* 28px */
  --space-8: calc(2rem / 1.5); /* 32px */
  --space-9: calc(2.25rem / 1.5); /* 36px */
  --space-10: calc(2.5rem / 1.5); /* 40px */
  --space-11: calc(2.75rem / 1.5); /* 44px */
  --space-12: calc(3rem / 1.5); /* 48px */
  --space-13: calc(3.5rem / 1.5); /* 56px */
  --space-14: calc(4rem / 1.5); /* 64px */
  --space-15: calc(5rem / 1.5); /* 80px */
}
@media (min-width: 60rem) {
  :root {
    --space-1: 0.25rem; /*  4px */
    --space-2: 0.5rem; /*  8px */
    --space-3: 0.75rem; /* 12px */
    --space-4: 1rem; /* 16px */
    --space-5: 1.25rem; /* 18px */
    --space-6: 1.5rem; /* 24px */
    --space-7: 1.75rem; /* 28px */
    --space-8: 2rem; /* 32px */
    --space-9: 2.25rem; /* 36px */
    --space-10: 2.5rem; /* 40px */
    --space-11: 2.75rem; /* 44px */
    --space-12: 3rem; /* 48px */
    --space-13: 3.5rem; /* 56px */
    --space-14: 4rem; /* 64px */
    --space-15: 5rem; /* 80px */
  }
}

:root {
  --ease-out-smooth: cubic-bezier(0, 0, .5, 1);
  --ease-elastic: linear(0, 0.55 7.5%, 0.85 12%, 0.95 14%, 1.03 16.5%, 1.09 20%, 1.13 22%, 1.14 23%, 1.15 24.5%, 1.15 26%, 1.13 28%, 1.11 31%, 1.05 39%, 1.02 43%, 0.99 47%, 0.98 52%, 0.97 59%, 1.002 81%, 1);
}

@media (prefers-reduced-motion: no-preference) {
  @keyframes spin {
    to {
      rotate: -360deg;
    }
  }
}
[data-highlight-marker-reveal] {
  visibility: hidden;
}

[data-highlight-marker-reveal] .highlight-marker-line {
  width: auto;
  display: inline-block !important;
  margin: -0.055em 0px;
}

.highlight-marker-bar {
  position: absolute;
  inset: -0.055em 0px;
  z-index: 1;
  pointer-events: none;
}

/* Box sizing rules */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin */
* {
  margin: 0;
  padding: 0;
  font: inherit;
}

/* Remove list styles on ul, ol elements with a list role, which suggests default styling will be removed */
ul[role=list],
ol[role=list] {
  list-style: none;
}

/* Set core root defaults */
html:focus-within {
  scroll-behavior: smooth;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* A elements that don't have a class get default styles */
a:not([class]) {
  text-decoration-skip-ink: auto;
}

/* Make images easier to work with */
img,
picture,
svg,
video {
  width: 100%;
  display: block;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations, transitions and smooth scroll for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  html:focus-within {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
.btn-bounce {
  white-space: nowrap;
  color: var(--white);
  padding-inline: var(--space-6);
  font-size: var(--fs-small);
  font-weight: 600;
  text-decoration: none;
  position: relative;
}

.btn-bounce.is--secondary {
  color: var(--brand-green);
}

.btn-bounce-bg {
  z-index: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg id='a' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 151.76 33.38'%3E%3Cpath d='M14.44.47C6.73,1.16,4.25,1.75,3.22,3.16c-1.59,2.19-1.67,9.57-.11,10.59.79.52.76.74-.1.74-.67,0-1.24.46-1.24,1s.62,1,1.38,1c.97,0,1.22.81.86,2.71-.44,2.29-.63,2.41-1.19.81-.6-1.71-.73-1.74-1.33-.24-.38.95-.4,2.36-.05,3.29.33.86.01,2-.67,2.43-1.02.64-1.03,1.43-.05,3.81l1.24,3,17.14.67c9.43.37,42.1.52,72.57.33l55.43-.33.33-2.24c.23-1.52-.2-2.24-1.33-2.24-.95,0-1.38-.29-1-.67s.18-1.24-.48-2c-.73-.86-.77-1.33-.1-1.33,1.3,0,1.14-5.23-.19-6.2-.57-.41,0-.78,1.24-.8,1.24-.03,2-.51,1.67-1.05-.34-.55.1-1,.95-1s1.57-.45,1.57-1-.41-1-.95-1c-1.33,0,0-4.07,1.52-4.65,1.62-.62,1.94-3.87.48-4.79-.57-.36-.83-1-.57-1.42.26-.42-4.1-1.05-9.71-1.41C123.49.09,24.95-.46,14.44.47h0Z' style='fill:%23669933; stroke-width:0px;'/%3E%3C/svg%3E");
  position: absolute;
  inset: 0%;
}

.btn-bounce-bg.is--secondary {
  background-color: transparent;
  background: none;
  border-radius: 50vw;
  border: 1px solid currentColor;
}

.btn-bounce-text {
  z-index: 1;
  display: block;
  position: relative;
  color: currentColor;
}

.btn-bounce-text__wrap {
  padding-block: var(--space-3);
  overflow: hidden;
}

/* Only apply hover animations if they are actually not supported */
@media (hover: hover) and (pointer: fine) {
  .btn-bounce,
  .btn-bounce-text,
  .btn-bounce-text__wrap {
    transition: transform 0.5s var(--ease-elastic);
  }
  .btn-bounce:hover .btn-bounce-bg.is--secondary {
    background-color: var(--ng-50);
    border: 1px solid var(--ng-100);
  }
  .btn-bounce:hover .btn-bounce-bg:not(.is--secondary) {
    background-image: url("data:image/svg+xml,%3C%3Fxml version='1.0' encoding='UTF-8'%3F%3E%3Csvg id='a' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 151.76 33.38'%3E%3Cpath d='M14.44.47C6.73,1.16,4.25,1.75,3.22,3.16c-1.59,2.19-1.67,9.57-.11,10.59.79.52.76.74-.1.74-.67,0-1.24.46-1.24,1s.62,1,1.38,1c.97,0,1.22.81.86,2.71-.44,2.29-.63,2.41-1.19.81-.6-1.71-.73-1.74-1.33-.24-.38.95-.4,2.36-.05,3.29.33.86.01,2-.67,2.43-1.02.64-1.03,1.43-.05,3.81l1.24,3,17.14.67c9.43.37,42.1.52,72.57.33l55.43-.33.33-2.24c.23-1.52-.2-2.24-1.33-2.24-.95,0-1.38-.29-1-.67s.18-1.24-.48-2c-.73-.86-.77-1.33-.1-1.33,1.3,0,1.14-5.23-.19-6.2-.57-.41,0-.78,1.24-.8,1.24-.03,2-.51,1.67-1.05-.34-.55.1-1,.95-1s1.57-.45,1.57-1-.41-1-.95-1c-1.33,0,0-4.07,1.52-4.65,1.62-.62,1.94-3.87.48-4.79-.57-.36-.83-1-.57-1.42.26-.42-4.1-1.05-9.71-1.41C123.49.09,24.95-.46,14.44.47h0Z' style='fill:%23ecf2e6; stroke-width:0px;'/%3E%3C/svg%3E");
  }
  /* Fake a duplicate text element using text shadow without blur  */
  /* We save the distance in a variable for easy use in the CSS animation */
  .btn-bounce:hover .btn-bounce-text,
  .btn-bounce:hover .btn-bounce-text.is--secondary {
    --text-duplicate-distance: 3em;
  }
  .btn-bounce:hover .btn-bounce-text {
    text-shadow: 0px var(--text-duplicate-distance) var(--green-700);
  }
  .btn-bounce:hover .btn-bounce-text.is--secondary {
    text-shadow: 0px var(--text-duplicate-distance) currentColor;
  }
  /* Scale down the button and rotate it slightly */
  .btn-bounce:hover {
    transform: scale(0.92) rotate(-2.5deg);
  }
  /* Rotate the text wrapper in the opposite direction so it appears straight */
  .btn-bounce:hover .btn-bounce-text__wrap {
    transform: rotate(2.5deg);
  }
  /* Move up the text span to reveal its text-shadow */
  .btn-bounce:hover .btn-bounce-text {
    transform: translate(0px, calc(-1 * var(--text-duplicate-distance)));
  }
}
@font-face {
  font-family: "Coolvetica";
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url("assets/fonts/coolvetica-regular.woff") format("woff");
}
body {
  font-family: "Arial", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: var(--text);
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Coolvetica", sans-serif;
}

h1 {
  font-size: var(--fs-h1);
  line-height: 1.1;
  /* Baranov: Große Headings – Letter-spacing leicht negativ */
  margin-top: calc(var(--lh-unit) * 3.5);
  margin-bottom: calc(var(--lh-unit) * 1);
}

h2 {
  font-size: var(--fs-h2);
  line-height: 1.1;
  margin-top: calc(var(--lh-unit) * 3);
  margin-bottom: calc(var(--lh-unit) * 1);
}

h3 {
  font-size: var(--fs-h3);
  line-height: 1.2;
  margin-top: calc(var(--lh-unit) * 2.5);
  margin-bottom: calc(var(--lh-unit) * 0.75);
}
h3.divider-year {
  font-size: var(--fs-h4);
  color: var(--muted);
}

h4 {
  font-size: var(--fs-h4);
  line-height: 1.3;
  margin-top: calc(var(--lh-unit) * 2);
  margin-bottom: calc(var(--lh-unit) * 0.5);
}

h5 {
  font-size: var(--fs-h5);
  line-height: 1.3;
  margin-top: calc(var(--lh-unit) * 1.75);
  margin-bottom: calc(var(--lh-unit) * 0.5);
}

h6 {
  font-size: var(--fs-body);
  line-height: 1.4;
  margin-top: calc(var(--lh-unit) * 1.75);
  margin-bottom: calc(var(--lh-unit) * 0.5);
}

/* Kein oberer Margin wenn Heading am Seitenanfang steht */
:is(h1, h2, h3, h4, h5, h6):first-child {
  margin-top: 0;
}

/* ──────────────────────────────────────────────────────────
    4. Absätze & Inline-Elemente
────────────────────────────────────────────────────────── */
p:not([class]) {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  /* Latin: max. Zeilenlänge ~65 Zeichen */
  max-width: var(--line-length);
  margin-top: 0;
  margin-bottom: calc(var(--lh-unit) * 1);
}
p:not([class]):last-child {
  margin-bottom: 0;
}

strong, b {
  font-weight: 700;
}

em, i {
  font-style: italic;
}

small {
  font-size: var(--fs-small);
}

sub, sup {
  font-size: 0.75em;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

abbr[title] {
  text-decoration: underline dotted;
  cursor: help;
}

mark {
  background-color: #ffe066;
  color: #1e1b16;
  padding-inline: 0.15em;
  border-radius: 2px;
}

del {
  text-decoration: line-through;
  color: var(--muted);
}

ins {
  text-decoration: underline;
  text-decoration-color: var(--c-accent);
}

/* ── Blockzitat ──────────────────────────────────────────── */
blockquote {
  /* Baranov: Im Fließtext nicht wesentlich größer als Body */
  font-size: calc(var(--fs-base) * 1.1);
  line-height: var(--lh-body);
  font-style: italic;
  border-left: 3px solid var(--c-accent);
  padding: calc(var(--lh-unit) * 0.5) var(--space-5);
  margin-top: calc(var(--lh-unit) * 1.5);
  margin-bottom: calc(var(--lh-unit) * 1.25);
  max-width: var(--line-length);
}

blockquote cite {
  display: block;
  font-size: var(--fs-caption);
  font-style: normal;
  color: var(--muted);
  margin-top: calc(var(--lh-unit) * 0.35);
}

/* ── Code & Vorformatiertes ──────────────────────────────── */
code, kbd, samp, var {
  font-family: ui-monospace, "Cascadia Code", "Source Code Pro", Menlo, Consolas, "Courier New", monospace;
  font-size: 0.875em;
}

kbd {
  padding: 0.1em 0.4em;
  border: 1px solid var(--c-border-th);
  border-radius: 3px;
  background: var(--c-bg);
}

pre {
  font-size: var(--fs-small);
  line-height: 1.6;
  overflow-x: auto;
  padding: var(--space-5);
  border: 1px solid var(--c-border);
  border-radius: 4px;
  margin-top: calc(var(--lh-unit) * 1.5);
  margin-bottom: calc(var(--lh-unit) * 1.25);
  /* Baranov: kein max-width – Code soll vollständig sichtbar sein */
}

pre code {
  font-size: inherit;
}

/* ── Horizontale Trennlinie ──────────────────────────────── */
hr {
  border: none;
  border-top: 1px solid var(--c-border);
  margin-block: calc(var(--lh-unit) * 2);
}

/* ──────────────────────────────────────────────────────────
    5. Listen
    Baranov: hängende Bullets, p↔ul gleicher Abstand wie p→p
────────────────────────────────────────────────────────── */
ul:not([class]),
ol:not([class]) {
  padding-left: 0;
  list-style-position: outside;
  margin-top: 0;
  margin-bottom: calc(var(--lh-unit) * 1);
  max-width: var(--line-length);
}

ul:not([class]) li,
ol:not([class]) li {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  margin-left: 1.5em;
  /* Baranov: einzeilige Items kompakt */
  margin-bottom: calc(var(--lh-unit) * 0.3);
}

/* Baranov: Mehrzeilige Items – größerer Abstand */
ul:not([class]) li + li,
ol:not([class]) li + li {
  margin-bottom: calc(var(--lh-unit) * 0.5);
}

/* Verschachtelte Listen */
li > ul, li > ol {
  margin-top: calc(var(--lh-unit) * 0.3);
  margin-bottom: 0;
}

/* ──────────────────────────────────────────────────────────
    6. Tabellen
    Baranov: keine vertikalen Trennlinien, Header-Hintergrund
            als Alternative zu Linien, Monospace für Zahlen
────────────────────────────────────────────────────────── */
table {
  border-collapse: collapse;
  font-size: var(--fs-th);
  width: 100%;
  max-width: 100%;
  margin-top: calc(var(--lh-unit) * 1.5);
  margin-bottom: calc(var(--lh-unit) * 1.25);
}

caption {
  font-size: var(--fs-small);
  font-weight: 700;
  text-align: left;
  padding-bottom: var(--space-2);
  color: var(--text);
}

th {
  font-size: var(--fs-th);
  font-weight: 600;
  text-align: left;
  padding: var(--space-2) var(--space-3);
  /* Baranov: Header-Linie statt Hintergrundfarbe */
  border-bottom: 1.5px solid var(--c-border-th);
}

td {
  font-size: var(--fs-th);
  padding: var(--space-2) var(--space-3);
  /* Baranov: keine vertikalen Trennlinien */
  border-bottom: 1px solid var(--c-border);
}

/* Zahlen-Spalten: Monospace für Ausrichtung (Baranov) */
td[data-type=number],
td[data-type=currency] {
  font-family: ui-monospace, "Cascadia Code", Menlo, monospace;
  text-align: right;
}

/* Mobile: Tabellen horizontal scrollbar (Baranov) */
@media (max-width: 600px) {
  table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
/* ──────────────────────────────────────────────────────────
    7. Medien & Figures
────────────────────────────────────────────────────────── */
figure {
  margin-top: calc(var(--lh-unit) * 1.75);
  margin-bottom: calc(var(--lh-unit) * 1.25);
  margin-inline: 0;
}

figure img, figure video, figure audio, figure canvas, figure svg {
  display: block;
  max-width: 100%;
  height: auto;
}

figcaption {
  font-size: var(--fs-caption);
  line-height: var(--lh-body);
  color: var(--muted);
  /* Baranov: img→figcaption ×0.35 lh-unit */
  margin-top: calc(var(--lh-unit) * 0.35);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

video, audio, iframe, canvas {
  max-width: 100%;
  display: block;
}

/* ──────────────────────────────────────────────────────────
    8. Links
────────────────────────────────────────────────────────── */
a {
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
/* ──────────────────────────────────────────────────────────
    9. Kombinationsoverrides (Abstandsmatrix nach Skill)
        Baranov: p↔ul/ol gleich wie p→p (1×)
        Latin: Heading gehört zum Nachfolger, nicht Vorgänger
────────────────────────────────────────────────────────── */
/* Abstand figure/table/blockquote/pre nach p oder Liste */
p + figure, ul + figure, ol + figure {
  margin-top: calc(var(--lh-unit) * 1.75);
}

p + table, ul + table, ol + table {
  margin-top: calc(var(--lh-unit) * 1.25);
}

p + blockquote, ul + blockquote {
  margin-top: calc(var(--lh-unit) * 1.5);
}

p + pre, ul + pre, ol + pre {
  margin-top: calc(var(--lh-unit) * 1.5);
}

/* Baranov: p↔liste gleicher Abstand wie p→p */
p + ul, p + ol, ul + p, ol + p {
  margin-top: calc(var(--lh-unit) * 1);
}

/* Heading → nächstes Element: kleiner Abstand (gehört zusammen) */
h1 + * {
  margin-top: calc(var(--lh-unit) * 1);
}

h2 + * {
  margin-top: calc(var(--lh-unit) * 0.75);
}

h3 + * {
  margin-top: calc(var(--lh-unit) * 0.75);
}

h4 + * {
  margin-top: calc(var(--lh-unit) * 0.5);
}

h5 + * {
  margin-top: calc(var(--lh-unit) * 0.5);
}

/* ──────────────────────────────────────────────────────────
    10. Interaktive Elemente
────────────────────────────────────────────────────────── */
/* ── Formulare ───────────────────────────────────────────── */
label {
  display: block;
  font-size: var(--fs-small);
  font-weight: 600;
  margin-bottom: var(--space-1);
  color: var(--text);
}

input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=color]),
select,
textarea {
  font-family: inherit;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--c-bg);
  border: 1px solid var(--c-border-th);
  border-radius: 4px;
  padding: var(--space-2) var(--space-3);
  min-height: 44px;
  width: 100%;
  max-width: var(--line-length);
}

textarea {
  min-height: calc(var(--lh-unit) * 6);
  resize: vertical;
}

fieldset {
  border: 1px solid var(--c-border);
  border-radius: 4px;
  padding: var(--space-4) var(--space-5);
  margin-bottom: calc(var(--lh-unit) * 1);
}

legend {
  font-weight: 700;
  font-size: var(--fs-body);
  padding-inline: var(--space-2);
}

/* ── Details / Summary ───────────────────────────────────── */
details {
  border: 1px solid var(--c-border);
  border-radius: 4px;
  padding: var(--space-3) var(--space-4);
  margin-bottom: calc(var(--lh-unit) * 0.75);
}

summary {
  font-weight: 600;
  cursor: pointer;
  min-height: 44px; /* Touch-Target */
  display: flex;
  align-items: center;
}

details[open] summary {
  margin-bottom: var(--space-3);
}

/* ── Dialog ──────────────────────────────────────────────── */
dialog {
  font-family: inherit;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: 6px;
  padding: var(--space-6);
  max-width: min(90vw, 40rem);
}

dialog::backdrop {
  background: rgba(0, 0, 0, 0.5);
}

/* ── Fortschritt & Meter ─────────────────────────────────── */
progress, meter {
  width: 100%;
  max-width: var(--line-length);
  height: var(--space-4);
}

/* ──────────────────────────────────────────────────────────
    11. Focus-States (WCAG 2.4.7 + 2.4.11)
────────────────────────────────────────────────────────── */
/* Browser-Standard-Outline nur für Maus/Touch entfernen */
*:focus:not(:focus-visible) {
  outline: none;
}

/* Keyboard-Fokus: immer sichtbar */
*:focus-visible {
  outline: 3px dotted var(--neutral-900);
  outline-offset: 2px;
  border-radius: 2px;
}

/* Fokus darf nicht hinter sticky Header verschwinden (WCAG 2.4.11) */
:target, :focus-visible {
  scroll-margin-top: 80px;
}

/* ──────────────────────────────────────────────────────────
    12. Barrierefreiheits-Hilfsstile
────────────────────────────────────────────────────────── */
/* Visuell versteckt, aber für Screenreader sichtbar */
.sr-only,
.visually-hidden:not(:focus):not(:active) {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

/* Skip-Links: versteckt, beim Fokus sichtbar (WCAG 2.4.1) */
.skip-link {
  position: absolute;
  top: -9999px;
  left: var(--space-4);
  z-index: 9999;
  background: var(--c-accent);
  color: #fff;
  padding: var(--space-2) var(--space-5);
  border-radius: 0 0 4px 4px;
  text-decoration: none;
  font-weight: 700;
}

.skip-link:focus {
  top: 0;
}

/* All-Caps-Klasse (Baranov: Letter-spacing erhöhen) */
.all-caps {
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Tablet / Smartphone */
@media (max-width: 600px) {
  /* Baranov: Heading-Hierarchie auf kleinen Screens schwächen */
  h1, h2 {
    letter-spacing: -0.015em;
  }
  /* Blockquotes: Innenabstand reduzieren */
  blockquote {
    padding: var(--space-3) var(--space-4);
  }
}
.underline-link {
  color: inherit;
}

[data-underline-link] {
  text-decoration: none;
  position: relative;
}

[data-underline-link]::before,
[data-underline-link=alt]::before,
[data-underline-link=alt]::after {
  content: "";
  position: absolute;
  bottom: -0.0625em;
  left: 0;
  width: 100%;
  height: 0.0625em;
  background-color: currentColor;
  transition: transform 0.735s cubic-bezier(0.625, 0.05, 0, 1);
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
}

[data-underline-link=alt]::before {
  transform-origin: left;
  transform: scaleX(1) rotate(0.001deg);
  transition-delay: 0.3s;
}

[data-underline-link=alt]::after {
  transform-origin: right;
  transform: scaleX(0) rotate(0.001deg);
  transition-delay: 0s;
}

@media (hover: hover) and (pointer: fine) {
  [data-hover]:hover [data-underline-link]::before,
  [data-underline-link]:hover::before {
    transform-origin: left;
    transform: scaleX(1) rotate(0.001deg);
  }
  [data-hover]:hover [data-underline-link=alt]::before,
  [data-underline-link=alt]:hover::before {
    transform-origin: right;
    transform: scaleX(0) rotate(0.001deg);
    transition-delay: 0s;
  }
  [data-hover]:hover [data-underline-link=alt]::after,
  [data-underline-link=alt]:hover::after {
    transform-origin: left;
    transform: scaleX(1) rotate(0.001deg);
    transition-delay: 0.3s;
  }
}
.content-grid {
  gap: var(--space-6);
  flex-flow: column;
  grid-auto-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  display: grid;
  position: relative;
}

body > header {
  background-color: var(--warm-200);
  padding: var(--space-6);
}
body > header a {
  text-decoration: none;
}
body > header .logo {
  font-family: "Coolvetica", sans-serif;
  color: var(--text);
  font-size: var(--fs-h4);
  line-height: 1.1;
}

/* Desktop */
:root {
  --size-unit: 16; /* body font-size in design - no px */
  --size-container-ideal: 1280; /* screen-size in design - no px */
  --size-container-min: 992px;
  --size-container-max: 1440px;
  --size-container: clamp(var(--size-container-min), 100vw, var(--size-container-max));
  --size-font: calc(var(--size-container) / (var(--size-container-ideal) / var(--size-unit)));
}

/* Tablet */
@media screen and (max-width: 991px) {
  :root {
    --size-container-ideal: 834; /* screen-size in design - no px */
    --size-container-min: 768px;
    --size-container-max: 991px;
  }
}
/* Mobile Landscape */
@media screen and (max-width: 767px) {
  :root {
    --size-container-ideal: 550; /* screen-size in design - no px */
    --size-container-min: 480px;
    --size-container-max: 767px;
  }
}
/* Mobile Portrait */
@media screen and (max-width: 479px) {
  :root {
    --size-container-ideal: 390; /* screen-size in design - no px */
    --size-container-min: 320px;
    --size-container-max: 479px;
  }
}
.container {
  width: min(100%, var(--size-container));
  margin-inline: auto;
  padding-inline: var(--space-6);
}

section.participating-artists, section.regular-page {
  padding-block: calc(var(--lh-unit) * 3);
}

.footer-wrap {
  position: relative;
  overflow: hidden;
  background-color: var(--text);
  color: var(--warm-50);
}
.footer-wrap__dark {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-color: var(--text-deep, #201d1d);
  opacity: 0;
  pointer-events: none;
}

.footer {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 3.75rem var(--space-6);
  padding-inline: var(--space-6);
  padding-block: calc(var(--lh-unit) * 3) var(--space-6);
}
@media (min-width: 60rem) {
  .footer {
    row-gap: 7.5rem;
  }
}
.footer__links-row {
  display: grid;
  gap: calc(var(--lh-unit) * 2);
}
@media (min-width: 50rem) {
  .footer__links-row {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 70rem) {
  .footer__links-row {
    grid-template-columns: 1fr 1.6fr 1fr 1fr;
  }
}
.footer__legals-row {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr auto;
  grid-template-areas: "nav nav" "copy version";
  padding-block-start: var(--space-6);
  border-block-start: 1px solid var(--warm-500);
}
@media (min-width: 50rem) {
  .footer__legals-row {
    grid-template-columns: 1fr auto 1fr;
    grid-template-areas: "copy nav version";
    align-items: center;
  }
}
.footer__legals-row .nav-legals {
  grid-area: nav;
}
.footer__legals-row .copyright {
  grid-area: copy;
}
.footer__legals-row .version {
  grid-area: version;
  color: var(--warm-500);
  text-align: end;
}
.footer__legals-row .nav-legals ul {
  display: flex;
  gap: var(--space-6);
  margin-block-end: 0;
  list-style: none;
}
.footer__legals-row .nav-legals ul li {
  margin: 0;
}
.footer__legals-row .nav-legals ul a {
  color: var(--warm-50);
}
.footer__col {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-6);
}
.footer__links {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3) 0.25em;
}
.footer__info {
  max-width: 44ch;
}
.footer__a {
  color: inherit;
  font-size: var(--fs-h4);
  font-weight: 600;
  line-height: 1;
  text-decoration: none;
}

#fkkb-logo {
  max-width: 10rem;
}

.eyebrow {
  margin-block-end: var(--space-1);
  color: var(--warm-400);
  font-size: var(--fs-caption);
  font-weight: 400;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.typo-scroll {
  color: var(--text);
  position: relative;
  overflow: clip;
}

.typo-scroll__collection {
  flex-flow: column;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

.typo-scroll__list {
  border-top: 1px solid var(--warm-700);
  padding-top: calc(var(--lh-unit) * 1.5);
  list-style: none;
  flex-flow: column;
  width: 100%;
  display: flex;
}

.typo-scroll__item {
  width: 100%;
  position: relative;
  border-bottom: 1px solid var(--warm-100);
}

.typo-scroll__link {
  color: inherit;
  width: 100%;
  text-decoration: none;
}
.typo-scroll__link .wrap {
  padding-block: var(--space-4);
  display: flex;
  gap: var(--space-4);
  justify-content: space-between;
  align-content: center;
}
.typo-scroll__link .wrap > span {
  color: var(--warm-400);
  font-size: var(--fs-h2);
}

.typo-scroll__h {
  position: relative;
  white-space: nowrap;
  margin-top: 0;
  margin-bottom: 0;
  font-size: var(--fs-hero);
  line-height: 1;
}
.typo-scroll__h .crew {
  font-size: clamp(1.5rem, 2vw + 0.5rem, 4rem);
  color: var(--text);
}

svg.member-badge {
  opacity: 0;
  position: absolute;
  display: block;
  width: 4em;
  height: 4em;
  top: var(--space-3);
  right: var(--space-3);
  animation: spin 6s infinite linear;
}

[data-typo-scroll-item=active] .member-badge {
  z-index: 4;
  opacity: 1;
}

[data-typo-scroll-item=active] .typo-scroll__h {
  z-index: 3;
  color: #6B6B6B;
  mix-blend-mode: difference;
}

.typo-scroll__media {
  aspect-ratio: 1/1;
  pointer-events: none;
  width: 17.5vw;
  z-index: 2;
  position: absolute;
  top: 50%;
  left: 50%;
  overflow: hidden;
  transform: translate(-50%, -50%);
  --po: 1.25em; /* Path offset */
  transition: clip-path 1.2s cubic-bezier(0.16, 1, 0.3, 1);
  clip-path: polygon(calc(0% + var(--po)) calc(0% + var(--po)), calc(100% - var(--po)) calc(0% + var(--po)), calc(100% - var(--po)) calc(100% - var(--po)), calc(0% + var(--po)) calc(100% - var(--po)));
  opacity: 0;
}

[data-typo-scroll-item=active] .typo-scroll__media {
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  opacity: 1;
}

@media (hover: none) and (pointer: coarse) {
  [data-typo-scroll-item=active] .typo-scroll__media {
    pointer-events: all;
  }
}
.typo-scroll__img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  max-height: 100%;
}

.typo-scroll__img.is--bw {
  filter: grayscale(1);
}

.typo-scroll__p {
  -webkit-backdrop-filter: blur(1em);
  backdrop-filter: blur(1em);
  color: #f4f4f4;
  text-align: center;
  white-space: nowrap;
  background-color: rgba(32, 29, 29, 0.2);
  margin-bottom: 0;
  padding: 0.25em;
  font-family: monospace;
  font-size: 0.75em;
  position: absolute;
  bottom: 2em;
  left: 50%;
  transform: translate(-50%);
}

@media screen and (max-width: 991px) {
  .typo-scroll__media {
    width: 52vw;
  }
}
.page-exhibition .exhibition-header {
  background-color: var(--ink);
  padding-block: calc(var(--lh-unit) * 3);
}
.page-exhibition .exhibition-header .container {
  display: grid;
  height: 100%;
  grid-template-columns: 1.6fr 1fr;
  grid-auto-rows: auto;
  gap: var(--space-14);
}
.page-exhibition .exhibition-header__images {
  grid-row: span 2/span 2;
}
.page-exhibition .exhibition-header__metadata {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: end;
}
.page-exhibition .exhibition-header__metadata .exhibtion-metadata .row {
  border-bottom: 0;
  padding-bottom: 0;
}
.page-exhibition .exhibition-header__metadata .exhibtion-metadata .row dd {
  color: var(--warm-100);
  font-size: var(--fs-h4);
}
.page-exhibition .exhibition-header .artist-name {
  line-height: 1.1;
  font-size: var(--fs-h4);
  color: var(--warm-400);
  margin-bottom: calc(var(--lh-unit) / 2);
}
.page-exhibition .exhibition-header .exhibition-title {
  font-size: var(--fs-hero);
  margin-top: 0;
  line-height: 0.9;
  letter-spacing: 0.04em;
  color: var(--white);
}
.page-exhibition .exhibition-header .description {
  font-size: var(--fs-body);
  max-width: 44ch;
  color: var(--white);
}
.page-exhibition .content {
  display: grid;
  gap: calc(var(--lh-unit) * 3);
  padding-block: calc(var(--lh-unit) * 3);
}
.page-exhibition .content h2 {
  font-size: var(--fs-h5);
}
@media (min-width: 50rem) {
  .page-exhibition .content {
    grid-template-columns: 1fr 2fr;
  }
}
.page-exhibition .exhibtion-metadata {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.page-exhibition .exhibtion-metadata .row {
  display: flex;
  flex-direction: column;
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--rule);
}
.page-exhibition .exhibtion-metadata dt {
  font-size: var(--fs-caption);
  text-transform: uppercase;
  color: var(--warm-400);
  margin-bottom: var(--space-1);
  letter-spacing: 0.05em;
}
.page-exhibition .exhibtion-metadata dd {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  color: var(--text);
  gap: var(--space-1);
}
.page-exhibition .exhibtion-metadata dd a {
  display: inline-block;
  white-space: nowrap;
  margin-right: auto;
}
.page-exhibition p.intro-text {
  font-size: var(--fs-h4);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -0.025em;
  max-width: 44ch;
  margin-bottom: calc(var(--lh-unit) * 1);
}

.exhibtion-teaser {
  display: grid;
  height: 100%;
  grid-template-columns: 1.6fr 1fr;
  grid-auto-rows: auto;
  background-color: var(--text);
  padding: var(--space-8) 0;
  /* &:last-child {
      grid-template-columns: 1fr;
      background-color: var(--bg);
      padding: var(--space-8);

      .title,
      .description,
      .exhibtion-meta-type__date,
      .exhibtion-meta-link a {
          color: var(--text);
      }
  } */
}
.exhibtion-teaser__header {
  display: flex;
  flex-direction: column;
  padding-bottom: var(--space-8);
}
.exhibtion-teaser__header .artist {
  font-size: var(--fs-base);
  color: var(--warm-400);
  margin-bottom: calc(var(--lh-unit) / 2);
}
.exhibtion-teaser__header .title {
  font-size: var(--fs-hero);
  margin-block: 0;
  line-height: 0.9;
  color: var(--white);
}
.exhibtion-teaser__header .description {
  font-size: var(--fs-base);
  max-width: 44ch;
  color: var(--white);
}
.exhibtion-teaser__metas {
  margin-top: auto;
  grid-column: span 2/span 2;
  grid-row-start: 2;
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: var(--space-10);
  align-items: end;
  padding-top: var(--space-6);
}
.exhibtion-teaser .exhibtion-meta-type {
  display: flex;
  flex-direction: column;
}
.exhibtion-teaser .exhibtion-meta-type__label {
  font-size: var(--fs-caption);
  text-transform: uppercase;
  color: var(--warm-400);
  margin-bottom: var(--space-1);
  letter-spacing: 0.05em;
}
.exhibtion-teaser .exhibtion-meta-type__date {
  color: var(--white);
}
.exhibtion-teaser .exhibtion-meta-link {
  display: flex;
  margin-left: auto;
  white-space: nowrap;
}
.exhibtion-teaser .exhibtion-meta-link a {
  color: var(--white);
}

.u-test-flex {
  display: flex;
}

html.lenis, html.lenis body {
  height: auto;
}

.lenis.lenis-smooth [data-lenis-prevent] {
  overscroll-behavior: contain;
}

.lenis.lenis-stopped {
  overflow: clip;
}

.lenis.lenis-smooth iframe {
  pointer-events: none;
}

*, *::before, *::after {
  box-sizing: border-box;
}

html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--text);
  margin-inline: auto;
  background-color: var(--bg);
}

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

img:is([sizes=auto i], [sizes^="auto," i]) {
  contain-intrinsic-size: 3000px 1500px;
}

/*# sourceMappingURL=style.css.map */
