/*
Theme Name: Maennerreih Merten Layout
Theme URI: https://www.maennerreih-merten.de
Author: Codex
Description: Block theme layout concept matching the current Maenner-Reih Merten site structure.
Version: 0.4.3
Requires at least: 6.5
Tested up to: 6.8
Requires PHP: 8.1
Text Domain: maennerreih-layout
*/

:root {
  --mr-black: #050505;
  --mr-white: #fff;
  --mr-cream: #fff;
  --mr-green: #086607;
  --mr-green-dark: #034d02;
  --mr-green-deep: #022f02;
  --mr-red: #c90000;
  --mr-red-dark: #a80000;
  --mr-gold: #f6b73c;
  --mr-line: rgb(3 77 2 / 18%);
  --mr-shadow-hard: 12px 12px 0 rgb(0 0 0 / 18%);
  --mr-shadow-soft: 0 22px 60px rgb(0 0 0 / 24%);
}

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

body {
  margin: 0;
  background: var(--mr-white);
  color: var(--mr-black);
  font-family: Poppins, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 16px;
  line-height: 1.45;
}

a {
  color: inherit;
}

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

:root :where(.mr-main, .mr-festival-hero, .mr-program, .mr-verein, .mr-page, .mr-single, .mr-archive, .mr-single-content, .mr-page-content).is-layout-flow> :first-child {
  margin-block-start: revert;
}

.mr-shell {
  max-width: 1220px;
  margin-inline: auto;
  padding-inline: clamp(16px, 4vw, 28px);
}

.mr-main {
  margin-top: 0;
  margin-block-end: 0;
}

.mr-topbar {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--mr-green-dark);
  color: var(--mr-white);
}

.mr-nav {
  min-height: 74px;
  gap: 20px;
  flex-wrap: nowrap;
}

.mr-brand {
  gap: 12px;
  color: var(--mr-white);
}

.mr-brand img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  background: var(--mr-white);
  border-radius: 50%;
  padding: 3px;
}

.mr-brand .wp-block-site-title a {
  color: var(--mr-white);
  font-size: 0.95rem;
  font-weight: 800;
  line-height: 1.05;
  text-decoration: none;
  text-transform: uppercase;
}

.mr-menu .wp-block-navigation-item__content {
  display: block;
  padding: 10px 14px;
  color: var(--mr-white);
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
}

.mr-menu .wp-block-navigation-item__content:hover,
.mr-menu .current-menu-item>.wp-block-navigation-item__content {
  background: var(--mr-red);
}

.mr-menu .wp-block-navigation__submenu-icon {
  width: 0.72em;
  height: 0.72em;
  margin-left: 8px;
  color: currentColor;
}

.mr-menu .has-child .wp-block-navigation__submenu-container,
.wp-block-navigation .has-child .wp-block-navigation__submenu-container {
  min-width: 240px;
  padding: 8px 0;
  background: var(--mr-white);
  border: 0;
  box-shadow: 10px 10px 0 rgb(0 0 0 / 12%);
}

.mr-menu .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item__content,
.wp-block-navigation .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  display: block;
  padding: 12px 18px;
  color: var(--mr-black);
  background: transparent;
  font-size: 0.88rem;
  font-weight: 850;
  line-height: 1.1;
  text-transform: uppercase;
}

.mr-menu .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover,
.mr-menu .has-child .wp-block-navigation__submenu-container .current-menu-item>.wp-block-navigation-item__content,
.wp-block-navigation .has-child .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover,
.wp-block-navigation .has-child .wp-block-navigation__submenu-container .current-menu-item>.wp-block-navigation-item__content {
  background: var(--mr-red);
  color: var(--mr-white);
}

.mr-menu .wp-block-navigation__responsive-container-open,
.mr-menu .wp-block-navigation__responsive-container-close {
  color: var(--mr-white);
}

.mr-menu .wp-block-navigation__responsive-container-open {
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
}

.mr-menu .wp-block-navigation__responsive-container-open svg,
.mr-menu .wp-block-navigation__responsive-container-close svg {
  width: 30px;
  height: 30px;
}

