:root{
  --blue:#0b2cff;
  --blue-dark:#070a2b;
  --text:#0e1020;
  --muted:#5b617a;
  --card:#ffffff;
  --border:#e8e8ef;
  --bg:#ffffff;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;background:var(--bg);color:var(--text)}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 18px}
.topbar{
  background:linear-gradient(90deg,var(--blue) 0%, var(--blue-dark) 60%);
  color:#fff;
  font-weight:600;
  font-size:.95rem;
}
.topbar .row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 0}
.topbar .left, .topbar .right{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:8px}
.ico{width:18px;height:18px;display:inline-block;vertical-align:-3px}
.header{
  background:#fff;
}
.header .row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:92px;height:auto}
.nav{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  font-weight:700;
}
.nav a{padding:8px 6px;border-radius:10px}
.nav a:hover{color:var(--blue)}
.actions{display:flex;align-items:center;gap:12px}
.iconbtn{
  width:40px;height:40px;border-radius:999px;border:1px solid var(--border);
  display:inline-flex;align-items:center;justify-content:center;background:#fff;
}
.cta{
  background:var(--blue);
  color:#fff;
  padding:10px 16px;
  border-radius:12px;
  font-weight:800;
  border:1px solid rgba(0,0,0,.06);
}
.cta:hover{filter:brightness(.95)}
.main{padding:30px 0}
.two-col{display:grid;grid-template-columns:1.35fr .65fr;gap:28px;align-items:start}
@media (max-width: 980px){.two-col{grid-template-columns:1fr}}
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
}
.small{color:var(--muted);font-size:.93rem}
h1{font-size:2.0rem;margin:.2rem 0 1rem}
h2{font-size:1.55rem;margin:1.3rem 0 .6rem}
h3{font-size:1.15rem;margin:.2rem 0 .6rem}
p{line-height:1.6}
hr{border:0;border-top:1px solid var(--border);margin:14px 0}
input,textarea,select,button{font:inherit;padding:10px 12px;border-radius:10px;border:1px solid #d0d0d0;background:#fff}
button{cursor:pointer}
.badge{display:inline-block;padding:3px 10px;border:1px solid var(--border);border-radius:999px;font-size:.85rem;background:#fff}
.footer{border-top:1px solid var(--border);margin-top:32px}
.footer .row{padding:18px 0;color:var(--muted);font-size:.92rem}

/* --- Footer like screenshot --- */
.footer{
  border-top:none;
  margin-top:48px;
  background: linear-gradient(180deg, #0c0f2b 0%, #080a1d 100%);
  color:#fff;
}
.footer-top{
  padding:34px 0 10px;
}
.footer-cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap:20px;
  align-items:stretch;
}
@media (max-width: 980px){
  .footer-cards{grid-template-columns:1fr;}
}
.footer-card{
  border:1px solid rgba(255,255,255,.14);
  border-radius:14px;
  padding:18px 18px;
  display:flex;
  gap:14px;
  align-items:center;
  background: rgba(255,255,255,.02);
}
.footer-card .fi{
  width:44px;height:44px;
  border-radius:12px;
  background: rgba(11,44,255,.18);
  display:flex;align-items:center;justify-content:center;
  color: var(--blue);
}
.footer-card .ttl{font-weight:900; letter-spacing:.2px}
.footer-card .sub{opacity:.9}
.footer-bottom{
  padding:26px 0 28px;
  border-top:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.footer-bottom .row2{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.footer-logo{
  display:flex;align-items:center;gap:12px;
}
.footer-logo img{
  width:140px;
  height:auto;
  border-radius:10px;
  background: rgba(11,44,255,.18);
  padding:10px;
}
.footer-copy{
  flex:1;
  text-align:center;
  opacity:.9;
}
.footer-copy a{color: var(--blue); text-decoration:none;}

/* --- Calendar --- */
.cal-wrap{display:grid; gap:16px}
.cal-head{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap}
.cal-head .title{font-size:1.35rem; font-weight:900}
.cal-nav{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.cal-btn{border:1px solid var(--border); background:#fff; padding:8px 12px; border-radius:12px; font-weight:800}
.cal-grid{width:100%; border:1px solid var(--border); border-radius:14px; overflow:hidden; background:#fff}
.cal-grid table{width:100%; border-collapse:collapse}
.cal-grid th{background:#f5f6ff; color:#1b1f3a; font-weight:900; font-size:.9rem; padding:10px}
.cal-grid td{border-top:1px solid var(--border); border-right:1px solid var(--border); vertical-align:top; height:120px; padding:10px}
.cal-grid td:last-child{border-right:0}
.cal-daynum{font-weight:900; font-size:.95rem}
.cal-muted{opacity:.45}
.cal-today{outline:2px solid rgba(11,44,255,.35); outline-offset:-2px}
.cal-event{margin-top:8px; padding:8px 10px; border-radius:12px; border:1px solid rgba(11,44,255,.25); background:rgba(11,44,255,.06)}
.cal-event .t{font-weight:900}
.cal-event .m{font-size:.9rem; color:var(--muted); margin-top:2px}
.cal-legend{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.dot{width:10px; height:10px; border-radius:99px; background:rgba(11,44,255,.6); display:inline-block}

/* --- Calendar views (week/day) --- */
.tabs{display:flex; gap:10px; flex-wrap:wrap}
.tab{border:1px solid var(--border); padding:8px 12px; border-radius:999px; font-weight:900; background:#fff}
.tab.active{background:rgba(11,44,255,.08); border-color:rgba(11,44,255,.25); color:var(--blue)}
.week-grid{border:1px solid var(--border); border-radius:14px; overflow:hidden; background:#fff}
.week-grid table{width:100%; border-collapse:collapse}
.week-grid th{background:#f5f6ff; padding:10px; font-weight:900; border-right:1px solid var(--border)}
.week-grid th:last-child{border-right:0}
.week-grid td{border-top:1px solid var(--border); border-right:1px solid var(--border); vertical-align:top; padding:10px; min-height:120px}
.week-grid td:last-child{border-right:0}
.day-col{display:flex; flex-direction:column; gap:10px}
.event-link{display:block}
.event-link:hover .cal-event{filter:brightness(.98)}
.day-list{display:grid; gap:10px}
.kv{display:flex; gap:10px; flex-wrap:wrap}
.kv b{min-width:110px}
.modal-backdrop{position:fixed; inset:0; background:rgba(0,0,0,.45); display:none; align-items:center; justify-content:center; padding:18px; z-index:1000}
.modal{max-width:860px; width:100%; background:#fff; border-radius:18px; border:1px solid var(--border); padding:18px}
.modal-head{display:flex; align-items:flex-start; justify-content:space-between; gap:12px}
.modal-close{border:1px solid var(--border); background:#fff; border-radius:12px; padding:8px 10px; font-weight:900}

/* --- Course categories --- */
.cat-dot{width:10px;height:10px;border-radius:99px;display:inline-block;margin-right:8px;vertical-align:-1px}
.cat-EHBO{background:#0b2cff}
.cat-BHV{background:#00a3ff}
.cat-AED{background:#00c853}
.cat-OVERIG{background:#6c6f86}

.cal-event[data-cat="EHBO"]{border-color:rgba(11,44,255,.45); background:rgba(11,44,255,.06)}
.cal-event[data-cat="BHV"]{border-color:rgba(0,163,255,.45); background:rgba(0,163,255,.06)}
.cal-event[data-cat="AED"]{border-color:rgba(0,200,83,.45); background:rgba(0,200,83,.06)}
.cal-event[data-cat="OVERIG"]{border-color:rgba(108,111,134,.35); background:rgba(108,111,134,.06)}

/* --- Calendar filter --- */
.filterbar{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.chip{display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; border:1px solid var(--border); background:#fff; font-weight:900; cursor:pointer; user-select:none}
.chip input{width:auto}
.chip.active{border-color:rgba(11,44,255,.25); background:rgba(11,44,255,.06)}


/* --- Mobile menu --- */
.menu-toggle{
  display:none;
  width:44px;height:44px;
  border-radius:999px;
  border:1px solid var(--border);
  background:#fff;
  align-items:center;
  justify-content:center;
}

@media (max-width: 980px){
  .header .row{align-items:center;}
  .nav{display:none;}
  .actions .iconbtn{display:none;} /* zoekknop verbergen op mobiel (optioneel) */
  .menu-toggle{display:inline-flex;}
}

/* dropdown panel */
.mobile-nav{
  display:none;
  border-top:1px solid var(--border);
  background:#fff;
}

.mobile-nav.open{display:block;}

.mobile-nav .inner{
  padding:12px 0 18px;
  display:grid;
  gap:10px;
}

.mobile-nav a{
  padding:12px 12px;
  border:1px solid var(--border);
  border-radius:12px;
  font-weight:800;
  background:#fff;
}

.mobile-nav a.cta{
  background:var(--blue);
  color:#fff;
  border-color:rgba(0,0,0,.06);
}

/* --- Admin nav (centering + spacing) --- */
.admin-nav{
  background: transparent;
  margin: 8px 0 18px;
}
.admin-nav-inner{
  display:flex;
  gap:22px;
  flex-wrap:wrap;
  align-items:center;
  font-weight:800;
}
.admin-nav-inner a{
  text-decoration:none;
  color: inherit;
  padding: 8px 0;
}
.admin-nav-inner a:hover{
  color: var(--blue);
}

/* --- Admin menu (netjes & consistent) --- */
.admin-nav{ margin: 10px 0 18px; }
.admin-nav-inner{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
  font-weight:800;
}
.admin-nav-inner a{
  text-decoration:none;
  color: inherit;
  padding: 8px 10px;
  border-radius: 10px;
}
.admin-nav-inner a:hover{ background: rgba(11,44,255,.06); color: var(--blue); }
.admin-nav-inner a.active{ background: rgba(11,44,255,.10); color: var(--blue); }

/* --- Admin title bar --- */
.admin-topbar{
  background:#0c0f2b;
  color:#fff;
  font-size:14px;
}
.admin-topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 0;
}
.admin-title{
  font-weight:900;
  letter-spacing:.2px;
}
.admin-site{
  opacity:.8;
}

/* --- Admin nav (onder titlebar) --- */
.admin-nav{
  margin: 8px 0 18px;
}
.admin-nav-inner{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
  font-weight:800;
}
.admin-nav-inner a{
  text-decoration:none;
  color: inherit;
  padding: 8px 10px;
  border-radius: 10px;
}
.admin-nav-inner a:hover{
  background: rgba(11,44,255,.06);
  color: var(--blue);
}
.admin-nav-inner a.active{
  background: rgba(11,44,255,.12);
  color: var(--blue);
}


/* --- Admin topbar --- */
.admin-topbar{
  background:#0c0f2b;
  color:#fff;
  font-size:14px;
}
.admin-topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:10px 0;
}
.admin-left{display:flex; align-items:center; gap:14px; flex-wrap:wrap}
.admin-title{font-weight:900; letter-spacing:.2px}
.admin-back{color:#fff; opacity:.85; text-decoration:none; font-weight:800}
.admin-back:hover{opacity:1; text-decoration:underline}

.admin-right{display:flex; align-items:center; gap:12px}
.admin-meta{display:flex; gap:14px; align-items:center; flex-wrap:wrap}
.admin-user{font-weight:900}
.admin-lastlogin{opacity:.85}

.admin-theme-btn{
  border:1px solid rgba(255,255,255,.22);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:12px;
  padding:8px 10px;
  font-weight:900;
  cursor:pointer;
}

/* --- Admin menu --- */
.admin-nav{ margin: 8px 0 18px; }
.admin-nav-inner{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
  font-weight:800;
}
.admin-nav-inner a{
  text-decoration:none;
  color: inherit;
  padding: 8px 10px;
  border-radius: 10px;
}
.admin-nav-inner a:hover{ background: rgba(11,44,255,.06); color: var(--blue); }
.admin-nav-inner a.active{ background: rgba(11,44,255,.12); color: var(--blue); }

/* --- Admin dark/light theme (only affects admin pages) --- */
html[data-admin-theme="dark"] body{
  background:#0b0f1a;
  color:#e9ecff;
}
html[data-admin-theme="dark"] .card{
  background:#0f1626;
  border-color: rgba(255,255,255,.10);
}
html[data-admin-theme="dark"] input,
html[data-admin-theme="dark"] textarea,
html[data-admin-theme="dark"] select{
  background:#0b1220;
  color:#e9ecff;
  border-color: rgba(255,255,255,.12);
}
html[data-admin-theme="dark"] .admin-nav-inner a{
  color:#e9ecff;
}
html[data-admin-theme="dark"] .admin-nav-inner a:hover{
  background: rgba(255,255,255,.06);
  color:#fff;
}


/* Admin page title */
.admin-pagehead{ margin: 8px 0 14px; }
.admin-pagehead h1{
  margin: 0;
  font-size: 34px;
  line-height: 1.1;
  font-weight: 900;
}


/* Force admin topbar full width */
.admin-topbar{
  width: 100%;
  display: block;
  background: #0c0f2b;
  color: #fff;
  margin: 0;
  padding: 0;
}

/* Zorg dat de container NIET de balk beperkt, alleen de inhoud */
.admin-topbar .container{
  max-width: 1200px; /* of jouw bestaande container width */
  margin: 0 auto;
  padding: 10px 16px; /* padding in de container ipv topbar */
}

.admin-topbar-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
}


/* VOL in kalender */
.cal-event.is-full{
  background: #b00020 !important;
  border: 2px solid #b00020 !important;
  color: #fff !important;
}

.cal-event.is-full .m{ opacity: .95; }

.cal-event.is-full::after{
  content: "VOL";
  display: inline-block;
  margin-left: 8px;
  padding: 2px 6px;
  font-size: 11px;
  font-weight: 900;
  border-radius: 6px;
  background: rgba(255,255,255,.2);
}


.home-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
}
.home-img{
  width:100%;
  height:180px;
  object-fit:cover;
  border-radius:12px;
  margin-bottom:10px;
}
@media (max-width: 980px){
  .home-grid{ grid-template-columns: 1fr; }
}

/* Homepage blokken */
.home-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.home-block{
  background: #fff;
  border-radius: 12px;
  padding: 14px;
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

/* 🔑 FIX: foto blijft binnen het blok */
.home-block img.home-img{
  width: 100%;
  max-width: 100%;
  height: 160px;          /* 👈 pas aan naar smaak (140–200px is mooi) */
  object-fit: cover;      /* snijdt netjes bij */
  border-radius: 10px;
  display: block;
  margin: 0 0 10px 0;
}

/* mobiel */
@media (max-width: 980px){
  .home-grid{
    grid-template-columns: 1fr;
  }
  .home-block img.home-img{
    height: 180px;
  }
}

/* Homepage blokken: rows */
.home-blocks { margin-top: 18px; }
.home-row{
  display:flex;
  gap:16px;
  align-items:stretch;
  padding:14px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  text-decoration:none;
  color:inherit;
  margin-bottom:14px;
}

/* wissel links/rechts */
.home-row.is-right{ flex-direction: row-reverse; }

/* media */
.home-media{
  position:relative;
  flex: 0 0 280px;      /* breedte foto-kolom */
  max-width: 280px;
  border-radius:12px;
  overflow:hidden;
}
.home-img{
  display:block;
  width:100%;
  height: 180px;        /* kleinere foto */
  object-fit: cover;
}

/* overlay */
.home-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:10px;
  background: linear-gradient(to top, rgba(0,0,0,.65), rgba(0,0,0,0));
}
.home-overlay-title{
  color:#fff;
  font-weight:900;
  font-size:14px;
  line-height:1.2;
}

/* content */
.home-content{ flex:1; min-width: 0; display:flex; flex-direction:column; justify-content:center; }
.home-title{ margin:0 0 6px 0; }
.home-text{ margin:0; opacity:.9; }
.home-cta{ margin-top:10px; font-weight:900; opacity:.9; }

/* hover */
.home-row:hover{ transform: translateY(-1px); transition: .15s; border-color: rgba(0,0,0,.14); }

/* mobiel */
@media (max-width: 980px){
  .home-row, .home-row.is-right{ flex-direction: column; }
  .home-media{ max-width: 100%; flex-basis:auto; }
  .home-img{ height: 200px; }
}

/* Homepage blokken - afwisselend links/rechts */
.home-blocks{ margin-top: 18px; }

.home-row{
  display:flex;
  gap:16px;
  align-items:stretch;
  padding:14px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
  text-decoration:none;
  color:inherit;
  margin-bottom:14px;
}

.home-row.is-right{ flex-direction: row-reverse; }

.home-media{
  position:relative;
  flex: 0 0 280px;   /* 👈 breedte foto-kolom (pas aan) */
  max-width: 280px;
  border-radius:12px;
  overflow:hidden;
}

.home-img{
  display:block;
  width:100%;
  max-width:100%;
  height: 170px;     /* 👈 foto minder groot */
  object-fit: cover;
}

/* Overlay */
.home-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:10px;
  background: linear-gradient(to top, rgba(0,0,0,.65), rgba(0,0,0,0));
}

.home-overlay-title{
  color:#fff;
  font-weight:900;
  font-size:14px;
  line-height:1.2;
}

/* Content */
.home-content{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.home-title{ margin:0 0 6px 0; }
.home-text{ margin:0; opacity:.92; }
.home-cta{ margin-top:10px; font-weight:900; opacity:.9; }

/* Hover */
.home-row:hover{
  transform: translateY(-1px);
  transition: .15s;
  border-color: rgba(0,0,0,.14);
}

.home-row.is-disabled{
  opacity:.7;
  cursor: default;
}
.home-row.is-disabled:hover{ transform:none; }

/* Mobiel */
@media (max-width: 980px){
  .home-row, .home-row.is-right{ flex-direction: column; }
  .home-media{ max-width:100%; flex-basis:auto; }
  .home-img{ height: 200px; }
}

/* Fix "uitgegrijsd": nooit opacity op hele blokken */
.home-row,
.card {
  opacity: 1 !important;
}

.home-row.is-nolink{
  opacity: 1;
}

.home-row:not(.is-nolink):hover{
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  transform: translateY(-2px);
}

/* ===== Hoofdmenu knoppen ===== */
.nav-buttons {
  display: flex;
  gap: 10px;
}

.nav-btn {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
  color: #0b0f2b;
  background: #f3f5ff;
  border: 1px solid #e0e4ff;
  transition: all .2s ease;
}

.nav-btn:hover {
  background: #e6eaff;
  transform: translateY(-1px);
}

/* actieve pagina */
.nav-btn.active {
  background: #1f3cff;
  color: #fff;
  border-color: #1f3cff;
}

/* Alleen hamburger-menu op mobiel */
@media (max-width: 980px){
  .nav, .nav-buttons { 
    display: none !important; 
  }
  .menu-toggle { 
    display: inline-flex !important; 
  }
}

/* Alleen desktop-menu op desktop */
@media (min-width: 981px){
  #mobileNav { 
    display: none !important; 
  }
  .menu-toggle { 
    display: none !important; 
  }
}

.mobile-nav { display: none; }
.mobile-nav.open { display: block; }

/* ===== UNIVERSELE KNOP STIJL ===== */
.btn,
button,
input[type="submit"],
a.btn,
a.cal-btn,
a.nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;

  padding: 8px 16px;
  border-radius: 999px;

  font-weight: 600;
  font-size: 14px;
  line-height: 1;

  text-decoration: none;
  cursor: pointer;

  color: #0b0f2b;
  background: #f3f5ff;
  border: 1px solid #e0e4ff;

  transition: all .2s ease;
}

/* Hover */
.btn:hover,
button:hover,
input[type="submit"]:hover,
a.btn:hover,
a.cal-btn:hover,
a.nav-btn:hover {
  background: #e6eaff;
  transform: translateY(-1px);
}

/* Actief / primaire knop */
.btn.primary,
button.primary,
a.btn.primary {
  background: #1f3cff;
  color: #fff;
  border-color: #1f3cff;
}

.btn.primary:hover,
button.primary:hover,
a.btn.primary:hover {
  background: #162fcc;
}

/* Gevaar (verwijderen) */
.btn.danger,
button.danger {
  background: #ffeaea;
  border-color: #ffb3b3;
  color: #8b0000;
}

.btn.danger:hover,
button.danger:hover {
  background: #ffd6d6;
}

/* Uitgeschakeld */
button:disabled,
.btn.disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}


