.cormorant-garamond-bold {
  font-family: "Cormorant Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

.manrope-bold {
  font-family: "Manrope", sans-serif;
  font-optical-sizing: auto;
  font-weight: 800;
  font-style: normal;
}

.space-grotesk-bold {
  font-family: "Space Grotesk", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
}

@font-face {
  font-family: "Helvetica Black Condensed";
  src: url("/fonts/Helvetica%20Black%20Condensed.otf") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Extra Compressed";
  src: url("/fonts/Helvetica%20Extra%20Compressed%20Regular.otf")
    format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Helvetica Black Condensed Oblique";
  src: url("/fonts/Helvetica%20Black%20Condensed%20Oblique.otf")
    format("opentype");
  font-weight: 900;
  font-style: oblique;
  font-display: swap;
}

@font-face {
  font-family: "Kyrilla Bold";
  src: url("/fonts/KyrillaSansSerif-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* === Theme tokens (Light default) === */
:root {
  color-scheme: light dark;

  /* Base */
  --bg: #ffffff;
  --surface: #f6f6f7;
  --text: #111827;
  --muted: #6b7280;
  --border: #e5e7eb;
  --gallery-bg: #eef2f8;
  --gallery-card-bg: #ffffff;
  --gallery-title: #111827;
  --gallery-text: #475569;
  --titel-color: #853535;
  --accent-contrast: #111827;
  --nav-accent: #853535;
  --nav-accent-contrast: #ffffff;
  --link: var(--accent);
  --focus: rgba(194, 164, 134, 0.35);

  /* Radius / typography */
  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius: var(--radius-md);
  --font-heading: "Poppins", "Inter", system-ui, sans-serif;
  --font-body: "Inter", system-ui, sans-serif;
  --festival-nav-height: 88px;

  /* Core palette */
  --kurd-white: #ffffff;
  --background: #ffe5e5;
  --background-alt: #eafdef;
  --default-bg: #f1f3fa;
  --surface-strong: #ffffff;
  --border-subtle: #e1e3ee;
  --border-strong: #c6cadb;
  --text-main: #2c3444;
  --text-opposite: #f9faff;
  --text-soft: #666c7f;
  --text-muted: #9aa0b4;
  --text-on-dark: #ffffff;
  --primary: #d13e3e;
  --primary-hover: #c73535;
  --primary-disabled: #f3c4c4;
  --primary-disabled-text: #ffffffb3;
  --primary-soft: #fbe4e4;
  --secondary: #fdf1cf;
  --secondary-hover: #f8d778;
  --secondary-text-color: #7a4f00;
  --accent: #64b680;
  --accent-green-soft: #e0f2e8;
  --accent-blue: #2251c2;
  --accent-blue-soft: #e0ecff;
  --kurd-red-soft: #f5c3c3;
  --kurd-green: #2e7d5b;
  --kurd-green-soft: #c4ecd6;
  --kurd-yellow-soft: #fbe7b3;
  --background-yellow: #fff;
  --kurd-yellow-middle: #fdf3d8;
  --kurd-yellow-soft-opposite: #6e5306;
  --background-yellow-opposite: #191301;
  --kurd-yellow-middle-opposite: #604904;
  --success: #2e7d5b;
  --success-soft: #d9f2e5;
  --warning: #f9a825;
  --warning-soft: #fff4d6;
  --error: #d32f2f;
  --error-soft: #fde1e1;
  --color-overlay: #090f1eb3;

  /* Page-level gradients */
  --media-section-bg: linear-gradient(
    90deg,
    var(--background-alt) 0%,
    #f4fef7 25%,
    #ffffff 100%
  );
  --media-card-bg: #f7c9c9;
  --media-card-text: #111827;
  --media-thumb-fallback: linear-gradient(
    135deg,
    #ffd4c2 0%,
    #f07c7c 45%,
    #5fd3d1 100%
  );
  --video-page-bg: linear-gradient(
    90deg,
    #fdecec 0%,
    #f7c2c2 45%,
    #fff4f4 100%
  );
  --tickets-hero-bg: var(--media-section-bg);
  --tickets-hero-title: var(--kurd-green);
  --tickets-hero-text: #3a6f56;
  --tickets-section-bg: var(--media-section-bg);
  --tickets-card-bg: #ccefdc;
  --tickets-card-shadow: rgba(46, 125, 91, 0.15);
  --tickets-card-text: #1b4a35;
  --tickets-muted: #5a7c6c;
  --tickets-accent: #d84848;

  --welcome-top-gradient: linear-gradient(
    180deg,
    var(--border-subtle) 0%,
    rgba(225, 227, 238, 0) 30%
  );
}

/* === Theme tokens (Dark) === */
:root[data-theme="dark"] {
  --bg: #0b0f17;
  --surface: #111827;
  --text: #f9fafb;
  --muted: #9ca3af;
  --border: #253044;
  --gallery-bg: #111827;
  --gallery-card-bg: #1f2937;
  --gallery-title: #f8fafc;
  --gallery-text: #cbd5f5;
  --titel-color: #faa4a4;
  --accent-contrast: #0b0f17;
  --focus: rgba(194, 164, 134, 0.28);

  --kurd-white: #ffffff;
  --background: #050709;
  --background-alt: #04130c;
  --default-bg: #101520;
  --surface-strong: #181d2b;
  --border-subtle: #252c40;
  --border-strong: #3a4258;
  --text-main: #f9faff;
  --text-opposite: #1b2230;
  --text-soft: #ebebeb;
  --text-muted: #8d93a8;
  --text-on-dark: #ffffff;
  --color-overlay: #000000b3;
  --primary: #d13e3e;
  --primary-hover: #c73535;
  --primary-disabled: #4c2a2a;
  --primary-disabled-text: #ffffffb3;
  --primary-soft: #521313;
  --secondary: #705404;
  --secondary-hover: #8c6408;
  --secondary-text-color: #fbe7b3;
  --accent: #64b680;
  --accent-green-soft: #1e4730;
  --accent-blue: #2251c2;
  --accent-blue-soft: #002766;
  --kurd-red-soft: #5a1616;
  --kurd-green: #2e7d5b;
  --kurd-green-soft: #1e4730;
  --kurd-yellow-soft: #6e5306;
  --background-yellow: #291f02;
  --kurd-yellow-middle: #604904;
  --kurd-yellow-soft-opposite: #b38716;
  --background-yellow-opposite: #fff;
  --kurd-yellow-middle-opposite: #fdf3d8;
  --success: #2e7d5b;
  --success-soft: #1e4730;
  --warning: #f9a825;
  --warning-soft: #633e02;
  --error: #d32f2f;
  --error-soft: #5f0606;
  --border-bottom: #000000;
  --media-section-bg: linear-gradient(
    90deg,
    #5a1616 0%,
    #2e0e0f 25%,
    #050709 100%
  );
  --media-card-bg: #521313;
  --media-card-text: #f9faff;
  --video-page-bg: linear-gradient(
    90deg,
    #5a1616 0%,
    #2e0e0f 40%,
    #050709 100%
  );
  --tickets-hero-bg: linear-gradient(
    90deg,
    var(--kurd-green-soft) 0%,
    #112e1e 25%,
    var(--background-alt) 100%
  );
  --tickets-hero-title: #5fb58a;
  --tickets-hero-text: #4d8e6a;
  --tickets-section-bg: linear-gradient(
    90deg,
    var(--kurd-green-soft) 0%,
    #112e1e 25%,
    var(--background-alt) 100%
  );
  --tickets-card-bg: #1f4a35;
  --tickets-card-shadow: rgba(0, 0, 0, 0.35);
  --tickets-card-text: #e0f2e8;
  --tickets-muted: #95b6a6;
  --tickets-accent: #ff5a5a;

  --welcome-top-gradient: linear-gradient(
    180deg,
    var(--border-subtle) 0%,
    rgba(37, 44, 64, 0) 30%
  );
}

/* === Optional: Accent presets (wenn du feste Farbschemen willst) === */
/* :root[data-accent="gold"] {
  --accent: #c2a486;
}
:root[data-accent="red"] {
  --accent: #d9463e;
}
:root[data-accent="blue"] {
  --accent: #3b82f6;
} */

/* === Use tokens === */
html,
body {
  background: var(--media-section-bg);
  color: var(--text);
  margin: 0px;
}

/* a:hover,
button:hover,
input[type="button"]:hover,
input[type="submit"]:hover,
input[type="reset"]:hover,
[role="button"]:hover,
[role="link"]:hover,
[data-link]:hover,
[data-clickable]:hover {
  cursor: var(--cursor-interactive);
} */

.page {
  overflow-x: hidden;
}

.page--legal {
  padding: 80px 0 100px;
}

.page--legal > * {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 60px;
}

.page--legal .richtext h2 {
  margin-top: 0;
}

@media (max-width: 1024px) {
  .page--legal {
    padding: 72px 0 88px;
  }

  .page--legal > * {
    padding: 0 24px;
  }
}

@media (max-width: 768px) {
  .page--legal {
    padding: 64px 0 80px;
  }

  .page--legal > * {
    padding: 0 10px;
  }
}

.videos-page {
  background: var(--video-page-bg);
}

@supports (overflow: clip) {
  .page {
    overflow-x: clip;
  }
}

html {
  scroll-behavior: smooth;
}

/* === Shared section layout === */
.section {
  width: 100%;
  margin-left: 0;
  padding: 80px 0;
  overflow: hidden;
}

.section__inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 60px;
}

.section--align-left .section__inner {
  text-align: left;
}

.section--align-center .section__inner {
  text-align: center;
}

.section--align-right .section__inner {
  text-align: right;
}

h1,
h2,
h3,
h4 {
  font-family: var(--font-heading);
  color: var(--text-main);
}

h1 {
  font-size: clamp(36px, 4vw, 44px);
  font-weight: 700;
}

h2 {
  font-size: clamp(28px, 3vw, 36px);
  font-weight: 600;
}

h3 {
  font-size: clamp(22px, 2.4vw, 24px);
  font-weight: 600;
}

h4 {
  font-size: clamp(18px, 2vw, 20px);
  font-weight: 600;
}

p {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--text-main);
}

.p-semi-bold {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.5;
  color: var(--text-main);
}

.p-small {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 400;
  color: var(--text-main);
}

.meta-caps {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 400;
  text-transform: uppercase;
  color: var(--text-main);
}

.meta-caps-semi {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--text-main);
}

a {
  color: var(--link);
  font-family: var(--font-body);
}

/* Global button radius consistency */
body:not(.admin-body)
  :is(
    button,
    input[type="button"],
    input[type="submit"],
    input[type="reset"],
    a[class*="button"],
    a[class*="btn"],
    a[class*="cta"],
    [role="button"]
  ) {
  border-radius: var(--radius-md) !important;
}

.container {
  padding-top: 50px;
}

.card,
.panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}

.btn-primary {
  background: var(--accent);
  color: var(--accent-contrast);
  border: 1px solid color-mix(in srgb, var(--accent), #000 12%);
}

:focus-visible {
  outline: 3px solid var(--focus);
  outline-offset: 2px;
}

.nav-settings {
  display: flex;
  gap: 10px;
  align-items: center;
}
.nav-select {
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
}
.nav-color {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  background: var(--surface);
  padding: 4px;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
/* Ausgangszustand: Element ist nach links versetzt und unsichtbar */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity 0.6s ease-out,
    transform 0.6s ease-out;
}

/* Wenn sichtbar (im Viewport): gleitet an Position und wird sichtbar */
.animate-on-scroll.visible {
  opacity: 1;
  transform: translateX(0);
}

/* Wenn gerade verlassen (Viewport nach oben verlassen): nach rechts versetzen und ausblenden */
.animate-on-scroll.out {
  opacity: 0;
  transform: translateY(40px);
}

.animate-on-scroll-right {
  opacity: 0;
  transform: translateX(40px);
  transition:
    opacity 0.6s ease-in,
    transform 0.6s ease-in;
}

/* Wenn sichtbar (im Viewport): gleitet an Position und wird sichtbar */
.animate-on-scroll-right.visible {
  opacity: 1;
  transform: translateX(0px);
}

/* Wenn gerade verlassen (Viewport nach oben verlassen): nach rechts versetzen und ausblenden */
.animate-on-scroll-right.out {
  opacity: 0;
  transform: translateX(40px);
}

.animate-on-scroll-left {
  opacity: 0;
  transform: translateX(-40px);
  transition:
    opacity 0.6s ease-in,
    transform 0.6s ease-in;
}

/* Wenn sichtbar (im Viewport): gleitet an Position und wird sichtbar */
.animate-on-scroll-left.visible {
  opacity: 1;
  transform: translateX(0px);
}

/* Wenn gerade verlassen (Viewport nach oben verlassen): nach rechts versetzen und ausblenden */
.animate-on-scroll-left.out {
  opacity: 0;
  transform: translateX(-40px);
}

/* === Media showcase (Festival Videos) === */

/* === Festival Navbar === */
.festival-nav {
  margin: 0;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.festival-nav__inner {
  margin: 0;
  padding: 14px 32px;
  border-radius: 0 0 12px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.08);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  position: relative;
  gap: 16px;
  transition:
    background 0.5s ease,
    box-shadow 0.5s ease,
    border-color 0.5s ease,
    border-radius 0.3s ease;
}

.festival-nav__left-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-self: start;
  min-width: 0;
}

.festival-nav__lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  /* background: color-mix(in srgb, var(--surface) 86%, transparent); */
}

.festival-nav__lang-link {
  font-family: var(--font-heading);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  color: var(--text-soft);
  opacity: 0.45;
  transition:
    opacity 0.2s ease,
    color 0.2s ease;
}

.festival-nav__lang-link:hover {
  opacity: 0.78;
  color: var(--text);
}

.festival-nav__lang-link.is-active {
  color: var(--primary);
  opacity: 1;
}

.festival-nav__lang-switch--mobile {
  display: none;
}

