/* ============================================================
   SPOED.APP -- app.css
   Lichte sidebar, mobile-first, Bootstrap 5 + eigen componenten
   Brand: rood #e30613, navy #1a2b4a
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
    --sp-sidebar-w:      260px;
    --sp-topbar-h:       58px;
    --sp-red:            #e30613;
    --sp-red-dark:       #b8040f;
    --sp-navy:           #1a2b4a;
    --sp-navy-light:     #243557;
    --sp-primary:        #1a2b4a;
    --sp-primary-hover:  #243557;
    --sp-accent:         #e30613;
    --sp-bg:             #f0f2f5;
    --sp-surface:        #ffffff;
    --sp-surface-2:      #f8f9fb;
    --sp-border:         #e2e6ed;
    --sp-sidebar-bg:          #ffffff;
    --sp-sidebar-border:      #e2e6ed;
    --sp-sidebar-text:        #4a5568;
    --sp-sidebar-label:       #9aa3b0;
    --sp-sidebar-active:      #1a2b4a;
    --sp-sidebar-active-bg:   rgba(26,43,74,.08);
    --sp-sidebar-hover-bg:    rgba(26,43,74,.05);
    --sp-sidebar-icon:        #6b7a94;
    --sp-sidebar-active-icon: #e30613;
    --sp-text:           #1a202c;
    --sp-text-2:         #4a5568;
    --sp-text-3:         #9aa3b0;
    --sp-font:           'Inter', system-ui, sans-serif;
    --sp-mono:           'JetBrains Mono', monospace;
    --sp-r:              8px;
    --sp-r-lg:           12px;
    --sp-r-xl:           16px;
    --sp-shadow-sm:      0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --sp-shadow:         0 4px 16px rgba(0,0,0,.08);
    --sp-shadow-sidebar: 2px 0 12px rgba(0,0,0,.06);
    --sp-t:              .15s ease;
}

@media (prefers-color-scheme: dark) {
    :root {
        --sp-bg:             #0f1520;
        --sp-surface:        #1a2235;
        --sp-surface-2:      #1f2840;
        --sp-border:         #2a3550;
        --sp-text:           #e8edf5;
        --sp-text-2:         #8896b0;
        --sp-text-3:         #4a5a78;
        --sp-sidebar-bg:          #141e30;
        --sp-sidebar-border:      #1f2d45;
        --sp-sidebar-text:        #8896b0;
        --sp-sidebar-label:       #4a5a78;
        --sp-sidebar-active:      #e8edf5;
        --sp-sidebar-active-bg:   rgba(227,6,19,.12);
        --sp-sidebar-hover-bg:    rgba(255,255,255,.04);
        --sp-sidebar-icon:        #5a6a88;
        --sp-sidebar-active-icon: #e30613;
    }
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--sp-font);
    font-size: .9rem;
    line-height: 1.6;
    color: var(--sp-text);
    background: var(--sp-bg);
    -webkit-font-smoothing: antialiased;
    margin: 0;
}
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--sp-border); border-radius: 99px; }

/* SIDEBAR */
.sp-sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: var(--sp-sidebar-w);
    background: var(--sp-sidebar-bg);
    border-right: 1px solid var(--sp-sidebar-border);
    box-shadow: var(--sp-shadow-sidebar);
    display: flex;
    flex-direction: column;
    z-index: 200;
    transition: transform .25s cubic-bezier(.4,0,.2,1);
    overflow-y: auto;
    overflow-x: hidden;
}
.sp-sidebar-header {
    padding: 0 1.25rem;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    min-height: var(--sp-topbar-h);
}
.sp-sidebar-header img { height: 34px; width: auto; }
.sp-nav { flex: 1; padding: .75rem .75rem 0; }
.sp-nav ul { list-style: none; margin: 0; padding: 0; }
.sp-nav-label {
    font-size: .65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--sp-sidebar-label);
    padding: 1rem .5rem .3rem;
    display: block;
}
.sp-nav li { position: relative; }
.sp-nav-link {
    display: flex;
    align-items: center;
    gap: .65rem;
    padding: .5rem .85rem;
    border-radius: var(--sp-r);
    color: var(--sp-sidebar-text);
    text-decoration: none;
    font-size: .875rem;
    font-weight: 500;
    transition: background var(--sp-t), color var(--sp-t);
    margin-bottom: 2px;
}
.sp-nav-link i {
    font-size: 1rem;
    flex-shrink: 0;
    color: var(--sp-sidebar-icon);
    transition: color var(--sp-t);
    width: 1.1rem;
    text-align: center;
}
.sp-nav-link:hover { background: var(--sp-sidebar-hover-bg); color: var(--sp-sidebar-active); }
.sp-nav-link:hover i { color: var(--sp-sidebar-active); }
.sp-nav-link.active { background: var(--sp-sidebar-active-bg); color: var(--sp-sidebar-active); font-weight: 600; }
.sp-nav-link.active i { color: var(--sp-sidebar-active-icon); }
.sp-nav-link.active::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%);
    width: 3px; height: 60%;
    background: var(--sp-accent);
    border-radius: 0 3px 3px 0;
}
.sp-sidebar-footer {
    padding: .75rem;
    border-top: 1px solid var(--sp-sidebar-border);
    flex-shrink: 0;
    margin-top: auto;
}
.sp-user-pill {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .6rem .75rem;
    border-radius: var(--sp-r);
    text-decoration: none;
    color: var(--sp-sidebar-text);
    transition: background var(--sp-t);
    border: 1px solid transparent;
}
.sp-user-pill:hover { background: var(--sp-sidebar-hover-bg); border-color: var(--sp-border); color: var(--sp-sidebar-active); }
.sp-user-pill-info { flex: 1; overflow: hidden; }
.sp-user-pill-name { display: block; font-size: .8rem; font-weight: 600; color: var(--sp-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-user-pill-role { font-size: .68rem; color: var(--sp-text-3); text-transform: capitalize; }
.sp-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 199; backdrop-filter: blur(2px); }

/* LAYOUT */
.sp-wrapper { margin-left: var(--sp-sidebar-w); min-height: 100vh; display: flex; flex-direction: column; }

/* TOPBAR */
.sp-topbar {
    position: sticky; top: 0; z-index: 100;
    height: var(--sp-topbar-h);
    background: var(--sp-surface);
    border-bottom: 1px solid var(--sp-border);
    display: flex; align-items: center;
    padding: 0 1.5rem; gap: 1rem;
    box-shadow: var(--sp-shadow-sm);
}
.sp-topbar-right { display: flex; align-items: center; gap: .5rem; margin-left: auto; }
.sp-topbar-center { position: absolute; left: 50%; transform: translateX(-50%); pointer-events: none; }
.sp-env-badge {
    display: inline-flex; align-items: center; gap: .35rem;
    font-size: .7rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
    color: #92400e; background: #fef3c7; border: 1px solid #fcd34d;
    padding: .2rem .6rem; border-radius: 20px;
}
.sp-menu-btn {
    background: none; border: none; font-size: 1.3rem;
    color: var(--sp-text-2); padding: .3rem .4rem;
    cursor: pointer; line-height: 1;
    border-radius: var(--sp-r); transition: background var(--sp-t);
}
.sp-menu-btn:hover { background: var(--sp-surface-2); }
.sp-icon-btn {
    width: 36px; height: 36px;
    border-radius: var(--sp-r);
    border: 1px solid var(--sp-border);
    background: var(--sp-surface);
    color: var(--sp-text-2);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; position: relative;
    transition: background var(--sp-t), border-color var(--sp-t);
    font-size: 1rem;
}
.sp-icon-btn:hover { background: var(--sp-surface-2); border-color: var(--sp-primary); color: var(--sp-text); }
.sp-notif-badge {
    position: absolute; top: 4px; right: 4px;
    min-width: 16px; height: 16px; border-radius: 8px; padding: 0 4px;
    background: var(--sp-accent); border: 2px solid var(--sp-surface);
    color: #fff; font-size: .58rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    line-height: 1;
}
.sp-link-btn { background: none; border: none; cursor: pointer; padding: 0; }
.sp-notification-dot {
    position: absolute; top: 7px; right: 7px;
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--sp-accent); border: 2px solid var(--sp-surface);
}
.sp-notification-dropdown { width: 320px; padding: 0; border-radius: var(--sp-r-lg); border: 1px solid var(--sp-border); overflow: hidden; box-shadow: var(--sp-shadow); }
.sp-notification-header { display: flex; justify-content: space-between; align-items: center; padding: .65rem 1rem; border-bottom: 1px solid var(--sp-border); background: var(--sp-surface-2); }
.sp-notification-body { max-height: 280px; overflow-y: auto; }
.sp-notification-item { display: flex; gap: .75rem; align-items: flex-start; padding: .75rem 1rem; border-bottom: 1px solid var(--sp-border); transition: background var(--sp-t); }
.sp-notification-item:hover { background: var(--sp-surface-2); }
.sp-notification-item:last-child { border-bottom: none; }
.sp-notification-unread { background: rgba(26,43,74,.03); }
.sp-notification-icon { width: 34px; height: 34px; border-radius: var(--sp-r); display: flex; align-items: center; justify-content: center; font-size: .9rem; flex-shrink: 0; background: var(--sp-surface-2); color: var(--sp-primary); }
.sp-notification-footer { padding: .6rem 1rem; text-align: center; border-top: 1px solid var(--sp-border); background: var(--sp-surface-2); }
.sp-avatar-btn { background: none; border: none; padding: 0; cursor: pointer; border-radius: 50%; }

