body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell', sans-serif;
  background-color: #f8f9fa;
  color: #333;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.app-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 3rem 1.25rem 2rem;
  text-align: center;
  background: linear-gradient(135deg, #0d47a1, #1976d2 55%, #42a5f5);
  color: #fff;
  border-radius: 18px;
  box-shadow: 0 12px 28px -8px rgba(13, 71, 161, 0.45);
  margin: 1.5rem 0 2rem;
}

.app-header h1 {
  font-size: clamp(2rem, 5vw, 2.8rem);
  margin: 0;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.controls-card {
  background: #fff;
  padding: 1.5rem;
  border-radius: 14px;
  box-shadow: 0 6px 18px -6px rgba(0, 0, 0, 0.18);
  margin-bottom: 1.5rem;
  transition: box-shadow 0.25s, transform 0.25s;
}

.controls-card:hover {
  box-shadow: 0 10px 26px -4px rgba(0, 0, 0, 0.28);
  transform: translateY(-2px);
}

.Select-control {
  border-radius: 8px !important;
  border-color: #d1d5db !important;
}

.live-update-section {
  background: #fff;
  padding: 1rem 1.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px -4px rgba(0, 0, 0, 0.15);
  margin-bottom: 1.5rem;
}

.live-update-section h4 {
  color: #0d47a1;
  font-size: 1.25rem;
  margin: 0 0 0.5rem;
  font-weight: 600;
}

.graph-card {
  background: #fff;
  padding: 1rem;
  border-radius: 14px;
  box-shadow: 0 6px 18px -6px rgba(0, 0, 0, 0.18);
  margin-bottom: 1.5rem;
}

label {
  color: #1f2937;
  font-weight: 600;
  font-size: 0.95rem;
  margin-bottom: 0.5rem;
  display: block;
}

@media (max-width: 640px) {
  .app-header { padding: 2.5rem 1rem 1.5rem; }
  .controls-card { padding: 1rem; }
}

.dHABtm {
    font-size: 20px !important;
    font-weight: bold;
}

/* ── Glass Measurement Cards ───────────────────────────────────────────── */
.dbc-card {
    background: rgba(255, 255, 255, 0.15);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 16px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
    padding: 20px;
}

.dbc-card .text-muted {
    color: rgba(255, 255, 255, 0.75) !important;
}

.dbc-card,
.dbc-card .display-6,
.dbc-card .fs-4,
.dbc-card .fs-5 {
    color: #ffffff;
}

.dbc-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.28);
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

/* ── Full-bleed helper ─────────────────────────────────────────────────── */
.full-bleed {
    margin-left: -0.75rem;
    margin-right: -0.75rem;
    width: calc(100% + 1.5rem);
}

/* ── Navbar ───────────────────────────────────────────────────────────── */
.navbar.bg-primary {
    background: #495057 !important;
    border: none;
    border-radius: 0;
    box-shadow: none;
}

/* Glas-effect navbar op de detail-pagina, zodat de zonnige achtergrondfoto
   erdoorheen schijnt. Deze regel moet MINSTENS even specifiek zijn als
   ".navbar.bg-primary" hierboven (en ook !important gebruiken), anders wint
   het opake grijze navbar-blok altijd — dat was de oorzaak van de "kapotte"
   glas-navbar: ".glass-navbar" alleen (1 klasse) verliest van
   ".navbar.bg-primary" (2 klassen). */
.navbar.glass-navbar.bg-primary {
    background: rgba(255, 255, 255, 0.15) !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
}

.navbar.glass-navbar .navbar-brand,
.navbar.glass-navbar .nav-link,
.navbar.glass-navbar .btn {
    color: #ffffff !important;
}

/* ── Sensor Detail Page ────────────────────────────────────────────────── */
/* De buitenste div krijgt de backgroundImage via inline style in Python.
   CSS regelt de rest: grootte, positie, fallback-kleur.

   Deze div krijgt in Python ook de klasse "full-bleed" (zie
   layout/app_components.py -> create_location_detail_layout). Dat is nodig
   omdat de buitenste ".container-fluid" uit app.py standaard horizontale
   Bootstrap-padding heeft; zonder "full-bleed" zag je daardoor links/rechts
   een dun randje van de paginakleur (#f8f9fa) naast de zonnige
   achtergrondfoto in plaats van een echte full-bleed achtergrond. */
.sensor-detail-page {
    min-height: 100vh;
    background-color: #1a2744;
    background-size: cover;
    background-position: center center;
    background-attachment: fixed;
    background-repeat: no-repeat;
}

