/* General */
body{
  margin: 0;
  padding: 0;
  background: var(--light-xs);
}
img{ max-width:100% }
* {
  font-family: system-ui;
  font-optical-sizing: auto;
  box-sizing: border-box;
}
.page-content :is(p,li,ul,ol) {line-height:26px }
.ml-auto{ margin-left: auto }
.mr-auto{ margin-right: auto }
section{ margin-bottom:40px; }
section:last-child{ margin-bottom:0px; }

main{ 
  min-height: calc(100vh - 145px);  
}
/* Menu */
.menu-container{
  background: var(--extra-light);
  position: sticky;
  top:0;
  width: 100%;
  padding: 0 30px;
  box-shadow: var(--box-shadow);
  z-index: 9;
}
.menu-container.footer{
  top:inherit;
  bottom:0;
  background: var(--dark);
  justify-content: center;
  align-items: center;
  display: flex;
  padding: 10px;
}
.social-links{ 
  display:flex;
  gap: 20px 
}
.social-links svg{
  width: 40px;
}
.social-links a{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;  
  color:white;
}
.social-links svg *{ fill:white }
.menu-container .bars{ display:none }
.menu-container .menu .ml-auto,
.menu-container .menu{
  display: flex;
  gap: 10px;
  padding: 10px 0;
  align-items: center;
}
.category-tree{ 
  padding-left: 0;
  background: var(--extra-light);
  padding: 10px 12px;
  border-radius: 10px;
}
.category-tree li.bigger{
  font-size: 28px;
  border-bottom: 2px solid rgba(0, 0, 0, .05);
  padding-bottom: 8px;
  text-align: center;  
}
.category-tree.pages{
  background: white;
  padding: 0;
}
.category-tree.pages li{ margin-bottom: 0 }
.category-tree.pages li h2{
  color:var(--dark);
  transition: var(--tr);
}
.category-tree.pages li:hover h2{ color:var(--red) }
.category-tree.pages li a{ 
  padding: 0 0 40px 0;
  color:var(--dark);
}
.category-tree.pages li:last-child a{ padding-bottom:0 }
.category-tree.pages li a span.description {
  padding: 6px 0 2px 0;
}
.category-tree li{
  margin-bottom: 6px;
  list-style: none;
  margin-bottom: 10px;
  color: var(--dark);
}
.related-categories{
  border-radius: 10px;
  background: var(--light-xs);
  padding: 20px;  
}
.category-tree li:last-child{ margin-bottom:0 }
.related-categories a,
.category-tree li a{
  padding: 8px 12px;
  display: flex;
  color: var(--dark);
  flex-direction: column;
  font-size: 18px;
  border-radius: 4px;
}
.related-categories a{ color:white }
.category-tree li a,
.breadcrumb li a{
  background: linear-gradient(to right, var(--red) 50%, transparent 50%);
  background-size: 210% 110%;
  background-position: right bottom;
  transition: background-position 0.2s ease, color 0.2s ease;  
}
.related-categories a{
  background: linear-gradient(to right, var(--red) 50%, var(--dark) 50%);
  background-size: 210% 100%;
  background-position: right bottom;
  transition: background-position 0.3s ease, color 0.3s ease;  
}
.related-categories .links{
  display: flex;
  gap: 10px;
}
.category-tree li a span.description{
  padding: 6px 0 2px 19px;
  font-size: 15px;  
}
.category-tree li.active a,
.category-tree:not(.pages) li a:hover,
.related-categories a:hover,
.breadcrumb li a:hover{
  color: white;
  background-position: left bottom;
}
.menu-container img.logo{
  width: 65px;
  height: 65px;
  margin: 10px 10px 10px 0;
  float: left;
}
.menu-container .menu a.item{
  height: 45px;
  background: var(--dark);
  transition: var(--tr);
  display: flex;
  justify-content: left;
  align-items: center;
  color: white;
  text-decoration: none;
  padding: 0 24px;
  line-height: 45px;
  border-radius: 4px;
}
.menu a.item span.menu-icon svg{
  width: 20px;
  height: 20px;
  margin: 2px 10px -2px -8px;  
}
a.item span.chevron svg{
  width: 14px;
  margin: 0 -14px 0 6px;
  height: 14px;  
  transform: rotate(-90deg);
  transition: var(--tr);  
}
.menu-container li:hover > a.item span.chevron svg {
  transform:rotate(0deg);
}
.menu a.item span.menu-icon svg *,
a.item span.chevron svg *
{ 
  fill: white;
  transition: var(--tr);
}
.menu-container .menu a.item[data-active],
.menu-container .menu li:has(a[data-active]) > a.item{
  background: var(--red)!important;
}
.menu-container .menu :is(a.active, a.item:hover){
  background: rgba(0,0,0,.6);
}
.menu-container ul{
  padding: 0;
  list-style: none;
  margin: 0;
}
.menu-container ul.submenu{
  display: none;
  position: absolute;
  z-index: 1000;
  flex-direction: column;
  align-items: stretch;
  min-width: max-content;
}
ul.categories{
  display: flex;
  gap: 10px;
}
.menu-container ul.submenu ul.submenu{
  left: calc(100%);
  padding-left: 6px;
  top:0;
}
.menu-container ul.submenu >li{ position:relative; }
.menu-container li:hover > ul.submenu {
  display: flex;
}
.menu-container .menu ul.submenu a.item{
  background: var(--medium);
  margin-top: 6px;
  font-size: 14px;
  height: 40px;  
}
.menu-container .menu ul.submenu a.item:hover{
  background: var(--red);
}