.festival-nav.is-scrolled .festival-nav__inner {
  background: color-mix(in srgb, var(--surface) 30%, transparent);
  border-bottom-color: color-mix(in srgb, var(--border) 65%, transparent);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.festival-nav.is-menu-open .festival-nav__inner {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  background: var(--surface);
  border-bottom-color: var(--border);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.08);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.festival-nav__burger {
  border: none;
  background: transparent;
  padding: 6px;
  display: inline-flex;
  flex-direction: column;
  gap: 6px;
  cursor: pointer;
}

.festival-nav__burger-line {
  width: 32px;
  height: 4px;
  border-radius: 999px;
  background: var(--primary);
}

.switch {
  font-size: 17px;
  position: relative;
  display: inline-block;
  width: 70px;
  height: 37px;
  flex: 0 0 auto;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: var(--nav-accent);
  transition: 0.4s;
  border-radius: 30px;
}

.slider:before {
  position: absolute;
  content: "";
  height: 33px;
  width: 33px;
  border-radius: 20px;
  left: 2px;
  bottom: 2px;
  z-index: 2;
  background-color: #f3efef;
  transition: 0.4s;
}

.sun svg {
  color: var(--secondary-hover);
  position: absolute;
  top: 6px;
  left: 36px;
  z-index: 1;
  width: 24px;
  height: 24px;
}

.moon svg {
  fill: var(--secondary-hover);
  position: absolute;
  top: 5px;
  left: 5px;
  z-index: 1;
  width: 24px;
  height: 24px;
}

/* .switch:hover */
.sun svg {
  animation: rotate 15s linear infinite;
}

@keyframes rotate {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

/* .switch:hover */
.moon svg {
  animation: tilt 5s linear infinite;
}

@keyframes tilt {
  0% {
    transform: rotate(0deg);
  }

  25% {
    transform: rotate(-10deg);
  }

  75% {
    transform: rotate(10deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

.input:checked + .slider {
  background-color: var(--border-subtle);
}

.input:focus + .slider {
  box-shadow: none;
}

.input:checked + .slider:before {
  transform: translateX(30px);
}

.festival-nav__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: center;
  position: static;
  transform: none;
  margin: 0;
  z-index: 150;
}

.festival-nav__logo img {
  height: 40px;
  width: auto;
  display: block;
}

.festival-nav__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-self: end;
  min-width: 0;
  z-index: 200;
}

.festival-nav__logo .logo--dark {
  display: none;
}

:root[data-theme="dark"] .festival-nav__logo .logo--light {
  display: none;
}

:root[data-theme="dark"] .festival-nav__logo .logo--dark {
  display: block;
}

.festival-nav__cta {
  background: var(--nav-accent);
  color: var(--nav-accent-contrast);
  padding: 10px 20px;
  border-radius: 12px;
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 14px;
  text-decoration: none;
  box-shadow: 0 12px 24px rgba(209, 62, 62, 0.25);
  transition:
    transform 0.2s ease,
    filter 0.2s ease,
    box-shadow 0.2s ease;
}

.festival-nav__cta:hover {
  filter: brightness(1.05);
  text-decoration: none;
}

.festival-nav__actions .festival-nav__cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(209, 62, 62, 0.3);
}

.festival-nav__actions .festival-nav__cta--secondary:hover {
  box-shadow: 0 16px 30px rgba(95, 181, 138, 0.3);
}

.festival-nav__cta--secondary {
  background: var(--kurd-green);
  color: var(--kurd-white);
  box-shadow: 0 12px 24px rgba(194, 164, 134, 0.25);
  z-index: 100;
}

.festival-nav__cta-button {
  border: none;
  cursor: pointer;
}

.festival-nav__auth-icon {
  width: 42px;
  min-width: 42px;
  height: 37px;
  padding: 0;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0;
  text-transform: none;
}

.festival-nav__auth-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

@media (hover: hover) and (pointer: fine) {
  .festival-nav__actions {
    --nav-tooltip-bg: color-mix(in srgb, var(--surface) 92%, #000 8%);
  }

  .festival-nav__theme-switch--desktop {
    position: relative;
  }

  .festival-nav__auth-icon::before,
  .festival-nav__theme-switch--desktop::before {
    content: attr(data-tooltip);
    position: absolute;
    left: 50%;
    top: calc(100% + 10px);
    transform: translate(-50%, -6px);
    padding: 5px 8px;
    border-radius: 8px;
    background: var(--nav-tooltip-bg);
    color: var(--text-main);
    font-family: "Inter", system-ui, sans-serif;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.01em;
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.14);
    transition:
      opacity 0.2s ease,
      transform 0.2s ease,
      visibility 0.2s ease;
    z-index: 12;
  }

  .festival-nav__auth-icon::after,
  .festival-nav__theme-switch--desktop::after {
    content: "";
    position: absolute;
    left: 50%;
    top: calc(100% + 4px);
    width: 8px;
    height: 8px;
    transform: translateX(-50%) rotate(45deg);
    background: var(--nav-tooltip-bg);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
      opacity 0.2s ease,
      visibility 0.2s ease;
    z-index: 11;
  }

  .festival-nav__auth-icon:hover::before,
  .festival-nav__auth-icon:hover::after,
  .festival-nav__auth-icon:focus-visible::before,
  .festival-nav__auth-icon:focus-visible::after,
  .festival-nav__theme-switch--desktop:hover:not(
      .is-tooltip-suppressed
    )::before,
  .festival-nav__theme-switch--desktop:hover:not(
      .is-tooltip-suppressed
    )::after {
    opacity: 1;
    visibility: visible;
  }

  .festival-nav__auth-icon:hover::before,
  .festival-nav__auth-icon:focus-visible::before,
  .festival-nav__theme-switch--desktop:hover:not(
      .is-tooltip-suppressed
    )::before {
    transform: translate(-50%, 0);
  }
}

.festival-nav__logout {
  margin: 0;
}

.festival-nav__menu {
  max-width: 100%;
  margin: 0;
  padding: 24px 32px;
  border-radius: 0 0 16px 16px;
  border-top: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.1);
  opacity: 0;
  transform: translateY(-12px);
  pointer-events: none;
  transition:
    opacity 0.8s ease,
    transform 0.8s ease;
  will-change: transform, opacity;
}

.festival-nav.is-menu-open .festival-nav__menu {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

@media (min-width: 801px) {
  .festival-nav.is-menu-open .festival-nav__inner {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 12px;
  }

  .festival-nav .festival-nav__menu {
    position: absolute;
    top: calc(100% - 1px);
    left: 0;
    width: 420px;
    max-width: none;
    padding: 0;
    border: none;
    background: transparent;
    box-shadow: none;
    overflow: visible;
    z-index: 1050;
  }

  .festival-nav .festival-nav__menu-grid {
    display: block;
  }

  .festival-nav .festival-nav__icon-menu {
    width: 420px;
    height: 430px;
    min-width: 0;
    min-height: 0;
    padding: 0px 50px 50px 0px;
    border-radius: 0;
    border: none;
    background: transparent;
    box-shadow: none;
    overflow: hidden;
    position: relative;
  }

  .festival-nav .festival-nav__icon-menu::before {
    content: "";
    position: absolute;
    top: -235px;
    left: -230px;
    width: 640px;
    height: 640px;
    border-radius: 50%;
    /* border: 1px solid 
color-mix(in srgb, var(--border) 82%, transparent); */
    background: var(--surface);
    box-shadow: 0 22px 44px rgba(0, 0, 0, 0.24);
    z-index: 0;
  }

  .festival-nav .festival-nav__icon-menu-ring {
    height: 320px;
    z-index: 1;
  }
}

.festival-nav__menu-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: start;
}

.festival-nav__icon-menu {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  min-height: 300px;
  padding: 0 0 0 8px;
}

.festival-nav__mobile-utilities {
  display: none;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}

.festival-nav__icon-menu-ring {
  position: relative;
  width: 100%;
  height: 180px;
}

.festival-nav__icon-link {
  position: absolute;
  left: 0;
  top: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: var(--text);
  opacity: 0;
  transform: translate(0, 0) scale(0.6);
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    opacity 0.25s ease;
  transition-delay: var(--reverse-delay, 0s);
  will-change: transform, opacity;
}

.festival-nav.is-menu-open .festival-nav__icon-link {
  opacity: 1;
  transform: translate(var(--x, 0), var(--y, 0)) scale(1);
  transition-delay: var(--delay, 0s);
}

.festival-nav__icon-shell {
  width: 64px;
  height: 64px;
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface) 70%, transparent);
  /* border: 1px solid color-mix(in srgb, var(--border) 60%, transparent); */
  display: grid;
  place-items: center;
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.12);
}

.festival-nav__icon-shell img {
  width: 64px;
  height: 64px;
}

.festival-nav__icon-label {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-align: center;
  position: absolute;
  bottom: -25px;
}

.festival-nav__icon-link:hover .festival-nav__icon-shell {
  border-color: var(--nav-accent);
  box-shadow: 0 18px 32px rgba(209, 62, 62, 0.2);
}

.festival-nav__icon-link:hover .festival-nav__icon-label {
  color: var(--nav-accent);
}

/* === Social Rail === */
.social-rail {
  position: fixed;
  top: 50%;
  right: 20px;
  bottom: auto;
  left: auto;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: 12px;
  padding: 14px 12px;
  border-radius: 24px;
  border: 1px solid color-mix(in srgb, var(--border) 90%, transparent);
  background: color-mix(in srgb, var(--surface) 95%, transparent);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition:
    opacity 0.4s ease,
    background 0.4s ease,
    box-shadow 0.4s ease;
  z-index: 900;
}

.social-rail__desktop-links {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.social-rail.is-dimmed {
  opacity: 0.7;
  background: color-mix(in srgb, var(--surface) 85%, transparent);
  box-shadow: 0 10px 18px rgba(0, 0, 0, 0.12);
}

.social-rail:hover {
  opacity: 1;
  background: color-mix(in srgb, var(--surface) 98%, transparent);
  box-shadow: 0 16px 30px rgba(0, 0, 0, 0.18);
}

.social-rail.is-hidden-at-bottom,
.social-rail.is-hidden-at-bottom:hover {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.social-rail__link {
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: var(--nav-accent);
  border: 1px solid var(--nav-accent);
  transition:
    transform 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease;
}

.social-rail__link svg {
  width: 22px;
  height: 22px;
}

.social-rail__link:hover {
  transform: translateY(-2px);
  color: #fff;
  border-color: var(--primary-hover);
  background: var(--primary-hover);
  text-decoration: none;
}

.social-rail-mobile {
  display: none;
}

.social-rail-mobile__toggle,
.social-rail-mobile__bubble {
  border: none;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 800px) {
  .festival-nav__inner {
    padding: 12px 16px;
    border-radius: 0 0 10px 10px;
  }

  .festival-nav__theme-switch--desktop {
    display: none;
  }

  .festival-nav__lang-switch--desktop {
    display: none;
  }

  .festival-nav__mobile-utilities {
    display: inline-flex;
    align-items: center;
    gap: 50px;
    margin-top: 30px;
    margin-left: -32px;
  }

  .festival-nav__lang-switch--mobile {
    display: inline-flex;
    padding: 5px 12px;
    gap: 30px;
  }

  .festival-nav__lang-switch--mobile .festival-nav__lang-link {
    font-size: 18px;
  }

  .festival-nav__theme-switch--mobile {
    width: 52px;
    height: 28px;
  }

  .festival-nav__theme-switch--mobile .slider:before {
    height: 24px;
    width: 24px;
    border-radius: 16px;
    left: 2px;
    bottom: 2px;
  }

  .festival-nav__theme-switch--mobile .sun svg {
    top: 5px;
    left: 30px;
    width: 18px;
    height: 18px;
  }

  .festival-nav__theme-switch--mobile .moon svg {
    top: 5px;
    left: 5px;
    width: 18px;
    height: 18px;
  }

  .festival-nav__theme-switch--mobile .input:checked + .slider:before {
    transform: translateX(24px);
  }

  .festival-nav__logo img {
    height: 34px;
  }

  .festival-nav__icon-menu {
    min-height: 300px;
    min-width: 400px;
  }

  .festival-nav__icon-menu-ring {
    height: 280px;
  }

  .festival-nav__menu-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .festival-nav__auth-icon {
    height: 32px;
  }

  :root {
    --festival-nav-height: 72px;
  }
}

/* === Site Footer === */
.site-footer {
  padding: 64px 0 10px;
  background: linear-gradient(
    90deg,
    rgba(251, 231, 179, 0.95) 0%,
    rgba(245, 195, 195, 0.95) 100%
  );
  color: var(--text-main);
  font-family: var(--font-body);
}

:root[data-theme="dark"] .site-footer {
  background: var(--background);
  color: var(--text-on-dark);
}

.site-footer__container {
  width: min(1200px, 92vw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.site-footer__top {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 36px;
  align-items: start;
}

.site-footer__brand {
  --site-footer-brand-name-size: 18px;
  --site-footer-brand-sub-size: 14px;
  --site-footer-brand-gap: 4px;
  --site-footer-brand-stack-height: calc(
    var(--site-footer-brand-name-size) + var(--site-footer-brand-sub-size) +
      var(--site-footer-brand-gap)
  );
  display: flex;
  gap: 16px;
  align-items: center;
}

.site-footer__logo {
  width: auto;
  height: var(--site-footer-brand-stack-height);
  border: 0;
  border-radius: 0;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: transparent;
  padding: 0;
}

:root[data-theme="dark"] .site-footer__logo {
  background: transparent;
}

.site-footer__logo img {
  width: auto;
  height: 100%;
  display: block;
}

.site-footer__logo .logo--dark {
  display: none;
}

:root[data-theme="dark"] .site-footer__logo .logo--light {
  display: none;
}

:root[data-theme="dark"] .site-footer__logo .logo--dark {
  display: block;
}

.site-footer__brand-text {
  display: flex;
  flex-direction: column;
  gap: var(--site-footer-brand-gap);
}

.site-footer__brand-name {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--site-footer-brand-name-size);
  line-height: 1;
}

.site-footer__brand-sub {
  font-size: var(--site-footer-brand-sub-size);
  line-height: 1;
  color: var(--text-soft);
}

.site-footer__columns {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 32px;
}

.site-footer__column h3 {
  font-family: var(--font-heading);
  font-size: 18px;
  margin: 0 0 12px;
}

.site-footer input,
.site-footer button,
.site-footer textarea,
.site-footer select {
  font-family: inherit;
}

.site-footer__column ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
}

.site-footer__column a {
  color: inherit;
  text-decoration: none;
}

.site-footer__column a:hover {
  text-decoration: underline;
}

/* === Hero === */
.hero {
  position: relative;
  min-height: clamp(560px, 88vh, 980px);
  background: var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
  overflow: hidden;
  --hero-main-title-size: clamp(2rem, 5.1vw, 7rem);
  --hero-subtitle-size: clamp(1.3rem, 3vw, 4.6rem);
  --hero-title-main: #db3928;
  --hero-title-film: #040404;
  --hero-event-number: #060606;
  --hero-event-year: #e4af99;
  --hero-kurdish-title: #717279;
  --hero-focus-color: #706f6f;
}

:root[data-theme="dark"] .hero {
  --hero-title-main: #db3928;
  --hero-title-film: #ffffff;
  --hero-event-number: #f2f2f2;
  --hero-event-year: #e4af99;
  --hero-kurdish-title: #c6c9d2;
  --hero-focus-color: #8f9090;
}

.hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1600px;
  margin: 0 auto;
  padding: clamp(128px, 18vh, 220px) 20px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: clamp(8px, 1.3vw, 16px);
}

.hero__headline-block {
  width: min(100%, 1660px);
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: clamp(12px, 1.4vw, 26px);
}

.hero__event-number {
  margin: 0;
  display: flex;
  align-items: flex-start;
  flex: 0 0 auto;
  font-family: "Helvetica Extra Compressed", "Arial Narrow", sans-serif;
  color: var(--hero-event-number);
  font-size: calc(var(--hero-main-title-size) * 2);
  line-height: 0.78;
  letter-spacing: -0.02em;
  text-transform: uppercase;
  padding-top: 0;
  position: relative;
  top: -0.11em;
}

.hero__title-stack {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  gap: clamp(2px, 0.42vw, 8px);
}

.hero__title {
  margin: 0;
  font-family: "Helvetica Black Condensed", "Arial Narrow", sans-serif;
  color: var(--hero-title-main);
  font-size: var(--hero-main-title-size);
  line-height: 0.88;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  white-space: nowrap;
  position: relative;
  text-align: left;
  z-index: 2;
}

.hero__title-film {
  color: var(--hero-title-film);
  margin-right: -2.5%;
}

.hero__title-festival {
  position: relative;
  display: inline-block;
  z-index: 1;
}

.hero__event-year {
  position: absolute;
  left: 85%;
  top: -70%;
  right: auto;
  margin: 0;
  font-family: "Helvetica Black Condensed Oblique", "Arial Narrow", sans-serif;
  color: var(--hero-event-year);
  font-size: clamp(3.2rem, 6.8vw, 9.2rem);
  line-height: 0.72;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  transform: translateX(-20%) skew(-8deg);
  z-index: -1;
  pointer-events: none;
}

.hero__event-year--fallback {
  left: auto;
  right: -0.08em;
  top: -0.9em;
  transform: skew(-8deg);
  z-index: 1;
}

.hero__subtitle-row {
  display: inline-flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: clamp(6px, 0.7vw, 14px);
}

.hero__kurdish-title {
  margin: 0;
  font-family:
    "Helvetica Black Condensed", "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: var(--hero-focus-color);
  font-size: var(--hero-subtitle-size);
  line-height: 0.95;
  text-transform: uppercase;
  letter-spacing: 0.01em;
  position: relative;
  z-index: 2;
}

.hero__kurdish-title-highlight {
  color: var(--hero-event-year);
}

.hero__berlin-title {
  margin: 0;
  position: relative;
  font-family: "Helvetica Black Condensed", "Arial Narrow", sans-serif;
  color: var(--hero-title-film);
  font-size: calc(var(--hero-main-title-size) * 1.1);
  line-height: 0.82;
  letter-spacing: 0.002em;
  text-transform: none;
  z-index: 1;
  pointer-events: none;
  margin-left: clamp(2px, 0.4vw, 10px);
}

.hero__date-image {
  width: min(62vw, 620px);
  height: auto;
  display: block;
}

.hero__focus {
  margin: 0;
  font-family: "Kyrilla Bold", "Arial Narrow", sans-serif;
  color: var(--hero-focus-color);
  font-size: clamp(2rem, 2.8vw, 3.6rem);
  line-height: 1.02;
  text-transform: none;
  letter-spacing: 0.008em;
}

.hero__showcase {
  margin-top: clamp(-80px, -5vw, -20px);
  border-radius: clamp(12px, 1.6vw, 24px) clamp(12px, 1.6vw, 24px) 0 0;
  overflow: hidden;
  z-index: -2;
  height: 100vh;
}

.hero__showcase-image {
  width: 100%;
  height: 100%;
  aspect-ratio: 4 / 4;
  display: block;
}

@media (max-width: 960px) {
  .hero {
    min-height: clamp(520px, 82vh, 820px);
  }

  .hero__inner {
    padding-top: clamp(64px, 9vh, 110px);
  }

  .hero__headline-block {
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .hero__event-number {
    font-size: clamp(4.8rem, 20vw, 9rem);
    line-height: 0.8;
    padding-top: 0;
    top: 0;
  }

  .hero__title-stack {
    align-items: center;
    padding-right: 0;
    width: 100%;
    max-width: 100%;
  }

  .hero__title {
    white-space: normal;
    text-align: center;
    font-size: clamp(2rem, 9vw, 4.4rem);
    line-height: 0.94;
    max-width: 14ch;
  }

  .hero__title-festival .hero__event-year,
  .hero__event-year--fallback {
    left: 58%;
    top: -0.88em;
    font-size: clamp(2.6rem, 11vw, 5.4rem);
    transform: translateX(-20%) skew(-8deg);
    z-index: 1;
  }

  .hero__event-year {
    display: none;
  }

  .hero__event-year--fallback {
    left: auto;
    right: -0.12em;
    transform: skew(-8deg);
  }

  .hero__subtitle-row {
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: column;
  }

  .hero__kurdish-title {
    text-align: center;
    font-size: clamp(1.22rem, 5vw, 2.6rem);
  }

  .hero__berlin-title {
    position: relative;
    right: auto;
    bottom: auto;
    margin-top: 0;
    align-self: auto;
    font-size: clamp(2.5rem, 11vw, 4.5rem);
    line-height: 0.82;
    margin-left: clamp(4px, 1.5vw, 12px);
  }

  .hero__date-image {
    width: min(82vw, 500px);
  }

  .hero__showcase {
    width: min(90vw, 820px);
    height: auto;
  }
}

@media (max-width: 640px) {
  .hero__inner {
    padding-left: 12px;
    padding-right: 12px;
  }

  .hero__focus {
    font-size: clamp(1.1rem, 5vw, 1.8rem);
  }
}

/* === Welcome section === */
.welcome {
  background: var(--welcome-top-gradient);
}

.welcome__inner {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.welcome__header {
  display: flex;
  justify-content: flex-end;
}

.welcome__headline {
  margin: 0;
  text-align: right;
}

.welcome__video {
  border-radius: 24px;
  overflow: hidden;
  border: 2px solid var(--border-subtle);
  min-height: fit-content;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  box-shadow: 3px 9px 15px 0px #1f1f1f;
}

.welcome__video-element {
  width: 100%;
  height: 100%;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.welcome__image {
  width: 100%;
  height: 100%;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.welcome__video-placeholder {
  width: 100%;
  aspect-ratio: 16 / 9;
  background: color-mix(in srgb, var(--border-subtle) 70%, transparent);
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.welcome__video-play {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-main) 30%, transparent);
  color: var(--text-on-dark);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
}

.welcome__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 40px;
  width: 100%;
}

.welcome__link {
  width: 140px;
  height: 25px;
  overflow: hidden;
  border: none;
  color: var(--primary);
  background: none;
  position: relative;
  display: block;
  cursor: pointer;
  text-decoration: none;
  font-weight: 600;
}

.welcome__link:first-child {
  width: 110px;
}

.welcome__link:nth-last-child(2) {
  width: 100px;
}

.welcome__link:last-child {
  width: 120px;
}

.welcome__link::before {
  content: "";
  position: absolute;
  height: 2px;
  bottom: 0;
  left: 0;
  width: 100%;
  transform: scaleX(0);
  transform-origin: bottom right;
  background: currentColor;
  transition: transform 0.25s ease-out;
}

.welcome__link:hover::before {
  transform: scaleX(1);
  transform-origin: bottom left;
}

.welcome__link-track,
.welcome__link-arrow {
  position: absolute;
  width: 100%;
  height: 100%;
  display: flex;
}

.welcome__link-track {
  align-items: center;
  justify-content: flex-start;
  pointer-events: none;
}

.welcome__link-track > span {
  opacity: 1;
  font-size: 1.05rem;
  line-height: 1.1;
  transition: 0.2s;
  margin-left: 4px;
}

.welcome__link-clone > span {
  transform: translateY(60px);
}

.welcome__link:hover .welcome__link-clone > span {
  opacity: 1;
  transform: translateY(0);
  transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}

.welcome__link:hover .welcome__link-text > span {
  opacity: 1;
  transform: translateY(-60px);
  transition: all 0.2s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}

.welcome__link:hover .welcome__link-clone > :nth-child(1) {
  transition-delay: 0.15s;
}

.welcome__link:hover .welcome__link-clone > :nth-child(2) {
  transition-delay: 0.2s;
}

.welcome__link:hover .welcome__link-clone > :nth-child(3) {
  transition-delay: 0.25s;
}

.welcome__link:hover .welcome__link-clone > :nth-child(4) {
  transition-delay: 0.3s;
}

.welcome__link-arrow {
  width: 20px;
  right: 0;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  transition: transform 0.2s ease-out;
}

.welcome__link:hover .welcome__link-arrow {
  transform: translateY(-50%) rotate(90deg);
}

.welcome__link:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--primary) 70%, transparent);
  outline-offset: 3px;
}

