/* reset.css
   Basis reset / sensible defaults
   - zet box-sizing
   - verwijdert standaardmarges/padding
   - zorgt dat formulieritems lettertype erven
   - maakt media en tabellen responsief
*/

/* 1) box-sizing - makkelijkere layoutberekeningen */
*, *::before, *::after {
  box-sizing: border-box;
}

/* 2) basis voor html/body */
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
  line-height: 1.4; /* basis leesbaarheid */
  -webkit-text-size-adjust: 100%; /* voorkomen van font-zoom op iOS */
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
}

/* 3) typografie - laat lettertypes later bepalen door jouw stylesheet */
body {
  font-family: inherit;
  color: inherit;
  background: transparent;
}

/* 4) lijsten, kopjes en paragrafen */
h1, h2, h3, h4, h5, h6, p {
  margin: 0;
  font-weight: inherit;
}

/* 5) links - geen opdringerige linkstijl, maar behoud focus voor accesibility */
a {
  color: inherit;
  text-decoration: none;
  background-color: transparent;
}
a:active, a:hover {
  outline: none;
}

/* 6) afbeeldingen en media - schaalbaar en blok-level zodat geen gap onder afbeeldingen */
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* 7) formulieren - erven lettertype en baseline instellingen */
input, button, textarea, select {
  font: inherit;
  color: inherit;
  margin: 0;
  background: none;
  border: none;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* maar behoud standaard button-rol visueel in jouw theme - voeg in jouw styles later knoppenstijl toe */

/* 8) buttons - toegankelijkere focus voor toetsenbordgebruikers */
button {
  cursor: pointer;
  background: transparent;
  border: none;
  padding: 0;
}

/* focus-visible: toon alleen focus wanneer relevant (keyboard) */
:focus:not(:focus-visible) {
  outline: none;
}
:focus-visible {
  outline: 2px solid #000;
  outline-offset: 2px;
}

/* 9) lijsten */
ul, ol {
  margin: 0;
  padding: 0;
}

/* 10) tabellen */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* 11) semantische HTML5 elementen: zet consistente display waarden */
main, header, nav, section, article, aside, footer, figure, figcaption {
  display: block;
}

/* 12) utilities / kleine defaults */
hr {
  height: 0;
  border: 0;
}

/* 13) hidden attribute */
[hidden] {
  display: none !important;
}

/* 14) prevent overflow on root for mobile */
html, body {
  overflow-x: hidden;
}

/* --- Optioneel: snelle helper voor visually-hidden (screenreader-only) --- */
.sr-only {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}