/* Containers */
.container{
  max-width: 1270px;
  margin: 0 auto;
  padding: 0 30px;
}
.container.xs{ max-width: 650px }

/* Page Blocks */
.page-block{
  padding:20px 25px;
  display: block;
}
a.page-block{  
  background: var(--medium-dark);
  color: white;  
}

/* Breadcrumbs */
.breadcrumb {
  font-size: 16px;
  background: var(--extra-light);
  padding: 10px 12px;
  border-radius: 10px;
  overflow: auto;
  white-space: nowrap; 
}
.breadcrumb ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}
.breadcrumb li {
  display: flex;
  align-items: center;
  position: relative;
}
.breadcrumb li + li::before {
  content: "→";
  margin: 0 5px;
  font-weight: bold;
  color: var(--dark);     
}
.breadcrumb li a {
  text-decoration: none;
  font-weight: 600;
  padding: 6px 12px;
  color: var(--dark);     
}
.breadcrumb li span {
  font-weight: 600;
  padding-left: 5px;
  color: var(--dark);     
}

/* Styling voor het icoon */
.breadcrumb i {
  margin-right: 5px;
  font-size: 16px;
  transition: color 0.3s ease;
}


/* Active breadcrumb styling */
.breadcrumb li:last-child a {
  pointer-events: none; /* voorkomt dat de laatste link klikbaar is */
}

.breadcrumb li:last-child span {
  font-weight: 400;
  padding: 6px 12px;
}

/* Shadow and border radius */
.sabr{
  border-radius: 3px;
  box-shadow: var(--box-shadow);
}

/* Forms */
.form-style{
  padding: 40px 30px 30px 30px;
  background: white;
  box-shadow: var(--box-shadow);
  border-radius: 4px;
}
.outer-yeld-container{
  padding: 30px 0;
}
.breadcumbr-icon{
  display: flex;
}
.breadcumbr-icon svg{
  width: 33px;
  height: 33px;
  margin-right: 6px;
}
textarea,
select,
input[type="email"],
input[type="password"],
input[type="text"]{
  width: 100%;
  line-height: 40px;
  padding: 0 20px;
  border-radius: var(--br);
  border: 1px solid var(--extra-light);
}
textarea{
  line-height: 22px;
  padding: 10px 20px;  
}
select{
  width: 300px;
  line-height: 42px;
  height: 42px;  
}
.field{
  display: flex;
  gap: 10px;
  margin-bottom: 25px;
  align-items: center;
}
.field:has(textarea),
.field:has(select[multiple]){
  align-items: baseline;
}
.field label{ 
  width:240px;
  flex-shrink: 0;
}
select[multiple]{ 
  height:auto;
  padding: 10px;
}
.btn,
input[type="submit"]{
  line-height: 40px;
  padding: 0 20px;
  border: none;
  background: var(--red);
  color:white;
  font-size: 16px;
  display: inline-block;
  filter: brightness(1);    
  transition: filter 0.2s ease;  
}
.btn:hover,
input[type="submit"]:hover{
  cursor: pointer;
  filter: brightness(1.1);  
}
.btn.success{ background:var(--success) }
.btn.primary{ background:var(--blue) }
table .btn{
  padding: 0 12px;
  font-size: 14px;
  line-height: 32px;
}
a{ 
  text-decoration:none;
  color:var(--blue);
}
.shared-links{ margin-top: 15px }
.shared-links a{ 
  color: var(--dark-red);
  text-decoration: none;
  font-size: 14px;
}
.col-center-horizontally{
  display: flex;
  justify-content: center;
  height: 100%;
}
/* Flash messages */
.flash-messages{
  position: fixed;
  z-index: 19;
  top: 120px;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: end;  
}
.flash-messages .flash{
  right: -100%;
  padding: 10px 20px;
  color: white;
  background: var(--dark);  
  transition: var(--tr);
  margin-top: 6px;
  position: relative;
  box-shadow: var(--box-shadow);
  width: fit-content;
  border-radius: 0;
}
.flash-messages .flash.success{ background:var(--success) }
.flash-messages .flash.danger{ background:var(--red) }
.flash-messages .flash.active{
  right: 0;
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  font-family: sans-serif;
  font-size: 14px;
  background-color: white;
  overflow: hidden;
}

table th {
  background-color: var(--dark);
  color:white;
  font-size: 16px;
}

