body {
  background-color: #f8f9fa;
}

.navbar-brand {
  font-size: 1.1rem;
  letter-spacing: 0.02em;
}

.card {
  border-radius: 0.5rem;
}

.table th {
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: #6c757d;
}

.table td {
  vertical-align: middle;
}

.badge {
  font-weight: 500;
}

/* Stat-Karten auf dem Dashboard */
.card.bg-primary,
.card.bg-success,
.card.bg-danger,
.card.bg-warning,
.card.bg-secondary {
  border: none;
}

/* Kompakte Seitennavigation */
.pagination .page-link {
  font-size: 0.85rem;
}

/* Formular-Labels etwas kleiner */
.form-label {
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 0.25rem;
}

/* Beleg-Anhang-Icon */
.bi-paperclip {
  font-size: 0.8rem;
}


/* ── Titelzeile: Benutzer-Dropdown blau ── */
#navbar-top .dropdown-menu {
  background-color: #3B7FED;
  border-color: rgba(255,255,255,0.2);
}
#navbar-top .dropdown-menu .dropdown-item {
  color: rgba(255,255,255,0.9);
}
#navbar-top .dropdown-menu .dropdown-item:hover,
#navbar-top .dropdown-menu .dropdown-item:focus {
  background-color: rgba(255,255,255,0.15);
  color: #fff;
}
#navbar-top .dropdown-menu .dropdown-divider {
  border-color: rgba(255,255,255,0.2);
}
#navbar-top .dropdown-menu .text-muted {
  color: rgba(255,255,255,0.65) !important;
}

/* ── Menüzeile: einheitliche Schrift für Nav + Dropdowns ── */
#navbar-nav .nav-link,
#navbar-nav .nav-link.active {
  font-size: 0.95rem !important;
  font-weight: 400 !important;
  white-space: nowrap;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
#navbar-nav .dropdown-menu .dropdown-item {
  font-size: 0.95rem;
}

/* ── Mobile Navbar ── */

/* Aufgeklapptes Menü: klarer Rahmen zum Seiteninhalt */
@media (max-width: 1199.98px) {
  #mainNavCollapse {
    border-top: 1px solid #e9ecef;
    box-shadow: 0 4px 8px rgba(0,0,0,0.08);
  }
  #navbar-nav .navbar-nav .nav-link {
    padding: 0.65rem 1rem !important;
    border-bottom: 1px solid #f1f3f5;
    white-space: normal !important;
  }
  #navbar-nav .navbar-nav > li:last-child > .nav-link {
    border-bottom: none;
  }
  /* Dropdown-Untermenüs einrücken */
  #navbar-nav .navbar-nav .dropdown-menu {
    box-shadow: none;
    border: none;
    border-left: 3px solid #dee2e6;
    border-radius: 0;
    margin-left: 1.5rem;
    padding: 0;
    background: #f8f9fa;
  }
  #navbar-nav .navbar-nav .dropdown-menu .dropdown-item {
    padding: 0.5rem 1rem;
    border-bottom: 1px solid #e9ecef;
    font-size: 0.9rem;
  }
  #navbar-nav .navbar-nav .dropdown-menu .dropdown-item:last-child {
    border-bottom: none;
  }
}

/* Hamburger-Button etwas größer und besser sichtbar */
@media (max-width: 1199.98px) {
  .navbar-toggler {
    padding: 0.4rem 0.6rem;
  }
}

/* ── Responsive page headers: wrap button groups on small screens ── */
@media (max-width: 575.98px) {
  /* Seiten-Header (h2 + Aktionsbuttons) umbrochen auf xs */
  .d-flex.justify-content-between.align-items-center.mb-3,
  .d-flex.justify-content-between.align-items-center.mb-4 {
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  /* Button-Gruppen in Headern fließen mit */
  .d-flex.justify-content-between.align-items-center.mb-3 > .d-flex,
  .d-flex.justify-content-between.align-items-center.mb-4 > .d-flex {
    flex-wrap: wrap;
  }
  /* Formulare in Header-Flex nicht breiter als nötig */
  .d-flex.justify-content-between.align-items-center.mb-3 > form,
  .d-flex.justify-content-between.align-items-center.mb-4 > form {
    margin: 0;
  }
}

/* ── Responsive: Tabellen auf kleinen Schirmen korrekt umbrechen ── */
@media (max-width: 767.98px) {
  .table-responsive table { min-width: unset; }
}

@media print {
  .navbar, .alert, .btn, form { display: none !important; }
}