@media (max-width: 768px) {
  .welcome.section--align-right .section__inner {
    text-align: left;
  }

  .welcome__header {
    justify-content: flex-start;
  }

  .welcome__headline {
    text-align: left;
  }

  .welcome__links {
    justify-content: center;
    gap: 10px 40px;
  }
}

/* === Newsletter === */
.newsletter {
  display: grid;
  gap: 12px;
}

.newsletter__input {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--text-soft) 40%, transparent);
  background: rgba(255, 255, 255, 0.65);
  width: 100%;
  max-width: fit-content;
}

:root[data-theme="dark"] .newsletter__input {
  background: rgba(0, 0, 0, 0.35);
  border-color: color-mix(in srgb, var(--text-on-dark) 35%, transparent);
}

.newsletter__input input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 8px 4px;
  color: inherit;
  font-size: 14px;
  width: 100%;
}

.newsletter__input input:focus {
  outline: none;
}

.newsletter__input button {
  border: none;
  background: var(--primary);
  color: var(--kurd-white);
  width: 36px;
  height: 36px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.newsletter__input button svg {
  width: 18px;
  height: 18px;
}

.newsletter__options {
  display: grid;
  gap: 6px;
  border: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}

.newsletter__options label {
  display: flex;
  align-items: center;
  gap: 8px;
}

.newsletter__privacy label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  line-height: 1.4;
}

.newsletter__privacy input {
  margin-top: 2px;
}

.newsletter__privacy a {
  color: inherit;
  text-decoration: underline;
}

.newsletter__status {
  font-size: 13px;
  color: var(--text-soft);
}

.newsletter__status--error {
  color: var(--error);
}

.newsletter-unsubscribe {
  padding: 80px 20px;
  display: flex;
  justify-content: center;
}

.newsletter-unsubscribe__card {
  width: min(640px, 100%);
  background: var(--surface);
  border-radius: 24px;
  padding: 32px;
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.08);
}

.newsletter-unsubscribe__card h1 {
  margin: 0 0 16px;
  font-size: 28px;
}

.newsletter-unsubscribe__form {
  display: grid;
  gap: 16px;
  margin: 20px 0;
}

.newsletter-unsubscribe__fieldset {
  display: grid;
  gap: 12px;
  border: none;
  padding: 0;
  margin: 0;
}

.newsletter-unsubscribe__option {
  display: flex;
  align-items: center;
  gap: 10px;
}

.newsletter-unsubscribe__button {
  background: var(--primary);
  border: none;
  color: var(--kurd-white);
  padding: 12px 20px;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
  width: fit-content;
}

.newsletter-unsubscribe__alert {
  padding: 12px 16px;
  border-radius: 12px;
  margin-bottom: 16px;
  font-weight: 500;
}

.newsletter-unsubscribe__alert--success {
  background: rgba(34, 197, 94, 0.16);
  color: #166534;
}

.newsletter-unsubscribe__alert--error {
  background: rgba(220, 38, 38, 0.16);
  color: #991b1b;
}

.newsletter-unsubscribe__note {
  font-size: 14px;
  color: var(--text-soft);
}

.site-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-top: 1px solid color-mix(in srgb, currentColor 18%, transparent);
  padding-top: 20px;
  font-size: 14px;
}

.site-footer__credit {
  margin: 0;
  color: inherit;
}

.site-footer__credit a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.site-footer__legal {
  display: flex;
  gap: 18px;
  flex-direction: row;
  flex-wrap: wrap;
}

.site-footer__social {
  display: flex;
  gap: 12px;
}

.site-footer__social a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.75);
  color: inherit;
}

:root[data-theme="dark"] .site-footer__social a {
  background: rgba(0, 0, 0, 0.45);
}

.site-footer__social svg {
  width: 18px;
  height: 18px;
}

.scroll-top-floating {
  position: fixed;
  left: 10px;
  bottom: calc(
    var(--scroll-top-offset, 12px) + env(safe-area-inset-bottom, 0px)
  );
  width: 40px;
  height: 40px;
  border: none;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
  color: var(--text-main);
  box-shadow: 0 8px 18px rgba(17, 24, 39, 0.2);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(10px);
  transition:
    opacity 0.35s ease,
    transform 0.35s ease,
    background 0.25s ease,
    color 0.25s ease,
    box-shadow 0.25s ease;
  z-index: 1001;
}

.scroll-top-floating svg {
  width: 20px;
  height: 20px;
}

.scroll-top-floating.is-visible {
  opacity: 0.78;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.scroll-top-floating.is-hidden-by-social {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  transform: translateY(-10px) !important;
}

.scroll-top-floating.is-visible.is-muted {
  opacity: 0.42;
}

.scroll-top-floating.is-visible.is-highlighted {
  opacity: 1;
  background: var(--nav-accent);
  color: var(--kurd-white);
  box-shadow: 0 14px 28px rgba(209, 80, 35, 0.36);
}

.scroll-top-floating.is-visible:hover {
  opacity: 1;
}

.scroll-top-floating:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--primary) 70%, transparent);
  outline-offset: 2px;
}

:root[data-theme="dark"] .scroll-top-floating {
  background: color-mix(in srgb, #0f172a 84%, transparent);
  color: var(--text-on-dark);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.45);
}

.donate-floating {
  --clr: var(--kurd-green);
  position: fixed;
  right: 20px;
  bottom: calc(
    var(--scroll-top-offset, 12px) + env(safe-area-inset-bottom, 0px)
  );
  z-index: 1001;
  display: none;
  text-decoration: none;
  line-height: 1;
  border-radius: var(--radius-sm);
  overflow: hidden;
  box-shadow: 10px 10px 20px rgba(0, 0, 0, 0.08);
  background-color: #fff;
  color: #121212;
  border: none;
  cursor: pointer;
}

.donate-floating__decor {
  position: absolute;
  inset: 0;
  background-color: var(--clr);
  transform: translateX(-100%);
  transition: transform 0.3s ease;
  z-index: 0;
}

.donate-floating__content {
  display: flex;
  align-items: center;
  font-weight: 600;
  font-size: 16px;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.donate-floating__icon {
  width: 56px;
  height: 46px;
  background-color: var(--clr);
  display: grid;
  place-items: center;
  color: #fff;
}

.donate-floating__icon svg {
  width: 24px;
  height: 24px;
}

.donate-floating__text {
  display: inline-block;
  transition: color 0.2s ease;
  padding: 4px 1.75rem 4px 0.9rem;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 170px;
}

.donate-floating:hover .donate-floating__text {
  color: #fff;
}

.donate-floating:hover .donate-floating__decor {
  transform: translateX(0);
}

.donate-floating:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--clr) 72%, transparent);
  outline-offset: 2px;
}

:root[data-theme="dark"] .donate-floating {
  background: color-mix(in srgb, var(--surface) 94%, #ffffff 6%);
  color: var(--text-on-dark);
  box-shadow: 10px 10px 22px rgba(0, 0, 0, 0.32);
}

@media (min-width: 901px) {
  .donate-floating {
    display: inline-block;
  }
}

@media (max-width: 600px) {
  .scroll-top-floating {
    left: 8px;
    bottom: calc(
      var(--scroll-top-offset, 12px) + env(safe-area-inset-bottom, 0px) + 10px
    );
    width: 38px;
    height: 38px;
    border-radius: 11px;
  }
}

@media (max-width: 1100px) {
  .site-footer__top {
    grid-template-columns: 1fr;
  }
  .site-footer__columns {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .site-footer__columns {
    grid-template-columns: 1fr;
  }
  .site-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }
  .welcome__link-track > span {
    font-size: 14px;
  }
  .welcome__link:first-child {
    width: 90px;
  }
  .welcome__link:nth-last-child(2) {
    width: 90px;
  }
  .welcome__link:last-child {
    width: 100px;
  }
  .welcome__links {
    gap: 10px 5px;
  }
}

.media-showcase__inner {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.media-showcase__header {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.media-showcase__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 3vw, 36px);
  color: var(--text-main);
  margin: 0;
}

.media-showcase__lead {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0;
}

.media-showcase__filters {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0;
}

.media-showcase__filter {
  height: 30px;
  padding: 6px 12px;
  border-radius: 999px;
  border: none;
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  cursor: pointer;
  transition:
    background 0.2s ease,
    color 0.2s ease;
}

.media-showcase__filter.is-active {
  background: var(--nav-accent);
  color: var(--kurd-white);
}

.media-showcase__content {
  position: relative;
}

.media-showcase__carousel {
  display: flex;
  gap: 24px;
  padding: 20px 0;
  justify-content: space-between;
}

.media-showcase__card {
  min-width: 290px;
  width: 320px;
  min-height: 400px;
  height: 100%;
  flex: 0 0 auto;
  box-sizing: border-box;
  padding: 16px;
  border-radius: var(--radius-md);
  background: var(--media-card-bg);
  color: var(--media-card-text);
  text-decoration: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 12px;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.08);
  text-align: left;
}

.media-showcase__body {
  height: 250px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.media-showcase__thumb {
  position: relative;
  width: 100%;
  height: 150px;
  border-radius: var(--radius-lg);
  background-image: var(--media-thumb-fallback);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

.media-showcase__badge {
  position: absolute;
  top: 10px;
  left: 10px;
  background: var(--nav-accent);
  border-radius: 999px;
  padding: 4px 10px;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--kurd-white);
}

.media-showcase__play {
  position: absolute;
  inset: 0;
  display: none;
  place-items: center;
  font-size: 28px;
  color: var(--kurd-white);
  text-shadow: 0 6px 16px rgba(0, 0, 0, 0.35);
}

.media-showcase__card-title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(18px, 2vw, 20px);
  line-height: 1.4;
  color: var(--titel-color);
  margin: 0;
  height: 60px;
  overflow: hidden;
}

.media-showcase__card-text {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-main);
  margin: 0;
  height: 170px;
}

.media-showcase__meta {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-soft);
}

.media-showcase__open {
  box-shadow: 0 12px 24px rgba(133, 53, 53, 0.25);
  transition:
    transform 0.2s ease,
    filter 0.2s ease,
    box-shadow 0.2s ease;
  width: fit-content;
  padding: 5px 15px;
  background: var(--nav-accent);
  color: var(--kurd-white);
  border-radius: var(--radius-md);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 24px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.media-showcase__open:hover {
  transform: translateY(-2px);
  filter: brightness(1.05);
  box-shadow: 0 16px 30px rgba(133, 53, 53, 0.3);
}

.media-showcase__duration {
  margin-left: auto;
}

.media-showcase__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  text-decoration: none;
  font-size: 14px;
}

.media-showcase__link svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.media-showcase__empty {
  width: 100%;
  text-align: center;
  padding: 32px;
  border-radius: var(--radius-md);
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
}

.media-showcase__cta {
  display: flex;
  justify-content: center;
}

.media-showcase__cta-button {
  background: var(--kurd-green);
  color: var(--kurd-white);
  padding: 10px 18px;
  border-radius: var(--radius-md);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  letter-spacing: 0.1em;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.media-showcase__scroll-hint {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-main) 15%, transparent);
  color: var(--text-main);
  place-items: center;
  border: none;
  padding: 0;
  cursor: pointer;
}
.media-showcase__scroll-hint[hidden] {
  display: none !important;
}

.media-showcase__scroll-hint--left {
  left: 0;
}

.media-showcase__scroll-hint--right {
  right: 0;
}

.media-showcase__scroll-hint svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.media-showcase__dots {
  display: none;
  justify-content: center;
  gap: 14px;
  margin-top: 8px;
}

.media-showcase__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--text-muted);
  opacity: 0.5;
}

.media-showcase__dot.is-active {
  opacity: 1;
}
/* === Tickets showcase === */
.ticket-showcase__inner {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
  text-align: center;
}

.ticket-showcase__header {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 920px;
}

.ticket-showcase__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 3vw, 36px);
  color: var(--text-main);
  margin: 0;
}

.ticket-showcase__lead {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0;
}
.ticket-showcase__content {
  position: relative;
  width: 100%;
  max-width: 940px;
}

.ticket-showcase__tickets {
  width: 100%;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 10px 0;
}

.tickets-section__tickets {
  justify-content: flex-start;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 20px;
  scroll-behavior: smooth;
  cursor: grab;
  scrollbar-width: none;
}

.ticket-card__price-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
}

.tickets-section__tickets .ticket-card {
  scroll-snap-align: start;
}

.tickets-section__tickets.is-dragging {
  cursor: grabbing;
  user-select: none;
  scroll-behavior: auto;
  scroll-snap-type: none;
}

.ticket-showcase__empty {
  width: 100%;
  padding: 32px;
  border-radius: var(--radius-md);
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  text-align: center;
}

.ticket-card {
  width: 290px;
  min-height: 350px;
  height: 100%;
  box-sizing: border-box;
  padding: 24px;
  border-radius: var(--radius-md);
  background: var(--kurd-green-soft);
  color: var(--text-main);
  display: flex;
  flex: 0 0 auto;
  flex-direction: column;
  justify-content: space-between;
  text-align: left;
  box-shadow: 5px 5px 13px rgba(0, 0, 0, 0.1);
}

.ticket-card__body {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ticket-card__badge {
  align-self: flex-start;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--ticket-badge-bg, var(--secondary));
  color: var(--ticket-badge-color, var(--secondary-text-color));
  font-family: "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
}

.ticket-card__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(22px, 2.6vw, 24px);
  color: var(--titel-color);
  margin: 0;
}

.ticket-card__text {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0;
  height: 40px;
}

Deutsch Badge .ticket-card__price-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0;
}

.ticket-card__price-old {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-muted);
  text-decoration: line-through;
}

.ticket-card__price-current {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(18px, 2vw, 20px);
  line-height: 1.4;
  color: var(--text-main);
}

.ticket-card__price-note {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-soft);
}

.ticket-card__features {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 0;
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-main);
}

.ticket-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  height: 55px;
}

.ticket-card__star {
  padding-top: 4px;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  fill: var(--primary);
}

.ticket-card__hint {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-soft);
  display: none;
}

.ticket-card__cta {
  display: flex;
  justify-content: flex-start;
}

