/* ===== Globale Styles für die gesamte App ===== */
  /* 1) Design-Variablen (Farben, Abstände, Radius) */
:root {
  --color-bg-sidebar: #f5f5f5;
  --color-bg-page: #ffffff;
  --color-text: #333;
  --color-muted: #666;
  --color-muted-soft: #999;
  --color-border: #ccc;

  --color-accent: #c00000;
  --color-accent-soft: #ff4d4d;

  --radius-md: 10px;
  --radius-lg: 12px;

  --shadow-soft: 0 2px 6px rgba(0, 0, 0, 0.08);
}

/* 2) Grundlayout: Sidebar links, Inhalt rechts*/

body {
  margin: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  display: flex;
  background-color: #fafafa;
  color: var(--color-text);
}

/* 3) Sidebar (gilt für alle Seiten) */
.sidebar {
  width: 220px;
  background-color: var(--color-bg-sidebar);
  height: 100vh;
  padding: 20px;
  box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);
  position: fixed;
  left: 0;
  top: 0;
}

.sidebar h2 {
  margin-top: 0;
  margin-bottom: 20px;
  font-size: 18px;
  letter-spacing: 0.05em;
  color: #444;
}

.sidebar a {
  display: block;
  padding: 10px 12px;
  margin-bottom: 8px;
  text-decoration: none;
  color: var(--color-text);
  border-radius: 6px;
  font-size: 15px;
}

.sidebar a:hover {
  background-color: #e0e0e0;
}

/* aktuell ausgewählter Menüpunkt */
.sidebar a.active {
  background: linear-gradient(
    90deg,
    var(--color-accent),
    var(--color-accent-soft)
  );
  color: white;
}

/* Logo-Bereich oben in der Sidebar */
.sidebar-header {
  background-color: #ffffff;
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 32px;
  height: 160px;
  box-shadow: var(--shadow-soft);
}

.sidebar-logo {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

.sidebar-appname {
  display: flex;
  flex-direction: column;
}

.sidebar-title {
  font-weight: 600;
  font-size: 16px;
}

.sidebar-subtitle {
  font-size: 12px;
  color: var(--color-muted-soft);
}

/* 4) Hauptbereich rechts (gemeinsam für alle Seiten) */
.content {
  margin-left: 260px;
  padding: 24px;
  flex-grow: 1;
}

.content h1 {
  margin-top: 0;
}

/* Rahmen für komplette Page */
.page-shell {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* 5) Obere Leiste + roter Titel-Balken*/
.topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: #f3f3f3;
  padding: 8px 16px;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  font-size: 13px;
  color: var(--color-muted);
}

.topbar-left .breadcrumbs {
  color: var(--color-muted-soft);
  margin-right: 4px;
}

.topbar-left .page-name {
  font-weight: 500;
}

.topbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
}

.icon-button {
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 18px;
  padding: 4px 6px;
  border-radius: 999px;
}

.icon-button:hover {
  background-color: #e0e0e0;
}

.sign-in-button {
  border-radius: 20px;
  border: 1px solid var(--color-border);
  background-color: white;
  padding: 6px 14px;
  font-size: 13px;
  cursor: pointer;
}

.sign-in-button:hover {
  background-color: #f0f0f0;
}

/* roter Balken mit Titel */
.headline-bar {
  background: linear-gradient(
    90deg,
    var(--color-accent),
    var(--color-accent-soft)
  );
  padding: 14px 24px;
  border-radius: var(--radius-lg);
  color: white;
}

.headline-title {
  margin: 0;
  font-size: 20px;
}

/* 6) Content-Layouts & Karten*/
.page-content {
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

/* Variante: einspaltiger Inhalt */
.page-content--single {
  flex-direction: column;
}

/* Allgemeine Card-Komponente (falls du sie auf anderen Seiten nutzt) */
.card {
  flex: 1;
  background-color: var(--color-bg-page);
  border-radius: var(--radius-lg);
  padding: 16px;
  box-shadow: var(--shadow-soft);
}

/* Wrapper für Map */
.map-wrapper {
  flex: 1;
}

/* 7) Google Maps Embed (iframe)*/
#map-embed {
  width: 100%;
  height: 400px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  display: block;
}

/* Karte soll den ganzen Platz ausfüllen */
.full-map #map-embed {
  height: calc(100vh - 220px);
  width: 100%;
  border-radius: 12px;
  border: 1px solid #ccc;
}