/* AVATARS */
.sp-avatar { display: inline-flex; align-items: center; justify-content: center; border-radius: 50%; background: var(--sp-navy); color: #fff; font-weight: 700; letter-spacing: .03em; flex-shrink: 0; }
.sp-avatar-xs  { width: 26px; height: 26px; font-size: .6rem; }
.sp-avatar-sm  { width: 30px; height: 30px; font-size: .65rem; }
.sp-avatar-md  { width: 36px; height: 36px; font-size: .75rem; }
.sp-avatar-lg  { width: 52px; height: 52px; font-size: 1rem; }
.sp-avatar-xl  { width: 80px; height: 80px; font-size: 1.4rem; }

/* MAIN */
.sp-main { flex: 1; padding: 1.75rem 2rem 1rem; }
.sp-footer { padding: .75rem 2rem; border-top: 1px solid var(--sp-border); display: flex; justify-content: space-between; font-size: .78rem; color: var(--sp-text-3); background: var(--sp-surface); }

/* PAGE HEADER */
.sp-page-header { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.5rem; }
.sp-page-title { font-size: 1.35rem; font-weight: 700; letter-spacing: -.02em; margin: 0; color: var(--sp-text); }
.sp-breadcrumb { font-size: .78rem; color: var(--sp-text-3); margin-top: .15rem; }
.sp-breadcrumb a { color: var(--sp-text-3); text-decoration: none; }
.sp-breadcrumb a:hover { color: var(--sp-primary); }
.sp-page-actions { display: flex; gap: .5rem; flex-wrap: wrap; }

/* CARDS */
.sp-card { background: var(--sp-surface); border: 1px solid var(--sp-border); border-radius: var(--sp-r-lg); box-shadow: var(--sp-shadow-sm); }
.sp-card-header { display: flex; align-items: center; justify-content: space-between; padding: .85rem 1.25rem; border-bottom: 1px solid var(--sp-border); }
.sp-card-title { font-weight: 600; font-size: .9rem; display: flex; align-items: center; gap: .4rem; color: var(--sp-text); }
.sp-card-body { padding: 1.25rem; }

/* STAT CARDS */
.sp-stat { background: var(--sp-surface); border: 1px solid var(--sp-border); border-radius: var(--sp-r-lg); padding: 1.25rem; display: flex; align-items: flex-start; gap: 1rem; box-shadow: var(--sp-shadow-sm); transition: box-shadow var(--sp-t), transform var(--sp-t); }
.sp-stat:hover { box-shadow: var(--sp-shadow); transform: translateY(-1px); }
.sp-stat-icon { width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.15rem; flex-shrink: 0; }
.sp-stat-label { font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; color: var(--sp-text-3); }
.sp-stat-value { font-size: 1.7rem; font-weight: 700; letter-spacing: -.03em; line-height: 1.15; color: var(--sp-text); }

/* TABLES */
.sp-table { width: 100%; border-collapse: collapse; }
.sp-table th { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--sp-text-3); padding: .6rem 1.25rem; border-bottom: 2px solid var(--sp-border); background: var(--sp-surface-2); white-space: nowrap; text-align: left; }
.sp-table td { padding: .75rem 1.25rem; border-bottom: 1px solid var(--sp-border); vertical-align: middle; font-size: .875rem; color: var(--sp-text); }
.sp-table tbody tr:last-child td { border-bottom: none; }
.sp-table tbody tr:hover td { background: var(--sp-surface-2); }
.sp-table-row-link { cursor: pointer; }

