/* ============================================================
   SoftUp — Premium Design Enhancement Layer v2.0
   Layered safely on top of app.css + animations.css
   Zero functionality impact — pure visual enhancement
   ============================================================

   TABLE OF CONTENTS
   01. CSS Variable Upgrades & Module Color Palette
   02. Body & Background
   03. Typography Refinements
   04. Sidebar — Premium Edition
   05. Topbar — Premium Edition
   06. Stat Cards — Premium Edition
   07. Cards & Surfaces — Premium Edition
   08. Tables — Premium Edition
   09. Buttons — Premium Edition
   10. Forms & Inputs — Premium Edition
   11. Flash Messages / Toasts
   12. Empty States
   13. Badges & Chips
   14. Pagination
   15. Progress Bars — Gradient & Animated
   16. Module Color System
   17. Quick Links
   18. AI FAB & Timer Chip
   19. Premium Utility Classes
   20. Dark Mode Enhancements
   21. Micro-interactions & Polish
   22. Responsive Refinements
   ============================================================ */

/* ── 01. CSS Variable Upgrades ─────────────────────────────── */
:root {
    /* Enhanced shadows */
    --su-shadow-2xs:  0 1px 2px rgba(0,0,0,.04);
    --su-shadow-card: 0 2px 8px rgba(0,0,0,.06), 0 0 0 1px rgba(0,0,0,.04);
    --su-shadow-float: 0 8px 32px rgba(124,58,237,.12), 0 2px 8px rgba(0,0,0,.06);

    /* Gradient library */
    --su-grad-primary: linear-gradient(135deg, #7c3aed 0%, #9333ea 50%, #a855f7 100%);
    --su-grad-primary-soft: linear-gradient(135deg, #ede9fe 0%, #f3e8ff 100%);
    --su-grad-success: linear-gradient(135deg, #059669 0%, #10b981 100%);
    --su-grad-danger:  linear-gradient(135deg, #dc2626 0%, #ef4444 100%);
    --su-grad-warning: linear-gradient(135deg, #d97706 0%, #f59e0b 100%);
    --su-grad-info:    linear-gradient(135deg, #2563eb 0%, #3b82f6 100%);

    /* Module Colors */
    --su-clr-tasks:       #7c3aed;
    --su-clr-goals:       #d97706;
    --su-clr-docs:        #2563eb;
    --su-clr-chat:        #16a34a;
    --su-clr-clients:     #0891b2;
    --su-clr-time:        #c2410c;
    --su-clr-automation:  #db2777;
    --su-clr-analytics:   #6366f1;
    --su-clr-sprints:     #7c3aed;
    --su-clr-cost:        #ca8a04;
    --su-clr-invoices:    #0d9488;
    --su-clr-settings:    #475569;
    --su-clr-members:     #0284c7;
    --su-clr-integrations:#6366f1;

    /* Surface tokens */
    --su-glass:      rgba(255,255,255,.72);
    --su-glass-dark: rgba(15,14,20,.72);
    --su-frost:      rgba(255,255,255,.5);

    /* Sidebar premium */
    --su-sidebar-w: 256px;
}

/* ── 02. Body & Background ─────────────────────────────────── */
body {
    background: #f4f3f8;
    background-image:
        radial-gradient(circle at 20% 10%, rgba(124,58,237,.04) 0%, transparent 50%),
        radial-gradient(circle at 80% 90%, rgba(59,130,246,.03) 0%, transparent 40%);
}

/* ── 03. Typography Refinements ─────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-feature-settings: "cv02","cv03","cv04","cv11";
    letter-spacing: -0.01em;
}

.su-page-title {
    font-size: 19px !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em;
    color: var(--su-text);
}

/* Section labels — uppercase group headings */
.su-section-label {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--su-text-light);
    padding: 0 4px;
}

/* Gradient text utility */
.su-gradient-text {
    background: var(--su-grad-primary);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── 04. Sidebar — Premium Edition ─────────────────────────── */
.su-sidebar {
    background: linear-gradient(180deg,
        #ffffff 0%,
        #fdfcff 60%,
        #faf8ff 100%) !important;
    border-right: 1px solid rgba(124,58,237,.08) !important;
    box-shadow: 2px 0 24px rgba(124,58,237,.04) !important;
}

/* Sidebar header — premium workspace switcher.
   NOTE: `backdrop-filter` removed intentionally. It creates a containing
   block for position:fixed descendants, which would scope the workspace
   switcher dropdown to this header instead of the viewport — and that
   defeated z-index for years, causing nav-item bleed-through. */
.su-sidebar-header {
    padding: 14px 12px 12px;
    background: linear-gradient(135deg,
        rgba(124,58,237,.06) 0%,
        rgba(124,58,237,.02) 100%);
    border-bottom: 1px solid rgba(124,58,237,.08);
}

/* WS avatar glow */
.su-ws-avatar {
    box-shadow: 0 2px 8px rgba(124,58,237,.3);
    transition: transform .2s ease, box-shadow .2s ease;
}
.su-ws-btn:hover .su-ws-avatar {
    transform: scale(1.05);
    box-shadow: 0 4px 12px rgba(124,58,237,.4);
}

.su-ws-name {
    font-size: 13.5px;
    font-weight: 600;
    background: linear-gradient(135deg, var(--su-text), #7c3aed);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Nav group headers — more visual */
.su-nav-group-header {
    font-size: 9.5px !important;
    letter-spacing: .1em !important;
    font-weight: 700 !important;
    color: var(--su-text-light) !important;
    margin-top: 18px !important;
    margin-bottom: 4px !important;
    padding: 0 12px !important;
    display: flex;
    align-items: center;
    gap: 8px;
}
.su-nav-group-header::after {
    content: '';
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, var(--su-border) 0%, transparent 100%);
    border-radius: 1px;
}

/* Nav item — premium active + hover */
.su-nav-item {
    border-radius: 9px !important;
    margin-bottom: 1px;
    transition:
        background .15s ease,
        color .15s ease,
        transform .1s ease,
        box-shadow .15s ease !important;
}

.su-nav-item:hover:not(.active) {
    background: rgba(124,58,237,.06) !important;
    color: #7c3aed !important;
    transform: translateX(1px);
}

.su-nav-item.active {
    background: linear-gradient(135deg,
        rgba(124,58,237,.14) 0%,
        rgba(124,58,237,.07) 100%) !important;
    color: #7c3aed !important;
    font-weight: 600 !important;
    box-shadow: 0 2px 8px rgba(124,58,237,.12) !important;
}

/* Active left bar — thicker and glowing */
.su-nav-item.active::before {
    content: '';
    position: absolute;
    left: 0; top: 8%; bottom: 8%;
    width: 3px;
    background: linear-gradient(180deg, #7c3aed, #a855f7);
    border-radius: 0 3px 3px 0;
    box-shadow: 1px 0 6px rgba(124,58,237,.5);
}

/* Nav item icons */
.su-nav-item i:first-child {
    width: 20px;
    text-align: center;
    font-size: 15px;
    flex-shrink: 0;
    transition: transform .15s ease;
}
.su-nav-item:hover i:first-child { transform: scale(1.1); }
.su-nav-item.active i:first-child { color: #7c3aed; }

/* Sidebar toggle button */
.su-sidebar-toggle {
    background: rgba(124,58,237,.06) !important;
    border-radius: 8px !important;
    transition: all .15s ease !important;
}
.su-sidebar-toggle:hover {
    background: rgba(124,58,237,.14) !important;
    color: #7c3aed !important;
    transform: scale(1.05);
}

/* Sidebar footer — glassy */
.su-sidebar-footer {
    background: linear-gradient(0deg,
        rgba(124,58,237,.04) 0%,
        transparent 100%);
    border-top: 1px solid rgba(124,58,237,.08) !important;
}

/* Nav user in footer */
.su-nav-user {
    border-radius: 10px !important;
    transition: background .15s ease, transform .1s ease !important;
}
.su-nav-user:hover {
    background: rgba(124,58,237,.07) !important;
    transform: translateX(1px);
}

/* User avatar glow */
.su-user-avatar {
    box-shadow: 0 0 0 2px #fff, 0 0 0 3.5px rgba(124,58,237,.3);
    transition: box-shadow .2s ease;
}
.su-nav-user:hover .su-user-avatar {
    box-shadow: 0 0 0 2px #fff, 0 0 0 3.5px rgba(124,58,237,.5);
}

/* Space item accent */
.su-nav-item--space {
    font-weight: 600 !important;
    font-size: 13px !important;
}

/* Sidebar nav scrollbar */
.su-sidebar-nav {
    scrollbar-width: thin;
    scrollbar-color: rgba(124,58,237,.2) transparent;
}
.su-sidebar-nav::-webkit-scrollbar-thumb {
    background: rgba(124,58,237,.2) !important;
    border-radius: 4px !important;
}

/* WS dropdown — premium.
   `backdrop-filter` removed: with the opaque white background the blur is
   invisible anyway, and keeping it adds an unnecessary stacking context. */
.su-ws-dropdown {
    border: 1px solid rgba(124,58,237,.12) !important;
    box-shadow: 0 8px 32px rgba(124,58,237,.1), 0 2px 8px rgba(0,0,0,.08) !important;
    border-radius: 14px !important;
}
.su-ws-item {
    border-radius: 8px !important;
    transition: background .12s ease, transform .1s ease !important;
}
.su-ws-item:hover {
    background: rgba(124,58,237,.08) !important;
    transform: translateX(2px);
}
.su-ws-item.active {
    background: linear-gradient(135deg, rgba(124,58,237,.14), rgba(124,58,237,.07)) !important;
}

/* ── 05. Topbar — Premium Edition ──────────────────────────── */
.su-topbar {
    background: rgba(255,255,255,.92) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-bottom: 1px solid rgba(124,58,237,.08) !important;
    box-shadow: 0 1px 0 rgba(124,58,237,.06), 0 2px 16px rgba(0,0,0,.04) !important;
}

/* Page title in topbar */
.su-page-title {
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: color .15s ease;
}

/* Search bar — premium */
.su-search-input-wrap {
    background: rgba(244,243,248,.8) !important;
    border: 1.5px solid rgba(124,58,237,.12) !important;
    border-radius: 12px !important;
    transition: all .2s ease !important;
    backdrop-filter: blur(8px);
}
.su-search-input-wrap:focus-within {
    background: #fff !important;
    border-color: #7c3aed !important;
    box-shadow: 0 0 0 4px rgba(124,58,237,.1), 0 4px 16px rgba(124,58,237,.08) !important;
}
.su-search-input {
    font-size: 13.5px !important;
    font-weight: 500;
}
.su-search-icon {
    color: rgba(124,58,237,.5) !important;
    font-size: 14px !important;
}

/* Search results dropdown */
.su-search-results {
    border: 1px solid rgba(124,58,237,.12) !important;
    border-radius: 14px !important;
    box-shadow: 0 12px 40px rgba(0,0,0,.12), 0 4px 16px rgba(124,58,237,.08) !important;
    overflow: hidden !important;
    backdrop-filter: blur(20px);
}
.su-search-result {
    border-radius: 0 !important;
    transition: background .1s ease, transform .1s ease !important;
}
.su-search-result:hover {
    background: rgba(124,58,237,.06) !important;
    transform: none;
}
.su-search-result-icon {
    background: linear-gradient(135deg, rgba(124,58,237,.1), rgba(168,85,247,.08)) !important;
    border-radius: 9px !important;
    color: #7c3aed;
}

/* Icon buttons in topbar */
.su-btn-icon {
    border-radius: 10px !important;
    transition: all .15s ease !important;
    position: relative;
}
.su-btn-icon:hover {
    background: rgba(124,58,237,.08) !important;
    color: #7c3aed !important;
    transform: scale(1.05) !important;
}
.su-btn-icon:active { transform: scale(.95) !important; }

/* Notification badge — pulsing */
.su-notif-count {
    background: linear-gradient(135deg, #ef4444, #f87171) !important;
    box-shadow: 0 0 0 2px #fff, 0 0 8px rgba(239,68,68,.4) !important;
    animation: su-notif-pulse 2.5s infinite !important;
    border: none !important;
}
@keyframes su-notif-pulse {
    0%, 100% { box-shadow: 0 0 0 2px #fff, 0 0 0 0 rgba(239,68,68,.4); }
    50%       { box-shadow: 0 0 0 2px #fff, 0 0 8px rgba(239,68,68,.35); }
}

/* Notification panel */
.su-notif-panel {
    border: 1px solid rgba(124,58,237,.1) !important;
    border-radius: 18px !important;
    box-shadow: 0 12px 48px rgba(0,0,0,.14), 0 4px 16px rgba(124,58,237,.08) !important;
    backdrop-filter: blur(20px);
    overflow: hidden !important;
}
.su-notif-header {
    background: linear-gradient(135deg,
        rgba(124,58,237,.06) 0%,
        rgba(124,58,237,.02) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.08) !important;
}
.su-notif-icon {
    background: linear-gradient(135deg, #ede9fe, #f3e8ff) !important;
    box-shadow: 0 2px 8px rgba(124,58,237,.2) !important;
    font-size: 13px !important;
    border-radius: 10px !important;
}
.su-notif-item {
    transition: background .12s ease !important;
    border-bottom: 1px solid rgba(124,58,237,.06) !important;
}
.su-notif-item:hover { background: rgba(124,58,237,.04) !important; }
.su-notif-item.unread {
    background: linear-gradient(135deg,
        rgba(124,58,237,.05) 0%,
        rgba(124,58,237,.02) 100%) !important;
    border-left: 3px solid #7c3aed;
}

/* User dropdown */
.su-user-dropdown {
    border: 1px solid rgba(124,58,237,.1) !important;
    border-radius: 18px !important;
    box-shadow: 0 12px 48px rgba(0,0,0,.14), 0 4px 16px rgba(124,58,237,.08) !important;
    backdrop-filter: blur(20px);
    overflow: hidden !important;
}
.su-user-info {
    background: linear-gradient(135deg,
        rgba(124,58,237,.06) 0%,
        rgba(124,58,237,.02) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.08) !important;
    padding: 12px 14px 10px !important;
}
.su-dropdown-item {
    border-radius: 9px !important;
    transition: all .12s ease !important;
    margin: 1px 4px;
}
.su-dropdown-item:hover {
    background: rgba(124,58,237,.08) !important;
    color: #7c3aed !important;
    transform: translateX(2px);
}
.su-dropdown-item--danger:hover {
    background: rgba(239,68,68,.07) !important;
    transform: translateX(2px);
}

/* User button */
.su-user-btn {
    transition: transform .15s ease, box-shadow .15s ease !important;
}
.su-user-btn:hover {
    box-shadow: 0 0 0 3px rgba(124,58,237,.2) !important;
    transform: scale(1.04);
}

/* Topbar avatar ring */
.su-topbar-avatar {
    box-shadow: 0 0 0 2px rgba(124,58,237,.3);
    transition: box-shadow .2s ease;
}
.su-user-btn:hover .su-topbar-avatar {
    box-shadow: 0 0 0 2px rgba(124,58,237,.5);
}

/* Trial pill */
.su-trial-pill {
    border-radius: 999px !important;
    font-weight: 600 !important;
    font-size: 11.5px !important;
    letter-spacing: .01em;
    box-shadow: 0 2px 8px rgba(0,0,0,.08);
    transition: all .2s ease !important;
}
.su-trial-pill:hover { transform: translateY(-1px) !important; box-shadow: 0 4px 12px rgba(0,0,0,.12) !important; }

/* ── 06. Stat Cards — Premium Edition ──────────────────────── */
.su-stat-card {
    border-radius: 18px !important;
    padding: 24px !important;
    border: 1px solid rgba(0,0,0,.05) !important;
    box-shadow: var(--su-shadow-card) !important;
    transition: transform .2s ease, box-shadow .2s ease !important;
    background: #fff !important;
    overflow: hidden;
    position: relative;
}
.su-stat-card:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 12px 32px rgba(124,58,237,.12), 0 4px 12px rgba(0,0,0,.06) !important;
}

/* Decorative background glow */
.su-stat-card::before {
    content: '';
    position: absolute;
    top: -30%; right: -10%;
    width: 120px; height: 120px;
    border-radius: 50%;
    opacity: .06;
    pointer-events: none;
    background: #7c3aed;
}
.su-stat-card--success::before { background: #10b981; }
.su-stat-card--danger::before  { background: #ef4444; }
.su-stat-card--info::before    { background: #3b82f6; }

/* Top accent bar */
.su-stat-card::after {
    height: 4px !important;
    border-radius: 18px 18px 0 0 !important;
    background: var(--su-grad-primary) !important;
}
.su-stat-card--success::after { background: var(--su-grad-success) !important; }
.su-stat-card--danger::after  { background: var(--su-grad-danger) !important; }
.su-stat-card--info::after    { background: var(--su-grad-info) !important; }

/* Icon container */
.su-stat-icon {
    width: 44px !important;
    height: 44px !important;
    border-radius: 14px !important;
    font-size: 20px !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.2) !important;
    background: linear-gradient(135deg, #ede9fe 0%, #f3e8ff 100%) !important;
    color: #7c3aed !important;
}
.su-stat-card--success .su-stat-icon {
    background: linear-gradient(135deg, #dcfce7 0%, #d1fae5 100%) !important;
    color: #059669 !important;
    box-shadow: 0 4px 12px rgba(16,185,129,.2) !important;
}
.su-stat-card--danger .su-stat-icon {
    background: linear-gradient(135deg, #fee2e2 0%, #fecaca 100%) !important;
    color: #dc2626 !important;
    box-shadow: 0 4px 12px rgba(239,68,68,.2) !important;
}
.su-stat-card--info .su-stat-icon {
    background: linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%) !important;
    color: #2563eb !important;
    box-shadow: 0 4px 12px rgba(59,130,246,.2) !important;
}

/* Value number */
.su-stat-value {
    font-size: 42px !important;
    font-weight: 800 !important;
    letter-spacing: -0.03em !important;
    line-height: 1 !important;
    background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    font-feature-settings: "tnum" !important;
}
.su-stat-card--success .su-stat-value { background: linear-gradient(135deg, #059669, #10b981) !important; -webkit-background-clip: text !important; background-clip: text !important; }
.su-stat-card--danger  .su-stat-value { background: linear-gradient(135deg, #dc2626, #ef4444) !important; -webkit-background-clip: text !important; background-clip: text !important; }
.su-stat-card--info    .su-stat-value { background: linear-gradient(135deg, #2563eb, #3b82f6) !important; -webkit-background-clip: text !important; background-clip: text !important; }

.su-stat-label {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    color: var(--su-text-muted) !important;
    margin-bottom: 6px !important;
}

/* Sparkline — taller and more vibrant */
.su-stat-spark {
    height: 28px !important;
    gap: 2px !important;
    margin-top: auto !important;
    padding-top: 10px !important;
}
.su-stat-spark span {
    border-radius: 3px !important;
    opacity: .8 !important;
    transition: height .4s ease !important;
    background: linear-gradient(180deg, #a78bfa, #7c3aed) !important;
}
.su-stat-card--success .su-stat-spark span { background: linear-gradient(180deg, #34d399, #059669) !important; }
.su-stat-card--danger  .su-stat-spark span { background: linear-gradient(180deg, #fca5a5, #ef4444) !important; }
.su-stat-card--info    .su-stat-spark span { background: linear-gradient(180deg, #93c5fd, #2563eb) !important; }

/* ── 07. Cards & Surfaces — Premium Edition ─────────────────── */
.su-card {
    border-radius: 18px !important;
    border: 1px solid rgba(0,0,0,.05) !important;
    box-shadow: var(--su-shadow-card) !important;
    transition: box-shadow .2s ease !important;
    background: #fff !important;
}
.su-card:hover {
    box-shadow: 0 8px 24px rgba(0,0,0,.08), 0 2px 8px rgba(124,58,237,.05) !important;
}

.su-card-header {
    padding: 18px 20px !important;
    border-bottom: 1px solid rgba(124,58,237,.06) !important;
    background: linear-gradient(90deg,
        rgba(124,58,237,.03) 0%,
        rgba(255,255,255,.5) 100%) !important;
}
.su-card-header h5 {
    font-size: 14.5px !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em;
}

.su-card-body { padding: 20px !important; }

.su-card-header-icon {
    width: 34px !important;
    height: 34px !important;
    border-radius: 10px !important;
    font-size: 15px !important;
    box-shadow: 0 2px 8px rgba(124,58,237,.2) !important;
    background: linear-gradient(135deg, #ede9fe, #f3e8ff) !important;
    color: #7c3aed !important;
}
.su-card-header-icon--primary {
    background: linear-gradient(135deg, #ede9fe, #f3e8ff) !important;
}

/* ── 08. Tables — Premium Edition ──────────────────────────── */
.table {
    --bs-table-hover-bg: rgba(124,58,237,.04);
    --bs-table-striped-bg: rgba(124,58,237,.02);
    font-size: 13.5px;
}

.table > thead > tr > th {
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .07em !important;
    color: var(--su-text-muted) !important;
    background: linear-gradient(90deg,
        rgba(124,58,237,.04) 0%,
        rgba(244,243,248,.5) 100%) !important;
    border-bottom: 2px solid rgba(124,58,237,.1) !important;
    padding: 12px 16px !important;
    vertical-align: middle;
    white-space: nowrap;
}

.table > tbody > tr > td {
    padding: 12px 16px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid rgba(0,0,0,.04) !important;
    font-size: 13.5px;
    color: var(--su-text);
    transition: background .12s ease;
}

.table > tbody > tr:hover > td {
    background: rgba(124,58,237,.04) !important;
}
.table > tbody > tr:last-child > td { border-bottom: none !important; }

/* Table inside card — no outer border */
.su-card .table {
    margin-bottom: 0;
}
.su-card .table-responsive {
    border-radius: 0 0 18px 18px;
    overflow: hidden;
}

/* Table action buttons */
.table .btn-sm {
    padding: 4px 10px !important;
    font-size: 12px !important;
    border-radius: 8px !important;
    font-weight: 500;
}

/* ── 09. Buttons — Premium Edition ─────────────────────────── */

/* Primary button */
.btn-primary {
    background: linear-gradient(135deg, #7c3aed 0%, #9333ea 50%, #a855f7 100%) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(124,58,237,.4), 0 1px 4px rgba(124,58,237,.2) !important;
    font-weight: 600 !important;
    letter-spacing: .01em;
    border-radius: 10px !important;
    transition: all .2s ease !important;
}
.btn-primary:hover {
    background: linear-gradient(135deg, #6d28d9 0%, #7c3aed 50%, #9333ea 100%) !important;
    box-shadow: 0 6px 20px rgba(124,58,237,.5), 0 2px 6px rgba(124,58,237,.3) !important;
    transform: translateY(-1px) !important;
}
.btn-primary:active {
    transform: translateY(0) scale(.98) !important;
    box-shadow: 0 2px 8px rgba(124,58,237,.3) !important;
}
.btn-primary:disabled {
    opacity: .6 !important;
    transform: none !important;
    box-shadow: none !important;
}

/* Secondary button */
.btn-secondary {
    background: #f4f3f8 !important;
    border: 1.5px solid rgba(124,58,237,.15) !important;
    color: var(--su-text) !important;
    font-weight: 500 !important;
    border-radius: 10px !important;
    transition: all .15s ease !important;
}
.btn-secondary:hover {
    background: rgba(124,58,237,.06) !important;
    border-color: rgba(124,58,237,.3) !important;
    color: #7c3aed !important;
}

/* Outline primary */
.btn-outline-primary {
    border: 1.5px solid rgba(124,58,237,.4) !important;
    color: #7c3aed !important;
    border-radius: 10px !important;
    font-weight: 500 !important;
    transition: all .15s ease !important;
}
.btn-outline-primary:hover {
    background: rgba(124,58,237,.08) !important;
    border-color: #7c3aed !important;
    color: #7c3aed !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(124,58,237,.2);
}

/* Outline secondary */
.btn-outline-secondary {
    border: 1.5px solid var(--su-border) !important;
    color: var(--su-text-muted) !important;
    border-radius: 10px !important;
    font-weight: 500 !important;
    transition: all .15s ease !important;
}
.btn-outline-secondary:hover {
    background: var(--su-bg) !important;
    border-color: rgba(124,58,237,.3) !important;
    color: #7c3aed !important;
}

/* Danger */
.btn-danger {
    background: linear-gradient(135deg, #dc2626, #ef4444) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(239,68,68,.3) !important;
    font-weight: 600 !important;
    border-radius: 10px !important;
    transition: all .2s ease !important;
}
.btn-danger:hover {
    box-shadow: 0 6px 20px rgba(239,68,68,.4) !important;
    transform: translateY(-1px) !important;
}

/* Success */
.btn-success {
    background: linear-gradient(135deg, #059669, #10b981) !important;
    border: none !important;
    box-shadow: 0 4px 14px rgba(16,185,129,.3) !important;
    font-weight: 600 !important;
    border-radius: 10px !important;
    transition: all .2s ease !important;
}
.btn-success:hover {
    box-shadow: 0 6px 20px rgba(16,185,129,.4) !important;
    transform: translateY(-1px) !important;
}

/* Button sizing */
.btn { font-size: 13.5px !important; font-weight: 500; }
.btn-sm { font-size: 12.5px !important; border-radius: 8px !important; }
.btn-lg { font-size: 15px !important; border-radius: 12px !important; padding: 12px 24px !important; }

/* ── 10. Forms & Inputs — Premium Edition ───────────────────── */
.form-label {
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
    color: var(--su-text-muted) !important;
    margin-bottom: 6px !important;
}

.form-control, .form-select {
    border: 1.5px solid var(--su-border) !important;
    border-radius: 10px !important;
    background: #faf9fc !important;
    font-size: 13.5px !important;
    padding: 9px 13px !important;
    color: var(--su-text) !important;
    transition: all .2s ease !important;
    box-shadow: 0 1px 2px rgba(0,0,0,.04) !important;
}
.form-control:focus, .form-select:focus {
    border-color: #7c3aed !important;
    background: #fff !important;
    box-shadow:
        0 0 0 4px rgba(124,58,237,.1),
        0 2px 8px rgba(124,58,237,.06) !important;
    outline: none !important;
}
.form-control::placeholder { color: var(--su-text-light) !important; font-weight: 400; }

/* Textarea */
textarea.form-control { resize: vertical; min-height: 100px; }

/* Input group */
.input-group .btn { border-radius: 0 10px 10px 0 !important; }
.input-group .form-control { border-radius: 10px 0 0 10px !important; }

/* Form text helper */
.form-text {
    font-size: 12px !important;
    color: var(--su-text-muted) !important;
    margin-top: 5px !important;
}

/* Checkbox & Radio */
.form-check-input {
    width: 16px !important;
    height: 16px !important;
    border: 2px solid var(--su-border) !important;
    border-radius: 5px !important;
    transition: all .15s ease !important;
}
.form-check-input:checked {
    background-color: #7c3aed !important;
    border-color: #7c3aed !important;
    box-shadow: 0 2px 6px rgba(124,58,237,.3) !important;
}
.form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(124,58,237,.2) !important;
    border-color: #7c3aed !important;
}

/* ── 11. Flash Messages / Toasts ────────────────────────────── */
.su-flash {
    margin: 10px 24px 0 !important;
    padding: 14px 18px !important;
    border-radius: 14px !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.1), 0 2px 6px rgba(0,0,0,.06) !important;
    animation: su-toast-in .25s cubic-bezier(.34,1.56,.64,1) !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    border: none !important;
    border-left: 4px solid transparent !important;
}
@keyframes su-toast-in {
    from { opacity: 0; transform: translateY(-12px) scale(.96); }
    to   { opacity: 1; transform: none; }
}
.su-flash--success {
    background: linear-gradient(135deg, #d1fae5 0%, #ecfdf5 100%) !important;
    border-left-color: #10b981 !important;
    color: #065f46 !important;
}
.su-flash--success i { color: #10b981; font-size: 16px; }
.su-flash--error {
    background: linear-gradient(135deg, #fee2e2 0%, #fff5f5 100%) !important;
    border-left-color: #ef4444 !important;
    color: #991b1b !important;
}
.su-flash--error i { color: #ef4444; font-size: 16px; }

/* ── 12. Empty States — Premium Edition ─────────────────────── */
.su-empty-state {
    padding: 56px 24px !important;
    gap: 12px !important;
}
.su-empty-state i {
    font-size: 44px !important;
    opacity: 1 !important;
    background: var(--su-grad-primary-soft);
    width: 80px;
    height: 80px;
    border-radius: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(124,58,237,.5);
    box-shadow: 0 4px 16px rgba(124,58,237,.12);
    margin-bottom: 8px;
}
.su-empty-state p {
    font-size: 14px !important;
    color: var(--su-text-muted) !important;
    font-weight: 500;
    line-height: 1.5;
    max-width: 280px;
}
.su-empty-state .btn {
    margin-top: 4px;
    box-shadow: 0 4px 14px rgba(124,58,237,.25);
}

/* ── 13. Badges & Chips — Premium Edition ───────────────────── */
.badge {
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 4px 9px !important;
    border-radius: 8px !important;
    letter-spacing: .02em;
}

/* Status badge enhancement */
.su-status-badge {
    font-size: 11.5px !important;
    font-weight: 600 !important;
    padding: 4px 10px !important;
    border-radius: 8px !important;
    border: 1px solid transparent;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    letter-spacing: .01em;
}
.su-status-badge::before {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: currentColor;
    opacity: .8;
    flex-shrink: 0;
}

/* Priority dot — larger and richer */
.su-priority-dot {
    width: 9px !important;
    height: 9px !important;
    box-shadow: 0 0 0 2px rgba(255,255,255,.8) !important;
}
.su-priority-dot--urgent  { background: #dc2626 !important; box-shadow: 0 0 4px rgba(220,38,38,.4), 0 0 0 2px rgba(255,255,255,.8) !important; }
.su-priority-dot--high    { background: #ea580c !important; }
.su-priority-dot--normal  { background: #2563eb !important; }
.su-priority-dot--low     { background: #94a3b8 !important; }

/* Tags */
.su-tag {
    background: linear-gradient(135deg, #ede9fe, #f3e8ff) !important;
    color: #7c3aed !important;
    border: 1px solid rgba(124,58,237,.15) !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    padding: 3px 10px !important;
    transition: all .15s ease !important;
}
.su-tag:hover { box-shadow: 0 2px 8px rgba(124,58,237,.2); }

/* Bootstrap badge variants */
.badge.bg-primary { background: linear-gradient(135deg, #7c3aed, #9333ea) !important; }
.badge.bg-success { background: linear-gradient(135deg, #059669, #10b981) !important; }
.badge.bg-danger  { background: linear-gradient(135deg, #dc2626, #ef4444) !important; }
.badge.bg-warning { background: linear-gradient(135deg, #d97706, #f59e0b) !important; color: #fff !important; }
.badge.bg-info    { background: linear-gradient(135deg, #2563eb, #3b82f6) !important; }
.badge.bg-secondary { background: linear-gradient(135deg, #475569, #64748b) !important; }

/* ── 14. Pagination — Premium Edition ──────────────────────── */
.pagination {
    gap: 4px !important;
    --bs-pagination-border-radius: 10px;
}
.page-link {
    border-radius: 10px !important;
    border: 1.5px solid var(--su-border) !important;
    color: var(--su-text-muted) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    padding: 7px 13px !important;
    transition: all .15s ease !important;
    background: #fff !important;
}
.page-link:hover {
    background: rgba(124,58,237,.08) !important;
    border-color: rgba(124,58,237,.3) !important;
    color: #7c3aed !important;
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(124,58,237,.15);
}
.page-item.active .page-link {
    background: linear-gradient(135deg, #7c3aed, #9333ea) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.4) !important;
}
.page-item.disabled .page-link {
    opacity: .4 !important;
    cursor: not-allowed;
}

/* ── 15. Progress Bars — Gradient & Animated ────────────────── */
.progress {
    background: rgba(124,58,237,.08) !important;
    border-radius: 999px !important;
    overflow: hidden !important;
}
.progress-bar {
    border-radius: 999px !important;
    background: linear-gradient(90deg, #7c3aed, #a855f7) !important;
    position: relative;
    overflow: hidden;
    transition: width .7s cubic-bezier(.4,0,.2,1) !important;
}
.progress-bar::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(255,255,255,.3) 50%,
        transparent 100%);
    animation: su-progress-shimmer 2s infinite;
}
@keyframes su-progress-shimmer {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}

/* Named progress colors */
.progress-bar.bg-success { background: linear-gradient(90deg, #059669, #10b981) !important; }
.progress-bar.bg-danger  { background: linear-gradient(90deg, #dc2626, #ef4444) !important; }
.progress-bar.bg-warning { background: linear-gradient(90deg, #d97706, #f59e0b) !important; }
.progress-bar.bg-info    { background: linear-gradient(90deg, #2563eb, #3b82f6) !important; }

/* ── 16. Module Color System ────────────────────────────────── */
/* Module-specific accent for page headers */
[data-module="tasks"]       { --su-module-accent: #7c3aed; }
[data-module="goals"]       { --su-module-accent: #d97706; }
[data-module="docs"]        { --su-module-accent: #2563eb; }
[data-module="chat"]        { --su-module-accent: #16a34a; }
[data-module="clients"]     { --su-module-accent: #0891b2; }
[data-module="time"]        { --su-module-accent: #c2410c; }
[data-module="automation"]  { --su-module-accent: #db2777; }
[data-module="analytics"]   { --su-module-accent: #6366f1; }
[data-module="sprints"]     { --su-module-accent: #7c3aed; }
[data-module="members"]     { --su-module-accent: #0284c7; }

/* ── 17. Quick Links — Premium Edition ──────────────────────── */
.su-quick-links {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}
.su-quick-link {
    min-width: 88px !important;
    padding: 16px 16px 14px !important;
    border-radius: 16px !important;
    border: 1.5px solid rgba(0,0,0,.06) !important;
    box-shadow: var(--su-shadow-2xs) !important;
    gap: 8px !important;
    background: #fff !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    color: var(--su-text) !important;
    transition: all .2s ease !important;
    position: relative;
    overflow: hidden;
}
.su-quick-link::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
        rgba(124,58,237,.04) 0%,
        transparent 60%);
    opacity: 0;
    transition: opacity .2s ease;
}
.su-quick-link:hover {
    border-color: rgba(124,58,237,.25) !important;
    color: #7c3aed !important;
    box-shadow: 0 8px 24px rgba(124,58,237,.12), 0 2px 8px rgba(0,0,0,.06) !important;
    transform: translateY(-3px) !important;
    text-decoration: none !important;
}
.su-quick-link:hover::before { opacity: 1; }
.su-quick-link-icon {
    width: 40px !important;
    height: 40px !important;
    border-radius: 12px !important;
    font-size: 18px !important;
    transition: transform .2s ease !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.1) !important;
}
.su-quick-link:hover .su-quick-link-icon {
    transform: scale(1.12) rotate(-3deg) !important;
}

/* ── 18. AI FAB & Timer Chip ─────────────────────────────────── */
.su-ai-fab {
    background: linear-gradient(135deg, #7c3aed, #a855f7, #c084fc) !important;
    box-shadow:
        0 6px 24px rgba(124,58,237,.5),
        0 2px 8px rgba(0,0,0,.15) !important;
    transition: all .25s cubic-bezier(.34,1.56,.64,1) !important;
    border-radius: 50% !important;
    width: 52px !important;
    height: 52px !important;
    font-size: 22px !important;
}
.su-ai-fab:hover {
    transform: scale(1.12) !important;
    box-shadow:
        0 10px 32px rgba(124,58,237,.6),
        0 4px 12px rgba(0,0,0,.2) !important;
}
.su-ai-fab::before {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7c3aed, #a855f7);
    opacity: .2;
    animation: su-fab-pulse 3s infinite;
    z-index: -1;
}
@keyframes su-fab-pulse {
    0%, 100% { transform: scale(1); opacity: .15; }
    50%       { transform: scale(1.2); opacity: .05; }
}
.su-ai-panel {
    border: 1px solid rgba(124,58,237,.12) !important;
    border-radius: 22px !important;
    box-shadow: 0 16px 56px rgba(0,0,0,.15), 0 4px 16px rgba(124,58,237,.12) !important;
    backdrop-filter: blur(20px);
}
.su-ai-panel-header {
    background: linear-gradient(135deg,
        rgba(124,58,237,.1) 0%,
        rgba(168,85,247,.06) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.1) !important;
}
.su-ai-msg-bubble {
    border-radius: 14px !important;
    font-size: 13.5px !important;
    line-height: 1.55 !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
}
.su-ai-msg--user .su-ai-msg-bubble {
    background: linear-gradient(135deg, #7c3aed, #9333ea) !important;
}
.su-ai-msg-avatar {
    background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
    box-shadow: 0 2px 8px rgba(124,58,237,.3) !important;
    border-radius: 12px !important;
    width: 28px !important;
    height: 28px !important;
    font-size: 13px !important;
}

/* Timer chip */
.su-timer-chip {
    background: linear-gradient(135deg, #fff, #faf8ff) !important;
    border: 2px solid rgba(124,58,237,.3) !important;
    border-radius: 999px !important;
    box-shadow: 0 8px 32px rgba(124,58,237,.25), 0 2px 8px rgba(0,0,0,.08) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    padding: 10px 20px !important;
    backdrop-filter: blur(12px);
    transition: all .2s ease !important;
}
.su-timer-chip:hover {
    box-shadow: 0 12px 40px rgba(124,58,237,.35), 0 4px 12px rgba(0,0,0,.1) !important;
    transform: translateY(-2px) !important;
}
.su-timer-chip-dot {
    background: linear-gradient(135deg, #ef4444, #f87171) !important;
    box-shadow: 0 0 6px rgba(239,68,68,.5) !important;
    animation: su-timer-dot-pulse 1.5s infinite !important;
}
@keyframes su-timer-dot-pulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50%       { transform: scale(1.4); opacity: .6; }
}

/* ── 19. Premium Utility Classes ────────────────────────────── */

/* Gradient backgrounds */
.su-bg-primary-gradient   { background: var(--su-grad-primary) !important; }
.su-bg-success-gradient   { background: var(--su-grad-success) !important; }
.su-bg-danger-gradient    { background: var(--su-grad-danger) !important; }
.su-bg-warning-gradient   { background: var(--su-grad-warning) !important; }
.su-bg-info-gradient      { background: var(--su-grad-info) !important; }

/* Glass card */
.su-glass-card {
    background: rgba(255,255,255,.72) !important;
    backdrop-filter: blur(20px) saturate(150%) !important;
    border: 1px solid rgba(255,255,255,.6) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,.08) !important;
    border-radius: 18px !important;
}

/* Premium section header */
.su-section-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    padding-bottom: 12px;
    border-bottom: 2px solid rgba(124,58,237,.08);
}
.su-section-header-icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    background: var(--su-grad-primary-soft);
    color: #7c3aed;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(124,58,237,.2);
}
.su-section-title {
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--su-text);
}

/* Divider with label */
.su-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 20px 0;
    color: var(--su-text-light);
    font-size: 11.5px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.su-divider::before, .su-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--su-border), transparent);
}

/* Module icon badge */
.su-module-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    flex-shrink: 0;
    box-shadow: 0 4px 14px rgba(0,0,0,.12);
}

/* Breadcrumb enhancement */
.su-breadcrumb {
    gap: 6px !important;
    font-size: 13px !important;
}
.su-breadcrumb-link {
    color: var(--su-text-muted) !important;
    text-decoration: none !important;
    font-weight: 500;
    padding: 2px 6px;
    border-radius: 6px;
    transition: all .12s ease !important;
}
.su-breadcrumb-link:hover {
    color: #7c3aed !important;
    background: rgba(124,58,237,.06);
    text-decoration: none !important;
}

/* Filter bar enhancement */
.su-filter-bar {
    background: #fff !important;
    border: 1.5px solid rgba(124,58,237,.08) !important;
    border-radius: 14px !important;
    box-shadow: var(--su-shadow-2xs) !important;
    padding: 12px 16px !important;
}
.su-filter-toggle {
    border-radius: 9px !important;
    font-size: 12.5px !important;
    font-weight: 500 !important;
    transition: all .15s ease !important;
    padding: 6px 12px !important;
    background: rgba(124,58,237,.04) !important;
    border: 1.5px solid rgba(124,58,237,.1) !important;
    color: var(--su-text-muted) !important;
}
.su-filter-toggle:hover, .su-filter-toggle.active {
    background: rgba(124,58,237,.1) !important;
    border-color: rgba(124,58,237,.3) !important;
    color: #7c3aed !important;
}

/* View tabs */
.su-view-tabs {
    background: rgba(124,58,237,.06) !important;
    border: 1.5px solid rgba(124,58,237,.1) !important;
    border-radius: 12px !important;
    padding: 4px !important;
}
.su-view-tab {
    border-radius: 8px !important;
    width: 34px !important;
    height: 32px !important;
    transition: all .15s ease !important;
}
.su-view-tab.active {
    background: #fff !important;
    color: #7c3aed !important;
    box-shadow: 0 2px 8px rgba(124,58,237,.2) !important;
}
.su-view-tab:hover:not(.active) {
    background: rgba(255,255,255,.6) !important;
    color: #7c3aed !important;
}

/* Alert bar */
.su-alert-bar {
    background: linear-gradient(135deg, #fffbeb 0%, #fefce8 100%) !important;
    border: 1.5px solid rgba(251,191,36,.3) !important;
    border-radius: 16px !important;
    box-shadow: 0 4px 16px rgba(251,191,36,.1) !important;
    overflow: hidden !important;
}
.su-alert-bar-header {
    background: rgba(251,191,36,.08) !important;
    border-bottom: 1px solid rgba(251,191,36,.2) !important;
    padding: 12px 18px !important;
}
.su-alert-item {
    padding: 11px 18px !important;
    transition: background .12s ease !important;
}
.su-alert-item:hover { background: rgba(251,191,36,.05) !important; }

/* Bulk action bar */
.su-bulk-bar {
    background: linear-gradient(135deg, #ede9fe, #f3e8ff) !important;
    border-bottom: 1.5px solid rgba(124,58,237,.2) !important;
    border-radius: 12px 12px 0 0 !important;
}

/* Modals — premium */
.su-modal {
    border-radius: 22px !important;
    border: 1px solid rgba(124,58,237,.1) !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.18), 0 8px 24px rgba(124,58,237,.1) !important;
}
.su-modal-header {
    background: linear-gradient(135deg,
        rgba(124,58,237,.05) 0%,
        rgba(255,255,255,.5) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.08) !important;
    border-radius: 22px 22px 0 0 !important;
}
.su-modal-footer {
    background: linear-gradient(0deg,
        rgba(124,58,237,.03) 0%,
        transparent 100%) !important;
    border-top: 1px solid rgba(124,58,237,.08) !important;
    border-radius: 0 0 22px 22px !important;
}
.su-modal-close {
    border-radius: 9px !important;
    width: 32px !important;
    height: 32px !important;
}

/* Bootstrap modal enhancement */
.modal-content {
    border-radius: 20px !important;
    border: 1px solid rgba(124,58,237,.1) !important;
    box-shadow: 0 24px 80px rgba(0,0,0,.18), 0 8px 24px rgba(124,58,237,.1) !important;
}
.modal-header {
    background: linear-gradient(135deg,
        rgba(124,58,237,.04) 0%,
        rgba(255,255,255,.6) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.08) !important;
    border-radius: 20px 20px 0 0 !important;
    padding: 18px 22px !important;
}
.modal-title { font-size: 15.5px !important; font-weight: 700 !important; letter-spacing: -0.01em; }
.modal-footer {
    background: rgba(124,58,237,.02) !important;
    border-top: 1px solid rgba(124,58,237,.08) !important;
    border-radius: 0 0 20px 20px !important;
    padding: 14px 22px !important;
    gap: 8px;
}
.modal-body { padding: 20px 22px !important; }

/* Dropdown menus — premium */
.dropdown-menu {
    border: 1px solid rgba(124,58,237,.1) !important;
    border-radius: 14px !important;
    box-shadow: 0 12px 40px rgba(0,0,0,.12), 0 4px 16px rgba(124,58,237,.08) !important;
    padding: 6px !important;
    backdrop-filter: blur(20px);
}
.dropdown-item {
    border-radius: 8px !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    padding: 9px 12px !important;
    color: var(--su-text) !important;
    transition: all .12s ease !important;
    display: flex;
    align-items: center;
    gap: 8px;
}
.dropdown-item:hover, .dropdown-item:focus {
    background: rgba(124,58,237,.08) !important;
    color: #7c3aed !important;
}
.dropdown-item.text-danger:hover { background: rgba(239,68,68,.07) !important; color: #dc2626 !important; }
.dropdown-divider {
    border-color: rgba(124,58,237,.06) !important;
    margin: 4px 0 !important;
}

/* Nav tabs */
.nav-tabs {
    border-bottom: 2px solid rgba(124,58,237,.08) !important;
    gap: 2px !important;
}
.nav-tabs .nav-link {
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: var(--su-text-muted) !important;
    border-radius: 8px 8px 0 0 !important;
    border: none !important;
    padding: 10px 16px !important;
    transition: all .15s ease !important;
    margin-bottom: -2px;
}
.nav-tabs .nav-link:hover {
    background: rgba(124,58,237,.06) !important;
    color: #7c3aed !important;
}
.nav-tabs .nav-link.active {
    background: linear-gradient(135deg, rgba(124,58,237,.12), rgba(124,58,237,.06)) !important;
    color: #7c3aed !important;
    font-weight: 600 !important;
    border-bottom: 2px solid #7c3aed !important;
}

/* Nav pills */
.nav-pills .nav-link {
    font-size: 13px !important;
    font-weight: 500 !important;
    border-radius: 9px !important;
    color: var(--su-text-muted) !important;
    padding: 8px 14px !important;
    transition: all .15s ease !important;
}
.nav-pills .nav-link:hover {
    background: rgba(124,58,237,.08) !important;
    color: #7c3aed !important;
}
.nav-pills .nav-link.active {
    background: linear-gradient(135deg, #7c3aed, #9333ea) !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.35) !important;
    font-weight: 600 !important;
}

/* List group */
.list-group-item {
    border: 1px solid rgba(0,0,0,.06) !important;
    font-size: 13.5px !important;
    padding: 12px 16px !important;
    transition: background .12s ease !important;
}
.list-group-item:hover:not(.disabled) {
    background: rgba(124,58,237,.04) !important;
}
.list-group-item.active {
    background: linear-gradient(135deg, #7c3aed, #9333ea) !important;
    border-color: transparent !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.3) !important;
}

/* Alert box (Bootstrap) */
.alert {
    border-radius: 14px !important;
    border: none !important;
    padding: 14px 18px !important;
    font-size: 13.5px !important;
    font-weight: 500 !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.06) !important;
}
.alert-success {
    background: linear-gradient(135deg, #d1fae5 0%, #ecfdf5 100%) !important;
    color: #065f46 !important;
    border-left: 4px solid #10b981 !important;
}
.alert-danger {
    background: linear-gradient(135deg, #fee2e2 0%, #fff5f5 100%) !important;
    color: #991b1b !important;
    border-left: 4px solid #ef4444 !important;
}
.alert-warning {
    background: linear-gradient(135deg, #fef3c7 0%, #fffbeb 100%) !important;
    color: #78350f !important;
    border-left: 4px solid #f59e0b !important;
}
.alert-info {
    background: linear-gradient(135deg, #dbeafe 0%, #eff6ff 100%) !important;
    color: #1e40af !important;
    border-left: 4px solid #3b82f6 !important;
}

/* ── 20. Dark Mode Enhancements ─────────────────────────────── */
[data-theme="dark"] body {
    background: #0f0d17 !important;
    background-image:
        radial-gradient(circle at 20% 10%, rgba(124,58,237,.06) 0%, transparent 50%),
        radial-gradient(circle at 80% 90%, rgba(99,102,241,.04) 0%, transparent 40%);
}

[data-theme="dark"] .su-sidebar {
    background: linear-gradient(180deg,
        #18151f 0%,
        #1a1626 60%,
        #1c1730 100%) !important;
    border-right: 1px solid rgba(124,58,237,.12) !important;
    box-shadow: 2px 0 24px rgba(0,0,0,.2) !important;
}

[data-theme="dark"] .su-sidebar-header {
    background: linear-gradient(135deg,
        rgba(124,58,237,.1) 0%,
        rgba(124,58,237,.04) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.12) !important;
}

[data-theme="dark"] .su-ws-name {
    background: linear-gradient(135deg, #e8e4f0, #a78bfa) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
}

[data-theme="dark"] .su-nav-item:hover:not(.active) {
    background: rgba(124,58,237,.1) !important;
}
[data-theme="dark"] .su-nav-item.active {
    background: linear-gradient(135deg,
        rgba(124,58,237,.22) 0%,
        rgba(124,58,237,.1) 100%) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.2) !important;
}

[data-theme="dark"] .su-topbar {
    background: rgba(24,21,31,.92) !important;
    border-bottom: 1px solid rgba(124,58,237,.12) !important;
    box-shadow: 0 1px 0 rgba(0,0,0,.2), 0 2px 16px rgba(0,0,0,.15) !important;
}

[data-theme="dark"] .su-search-input-wrap {
    background: rgba(30,26,40,.8) !important;
    border-color: rgba(124,58,237,.2) !important;
}
[data-theme="dark"] .su-search-input-wrap:focus-within {
    background: rgba(30,26,40,1) !important;
    border-color: rgba(124,58,237,.5) !important;
    box-shadow: 0 0 0 4px rgba(124,58,237,.12), 0 4px 16px rgba(0,0,0,.2) !important;
}

[data-theme="dark"] .su-stat-card {
    background: #1e1a28 !important;
    border: 1px solid rgba(124,58,237,.12) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.2) !important;
}
[data-theme="dark"] .su-stat-card:hover {
    box-shadow: 0 12px 32px rgba(0,0,0,.3), 0 4px 12px rgba(124,58,237,.15) !important;
}

[data-theme="dark"] .su-card {
    background: #1e1a28 !important;
    border: 1px solid rgba(124,58,237,.1) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.2) !important;
}
[data-theme="dark"] .su-card-header {
    background: linear-gradient(90deg,
        rgba(124,58,237,.08) 0%,
        rgba(255,255,255,.02) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.1) !important;
}

[data-theme="dark"] .su-stat-value {
    background: linear-gradient(135deg, #c4b5fd, #a78bfa) !important;
    -webkit-background-clip: text !important; background-clip: text !important;
}
[data-theme="dark"] .su-stat-card--success .su-stat-value { background: linear-gradient(135deg, #4ade80, #22c55e) !important; -webkit-background-clip: text !important; background-clip: text !important; }
[data-theme="dark"] .su-stat-card--danger .su-stat-value  { background: linear-gradient(135deg, #fca5a5, #f87171) !important; -webkit-background-clip: text !important; background-clip: text !important; }
[data-theme="dark"] .su-stat-card--info .su-stat-value    { background: linear-gradient(135deg, #93c5fd, #60a5fa) !important; -webkit-background-clip: text !important; background-clip: text !important; }

[data-theme="dark"] .su-flash--success {
    background: linear-gradient(135deg, rgba(16,185,129,.15), rgba(16,185,129,.08)) !important;
    color: #6ee7b7 !important;
}
[data-theme="dark"] .su-flash--error {
    background: linear-gradient(135deg, rgba(239,68,68,.15), rgba(239,68,68,.08)) !important;
    color: #fca5a5 !important;
}

[data-theme="dark"] .su-empty-state i {
    background: rgba(124,58,237,.15) !important;
    color: rgba(167,139,250,.6) !important;
}

[data-theme="dark"] .btn-primary {
    background: linear-gradient(135deg, #7c3aed, #9333ea, #a855f7) !important;
    box-shadow: 0 4px 14px rgba(124,58,237,.35), 0 1px 4px rgba(0,0,0,.3) !important;
}
[data-theme="dark"] .form-control, [data-theme="dark"] .form-select {
    background: #261f38 !important;
    border-color: rgba(124,58,237,.2) !important;
    color: #e8e4f0 !important;
}
[data-theme="dark"] .form-control:focus, [data-theme="dark"] .form-select:focus {
    background: #2d2545 !important;
    border-color: rgba(124,58,237,.5) !important;
    box-shadow: 0 0 0 4px rgba(124,58,237,.12), 0 2px 8px rgba(0,0,0,.2) !important;
}
[data-theme="dark"] .table > thead > tr > th {
    background: linear-gradient(90deg,
        rgba(124,58,237,.1) 0%,
        rgba(30,26,40,.8) 100%) !important;
    border-bottom: 2px solid rgba(124,58,237,.15) !important;
    color: #9490a8 !important;
}
[data-theme="dark"] .table > tbody > tr > td {
    border-bottom: 1px solid rgba(255,255,255,.04) !important;
    color: #e8e4f0;
}
[data-theme="dark"] .table > tbody > tr:hover > td {
    background: rgba(124,58,237,.06) !important;
}
[data-theme="dark"] .quick-link {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.12) !important;
    color: #e8e4f0 !important;
}
[data-theme="dark"] .su-quick-link {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.1) !important;
    color: #c4b5fd !important;
}
[data-theme="dark"] .su-quick-link:hover {
    border-color: rgba(124,58,237,.3) !important;
    background: #261f38 !important;
    color: #a78bfa !important;
}
[data-theme="dark"] .modal-content {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .modal-header {
    background: linear-gradient(135deg,
        rgba(124,58,237,.1) 0%,
        rgba(30,26,40,.5) 100%) !important;
    border-bottom: 1px solid rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .dropdown-menu {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.15) !important;
    box-shadow: 0 12px 40px rgba(0,0,0,.4), 0 4px 16px rgba(0,0,0,.2) !important;
}
[data-theme="dark"] .dropdown-item:hover, [data-theme="dark"] .dropdown-item:focus {
    background: rgba(124,58,237,.12) !important;
    color: #a78bfa !important;
}
[data-theme="dark"] .progress { background: rgba(124,58,237,.15) !important; }
[data-theme="dark"] .page-link {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.15) !important;
    color: #9490a8 !important;
}
[data-theme="dark"] .page-link:hover {
    background: rgba(124,58,237,.12) !important;
    border-color: rgba(124,58,237,.35) !important;
    color: #a78bfa !important;
}
[data-theme="dark"] .su-notif-panel,
[data-theme="dark"] .su-user-dropdown,
[data-theme="dark"] .su-ws-dropdown,
[data-theme="dark"] .su-search-results {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.15) !important;
}
[data-theme="dark"] .su-notif-header {
    background: rgba(124,58,237,.1) !important;
    border-bottom-color: rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .su-notif-item.unread { border-left-color: #a78bfa; }
[data-theme="dark"] .su-ai-panel {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.15) !important;
}
[data-theme="dark"] .su-ai-msg-bubble { background: #261f38 !important; }
[data-theme="dark"] .su-timer-chip {
    background: linear-gradient(135deg, #1e1a28, #261f38) !important;
    border-color: rgba(124,58,237,.4) !important;
}
[data-theme="dark"] .su-tag {
    background: rgba(124,58,237,.2) !important;
    border-color: rgba(124,58,237,.25) !important;
    color: #c4b5fd !important;
}
[data-theme="dark"] .su-filter-bar {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .su-alert-bar {
    background: linear-gradient(135deg, rgba(251,191,36,.08), rgba(251,191,36,.04)) !important;
    border-color: rgba(251,191,36,.2) !important;
}
[data-theme="dark"] .su-sidebar-footer {
    background: linear-gradient(0deg,
        rgba(124,58,237,.08) 0%,
        transparent 100%) !important;
    border-top-color: rgba(124,58,237,.1) !important;
}
[data-theme="dark"] .nav-tabs {
    border-bottom-color: rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .nav-tabs .nav-link { color: #9490a8 !important; }
[data-theme="dark"] .nav-tabs .nav-link:hover { background: rgba(124,58,237,.08) !important; color: #a78bfa !important; }
[data-theme="dark"] .nav-tabs .nav-link.active { background: rgba(124,58,237,.18) !important; color: #c4b5fd !important; border-bottom-color: #a78bfa !important; }
[data-theme="dark"] .alert-bar { background: #1e1a28 !important; }

/* ── 21. Micro-interactions & Polish ────────────────────────── */

/* Smooth card entrance */
.su-card,
.su-stat-card,
.su-dash-widget {
    animation: su-card-enter .3s ease both;
}
@keyframes su-card-enter {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: none; }
}

/* Row stagger in tables */
.table > tbody > tr {
    animation: su-fade-in .25s ease both;
}
.table > tbody > tr:nth-child(1) { animation-delay: .04s; }
.table > tbody > tr:nth-child(2) { animation-delay: .07s; }
.table > tbody > tr:nth-child(3) { animation-delay: .10s; }
.table > tbody > tr:nth-child(4) { animation-delay: .13s; }
.table > tbody > tr:nth-child(5) { animation-delay: .16s; }
.table > tbody > tr:nth-child(n+6) { animation-delay: .19s; }

/* Quick link stagger */
.su-quick-link:nth-child(1) { animation-delay: .05s; }
.su-quick-link:nth-child(2) { animation-delay: .09s; }
.su-quick-link:nth-child(3) { animation-delay: .13s; }
.su-quick-link:nth-child(4) { animation-delay: .17s; }
.su-quick-link:nth-child(5) { animation-delay: .21s; }
.su-quick-link:nth-child(6) { animation-delay: .25s; }
.su-quick-link:nth-child(7) { animation-delay: .29s; }

/* Focus ring — premium */
:focus-visible {
    outline: 2px solid rgba(124,58,237,.7) !important;
    outline-offset: 2px !important;
    box-shadow: 0 0 0 4px rgba(124,58,237,.15) !important;
    border-radius: 6px;
}

/* Selection */
::selection {
    background: rgba(124,58,237,.2) !important;
    color: #7c3aed !important;
}

/* Custom scrollbar — more vibrant */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: rgba(124,58,237,.25);
    border-radius: 10px;
}
::-webkit-scrollbar-thumb:hover { background: rgba(124,58,237,.4); }

/* Skeleton shimmer */
.su-skeleton {
    background: linear-gradient(
        90deg,
        rgba(124,58,237,.06) 0%,
        rgba(124,58,237,.12) 40%,
        rgba(124,58,237,.06) 100%
    ) !important;
    background-size: 200% 100% !important;
    animation: su-shimmer 1.6s infinite ease-in-out !important;
    border-radius: 8px !important;
}

/* Spin */
.su-spin { animation: su-spin-anim .8s linear infinite; }
@keyframes su-spin-anim { to { transform: rotate(360deg); } }

/* ── 22. Responsive Refinements ─────────────────────────────── */
@media (max-width: 768px) {
    .su-topbar {
        padding: 0 14px !important;
        backdrop-filter: blur(20px) !important;
    }
    .su-content { padding: 14px 16px !important; }
    .su-stat-card {
        padding: 18px !important;
        border-radius: 16px !important;
    }
    .su-stat-value { font-size: 34px !important; }
    .su-card { border-radius: 16px !important; }
    .su-quick-link {
        min-width: 72px !important;
        padding: 12px 12px 10px !important;
        border-radius: 14px !important;
    }
    .su-quick-link-icon {
        width: 36px !important;
        height: 36px !important;
        font-size: 16px !important;
    }
    .su-flash { margin: 8px 14px 0 !important; border-radius: 12px !important; }
    .modal-content { border-radius: 18px !important; }
    .su-modal { border-radius: 18px !important; }
    .btn { border-radius: 9px !important; }
}

@media (max-width: 480px) {
    .su-stat-value { font-size: 28px !important; }
    .su-stat-card { padding: 16px !important; }
    .su-home-greeting { font-size: 20px !important; }
}

/* ── Print ──────────────────────────────────────────────────── */
@media print {
    .su-sidebar, .su-topbar, .su-ai-fab, #suRunningTimer,
    .su-btn-icon, .su-timer-chip { display: none !important; }
    .su-main-wrap.su-has-sidebar { margin-left: 0 !important; }
    .su-content { padding: 0 !important; }
    .su-card { box-shadow: none !important; border: 1px solid #ddd !important; }
}

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

/* ── 23. Auth Pages — Premium Edition ──────────────────────── */

/* Override auth form labels — keep them legible (not uppercase for auth) */
.su-auth-card .form-label {
    text-transform: none !important;
    letter-spacing: .01em !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--su-text) !important;
}

/* Auth card — elevated glassmorphism */
.su-auth-card {
    background: rgba(255,255,255,.96) !important;
    border-radius: 24px !important;
    border: 1px solid rgba(255,255,255,.9) !important;
    box-shadow:
        0 20px 60px rgba(0,0,0,.14),
        0 8px 24px rgba(124,58,237,.1),
        0 2px 8px rgba(0,0,0,.06) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    padding: 44px 42px !important;
}

/* Auth title — gradient heading */
.su-auth-title {
    background: linear-gradient(135deg, #1a1333 0%, #7c3aed 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    font-weight: 800 !important;
    font-size: 24px !important;
    letter-spacing: -0.025em !important;
    margin-bottom: 28px !important;
}

/* Auth logo wordmark */
.su-auth-wordmark {
    gap: 10px;
}
.su-logo-icon {
    width: 40px !important;
    height: 40px !important;
    border-radius: 12px !important;
    background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
    color: #fff !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 20px !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.4) !important;
}
.su-logo-text {
    font-weight: 800;
    font-size: 22px;
    background: linear-gradient(135deg, #7c3aed, #a855f7);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Auth tagline */
.su-auth-tagline {
    color: var(--su-text-muted) !important;
    font-size: 13px !important;
    font-weight: 400;
}

/* Auth submit button — full-width, gradient */
.su-auth-card .btn-primary.w-100 {
    padding: 12px 20px !important;
    font-size: 14.5px !important;
    font-weight: 700 !important;
    border-radius: 12px !important;
    letter-spacing: .01em;
    box-shadow: 0 6px 20px rgba(124,58,237,.45), 0 2px 6px rgba(124,58,237,.2) !important;
}

/* Auth OAuth buttons */
.su-oauth-btn {
    border-radius: 10px !important;
    padding: 10px 14px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    transition: all .2s ease !important;
    border: 1.5px solid rgba(124,58,237,.15) !important;
}
.su-oauth-btn:hover {
    background: rgba(124,58,237,.05) !important;
    border-color: rgba(124,58,237,.3) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.12) !important;
}

/* Auth divider */
.su-auth-divider {
    gap: 14px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: var(--su-text-light) !important;
    margin: 22px 0 !important;
}
.su-auth-divider::before,
.su-auth-divider::after {
    background: linear-gradient(90deg, transparent, rgba(124,58,237,.15), transparent) !important;
}

/* Auth footer */
.su-auth-footer {
    margin-top: 22px !important;
    font-size: 13px !important;
}
.su-auth-footer .su-link {
    font-weight: 600 !important;
    color: #7c3aed !important;
}

/* Auth feature chips at bottom */
.su-auth-feature {
    font-size: 12px !important;
    padding: 5px 12px !important;
    border-radius: 99px !important;
    background: rgba(255,255,255,.8) !important;
    border: 1px solid rgba(124,58,237,.15) !important;
    backdrop-filter: blur(8px) !important;
    transition: all .2s ease !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.06) !important;
}
.su-auth-feature:hover {
    background: rgba(255,255,255,.95) !important;
    border-color: rgba(124,58,237,.3) !important;
    transform: translateY(-1px) !important;
}

/* Auth blob animation enhancement */
.su-auth-blob {
    opacity: .25 !important;
    filter: blur(48px) !important;
}

/* Auth background — purple-to-indigo mesh gradient */
.su-auth-body {
    background:
        radial-gradient(ellipse at 30% 10%, rgba(124,58,237,.12) 0%, transparent 60%),
        radial-gradient(ellipse at 70% 90%, rgba(99,102,241,.1) 0%, transparent 60%),
        radial-gradient(ellipse at 80% 30%, rgba(236,72,153,.08) 0%, transparent 50%),
        #f4f3f8 !important;
}

/* Dark mode auth */
[data-theme="dark"] .su-auth-card {
    background: rgba(30,26,40,.95) !important;
    border-color: rgba(124,58,237,.15) !important;
    box-shadow:
        0 20px 60px rgba(0,0,0,.4),
        0 8px 24px rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .su-auth-title {
    background: linear-gradient(135deg, #e8e4f0 0%, #a78bfa 100%) !important;
    -webkit-background-clip: text !important; background-clip: text !important;
}
[data-theme="dark"] .su-auth-body {
    background:
        radial-gradient(ellipse at 30% 10%, rgba(124,58,237,.15) 0%, transparent 60%),
        radial-gradient(ellipse at 70% 90%, rgba(99,102,241,.12) 0%, transparent 60%),
        #0f0d17 !important;
}

/* ── 24. Task Rows — Premium Edition ────────────────────────── */
.su-task-row {
    padding: 11px 18px !important;
    border-bottom: 1px solid rgba(0,0,0,.04) !important;
    transition:
        background .12s ease,
        transform .1s ease,
        box-shadow .12s ease !important;
    position: relative;
}
.su-task-row:hover {
    background: rgba(124,58,237,.04) !important;
    transform: translateX(2px) !important;
    text-decoration: none !important;
}
.su-task-row-title {
    font-size: 13.5px !important;
    font-weight: 500 !important;
    color: var(--su-text) !important;
    transition: color .12s ease !important;
}
.su-task-row:hover .su-task-row-title {
    color: #7c3aed !important;
}

[data-theme="dark"] .su-task-row {
    border-bottom-color: rgba(255,255,255,.04) !important;
}
[data-theme="dark"] .su-task-row:hover {
    background: rgba(124,58,237,.07) !important;
}

/* ── 25. Home Hero — Premium Edition ───────────────────────── */
.su-home-hero {
    background: linear-gradient(135deg,
        rgba(124,58,237,.04) 0%,
        rgba(168,85,247,.03) 50%,
        rgba(255,255,255,0) 100%) !important;
    border: 1px solid rgba(124,58,237,.07) !important;
    border-radius: 20px !important;
    padding: 24px 28px !important;
    margin-bottom: 20px !important;
    backdrop-filter: blur(8px);
    box-shadow: 0 2px 12px rgba(124,58,237,.05) !important;
}

.su-home-greeting {
    font-size: 26px !important;
    font-weight: 800 !important;
    letter-spacing: -0.03em !important;
    line-height: 1.2 !important;
    color: var(--su-text) !important;
}

.su-home-sub {
    font-size: 14px !important;
    color: var(--su-text-muted) !important;
    margin-top: 4px !important;
    font-weight: 400;
}

[data-theme="dark"] .su-home-hero {
    background: linear-gradient(135deg,
        rgba(124,58,237,.08) 0%,
        rgba(168,85,247,.05) 50%,
        rgba(30,26,40,0) 100%) !important;
    border-color: rgba(124,58,237,.12) !important;
}

/* ── 26. Home Stat Foot ─────────────────────────────────────── */
.su-stat-foot {
    font-size: 11.5px !important;
    font-weight: 500 !important;
    margin-top: 10px !important;
    opacity: .85;
}

/* ── 27. Nav Badge (unread) ─────────────────────────────────── */
.su-nav-badge {
    background: linear-gradient(135deg, #ef4444, #f87171) !important;
    color: #fff !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    min-width: 16px !important;
    height: 16px !important;
    border-radius: 999px !important;
    padding: 0 4px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: auto !important;
    animation: su-notif-pulse 2.5s infinite !important;
    box-shadow: 0 0 0 2px #fff !important;
}
[data-theme="dark"] .su-nav-badge { box-shadow: 0 0 0 2px #1e1a28 !important; }

/* ── 28. Kanban Board — Premium Edition ─────────────────────── */
.su-kanban-col {
    background: rgba(124,58,237,.025) !important;
    border: 1.5px solid rgba(124,58,237,.08) !important;
    border-radius: 18px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,.04) !important;
    transition: box-shadow .2s ease, border-color .2s ease !important;
}
.su-kanban-col:hover {
    border-color: rgba(124,58,237,.15) !important;
    box-shadow: 0 4px 20px rgba(124,58,237,.06) !important;
}
.su-kanban-col-header {
    border-radius: 14px 14px 0 0 !important;
    border-bottom: 1.5px solid rgba(124,58,237,.08) !important;
    background: rgba(255,255,255,.5) !important;
    backdrop-filter: blur(8px) !important;
}
.su-kanban-card {
    border-radius: 12px !important;
    border: 1px solid rgba(0,0,0,.06) !important;
    background: #fff !important;
    box-shadow: 0 1px 4px rgba(0,0,0,.06), 0 0 0 0 rgba(124,58,237,.15) !important;
    transition: all .2s ease !important;
    position: relative;
    overflow: hidden;
}
.su-kanban-card:hover {
    border-color: rgba(124,58,237,.2) !important;
    box-shadow:
        0 6px 20px rgba(124,58,237,.1),
        0 2px 8px rgba(0,0,0,.07),
        0 0 0 1.5px rgba(124,58,237,.15) !important;
    transform: translateY(-2px) !important;
}
.su-kanban-card-add {
    border: 1.5px dashed rgba(124,58,237,.2) !important;
    border-radius: 10px !important;
    transition: all .15s ease !important;
    color: var(--su-text-muted) !important;
    font-size: 12.5px !important;
}
.su-kanban-card-add:hover {
    border-color: rgba(124,58,237,.4) !important;
    background: rgba(124,58,237,.04) !important;
    color: #7c3aed !important;
}

[data-theme="dark"] .su-kanban-col {
    background: rgba(30,26,40,.6) !important;
    border-color: rgba(124,58,237,.12) !important;
}
[data-theme="dark"] .su-kanban-card {
    background: #1e1a28 !important;
    border-color: rgba(124,58,237,.1) !important;
}
[data-theme="dark"] .su-kanban-card:hover {
    border-color: rgba(124,58,237,.25) !important;
    box-shadow: 0 6px 20px rgba(0,0,0,.2), 0 0 0 1.5px rgba(124,58,237,.2) !important;
}

/* ── 29. Nav Divider (Spaces header) ─────────────────────────── */
.su-nav-divider {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 16px 12px 4px !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: .1em !important;
    color: var(--su-text-light) !important;
}
.su-nav-divider::after {
    content: '' !important;
    flex: 1 !important;
    height: 1px !important;
    background: linear-gradient(90deg, rgba(124,58,237,.15) 0%, transparent 100%) !important;
}

/* ── 30. Timer Widget in Topbar ─────────────────────────────── */
.su-timer-widget {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    background: linear-gradient(135deg, rgba(124,58,237,.08), rgba(124,58,237,.04)) !important;
    border: 1.5px solid rgba(124,58,237,.2) !important;
    border-radius: 99px !important;
    padding: 5px 12px !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    transition: all .2s ease !important;
}
.su-timer-widget:hover {
    background: rgba(124,58,237,.12) !important;
    border-color: rgba(124,58,237,.35) !important;
}
.su-timer-dot {
    width: 7px !important;
    height: 7px !important;
    border-radius: 50% !important;
    background: #ef4444 !important;
    box-shadow: 0 0 0 0 rgba(239,68,68,.4) !important;
    animation: su-timer-dot-pulse 1.5s ease-in-out infinite !important;
    flex-shrink: 0 !important;
}
.su-timer-elapsed {
    font-variant-numeric: tabular-nums !important;
    letter-spacing: .02em !important;
    color: #7c3aed !important;
}
.su-timer-stop {
    background: none !important;
    border: none !important;
    padding: 0 !important;
    color: #ef4444 !important;
    font-size: 14px !important;
    line-height: 1 !important;
    transition: transform .15s ease !important;
    cursor: pointer !important;
}
.su-timer-stop:hover { transform: scale(1.2) !important; }

/* ── 31. Presence Strip ─────────────────────────────────────── */
.su-presence-strip {
    display: flex !important;
    align-items: center !important;
    gap: -6px !important;
}
.su-presence-avatar {
    width: 28px !important;
    height: 28px !important;
    border-radius: 50% !important;
    border: 2px solid #fff !important;
    margin-left: -6px !important;
    box-shadow: 0 0 0 1.5px rgba(124,58,237,.2) !important;
    transition: transform .15s ease, box-shadow .15s ease !important;
    object-fit: cover !important;
}
.su-presence-avatar:first-child { margin-left: 0 !important; }
.su-presence-avatar:hover {
    transform: translateY(-2px) scale(1.1) !important;
    box-shadow: 0 4px 12px rgba(124,58,237,.3) !important;
    z-index: 1 !important;
}
.su-presence-more {
    font-size: 10px !important;
    font-weight: 700 !important;
    background: rgba(124,58,237,.1) !important;
    color: #7c3aed !important;
    border-radius: 99px !important;
    padding: 2px 6px !important;
    margin-left: 4px !important;
    border: 1.5px solid rgba(124,58,237,.2) !important;
}

[data-theme="dark"] .su-presence-avatar { border-color: #1a1626 !important; }
[data-theme="dark"] .su-timer-widget {
    background: rgba(124,58,237,.12) !important;
    border-color: rgba(124,58,237,.25) !important;
}
