@import url('open-iconic/font/css/open-iconic-bootstrap.min.css');

/* =========================
   1) Tokens / basis
   Zoom‑proof + schaalbaar met clamp()
   ========================= */
:root{

  /* ---------- Achtergrond & merk ---------- */
  --page-bg: #dde1e7;       /* algemene app achtergrond */

  --brand-900: #003a74;     /* donkerblauw */
  --brand-600: #297dd1;     /* accent/blauw */

  /* ---------- Sidebar breedtes ---------- */
  --sidebar-expanded: 12%;     /* brede staat */
  --sidebar-collapsed: 3.5%;   /* smalle staat */
  --sidebar-w: var(--sidebar-expanded);

  /* ---------- Spacing (zoom‑proof) ---------- */
  /* Vervangt pure vw → stabiel bij browser zoom */
  --gap: clamp(8px, 1vw, 14px);          /* ruimte tussen tiles */
  --shell-pad: clamp(10px, 1vw, 20px);   /* padding in main + sidebar */
  --tile-pad: clamp(10px, 0.9vw, 18px);  /* interne padding van tiles */

  /* ---------- Tile styling ---------- */
  --tile-bg: var(--brand-900);
  --tile-border: rgba(255,255,255,0.35);

  /* Hoekradius en schaduw: clamp om zoom‑break te voorkomen */
  --tile-radius: clamp(4px, 0.35vw, 10px);
  --tile-shadow: 0 6px 14px rgba(0,0,0,0.12);

  /* ---------- Typografie (schaalbaar + leesbaar) ---------- */
  --page-title: clamp(18px, 1.6vw, 34px);
  --page-subtitle: clamp(12px, 1.0vw, 18px);
  --tab-font: clamp(12px, 0.95vw, 18px);

  --tile-title: clamp(12px, 1.0vw, 18px);
  --tile-value: clamp(16px, 2.2vw, 44px);

  /* ---------- Hoogteverdeling (optioneel, nog niet actief gebruikt) ---------- */
  --header-block: 14%;     /* hoogte header + tabs */
  --content-block: 86%;    /* hoogte inhoudsgebied */

  /* =========================
     Tabs + oppervlakte / pagina
     ========================= */

  /* Inactieve tabs */
  --tabbar-bg: #00509e;  
  --tabbar-border: rgba(0,0,0,0.18);

  --tab-inactive-bg: var(--tabbar-bg);
  --tab-inactive-text: rgba(255,255,255,0.95);

  /* Actieve tab = zelfde kleur als surface */
  --page-surface-bg: #f7f8fa;      /* bijna wit (papier) */
  --tab-active-bg: var(--page-surface-bg);
  --tab-active-text: var(--brand-900);

  /* Paneel / pagina achter tiles */
  --page-surface-radius: clamp(4px, 0.35vw, 10px);
  --page-surface-pad: clamp(10px, 0.9vw, 22px);
  --page-surface-shadow: 0 6px 18px rgba(0,0,0,0.10);

  /* Tab‑afronding */
  --tab-radius: clamp(3px, 0.28vw, 8px);
}

/* Sidebar collapsed overschrijft alleen de breedte-token */
body.sidebar-collapsed{
  --sidebar-w: var(--sidebar-collapsed);
}


/* =========================
   2) Reset / global (zoom‑proof)
   ========================= */
*{ box-sizing: border-box; }