/* BUTTONS */
.sp-btn { display: inline-flex; align-items: center; gap: .35rem; padding: .48rem 1.1rem; border-radius: var(--sp-r); font-weight: 500; font-size: .875rem; font-family: var(--sp-font); cursor: pointer; text-decoration: none; border: 1px solid transparent; transition: background var(--sp-t), border-color var(--sp-t), box-shadow var(--sp-t); white-space: nowrap; line-height: 1.4; }
.sp-btn:active { transform: scale(.97); }
.sp-btn-primary { background: var(--sp-primary); color: #fff; border-color: var(--sp-primary); }
.sp-btn-primary:hover { background: var(--sp-primary-hover); border-color: var(--sp-primary-hover); color: #fff; box-shadow: 0 2px 8px rgba(26,43,74,.25); }
.sp-btn-accent { background: var(--sp-accent); color: #fff; border-color: var(--sp-accent); }
.sp-btn-accent:hover { background: var(--sp-red-dark); border-color: var(--sp-red-dark); color: #fff; }
.sp-btn-outline { background: transparent; color: var(--sp-text); border-color: var(--sp-border); }
.sp-btn-outline:hover { background: var(--sp-surface-2); border-color: var(--sp-primary); color: var(--sp-text); }
.sp-btn-ghost { background: transparent; color: var(--sp-text-2); border-color: transparent; }
.sp-btn-ghost:hover { background: var(--sp-surface-2); color: var(--sp-text); }
.sp-btn-success { background: #16a34a; color: #fff; border-color: #16a34a; }
.sp-btn-success:hover { background: #15803d; color: #fff; }
.sp-btn-danger-outline { background: transparent; color: #dc2626; border-color: #dc2626; }
.sp-btn-danger-outline:hover { background: rgba(220,38,38,.06); }
.sp-btn-sm { padding: .32rem .75rem; font-size: .8rem; }
.sp-btn-xs { padding: .2rem .55rem; font-size: .75rem; }

/* BADGES */
.sp-badge { display: inline-flex; align-items: center; gap: .25rem; padding: .2rem .65rem; border-radius: 20px; font-size: .68rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.sp-badge-role-admin        { background: rgba(227,6,19,.1);    color: #c00; }
.sp-badge-role-diensthoofd  { background: rgba(26,43,74,.1);    color: #1a2b4a; }
.sp-badge-role-staflid      { background: rgba(37,99,235,.1);   color: #1d4ed8; }
.sp-badge-role-aso          { background: rgba(5,150,105,.1);   color: #047857; }
.sp-badge-role-verpleging   { background: rgba(217,119,6,.1);   color: #b45309; }
.sp-badge-role-secretariaat { background: rgba(100,116,139,.1); color: #475569; }
.sp-badge-success { background: rgba(22,163,74,.1);  color: #15803d; }
.sp-badge-warning { background: rgba(217,119,6,.1);  color: #b45309; }
.sp-badge-danger  { background: rgba(220,38,38,.1);  color: #b91c1c; }
.sp-badge-info    { background: rgba(26,43,74,.08);  color: #1a2b4a; }
.sp-badge-neutral { background: rgba(100,116,139,.1);color: #475569; }

/* FORMS */
.sp-label { display: block; font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; color: var(--sp-text-2); margin-bottom: .3rem; }
.sp-input { display: block; width: 100%; padding: .52rem .9rem; border: 1px solid var(--sp-border); border-radius: var(--sp-r); background: var(--sp-surface); color: var(--sp-text); font-family: var(--sp-font); font-size: .875rem; line-height: 1.5; outline: none; transition: border-color var(--sp-t), box-shadow var(--sp-t); -webkit-appearance: none; }
.sp-input:focus { border-color: var(--sp-primary); box-shadow: 0 0 0 3px rgba(26,43,74,.1); }
textarea.sp-input { resize: vertical; }
.sp-input-group { position: relative; display: flex; align-items: stretch; }
.sp-input-group .sp-input { border-radius: var(--sp-r) 0 0 var(--sp-r); flex: 1; }
.sp-input-addon { display: flex; align-items: center; padding: 0 .85rem; border: 1px solid var(--sp-border); border-left: none; border-radius: 0 var(--sp-r) var(--sp-r) 0; background: var(--sp-surface-2); color: var(--sp-text-2); cursor: pointer; font-size: 1rem; transition: background var(--sp-t); }
.sp-input-addon:hover { background: var(--sp-border); }

/* ALERTS */
.sp-alert { display: flex; align-items: flex-start; gap: .75rem; padding: .85rem 1rem; border-radius: var(--sp-r); font-size: .875rem; border: 1px solid transparent; margin-bottom: 1rem; }
.sp-alert i { margin-top: .1rem; flex-shrink: 0; }
.sp-alert-success { background: rgba(22,163,74,.08); border-color: rgba(22,163,74,.2); }
.sp-alert-success i { color: #16a34a; }
.sp-alert-danger  { background: rgba(220,38,38,.08); border-color: rgba(220,38,38,.2); }
.sp-alert-danger i { color: #dc2626; }
.sp-alert-info    { background: rgba(26,43,74,.06);  border-color: rgba(26,43,74,.15); }
.sp-alert-info i { color: var(--sp-navy); }
.sp-alert-warning { background: rgba(217,119,6,.08); border-color: rgba(217,119,6,.2); }
.sp-alert-warning i { color: #d97706; }

/* BULLETIN */
.sp-bulletin { border-left: 3px solid var(--sp-border); padding: .7rem 1rem; margin-bottom: .5rem; border-radius: 0 var(--sp-r) var(--sp-r) 0; transition: background var(--sp-t); }
.sp-bulletin:last-child { margin-bottom: 0; }
.sp-bulletin:hover { background: var(--sp-surface-2); }
.sp-bulletin-info    { border-color: var(--sp-navy); background: rgba(26,43,74,.03); }
.sp-bulletin-urgent  { border-color: var(--sp-accent); background: rgba(227,6,19,.03); }
.sp-bulletin-success { border-color: #16a34a; background: rgba(22,163,74,.03); }
.sp-bulletin-meta    { font-size: .72rem; color: var(--sp-text-3); font-family: var(--sp-mono); margin-bottom: .2rem; }
.sp-bulletin-title   { font-weight: 600; font-size: .9rem; color: var(--sp-text); }
.sp-bulletin-body    { font-size: .82rem; color: var(--sp-text-2); margin-top: .2rem; }

/* USER CELL */
.sp-user-cell { display: flex; align-items: center; gap: .6rem; }

/* UTILS */
.sp-mono { font-family: var(--sp-mono); font-size: .82rem; }
.sp-link { color: var(--sp-primary); text-decoration: none; }
.sp-link:hover { text-decoration: underline; }
.sp-divider { height: 1px; background: var(--sp-border); margin: 1.25rem 0; }

/* TABS */
.sp-tab-nav { display: flex; gap: .15rem; border-bottom: 2px solid var(--sp-border); margin-bottom: 1.5rem; overflow-x: auto; -ms-overflow-style: none; scrollbar-width: none; }
.sp-tab-nav::-webkit-scrollbar { display: none; }
.sp-tab-link { display: flex; align-items: center; gap: .4rem; padding: .6rem 1rem; color: var(--sp-text-2); text-decoration: none; font-size: .875rem; font-weight: 500; white-space: nowrap; border-bottom: 2px solid transparent; margin-bottom: -2px; transition: color var(--sp-t), border-color var(--sp-t); }
.sp-tab-link:hover { color: var(--sp-text); }
.sp-tab-link.active { color: var(--sp-primary); border-color: var(--sp-accent); font-weight: 600; }

/* AVATAR UPLOAD */
.sp-avatar-upload { position: relative; display: inline-block; }
.sp-avatar-upload-overlay { position: absolute; inset: 0; border-radius: 50%; background: rgba(0,0,0,.5); color: #fff; display: flex; align-items: center; justify-content: center; font-size: .7rem; font-weight: 600; opacity: 0; transition: opacity var(--sp-t); cursor: pointer; text-align: center; }
.sp-avatar-upload:hover .sp-avatar-upload-overlay { opacity: 1; }

/* AUTH LAYOUT */
.sp-auth-body { min-height: 100vh; display: flex; background: var(--sp-navy); overflow: hidden; }
.sp-auth-left { flex: 1; display: none; position: relative; overflow: hidden; }
@media (min-width: 992px) { .sp-auth-left { display: block; } }
.sp-auth-left img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.sp-auth-left-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(26,43,74,.75) 0%, rgba(26,43,74,.35) 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 2.5rem; }
.sp-auth-left-tagline { color: rgba(255,255,255,.95); font-size: 1.5rem; font-weight: 700; line-height: 1.3; margin-bottom: .5rem; }
.sp-auth-left-sub { color: rgba(255,255,255,.65); font-size: .9rem; }
.sp-auth-right { width: 100%; max-width: 440px; background: var(--sp-surface); display: flex; flex-direction: column; justify-content: center; padding: 3rem 2.5rem; }
@media (max-width: 991.98px) { .sp-auth-right { max-width: 100%; padding: 2rem 1.5rem; } }
.sp-auth-logo { display: flex; align-items: center; margin-bottom: 2.5rem; }
.sp-auth-logo img { height: 30px; width: auto; }
.sp-auth-title { font-size: 1.5rem; font-weight: 700; color: var(--sp-text); margin-bottom: .35rem; letter-spacing: -.02em; }
.sp-auth-sub { color: var(--sp-text-2); font-size: .9rem; margin-bottom: 2rem; }

/* RESPONSIVE */
@media (max-width: 991.98px) {
    .sp-sidebar { transform: translateX(calc(-1 * var(--sp-sidebar-w))); box-shadow: none; }
    .sp-sidebar.open { transform: translateX(0); box-shadow: var(--sp-shadow); }
    .sp-backdrop.open { display: block; }
    .sp-wrapper { margin-left: 0; }
    .sp-main { padding: 1.25rem 1rem; }
    .sp-footer { padding: .75rem 1rem; }
}
@media (max-width: 767.98px) {
    .sp-page-header { flex-direction: column; align-items: flex-start; }
    .sp-page-actions { width: 100%; }
    .sp-page-actions .sp-btn { flex: 1; justify-content: center; }
    .sp-stat-value { font-size: 1.4rem; }
    .sp-topbar { padding: 0 1rem; }
}
@media (max-width: 575.98px) {
    .sp-main { padding: 1rem .75rem; }
    .sp-table th, .sp-table td { padding: .6rem .75rem; }
    .sp-card-header { padding: .75rem 1rem; }
    .sp-card-body { padding: 1rem; }
}

/* AUTH LAYOUT -- gecentreerd venster met hero image */
.sp-auth-body {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f0f2f5;
    padding: 1.5rem;
}

.sp-auth-card {
    width: 100%;
    max-width: 440px;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 8px 32px rgba(0,0,0,.1), 0 1px 3px rgba(0,0,0,.06);
    overflow: hidden;
}

/* Hero: ziekenhuis afbeelding bovenaan */
.sp-auth-hero {
    background: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 2rem 1rem;
}

.sp-auth-hero img {
    max-width: 100%;
    max-height: 160px;
    object-fit: contain;
}

/* Form area */
.sp-auth-form-area {
    padding: 1.75rem 2rem;
}

.sp-auth-logo-wrap {
    margin-bottom: 1.5rem;
}

.sp-auth-logo-wrap img { height: 26px; }

.sp-auth-card-footer {
    padding: .75rem 2rem;
    border-top: 1px solid #e2e6ed;
    font-size: .72rem;
    color: #9aa3b0;
    text-align: center;
    background: #f8f9fb;
}

@media (max-width: 480px) {
    .sp-auth-form-area { padding: 1.5rem; }
    .sp-auth-hero { padding: 1.25rem 1.5rem 1rem; }
    .sp-auth-hero img { max-height: 120px; }
}

/* NOTIFICATION ROWS */
.sp-notif-row {
    display: flex;
    align-items: flex-start;
    gap: .9rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--sp-border);
    transition: background var(--sp-t);
}
.sp-notif-row:last-child { border-bottom: none; }
.sp-notif-row:hover { background: var(--sp-surface-2); }
.sp-notif-row--unread { background: rgba(26,43,74,.03); }
.sp-notif-row-icon {
    width: 38px; height: 38px;
    border-radius: var(--sp-r);
    display: flex; align-items: center; justify-content: center;
    font-size: .95rem;
    flex-shrink: 0;
}
.sp-notif-row-body { flex: 1; min-width: 0; }
.sp-notif-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--sp-accent);
    flex-shrink: 0;
    margin-top: .4rem;
}

/* SHIFT / SWAP CARDS (mobile-friendly list items) */
.sp-shift-card {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1.25rem;
    border-bottom: 1px solid var(--sp-border);
    transition: background var(--sp-t);
}
.sp-shift-card:last-child { border-bottom: none; }
.sp-shift-card:hover { background: var(--sp-surface-2); }

.sp-shift-card-date {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 38px;
    flex-shrink: 0;
}
.sp-shift-day {
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--sp-text-3);
    letter-spacing: .04em;
}
.sp-shift-dm {
    font-size: .85rem;
    font-weight: 700;
    color: var(--sp-text);
    font-family: var(--sp-mono);
}

.sp-shift-card-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: .2rem;
    min-width: 0;
}

/* Stat label: don't wrap */
.sp-stat-label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Small input variant */
.sp-input-sm {
    padding: .32rem .65rem;
    font-size: .8rem;
}

/* SHIFT PREFS TABLE (label links, input rechts) */
.sp-prefs-table { width: 100%; border-collapse: collapse; }
.sp-prefs-table tr { border-bottom: 1px solid var(--sp-border); }
.sp-prefs-table tr:last-child { border-bottom: none; }
.sp-prefs-table td { padding: .75rem .5rem; vertical-align: middle; }
.sp-prefs-label {
    width: 40%;
    font-size: .875rem;
    font-weight: 500;
    color: var(--sp-text-2);
    padding-right: 1.5rem;
}

/* DUAL RANGE SLIDER */
.sp-dual-range { position: relative; padding-top: .5rem; }
.sp-dual-range-labels {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: .82rem;
    margin-bottom: .4rem;
    font-family: var(--sp-mono);
}
.sp-dual-range-labels span:first-child,
.sp-dual-range-labels span:last-child {
    background: var(--sp-primary);
    color: #fff;
    padding: .1rem .45rem;
    border-radius: 4px;
    font-size: .75rem;
    min-width: 1.6rem;
    text-align: center;
}
.sp-dual-range-track {
    position: relative;
    height: 6px;
    background: var(--sp-border);
    border-radius: 3px;
}
.sp-dual-range-fill {
    position: absolute;
    height: 100%;
    background: var(--sp-primary);
    border-radius: 3px;
    pointer-events: none;
    top: 0;
}
.sp-range-thumb {
    position: absolute;
    width: 100%;
    height: 6px;
    background: transparent;
    pointer-events: none;
    -webkit-appearance: none;
    appearance: none;
    outline: none;
    top: 0;
}
.sp-range-thumb::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--sp-primary);
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,.2);
    cursor: pointer;
    pointer-events: all;
    margin-top: -6px;
}
.sp-range-thumb::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--sp-primary);
    border: 2px solid #fff;
    cursor: pointer;
    pointer-events: all;
}

/* TEAM CARDS */
.sp-team-card { transition: box-shadow var(--sp-t), transform var(--sp-t); }
.sp-team-card:hover { box-shadow: var(--sp-shadow); transform: translateY(-1px); }
.sp-team-card-inner {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .85rem 1rem;
}
.sp-team-card-info { flex: 1; min-width: 0; }

/* PERMISSION TABLE */
.sp-perm-table .sp-perm-module-col  { min-width:200px; }
.sp-perm-table .sp-perm-role-header { padding:.5rem .4rem; vertical-align:middle; white-space:nowrap; }
.sp-perm-table .sp-perm-lvl-row th  { font-size:.65rem; font-weight:700; color:var(--sp-text-2); padding:.2rem .3rem; text-transform:uppercase; letter-spacing:.05em; }
.sp-perm-table .sp-perm-lvl         { width:52px; min-width:52px; }
.sp-perm-table .sp-perm-cell        { padding:.35rem .3rem; width:40px; min-width:40px; vertical-align:middle; }
.sp-perm-table .sp-perm-cell .form-check-input { margin:0; }
.sp-perm-table .sp-perm-action-label { padding-left:1.5rem; font-size:.82rem; color:var(--sp-text-2); }
.sp-perm-module-row td               { background:var(--sp-surface-2,#f8fafc); padding:.5rem .75rem !important; border-top:2px solid var(--sp-border) !important; color:var(--sp-text-1); }
.sp-perm-module-row:first-child td   { border-top:none !important; }
.sp-perm-granted      { color:#16a34a; font-size:.9rem; }
.sp-perm-granted-all  { color:#94a3b8; font-size:.9rem; }
.sp-perm-none         { color:#e2e8f0; font-size:.9rem; }

/* HELP POPOVER BUTTON */
.sp-help-btn { display:inline-flex; align-items:center; justify-content:center; padding:0; background:none; border:none; color:var(--sp-text-3); cursor:pointer; font-size:.82rem; vertical-align:middle; opacity:.6; line-height:1; transition:opacity .15s,color .15s; margin-left:3px; position:relative; top:-1px; }
.sp-help-btn:hover, .sp-help-btn:focus { opacity:1; color:var(--sp-primary); outline:none; }

/* CONTACT ICONS (bel / WhatsApp) */
.sp-contact-icon { display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:50%; color:#64748b; font-size:.75rem; text-decoration:none; transition:background .15s, color .15s; flex-shrink:0; }
.sp-contact-icon:hover { background:rgba(26,43,74,.1); color:#1a2b4a; }
.sp-contact-wa { color:#25d366; }
.sp-contact-wa:hover { background:rgba(37,211,102,.12); color:#128c52; }

/* HOLIDAY / VACATION ROWS */
.sp-holiday-row { border-bottom: 1px solid var(--sp-border); }
.sp-holiday-row:last-child { border-bottom: none; }
.sp-holiday-row-inner {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .65rem 1.25rem;
    flex-wrap: wrap;
}

/* LEAVE BANNER */
.sp-leave-banner {
    background: linear-gradient(135deg, rgba(26,43,74,.06) 0%, rgba(26,43,74,.02) 100%);
    border: 1px solid rgba(26,43,74,.12);
    border-radius: var(--sp-r-lg);
    padding: .85rem 1.25rem;
}
.sp-leave-banner-inner {
    display: flex;
    align-items: center;
    gap: .75rem;
}
.sp-leave-banner-icon {
    font-size: 1.4rem;
    color: var(--sp-primary);
    flex-shrink: 0;
}
.sp-leave-banner-title {
    font-size: .9rem;
    font-weight: 500;
    color: var(--sp-text);
}
.sp-leave-banner-sub {
    font-size: .78rem;
    color: var(--sp-text-2);
    margin-top: .1rem;
}

/* SHIFTDEFINITIES PAGE */
.sp-def-required {
    color: var(--sp-accent);
    font-size: .85rem;
    font-weight: 700;
    line-height: 1;
    vertical-align: super;
    cursor: default;
    user-select: none;
}

/* SKELETON PAGE */
.sp-skeleton-row {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .75rem 1.25rem;
    border-bottom: 1px solid var(--sp-border);
    transition: background var(--sp-t);
}
.sp-skeleton-row:last-child { border-bottom: none; }
.sp-skeleton-row:hover { background: var(--sp-surface-2); }
.sp-skeleton-legend {
    padding: .5rem 1rem;
    font-size: .72rem;
    color: var(--sp-text-3);
    border-top: 1px solid var(--sp-border);
}
.sp-skeleton-color {
    width: 4px;
    height: 36px;
    border-radius: 2px;
    flex-shrink: 0;
}
.sp-skeleton-name-cell {
    display: flex;
    align-items: center;
    gap: .4rem;
}
.sp-skeleton-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* SKELETON GRID */
.sp-skeleton-grid-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.sp-skeleton-grid {
    width: 100%;
    border-collapse: collapse;
    min-width: 560px;
}
.sp-skeleton-grid th,
.sp-skeleton-grid td {
    padding: .4rem .3rem;
    border-bottom: 1px solid var(--sp-border);
    text-align: center;
    vertical-align: middle;
}
.sp-skeleton-grid tbody tr:last-child td { border-bottom: none; }
.sp-skeleton-grid-label {
    text-align: left !important;
    white-space: nowrap;
    width: 130px;
    padding-left: 1.25rem !important;
}
.sp-skeleton-grid-day {
    font-size: .75rem;
    color: var(--sp-text-2);
    font-weight: 600;
    padding: .5rem .3rem !important;
    border-left: 1px solid var(--sp-border);
}
.sp-skeleton-holiday { background: rgba(217,119,6,.04); }
.sp-skeleton-day-name { font-weight: 700; font-size: .75rem; }
.sp-skeleton-day-date { font-size: .68rem; color: var(--sp-text-3); }
.sp-skeleton-day-holiday { font-size: .6rem; color: #d97706; }
.sp-skeleton-grid-cell {
    border-left: 1px solid var(--sp-border);
    font-size: .72rem;
    min-width: 70px;
}
.sp-skeleton-slot {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding: .2rem .35rem;
    border-radius: 4px;
    border: 1px solid;
    line-height: 1.3;
}
.sp-skeleton-slot-time {
    font-family: var(--sp-mono);
    font-size: .68rem;
    font-weight: 600;
}
.sp-skeleton-slot-sep { font-size: .55rem; color: var(--sp-text-3); }
.sp-skeleton-empty { color: var(--sp-border); font-size: .9rem; }

/* Color swatches */
.sp-color-swatch-label { cursor: pointer; }
.sp-color-swatch {
    display: inline-block;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2px solid transparent;
    transition: border-color var(--sp-t), transform var(--sp-t);
}
.sp-color-swatch.selected,
.sp-color-swatch-label:hover .sp-color-swatch {
    border-color: var(--sp-text);
    transform: scale(1.15);
}

/* SCHEDULE CALENDAR (maandoverzicht) */
.sp-cal-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    border-bottom: 1px solid var(--sp-border);
    background: var(--sp-surface-2);
}
.sp-cal-header-cell {
    text-align: center;
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--sp-text-3);
    padding: .4rem 0;
}
.sp-cal-weekend-label { color: var(--sp-accent); }

.sp-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
}

.sp-cal-day {
    border-right: 1px solid var(--sp-border);
    border-bottom: 1px solid var(--sp-border);
    padding: 4px;
    min-height: 90px;
    cursor: pointer;
    transition: background var(--sp-t);
}
.sp-cal-day:hover { background: var(--sp-surface-2); }
.sp-cal-day:nth-child(7n) { border-right: none; }
.sp-cal-empty { background: var(--sp-surface-2); opacity: .5; cursor: default; }
.sp-cal-day-we { background: rgba(227,6,19,.02); }
.sp-cal-day-hol { background: rgba(217,119,6,.04); }
.sp-cal-day-today { background: rgba(26,43,74,.04); }

.sp-cal-daynum {
    display: flex;
    align-items: center;
    gap: 3px;
    margin-bottom: 3px;
    font-size: .7rem;
    font-weight: 600;
    color: var(--sp-text-2);
}
.sp-cal-today-dot {
    background: var(--sp-primary);
    color: #fff;
    border-radius: 50%;
    width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .65rem;
}
.sp-cal-hol-label { font-size: .6rem; color: #d97706; }

.sp-cal-pill {
    display: flex;
    align-items: center;
    gap: 3px;
    font-size: .7rem;
    padding: 1px 4px;
    border-radius: 3px;
    border-left: 2px solid transparent;
    margin-bottom: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sp-cal-pill-mine { font-weight: 600; outline: 1px solid rgba(0,0,0,.12); }
.sp-cal-pill-time { font-size: .62rem; opacity: .75; font-family: var(--sp-mono); flex-shrink: 0; }
.sp-cal-pill-name { overflow: hidden; text-overflow: ellipsis; }
.sp-cal-more { font-size: .65rem; color: var(--sp-text-3); padding-left: 2px; }

/* Day-of-week label: only visible in mobile list layout */
.sp-cal-dowlabel { display: none; }

/* Mobile: switch from 7-col grid to vertical day list */
@media (max-width: 599px) {
    .sp-cal-header { display: none; }
    .sp-cal-grid   { grid-template-columns: 1fr; }
    .sp-cal-empty  { display: none; }

    .sp-cal-day {
        min-height: 0;
        border-right: none;
        display: flex;
        align-items: flex-start;
        gap: 8px;
        padding: 5px 10px;
    }
    /* override nth-child border rule */
    .sp-cal-day:nth-child(7n) { border-right: none; }

    .sp-cal-daynum {
        flex-shrink: 0;
        width: 32px;
        flex-direction: column;
        align-items: center;
        gap: 1px;
        margin-bottom: 0;
        padding-top: 1px;
        text-align: center;
    }
    .sp-cal-dowlabel {
        display: block;
        font-size: .58rem;
        font-weight: 700;
        text-transform: uppercase;
        color: var(--sp-text-3);
        letter-spacing: .03em;
    }
    .sp-cal-today-dot {
        width: 20px;
        height: 20px;
    }

    .sp-cal-pills {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-wrap: wrap;
        gap: 3px;
        align-content: flex-start;
        padding: 1px 0;
    }
    .sp-cal-pill {
        white-space: normal;
        overflow: visible;
        text-overflow: unset;
        flex-shrink: 0;
        max-width: 100%;
    }
}

/* PLAN page */
.sp-plan-mini-header {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-size: .65rem;
    font-weight: 700;
    color: var(--sp-text-3);
    margin-bottom: 3px;
}
.sp-plan-mini-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}
.sp-plan-day {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    font-size: .72rem;
    cursor: pointer;
    position: relative;
    transition: background var(--sp-t);
}
.sp-plan-day:hover { background: var(--sp-surface-2); }
.sp-plan-day.selected { background: var(--sp-primary); color: #fff; }
.sp-plan-we { color: var(--sp-accent); }
.sp-plan-hol { color: #d97706; }
.sp-plan-today > span { background: var(--sp-primary); color: #fff; border-radius: 50%; width: 18px; height: 18px; display: flex; align-items: center; justify-content: center; }
.sp-plan-day.selected .sp-plan-day-dot { background: #fff; }
.sp-plan-day-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--sp-accent); }

/* Plan overview table */
.sp-plan-table { border-collapse: collapse; width: 100%; }
.sp-plan-table th, .sp-plan-table td { border: 1px solid var(--sp-border); }
.sp-plan-th-shift { font-size: .7rem; color: var(--sp-text-3); padding: .35rem .75rem; background: var(--sp-surface-2); text-align: left; white-space: nowrap; min-width: 100px; }
.sp-plan-th-day { font-size: .65rem; color: var(--sp-text-3); padding: .2rem .15rem; text-align: center; min-width: 28px; }
.sp-plan-th-day.sp-plan-we { color: var(--sp-accent); background: rgba(227,6,19,.03); }
.sp-plan-th-day.sp-plan-hol { background: rgba(217,119,6,.05); }
.sp-plan-th-day.sp-plan-today-col { background: rgba(26,43,74,.06); }
.sp-plan-label { font-size: .72rem; padding: .3rem .75rem; white-space: nowrap; color: var(--sp-text-2); }
.sp-plan-cell { padding: 1px; vertical-align: top; min-height: 24px; cursor: pointer; }
.sp-plan-cell:hover { background: var(--sp-surface-2); }
.sp-plan-cell-pill {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: .65rem;
    padding: 1px 3px;
    border-radius: 2px;
    border: 0.5px solid;
    margin-bottom: 1px;
    white-space: nowrap;
    overflow: hidden;
}
.sp-plan-remove {
    background: none;
    border: none;
    cursor: pointer;
    color: inherit;
    opacity: .5;
    padding: 0;
    font-size: 12px;
    line-height: 1;
    margin-left: 2px;
    flex-shrink: 0;
}
.sp-plan-remove:hover { opacity: 1; }

/* MIJN MAAND BUTTON (dashboard) */
.sp-mijn-maand-btn {
    display: block;
    text-decoration: none;
    background: var(--sp-surface);
    border: 1px solid var(--sp-border);
    border-radius: var(--sp-r-lg);
    box-shadow: var(--sp-shadow-sm);
    transition: box-shadow var(--sp-t), transform var(--sp-t);
}
.sp-mijn-maand-btn:hover {
    box-shadow: var(--sp-shadow);
    transform: translateY(-1px);
    text-decoration: none;
}
.sp-mijn-maand-inner {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
}
.sp-mijn-maand-icon {
    font-size: 1.5rem;
    color: var(--sp-primary);
    flex-shrink: 0;
}
.sp-mijn-maand-title {
    font-size: .9rem;
    font-weight: 600;
    color: var(--sp-text);
}
.sp-mijn-maand-sub {
    font-size: .78rem;
    color: var(--sp-text-2);
    margin-top: .1rem;
}

/* Vacation day markers */
.sp-cal-day-vac {
    background: rgba(5,150,105,.04);
}
.sp-cal-vac-label {
    font-size: .6rem;
    color: #059669;
}
.sp-week-vac {
    background: rgba(5,150,105,.05);
}

/* Plan table extras */
.sp-plan-cell-off {
    background: var(--sp-surface-2);
    cursor: default !important;
    opacity: .5;
}
.sp-plan-cell-dash {
    color: var(--sp-border);
    font-size: .75rem;
}
.sp-plan-row-adhoc td {
    background: repeating-linear-gradient(
        45deg,
        transparent,
        transparent 4px,
        rgba(0,0,0,.02) 4px,
        rgba(0,0,0,.02) 8px
    );
}

/* IMPOSTER BAR */
.sp-imposter-bar {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 9999;
    background: #7c3aed;
    color: #fff;
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .4rem 1.25rem;
    font-size: .8rem;
    font-weight: 500;
    box-shadow: 0 2px 8px rgba(124,58,237,.35);
}
.sp-imposter-bar i { font-size: .9rem; }
.sp-imposter-bar a {
    color: #e9d5ff;
    text-decoration: underline;
    cursor: pointer;
    margin-left: auto;
    white-space: nowrap;
}
.sp-imposter-bar a:hover { color: #fff; }
/* Push content down when imposter bar is active */
body.sp-imposter-active {
    padding-top: 34px;
}
