* { box-sizing: border-box; }

:root {
  color-scheme: light;
  --bg: #85ad33;
  --panel: rgba(255,255,255,0.88);
  --panel-2: rgba(255,255,255,0.94);
  --line: rgba(0,0,0,0.15);
  --text: #11161d;
  --muted: #4f5d72;
  --map-bg: #7ea82d;
  --grid-a: rgba(255,255,255,0.10);
  --grid-b: rgba(0,0,0,0.06);
}

body.theme-dark {
  color-scheme: dark;
  --bg: #0f1115;
  --panel: #171a21;
  --panel-2: #1f2430;
  --line: #2f3645;
  --text: #e7eaf0;
  --muted: #9ea7b8;
  --map-bg: #11151d;
  --grid-a: rgba(255,255,255,0.04);
  --grid-b: rgba(255,255,255,0.04);
}

html, body {
  margin: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
}

body {
  padding: 12px;
  transition: background-color .15s ease, color .15s ease;
  overflow: hidden;
}

.app { display: grid; gap: 12px; height: calc(100vh - 24px); min-height: calc(100vh - 24px); overflow: hidden; }

.topbar, .map-panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
}

.topbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  padding: 16px 18px;
  gap: 12px 18px;
}

.title-block { display: grid; gap: 6px; min-width: 0; }
.topbar h1 { margin: 0; font-size: 1.9rem; line-height: 1.1; }
.meta-line { color: var(--muted); font-size: 0.75rem; line-height: 1.2; }

.topbar-actions, .toolbar-group {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.topbar-actions {
  justify-self: end;
  align-self: start;
}

.lang-label { color: var(--muted); }

.layout { display: grid; gap: 12px; min-height: 0; height: 100%; }
.layout-single { grid-template-columns: 1fr; }

.map-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  min-height: 0;
  height: 100%;
  overflow: hidden;
}

.map-toolbar {
  display: grid;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  background: var(--panel-2);
  border-radius: 16px 16px 0 0;
}

.toolbar-group {
  justify-content: flex-start;
}

.toolbar-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  align-items: center;
}


.toolbar-grid-primary,
.toolbar-grid-vehicle {
  align-items: center;
}

.toolbar-grid-vehicle {
  position: relative;
}

.map-wrap {
  position: relative;
  min-height: 0;
  height: 100%;
  overflow: hidden;
  border-radius: 0 0 16px 16px;
  background:
    linear-gradient(to right, var(--grid-a) 1px, transparent 1px) 0 0 / 80px 80px,
    linear-gradient(to bottom, var(--grid-b) 1px, transparent 1px) 0 0 / 80px 80px,
    var(--map-bg);
}

.map-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--bg);
  z-index: 0;
  pointer-events: none;
}

#mapCanvas { width: 100%; height: 100%; display: block; position: relative; z-index: 1; }

.checkbox { display: inline-flex; align-items: center; gap: 6px; }

button, select, input[type="range"] {
  background: var(--panel-2);
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 10px;
}

button { cursor: pointer; }
label { display: inline-flex; align-items: center; gap: 8px; }

.legacy-hidden { display: none !important; }

@media (max-width: 700px) {
  .topbar {
    grid-template-columns: 1fr;
  }

  .topbar-actions {
    justify-self: start;
  }
}


/* v0.3.6 dark stripe fix */
body.theme-dark,
body.theme-dark html,
body.theme-dark .app {
  background: #0f1115 !important;
}

body.theme-dark .map-panel {
  background: #171a21 !important;
}

body.theme-dark .map-toolbar {
  background: #1f2430 !important;
}

body.theme-dark .map-wrap {
  background:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px) 0 0 / 80px 80px,
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px) 0 0 / 80px 80px,
    #11151d !important;
}

body.theme-dark #mapCanvas {
  background: transparent !important;
}

/* v0.3.7 viewport + dark root fix */
html.theme-dark,
body.theme-dark {
  background: #0f1115 !important;
}

html.theme-dark .app,
body.theme-dark .app {
  background: transparent !important;
}