.ticket-card__button {
  box-shadow: 0 12px 24px rgba(133, 53, 53, 0.25);
  transition:
    transform 0.2s ease,
    filter 0.2s ease,
    box-shadow 0.2s ease;
  width: fit-content;
  padding: 5px 15px;
  background: var(--nav-accent);
  color: var(--kurd-white);
  border-radius: var(--radius-md);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 24px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ticket-card__button:hover {
  transform: translateY(-2px);
  filter: brightness(1.05);
  box-shadow: 0 16px 30px rgba(133, 53, 53, 0.3);
}

.ticket-card__button svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

.ticket-showcase__cta {
  display: flex;
  justify-content: center;
}

.ticket-showcase__cta-button {
  background: var(--kurd-green);
  color: var(--text-on-dark);
  padding: 10px 18px;
  border-radius: var(--radius-md);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  letter-spacing: 0.1em;
  text-decoration: none;
}

.ticket-showcase__scroll-hint {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-main) 15%, transparent);
  color: var(--text-main);
  place-items: center;
  border: none;
  padding: 0;
  cursor: pointer;
}

.ticket-showcase__scroll-hint[hidden] {
  display: none !important;
}

.ticket-showcase__scroll-hint--left {
  left: 0px;
}

.ticket-showcase__scroll-hint--right {
  right: 0px;
}

.ticket-showcase__scroll-hint svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.ticket-showcase__dots {
  display: none;
  justify-content: center;
  gap: 14px;
  margin-top: 8px;
}

.ticket-showcase__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--text-muted);
  opacity: 0.5;
}

.ticket-showcase__dot.is-active {
  opacity: 1;
}

.tickets-section .ticket-showcase__scroll-hint {
  display: grid;
}

.tickets-section .ticket-showcase__dots {
  display: flex;
}

@media (min-width: 901px) {
  .tickets-section .ticket-showcase__content {
    padding-bottom: 52px;
  }

  .tickets-section .ticket-showcase__scroll-hint {
    top: auto;
    bottom: 40px;
    transform: none;
  }

  .tickets-section .ticket-showcase__scroll-hint--left {
    left: 0;
  }

  .tickets-section .ticket-showcase__scroll-hint--right {
    right: 0;
  }
}

.tickets-section__tickets::-webkit-scrollbar {
  display: none;
}
/* === News section (Festival News) === */
.news-section__inner {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.news-section__header {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.news-section__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(28px, 3vw, 36px);
  color: var(--text-main);
  margin: 0;
}

.news-section__lead {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-soft);
  margin: 0;
}

.news-section__content {
  position: relative;
}

.news-section__carousel {
  display: flex;
  gap: 24px;
  justify-content: center;
  padding: 10px 0;
  justify-content: space-between;
}

.news-overview__item {
  height: fit-content;
  margin: 0;
}

.news-card {
  position: relative;
  height: 440px;
  min-width: 290px;
  width: 320px;
  box-sizing: border-box;
  padding-bottom: 16px;
  border-radius: var(--radius-md);
  background: var(--kurd-yellow-soft);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: var(--text-main);
  box-shadow: 6px 7px 5px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  cursor: pointer;
}

.news-card__badge {
  position: absolute;
  top: 15px;
  left: 15px;
  padding: 4px 10px;
  background: var(--primary);
  color: var(--text-on-dark);
  border-radius: 999px;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.news-card__image {
  width: 100%;
  height: 170px;
  background: var(--media-thumb-fallback);
}

.news-card__image img {
  width: 100%;
  height: 170px;
  object-fit: cover;
  display: block;
}

.news-card__image video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.news-card__body {
  padding: 16px 16px 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  justify-content: space-between;
  height: 100%;
}

.news-card__category {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-soft);
  height: 30px;
}

.news-card__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.4;
  color: var(--titel-color);
  margin: 0;
  padding: 0;
}

.news-card__date {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-soft);
  margin-left: auto;
  white-space: nowrap;
}

.news-card__text {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: var(--text-main);
}

.news-card__textarea {
  display: flex;
  gap: 10px;
  flex-direction: column;
  justify-content: flex-start;
}

.news-card__actions {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
}

.news-card__open {
  box-shadow: 0 12px 24px rgba(209, 62, 62, 0.25);
  transition:
    transform 0.2s ease,
    filter 0.2s ease,
    box-shadow 0.2s ease;
  width: fit-content;
  padding: 5px 15px;
  background: var(--nav-accent);
  color: var(--kurd-white);
  border-radius: var(--radius-md);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 500;
  font-size: 14px;
  line-height: 24px;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.news-card__open:hover {
  transform: translateY(-2px);
  filter: brightness(1.05);
  box-shadow: 0 16px 30px rgba(209, 62, 62, 0.3);
}

.news-card__more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-muted);
  text-decoration: none;
}

.news-card__more svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.news-section__empty {
  width: 100%;
  text-align: center;
  padding: 32px;
  border-radius: var(--radius-md);
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
}

.news-section__cta {
  display: flex;
  justify-content: center;
}

.news-section__cta-button {
  background: var(--kurd-green);
  color: var(--kurd-white);
  padding: 10px 18px;
  border-radius: var(--radius-md);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 24px;
  letter-spacing: 0.1em;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.media-showcase__cta-button,
.ticket-showcase__cta-button,
.news-section__cta-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  box-shadow: 0px 3px 4px color-mix(in srgb, var(--kurd-green) 38%, transparent);
  transition:
    transform 0.2s ease,
    filter 0.2s ease,
    box-shadow 0.2s ease;
}

.media-showcase__cta-button:hover,
.ticket-showcase__cta-button:hover,
.news-section__cta-button:hover {
  transform: translateY(-1px);
  filter: brightness(1.02);
  box-shadow: 0px 5px 8px color-mix(in srgb, var(--kurd-green) 42%, transparent);
}

.media-showcase__cta-button:focus-visible,
.ticket-showcase__cta-button:focus-visible,
.news-section__cta-button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--kurd-green) 70%, transparent);
  outline-offset: 2px;
}

.news-section__scroll-hint {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--text-main) 15%, transparent);
  color: var(--text-main);
  place-items: center;
  border: none;
  padding: 0;
  cursor: pointer;
}
.news-section__scroll-hint[hidden] {
  display: none !important;
}

.news-section__scroll-hint--left {
  left: 0;
}

.news-section__scroll-hint--right {
  right: 0;
}

.news-section__scroll-hint svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.news-section__dots {
  display: none;
  justify-content: center;
  gap: 14px;
  margin-top: 8px;
}

.news-section__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--text-muted);
  opacity: 0.5;
}

.news-section__dot.is-active {
  opacity: 1;
}

/* === Auth Pages === */
.auth-card {
  max-width: 520px;
  margin: 80px auto;
  padding: 32px;
  background: var(--default-bg);
  border-radius: 18px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
  font-family: var(--font-body);
}

.auth-card h1 {
  margin-top: 0;
  font-size: 28px;
}

.auth-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 20px;
}

.auth-form label {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-weight: 600;
}

.auth-form input {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid #d3d6e6;
  background: var(--background);
  color: var(--text-main);
}

.auth-button {
  padding: 12px 18px;
  border-radius: 12px;
  border: none;
  background: #d13e3e;
  color: #fff;
  font-weight: 700;
  cursor: pointer;
}

.auth-note {
  margin-top: 20px;
}

.auth-google {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 12px;
  border: 1px solid #d3d6e6;
  background: #fff;
  color: #111827;
  font-weight: 600;
  text-decoration: none;
  margin-top: 12px;
}

.auth-google:hover {
  background: #f3f4f6;
}

.auth-error {
  color: #b91c1c;
  font-weight: 600;
}

.auth-fieldset {
  border: 1px solid #e3e6f0;
  border-radius: 12px;
  padding: 16px;
}

.auth-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
}

/* === Admin Panel === */
.admin-body {
  background: #fdf4f4;
  min-height: 100vh;
}

.admin-body.is-card-preview-open {
  overflow: hidden;
}

.blass {
  color: var(--border-strong);
}

.admin-main {
  padding: 20px;
}

.admin-shell {
  display: flex;
  gap: 20px;
  min-height: calc(100vh - 40px);
}

.admin-sidebar {
  flex: 0 0 280px;
  background: #f8e1e1;
  border-radius: 24px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.admin-body h1,
.admin-body h2,
.admin-body h3,
.admin-body h4,
.admin-body p {
  color: #1b2230;
}

.admin-sidebar__header h1 {
  margin: 0;
  font-size: 28px;
  color: #1f2937;
}

.admin-profile {
  display: flex;
  align-items: center;
  gap: 16px;
}

.admin-avatar {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: #d7b6b6;
  display: grid;
  place-items: center;
  font-weight: 700;
  color: #1f2937;
}

.admin-profile__text {
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: #1f2937;
}

.admin-nav {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.admin-nav__item {
  border: none;
  background: transparent;
  text-align: left;
  padding: 12px 14px;
  font-weight: 600;
  border-bottom: 1px solid #d6bcbc;
  color: #1f1f1f;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-decoration: none;
}

.admin-nav__item.is-active {
  background: #d13e3e;
  color: #fff;
  border-radius: 10px;
  border-bottom: none;
}

.admin-nav__chevron {
  font-size: 18px;
}

.admin-content {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.admin-content__section.is-hidden {
  display: none;
}

.admin-content__header h2 {
  margin-bottom: 4px;
  color: #1f2937;
}

.admin-content__header p {
  margin: 0;
  color: #6b7280;
}

.admin-tabs {
  display: flex;
  gap: 6px;
  margin-top: 12px;
}

.admin-tabs--sub {
  margin-top: 0;
}

.admin-tab {
  border: none;
  background: #d8dbe8;
  color: #111827;
  padding: 6px 12px;
  border-radius: 10px 10px 0 0;
  font-weight: 600;
  cursor: pointer;
}

.admin-tab.is-active {
  background: #cfd2e2;
}

.admin-panel {
  background: #cfd2e2;
  border-radius: 0px 0px 20px 20px;
  margin-bottom: 30px;
  padding: 0px 28px 28px 28px;
}

.admin-panel.is-hidden {
  display: none;
}

.admin-panel__section {
  padding: 16px 0;
  border-bottom: 2px solid #2d3748;
}

.admin-panel__section:last-of-type {
  border-bottom: none;
}

.admin-panel__title {
  font-size: 18px;
  margin-bottom: 12px;
}

.admin-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 14px;
}

.admin-grid--single {
  grid-template-columns: minmax(0, 1fr);
}

.admin-grid--rahmenplan-locales {
  align-items: start;
}

.admin-rahmenplan-locale {
  background: rgba(255, 255, 255, 0.45);
  border: 1px solid #b9c0da;
  border-radius: 12px;
  padding: 14px;
}

.admin-rahmenplan-locale__title {
  margin: 0 0 12px;
  font-size: 16px;
}

.admin-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-weight: 600;
  color: #1f1f1f;
}

.admin-ticket-field--hidden {
  display: flex;
}

.admin-ticket-fields--hidden {
  display: grid;
}

.admin-field-gallery-category {
  flex-direction: row;
  padding-left: 140px;
}

.admin-field input {
  border: none;
  border-radius: 8px;
  padding: 8px 10px;
  color: var(--text-muted);
  background: #fff;
  box-shadow: inset 0 0 0 1px #d3d6e6;
}

.admin-field textarea {
  border: none;
  border-radius: 8px;
  padding: 8px 10px;
  color: var(--text-muted);
  background: #fff;
  box-shadow: inset 0 0 0 1px #d3d6e6;
  resize: vertical;
  min-height: 140px;
  font-family: inherit;
}

.admin-field--error input,
.admin-field--error textarea,
.admin-field--error select {
  background: rgba(237, 79, 79, 0.12);
  box-shadow: inset 0 0 0 1px rgba(167, 55, 55, 0.45);
}

.admin-field--checkbox {
  flex-direction: row;
  align-items: center;
  gap: 10px;
}

.admin-field--checkbox input {
  width: auto;
  padding: 0;
  box-shadow: none;
}

.admin-field small {
  font-weight: 400;
  color: var(--text-muted);
}

.admin-link-helper {
  position: absolute;
  z-index: 40;
  width: 220px;
  padding: 10px;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.18);
  display: flex;
  flex-direction: column;
  gap: 8px;
  color: #111827;
  font-size: 12px;
}

.admin-link-helper.is-hidden {
  display: none;
}

.admin-link-helper__header {
  font-weight: 700;
  font-size: 13px;
}

.admin-link-helper__actions {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.admin-link-helper__choice {
  border: none;
  border-radius: 8px;
  background: #eef2ff;
  color: #273574;
  padding: 6px 0;
  font-weight: 600;
  cursor: pointer;
  font-size: 12px;
}

.admin-link-helper__choice.is-active {
  background: #2d5bff;
  color: #ffffff;
}

.admin-link-helper__editor {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.admin-link-helper__editor.is-hidden {
  display: none;
}

.admin-link-helper__field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-weight: 600;
  color: #1f1f1f;
}

.admin-link-helper__field.is-hidden {
  display: none;
}

.admin-link-helper__field span {
  font-size: 11px;
  font-weight: 500;
  color: #6b7280;
}

.admin-link-helper__field input {
  border: none;
  border-radius: 8px;
  padding: 6px 8px;
  color: var(--text-muted);
  background: #f9fafb;
  box-shadow: inset 0 0 0 1px #d3d6e6;
  font-size: 12px;
}

.admin-link-helper__button {
  border: none;
  border-radius: 999px;
  background: #2d5bff;
  color: #ffffff;
  padding: 6px 12px;
  font-weight: 600;
  cursor: pointer;
  font-size: 12px;
}

.admin-link-helper__button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.admin-panel__actions {
  display: flex;
  justify-content: center;
  padding-top: 18px;
}

.admin-panel__actions--preview {
  gap: 12px;
  flex-wrap: wrap;
}

.admin-panel__actions--inline {
  justify-content: flex-end;
  gap: 12px;
  padding-top: 12px;
}

.admin-panel__alert {
  margin: 0 0 20px;
  padding: 14px 18px;
  border-radius: 12px;
  font-weight: 600;
}

.admin-panel__alert--error {
  background: rgba(237, 79, 79, 0.12);
  color: #a73737;
  border: 1px solid rgba(167, 55, 55, 0.35);
}

.admin-panel__alert--success {
  background: rgba(45, 166, 104, 0.12);
  color: #1f7a4f;
  border: 1px solid rgba(31, 122, 79, 0.3);
}

.admin-newsletter-table__wrapper {
  overflow-x: auto;
  border-radius: 14px;
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.08);
}

.admin-newsletter-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  min-width: 640px;
}

.admin-newsletter-table th,
.admin-newsletter-table td {
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
  font-size: 14px;
  color: #123;
}

.admin-newsletter-table th {
  background: #eef0f8;
  font-weight: 700;
  color: #111827;
}

.admin-newsletter-table tbody tr:nth-child(even) {
  background: #f9fafb;
}

.admin-table {
  display: grid;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  overflow-x: auto;
}

.admin-table__row {
  display: grid;
  grid-template-columns:
    minmax(160px, 1.2fr) minmax(180px, 1.4fr) minmax(110px, 0.7fr)
    minmax(150px, 0.9fr) minmax(190px, 1.3fr) minmax(120px, 0.8fr) minmax(
      120px,
      0.6fr
    );
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid #e5e7eb;
  font-size: 14px;
  color: #111827;
}

.admin-table__row--header {
  background: #eef0f8;
  font-weight: 700;
}

.admin-table__row:last-child {
  border-bottom: none;
}

.admin-table__row small {
  display: block;
  color: #6b7280;
}

.admin-table__row.is-hidden {
  display: none;
}

.admin-table--ticket-orders .admin-table__row {
  grid-template-columns:
    minmax(110px, 0.7fr)
    minmax(140px, 1fr)
    minmax(170px, 1.2fr)
    minmax(110px, 0.6fr)
    minmax(200px, 1.4fr)
    minmax(150px, 1fr)
    minmax(130px, 0.8fr)
    minmax(130px, 0.8fr);
}

.admin-table--donations .admin-table__row {
  grid-template-columns:
    minmax(120px, 0.8fr)
    minmax(120px, 0.8fr)
    minmax(160px, 1fr)
    minmax(200px, 1.2fr)
    minmax(220px, 1.6fr)
    minmax(80px, 0.5fr)
    minmax(120px, 0.7fr)
    minmax(200px, 1fr);
}

.admin-receipt-frame {
  width: 100%;
  min-height: 80vh;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #fff;
}

.admin-ticket-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.admin-ticket-filter {
  border: none;
  background: rgba(15, 23, 42, 0.1);
  color: #111827;
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 600;
  cursor: pointer;
}

.admin-ticket-filter.is-active {
  background: #111827;
  color: #fff;
}

.admin-gallery-panel.is-hidden {
  display: none;
}

.admin-tab.is-hidden {
  display: none;
}

.admin-media-picker__controls {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 8px;
}

.admin-media-picker__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 6px 0 4px;
}

.admin-media-picker__pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(30, 30, 30, 0.08);
  font-size: 13px;
}