.mr-menu .wp-block-navigation__responsive-container.is-menu-open {
  background: var(--mr-green-dark);
  color: var(--mr-white);
}

.mr-festival-page {
    background: url(logo-bg.svg), linear-gradient(135deg, var(--mr-green-dark) 0%, var(--mr-green) 62%, #087a07 100%);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.mr-festival-hero {
  position: relative;
  isolation: isolate;
  min-height: auto;
  overflow: clip;
  color: var(--mr-white);
}

.mr-festival-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -2;
  opacity: 1;
}

.mr-festival-hero-inner {
  min-height: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: clamp(28px, 4vw, 56px);
  align-items: center;
  padding-block: clamp(42px, 6vw, 86px);
}

.mr-festival-number {
  display: inline-flex;
  margin: 0 0 14px;
  color: var(--mr-white);
  font-size: clamp(1.25rem, 3vw, 2.2rem);
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1;
  text-shadow: 0 5px 0 rgb(0 0 0 / 15%);
  text-transform: uppercase;
}

.mr-festival-kicker {
  max-width: 720px;
  margin: 0 0 18px;
  color: var(--mr-white);
  font-size: clamp(1.05rem, 2vw, 1.45rem);
  font-weight: 900;
  letter-spacing: 0.02em;
  line-height: 1.15;
  text-transform: uppercase;
  text-shadow: 0 5px 0 rgb(0 0 0 / 14%);
}

.mr-festival-title {
  max-width: 900px;
  margin: 0;
  color: var(--mr-white);
  font-family: Poppins, system-ui, sans-serif;
  font-size: clamp(3.2rem, 7vw, 6.4rem);
  font-weight: 700;
  letter-spacing: -0.06em;
  line-height: 0.9;
  text-shadow: 0 10px 0 rgb(0 0 0 / 15%);
}

.mr-date-strip,
.mr-time-strip {
  display: inline-block;
  background: var(--mr-white);
  color: var(--mr-black);
  font-weight: 800;
  letter-spacing: -0.055em;
  line-height: 0.98;
}

.mr-date-strip {
  margin-top: 28px;
  padding: 0.26em 0.42em 0.32em;
  font-size: clamp(1.25rem, 3vw, 2.35rem);
  box-shadow: var(--mr-shadow-hard);
  letter-spacing: -0.035em;
}

.mr-event-location {
  max-width: 620px;
  margin: 28px 0 0;
  color: var(--mr-white);
  font-size: clamp(1.05rem, 2vw, 1.45rem);
  font-weight: 800;
}

.mr-intro-copy {
  max-width: 680px;
  margin: 18px 0 0;
  color: rgb(255 255 255 / 90%);
  font-size: 1.05rem;
  font-weight: 650;
  line-height: 1.5;
}

.mr-hero-actions {
  margin-top: 26px;
}

.mr-button-primary .wp-block-button__link,
.mr-button-secondary .wp-block-button__link,
.mr-social-button .wp-block-button__link {
  border-radius: 0;
  box-shadow: 7px 7px 0 rgb(0 0 0 / 20%);
  font-weight: 800;
  text-transform: uppercase;
}

.mr-button-primary .wp-block-button__link,
.mr-social-button .wp-block-button__link {
  background: var(--mr-red);
  color: var(--mr-white);
}

.mr-button-secondary .wp-block-button__link {
  background: var(--mr-white);
  color: var(--mr-black);
}

.mr-hero-post-query {
  position: relative;
  z-index: 1;
  min-height: auto;
}

.mr-hero-post-card {
  position: relative;
  z-index: 1;
  width: min(430px, 100%);
  margin-left: auto;
  padding: clamp(18px, 3vw, 26px);
  background: var(--mr-white);
  color: var(--mr-black);
  box-shadow: var(--mr-shadow-hard);
  transform: rotate(1deg);
}

