/* ════════════════════════════════════════════════════════════════
   SCHOONGENOEG — Professional UI v1.0
   Doel: Uniforme, nette en professionele uitstraling voor de hele app.
   Bevat:
   1. Login scherm — verfijnd, vertrouwenwekkend
   2. AV-modal — cleaner scroll-box, duidelijker CTA
   3. Topbar — subtiele verbetering
   4. Cards & Sections — consistente witruimte + schaduwen
   5. Knoppen — consistente stijl, hover/active states
   6. Typography — heading hierarchy, label stijlen
   7. Badges & Pills — kleuren op orde
   8. Animaties — vloeiend, niet afleidend
   ════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════
   1. LOGIN SCHERM — professionele verbeteringen
   ══════════════════════════════════════════════ */

/* Achtergrond: rijkere gradiënt met subtiele sterren-effect */
.login-bg {
  background: linear-gradient(160deg, #060d1a 0%, #0f2044 40%, #1a0a2e 70%, #0a1628 100%) !important;
}
.login-bg::before {
  background:
    radial-gradient(ellipse 70% 50% at 20% 15%, rgba(37,99,235,.15), transparent),
    radial-gradient(ellipse 50% 50% at 85% 75%, rgba(227,6,19,.1), transparent),
    radial-gradient(ellipse 30% 30% at 60% 40%, rgba(124,58,237,.08), transparent) !important;
}

/* Login-kaart: subtielere schaduw, iets meer breedte op tablet */
.login-card {
  max-width: 420px !important;
  box-shadow:
    0 32px 80px rgba(0,0,0,.55),
    0 8px 24px rgba(0,0,0,.25),
    0 0 0 1px rgba(255,255,255,.07) !important;
}

/* Header: rijkere gradiënt met rode accent-lijn onderaan */
.lc-header {
  background: linear-gradient(160deg, #0c1120 0%, #111827 60%, #1a1030 100%) !important;
  padding: 30px 24px 26px !important;
  border-bottom: 2px solid rgba(227,6,19,.25) !important;
  position: relative;
  overflow: hidden;
}
/* Subtiele rode gloed rechtsonder in header */
.lc-header::after {
  content: '';
  position: absolute;
  bottom: -20px; right: -20px;
  width: 120px; height: 120px;
  background: radial-gradient(circle, rgba(227,6,19,.12), transparent 70%);
  pointer-events: none;
}

/* Logo wrapper: lichte gloed */
.lc-logo-wrap {
  box-shadow: 0 0 0 3px rgba(227,6,19,.15), 0 8px 24px rgba(0,0,0,.6) !important;
  border: 2px solid rgba(255,255,255,.12) !important;
  background: #0f172a !important;
}

/* Merk naam: iets groter, scherper */
.lc-brand {
  font-size: 1.45rem !important;
  letter-spacing: -.6px !important;
}
.lc-brand span {
  background: linear-gradient(135deg, #e30613, #ff3d4e);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Tagline: iets zichtbaarder */
.lc-tagline {
  color: rgba(255,255,255,.5) !important;
  letter-spacing: 1.8px !important;
  font-size: .7rem !important;
}

/* Labels: iets donkerder, beter leesbaar */
.lc-label {
  color: #475569 !important;
  font-size: .73rem !important;
  letter-spacing: .07em !important;
}

/* Input velden: verfijnde focus staat */
.lc-input {
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 11px !important;
  background: #f8fafc !important;
  font-size: .9rem !important;
  transition: all .2s !important;
}
.lc-input:focus {
  border-color: #e30613 !important;
  background: #ffffff !important;
  box-shadow: 0 0 0 4px rgba(227,6,19,.1), 0 1px 3px rgba(0,0,0,.08) !important;
}

/* Login knop: rijkere kleur + betere hover */
.lc-login-btn {
  background: linear-gradient(135deg, #e30613 0%, #c5000f 100%) !important;
  border-radius: 12px !important;
  font-size: .93rem !important;
  padding: 14px !important;
  letter-spacing: .01em !important;
  box-shadow: 0 4px 16px rgba(227,6,19,.35), 0 1px 3px rgba(0,0,0,.2) !important;
  transition: all .2s !important;
}
.lc-login-btn:hover {
  background: linear-gradient(135deg, #f5001a 0%, #d40010 100%) !important;
  box-shadow: 0 6px 22px rgba(227,6,19,.45), 0 2px 6px rgba(0,0,0,.2) !important;
  transform: translateY(-1px) !important;
}
.lc-login-btn:active {
  transform: scale(.98) translateY(0) !important;
  box-shadow: 0 2px 10px rgba(227,6,19,.3) !important;
}
.lc-login-btn:disabled {
  background: linear-gradient(135deg, #94a3b8, #64748b) !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
  transform: none !important;
}

/* Wachtwoord vergeten link */
.lc-forgot a {
  font-size: .8rem !important;
  color: #94a3b8 !important;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.lc-forgot a:hover {
  color: #e30613 !important;
}

/* Login footer: account info chips */
.lc-account-hint {
  margin: 8px 20px 16px;
  background: #f8fafc;
  border: 1.5px solid #e2e8f0;
  border-radius: 12px;
  padding: 11px 13px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.lc-account-hint-title {
  font-size: .68rem;
  font-weight: 800;
  color: #94a3b8;
  text-transform: uppercase;
  letter-spacing: .08em;
  display: flex;
  align-items: center;
  gap: 5px;
  margin-bottom: 2px;
}
.lc-account-hint-title i {
  font-size: .65rem;
  color: #cbd5e1;
}
.lc-account-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s;
}
.lc-account-row:hover {
  background: #f1f5f9;
}
.lc-account-row:active {
  background: #e2e8f0;
}
.lc-account-icon {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .75rem;
  flex-shrink: 0;
}
.lc-account-icon.og   { background: #fef2f2; color: #b91c1c; }
.lc-account-icon.zzp  { background: #f0fdf4; color: #15803d; }
.lc-account-icon.sub  { background: rgba(227,6,19,.08); color: var(--wl-primary,#e30613); }
.lc-account-icon.adm  { background: rgba(227,6,19,.08); color: #e30613; }
.lc-account-icon.dev  { background: #fff7ed; color: #c2410c; }
.lc-account-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  overflow: hidden;
}
.lc-account-name {
  font-size: .76rem;
  font-weight: 700;
  color: #1e293b;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lc-account-email {
  font-size: .67rem;
  font-weight: 500;
  color: #64748b;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lc-account-plan {
  font-size: .65rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  white-space: nowrap;
  flex-shrink: 0;
}
.lc-account-plan.og  { background: #fef2f2; color: #b91c1c; border: 1px solid #fca5a5; }
.lc-account-plan.zzp { background: #f0fdf4; color: #15803d; border: 1px solid #86efac; }
.lc-account-plan.sub { background: rgba(227,6,19,.08); color: var(--wl-primary,#e30613); border: 1px solid rgba(227,6,19,.25); }
.lc-account-plan.adm { background: rgba(227,6,19,.08); color: #e30613; border: 1px solid rgba(227,6,19,.25); }
.lc-account-plan.dev { background: #fff7ed; color: #c2410c; border: 1px solid #fdba74; }

/* Scheidingslijn tussen accountgroepen in loginscherm */
.lc-account-divider {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 4px 0 2px;
}
.lc-account-divider span {
  font-size: .6rem;
  font-weight: 700;
  color: #cbd5e1;
  text-transform: uppercase;
  letter-spacing: .07em;
  white-space: nowrap;
}
.lc-account-divider::before,
.lc-account-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: #e2e8f0;
}

/* ── Testomgeving tab-balk ─────────────────────────────── */
.lc-tabs-bar {
  display: flex;
  gap: 4px;
  margin-bottom: 8px;
  background: #f1f5f9;
  border-radius: 10px;
  padding: 3px;
}
.lc-tab-btn {
  flex: 1;
  padding: 6px 4px;
  font-size: .7rem;
  font-weight: 700;
  border: none;
  border-radius: 7px;
  cursor: pointer;
  background: transparent;
  color: #94a3b8;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: all .15s;
}
.lc-tab-btn.active {
  background: #fff;
  color: #e30613;
  box-shadow: 0 1px 4px rgba(0,0,0,.1);
}
.lc-tab-btn:hover:not(.active) {
  color: #475569;
  background: rgba(255,255,255,.5);
}

/* Wachtwoord badge bovenin tab-pane */
.lc-pw-badge {
  display: flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, #fef9ec, #fef3c7);
  border: 1.5px solid #fcd34d;
  border-radius: 8px;
  padding: 6px 10px;
  font-size: .72rem;
  font-weight: 600;
  color: #92400e;
  margin-bottom: 4px;
}
.lc-pw-badge i {
  color: #f59e0b;
  font-size: .68rem;
}
.lc-pw-badge strong {
  background: #fff;
  padding: 1px 7px;
  border-radius: 5px;
  font-family: monospace;
  font-size: .78rem;
  color: #b45309;
  letter-spacing: .05em;
  border: 1px solid #fcd34d;
}

/* God Mode button: beter verborgen */
.lc-godmode-btn {
  background: none !important;
  border: none !important;
  cursor: pointer !important;
  color: rgba(120,80,200,.5) !important;
  font-size: .63rem !important;
  letter-spacing: .06em !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  transition: opacity .2s !important;
  opacity: .35 !important;
  font-weight: 600 !important;
  padding: 4px 10px 12px !important;
  font-family: inherit !important;
}
.lc-godmode-btn:hover { opacity: .7 !important; }


/* ══════════════════════════════════════════════
   2. ONBOARDING / AV MODAL — professioneel
   ══════════════════════════════════════════════ */

#sgOnboardingModal > div {
  padding: 16px;
}
#sgOnboardingModal > div > div {
  border-radius: 22px !important;
  box-shadow: 0 40px 100px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.06) !important;
  border: none !important;
}

/* AV scroll box — professioneler */
#sgAvScrollBox {
  border-radius: 14px !important;
  border: 1.5px solid #e2e8f0 !important;
  background: #fafbfc !important;
  font-size: .8rem !important;
  line-height: 1.8 !important;
  padding: 16px 18px !important;
}
#sgAvScrollBox::-webkit-scrollbar { width: 4px; }
#sgAvScrollBox::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 4px;
}
#sgAvScrollBox::-webkit-scrollbar-track {
  background: transparent;
}

/* Accepteer knop — duidelijker enabled staat */
#sgOnboardingBevestigBtn:not(:disabled) {
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000)) !important;
  box-shadow: 0 6px 20px rgba(227,6,19,.4) !important;
  transform: translateY(0) !important;
  transition: all .2s !important;
}
#sgOnboardingBevestigBtn:not(:disabled):hover {
  background: linear-gradient(135deg, #ff2020, var(--wl-primary,#e30613)) !important;
  box-shadow: 0 8px 26px rgba(227,6,19,.5) !important;
  transform: translateY(-1px) !important;
}
#sgOnboardingBevestigBtn:not(:disabled):active {
  transform: scale(.98) translateY(0) !important;
}


/* ══════════════════════════════════════════════
   3. TOPBAR — verfijnd
   ══════════════════════════════════════════════ */

/* Topbar alleen donker in dark-theme — licht thema behoudt zijn eigen kleur */
html.sg-theme-dark .topbar {
  background: linear-gradient(to right, #0c1120, #111827) !important;
  border-bottom: 1px solid rgba(255,255,255,.05) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.4) !important;
}

/* Logo tekst */
.topbar-logo span {
  font-weight: 900 !important;
  letter-spacing: -.3px !important;
}

/* Icon buttons: hover per thema */
html.sg-theme-dark .icon-btn:hover  { background: rgba(255,255,255,.1) !important; }
html.sg-theme-light .icon-btn:hover { background: rgba(15,23,42,.07) !important; }

/* Avatar: rode rand bij klikken */
.user-avatar {
  background: linear-gradient(135deg, #e30613, #c5000f) !important;
  box-shadow: 0 0 0 2px rgba(227,6,19,.25) !important;
  transition: box-shadow .15s !important;
}
.user-avatar:hover {
  box-shadow: 0 0 0 3px rgba(227,6,19,.4) !important;
}


/* ══════════════════════════════════════════════
   4. CARDS — consistente stijl
   ══════════════════════════════════════════════ */

.card {
  border: 1.5px solid rgba(226,232,240,.8) !important;
  border-radius: 16px !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.06), 0 4px 12px rgba(0,0,0,.04) !important;
  transition: box-shadow .2s, transform .2s !important;
}
.card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.1), 0 1px 4px rgba(0,0,0,.06) !important;
}

/* Stat cards: rijkere hover */
.stat-card {
  border: 1.5px solid rgba(226,232,240,.7) !important;
  border-radius: 14px !important;
  transition: transform .2s, box-shadow .2s !important;
}
.stat-card:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,.1) !important;
}

/* Stat value: groter, opvallender */
.stat-value {
  font-size: 1.7rem !important;
  font-weight: 900 !important;
  letter-spacing: -.5px !important;
}

/* Section titles */
.section-header h2 {
  font-size: 1.2rem !important;
  font-weight: 800 !important;
  letter-spacing: -.3px !important;
  color: #0f172a !important;
}


/* ══════════════════════════════════════════════
   5. KNOPPEN — consistente stijl
   ══════════════════════════════════════════════ */

/* Primaire knop globaal */
.btn-primary,
button.btn-primary,
[class*="btn-prim"] {
  background: linear-gradient(135deg, #e30613, #c5000f) !important;
  color: white !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  transition: all .2s !important;
  box-shadow: 0 3px 10px rgba(227,6,19,.25) !important;
}
.btn-primary:hover,
button.btn-primary:hover {
  box-shadow: 0 5px 16px rgba(227,6,19,.35) !important;
  transform: translateY(-1px) !important;
}
.btn-primary:active,
button.btn-primary:active {
  transform: scale(.97) !important;
}

/* Secundaire knop */
.btn-secondary,
button.btn-secondary {
  background: #f1f5f9 !important;
  color: #374151 !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 10px !important;
  font-weight: 600 !important;
  transition: all .15s !important;
}
.btn-secondary:hover,
button.btn-secondary:hover {
  background: #e2e8f0 !important;
  border-color: #cbd5e1 !important;
}

/* Groene knop */
.btn-green,
button.btn-green,
.btn-success {
  background: linear-gradient(135deg, #16a34a, #15803d) !important;
  color: white !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  box-shadow: 0 3px 10px rgba(22,163,74,.25) !important;
  transition: all .2s !important;
}
.btn-green:hover { box-shadow: 0 5px 16px rgba(22,163,74,.35) !important; transform: translateY(-1px) !important; }

/* Primaire knop (whitelabel rood) */
.btn-blue,
button.btn-blue {
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000)) !important;
  color: white !important;
  border: none !important;
  border-radius: 10px !important;
  font-weight: 700 !important;
  box-shadow: 0 3px 10px rgba(227,6,19,.25) !important;
  transition: all .2s !important;
}
.btn-blue:hover { box-shadow: 0 5px 16px rgba(227,6,19,.35) !important; transform: translateY(-1px) !important; }

/* Kleine knoppen */
.btn-xs {
  border-radius: 8px !important;
  font-size: .76rem !important;
  font-weight: 700 !important;
  padding: 5px 10px !important;
  letter-spacing: .01em !important;
}
.btn-sm {
  border-radius: 9px !important;
  font-size: .84rem !important;
  font-weight: 700 !important;
}


/* ══════════════════════════════════════════════
   6. MODALS — professioneler
   ══════════════════════════════════════════════ */

.modal-overlay {
  backdrop-filter: blur(3px) !important;
}
.modal {
  border-radius: 20px !important;
  border: 1px solid rgba(226,232,240,.6) !important;
  box-shadow: 0 32px 80px rgba(0,0,0,.2), 0 8px 24px rgba(0,0,0,.1) !important;
  overflow: hidden !important;
}
.modal-header {
  padding: 18px 20px 16px !important;
  border-bottom: 1px solid #f1f5f9 !important;
}
.modal-header h3,
.modal-header .modal-title {
  font-size: 1rem !important;
  font-weight: 800 !important;
  letter-spacing: -.2px !important;
  color: #0f172a !important;
}
.modal-body {
  padding: 20px !important;
}
.modal-footer {
  padding: 14px 20px !important;
  border-top: 1px solid #f1f5f9 !important;
  background: #fafafa !important;
}

/* Modal close knop */
.modal-close {
  width: 34px !important;
  height: 34px !important;
  border-radius: 10px !important;
  background: #f1f5f9 !important;
  color: #64748b !important;
  border: none !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all .15s !important;
  flex-shrink: 0 !important;
}
.modal-close:hover {
  background: #fee2e2 !important;
  color: #dc2626 !important;
}


/* ══════════════════════════════════════════════
   7. SIDEBAR — verfijnd
   ══════════════════════════════════════════════ */

.sidebar {
  background: linear-gradient(180deg, #0c1120 0%, #111827 100%) !important;
  border-right: 1px solid rgba(255,255,255,.06) !important;
}

/* Rol-indicatie balk */
#sidebarRoleBar {
  border: 1px solid rgba(255,255,255,.08) !important;
}

/* Actieve nav item: betere kleur */
.nav-item.active {
  background: rgba(255,255,255,.1) !important;
  box-shadow: inset 3px 0 0 #e30613 !important;
}
.nav-item.active i {
  filter: brightness(1.3) drop-shadow(0 0 4px currentColor) !important;
}


/* ══════════════════════════════════════════════
   8. BOTTOM NAVIGATIE — verfijnd
   ══════════════════════════════════════════════ */

/* bottom-nav achtergrond ALLEEN in dark theme donker maken */
html.sg-theme-dark .bottom-nav {
  background: linear-gradient(to top, #0c1120, #111827) !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
  box-shadow: 0 -4px 16px rgba(0,0,0,.3) !important;
}

.bottom-nav-btn.active {
  color: #e30613 !important;
}
.bottom-nav-btn.active i {
  filter: drop-shadow(0 0 4px rgba(227,6,19,.5)) !important;
}


/* ══════════════════════════════════════════════
   9. TOAST BERICHTEN — verfijnd
   ══════════════════════════════════════════════ */

#sgToast {
  border-radius: 14px !important;
  box-shadow: 0 12px 32px rgba(0,0,0,.25), 0 2px 8px rgba(0,0,0,.15) !important;
  font-size: .86rem !important;
  font-weight: 600 !important;
  padding: 12px 18px !important;
  backdrop-filter: blur(8px) !important;
  border: 1px solid rgba(255,255,255,.1) !important;
}

/* ══════════════════════════════════════════════
   10. QUICK ACTIONS GRID — verfijnd
   ══════════════════════════════════════════════ */

.quick-action-btn {
  border-radius: 14px !important;
  border: 1.5px solid #e2e8f0 !important;
  transition: all .2s !important;
}
.quick-action-btn:hover {
  border-color: #cbd5e1 !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.08) !important;
  transform: translateY(-2px) !important;
}
.quick-action-btn:active {
  transform: scale(.97) !important;
}
.quick-action-icon {
  border-radius: 12px !important;
}

/* ══════════════════════════════════════════════
   11. PROJECT KAARTEN — verfijnd
   ══════════════════════════════════════════════ */

.project-card-v2 {
  border-radius: 18px !important;
  box-shadow: 0 2px 8px rgba(0,0,0,.06), 0 0 0 1px rgba(226,232,240,.8) !important;
  border: none !important;
  transition: all .2s !important;
}
.project-card-v2:hover {
  box-shadow: 0 8px 28px rgba(0,0,0,.12), 0 0 0 1px rgba(226,232,240,.8) !important;
  transform: translateY(-3px) !important;
}

/* ══════════════════════════════════════════════
   12. STATUS BADGES — uniforme stijl
   ══════════════════════════════════════════════ */

.status-badge,
.badge,
.pill {
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  border-radius: 20px !important;
}

/* ══════════════════════════════════════════════
   13. SECTION TRANSITIE — vloeiende fade-in
   ══════════════════════════════════════════════ */

.section {
  animation: sgSectionIn .25s ease both;
}
@keyframes sgSectionIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════════════════
   14. FILTER KNOPPEN — verfijnd
   ══════════════════════════════════════════════ */

.filter-btn {
  border-radius: 22px !important;
  font-weight: 600 !important;
  font-size: .8rem !important;
  transition: all .15s !important;
}
.filter-btn.active {
  background: #0f172a !important;
  color: white !important;
  border-color: #0f172a !important;
  box-shadow: 0 3px 10px rgba(15,23,42,.25) !important;
}
.filter-btn:hover:not(.active) {
  background: #f1f5f9 !important;
  border-color: #cbd5e1 !important;
}

/* ══════════════════════════════════════════════
   15. ONBOARDING MODAL — extra stijl
   ══════════════════════════════════════════════ */

/* Fade-in animatie (gebruikt door de modal overlay) */
@keyframes sgFadeIn {
  from { opacity: 0; transform: scale(.97); }
  to   { opacity: 1; transform: scale(1); }
}

/* Slide-in van onderaf (voor mobiele modals) */
@keyframes sgSlideUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Scroll-hint pijl animatie */
@keyframes sgBounceDown {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(5px); }
}
#sgAvScrollHint i,
.sg-scroll-hint-icon {
  animation: sgBounceDown 1.2s ease infinite;
}

/* Checkbox label hover effect */
#sgAvCheckLabel:not([style*="pointer-events: none"]):hover,
#sgAvCheckLabel:not([style*="pointer-events:none"]):hover {
  background: rgba(227,6,19,.06) !important;
  border-color: rgba(227,6,19,.25) !important;
}

/* Lees-voortgangsbalk animatie */
#sgAvReadProgress {
  transition: width .25s ease !important;
}

