:root {
  --font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --max-width: 70rem;
  --content-width: min(calc(100% - 2rem), var(--max-width));
  --full-bleed-offset: calc(50% - 50vw);

  --color-primary: #9b1b9e;
  /*--color-primary: #972680 */
  --color-accent: #ffc000;
  /*--color-accent: #ffdb15 */
  
  --color-text: #222;
  --color-surface: #fff;
  --color-submenu-hover: #f4eef4;
  --color-nav-hover: rgba(255, 255, 255, 0.15);

  --space-xs: 0.25rem;
  --space-sm: 0.75rem;
  --space-md: 1rem;
  --space-lg: 0.5rem;
  --space-xl: 2rem;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-family: var(--font);
  line-height: 1.6;
  color: var(--color-text);
}

body {
  margin: 0;
}

button {
  font: inherit;
}

a {
  color: inherit;
}

a[href^="mailto:"],
a[href^="tel:"],
a[href^="http"] {
  text-decoration: none;
}


.skip-link {
  position: absolute;
  left: var(--space-md);
  top: var(--space-md);
  transform: translateY(-200%);
  background: var(--color-surface);
  color: var(--color-primary);
  padding: 0.5rem var(--space-sm);
  z-index: 100;
}

.skip-link:focus {
  transform: translateY(0);
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.site-header,
.page-content {
  width: var(--content-width);
  margin-inline: auto;
}

.site-header {
  margin-top: 0;
}

.header-frame,
.main-nav {
  width: 100vw;
  margin-left: var(--full-bleed-offset);
}

.header-frame {
  position: relative;
  border-bottom: 1px solid var(--color-text);
}

.header-image {
  display: block;
  width: 100%;
}

.header-image {
  height: clamp(14rem, 34vw, 25rem);
  object-fit: cover;
  object-position: center 38%;
}

.header-logo-box {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 0.8rem;
  left: 0;
  bottom: calc(var(--space-xl) + 4rem);
  /* width: min(34rem, calc(100% - 2rem)); */
  width: min(36rem, calc(100% - 2rem));
  min-height: 3.7rem;
  max-height: 5.5rem;
  padding: 0.35rem 1rem 0.35rem 0.5rem;
  background: var(--color-accent);
}

.header-logo-box img {
  display: block;
  flex: 0 0 min(9.2rem, 32vw);
  width: min(9.2rem, 32vw);
}

.header-logo-title {
  color: var(--color-primary);
  font-size: clamp(2rem, 2.05vw, 1.5rem);
  font-weight: 400;
  line-height: 1.12;
}

.menu-toggle,
.submenu-toggle {
  display: none;
}

.main-nav {
  background: var(--color-primary);
}

.main-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  /* padding: 0.5rem 0; */
}

.main-nav ul + li {
  padding: 0.5rem;
}

.main-nav > ul {
  display: flex;
}

.main-nav > ul {
  justify-content: center;
  gap: calc(var(--space-xl) * 2);
}

.nav-item {
  display: flex;
  position: relative;
}

.main-nav a {
  display: block;
  /* padding: var(--space-md) var(--space-lg); */
  /* padding: calc(var(--space-md)-0.1rem) var(--space-lg); */
  padding: 0.5rem var(--space-lg);

  font-weight: 700;
}

.main-nav a {
  color: var(--color-surface);
  text-decoration: none;
}

.main-nav > ul > .nav-item > a {
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
}

.main-nav a:hover,
.main-nav a:focus,
.submenu-toggle:hover,
.submenu-toggle:focus {
  background: var(--color-nav-hover);
}

.main-nav a:focus-visible,
.submenu-toggle:focus-visible,
.menu-toggle:focus-visible {
  outline: 2px solid var(--color-surface);
  outline-offset: 2px;
}

.submenu-toggle {
  padding: var(--space-md) var(--space-lg);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border: 0;
  background: transparent;
  color: var(--color-accent);
  cursor: pointer;
}