.mr-hero-post-card::before {
  content: "AKTUELL";
  position: absolute;
  top: -18px;
  left: -18px;
  z-index: 2;
  padding: 8px 14px;
  background: var(--mr-red);
  color: var(--mr-white);
  font-size: 1.05rem;
  font-weight: 800;
  transform: rotate(-5deg);
  box-shadow: 6px 6px 0 rgb(0 0 0 / 20%);
}

.mr-kicker {
  margin: 0 0 14px;
  color: var(--mr-red);
  font-size: 0.86rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.mr-hero-post-image img {
  width: 100%;
  aspect-ratio: 16 / 11;
  object-fit: cover;
}

.mr-hero-post-title {
  margin: 16px 0 10px;
  color: var(--mr-black);
  font-size: clamp(1.55rem, 3vw, 2.35rem);
  font-weight: 900;
  letter-spacing: -0.055em;
  line-height: 0.98;
}

.mr-hero-post-title a,
.mr-program-post-title a {
  color: inherit;
  text-decoration: none;
}

.mr-hero-post-card .wp-block-post-excerpt {
  margin: 0;
}

.mr-hero-post-card .wp-block-post-excerpt__excerpt {
  color: var(--mr-black);
  font-weight: 650;
  line-height: 1.45;
}

.mr-post-terms {
  margin-top: 14px;
  font-size: 0.82rem;
  font-weight: 900;
  text-transform: uppercase;
}

.mr-post-terms a {
  color: var(--mr-red);
  text-decoration: none;
}

.mr-empty-posts {
  padding: 24px;
  background: var(--mr-white);
  color: var(--mr-black);
  font-weight: 800;
}

.mr-ticker {
  position: relative;
  z-index: 3;
  margin-top: -30px;
  overflow: hidden;
  background: var(--mr-white);
  color: var(--mr-black);
  transform: rotate(-2.2deg);
  box-shadow: 0 16px 28px rgb(0 0 0 / 22%);
}

.mr-ticker p {
  margin: 0;
  padding: 12px 0;
  font-size: clamp(1.25rem, 3.2vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  white-space: nowrap;
  text-align: center;
}

.mr-statement {
  padding-block: 66px 30px;
  background: var(--mr-green);
  color: var(--mr-white);
}

.mr-statement-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.72fr) minmax(300px, 1.28fr);
  gap: 26px;
  align-items: stretch;
}

.mr-statement-label,
.mr-statement-copy,
.mr-day-card,
.mr-news-card,
.mr-verein-card,
.mr-timeline,
.mr-card {
  box-shadow: var(--mr-shadow-hard);
}

.mr-statement-label {
  min-height: 210px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--mr-red);
  transform: rotate(-1.5deg);
}

.mr-statement-label span {
  color: var(--mr-white);
  font-size: clamp(2.7rem, 7vw, 6rem);
  font-weight: 800;
  letter-spacing: -0.06em;
  line-height: 0.9;
}

.mr-statement-copy {
  padding: 28px;
  background: var(--mr-white);
  color: var(--mr-black);
}

.mr-statement-copy h2,
.mr-section-title h2,
.mr-verein-card h2,
.mr-timeline h2,
.mr-page-content h1 {
  margin: 0;
  color: inherit;
  font-family: Poppins, system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.065em;
  line-height: 0.92;
}

.mr-statement-copy h2 {
  margin-bottom: 14px;
  font-size: clamp(2rem, 5vw, 4.6rem);
}

.mr-statement-copy p {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 650;
  line-height: 1.55;
}

.mr-program {
  padding-block: 82px 70px;
  color: var(--mr-white);
}

.mr-section-title-inverted {
  color: var(--mr-white);
}

.mr-section-title-inverted p {
  color: rgb(255 255 255 / 86%);
}

.mr-program-post-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.mr-program-post-card {
  height: 100%;
  padding: 18px 18px 22px;
  background: var(--mr-white);
  color: var(--mr-black);
  box-shadow: var(--mr-shadow-hard);
}

.mr-program-post-image img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.mr-program-post-title {
  margin: 14px 0 10px;
  color: var(--mr-black);
  font-size: clamp(1.45rem, 3vw, 2.35rem);
  font-weight: 900;
  letter-spacing: -0.055em;
  line-height: 1;
}