html.theme-dark .map-wrap,
body.theme-dark .map-wrap {
  background:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px) 0 0 / 80px 80px,
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px) 0 0 / 80px 80px,
    #11151d !important;
}

html.theme-dark #mapCanvas,
body.theme-dark #mapCanvas {
  background: transparent !important;
}


/* v0.3.8 square viewport fix */
.map-wrap {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

#mapCanvas {
  flex: 0 0 auto;
  width: auto;
  height: auto;
  display: block;
}

html.theme-dark,
body.theme-dark,
html.theme-dark body,
body.theme-dark .app,
html.theme-dark .app {
  background: #0f1115 !important;
}


/* v0.4.0 topbar layout */
.app {
  grid-template-rows: auto minmax(0, 1fr) !important;
  align-content: start !important;
}

.topbar {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: start !important;
  align-content: start !important;
  justify-items: stretch !important;
  height: auto !important;
  min-height: 0 !important;
}

.topbar-actions {
  justify-self: end !important;
  align-self: start !important;
  width: auto !important;
  margin-top: 0;
}

.topbar > .toolbar-group {
  grid-column: 1 / -1;
}

.title-block {
  width: 100%;
}

/* do not stretch first row on tall portrait windows */
.layout {
  min-height: 0;
}

@media (max-width: 700px) {
  .topbar {
    grid-template-columns: 1fr !important;
  }

  .topbar-actions {
    justify-self: start !important;
  }
}


/* v0.5.5 performance selector */
.topbar-actions select {
  min-width: 86px;
}


/* v0.6.7 map-only mode */
body.map-only {
  padding: 0 !important;
}

body.map-only .app {
  height: 100vh !important;
  min-height: 100vh !important;
  gap: 0 !important;
}

body.map-only .topbar {
  display: none !important;
}

body.map-only .map-panel {
  border-radius: 0 !important;
  border: 0 !important;
  height: 100vh !important;
  min-height: 100vh !important;
}

body.map-only .map-toolbar {
  display: none !important;
}

body.map-only .map-wrap {
  height: 100vh !important;
  min-height: 100vh !important;
  border-radius: 0 !important;
}

body.map-only #mapCanvas {
  width: 100% !important;
  height: 100% !important;
  display: block !important;
}


/* v0.6.9 map-only no-stretch fix */
body.map-only .map-wrap {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.map-only #mapCanvas {
  display: block !important;
  flex: 0 0 auto !important;
}


/* v0.7.0 map-only viewport fit */
body.map-only,
body.map-only html {
  overflow: hidden !important;
}

body.map-only .map-panel,
body.map-only .map-wrap {
  width: 100vw !important;
  max-width: 100vw !important;
  height: 100dvh !important;
  min-height: 100dvh !important;
  max-height: 100dvh !important;
  overflow: hidden !important;
}

body.map-only .map-wrap {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
}

body.map-only #mapCanvas {
  display: block !important;
  flex: 0 0 auto !important;
}


/* v0.7.3 mobile viewport fix */
html, body {
  max-width: 100%;
}

body {
  overscroll-behavior: none;
}

.map-wrap,
#mapCanvas {
  touch-action: none;
}


/* v0.7.4 visible viewport fix */
:root {
  --fs25-vh: 100dvh;
}

.app {
  height: calc(var(--fs25-vh) - 24px) !important;
  min-height: calc(var(--fs25-vh) - 24px) !important;
}

body.map-only .app,
body.map-only .map-panel,
body.map-only .map-wrap {
  height: var(--fs25-vh) !important;
  min-height: var(--fs25-vh) !important;
  max-height: var(--fs25-vh) !important;
}


/* v0.7.5 fullscreen square final override */
body.map-only .map-panel {
  width: 100vw !important;
  max-width: 100vw !important;
  height: var(--fs25-vh) !important;
  min-height: var(--fs25-vh) !important;
  max-height: var(--fs25-vh) !important;
  overflow: hidden !important;
}

body.map-only .map-wrap {
  width: 100vw !important;
  max-width: 100vw !important;
  height: var(--fs25-vh) !important;
  min-height: var(--fs25-vh) !important;
  max-height: var(--fs25-vh) !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 0 !important;
  margin: 0 !important;
}