html, body{
  margin: 0;
  padding: 0;
  height: 100%;
  background: var(--page-bg);
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

/* Voorkom horizontale "1px" scroll door vw/rounding */
body{
  overflow-x: hidden;
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: #0071c1;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #00509e;
}

.content {
    padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid red;
}

.validation-message {
    color: red;
}

#blazor-error-ui {
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.loading-progress {
    position: relative;
    display: block;
    width: 8rem;
    height: 8rem;
    margin: 20vh auto 1rem auto;
}

.loading-progress circle {
        fill: none;
        stroke: #e0e0e0;
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

.loading-progress circle:last-child {
            stroke: #1b6ec2;
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    position: absolute;
    text-align: center;
    font-weight: bold;
    inset: calc(20vh + 3.25rem) 0 auto 0.2rem;
}

    .loading-progress-text:after {
        content: var(--blazor-load-percentage-text, "Loading");
    }

    /** CUSTOM CSS OWN ADITION **/

    .loading-overlay {
        position: fixed;
        top: 0px;
        left: 0;
        width: 100%;
        height: 100%;
        backdrop-filter: blur(5px);
        background-color: rgba(255, 255, 255, 0.5);
        z-index: 9999;
        display: flex;
        justify-content: center;
        align-items: center;
    }

.spinner{
    background-image: url("../images/33568_Rehydro_Logo_RGB.svg");
    background-repeat: no-repeat;
    background-size: 64px 64px;
    top: calc(50vh - 64px);
    left: 50vw;
    width: 64px;
    height: 64px;
    animation: spin 1s linear infinite;
    position: absolute;
    
}

.small-spinner{
    background-image: url("../images/33568_Rehydro_Logo_RGB.svg");
    background-repeat: no-repeat;
    background-size: 30px 30px;
    width: 30px;
    height: 30px;
    animation: spin 1s linear infinite;
    animation: spin 700ms linear infinite;
    top: 40%;
    bottom: 55%;
}

@keyframes spin{
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/** Custom scrollbar **/

::-webkit-scrollbar{
    width: 7px;
}

::-webkit-scrollbar-track{
    box-shadow: inset 0 0 5px grey;
    border-radius: 10px;
}

::-webkit-scrollbar-thumb{
    background: #0d6ecf33;
    border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover{
    background: rgb(0, 104, 173);
}


/*********************/

/*****tooltip********/

.custom-tooltip {
    position: fixed;
    background-color: #297dd1;
    color: white;
    border: 1px solid #ccc;
    border-radius: 8px;
    padding: .25em;
    z-index: 1000;
    pointer-events: none;
}

.quickgrid tbody tr:not(:has(td:not(:empty))) {
    display: none;
}


/**Layout V2**/
/* =========================
   3) Shell layout (zoom‑proof)
   Sidebar + main vullen het scherm
   ========================= */
.app-shell{
  /* 100dvh = dynamische viewport hoogte (stabieler bij zoom/adresbalk) */
  min-height: 100dvh;
  height: 100dvh;
  width: 100%;

  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  background: var(--page-bg);

  /* voorkomt dat children buiten de grid duwen */
  min-width: 0;
}

/* Sidebar */
.app-sidebar{
  background: var(--brand-900);
  color: #fff;
  padding: var(--shell-pad);

  display: flex;
  flex-direction: column;

  /* vh → clamp voor stabiel gedrag bij zoom */
  gap: clamp(8px, 1vh, 12px);

  height: 100vh;
  min-width: 0;
}

/* Sidebar header */
.sidebar-header{
  display: flex;
  align-items: center;
  justify-content: space-between;

  /* vw → clamp */
  gap: clamp(8px, 0.8vw, 14px);
  flex: 0 0 auto;
}

.sidebar-brand{
  display: flex;
  align-items: center;
  gap: clamp(6px, 0.6vw, 12px);
  min-width: 0;
}

.sidebar-title{
  font-weight: 700;
  font-size: clamp(12px, 1.0vw, 18px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-toggle{
  width: clamp(34px, 2.8vw, 30px);
  height: clamp(34px, 2.8vw, 30px);

  display: grid;
  place-items: center;

  /* vw radius → clamp (of token, als je wil) */
  border-radius: clamp(6px, 0.8vw, 12px);
  border: 1px solid rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.10);
  color: #fff;
}

/* Sidebar nav */
.sidebar-nav{
direction: rtl;
  flex: 1 1 auto;
  min-height: 0;

  display: flex;
  flex-direction: column;

  gap: clamp(6px, 0.5vh, 10px);

  overflow: auto;
  padding-right: clamp(6px, 0.4vw, 10px);
}


.sidebar-nav > * {
  direction: ltr;
}


/* Links */
.sidebar-link{
  display: flex;
  align-items: center;

  color: #fff;
  text-decoration: none;

  /* vw padding/radius → clamp */
  padding: clamp(8px, 0.6vw, 12px) clamp(10px, 0.8vw, 14px);
  border-radius: clamp(6px, 0.6vw, 10px);

  opacity: 0.92;
}

.sidebar-link-text{
  color: #fff;
}

.sidebar-link:hover{
  background: rgba(255,255,255,0.12);
  opacity: 1;
  color: #fff;
}

.sidebar-link.active{
  background: rgba(255,255,255,0.18);
  font-weight: 600;
}

/* Footer */
.sidebar-footer{
  margin-top: auto;
  padding-top: clamp(8px, 1vh, 14px);
  border-top: 1px solid rgba(255,255,255,0.25);

  display: flex;
  flex-direction: column;
  gap: clamp(8px, 0.8vh, 12px);
  flex: 0 0 auto;
}

.sidebar-footer-actions{
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 0.8vh, 12px);
}

.sidebar-footer-meta{
  font-size: clamp(10px, 0.9vw, 14px);
  line-height: 1.2;
  opacity: 0.95;
}

/* =========================
   4) Collapsed: alleen toggle zichtbaar
   ========================= */
body.sidebar-collapsed .sidebar-brand,
body.sidebar-collapsed .sidebar-nav,
body.sidebar-collapsed .sidebar-footer{
  display: none !important;
}

body.sidebar-collapsed .app-sidebar{
  align-items: center;
  justify-content: flex-start;

  /* werkt goed met jouw clamp-based --shell-pad */
  padding: calc(var(--shell-pad) * 0.6);
}

body.sidebar-collapsed .sidebar-header{
  width: 100%;
  justify-content: center;
}

/* =========================
   5) Main area: één scherm, geen scroll
   ========================= */
.app-main{
  height: 100vh;
  min-width: 100vw;

  /* belangrijk om children te laten krimpen binnen flex */
  min-height: 0;

  padding: var(--shell-pad);

  display: flex;
  flex-direction: column;

  /* vh → clamp (zoom‑proof) */
  gap: clamp(8px, 0.8vh, 12px);

  overflow: hidden; /* 1 scherm (scroll beheren we lager in de boom) */
}

/* Optionele topbar uitzetten */
.app-shell[data-has-topbar="false"] .app-topbar{
  display: none;
}

/* Page header */
.page-header{
  flex: 0 0 auto;
  min-height: 0;
}

.page-title{
  margin: 0;
  font-size: var(--page-title);
  font-weight: 800;
  line-height: 1.1;
  color: var(--brand-900);
}

.page-subtitle{
  margin: 0.2em 0 0;
  font-size: var(--page-subtitle);
  color: rgba(0,0,0,0.65);
}


/* =========================
   6) Tabs — strak zonder blauwe balk (zoom‑proof)
   ========================= */

.tabs{
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0; /* geen ruimte nodig */
}

/* Geen blauwe balk meer: alleen tabs zelf */
.tablist{
  display: flex;
  align-items: flex-end;

  background: transparent;
  border-radius: 0;
  box-shadow: none;

  padding: 0;

  /* vw → clamp voor zoom‑stabiliteit */
  gap: clamp(4px, 0.35vw, 10px);

  overflow: visible;
}

/* Tab: inactief = blauw */
.tab{
  font-size: var(--tab-font);

  /* padding in em is al zoom‑vriendelijk */
  padding: 0.5em 1.0em;

  color: var(--tab-inactive-text);
  background: var(--tab-inactive-bg);

  border: 1px solid rgba(0,0,0,0.12);
  border-bottom: none;

  border-top-left-radius: var(--tab-radius);
  border-top-right-radius: var(--tab-radius);

  cursor: pointer;
  position: relative;
}

/* Hover alleen op apparaten waar hover bestaat */
@media (hover: hover) and (pointer: fine){
  .tab:hover{
    filter: brightness(1.05);
  }
}

/* Actieve tab = surface kleur + donkerblauw tekst (zelfde font-weight) */
.tab.active{
  background: var(--tab-active-bg);
  color: var(--tab-active-text);

  border-color: var(--tabbar-border);
  z-index: 2;

  transform: none;
}

/* Naadloos aansluiten op panel (geen randje zichtbaar) */
.tab.active::after{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 2px;
  background: var(--tab-active-bg);
}

/* Focus: clamp zodat dikte stabiel blijft bij zoom */
.tab:focus-visible{
  outline: clamp(2px, 0.2vw, 4px) solid rgba(0,80,158,0.35);
  outline-offset: clamp(1px, 0.1vw, 3px);
}

/* Page/surface achter tiles */
.tabpanel-wrap{
  flex: 1 1 auto;
  min-height: 0;

  background: var(--page-surface-bg);
  border: 1px solid var(--tabbar-border);
  border-top: none;

  border-radius: 0 0 var(--page-surface-radius) var(--page-surface-radius);
  box-shadow: var(--page-surface-shadow);

  padding: var(--page-surface-pad);

  overflow: hidden; /* houdt 1-screen strak */
}

.tabpanel[hidden]{
  display: none;
}

.tabpanel{
  height: 100%;
  min-height: 0;

  display: flex;
  flex-direction: column;

  /* vh → clamp */
  gap: clamp(6px, 0.6vh, 10px);
}

.panel-header{
  flex: 0 0 auto;
}

.panel-title{
  margin: 0.3em 0 0;
  font-size: clamp(14px, 1.2vw, 22px);
  font-weight: 800;
  color: var(--brand-900);
}

.panel-subtitle{
  margin: 0.1em 0 0;
  font-size: clamp(11px, 1.0vw, 16px);
  color: rgba(0,0,0,0.65);
}

.panel-content{
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden; /* 1 scherm */
}

/* =========================
   7) Dashboard grid (vaste compositie, geen herschikking)
   Zoom‑proof spacing
   ========================= */
.dashboard-grid{
  height: 100%;
  width: 100%;

  display: grid;
  gap: var(--gap);

  grid-template-columns: repeat(var(--grid-cols, 12), 1fr);
  grid-template-rows: repeat(var(--grid-rows, 6), 1fr);

  min-width: 0;
  min-height: 0;
}

/* =========================
   8) Tiles
   Alles past in vakken: clamp + ellipsis + line-clamp
   ========================= */
.tile{
  background: var(--tile-bg);
  color: #fff;
  border: 1px solid var(--tile-border);
  border-radius: var(--tile-radius);
  box-shadow: var(--tile-shadow);

  padding: var(--tile-pad);

  display: flex;
  flex-direction: column;
  justify-content: space-between;

  /* vh → clamp voor zoom-stabiliteit */
  gap: clamp(6px, 0.6vh, 10px);

  min-width: 0;
  min-height: 0;

  /* spans (via inline css vars per tile) */
  grid-column: span var(--col-span, 3);
  grid-row: span var(--row-span, 1);
}

/* ✅ Belangrijk: als tile een <a> is, behoud layout + voorkom default linkkleuren */
a.tile{
  display: flex;              /* <a> is standaard inline -> dit fixeert "opmaak kwijt" */
  flex-direction: column;
  justify-content: space-between;
  gap: clamp(6px, 0.6vh, 10px);

  text-decoration: none;      /* underline weg */
  color: #fff;                /* expliciet wit (overschrijft bootstrap linkkleur) */

  /* optioneel: netter op mobile */
  -webkit-tap-highlight-color: transparent;
}

/* Zorg dat visited links ook niet paars/blauw worden */
a.tile:visited{
  color: #fff;
}

/* (Optioneel) ook bij hover/active dezelfde tekstkleur houden */
a.tile:hover,
a.tile:active{
  color: #fff;
}

/* Klikbare tiles (alleen voor tiles die je echt als link wil gebruiken) */
.tile--link{
  cursor: pointer;
  position: relative; /* nodig voor overlay */
  transition: border-color 140ms ease;
}

/* Subtiele "oplicht" overlay (geen beweging) */
.tile--link::before{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: rgba(255,255,255,0.06);
  opacity: 0;
  transition: opacity 140ms ease;
  pointer-events: none;
}

/* Hover alleen op apparaten waar hover bestaat (desktop/muis) */
@media (hover: hover) and (pointer: fine){
  .tile--link:hover::before{
    opacity: 1;
  }

  .tile--link:hover{
    border-color: rgba(255,255,255,0.55);
  }
}

/* Toegankelijkheid: focus zichtbaar + ook oplichten (vw → clamp) */
.tile--link:focus-visible{
  outline: clamp(2px, 0.22vw, 4px) solid rgba(41,125,209,0.55);
  outline-offset: clamp(2px, 0.18vw, 4px);
}

.tile--link:focus-visible::before{
  opacity: 1;
}

/* Titel: max 2-3 regels, daarna ellipsis */
.tile-title{
  font-size: var(--tile-title);
  font-weight: 800;
  line-height: 1.15;

  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Value: altijd in één regel en schaalt mee */
.tile-value{
  font-size: var(--tile-value);
  font-weight: 900;
  line-height: 1.0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Alert rood bij controle != 0 */
.tile-value--alert{
  color: #ff3b3b;
}

/* Body: voor charts/lijsten */
.tile-body{
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  font-size: clamp(12px, 1.0vw, 18px);
  opacity: 0.95;
}

.tile-body--placeholder{
  display: grid;
  place-items: center;
  border: 1px dashed rgba(255,255,255,0.45);

  /* vw → clamp zodat radius stabiel blijft bij zoom */
  border-radius: clamp(4px, 0.5vw, 10px);
}


/* Zorg dat de tile een echte hoogte context is */
.tile--chart{
  display: flex;
  flex-direction: column;
  min-height: 0;     /* belangrijk in grid/flex combinaties */
}

/* Inner wrap vult de beschikbare hoogte van de tile */
.tile--chart .chart-wrap{
  flex: 1 1 auto;
  min-height: 0;
  padding-top: 20px;
  padding-left: 20px;

  /* dit is jouw “max-height relatief aan tile” */
  max-height: 100%;
  overflow: hidden; /* of auto als je liever binnen de tile wilt scrollen */
}

/* Canvas neemt de ruimte van de wrapper */
.tile--chart canvas{
  width: 100%;
  height: 100%;
  display: block;
}


/* To-do list voorbeeld */
.todo-list{
  margin: 0;
  padding-left: 1.1em;
  line-height: 1.35;
  font-size: clamp(12px, 1.0vw, 18px);
  overflow: hidden;
}

/* =========================
   9) Map
   ========================= */


.map-layout {
    display: grid;
    grid-template-columns: 250px 1fr;
    gap: 1rem;
    height: 100%;
}


/* Linkerkant: legenda */

.legend {
    display: flex;
    flex-direction: column;
}


.legend-title {
    margin-bottom: 6px;
}


.legend-row {
    display: flex;
    align-items: center;
    margin-bottom: 6px;
}



.legend-color {
    width: 14px;
    height: 14px;
    border-radius: 2px;
    margin-right: 8px;
}


.legend-name {
    flex: 1;
}

/* Rechterkant: kaart */
.map-area {
    /* flex: 1; /* gelijk aan col-9 
    display: flex; */
    height: 100%;
}