.submenu-toggle::after {
  content: "";
  display: block;
  width: 0.55rem;
  height: 0.55rem;
  border-right: 0.15rem solid currentColor;
  border-bottom: 0.15rem solid currentColor;
  transform: rotate(45deg);
}

.submenu-toggle[aria-expanded="true"]::after {
  transform: translateY(0.2rem) rotate(225deg);
}

.submenu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 16rem;
  background: var(--color-surface);
  box-shadow: 0 0.5rem var(--space-md) rgba(0, 0, 0, 0.15);
  z-index: 10;
}

.nav-item:hover .submenu,
.nav-item:focus-within .submenu,
.submenu-toggle[aria-expanded="true"] + .submenu {
  display: block;
}

.submenu a {
  color: var(--color-text);
  font-weight: 500;
}

.submenu a:hover,
.submenu a:focus {
  background: var(--color-submenu-hover);
  color: var(--color-primary);
}

.page-content {
  padding-block: 3rem;
}

.page-content h1 {
  color: var(--color-primary);
  line-height: 1.2;
}

.lead {
  font-size: 1.25rem;
  font-weight: 600;
}

.event-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-lg);
  margin-block: var(--space-lg) var(--space-xl);
}

.event-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(155, 27, 158, 0.22);
  border-radius: 0.5rem;
  background: var(--color-surface);
  box-shadow: 0 0.75rem 1.5rem rgba(34, 34, 34, 0.08);
  border-bottom: 0.35rem solid var(--color-accent);
}

.event-card img {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4.2;
  object-fit: cover;
  background: var(--color-submenu-hover);
}

.event-card-content {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: var(--space-md);
  border-top: 0.35rem solid var(--color-accent);
  border-bottom: 0.15rem solid var(--color-accent);
}

.event-card h3 {
  margin-block: 0 var(--space-sm);
  /* color: var(--color-primary); */
  font-size: 1.05rem;
  line-height: 1.3;
}

.event-card p {
  margin-block: 0 var(--space-sm);
}

.event-card p:last-child {
  margin-bottom: 0;
}

.back-link {
  margin-block: var(--space-xl) 0;
}

.back-link a {
  color: var(--color-text);
  font-weight: 400;
  text-decoration: none;
  text-underline-offset: 0.2em;
}

.structure-section {
  margin-top: var(--space-xl);
}

.structure-section h2 {
  color: var(--color-primary);
  line-height: 1.3;
}

.org-chart {
  --org-arrow-length: 2.6rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(14rem, 0.8fr) minmax(0, 1fr);
  column-gap: calc(var(--space-xl) + var(--space-sm));
  row-gap: var(--space-md);
  align-items: center;
  margin-block: var(--space-lg) var(--space-xl);
  margin: 3rem 4rem;
}

.org-list {
  display: grid;
  gap: var(--space-md);
  margin: 0;
  padding: 0;
  list-style: none;
}

.org-list li,
.org-node {
  position: relative;
  padding: calc(var(--space-md) + 0.4rem) var(--space-md);
  min-height: 5.5rem;
  border: 1px solid rgba(155, 27, 158, 0.24);
  background: var(--color-surface);
  box-shadow: 0 0.45rem 1rem rgba(34, 34, 34, 0.06);
}

.org-list li {
  background: var(--color-primary);
  /* color: var(--color-accent); */
  text-align: center;
  color: white;
}

.org-list li::after {
  content: "";
  position: absolute;
  top: 50%;
  width: var(--org-arrow-length);
  height: 0.8rem;
  background: var(--color-accent);
  clip-path: polygon(0 50%, 24% 0, 24% 35%, 100% 35%, 100% 65%, 24% 65%, 24% 100%);
  pointer-events: none;
  transform: translateY(-50%);
  z-index: 1;
}

.org-list-left li::after {
  right: calc(-1 * var(--org-arrow-length));
  transform-origin: right center;
}

.org-list-right li::after {
  left: calc(-1 * var(--org-arrow-length));
  transform-origin: left center;
}

.org-list-left li:first-child::after,
.org-list-right li:last-child::after {
  transform: translateY(-50%) rotate(24deg);
}

