/* --- Fonts --- */
@font-face {
  font-family: 'Merriweather Sans';
  src: url('../fonts/MerriweatherSans.ttf') format('truetype');
  font-style: normal;
  font-weight: 400;
}
@font-face {
  font-family: 'Merriweather Sans';
  src: url('../fonts/MerriweatherSans-Italic.ttf') format('truetype');
  font-style: italic;
  font-weight: 400;
}


/* --- Logos --- */
.navbar-logo-right {
  height: 40px;
  margin-left: 80px;
  margin-top: 3px;
  margin-bottom: 3px;
  object-fit: contain;
  display: block;
}

.navbar-logo-small {
  display: none;          /* Standard: ausgeblendet */
  margin: 6px auto 4px;   /* mittig, kleiner Abstand oben/unten */
  height: 60px;           /* kleinere Höhe */
  object-fit: contain;
}

/* Tablets (Bootstrap: 769px–991px) → linke Margin zurücksetzen */
@media (min-width: 769px) and (max-width: 991px) {
  .navbar-logo-right {
    margin-left: 10px;
  }
}

/* Tablet & kleinere Screens: kleines Logo sichtbar, großes Logo weg */
@media (max-width: 768px) {
  .navbar-logo-right {
    display: none;
  }
  .navbar-logo-small {
    display: block;
    height: 26px;
    margin-top: 4px;
    margin-bottom: 4px;
  }
}

/* Sehr kleine Smartphones */
@media (max-width: 400px) {
  .navbar-logo-small {
    height: 22px;
    margin-top: 2px;
    margin-bottom: 2px;
  }
}

/* --- Navbar Styling --- */
.navbar {
  background-color: #323131 !important;
}

.navbar .navbar-brand, 
.navbar-nav > li > a {
  color: #FFFFFF !important;
}

.nav-underline .nav-link.active {
  border-bottom: 2px solid #FFB300 !important;
}

.navbar .navbar-brand {
  font-size: 1.5rem !important;
  font-weight: bold;
  white-space: normal !important;  /* Zeilenumbruch bei Bedarf */
  text-align: center;              /* zentrieren auf kleineren Geräten */
  max-width: 90%;                  /* verhindert Überlaufen */
}

.navbar .nav-link {
  font-size: 1.2rem !important;
}

.bslib-navs-card-title {
  font-size: 1.2rem !important;
}

/* --- Typografie --- */
/* Standardgröße für Desktop */
body, .text-style, .card, .plotly, .ggplot {
  font-size: 16px;
}

/* Tablet: kleinere Schrift */
@media (max-width: 992px) {
  body, .text-style, .card, .plotly, .ggplot {
    font-size: 14px;
  }
  h6, h5 {
    font-size: 0.9rem;
  }
}

/* Smartphone: noch kleinere Schrift */
@media (max-width: 576px) {
  body, .text-style, .card, .plotly, .ggplot {
    font-size: 12px;
  }
  h6, h5 {
    font-size: 0.8rem;
  }
}

/* --- Plotly Cursors --- */
.plotly .cursor-pointer, 
.plotly .hoverlayer, 
.plotly .zoomlayer, 
.plotly .draglayer {
  cursor: default !important;
}

/* --- DataTable Styling --- */
table.dataTable.stripe tbody tr.odd,
table.dataTable.display tbody tr.odd {
  background-color: #FFFFFF !important;
}

table.dataTable.stripe tbody tr.even,
table.dataTable.display tbody tr.even {
  background-color: #FFFFFF !important;
}

table.dataTable.hover tbody tr:hover {
  background-color: #f5f5f5 !important;
}


/* --- Hamburger-Icon sicher auf weiß setzen (Bootstrap 5 / bslib) --- */

.navbar,
.navbar.navbar-light,
.navbar.navbar-dark {
  --bs-navbar-toggler-border-color: rgba(255,255,255,.55) !important;
  --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

.navbar .navbar-toggler {
  border-color: var(--bs-navbar-toggler-border-color) !important;
  background-color: transparent !important;
}

.navbar .navbar-toggler-icon {
  background-image: var(--bs-navbar-toggler-icon-bg) !important;
}

/* plotly immer volle Breite im Card/Tab-Layout */
.js-plotly-plot, .plot-container {
  width: 100% !important;
}

/* --- Globale Hervorhebung für ausgewählte DataTable-Zeilen --- */

/* ausgewählte Zeile: schwarz hinterlegt, weiße Schrift */
table.dataTable tbody tr.selected,
table.dataTable tbody tr.selected td {
  background-color: #323131 !important;
  color: #fff !important;
}

/* auch beim Hover Schrift weiß lassen */
table.dataTable tbody tr.selected:hover td {
  color: #fff !important;
}

/* Cursor-Pointer und leichte Hervorhebung beim Hover */
table.dataTable tbody tr:hover {
  cursor: pointer;
}