/* Checkbox aangevinkt: label groen */
#sgOnboardingAkkoord:checked + span {
  color: #15803d !important;
}

/* Ontgrendelde knop hover-effect (via CSS voor touch-devices) */
#sgOnboardingBevestigBtn:not(:disabled):hover {
  transform: translateY(-1px) !important;
}
#sgOnboardingBevestigBtn:not(:disabled):active {
  transform: scale(.97) translateY(0) !important;
}

/* ══════════════════════════════════════════════
   16. ALGEMENE VERBETERINGEN — Typography & UX
   ══════════════════════════════════════════════ */

/* Login-knop: betere animatie bij laden */
@keyframes sgLoginSpin {
  to { transform: rotate(360deg); }
}
.lc-login-btn .fa-spinner {
  animation: sgLoginSpin .8s linear infinite !important;
}

/* Testaccount rijen: visuele hover-feedback */
.lc-account-row {
  position: relative;
  overflow: hidden;
}
.lc-account-row::after {
  content: '';
  position: absolute; inset: 0;
  background: rgba(37,99,235,.04);
  opacity: 0;
  transition: opacity .15s;
  pointer-events: none;
}
.lc-account-row:hover::after { opacity: 1; }
.lc-account-row:active::after { background: rgba(227,6,19,.1); opacity: 1; }