.org-list-left li:last-child::after,
.org-list-right li:first-child::after {
  transform: translateY(-50%) rotate(-24deg);
}

.org-center {
  display: grid;
  gap: var(--space-sm);
  text-align: center;
}

.org-node {
  margin: 0;
  /* color: var(--color-primary); */
  color: white;
  background: var(--color-primary);
  font-weight: 800;
  text-transform: uppercase;
}

/* .org-node-white {
  color: white;
} */

.org-node-primary {
  background: var(--color-primary);
  color: white;
  /* color: var(--color-accent); */
}

.org-relation {
  margin: 0;
  color: var(--color-primary);
}

.org-relation::before,
.org-relation::after {
  content: "";
  display: block;
  margin-inline: auto;
  background: var(--color-accent);
}

.org-relation::before {
  width: 0.15rem;
  height: 1.2rem;
}

.org-relation::after {
  width: 0.9rem;
  height: 1.55rem;
  clip-path: polygon(42% 0, 58% 0, 58% 60%, 100% 60%, 50% 100%, 0 60%, 42% 60%);
}

@media (min-width: 45.01rem) {
  .org-list,
  .org-center {
    display: contents;
  }

  .org-list-left li {
    grid-column: 1;
  }

  .org-list-right li {
    grid-column: 3;
  }

  .org-list li:nth-child(1) {
    grid-row: 1;
  }

  .org-list li:nth-child(2) {
    grid-row: 2;
  }

  .org-list li:nth-child(3) {
    grid-row: 3;
  }

  .org-node-primary {
    grid-column: 2;
    grid-row: 2;
  }

  .org-relation {
    grid-column: 2;
    grid-row: 3;
    margin-top: var(--space-sm);
  }

  .org-center .org-node:not(.org-node-primary) {
    grid-column: 2;
    grid-row: 4;
  }
}

.profile-section {
  margin-top: var(--space-xl);
}

.profile-section h2 {
  color: black;
  line-height: 1.3;
}

.profile-section p {
  margin-left: 4rem;
}

.info-list, .recommendation-list {
  display: grid;
  gap: var(0.4);
  margin-block: var(--space-lg) var(--space-xl);
  padding-left: 4rem;
}

.recommendation-list {
  padding-left: 0rem;
}

.info-list div, .recommendation-list div {
  display: grid;
  grid-template-columns: minmax(10rem, 0.35fr) minmax(0, 1fr);
  gap: var(--space-sm);
  padding-block: var(--space-sm);
  border-bottom: 1px solid rgba(155, 27, 158, 0.2);
}

.info-list dt, .recommendation-list dt {
  color: black;
  /* font-weight: 800; */
}

.recommendation-list dt {
  font-weight: 800;
}

.info-list dd, .recommendation-list dd {
  margin: 0;
  /* font-weight: 700; */
}

.topic-nav {
  margin-block: var(--space-xl);
}

.topic-nav ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-md);
  margin: 0;
  padding: 0;
  list-style: none;
}

.topic-nav a {
  display: block;
  min-height: 100%;
  padding: var(--space-md);
  border: 1px solid rgba(155, 27, 158, 0.24);
  border-left: 0.35rem solid var(--color-accent);
  color: var(--color-primary);
  font-weight: 800;
  text-decoration: none;
}

.topic-nav a:hover,
.topic-nav a:focus {
  background: var(--color-submenu-hover);
}

.legal-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.4fr);
  gap: var(--space-xl);
  margin-block: var(--space-lg) var(--space-xl);
}

.legal-grid section {
  border-top: 0.35rem solid var(--color-accent);
  padding-top: var(--space-md);
}

.legal-grid h2 {
  margin-block: var(--space-lg) var(--space-xs);
  color: var(--color-primary);
  font-size: 1.1rem;
  line-height: 1.3;
}

.legal-grid h2:first-child {
  margin-top: 0;
}

.legal-grid h3 {
  margin-block: var(--space-md) var(--space-xs);
  font-size: 1rem;
}

.legal-grid p {
  margin-block: 0 var(--space-md);
}