body.map-only #mapCanvas {
  width: min(100vw, var(--fs25-vh)) !important;
  height: min(100vw, var(--fs25-vh)) !important;
  min-width: min(100vw, var(--fs25-vh)) !important;
  min-height: min(100vw, var(--fs25-vh)) !important;
  max-width: min(100vw, var(--fs25-vh)) !important;
  max-height: min(100vw, var(--fs25-vh)) !important;
  aspect-ratio: 1 / 1 !important;
  flex: 0 0 auto !important;
  display: block !important;
}


/* v0.7.6 touch gestures for map-only */
body.map-only .map-wrap,
body.map-only #mapCanvas {
  touch-action: none !important;
}


/* v0.7.9 fullscreen emphasis */
#mapOnlyBtn {
  font-weight: 700 !important;
}


.vehicle-type-filters-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.vehicle-filters-toggle {
  border: none;
  background: transparent;
  color: var(--muted);
  padding: 0;
  border-radius: 0;
  font: inherit;
}

.vehicle-filters-toggle:hover {
  color: var(--text);
}

.vehicle-filters-toggle:disabled {
  opacity: 0.6;
  cursor: default;
}

.vehicle-type-panel {
  position: absolute;
  left: calc(100% + 12px);
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 16px;
  min-width: min(640px, calc(100vw - 120px));
  max-width: min(760px, calc(100vw - 100px));
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  z-index: 20;
}

.vehicle-type-panel[hidden] {
  display: none;
}

.vehicle-type-filters-wrap.disabled {
  opacity: 0.6;
}

@media (max-width: 1100px) {
  .vehicle-type-panel {
    left: 0;
    top: calc(100% + 10px);
    transform: none;
    min-width: min(520px, calc(100vw - 80px));
    max-width: min(620px, calc(100vw - 60px));
  }
}

/* v0.8.50 compact dropdown menus */
.dropdown-menu-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.dropdown-menu-toggle {
  position: relative;
  min-width: 120px;
  justify-content: flex-start;
  padding: 8px 34px 8px 12px;
}

.dropdown-menu-toggle::after {
  content: "▾";
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  pointer-events: none;
}

.dropdown-menu-wrap.open .dropdown-menu-toggle::after {
  content: "▴";
}

.dropdown-menu-panel {
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 2px;
  min-width: 200px;
  max-width: min(300px, calc(100vw - 40px));
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel-2);
  box-shadow: 0 10px 28px rgba(0,0,0,0.18);
  z-index: 20;
}

.dropdown-menu-panel[hidden] {
  display: none;
}

button.dropdown-menu-option {
  all: unset;
  display: block;
  width: 100%;
  box-sizing: border-box;
  cursor: pointer;
  color: var(--text);
  padding: 4px 2px;
  line-height: 1.35;
}

button.dropdown-menu-option:hover,
button.dropdown-menu-option:focus-visible {
  color: var(--text);
  text-decoration: underline;
  outline: none;
}

button.dropdown-menu-option.inactive {
  color: var(--muted);
  opacity: 0.62;
}

button.dropdown-menu-option.active {
  color: var(--text);
  opacity: 1;
}

.dropdown-menu-separator {
  height: 1px;
  margin: 5px 0;
  background: var(--line);
}

#languageMenu .dropdown-menu-toggle {
  min-width: 160px;
}

#vehiclesMenu .dropdown-menu-toggle {
  min-width: 140px;
}
.topbar > .toolbar-group {
  width: 100%;
}

.toolbar-grid-primary {
  width: 100%;
}

#performanceMenu {
  order: 100;
  margin-left: auto;
}

#performanceMenu .dropdown-menu-panel {
  left: auto;
  right: 0;
}
.hidden-link {
  color: inherit;        /* gleiche Farbe wie Text */
  text-decoration: none; /* keine Unterstreichung */
  cursor: pointer;
}

.hidden-link:hover {
  opacity: 0.8;          /* leichtes Feedback */

}

#pageTitle {
  display: flex;
  justify-content: center;
  align-items: center;
}