/* Input-icoon kleur bij focus */
.lc-input-wrap:focus-within .lc-input-icon {
  color: #e30613 !important;
  transition: color .2s;
}

/* Wachtwoord-toggle: betere zichtbaarheid */
.lc-pwd-toggle {
  transition: color .15s, background .15s !important;
  border-radius: 6px !important;
}
.lc-pwd-toggle:hover {
  background: #f1f5f9 !important;
  color: #334155 !important;
}

/* Secties: subtielere achtergrond */
.section {
  background: var(--bg) !important;
}

/* Card titles consistentie */
.card-header h3,
.card-title {
  font-weight: 700 !important;
  color: #0f172a !important;
  letter-spacing: -.15px !important;
}

/* Tekst-light kleur consistentie */
.text-muted,
.text-light,
[class*="text-light"],
[class*="text-muted"] {
  color: #64748b !important;
}

/* Chip/Label in kaarten */
.lc-chip {
  font-size: .67rem !important;
  font-weight: 700 !important;
}

/* ══════════════════════════════════════════════
   17. MEDIA QUERIES — mobile extra polish
   ══════════════════════════════════════════════ */

@media (max-width: 480px) {
  /* Login kaart vult beter scherm op mobiel */
  .login-card {
    border-radius: 18px !important;
    margin: 8px !important;
  }

  /* Sectie padding kleiner op mobiel */
  .section {
    padding: 12px 12px 20px !important;
  }

  /* Modal minder padding op mobiel */
  .modal-body {
    padding: 16px !important;
  }
}