.privacy-page h2,
.privacy-page h3 {
  color: var(--color-primary);
  line-height: 1.3;
}

.privacy-page h2 {
  margin-top: var(--space-xl);
  font-size: 1.25rem;
}

.privacy-page h3 {
  margin-top: var(--space-lg);
  font-size: 1.05rem;
}

.site-footer {
  display: flex;
  justify-content: space-between;
  gap: var(--space-xl);
  padding: var(--space-lg) max(var(--space-md), calc((100vw - var(--max-width)) / 2));
  background: var(--color-accent);
  color: var(--color-text);
}

.site-footer nav {
  /* 
  display: grid;
  gap: var(--space-xs);
  */
  display: inline;
  text-align: right;

}

.site-footer a {
  text-decoration-thickness: 0.08em;
  text-decoration: none;
  text-underline-offset: 0.2em;
}

@media (max-width: 45rem) {
  .menu-toggle {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    width: 100vw;
    margin-left: var(--full-bleed-offset);
    padding: var(--space-md);
    border: 0;
    background: var(--color-primary);
    color: var(--color-accent);
    font-weight: 800;
    text-transform: uppercase;
    cursor: pointer;
  }

  .submenu-toggle {
    display: block;
  }

  .menu-toggle span,
  .menu-toggle span::before,
  .menu-toggle span::after {
    display: block;
    width: 1.5rem;
    height: 0.15rem;
    background: currentColor;
  }

  .menu-toggle span {
    position: relative;
  }

  .menu-toggle span::before,
  .menu-toggle span::after {
    content: "";
    position: absolute;
    left: 0;
  }

  .menu-toggle span::before {
    top: -0.45rem;
  }

  .menu-toggle span::after {
    top: 0.45rem;
  }

  .main-nav > ul {
    flex-direction: column;
    gap: 0;
  }

  .nav-item {
    display: grid;
    grid-template-columns: 1fr auto;
  }

  .submenu {
    grid-column: 1 / -1;
    position: static;
    box-shadow: none;
  }

  .site-footer {
    flex-direction: column;
  }

  .header-logo-box {
    bottom: var(--space-md);
    gap: 0.6rem;
    width: calc(100% - 1rem);
    min-height: 3.6rem;
    padding: 0.35rem 0.75rem 0.35rem 0.45rem;
  }

  .header-logo-box img {
    flex-basis: min(7.4rem, 36vw);
    width: min(7.4rem, 36vw);
  }

  .header-logo-title {
    font-size: clamp(0.88rem, 4vw, 1.2rem);
  }

  .event-grid {
    grid-template-columns: 1fr;
  }

  .legal-grid {
    grid-template-columns: 1fr;
  }

  .org-chart {
    grid-template-columns: 1fr;
    align-items: stretch;
    gap: var(--space-lg);
  }

  .org-list li::after {
    display: none;
  }

  .info-list div {
    grid-template-columns: 1fr;
    gap: var(--space-xs);
  }

  .topic-nav ul {
    grid-template-columns: 1fr;
  }
}

.footer-logo-box {
  /* bottom: var(--space-md);
  gap: 0.6rem;
  width: calc(100% - 1rem);
  min-height: 3.6rem;
  padding: 0.35rem 0.75rem 0.35rem 0.45rem; */
}
.footer-logo-box img {
  display: block;
  /* flex: 0 0 min(9.2rem, 32vw); */
  /* width: min(9.2rem, 32vw); */
  width: min(11rem, 30vw);
  padding: 0;
  margin: 0;
}

.footer-right {
  display: flex;
  /* gap: var(--space-xs); */
  gap: 1em;
  align-items: center;
}

.two-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-xl);
}

h2#europa, h2#christ-sein, h2#konzertcafe, h2#sinn-klang {
  margin-bottom: 0;
}
h2#europa + p, h2#christ-sein + p, h2#konzertcafe + p, h2#sinn-klang + p {
  margin-top: 0;
}

.link-list {
  list-style-type: none;
  padding-left: 0;
}