.admin-media-picker__pill a {
  color: inherit;
  text-decoration: none;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.admin-media-picker__pill a:hover,
.admin-media-picker__pill a:focus {
  text-decoration: underline;
}

.admin-media-picker__preview-link {
  color: inherit;
  text-decoration: none;
  max-width: 100%;
  display: inline-block;
}

.admin-media-picker__preview-link:hover,
.admin-media-picker__preview-link:focus {
  text-decoration: underline;
}

.admin-media-picker__pill button {
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
}

.admin-media-picker__preview {
  position: absolute;
  z-index: 2000;
  padding: 8px;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
  opacity: 0;
  pointer-events: none;
  transform: translateY(6px);
  transition:
    opacity 0.15s ease,
    transform 0.15s ease;
}

.admin-media-picker__preview.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.admin-media-picker__preview img {
  display: none;
  max-width: 240px;
  max-height: 240px;
  border-radius: 6px;
}

.admin-media-picker__preview video {
  display: none;
  max-width: 240px;
  max-height: 240px;
  border-radius: 6px;
}

.admin-media-picker__preview img.is-visible,
.admin-media-picker__preview video.is-visible {
  display: block;
}

.admin-media-picker small {
  display: block;
  color: #6f6f6f;
}

.admin-panel {
  color: var(--primary);
}

.admin-article-select select {
  border: none;
  border-radius: 8px;
  padding: 8px 10px;
  background: #fff;
  box-shadow: inset 0 0 0 1px #d3d6e6;
  color: var(--text-muted);
}

.admin-article-grid {
  display: flex;
  gap: 18px;
  padding-bottom: 24px;
  flex-wrap: wrap;
  flex-direction: row;
}

.admin-article-card {
  position: relative;
  width: 320px;
}

.admin-article-card__actions {
  position: absolute;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  pointer-events: none;
  z-index: 2;
}

.admin-article-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, 0.9);
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 600;
  pointer-events: auto;
  color: #1b2230;
}

.admin-article-card__delete {
  border: none;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: 18px;
  cursor: pointer;
  pointer-events: auto;
  color: #1b2230;
}

.admin-article-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.admin-article-modal.is-hidden {
  display: none;
}

.admin-article-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
}

.admin-article-modal__dialog {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 16px;
  padding: 20px;
  width: min(520px, 100%);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.admin-article-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.admin-article-modal__close {
  border: none;
  background: transparent;
  font-size: 22px;
  cursor: pointer;
}

.admin-article-modal__options {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.admin-film-select select {
  border: none;
  border-radius: 8px;
  padding: 8px 10px;
  background: #fff;
  box-shadow: inset 0 0 0 1px #d3d6e6;
  color: var(--text-muted);
}

.admin-ticket-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 24px;
}

.admin-ticket-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
  width: 300px;
  background: beige;
  border-radius: 16px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
  color: inherit;
  text-decoration: none;
  position: relative;
}

.admin-ticket-card.is-hidden {
  display: none;
}

.admin-ticket-card__title {
  font-weight: 700;
  color: #1f2937;
}

.admin-ticket-card__meta {
  font-size: 13px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.admin-ticket-card__description {
  font-size: 14px;
  color: #4b5563;
}

.admin-ticket-card__price {
  font-weight: 600;
  color: #111827;
}

.admin-badge-picker {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.admin-badge-option {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
  color: var(--text-muted);
}

.admin-badge-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.admin-badge-option__preview {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--badge-color, #e5e7eb);
  border: 1px solid rgba(0, 0, 0, 0.15);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.6);
}

.admin-badge-option__letter {
  font-size: 9px;
  font-weight: 700;
  color: var(--badge-text-color, #111827);
}

.admin-badge-option input:checked + .admin-badge-option__preview {
  box-shadow:
    0 0 0 2px rgba(17, 24, 39, 0.2),
    inset 0 0 0 2px rgba(255, 255, 255, 0.6);
  transform: scale(1.05);
}

.admin-ticket-card__actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.admin-ticket-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, 0.9);
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 600;
  color: #1b2230;
}

.admin-ticket-card__delete {
  border: none;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: 18px;
  cursor: pointer;
  color: #1b2230;
}

.admin-ticket-card__body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.admin-ticket-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.admin-ticket-modal.is-hidden {
  display: none;
}

.admin-ticket-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.4);
}

.admin-ticket-modal__dialog {
  position: relative;
  z-index: 2;
  background: #fff;
  border-radius: 18px;
  padding: 24px;
  width: min(520px, 100%);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.admin-ticket-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.admin-ticket-modal__close {
  border: none;
  background: transparent;
  font-size: 22px;
  cursor: pointer;
}

.admin-ticket-modal__options {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.admin-film-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
  padding-bottom: 24px;
}

.admin-film-card {
  position: relative;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
}

.admin-film-card__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 16px;
}

.admin-film-card__thumb {
  width: 100%;
  padding-top: 56%;
  border-radius: 12px;
  background-color: #f2f2f2;
  background-size: cover;
  background-position: center;
}

.admin-film-card__title {
  font-weight: 700;
  color: #1f2937;
}

.admin-film-card__actions {
  position: absolute;
  inset: 12px 12px auto 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  pointer-events: none;
  z-index: 2;
}

.admin-film-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 255, 255, 0.9);
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 600;
  pointer-events: auto;
  color: #1b2230;
}

.admin-film-card__delete {
  border: none;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  width: 32px;
  height: 32px;
  font-size: 18px;
  cursor: pointer;
  pointer-events: auto;
  color: #1b2230;
}

.admin-film-modal {
  position: fixed;
  inset: 0;
  z-index: 1300;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.admin-film-modal.is-hidden {
  display: none;
}

.admin-film-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
}

.admin-film-modal__dialog {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 16px;
  padding: 20px;
  width: min(520px, 100%);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.2);
}

.admin-film-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.admin-film-modal__close {
  border: none;
  background: transparent;
  font-size: 22px;
  cursor: pointer;
}

.admin-film-modal__options {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.admin-card-preview-modal {
  position: fixed;
  inset: 0;
  z-index: 1320;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.admin-card-preview-modal.is-hidden {
  display: none;
}

.admin-card-preview-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.62);
}

.admin-card-preview-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(820px, 100%);
  max-height: min(92vh, 920px);
  border-radius: 18px;
  background: #fff;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 50px rgba(0, 0, 0, 0.24);
}

.admin-card-preview-modal__header {
  padding: 18px 22px 14px;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  border-bottom: 1px solid #e5e7eb;
}

.admin-card-preview-modal__heading h3 {
  margin: 0;
}

.admin-card-preview-modal__heading p {
  margin: 4px 0 0;
  color: #6b7280;
  font-size: 14px;
}

.admin-card-preview-modal__close {
  border: none;
  background: transparent;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  color: #1b2230;
}

.admin-card-preview-modal__controls {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  border-bottom: 1px solid #e5e7eb;
}

.admin-card-preview-modal__controls label {
  font-weight: 600;
  color: #1b2230;
}

.admin-card-preview-modal__controls select {
  min-width: 180px;
  border: 1px solid #d4d8e3;
  border-radius: 10px;
  padding: 8px 10px;
  font: inherit;
  color: #1b2230;
  background: #fff;
}

.admin-card-preview-modal__content {
  padding: 28px 18px 32px;
  overflow: auto;
  background: #f6f7fb;
  display: flex;
  justify-content: center;
  align-items: flex-start;
}

.admin-card-preview-modal__stack {
  width: min(1080px, 100%);
  display: flex;
  flex-direction: column;
  gap: 28px;
}

.admin-card-preview-modal__block {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}

.admin-card-preview-modal__block--hero {
  align-items: stretch;
}

.admin-card-preview-modal__block-title {
  margin: 0;
  font-size: 14px;
  font-weight: 700;
  color: #4b5563;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.admin-card-preview-modal__card-wrap {
  width: 100%;
  display: flex;
  justify-content: center;
}

.admin-card-preview-modal__card-wrap--hero {
  justify-content: stretch;
}

.admin-card-preview-modal__card-wrap .news-card,
.admin-card-preview-modal__card-wrap .ticket-card,
.admin-card-preview-modal__card-wrap .media-showcase__card {
  width: min(320px, 100%);
}

.admin-card-preview-modal__card-wrap--hero .video-hero {
  width: 100%;
  padding: 0;
}

.admin-card-preview-modal__card-wrap--hero .video-hero__inner {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}

.admin-card-preview-modal__card-wrap--hero .video-hero__scene {
  width: 160px;
  height: 110px;
}

.admin-card-preview-modal__card-wrap--hero .video-hero__description {
  white-space: pre-wrap;
}

@media (max-width: 720px) {
  .admin-card-preview-modal {
    padding: 12px;
  }

  .admin-card-preview-modal__header,
  .admin-card-preview-modal__controls {
    padding-left: 14px;
    padding-right: 14px;
  }

  .admin-card-preview-modal__controls {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-card-preview-modal__controls select {
    width: 100%;
  }

  .admin-card-preview-modal__stack {
    gap: 20px;
  }

  .admin-card-preview-modal__card-wrap--hero .video-hero__scene {
    width: 130px;
    height: 92px;
  }
}

.admin-gallery-selector {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.admin-gallery-selector.is-hidden {
  display: none;
}

.admin-gallery-selector__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
}

.admin-gallery-selector__modal {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 12px;
  width: min(960px, 100%);
  max-height: 85vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.admin-gallery-selector__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #e7e7e7;
}

.admin-gallery-selector__close {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: #1b2230;
}

.admin-gallery-selector__tabs {
  display: flex;
  gap: 12px;
  padding: 12px 20px 0;
}

.admin-gallery-selector__panel {
  padding: 20px;
  overflow-y: auto;
}

.admin-gallery-selector__panel.is-hidden {
  display: none;
}

.admin-gallery-selector__grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
}

.admin-gallery-selector__item {
  border: 1px solid #e4e4e4;
  background: #fff;
  border-radius: 10px;
  padding: 10px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
}

.admin-gallery-selector__item img,
.admin-gallery-selector__item video {
  width: 100%;
  height: 120px;
  object-fit: cover;
  border-radius: 8px;
}

.admin-gallery-selector__item span {
  font-size: 12px;
  color: #333;
  word-break: break-word;
}

.admin-gallery-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.admin-gallery-grid {
  columns: 3;
  column-gap: 20px;
}

.admin-gallery-card {
  position: relative;
  background: #fff;
  border-radius: 14px;
  padding: 10px;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
  display: flex;
  flex-direction: column;
  gap: 10px;
  break-inside: avoid;
  margin-bottom: 20px;
}

.admin-gallery-card.is-dragging {
  opacity: 0.6;
  box-shadow: 0 12px 20px rgba(0, 0, 0, 0.16);
}

.admin-gallery-card__handle {
  position: absolute;
  bottom: 8px;
  right: 8px;
  z-index: 1;
  border: none;
  border-radius: 999px;
  background: rgba(17, 24, 39, 0.8);
  color: #fff;
  font-size: 12px;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
}

.admin-gallery-card__handle:active {
  cursor: grabbing;
}

.admin-gallery-card img,
.admin-gallery-card video {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 12px;
  background: #111;
}

.admin-gallery-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
  color: #1f2937;
}

.admin-gallery-meta p {
  margin: 0;
}

.admin-gallery-visibility {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 1;
}

.admin-gallery-visibility label {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(17, 24, 39, 0.8);
  color: #fff;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 11px;
}

.admin-gallery-visibility input[type="checkbox"] {
  accent-color: #d13e3e;
}

.admin-gallery-delete {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 1;
}

.admin-gallery-delete button {
  border: none;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}

.admin-empty {
  margin: 0;
  color: #1f2937;
}

.admin-button {
  background: #d13e3e;
  color: #fff;
  border: none;
  padding: 10px 22px;
  border-radius: 12px;
  font-weight: 700;
  cursor: pointer;
}

.admin-button--outline {
  background: #fff;
  color: #1f2937;
  border: 1px solid #d1d5db;
}

.admin-button--outline:hover {
  background: #f9fafb;
}

.admin-upload-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: grid;
  place-items: center;
  background: rgba(15, 23, 42, 0.78);
  padding: 20px;
}

.admin-upload-overlay.is-hidden {
  display: none;
}

.admin-upload-overlay__dialog {
  background: rgba(15, 23, 42, 0.92);
  border-radius: 20px;
  padding: 32px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  color: #fff;
  min-width: min(360px, 90vw);
}

.admin-upload-overlay__spinner {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  border: 6px solid rgba(255, 255, 255, 0.25);
  border-top-color: #fff;
  animation: adminUploadSpin 1s linear infinite;
}

.admin-upload-overlay__progress {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.admin-upload-overlay__percent {
  font-size: 14px;
  letter-spacing: 0.08em;
}

.admin-upload-overlay__bar {
  width: 100%;
  max-width: 320px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.2);
  overflow: hidden;
}

.admin-upload-overlay__bar-fill {
  height: 100%;
  width: 0%;
  background: #fff;
  transition: width 0.2s ease;
}

.admin-downloads {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.admin-downloads__row {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) minmax(200px, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.admin-downloads__row input[type="text"],
.admin-downloads__row input[type="file"] {
  width: 100%;
}

.admin-downloads__preview {
  font-size: 12px;
  color: var(--text-soft);
  text-decoration: underline;
}

@keyframes adminUploadSpin {
  to {
    transform: rotate(360deg);
  }
}

@media (max-width: 960px) {
  .admin-gallery-grid {
    columns: 2;
  }
}

@media (max-width: 640px) {
  .admin-gallery-grid {
    columns: 1;
  }
  .festival-nav__cta {
    font-size: 10px;
  }
}

/* === Public gallery === */
.festival-gallery {
  background: var(--gallery-bg);
  border-radius: 24px;
  padding: 48px 48px 64px;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
  max-width: 1120px;
  margin: 48px auto;
}

.festival-gallery__header {
  text-align: center;
  margin-bottom: 32px;
}

.festival-gallery__header h1 {
  margin: 0 0 12px;
  font-size: clamp(28px, 3vw, 40px);
  color: var(--gallery-title);
}

.festival-gallery__header p {
  margin: 0;
  color: var(--gallery-text);
  font-size: 15px;
}

.festival-gallery__grid {
  columns: 3;
  column-gap: 20px;
}

.festival-gallery__section + .festival-gallery__section {
  margin-top: 32px;
}

.festival-gallery__heading {
  margin: 0 0 18px;
  font-size: clamp(20px, 2.2vw, 28px);
  color: var(--gallery-title);
}

.festival-gallery__item {
  margin: 0 0 20px;
  break-inside: avoid;
  border-radius: 16px;
  overflow: hidden;
  background: var(--gallery-card-bg);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.14);
}

.festival-gallery__item img,
.festival-gallery__item video {
  width: 100%;
  display: block;
  height: auto;
}

.festival-gallery__empty {
  text-align: center;
  color: var(--gallery-text);
}

@media (max-width: 960px) {
  .festival-gallery__grid {
    columns: 2;
  }

  .festival-gallery {
    padding: 40px 32px 56px;
  }
}

@media (max-width: 640px) {
  .festival-gallery__grid {
    columns: 1;
  }

  .festival-gallery {
    padding: 32px 20px 48px;
  }
}

/* === News page === */
.news-page {
  display: flex;
  flex-direction: column;
  background: linear-gradient(
    90deg,
    var(--kurd-yellow-soft) 0%,
    var(--kurd-yellow-middle) 25%,
    var(--background-yellow) 100%
  );
}

/* === Rahmenplan page === */
.rahmenplan-page {
  background: linear-gradient(
    90deg,
    var(--kurd-yellow-soft) 0%,
    var(--kurd-yellow-middle) 25%,
    var(--background-yellow) 100%
  );
}

.rahmenplan-page__inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 80px 60px 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}

@media (max-width: 1100px) {
  .rahmenplan-page__inner {
    padding: 80px 24px 100px;
  }
}

@media (max-width: 768px) {
  .rahmenplan-page__inner {
    padding: 72px 24px 90px;
  }
}

.rahmenplan-page__title {
  margin: 0 0 12px;
  font-size: clamp(28px, 3vw, 40px);
  color: var(--text-main);
  text-align: center;
}

.rahmenplan-page__intro p,
.rahmenplan-page__body p {
  margin: 0 0 12px;
  color: var(--text-soft);
  line-height: 1.6;
}

.rahmenplan-page__intro p {
  text-align: center;
}

.rahmenplan-page__poster {
  display: flex;
  justify-content: center;
}

.rahmenplan-page__poster img {
  max-width: 100%;
  max-height: 80vh;
  height: auto;
  border-radius: var(--radius-md);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
}

.rahmenplan-page__downloads {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 16px;
}

.rahmenplan-page__download {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  background: var(--kurd-red);
  color: #ffffff;
  text-decoration: none;
  border-radius: var(--radius-md);
  font-weight: 600;
  letter-spacing: 0.02em;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
  background: var(--kurd-green);
}

.rahmenplan-page__download:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
}

.news-hero {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #0a0a0a;
}

.news-hero__carousel {
  display: flex;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
}

.news-hero__carousel::-webkit-scrollbar {
  display: none;
}

.news-hero__slide {
  position: relative;
  min-width: 100%;
  height: 100vh;
  min-height: 900px;
  scroll-snap-align: start;
}

.news-hero__link {
  position: absolute;
  inset: 0;
  display: block;
  color: inherit;
  text-decoration: none;
}

.news-hero__image {
  position: absolute;
  inset: 0;
  background: #111;
}

.news-hero__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.news-hero__image video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.news-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.7) 0%,
    rgba(0, 0, 0, 0.25) 60%,
    rgba(0, 0, 0, 0) 100%
  );
}

.news-hero__content {
  position: absolute;
  left: 80px;
  bottom: 120px;
  max-width: 540px;
  color: #ffffff;
  display: flex;
  flex-direction: column;
  gap: 16px;
  z-index: 2;
}

.news-hero__category {
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.news-hero__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-size: clamp(28px, 4vw, 48px);
  line-height: 1.1;
  margin: 0;
  color: var(--text-on-dark);
}

.news-hero__intro {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.85);
}

.news-hero__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: none;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, 0.4);
  color: #ffffff;
  cursor: pointer;
  z-index: 3;
}

.news-hero__arrow[hidden] {
  display: none !important;
}

