/* ============================================================
   HR Platform — Design System v14
   Light + Dark mode, modern cards, animations, glassmorphism
   ============================================================ */

/* ─── Google Font ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ============================================================
   1. DESIGN TOKENS
   ============================================================ */
:root {
    /* ─── Brand & Accents ─────────────────── */
    --ds-accent:        #4f46e5;   /* primary indigo */
    --ds-accent-soft:   #eef2ff;
    --ds-accent-2:      #8b5cf6;
    --ds-accent-3:      #06b6d4;

    /* Role accents (used by sidebar / dashboards) */
    --ds-role-admin:    #4f46e5;
    --ds-role-platform: #e63946;
    --ds-role-manager:  #16a34a;
    --ds-role-employee: #0ea5e9;

    /* ─── Semantic colors ─────────────────── */
    --ds-success: #16a34a;
    --ds-warning: #eab308;
    --ds-danger:  #ef4444;
    --ds-info:    #06b6d4;

    /* ─── Neutrals (LIGHT) ────────────────── */
    --ds-bg:           #f6f7fb;
    --ds-bg-elev:      #ffffff;
    --ds-surface:      #ffffff;
    --ds-surface-2:    #f1f3f9;
    --ds-border:       #e2e7ef;
    --ds-border-soft:  #eef0f6;
    --ds-text:         #0f172a;
    --ds-text-muted:   #64748b;
    --ds-text-soft:    #94a3b8;

    --ds-sidebar-bg:    #0f172a;
    --ds-sidebar-text:  #cbd5e1;
    --ds-sidebar-text-active: #ffffff;

    /* ─── Shadows ─────────────────────────── */
    --ds-shadow-xs: 0 1px 2px rgba(15, 23, 42, .04);
    --ds-shadow-sm: 0 2px 4px rgba(15, 23, 42, .04), 0 1px 2px rgba(15, 23, 42, .03);
    --ds-shadow-md: 0 6px 16px rgba(15, 23, 42, .08), 0 1px 3px rgba(15, 23, 42, .03);
    --ds-shadow-lg: 0 12px 32px rgba(15, 23, 42, .12), 0 2px 8px rgba(15, 23, 42, .06);
    --ds-shadow-glow: 0 0 0 4px rgba(79, 70, 229, .15);

    /* ─── Radius ──────────────────────────── */
    --ds-radius-xs: 6px;
    --ds-radius-sm: 10px;
    --ds-radius-md: 14px;
    --ds-radius-lg: 18px;
    --ds-radius-xl: 24px;
    --ds-radius-pill: 999px;

    /* ─── Spacing & motion ────────────────── */
    --ds-space-tight: .35rem;
    --ds-space-cozy:  .65rem;
    --ds-space-loose: 1.25rem;
    --ds-ease:    cubic-bezier(.4, 0, .2, 1);
    --ds-ease-spring: cubic-bezier(.34, 1.56, .64, 1);
    --ds-dur-fast: 120ms;
    --ds-dur:      220ms;
    --ds-dur-slow: 380ms;

    /* ─── Sidebar / Topbar dimensions ─────── */
    --ds-sidebar-w: 264px;
    --ds-sidebar-w-mini: 76px;
    --ds-topbar-h: 64px;
}

/* ─── DARK MODE overrides ─────────────────────────────────── */
[data-theme="dark"] {
    --ds-bg:           #0b1020;
    --ds-bg-elev:      #131a2c;
    --ds-surface:      #131a2c;
    --ds-surface-2:    #1a2238;
    --ds-border:       #25304a;
    --ds-border-soft:  #1f2a44;
    --ds-text:         #e2e8f0;
    --ds-text-muted:   #94a3b8;
    --ds-text-soft:    #64748b;

    --ds-sidebar-bg:   #060912;
    --ds-sidebar-text: #94a3b8;
    --ds-sidebar-text-active: #ffffff;

    --ds-accent-soft:  rgba(79, 70, 229, .15);

    --ds-shadow-xs: 0 1px 2px rgba(0, 0, 0, .35);
    --ds-shadow-sm: 0 2px 6px rgba(0, 0, 0, .4);
    --ds-shadow-md: 0 6px 18px rgba(0, 0, 0, .55);
    --ds-shadow-lg: 0 14px 36px rgba(0, 0, 0, .65);
}

/* ─── Role accent application ─────────────────────────────── */
[data-role="admin"]    { --ds-accent: var(--ds-role-admin); }
[data-role="platform"] { --ds-accent: var(--ds-role-platform); }
[data-role="manager"]  { --ds-accent: var(--ds-role-manager); }
[data-role="employee"] { --ds-accent: var(--ds-role-employee); }

/* ============================================================
   2. BASE + RESET
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif !important;
    background: var(--ds-bg) !important;
    color: var(--ds-text);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transition: background-color var(--ds-dur) var(--ds-ease),
                color var(--ds-dur) var(--ds-ease);
}

a { color: var(--ds-accent); transition: color var(--ds-dur-fast) var(--ds-ease); }
a:hover { color: var(--ds-accent); filter: brightness(.85); }

::selection { background: var(--ds-accent); color: #fff; }

/* Scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: var(--ds-border);
    border-radius: 10px;
    border: 2px solid var(--ds-bg);
}
::-webkit-scrollbar-thumb:hover { background: var(--ds-text-soft); }

/* ============================================================
   3. TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    color: var(--ds-text);
    letter-spacing: -.015em;
}
h1 { font-size: 1.875rem; }
h2 { font-size: 1.5rem; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.125rem; }
h5 { font-size: 1rem; }

.text-muted, .text-secondary { color: var(--ds-text-muted) !important; }

.eyebrow {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--ds-text-muted);
}

.display-stat {
    font-size: 2.25rem;
    font-weight: 800;
    letter-spacing: -.02em;
    color: var(--ds-text);
    line-height: 1.1;
}

/* ============================================================
   4. CARDS
   ============================================================ */
.card,
.ds-card {
    background: var(--ds-surface) !important;
    border: 1px solid var(--ds-border) !important;
    border-radius: var(--ds-radius-md) !important;
    box-shadow: var(--ds-shadow-sm);
    transition: transform var(--ds-dur) var(--ds-ease),
                box-shadow var(--ds-dur) var(--ds-ease),
                border-color var(--ds-dur) var(--ds-ease);
    color: var(--ds-text);
}

.card:hover,
.ds-card:hover {
    box-shadow: var(--ds-shadow-md);
}

.card-header,
.card-footer {
    background: transparent !important;
    border-color: var(--ds-border-soft) !important;
}

.ds-card.ds-card-hover:hover {
    transform: translateY(-2px);
    border-color: var(--ds-accent) !important;
}

/* Stat cards — used on dashboards */
.ds-stat {
    position: relative;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    padding: 1.25rem;
    overflow: hidden;
    transition: transform var(--ds-dur) var(--ds-ease), box-shadow var(--ds-dur) var(--ds-ease);
}
.ds-stat:hover { transform: translateY(-3px); box-shadow: var(--ds-shadow-md); }
.ds-stat::before {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(120% 80% at 100% 0%, var(--ds-stat-tint, rgba(79,70,229,.1)) 0%, transparent 60%);
    opacity: .9;
    pointer-events: none;
}
.ds-stat-label {
    font-size: .7rem; text-transform: uppercase; letter-spacing: .1em;
    color: var(--ds-text-muted); font-weight: 600; margin-bottom: .5rem;
}
.ds-stat-value {
    font-size: 2rem; font-weight: 800; color: var(--ds-text);
    letter-spacing: -.02em; line-height: 1.1;
}
.ds-stat-icon {
    position: absolute; top: 1rem; right: 1rem;
    width: 44px; height: 44px;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem;
    background: var(--ds-stat-icon-bg, rgba(79,70,229,.12));
    color:      var(--ds-stat-icon-color, var(--ds-accent));
}
.ds-stat-trend { font-size: .82rem; font-weight: 600; margin-top: .25rem; }
.ds-stat-trend.up   { color: var(--ds-success); }
.ds-stat-trend.down { color: var(--ds-danger); }