/* ══════════════════════════════════════════════
   18. DARK MODE OVERRIDES
   ══════════════════════════════════════════════ */

html.sg-theme-dark .card {
  border-color: rgba(255,255,255,.06) !important;
  background: #1e293b !important;
}
html.sg-theme-dark .stat-card {
  background: #1e293b !important;
  border-color: rgba(255,255,255,.06) !important;
}
html.sg-theme-dark .section-header h2 {
  color: #f1f5f9 !important;
}
html.sg-theme-dark .filter-btn {
  background: #1e293b !important;
  border-color: rgba(255,255,255,.1) !important;
  color: #94a3b8 !important;
}
html.sg-theme-dark .filter-btn.active {
  background: #e2e8f0 !important;
  color: #0f172a !important;
}
html.sg-theme-dark .quick-action-btn {
  background: #1e293b !important;
  border-color: rgba(255,255,255,.08) !important;
  color: #e2e8f0 !important;
}
html.sg-theme-dark .quick-action-btn:hover {
  background: #263348 !important;
}

/* Dark mode modal */
html.sg-theme-dark .modal {
  background: #1e293b !important;
  border-color: rgba(255,255,255,.08) !important;
}
html.sg-theme-dark .modal-header {
  border-bottom-color: rgba(255,255,255,.06) !important;
}
html.sg-theme-dark .modal-header h3,
html.sg-theme-dark .modal-header .modal-title {
  color: #f1f5f9 !important;
}
html.sg-theme-dark .modal-footer {
  background: #182030 !important;
  border-top-color: rgba(255,255,255,.06) !important;
}
html.sg-theme-dark .modal-close {
  background: rgba(255,255,255,.08) !important;
  color: #94a3b8 !important;
}
html.sg-theme-dark .modal-close:hover {
  background: rgba(239,68,68,.15) !important;
  color: #f87171 !important;
}