/* background-attachment: fixed geeft op veel mobiele browsers (vooral iOS
   Safari) rendering-problemen: de achtergrondfoto kan tijdens scrollen
   (deels) verdwijnen of "glitchen". Op kleine schermen vallen we daarom
   terug op het normale scroll-gedrag. */
@media (max-width: 768px) {
    .sensor-detail-page {
        background-attachment: scroll;
    }
}

.sensor-detail-content {
    padding: 1.5rem 0.75rem;
}

/* Alle tekst op de detail-pagina wit */
.sensor-detail-page,
.sensor-detail-page h1,
.sensor-detail-page h2,
.sensor-detail-page h3,
.sensor-detail-page h4,
.sensor-detail-page h5,
.sensor-detail-page h6,
.sensor-detail-page p,
.sensor-detail-page label,
.sensor-detail-page .text-muted {
    color: #ffffff !important;
}

/* ── Fix: dcc.Dropdown leesbaar op detail-pagina ──────────────────────── */
.sensor-detail-page .Select-control,
.sensor-detail-page .Select-value-label,
.sensor-detail-page .Select-placeholder,
.sensor-detail-page .Select-input,
.sensor-detail-page .Select-input input,
.sensor-detail-page .Select-menu-outer,
.sensor-detail-page .Select-menu,
.sensor-detail-page .Select-option,
.sensor-detail-page .Select-noresults,
.sensor-detail-page .VirtualizedSelectOption,
.sensor-detail-page .VirtualizedSelectFocusedOption,
.sensor-detail-page .VirtualizedSelectSelectedOption {
    color: #1f2937 !important;
}

.sensor-detail-page .Select-control,
.sensor-detail-page .Select-menu-outer {
    background-color: #ffffff !important;
}

.sensor-detail-page .Select-option.is-focused,
.sensor-detail-page .VirtualizedSelectFocusedOption {
    background-color: #e9ecef !important;
}

/* ── Live map controls ─────────────────────────────────────────────────── */
.live-map-controls .form-check-input:checked {
    background-color: #6c757d !important;
    border-color: #6c757d !important;
}

.live-map-controls .form-check-input:focus {
    border-color: #6c757d !important;
    box-shadow: 0 0 0 0.25rem rgba(108, 117, 125, 0.25) !important;
}

/* Metric-dropdown (select-metric): grijs (secondary) i.p.v. het standaard
   Bootstrap-blauw bij hover/klik/openen.
   BELANGRIJK: dit was eerst een native <select> ("dbc.Select"/.form-select).
   De geopende optielijst van een native <select> is browser-eigen UI:
   Chrome/Edge tekenen die zelf en laten GEEN CSS toe op de hover-kleur van
   de losse <option>-items — vandaar dat het eerder nog blauw bleef, ook na
   het overschrijven van de focus-outline/box-shadow op het vak zelf.
   Daarom is select-metric in layout/app_components.py omgezet naar
   "dcc.Dropdown" (className "metric-dropdown"): dat rendert zijn eigen DOM
   (".Select-control", ".Select-menu-outer", ".Select-option", ...) die wél
   volledig met CSS te stylen is, net zoals hierboven al gebeurt voor de
   dcc.Dropdown op de sensor-detailpagina (".sensor-detail-page .Select-..."). */
.live-map-controls .metric-dropdown .Select-control {
    border-color: #ced4da;
    box-shadow: none !important;
    cursor: pointer;
}

.live-map-controls .metric-dropdown.is-focused > .Select-control,
.live-map-controls .metric-dropdown.is-open > .Select-control {
    border-color: #6c757d !important;
    box-shadow: 0 0 0 0.25rem rgba(108, 117, 125, 0.25) !important;
}

.live-map-controls .metric-dropdown .Select-menu-outer {
    border-color: #6c757d !important;
}

/* Gehoverde/met-pijltjes-gemarkeerde optie in de geopende lijst */
.live-map-controls .metric-dropdown .Select-option.is-focused,
.live-map-controls .metric-dropdown .VirtualizedSelectFocusedOption {
    background-color: #6c757d !important;
    color: #ffffff !important;
}

/* De optie die momenteel geselecteerd is (terwijl de lijst open staat) */
.live-map-controls .metric-dropdown .Select-option.is-selected,
.live-map-controls .metric-dropdown .VirtualizedSelectSelectedOption {
    background-color: #e9ecef !important;
    color: #1f2937 !important;
}