/* --- MODERN & CLEAN RESET --- */
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  scrollbar-gutter: stable;
}

body {
  min-height: 100vh;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  /* Jouw specifieke styling */
  display: flex;
  justify-content: center;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background-color: #191919;
  color: #ffffff;
  padding: 15px;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}

/* --- TABEL RESET (Geoptimaliseerd voor dashboards) --- */

.table-wrapper {
  width: 100%;
  overflow-x: auto; /* De redding voor mobiel */
  -webkit-overflow-scrolling: touch;
  margin-bottom: 1rem;
}

table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  text-align: left;
  /* Veranderd naar auto zodat kolommen meebewegen met data */
  table-layout: auto; 
}

/* Reset alle browser-stijlen voor tabelonderdelen */
thead, tbody, tfoot, tr {
  vertical-align: inherit;
}

th, td {
  font-weight: normal;
  vertical-align: top;
  text-align: inherit;
}

.text-right{
  text-align: right!important;
  padding-right: 8px;
}
.text-center{
  text-align: center!important;
}
.text-left{
  text-align: left!important;
  padding-right: 8px;
}
/* --- LAYOUT COMPONENTEN --- */

.container {
  width: 100%;
  max-width: 900px;
  background-color: #2a2a2a;
  padding: 20px;
  border-radius: 15px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.3);
  /* 'hidden' verwijderd: dit veroorzaakt vaak verticale afsnijdingen */
  overflow: visible; 
  /* Zorgt dat container meegroeit */
  display: flow-root; 
}

#portal {
  width: 100%;
  padding: 6px 12px;
  background-color: #2ecc71;
  border: none;
  color: #2a2a2a;
  font-weight: bold;
  cursor: pointer;
  border-radius: 4px;
  font-size: 0.825rem;
  transition: opacity 0.2s;
}

#portal:hover {
  opacity: 0.9;
}

/* --- RESPONSIVE FINETUNING --- */
@media screen and (max-width: 600px) {
  .container {
    padding: 15px;
    border-radius: 0; /* Bespaart ruimte op mobiel */
  }
  
  th, td {
    padding: 8px 4px; /* Iets compacter op mobiel */
  }
}