:root {
  /* Theme tokens */
  --border: #e5e7eb;
  --muted: #6b7280;
  --fg:    #111827;
  --bg:    #ffffff;
  --primary: #111827;
}

/* --- Base layout --- */
html,
body {
  height: 100%;
  margin: 0;
}

body {
  display: flex;
  flex-direction: column;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color: var(--fg);
  background: var(--bg);
}

/* Root container voor de volledige app */
.app-root {
  display: flex;
  flex-direction: column;
  min-height: 100vh; /* zorgt dat de map hoogte krijgt, ook buiten fullscreen */
}

body {
  display: flex;
  flex-direction: column;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color: var(--fg);
  background: var(--bg);
}

/* --- Toolbar --- */
.toolbar {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .75rem;
  border-bottom: 1px solid var(--border);
  background: rgba(255, 255, 255, .9);
  backdrop-filter: blur(4px);
  position: sticky;
  top: 0;
  z-index: 1000;
}

.sep_vervallen {
  width: 1px;
  height: 1.5rem;
  background: var(--border);
  margin: 0 .5rem;
}

/* --- Map area --- */
#map {
  position: absolute;
  inset: 0;
}

.mapwrap {
  position: relative;
  flex: 1 1 auto;   /* neemt alle resterende ruimte */
  min-height: 0;    /* belangrijk i.c.m. flexbox */
}

/* --- Chips / inline badges --- */
.chip {
  border: 1px solid var(--border);
  padding: .1rem .5rem;
  border-radius: 999px;
  font-size: .8rem;
}

.error {
  color: #b91c1c;
}

/* --- Context menu --- */
.ctxmenu {
  position: fixed;
  z-index: 2000;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: .5rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .12);
  padding: .25rem;
  display: none;
}

.ctxmenu:not(.card):not(#exportDlg):not(#importDlg) button {
  display: block;
  width: 100%;
  text-align: left;
  padding: .4rem .6rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-size: .9rem;
}

.ctxmenu:not(.card):not(#exportDlg):not(#importDlg) button:hover {
  background: #f3f4f6;
}

/* --- Icon-only buttons --- */
.iconbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .4rem;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--border);
  border-radius: .6rem;
  background: #fff;
  cursor: pointer;
}

.iconbtn:disabled {
  opacity: .5;
  cursor: default;
}

.iconbtn i {
  font-size: 1.1rem;
}

/* Mode colors */
.iconbtn.mode.straight {
  background: #e0f2fe; /* lichtblauw */
  color: #075985;
}

.iconbtn.mode.auto {
  background: #1e3a8a; /* donkerblauw */
  color: #fff;
}

/* --- Menus / dropdowns --- */
.menuwrap {
  position: relative;
}

.menu {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: .5rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .12);
  display: none;
  min-width: 280px;              /* breder paneel zodat input+knop passen */
  max-width: min(92vw, 640px);   /* ruim, maar binnen viewport */
  padding: .25rem;
  z-index: 1500;
}


.menu.open {
  display: block;
}

.menu button,
.menu .menubtn {
  /* baseline item sizing */
  display: flex;
  align-items: center;
  gap: .5rem;
  width: 100%;
  padding: .45rem .65rem;
  text-align: left;
  font-size: .9rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  /* keep overlay-friendly box model */
  position: relative;
  box-sizing: border-box;
  overflow: hidden;
}

/* icons inside stay clickable but ignore file-input overlay */
.menu .menubtn i { pointer-events: none; }

.menu button:hover,
.menu .menubtn:hover {
  background: #f3f4f6;
}

.menu .menubtn {
  position: relative;
}

.menu .menubtn input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

/* --- Statusbar (right aligned in toolbar) --- */
.spacer {
  flex: 1;
}

.statusbar {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .9rem;
  color: var(--fg);
}

.statusbar .chip {
  border: 1px solid var(--border);
  padding: .1rem .5rem;
  border-radius: 999px;
  font-size: .8rem;
}

.statusbar #count {
  color: var(--muted);
}

/* --- Help overlay --- */
.help-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  display: none;
  z-index: 3000;
}

.help-overlay.open {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 4vh 1rem;
}

.help-panel {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: .75rem;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .2);
  max-width: 960px;
  width: 100%;
  max-height: 92vh;
  overflow: auto;
}

.help-header {
  position: sticky;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem;
  border-bottom: 1px solid var(--border);
  background: #fff;
}

.help-content {
  padding: 1rem;
}

.help-grid {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: .75rem 1rem;
  align-items: flex-start;
}

.help-grid .icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--border);
  border-radius: .5rem;
}

.help-legend {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem 1rem;
  align-items: center;
  margin: .25rem 0 1rem;
}

.badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .15rem .5rem;
  font-size: .8rem;
}

.btn-close {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: .5rem;
  padding: .35rem .6rem;
  cursor: pointer;
}

/* --- Menu: search input --- */
.menu input[type="text"] {
  box-sizing: border-box;
  flex: 1 1 auto;               /* vul de rij, laat ruimte voor knop */
  width: auto;
  border: 1px solid var(--border);
  border-radius: .5rem;
  padding: .7rem .9rem;
  font-size: 1.05rem;
  outline: none;
}


/* Search form layout (generic) */
.menu-search {
  display: flex;                 /* input en knop naast elkaar */
  align-items: center;
  gap: .5rem;
  padding: .75rem;
  flex-wrap: nowrap;             /* knoop naast input, niet eronder */
  /* géén vaste min-/max-breedte hier; laat het oudermenu bepalen */
}