.mr-program-post-card .wp-block-post-excerpt__excerpt {
  color: var(--mr-black);
  font-weight: 650;
}

.mr-archive-actions {
  margin-top: clamp(30px, 5vw, 48px);
}

.mr-program-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 22px;
  align-items: stretch;
}

.mr-day-card {
  position: relative;
  min-height: 360px;
  padding: clamp(22px, 4vw, 34px);
  background: rgb(3 77 2 / 94%);
  color: var(--mr-white);
  overflow: hidden;
}

.mr-day-card-saturday {
  grid-column: span 5;
}

.mr-day-card-sunday {
  grid-column: span 7;
  background: rgb(8 102 7 / 96%);
}

.mr-day-card-special {
  grid-column: 4 / -1;
  min-height: 310px;
  margin-top: 8px;
  background: var(--mr-red);
}

.mr-day-badge,
.mr-new-badge {
  display: inline-block;
  margin: 0 0 18px;
  padding: 0.08em 0.34em 0.14em;
  background: var(--mr-red);
  color: var(--mr-white);
  font-size: clamp(2.5rem, 6vw, 5.8rem);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.05em;
}

.mr-new-badge {
  background: var(--mr-green);
}

.mr-time-strip {
  margin: 0 0 24px;
  padding: 0.08em 0.28em 0.14em;
  font-size: clamp(1.9rem, 4vw, 3.8rem);
  font-weight: 700;
  line-height: 1;
}

.mr-day-card h3 {
  margin: 0 0 14px;
  color: var(--mr-white);
  font-family: Poppins, system-ui, sans-serif;
  font-size: clamp(2rem, 4vw, 4rem);
  font-weight: 800;
  letter-spacing: -0.05em;
  line-height: 0.94;
}

.mr-day-card p:not(.mr-day-badge):not(.mr-new-badge):not(.mr-time-strip) {
  max-width: 650px;
  margin: 0;
  color: var(--mr-white);
  font-size: clamp(1rem, 1.5vw, 1.18rem);
  font-weight: 650;
}

.mr-section {
  padding-block: 82px;
  background: var(--mr-white);
}

.mr-section-title {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 420px);
  gap: 28px;
  align-items: end;
  margin-bottom: 28px;
  color: var(--mr-black);
}

.mr-section-title h2 {
  font-size: clamp(3rem, 8vw, 7rem);
}

.mr-section-title p {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 650;
}

.mr-loop-list {
  display: grid;
  gap: 16px;
}

.mr-card,
.mr-post-card {
  background: var(--mr-white);
  border-radius: 0;
}

.mr-archive .mr-card,
.mr-archive .mr-post-card,
.mr-archive .wp-block-post-template>li,
.mr-archive .wp-block-post {
  background: transparent;
  box-shadow: none;
}

.mr-archive .mr-card {
  padding: 0 !important;
}

.mr-archive .mr-loop-list {
  gap: clamp(28px, 5vw, 48px);
}

.mr-archive .mr-post-row {
  padding-bottom: clamp(28px, 5vw, 48px);
}

.mr-post-row {
  display: grid;
  grid-template-columns: 138px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.mr-post-thumb {
  margin: 0;
}

.mr-post-thumb img {
  width: 138px;
  height: 118px;
  object-fit: cover;
  object-position: top center;
  box-shadow: none;
}

.wp-block-post-terms a,
.mr-label {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  margin-right: 8px;
  margin-bottom: 8px;
  padding: 7px 14px;
  background: var(--mr-red);
  color: var(--mr-white);
  font-size: 0.8rem;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
}

.wp-block-post-terms {
  font-size: 0;
}

.mr-post-content .wp-block-post-title {
  margin: 8px 0;
}

.mr-post-content .wp-block-post-title a {
  color: var(--mr-black);
  font-family: Poppins, system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.035em;
  text-decoration: none;
}

.mr-post-content .wp-block-post-excerpt,
.mr-post-content .wp-block-post-excerpt__excerpt {
  color: var(--mr-black);
  font-weight: 600;
}

.mr-meta {
  color: var(--mr-black);
  font-size: 0.88rem;
  font-weight: 700;
}

.mr-verein {
  padding-block: 82px;
  background: var(--mr-green-dark);
  color: var(--mr-white);
  margin-block-end: 0;
}

.mr-verein-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1.05fr);
  gap: 24px;
  align-items: stretch;
}

