/* Veranstaltungskalender – minutentakt.eu */

.va-wrap { max-width: 900px; margin: 2rem auto; padding: 0 1rem; }

.va-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1.5rem; flex-wrap: wrap; gap: 1rem;
}

.va-nav { display: flex; align-items: center; gap: 0.8rem; }

.va-nav-btn {
  background: none; border: 1px solid var(--farbe-grau-mittel, #ccc);
  padding: 0.3rem 0.7rem; border-radius: 3px; cursor: pointer; font-size: 1rem;
}

.va-nav-btn:hover { border-color: var(--farbe-akzent, #c0392b); color: var(--farbe-akzent, #c0392b); }

.va-monat-label { font-weight: 700; font-size: 1.1rem; min-width: 140px; text-align: center; }

.va-filter { display: flex; gap: 0.4rem; flex-wrap: wrap; }

.va-filter-btn {
  padding: 0.3rem 0.8rem; border: 1px solid var(--farbe-grau-mittel, #ccc);
  border-radius: 20px; background: #fff; cursor: pointer; font-size: 0.82rem;
  transition: all 0.15s;
}
.va-filter-btn.aktiv, .va-filter-btn:hover {
  background: var(--farbe-akzent, #c0392b);
  border-color: var(--farbe-akzent, #c0392b); color: #fff;
}

.va-neu-btn {
  padding: 0.5rem 1.2rem; background: var(--farbe-akzent, #c0392b);
  color: #fff; border: none; border-radius: 3px; font-size: 0.95rem;
  font-weight: 600; cursor: pointer; text-decoration: none; display: inline-block;
}

/* Event-Liste */
.va-liste { display: flex; flex-direction: column; gap: 0.8rem; }

.va-event {
  display: grid; grid-template-columns: 80px 1fr;
  border: 1px solid var(--farbe-grau-mittel, #ddd); border-radius: 4px;
  overflow: hidden; background: #fff;
}

.va-datum {
  background: var(--farbe-akzent, #c0392b); color: #fff;
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 0.8rem 0.5rem; text-align: center;
}

.va-datum-tag { font-size: 1.8rem; font-weight: 700; line-height: 1; }
.va-datum-mon { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; }

.va-inhalt { padding: 0.8rem 1rem; }

.va-kategorie {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.05em;
  font-weight: 700; color: var(--farbe-akzent, #c0392b); margin-bottom: 0.2rem;
}

.va-titel { font-size: 1rem; font-weight: 600; margin: 0 0 0.3rem 0; }

.va-meta { font-size: 0.82rem; color: #777; display: flex; flex-wrap: wrap; gap: 0.6rem; }

.va-beschreibung { font-size: 0.85rem; color: #555; margin-top: 0.4rem; line-height: 1.5; }

.va-leer { color: #888; font-style: italic; padding: 2rem 0; text-align: center; }

/* Formular */
.va-form-wrap { max-width: 660px; margin: 2rem auto; padding: 0 1rem; }
.va-form .feld-gruppe { margin-bottom: 1.2rem; }
.va-form label {
  display: block; font-size: 0.85rem; font-weight: 600;
  color: var(--farbe-grau-dunkel, #555); margin-bottom: 0.3rem;
  text-transform: uppercase; letter-spacing: 0.05em;
}
.va-form input[type="text"], .va-form input[type="date"],
.va-form input[type="time"], .va-form input[type="url"],
.va-form textarea, .va-form select {
  width: 100%; padding: 0.6rem 0.8rem; border: 1px solid var(--farbe-grau-mittel, #ccc);
  border-radius: 3px; font-size: 1rem; font-family: inherit; box-sizing: border-box;
}
.va-form input:focus, .va-form textarea:focus, .va-form select:focus {
  outline: none; border-color: var(--farbe-akzent, #c0392b);
}
.va-datum-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; }

.va-btn {
  display: inline-block; padding: 0.7rem 1.6rem;
  background: var(--farbe-akzent, #c0392b); color: #fff;
  border: none; border-radius: 3px; font-size: 1rem; font-weight: 600; cursor: pointer;
}
.va-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.va-geo-status { font-size: 0.8rem; margin-top: 0.25rem; min-height: 1.2em; color: #888; }
.va-geo-status.ok { color: #2ecc71; }
.va-geo-status.fehler { color: #e74c3c; }

.va-toast {
  position: fixed; bottom: 2rem; left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: #222; color: #fff; padding: 0.8rem 1.5rem;
  border-radius: 4px; font-size: 0.95rem; transition: transform 0.3s; z-index: 9999;
}
.va-toast.sichtbar { transform: translateX(-50%) translateY(0); }

.va-token-box {
  background: #fffbea; border: 1px solid #f0c040; border-radius: 4px;
  padding: 1rem; margin-top: 1rem; font-size: 0.9rem;
}
.va-token-box code {
  font-size: 0.8rem; word-break: break-all; background: #f5f0d0;
  padding: 0.3rem 0.5rem; display: block; border-radius: 3px; margin: 0.4rem 0;
}

@media (max-width: 599px) {
  .va-event { grid-template-columns: 60px 1fr; }
  .va-datum-tag { font-size: 1.4rem; }
  .va-datum-row { grid-template-columns: 1fr; }
}