th, td {
  padding: 8px 16px;
  text-align: left;
  border-bottom: 1px solid #ddd;
}

td.actions,
th.actions {
  white-space: nowrap;
  width: 1%;
  text-align: right;
}

tr:hover {
  background-color: #f9f9f9;
}

table tr[data-dept="1"] td:first-child{ padding-left:32px }
table tr[data-dept="2"] td:first-child{ padding-left:52px }
table tr[data-dept="3"] td:first-child{ padding-left:72px }
table tr[data-dept="4"] td:first-child{ padding-left:92px }
table tr[data-dept="5"] td:first-child{ padding-left:112px }

th {
  font-weight: 600;
  color: #333;
}

td {
  color: #555;
}
.youtube-image {
  position: relative;
  width: 100%;
  border-radius: 10px;
  padding-top: 56%; /* 9 / 16 = 0.5625 */
  overflow: hidden; /* alles buiten de ratio wordt afgesneden */
}
.youtube-image svg{
  position: absolute;
  z-index: 3;
  width: 60px;
  height: 60px;
  top: calc(50% - 30px);
  left: calc(50% - 30px);  
}
.youtube-image svg *{ fill: var(--extra-light) }
.youtube-image:before{
  content: '';
  background: var(--extra-light);
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0%;
  left: 0%;
  opacity: .4;
  z-index: 1;
  transition: var(--tr);
}
.category-tree li a:hover .youtube-image:before{ opacity:0 }

.youtube-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; /* belangrijkste: vult de container, snijdt de zwarte balken af */
  object-position: center; /* centrum van het beeld */
}
.video-embed{
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 10px;
  overflow: hidden;
  background-size: 100%;
}
.video-embed[data_source]:hover{
  cursor: pointer;
}
.video-embed iframe{
  width: 100%;
  height: 100%;
  border: 0;
}
.link-details{ position:relative; }
.link-details:has(.youtube-image) .stats{ 
  position: absolute;
  bottom: 0;
  z-index: 2;
  width: 100%;
  border-radius: 0 0 10px 10px;
}
.stats{
  background: var(--dark);  
  display: flex;
  align-items: center;
  height: 40px;
  padding: 6px 12px;
  width: 100%;
  gap: 8px;
  color: white;  
  border-radius: 10px;
}
.category-tree .stats{
  background: var(--extra-light);
  color: var(--dark);
}
.stats svg{
  height: 20px;
}
.stats svg * {
  fill: var(--extra-light);
}
.link-details .stats svg *{
  fill: var(--dark);
}
.stats .ml-auto{
  display: flex;
  gap: 6px;
  align-items: center;  
}
td .stats{ margin-top: 6px }

.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin: 2rem 0;
  font-family: Arial, sans-serif;
  font-size: 14px;
}

.pagination a,
.pagination span,
.pagination em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: 6px;
  text-decoration: none;
  color: lightcoral;
  background-color: #f8f9fa;
  border: 1px solid var(--light-xs);
  transition: background-color 0.2s, color 0.2s;
}

.pagination a:hover {
  background-color: var(--red);
  color: #fff;
}

.pagination em.current {
  background-color: var(--red);
  color: #fff;
  font-weight: bold;
  cursor: default;
}

.pagination span.disabled {
  color: var(--medium);
  cursor: not-allowed;
  background-color: #e9ecef;
}

.pagination a.next_page,
.pagination a[rel="next"] {
  font-weight: bold;
}

.pagination a.previous_page,
.pagination a[rel="prev"] {
  font-weight: bold;
}

@media screen and (max-width: 768px){
  .menu-container{
    position: fixed;
    top: 0;
  }
  .outer-yeld-container{ padding: 85px 0 0 0 }
  .form-style{ 
    padding: 20px;
    box-shadow: none;
  }
  .container{ padding: 0 }
  h2{ font-size:20px }

  .menu-container .menu{
    flex-direction: column;
    align-items: flex-end;
    position: fixed;
    right: -100%;
    padding: 20px;
    background: var(--extra-light); 
    max-width: 100%;  
    transition: var(--tr); 
    top: 85px;
    overflow: auto;
    height: calc(100vh - 145px); 
  }
  .menu-container.active .menu{ right:0 }
  .menu-container :is(ul, li, .menu a.item){
    width: 100%;
  }
  main{ padding-bottom:50px }
  .menu-container .menu .ml-auto{
    padding:0;
    flex-direction: column;
    width: 100%;
  }
  ul.categories{
    flex-direction: column;
  }
  .menu-container li ul.submenu{
    position: relative;
    display: flex;
    left:0;
    padding-left:20px;
  }
  .menu-container ul.submenu ul.submenu{
    left:0;
    padding-left:20px;
  }
  .menu-container .bars{ 
    display: inline-block;
    float: right;
    margin-top: 20px;    
  }
  .menu-container .bars svg{
    width: 40px;
  }
  .menu-container .bars svg *{
    fill: var(--dark);
  }
  .menu-container.footer .social-links span{ display:none }
}