.mr-verein-card {
  background: var(--mr-white);
  color: var(--mr-black);
  overflow: hidden;
}

.mr-verein-card img {
  width: 100%;
  aspect-ratio: 16 / 11;
  object-fit: cover;
}

.mr-verein-card-body {
  padding: 24px;
}

.mr-verein-card h2,
.mr-timeline h2 {
  margin-bottom: 14px;
  font-size: clamp(2.4rem, 6vw, 5.8rem);
}

.mr-verein-card p {
  margin: 0;
  font-weight: 650;
  line-height: 1.55;
}

.mr-timeline {
  padding: 24px;
  background: var(--mr-red);
  color: var(--mr-white);
}

.mr-timeline-list {
  display: grid;
  gap: 10px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.mr-timeline-list li {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 14px;
  align-items: baseline;
  padding: 10px 0;
  font-weight: 700;
}

.mr-timeline-list strong {
  display: inline-block;
  background: var(--mr-white);
  color: var(--mr-black);
  padding: 2px 8px;
  font-size: 1.15rem;
  line-height: 1.2;
}

.mr-page,
.mr-single,
.mr-archive {
  background: var(--mr-white);
}

:where(.wp-site-blocks)>.mr-page,
:where(.wp-site-blocks)>.mr-single,
.mr-page>.mr-single-hero-image,
.mr-single>.mr-single-hero-image {
  margin-block-start: 0 !important;
}

.mr-archive {
  padding-block: 70px;
}

.mr-page-content {
  max-width: 920px;
  margin-inline: auto;
  padding-block: clamp(34px, 6vw, 76px);
  background: var(--mr-white);
}

.mr-single-hero-image {
  margin: 0;
  width: 100%;
}

.mr-single-hero-image img {
  width: 100%;
  height: clamp(220px, 32vw, 420px);
  object-fit: cover;
  object-position: center;
}

.mr-single-content {
  max-width: 920px;
  margin-inline: auto;
  padding-block: clamp(34px, 6vw, 76px);
}

.mr-page-content h1 {
  max-width: 820px;
  margin-bottom: 18px;
  color: var(--mr-black);
  font-size: clamp(2.15rem, 4.2vw, 3.9rem);
  letter-spacing: -0.045em;
  line-height: 1;
}

.mr-single-content h1 {
  max-width: 820px;
  margin-bottom: 18px;
  color: var(--mr-black);
  font-size: clamp(2.15rem, 4.2vw, 3.9rem);
  letter-spacing: -0.045em;
  line-height: 1;
}

.mr-single-content .wp-block-post-terms {
  margin-bottom: 14px;
}

.mr-page-content .wp-block-post-featured-image img {
  width: 100%;
  box-shadow: none;
}

.mr-page-content .wp-block-post-content,
.mr-single-content .wp-block-post-content {
  color: var(--mr-black);
  font-weight: 600;
}

.mr-page-content .wp-block-post-content>*,
.mr-single-content .wp-block-post-content>* {
  max-width: 820px;
}

.mr-page-content .wp-block-post-content>.alignwide,
.mr-page-content .wp-block-post-content>.alignfull,
.mr-single-content .wp-block-post-content>.alignwide,
.mr-single-content .wp-block-post-content>.alignfull {
  max-width: none;
}

.mr-footer {
  margin-block-start: 0;
  padding-block: 28px;
  background: var(--mr-red);
  color: var(--mr-white);
}

:where(.wp-site-blocks)>.mr-footer,
:where(.wp-site-blocks)>footer.mr-footer {
  margin-block-start: 0;
}

.mr-footer-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  padding-bottom: 18px;
}

