/* Algemene Stijlen & Body */
body { 
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; 
    line-height: 1.6; 
    margin: 0; 
    padding: 0; 
    background-color: #f4f7f6; 
    color: #333; 
    -webkit-text-size-adjust: 100%; 
    text-size-adjust: 100%;
}
*, *::before, *::after { 
    box-sizing: border-box;
}
.container { 
    width: 100%; 
    max-width: 1200px; 
    margin-left: auto; 
    margin-right: auto; 
    padding-left: 15px;  
    padding-right: 15px; 
}
main.container { 
    padding-top: 20px; 
    padding-bottom: 40px; 
    min-height: calc(100vh - 120px); 
} 
.content-page { 
    background-color: #fff;
    padding: 30px 50px; 
    margin-top: 20px;
    margin-bottom: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.content-page h1 { margin-top: 0; margin-bottom: 20px; font-size: 1.8em; }
.content-page h2 { margin-top: 30px; margin-bottom: 15px; font-size: 1.5em; border-bottom: 1px solid #eee; padding-bottom: 5px;}
.content-page h3 { margin-top: 25px; margin-bottom: 10px; font-size: 1.2em; }
.content-page p, .content-page ul, .content-page ol { margin-bottom: 15px; line-height: 1.7; }
.content-page ul, .content-page ol { padding-left: 25px; }
.content-page li { margin-bottom: 8px; }
.content-page a { color: #007bff; text-decoration: underline; }
.content-page a:hover { color: #0056b3; }

/* Header & Navigatie */
header { background: #007bff; color: #fff; padding: 10px 0; min-height: auto; border-bottom: none; }
header .container { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; padding-left: 10px; padding-right: 10px; }
header .logo { margin-bottom: 5px; } 
header .logo a { color: #fff; text-decoration: none; text-transform: uppercase; font-size: 1.3em; font-weight: bold; }
header nav ul { margin: 0; padding: 0; list-style: none; display: flex; flex-wrap: wrap; justify-content: center; } 
header nav ul li { display: inline-block; margin-left: 8px; margin-right: 8px; margin-bottom: 5px; }
header nav ul li:first-child { margin-left: 0; }
header nav ul li a { color: #fff; text-decoration: none; font-size: 1em; padding: 5px 0; }
header nav ul li a:hover, header nav ul li a.active { color: #cce5ff; }

/* Footer */
footer { background: #333; color: #fff; text-align: center; padding: 15px 10px; margin-top: 30px; font-size: 0.9em; min-height: auto;}

/* Formulieren Algemeen */
.form-group { margin-bottom: 18px; }
.form-group label { display: block; margin-bottom: 6px; font-weight: bold; color: #495057; font-size: 0.95em; }
.form-group input[type="email"],.form-group input[type="password"],.form-group input[type="text"],
.form-group input[type="number"],.form-group input[type="url"],.form-group select,.form-group textarea {
    width: 100%; padding: 10px; border: 1px solid #ced4da; border-radius: 0.25rem; 
    font-size: 1em; transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus { border-color:#80bdff; outline:0; box-shadow:0 0 0 .2rem rgba(0,123,255,.25); }
.question-block textarea.form-control { width:100%; min-height:100px; padding:10px; border:1px solid #ced4da; border-radius:.25rem; font-family:inherit; font-size:1em; line-height:1.6; }
.form-group textarea { min-height: 100px; resize: vertical; } 

/* --- CSS VOOR ACCOUNT PAGINA PADDING & SPACING --- */
.account-container { 
    padding-top: 30px !important; padding-bottom: 30px !important;
    padding-left: 30px !important; padding-right: 30px !important;
}
.account-form fieldset, .admin-form fieldset { /* admin-form is voor de setup flow op account.php */
    padding: 25px 30px !important; margin-bottom: 30px !important;
}
.account-form fieldset:last-of-type, .admin-form fieldset:last-of-type {
    margin-bottom: 20px !important; 
}
div.form-group.form-submit-group {
    margin-top: 25px !important; margin-bottom: 15px !important; 
}
div.form-group.form-submit-group .button + .button { margin-left: 10px !important; }
.account-container > hr { margin-top: 35px !important; margin-bottom: 30px !important; }
.account-container > h2#mfa-section { margin-top: 0 !important; margin-bottom: 25px !important; }
.account-container > h2#mfa-section + p, .account-container > form.mfa-form,
.account-container > form.mfa-form + p, .account-container > form.mfa-form + form.mfa-form {
    margin-bottom: 25px !important; 
}
.account-container #adminMfaSetupSection p, .account-container form.mfa-form p {
    margin-bottom: 18px !important;
}
.account-container .mfa-qr-code + p { margin-top: 10px !important; margin-bottom: 20px !important; }
.account-container .mfa-qr-code { margin-bottom: 10px !important; }
.account-container .mfa-recovery-codes { margin-bottom: 25px !important; }
.account-container .mfa-recovery-codes ul { margin-top: 10px !important; padding-left: 20px !important; margin-bottom: 0; }
.account-container .mfa-recovery-codes li { margin-bottom: 6px !important; }
.account-container #adminMfaSetupSection hr, .account-container form.mfa-form + hr,
.account-container .mfa-recovery-codes + hr { margin-top: 30px !important; margin-bottom: 25px !important; }
fieldset > .form-group:last-child { margin-bottom: 0 !important; }
fieldset > .form-group.form-submit-group:last-child { margin-bottom: 5px !important; }
/* --- EINDE CSS VOOR ACCOUNT PAGINA PADDING & SPACING --- */

/* Knoppen Algemeen */
.button { display:inline-block; width:auto; padding:10px 18px; color:white !important; border:1px solid transparent; border-radius:.25rem; cursor:pointer; text-decoration:none; font-size:1em; font-weight:500; transition:background-color .2s ease-in-out,transform .1s ease,border-color .15s ease-in-out; line-height:1.5; text-align:center; vertical-align:middle; user-select:none;}
.button:hover { transform: translateY(-1px); filter: brightness(90%); } 
.button:active { transform: translateY(0px); filter: brightness(80%);}
button.button-full-width, input[type="submit"].button-full-width { width: 100%; }
.button-primary { background-color:#007bff; border-color:#007bff; color: white !important;} .button-primary:hover { background-color:#0069d9; border-color:#0062cc; }
.button-success { background-color:#28a745; border-color:#28a745; color: white !important;} .button-success:hover { background-color:#218838; border-color:#1e7e34; }
.button-secondary { background-color:#6c757d; border-color:#6c757d; color: white !important;} .button-secondary:hover { background-color:#5a6268; border-color:#545b62; }
.button-danger { background-color:#dc3545; border-color:#dc3545; color: white !important;} .button-danger:hover { background-color:#c82333; border-color:#bd2130; }
.button-info { background-color:#17a2b8; border-color:#17a2b8; color: white !important;} .button-info:hover { background-color:#138496; border-color:#117a8b; }
.button-custom-orange,.button-warning { color:#fff !important; background-color:#e79405; border-color:#e79405; }
.button-custom-orange:hover,.button-warning:hover { color:#fff !important; background-color:#c67c04; border-color:#b06d03; }
.button-default { background-color:#f8f9fa;color:#343a40 !important;border:1px solid #ced4da} .button-default:hover { background-color:#e2e6ea}
.button.disabled,.button:disabled { background-color:#6c757d !important; border-color:#6c757d !important; opacity:.65; cursor:not-allowed; pointer-events:none}

/* Meldingen */
.message { padding:12px 15px; margin-bottom:18px;border:1px solid transparent;border-radius:4px;font-size:.9em}
.error-messages,.error-message { color:#721c24;background-color:#f8d7da;border-color:#f5c6cb}
.error-messages ul { margin-top:8px;margin-bottom:0;padding-left:18px}
.success-message { color:#155724;background-color:#d4edda;border-color:#c3e6cb}
.info-message { color:#0c5460;background-color:#d1ecf1;border-color:#bee5eb}
.warning-message { color:#856404;background-color:#fff3cd;border-color:#ffeeba}
.error-text { color:#721c24;font-size:.875em;display:block;margin-top:4px}
.form-group small { font-size:.875em;color:#6c757d;display:block;margin-top:4px}

/* Styling voor verplichte vragen */
.mandatory-indicator { color: red; font-weight: bold; margin-left: 2px; margin-right: 3px; }
.question-block.highlight-mandatory-error { border: 2px solid red !important; box-shadow: 0 0 10px rgba(255, 0, 0, 0.3) !important; transition: border 0.3s ease-out, box-shadow 0.3s ease-out; padding-top: 15px !important; padding-bottom: 15px !important; }
.specific-mandatory-error-message { font-weight: bold; font-size: 0.9em; padding: 8px 10px !important; margin-top: 10px !important; margin-bottom: 5px !important; text-align: left; }
.page-level-error { border: 2px solid #dc3545; font-weight: bold; }

/* Login, Registratie, Account, MFA Pagina's */
.login-container,.register-container,.account-container,.mfa-verify-container { margin:30px auto; border:1px solid #ddd; border-radius:8px; background-color:#fff; box-shadow:0 2px 8px rgba(0,0,0,.1); max-width:500px }
.login-container h2,.register-container h2,.account-container h2,.mfa-verify-container h2 { text-align:center; margin-top:0; margin-bottom:15px; color:#343a40; font-weight:500; font-size:1.6em }
.login-container p,.register-container p,.mfa-verify-container p:not(.message) { text-align:center; margin-top:15px; margin-bottom:20px; font-size:.9em }
.registration-fee-notice { text-align: center; font-size: 1.1em; color: #555; margin-top: 0; margin-bottom: 25px; }
.form-check { padding-left:1.2em;margin-bottom:.5rem} .form-check-input { float:left;margin-left:-1.2em; margin-top: 0.25em; } .form-check-label { margin-bottom:0; font-size: 0.95em; }

/* Homepage Stijlen */
.homepage-intro { text-align:center;margin-bottom:25px}
.homepage-intro h1 { font-size:1.8em;color:#343a40;font-weight:500;margin-bottom:8px}
.homepage-intro p { font-size:1.05em;color:#495057}
.homepage-layout-trifold { display:flex; flex-direction: column; gap:15px; }
.lessons-sidebar-left, .main-lesson-display-trifold, .lessons-sidebar-right { width: 100%; order: 0; }
.main-lesson-display-trifold { order: 1; } .lessons-sidebar-left { order: 2; } .lessons-sidebar-right { order: 3; }
.lessons-sidebar { background-color:#fff;padding:12px;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07);}
.lessons-sidebar h3 { margin-top:0;margin-bottom:12px;font-size:1.05em;color:#343a40;border-bottom:1px solid #eee;padding-bottom:8px}
ul.lesson-quick-nav { list-style:none;padding:0;margin:0}
hr.sidebar-separator { border:0;border-top:1px solid #eee;margin:12px 0}
.standalone-sidebar-item { margin-bottom:5px}
.accordion-container .accordion-item { border-bottom:1px solid #eee} .accordion-container .accordion-item:last-child { border-bottom:none}
.accordion-header { background-color:transparent;color:#007bff;cursor:pointer;padding:10px 5px;width:100%;border:none;text-align:left;outline:none;font-size:1em;font-weight:700;display:flex;justify-content:space-between;align-items:center}
.accordion-header:hover { background-color:#f8f9fa}
.accordion-icon { margin-left:auto;transition:transform .2s ease-in-out;font-size:.75em}
.accordion-item.active .accordion-icon { transform:rotate(180deg)}
.accordion-content { padding:0 5px 8px;display:none;overflow:hidden;background-color:#fff}
.accordion-content ul.lesson-quick-nav { padding-top:4px}
a.button-lesson-nav { display: flex; align-items: center; justify-content: flex-start; padding: 8px 10px; text-decoration:none;color:#333 !important; border-radius:4px;font-size:.9em;text-align:left;margin-bottom:6px; box-shadow:0 1px 2px rgba(0,0,0,.1); transition:filter .2s ease,box-shadow .2s ease, background-color .2s ease; border:1px solid #ccc; }
.lesson-button-icon-left { margin-right: 8px; flex-shrink: 0; display: inline-flex; align-items: center; font-size: 1.1em; }
.lesson-button-icon-left .fa-lock { font-size: 0.9em; }
.lesson-button-text { flex-grow: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lesson-button-icon-right { margin-left: auto; padding-left: 8px; flex-shrink: 0; display: inline-flex; align-items: center; font-size: 0.85em; }
a.button-lesson-nav:hover { filter:brightness(95%); box-shadow:0 2px 4px rgba(0,0,0,.15); }
a.button-lesson-nav.item-not-opened { background-color: #dde0d7; border-color: #c8cac4; }
a.button-lesson-nav.item-not-opened:hover { background-color: #d0d3c9; }
a.button-lesson-nav.item-in-progress-or-editing { background-color: #aae0b6 !important; border-color: #99d0a5 !important; color: #1e4620 !important; }
a.button-lesson-nav.item-in-progress-or-editing:hover { background-color: #9ed4a9 !important; }
a.button-lesson-nav.status-custom-link { background-color:#17a2b8; border-color:#17a2b8; color: #fff !important;}
a.button-lesson-nav.status-custom-link:hover { background-color: #139cb2; }
a.button-lesson-nav.status-sent { background-color:#28a745 !important; border-color:#28a745 !important; color: #fff !important; }
a.button-lesson-nav.status-sent:hover { background-color: #218838 !important; border-color: #1e7e34 !important;}
a.button-lesson-nav.status-sent .lesson-button-icon-left i, a.button-lesson-nav.status-sent .lesson-button-icon-right i { color: #fff !important; }
a.button-lesson-nav.active-lesson-link { background-color: #007bff !important; border-color: #007bff !important; color: #fff !important; font-weight:700; box-shadow:0 0 0 2px #fff,0 0 0 3px #007bff; }
a.button-lesson-nav.active-lesson-link:hover { background-color: #0069d9 !important; border-color: #0062cc !important; filter: none; }
a.button-lesson-nav.active-lesson-link .lesson-button-icon-left i, a.button-lesson-nav.active-lesson-link .lesson-button-icon-right i { color: #fff !important; }
a.button-lesson-nav.disabled-lesson-link { cursor: not-allowed; opacity: 0.75; }
a.button-lesson-nav.disabled-lesson-link:hover { filter: none; }
a.button-lesson-nav.disabled-lesson-link .lesson-button-icon-left .fa-lock { color: #495057 !important; }
.lessons-sidebar-right a.button-lesson-nav, .lessons-sidebar-right .standalone-sidebar-item a.button-lesson-nav, a.button-lesson-nav.item-in-tools-column { background-color: #f2bf07 !important; border-color: #e0ac00 !important; color: #212529 !important; }
.lessons-sidebar-right a.button-lesson-nav:hover, .lessons-sidebar-right .standalone-sidebar-item a.button-lesson-nav:hover, a.button-lesson-nav.item-in-tools-column:hover { background-color: #e0ac00 !important; border-color: #c49500 !important; filter: none; }
.lessons-sidebar-right a.button-lesson-nav .lesson-button-icon-left i, .lessons-sidebar-right a.button-lesson-nav .lesson-button-icon-right i, a.button-lesson-nav.item-in-tools-column .lesson-button-icon-left i, a.button-lesson-nav.item-in-tools-column .lesson-button-icon-right i { color: #212529 !important; opacity: 0.8; }
.lessons-sidebar-right a.button-lesson-nav.active-lesson-link, a.button-lesson-nav.item-in-tools-column.active-lesson-link { box-shadow: 0 0 0 2px #fff,0 0 0 3px #f2bf07; }
.main-lesson-display-trifold .lesson-card.active-lesson-display { background-color:#fff;border:1px solid #e0e0e0;box-shadow:0 1px 4px rgba(0,0,0,.07);padding:20px;}
.main-lesson-display-trifold .lesson-card.active-lesson-display h2 { font-size:1.5em;color:#343a40}
.lesson-card { border:1px solid #e0e0e0;border-radius:6px;padding:20px;background-color:#fff;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.lesson-card:hover { box-shadow:0 4px 12px rgba(0,0,0,.1);transform:translateY(-2px)}
.lesson-card h2 { margin-top:0;font-size:1.3em;color:#007bff;margin-bottom:10px;font-weight:500}
.lesson-description { font-size:.9em;color:#555;flex-grow:1;margin-bottom:15px;line-height:1.5} .lesson-description p:last-child { margin-bottom:0}
.progress-bar-container { width:100%;background-color:#e9ecef;border-radius:8px;margin-bottom:12px;height:20px;overflow:hidden}
.progress-bar { height:100%;background-color:#28a745;color:#fff;text-align:center;line-height:20px;font-size:.8em;font-weight:700;border-radius:8px 0 0 8px;transition:width .5s ease-in-out;white-space:nowrap}
.progress-bar[style*="width: 100%"] { border-radius:8px} .progress-bar[style*="width: 0%"] { font-size:0;background-color:transparent !important}
.lesson-status { font-size:.85em;color:#6c757d;margin-bottom:15px} .lesson-status strong { color:#495057}
.lesson-actions .button { width:100%;display:block; padding:10px 15px;font-size:.95em;margin-top:8px;margin-right:0} 
.lesson-card.lesson-sent { border-left:5px solid #28a745} .lesson-card.lesson-sent h2 { color:#28a745} .lesson-card.lesson-sent .progress-bar { background-color:#28a745}
.lesson-card.lesson-completed:not(.lesson-sent) { border-left:5px solid #007bff} .lesson-card.lesson-completed:not(.lesson-sent) .progress-bar { background-color:#007bff}
.lesson-card.lesson-editing { border-left:5px solid #e79405}
.no-lesson-selected { padding:25px;text-align:center;background-color:#fff;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07);color:#6c757d;font-size:0.95em;}
.account-form fieldset { border:1px solid #e0e0e0;padding:25px 30px !important;margin-bottom:30px !important;border-radius:6px;background-color:#fff;box-shadow:0 1px 2px rgba(0,0,0,.05)}
.account-form legend { font-size:1.2em;font-weight:500;padding:0 8px;margin-left:-8px;margin-bottom:20px !important;color:#007bff;width:auto;border-bottom:none}
.mfa-qr-code img { max-width:180px;height:auto;border:1px solid #ccc;padding:4px;margin:0 auto 15px;display:block}
.mfa-recovery-codes ul { column-count:1; padding-left: 20px !important; list-style-position: inside;} 
.mfa-recovery-codes li { margin-bottom: 6px !important;}
.lesson-header { margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid #eee}
.lesson-header h1 { font-size:1.6em;color:#343a40;margin-bottom:12px;font-weight:500}
.lesson-page-navigation { margin-top:0;margin-bottom:20px;text-align:center; }
.page-nav-button { display:inline-block;min-width:30px;height:30px;line-height:30px;text-align:center;background-color:#6c757d;color:#fff !important;text-decoration:none;border-radius:3px;margin:2px;font-size:.85em;font-weight:700;padding:0 4px}
.page-nav-button:hover { background-color:#545b62} .page-nav-button.active { background-color:#007bff}
.admin-view-notice { background-color:#fff3cd;border-color:#ffeeba;color:#856404;font-size:0.85em;padding:10px;} .admin-view-notice i { margin-right:6px}
.lesson-content .content-block { margin-bottom:25px;padding:15px;background-color:#fff;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.lesson-content .text-block { line-height:1.65; font-size:0.95em;} 

/* --- AANPASSINGEN VOOR VRAAGTEKST OPMAAK --- */
.question-text-wrapper { 
    margin-bottom:12px;
    font-size:1.05em; /* Standaard lettergrootte voor de vraagtekst container */
    color:#495057;
    line-height:1.65;
}
/* Zorg ervoor dat P, OL, UL, LI, STRONG, EM hun standaard browser styling behouden 
   of de styling krijgen die je via TinyMCE hebt ingesteld. */
.question-text-wrapper p {
    margin-top: 0; /* Reset eventuele eerdere margin */
    margin-bottom: 0.8em; /* Ruimte onder paragraaf */
    /* Andere p-specifieke stijlen indien nodig */
}
.question-text-wrapper ol,
.question-text-wrapper ul {
    margin-top: 0;
    margin-bottom: 0.8em;
    padding-left: 25px; /* Standaard browser indentatie voor lijsten */
}
.question-text-wrapper li {
    margin-bottom: 0.3em; /* Kleinere marge voor list items */
    /* list-style-type: inherit; -- Laat browser default doen */
}
.question-text-wrapper strong,
.question-text-wrapper b { /* b is ook een optie die TinyMCE kan gebruiken */
    font-weight: bold;
}
.question-text-wrapper em,
.question-text-wrapper i { /* i is ook een optie */
    font-style: italic;
}
.question-text-wrapper u {
    text-decoration: underline;
}
/* Je kunt hier meer specifieke styling toevoegen voor andere HTML tags die TinyMCE kan genereren */
/* --- EINDE AANPASSINGEN VOOR VRAAGTEKST OPMAAK --- */

.lesson-content .text-block h1,.lesson-content .text-block h2,.lesson-content .text-block h3,.lesson-content .text-block h4 { margin-top:0;color:#007bff; line-height: 1.3; margin-bottom: 0.5em;}
.lesson-content .video-block.responsive-video { position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:6px}
.lesson-content .video-block.responsive-video iframe, 
.lesson-content .video-block.responsive-video video { position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.lesson-content .audio-block audio { width:100%;border-radius:4px}
.question-block { margin-bottom:25px;padding:20px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px}
/* .question-text-wrapper strong { font-weight:500} -- Deze was te generiek en kon strong binnen p overschrijven */
.question-block fieldset { border:none;padding:0;margin:0}
.question-block .form-check-input { margin-top:.25em}
.question-block .form-check-label { font-weight:400;margin-bottom:0;font-size:.95em;color:#212529}
.lesson-navigation-buttons { margin-top:30px;padding-top:20px;border-top:1px solid #dee2e6;display:flex;flex-direction:column;gap:10px} 
.lesson-navigation-buttons .nav-group-left,.lesson-navigation-buttons .nav-group-center,.lesson-navigation-buttons .nav-group-right { display:flex;flex-direction:column;width:100%;gap:8px}
.lesson-navigation-buttons .button { width:100%; margin: 0 !important; } 
.question-short-text .short-text-input { width:100%;max-width:100%;padding:10px} 
.question-multi-step-display-all .multi-step-main-intro-text { margin-bottom:18px;font-size:1.05em;line-height:1.65}
.sub-question-item { padding:12px 0;border-bottom:1px solid #eee} .sub-question-item:last-child { border-bottom:none}
.choice-buttons-group,.checklist-buttons-group,.multi-step-options-group { display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.question-checklist.display-as-buttons .choice-buttons-group,.question-checklist.display-as-buttons .checklist-buttons-group { flex-direction:column;align-items:stretch;gap:6px}
.question-checklist.display-as-buttons .choice-button-item,.question-checklist.display-as-buttons .checklist-button-item { width:100%}
.question-checklist.display-as-buttons .choice-button-label,.question-checklist.display-as-buttons .checklist-button-label { width:100%;text-align:left;padding:10px 12px}
.choice-button-item,.checklist-button-item,.multi-step-option-item {}
.choice-button-label,.checklist-button-label,.multi-step-option-button-label { display:inline-block;padding:8px 12px;color:#fff !important;border:1px solid;border-radius:4px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;font-size:.9em;min-width:70px;text-align:center;margin:2px 0;line-height:1.4}
.multi-step-option-button-label,.choice-button-label:not(.checklist-button-label) { background-color:#007bff;border-color:#007bff}
.multi-step-option-button-label:not(.disabled-label):hover,.choice-button-label:not(.checklist-button-label):not(.disabled-label):hover { background-color:#0056b3;border-color:#0056b3}
.checklist-button-label { background-color:#6c757d;border-color:#6c757d}
.checklist-button-label:not(.disabled-label):hover { background-color:#5a6268;border-color:#545b62}
.multi-step-radio:checked+.multi-step-option-button-label,.checklist-button-checkbox:checked+.checklist-button-label,.choice-button-radio:checked+.choice-button-label,.choice-button-checkbox:checked+.choice-button-label,
.multi-step-option-button-label.selected,.checklist-button-label.selected,.choice-button-label.selected { background-color:#28a745 !important;border-color:#28a745 !important}
.multi-step-option-button-label.disabled-label,.checklist-button-label.disabled-label,.choice-button-label.disabled-label { cursor:default;background-color:#e9ecef;border-color:#ced4da;color:#6c757d !important;opacity:.7}
.multi-step-option-button-label.disabled-label:hover,.checklist-button-label.disabled-label:hover,.choice-button-label.disabled-label:hover { background-color:#e9ecef;border-color:#ced4da}
.multi-step-radio,.checklist-button-checkbox,.choice-button-radio,.choice-button-checkbox { display:none}
.answer-placeholder, .user-data-placeholder { background-color: #f0f0f0; padding: 1px 4px; border-radius: 3px; border: 1px dashed #ccc; font-family: monospace; font-size: 0.95em; display: inline; }
.answer-placeholder strong, .user-data-placeholder strong { font-weight: bold; }
.text-block .answer-value-display { /* Erft styling */ }
.text-block .placeholder-missing.answer-value-display { font-style: italic; color: #777 !important; background-color: transparent !important; padding: 0 !important; border: none !important; }
.text-block ul.answer-value-display.answer-list-display { list-style-type: disc; padding-left: 20px; margin-top: 5px; margin-bottom: 5px; }
.text-block ul.answer-value-display.answer-list-display li { display: list-item; padding: 0; margin: 0 0 3px 0; line-height: 1.5; }
.text-block ul.answer-value-display.answer-list-display li strong { font-weight: bold; }
.cookie-consent-popup { position:fixed;bottom:0;left:0;width:100%;background-color:#2d3748;color:#edf2f7;padding:15px;text-align:center;z-index:1050;box-shadow:0 -2px 8px rgba(0,0,0,.15);font-size:.85em;line-height:1.4}
.cookie-consent-popup p { margin:0 0 12px;max-width:900px;margin-left:auto;margin-right:auto}
.cookie-consent-popup a.cookie-consent-link { color:#63b3ed;text-decoration:underline}
.cookie-consent-popup a.cookie-consent-link:hover { color:#90cdf4}
.cookie-consent-popup .button { padding:7px 18px;font-size:.9em}

/* Responsive aanpassingen - Tablet en groter */
@media (min-width: 768px) {
    .container { padding-left: 20px; padding-right: 20px; }
    main.container { min-height: calc(100vh - 150px); }
    header { padding: 15px 0; }
    header .logo a { font-size: 1.5em; }
    header nav ul li { margin-left: 15px; margin-right: 15px; margin-bottom: 0; }
    header nav ul li a { font-size: 1.05em; padding: 8px 5px;}
    footer { padding: 20px 0; font-size: 0.9em; }
    .login-container,.register-container,.account-container,.mfa-verify-container { margin: 60px auto; padding: 30px 35px !important; }
    .login-container h2,.register-container h2,.account-container h2,.mfa-verify-container h2 { font-size: 1.8em; margin-bottom: 20px !important; } 
    .registration-fee-notice { margin-bottom: 30px; }
    .form-group label { font-size: 1em; }
    .form-group input[type="email"], .form-group input[type="text"], .form-group input[type="password"], .form-group input[type="number"], .form-group input[type="url"], .form-group select, .form-group textarea { padding: 12px; } 
    .button { padding: 10px 20px; font-size: 1em; }
    .message {padding: 15px; font-size: .95em; }
    .homepage-intro h1 { font-size: 2.2em; } .homepage-intro p { font-size: 1.15em; }
    .homepage-layout-trifold { flex-direction: row; gap: 20px; }
    .lessons-sidebar-left { flex-grow:1; flex-shrink:1; flex-basis:calc(25% - 14px); min-width:220px; order:1 }
    .main-lesson-display-trifold { flex-grow:2; flex-shrink:1; flex-basis:calc(50% - 13px); min-width:320px; order:2 }
    .lessons-sidebar-right { flex-grow:1; flex-shrink:1; flex-basis:calc(25% - 14px); min-width:220px; order:3 }
    .lessons-sidebar { padding: 20px; } .lessons-sidebar h3 { font-size: 1.1em; }
    .accordion-header { font-size: 1.05em; } a.button-lesson-nav { font-size: .9em; }
    .main-lesson-display-trifold .lesson-card.active-lesson-display { padding: 25px; }
    .main-lesson-display-trifold .lesson-card.active-lesson-display h2 { font-size: 1.6em; }
    .lesson-card { padding: 20px; } .lesson-card h2 { font-size: 1.4em; }
    .lesson-actions .button { width: auto; display: inline-block; }
    .no-lesson-selected { font-size: 1em; }
    .account-form fieldset { padding: 25px 30px !important; margin-bottom: 30px !important; }
    .account-form fieldset:last-of-type { margin-bottom: 20px !important; }
    .account-form legend { font-size: 1.3em; margin-bottom:20px !important;}
    .mfa-qr-code img { max-width: 200px; } .mfa-recovery-codes ul { column-count: 2; padding-left: 25px !important;}
    .mfa-recovery-codes li { margin-bottom: 6px !important;}
    .lesson-header h1 { font-size: 1.8em; }
    .lesson-page-navigation { text-align: left; }
    .page-nav-button { min-width:32px;height:32px;line-height:32px;font-size:.9em;padding:0 5px}
    .admin-view-notice {font-size: 0.9em; padding: 12px;}
    .lesson-content .content-block { padding: 20px; } .lesson-content .text-block { font-size: 1em; }
    /* .question-block { padding: 25px; } -- Behoud bestaande padding */
    /* .question-text-wrapper { font-size: 1.1em; } -- Verhoogd van 1.05em */
    .question-block .form-check-label { font-size: 1em; }
    .lesson-navigation-buttons { flex-direction: row; justify-content: space-between; }
    .lesson-navigation-buttons .nav-group-left,.lesson-navigation-buttons .nav-group-center,.lesson-navigation-buttons .nav-group-right { width: auto; flex-direction: row; }
    .lesson-navigation-buttons .button { width: auto; margin: 0 5px !important; }
    .question-short-text .short-text-input { width:auto; max-width: 250px; padding:8px 10px }
    .choice-button-label,.checklist-button-label,.multi-step-option-button-label {font-size:.95em; padding:8px 15px;}
    .question-checklist.display-as-buttons .choice-button-label, .question-checklist.display-as-buttons .checklist-button-label { padding: 10px 15px; } 
    .cookie-consent-popup {padding: 20px 30px; font-size: .9em; }
    .cookie-consent-popup .button { padding: 8px 25px; font-size: .95em; }
}

/* Grote desktops */
@media (min-width: 1200px) {
    .container { padding-left: 0; padding-right: 0; }
}

/* TinyMCE Content Styling (als content_css wordt gebruikt) */
body.mce-content-body {
    padding: 10px 15px !important; /* Iets meer padding */
    line-height: 1.65; 
    font-size: 15px;   
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif; 
}
/* Specifieke styling voor elementen BINNEN de TinyMCE editor via de body class */
body.mce-content-body p { margin-bottom: 0.8em; }
body.mce-content-body h1, body.mce-content-body h2, body.mce-content-body h3, 
body.mce-content-body h4, body.mce-content-body h5, body.mce-content-body h6 { 
    color: #0056b3; margin-top: 1.2em; margin-bottom: 0.6em; line-height: 1.3; 
}
body.mce-content-body ul, body.mce-content-body ol { 
    padding-left: 25px; margin-bottom: 0.8em; 
}
body.mce-content-body li {
    margin-bottom: 0.3em;
}
/* font-weight en font-style worden door TinyMCE's eigen controls afgehandeld. */