/* ========================================
   Vereinskalender – Layout & Farben
======================================== */

.kalender {
  max-width: 1040px;
  margin: 0 auto;
  background-color: #282828;
  text-align: left;
}

/* ========================================
   Desktop (ab 768px)
======================================== */
@media (min-width: 768px) {
  .kalender {
    padding-left: 1.1rem;
    padding-right: 1.1rem;
    padding-bottom: 2rem;
  }

  .kalender table {
    margin-left: -0.9rem;
}

  main.container.vereinskalender > h1 {
    margin-left: 0.1rem;
  }
}

.kalender .hinweis,
.kalender .ort {
  margin-left: -0.9rem;
}

/* ========================================
   typografische Regeln
======================================== */

.kalender table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: 1.25rem;
  line-height: 1.6;
  color: #f9f2e8;
  margin-top: 2rem;
}

.kalender td {
  padding: 0.3rem 1rem 0.3rem 0;
  vertical-align: top;
}

.kalender td:first-child {
  font-weight: 600;
  white-space: nowrap;
  width: 10rem;
  padding-left: 0;
}

.kalender .monatsthema {
  display: inline-block;
  margin-top: 0.25rem;
  color: #9cbbf6;
}

.kalender .raw {
  display: inline-block;
  margin-top: 0.25rem;
  color: #e0b060;
  font-style: italic;
}

.kalender .nn {
  color: #ff6666;
  font-weight: 400;
}

.kalender .hinweis,
.kalender .ort {
  margin-top: 2rem;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.6;
  color: #ccc;
}

/* ========================================
   Smartphone (bis 767px)
======================================== */
@media (max-width: 767px) {
  .kalender {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0.3rem;
    padding-right: 0.8rem;
    font-size: 0.8rem;
  }

  .kalender table {
    table-layout: auto;
    word-break: break-word;
    font-size: 0.8rem;
    margin-right: -0.5rem;
    width: 100% !important;
  }

  main.container.vereinskalender > h1 {
    font-size: 1.6rem;
    font-weight: 600;
    margin-top: -0.3rem;
    margin-left: 0.5rem;
    margin-bottom: 0.5rem;
    text-align: left;
  }

  .kalender td {
    padding-right: 0.5rem;
    vertical-align: top;
  }

  .kalender td:nth-child(1) {
    max-width: 4rem;
    white-space: nowrap;
    text-align: left;
    padding-right: 0.5rem;
  }

  .kalender td:nth-child(2) {
    display: block;
    width: calc(100vw - 6.8rem);
    margin-left: 1.7rem;
    box-sizing: border-box;
    padding-left: 0.2rem;
    padding-right: 0.2rem;
    word-break: break-word;
  }

  body.vereinskalender main.container {
    max-width: 100% !important;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
  }

  .kalender .hinweis,
  .kalender .ort {
    font-size: 0.8rem;
    line-height: 1.4;
    margin-left: 0.2rem; /* ← NEU: richtet linksbündig aus */
  }
}