.mr-footer-menu {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mr-copyright {
  font-size: 0.82rem;
  font-weight: 650;
}

blockquote {
  background: var(--mr-white);
  padding: 24px;
  margin: 28px 0;
  color: var(--mr-black);
  font-weight: 700;
}

@media (max-width: 980px) {
  .mr-nav {
    min-height: 62px;
    align-items: center;
    gap: 10px;
    flex-wrap: nowrap !important;
    padding-block: 6px;
  }

  .mr-brand {
    min-width: 0;
    flex: 1 1 auto;
    gap: 9px;
  }

  .mr-brand .wp-block-image {
    flex: 0 0 auto;
    margin: 0;
  }

  .mr-brand img {
    width: 44px;
    height: 44px;
  }

  .mr-brand .wp-block-site-title {
    min-width: 0;
  }

  .mr-brand .wp-block-site-title a {
    display: block;
    max-width: min(58vw, 430px);
    overflow: hidden;
    font-size: clamp(0.72rem, 2vw, 0.9rem);
    line-height: 1.08;
    text-overflow: ellipsis;
  }

  .mr-menu {
    width: auto;
    flex: 0 0 auto;
    justify-content: flex-end;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open {
    padding: 22px;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
    align-items: stretch;
    padding-top: 54px;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item,
  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
    width: 100%;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content {
    padding: 16px 0;
    color: var(--mr-white);
    font-size: 1.45rem;
    line-height: 1;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container {
    min-width: 0;
    padding: 0 0 10px 18px;
    background: transparent;
    box-shadow: none;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
    padding: 10px 0;
    color: var(--mr-white);
    font-size: 1rem;
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-icon {
    color: var(--mr-white);
  }

  .mr-menu .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container {
    width: 100%;
  }

  .mr-festival-hero-inner,
  .mr-statement-grid,
  .mr-program-grid,
  .mr-program-post-grid,
  .mr-section-title,
  .mr-verein-grid {
    grid-template-columns: 1fr;
  }

  .mr-festival-hero,
  .mr-festival-hero-inner {
    min-height: auto;
  }

  .mr-hero-post-card {
    width: 100%;
    margin-left: 0;
    transform: rotate(0);
  }

  .mr-day-card-saturday,
  .mr-day-card-sunday,
  .mr-day-card-special {
    grid-column: auto;
  }

  .mr-footer-grid {
    grid-template-columns: 1fr;
  }

  .mr-footer-menu {
    justify-content: flex-start;
  }
}

@media (max-width: 620px) {
  .mr-shell {
    padding-inline: 11px;
  }

  .mr-nav {
    min-height: 54px;
    padding-block: 5px;
  }

  .mr-nav ul li a {
    color: var(--mr-black) !important;
    text-align: center !important;
    display: block !important;
  }

  .mr-nav ul {
    width: 100% !important;
  }

  .mr-brand img {
    width: 38px;
    height: 38px;
  }

  .mr-brand .wp-block-site-title a {
    max-width: 64vw;
    font-size: 0.68rem;
    line-height: 1.05;
  }

  .mr-menu .wp-block-navigation__responsive-container-open {
    width: 38px;
    height: 38px;
  }

  .mr-festival-hero-inner {
    padding-block: 34px 66px;
  }

  .mr-festival-title {
    max-width: 100%;
    font-size: clamp(3.05rem, 14vw, 4.1rem);
    letter-spacing: -0.08em;
    line-height: 0.92;
  }

  .mr-date-strip {
    max-width: 100%;
    font-size: clamp(2rem, 11vw, 3.1rem);
    white-space: normal;
  }

  .mr-ticker p {
    text-align: left;
    padding-left: 18px;
  }

  .mr-statement-label {
    min-height: 150px;
  }

  .mr-post-row,
  .mr-timeline-list li {
    grid-template-columns: 1fr;
  }

  .mr-post-thumb img {
    width: 100%;
    height: auto;
    aspect-ratio: 16 / 10;
  }
}

footer.wp-block-template-part {
  margin-top: 0;
}