.news-hero__arrow--left {
  left: 32px;
}

.news-hero__arrow--right {
  right: 32px;
}

.news-hero__arrow svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.news-hero__dots {
  position: absolute;
  bottom: 32px;
  left: 0;
  right: 0;
  display: flex;
  justify-content: center;
  gap: 12px;
  z-index: 3;
}

.news-hero__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.6);
  opacity: 0.5;
}

.news-hero__dot.is-active {
  opacity: 1;
}

.news-overview {
  padding: 80px 0 100px;
}

.news-overview__header,
.news-overview__grid,
.news-overview__load {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 60px;
}

.news-overview__intro {
  margin: 0;
  font-size: 14px;
  color: var(--text-soft);
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.news-overview__title {
  margin: 8px 0 0;
  font-size: clamp(28px, 3vw, 36px);
  color: var(--text-main);
}

.news-overview__grid {
  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
  align-items: start;
}

.news-overview__item .news-card {
  width: 100%;
}

.news-overview__empty {
  margin: 0;
  padding: 20px;
  grid-column: 1 / -1;
  border-radius: var(--radius-md);
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: "Inter", system-ui, sans-serif;
}

.news-overview__newsletter {
  margin-top: 48px;
  width: min(560px, calc(100% - 10px));
  margin-left: auto;
  margin-right: auto;
  background: linear-gradient(
    135deg,
    var(--kurd-yellow-soft-opposite) 0%,
    var(--kurd-yellow-middle-opposite) 100%
  );
  border-radius: 28px;
  padding: 32px;
  box-sizing: border-box;
  display: block;
  overflow: hidden;
}

.news-overview__newsletter-content {
  max-width: 100%;
  margin: 0;
  padding: 0;
}

.news-overview__newsletter-content h3 {
  margin-top: 0;
  margin-bottom: 12px;
  color: var(--text-opposite);
}

.news-overview__newsletter-content p {
  margin: 0 0 20px;
  color: var(--text-opposite);
}

.news-overview__newsletter-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.news-overview__newsletter-input {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  background: var(--background-yellow);
  border: 1px solid rgba(0, 0, 0, 0.08);
  color: var(--text-main);
}

.news-overview__newsletter-input input {
  color: var(--text-main);
  flex: 1;
  border: none;
  background: transparent;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  outline: none;
}

.news-overview__newsletter-input button {
  border: none;
  background: #1f1505;
  color: #ffffff;
  border-radius: 999px;
  padding: 8px 16px;
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 600;
  cursor: pointer;
}

.news-overview__newsletter-options label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 14px;
  color: var(--text-opposite);
}

.news-overview__newsletter-privacy label {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.4;
  color: #1f1505;
}

.news-overview__newsletter-privacy input {
  margin-top: 2px;
}

.news-overview__newsletter-privacy a {
  color: inherit;
  text-decoration: underline;
}

.news-overview__load {
  margin-top: 28px;
  display: flex;
  justify-content: center;
}

.news-overview__load-button {
  border: none;
  padding: 12px 24px;
  border-radius: 999px;
  background: var(--primary);
  color: var(--text-on-dark);
  font-family: "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.1em;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* === News detail === */
.news-detail {
  display: flex;
  flex-direction: column;
  background: linear-gradient(
    90deg,
    var(--kurd-yellow-soft) 0%,
    var(--kurd-yellow-middle) 40%,
    var(--background-yellow) 100%
  );
  color: var(--text-on-dark);
  padding-bottom: 120px;
}

.news-detail__hero {
  padding: 120px 24px 40px;
  text-align: center;
}

.news-detail__hero-inner {
  max-width: 900px;
  margin: 0 auto;
}

.news-detail__hero h1 {
  margin: 0;
  font-size: clamp(32px, 4vw, 54px);
  line-height: 1.15;
  color: var(--text-main);
}

.news-detail__subtitle {
  margin: 14px 0 0;
  font-size: 15px;
  color: var(--text-soft);
}

.news-detail__intro {
  padding: 0 24px;
}

:root[data-theme="dark"] .news-detail__intro-card {
  background: #111827;
}

:root[data-theme="dark"] .news-detail__intro-text h2,
:root[data-theme="dark"] .news-detail__intro-text p {
  color: var(--text-main);
}

.news-detail__intro-card {
  max-width: 1100px;
  margin: 0 auto;
  background: var(--media-card-text);
  /* background: linear-gradient(
    90deg,
    var(--kurd-yellow-soft-opposite) 0%,
    var(--kurd-yellow-middle-opposite) 40%,
    var(--background-yellow-opposite) 100%
  ); */
  color: var(--text-main);
  border-radius: 28px;
  padding: 32px 40px;
  display: flex;
  align-items: center;
  gap: 32px;
  box-shadow: 0 8px 13px 6px rgba(0, 0, 0, 0.18);
  border-bottom-left-radius: 100px;
  border-top-right-radius: 100px;
  border: var(--kurd-yellow-soft) 7px double;
}

.news-detail__intro-text h2 {
  margin-top: 0;
  margin-bottom: 12px;
  font-size: 22px;
  color: var(--text-opposite);
}

.news-detail__intro-text p {
  margin: 0;
  line-height: 1.6;
  color: var(--text-opposite);
}

.news-detail__intro-media {
  flex-shrink: 0;
  width: min(380px, 100%);
}

.news-detail__intro-media img {
  width: 100%;
  display: block;
  border-radius: 20px;
  object-fit: cover;
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.25);
}

.news-detail__intro-media video {
  width: 100%;
  display: block;
  border-radius: 20px;
  box-shadow: 0 18px 30px rgba(0, 0, 0, 0.25);
}

.news-detail__body {
  max-width: 1120px;
  margin: 64px auto 100px;
  padding: 0 24px;
}

.news-detail__body-title {
  margin: 0 0 20px;
  font-size: clamp(22px, 3vw, 30px);
  color: var(--text-main);
}

.news-detail__body-text p {
  margin: 0 0 18px;
  line-height: 1.6;
  color: var(--text-soft);
}

.news-detail__gallery {
  margin-top: 72px;
  padding: 0 24px;
}

.news-detail__gallery-header {
  max-width: 900px;
  margin: 0 auto 24px;
  text-align: center;
}

.news-detail__gallery-header h3 {
  margin: 0 0 10px;
  font-size: 24px;
  color: var(--text-main);
}

.news-detail__gallery-header p {
  margin: 0;
  color: var(--text-soft);
}

.news-detail__gallery-stage {
  position: relative;
  max-width: 1000px;
  margin: 0 auto;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.news-detail__gallery-item {
  position: absolute;
  inset: 0;
  border: none;
  padding: 0;
  background: transparent;
  cursor: pointer;
  opacity: 0;
  transform: translate(0, 0) scale(0.9);
  transition:
    transform 0.45s ease,
    opacity 0.45s ease;
  pointer-events: none;
}

.news-detail__gallery-item.is-active,
.news-detail__gallery-item.is-next {
  opacity: 1;
}

.news-detail__gallery-item.is-active {
  transform: translate(0, 0) scale(1);
  z-index: 2;
  pointer-events: auto;
}

.news-detail__gallery-item.is-next {
  transform: translate(48px, 48px) scale(0.4);
  z-index: 1;
  pointer-events: auto;
}

.news-detail__gallery-frame {
  width: 100%;
  height: 100%;
  border-radius: 26px;
  overflow: hidden;
  background: #0f0c03;
  box-shadow: 0 24px 40px rgba(0, 0, 0, 0.35);
}

.news-detail__gallery-item.is-next .news-detail__gallery-frame {
  box-shadow: 0 16px 24px rgba(0, 0, 0, 0.3);
}

.news-detail__gallery-frame img,
.news-detail__gallery-frame video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.news-detail__gallery-arrow {
  position: absolute;
  right: 16px;
  bottom: 16px;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  border: none;
  display: grid;
  place-items: center;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  cursor: pointer;
  z-index: 4;
  transition: transform 0.2s ease;
}

.news-detail__gallery-arrow:hover {
  transform: translateY(-2px);
}

.news-detail__gallery-arrow svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

/* === Video page === */

.video-hero {
  padding: 120px 0 64px;
}

.video-back-link {
  display: inline-flex;
  align-items: center;
  position: absolute;
  gap: 8px;
  margin: 50px 0 0 24px;
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--text-main);
  text-decoration: none;
}

.video-back-link:hover {
  text-decoration: underline;
}

.video-hero__inner {
  display: grid;
  gap: 32px;
  align-items: center;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.video-hero__media-stack {
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
}

.video-hero__media {
  position: relative;
  width: 100%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: color-mix(in srgb, var(--primary) 25%, transparent);
  min-height: fit-content;
}

.video-hero__empty {
  padding: 40px;
  border-radius: var(--radius-lg);
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: var(--font-body);
}

.video-hero__player {
  width: 100%;
  aspect-ratio: 16 / 9;
}

.video-hero__player--consent {
  background: var(--default-bg);
}

.video-hero__player iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.video-hero__consent-prompt {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  background: color-mix(in srgb, var(--default-bg) 90%, transparent);
  border-top: 1px solid var(--border-subtle);
}

.video-hero__consent-prompt p {
  margin: 0;
  color: var(--text-soft);
  font-family: var(--font-body);
}

.video-hero__play {
  position: absolute;
  inset: auto auto 20px 20px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  border: none;
  background: var(--primary);
  color: var(--kurd-white);
  font-family: var(--font-body);
  font-weight: 600;
  cursor: pointer;
}

.video-hero__thumbnail {
  width: 100%;
  aspect-ratio: 16 / 9;
  background-color: var(--default-bg);
  background-size: cover;
  background-position: center;
}

.video-hero__scenes {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.video-hero__scenes-label {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--text-main);
}

.video-hero__scenes-grid {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 4px;
  scrollbar-width: none;
  touch-action: pan-y;
  cursor: grab;
}

.video-hero__scenes-grid::-webkit-scrollbar {
  display: none;
}

.video-hero__scenes-grid.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;
}

.video-hero__scene {
  border: none;
  background: transparent;
  padding: 0;
  flex: 0 0 auto;
  width: 200px;
  height: 150px;
  scroll-snap-align: start;
  cursor: pointer;
  user-select: none;
  -webkit-user-drag: none;
}

.video-hero__scene:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--primary) 70%, transparent);
  outline-offset: 4px;
}

.video-hero__scene img,
.video-hero__scene video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: 0 12px 20px rgba(0, 0, 0, 0.12);
  -webkit-user-drag: none;
  user-select: none;
  pointer-events: none;
}

.video-hero__scene--youtube {
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  background: #111827;
}

.video-hero__scene-youtube-badge {
  position: absolute;
  inset: auto 8px 8px auto;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 700;
}

.video-hero__scene-youtube-fallback {
  width: 100%;
  height: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-family: var(--font-body);
  font-weight: 700;
  letter-spacing: 0.02em;
}

.video-hero__details {
  display: flex;
  flex-direction: column;
  gap: 16px;
  color: var(--text-main);
  min-width: 0;
}

.video-hero__title {
  margin: 0;
}

.video-hero__meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin: 0;
  font-family: var(--font-body);
  color: var(--text-soft);
}

.video-hero__meta div {
  display: grid;
  gap: 4px;
}

.video-hero__meta dt {
  font-weight: 600;
  color: var(--text-main);
}

.video-hero__meta dd {
  margin: 0;
}

.video-hero__description {
  margin: 0;
  font-family: var(--font-body);
  color: var(--text-main);
  line-height: 1.6;
}

.video-hero__link {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.video-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.video-hero__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 600;
  text-decoration: none;
}

.video-hero__button--primary {
  background: var(--primary);
  color: var(--kurd-white);
}

.video-scenes-lightbox {
  position: fixed;
  inset: 0;
  z-index: 2000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.video-scenes-lightbox.is-active {
  opacity: 1;
  pointer-events: auto;
}

.video-scenes-lightbox__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
  background: rgba(17, 24, 39, 0.55);
}

.video-scenes-lightbox__frame {
  position: relative;
  width: min(1200px, 100%);
  height: min(720px, 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.video-scenes-lightbox__media {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.video-scenes-lightbox__media img,
.video-scenes-lightbox__media video {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  border-radius: 18px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.35);
}

.video-scenes-lightbox__youtube {
  width: min(1100px, 100%);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.video-scenes-lightbox__youtube-player {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.35);
}

.video-scenes-lightbox__youtube-player iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.video-scenes-lightbox__youtube-consent {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.9);
}

.video-scenes-lightbox__youtube-consent p {
  margin: 0;
  color: #111827;
  font-family: var(--font-body);
}

.video-scenes-lightbox__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: none;
  background: rgba(255, 255, 255, 0.85);
  color: #111827;
  font-size: 28px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition:
    transform 0.2s ease,
    background 0.2s ease;
}

.video-scenes-lightbox__arrow:hover {
  transform: translateY(-50%) scale(1.04);
  background: rgba(255, 255, 255, 0.95);
}

.video-scenes-lightbox__arrow--left {
  left: 12px;
}

.video-scenes-lightbox__arrow--right {
  right: 12px;
}

.video-scenes-lightbox__close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: none;
  background: rgba(255, 255, 255, 0.92);
  color: #111827;
  font-size: 22px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

body.is-video-scenes-open {
  overflow: hidden;
}

@media (max-width: 600px) {
  .video-hero {
    padding: 90px 0 40px;
  }

  .video-category {
    padding-bottom: 12px;
  }

  .video-hero__scenes-grid {
    margin: 0 -24px;
    padding: 0 24px 6px;
    scroll-padding-left: 24px;
  }
}

.video-hero__button--secondary {
  background: var(--secondary);
  color: var(--secondary-text-color);
}

.video-categories {
  padding: 0;
  overflow: visible;
}

.video-newsletter .news-overview__newsletter {
  margin-top: 0;
  background: linear-gradient(
    135deg,
    var(--primary-soft) 0%,
    var(--kurd-red-soft) 100%
  );
}

.video-newsletter .news-overview__newsletter-content h3,
.video-newsletter .news-overview__newsletter-content p,
.video-newsletter .news-overview__newsletter-options label,
.video-newsletter .news-overview__newsletter-privacy label {
  color: var(--text-main);
}

.video-newsletter .news-overview__newsletter-input {
  background: color-mix(in srgb, var(--surface-strong) 88%, transparent);
  border-color: color-mix(in srgb, var(--primary) 24%, transparent);
  color: var(--text-main);
}

.video-newsletter .news-overview__newsletter-input button {
  background: var(--primary);
  color: var(--text-on-dark);
}

.video-newsletter .news-overview__newsletter-privacy a {
  color: var(--text-main);
}

.video-category {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-bottom: 18px;
  position: relative;
}

.video-category__carousel-wrap {
  position: relative;
}

.video-category__carousel {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding-bottom: 12px;
  scroll-behavior: smooth;
  cursor: grab;
  touch-action: auto;
  scrollbar-width: thin;
  scrollbar-color: transparent transparent;
}

.video-category__header h2 {
  margin: 0 0 8px;
}

.video-category:last-child {
  padding-bottom: 0;
}

.video-category__carousel.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;
  scroll-behavior: auto;
  scrollbar-width: thin;
  scrollbar-color: color-mix(in srgb, var(--text-main) 30%, transparent)
    transparent;
}

.video-category__carousel::-webkit-scrollbar {
  height: 4px;
}

.video-category__carousel::-webkit-scrollbar-track {
  background: transparent;
}

.video-category__carousel::-webkit-scrollbar-thumb {
  background: transparent;
  border-radius: 999px;
}

.video-category__carousel.is-dragging::-webkit-scrollbar-thumb {
  background: color-mix(in srgb, var(--text-main) 30%, transparent);
}

.video-category__scroll-hint {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: none;
  display: grid;
  place-items: center;
  padding: 0;
  background: color-mix(in srgb, var(--text-main) 15%, transparent);
  color: var(--text-main);
  cursor: pointer;
  z-index: 5;
}

.video-category__scroll-hint:hover {
  background: color-mix(in srgb, var(--text-main) 24%, transparent);
}

.video-category__scroll-hint[hidden] {
  display: none !important;
}

.video-category__scroll-hint--left {
  left: -8px;
}

.video-category__scroll-hint--right {
  right: -8px;
}

.video-category__scroll-hint svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.video-card {
  position: relative;
  min-width: 200px;
  height: 120px;
  border-radius: var(--radius-md);
  overflow: hidden;
  scroll-snap-align: start;
  background: var(--default-bg);
  text-decoration: none;
  isolation: isolate;
}

.video-card__thumb {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  transition:
    filter 0.2s ease,
    transform 0.2s ease;
}

.video-card::before {
  content: "Öffnen";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0.95);
  z-index: 3;
  padding: 8px 16px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text-opposite) 55%, transparent);
  background: var(--titel-color);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: var(--text-opposite);
  font-family: var(--font-body);
  font-weight: 600;
  letter-spacing: 0.02em;
  pointer-events: none;
  opacity: 0;
  transition:
    opacity 0.2s ease,
    transform 0.2s ease;
}

.video-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.7) 0%,
    rgba(0, 0, 0, 0) 60%
  );
  transition: opacity 0.2s ease;
  z-index: 1;
}

.video-card__title {
  position: absolute;
  left: 12px;
  bottom: 10px;
  z-index: 2;
  font-family: var(--font-body);
  font-weight: 600;
  color: #fff;
  transition: opacity 0.2s ease;
}

.video-card:hover::before,
.video-card:focus-visible::before,
.video-card.is-preview-active::before {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}