/* ══════════════════════════════════════════════════════════════════
   19. CLOUD BACKUP UI — sg-cloud-backup.js
   ══════════════════════════════════════════════════════════════════ */

/* ── Card wrapper ── */
.sgcb-card {
  background: var(--card, #fff);
  border: 1.5px solid var(--border, #e2e8f0);
  border-radius: 16px;
  overflow: hidden;
  transition: box-shadow .2s;
}

/* ── Header ── */
.sgcb-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border-bottom: 1.5px solid var(--border, #e2e8f0);
  background: linear-gradient(90deg, #f8fafc, #fff);
}
.sgcb-header-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000));
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1.1rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(227,6,19,.3);
}
.sgcb-header-text { flex: 1; }
.sgcb-header-title {
  font-size: .95rem;
  font-weight: 800;
  color: var(--text, #0f172a);
  margin-bottom: 2px;
}
.sgcb-header-sub {
  font-size: .74rem;
  color: var(--text-light, #64748b);
  line-height: 1.4;
}

/* ── Toggle switch ── */
.sgcb-toggle {
  position: relative;
  display: inline-block;
  width: 48px; height: 26px;
  flex-shrink: 0;
  cursor: pointer;
}
.sgcb-toggle input { opacity: 0; width: 0; height: 0; }
.sgcb-toggle-slider {
  position: absolute; inset: 0;
  background: #cbd5e1;
  border-radius: 26px;
  transition: background .2s;
}
.sgcb-toggle-slider::before {
  content: '';
  position: absolute;
  width: 20px; height: 20px;
  left: 3px; top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform .2s;
  box-shadow: 0 1px 4px rgba(0,0,0,.2);
}
.sgcb-toggle input:checked + .sgcb-toggle-slider {
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000));
}
.sgcb-toggle input:checked + .sgcb-toggle-slider::before {
  transform: translateX(22px);
}