/* Zoekknop naast het veld */
.menu-search button[type="submit"],
.menu-search .searchbtn {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border: 1px solid var(--border);
  border-radius: .6rem;
  background: #fff;
  cursor: pointer;
}
.menu-search button[type="submit"]:hover,
.menu-search .searchbtn:hover {
  background: #f9fafb;
}

/* ===== Zoekmenu specifieke sizing (alleen voor #moreMenu) ===== */
#moreMenu {
  width: fit-content;            /* menu groeit mee met inhoud */
  max-width: 92vw;               /* maar nooit breder dan viewport */
}
@supports not (width: fit-content) {
  /* fallback voor oudere engines */
  #moreMenu { width: auto; }
}

#moreMenu .menu-search {
  min-width: 0;                  /* laat inhoud bepalen; geen harde ondergrens */
}

#moreMenu .menu-search input[type="text"] {
  /* start breed (28rem), maar mag krimpen op small screens */
  flex: 1 1 28rem;               /* basisbreedte ~448px, shrink/expand allowed */
  min-width: 12rem;              /* nooit kleiner dan ~192px */
}


/* ▼ Indicator voor knoppen met submenu (rechtsonder pijltje) */
.iconbtn.has-sub { position: relative; }
.iconbtn.has-sub::after {
  content: "";
  position: absolute;
  right: 4px;
  bottom: 3px;
  width: 0; height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid currentColor; /* naar beneden wijzend driehoekje */
  opacity: .75;
  pointer-events: none;
}
.iconbtn.has-sub:disabled::after { opacity: .4; }

/* --- Drag & drop sorteer-lijst (Waypoints sorteren) --- */
.sortlist {
  list-style: none;
  margin: .25rem 0;
  padding: 0;
  max-height: 50vh;
  overflow: auto;
}
.sortitem {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .55rem .65rem;
  margin: .4rem 0;
  border: 1px solid var(--border);
  border-radius: .6rem;
  background: #f7f8fa;            /* lichte grijstint */
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
  user-select: none;
}
.sortitem:hover { background: #f3f4f6; }
.sortitem.dragging { opacity: .85; box-shadow: 0 2px 6px rgba(0,0,0,.08); }
.sortitem .handle { cursor: grab; display: inline-flex; align-items: center; padding: .1rem .25rem; border-radius: .4rem; }
.sortitem .name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }


/* Waypoint editor – formaat & spacing */
#iwpEditor.ctxmenu {
  width: 700px; /* ~2.5× breder dan ~280px */
  /* Zorg dat Bootstrap-knoppen hun eigen styling behouden */
}

/* Binnen het editor-card geen menu-stijl erzettend gedrag toepassen */
#iwpEditor.ctxmenu .btn {
  display: inline-flex;
  width: auto;
  text-align: center;
}

#iwpEdHeader {
  cursor: move; /* visuele hint voor slepen */
}

#iwpEdPreview img {
  max-height: 240px;
  object-fit: contain;
}

.iconbtn.is-disabled { opacity: .5; pointer-events: none; }
.menu .is-disabled { opacity: .5; pointer-events: none; }

/* --- Import/Export dialog (robust + Bootstrap-friendly) --- */
#exportDlg, #importDlg {
  width: 520px;                      /* robuuste basisbreedte */
  max-width: calc(100vw - 2rem);
}

/* Als we Bootstrap card markup gebruiken in de HTML */
#exportDlg.card, #importDlg.card {
  padding: 0;                        /* card regelt zelf spacing */
}
#exportDlg.card .card-header,
#importDlg.card .card-header {
  background: var(--bs-tertiary-bg, #f8f9fa);
  border-bottom: 1px solid var(--border);
}
#exportDlg.card .card-body,
#importDlg.card .card-body { padding: 1rem; }
#exportDlg.card .card-footer,
#importDlg.card .card-footer {
  padding: .75rem 1rem;
  border-top: 1px solid var(--border);
  background: var(--bs-tertiary-bg, #f8f9fa);
  display: flex;
  gap: .5rem;
  justify-content: flex-end;
}

/* Zonder card-markup: maak het alsnog netjes */
#exportDlg:not(.card) > #exportDlgTitle,
#importDlg:not(.card) > .title {      /* fallback titel selector */
  font-weight: 600;
  margin: .25rem .75rem .5rem;
}
#exportDlg:not(.card) label,
#importDlg:not(.card) label {
  display: flex;
  gap: .5rem;
  align-items: center;
  margin: .4rem .75rem;
}
#exportDlg:not(.card) .btn,
#importDlg:not(.card) .btn {
  margin: .5rem .4rem .6rem;
}

/* Add-point mode: show crosshair cursor over the map (exclude interactive/marker elements) */
body.addpoint-cursor #map,
body.addpoint-cursor .gm-style,
body.addpoint-cursor .gm-style *:not(.iwp-marker):not(.route-marker):not(.route-vertex):not(.segment-vertex):not(.route-handle):not([role="button"]):not(.gm-clickable):not(.gm-style-iw):not(.gm-bundled-control):not(.gm-fullscreen-control):not(.gm-svpc):not(.gm-control-active) {
  cursor: crosshair;
}

/* Strong pointer fallback for route vertices/handles and common GM overlay elements */
body.addpoint-cursor .gm-style .gm-draggable,
body.addpoint-cursor .gm-style .gm-draggable *,
body.addpoint-cursor .gm-style [draggable],
body.addpoint-cursor .gm-style svg [stroke],
body.addpoint-cursor .gm-style svg [fill],
body.addpoint-cursor .gm-style svg [cursor],
body.addpoint-cursor .gm-style img[usemap],
body.addpoint-cursor .gm-style canvas.gmnoprint {
  cursor: pointer !important;
}
