:root {
  --bg: #000;
  --gold: #d19a4c;
  --gold-soft: #d9a34c;
  --text: #ecd6b0;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

img {display: block;}

body {
  background: #000;
  color: var(--text);
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
}

ul {
    list-style-type: none;
    padding-left: 0px !important;
}

.section-place .copy, .contact {color: #fff;}

.page {
  width: min(1366px, 100%);
  margin: 0 auto;
}

.hero {
  position: relative;
  border: 1px solid #1b1b1b;
  margin-bottom: 16px;
}

.hero img {
  display: block;
  width: 100%;
  height: auto;
}

.section {
  margin-top: 18px;
  border: 1px solid #1b1b1b;
  background: #000;
}

.section-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 470px;
}

.section-head h2 {
  margin: 0;
  padding: 18px 24px;
  color: #050505;
  background: linear-gradient(
    90deg, 
    #c68a39 0%,    /* Dunkleres Gold links */
    #d49c4d 30%,   /* Mittleres Gold */
    #b97b2d 65%,   /* Schattenbereich */
    #a86e26 100%   /* Dunklerer Abschluss rechts */
  );
  font-size: clamp(1.45rem, 2.35vw, 2.35rem);
  font-weight: 400;
  letter-spacing: 0.01em;
}

.head-logos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  background: #000;
  padding: 0 8px;
  align-items: center;
}

.head-logos img {
  width: 100%;
  height: 100px;
  object-fit: contain;
  border-right: 7px solid #d19a4c;
}

.cols-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  padding: 28px 26px 30px;
}

.card img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
}

.card p {
  margin: 14px 0 0;
  color: var(--gold-soft);
  text-align: center;
  font-size: clamp(1.1rem, 1.6vw, 1.2rem);
  line-height: 1.28;
}

.card p strong {
  font-weight: 800;
}

.place-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 24px;
  padding: 26px 26px 30px;
}

.copy p {
  margin: 0 0 16px;
  font-size: clamp(1.1rem, 1.8vw, 1.18rem);
  line-height: 1.34;
}

.accent {
  color: var(--gold-soft);
  font-weight: 700;
  font-style: italic;
}

.stack {
  display: grid;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.stack img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.program-grid {
  display: grid;
  grid-template-columns: 1.02fr 1fr;
  gap: 24px;
  padding: 26px;
}

.copy h3 {
  margin: 0 0 10px;
  color: var(--gold-soft);
  font-size: clamp(1.25rem, 2.2vw, 1.85rem);
  font-style: italic;
}

.program-images {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-auto-rows: auto;
}

.program-images img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.program-images img:first-child {
  grid-column: span 1;
  grid-row: span 1;
}

.program-images img:nth-child(2) {
  grid-column: span 2;
  grid-row: span 1;
}

.program-night {
  display: grid;
  grid-template-columns: 1fr 0.9fr;
  gap: 24px;
  padding: 26px;
}

.program-night img {
  width: 100%;
  height: auto;
}

ul {
  margin: 8px 0 0;
  padding-left: 20px;
}

li {
  margin: 4px 0;
  font-size: clamp(1rem, 1.8vw, 1.1rem);
}

.charity-grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 24px;
  padding: 26px;
}

.charity-grid .copy img {
  margin-top: 10px;
  width: 100%;
  max-width: 460px;
}