/* Stat color presets */
.ds-stat--indigo  { --ds-stat-tint: rgba(79,70,229,.1);  --ds-stat-icon-bg: rgba(79,70,229,.12);  --ds-stat-icon-color: #4f46e5; }
.ds-stat--rose    { --ds-stat-tint: rgba(244,63,94,.1);   --ds-stat-icon-bg: rgba(244,63,94,.12);   --ds-stat-icon-color: #f43f5e; }
.ds-stat--emerald { --ds-stat-tint: rgba(16,185,129,.1);  --ds-stat-icon-bg: rgba(16,185,129,.12);  --ds-stat-icon-color: #10b981; }
.ds-stat--amber   { --ds-stat-tint: rgba(245,158,11,.1);  --ds-stat-icon-bg: rgba(245,158,11,.12);  --ds-stat-icon-color: #f59e0b; }
.ds-stat--cyan    { --ds-stat-tint: rgba(6,182,212,.1);   --ds-stat-icon-bg: rgba(6,182,212,.12);   --ds-stat-icon-color: #06b6d4; }
.ds-stat--violet  { --ds-stat-tint: rgba(139,92,246,.1);  --ds-stat-icon-bg: rgba(139,92,246,.12);  --ds-stat-icon-color: #8b5cf6; }
.ds-stat--pink    { --ds-stat-tint: rgba(236,72,153,.1);  --ds-stat-icon-bg: rgba(236,72,153,.12);  --ds-stat-icon-color: #ec4899; }

/* Hero card with gradient */
.ds-hero {
    position: relative;
    border-radius: var(--ds-radius-lg);
    padding: 1.75rem 2rem;
    color: #fff;
    background:
        radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,.18) 0%, transparent 60%),
        linear-gradient(135deg, var(--ds-accent) 0%, var(--ds-accent-2) 100%);
    box-shadow: var(--ds-shadow-md);
    overflow: hidden;
}
.ds-hero::before {
    content: "";
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 90% 20%, rgba(255,255,255,.12), transparent 30%),
        radial-gradient(circle at 10% 90%, rgba(255,255,255,.08), transparent 35%);
    pointer-events: none;
}
.ds-hero h1, .ds-hero h2, .ds-hero h3 { color: #fff; }
.ds-hero .text-muted { color: rgba(255,255,255,.78) !important; }

/* Glass card */
.ds-glass {
    background: rgba(255, 255, 255, .65);
    backdrop-filter: blur(14px) saturate(160%);
    -webkit-backdrop-filter: blur(14px) saturate(160%);
    border: 1px solid rgba(255, 255, 255, .35);
    border-radius: var(--ds-radius-md);
}
[data-theme="dark"] .ds-glass {
    background: rgba(19, 26, 44, .55);
    border-color: rgba(255, 255, 255, .08);
}

/* ============================================================
   5. BUTTONS
   ============================================================ */
.btn {
    border-radius: var(--ds-radius-sm);
    font-weight: 600;
    transition: all var(--ds-dur-fast) var(--ds-ease);
    border-width: 1px;
}
.btn:focus, .btn:active { box-shadow: var(--ds-shadow-glow) !important; }

.btn-primary {
    background: var(--ds-accent) !important;
    border-color: var(--ds-accent) !important;
    color: #fff !important;
}
.btn-primary:hover {
    filter: brightness(.92);
    transform: translateY(-1px);
    box-shadow: 0 6px 14px rgba(79,70,229,.25);
}

.btn-outline-primary {
    color: var(--ds-accent) !important;
    border-color: var(--ds-accent) !important;
    background: transparent !important;
}
.btn-outline-primary:hover {
    background: var(--ds-accent) !important;
    color: #fff !important;
}

.btn-ghost {
    background: transparent;
    border: none;
    color: var(--ds-text-muted);
    border-radius: var(--ds-radius-sm);
    padding: .5rem .75rem;
}
.btn-ghost:hover { background: var(--ds-surface-2); color: var(--ds-text); }

.btn-icon {
    width: 38px; height: 38px;
    border-radius: var(--ds-radius-sm);
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    color: var(--ds-text-muted);
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.btn-icon:hover { background: var(--ds-surface-2); color: var(--ds-text); transform: translateY(-1px); }

/* ============================================================
   6. FORMS
   ============================================================ */
.form-control,
.form-select {
    background: var(--ds-surface) !important;
    border: 1px solid var(--ds-border) !important;
    color: var(--ds-text) !important;
    border-radius: var(--ds-radius-sm) !important;
    transition: border-color var(--ds-dur-fast) var(--ds-ease),
                box-shadow var(--ds-dur-fast) var(--ds-ease);
}
.form-control:focus,
.form-select:focus {
    border-color: var(--ds-accent) !important;
    box-shadow: 0 0 0 3px var(--ds-accent-soft) !important;
}

.form-label { color: var(--ds-text); font-weight: 500; font-size: .9rem; }
.input-group-text {
    background: var(--ds-surface-2) !important;
    border-color: var(--ds-border) !important;
    color: var(--ds-text-muted);
}

/* ============================================================
   7. TABLES
   ============================================================ */
.table {
    color: var(--ds-text);
    --bs-table-bg: transparent;
    --bs-table-color: var(--ds-text);
    --bs-table-striped-bg: var(--ds-surface-2);
    --bs-table-hover-bg: var(--ds-accent-soft);
    border-color: var(--ds-border-soft);
}
.table thead {
    background: var(--ds-surface-2);
}
.table thead th {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    font-weight: 700;
    color: var(--ds-text-muted);
    border-bottom: 1px solid var(--ds-border) !important;
    padding: .75rem 1rem;
}
.table tbody td {
    border-color: var(--ds-border-soft) !important;
    padding: .75rem 1rem;
    vertical-align: middle;
}
.table tbody tr { transition: background-color var(--ds-dur-fast) var(--ds-ease); }

/* ============================================================
   8. BADGES
   ============================================================ */
.badge {
    font-weight: 600;
    border-radius: var(--ds-radius-pill);
    padding: .35em .7em;
    letter-spacing: .02em;
}
.badge.bg-success { background: rgba(22,163,74,.12) !important; color: #15803d !important; }
.badge.bg-danger  { background: rgba(239,68,68,.12)  !important; color: #b91c1c !important; }
.badge.bg-warning { background: rgba(234,179,8,.18) !important; color: #a16207 !important; }
.badge.bg-info    { background: rgba(6,182,212,.14) !important; color: #0e7490 !important; }
.badge.bg-primary { background: var(--ds-accent-soft) !important; color: var(--ds-accent) !important; }
.badge.bg-secondary { background: var(--ds-surface-2) !important; color: var(--ds-text-muted) !important; }

[data-theme="dark"] .badge.bg-success { color: #4ade80 !important; }
[data-theme="dark"] .badge.bg-danger  { color: #fca5a5 !important; }
[data-theme="dark"] .badge.bg-warning { color: #fcd34d !important; }
[data-theme="dark"] .badge.bg-info    { color: #67e8f9 !important; }

/* ============================================================
   9. DROPDOWNS
   ============================================================ */
.dropdown-menu {
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    box-shadow: var(--ds-shadow-lg);
    padding: .5rem;
    min-width: 220px;
}
.dropdown-item {
    color: var(--ds-text);
    border-radius: var(--ds-radius-xs);
    padding: .5rem .75rem;
    font-size: .9rem;
    transition: background-color var(--ds-dur-fast) var(--ds-ease);
}
.dropdown-item:hover { background: var(--ds-surface-2); color: var(--ds-text); }
.dropdown-item.active, .dropdown-item:active {
    background: var(--ds-accent) !important;
    color: #fff !important;
}
.dropdown-header {
    color: var(--ds-text-muted);
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .08em;
}
.dropdown-divider { border-color: var(--ds-border-soft); }

/* ============================================================
   10. MODALS
   ============================================================ */
.modal-content {
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-lg);
    box-shadow: var(--ds-shadow-lg);
    color: var(--ds-text);
}
.modal-header, .modal-footer { border-color: var(--ds-border-soft); }
.modal-backdrop.show { backdrop-filter: blur(2px); }

/* ============================================================
   11. ALERTS
   ============================================================ */
.alert {
    border-radius: var(--ds-radius-md);
    border-width: 1px;
    padding: .85rem 1rem;
}
.alert-success { background: rgba(22,163,74,.08); border-color: rgba(22,163,74,.25); color: #14532d; }
.alert-danger  { background: rgba(239,68,68,.08); border-color: rgba(239,68,68,.25); color: #7f1d1d; }
.alert-warning { background: rgba(234,179,8,.1);  border-color: rgba(234,179,8,.3);  color: #713f12; }
.alert-info    { background: rgba(6,182,212,.08); border-color: rgba(6,182,212,.25); color: #155e75; }

[data-theme="dark"] .alert-success { color: #86efac; }
[data-theme="dark"] .alert-danger  { color: #fca5a5; }
[data-theme="dark"] .alert-warning { color: #fcd34d; }
[data-theme="dark"] .alert-info    { color: #67e8f9; }

/* ============================================================
   12. SIDEBAR (universal pentru toate layout-urile)
   ============================================================ */
.ds-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: var(--ds-sidebar-w);
    background: var(--ds-sidebar-bg);
    color: var(--ds-sidebar-text);
    z-index: 1040;
    overflow-y: auto;
    transition: width var(--ds-dur) var(--ds-ease),
                transform var(--ds-dur) var(--ds-ease);
    display: flex; flex-direction: column;
}
.ds-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-color: transparent; }

.ds-sidebar-brand {
    padding: 1.1rem 1.25rem;
    display: flex; align-items: center; gap: .65rem;
    color: #fff;
    font-weight: 700; font-size: 1.05rem;
    border-bottom: 1px solid rgba(255,255,255,.06);
    flex-shrink: 0;
}
.ds-sidebar-brand .ds-logo {
    width: 36px; height: 36px;
    background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.1rem;
    box-shadow: 0 4px 12px rgba(79,70,229,.45);
}
.ds-sidebar-brand .ds-brand-text {
    display: flex; flex-direction: column; line-height: 1.15;
    white-space: nowrap; overflow: hidden;
}
.ds-sidebar-brand .ds-brand-sub {
    font-size: .68rem; font-weight: 500; color: var(--ds-text-soft);
    text-transform: uppercase; letter-spacing: .1em;
}

.ds-sidebar-nav { flex: 1; padding: .75rem .65rem; }
.ds-sidebar-section {
    padding: .85rem 1rem .35rem;
    font-size: .65rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: rgba(255,255,255,.35);
    font-weight: 700;
}
.ds-sidebar-link {
    display: flex; align-items: center; gap: .8rem;
    padding: .6rem .85rem;
    color: var(--ds-sidebar-text);
    text-decoration: none;
    font-size: .92rem; font-weight: 500;
    border-radius: var(--ds-radius-sm);
    margin-bottom: 2px;
    position: relative;
    transition: background var(--ds-dur-fast) var(--ds-ease),
                color var(--ds-dur-fast) var(--ds-ease);
}
.ds-sidebar-link i { font-size: 1.05rem; width: 22px; text-align: center; }
.ds-sidebar-link:hover {
    background: rgba(255,255,255,.05);
    color: #fff;
}
.ds-sidebar-link.active {
    background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
    color: #fff;
    font-weight: 600;
    box-shadow: 0 4px 14px rgba(79,70,229,.35);
}
.ds-sidebar-link .badge-count {
    margin-left: auto;
    font-size: .68rem;
    background: rgba(255,255,255,.15);
    padding: 2px 7px;
    border-radius: var(--ds-radius-pill);
    font-weight: 700;
}
.ds-sidebar-link.active .badge-count { background: rgba(255,255,255,.25); }

.ds-sidebar-footer {
    padding: .85rem 1rem;
    border-top: 1px solid rgba(255,255,255,.06);
    flex-shrink: 0;
}

/* ─── Sidebar collapsed (mini) ─── */
.ds-sidebar.is-collapsed { width: var(--ds-sidebar-w-mini); }
.ds-sidebar.is-collapsed .ds-brand-text,
.ds-sidebar.is-collapsed .ds-sidebar-section,
.ds-sidebar.is-collapsed .ds-sidebar-link span,
.ds-sidebar.is-collapsed .ds-sidebar-link .badge-count,
.ds-sidebar.is-collapsed .ds-sidebar-footer { display: none; }
.ds-sidebar.is-collapsed .ds-sidebar-link { justify-content: center; padding: .65rem; }

/* ─── Sidebar mobile drawer ─── */
@media (max-width: 991.98px) {
    .ds-sidebar { transform: translateX(-100%); }
    .ds-sidebar.is-open { transform: translateX(0); }
}

/* ─── Backdrop pentru mobile sidebar ─── */
.ds-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.5);
    backdrop-filter: blur(2px);
    z-index: 1039;
    opacity: 0; pointer-events: none;
    transition: opacity var(--ds-dur) var(--ds-ease);
}
.ds-backdrop.is-show { opacity: 1; pointer-events: auto; }

/* ============================================================
   13. MAIN WRAPPER + TOPBAR
   ============================================================ */
.ds-main {
    margin-left: var(--ds-sidebar-w);
    min-height: 100vh;
    transition: margin-left var(--ds-dur) var(--ds-ease);
}
.ds-main.is-collapsed-host { margin-left: var(--ds-sidebar-w-mini); }
@media (max-width: 991.98px) { .ds-main { margin-left: 0; } }

.ds-topbar {
    height: var(--ds-topbar-h);
    background: var(--ds-bg-elev);
    border-bottom: 1px solid var(--ds-border);
    position: sticky; top: 0;
    z-index: 1030;
    display: flex; align-items: center; gap: 1rem;
    padding: 0 1.25rem;
    backdrop-filter: blur(8px);
}
[data-theme="dark"] .ds-topbar { background: rgba(19,26,44,.85); }

.ds-topbar-search {
    flex: 1; max-width: 480px;
    position: relative;
}
.ds-topbar-search input {
    width: 100%;
    border: 1px solid var(--ds-border);
    background: var(--ds-surface-2);
    border-radius: var(--ds-radius-pill);
    padding: .5rem 1rem .5rem 2.5rem;
    color: var(--ds-text);
    font-size: .9rem;
}
.ds-topbar-search input:focus {
    outline: none;
    border-color: var(--ds-accent);
    box-shadow: 0 0 0 3px var(--ds-accent-soft);
}
.ds-topbar-search i {
    position: absolute; left: 1rem; top: 50%; transform: translateY(-50%);
    color: var(--ds-text-muted);
}
.ds-topbar-search kbd {
    position: absolute; right: .5rem; top: 50%; transform: translateY(-50%);
    font-size: .7rem; padding: 2px 6px;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: 4px;
    color: var(--ds-text-muted);
}

.ds-page {
    padding: 1.5rem;
    max-width: 1480px;
    margin: 0 auto;
}
.ds-page-header {
    margin-bottom: 1.5rem;
}
.ds-page-title {
    display: flex; align-items: center; gap: .75rem;
    font-size: 1.5rem; font-weight: 700;
}

/* ─── Avatar ─── */
.ds-avatar {
    width: 38px; height: 38px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-weight: 700; font-size: .85rem;
    cursor: pointer;
    transition: transform var(--ds-dur-fast) var(--ds-ease);
}
.ds-avatar:hover { transform: scale(1.05); }

/* ============================================================
   14. WIDGETS (drag & drop)
   ============================================================ */
.ds-widget-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 1rem;
}
.ds-widget {
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    box-shadow: var(--ds-shadow-sm);
    overflow: hidden;
    position: relative;
    transition: transform var(--ds-dur) var(--ds-ease),
                box-shadow var(--ds-dur) var(--ds-ease);
    grid-column: span 4;       /* default md */
    min-width: 0;
}
.ds-widget[data-size="sm"], .ds-widget.ds-widget-sm { grid-column: span 3; }
.ds-widget[data-size="md"], .ds-widget.ds-widget-md { grid-column: span 4; }
.ds-widget[data-size="lg"], .ds-widget.ds-widget-lg { grid-column: span 6; }
.ds-widget[data-size="xl"], .ds-widget.ds-widget-xl { grid-column: span 12; }

@media (max-width: 991.98px) {
    .ds-widget,
    .ds-widget[data-size="sm"], .ds-widget.ds-widget-sm,
    .ds-widget[data-size="md"], .ds-widget.ds-widget-md { grid-column: span 6; }
    .ds-widget[data-size="lg"], .ds-widget.ds-widget-lg,
    .ds-widget[data-size="xl"], .ds-widget.ds-widget-xl { grid-column: span 12; }
}
@media (max-width: 575.98px) {
    .ds-widget,
    .ds-widget[data-size="sm"], .ds-widget.ds-widget-sm,
    .ds-widget[data-size="md"], .ds-widget.ds-widget-md,
    .ds-widget[data-size="lg"], .ds-widget.ds-widget-lg,
    .ds-widget[data-size="xl"], .ds-widget.ds-widget-xl { grid-column: span 12; }
}

.ds-widget-header {
    display: flex; align-items: center; gap: .5rem;
    padding: .85rem 1rem;
    border-bottom: 1px solid var(--ds-border-soft);
    font-weight: 600; font-size: .92rem;
}
/* Actions/handle ascunse complet în afara modului edit */
.ds-widget > .ds-widget-actions {
    position: absolute;
    top: .5rem; right: .5rem;
    z-index: 3;
    display: none;
    gap: .25rem; align-items: center;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    padding: 2px;
    box-shadow: var(--ds-shadow-sm);
}
body.is-widget-editing .ds-widget > .ds-widget-actions {
    display: flex;
    animation: ds-pop-in .25s var(--ds-ease-spring, cubic-bezier(.34,1.56,.64,1)) both;
}

/* Actions nested inside header (legacy) */
.ds-widget-header .ds-widget-actions {
    margin-left: auto;
    display: none;
    gap: .25rem; align-items: center;
}
body.is-widget-editing .ds-widget-header .ds-widget-actions { display: flex; }

/* Action buttons (hide / resize) */
.ds-widget-action,
.ds-widget-hide,
.ds-widget-resize {
    background: transparent;
    border: none;
    color: var(--ds-text-muted);
    width: 28px; height: 28px;
    border-radius: 6px;
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    font-size: .85rem;
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.ds-widget-action:hover,
.ds-widget-hide:hover,
.ds-widget-resize:hover { background: var(--ds-surface-2); color: var(--ds-text); }
.ds-widget-hide:hover { color: var(--ds-danger, #dc3545); }
.ds-widget-resize.is-active {
    background: var(--ds-accent);
    color: #fff;
}

.ds-widget-body { padding: 1rem; }
.ds-widget-foot {
    padding: .65rem 1rem;
    border-top: 1px solid var(--ds-border-soft);
    color: var(--ds-text-muted);
    font-size: .85rem;
    margin: 0;
}

/* Drag handle — ascuns complet, vizibil doar în edit mode */
.ds-widget > .ds-widget-handle {
    position: absolute;
    top: -10px; left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    display: none;
    align-items: center; justify-content: center;
    color: var(--ds-text-muted);
    cursor: grab;
    border-radius: 999px;
}
body.is-widget-editing .ds-widget > .ds-widget-handle {
    display: inline-flex;
    animation: ds-pop-in .25s var(--ds-ease-spring, cubic-bezier(.34,1.56,.64,1)) both;
}
.ds-widget > .ds-widget-handle:hover { background: var(--ds-accent); color: #fff; border-color: var(--ds-accent); }
.ds-widget > .ds-widget-handle:active { cursor: grabbing; }

/* Edit-mode visual cue + iOS wiggle */
body.is-widget-editing .ds-widget {
    cursor: grab;
    animation: ds-wiggle 2.4s ease-in-out infinite;
    animation-delay: calc(var(--w-i, 0) * 70ms);
    transform-origin: center;
}
body.is-widget-editing .ds-widget:nth-child(odd)  { animation-name: ds-wiggle-a; }
body.is-widget-editing .ds-widget:nth-child(even) { animation-name: ds-wiggle-b; }
body.is-widget-editing .ds-widget:active { animation: none; cursor: grabbing; }
body.is-widget-editing .ds-widget.is-chosen,
body.is-widget-editing .ds-widget.is-ghost { animation: none; }

@keyframes ds-pop-in {
    0%   { opacity: 0; transform: translateY(-4px) scale(.85); }
    100% { opacity: 1; transform: translateY(0)    scale(1); }
}
@keyframes ds-wiggle-a {
    0%, 100% { transform: rotate(-.4deg); }
    50%      { transform: rotate(.4deg);  }
}
@keyframes ds-wiggle-b {
    0%, 100% { transform: rotate(.4deg);  }
    50%      { transform: rotate(-.4deg); }
}
@media (prefers-reduced-motion: reduce) {
    body.is-widget-editing .ds-widget { animation: none !important; }
}

/* Hidden widget — apare în edit mode, dimmed cu overlay "Afișează" */
.ds-widget.is-hidden-edit {
    opacity: .5;
    filter: grayscale(.4);
    border-style: dashed !important;
}
.ds-widget.is-hidden-edit .ds-widget-show-overlay {
    position: absolute;
    inset: 0;
    z-index: 4;
    display: flex; align-items: center; justify-content: center;
    background: rgba(15,23,42,.05);
    cursor: pointer;
    border-radius: inherit;
    transition: all var(--ds-dur) var(--ds-ease);
}
[data-theme="dark"] .ds-widget.is-hidden-edit .ds-widget-show-overlay {
    background: rgba(255,255,255,.05);
}
.ds-widget.is-hidden-edit .ds-widget-show-overlay span {
    background: var(--ds-accent);
    color: #fff;
    padding: .65rem 1.1rem;
    border-radius: 999px;
    font-weight: 600;
    font-size: .9rem;
    box-shadow: var(--ds-shadow-md);
    display: inline-flex; align-items: center; gap: .4rem;
    transition: transform var(--ds-dur) var(--ds-ease-spring, cubic-bezier(.34,1.56,.64,1));
}
.ds-widget.is-hidden-edit .ds-widget-show-overlay:hover span {
    transform: scale(1.06);
}
/* În edit mode, ascunde butoanele resize/hide pe carduri marcate is-hidden-edit (le restorezi prin overlay) */
body.is-widget-editing .ds-widget.is-hidden-edit > .ds-widget-actions,
body.is-widget-editing .ds-widget.is-hidden-edit > .ds-widget-handle { display: none; }

.ds-widget.is-ghost {
    opacity: .5; transform: scale(.97);
    background: var(--ds-surface-2);
}
.ds-widget.is-chosen {
    box-shadow: var(--ds-shadow-lg);
    transform: rotate(.5deg) scale(1.02);
}

/* Toolbar above grid (Personalizează / Resetează) */
.ds-widget-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
    padding: .65rem 1rem;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    box-shadow: var(--ds-shadow-sm);
}
.ds-widget-toolbar .ds-clock {
    font-weight: 500;
    color: var(--ds-text-muted);
}
.ds-widget-toolbar-actions {
    display: flex;
    gap: .5rem;
    align-items: center;
}

/* Lista widget-urilor ascunse */
.ds-widget-hidden-list {
    margin-top: 1rem;
    padding: .85rem 1rem;
    background: var(--ds-surface-2);
    border: 1px dashed var(--ds-border);
    border-radius: var(--ds-radius-md);
}
.ds-widget-hidden-list > summary {
    cursor: pointer;
    font-weight: 600;
    color: var(--ds-text-muted);
}
.ds-widget-hidden-grid {
    margin-top: .65rem;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.ds-widget-empty {
    margin-top: 1rem;
}

/* Edit-mode banner */
.ds-edit-banner {
    background: linear-gradient(90deg, var(--ds-accent), var(--ds-accent-2));
    color: #fff;
    padding: .65rem 1rem;
    border-radius: var(--ds-radius-md);
    display: flex; align-items: center; gap: .75rem;
    margin-bottom: 1rem;
    box-shadow: var(--ds-shadow-md);
    animation: pulse-glow 2s ease-in-out infinite;
}
@keyframes pulse-glow {
    0%, 100% { box-shadow: 0 0 0 0 rgba(79,70,229,.4); }
    50%      { box-shadow: 0 0 0 8px rgba(79,70,229,0); }
}

/* ============================================================
   15. ANIMATIONS / UTILITIES
   ============================================================ */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes scaleIn { from { transform: scale(.9); opacity: 0; } to { transform: scale(1); opacity: 1; } }
@keyframes slideInLeft { from { transform: translateX(-20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
@keyframes shimmer {
    0% { background-position: -1000px 0; }
    100% { background-position: 1000px 0; }
}

.ds-fade-in   { animation: fadeIn   var(--ds-dur-slow) var(--ds-ease) both; }
.ds-fade-up   { animation: fadeInUp var(--ds-dur-slow) var(--ds-ease) both; }
.ds-scale-in  { animation: scaleIn  var(--ds-dur-slow) var(--ds-ease-spring) both; }

.ds-stagger > * { animation: fadeInUp var(--ds-dur-slow) var(--ds-ease) both; }
.ds-stagger > *:nth-child(1) { animation-delay: .04s; }
.ds-stagger > *:nth-child(2) { animation-delay: .08s; }
.ds-stagger > *:nth-child(3) { animation-delay: .12s; }
.ds-stagger > *:nth-child(4) { animation-delay: .16s; }
.ds-stagger > *:nth-child(5) { animation-delay: .20s; }
.ds-stagger > *:nth-child(6) { animation-delay: .24s; }
.ds-stagger > *:nth-child(7) { animation-delay: .28s; }
.ds-stagger > *:nth-child(8) { animation-delay: .32s; }

/* Skeleton loader */
.ds-skeleton {
    background: linear-gradient(90deg,
        var(--ds-surface-2) 0%,
        var(--ds-border-soft) 50%,
        var(--ds-surface-2) 100%);
    background-size: 1000px 100%;
    animation: shimmer 1.6s linear infinite;
    border-radius: var(--ds-radius-xs);
}

/* ============================================================
   16. COMMAND PALETTE
   ============================================================ */
.ds-cmdk-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.5);
    backdrop-filter: blur(4px);
    z-index: 2000;
    display: none;
    align-items: flex-start; justify-content: center;
    padding-top: 12vh;
    animation: fadeIn 180ms ease both;
}
.ds-cmdk-overlay.is-open { display: flex; }
.ds-cmdk {
    width: 100%;
    max-width: 580px;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-lg);
    box-shadow: var(--ds-shadow-lg);
    overflow: hidden;
    animation: scaleIn 220ms var(--ds-ease-spring) both;
}
.ds-cmdk-input-wrap {
    padding: .75rem 1rem;
    display: flex; align-items: center; gap: .65rem;
    border-bottom: 1px solid var(--ds-border-soft);
}
.ds-cmdk-input {
    flex: 1; border: none; outline: none;
    background: transparent;
    font-size: 1rem; color: var(--ds-text);
}
.ds-cmdk-results { max-height: 50vh; overflow-y: auto; padding: .5rem; }
.ds-cmdk-item {
    display: flex; align-items: center; gap: .75rem;
    padding: .65rem .85rem;
    border-radius: var(--ds-radius-sm);
    cursor: pointer;
    transition: background var(--ds-dur-fast) var(--ds-ease);
    color: var(--ds-text);
    text-decoration: none;
}
.ds-cmdk-item:hover,
.ds-cmdk-item.is-active {
    background: var(--ds-accent-soft);
    color: var(--ds-accent);
}
.ds-cmdk-item .ds-cmdk-icon {
    width: 32px; height: 32px;
    border-radius: 8px;
    background: var(--ds-surface-2);
    display: flex; align-items: center; justify-content: center;
}
.ds-cmdk-empty { padding: 2rem; text-align: center; color: var(--ds-text-muted); font-size: .9rem; }
.ds-cmdk-footer {
    padding: .65rem 1rem;
    border-top: 1px solid var(--ds-border-soft);
    background: var(--ds-surface-2);
    font-size: .75rem; color: var(--ds-text-muted);
    display: flex; gap: 1rem;
}
.ds-cmdk-footer kbd {
    font-size: .7rem; padding: 1px 5px;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: 3px;
}

/* ============================================================
   17. THEME TOGGLE
   — varianta "switch pill" (folosită stand-alone pe pagini auth)
   — varianta "icon button" (când e combinat cu .ds-icon-btn)
   ============================================================ */
.ds-theme-toggle:not(.ds-icon-btn) {
    position: relative;
    width: 44px; height: 26px;
    background: var(--ds-surface-2);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-pill);
    cursor: pointer;
    transition: background var(--ds-dur) var(--ds-ease);
}
.ds-theme-toggle:not(.ds-icon-btn)::before {
    content: ""; position: absolute;
    width: 18px; height: 18px;
    top: 3px; left: 3px;
    background: linear-gradient(135deg, #fbbf24, #f59e0b);
    border-radius: 50%;
    transition: transform var(--ds-dur) var(--ds-ease-spring),
                background var(--ds-dur) var(--ds-ease);
    box-shadow: var(--ds-shadow-sm);
}
[data-theme="dark"] .ds-theme-toggle:not(.ds-icon-btn)::before {
    transform: translateX(18px);
    background: linear-gradient(135deg, #6366f1, #4f46e5);
}
/* Când e folosit ca buton iconă în topbar — ascunde pseudo-elementul de switch */
.ds-icon-btn.ds-theme-toggle { width: 38px; height: 38px; padding: 0; }
.ds-icon-btn.ds-theme-toggle::before { content: none; }
.ds-icon-btn.ds-theme-toggle .ds-icon-light,
.ds-icon-btn.ds-theme-toggle .ds-icon-dark {
    position: absolute; inset: 0;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.05rem;
    transition: opacity var(--ds-dur) var(--ds-ease),
                transform var(--ds-dur) var(--ds-ease-spring);
}
.ds-icon-btn.ds-theme-toggle .ds-icon-light {
    color: #f59e0b; opacity: 1; transform: rotate(0) scale(1);
}
.ds-icon-btn.ds-theme-toggle .ds-icon-dark  {
    color: #6366f1; opacity: 0; transform: rotate(-90deg) scale(.7);
}
[data-theme="dark"] .ds-icon-btn.ds-theme-toggle .ds-icon-light {
    opacity: 0; transform: rotate(90deg) scale(.7);
}
[data-theme="dark"] .ds-icon-btn.ds-theme-toggle .ds-icon-dark {
    opacity: 1; transform: rotate(0) scale(1);
}

/* ============================================================
   18. MISC
   ============================================================ */
hr { border-color: var(--ds-border-soft); }

.divider-vert {
    width: 1px; height: 24px;
    background: var(--ds-border);
    margin: 0 .25rem;
}

/* Smooth fade for tab switches etc */
.tab-pane.fade { transition: opacity var(--ds-dur) var(--ds-ease); }

/* Pagination */
.pagination .page-link {
    color: var(--ds-text);
    background: var(--ds-surface);
    border-color: var(--ds-border);
}
.pagination .page-link:hover { background: var(--ds-surface-2); }
.pagination .active .page-link {
    background: var(--ds-accent) !important;
    border-color: var(--ds-accent) !important;
    color: #fff !important;
}

/* List groups */
.list-group-item {
    background: transparent;
    color: var(--ds-text);
    border-color: var(--ds-border-soft);
}
.list-group-item-action:hover { background: var(--ds-surface-2); }

/* Nav tabs */
.nav-tabs { border-bottom-color: var(--ds-border); }
.nav-tabs .nav-link {
    color: var(--ds-text-muted);
    border: none;
    border-bottom: 2px solid transparent;
    border-radius: 0;
    padding: .65rem 1rem;
    font-weight: 500;
}
.nav-tabs .nav-link:hover { color: var(--ds-text); border-color: transparent; }
.nav-tabs .nav-link.active {
    color: var(--ds-accent);
    background: transparent;
    border-bottom: 2px solid var(--ds-accent);
}

/* Progress bars */
.progress {
    background: var(--ds-surface-2);
    border-radius: var(--ds-radius-pill);
    overflow: hidden;
    height: 8px;
}
.progress-bar {
    background: linear-gradient(90deg, var(--ds-accent), var(--ds-accent-2));
    transition: width 1.2s var(--ds-ease);
}

/* Toast notifications */
.toast {
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    box-shadow: var(--ds-shadow-lg);
    color: var(--ds-text);
}

/* Floating action button */
.ds-fab {
    position: fixed;
    bottom: 24px; right: 24px;
    width: 56px; height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
    color: #fff;
    border: none;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    box-shadow: var(--ds-shadow-lg);
    cursor: pointer;
    transition: transform var(--ds-dur) var(--ds-ease-spring);
    z-index: 1050;
}
.ds-fab:hover { transform: scale(1.08) rotate(-5deg); }

/* Reduce motion (a11y) */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .01ms !important;
        transition-duration: .01ms !important;
    }
}

/* ============================================================
   UNIVERSAL OVERRIDES — components not yet covered
   ============================================================ */

/* Pagination */
.pagination .page-link {
    background: var(--ds-surface) !important;
    border: 1px solid var(--ds-border) !important;
    color: var(--ds-text) !important;
    border-radius: var(--ds-radius-xs) !important;
    margin: 0 2px;
    font-weight: 500;
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.pagination .page-link:hover {
    background: var(--ds-surface-2) !important;
    color: var(--ds-accent) !important;
    border-color: var(--ds-accent) !important;
}
.pagination .page-item.active .page-link {
    background: var(--ds-accent) !important;
    border-color: var(--ds-accent) !important;
    color: #fff !important;
    box-shadow: 0 4px 10px rgba(79, 70, 229, .25);
}
.pagination .page-item.disabled .page-link {
    background: var(--ds-surface-2) !important;
    color: var(--ds-text-soft) !important;
    border-color: var(--ds-border-soft) !important;
}

/* Breadcrumbs */
.breadcrumb {
    background: transparent;
    padding: .5rem 0;
    font-size: .9rem;
    margin-bottom: 1rem;
}
.breadcrumb-item { color: var(--ds-text-muted); }
.breadcrumb-item a { color: var(--ds-text-muted); text-decoration: none; }
.breadcrumb-item a:hover { color: var(--ds-accent); }
.breadcrumb-item.active { color: var(--ds-text); font-weight: 600; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--ds-text-soft); }

/* List groups */
.list-group {
    border-radius: var(--ds-radius-md);
    overflow: hidden;
    border: 1px solid var(--ds-border);
}
.list-group-item {
    background: var(--ds-surface) !important;
    border-color: var(--ds-border-soft) !important;
    color: var(--ds-text);
    padding: .85rem 1rem;
    transition: background var(--ds-dur-fast) var(--ds-ease);
}
.list-group-item.active {
    background: var(--ds-accent) !important;
    border-color: var(--ds-accent) !important;
    color: #fff !important;
}
.list-group-item-action:hover {
    background: var(--ds-surface-2) !important;
    color: var(--ds-text) !important;
}

/* Progress bars */
.progress {
    background: var(--ds-surface-2);
    border-radius: var(--ds-radius-pill);
    height: 8px;
    overflow: hidden;
}
.progress-bar {
    background: linear-gradient(90deg, var(--ds-accent), var(--ds-accent-2));
    border-radius: var(--ds-radius-pill);
    transition: width .6s var(--ds-ease);
}
.progress-bar.bg-success { background: linear-gradient(90deg, #16a34a, #22c55e) !important; }
.progress-bar.bg-warning { background: linear-gradient(90deg, #eab308, #fbbf24) !important; }
.progress-bar.bg-danger  { background: linear-gradient(90deg, #ef4444, #f87171) !important; }
.progress-bar.bg-info    { background: linear-gradient(90deg, #06b6d4, #67e8f9) !important; }

/* Nav-tabs (non-auth, generic) */
.nav-tabs:not(.ds-auth-tabs):not(.auth-tabs) {
    border-bottom: 1px solid var(--ds-border);
    margin-bottom: 1rem;
}
.nav-tabs:not(.ds-auth-tabs):not(.auth-tabs) .nav-link {
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--ds-text-muted);
    font-weight: 600;
    padding: .65rem 1rem;
    background: transparent;
    transition: all var(--ds-dur-fast) var(--ds-ease);
    margin-bottom: -1px;
}
.nav-tabs:not(.ds-auth-tabs):not(.auth-tabs) .nav-link:hover {
    color: var(--ds-text);
    border-color: transparent;
}
.nav-tabs:not(.ds-auth-tabs):not(.auth-tabs) .nav-link.active {
    color: var(--ds-accent) !important;
    background: transparent !important;
    border-bottom: 2px solid var(--ds-accent) !important;
}

/* Nav-pills */
.nav-pills .nav-link {
    color: var(--ds-text-muted);
    font-weight: 600;
    border-radius: var(--ds-radius-sm);
    padding: .55rem 1rem;
}
.nav-pills .nav-link:hover { background: var(--ds-surface-2); color: var(--ds-text); }
.nav-pills .nav-link.active {
    background: var(--ds-accent) !important;
    color: #fff !important;
}

/* Accordion */
.accordion-item {
    background: var(--ds-surface) !important;
    border: 1px solid var(--ds-border) !important;
    border-radius: var(--ds-radius-md) !important;
    margin-bottom: .5rem;
    overflow: hidden;
}
.accordion-button {
    background: var(--ds-surface) !important;
    color: var(--ds-text) !important;
    font-weight: 600;
    padding: 1rem 1.15rem;
}
.accordion-button:not(.collapsed) {
    background: var(--ds-accent-soft) !important;
    color: var(--ds-accent) !important;
    box-shadow: none !important;
}
.accordion-button:focus {
    box-shadow: 0 0 0 3px var(--ds-accent-soft) !important;
    border-color: var(--ds-accent) !important;
}
.accordion-body {
    background: var(--ds-surface);
    color: var(--ds-text);
    padding: 1rem 1.15rem;
}

/* Toast */
.toast {
    background: var(--ds-surface) !important;
    border: 1px solid var(--ds-border) !important;
    border-radius: var(--ds-radius-md) !important;
    box-shadow: var(--ds-shadow-lg);
    color: var(--ds-text);
}
.toast-header {
    background: transparent !important;
    border-color: var(--ds-border-soft) !important;
    color: var(--ds-text);
}

/* Form-check (checkboxes / radios) */
.form-check-input {
    background-color: var(--ds-surface);
    border-color: var(--ds-border);
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.form-check-input:checked {
    background-color: var(--ds-accent);
    border-color: var(--ds-accent);
}
.form-check-input:focus {
    box-shadow: 0 0 0 3px var(--ds-accent-soft);
    border-color: var(--ds-accent);
}

/* Form-switch */
.form-switch .form-check-input {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23cbd5e1'/%3e%3c/svg%3e");
}
.form-switch .form-check-input:checked {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}

/* Input groups */
.input-group .form-control:focus + .input-group-text,
.input-group .input-group-text + .form-control:focus {
    border-color: var(--ds-accent) !important;
}

/* Spinner */
.spinner-border, .spinner-grow { color: var(--ds-accent); }

/* Code & pre */
code { color: var(--ds-accent); background: var(--ds-accent-soft); padding: 1px 6px; border-radius: 4px; font-size: .9em; }
pre {
    background: var(--ds-surface-2);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-sm);
    padding: 1rem;
    color: var(--ds-text);
    font-size: .88rem;
}

/* HR */
hr { border-color: var(--ds-border-soft); opacity: 1; }

/* Bootstrap utilities — adapt to dark mode */
.bg-light { background: var(--ds-surface-2) !important; color: var(--ds-text); }
.bg-white { background: var(--ds-surface) !important; }
[data-theme="dark"] .bg-white { background: var(--ds-surface) !important; color: var(--ds-text); }
.text-dark { color: var(--ds-text) !important; }
.border { border-color: var(--ds-border) !important; }
.border-top, .border-bottom, .border-start, .border-end { border-color: var(--ds-border-soft) !important; }
.shadow-sm { box-shadow: var(--ds-shadow-sm) !important; }
.shadow     { box-shadow: var(--ds-shadow-md) !important; }
.shadow-lg  { box-shadow: var(--ds-shadow-lg) !important; }

/* Empty state — generic helper */
.ds-empty-state {
    text-align: center;
    padding: 2rem 1rem;
    color: var(--ds-text-muted);
}
.ds-empty-state i {
    font-size: 3rem;
    color: var(--ds-text-soft);
    display: block;
    margin-bottom: .75rem;
}
.ds-empty-state-pad { padding: 1.5rem 1rem; }

/* Generic chip (used in dashboards & lists) */
.ds-chip {
    display: inline-flex; align-items: center;
    padding: .25rem .6rem;
    background: var(--ds-surface-2);
    color: var(--ds-text-muted);
    border-radius: var(--ds-radius-pill);
    font-size: .78rem;
    font-weight: 600;
}
.ds-chip-success { background: rgba(22,163,74,.12); color: #15803d; }
.ds-chip-warning { background: rgba(234,179,8,.18); color: #a16207; }
.ds-chip-danger  { background: rgba(239,68,68,.12); color: #b91c1c; }
.ds-chip-info    { background: rgba(6,182,212,.14); color: #0e7490; }
[data-theme="dark"] .ds-chip-success { color: #4ade80; }
[data-theme="dark"] .ds-chip-warning { color: #fcd34d; }
[data-theme="dark"] .ds-chip-danger  { color: #fca5a5; }
[data-theme="dark"] .ds-chip-info    { color: #67e8f9; }

/* ============================================================
   AUTH PAGES — split-screen with gradient + form
   ============================================================ */
.ds-auth-shell {
    min-height: 100vh;
    display: grid;
    grid-template-columns: 1fr;
    background: var(--ds-bg);
    position: relative;
    overflow: hidden;
}
@media (min-width: 992px) {
    .ds-auth-shell { grid-template-columns: 1.05fr 1fr; }
}

/* Aside (branding pane) */
.ds-auth-aside {
    position: relative;
    display: none;
    padding: 3rem 3rem 2rem;
    color: #fff;
    overflow: hidden;
    background:
        radial-gradient(circle at 20% 10%, rgba(139, 92, 246, .55), transparent 55%),
        radial-gradient(circle at 80% 90%, rgba(6, 182, 212, .50), transparent 55%),
        linear-gradient(135deg, #4f46e5 0%, #6d28d9 60%, #1e1b4b 100%);
    isolation: isolate;
}
@media (min-width: 992px) { .ds-auth-aside { display: flex; flex-direction: column; justify-content: space-between; } }

.ds-auth-aside::before, .ds-auth-aside::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    opacity: .55;
    pointer-events: none;
    z-index: -1;
}
.ds-auth-aside::before {
    width: 380px; height: 380px;
    background: rgba(99, 102, 241, .8);
    top: -120px; right: -100px;
    animation: ds-blob-float 14s ease-in-out infinite;
}
.ds-auth-aside::after {
    width: 320px; height: 320px;
    background: rgba(6, 182, 212, .65);
    bottom: -120px; left: -80px;
    animation: ds-blob-float 18s ease-in-out infinite reverse;
}

@keyframes ds-blob-float {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50%      { transform: translate(30px, -20px) scale(1.07); }
}

.ds-auth-brand {
    display: flex; align-items: center; gap: .75rem;
    font-size: 1.5rem; font-weight: 800;
    text-decoration: none; color: #fff;
}
.ds-auth-brand:hover { color: #fff; opacity: .95; }
.ds-auth-brand-mark {
    width: 48px; height: 48px;
    border-radius: 14px;
    background: rgba(255, 255, 255, .15);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, .25);
    display: grid; place-items: center;
    font-size: 1.5rem;
}

.ds-auth-hero {
    margin: auto 0;
}
.ds-auth-hero h1 {
    font-size: clamp(2rem, 3vw, 2.75rem);
    font-weight: 800;
    line-height: 1.15;
    margin-bottom: 1rem;
    color: #fff;
}
.ds-auth-hero p {
    font-size: 1.05rem;
    opacity: .9;
    max-width: 480px;
    margin-bottom: 2rem;
}
.ds-auth-feature-list {
    list-style: none; padding: 0; margin: 0;
    display: grid; gap: 1rem;
}
.ds-auth-feature-list li {
    display: flex; align-items: flex-start; gap: .85rem;
    font-size: .95rem;
    line-height: 1.5;
}
.ds-auth-feature-list li i {
    flex-shrink: 0;
    width: 36px; height: 36px;
    border-radius: 10px;
    background: rgba(255, 255, 255, .18);
    border: 1px solid rgba(255, 255, 255, .22);
    display: grid; place-items: center;
    font-size: 1.05rem;
}

.ds-auth-aside-footer {
    font-size: .82rem;
    opacity: .8;
}

/* Form pane */
.ds-auth-form-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1.25rem;
    min-height: 100vh;
}
@media (min-width: 576px) { .ds-auth-form-wrap { padding: 3rem 2rem; } }

.ds-auth-card {
    width: 100%;
    max-width: 480px;
    background: var(--ds-surface);
    border-radius: var(--ds-radius-lg);
    box-shadow: var(--ds-shadow-md);
    padding: 2rem 1.5rem;
    border: 1px solid var(--ds-border);
    animation: ds-auth-rise .6s var(--ds-ease) both;
}
@media (min-width: 576px) { .ds-auth-card { padding: 2.5rem; } }
.ds-auth-card.is-wide { max-width: 720px; }

@keyframes ds-auth-rise {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}

.ds-auth-card-header {
    text-align: center;
    margin-bottom: 1.5rem;
}
.ds-auth-card-header h2 {
    font-size: 1.5rem;
    font-weight: 700;
    margin-bottom: .35rem;
    color: var(--ds-text);
}
.ds-auth-card-header p {
    color: var(--ds-text-muted);
    margin: 0;
    font-size: .92rem;
}
.ds-auth-card-mobile-brand {
    display: none;
    text-align: center;
    margin-bottom: 1.25rem;
}
@media (max-width: 991.98px) {
    .ds-auth-card-mobile-brand { display: block; }
    .ds-auth-card-mobile-brand .ds-logo-mark {
        background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
        color: #fff;
        margin: 0 auto;
    }
}

/* Tabs */
.ds-auth-tabs {
    display: flex;
    gap: .25rem;
    background: var(--ds-surface-2);
    padding: .25rem;
    border-radius: var(--ds-radius-sm);
    margin-bottom: 1.5rem;
    border: none;
}
.ds-auth-tabs .nav-item { flex: 1; }
.ds-auth-tabs .nav-link {
    width: 100%;
    border: none !important;
    background: transparent;
    color: var(--ds-text-muted);
    font-weight: 600;
    font-size: .9rem;
    padding: .65rem .5rem;
    border-radius: var(--ds-radius-xs) !important;
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.ds-auth-tabs .nav-link:hover { color: var(--ds-text); background: rgba(0, 0, 0, .03); }
[data-theme="dark"] .ds-auth-tabs .nav-link:hover { background: rgba(255, 255, 255, .04); }
.ds-auth-tabs .nav-link.active {
    background: var(--ds-surface) !important;
    color: var(--ds-accent) !important;
    box-shadow: var(--ds-shadow-xs);
}

/* Role cards (signup choice) */
.ds-auth-role-card {
    display: flex; align-items: center; gap: 1rem;
    padding: 1rem 1.1rem;
    border-radius: var(--ds-radius-md);
    border: 1.5px solid var(--ds-border);
    background: var(--ds-surface);
    color: var(--ds-text);
    text-decoration: none;
    transition: all var(--ds-dur) var(--ds-ease);
    cursor: pointer;
}
.ds-auth-role-card:hover {
    border-color: var(--ds-accent);
    background: var(--ds-accent-soft);
    color: var(--ds-text);
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: var(--ds-shadow-sm);
}
.ds-auth-role-card-icon {
    flex-shrink: 0;
    width: 48px; height: 48px;
    border-radius: var(--ds-radius-sm);
    background: var(--ds-accent-soft);
    color: var(--ds-accent);
    display: grid; place-items: center;
    font-size: 1.4rem;
}
.ds-auth-role-card:hover .ds-auth-role-card-icon {
    background: var(--ds-accent);
    color: #fff;
}
.ds-auth-role-card-body { flex: 1; }
.ds-auth-role-card-body strong { display: block; font-size: 1rem; font-weight: 700; }
.ds-auth-role-card-body small { color: var(--ds-text-muted); font-size: .82rem; }
.ds-auth-role-card-arrow { color: var(--ds-text-soft); }

/* Section title */
.ds-auth-section-title {
    text-transform: uppercase;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .08em;
    color: var(--ds-text-muted);
    margin: 1.25rem 0 .75rem;
    padding-bottom: .35rem;
    border-bottom: 1px dashed var(--ds-border);
}

/* Code input (firma code) */
.ds-auth-code-input {
    font-family: 'SF Mono', 'Monaco', 'Consolas', monospace;
    font-size: 1.4rem !important;
    letter-spacing: .35em;
    text-transform: uppercase;
    text-align: center;
    font-weight: 800 !important;
    background: var(--ds-surface-2) !important;
}

/* Hint card */
.ds-auth-hint {
    background: var(--ds-accent-soft);
    border-left: 3px solid var(--ds-accent);
    padding: .85rem 1rem;
    border-radius: var(--ds-radius-sm);
    color: var(--ds-text);
    font-size: .88rem;
    line-height: 1.5;
    margin-bottom: 1.25rem;
}
.ds-auth-hint i { color: var(--ds-accent); margin-right: .25rem; }

/* Footer link below card */
.ds-auth-footer-link {
    text-align: center;
    margin-top: 1.25rem;
    font-size: .88rem;
    color: var(--ds-text-muted);
}
.ds-auth-footer-link a {
    color: var(--ds-accent);
    font-weight: 600;
    text-decoration: none;
}
.ds-auth-footer-link a:hover { text-decoration: underline; }

/* Theme toggle (top-right corner) */
.ds-auth-theme-toggle {
    position: absolute;
    top: 1rem; right: 1rem;
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    color: var(--ds-text-muted);
    display: grid; place-items: center;
    cursor: pointer;
    z-index: 10;
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.ds-auth-theme-toggle:hover { color: var(--ds-text); transform: scale(1.05); }
.ds-auth-theme-toggle .ds-icon-light { display: none; }
.ds-auth-theme-toggle .ds-icon-dark  { display: inline; }
[data-theme="dark"] .ds-auth-theme-toggle .ds-icon-light { display: inline; }
[data-theme="dark"] .ds-auth-theme-toggle .ds-icon-dark  { display: none; }

/* Success splash */
.ds-auth-success {
    text-align: center;
    padding: 1.5rem 1rem;
}
.ds-auth-success-icon {
    width: 80px; height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, #16a34a, #22c55e);
    color: #fff;
    display: grid; place-items: center;
    font-size: 2.4rem;
    margin: 0 auto 1rem;
    animation: ds-pop .4s var(--ds-ease-spring) both;
}
@keyframes ds-pop {
    0%   { transform: scale(0); }
    60%  { transform: scale(1.15); }
    100% { transform: scale(1); }
}
.ds-auth-success h3 { font-size: 1.4rem; font-weight: 700; margin-bottom: .5rem; }
.ds-auth-success p  { color: var(--ds-text-muted); margin-bottom: .25rem; }


/* ============================================================
   v14.1 — LAYOUT CLASSES (sidebar, topbar, main wrapper)
   Folosite în layouts/{employee,admin,manager,platform}.php
   ============================================================ */

/* ── Sidebar wrapper ──────────────────────────────────────── */
.ds-sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: var(--ds-sidebar-w, 264px);
    background: linear-gradient(180deg, #0b1224 0%, #1a2240 100%);
    color: #e8ecf7;
    display: flex;
    flex-direction: column;
    z-index: 1040;
    transition: width .25s ease, transform .25s ease;
    overflow-y: auto;
    overflow-x: hidden;
}
[data-role="employee"] .ds-sidebar { background: linear-gradient(180deg, #0d1429 0%, #1f2a52 100%); }
[data-role="admin"]    .ds-sidebar { background: linear-gradient(180deg, #0a0f24 0%, #1c2451 100%); }
[data-role="manager"]  .ds-sidebar { background: linear-gradient(180deg, #1a0e2c 0%, #3a1a5e 100%); }
[data-role="platform"] .ds-sidebar { background: linear-gradient(180deg, #2c0a1a 0%, #5e1a3a 100%); }

.ds-sidebar-header {
    padding: 1.25rem 1rem 1rem;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.ds-sidebar-header .ds-logo {
    display: flex; align-items: center; gap: .65rem;
    color: #fff; text-decoration: none;
}
.ds-sidebar-header .ds-logo-mark {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: linear-gradient(135deg, #4f46e5, #7c3aed);
    display: grid; place-items: center;
    font-size: 1.2rem;
    box-shadow: 0 4px 12px rgba(79,70,229,.4);
    flex-shrink: 0;
}
.ds-sidebar-header .ds-logo-text {
    font-weight: 700;
    font-size: 1rem;
    line-height: 1.1;
    display: flex; flex-direction: column;
}
.ds-sidebar-header .ds-logo-sub {
    font-size: .72rem;
    font-weight: 500;
    color: rgba(255,255,255,.55);
    margin-top: 2px;
}

.ds-sidebar-nav {
    flex: 1;
    padding: .75rem .65rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ds-nav-section {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(255,255,255,.42);
    padding: 1rem .85rem .35rem;
}
.ds-nav-item {
    display: flex; align-items: center; gap: .7rem;
    padding: .55rem .85rem;
    border-radius: 8px;
    color: rgba(255,255,255,.78);
    text-decoration: none;
    font-size: .9rem;
    font-weight: 500;
    transition: background .15s ease, color .15s ease;
    position: relative;
}
.ds-nav-item i { font-size: 1.05rem; width: 22px; text-align: center; flex-shrink: 0; }
.ds-nav-item span { flex: 1; }
.ds-nav-item:hover {
    background: rgba(255,255,255,.06);
    color: #fff;
}
.ds-nav-item.is-active {
    background: linear-gradient(135deg, var(--ds-accent, #4f46e5), var(--ds-accent-2, #7c3aed));
    color: #fff;
    box-shadow: 0 4px 12px rgba(79,70,229,.35);
}
.ds-nav-badge {
    background: #ef4444;
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    padding: 1px 7px;
    border-radius: 999px;
    min-width: 20px;
    text-align: center;
}
.ds-nav-item.is-active .ds-nav-badge { background: rgba(255,255,255,.25); }

.ds-sidebar-footer {
    padding: .85rem .75rem 1rem;
    border-top: 1px solid rgba(255,255,255,.08);
}
.ds-sidebar-collapse {
    width: 100%;
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.85);
    border: none;
    padding: .55rem .85rem;
    border-radius: 8px;
    font-size: .85rem;
    font-weight: 500;
    display: flex; align-items: center; gap: .5rem;
    cursor: pointer;
    transition: background .15s ease;
}
.ds-sidebar-collapse:hover { background: rgba(255,255,255,.12); color: #fff; }
.ds-sidebar-collapse i { font-size: 1rem; }

/* ── Sidebar collapsed ───────────────────────────────────── */
body.sidebar-collapsed .ds-sidebar { width: var(--ds-sidebar-w-mini, 76px); }
body.sidebar-collapsed .ds-sidebar .ds-logo-text,
body.sidebar-collapsed .ds-sidebar .ds-nav-section,
body.sidebar-collapsed .ds-nav-item span,
body.sidebar-collapsed .ds-nav-badge,
body.sidebar-collapsed .ds-sidebar-collapse span { display: none; }
body.sidebar-collapsed .ds-nav-item { justify-content: center; padding: .65rem; }
body.sidebar-collapsed .ds-sidebar-collapse { justify-content: center; padding: .55rem; }
body.sidebar-collapsed .ds-sidebar-collapse i { transform: rotate(180deg); }

/* ── Sidebar mobile backdrop ─────────────────────────────── */
.ds-sidebar-backdrop {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 1039;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
}
body.sidebar-mobile-open .ds-sidebar-backdrop {
    opacity: 1;
    pointer-events: auto;
}

@media (max-width: 991.98px) {
    .ds-sidebar {
        transform: translateX(-100%);
        width: var(--ds-sidebar-w, 264px) !important;
    }
    body.sidebar-mobile-open .ds-sidebar { transform: translateX(0); }
    body.sidebar-collapsed .ds-sidebar .ds-logo-text,
    body.sidebar-collapsed .ds-sidebar .ds-nav-section,
    body.sidebar-collapsed .ds-nav-item span,
    body.sidebar-collapsed .ds-nav-badge,
    body.sidebar-collapsed .ds-sidebar-collapse span { display: initial; }
    body.sidebar-collapsed .ds-nav-item { justify-content: flex-start; padding: .55rem .85rem; }
}

/* ── Main wrapper (zona din dreapta sidebar-ului) ────────── */
.ds-main-wrapper {
    margin-left: var(--ds-sidebar-w, 264px);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    transition: margin-left .25s ease;
    background: var(--ds-bg);
}
body.sidebar-collapsed .ds-main-wrapper {
    margin-left: var(--ds-sidebar-w-mini, 76px);
}
@media (max-width: 991.98px) {
    .ds-main-wrapper { margin-left: 0 !important; }
}

/* ── Topbar ──────────────────────────────────────────────── */
.ds-topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .9rem 1.5rem;
    background: var(--ds-bg-elev);
    border-bottom: 1px solid var(--ds-border, #e2e8f0);
    position: sticky;
    top: 0;
    z-index: 1020;
    backdrop-filter: saturate(180%) blur(8px);
}
[data-theme="dark"] .ds-topbar {
    background: rgba(19,26,44,.85);
    border-bottom-color: rgba(255,255,255,.08);
}
.ds-topbar-left {
    display: flex; align-items: center; gap: .85rem;
    flex: 1; min-width: 0;
}
.ds-topbar-right {
    display: flex; align-items: center; gap: .5rem;
}
.ds-page-title {
    display: flex; flex-direction: column;
    min-width: 0;
}
.ds-page-title h1 {
    font-size: 1.15rem;
    font-weight: 700;
    margin: 0;
    color: var(--ds-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ds-breadcrumb {
    font-size: .78rem;
    color: var(--ds-text-muted);
    margin-top: 1px;
}

/* Icon button (theme toggle, bell, sidebar toggle, etc.) */
.ds-icon-btn {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: transparent;
    border: 1px solid transparent;
    color: var(--ds-text-muted);
    display: grid; place-items: center;
    cursor: pointer;
    font-size: 1.05rem;
    transition: background .15s ease, color .15s ease, border-color .15s ease;
    position: relative;
}
.ds-icon-btn:hover {
    background: rgba(99,102,241,.08);
    color: var(--ds-accent, #4f46e5);
    border-color: rgba(99,102,241,.15);
}
[data-theme="dark"] .ds-icon-btn:hover { background: rgba(99,102,241,.15); }

.ds-sidebar-toggle { display: none; }
@media (max-width: 991.98px) { .ds-sidebar-toggle { display: grid; } }

/* Theme toggle — afișează icon contextual */
.ds-theme-toggle .ds-icon-light { display: inline-block; }
.ds-theme-toggle .ds-icon-dark  { display: none; }
[data-theme="dark"] .ds-theme-toggle .ds-icon-light { display: none; }
[data-theme="dark"] .ds-theme-toggle .ds-icon-dark  { display: inline-block; }

/* Search trigger (Ctrl+K) */
.ds-search-trigger {
    display: flex; align-items: center; gap: .55rem;
    padding: .45rem .8rem .45rem .7rem;
    background: var(--ds-bg);
    border: 1px solid var(--ds-border, #e2e8f0);
    border-radius: 10px;
    color: var(--ds-text-muted);
    font-size: .85rem;
    cursor: pointer;
    transition: border-color .15s ease, background .15s ease;
    min-width: 220px;
}
.ds-search-trigger:hover {
    border-color: var(--ds-accent, #4f46e5);
    background: var(--ds-bg-elev);
}
.ds-search-trigger .ds-search-label { flex: 1; text-align: left; }
.ds-kbd {
    background: var(--ds-bg-elev);
    border: 1px solid var(--ds-border, #e2e8f0);
    color: var(--ds-text-muted);
    font-size: .7rem;
    padding: 1px 6px;
    border-radius: 4px;
    font-family: 'SF Mono', Menlo, Consolas, monospace;
}
@media (max-width: 767.98px) {
    .ds-search-trigger .ds-search-label,
    .ds-search-trigger .ds-kbd { display: none; }
    .ds-search-trigger { min-width: auto; padding: .55rem; }
}

/* Bell dot (notificări neamcitite) */
.ds-bell-dot {
    position: absolute;
    top: 4px; right: 4px;
    background: #ef4444;
    color: #fff;
    font-size: .62rem;
    font-weight: 700;
    padding: 1px 5px;
    border-radius: 999px;
    min-width: 16px;
    line-height: 1;
    border: 2px solid var(--ds-bg-elev);
}
.ds-bell-dot.ds-bell-dot-info,
.ds-bell-dot-info {
    background: var(--ds-primary, #6366f1);
}

/* User dropdown button */
.ds-user-btn {
    display: flex; align-items: center; gap: .6rem;
    background: transparent;
    border: 1px solid transparent;
    padding: .35rem .65rem .35rem .35rem;
    border-radius: 12px;
    color: var(--ds-text);
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease;
}
.ds-user-btn:hover {
    background: var(--ds-bg);
    border-color: var(--ds-border, #e2e8f0);
}
.ds-avatar {
    width: 34px; height: 34px;
    border-radius: 10px;
    background: linear-gradient(135deg, #4f46e5, #7c3aed);
    color: #fff;
    display: grid; place-items: center;
    font-size: .82rem;
    font-weight: 700;
    flex-shrink: 0;
}
.ds-avatar-lg { width: 44px; height: 44px; font-size: 1rem; border-radius: 12px; }
.ds-avatar-employee { background: linear-gradient(135deg, #0ea5e9, #06b6d4); }
.ds-avatar-admin    { background: linear-gradient(135deg, #4f46e5, #7c3aed); }
.ds-avatar-manager  { background: linear-gradient(135deg, #8b5cf6, #ec4899); }
.ds-avatar-platform { background: linear-gradient(135deg, #ef4444, #f59e0b); }

.ds-user-meta {
    display: flex; flex-direction: column;
    line-height: 1.1;
    text-align: left;
}
.ds-user-meta small {
    font-size: .7rem;
    color: var(--ds-text-muted);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.ds-user-meta strong {
    font-size: .85rem;
    font-weight: 600;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ds-user-caret { font-size: .75rem; color: var(--ds-text-muted); }
@media (max-width: 767.98px) {
    .ds-user-btn .ds-user-meta,
    .ds-user-btn .ds-user-caret { display: none; }
}

/* User dropdown menu */
.ds-dropdown-user {
    min-width: 260px;
    padding: .35rem;
    border-radius: 14px;
    border: 1px solid var(--ds-border, #e2e8f0);
    box-shadow: var(--ds-shadow-lg);
}
.ds-user-card {
    display: flex; align-items: center; gap: .75rem;
    padding: .85rem .75rem;
}
.ds-user-card strong { display: block; font-size: .9rem; font-weight: 600; }
.ds-user-card small { font-size: .72rem; color: var(--ds-text-muted); }

/* Notif dropdown */
.ds-dropdown-notifs {
    min-width: 360px;
    max-height: 480px;
    overflow-y: auto;
    padding: 0;
    border-radius: 14px;
    border: 1px solid var(--ds-border, #e2e8f0);
    box-shadow: var(--ds-shadow-lg);
}
.ds-dropdown-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: .8rem 1rem;
    border-bottom: 1px solid var(--ds-border, #e2e8f0);
    font-weight: 600;
    font-size: .9rem;
}
.ds-dropdown-footer {
    padding: .65rem 1rem;
    border-top: 1px solid var(--ds-border, #e2e8f0);
    text-align: center;
    background: var(--ds-bg-elev-2, #f8fafc);
    border-radius: 0 0 14px 14px;
}
.ds-dropdown-footer a {
    color: var(--ds-primary, #6366f1);
    text-decoration: none;
    font-size: .85rem;
    font-weight: 500;
}
.ds-dropdown-footer a:hover { text-decoration: underline; }

/* Firm card (employee sidebar) */
.ds-firm-card {
    display: flex; flex-direction: column; gap: 2px;
    margin: .75rem 1rem;
    padding: .65rem .85rem;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 10px;
    color: rgba(255,255,255,.95);
}
.ds-firm-label {
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: rgba(255,255,255,.55);
    font-weight: 600;
}
.ds-firm-name {
    font-size: .92rem;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}
body.sidebar-collapsed .ds-firm-card { display: none; }
.ds-notif-item {
    display: flex; gap: .65rem;
    padding: .75rem 1rem;
    border-bottom: 1px solid var(--ds-border, #e2e8f0);
    text-decoration: none;
    color: var(--ds-text);
    transition: background .12s ease;
}
.ds-notif-item:hover { background: var(--ds-bg); }
.ds-notif-item.is-unread { background: rgba(79,70,229,.04); }
.ds-notif-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: transparent;
    margin-top: 6px;
    flex-shrink: 0;
}
.ds-notif-dot.is-active { background: var(--ds-accent, #4f46e5); }
.ds-notif-body { flex: 1; min-width: 0; }
.ds-notif-title { font-weight: 600; font-size: .85rem; margin-bottom: 2px; }
.ds-notif-msg   { font-size: .78rem; color: var(--ds-text-muted); margin-bottom: 3px; }
.ds-notif-time  { font-size: .7rem; color: var(--ds-text-soft); }

/* ── Page content area ───────────────────────────────────── */
.ds-page-content {
    flex: 1;
    padding: 1.5rem;
    max-width: 1600px;
    width: 100%;
    margin: 0 auto;
}
@media (max-width: 767.98px) { .ds-page-content { padding: 1rem; } }

/* ── Command palette (Ctrl+K) ────────────────────────────── */
.ds-cmdk-overlay {
    position: fixed; inset: 0;
    background: rgba(15,23,42,.5);
    backdrop-filter: blur(4px);
    z-index: 2000;
    display: grid; place-items: start center;
    padding-top: 12vh;
}
.ds-cmdk-overlay[hidden] { display: none; }
.ds-cmdk-modal {
    background: var(--ds-bg-elev);
    border-radius: 14px;
    box-shadow: var(--ds-shadow-lg);
    border: 1px solid var(--ds-border, #e2e8f0);
    width: min(560px, 92vw);
    max-height: 70vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.ds-cmdk-input-wrap {
    display: flex; align-items: center; gap: .65rem;
    padding: .85rem 1rem;
    border-bottom: 1px solid var(--ds-border, #e2e8f0);
}
.ds-cmdk-input-wrap i { color: var(--ds-text-muted); font-size: 1.1rem; }
.ds-cmdk-input-wrap input {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-size: 1rem;
    color: var(--ds-text);
}
.ds-cmdk-list {
    list-style: none;
    margin: 0; padding: .35rem;
    overflow-y: auto;
}
.ds-cmdk-list li {
    display: flex; align-items: center; gap: .65rem;
    padding: .65rem .85rem;
    border-radius: 8px;
    cursor: pointer;
    color: var(--ds-text);
    font-size: .9rem;
    transition: background .1s ease;
}
.ds-cmdk-list li:hover,
.ds-cmdk-list li.is-active {
    background: rgba(99,102,241,.1);
    color: var(--ds-accent, #4f46e5);
}
.ds-cmdk-list li i { font-size: 1rem; width: 22px; text-align: center; }

/* ── Empty state ─────────────────────────────────────────── */
.ds-empty-state {
    text-align: center;
    padding: 2rem 1rem;
    color: var(--ds-text-muted);
}
.ds-empty-state i {
    font-size: 2rem;
    color: var(--ds-text-soft);
    display: block;
    margin-bottom: .5rem;
}
.ds-empty-state p { margin: 0; font-size: .85rem; }

/* ── Stagger animation pentru sidebar items ──────────────── */
.ds-stagger > * {
    opacity: 0;
    transform: translateX(-8px);
    animation: ds-stagger-in .35s var(--ds-ease, ease-out) forwards;
}
.ds-stagger > *:nth-child(1)  { animation-delay: .03s; }
.ds-stagger > *:nth-child(2)  { animation-delay: .06s; }
.ds-stagger > *:nth-child(3)  { animation-delay: .09s; }
.ds-stagger > *:nth-child(4)  { animation-delay: .12s; }
.ds-stagger > *:nth-child(5)  { animation-delay: .15s; }
.ds-stagger > *:nth-child(6)  { animation-delay: .18s; }
.ds-stagger > *:nth-child(7)  { animation-delay: .21s; }
.ds-stagger > *:nth-child(8)  { animation-delay: .24s; }
.ds-stagger > *:nth-child(9)  { animation-delay: .27s; }
.ds-stagger > *:nth-child(10) { animation-delay: .30s; }
@keyframes ds-stagger-in {
    to { opacity: 1; transform: translateX(0); }
}

/* ============================================================
   v15.1 — HIDDEN WIDGETS PANEL (auto-vizibil)
   ============================================================ */
.ds-widget-hidden-list {
    margin-top: 1.25rem;
    padding: .85rem 1rem;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-md);
    box-shadow: var(--ds-shadow-sm);
    transition: border-color var(--ds-dur) var(--ds-ease),
                background var(--ds-dur) var(--ds-ease),
                box-shadow var(--ds-dur) var(--ds-ease);
}
.ds-widget-hidden-list[hidden] { display: block !important; }
.ds-widget-hidden-list.is-empty {
    opacity: .65;
    background: transparent;
    border-style: dashed;
}
.ds-widget-hidden-list.is-flash {
    border-color: var(--ds-accent);
    box-shadow: 0 0 0 4px rgba(99,102,241,.18);
}
.ds-widget-hidden-head {
    display: flex; align-items: center; gap: .5rem;
    margin-bottom: .65rem;
    color: var(--ds-text);
    font-size: .9rem;
}
.ds-widget-hidden-head strong { font-weight: 600; }
.ds-widget-hidden-grid {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}
.ds-widget-hidden-list.is-empty .ds-widget-hidden-grid em {
    color: var(--ds-text-muted);
    font-style: italic;
    font-size: .85rem;
}

/* Chip-uri restorabile */
.ds-widget-chip {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .4rem .75rem;
    border: 1px solid var(--ds-border);
    background: var(--ds-surface-2);
    color: var(--ds-text);
    border-radius: 999px;
    font-size: .82rem;
    cursor: pointer;
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.ds-widget-chip:hover {
    background: var(--ds-accent);
    color: #fff;
    border-color: var(--ds-accent);
    transform: translateY(-1px);
    box-shadow: var(--ds-shadow-md);
}
.ds-widget-chip i { font-size: .95rem; }

/* ============================================================
   v15.1 — DRAG HANDLE BAR (cu text "Trage")
   ============================================================ */
.ds-widget > .ds-widget-handle {
    width: auto !important;
    height: auto !important;
    padding: 2px 8px;
    background: var(--ds-surface-2);
    border: 1px solid var(--ds-border);
    border-radius: 999px;
    font-size: .68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--ds-text-muted);
    gap: .25rem;
}
.ds-widget > .ds-widget-handle i { font-size: .85rem; }
.ds-widget > .ds-widget-handle span { line-height: 1; }

/* ============================================================
   v15.1 — COMMAND PALETTE — group headers + empty state
   ============================================================ */
.ds-cmdk-list .ds-cmdk-group {
    padding: .55rem .85rem .25rem;
    font-size: .68rem !important;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: var(--ds-text-soft);
    cursor: default !important;
    background: transparent !important;
    pointer-events: none;
}
.ds-cmdk-list .ds-cmdk-group:hover { background: transparent !important; color: var(--ds-text-soft) !important; }
.ds-cmdk-list .ds-cmdk-empty {
    text-align: center;
    color: var(--ds-text-muted);
    font-style: italic;
    padding: 1.25rem !important;
    cursor: default !important;
    background: transparent !important;
}
.ds-cmdk-list .ds-cmdk-empty:hover { background: transparent !important; color: var(--ds-text-muted) !important; }
.ds-cmdk-list .ds-cmdk-item span { flex: 1; }

/* ============================================================
   v15.1 — Widget actions bar — show on hover/edit, full opacity
   ============================================================ */
.ds-widget > .ds-widget-actions { padding: 3px; gap: 2px; }
.ds-widget-resize { width: 30px; height: 28px; }
.ds-widget-hide { width: 30px; height: 28px; margin-left: 2px; border-left: 1px solid var(--ds-border-soft); border-radius: 0 6px 6px 0; padding-left: 4px; }

/* Buton "Personalizează" mai vizibil */
#widgetEditToggle {
    background: linear-gradient(90deg, var(--ds-accent), var(--ds-accent-2));
    color: #fff !important;
    border: none !important;
    font-weight: 600;
    box-shadow: 0 2px 6px rgba(99,102,241,.3);
    transition: all .2s ease;
}
#widgetEditToggle:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(99,102,241,.4);
    color: #fff !important;
}
#widgetEditToggle.is-active {
    background: linear-gradient(90deg, #16a34a, #22c55e);
    box-shadow: 0 2px 6px rgba(34,197,94,.3);
}
#widgetEditToggle.is-active:hover {
    box-shadow: 0 4px 12px rgba(34,197,94,.4);
}

/* În edit mode, panel hidden devine inutil — ascunde-l (folosim overlay în grid) */
body.is-widget-editing #widgetHiddenList { display: none !important; }

/* Tip-tap edit hint pe widgets în edit mode */
body.is-widget-editing .ds-widget { cursor: move; }
body.is-widget-editing .ds-widget:hover { box-shadow: var(--ds-shadow-md); }

/* ============================================================
   v15.2 — LIST CARDS (Cereri recente etc.)
   ============================================================ */
.ds-list-cards {
    list-style: none;
    margin: 0; padding: .5rem;
}
.ds-list-cards > li {
    margin-bottom: .35rem;
}
.ds-list-cards > li:last-child { margin-bottom: 0; }

.ds-list-card {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .65rem .85rem;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border-soft);
    border-radius: var(--ds-radius-md);
    transition: all var(--ds-dur-fast) var(--ds-ease);
}
.ds-list-card:hover {
    background: var(--ds-surface-2);
    border-color: var(--ds-border);
    transform: translateY(-1px);
    box-shadow: var(--ds-shadow-sm);
}
.ds-list-card-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
    color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}
.ds-list-card-body {
    flex: 1;
    min-width: 0;
    display: flex; flex-direction: column; gap: 2px;
}
.ds-list-card-body strong {
    font-weight: 600;
    font-size: .92rem;
    color: var(--ds-text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ds-list-card-body small {
    color: var(--ds-text-muted);
    font-size: .78rem;
}

/* ============================================================
   v15.2 — QUICK LINKS GRID (Acțiuni rapide)
   ============================================================ */
.ds-quicklinks {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: .75rem;
    padding: 1rem;
}
.ds-quicklink {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    padding: 1rem;
    border-radius: var(--ds-radius-md);
    color: #fff !important;
    text-decoration: none !important;
    transition: all var(--ds-dur) var(--ds-ease);
    box-shadow: var(--ds-shadow-sm);
    min-height: 110px;
    position: relative;
    overflow: hidden;
}
.ds-quicklink:hover {
    transform: translateY(-3px);
    box-shadow: var(--ds-shadow-lg);
}
.ds-quicklink::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0) 50%, rgba(255,255,255,.18) 100%);
    pointer-events: none;
    border-radius: inherit;
}
.ds-quicklink i {
    font-size: 1.5rem;
    margin-bottom: .25rem;
    opacity: .95;
}
.ds-quicklink strong {
    font-size: .95rem;
    font-weight: 600;
}
.ds-quicklink small {
    font-size: .75rem;
    opacity: .85;
    line-height: 1.3;
}
.ds-quicklink-orange  { background: linear-gradient(135deg, #f97316, #ea580c); }
.ds-quicklink-blue    { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.ds-quicklink-green   { background: linear-gradient(135deg, #22c55e, #16a34a); }
.ds-quicklink-purple  { background: linear-gradient(135deg, #a855f7, #9333ea); }
.ds-quicklink-pink    { background: linear-gradient(135deg, #ec4899, #db2777); }
.ds-quicklink-indigo  { background: linear-gradient(135deg, #6366f1, #4f46e5); }
.ds-quicklink-teal    { background: linear-gradient(135deg, #14b8a6, #0d9488); }
.ds-quicklink-red     { background: linear-gradient(135deg, #ef4444, #dc2626); }

/* ============================================================
   v15.2 — Stiluri pentru pagina /admin/employee-profile
   (mutate din inline <style> ca să folosească teme & dark mode)
   ============================================================ */
.profile-avatar {
    width: 110px; height: 110px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 42px; font-weight: 700;
    box-shadow: 0 4px 15px rgba(102,126,234,0.3);
}
.stat-card {
    background: var(--ds-surface);
    border-radius: 12px;
    padding: 1rem;
    text-align: center;
    border: 1px solid var(--ds-border);
    transition: box-shadow .2s;
    color: var(--ds-text);
}
.stat-card:hover { box-shadow: var(--ds-shadow-md); }
.stat-value { font-size: 1.5rem; font-weight: 700; color: var(--ds-text); }
.stat-label { font-size: .78rem; color: var(--ds-text-muted); }

.nav-tabs .nav-link { font-size: .88rem; padding: .65rem 1rem; }
.nav-tabs .nav-link.active { font-weight: 600; }

.info-row { padding: .5rem 0; border-bottom: 1px solid var(--ds-border-soft); }
.info-row:last-child { border-bottom: none; }
.info-label { font-size: .78rem; color: var(--ds-text-soft); margin-bottom: 2px; }
.info-value { font-size: .92rem; font-weight: 500; color: var(--ds-text); }

.legal-article-card {
    border-left: 4px solid #4dabf7;
    background: var(--ds-surface-2);
    border-radius: 0 8px 8px 0;
    padding: 1rem 1.25rem;
    margin-bottom: .75rem;
}
.legal-article-card.art-danger  { border-left-color: #fa5252; }
.legal-article-card.art-warning { border-left-color: #fab005; }
.legal-article-card.art-success { border-left-color: #40c057; }
.legal-article-card.art-info    { border-left-color: #4dabf7; }
.legal-article-card h6 { font-size: .9rem; margin-bottom: .5rem; color: var(--ds-text); }
.legal-article-card ul { margin-bottom: 0; padding-left: 1.25rem; }
.legal-article-card li { font-size: .82rem; margin-bottom: .25rem; color: var(--ds-text-muted); }

.revisal-warning {
    background: rgba(239,68,68,.08);
    border: 2px solid #ef4444;
    border-radius: 10px;
    padding: 1rem 1.25rem;
    color: #c92a2a;
    font-weight: 600;
}
[data-theme="dark"] .revisal-warning { background: rgba(239,68,68,.15); color: #fca5a5; }
.revisal-warning i { font-size: 1.2rem; }

.procedure-step {
    display: flex; gap: 1rem;
    padding: .75rem 0;
    border-bottom: 1px solid var(--ds-border-soft);
}
.procedure-step:last-child { border-bottom: none; }
.step-number {
    width: 32px; height: 32px; min-width: 32px;
    background: linear-gradient(135deg, #667eea, #764ba2);
    color: #fff; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: .85rem;
}

.suspension-type-card {
    cursor: pointer;
    border: 2px solid var(--ds-border);
    border-radius: 10px;
    padding: .75rem 1rem;
    transition: all .2s;
    background: var(--ds-surface);
    color: var(--ds-text);
}
.suspension-type-card:hover { border-color: var(--ds-accent); background: var(--ds-surface-2); }
.suspension-type-card.selected { border-color: var(--ds-accent); background: rgba(99,102,241,.08); }

/* ============================================================
   v15.3 — STAT GRID + COLOR MODIFIERS (FIX cropping pe stat cards)
   ============================================================ */
.ds-stat-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: .75rem;
    padding: 1rem;
}
@media (min-width: 1200px) {
    .ds-stat-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 575.98px) {
    .ds-stat-grid { grid-template-columns: 1fr; }
}

.ds-stat-body {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    gap: .25rem;
    padding-right: 56px;  /* loc pentru icon */
}

/* Color modifiers (single-hyphen) — folosite în view-uri */
.ds-stat-primary,
.ds-stat--indigo {
    --ds-stat-tint: rgba(79,70,229,.1);
    --ds-stat-icon-bg: rgba(79,70,229,.12);
    --ds-stat-icon-color: #4f46e5;
}
.ds-stat-success,
.ds-stat--emerald {
    --ds-stat-tint: rgba(16,185,129,.1);
    --ds-stat-icon-bg: rgba(16,185,129,.14);
    --ds-stat-icon-color: #10b981;
}
.ds-stat-warning,
.ds-stat--amber {
    --ds-stat-tint: rgba(245,158,11,.1);
    --ds-stat-icon-bg: rgba(245,158,11,.16);
    --ds-stat-icon-color: #f59e0b;
}
.ds-stat-info,
.ds-stat--cyan {
    --ds-stat-tint: rgba(6,182,212,.1);
    --ds-stat-icon-bg: rgba(6,182,212,.14);
    --ds-stat-icon-color: #06b6d4;
}
.ds-stat-danger,
.ds-stat--rose {
    --ds-stat-tint: rgba(244,63,94,.1);
    --ds-stat-icon-bg: rgba(244,63,94,.14);
    --ds-stat-icon-color: #f43f5e;
}
.ds-stat--violet {
    --ds-stat-tint: rgba(139,92,246,.1);
    --ds-stat-icon-bg: rgba(139,92,246,.14);
    --ds-stat-icon-color: #8b5cf6;
}
.ds-stat--pink {
    --ds-stat-tint: rgba(236,72,153,.1);
    --ds-stat-icon-bg: rgba(236,72,153,.14);
    --ds-stat-icon-color: #ec4899;
}

a.ds-stat { text-decoration: none; color: inherit; }
a.ds-stat:hover { color: inherit; }

/* ============================================================
   v15.3 — SIDEBAR EXPAND BUTTON (collapsed state)
   ============================================================ */
.ds-sidebar-expand-btn {
    position: absolute;
    top: 18px;
    right: -14px;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    box-shadow: var(--ds-shadow-md);
    color: var(--ds-text);
    display: none;
    align-items: center; justify-content: center;
    cursor: pointer;
    z-index: 1100;
    transition: all var(--ds-dur) var(--ds-ease-spring, cubic-bezier(.34,1.56,.64,1));
}
.ds-sidebar-expand-btn:hover {
    background: var(--ds-accent);
    color: #fff;
    border-color: var(--ds-accent);
    transform: scale(1.1);
}
body.sidebar-collapsed .ds-sidebar-expand-btn { display: inline-flex; }
@media (max-width: 991.98px) {
    .ds-sidebar-expand-btn { display: none !important; }
}

/* Tooltip-uri pe iconițe sidebar collapsed (S3) */
body.sidebar-collapsed .ds-sidebar .ds-nav-item {
    position: relative;
}
body.sidebar-collapsed .ds-sidebar .ds-nav-item::after {
    content: attr(data-tooltip);
    position: absolute;
    left: calc(100% + 14px);
    top: 50%;
    transform: translateY(-50%);
    background: var(--ds-text);
    color: var(--ds-bg);
    padding: 4px 10px;
    border-radius: 6px;
    font-size: .78rem;
    white-space: nowrap;
    box-shadow: var(--ds-shadow-md);
    opacity: 0;
    pointer-events: none;
    transition: opacity .15s ease;
    z-index: 1200;
}
body.sidebar-collapsed .ds-sidebar .ds-nav-item:hover::after { opacity: 1; }

/* ============================================================
   v15.3 — TOPBAR — reduce înălțimea ca să nu acopere conținutul (S4)
   ============================================================ */
:root { --ds-topbar-h: 60px; }
.ds-page-content { padding-top: 1.25rem; }

/* ============================================================
   v15.3 — REDESIGN CLOCK WIDGET (ceas mare, In/Out, progres) (I3A)
   ============================================================ */
.ds-clock-card {
    padding: 1.5rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
}
.ds-clock-time {
    font-size: 4rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -.04em;
    color: var(--ds-text);
    background: linear-gradient(135deg, var(--ds-accent), var(--ds-accent-2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-variant-numeric: tabular-nums;
    margin-bottom: -.25rem;
}
.ds-clock-date {
    font-size: .85rem;
    color: var(--ds-text-muted);
    text-transform: capitalize;
}
.ds-clock-status {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
}
.ds-clock-status .ds-chip {
    padding: .45rem .85rem;
    border-radius: 999px;
    font-size: .82rem;
    font-weight: 500;
    display: inline-flex; align-items: center; gap: .35rem;
    border: 1px solid var(--ds-border);
    background: var(--ds-surface);
}
.ds-clock-card form { width: 100%; }
.ds-clock-total {
    width: 100%;
    padding: .85rem 1rem;
    background: linear-gradient(135deg, rgba(16,185,129,.08), rgba(16,185,129,.02));
    border: 1px solid rgba(16,185,129,.18);
    border-radius: var(--ds-radius-md);
    display: flex; align-items: baseline; justify-content: center; gap: .5rem;
}
.ds-clock-total strong {
    font-size: 2rem;
    font-weight: 800;
    color: #16a34a;
    font-variant-numeric: tabular-nums;
    line-height: 1;
}
.ds-clock-total span {
    color: var(--ds-text-muted);
    font-size: .85rem;
}
[data-theme="dark"] .ds-clock-total strong { color: #4ade80; }

/* ============================================================
   v15.3 — QUICK LINKS — culori auto cu nth-child (manager + altele)
   ============================================================ */
.ds-quicklinks .ds-quicklink:not([class*="ds-quicklink-"]):nth-child(6n+1) { background: linear-gradient(135deg, #f97316, #ea580c); }
.ds-quicklinks .ds-quicklink:not([class*="ds-quicklink-"]):nth-child(6n+2) { background: linear-gradient(135deg, #3b82f6, #2563eb); }
.ds-quicklinks .ds-quicklink:not([class*="ds-quicklink-"]):nth-child(6n+3) { background: linear-gradient(135deg, #22c55e, #16a34a); }
.ds-quicklinks .ds-quicklink:not([class*="ds-quicklink-"]):nth-child(6n+4) { background: linear-gradient(135deg, #a855f7, #9333ea); }
.ds-quicklinks .ds-quicklink:not([class*="ds-quicklink-"]):nth-child(6n+5) { background: linear-gradient(135deg, #ec4899, #db2777); }
.ds-quicklinks .ds-quicklink:not([class*="ds-quicklink-"]):nth-child(6n)   { background: linear-gradient(135deg, #6366f1, #4f46e5); }

/* ============================================================
   v15.3 — HERO ÎN CONCEDIU — fundal portocaliu (S5)
   ============================================================ */
.ds-hero.is-on-leave,
.ds-widget[data-on-leave="1"] .ds-hero {
    background: linear-gradient(135deg, #f97316, #c2410c) !important;
}

/* ============================================================
   v15.3 — Command Palette — group result type + meta
   ============================================================ */
.ds-cmdk-list .ds-cmdk-item .ds-cmdk-meta {
    margin-left: auto;
    font-size: .72rem;
    color: var(--ds-text-soft);
    background: var(--ds-surface-2);
    padding: 1px 8px;
    border-radius: 999px;
    flex-shrink: 0;
}
.ds-cmdk-loading {
    text-align: center;
    color: var(--ds-text-muted);
    padding: 1rem !important;
    font-style: italic;
    cursor: default !important;
}
.ds-cmdk-loading:hover { background: transparent !important; color: var(--ds-text-muted) !important; }