.video-card:hover .video-card__thumb,
.video-card:focus-visible .video-card__thumb,
.video-card.is-preview-active .video-card__thumb {
  filter: blur(2px) brightness(0.75);
  transform: scale(1.03);
}

.video-card:hover .video-card__title,
.video-card:focus-visible .video-card__title,
.video-card.is-preview-active .video-card__title {
  opacity: 0;
}

.video-card-preview {
  position: absolute;
  z-index: 20;
  width: min(720px, 92vw);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(8px);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    visibility 0s linear 0.2s;
}

.video-card-preview.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease;
}

.video-card-preview[hidden] {
  display: block;
}

.video-card-preview__inner {
  display: grid;
  grid-template-columns: minmax(220px, 320px) 1fr;
  gap: 24px;
  padding: 20px;
  border-radius: var(--radius-lg);
  background: var(--media-card-bg);
  color: var(--media-card-text);
  box-shadow: 0 24px 48px color-mix(in srgb, var(--media-card-bg) 35%, #000);
}

.video-card-preview__media-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.video-card-preview__media {
  display: block;
  border-radius: var(--radius-md);
  overflow: hidden;
}

.video-card-preview__image {
  width: 100%;
  aspect-ratio: 16 / 9;
  background-color: color-mix(in srgb, var(--media-card-bg) 70%, #fff);
  background-size: cover;
  background-position: center;
}

.video-card-preview__content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.video-card-preview__title {
  margin: 0;
}

.video-card-preview__meta {
  display: grid;
  gap: 6px;
  margin: 0;
  font-family: var(--font-body);
  color: color-mix(in srgb, var(--media-card-text) 70%, transparent);
}

.video-card-preview__meta div {
  display: grid;
  gap: 2px;
}

.video-card-preview__meta dt {
  font-weight: 600;
  color: var(--media-card-text);
}

.video-card-preview__meta dd {
  margin: 0;
}

.video-card-preview__description {
  margin: 0;
  font-family: var(--font-body);
  color: var(--media-card-text);
  line-height: 1.6;
}

.video-card-preview__scenes {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.video-card-preview__scenes-label {
  margin: 0;
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--media-card-text);
}

.video-card-preview__scenes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(56px, 1fr));
  gap: 8px;
}

.video-card-preview__scenes-grid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 10px;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.15);
}

.video-category__empty {
  color: var(--text-soft);
  font-family: var(--font-body);
}

/* === Tickets Hero === */
.tickets-hero {
  background: var(--tickets-hero-bg);
  padding: 80px 0;
}

.tickets-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.tickets-hero__controls {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 6px;
  flex-wrap: wrap;
}

.tickets-hero__tab {
  border: 1px solid transparent;
  background: rgba(46, 125, 91, 0.12);
  color: var(--tickets-hero-title);
  font-weight: 600;
  padding: 10px 26px;
  border-radius: 999px;
  cursor: pointer;
  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.tickets-hero__tab:hover {
  transform: translateY(-1px);
}

.tickets-hero__tab.is-active {
  background: var(--kurd-green);
  color: var(--kurd-white);
}

.tickets-hero__panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: center;
  gap: 48px;
}

.tickets-hero__panel[hidden] {
  display: none;
}

.tickets-hero__media {
  display: flex;
  justify-content: center;
  align-items: center;
}

.tickets-hero__media img {
  width: min(520px, 100%);
  height: auto;
  display: block;
}

.tickets-hero__content {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}

.tickets-hero__title {
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  color: var(--tickets-hero-title);
  margin: 0;
  text-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
}

.tickets-hero__text {
  color: var(--text-main);
  max-width: 520px;
  margin: 0;
  line-height: 1.6;
}

.tickets-hero__button {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: var(--kurd-green);
  color: var(--kurd-white);
  padding: 12px 28px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
  display: none;
}

.tickets-hero__button svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

/* .tickets-hero__dots {
  display: flex;
  gap: 12px;
  margin-top: 4px;
}

.tickets-hero__dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(46, 125, 91, 0.35);
}

.tickets-hero__dot.is-active {
  background: var(--kurd-green);
} */

:root[data-theme="dark"] .tickets-hero__tab {
  background: rgba(255, 255, 255, 0.08);
  color: var(--tickets-hero-title);
}

:root[data-theme="dark"] .tickets-hero__tab.is-active {
  background: var(--kurd-green);
  color: var(--kurd-white);
}

/* :root[data-theme="dark"] .tickets-hero__dot {
  background: rgba(255, 255, 255, 0.18);
}

:root[data-theme="dark"] .tickets-hero__dot.is-active {
  background: var(--accent);
} */

.checkout-page,
.online-access-page {
  background: var(--media-section-bg);
}

.checkout-page {
  --checkout-green-text: #1b4a35;
}

:root[data-theme="dark"] .checkout-page {
  --checkout-green-text: #9cdbc0;
}

.checkout__inner,
.online-access__inner {
  display: grid;
  gap: 24px;
  padding: 32px;
  border-radius: 24px;
}

.checkout__header h1 {
  margin: 0;
  color: var(--checkout-green-text);
}

.checkout__card h2 {
  color: var(--checkout-green-text);
}

.online-access__inner h1 {
  margin: 0;
  color: var(--kurd-green);
}

.checkout__form {
  display: grid;
  gap: 20px;
}

.checkout__card {
  display: grid;
  gap: 12px;
  background: #ffffff0d;
  border-radius: 16px;
  padding: 20px;
  box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
}

.online-access__form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: flex-start;
}

.checkout__card label {
  display: grid;
  gap: 6px;
  font-weight: 600;
  color: var(--text-main);
}

.online-access__form label {
  display: grid;
  gap: 6px;
  font-weight: 600;
  color: #1b4a35;
}

.checkout__card input,
.checkout__card select,
.online-access__form input {
  border: 1px solid #d1e3d7;
  border-radius: 10px;
  padding: 10px 12px;
  font-size: 16px;
  width: 300px;
}

.checkout__note {
  margin: 0;
  font-size: 14px;
  color: var(--checkout-green-text);
}

.checkout__attendee {
  border: 1px dashed #b7d2c3;
  padding: 16px;
  border-radius: 12px;
  display: grid;
  gap: 10px;
}

.checkout__attendee h3 {
  margin: 0;
  color: var(--tickets-accent);
}

.checkout__actions {
  display: grid;
  gap: 8px;
}

.checkout__summary {
  gap: 10px;
}

.checkout__summary-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  font-weight: 600;
}

.checkout__summary-row--sub {
  font-weight: 500;
  color: var(--checkout-green-text);
  font-size: 14px;
}

.checkout__summary-row--total {
  font-size: 18px;
  color: var(--checkout-green-text);
}

.checkout__summary-divider {
  border-top: 1px solid rgba(15, 23, 42, 0.12);
  margin: 4px 0;
}

.checkout__submit,
.online-access__form button,
.checkout__link {
  background: var(--tickets-accent);
  color: #fff;
  border: none;
  border-radius: 999px;
  padding: 12px 20px;
  font-weight: 700;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
}

.checkout__error,
.online-access__error {
  color: #b91c1c;
  font-weight: 600;
}

.online-access__success {
  color: #15803d;
  font-weight: 600;
}

/* === Tickets Hero === */
.tickets-hero {
  background: var(--tickets-hero-bg);
  padding: 80px 0;
}

.tickets-hero__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.tickets-hero__controls {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 6px;
  flex-wrap: wrap;
}

.tickets-hero__tab {
  border: 1px solid transparent;
  background: rgba(46, 125, 91, 0.12);
  color: var(--tickets-hero-title);
  font-weight: 600;
  padding: 10px 26px;
  border-radius: 999px;
  cursor: pointer;
  transition:
    background 0.2s ease,
    color 0.2s ease,
    transform 0.2s ease;
}

.tickets-hero__tab:hover {
  transform: translateY(-1px);
}

.tickets-hero__tab.is-active {
  background: var(--kurd-green);
  color: var(--kurd-white);
}

.tickets-hero__panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  align-items: center;
  gap: 48px;
}

.tickets-hero__panel[hidden] {
  display: none;
}

.tickets-hero__media {
  display: flex;
  justify-content: center;
  align-items: center;
}

.tickets-hero__media img {
  width: min(520px, 100%);
  height: auto;
  display: block;
}

.tickets-hero__content {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}

.tickets-hero__title {
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  color: var(--tickets-hero-title);
  margin: 0;
  text-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
}

.tickets-hero__button svg {
  width: 18px;
  height: 18px;
  fill: currentColor;
}

/* .tickets-hero__dots {
  display: flex;
  gap: 12px;
  margin-top: 4px;
}

.tickets-hero__dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(46, 125, 91, 0.35);
}

.tickets-hero__dot.is-active {
  background: var(--kurd-green);
} */

:root[data-theme="dark"] .tickets-hero__tab {
  background: rgba(255, 255, 255, 0.08);
  color: var(--tickets-hero-title);
}

/* :root[data-theme="dark"] .tickets-hero__dot {
  background: rgba(255, 255, 255, 0.18);
}

:root[data-theme="dark"] .tickets-hero__dot.is-active {
  background: var(--accent);
} */

/* === Tickets Section === */
.tickets-section {
  background: var(--tickets-section-bg);
  padding: 60px 0 90px;
}

.tickets-section__panel {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.tickets-section__panel[hidden] {
  display: none;
}

.tickets-section__intro {
  max-width: 680px;
  color: var(--tickets-card-text);
}

.tickets-section__title {
  color: var(--tickets-hero-title);
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  margin: 0 0 12px;
}

.tickets-section__text {
  margin: 0;
  color: var(--text-main);
  line-height: 1.6;
}

.tickets-section__packages {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 24px;
}

.tickets-package {
  background: var(--tickets-card-bg);
  color: var(--tickets-card-text);
  border-radius: 20px;
  padding: 24px;
  box-shadow: 0 18px 36px var(--tickets-card-shadow);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.tickets-package__badge {
  align-self: flex-start;
  background: var(--ticket-badge-bg, #1e4730);
  color: var(--ticket-badge-color, #eafdef);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.tickets-package__title {
  margin: 0;
  font-size: 1.2rem;
  color: var(--tickets-accent);
}

.tickets-package__price {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 0.95rem;
}

.tickets-package__price strong {
  font-size: 1.2rem;
}

.tickets-package__features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 8px;
  font-size: 0.9rem;
}

.tickets-package__star {
  color: var(--tickets-accent);
  margin-right: 6px;
}

.tickets-package__note {
  margin: 0;
  color: var(--tickets-muted);
  font-size: 0.85rem;
}

.tickets-package__button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--tickets-accent);
  color: var(--kurd-white);
  padding: 10px 18px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
}

.tickets-package__button svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}

.tickets-section__listing {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.tickets-section__subtitle {
  margin: 0;
  font-size: 1.2rem;
  color: var(--tickets-card-text);
}

.tickets-feature {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 24px;
  background: rgba(255, 255, 255, 0.6);
  border-radius: 20px;
  padding: 20px;
  border: solid var(--accent-green-soft);
  font-family: var(--font-body);
}

:root[data-theme="dark"] .tickets-feature {
  background: rgba(0, 0, 0, 0.2);
}

.tickets-feature__image img {
  width: 100%;
  height: auto;
  border-radius: 16px;
  display: block;
}

.tickets-feature__content h4 {
  margin: 0 0 8px;
  font-size: 1.2rem;
  color: var(--tickets-card-text);
  font-family: var(--font-heading);
}

.tickets-feature__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 0.85rem;
  color: var(--tickets-muted);
  margin-bottom: 12px;
  font-family: var(--font-body);
}

.tickets-feature__tag {
  background: rgba(46, 125, 91, 0.2);
  color: var(--tickets-card-text);
  padding: 2px 8px;
  border-radius: 999px;
  font-weight: 600;
}

.tickets-feature__content p {
  margin: 0 0 16px;
  color: var(--tickets-muted);
  font-family: var(--font-body);
}

.tickets-feature__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.tickets-feature__button {
  background: var(--nav-accent);
  color: var(--kurd-white);
  padding: 10px 18px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  font-family: var(--font-body);
}

.tickets-feature__button.is-secondary {
  background: #f2c15f;
  color: #4a3500;
}

.tickets-scenes__label {
  margin: 0 0 10px;
  color: var(--tickets-card-text);
  font-weight: 600;
}

.tickets-scenes__grid {
  display: flex;
  gap: 12px;
  flex-direction: row;
  justify-content: flex-start;
}

.tickets-scenes__item img {
  width: 200px;
  height: 90px;
  object-fit: cover;
  border-radius: 12px;
  display: block;
  border: solid var(--accent-green-soft);
}

.tickets-videos__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin: 0 0 10px;
}

.tickets-videos__header h4 {
  margin: 0;
  color: var(--tickets-card-text);
}

.tickets-videos__link {
  color: var(--tickets-muted);
  text-decoration: none;
  font-size: 0.85rem;
}

.tickets-videos__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 16px;
}

.tickets-video-card {
  background: rgba(255, 255, 255, 0.55);
  padding: 12px;
  border-radius: 16px;
  border: solid var(--accent-green-soft);
}

:root[data-theme="dark"] .tickets-video-card {
  background: rgba(0, 0, 0, 0.2);
}

.tickets-video-card__image {
  width: 100%;
  height: 120px;
  border-radius: 12px;
  background-size: cover;
  background-position: center;
  margin-bottom: 10px;
}

.tickets-video-card h5 {
  margin: 0;
  font-size: 0.9rem;
  color: var(--tickets-card-text);
}

@media (max-width: 960px) {
}

/* === Team page === */
.team-page {
  display: flex;
  flex-direction: column;
  background: linear-gradient(
    90deg,
    var(--kurd-yellow-soft) 0%,
    var(--kurd-yellow-middle) 25%,
    var(--background-yellow) 100%
  );
}

.team-hero__inner {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.team-hero__header {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.team-hero__title {
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-weight: 600;
  margin: 0;
  color: var(--text-main);
}

.team-hero__subtitle {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 16px;
  color: var(--text-soft);
  max-width: 720px;
}

.team-slider {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.team-slider__content {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 30px;
}

.team-slider__carousel {
  display: flex;
  gap: 24px;
  overflow-x: auto;
  scroll-behavior: auto;
  padding: 12px 0;
  scrollbar-width: none;
  cursor: grab;
  touch-action: pan-x;
  width: 100%;
}

.team-slider__carousel::-webkit-scrollbar {
  display: none;
}

.team-slider__carousel.is-dragging {
  cursor: grabbing;
  user-select: none;
}

.team-slider__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: none;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--text-main) 12%, transparent);
  color: var(--text-main);
  cursor: pointer;
  flex-shrink: 0;
}

.team-slider__arrow--left {
  left: -10px;
}

.team-slider__arrow--right {
  right: -10px;
}

.team-slider__arrow[hidden] {
  display: none !important;
}

.team-slider__arrow svg {
  width: 22px;
  height: 22px;
  fill: currentColor;
}

.team-card {
  position: relative;
  width: 300px;
  min-width: 300px;
  height: 420px;
  perspective: 1200px;
  scroll-snap-align: center;
}

.team-card__inner {
  width: 100%;
  height: 100%;
  border-radius: var(--radius-lg);
  position: relative;
  transform-style: preserve-3d;
  transition: transform 0.6s ease;
  border: none;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

.team-card.is-flipped .team-card__inner {
  transform: rotateY(180deg);
}

.team-card__face {
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  background: var(--kurd-yellow-soft);
  box-shadow: 6px 7px 5px rgba(0, 0, 0, 0.08);
  backface-visibility: hidden;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.team-card__face--front img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.team-card__placeholder {
  width: 100%;
  height: 100%;
  background: var(--kurd-yellow-middle);
}

.team-card__face--back {
  padding: 20px;
  background: var(--kurd-yellow-middle);
  transform: rotateY(180deg);
  text-align: left;
  gap: 12px;
  min-height: 0;
}

.team-card__meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.team-card__name {
  margin: 0;
  font-family: "Poppins", "Inter", system-ui, sans-serif;
  font-size: 20px;
  color: var(--text-main);
}

.team-card__role {
  margin: 0;
  font-size: 14px;
  color: var(--text-muted);
}

.team-card__description {
  margin: 0;
  flex: 1;
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-main);
  overflow-y: auto;
  padding-right: 6px;
}

.team-slider__dots {
  display: flex;
  justify-content: center;
  gap: 12px;
}

.team-slider__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--text-muted);
  opacity: 0.5;
}

.team-slider__dot.is-active {
  opacity: 1;
}

.team-slider__empty {
  padding: 24px;
  border-radius: var(--radius-md);
  background: var(--default-bg);
  color: var(--text-soft);
  font-family: "Inter", system-ui, sans-serif;
}

.team-about__inner {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.team-about__title {
  margin: 0;
  color: var(--text-main);
}

.team-about__text {
  margin: 0;
  color: var(--text-main);
}

.admin-team-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.admin-team-card {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  border-radius: 12px;
  background: #ffffff;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.08);
}

.admin-team-card__info {
  display: flex;
  align-items: center;
  gap: 12px;
}

.admin-team-card__info img {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  object-fit: cover;
}

.admin-team-card__info span {
  display: block;
  font-size: 13px;
  color: #6b7280;
}

.admin-team-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.admin-team-card__actions form {
  display: flex;
  align-items: center;
  gap: 8px;
}

.admin-button--danger {
  background: #b91c1c;
}

.admin-empty {
  margin: 0;
  padding: 12px 0;
  color: #6b7280;
}

/* === Donation section === */
.donation {
  background: var(--background-alt);
}

.donation__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}