/* ── Status bar ── */
.sgcb-status-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 20px;
  background: #f8fafc;
  border-bottom: 1px solid var(--border, #e2e8f0);
  font-size: .78rem;
}
.sgcb-status-last {
  display: flex; align-items: center; gap: 7px;
  color: var(--text, #0f172a);
}
.sgcb-status-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: .73rem;
  font-weight: 700;
  border: 1.5px solid currentColor;
}

/* ── Body ── */
#sgcbBody { padding: 0; }

/* ── Sections ── */
.sgcb-section {
  padding: 18px 20px;
  border-bottom: 1px solid var(--border, #f1f5f9);
}
.sgcb-section:last-child { border-bottom: none; }
.sgcb-section-title {
  font-size: .78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text-light, #64748b);
  margin-bottom: 14px;
  display: flex; align-items: center; gap: 8px;
}

/* ── Provider kaarten ── */
.sgcb-providers {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sgcb-provider-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border: 1.5px solid var(--border, #e2e8f0);
  border-radius: 12px;
  background: var(--card, #fff);
  transition: border-color .15s, box-shadow .15s;
}
.sgcb-provider-card:hover {
  border-color: rgba(227,6,19,.25);
  box-shadow: 0 2px 8px rgba(227,6,19,.10);
}
.sgcb-provider--active {
  border-color: var(--wl-primary,#e30613) !important;
  background: rgba(227,6,19,.05) !important;
  box-shadow: 0 2px 10px rgba(37,99,235,.12) !important;
}
.sgcb-provider-logo {
  width: 44px; height: 44px;
  border-radius: 11px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  flex-shrink: 0;
}
.sgcb-provider-logo--google   { background: #e8f0fe; color: #4285F4; }
.sgcb-provider-logo--onedrive { background: #e3f0ff; color: #0078d4; }
.sgcb-provider-info { flex: 1; min-width: 0; }
.sgcb-provider-name {
  font-size: .88rem;
  font-weight: 700;
  color: var(--text, #0f172a);
  margin-bottom: 3px;
}
.sgcb-provider-sub {
  font-size: .74rem;
  color: var(--text-light, #64748b);
}
.sgcb-provider-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex-shrink: 0;
}

/* ── Active provider strip ── */
.sgcb-active-provider {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
  padding: 10px 14px;
  background: #f0fdf4;
  border: 1.5px solid #86efac;
  border-radius: 10px;
  font-size: .8rem;
  color: #065f46;
  font-weight: 600;
}
.sgcb-folder-path {
  display: flex; align-items: center; gap: 5px;
  font-size: .74rem;
  color: #64748b;
  font-weight: 400;
  margin-left: auto;
}

/* ── Settings grid ── */
.sgcb-settings-grid {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.sgcb-setting-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  background: #f8fafc;
  border: 1.5px solid var(--border, #e2e8f0);
  border-radius: 10px;
}
.sgcb-setting-row--col {
  flex-direction: column;
  align-items: stretch;
}
.sgcb-setting-label {
  display: flex; align-items: center; gap: 10px;
  color: var(--text-light, #64748b);
  font-size: .85rem;
  flex: 1;
}
.sgcb-select {
  padding: 7px 12px;
  border: 1.5px solid #e2e8f0;
  border-radius: 9px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text, #0f172a);
  background: #fff;
  cursor: pointer;
  outline: none;
  font-family: inherit;
  transition: border-color .15s;
  flex-shrink: 0;
}
.sgcb-select:focus { border-color: #e30613; }

/* ── Checkboxes ── */
.sgcb-checkboxes {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sgcb-check-label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border: 1.5px solid var(--border, #e2e8f0);
  border-radius: 9px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text, #0f172a);
  cursor: pointer;
  background: #fff;
  transition: border-color .15s, background .15s;
}
.sgcb-check-label:hover { border-color: rgba(227,6,19,.25); background: rgba(227,6,19,.06); }
.sgcb-check-label input { accent-color: var(--wl-primary,#e30613); width: 16px; height: 16px; }

/* ── Mappenstructuur preview ── */
.sgcb-folder-preview {
  margin-top: 16px;
  padding: 14px 16px;
  background: #fafbfc;
  border: 1.5px solid var(--border, #e2e8f0);
  border-radius: 10px;
}
.sgcb-folder-preview-title {
  font-size: .75rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text-light, #64748b);
  margin-bottom: 12px;
  display: flex; align-items: center; gap: 7px;
}
.sgcb-tree { font-size: .79rem; line-height: 1.8; }
.sgcb-tree-root {
  display: flex; align-items: center; gap: 7px;
  font-weight: 800;
  color: var(--text, #0f172a);
  padding-bottom: 4px;
}
.sgcb-tree-child {
  padding-left: 20px;
  border-left: 2px solid #e2e8f0;
  margin-left: 7px;
  padding-top: 4px;
  color: #334155;
}
.sgcb-tree-grandchild {
  padding-left: 20px;
  border-left: 2px dashed #e2e8f0;
  margin-left: 7px;
  margin-top: 2px;
}
.sgcb-tree-leaf {
  display: flex; align-items: center; gap: 7px;
  color: #64748b;
  font-size: .76rem;
  padding: 1px 0;
}

/* ── Actie knoppen ── */
.sgcb-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border, #f1f5f9);
}

/* ── Knoppen ── */
.sgcb-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 18px;
  border-radius: 10px;
  font-size: .82rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  border: none;
  transition: all .15s;
  text-decoration: none;
  white-space: nowrap;
}
.sgcb-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none !important;
}
.sgcb-btn--primary {
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000));
  color: #fff;
  box-shadow: 0 3px 10px rgba(227,6,19,.3);
}
.sgcb-btn--primary:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(227,6,19,.4);
}
.sgcb-btn--primary:active:not(:disabled) { transform: scale(.97); }

.sgcb-btn--blue {
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000));
  color: #fff;
  box-shadow: 0 2px 8px rgba(227,6,19,.25);
}
.sgcb-btn--blue:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 5px 14px rgba(227,6,19,.35);
}

.sgcb-btn--green {
  background: linear-gradient(135deg, #16a34a, #15803d);
  color: #fff;
  box-shadow: 0 2px 8px rgba(22,163,74,.25);
}
.sgcb-btn--green:hover:not(:disabled) { transform: translateY(-1px); }

.sgcb-btn--ghost {
  background: var(--card, #fff);
  color: var(--text, #334155);
  border: 1.5px solid var(--border, #e2e8f0);
}
.sgcb-btn--ghost:hover:not(:disabled) {
  background: #f1f5f9;
  border-color: #cbd5e1;
}

.sgcb-btn--sm {
  padding: 6px 13px;
  font-size: .76rem;
  border-radius: 8px;
}

/* ── Log ── */
.sgcb-log {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sgcb-log-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: #f8fafc;
  border: 1px solid var(--border, #e2e8f0);
  border-radius: 9px;
}
.sgcb-log-icon { flex-shrink: 0; margin-top: 1px; }
.sgcb-log-title {
  font-size: .8rem;
  font-weight: 700;
  color: var(--text, #0f172a);
  margin-bottom: 2px;
}
.sgcb-log-sub {
  font-size: .74rem;
  color: var(--text-light, #64748b);
}
.sgcb-empty {
  font-size: .82rem;
  color: var(--text-light, #94a3b8);
  text-align: center;
  padding: 16px;
}

/* ── Onboarding ── */
.sgcb-onboarding {
  padding: 28px 24px;
  text-align: center;
}
.sgcb-onboarding-icon {
  width: 56px; height: 56px;
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(227,6,19,.10), rgba(227,6,19,.18));
  border: 1.5px solid rgba(227,6,19,.28);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; color: var(--wl-primary,#e30613);
  margin: 0 auto 14px;
}
.sgcb-onboarding-title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--text, #0f172a);
  margin-bottom: 8px;
}
.sgcb-onboarding-sub {
  font-size: .82rem;
  color: var(--text-light, #64748b);
  max-width: 380px;
  margin: 0 auto 20px;
  line-height: 1.6;
}
.sgcb-onboarding-steps {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  max-width: 340px;
  margin: 0 auto;
}
.sgcb-step {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .8rem;
  color: var(--text, #334155);
  line-height: 1.5;
}
.sgcb-step-num {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--wl-primary,#e30613), var(--wl-primary-dark,#9b0000));
  color: #fff;
  font-size: .68rem;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Dark mode ── */
html.sg-theme-dark .sgcb-card {
  background: #1e293b !important;
  border-color: rgba(255,255,255,.07) !important;
}
html.sg-theme-dark .sgcb-header {
  background: linear-gradient(90deg, #1a2744, #1e293b) !important;
  border-bottom-color: rgba(255,255,255,.07) !important;
}
html.sg-theme-dark .sgcb-header-title { color: #f1f5f9 !important; }
html.sg-theme-dark .sgcb-status-bar {
  background: #152030 !important;
  border-bottom-color: rgba(255,255,255,.06) !important;
}
html.sg-theme-dark .sgcb-section { border-bottom-color: rgba(255,255,255,.06) !important; }
html.sg-theme-dark .sgcb-provider-card {
  background: #263348 !important;
  border-color: rgba(255,255,255,.08) !important;
}
html.sg-theme-dark .sgcb-provider--active {
  background: #2d0a0b !important;
  border-color: #e30613 !important;
}
html.sg-theme-dark .sgcb-provider-name { color: #f1f5f9 !important; }
html.sg-theme-dark .sgcb-setting-row {
  background: #1a2744 !important;
  border-color: rgba(255,255,255,.08) !important;
}
html.sg-theme-dark .sgcb-check-label {
  background: #1e293b !important;
  border-color: rgba(255,255,255,.08) !important;
  color: #e2e8f0 !important;
}
html.sg-theme-dark .sgcb-check-label:hover {
  background: #2d0a0b !important;
  border-color: #e30613 !important;
}
html.sg-theme-dark .sgcb-select {
  background: #263348 !important;
  border-color: rgba(255,255,255,.12) !important;
  color: #e2e8f0 !important;
}
html.sg-theme-dark .sgcb-folder-preview {
  background: #152030 !important;
  border-color: rgba(255,255,255,.07) !important;
}
html.sg-theme-dark .sgcb-btn--ghost {
  background: #263348 !important;
  border-color: rgba(255,255,255,.1) !important;
  color: #e2e8f0 !important;
}
html.sg-theme-dark .sgcb-btn--ghost:hover:not(:disabled) {
  background: #2d3f5e !important;
}
html.sg-theme-dark .sgcb-log-row {
  background: #1a2744 !important;
  border-color: rgba(255,255,255,.07) !important;
}
html.sg-theme-dark .sgcb-log-title { color: #f1f5f9 !important; }
html.sg-theme-dark .sgcb-onboarding-icon {
  background: linear-gradient(135deg, #1e3a6e, #1e2f5e) !important;
  border-color: rgba(59,130,246,.3) !important;
}
html.sg-theme-dark .sgcb-onboarding-title { color: #f1f5f9 !important; }
html.sg-theme-dark .sgcb-tree-root { color: #f1f5f9 !important; }
html.sg-theme-dark .sgcb-tree-child,
html.sg-theme-dark .sgcb-tree-grandchild {
  border-color: rgba(255,255,255,.1) !important;
}
html.sg-theme-dark .sgcb-active-provider {
  background: #0d2b1a !important;
  border-color: rgba(134,239,172,.3) !important;
}

/* ── Responsive ── */
@media (max-width: 560px) {
  .sgcb-header { flex-wrap: wrap; }
  .sgcb-provider-card { flex-wrap: wrap; }
  .sgcb-provider-actions { width: 100%; }
  .sgcb-actions { flex-direction: column; }
  .sgcb-actions .sgcb-btn { width: 100%; justify-content: center; }
  .sgcb-folder-path { display: none; }
}
