/* ============================================================
   WheelzUp — site.css
   Eén bron van waarheid: reset, layout, utilities, components.
   Tokens worden uitsluitend gedefinieerd in _Layout.cshtml.
   Page CSS files gebruiken var(--wz-*) zonder te herdefiniëren.
   ============================================================ */

/* ===== RESET ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; }
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background: radial-gradient(circle at top center, rgba(var(--wz-accent-rgb), 0.10) 0%, transparent 26%),
                linear-gradient(90deg, rgba(var(--wz-accent-rgb), 0.06) 0%, transparent 20%, transparent 80%, rgba(var(--wz-accent-rgb), 0.06) 100%),
                linear-gradient(180deg, var(--wz-bg-2, #111307) 0%, var(--wz-bg, #0b0d05) 100%);
    color: var(--wz-text, #f4f1e8);
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
}
img, svg { display: block; max-width: 100%; }
button { cursor: pointer; font: inherit; background: none; border: none; }
a { color: inherit; }
input, select, textarea { font: inherit; }
ul, ol { list-style: none; }
table { border-collapse: collapse; width: 100%; }

/* ===== SHELL LAYOUT ===== */
.wz-shell {
    display: flex;
    align-items: stretch;
    flex: 1 0 auto;
    min-height: 0;
}

.wz-sidebar {
    width: 270px;
    flex-shrink: 0;
    padding: 1.25rem 1rem;
    background: linear-gradient(180deg, var(--wz-bg-sidebar, #0e1008) 0%, var(--wz-bg-sidebar-2, #090a06) 100%);
    border-right: 1px solid var(--wz-border-soft, rgba(255,255,255,0.06));
    box-shadow: 10px 0 30px rgba(0,0,0,0.16);
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    position: sticky;
    top: 0;
    height: 100vh;
    overflow-y: auto;
}

.wz-main-wrap {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.wz-main {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 1.75rem 1.5rem 1.25rem;
}

.wz-main > * { width: 100%; max-width: 1280px; margin: 0; }

/* No-sidebar layout */
.wz-nosidebar-wrap {
    flex: 1 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
}

.wz-nosidebar-main { width: 100%; min-width: 320px; }

/* ===== SIDEBAR COMPONENTS ===== */
.wz-sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
}

.wz-sidebar-brand {
    display: flex;
    align-items: center;
    gap: .85rem;
    margin-bottom: 1.25rem;
}

.wz-brand-box {
    width: 42px;
    height: 42px;
    border-radius: var(--wz-r-md, 14px);
    background: var(--wz-accent, #e6ea35);
    color: #111;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.wz-brand-name {
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: .06em;
    color: var(--wz-text, #f1eedf);
}

.wz-sidebar-nav {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    flex: 1 1 auto;
}

.wz-sidebar-footer {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    flex-shrink: 0;
}

.wz-sidebar-user {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem .95rem;
    color: var(--wz-text-muted, #8f9685);
    font-size: .88rem;
    overflow: hidden;
}

.wz-sidebar-username {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.wz-signout-btn {
    color: var(--wz-danger, #ff8ea2);
}

.wz-signout-btn:hover {
    background: var(--wz-danger-soft, rgba(255,77,109,0.14));
    color: var(--wz-danger, #ff8ea2);
}

.nav-link {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .8rem .95rem;
    border-radius: var(--wz-r-lg, 18px);
    color: var(--wz-text, #f1eedf);
    text-decoration: none;
    transition: background var(--wz-fast, .16s), color var(--wz-fast, .16s);
}

.nav-link:hover { background: rgba(255,255,255,0.04); color: #fff; }
.nav-link.active { background: var(--wz-accent, #e6ea35); color: #111; font-weight: 700; }
[data-theme="light"] .nav-link:hover { background: rgba(0,0,0,0.04); color: var(--wz-text); }

.wz-sidebar-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 40px; height: 40px;
    flex-shrink: 0;
    border-radius: var(--wz-r-md, 14px);
    border: 1px solid rgba(255,255,255,0.1);
    background: rgba(255,255,255,0.04);
    color: var(--wz-text, #f1eedf);
    font-size: 1rem;
    transition: background var(--wz-fast), border-color var(--wz-fast), transform var(--wz-fast);
}

.wz-sidebar-toggle:hover { background: rgba(255,255,255,0.09); border-color: rgba(255,255,255,0.18); }
.wz-sidebar-toggle:active { transform: scale(.94); }

/* ===== FOOTER ===== */
.footer {
    padding: 1.25rem 1.5rem .75rem;
    color: var(--wz-text-muted, #666);
    font-size: .82rem;
    flex-shrink: 0;
    margin-top: auto;
}

.wz-footer-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: .5rem;
    max-width: 1280px;
    margin: 0 auto;
}

.wz-footer-links { display: flex; gap: 1.25rem; }
.footer-text { color: var(--wz-text-soft, #d7d7d7); }
.footer-link { color: #6ea0ff; text-decoration: underline; }
.footer-link:hover { color: var(--wz-accent, #e6f21a); }

/* ===== SCROLLBAR ===== */
.fancy-scroll {
    scrollbar-width: thin;
    scrollbar-color: var(--wz-scroll-thumb, #555) var(--wz-scroll-track, #111);
}
.fancy-scroll::-webkit-scrollbar { width: 8px; }
.fancy-scroll::-webkit-scrollbar-track { background: var(--wz-scroll-track, #111); }
.fancy-scroll::-webkit-scrollbar-thumb { background-color: var(--wz-scroll-thumb, #555); border-radius: 4px; }
.fancy-scroll::-webkit-scrollbar-thumb:hover { filter: brightness(1.3); }

/* ===== GRID SYSTEM (Bootstrap-compatible subset) ===== */
.row {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
}
.row > * { grid-column: span 12; min-width: 0; }

.col-1  { grid-column: span 1; }
.col-2  { grid-column: span 2; }
.col-3  { grid-column: span 3; }
.col-4  { grid-column: span 4; }
.col-6  { grid-column: span 6; }
.col-8  { grid-column: span 8; }
.col-9  { grid-column: span 9; }
.col-12 { grid-column: span 12; }

.g-2 { gap: .5rem; }
.g-3 { gap: 1rem; }
.g-4 { gap: 1.5rem; }
.gy-3 { row-gap: 1rem; }
.gy-4 { row-gap: 1.5rem; }

@media (min-width: 768px) {
    .col-md-4  { grid-column: span 4; }
    .col-md-6  { grid-column: span 6; }
    .col-md-8  { grid-column: span 8; }
    .col-md-12 { grid-column: span 12; }
}

@media (min-width: 992px) {
    .col-lg-3  { grid-column: span 3; }
    .col-lg-4  { grid-column: span 4; }
    .col-lg-6  { grid-column: span 6; }
    .col-lg-8  { grid-column: span 8; }
    .col-lg-9  { grid-column: span 9; }
    .col-lg-12 { grid-column: span 12; }
}

/* ===== FLEX UTILITIES ===== */
.d-flex        { display: flex !important; }
.d-grid        { display: grid !important; }
.d-block       { display: block !important; }
.d-none        { display: none !important; }
.d-inline      { display: inline !important; }
.d-inline-flex { display: inline-flex !important; }

.flex-row    { flex-direction: row; }
.flex-column { flex-direction: column; }
.flex-wrap   { flex-wrap: wrap; }
.flex-nowrap { flex-wrap: nowrap; }

.justify-content-start   { justify-content: flex-start; }
.justify-content-end     { justify-content: flex-end; }
.justify-content-center  { justify-content: center; }
.justify-content-between { justify-content: space-between; }

.align-items-start   { align-items: flex-start; }
.align-items-center  { align-items: center; }
.align-items-end     { align-items: flex-end; }
.align-items-stretch { align-items: stretch; }
.align-middle        { vertical-align: middle; }

.flex-shrink-0 { flex-shrink: 0; }
.flex-grow-1   { flex-grow: 1; }

.gap-1 { gap: .25rem; }
.gap-2 { gap: .5rem; }
.gap-3 { gap: 1rem; }
.gap-4 { gap: 1.5rem; }

@media (min-width: 992px) {
    .flex-lg-row    { flex-direction: row !important; }
    .flex-lg-column { flex-direction: column !important; }
    .align-items-lg-start  { align-items: flex-start !important; }
    .align-items-lg-center { align-items: center !important; }
    .justify-content-lg-between { justify-content: space-between !important; }
}

/* ===== SIZING & SPACING ===== */
.w-100 { width: 100%; }
.h-100 { height: 100%; }
.overflow-hidden { overflow: hidden; }
.overflow-auto   { overflow: auto; }

.m-0  { margin: 0; }
.mt-1 { margin-top: .25rem; }
.mt-2 { margin-top: .5rem; }
.mt-3 { margin-top: 1rem; }
.mt-4 { margin-top: 1.5rem; }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: .25rem; }
.mb-2 { margin-bottom: .5rem; }
.mb-3 { margin-bottom: 1rem; }
.mb-4 { margin-bottom: 1.5rem; }
.ms-1 { margin-left: .25rem; }
.ms-2 { margin-left: .5rem; }
.me-1 { margin-right: .25rem; }
.me-2 { margin-right: .5rem; }
.me-3 { margin-right: 1rem; }
.mx-auto { margin-left: auto; margin-right: auto; }

.p-0  { padding: 0; }
.p-2  { padding: .5rem; }
.p-3  { padding: 1rem; }
.p-4  { padding: 1.5rem; }
.pb-2 { padding-bottom: .5rem; }
.pb-3 { padding-bottom: 1rem; }
.pt-2 { padding-top: .5rem; }
.pt-3 { padding-top: 1rem; }
.px-3 { padding-left: 1rem; padding-right: 1rem; }
.py-2 { padding-top: .5rem; padding-bottom: .5rem; }
.py-3 { padding-top: 1rem; padding-bottom: 1rem; }

/* ===== TYPOGRAPHY ===== */
.text-center  { text-align: center; }
.text-end     { text-align: right; }
.text-muted   { color: var(--wz-text-muted); }
.text-soft    { color: var(--wz-text-soft); }
.text-danger  { color: var(--wz-danger); }
.text-success { color: var(--wz-success); }
.text-warning { color: var(--wz-warning); }
.text-accent  { color: var(--wz-accent); }
.text-theme-yellow { color: var(--wz-accent); }
.text-theme-orange { color: var(--wz-warning); }
.text-dark    { color: var(--wz-text); }

.fw-bold { font-weight: 700; }
.fw-800  { font-weight: 800; }

/* ===== FORM COMPONENTS ===== */
.wz-input,
.form-control {
    display: block;
    width: 100%;
    padding: .65rem .9rem;
    background: var(--wz-surface, #151712);
    border: 1px solid var(--wz-border, rgba(255,255,255,0.08));
    border-radius: var(--wz-r-md, 14px);
    color: var(--wz-text, #f4f1e8);
    font-size: .95rem;
    transition: border-color var(--wz-fast), box-shadow var(--wz-fast);
    outline: none;
}

.wz-input:focus, .form-control:focus {
    border-color: rgba(var(--wz-accent-rgb), 0.5);
    box-shadow: var(--wz-ring);
}

.wz-input::placeholder, .form-control::placeholder { color: var(--wz-text-muted); }

select.form-control,
select.wz-input,
.form-select {
    appearance: none;
    background-color: var(--wz-surface);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238f9685' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.8rem center;
    background-size: 16px 16px;
    padding-right: 2.5rem;
    cursor: pointer;
}

.form-select {
    display: block;
    width: 100%;
    padding: .65rem .9rem;
    background-color: var(--wz-surface);
    border: 1px solid var(--wz-border);
    border-radius: var(--wz-r-md);
    color: var(--wz-text);
    font-size: .95rem;
    transition: border-color var(--wz-fast), box-shadow var(--wz-fast);
    outline: none;
}

.form-select:focus {
    border-color: rgba(var(--wz-accent-rgb), 0.5);
    box-shadow: var(--wz-ring);
}

select.form-control:hover,
select.wz-input:hover,
.form-select:hover {
    border-color: var(--wz-border);
    background-color: var(--wz-surface-2);
}

select.form-control option,
select.wz-input option,
.form-select option {
    background: var(--wz-surface);
    color: var(--wz-text);
}

/* Light mode: donkerdere pijl zodat het zichtbaar blijft op lichte achtergrond */
[data-theme="light"] select.form-control,
[data-theme="light"] select.wz-input,
[data-theme="light"] .form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b6b5e' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
}

[data-theme="light"] select.form-control option,
[data-theme="light"] select.wz-input option,
[data-theme="light"] .form-select option {
    background: #ffffff;
    color: #1a1a1a;
}

.wz-label, .form-label {
    display: block;
    margin-bottom: .4rem;
    font-size: .85rem;
    font-weight: 600;
    color: var(--wz-text-muted);
    letter-spacing: .02em;
}

.form-group { margin-bottom: 1rem; }

/* Form floating */
.form-floating { position: relative; }
.form-floating > .form-control { padding-top: 1.4rem; padding-bottom: .4rem; }
.form-floating > label {
    position: absolute;
    top: 0; left: 0;
    padding: .65rem .9rem;
    color: var(--wz-text-muted);
    pointer-events: none;
    transition: transform var(--wz-fast), font-size var(--wz-fast);
}
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label {
    transform: translateY(-.5rem) scale(.78);
    font-size: .75rem;
}

/* Input group */
.input-group { display: flex; }
.input-group > .form-control { flex: 1 1 auto; border-radius: var(--wz-r-md) 0 0 var(--wz-r-md); }
.input-group-text {
    display: flex;
    align-items: center;
    padding: .65rem .85rem;
    background: var(--wz-surface-2, #181a14);
    border: 1px solid var(--wz-border);
    border-left: none;
    border-radius: 0 var(--wz-r-md) var(--wz-r-md) 0;
    color: var(--wz-text-muted);
    font-size: .9rem;
    white-space: nowrap;
}

/* Checkbox */
.form-check-input {
    width: 1rem; height: 1rem;
    margin-right: .4rem;
    accent-color: var(--wz-accent);
    cursor: pointer;
    vertical-align: middle;
}

/* Validation */
.is-invalid { border-color: var(--wz-danger) !important; }
.is-valid   { border-color: var(--wz-success) !important; }
span.text-danger, .invalid-feedback { display: block; font-size: .82rem; color: var(--wz-danger); margin-top: .25rem; }
.valid-feedback { display: block; font-size: .82rem; color: var(--wz-success); margin-top: .25rem; }

/* ===== BUTTONS ===== */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4rem;
    padding: .6rem 1.1rem;
    border-radius: var(--wz-r-md, 14px);
    border: 1px solid transparent;
    font-size: .92rem;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    transition: background var(--wz-fast), color var(--wz-fast), border-color var(--wz-fast), transform var(--wz-fast), filter var(--wz-fast);
}

.btn:active { transform: translateY(1px) scale(.99); }
.btn-lg { padding: .8rem 1.4rem; font-size: 1rem; border-radius: var(--wz-r-lg); }
.btn-sm { padding: .35rem .75rem; font-size: .82rem; border-radius: var(--wz-r-sm); }

.btn-primary   { background: var(--wz-accent); color: #111; border-color: var(--wz-accent); }
.btn-primary:hover { filter: brightness(1.08); }
.btn-secondary { background: rgba(255,255,255,0.05); color: var(--wz-text); border-color: var(--wz-border); }
.btn-secondary:hover { background: rgba(255,255,255,0.09); }
.btn-danger    { background: var(--wz-danger-soft); color: var(--wz-danger); border-color: var(--wz-danger-border); }
.btn-danger:hover { filter: brightness(1.1); }
.btn-outline   { background: transparent; color: var(--wz-text); border-color: var(--wz-border); }
.btn-outline:hover { background: var(--wz-surface); }

[data-theme="light"] .btn-secondary { background: rgba(0,0,0,0.04); border-color: var(--wz-border); }
[data-theme="light"] .btn-secondary:hover { background: rgba(0,0,0,0.07); }
[data-theme="light"] .btn-outline:hover { background: var(--wz-surface); }

/* ===== TABLE ===== */
.table { width: 100%; border-collapse: collapse; color: var(--wz-text); font-size: .92rem; }
.table th, .table td {
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--wz-border-soft);
    text-align: left;
    vertical-align: middle;
}
.table thead th {
    font-size: .78rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    color: var(--wz-text-muted);
}
.table tbody tr:hover { background: rgba(255,255,255,0.02); }
[data-theme="light"] .table tbody tr:hover { background: rgba(0,0,0,0.025); }
.table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }

/* ===== PROGRESS BAR ===== */
.progress {
    width: 100%;
    height: 8px;
    background: var(--wz-track, rgba(255,255,255,0.08));
    border-radius: 99px;
    overflow: hidden;
}
.progress-bar { height: 100%; border-radius: 99px; transition: width .4s ease; }
.progress-green  { background: var(--wz-success); }
.progress-yellow { background: var(--wz-accent); }
.progress-red    { background: var(--wz-danger); }
.dashboard-progress { margin-bottom: .25rem; }

/* ===== ALERTS ===== */
.alert-error, .alert-success,
.settings-alert, .settings-alert-success, .settings-alert-error {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .85rem 1.1rem;
    border-radius: var(--wz-r-lg, 18px);
    font-size: .92rem;
    font-weight: 600;
    margin-bottom: 1.25rem;
    border: 1px solid transparent;
}

.alert-success, .settings-alert-success {
    background: var(--wz-success-soft);
    border-color: var(--wz-success);
    color: var(--wz-success);
}

.alert-error, .settings-alert-error {
    background: var(--wz-danger-soft);
    border-color: var(--wz-danger-border);
    color: var(--wz-danger);
}

/* ===== MODAL BUTTONS (shared across pages) ===== */
.training-btn-secondary, .training-btn-danger,
.sub-btn-secondary, .sub-btn-danger {
    min-height: 44px;
    padding: .82rem 1rem;
    border-radius: var(--wz-r-lg, 18px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: .92rem;
    font-weight: 800;
    line-height: 1;
    cursor: pointer;
    border: 1px solid transparent;
    transition: transform var(--wz-fast), background var(--wz-fast), border-color var(--wz-fast), filter var(--wz-fast);
}

.training-btn-secondary, .sub-btn-secondary {
    height: 52px; min-width: 110px;
    border-color: var(--wz-border);
    background: var(--wz-surface);
    color: var(--wz-text);
}

.training-btn-secondary:hover, .sub-btn-secondary:hover {
    transform: translateY(-1px);
    background: var(--wz-surface-2);
}

.training-btn-danger, .sub-btn-danger {
    height: 52px;
    border-color: var(--wz-danger-border);
    background: var(--wz-danger-soft);
    color: var(--wz-danger);
}

.training-btn-danger:hover, .sub-btn-danger:hover { transform: translateY(-1px); filter: brightness(1.1); }
.training-btn-secondary:active, .training-btn-danger:active,
.sub-btn-secondary:active, .sub-btn-danger:active { transform: translateY(1px) scale(.99); }
.training-btn-secondary:focus-visible, .training-btn-danger:focus-visible,
.sub-btn-secondary:focus-visible, .sub-btn-danger:focus-visible { outline: none; box-shadow: var(--wz-ring); }

/* ===== DELETE MODAL (shared pattern) ===== */
.training-delete-modal, .sub-delete-modal {
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--wz-med), visibility var(--wz-med);
}

.training-delete-modal.is-open, .sub-delete-modal.is-open {
    opacity: 1; visibility: visible; pointer-events: auto;
}

.training-delete-modal.is-closing, .sub-delete-modal.is-closing {
    opacity: 0; visibility: visible; pointer-events: none;
}

.training-delete-backdrop, .sub-delete-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(3,4,6,0.78);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.training-delete-dialog, .sub-delete-dialog {
    position: absolute;
    top: 50%; left: 50%;
    width: min(92vw, 640px);
    transform: translate(-50%, -50%) scale(.965);
    opacity: 0;
    border-radius: var(--wz-r-xl, 22px);
    border: 1px solid var(--wz-border);
    background: var(--wz-panel);
    box-shadow: var(--wz-shadow-lg);
    padding: 1.5rem;
    color: var(--wz-text);
    transition: transform var(--wz-med), opacity var(--wz-med);
}

.training-delete-modal.is-open .training-delete-dialog,
.sub-delete-modal.is-open .sub-delete-dialog { transform: translate(-50%, -50%) scale(1); opacity: 1; }

.training-delete-modal.is-closing .training-delete-dialog,
.sub-delete-modal.is-closing .sub-delete-dialog { transform: translate(-50%, -48%) scale(.975); opacity: 0; }

.training-delete-close, .sub-delete-close {
    position: absolute; top: 1rem; right: 1rem;
    width: 40px; height: 40px;
    border-radius: var(--wz-r-md, 14px);
    border: 1px solid var(--wz-border-soft);
    background: var(--wz-surface);
    color: var(--wz-text-soft);
    display: inline-flex;
    align-items: center; justify-content: center;
    font-size: 1rem; cursor: pointer;
    transition: transform var(--wz-fast), background var(--wz-fast);
}

.training-delete-close:hover, .sub-delete-close:hover { transform: rotate(6deg); background: var(--wz-surface-2); color: var(--wz-text); }

.training-delete-head, .sub-delete-head {
    display: flex; align-items: flex-start; gap: 1rem;
    margin-bottom: 1.15rem; padding-right: 3.25rem;
}

.training-delete-head h3, .sub-delete-head h3 { margin: 0 0 .25rem; font-size: 1.55rem; font-weight: 800; }
.training-delete-head p, .sub-delete-head p { margin: 0; color: var(--wz-text-muted); font-size: .95rem; }

.training-delete-icon, .sub-delete-icon {
    width: 56px; height: 56px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    border-radius: var(--wz-r-lg, 18px);
    font-size: 1.2rem;
    background: var(--wz-danger-soft);
    border: 1px solid var(--wz-danger-border);
}

.training-delete-body, .sub-delete-body { display: flex; flex-direction: column; gap: 1rem; }

.training-delete-info, .sub-delete-info {
    padding: 1rem 1.1rem;
    border-radius: var(--wz-r-lg, 18px);
    background: var(--wz-surface);
    border: 1px solid var(--wz-border-soft);
}

.training-delete-label, .sub-delete-label {
    display: block; margin-bottom: .4rem;
    font-size: .79rem; font-weight: 700;
    letter-spacing: .04em; text-transform: uppercase;
    color: var(--wz-text-muted);
}

.training-delete-value, .sub-delete-value { font-size: 1rem; line-height: 1.5; color: var(--wz-text); }
.training-delete-description, .sub-delete-description { color: var(--wz-text-soft); }

.training-delete-warning, .sub-delete-warning {
    padding: 1rem 1.1rem;
    border-radius: var(--wz-r-lg, 18px);
    font-size: .94rem; font-weight: 600;
    color: var(--wz-danger);
    background: var(--wz-danger-soft);
    border: 1px solid var(--wz-danger-border);
}

.training-delete-actions, .sub-delete-actions {
    display: flex; justify-content: flex-end; align-items: center;
    gap: .85rem; margin-top: 1.35rem;
}

.training-delete-actions .training-btn-secondary,
.training-delete-actions .training-btn-danger,
.sub-delete-actions .sub-btn-secondary,
.sub-delete-actions .sub-btn-danger { min-width: 160px; }

/* ===== SIDEBAR RESPONSIVE ===== */
@media (max-width: 991.98px) {
    .wz-shell { flex-direction: column; min-height: auto; }
    .wz-sidebar { width: 100%; padding: 1rem .9rem; border-right: none; border-bottom: 1px solid var(--wz-border-soft); box-shadow: 0 10px 30px rgba(0,0,0,0.12); position: static; height: auto; overflow-y: visible; }
    .wz-main-wrap { overflow-y: visible; }
    .wz-main { padding: 1rem; }
    .wz-sidebar-header { margin-bottom: 0; }
    .wz-sidebar-brand  { margin-bottom: 0; }
    .wz-sidebar-toggle { display: flex; }
    .wz-sidebar-nav {
        flex-direction: column; gap: .35rem;
        overflow: hidden; max-height: 0; opacity: 0; margin-top: 0;
        transition: max-height .32s cubic-bezier(0.16, 1, 0.3, 1), opacity .24s ease, margin-top .24s ease;
    }
    .wz-sidebar-nav.wz-nav-open { max-height: 800px; opacity: 1; margin-top: .75rem; }
    .wz-sidebar-footer {
        overflow: hidden; max-height: 0; opacity: 0;
        transition: max-height .32s cubic-bezier(0.16, 1, 0.3, 1), opacity .24s ease;
    }
    .wz-sidebar-footer.wz-nav-open { max-height: 300px; opacity: 1; }
    .nav-link { width: 100%; padding: .75rem .9rem; font-size: .95rem; }
}

@media (max-width: 575.98px) {
    .wz-main { padding: .75rem; }
    .wz-sidebar { padding: .85rem .75rem; }
    .wz-brand-name { font-size: 1.05rem; }
    .nav-link { padding: .7rem .85rem; font-size: .92rem; }

    .training-delete-dialog, .sub-delete-dialog {
        width: calc(100vw - 24px); max-width: none;
        padding: 1rem; border-radius: var(--wz-r-lg, 18px);
    }
    .training-delete-actions, .sub-delete-actions { flex-direction: column-reverse; align-items: stretch; }
    .training-delete-actions .training-btn-secondary,
    .training-delete-actions .training-btn-danger,
    .sub-delete-actions .sub-btn-secondary,
    .sub-delete-actions .sub-btn-danger { width: 100%; min-width: 0; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition: none !important; animation: none !important; }
}

/* ===== CUSTOM SELECT DROPDOWN ===== */
/*
 * Vervangt native <select> met een volledig gestijlde dropdown.
 * De native <select> blijft in de DOM (verborgen) voor formulierverwerking.
 * Dropdown panel wordt als portal aan <body> gehangen zodat overflow:hidden
 * het nooit afknipt. Initialisatie via site.js.
 */

/* Wrapper: neemt de plek in van de originele <select>.
 * Geen expliciete width hier — die wordt door de JS ingesteld op basis van
 * de gemeten breedte van de originele <select> (100% of vaste px waarde). */
.wz-select {
    position: relative;
    display: block;
    box-sizing: border-box;
    flex-shrink: 0; /* voorkomt dat flex de wrapper ongewenst verkleint */
}

/*
 * Trigger button.
 * Klassen van de originele <select> worden ook op de trigger gezet zodat
 * bestaande CSS de juiste hoogte, padding en kleuren geeft.
 * Hieronder overschrijven we alleen wat select-specifiek is.
 */
.wz-select__trigger {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    width: 100%; /* wordt overschreven door klassen als training-input-small */
    text-align: left;
    cursor: pointer;
    font-family: inherit;
    outline: none;
    box-sizing: border-box;
    min-height: 0;  /* laat expliciete height van de overgenomen klasse altijd winnen */
    /* Fallback-stijl als geen andere klasse hoogte/padding geeft */
    padding-top: .65rem;
    padding-bottom: .65rem;
    padding-left: .9rem;
    background: var(--wz-surface, #151712);
    border: 1px solid var(--wz-border, rgba(255,255,255,0.08));
    border-radius: var(--wz-r-md, 14px);
    color: var(--wz-text, #f4f1e8);
    font-size: .95rem;
    transition: border-color var(--wz-fast, .16s), box-shadow var(--wz-fast, .16s), background var(--wz-fast, .16s);
    /* Overschrijf select-specifieke CSS die op de klassen staat */
    background-image: none !important;
    padding-right: 2.5rem !important;  /* ruimte voor het pijl-icoon */
}

.wz-select__trigger:hover {
    background: var(--wz-surface-2, #181a14);
    border-color: rgba(255,255,255,0.12);
}

/* Open-state: trigger krijgt accent border */
.wz-select--open .wz-select__trigger,
.wz-select__trigger:focus-visible {
    border-color: rgba(var(--wz-accent-rgb), 0.5) !important;
    box-shadow: var(--wz-ring) !important;
}

/* Tekst in trigger */
.wz-select__text {
    flex: 1 1 auto;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.4;
}

.wz-select__text--placeholder {
    color: var(--wz-text-muted, #8f9685);
}

/* Pijl-icoon — absolute rechts, zodat hij altijd op de goede plek staat
   ongeacht welke padding de trigger heeft */
.wz-select__icon {
    position: absolute;
    right: .85rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--wz-text-muted, #8f9685);
    display: flex;
    align-items: center;
    line-height: 0;
    pointer-events: none;
    transition: transform var(--wz-fast, .16s);
}

.wz-select--open .wz-select__icon {
    transform: translateY(-50%) rotate(180deg);
}

/*
 * Dropdown panel — wordt als portal aan <body> gehangen (position: fixed)
 * zodat overflow:hidden op tussenliggende containers hem nooit afknipt.
 * De JS voegt .wz-select__dropdown--open toe voor de animatie.
 */
.wz-select__dropdown {
    position: fixed;
    z-index: 99999;
    background: var(--wz-panel, #181b10);
    border: 1px solid var(--wz-border, rgba(255,255,255,0.1));
    border-radius: var(--wz-r-lg, 18px);
    box-shadow: 0 20px 48px rgba(0,0,0,0.48), 0 4px 12px rgba(0,0,0,0.22);
    padding: .35rem;
    max-height: 260px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--wz-scroll-thumb, #555) transparent;
    /* Beginstand (gesloten) */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px) scale(.98);
    transform-origin: top center;
    transition: opacity .14s ease, transform .14s ease, visibility .14s;
}

.wz-select__dropdown::-webkit-scrollbar { width: 6px; }
.wz-select__dropdown::-webkit-scrollbar-thumb { background: var(--wz-scroll-thumb, #555); border-radius: 3px; }

/* Open-animatie */
.wz-select__dropdown--open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

/* Dropdown opent omhoog als er onderaan geen ruimte is */
.wz-select__dropdown--flip {
    transform-origin: bottom center;
}
.wz-select__dropdown--flip:not(.wz-select__dropdown--open) {
    transform: translateY(6px) scale(.98);
}

/* Optie-knoppen */
.wz-select__option {
    display: block;
    width: 100%;
    padding: .52rem .8rem;
    border: none;
    background: transparent;
    border-radius: var(--wz-r-sm, 10px);
    color: var(--wz-text, #f4f1e8);
    font-size: .92rem;
    font-family: inherit;
    text-align: left;
    cursor: pointer;
    outline: none;
    transition: background var(--wz-fast, .16s), color var(--wz-fast, .16s);
    line-height: 1.4;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.wz-select__option:hover,
.wz-select__option:focus-visible {
    background: rgba(var(--wz-accent-rgb), 0.1);
    color: var(--wz-accent, #e6ea35);
}

.wz-select__option--selected {
    background: rgba(var(--wz-accent-rgb), 0.13);
    color: var(--wz-accent, #e6ea35);
    font-weight: 600;
}

.wz-select__option--placeholder {
    color: var(--wz-text-muted, #8f9685);
    font-style: italic;
}

/* Light mode — trigger */
[data-theme="light"] .wz-select__trigger {
    background: #ffffff;
    border-color: rgba(0,0,0,0.1);
    color: #1a1a1a;
}

[data-theme="light"] .wz-select__trigger:hover {
    background: #f8f8f4;
}

[data-theme="light"] .wz-select--open .wz-select__trigger,
[data-theme="light"] .wz-select__trigger:focus-visible {
    border-color: rgba(var(--wz-accent-rgb), 0.4) !important;
}

/* Light mode — portal dropdown (zit aan body, erft data-theme van html/body) */
[data-theme="light"] .wz-select__dropdown {
    background: #ffffff;
    border-color: rgba(0,0,0,0.1);
    box-shadow: 0 16px 40px rgba(0,0,0,0.12), 0 4px 12px rgba(0,0,0,0.06);
}

[data-theme="light"] .wz-select__option {
    color: #1a1a1a;
}

[data-theme="light"] .wz-select__option:hover,
[data-theme="light"] .wz-select__option:focus-visible {
    background: rgba(var(--wz-accent-rgb), 0.08);
    color: #333;
}

[data-theme="light"] .wz-select__option--selected {
    background: rgba(var(--wz-accent-rgb), 0.12);
    color: #1a1a1a;
}

[data-theme="light"] .wz-select__option--placeholder {
    color: #999;
}