.donation__header {
  text-align: center;
  max-width: 720px;
}

.donation__title {
  margin-bottom: 12px;
}

.donation__description {
  color: var(--text-soft);
  margin: 0;
}

.donation__card {
  width: min(720px, 100%);
  background: var(--surface-strong);
  border: 2px solid var(--border-strong);
  border-radius: 24px;
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
}

.donation__subtitle {
  margin: 0 0 16px;
  text-align: left;
}

.donation__amount-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.donation__amount-button {
  border-radius: 999px;
  border: 1px solid transparent;
  background: color-mix(in srgb, var(--border-subtle) 65%, transparent);
  color: var(--text-main);
  padding: 10px 18px;
  font-weight: 600;
  font-size: 16px;
  cursor: pointer;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    background 0.2s ease;
}

.donation__amount-button:hover,
.donation__amount-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.08);
}

.donation__amount-button.is-active {
  background: var(--kurd-green);
  color: var(--text-on-dark);
  border-color: var(--kurd-green);
}

.donation__amount-button--custom {
  background: color-mix(in srgb, var(--accent-green-soft) 80%, transparent);
}

.donation__custom-field {
  margin-top: 12px;
}

.donation__custom-field input {
  background: var(--background);
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 16px;
  color: var(--text-main);
}

.donation__personal {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.donation__personal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.donation__personal input {
  background: var(--background);
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  padding: 12px 14px;
  font-size: 16px;
  color: var(--text-main);
}

.donation__submit {
  align-self: center;
  background: var(--primary);
  color: var(--text-on-dark);
  border: none;
  border-radius: 999px;
  padding: 12px 28px;
  font-size: 16px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.donation__error {
  margin: 0;
  text-align: center;
  color: #b91c1c;
  font-weight: 600;
}

.donation__closing {
  margin: 0;
  text-align: center;
  color: var(--text-soft);
  max-width: 720px;
}

.director-page {
  position: relative;
}

.director-hero {
  position: relative;
}

.director-hero__image {
  min-height: 33vh;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  position: relative;
}

.director-hero__portrait {
  --portrait-size: 200px;
  position: absolute;
  left: 50%;
  bottom: calc(var(--portrait-size) / -2);
  transform: translateX(-50%);
  width: var(--portrait-size);
  height: var(--portrait-size);
  border-radius: 50%;
  overflow: hidden;
  border: 6px solid #fff;
  background: #f4f4f4;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2);
  z-index: 2;
}

.director-hero__portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.director-content__inner {
  padding-top: 120px;
}

.director-content__title {
  margin-top: 0;
}

.director-content__text {
  white-space: pre-line;
  text-align: left;
  margin: 0;
}

.director-videos__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;
}

.director-videos__empty {
  margin: 0;
}

.sponsor-hero {
  position: relative;
  padding: clamp(3rem, 8vw, 6rem) 24px 2.5rem;
  background: var(--media-section-bg);
  text-align: center;
}

.sponsor-hero__inner {
  max-width: 960px;
  margin: 0 auto;
}

.sponsor-hero__title {
  margin: 0;
  font-size: clamp(2.5rem, 5vw, 4rem);
  color: var(--text-main);
}

.sponsor-section {
  background: var(--media-section-bg);
  padding: 0 24px clamp(3rem, 6vw, 5rem);
}

.sponsor-section__inner {
  max-width: 1200px;
  margin: 0 auto;
}

.sponsor-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}

.sponsor-card {
  padding: 24px;
  text-align: center;
  margin: 0;
}

.sponsor-card__logo {
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sponsor-card__logo a {
  display: block;
  width: 100%;
  height: 100%;
}

.sponsor-card__logo img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  object-fit: contain;
}

.sponsor-card__placeholder {
  font-size: 0.9rem;
  color: var(--text-muted);
}

.sponsor-card__name {
  margin: 10px 0;
}

.sponsor-card__name h3 {
  margin: 0;
  color: var(--text-main);
  font-weight: 700;
  font-size: 1.1rem;
}

.sponsor-card__description {
  margin: 0.5rem 0 0;
  color: var(--text-soft);
  font-size: 0.95rem;
}

.sponsor-section__empty {
  text-align: center;
  color: var(--text-muted);
  margin-top: 24px;
}

@media (max-width: 1024px) {
  .news-hero__content {
    left: 40px;
    right: 40px;
  }

  .news-overview__newsletter {
    width: min(560px, calc(100% - 10px));
    padding: 24px;
  }

  .news-overview__newsletter-content {
    max-width: 100%;
    margin: 0;
    padding: 0;
  }

  .news-detail__intro-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .news-detail__intro-media {
    width: 100%;
  }
  .tickets-hero {
    padding: 60px 0;
  }

  .tickets-hero__panel {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .tickets-hero__media {
    order: 2;
  }

  .tickets-hero__content {
    order: 1;
  }

  .tickets-feature {
    grid-template-columns: 1fr;
  }

  .team-card {
    width: 260px;
    min-width: 260px;
    height: 360px;
  }
  .sponsor-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .news-hero__slide {
    min-height: 600px;
  }

  .news-hero__content {
    left: 24px;
    right: 24px;
    bottom: 80px;
  }

  .news-hero__intro {
    display: none;
  }

  .news-hero__arrow {
    width: 36px;
    height: 36px;
  }

  .news-overview__header,
  .news-overview__grid,
  .news-overview__load {
    padding: 0 10px;
  }

  .news-overview__newsletter {
    width: calc(100% - 10px);
    padding: 20px;
  }

  .news-overview__newsletter-input {
    flex-wrap: nowrap;
    gap: 8px;
  }

  .news-overview__newsletter-input input {
    min-width: 0;
  }

  .news-overview__newsletter-input button {
    width: auto;
    flex-shrink: 0;
    white-space: nowrap;
  }

  .news-detail__hero {
    padding: 90px 20px 32px;
  }

  .news-detail__intro-card {
    padding: 24px;
  }

  .news-detail__gallery-stage {
    aspect-ratio: 4 / 3;
  }

  .news-detail__gallery-item.is-next {
    transform: translate(26px, 26px) scale(0.5);
  }
  .video-hero__inner {
    grid-template-columns: 1fr;
  }
  .video-card {
    min-width: 180px;
  }
  .team-card {
    width: 240px;
    min-width: 240px;
    height: 340px;
  }

  .team-slider__arrow {
    width: 34px;
    height: 34px;
  }
  .donation__card {
    padding: 24px;
  }

  .donation__personal-grid {
    grid-template-columns: 1fr;
  }

  .donation__amount-grid {
    justify-content: center;
  }
  .director-hero__portrait {
    --portrait-size: 160px;
    border-width: 4px;
  }

  .director-content__inner {
    padding-top: 96px;
  }
  .sponsor-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 1100px) {
  .admin-shell {
    flex-direction: column;
  }

  .admin-sidebar {
    flex: 1;
  }

  .admin-grid {
    grid-template-columns: 1fr;
  }

  .media-showcase__inner,
  .ticket-showcase__inner,
  .news-section__inner {
    padding: 0 24px;
  }

  .media-showcase__carousel {
    justify-content: flex-start;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 12px;
  }

  .media-showcase__card {
    scroll-snap-align: end;
    width: 290px;
  }

  .media-showcase__dots {
    display: flex;
  }

  .media-showcase__content.is-scrollable .media-showcase__scroll-hint {
    display: grid;
  }

  .ticket-showcase__tickets {
    justify-content: flex-start;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 12px;
  }

  .ticket-card {
    scroll-snap-align: start;
    width: 290px;
  }

  .ticket-showcase__dots {
    display: flex;
  }

  .ticket-showcase__content.is-scrollable .ticket-showcase__scroll-hint {
    display: grid;
  }

  .news-section__carousel {
    justify-content: flex-start;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 12px;
  }

  .news-card {
    scroll-snap-align: start;
    width: 290px;
  }

  .news-section__dots {
    display: flex;
  }

  .news-section__content.is-scrollable .news-section__scroll-hint {
    display: grid;
  }

  .media-showcase__carousel,
  .ticket-showcase__tickets,
  .news-section__carousel {
    scrollbar-width: auto;
  }

  .media-showcase__carousel::-webkit-scrollbar,
  .ticket-showcase__tickets::-webkit-scrollbar,
  .news-section__carousel::-webkit-scrollbar {
    height: 8px;
  }

  .media-showcase__carousel::-webkit-scrollbar-track,
  .ticket-showcase__tickets::-webkit-scrollbar-track,
  .news-section__carousel::-webkit-scrollbar-track {
    background: transparent;
  }

  .media-showcase__carousel::-webkit-scrollbar-thumb,
  .ticket-showcase__tickets::-webkit-scrollbar-thumb,
  .news-section__carousel::-webkit-scrollbar-thumb {
    background: color-mix(in srgb, var(--text-main) 28%, transparent);
    border-radius: 999px;
  }
}

@media (min-width: 1200px) {
  .section__inner {
    padding: 0;
  }
}

@media (max-width: 900px) {
  .social-rail {
    top: auto;
    right: auto;
    bottom: calc(
      var(--scroll-top-offset, 12px) + env(safe-area-inset-bottom, 0px) + 10px
    );
    left: 50%;
    transform: translateX(-50%);
    padding: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .social-rail.is-dimmed {
    opacity: 0.8;
    background: transparent;
    box-shadow: none;
  }

  .social-rail:hover {
    background: transparent;
    box-shadow: none;
  }

  .social-rail__desktop-links {
    display: none;
  }

  .social-rail-mobile {
    --mobile-social-toggle-size: 56px;
    --mobile-social-shift-near: clamp(62px, 14vw, 78px);
    --mobile-social-shift-far: clamp(156px, 34vw, 188px);
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(420px, calc(100vw - 24px));
    min-width: 260px;
    height: var(--mobile-social-toggle-size);
  }

  .social-rail-mobile__toggle {
    width: var(--mobile-social-toggle-size);
    height: var(--mobile-social-toggle-size);
    color: #fff;
    background: var(--nav-accent);
    box-shadow: 0 14px 26px
      color-mix(in srgb, var(--nav-accent) 35%, transparent);
    transition:
      transform 0.3s ease,
      width 0.25s ease,
      height 0.25s ease,
      background 0.25s ease,
      box-shadow 0.25s ease;
    cursor: pointer;
    z-index: 3;
  }

  .social-rail-mobile__toggle-icon {
    width: 30px;
    height: 30px;
    transition: opacity 0.2s ease;
  }

  .social-rail-mobile__toggle-icon--close {
    display: none;
  }

  .social-rail-mobile__items {
    position: absolute;
    inset: 0;
    pointer-events: none;
  }

  .social-rail-mobile__item {
    position: absolute;
    top: 50%;
    left: 50%;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    width: 50px;
    min-width: 50px;
    min-height: 58px;
    box-sizing: border-box;
    padding: 8px 4px 6px;
    border-radius: 16px;
    border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
    background: color-mix(in srgb, var(--surface) 70%, transparent);
    color: var(--text-main);
    box-shadow: 0 12px 22px rgba(0, 0, 0, 0.16);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transform: translate(-50%, -50%) scale(0.85);
    opacity: 0;
    pointer-events: none;
    text-decoration: none;
    transition:
      transform 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55),
      opacity 0.35s ease;
  }

  .social-rail-mobile__bubble {
    width: 22px;
    height: 22px;
    background: transparent;
    color: inherit;
    box-shadow: none;
    border-radius: 0;
    transition:
      transform 0.25s ease,
      background 0.25s ease,
      color 0.25s ease;
  }

  .social-rail-mobile__bubble svg {
    width: 20px;
    height: 20px;
  }

  .social-rail-mobile__bubble--donate {
    background: transparent;
    color: inherit;
  }

  .social-rail-mobile__label {
    font-size: 9px;
    font-weight: 600;
    color: inherit;
    line-height: 1.05;
    text-align: center;
    opacity: 0;
    transition: opacity 0.25s ease;
    white-space: normal;
    overflow-wrap: anywhere;
    max-width: 100%;
  }

  .social-rail-mobile__item--donate {
    background: color-mix(in srgb, var(--kurd-green) 86%, transparent);
    border-color: color-mix(in srgb, var(--kurd-green) 92%, transparent);
    color: #fff;
  }

  .social-rail-mobile.is-open .social-rail-mobile__toggle {
    width: 40px;
    height: 40px;
    transform: none;
    box-shadow: 0 8px 14px
      color-mix(in srgb, var(--nav-accent) 32%, transparent);
  }

  .social-rail-mobile.is-open .social-rail-mobile__toggle-icon {
    width: 32px;
    height: 32px;
  }

  .social-rail-mobile.is-open .social-rail-mobile__toggle-icon--info {
    display: none;
  }

  .social-rail-mobile.is-open .social-rail-mobile__toggle-icon--close {
    display: block;
  }

  .social-rail-mobile.is-open .social-rail-mobile__item {
    opacity: 1;
    pointer-events: auto;
    width: 60px;
  }

  .social-rail-mobile.is-open .social-rail-mobile__item--instagram {
    transform: translate(
        calc(-50% - var(--mobile-social-shift-far)),
        calc(-50% - 30px)
      )
      scale(1);
    transition-delay: 50ms;
  }

  .social-rail-mobile.is-open .social-rail-mobile__item--facebook {
    transform: translate(
        calc(-50% - var(--mobile-social-shift-near)),
        calc(-50% - 30px)
      )
      scale(1);
    transition-delay: 100ms;
  }

  .social-rail-mobile.is-open .social-rail-mobile__item--info {
    transform: translate(
        calc(-50% + var(--mobile-social-shift-near)),
        calc(-50% - 30px)
      )
      scale(1);
    transition-delay: 150ms;
  }

  .social-rail-mobile.is-open .social-rail-mobile__item--donate {
    transform: translate(
        calc(-50% + var(--mobile-social-shift-far)),
        calc(-50% - 30px)
      )
      scale(1);
    transition-delay: 200ms;
  }

  .social-rail-mobile.is-open .social-rail-mobile__label {
    opacity: 1;
    transition-delay: 220ms;
  }

  .social-rail-mobile__item:active .social-rail-mobile__bubble,
  .social-rail-mobile__item:focus-visible .social-rail-mobile__bubble {
    transform: scale(1.08);
  }

  .social-rail-mobile__item:focus-visible {
    outline: none;
  }

  .social-rail-mobile__item:focus-visible .social-rail-mobile__label {
    opacity: 1;
  }
  .section__inner {
    padding: 0 24px;
  }
  .media-showcase__carousel {
    justify-content: flex-start;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 12px;
  }
  .media-showcase__card {
    scroll-snap-align: end;
    width: 290px;
  }
  .media-showcase__dots {
    display: flex;
  }
  .media-showcase__content.is-scrollable .media-showcase__scroll-hint {
    display: grid;
  }

  .ticket-showcase__inner {
    padding: 0 24px;
  }

  .ticket-showcase__tickets {
    justify-content: flex-start;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 12px;
  }
  .ticket-card {
    scroll-snap-align: start;
    width: 290px;
  }
  .ticket-showcase__dots {
    display: flex;
  }
  .ticket-showcase__content.is-scrollable .ticket-showcase__scroll-hint {
    display: grid;
  }
  .news-section__inner {
    padding: 0 24px;
  }
  .news-section__carousel {
    justify-content: flex-start;
    gap: 24px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 12px;
  }
  .news-card {
    scroll-snap-align: start;
    width: 290px;
  }
  .news-section__dots {
    display: flex;
  }
  .news-section__content.is-scrollable .news-section__scroll-hint {
    display: grid;
  }
}

@media (max-width: 600px) {
  .social-rail {
    top: auto;
    right: auto;
    bottom: calc(
      var(--scroll-top-offset, 12px) + env(safe-area-inset-bottom, 0px) + 10px
    );
    left: 50%;
    transform: translateX(-50%);
  }

  .social-rail-mobile {
    --mobile-social-toggle-size: 52px;
    --mobile-social-shift-near: clamp(50px, 15vw, 62px);
    --mobile-social-shift-far: clamp(126px, 36vw, 152px);
    width: min(360px, calc(100vw - 20px));
    min-width: 220px;
  }

  .social-rail-mobile__toggle {
    width: var(--mobile-social-toggle-size);
    height: var(--mobile-social-toggle-size);
  }

  .social-rail-mobile__toggle-icon {
    width: 24px;
    height: 24px;
  }

  .social-rail-mobile__bubble {
    width: 20px;
    height: 20px;
  }

  .social-rail-mobile__bubble svg {
    width: 18px;
    height: 18px;
  }

  .social-rail-mobile__label {
    font-size: 8px;
  }

  .team-slider__carousel {
    scroll-snap-type: x mandatory;
  }

  .media-showcase {
    padding: 90px 0;
  }
  .media-showcase__cta {
    justify-content: center;
  }

  .ticket-showcase {
    padding: 90px 0;
  }

  .ticket-card__cta {
    justify-content: center;
  }
  .news-section {
    padding: 90px 0;
  }
}

@media (max-width: 400px) {
  .festival-nav__inner {
    display: flex;
    justify-content: space-between;
    gap: 8px;
  }

  .festival-nav__left-controls {
    justify-self: auto;
    min-width: auto;
  }

  .festival-nav__logo {
    position: static;
    top: auto;
    left: auto;
    transform: none;
    flex: 1 1 auto;
    justify-self: auto;
    margin: 0;
    z-index: auto;
  }

  .festival-nav__actions {
    justify-self: auto;
    min-width: auto;
    gap: 8px;
  }
}