.charity-side .three {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.charity-side .three img {
  width: 100%;
  aspect-ratio: 2 / 3;
  object-fit: cover;
}

blockquote {
  margin: 18px 0 0;
  color: #da373c;
  font-family: "Lucida Handwriting Std", sans-serif;
  font-weight: 600;
  letter-spacing: 1px;
  font-size: clamp(1.5rem, 2.8vw, 2.4rem);
  text-align: center;
  font-style: italic;
  line-height: 1.8;
}

.kinder {
  display: block;
  margin: 14px auto 0;
  width: 220px;
}

.contact {
  text-align: center;
  padding: 28px 18px 32px;
}

.contact > img {
  width: 210px;
  margin: 0 auto 14px;
}

.contact p {
  margin: 10px 0 0;
  font-size: clamp(1rem, 1.9vw, 1.08rem);
  letter-spacing: 0.14em;
}

.mttc-badge img {
  width: 90px;
  margin: 20px auto 0;
}

small {
  display: block;
  margin: 24px auto 0;
  max-width: 1200px;
  font-size: 0.82rem;
  line-height: 1.35;
  opacity: 0.95;
  font-style: italic;
}

.section-place .copy p strong {
  color: var(--gold-soft);
}

.section-program-day .copy p,
.section-program-night .copy p,
.section-program-night li,
.section-contact .contact p {
  letter-spacing: 0.12em;
}

.section-program-day .copy h3,
.section-program-night .copy h3 {
  letter-spacing: 0.01em;
}

.section-charity .copy p {
  text-align: center;
  font-size: clamp(1.1rem, 2.1vw, 1.5rem);
}

.section-charity .copy p strong {
  color: var(--gold-soft);
}

.section-contact .contact > img {
  width: 250px;
}

.section-contact .contact p:nth-child(2),
.section-contact .contact p:nth-child(3) {
  letter-spacing: 0.18em;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Versteckt die Logos auf Geräten mit einer Breite bis 768px */
@media (max-width: 768px) {
    .head-logos {
        display: none;
    }
}


@media (max-width: 1100px) {
  .section-head {
    grid-template-columns: 1fr;
  }

  .head-logos {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 6px;
  }
}

@media (max-width: 900px) {
  .cols-2,
  .place-grid,
  .program-night,
  .charity-grid {
    grid-template-columns: 1fr;
  }
  
  .program-grid {grid-template-columns: 1fr 1fr;}

  .program-images {
    grid-template-columns: 1fr 1fr;
  }

  .program-images img:nth-child(2) {
    grid-column: span 1;
  }
}

@media (max-width: 620px) {
  .page {
    width: 100%;
  }

  .section-head h2 {
    padding: 12px 14px;
  }

  .cols-2,
  .place-grid,
  .program-night,
  .charity-grid {
    padding: 14px;
    gap: 14px;
  }
  
  .program-grid .program-images {
    grid-template-columns: 1fr;
  }

  .program-images {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .charity-side .three {
    grid-template-columns: 1fr;
  }
  
  img.mobile-hide { display: none !important; }
}

@media (min-width: 1200px) {
  .page {
    width: 1366px;
  }

  .hero {
    margin-bottom: 14px;
    border-color: #242424;
  }

  .section {
    margin-top: 14px;
  }

  .section-head {
    grid-template-columns: 1fr 438px;
  }

  .section-head h2 {
    min-height: 100px;
    padding: 28px 30px;
    font-size: 34px;
    line-height: 1;
    letter-spacing: 0;
  }

  .head-logos {
    padding: 0 10px;
    gap: 10px;
  }

  .head-logos img {
    height: 103px;
  }

  .section-intro .cols-2 {
    min-height: 620px;
    padding: 60px 70px 52px;
    gap: 70px;
    align-items: start;
  }

  .section-intro .card img {
    aspect-ratio: 16 / 10;
  }

  .section-intro .card p {
    margin-top: 16px;
    font-size: 20px;
    line-height: 1.34;
    letter-spacing: 0.01em;
  }

  .section-place .place-grid {
    min-height: 642px;
    grid-template-columns: 1fr 345px;
    padding: 34px 54px 28px;
    gap: 30px;
  }

  .section-place .copy p {
    font-size: 20px;
    line-height: 1.35;
    margin-bottom: 16px;
    max-width: 610px;
  }

  .section-place .stack {
    gap: 14px;
  }

  .section-place .stack img {
    height: 205px;
  }

  .section-program-day .program-grid {
    min-height: 425px;
    grid-template-columns: 0.98fr 1.02fr;
    padding: 30px 36px 26px;
    gap: 30px;
  }
  
  .threei {grid-template-columns: repeat(4, minmax(0, 1fr));}
  .threei img {max-height: 230px;}
  

  .section-program-day .copy h3 {
    font-size: 20px;
    margin-bottom: 8px;
  }

  .section-program-day .copy p {
    font-size: 20px;
    margin-bottom: 8px;
  }

  .section-program-day .copy .accent {
    margin-top: 8px;
  }

  .section-program-day .program-images {
    grid-auto-rows: auto;
    gap: 10px;
  }

  .section-program-night .program-night {
    min-height: 642px;
    grid-template-columns: 1fr 455px;
    gap: 38px;
    padding: 34px 48px 30px;
    align-items: start;
  }

  .section-program-night .copy h3 {
    font-size: 20px;
    margin-bottom: 8px;
  }

  .section-program-night .copy p {
    font-size: 20px;
    margin-bottom: 12px;
  }

  .section-program-night li {
    font-size: 18px;
    margin: 7px 0;
    letter-spacing: 0.09em;
  }

  .section-program-night ul {
    margin-top: 6px;
  }

  .section-program-night > .program-night > img {
    margin-top: 18px;
  }

  .section-charity .charity-grid {
    min-height: 448px;
    grid-template-columns: 0.86fr 1.14fr;
    padding: 24px 34px 26px;
    gap: 24px;
  }

  .section-charity .copy p {
    font-size: 20px;
    line-height: 1.34;
    margin-bottom: 16px;
  }

  .section-charity .copy img {
    max-width: 435px;
    margin: 12px auto 0;
  }

  .section-charity .charity-side .three img {
    aspect-ratio: 0.66 / 1;
  }

  .section-charity blockquote {
    font-size: 24px;
    margin: 10px 0 0;
    line-height: 1.4;
  }

  .section-charity .kinder {
    width: 180px;
    margin-top: 10px;
  }

  .section-contact .contact {
    min-height: 645px;
    padding-top: 26px;
  }

  .section-contact .contact > img {
    width: 220px;
    margin-bottom: 20px;
  }

  .section-contact .contact p {
    font-size: 18px;
    margin: 8px 0;
  }

  .section-contact .mttc-badge img {
    width: 92px;
    margin-top: 8px;
  }

  .section-contact small {
    margin-top: 26px;
    font-size: 12px;
    line-height: 1.35;
    max-width: 1230px;
  }
}

.mttc-badge {
  display: flex;
  align-items: center;
  gap: 0;
  max-width: 500px;
  margin: auto;
}