/* Einspaltiges Layout final */
.page-content--single {
  display: block;
}

/* ===== Login Page (isoliert) ===== */
.login-body {
  display: block; /* überschreibt body { display:flex } */
}
.login-page {
  min-height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #f5f6f8;
  padding: 2rem;
}

.login-card {
  width: 100%;
  max-width: 640px;
  background: white;
  border: 4px solid var(--color-accent);
  border-radius: 18px;
  padding: 32px;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.14), 0 0 0 6px rgba(192, 0, 0, 0.25);
}

.login-title {
  margin: 0 0 6px 0;
  font-size: 32px;
}

.login-sub {
  margin: 0 0 18px 0;
  color: #666;
}

.login-form {
  display: grid;
  gap: 14px;
}

.login-label {
  display: grid;
  gap: 6px;
  font-weight: 600;
}

.login-input {
  height: 42px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(0, 0, 0, 0.18);
  font-size: 14px;
}

.login-btn {
  height: 44px;
  border-radius: 12px;
  border: 1px solid rgba(0, 0, 0, 0.15);
  background: #fff;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
}

.login-btn:hover {
  background: #f3f3f3;
}

.login-error {
  color: #b00020;
  margin: 6px 0 0;
}
.login-title {
  color: var(--color-accent);
}
/* ===== Abfahrten: zwei Tafeln nebeneinander ===== */

.departures-grid {
  display: flex;
  gap: 24px;
  align-items: stretch;
}

/* Beide Tafeln gleich breit */
.departures-card {
  flex: 1;
  min-width: 0; /* verhindert, dass iframes das Layout sprengen */
}

/* iframe bleibt sauber im Card-Rahmen */
.vvs-departures {
  width: 100%;
  height: 340px;
  border: 0;
  border-radius: var(--radius-lg);
  display: block;
}

/* Optional: Überschrift/Quelle etwas ruhiger */
.departures-card small {
  display: inline-block;
  margin-top: 8px;
  color: var(--color-muted);
}

/* Auf kleineren Bildschirmen untereinander */
@media (max-width: 900px) {
  .departures-grid {
    flex-direction: column;
  }
}

/* Optional: Überschrift/Quelle etwas ruhiger */
.departures-card small {
  display: inline-block;
  margin-top: 8px;
  color: var(--color-muted);
}

/* Auf kleineren Bildschirmen untereinander */
@media (max-width: 900px) {
  .departures-grid {
    flex-direction: column;
  }
}

/* Container für Elemente, die nebeneinander stehen sollen */
.input-row {
  display: flex;
  gap: 16px;
  width: 100%;
}

/* Sorgt dafür, dass die Gruppen gleichmäßig wachsen und nicht überlappen */
.input-row .input-group {
  flex: 1;
  min-width: 0; /* Verhindert das "Rausdrücken" aus der Reihe */
}

/* Standard-Styling für alle Formularfelder */
input[type="date"],
input[type="time"],
input[type="text"],
select {
  width: 100%;
  box-sizing: border-box; /* WICHTIG: Padding wird nicht zur Breite addiert */
  padding: 10px;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  font-size: 14px;
  background-color: #fff;
}

/* Optional: Damit es auf dem Handy untereinander springt */
@media (max-width: 500px) {
  .input-row {
    flex-direction: column;
    gap: 10px;
  }
}
/* =========================
   Mobile Sidebar (Responsive)
   ========================= */

.mobile-menu-btn {
  display: none;
  background: none;
  border: none;
  font-size: 26px;
  cursor: pointer;
  margin-right: 10px;
}

/* Overlay hinter Sidebar */
.sidebar-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 998;
  display: none;
}

/* -------- Mobile Layout -------- */
@media (max-width: 768px) {
  .mobile-menu-btn {
    display: block;
  }

  .sidebar {
    position: fixed;
    top: 0;
    left: 0; /* bleibt 0 */
    height: 100%;
    width: 260px;
    z-index: 999;

    /* WICHTIG: komplett raus schieben */
    transform: translateX(-110%);
    transition: transform 0.3s ease;

    /* damit sie wirklich “weg” ist */
    pointer-events: none;
  }

  .sidebar.open {
    transform: translateX(0);
    pointer-events: auto;
  }

  .sidebar-overlay.show {
    display: block;
  }

  .content {
    margin-left: 0;
    padding: 0;
  }
}
