:root {
    /* Light theme - Tyga color palette */
    --color-bg: #fafafa;
    --color-surface: #ffffff;
    --color-surface-subtle: var(--color-surface-subtle);
    --color-border: #e1e5e9;
    --color-border-light: #f1f3f5;
    --color-text-primary: #0d1117;
    --color-text-secondary: #656d76;
    --color-text-muted: #8b949e;
    --color-accent: #292524;
    --color-accent-hover: #1c1917;
    --color-success: #1a7f37;
    --color-warning: #bf8700;
    --color-danger: #cf222e;
    --color-info: #292524;
    --color-brand: #1E3A5F;
    --color-brand-hover: #152C4A;
    --color-pink: var(--color-brand);
    --color-pink-hover: var(--color-brand-hover);
    
    /* Subtle shadows */
    --shadow-subtle: 0 1px 2px 0 rgb(0 0 0 / 0.03);
    --shadow-soft: 0 1px 3px 0 rgb(0 0 0 / 0.06), 0 1px 2px 0 rgb(0 0 0 / 0.04);
    --shadow-medium: 0 4px 6px -1px rgb(0 0 0 / 0.08), 0 2px 4px -2px rgb(0 0 0 / 0.04);
    
    /* Border radius */
    --radius: 6px;
    --radius-lg: 8px;
    --radius-xl: 12px;
    
    /* Spacing */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 12px;
    --spacing-lg: 16px;
    --spacing-xl: 20px;
    --spacing-2xl: 24px;
    --spacing-3xl: 32px;

    /* Legacy alias variables for compatibility */
    --primary-color: #292524;
    --secondary-color: #656d76;
    --background-color: #fafafa;
    --text-color: #0d1117;
    --border-color: #e1e5e9;
    --sidebar-bg: #ffffff;
    --card-bg: #ffffff;
    --success-color: #1a7f37;
    --warning-color: #bf8700;
    --error-color: #cf222e;

    /* Widget variables */
    --bg-primary: #ffffff;
    --bg-secondary: #f9fafb;
    --text-primary: #0d1117;
    --text-secondary: #656d76;
    --hover-bg: #f9fafb;
}

/* Dark theme variables */
[data-theme="dark"] {
    --color-bg: #0d1117;
    --color-surface: #161b22;
    --color-surface-subtle: #1c2128;
    --color-border: #30363d;
    --color-border-light: #21262d;
    --color-text-primary: #f0f6fc;
    --color-text-secondary: #8b949e;
    --color-text-muted: #656d76;
    --color-accent: #238636;
    --color-accent-hover: #2ea043;
    --color-success: #3fb950;
    --color-warning: #d29922;
    --color-danger: #f85149;
    --color-info: #58a6ff;
    --color-brand: #1E3A5F;
    --color-brand-hover: #152C4A;
    --color-pink: var(--color-brand);
    --color-pink-hover: var(--color-brand-hover);

    /* Legacy alias overrides */
    --primary-color: #238636;
    --secondary-color: #8b949e;
    --background-color: #0d1117;
    --text-color: #f0f6fc;
    --border-color: #30363d;
    --sidebar-bg: #161b22;
    --card-bg: #161b22;

    /* Widget variable overrides */
    --bg-primary: #161b22;
    --bg-secondary: #1c2128;
    --text-primary: #f0f6fc;
    --text-secondary: #8b949e;
    --hover-bg: #1c2128;

    /* Enhanced shadows for dark mode */
    --shadow-subtle: 0 1px 2px 0 rgb(0 0 0 / 0.3);
    --shadow-soft: 0 1px 3px 0 rgb(0 0 0 / 0.4), 0 1px 2px 0 rgb(0 0 0 / 0.3);
    --shadow-medium: 0 4px 6px -1px rgb(0 0 0 / 0.5), 0 2px 4px -2px rgb(0 0 0 / 0.4);
}

/* Auto theme based on system preference */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --color-bg: #0d1117;
        --color-surface: #161b22;
        --color-surface-subtle: #1c2128;
        --color-border: #30363d;
        --color-border-light: #21262d;
        --color-text-primary: #f0f6fc;
        --color-text-secondary: #8b949e;
        --color-text-muted: #656d76;
        --color-accent: #238636;
        --color-accent-hover: #2ea043;
        --color-success: #3fb950;
        --color-warning: #d29922;
        --color-danger: #f85149;
        --color-info: #58a6ff;
        --color-brand: #1E3A5F;
        --color-brand-hover: #152C4A;
        --color-pink: var(--color-brand);
        --color-pink-hover: var(--color-brand-hover);

        /* Legacy alias overrides */
        --primary-color: #238636;
        --secondary-color: #8b949e;
        --background-color: #0d1117;
        --text-color: #f0f6fc;
        --border-color: #30363d;
        --sidebar-bg: #161b22;
        --card-bg: #161b22;

        /* Widget variable overrides */
        --bg-primary: #161b22;
        --bg-secondary: #1c2128;
        --text-primary: #f0f6fc;
        --text-secondary: #8b949e;
        --hover-bg: #1c2128;

        --shadow-subtle: 0 1px 2px 0 rgb(0 0 0 / 0.3);
        --shadow-soft: 0 1px 3px 0 rgb(0 0 0 / 0.4), 0 1px 2px 0 rgb(0 0 0 / 0.3);
        --shadow-medium: 0 4px 6px -1px rgb(0 0 0 / 0.5), 0 2px 4px -2px rgb(0 0 0 / 0.4);
    }
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* Wizard buttons — pill style for ALL wizards */
.wizard-footer .btn,
.wizard-actions .btn,
.wizard-nav-left .btn,
.wizard-nav-right .btn,
#wizardCancelBtn,
#wizardPreviousBtn,
#wizardNextBtn,
#wizardCompleteBtn {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border: 1px solid var(--color-border) !important;
    border-radius: 20px !important;
    padding: 8px 16px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    cursor: pointer;
    transition: all 0.15s ease;
    box-shadow: none !important;
    transform: none !important;
}

.wizard-footer .btn:hover,
.wizard-actions .btn:hover,
.wizard-nav-left .btn:hover,
.wizard-nav-right .btn:hover,
#wizardCancelBtn:hover,
#wizardPreviousBtn:hover,
#wizardNextBtn:hover,
#wizardCompleteBtn:hover {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-text-muted) !important;
}

/* Primary wizard actions — navy filled pills */
#wizardNextBtn,
#wizardCompleteBtn {
    background: #1E3A5F !important;
    color: #ffffff !important;
    border-color: #1E3A5F !important;
}

#wizardNextBtn:hover,
#wizardCompleteBtn:hover {
    background: #152C4A !important;
    border-color: #152C4A !important;
    color: #ffffff !important;
}

#wizardCompleteBtn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Global link color — no blue anywhere in the dashboard */
.dashboard-container a,
.dashboard-container a:link,
.dashboard-container a:visited,
.dashboard-container a:active,
.content-section a,
.content-section a:link,
.content-section a:visited,
.content-section a:active,
a[href^="mailto:"],
a[href^="tel:"],
a[href^="http"] {
    color: var(--color-text-primary) !important;
    text-decoration: none;
}

.dashboard-container a:hover,
.content-section a:hover,
a[href^="mailto:"]:hover,
a[href^="tel:"]:hover,
a[href^="http"]:hover {
    color: #1E3A5F !important;
    text-decoration: underline;
}

/* Override any remaining blue focus outlines */
*:focus-visible {
    outline-color: #1E3A5F;
}

input:focus, select:focus, textarea:focus {
    border-color: #1E3A5F !important;
    box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.12) !important;
}

/* ========================================
   PREVENT FLASH OF OLD CONTENT (FOUC)
   Hide legacy/old content until JS replaces it
   ======================================== */

/* Hide legacy overview section content completely */
#overview-section > .page-header,
#overview-section > .stats-grid,
#overview-section > .content-grid {
    display: none !important;
}

/* Hide legacy meetings section placeholder */
#meetings-section > .page-header,
#meetings-section > .loading {
    display: none !important;
}

/* Hide legacy bookings section placeholder */
#bookings-section > .page-header,
#bookings-section > .loading {
    display: none !important;
}


body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    background-color: var(--color-bg);
    color: var(--color-text-primary);
    line-height: 1.5;
    font-size: 14px;
    font-weight: 400;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

.dashboard-container {
    display: flex;
    min-height: 100vh;
    background-color: var(--color-bg);
}

/* Sidebar - Ultra clean and minimal */
.sidebar {
    width: 280px;
    background: var(--color-surface);
    border-right: 1px solid var(--color-border-light);
    display: flex;
    flex-direction: column;
    position: fixed;
    height: 100vh;
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 100;
    transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
}

.sidebar-logo {
    height: 40px;
    width: auto;
    opacity: 0.95;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

[data-theme="dark"] .sidebar-logo {
    filter: brightness(0) invert(1);
}

/* Sidebar Minimizer Button */
.sidebar-minimizer {
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    color: var(--color-text-secondary);
    cursor: pointer;
    padding: 8px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    opacity: 0.9;
    position: fixed;
    top: var(--spacing-xl);
    left: 264px;
    z-index: 1001;
    width: 32px;
    height: 32px;
    box-shadow: var(--shadow-soft);
}


/* Choices.js Dark Mode Support */
[data-theme="dark"] .choices,
.dark-theme .choices {
    background-color: var(--color-surface);
    border-color: var(--color-border-light);
}

[data-theme="dark"] .choices__inner,
.dark-theme .choices__inner {
    background-color: var(--color-surface);
    border-color: var(--color-border-light);
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices__input,
.dark-theme .choices__input {
    background-color: transparent;
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices__input::placeholder,
.dark-theme .choices__input::placeholder {
    color: var(--color-text-secondary);
}

[data-theme="dark"] .choices__list--dropdown,
.dark-theme .choices__list--dropdown {
    background-color: var(--color-surface);
    border-color: var(--color-border-light);
    box-shadow: var(--shadow-medium);
}

[data-theme="dark"] .choices__item,
.dark-theme .choices__item {
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices__item--choice,
.dark-theme .choices__item--choice {
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices__item--choice:hover,
[data-theme="dark"] .choices__item--choice.is-highlighted,
.dark-theme .choices__item--choice:hover,
.dark-theme .choices__item--choice.is-highlighted {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices__item--choice.is-selected,
.dark-theme .choices__item--choice.is-selected {
    background-color: var(--color-accent);
    color: white;
}

[data-theme="dark"] .choices__item--selectable,
.dark-theme .choices__item--selectable {
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices__item--selectable:hover,
.dark-theme .choices__item--selectable:hover {
    background-color: var(--color-border-light);
}

[data-theme="dark"] .choices__placeholder,
.dark-theme .choices__placeholder {
    color: var(--color-text-secondary);
}

[data-theme="dark"] .choices__button,
.dark-theme .choices__button {
    background-color: transparent;
    border-color: var(--color-border-light);
    color: var(--color-text-secondary);
}

[data-theme="dark"] .choices__button:hover,
.dark-theme .choices__button:hover {
    color: var(--color-text-primary);
}

[data-theme="dark"] .choices[data-type*="select-one"] .choices__inner,
.dark-theme .choices[data-type*="select-one"] .choices__inner {
    background-color: var(--color-surface);
}

[data-theme="dark"] .choices[data-type*="select-multiple"] .choices__inner,
.dark-theme .choices[data-type*="select-multiple"] .choices__inner {
    background-color: var(--color-surface);
}

[data-theme="dark"] .choices__item--choice[data-choice-disabled],
.dark-theme .choices__item--choice[data-choice-disabled] {
    color: var(--color-text-secondary);
    opacity: 0.5;
}

[data-theme="dark"] .theme-toggle .moon-icon {
    display: none;
}

/* Auto theme icons based on system preference */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .theme-toggle .sun-icon {
        display: block;
    }
    
    :root:not([data-theme="light"]) .theme-toggle .moon-icon {
        display: none;
    }
}

.sidebar-minimizer:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
    opacity: 1;
    transform: scale(1.1);
    box-shadow: var(--shadow-medium);
}

.sidebar-minimizer:active {
    transform: scale(0.95);
}

.sidebar-minimizer svg {
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    width: 14px;
    height: 14px;
}

/* Minimized Sidebar State */
.sidebar.minimized {
    width: 72px;
    overflow: visible;
}

.sidebar.minimized .sidebar-header {
    justify-content: center;
    padding: var(--spacing-xl) var(--spacing-md);
    position: relative;
}

.sidebar.minimized .sidebar-logo {
    opacity: 1;
    transform: translateX(-50%) scale(0.6);
    pointer-events: auto;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) scale(0.6);
    width: 55px;
    height: auto;
}

.sidebar.minimized .sidebar-minimizer {
    left: 56px;
}

.sidebar.minimized .sidebar-minimizer svg {
    transform: rotate(180deg);
}

.sidebar.minimized .nav-section {
    margin-bottom: 0 !important;
}

.sidebar.minimized .nav-section.collapsible.collapsed .nav-item {
    display: none !important;
}

.sidebar.minimized .nav-section-title {
    opacity: 0;
    visibility: hidden;
    height: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Section icons visible in minimised sidebar when section is collapsed */

.sidebar.minimized .nav-section.collapsed .nav-section-title {
    opacity: 1;
    visibility: visible;
    height: auto;
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: center;
}

.sidebar.minimized .nav-section.collapsed .nav-section-title span,
.sidebar.minimized .nav-section.collapsed .nav-section-title .collapse-icon {
    display: none;
}

.sidebar.minimized .nav-section.collapsed .nav-section-title .section-icon {
    display: flex;
    font-size: 18px;
    color: var(--color-text-muted, #8b949e);
    cursor: pointer;
    padding: 10px;
    border-radius: 6px;
    transition: all 0.15s ease;
    position: relative;
}

.sidebar.minimized .nav-section.collapsed .nav-section-title .section-icon:hover {
    background: var(--color-border-light, #f1f3f5);
    color: var(--color-text-primary, #24292f);
}

/* Tooltip for collapsed section icons in minimised sidebar */
.sidebar.minimized .nav-section.collapsed .nav-section-title .section-icon:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 12px;
    background: rgba(26, 26, 26, 0.95);
    color: #ffffff;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    z-index: 10001;
    pointer-events: none;
}

.sidebar.minimized .nav-item {
    justify-content: center;
    padding: var(--spacing-md);
    margin: var(--spacing-xs) var(--spacing-sm);
    position: relative;
    display: flex;
    align-items: center;
    min-height: 40px;
}

.sidebar.minimized .nav-item span {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    width: 0;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar.minimized .nav-item i {
    margin-right: 0;
    width: 18px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.sidebar.minimized .nav-item .nav-icon {
    margin-right: 0;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.sidebar.minimized .user-info {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    width: 0;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar.minimized .user-profile {
    justify-content: center;
    padding: var(--spacing-md);
    position: relative;
}

.sidebar.minimized .user-avatar {
    margin-right: 0;
    margin-bottom: 0;
    width: 32px;
    height: 32px;
    min-width: 32px;
    min-height: 32px;
    flex-shrink: 0;
}

/* Tooltip for minimized items */
.sidebar.minimized .nav-item {
    position: relative;
}

.sidebar.minimized .nav-item:hover::after {
    content: attr(data-tooltip);
    position: absolute;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 12px;
    background: rgba(26, 26, 26, 0.95);
    color: #ffffff;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    z-index: 10001;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
    pointer-events: none;
    backdrop-filter: blur(8px);
    animation: tooltipFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar.minimized .nav-item:hover::before {
    content: '';
    position: absolute;
    left: 100%;
    top: 50%;
    transform: translateY(-50%);
    margin-left: 6px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 6px 6px 0;
    border-color: transparent rgba(26, 26, 26, 0.95) transparent transparent;
    z-index: 10001;
    pointer-events: none;
    animation: tooltipFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes tooltipFadeIn {
    from {
        opacity: 0;
        transform: translateY(-50%) translateX(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(-50%) translateX(0);
    }
}

/* Ensure tooltips work for user profile too */
.sidebar.minimized .user-profile:hover::after {
    content: attr(data-tooltip);
    position: fixed;
    left: 84px;
    bottom: 20px;
    background: rgba(26, 26, 26, 0.95);
    color: #ffffff;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    z-index: 10001;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
    pointer-events: none;
    backdrop-filter: blur(8px);
    animation: tooltipFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar.minimized .user-profile:hover::before {
    content: '';
    position: fixed;
    left: 78px;
    bottom: 32px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 6px 6px 0;
    border-color: transparent rgba(26, 26, 26, 0.95) transparent transparent;
    z-index: 10001;
    pointer-events: none;
    animation: tooltipFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar-nav {
    flex: 1;
    padding: var(--spacing-lg) 0;
    transition: opacity 0.15s ease-out;
}

/* Sidebar content transition states */
.sidebar-nav.transitioning-out {
    opacity: 0;
    pointer-events: none;
}

.sidebar-nav.transitioning-in {
    opacity: 0;
}

.nav-section {
    margin-bottom: var(--spacing-2xl);
}

.nav-section:last-child {
    margin-bottom: 0;
}

.nav-section-title {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    padding: 0 var(--spacing-xl);
    margin-bottom: var(--spacing-sm);
}

/* Section icons hidden in expanded sidebar */
.nav-section-title .section-icon {
    display: none;
}

/* Collapsible Nav Sections */
.nav-section.collapsible .nav-section-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    padding-right: var(--spacing-lg);
    transition: color 0.2s ease;
}

.nav-section.collapsible .nav-section-title:hover {
    color: var(--color-text-secondary);
}

.nav-section.collapsible .collapse-icon {
    font-size: 10px;
    transition: transform 0.25s ease;
    opacity: 0.6;
}

.nav-section.collapsible.collapsed .collapse-icon {
    transform: rotate(-90deg);
}

.nav-section.collapsible .nav-item {
    max-height: 50px;
    opacity: 1;
    overflow: hidden;
    transition: max-height 0.25s ease, opacity 0.2s ease, margin 0.25s ease, padding 0.25s ease;
}

.nav-section.collapsible.collapsed .nav-item {
    max-height: 0;
    opacity: 0;
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
}

.nav-item {
    display: flex;
    align-items: center;
    padding: var(--spacing-sm) var(--spacing-xl);
    color: var(--color-text-secondary);
    text-decoration: none;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 14px;
    font-weight: 400;
    border-radius: 0;
    margin: 0 var(--spacing-sm);
    border-radius: var(--radius);
    outline: none;
    border: none;
}

.nav-item:focus,
.nav-item:focus-visible {
    outline: none;
    box-shadow: none;
}

.nav-item:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

.nav-item.active {
    background-color: var(--color-brand) !important;
    color: #ffffff !important;
    font-weight: 500;
}

/* Nav item icons - supports both <i> (font icons) and <img> (image icons) */
.nav-item i {
    width: 18px;
    margin-right: var(--spacing-md);
    font-size: 14px;
    opacity: 0.8;
    text-align: center;
}

.nav-item .nav-icon {
    width: 20px;
    height: 20px;
    margin-right: var(--spacing-md);
    opacity: 0.7;
    object-fit: contain;
    flex-shrink: 0;
    transition: all 0.15s ease;
}

.nav-item:hover .nav-icon {
    opacity: 1;
}

.nav-item.active .nav-icon {
    opacity: 1;
    filter: invert(1); /* Invert icon colors: dark strokes become white, white fills become dark to match active bg */
}

/* Dark mode: invert dark-stroke icons so they're visible on dark sidebar */
[data-theme="dark"] .nav-item:not(.active) .nav-icon {
    filter: invert(0.85);
    opacity: 0.85;
}

.nav-item.active i,
.nav-item.active span {
    opacity: 1;
    color: #ffffff !important;
}

.nav-item:hover i {
    opacity: 1;
}

.nav-item span {
    flex: 1;
}

.sidebar-footer {
    padding: var(--spacing-lg) var(--spacing-xl);
    border-top: 1px solid var(--color-border-light);
}

.user-profile {
    display: flex;
    align-items: center;
    padding: var(--spacing-md);
    border-radius: var(--radius-lg);
    transition: all 0.15s ease;
}

.user-profile.clickable {
    cursor: pointer;
}

.user-profile.clickable:hover {
    background-color: var(--color-border-light);
    transform: translateY(-1px);
    box-shadow: var(--shadow-subtle);
}

.user-profile.clickable:active {
    transform: translateY(0);
    box-shadow: none;
}

.user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 13px;
    margin-right: var(--spacing-md);
    box-shadow: var(--shadow-subtle);
    flex-shrink: 0;
    min-width: 32px;
    min-height: 32px;
}

.user-info {
    flex: 1;
    min-width: 0;
}

.user-name {
    font-weight: 500;
    font-size: 13px;
    color: var(--color-text-primary);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-email {
    font-size: 11px;
    color: var(--color-text-muted);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Main Content - Spacious and breathable */
.main-content {
    flex: 1 0 auto;
    margin-left: 280px;
    padding: var(--spacing-3xl);
    max-width: calc(100vw - 280px);
    background-color: var(--color-bg);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}


/* Main content adjustment when sidebar is minimized */
.dashboard-container:has(.sidebar.minimized) .main-content {
    margin-left: 72px;
    max-width: calc(100vw - 72px);
}

.page-header {
    margin-bottom: var(--spacing-3xl);
}

.page-title {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.page-subtitle {
    color: var(--color-text-secondary);
    font-size: 14px;
    font-weight: 400;
    line-height: 1.4;
}

/* ========================================
   DASHBOARD WELCOME HEADER
   ======================================== */

.dashboard-welcome-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-xl) 0;
}

.welcome-left {
    flex: 1;
}

.welcome-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-xs) 0;
    letter-spacing: -0.02em;
}

.welcome-subtitle {
    color: var(--color-text-secondary);
    font-size: 15px;
    margin: 0;
}

.welcome-right {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.btn-add-widget {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: #10b981;
    border: none;
    color: white;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.btn-add-widget:hover {
    background: #059669;
    transform: scale(1.05);
}

.btn-open-room {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
    padding: 10px 20px;
    border-radius: 20px;
    font-weight: 500;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.btn-open-room:hover {
    background: var(--color-surface-subtle);
    border-color: var(--color-text-muted);
}

.btn-invite-member {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    color: var(--color-text-primary);
    padding: 10px 20px;
    border-radius: 20px;
    font-weight: 500;
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.btn-invite-member:hover {
    background: var(--color-surface-subtle);
    border-color: var(--color-text-muted);
}

/* Dashboard Hint Row */
.dashboard-hint-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-xl);
}

.dashboard-hint {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.hint-icon {
    font-size: 20px;
}

.hint-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.hint-text strong {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.hint-text span {
    font-size: 13px;
    color: var(--color-text-secondary);
}

.btn-reset-layout {
    background: none;
    border: none;
    color: var(--color-text-secondary);
    font-size: 13px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    border-radius: 6px;
    transition: all 0.2s ease;
}

.btn-reset-layout:hover {
    background: var(--color-border-light);
    color: var(--color-text-primary);
}

@media (max-width: 768px) {
    .dashboard-welcome-header {
        flex-direction: column;
        gap: var(--spacing-lg);
    }

    .welcome-right {
        width: 100%;
        justify-content: flex-start;
    }

    .dashboard-hint-row {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
}

/* Content Sections */
.content-section {
    display: none;
}

.content-section.active {
    display: block;
}

/* Stats Cards - Compact Anthropic Design */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.stat-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
    text-align: center;
}

.stat-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.stat-header {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--spacing-sm);
}

.stat-title {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-align: center;
    margin-bottom: var(--spacing-xs);
}

.stat-icon {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    border-radius: var(--radius);
    opacity: 0.8;
    margin: 0 auto var(--spacing-sm) auto;
}

.stat-icon.primary {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.stat-icon.success {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.stat-icon.warning {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.stat-icon.danger {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.stat-value {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.02em;
    line-height: 1.1;
}

.stat-change {
    font-size: 10px;
    font-weight: 500;
    color: var(--color-text-muted);
}

.stat-change.positive {
    color: var(--color-success);
}

.stat-change.negative {
    color: var(--color-danger);
}

/* Content Grid */
.content-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--spacing-xl);
}

.content-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
    transition: all 0.15s ease;
}

.content-card:hover {
    box-shadow: var(--shadow-soft);
}

.card-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.card-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.card-body {
    padding: var(--spacing-xl);
}

/* Loading States - Elegant */
.loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
    color: var(--color-text-muted);
    font-size: 14px;
    flex-direction: column;
    gap: var(--spacing-md);
}

.loading-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
    text-align: center;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.loading-spinner {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--spacing-xl);
}

.loading-state h3 {
    font-size: 16px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.01em;
}

.loading-state p {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin: 0;
}

.spinner {
    width: 20px;
    height: 20px;
    border: 2px solid var(--color-border-light);
    border-top: 2px solid var(--color-accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Empty States - Minimal and friendly */
.empty-state {
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
    color: var(--color-text-muted);
}

.empty-state i {
    font-size: 40px;
    margin-bottom: var(--spacing-lg);
    opacity: 0.3;
    color: var(--color-text-muted);
}

.empty-state h3 {
    font-size: 16px;
    font-weight: 500;
    margin-bottom: var(--spacing-xs);
    color: var(--color-text-secondary);
}

.empty-state p {
    font-size: 14px;
    color: var(--color-text-muted);
    line-height: 1.4;
}

/* Booking List - Compact and minimal */
.booking-list {
    list-style: none;
}

.booking-item {
    display: flex;
    align-items: center;
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--color-border-light);
    transition: background-color 0.15s ease;
}

.booking-item:hover {
    background-color: var(--color-border-light);
    margin: 0 calc(-1 * var(--spacing-lg));
    padding-left: var(--spacing-lg);
    padding-right: var(--spacing-lg);
    border-radius: var(--radius);
}

.booking-item:last-child {
    border-bottom: none;
}

.booking-time {
    font-size: 11px;
    font-weight: 500;
    color: var(--color-text-muted);
    min-width: 60px;
    font-variant-numeric: tabular-nums;
}

.booking-details {
    flex: 1;
    margin-left: var(--spacing-md);
}

.booking-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 2px;
    line-height: 1.3;
}

.booking-attendee {
    font-size: 11px;
    color: var(--color-text-secondary);
    line-height: 1.3;
}

.booking-status {
    padding: 2px 6px;
    border-radius: var(--radius);
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.booking-status.confirmed {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.booking-status.pending {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.booking-status.completed {
    background-color: var(--color-border-light);
    color: var(--color-text-secondary);
}

.booking-status.cancelled {
    background-color: #fef2f2;
    color: var(--color-danger);
}

/* ========================================
   TOP NAVIGATION COMPONENT
   ======================================== */

/* Top Navigation Container */
.top-navigation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg) 5;
    padding-bottom: 2px;
    margin-bottom: var(--spacing-2xl);
    border-bottom: 1px solid var(--color-border-light);
    background: var(--color-bg);
    position: sticky;
    top: 0;
    z-index: 100;
    backdrop-filter: blur(8px);
}

/* Breadcrumb Section */
.nav-breadcrumb {
    flex-shrink: 0;
    min-width: 0;
}

.breadcrumb-items {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 14px;
}

.breadcrumb-item {
    color: var(--color-text-secondary);
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.breadcrumb-item.active {
    color: var(--color-text-primary);
    font-weight: 600;
}

.breadcrumb-separator {
    color: var(--color-text-muted);
    font-size: 12px;
    opacity: 0.6;
}

/* Navigation Actions */
.nav-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    flex-shrink: 0;
}

/* Theme Toggle Button in Top Nav */
.nav-actions .theme-toggle {
    position: relative;
    width: 40px;
    height: 40px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    color: var(--color-text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 16px;
    flex-shrink: 0;
    box-shadow: none;
    z-index: auto;
}

.nav-actions .theme-toggle:hover {
    background: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
    transform: translateY(-1px);
    box-shadow: var(--shadow-subtle);
}

.nav-actions .theme-toggle:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.nav-actions .theme-toggle svg {
    position: absolute;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    width: 18px;
    height: 18px;
}

.nav-actions .theme-toggle .sun-icon {
    opacity: 0;
    transform: rotate(-90deg) scale(0.8);
}

.nav-actions .theme-toggle .moon-icon {
    opacity: 1;
    transform: rotate(0deg) scale(1);
}

/* Dark theme icon states for top nav button */
[data-theme="dark"] .nav-actions .theme-toggle .sun-icon {
    opacity: 1;
    transform: rotate(0deg) scale(1);
}

[data-theme="dark"] .nav-actions .theme-toggle .moon-icon {
    opacity: 0;
    transform: rotate(90deg) scale(0.8);
}

/* Auto theme icons based on system preference for top nav */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .nav-actions .theme-toggle .sun-icon {
        opacity: 1;
        transform: rotate(0deg) scale(1);
    }
    
    :root:not([data-theme="light"]) .nav-actions .theme-toggle .moon-icon {
        opacity: 0;
        transform: rotate(90deg) scale(0.8);
    }
}

/* Navigation Widgets */
.nav-widget {
    position: relative;
    display: flex;
    align-items: center;
}

/* Widget Triggers */
.widget-trigger {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    min-height: 40px;
    position: relative;
}

.widget-trigger:hover {
    background: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
    transform: translateY(-1px);
    box-shadow: var(--shadow-subtle);
}

.widget-trigger:focus,
.widget-trigger.active {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.widget-trigger i {
    font-size: 16px;
    opacity: 0.8;
}

.widget-trigger.active i {
    opacity: 1;
}

/* User Trigger Specific */
.user-trigger {
    padding: var(--spacing-sm) var(--spacing-md);
    min-width: 120px;
}

.user-avatar-small {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 11px;
    flex-shrink: 0;
}

.user-name-small {
    font-size: 13px;
    font-weight: 500;
    color: inherit;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 80px;
}

.user-trigger i {
    font-size: 12px;
    margin-left: auto;
    transition: transform 0.2s ease;
}

.user-trigger.active i {
    transform: rotate(180deg);
}

/* Session Timer Widget */
.session-timer-widget {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md) var(--spacing-lg);
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    box-shadow: var(--shadow-subtle);
    min-width: 180px;
    transition: all 0.15s ease;
}

.session-timer-widget:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.session-timer-widget.warning {
    border-color: var(--color-warning);
    background: linear-gradient(135deg, #fffbeb 0%, var(--color-surface) 100%);
}

.session-timer-widget.danger {
    border-color: var(--color-danger);
    background: linear-gradient(135deg, #fef2f2 0%, var(--color-surface) 100%);
}

.widget-icon {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: 14px;
    background-color: var(--color-border-light);
    border-radius: var(--radius);
    flex-shrink: 0;
}

.session-timer-widget.warning .widget-icon {
    color: var(--color-warning);
    background-color: #fffbeb;
}

.session-timer-widget.danger .widget-icon {
    color: var(--color-danger);
    background-color: #fef2f2;
}

.widget-content {
    flex: 1;
    min-width: 0;
}

.widget-label {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 2px;
    line-height: 1;
}

.widget-value {
    font-size: 13px;
    font-weight: 700;
    color: var(--color-text-primary);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
    line-height: 1;
}

.session-timer-widget.warning .widget-value {
    color: var(--color-warning);
}

.session-timer-widget.danger .widget-value {
    color: var(--color-danger);
}

/* Notification Badge */
.notification-badge {
    position: absolute;
    top: -6px;
    right: -6px;
    background: var(--color-danger);
    color: white;
    font-size: 10px;
    font-weight: 600;
    padding: 2px 6px;
    border-radius: 10px;
    min-width: 18px;
    height: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 2px 4px rgba(207, 34, 46, 0.3);
    animation: pulse-badge 2s infinite;
}

@keyframes pulse-badge {
    0% {
        box-shadow: 0 2px 4px rgba(207, 34, 46, 0.3);
    }
    50% {
        box-shadow: 0 2px 8px rgba(207, 34, 46, 0.5);
    }
    100% {
        box-shadow: 0 2px 4px rgba(207, 34, 46, 0.3);
    }
}

/* Widget Dropdowns */
.widget-dropdown {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-medium);
    min-width: 280px;
    max-width: 400px;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px) scale(0.95);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    overflow: hidden;
}

.widget-dropdown.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0) scale(1);
}

.widget-dropdown::before {
    content: '';
    position: absolute;
    top: -6px;
    right: 20px;
    width: 12px;
    height: 12px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-bottom: none;
    border-right: none;
    transform: rotate(45deg);
    z-index: 1001;
}

/* Dropdown Header */
.dropdown-header {
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.dropdown-header h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.mark-all-read {
    background: none;
    border: none;
    color: var(--color-accent);
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    padding: var(--spacing-xs) var(--spacing-sm);
    border-radius: var(--radius);
    transition: all 0.15s ease;
}

.mark-all-read:hover {
    background: var(--color-border-light);
    color: var(--color-accent-hover);
}

/* User Info Header */
.user-info-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.user-info-header.clickable {
    cursor: pointer;
    transition: background 0.2s ease;
}

.user-info-header.clickable:hover {
    background: linear-gradient(180deg, #f0f4f8 0%, #e8ecf0 100%);
}

[data-theme="dark"] .user-info-header.clickable:hover {
    background: linear-gradient(180deg, #2a2a2a 0%, #252525 100%);
}

.user-info-header .user-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 16px;
    flex-shrink: 0;
    box-shadow: var(--shadow-subtle);
}

.user-details {
    flex: 1;
    min-width: 0;
}

.user-details .user-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: 2px;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-details .user-email {
    font-size: 12px;
    color: var(--color-text-muted);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Dropdown Body */
.dropdown-body {
    padding: var(--spacing-sm) 0;
    max-height: 300px;
    overflow-y: auto;
}

/* Dropdown Footer */
.dropdown-footer {
    padding: var(--spacing-md) var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
    background: var(--color-border-light);
}

.view-all-link {
    color: var(--color-accent);
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s ease;
}

.view-all-link:hover {
    color: var(--color-accent-hover);
}

/* Notifications List */
.notifications-list {
    display: flex;
    flex-direction: column;
}

.empty-notifications {
    text-align: center;
    padding: var(--spacing-2xl) var(--spacing-lg);
    color: var(--color-text-muted);
}

.empty-notifications i {
    font-size: 32px;
    margin-bottom: var(--spacing-md);
    opacity: 0.5;
}

.empty-notifications p {
    font-size: 13px;
    margin: 0;
}

.notification-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid var(--color-border-light);
    transition: all 0.15s ease;
    position: relative;
    cursor: pointer;
}

.notification-item:hover {
    background: var(--color-border-light);
}

.notification-item:last-child {
    border-bottom: none;
}

.notification-item.unread {
    background: linear-gradient(90deg, #f0f9ff 0%, var(--color-surface) 100%);
}

.notification-icon {
    width: 32px;
    height: 32px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
    margin-top: 2px;
}

.notification-icon.booking {
    background: #f0fdf4;
    color: var(--color-success);
}

.notification-icon.payment {
    background: #f0f9ff;
    color: var(--color-info);
}

.notification-icon.system {
    background: var(--color-surface-subtle);
    color: var(--color-text-muted);
}

.notification-content {
    flex: 1;
    min-width: 0;
}

.notification-title {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    line-height: 1.3;
}

.notification-message {
    font-size: 12px;
    color: var(--color-text-secondary);
    line-height: 1.3;
    margin-bottom: var(--spacing-xs);
}

.notification-time {
    font-size: 11px;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

.unread-indicator {
    position: absolute;
    top: 50%;
    right: var(--spacing-lg);
    transform: translateY(-50%);
    width: 8px;
    height: 8px;
    background: var(--color-info);
    border-radius: 50%;
    flex-shrink: 0;
}

/* Quick Actions List */
.quick-actions-list {
    display: flex;
    flex-direction: column;
    padding: var(--spacing-sm) 0;
}

.quick-action-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.15s ease;
    border-radius: 0;
}

.quick-action-item:hover {
    background: var(--color-border-light);
    color: var(--color-text-primary);
}

.quick-action-item i {
    width: 16px;
    font-size: 14px;
    color: currentColor;
    opacity: 0.8;
    flex-shrink: 0;
}

.quick-action-item:hover i {
    opacity: 1;
}

/* User Menu List */
.user-menu-list {
    display: flex;
    flex-direction: column;
    padding: var(--spacing-sm) 0;
}

.user-menu-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-md) var(--spacing-lg);
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    transition: all 0.15s ease;
    border-radius: 0;
}

.user-menu-item:hover {
    background: var(--color-border-light);
    color: var(--color-text-primary);
}

.user-menu-item i {
    width: 16px;
    font-size: 14px;
    color: currentColor;
    opacity: 0.8;
    flex-shrink: 0;
}

.user-menu-item:hover i {
    opacity: 1;
}

.logout-item {
    color: var(--color-danger);
}

.logout-item:hover {
    background: #fef2f2;
    color: var(--color-danger);
}

.logout-item i {
    color: var(--color-danger);
}

/* Menu Divider */
.menu-divider {
    height: 1px;
    background: var(--color-border-light);
    margin: var(--spacing-sm) var(--spacing-lg);
}

/* Responsive Design for Top Navigation */
@media (max-width: 768px) {
    .top-navigation {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 8px;
        padding: 8px 0;
    }

    /* Plan badge: compact on mobile */
    .plan-usage-widget {
        margin-right: 0;
    }

    .plan-usage-widget .usage-indicator {
        display: none;
    }

    .nav-breadcrumb {
        display: none;
    }

    .nav-actions {
        margin-left: auto;
        gap: 8px;
    }

    .user-trigger {
        min-width: auto;
        padding: 4px 8px;
    }

    .user-name-small {
        display: none;
    }

    .widget-dropdown {
        min-width: 260px;
        max-width: calc(100vw - 40px);
        right: 0;
        left: auto;
    }

    /* Sidebar tooltips: hide on mobile to prevent overlap */
    .sidebar.minimized .nav-item:hover::after,
    .sidebar.minimized .nav-item:hover::before {
        display: none !important;
    }

    /* Dashboard widget cards: 2x2 grid on mobile */
    .widgets-grid,
    .dashboard-widgets-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    /* Stat cards: 2x2 on mobile */
    .stats-grid,
    .pipeline-stats,
    .bookings-stats,
    .leads-stats,
    .opportunities-stats,
    .kb-articles-stats {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 480px) {
    .nav-actions {
        flex-wrap: wrap;
        gap: var(--spacing-xs);
    }
    
    .session-timer-widget {
        min-width: 120px;
        padding: var(--spacing-xs) var(--spacing-sm);
    }
    
    .widget-icon {
        width: 20px;
        height: 20px;
        font-size: 12px;
    }
    
    .widget-label {
        font-size: 9px;
    }
    
    .widget-value {
        font-size: 11px;
    }
    
    .widget-trigger {
        min-height: 36px;
        padding: var(--spacing-xs) var(--spacing-sm);
        font-size: 13px;
    }
    
    .user-trigger {
        min-width: 80px;
    }
    
    .user-name-small {
        max-width: 40px;
        font-size: 11px;
    }
    
    .user-avatar-small {
        width: 20px;
        height: 20px;
        font-size: 10px;
    }
    
    .widget-dropdown {
        min-width: 240px;
    }
    
    .dropdown-header,
    .user-info-header {
        padding: var(--spacing-md);
    }
    
    .notification-item,
    .quick-action-item,
    .user-menu-item {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 12px;
    }
    
    .breadcrumb-items {
        font-size: 12px;
    }
    
    .breadcrumb-item {
        max-width: 80px;
    }
}

/* Dark Theme Support for Top Navigation */
[data-theme="dark"] .top-navigation {
    background: var(--color-bg);
    border-bottom-color: var(--color-border);
}

[data-theme="dark"] .widget-dropdown {
    background: var(--color-surface);
    border-color: var(--color-border);
    box-shadow: var(--shadow-medium);
}

[data-theme="dark"] .widget-dropdown::before {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-theme="dark"] .dropdown-header,
[data-theme="dark"] .user-info-header {
    background: linear-gradient(180deg, var(--color-surface) 0%, #1a1a1a 100%);
}

[data-theme="dark"] .notification-item.unread {
    background: linear-gradient(90deg, #0f172a 0%, var(--color-surface) 100%);
}

/* Auto theme based on system preference */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .top-navigation {
        background: var(--color-bg);
        border-bottom-color: var(--color-border);
    }
    
    :root:not([data-theme="light"]) .widget-dropdown {
        background: var(--color-surface);
        border-color: var(--color-border);
        box-shadow: var(--shadow-medium);
    }
    
    :root:not([data-theme="light"]) .widget-dropdown::before {
        background: var(--color-surface);
        border-color: var(--color-border);
    }
    
    :root:not([data-theme="light"]) .dropdown-header,
    :root:not([data-theme="light"]) .user-info-header {
        background: linear-gradient(180deg, var(--color-surface) 0%, #1a1a1a 100%);
    }
    
    :root:not([data-theme="light"]) .notification-item.unread {
        background: linear-gradient(90deg, #0f172a 0%, var(--color-surface) 100%);
    }
}

/* Legacy Session Timer (for backward compatibility) - Hidden by default */
.session-timer {
    display: none !important;
}

/* Mobile Menu Toggle */
.mobile-menu-toggle {
    display: none;
    position: fixed;
    top: var(--spacing-lg);
    left: var(--spacing-lg);
    z-index: 1001;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-md);
    cursor: pointer;
    box-shadow: var(--shadow-medium);
    color: var(--color-text-secondary);
    font-size: 16px;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
}

.mobile-menu-toggle:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

/* Responsive Design */
@media (max-width: 768px) {
    /* Hide mobile menu toggle at tablet — 480px rule overrides */
    .mobile-menu-toggle {
        display: none;
    }

    .main-content {
        margin-left: 72px;
        padding: var(--spacing-xl);
        max-width: calc(100vw - 72px);
    }

    /* Auto-minimize sidebar on tablet */
    .sidebar {
        width: 72px;
    }

    .sidebar-minimizer {
        left: 56px;
    }

    .content-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }

    .stats-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }

    .page-title {
        font-size: 20px;
    }

    .stat-card {
        padding: var(--spacing-lg);
    }

    .card-body {
        padding: var(--spacing-lg);
    }

    .session-timer {
        top: 70px;
        right: var(--spacing-lg);
        min-width: 180px;
        padding: var(--spacing-md);
    }
}

@media (max-width: 480px) {
    /* Show hamburger toggle on mobile */
    .mobile-menu-toggle {
        display: flex !important;
    }

    /* Sidebar: off-screen overlay on mobile */
    .sidebar {
        width: 280px;
        transform: translateX(-100%);
        z-index: 1000;
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .sidebar.open {
        transform: translateX(0);
        box-shadow: 4px 0 20px rgba(0, 0, 0, 0.15);
    }

    /* Hide minimizer on mobile */
    .sidebar-minimizer {
        display: none !important;
    }

    /* Full-width main content */
    .main-content {
        margin-left: 0;
        max-width: 100vw;
        padding: 12px;
    }

    /* Override minimized sidebar state on mobile */
    .dashboard-container:has(.sidebar.minimized) .main-content {
        margin-left: 0;
        max-width: 100vw;
    }

    .stats-grid {
        gap: var(--spacing-sm);
    }

    .content-grid {
        gap: var(--spacing-md);
    }

    .stat-card {
        padding: var(--spacing-md);
    }

    .card-header {
        padding: var(--spacing-lg);
    }

    .card-body {
        padding: var(--spacing-md);
    }

    .session-timer {
        position: relative;
        top: auto;
        right: auto;
        margin: var(--spacing-md) 0;
        width: 100%;
    }

    .page-title {
        font-size: 18px;
    }

    .page-header {
        margin-bottom: var(--spacing-xl);
    }
}

/* Organization Profile Styles - Anthropic muted, clean and minimal */
.org-form {
    max-width: 100%;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.form-group {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--spacing-lg);
}

.form-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.01em;
}

.form-input {
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: inherit;
    line-height: 1.4;
}

.form-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.form-input:hover:not(:focus) {
    border-color: var(--color-text-muted);
}

.form-input:disabled,
.form-input[readonly] {
    background-color: var(--color-border-light);
    color: var(--color-text-muted);
    cursor: not-allowed;
}

.form-input::placeholder {
    color: var(--color-text-muted);
    opacity: 0.8;
}

.form-help {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
    line-height: 1.4;
}

.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    margin-top: var(--spacing-2xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid var(--color-border-light);
}

/* Buttons - Clean and minimal */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md) var(--spacing-xl);
    border: 1px solid transparent;
    border-radius: var(--radius);
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: inherit;
    line-height: 1.4;
    white-space: nowrap;
    user-select: none;
}

.btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.btn-primary {
    background-color: var(--color-accent);
    color: white;
    border-color: var(--color-accent);
}

.btn-primary:hover:not(:disabled) {
    background-color: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
}

.btn-secondary {
    background-color: var(--color-surface);
    color: var(--color-text-secondary);
    border-color: var(--color-border);
}

.btn-secondary:hover:not(:disabled) {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

/* Info Groups - Clean information display */
.info-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.info-item {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.info-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-secondary);
    letter-spacing: -0.01em;
}

.info-value {
    font-size: 14px;
    color: var(--color-text-primary);
    font-weight: 400;
    line-height: 1.4;
}

/* Settings Groups - Clean toggle switches */
.settings-group {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.setting-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg) 0;
    border-bottom: 1px solid var(--color-border-light);
}

.setting-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.setting-info {
    flex: 1;
}

.setting-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.setting-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin: 0;
}

.setting-control {
    flex-shrink: 0;
}

/* Toggle Switch - Minimal and clean */
.toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
    cursor: pointer;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--color-border);
    border-radius: 12px;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    border: 1px solid var(--color-border);
}

.toggle-slider:before {
    position: absolute;
    content: "";
    height: 18px;
    width: 18px;
    left: 2px;
    bottom: 2px;
    background-color: white;
    border-radius: 50%;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.toggle-switch input:checked + .toggle-slider {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
}

.toggle-switch input:checked + .toggle-slider:before {
    transform: translateX(20px);
}

.toggle-switch input:focus + .toggle-slider {
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.toggle-switch:hover .toggle-slider:not(:has(input:checked)) {
    background-color: var(--color-text-muted);
    border-color: var(--color-text-muted);
}

/* Responsive adjustments for forms */
@media (max-width: 768px) {
    .form-row {
        grid-template-columns: 1fr;
        gap: 0;
    }
    
    .form-actions {
        flex-direction: column-reverse;
        gap: var(--spacing-sm);
    }
    
    .btn {
        width: 100%;
        justify-content: center;
    }
    
    .setting-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .setting-control {
        align-self: flex-end;
    }
}

/* Utility Classes */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-muted { color: var(--color-text-muted); }
.text-secondary { color: var(--color-text-secondary); }
.text-primary { color: var(--color-text-primary); }

.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }

.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--spacing-xs); }
.mb-2 { margin-bottom: var(--spacing-sm); }
.mb-3 { margin-bottom: var(--spacing-md); }
.mb-4 { margin-bottom: var(--spacing-lg); }
.mb-5 { margin-bottom: var(--spacing-xl); }
.mb-6 { margin-bottom: var(--spacing-2xl); }

.mt-0 { margin-top: 0; }
.mt-1 { margin-top: var(--spacing-xs); }
.mt-2 { margin-top: var(--spacing-sm); }
.mt-3 { margin-top: var(--spacing-md); }
.mt-4 { margin-top: var(--spacing-lg); }
.mt-5 { margin-top: var(--spacing-xl); }
.mt-6 { margin-top: var(--spacing-2xl); }

/* Focus states for accessibility */
.user-profile:focus,
.mobile-menu-toggle:focus {
    outline: 2px solid var(--color-info);
    outline-offset: 2px;
}

/* Smooth transitions for better UX */
* {
    transition: color 0.15s ease, background-color 0.15s ease, border-color 0.15s ease;
}

/* High contrast mode support */
@media (prefers-contrast: high) {
    :root {
        --color-border: #666;
        --color-text-muted: #555;
        --shadow-subtle: 0 1px 2px 0 rgb(0 0 0 / 0.2);
        --shadow-soft: 0 1px 3px 0 rgb(0 0 0 / 0.3);
    }
}

/* Reduced motion support */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Organization, Team Members, and Workspaces Module Styles - Anthropic minimal style */

/* Card Actions - Clean button groups */
.card-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.card-subtitle {
    font-size: 13px;
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
    line-height: 1.4;
}

/* Button Variants - Minimal and clean */
.btn-outline {
    background-color: transparent;
    color: var(--color-text-secondary);
    border-color: var(--color-border);
}

.btn-outline:hover:not(:disabled) {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

.btn-danger {
    background-color: var(--color-danger);
    color: white;
    border-color: var(--color-danger);
}

.btn-danger:hover:not(:disabled) {
    background-color: #b91c1c;
    border-color: #b91c1c;
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
}

.btn-warning {
    background-color: var(--color-warning);
    color: white;
    border-color: var(--color-warning);
}

.btn-warning:hover:not(:disabled) {
    background-color: #a16207;
    border-color: #a16207;
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
}

.btn-sm {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 12px;
    font-weight: 500;
}

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background-color: var(--color-surface);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 14px;
}

.btn-icon:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
    transform: translateY(-1px);
}

.btn-icon:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

/* Icon spacing in buttons */
.btn i {
    margin-right: var(--spacing-sm);
    font-size: 13px;
}

.btn i:only-child {
    margin-right: 0;
}

/* Editable Fields - Clean inline editing */
.editable-field {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid transparent;
    border-radius: var(--radius);
    background-color: transparent;
    color: var(--color-text-primary);
    font-size: 14px;
    line-height: 1.4;
    transition: all 0.15s ease;
    cursor: text;
    min-height: 38px;
    display: flex;
    align-items: center;
}

.editable-field:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-border);
}

.editable-field input,
.editable-field textarea {
    width: 100%;
    border: none;
    background: transparent;
    font: inherit;
    color: inherit;
    outline: none;
    resize: vertical;
}

.editable-field textarea {
    min-height: 60px;
    padding: var(--spacing-sm) 0;
}

/* Statistics Grid - Clean metrics display */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
    margin: var(--spacing-xl) 0;
}

.stat-item {
    text-align: center;
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius-lg);
    transition: all 0.15s ease;
}

.stat-item:hover {
    background-color: var(--color-border);
    transform: translateY(-1px);
}

.stat-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.02em;
}

.stat-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Team Members List - Clean member cards */
.team-members-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.team-member-item {
    display: flex;
    align-items: center;
    padding: var(--spacing-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all 0.15s ease;
}

.team-member-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.member-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 16px;
    margin-right: var(--spacing-lg);
    flex-shrink: 0;
}

.member-info {
    flex: 1;
    min-width: 0;
}

.member-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 2px;
    line-height: 1.3;
}

.member-email {
    font-size: 12px;
    color: var(--color-text-secondary);
    margin-bottom: 2px;
    line-height: 1.3;
}

.member-role {
    font-size: 11px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 500;
    margin-bottom: 2px;
}

.member-joined {
    font-size: 11px;
    color: var(--color-text-muted);
    line-height: 1.3;
}

.member-status {
    margin-right: var(--spacing-lg);
    flex-shrink: 0;
}

.member-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-shrink: 0;
}

/* Status Badges - Minimal and clean */
.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    line-height: 1;
}

.status-badge.active {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.status-badge.inactive {
    background-color: var(--color-border-light);
    color: var(--color-text-muted);
}

.status-badge.pending {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.status-badge.archived {
    background-color: var(--color-border-light);
    color: var(--color-text-muted);
}

/* Workspaces List - Clean workspace cards */
.workspaces-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.workspace-item {
    display: flex;
    align-items: center;
    padding: var(--spacing-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all 0.15s ease;
}

.workspace-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.workspace-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-lg);
    background-color: var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-secondary);
    font-size: 16px;
    margin-right: var(--spacing-lg);
    flex-shrink: 0;
}

.workspace-info {
    flex: 1;
    min-width: 0;
}

.workspace-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 2px;
    line-height: 1.3;
}

.workspace-description {
    font-size: 12px;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-xs);
    line-height: 1.3;
}

.workspace-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 11px;
    color: var(--color-text-muted);
}

.workspace-type,
.workspace-category,
.workspace-created {
    font-size: 11px;
    color: var(--color-text-muted);
}

.workspace-status {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--spacing-xs);
    margin-right: var(--spacing-lg);
    flex-shrink: 0;
}

.visibility-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    border-radius: var(--radius);
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background-color: var(--color-border-light);
    color: var(--color-text-muted);
}

.visibility-badge.organization {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.visibility-badge.private {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.visibility-badge.public {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.workspace-stats {
    margin-right: var(--spacing-lg);
    flex-shrink: 0;
}

.workspace-stats .stat {
    text-align: center;
}

.workspace-stats .stat-value {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    line-height: 1.2;
}

.workspace-stats .stat-label {
    font-size: 10px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 500;
}

.workspace-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    flex-shrink: 0;
}

/* Pending Invitations List - Clean invitation cards */
.pending-invitations-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.invitation-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    background-color: #fffbeb;
    border: 1px solid #fbbf24;
    border-radius: var(--radius-lg);
    transition: all 0.15s ease;
}

.invitation-item:hover {
    border-color: var(--color-warning);
    box-shadow: var(--shadow-soft);
}

.invitation-info {
    flex: 1;
}

.invitation-email {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 2px;
}

.invitation-role {
    font-size: 12px;
    color: var(--color-text-secondary);
    margin-bottom: 2px;
}

.invitation-sent {
    font-size: 11px;
    color: var(--color-text-muted);
}

.invitation-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Modal Styles - Clean and minimal */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal {
    background: var(--color-surface);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-medium);
    max-width: 500px;
    width: 90%;
    max-height: 90vh;
    overflow: hidden;
    transform: scale(0.95) translateY(20px);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.modal-overlay.active .modal {
    transform: scale(1) translateY(0);
}

.modal-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.modal-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
}

.modal-close {
    width: 32px;
    height: 32px;
    border: none;
    background: none;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: all 0.15s ease;
}

.modal-close:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

.modal-body {
    padding: var(--spacing-xl);
    max-height: 60vh;
    overflow-y: auto;
}

.modal-footer {
    padding: var(--spacing-xl);
    border-top: 1px solid var(--color-border-light);
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
}

/* Danger Zone - Warning styling */
.danger-zone {
    border-color: var(--color-danger);
    background: linear-gradient(135deg, #fef2f2 0%, var(--color-surface) 100%);
}

.danger-zone .card-header {
    background: linear-gradient(180deg, #fef2f2 0%, #fef7f7 100%);
    border-bottom-color: #fecaca;
}

.danger-zone .card-title {
    color: var(--color-danger);
}

.danger-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-xl);
    line-height: 1.4;
}

.danger-actions {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.danger-action {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
}

.action-info h4 {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
}

.action-info p {
    font-size: 12px;
    color: var(--color-text-secondary);
    margin: 0;
    line-height: 1.4;
}

/* Domain Management - Clean domain list */
.domain-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    margin-bottom: var(--spacing-md);
    transition: all 0.15s ease;
}

.domain-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
}

.domain-item:last-child {
    margin-bottom: 0;
}

.domain-info {
    flex: 1;
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.domain-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
}

.domain-status {
    padding: 2px 6px;
    border-radius: var(--radius);
    font-size: 10px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.domain-status.verified {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.domain-status.pending {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.domain-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Templates Grid - Clean template cards */
.templates-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-lg);
}

.template-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    text-align: center;
    background-color: var(--color-surface);
    transition: all 0.15s ease;
    cursor: pointer;
}

.template-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-2px);
}

.template-icon {
    font-size: 2rem;
    margin-bottom: var(--spacing-lg);
    opacity: 0.8;
}

.template-card h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
}

.template-card p {
    font-size: 12px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-lg);
}

/* Form Text Helper */
.form-text {
    font-size: 11px;
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
    line-height: 1.4;
}

/* Warning Message in Modals */
.warning-message {
    background-color: #fffbeb;
    border: 1px solid #fbbf24;
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.warning-message strong {
    color: var(--color-warning);
    font-weight: 600;
}

.warning-message p {
    margin: var(--spacing-sm) 0;
    color: var(--color-text-secondary);
    font-size: 13px;
}

.warning-message ul {
    margin: var(--spacing-sm) 0;
    padding-left: var(--spacing-lg);
    color: var(--color-text-secondary);
    font-size: 13px;
}

.warning-message li {
    margin-bottom: var(--spacing-xs);
}

/* Billing Module Specific Styles */
.billing-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

.setting-group {
    background: transparent; /* var(--color-surface); */
    border: 0px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
    padding: 5px;
}

.setting-group h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.setting-group .card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.setting-group .card-header h3 {
    padding: 0;
    border: none;
    background: none;
}

/* Permission Denied State - Clean and informative */
.permission-denied-state {
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.permission-icon {
    font-size: 48px;
    margin-bottom: var(--spacing-xl);
    opacity: 0.6;
    color: var(--color-text-muted);
}

.permission-denied-state h3 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-lg);
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.permission-denied-state p {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.5;
    margin-bottom: var(--spacing-lg);
}

.permission-reasons {
    text-align: left;
    max-width: 400px;
    margin: 0 auto var(--spacing-xl) auto;
    padding: 0;
    list-style: none;
}

.permission-reasons li {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.permission-reasons li:before {
    content: "•";
    color: var(--color-text-muted);
    font-weight: bold;
    flex-shrink: 0;
    margin-top: 2px;
}

.permission-actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-xl);
}

.permission-note {
    font-size: 12px;
    color: var(--color-text-muted);
    font-style: italic;
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
    margin-top: var(--spacing-lg);
}

/* Subscription Card - Clean subscription display */
.subscription-card {
    padding: var(--spacing-xl);
}

.subscription-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: var(--spacing-xl);
}

.plan-info h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
}

.plan-price {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-xs);
}

.plan-price .price {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text-primary);
    letter-spacing: -0.02em;
}

.plan-price .period {
    font-size: 14px;
    color: var(--color-text-secondary);
}

.subscription-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius-lg);
}

.detail-item {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.detail-item label {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.detail-item span,
.detail-item select {
    font-size: 14px;
    color: var(--color-text-primary);
    font-weight: 500;
}

.detail-item select {
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-sm);
    background-color: var(--color-surface);
}

.subscription-features {
    margin-bottom: var(--spacing-xl);
}

.subscription-features h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-md);
}

.features-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-sm);
}

.feature-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.feature-icon {
    color: var(--color-success);
    font-weight: bold;
    flex-shrink: 0;
}

.subscription-actions {
    display: flex;
    gap: var(--spacing-md);
    justify-content: flex-start;
}

/* Usage Metrics Card - Clean usage display */
.usage-metrics-card {
    padding: var(--spacing-xl);
}

.usage-metrics-card h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xl);
}

.usage-metrics {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.usage-metric {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.metric-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.metric-name {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-secondary);
}

.metric-value {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-primary);
    font-variant-numeric: tabular-nums;
}

.metric-bar {
    height: 6px;
    background-color: var(--color-border-light);
    border-radius: 3px;
    overflow: hidden;
}

.metric-progress {
    height: 100%;
    background: linear-gradient(90deg, var(--color-success) 0%, var(--color-warning) 70%, var(--color-danger) 100%);
    border-radius: 3px;
    transition: width 0.3s ease;
}

.usage-warning {
    margin-top: var(--spacing-lg);
    padding: var(--spacing-md);
    background-color: #fffbeb;
    border: 1px solid #fbbf24;
    border-radius: var(--radius);
    font-size: 13px;
    color: var(--color-warning);
}

/* Payment Methods Card - Clean payment method display */
.payment-methods-card {
    padding: 0;
}

.payment-methods-list {
    padding: var(--spacing-xl);
}

.payment-method-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    margin-bottom: var(--spacing-md);
    transition: all 0.15s ease;
}

.payment-method-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
}

.payment-method-item:last-child {
    margin-bottom: 0;
}

.payment-method-item.default {
    border-color: var(--color-success);
    background: linear-gradient(135deg, #f0fdf4 0%, var(--color-surface) 100%);
}

.method-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.method-type {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.method-icon {
    font-size: 16px;
}

.method-details {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.default-badge {
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-success);
    background-color: #f0fdf4;
    padding: 2px 6px;
    border-radius: var(--radius);
}

.method-meta {
    font-size: 12px;
    color: var(--color-text-secondary);
}

.method-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

/* Invoices Card - Clean invoice table */
.invoices-card {
    padding: 0;
}

.invoices-table {
    padding: var(--spacing-xl);
}

.table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.table th {
    text-align: left;
    padding: var(--spacing-md) var(--spacing-sm);
    border-bottom: 2px solid var(--color-border);
    font-weight: 600;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-size: 11px;
}

.table td {
    padding: var(--spacing-md) var(--spacing-sm);
    border-bottom: 1px solid var(--color-border-light);
    color: var(--color-text-primary);
}

.table tr:hover {
    background-color: var(--color-border-light);
}

/* Support Options - Clean support modal */
.support-options {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
    margin-top: var(--spacing-lg);
}

.support-option {
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    text-align: center;
    transition: all 0.15s ease;
}

.support-option:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.support-option h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
}

.support-option p {
    font-size: 12px;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-md);
    line-height: 1.4;
}

/* Large Modal - For subscription plans */
.large-modal {
    max-width: 800px;
    width: 95%;
}

.billing-toggle {
    display: flex;
    justify-content: center;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
    padding: var(--spacing-md);
    background-color: var(--color-border-light);
    border-radius: var(--radius-lg);
}

.toggle-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-secondary);
    transition: color 0.15s ease;
}

.toggle-label input[type="radio"] {
    margin: 0;
}

.toggle-label:has(input:checked) {
    color: var(--color-text-primary);
}

.plans-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--spacing-lg);
}

.plan-card {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    text-align: center;
    background-color: var(--color-surface);
    transition: all 0.15s ease;
    position: relative;
}

.plan-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-2px);
}

.plan-card.featured {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-medium);
    transform: scale(1.02);
}

.plan-badge {
    position: absolute;
    top: -8px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--color-accent);
    color: white;
    padding: 2px 8px;
    border-radius: var(--radius);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    white-space: nowrap;
    line-height: 1.2;
}

.plan-header {
    margin-bottom: var(--spacing-xl);
}

.plan-card h4 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-md);
}

.plan-card .plan-price {
    margin-bottom: var(--spacing-sm);
}

.yearly-savings {
    font-size: 11px;
    color: var(--color-success);
    font-weight: 500;
}

.plan-features {
    list-style: none;
    padding: 0;
    margin: 0 0 var(--spacing-xl) 0;
    text-align: left;
}

.plan-features li {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-sm);
    font-size: 12px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.plan-features li:before {
    content: "✓";
    color: var(--color-success);
    font-weight: bold;
    flex-shrink: 0;
}

/* Danger Modal - Warning styling for cancellation */
.danger-modal {
    border-top: 4px solid var(--color-danger);
}

.danger-modal .modal-header {
    background: linear-gradient(135deg, #fef2f2 0%, var(--color-surface) 100%);
}

.danger-modal .modal-title {
    color: var(--color-danger);
}

/* Responsive adjustments for billing */
@media (max-width: 768px) {
    .permission-actions {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .permission-actions .btn {
        width: 100%;
    }
    
    .subscription-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .subscription-details {
        grid-template-columns: 1fr;
    }
    
    .subscription-actions {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .subscription-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .features-list {
        grid-template-columns: 1fr;
    }
    
    .payment-method-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .method-actions {
        align-self: flex-end;
    }
    
    .plans-grid {
        grid-template-columns: 1fr;
    }
    
    .billing-toggle {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .support-options {
        gap: var(--spacing-md);
    }
    
    .table {
        font-size: 12px;
    }
    
    .table th,
    .table td {
        padding: var(--spacing-sm) var(--spacing-xs);
    }
}

/* Responsive adjustments for organization modules */
@media (max-width: 768px) {
    .team-member-item,
    .workspace-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .member-avatar,
    .workspace-icon {
        margin-right: 0;
        margin-bottom: var(--spacing-sm);
    }
    
    .member-actions,
    .workspace-actions {
        align-self: flex-end;
        margin-top: var(--spacing-sm);
    }
    
    .workspace-status,
    .workspace-stats {
        margin-right: 0;
        align-self: flex-start;
        margin-top: var(--spacing-sm);
    }
    
    .templates-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }
    
    .danger-action {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .modal {
        width: 95%;
        margin: var(--spacing-lg);
    }
    
    .modal-footer {
        flex-direction: column-reverse;
        gap: var(--spacing-sm);
    }
    
    .modal-footer .btn {
        width: 100%;
    }
}

@media (max-width: 480px) {
    .stats-grid {
        grid-template-columns: 1fr;
    }
    
    .card-actions {
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-sm);
    }
    
    .card-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .invitation-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .invitation-actions {
        align-self: flex-end;
    }
    
    .domain-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .domain-actions {
        align-self: flex-end;
    }
}

/* Event Types Module Styles - Clean and minimal */
.event-types-filters {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
    padding: var(--spacing-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.filters-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    width: 100%;
}

.search-box {
    position: relative;
    flex: 1;
    max-width: 300px;
}

.search-box i {
    position: absolute;
    left: var(--spacing-md);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    font-size: 14px;
}

.search-box .form-control {
    padding-left: var(--spacing-3xl);
}

.form-control {
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: inherit;
    line-height: 1.4;
}

.form-control:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.form-control:hover:not(:focus) {
    border-color: var(--color-text-muted);
}

.event-types-container {
    min-height: 400px;
}

.event-types-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--spacing-xl);
}

.event-type-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
}

.event-type-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-2px);
}

.event-type-card.inactive {
    opacity: 0.6;
    background-color: var(--color-border-light);
}

.event-type-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-lg);
}

.event-type-info h4 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.event-type-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin: 0;
}

.event-type-details {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
}

.detail-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 12px;
    color: var(--color-text-secondary);
}

.detail-item i {
    width: 14px;
    color: var(--color-text-muted);
    font-size: 12px;
}

.event-type-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.dropdown {
    position: relative;
}

.dropdown-toggle {
    background: none;
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
    cursor: pointer;
    transition: all 0.15s ease;
}

.dropdown-toggle:hover {
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

.dropdown-menu {
    position: absolute;
    top: 100%;
    right: 0;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-medium);
    min-width: 160px;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.15s ease;
}

.dropdown-menu.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.dropdown-menu a {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    color: var(--color-text-secondary);
    text-decoration: none;
    font-size: 13px;
    transition: all 0.15s ease;
}

.dropdown-menu a:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

.dropdown-menu a.text-danger {
    color: var(--color-danger);
}

.dropdown-menu a.text-danger:hover {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.dropdown-divider {
    height: 1px;
    background-color: var(--color-border-light);
    margin: var(--spacing-xs) 0;
}

.error-state {
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.error-icon {
    font-size: 48px;
    margin-bottom: var(--spacing-xl);
    opacity: 0.6;
    color: var(--color-danger);
}

.error-state h3 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-lg);
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.error-state p {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.5;
    margin-bottom: var(--spacing-xl);
}

/* Bookings Module Styles - Anthropic Muted & Minimal */
.bookings-filters {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    box-shadow: var(--shadow-subtle);
}

.filters-row {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    align-items: end;
}

.filter-group {
    display: flex;
    flex-direction: column;
    min-width: 120px;
    flex: 1;
}

.filter-group label {
    font-weight: 500;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-xs);
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.filter-group .form-select,
.filter-group .form-control {
    height: 32px;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 13px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    color: var(--color-text-primary);
    transition: all 0.15s ease;
}

.filter-group .form-select:focus,
.filter-group .form-control:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px rgba(36, 41, 47, 0.06);
}

.filter-group .form-control::placeholder {
    color: var(--color-text-muted);
    font-size: 12px;
}

.filter-actions {
    display: flex;
    align-items: end;
    margin-left: auto;
}

.filter-actions .btn {
    height: 32px;
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: 12px;
    font-weight: 500;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    transition: all 0.15s ease;
}

.filter-actions .btn-outline-secondary {
    border: 1px solid var(--color-border);
    color: var(--color-text-secondary);
    background: var(--color-surface);
}

.filter-actions .btn-outline-secondary:hover {
    background: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

.filter-actions .btn i {
    font-size: 11px;
}

/* Responsive adjustments for bookings filters */
@media (max-width: 768px) {
    .filters-row {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .filter-group {
        min-width: 100%;
    }
    
    .filter-actions {
        margin-left: 0;
        justify-content: flex-start;
    }
}

.filter-btn {
    padding: var(--spacing-sm) var(--spacing-lg);
    border: none;
    background: transparent;
    color: var(--color-text-secondary);
    font-size: 13px;
    font-weight: 500;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.filter-btn:hover {
    background-color: var(--color-surface);
    color: var(--color-text-primary);
}

.filter-btn.active {
    background-color: var(--color-accent);
    color: white;
}

.bookings-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.booking-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-lg);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
}

.booking-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.booking-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-md);
}

.booking-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.booking-details {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-lg);
}

.booking-time,
.booking-date,
.booking-attendee {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 12px;
    color: var(--color-text-secondary);
}

.booking-time i,
.booking-date i,
.booking-attendee i {
    width: 12px;
    color: var(--color-text-muted);
    font-size: 11px;
}

.booking-actions {
    display: flex;
    gap: var(--spacing-xs);
}

.btn-secondary {
    background-color: var(--color-surface);
    color: var(--color-text-secondary);
    border-color: var(--color-border);
}

.btn-secondary:hover:not(:disabled) {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

/* Availability Module Styles - Clean schedule management */
.working-hours-grid {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.working-hours-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background-color: var(--color-surface);
    transition: all 0.15s ease;
}

.working-hours-row:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-subtle);
}

.day-name {
    flex: 1;
    min-width: 120px;
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
}

.checkbox-label input[type="checkbox"] {
    margin: 0;
    width: 16px;
    height: 16px;
    accent-color: #292524 !important;
}

/* ========================================
   GLOBAL CHECKBOX BLACK COLOR OVERRIDE
   FORCE ALL CHECKBOXES TO USE BLACK
   ======================================== */

/* Global checkbox color - applies to ALL checkboxes */
input[type="checkbox"],
input[type="checkbox"]:checked,
*[type="checkbox"],
.form-check-input[type="checkbox"],
.form-control[type="checkbox"] {
    accent-color: #292524 !important;
    color-scheme: light !important;
}

/* Dark mode checkbox override */
[data-theme="dark"] input[type="checkbox"],
[data-theme="dark"] input[type="checkbox"]:checked {
    accent-color: #ffffff !important;
}

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) input[type="checkbox"],
    :root:not([data-theme="light"]) input[type="checkbox"]:checked {
        accent-color: #ffffff !important;
    }
}

/* ========================================
   FINAL NUCLEAR OVERRIDES - MUST BE LAST
   ======================================== */

/* Force all time inputs to use Anthropic black with MAXIMUM specificity */
.availability-container input.tyga-availability-time[type="time"],
.working-hours-grid input.tyga-availability-time[type="time"],
input.form-control.working-hours-time.tyga-availability-time[type="time"],
input.tyga-availability-time[type="time"],
input[type="time"].tyga-availability-time {
    accent-color: #292524 !important;
    color-scheme: light !important;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

/* Also force all time inputs globally */
input[type="time"],
input[type="time"]::-webkit-calendar-picker-indicator,
*[type="time"],
.working-hours-time,
.form-control[type="time"] {
    accent-color: #292524 !important;
    color-scheme: light !important;
}

.checkmark {
    /* Custom checkbox styling can be added here if needed */
}

.time-inputs {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    flex: 2;
    justify-content: flex-end;
}

.time-inputs.disabled {
    opacity: 0.5;
}

.time-inputs input[type="time"] {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 13px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    font-family: inherit;
}

.time-inputs input[type="time"]:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.time-separator {
    font-size: 13px;
    color: var(--color-text-muted);
    font-weight: 500;
}

.availability-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid var(--color-border-light);
}

.time-slots-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.time-slots-header {
    display: flex;
    justify-content: flex-end;
}

.time-slot-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    transition: all 0.15s ease;
}

.time-slot-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
}

.time-slot-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.time-slot-date {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
}

.time-slot-time {
    font-size: 13px;
    color: var(--color-text-secondary);
    font-variant-numeric: tabular-nums;
}

.time-slot-status {
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 2px 6px;
    border-radius: var(--radius);
}

.time-slot-status.available {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.time-slot-status.unavailable {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.time-slot-actions {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.calendar-preview {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.calendar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
}

.calendar-header h4 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
}

.calendar-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: var(--spacing-sm);
}

.calendar-day {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-md);
    text-align: center;
    transition: all 0.15s ease;
    min-height: 80px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.calendar-day:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-subtle);
}

.calendar-day.unavailable {
    background-color: var(--color-border-light);
    opacity: 0.6;
}

.day-header {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-sm);
}

.day-name {
    font-size: 11px;
    font-weight: 600;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.day-date {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.day-content {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.available-hours {
    font-size: 10px;
    color: var(--color-success);
    font-weight: 500;
    background-color: #f0fdf4;
    padding: 2px 4px;
    border-radius: var(--radius);
    font-variant-numeric: tabular-nums;
}

.unavailable-text {
    font-size: 10px;
    color: var(--color-text-muted);
    font-weight: 500;
}

/* Responsive adjustments for new modules */
@media (max-width: 768px) {
    .event-types-filters {
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-md);
    }
    
    .filters-row {
        flex-direction: column;
        gap: var(--spacing-md);
    }
    
    .search-box {
        max-width: none;
    }
    
    .event-types-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .event-type-actions {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .bookings-filters {
        justify-content: flex-start;
        padding: var(--spacing-sm);
    }
    
    .booking-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }
    
    .booking-actions {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .working-hours-row {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .time-inputs {
        justify-content: flex-start;
        width: 100%;
    }
    
    .availability-actions {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .availability-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .calendar-grid {
        grid-template-columns: repeat(7, 1fr);
        gap: 2px;
    }
    
    .calendar-day {
        min-height: 60px;
        padding: var(--spacing-sm);
    }
    
    .time-slot-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .time-slot-actions {
        align-self: flex-end;
    }
}

@media (max-width: 480px) {
    .event-type-card {
        padding: var(--spacing-lg);
    }
    
    .booking-card {
        padding: var(--spacing-lg);
    }
    
    .calendar-grid {
        grid-template-columns: repeat(7, 1fr);
        gap: 1px;
    }
    
    .calendar-day {
        min-height: 50px;
        padding: var(--spacing-xs);
    }
    
    .day-date {
        font-size: 14px;
    }
    
    .available-hours,
    .unavailable-text {
        font-size: 9px;
    }
    
    .dropdown-menu {
        position: fixed;
        top: auto;
        bottom: 20px;
        left: 20px;
        right: 20px;
        width: auto;
        min-width: auto;
    }
}

/* ===== LOGOUT MODAL STYLES ===== */
.logout-modal {
    display: none;
    position: fixed;
    z-index: 1001;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(6px);
    animation: fadeIn 0.3s ease-out;
}

.logout-modal-content {
    background-color: var(--color-surface);
    margin: 15% auto;
    padding: 0;
    border: none;
    border-radius: var(--radius-xl);
    width: 90%;
    max-width: 420px;
    box-shadow: var(--shadow-medium);
    animation: modalSlideUp 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    overflow: hidden;
}

.logout-modal-header {
    padding: var(--spacing-2xl) var(--spacing-2xl) var(--spacing-lg) var(--spacing-2xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(135deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.logout-modal-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    letter-spacing: -0.01em;
}

.logout-modal-title i {
    color: var(--color-warning);
    font-size: 22px;
}

.logout-modal-body {
    padding: var(--spacing-2xl);
}

.logout-user-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-xl);
    border: 1px solid var(--color-border);
}

.logout-user-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 18px;
    flex-shrink: 0;
    box-shadow: var(--shadow-subtle);
}

.logout-user-details h4 {
    margin: 0 0 var(--spacing-xs) 0;
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.logout-user-details p {
    margin: 0;
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.logout-message {
    color: var(--color-text-secondary);
    font-size: 15px;
    line-height: 1.5;
    margin-bottom: var(--spacing-2xl);
    text-align: center;
}

.logout-modal-actions {
    display: flex;
    gap: var(--spacing-md);
    justify-content: flex-end;
}

.logout-cancel-btn {
    padding: var(--spacing-md) var(--spacing-xl);
    border: 1px solid var(--color-border);
    background-color: var(--color-surface);
    color: var(--color-text-secondary);
    border-radius: var(--radius);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 100px;
    font-family: inherit;
}

.logout-cancel-btn:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
    transform: translateY(-1px);
    box-shadow: var(--shadow-subtle);
}

.logout-confirm-btn {
    padding: var(--spacing-md) var(--spacing-xl);
    border: none;
    background: linear-gradient(135deg, var(--color-danger) 0%, #b91c1c 100%);
    color: white;
    border-radius: var(--radius);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    min-width: 100px;
    position: relative;
    overflow: hidden;
    font-family: inherit;
}

.logout-confirm-btn:hover {
    background: linear-gradient(135deg, #b91c1c 0%, #991b1b 100%);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(220, 53, 69, 0.3);
}

.logout-confirm-btn:active {
    transform: translateY(0);
}

.logout-confirm-btn.loading {
    pointer-events: none;
    opacity: 0.8;
}

.logout-confirm-btn.loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 16px;
    height: 16px;
    margin: -8px 0 0 -8px;
    border: 2px solid transparent;
    border-top: 2px solid white;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.logout-confirm-btn.loading span {
    opacity: 0;
}

/* ===== LOGOUT MODAL ANIMATIONS ===== */
@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

@keyframes modalSlideUp {
    from {
        opacity: 0;
        transform: translateY(30px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

/* ===== RESPONSIVE LOGOUT MODAL ===== */
@media (max-width: 768px) {
    .logout-modal-content {
        margin: 20% auto;
        width: 95%;
        max-width: 380px;
    }
    
    .logout-modal-header {
        padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-lg) var(--spacing-xl);
    }
    
    .logout-modal-title {
        font-size: 18px;
    }
    
    .logout-modal-body {
        padding: var(--spacing-xl);
    }
    
    .logout-user-info {
        padding: var(--spacing-lg);
        gap: var(--spacing-lg);
    }
    
    .logout-user-avatar {
        width: 44px;
        height: 44px;
        font-size: 16px;
    }
    
    .logout-modal-actions {
        flex-direction: column-reverse;
        gap: var(--spacing-sm);
    }
    
    .logout-cancel-btn,
    .logout-confirm-btn {
        width: 100%;
        padding: var(--spacing-lg) var(--spacing-xl);
        justify-content: center;
    }
}

/* Dark Theme Support for Logout Modal */
[data-theme="dark"] .logout-modal-content {
    background-color: var(--color-surface);
}

[data-theme="dark"] .logout-modal-header {
    background: linear-gradient(135deg, var(--color-surface) 0%, #1a1a1a 100%);
    border-bottom-color: var(--color-border);
}

[data-theme="dark"] .logout-user-info {
    background-color: var(--color-border-light);
    border-color: var(--color-border);
}

[data-theme="dark"] .logout-cancel-btn {
    background-color: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text-secondary);
}

[data-theme="dark"] .logout-cancel-btn:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

/* Auto theme based on system preference */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .logout-modal-content {
        background-color: var(--color-surface);
    }
    
    :root:not([data-theme="light"]) .logout-modal-header {
        background: linear-gradient(135deg, var(--color-surface) 0%, #1a1a1a 100%);
        border-bottom-color: var(--color-border);
    }
    
    :root:not([data-theme="light"]) .logout-user-info {
        background-color: var(--color-border-light);
        border-color: var(--color-border);
    }
    
    :root:not([data-theme="light"]) .logout-cancel-btn {
        background-color: var(--color-surface);
        border-color: var(--color-border);
        color: var(--color-text-secondary);
    }
    
    :root:not([data-theme="light"]) .logout-cancel-btn:hover {
        background-color: var(--color-border-light);
        border-color: var(--color-text-muted);
        color: var(--color-text-primary);
    }
}

/* ========================================
   TYGA CUSTOM DROPDOWN COMPONENT (DRY)
   ======================================== */

/* Custom Select Container */
.custom-select {
    position: relative;
    display: inline-block;
    min-width: 160px;
    font-family: inherit;
}

/* Select Trigger - The clickable area that shows current selection */
.select-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 14px;
    color: var(--color-text-primary);
    line-height: 1.4;
    min-height: 40px;
    user-select: none;
}

.select-trigger:hover {
    border-color: var(--color-text-muted);
    background-color: var(--color-border-light);
}

.select-trigger:focus,
.custom-select.open .select-trigger {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.custom-select.open .select-trigger {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-bottom-color: transparent;
}

/* Trigger Text */
.select-trigger span {
    flex: 1;
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Chevron Icon */
.select-trigger i {
    margin-left: var(--spacing-sm);
    font-size: 12px;
    color: var(--color-text-muted);
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    flex-shrink: 0;
}

.custom-select.open .select-trigger i {
    transform: rotate(180deg);
}

/* Options Container */
.select-options {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background-color: var(--color-surface);
    border: 1px solid var(--color-accent);
    border-top: none;
    border-radius: 0 0 var(--radius) var(--radius);
    box-shadow: var(--shadow-medium);
    z-index: 1000;
    max-height: 240px;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.custom-select.open .select-options {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Individual Option */
.select-option {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-lg);
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    border-bottom: 1px solid var(--color-border-light);
}

.select-option:last-child {
    border-bottom: none;
}

.select-option:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

.select-option.selected {
    background-color: var(--color-accent);
    color: white;
}

.select-option.selected:hover {
    background-color: var(--color-accent-hover);
}

/* Option Icons */
.select-option i {
    width: 16px;
    font-size: 14px;
    color: currentColor;
    opacity: 0.8;
    flex-shrink: 0;
}

.select-option.selected i {
    opacity: 1;
}

/* Disabled State */
.custom-select.disabled .select-trigger {
    background-color: var(--color-border-light);
    color: var(--color-text-muted);
    cursor: not-allowed;
    border-color: var(--color-border);
}

.custom-select.disabled .select-trigger:hover {
    border-color: var(--color-border);
    background-color: var(--color-border-light);
}

/* Small Size Variant */
.custom-select.small .select-trigger {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 13px;
    min-height: 32px;
}

.custom-select.small .select-option {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 13px;
}

/* Large Size Variant */
.custom-select.large .select-trigger {
    padding: var(--spacing-lg) var(--spacing-xl);
    font-size: 16px;
    min-height: 48px;
}

.custom-select.large .select-option {
    padding: var(--spacing-lg) var(--spacing-xl);
    font-size: 16px;
}

/* Full Width Variant */
.custom-select.full-width {
    width: 100%;
    min-width: auto;
}

/* Error State */
.custom-select.error .select-trigger {
    border-color: var(--color-danger);
    background-color: #fef2f2;
}

.custom-select.error .select-trigger:hover,
.custom-select.error .select-trigger:focus {
    border-color: var(--color-danger);
    box-shadow: 0 0 0 3px rgba(207, 34, 46, 0.08);
}

/* Success State */
.custom-select.success .select-trigger {
    border-color: var(--color-success);
    background-color: #f0fdf4;
}

.custom-select.success .select-trigger:hover,
.custom-select.success .select-trigger:focus {
    border-color: var(--color-success);
    box-shadow: 0 0 0 3px rgba(26, 127, 55, 0.08);
}

/* Dark Theme Support */
@media (prefers-color-scheme: dark) {
    .select-trigger {
        background-color: #1a1a1a;
        border-color: #333;
        color: #e5e5e5;
    }
    
    .select-trigger:hover {
        border-color: #555;
        background-color: #2a2a2a;
    }
    
    .select-options {
        background-color: #1a1a1a;
        border-color: #333;
    }
    
    .select-option {
        color: #b5b5b5;
        border-bottom-color: #333;
    }
    
    .select-option:hover {
        background-color: #2a2a2a;
        color: #e5e5e5;
    }
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    .select-trigger {
        border-width: 2px;
    }
    
    .select-option {
        border-bottom-width: 2px;
    }
    
    .select-option.selected {
        font-weight: 600;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    .select-trigger,
    .select-options,
    .select-option,
    .select-trigger i {
        transition: none;
    }
}

/* Focus Management for Accessibility */
.custom-select:focus-within .select-trigger {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

/* Keyboard Navigation Styles */
.select-option.keyboard-focused {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
    outline: 2px solid var(--color-accent);
    outline-offset: -2px;
}

.select-option.keyboard-focused.selected {
    background-color: var(--color-accent-hover);
    outline-color: white;
}

/* Mobile Responsive Adjustments */
@media (max-width: 768px) {
    .custom-select {
        min-width: 140px;
    }
    
    .select-trigger {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 14px;
    }
    
    .select-option {
        padding: var(--spacing-md) var(--spacing-lg);
        font-size: 14px;
    }
    
    .select-options {
        max-height: 200px;
    }
}

@media (max-width: 480px) {
    .custom-select {
        min-width: 120px;
    }
    
    .select-trigger {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 13px;
    }
    
    .select-option {
        padding: var(--spacing-sm) var(--spacing-md);
        font-size: 13px;
    }
    
    .select-options {
        max-height: 160px;
    }
}

/* Animation for smooth opening/closing */
@keyframes tyga-dropdown-open {
    from {
        opacity: 0;
        transform: translateY(-10px) scale(0.95);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes tyga-dropdown-close {
    from {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
    to {
        opacity: 0;
        transform: translateY(-10px) scale(0.95);
    }
}

.custom-select.opening .select-options {
    animation: tyga-dropdown-open 0.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.custom-select.closing .select-options {
    animation: tyga-dropdown-close 0.15s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* Special styling for status/category dropdowns with colored indicators */
.select-option[data-value="active"] i {
    color: var(--color-success);
}

.select-option[data-value="inactive"] i {
    color: var(--color-text-muted);
}

.select-option[data-value="pending"] i {
    color: var(--color-warning);
}

.select-option[data-value="archived"] i {
    color: var(--color-text-muted);
}

/* Category-specific icon colors */
.select-option[data-value="general"] i {
    color: var(--color-text-secondary);
}

.select-option[data-value="consultation"] i {
    color: #2A4F7A;
}

.select-option[data-value="meeting"] i {
    color: #06b6d4;
}

.select-option[data-value="interview"] i {
    color: #f59e0b;
}

.select-option[data-value="demo"] i {
    color: #10b981;
}

.select-option[data-value="support"] i {
    color: #ef4444;
}

.select-option[data-value="training"] i {
    color: #3b82f6;
}

/* Location type icon colors */
.select-option[data-value="video"] i {
    color: #2A4F7A;
}

.select-option[data-value="phone"] i {
    color: #10b981;
}

.select-option[data-value="in-person"] i {
    color: #f59e0b;
}

.select-option[data-value="custom"] i {
    color: var(--color-text-secondary);
}

/* Duration icon styling */
.select-option[data-value*="15"] i,
.select-option[data-value*="30"] i,
.select-option[data-value*="45"] i,
.select-option[data-value*="60"] i,
.select-option[data-value*="90"] i,
.select-option[data-value*="120"] i {
    color: var(--color-info);
}

/* ========================================
   SECURITY SECTION STYLES
   ======================================== */

/* Security Overview Container */
.security-overview {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

/* Security Score Card */
.security-score-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-2xl);
    text-align: center;
    box-shadow: var(--shadow-subtle);
    transition: all 0.15s ease;
}

.security-score-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.security-score {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-lg);
}

.score-circle {
    position: relative;
    width: 120px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: conic-gradient(
        from 0deg,
        var(--color-danger) 0deg,
        var(--color-warning) 120deg,
        var(--color-success) 240deg,
        var(--color-success) 360deg
    );
    padding: 4px;
}

.score-circle::before {
    content: '';
    position: absolute;
    inset: 4px;
    border-radius: 50%;
    background: var(--color-surface);
}

.score-value {
    position: relative;
    z-index: 1;
    font-size: 32px;
    font-weight: 700;
    color: var(--color-text-primary);
    letter-spacing: -0.02em;
}

.score-label {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: var(--spacing-sm);
}

.score-description {
    font-size: 13px;
    color: var(--color-text-muted);
    line-height: 1.4;
    max-width: 300px;
    margin: 0 auto;
}

/* Security Score Variants */
.score-circle.excellent {
    background: conic-gradient(
        from 0deg,
        var(--color-success) 0deg 90%,
        var(--color-border-light) 90% 100%
    );
}

.score-circle.good {
    background: conic-gradient(
        from 0deg,
        var(--color-success) 0deg 70%,
        var(--color-border-light) 70% 100%
    );
}

.score-circle.fair {
    background: conic-gradient(
        from 0deg,
        var(--color-warning) 0deg 50%,
        var(--color-border-light) 50% 100%
    );
}

.score-circle.poor {
    background: conic-gradient(
        from 0deg,
        var(--color-danger) 0deg 30%,
        var(--color-border-light) 30% 100%
    );
}

/* Security Metrics Grid */
.security-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-xl);
}

.metric-item {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
}

.metric-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.metric-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
}

.metric-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.metric-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
    font-size: 16px;
    flex-shrink: 0;
}

.metric-icon.secure {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.metric-icon.warning {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.metric-icon.danger {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.metric-icon.info {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.metric-status {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.01em;
}

.metric-status.secure {
    color: var(--color-success);
}

.metric-status.warning {
    color: var(--color-warning);
}

.metric-status.danger {
    color: var(--color-danger);
}

.metric-status.info {
    color: var(--color-info);
}

.metric-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-lg);
}

.metric-details {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.metric-detail {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: var(--color-text-muted);
}

.metric-detail-label {
    flex: 1;
}

.metric-detail-value {
    font-weight: 500;
    color: var(--color-text-secondary);
}

.metric-actions {
    margin-top: var(--spacing-lg);
    display: flex;
    gap: var(--spacing-sm);
}

/* Security Recommendations */
.security-recommendations {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
}

.recommendations-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.recommendations-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.recommendations-subtitle {
    font-size: 13px;
    color: var(--color-text-secondary);
    margin-top: var(--spacing-xs);
    line-height: 1.4;
}

.recommendations-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

.recommendation-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    transition: all 0.15s ease;
}

.recommendation-item:hover {
    background-color: var(--color-border-light);
}

.recommendation-item:last-child {
    border-bottom: none;
}

.recommendation-icon {
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-lg);
    font-size: 18px;
    flex-shrink: 0;
    margin-top: 2px;
}

.recommendation-icon.high {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.recommendation-icon.medium {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.recommendation-icon.low {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.recommendation-content {
    flex: 1;
    min-width: 0;
}

.recommendation-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.recommendation-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-md);
}

.recommendation-priority {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--spacing-md);
}

.recommendation-priority.high {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.recommendation-priority.medium {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.recommendation-priority.low {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.recommendation-actions {
    display: flex;
    gap: var(--spacing-sm);
    margin-top: var(--spacing-md);
}

/* Security Settings */
.security-settings {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

.security-setting-group {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
}

.security-setting-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.security-setting-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.security-setting-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    margin-top: var(--spacing-xs);
    line-height: 1.4;
}

.security-setting-body {
    padding: var(--spacing-xl);
}

.security-setting-item {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg) 0;
    border-bottom: 1px solid var(--color-border-light);
}

.security-setting-item:last-child {
    border-bottom: none;
    padding-bottom: 0;
}

.security-setting-info {
    flex: 1;
}

.security-setting-name {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.security-setting-help {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin: 0;
}

.security-setting-control {
    flex-shrink: 0;
}

/* Security Audit Log */
.security-audit-log {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
}

.audit-log-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.audit-log-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.audit-log-filters {
    display: flex;
    gap: var(--spacing-sm);
}

.audit-log-body {
    max-height: 400px;
    overflow-y: auto;
}

.audit-log-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

.audit-log-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg) var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    transition: all 0.15s ease;
}

.audit-log-item:hover {
    background-color: var(--color-border-light);
}

.audit-log-item:last-child {
    border-bottom: none;
}

.audit-log-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
    font-size: 14px;
    flex-shrink: 0;
    margin-top: 2px;
}

.audit-log-icon.success {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.audit-log-icon.warning {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.audit-log-icon.danger {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.audit-log-icon.info {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.audit-log-content {
    flex: 1;
    min-width: 0;
}

.audit-log-action {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.audit-log-details {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-sm);
}

.audit-log-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    font-size: 12px;
    color: var(--color-text-muted);
}

.audit-log-time {
    font-variant-numeric: tabular-nums;
}

.audit-log-user {
    font-weight: 500;
}

.audit-log-ip {
    font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    background-color: var(--color-border-light);
    padding: 2px 4px;
    border-radius: 3px;
    font-size: 11px;
}

/* Security Alerts */
.security-alerts {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.security-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg);
    border-radius: var(--radius-lg);
    border-left: 4px solid;
}

.security-alert.critical {
    background-color: #fef2f2;
    border-left-color: var(--color-danger);
}

.security-alert.warning {
    background-color: #fffbeb;
    border-left-color: var(--color-warning);
}

.security-alert.info {
    background-color: #f0f9ff;
    border-left-color: var(--color-info);
}

.security-alert.success {
    background-color: #f0fdf4;
    border-left-color: var(--color-success);
}

.alert-icon {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 12px;
    flex-shrink: 0;
    margin-top: 2px;
}

.security-alert.critical .alert-icon {
    background-color: var(--color-danger);
    color: white;
}

.security-alert.warning .alert-icon {
    background-color: var(--color-warning);
    color: white;
}

.security-alert.info .alert-icon {
    background-color: var(--color-info);
    color: white;
}

.security-alert.success .alert-icon {
    background-color: var(--color-success);
    color: white;
}

.alert-content {
    flex: 1;
    min-width: 0;
}

.alert-title {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.security-alert.critical .alert-title {
    color: var(--color-danger);
}

.security-alert.warning .alert-title {
    color: var(--color-warning);
}

.security-alert.info .alert-title {
    color: var(--color-info);
}

.security-alert.success .alert-title {
    color: var(--color-success);
}

.alert-message {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-md);
}

.alert-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.alert-time {
    font-size: 12px;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
    margin-top: var(--spacing-sm);
}

/* Responsive Design for Security Section */
@media (max-width: 768px) {
    .security-overview {
        gap: var(--spacing-xl);
    }
    
    .security-metrics {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .score-circle {
        width: 100px;
        height: 100px;
    }
    
    .score-value {
        font-size: 28px;
    }
    
    .metric-item {
        padding: var(--spacing-lg);
    }
    
    .recommendation-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
        padding: var(--spacing-lg);
    }
    
    .recommendation-icon {
        margin-top: 0;
    }
    
    .security-setting-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .security-setting-control {
        align-self: flex-end;
    }
    
    .audit-log-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .audit-log-filters {
        width: 100%;
        justify-content: flex-start;
    }
    
    .audit-log-item {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
        padding: var(--spacing-lg);
    }
    
    .audit-log-icon {
        margin-top: 0;
    }
    
    .security-alert {
        flex-direction: column;
        gap: var(--spacing-md);
        padding: var(--spacing-md);
    }
    
    .alert-icon {
        margin-top: 0;
    }
    
    .alert-actions {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .alert-actions .btn {
        width: 100%;
        justify-content: center;
    }
}

@media (max-width: 480px) {
    .security-score-card {
        padding: var(--spacing-xl);
    }
    
    .score-circle {
        width: 80px;
        height: 80px;
    }
    
    .score-value {
        font-size: 24px;
    }
    
    .metric-item {
        padding: var(--spacing-md);
    }
    
    .recommendation-item {
        padding: var(--spacing-md);
    }
    
    .security-setting-header,
    .recommendations-header,
    .audit-log-header {
        padding: var(--spacing-lg);
    }
    
    .security-setting-body,
    .audit-log-body {
        padding: var(--spacing-lg);
    }
    
    .audit-log-item {
        padding: var(--spacing-md);
    }
    
    .audit-log-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-xs);
    }
}

/* ========================================
   SUPPORT SECTIONS STYLES
   ======================================== */

/* Support Tickets Module */
.support-tickets-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

.tickets-filters {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
    padding: var(--spacing-lg);
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.tickets-search {
    position: relative;
    flex: 1;
    max-width: 300px;
}

.tickets-search i {
    position: absolute;
    left: var(--spacing-md);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    font-size: 14px;
}

.tickets-search .form-control {
    padding-left: var(--spacing-3xl);
}

.tickets-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
}

.ticket-stat-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    text-align: center;
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
}

.ticket-stat-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.ticket-stat-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.02em;
}

.ticket-stat-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.tickets-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.ticket-item {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
}

.ticket-item:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.ticket-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-lg);
}

.ticket-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.ticket-id {
    font-size: 12px;
    color: var(--color-text-muted);
    font-family: 'Monaco', 'Menlo', 'Ubuntu Mono', monospace;
    background-color: var(--color-border-light);
    padding: 2px 6px;
    border-radius: var(--radius);
}

.ticket-priority {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ticket-priority.high {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.ticket-priority.medium {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.ticket-priority.low {
    background-color: #f0f9ff;
    color: var(--color-info);
}

.ticket-priority.urgent {
    background-color: #7c2d12;
    color: white;
}

.ticket-status {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-left: var(--spacing-sm);
}

.ticket-status.open {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.ticket-status.pending {
    background-color: #fffbeb;
    color: var(--color-warning);
}

.ticket-status.resolved {
    background-color: var(--color-border-light);
    color: var(--color-text-secondary);
}

.ticket-status.closed {
    background-color: var(--color-border-light);
    color: var(--color-text-muted);
}

.ticket-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-lg);
}

.ticket-meta {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    font-size: 12px;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-lg);
}

.ticket-created,
.ticket-updated,
.ticket-category {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.ticket-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.ticket-messages {
    margin-top: var(--spacing-lg);
    padding-top: var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
}

.ticket-message {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-md);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
}

.ticket-message:last-child {
    margin-bottom: 0;
}

.message-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 12px;
    flex-shrink: 0;
}

.message-content {
    flex: 1;
    min-width: 0;
}

.message-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xs);
}

.message-author {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-primary);
}

.message-time {
    font-size: 11px;
    color: var(--color-text-muted);
    font-variant-numeric: tabular-nums;
}

.message-text {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

/* Support Knowledgebase Module */
.knowledgebase-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
}

.kb-search-section {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-2xl);
    text-align: center;
    box-shadow: var(--shadow-subtle);
}

.kb-search-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-md);
    letter-spacing: -0.01em;
}

.kb-search-subtitle {
    font-size: 14px;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-xl);
    line-height: 1.4;
}

.kb-search-box {
    position: relative;
    max-width: 500px;
    margin: 0 auto;
}

.kb-search-box i {
    position: absolute;
    left: var(--spacing-lg);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    font-size: 16px;
}

.kb-search-input {
    width: 100%;
    padding: var(--spacing-lg) var(--spacing-lg) var(--spacing-lg) 50px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: 16px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: inherit;
    line-height: 1.4;
}

.kb-search-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.kb-categories {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-xl);
}

.kb-category-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
    cursor: pointer;
}

.kb-category-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-2px);
}

.kb-category-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.kb-category-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-lg);
    background-color: var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-secondary);
    font-size: 18px;
    flex-shrink: 0;
}

.kb-category-info {
    flex: 1;
    min-width: 0;
}

.kb-category-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.kb-category-count {
    font-size: 12px;
    color: var(--color-text-muted);
    font-weight: 500;
}

.kb-category-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-lg);
}

.kb-recent-articles {
    list-style: none;
    padding: 0;
    margin: 0;
}

.kb-article-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-border-light);
    transition: all 0.15s ease;
}

.kb-article-item:hover {
    color: var(--color-text-primary);
}

.kb-article-item:last-child {
    border-bottom: none;
}

.kb-article-title {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.3;
    flex: 1;
    text-decoration: none;
}

.kb-article-rating {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 11px;
    color: var(--color-text-muted);
}

.kb-article-helpful {
    color: var(--color-success);
}

.kb-article-not-helpful {
    color: var(--color-danger);
}

.kb-popular-articles {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
}

.kb-popular-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.kb-popular-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.kb-popular-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

.kb-popular-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-lg) var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    transition: all 0.15s ease;
    text-decoration: none;
    color: inherit;
}

.kb-popular-item:hover {
    background-color: var(--color-border-light);
}

.kb-popular-item:last-child {
    border-bottom: none;
}

.kb-popular-rank {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background-color: var(--color-accent);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 600;
    flex-shrink: 0;
}

.kb-popular-content {
    flex: 1;
    min-width: 0;
}

.kb-popular-article-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    line-height: 1.3;
}

.kb-popular-views {
    font-size: 12px;
    color: var(--color-text-muted);
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

/* Support Live Chat Module */
.livechat-container {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);
    height: 600px;
}

.chat-header {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-subtle);
}

.chat-status {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
}

.chat-status-indicator {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: var(--color-success);
    animation: pulse 2s infinite;
}

.status-dot.offline {
    background-color: var(--color-text-muted);
    animation: none;
}

@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(26, 127, 55, 0.7);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(26, 127, 55, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(26, 127, 55, 0);
    }
}

.status-text {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
}

.chat-department-select {
    min-width: 150px;
}

.chat-info {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    font-size: 13px;
    color: var(--color-text-secondary);
}

.chat-queue,
.chat-agents {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.chat-window {
    flex: 1;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: var(--shadow-subtle);
}

.chat-messages {
    flex: 1;
    padding: var(--spacing-lg);
    overflow-y: auto;
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.chat-message {
    display: flex;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-lg);
}

.chat-message:last-child {
    margin-bottom: 0;
}

.chat-message.user {
    flex-direction: row-reverse;
}

.chat-message.user .message-bubble {
    background-color: var(--color-accent);
    color: white;
}

.chat-message.user .message-avatar {
    background: linear-gradient(135deg, var(--color-info) 0%, #0ea5e9 100%);
}

.message-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-success) 0%, #16a34a 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 12px;
    flex-shrink: 0;
}

.message-bubble {
    max-width: 70%;
    padding: var(--spacing-md) var(--spacing-lg);
    border-radius: var(--radius-lg);
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
    font-size: 14px;
    line-height: 1.4;
    position: relative;
}

.message-bubble::before {
    content: '';
    position: absolute;
    top: 10px;
    width: 0;
    height: 0;
    border-style: solid;
}

.chat-message:not(.user) .message-bubble::before {
    left: -8px;
    border-width: 8px 8px 8px 0;
    border-color: transparent var(--color-border-light) transparent transparent;
}

.chat-message.user .message-bubble::before {
    right: -8px;
    border-width: 8px 0 8px 8px;
    border-color: transparent transparent transparent var(--color-accent);
}

.message-time {
    font-size: 11px;
    color: var(--color-text-muted);
    margin-top: var(--spacing-xs);
    text-align: center;
}

.chat-input-area {
    padding: var(--spacing-lg);
    border-top: 1px solid var(--color-border-light);
    background: var(--color-surface);
}

.chat-input-container {
    display: flex;
    gap: var(--spacing-md);
    align-items: flex-end;
}

.chat-input {
    flex: 1;
    min-height: 40px;
    max-height: 120px;
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    font-size: 14px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    resize: none;
    font-family: inherit;
    line-height: 1.4;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}

.chat-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.chat-send-btn {
    width: 40px;
    height: 40px;
    border: none;
    border-radius: var(--radius-lg);
    background-color: var(--color-accent);
    color: white;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.chat-send-btn:hover:not(:disabled) {
    background-color: var(--color-accent-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
}

.chat-send-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.chat-typing-indicator {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md);
    font-size: 13px;
    color: var(--color-text-muted);
    font-style: italic;
}

.typing-dots {
    display: flex;
    gap: 2px;
}

.typing-dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background-color: var(--color-text-muted);
    animation: typing 1.4s infinite ease-in-out;
}

.typing-dot:nth-child(1) {
    animation-delay: -0.32s;
}

.typing-dot:nth-child(2) {
    animation-delay: -0.16s;
}

@keyframes typing {
    0%, 80%, 100% {
        transform: scale(0);
        opacity: 0.5;
    }
    40% {
        transform: scale(1);
        opacity: 1;
    }
}

.chat-file-upload {
    position: relative;
    overflow: hidden;
    display: inline-block;
}

.chat-file-input {
    position: absolute;
    left: -9999px;
}

.chat-file-btn {
    width: 40px;
    height: 40px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    color: var(--color-text-muted);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    transition: all 0.15s ease;
    flex-shrink: 0;
}

.chat-file-btn:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

/* Support Common Styles */
.support-empty-state {
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.support-empty-icon {
    font-size: 48px;
    margin-bottom: var(--spacing-xl);
    opacity: 0.6;
    color: var(--color-text-muted);
}

.support-empty-title {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: var(--spacing-lg);
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

.support-empty-description {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.5;
    margin-bottom: var(--spacing-xl);
}

.support-empty-actions {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
}

.support-loading-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-3xl);
    text-align: center;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-subtle);
}

.support-loading-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--color-border-light);
    border-top: 3px solid var(--color-accent);
    border-radius: 50%;
    animation: spin 1s linear infinite;
    margin-bottom: var(--spacing-lg);
}

.support-loading-text {
    font-size: 14px;
    color: var(--color-text-secondary);
    margin: 0;
}

/* Dark Theme Support for Support Sections */
[data-theme="dark"] .kb-search-section,
[data-theme="dark"] .chat-header,
[data-theme="dark"] .chat-window,
[data-theme="dark"] .support-empty-state,
[data-theme="dark"] .support-loading-state {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-theme="dark"] .chat-messages {
    background: linear-gradient(180deg, var(--color-surface) 0%, #1a1a1a 100%);
}

[data-theme="dark"] .message-bubble {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

[data-theme="dark"] .chat-message.user .message-bubble {
    background-color: var(--color-accent);
    color: white;
}

[data-theme="dark"] .chat-message:not(.user) .message-bubble::before {
    border-color: transparent var(--color-border-light) transparent transparent;
}

[data-theme="dark"] .chat-input {
    background-color: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text-primary);
}

[data-theme="dark"] .chat-input:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(35, 134, 54, 0.08);
}

[data-theme="dark"] .kb-search-input {
    background-color: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text-primary);
}

[data-theme="dark"] .kb-search-input:focus {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(35, 134, 54, 0.08);
}

/* Auto theme based on system preference */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .kb-search-section,
    :root:not([data-theme="light"]) .chat-header,
    :root:not([data-theme="light"]) .chat-window,
    :root:not([data-theme="light"]) .support-empty-state,
    :root:not([data-theme="light"]) .support-loading-state {
        background: var(--color-surface);
        border-color: var(--color-border);
    }
    
    :root:not([data-theme="light"]) .chat-messages {
        background: linear-gradient(180deg, var(--color-surface) 0%, #1a1a1a 100%);
    }
    
    :root:not([data-theme="light"]) .message-bubble {
        background-color: var(--color-border-light);
        color: var(--color-text-primary);
    }
    
    :root:not([data-theme="light"]) .chat-message.user .message-bubble {
        background-color: var(--color-accent);
        color: white;
    }
    
    :root:not([data-theme="light"]) .chat-input,
    :root:not([data-theme="light"]) .kb-search-input {
        background-color: var(--color-surface);
        border-color: var(--color-border);
        color: var(--color-text-primary);
    }
    
    :root:not([data-theme="light"]) .chat-input:focus,
    :root:not([data-theme="light"]) .kb-search-input:focus {
        border-color: var(--color-accent);
        box-shadow: 0 0 0 3px rgba(35, 134, 54, 0.08);
    }
}

/* Responsive Design for Support Sections */
@media (max-width: 768px) {
    .support-tickets-container,
    .knowledgebase-container,
    .livechat-container {
        gap: var(--spacing-xl);
    }
    
    .tickets-filters {
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-md);
    }
    
    .tickets-search {
        max-width: none;
    }
    
    .tickets-stats {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
        gap: var(--spacing-md);
    }
    
    .ticket-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }
    
    .ticket-meta {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }
    
    .ticket-actions {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .kb-categories {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .kb-category-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .chat-status {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .chat-info {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-sm);
    }
    
    .chat-input-container {
        gap: var(--spacing-sm);
    }
    
    .livechat-container {
        height: 500px;
    }
}

@media (max-width: 480px) {
    .ticket-stat-card {
        padding: var(--spacing-lg);
    }
    
    .ticket-item {
        padding: var(--spacing-lg);
    }
    
    .kb-search-section {
        padding: var(--spacing-xl);
    }
    
    .kb-category-card {
        padding: var(--spacing-lg);
    }
    
    .chat-header {
        padding: var(--spacing-lg);
    }
    
    .chat-messages {
        padding: var(--spacing-md);
    }
    
    .chat-input-area {
        padding: var(--spacing-md);
    }
    
    .message-bubble {
        max-width: 85%;
        padding: var(--spacing-sm) var(--spacing-md);
    }
    
    .livechat-container {
        height: 400px;
    }
    
    .support-empty-state {
        padding: var(--spacing-xl) var(--spacing-md);
    }
}

/* ========================================
   SUB-SIDEBAR COMPONENT STYLES
   ======================================== */

/* Sub-sidebar Header */
.sub-sidebar-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.sub-sidebar-back-btn {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    color: var(--color-text-secondary);
    cursor: pointer;
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    margin-bottom: var(--spacing-lg);
    width: fit-content;
}

.sub-sidebar-back-btn:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
    transform: translateX(-2px);
}

.sub-sidebar-back-btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.sub-sidebar-back-btn i {
    font-size: 12px;
    transition: transform 0.15s ease;
}

.sub-sidebar-back-btn:hover i {
    transform: translateX(-2px);
}

.sub-sidebar-title {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
}

.sub-sidebar-title i {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: var(--color-text-secondary);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
    flex-shrink: 0;
}

.sub-sidebar-title span {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    letter-spacing: -0.01em;
}

/* Sub-sidebar Active State */
.sidebar.sub-sidebar-active {
    border-right-color: var(--color-accent);
    box-shadow: var(--shadow-soft);
}

.sidebar.sub-sidebar-active .nav-section-title {
    color: var(--color-accent);
    font-weight: 600;
}

/* Sub-nav Items */
.sub-nav-item {
    position: relative;
    border-radius: var(--radius) !important;
}

.sub-nav-item:hover {
    background-color: var(--color-border-light);
    border-radius: var(--radius) !important;
}

.sub-nav-item.active {
    background-color: var(--color-brand) !important;
    color: #ffffff !important;
    border-radius: var(--radius) !important;
}

.sub-nav-item::before {
    display: none; /* Remove left bar indicator, use full background instead */
}

/* Sub-sidebar Animations */
.sidebar-nav {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sub-sidebar-enter {
    opacity: 0;
    transform: translateX(-20px);
}

.sub-sidebar-enter-active {
    opacity: 1;
    transform: translateX(0);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.sub-sidebar-exit {
    opacity: 1;
    transform: translateX(0);
}

.sub-sidebar-exit-active {
    opacity: 0;
    transform: translateX(-20px);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Sub-sidebar Minimized State */
.sidebar.minimized.sub-sidebar-active .sub-sidebar-header {
    padding: var(--spacing-md);
    text-align: center;
}

.sidebar.minimized.sub-sidebar-active .sub-sidebar-back-btn {
    width: 32px;
    height: 32px;
    padding: 0;
    justify-content: center;
    margin: 0 auto var(--spacing-md) auto;
}

.sidebar.minimized.sub-sidebar-active .sub-sidebar-back-btn span {
    display: none;
}

.sidebar.minimized.sub-sidebar-active .sub-sidebar-title {
    flex-direction: column;
    gap: var(--spacing-xs);
}

.sidebar.minimized.sub-sidebar-active .sub-sidebar-title span {
    font-size: 10px;
    text-align: center;
    line-height: 1.2;
    opacity: 0.8;
}

/* Sub-sidebar Tooltips for Minimized State */
.sidebar.minimized.sub-sidebar-active .sub-nav-item:hover::after {
    content: attr(data-tooltip);
    position: fixed;
    left: 84px;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(26, 26, 26, 0.95);
    color: #ffffff;
    padding: var(--spacing-sm) var(--spacing-md);
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    z-index: 10001;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
    pointer-events: none;
    backdrop-filter: blur(8px);
    animation: tooltipFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.sidebar.minimized.sub-sidebar-active .sub-nav-item:hover::before {
    content: '';
    position: fixed;
    left: 78px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 6px 6px 0;
    border-color: transparent rgba(26, 26, 26, 0.95) transparent transparent;
    z-index: 10001;
    pointer-events: none;
    animation: tooltipFadeIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Dark Theme Support for Sub-sidebar */
[data-theme="dark"] .sub-sidebar-header {
    background: linear-gradient(180deg, var(--color-surface) 0%, #1a1a1a 100%);
}

[data-theme="dark"] .sub-sidebar-back-btn {
    background: var(--color-surface);
    border-color: var(--color-border);
    color: var(--color-text-secondary);
}

[data-theme="dark"] .sub-sidebar-back-btn:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

[data-theme="dark"] .sub-sidebar-title i {
    background-color: var(--color-border-light);
    color: var(--color-text-secondary);
}

[data-theme="dark"] .sidebar.sub-sidebar-active {
    border-right-color: var(--color-accent);
}

/* Auto theme based on system preference */
@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) .sub-sidebar-header {
        background: linear-gradient(180deg, var(--color-surface) 0%, #1a1a1a 100%);
    }
    
    :root:not([data-theme="light"]) .sub-sidebar-back-btn {
        background: var(--color-surface);
        border-color: var(--color-border);
        color: var(--color-text-secondary);
    }
    
    :root:not([data-theme="light"]) .sub-sidebar-back-btn:hover {
        background-color: var(--color-border-light);
        border-color: var(--color-text-muted);
        color: var(--color-text-primary);
    }
    
    :root:not([data-theme="light"]) .sub-sidebar-title i {
        background-color: var(--color-border-light);
        color: var(--color-text-secondary);
    }
    
    :root:not([data-theme="light"]) .sidebar.sub-sidebar-active {
        border-right-color: var(--color-accent);
    }
}

/* Responsive Design for Sub-sidebar */
@media (max-width: 768px) {
    .sub-sidebar-header {
        padding: var(--spacing-lg);
    }
    
    .sub-sidebar-back-btn {
        margin-bottom: var(--spacing-md);
    }
    
    .sub-sidebar-title {
        gap: var(--spacing-sm);
    }
    
    .sub-sidebar-title i {
        width: 18px;
        height: 18px;
        font-size: 14px;
    }
    
    .sub-sidebar-title span {
        font-size: 15px;
    }
}

@media (max-width: 480px) {
    .sub-sidebar-header {
        padding: var(--spacing-md);
    }
    
    .sub-sidebar-back-btn {
        padding: var(--spacing-xs) var(--spacing-sm);
        font-size: 12px;
        margin-bottom: var(--spacing-sm);
    }
    
    .sub-sidebar-title i {
        width: 16px;
        height: 16px;
        font-size: 12px;
    }
    
    .sub-sidebar-title span {
        font-size: 14px;
    }
}

/* ========================================
   EVENT TYPES TEMPLATES STYLES
   ======================================== */

/* Template Filters */
.template-filters {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
    box-shadow: var(--shadow-subtle);
}

.filters-row {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    flex-wrap: wrap;
}

.search-box {
    position: relative;
    flex: 1;
    min-width: 250px;
}

.search-box i {
    position: absolute;
    left: var(--spacing-md);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    font-size: 14px;
}

.search-box .form-control {
    padding-left: var(--spacing-3xl);
}

.filter-select {
    min-width: 150px;
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    font-family: inherit;
    line-height: 1.4;
}

.filter-select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.filter-btn {
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text-secondary);
    font-size: 14px;
    font-weight: 500;
    border-radius: var(--radius);
    cursor: pointer;
    transition: all 0.15s ease;
    white-space: nowrap;
}

.filter-btn:hover {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

.filter-btn.active {
    background-color: var(--color-accent);
    border-color: var(--color-accent);
    color: white;
}

/* Templates Container */
.templates-container {
    min-height: 400px;
}

.templates-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--spacing-xl);
}

/* Template Card */
.template-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
    position: relative;
    cursor: pointer;
}

.template-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-2px);
}

.template-card.popular {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-medium);
}

.popular-badge {
    position: absolute;
    top: -6px;
    right: var(--spacing-lg);
    background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-hover) 100%);
    color: white;
    padding: 2px 6px;
    border-radius: var(--radius);
    font-size: 9px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    display: flex;
    align-items: center;
    gap: 2px;
    box-shadow: var(--shadow-soft);
    white-space: nowrap;
    line-height: 1.2;
}

.popular-badge i {
    font-size: 10px;
}

/* Template Header */
.template-header {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.template-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 20px;
    flex-shrink: 0;
    box-shadow: var(--shadow-subtle);
}

.template-info {
    flex: 1;
    min-width: 0;
}

.template-info h4 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
    line-height: 1.3;
}

.template-category {
    font-size: 12px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 500;
}

/* Template Description */
.template-description {
    margin-bottom: var(--spacing-lg);
}

.template-description p {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin: 0;
}

/* Template Details */
.template-details {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-md);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
}

.detail-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 12px;
    color: var(--color-text-secondary);
}

.detail-item i {
    width: 14px;
    color: var(--color-text-muted);
    font-size: 11px;
    text-align: center;
}

/* Template Actions */
.template-actions {
    display: flex;
    gap: var(--spacing-sm);
}

.btn-sm {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: 12px;
    font-weight: 500;
    border-radius: var(--radius);
}

.btn-outline {
    background-color: transparent;
    color: var(--color-text-secondary);
    border: 1px solid var(--color-border);
}

.btn-outline:hover:not(:disabled) {
    background-color: var(--color-border-light);
    border-color: var(--color-text-muted);
    color: var(--color-text-primary);
}

.btn-primary {
    background-color: var(--color-accent);
    color: white;
    border: 1px solid var(--color-accent);
}

.btn-primary:hover:not(:disabled) {
    background-color: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    transform: translateY(-1px);
    box-shadow: var(--shadow-soft);
}

/* Page Header */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-2xl);
}

.header-content {
    flex: 1;
}

.page-title {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.page-subtitle {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.header-actions {
    display: flex;
    gap: var(--spacing-md);
    flex-shrink: 0;
}

/* Existing Event Types */
.existing-event-types {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--spacing-lg);
}

.section-header h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.event-types-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.existing-event-type-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-subtle);
}

.existing-event-type-card:hover {
    border-color: var(--color-text-muted);
    box-shadow: var(--shadow-soft);
    transform: translateY(-1px);
}

.existing-event-type-card.inactive {
    opacity: 0.6;
    background-color: var(--color-border-light);
}

.event-type-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--spacing-lg);
}

.event-type-icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 16px;
    flex-shrink: 0;
    margin-right: var(--spacing-lg);
}

.event-type-info {
    flex: 1;
    min-width: 0;
}

.event-type-info h4 {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
    letter-spacing: -0.01em;
}

.event-type-description {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.event-type-status {
    flex-shrink: 0;
}

.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.status-badge.active {
    background-color: #f0fdf4;
    color: var(--color-success);
}

.status-badge.inactive {
    background-color: #fef2f2;
    color: var(--color-danger);
}

.event-type-stats {
    display: flex;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
    padding: var(--spacing-md);
    background-color: var(--color-border-light);
    border-radius: var(--radius);
}

.stat-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 12px;
    color: var(--color-text-secondary);
}

.stat-item i {
    width: 14px;
    color: var(--color-text-muted);
    font-size: 11px;
    text-align: center;
}

.event-type-actions {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

/* Modal Styles for Templates */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10000;
    opacity: 1;
    visibility: visible;
}

.modal {
    background: var(--color-surface);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-medium);
    max-width: 600px;
    width: 90%;
    max-height: 90vh;
    overflow: hidden;
    transform: scale(1) translateY(0);
}

.large-modal {
    max-width: 800px;
    width: 95%;
}

.medium-modal {
    max-width: 700px;
    width: 90%;
}

.modal-header {
    padding: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-subtle) 100%);
}

.modal-header h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.modal-close {
    width: 32px;
    height: 32px;
    border: none;
    background: none;
    color: var(--color-text-muted);
    cursor: pointer;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    transition: all 0.15s ease;
}

.modal-close:hover {
    background-color: var(--color-border-light);
    color: var(--color-text-primary);
}

.modal-body {
    padding: var(--spacing-xl);
    max-height: 60vh;
    overflow-y: auto;
}

.modal-footer {
    padding: var(--spacing-xl);
    border-top: 1px solid var(--color-border-light);
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    background: var(--color-surface);
}

/* Template Preview */
.template-preview {
    margin-bottom: var(--spacing-xl);
}

.template-preview-card {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    padding: var(--spacing-lg);
    background-color: var(--color-border-light);
    border-radius: var(--radius-lg);
}

.template-preview-card .template-icon {
    width: 56px;
    height: 56px;
    font-size: 24px;
}

.template-details h4 {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.01em;
}

.template-details p {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.4;
    margin-bottom: var(--spacing-md);
}

.template-specs {
    display: flex;
    gap: var(--spacing-lg);
}

.template-specs span {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
    font-size: 12px;
    color: var(--color-text-muted);
}

.template-specs i {
    font-size: 11px;
}

/* Template Preview Full */
.template-preview-full {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.preview-header {
    display: flex;
    align-items: center;
    gap: var(--spacing-xl);
    padding: var(--spacing-xl);
    background-color: var(--color-border-light);
    border-radius: var(--radius-lg);
}

.template-icon.large {
    width: 80px;
    height: 80px;
    font-size: 32px;
}

.preview-info {
    flex: 1;
}

.preview-info h2 {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.01em;
}

.preview-info .category {
    font-size: 14px;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 500;
    margin-bottom: var(--spacing-md);
}

.preview-info .description {
    font-size: 16px;
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.preview-details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: var(--spacing-xl);
}

.detail-section {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.detail-section h4 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0;
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.detail-section h4 i {
    font-size: 12px;
    color: var(--color-text-muted);
}

.detail-section p {
    font-size: 14px;
    color: var(--color-text-secondary);
    margin: 0;
}

.detail-section ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.detail-section li {
    font-size: 13px;
    color: var(--color-text-secondary);
    padding: var(--spacing-xs) 0;
    border-bottom: 1px solid var(--color-border-light);
}

.detail-section li:last-child {
    border-bottom: none;
}

/* Form Styles for Template Customization */
.form-group {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--spacing-lg);
}

.form-group label {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-sm);
    letter-spacing: -0.01em;
}

.form-control {
    padding: var(--spacing-md) var(--spacing-lg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    color: var(--color-text-primary);
    background-color: var(--color-surface);
    transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    font-family: inherit;
    line-height: 1.4;
}

.form-control:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(36, 41, 47, 0.08);
}

.form-control:hover:not(:focus) {
    border-color: var(--color-text-muted);
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.color-input {
    width: 60px;
    height: 40px;
    padding: 0;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
}

.checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    font-size: 14px;
    color: var(--color-text-primary);
}

.checkbox-label input[type="checkbox"] {
    margin: 0;
    width: 16px;
    height: 16px;
    accent-color: var(--color-accent);
}

/* Responsive Design for Templates */
@media (max-width: 768px) {
    .template-filters {
        padding: var(--spacing-md);
    }
    
    .filters-row {
        flex-direction: column;
        align-items: stretch;
        gap: var(--spacing-md);
    }
    
    .search-box {
        min-width: auto;
    }
    
    .templates-grid {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .template-card {
        padding: var(--spacing-lg);
    }
    
    .template-header {
        gap: var(--spacing-md);
    }
    
    .template-icon {
        width: 40px;
        height: 40px;
        font-size: 18px;
    }
    
    .template-details {
        flex-direction: column;
        gap: var(--spacing-sm);
        align-items: flex-start;
    }
    
    .template-actions {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .template-actions .btn {
        width: 100%;
        justify-content: center;
    }
    
    .page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-lg);
    }
    
    .header-actions {
        width: 100%;
        justify-content: flex-start;
    }
    
    .event-type-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-md);
    }
    
    .event-type-stats {
        flex-direction: column;
        gap: var(--spacing-sm);
    }
    
    .event-type-actions {
        flex-wrap: wrap;
        gap: var(--spacing-sm);
    }
    
    .modal {
        width: 95%;
        margin: var(--spacing-lg);
    }
    
    .modal-body {
        padding: var(--spacing-lg);
    }
    
    .modal-footer {
        flex-direction: column-reverse;
        gap: var(--spacing-sm);
    }
    
    .modal-footer .btn {
        width: 100%;
    }
    
    .template-preview-card {
        flex-direction: column;
        text-align: center;
        gap: var(--spacing-md);
    }
    
    .preview-header {
        flex-direction: column;
        text-align: center;
        gap: var(--spacing-lg);
    }
    
    .preview-details {
        grid-template-columns: 1fr;
        gap: var(--spacing-lg);
    }
    
    .form-row {
        grid-template-columns: 1fr;
        gap: var(--spacing-md);
    }
}

@media (max-width: 480px) {
    .template-card {
        padding: var(--spacing-md);
    }
    
    .template-header {
        gap: var(--spacing-sm);
    }
    
    .template-icon {
        width: 36px;
        height: 36px;
        font-size: 16px;
    }
    
    .template-info h4 {
        font-size: 14px;
    }
    
    .existing-event-type-card {
        padding: var(--spacing-lg);
    }
    
    .modal-header,
    .modal-body,
    .modal-footer {
        padding: var(--spacing-lg);
    }
    
    .template-icon.large {
        width: 60px;
        height: 60px;
        font-size: 24px;
    }
    
    .preview-info h2 {
        font-size: 20px;
    }
}

/* ============================================
   Business Hub Module Styles (mc- prefix)
   Used by: usercustomers, subscription-plans, userpayments, etc.
   ============================================ */

/* Module Header */
.mc-header {
    margin-bottom: var(--spacing-2xl);
}

.mc-title {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-xs) 0;
    letter-spacing: -0.01em;
}

.mc-subtitle {
    font-size: 14px;
    color: var(--color-text-secondary);
    margin: 0;
}

/* Toolbar */
.mc-toolbar {
    display: flex;
    align-items: center;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
    flex-wrap: wrap;
}

.mc-search-container {
    flex: 1;
    min-width: 200px;
    max-width: 400px;
    position: relative;
}

.mc-search-icon {
    position: absolute;
    left: var(--spacing-md);
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-text-muted);
    font-size: 14px;
}

.mc-search-input {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 36px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    background: var(--color-surface);
    color: var(--color-text-primary);
    transition: all 0.15s ease;
}

.mc-search-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(25, 25, 25, 0.08);
}

.mc-search-input::placeholder {
    color: var(--color-text-muted);
}

.mc-toolbar-actions {
    display: flex;
    gap: var(--spacing-sm);
    flex-wrap: wrap;
}

/* Buttons */
/* Management Console Buttons - Pill style */
.mc-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text-primary);
    white-space: nowrap;
}

.mc-btn:hover {
    background: var(--color-surface-subtle);
    border-color: var(--color-text-muted);
}

.mc-btn i {
    font-size: 12px;
}

.mc-btn-primary {
    background: var(--color-surface);
    color: var(--color-text-primary);
    border-color: var(--color-border);
}

.mc-btn-primary:hover {
    background: var(--color-surface-subtle);
    border-color: var(--color-text-muted);
}

.mc-btn-outline {
    background: var(--color-surface);
    color: var(--color-text-primary);
    border-color: var(--color-border);
}

.mc-btn-outline:hover {
    background: var(--color-surface-subtle);
    border-color: var(--color-text-muted);
}

.mc-btn-text {
    background: transparent;
    color: var(--color-text-secondary);
    border: none;
    padding: var(--spacing-sm);
}

.mc-btn-text:hover {
    color: var(--color-text-primary);
    background-color: var(--color-border-light);
}

.mc-btn-icon {
    padding: var(--spacing-sm);
    width: 32px;
    height: 32px;
    justify-content: center;
}

.mc-btn-danger {
    color: var(--color-danger);
}

.mc-btn-danger:hover {
    background-color: #fef2f2;
}

/* Filter Panel */
.mc-filter-panel {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-xl);
}

.mc-filter-row {
    display: flex;
    gap: var(--spacing-md);
    flex-wrap: wrap;
    align-items: center;
}

.mc-filter-select {
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    background: var(--color-surface);
    color: var(--color-text-primary);
    min-width: 150px;
}

.mc-filter-select:focus {
    outline: none;
    border-color: var(--color-accent);
}

/* Table Container */
.mc-table-container {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: visible;
}

.mc-table {
    width: 100%;
    overflow: visible;
}

.mc-table-header {
    display: none;
}

.mc-table-body {
    position: relative;
}

.mc-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 14px 16px;
    border-bottom: 1px solid var(--color-border-light);
    transition: background-color 0.15s ease;
    position: relative;
}

.mc-row:hover {
    background-color: var(--color-surface-subtle);
}

.mc-row:last-child {
    border-bottom: none;
}

.mc-cell {
    font-size: 13px;
    color: var(--color-text-primary);
    display: flex;
    align-items: center;
}

.mc-cell-plan {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.mc-plan-name {
    font-weight: 600;
    font-size: 14px;
    color: var(--color-text-primary);
}

.mc-plan-description {
    font-size: 12px;
    color: #8b949e;
    line-height: 1.4;
}

/* Row 2: type, pricing, status, subscribers, actions inline */
.mc-cell-type,
.mc-cell-pricing,
.mc-cell-status,
.mc-cell-subscribers,
.mc-cell-actions {
    display: inline-flex;
}

.mc-row-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.mc-pricing-monthly {
    font-weight: 600;
    font-size: 13px;
    color: var(--color-text-primary);
}

.mc-pricing-yearly {
    font-size: 11px;
    color: #8b949e;
    margin-left: 4px;
}

.mc-plan-info {
    min-width: 0;
    flex: 1;
}

.mc-plan-name {
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 2px;
}

.mc-plan-description {
    font-size: 13px;
    color: var(--color-text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Status & Type Badges */
.mc-type-badge,
.mc-status-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: var(--radius);
    font-size: 12px;
    font-weight: 500;
}

/* Pricing Display */
.mc-pricing-monthly {
    font-weight: 500;
    color: var(--color-text-primary);
}

.mc-pricing-yearly {
    font-size: 12px;
    color: var(--color-text-muted);
}

/* Subscriber Count */
.mc-subscriber-count {
    font-weight: 500;
}

/* Actions Dropdown */
.mc-actions-dropdown {
    position: relative;
}

.mc-actions-btn {
    background: transparent;
    border: none;
    padding: var(--spacing-sm);
    cursor: pointer;
    color: var(--color-text-muted);
    border-radius: var(--radius);
    transition: all 0.15s ease;
}

.mc-actions-btn:hover {
    background: var(--color-border-light);
    color: var(--color-text-primary);
}

.mc-dropdown-menu {
    position: absolute;
    right: 0;
    top: 100%;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-medium);
    min-width: 160px;
    z-index: 1000;
    display: none;
    padding: var(--spacing-xs) 0;
}

/* Position dropdown upward if near bottom of viewport */
.mc-row:last-child .mc-dropdown-menu,
.mc-row:nth-last-child(2) .mc-dropdown-menu {
    top: auto;
    bottom: 100%;
}

.mc-dropdown-menu.show {
    display: block;
}

.mc-dropdown-item {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: none;
    background: transparent;
    font-size: 14px;
    color: var(--color-text-primary);
    cursor: pointer;
    text-align: left;
    transition: background-color 0.15s ease;
}

.mc-dropdown-item:hover {
    background-color: var(--color-border-light);
}

.mc-dropdown-item i {
    width: 16px;
    color: var(--color-text-muted);
}

.mc-dropdown-item-danger {
    color: var(--color-danger);
}

.mc-dropdown-item-danger:hover {
    background-color: #fef2f2;
}

/* Pagination */
.mc-pagination {
    display: flex;
    justify-content: center;
    padding: var(--spacing-lg);
    border-top: 1px solid var(--color-border);
}

.mc-pagination-controls {
    display: flex;
    align-items: center;
    gap: var(--spacing-xs);
}

.mc-pagination-btn {
    padding: var(--spacing-xs) var(--spacing-sm);
    min-width: 32px;
    height: 32px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    color: var(--color-text-secondary);
    cursor: pointer;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
}

.mc-pagination-btn:hover:not(:disabled) {
    border-color: var(--color-accent);
    color: var(--color-text-primary);
}

.mc-pagination-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.mc-pagination-active {
    background: var(--color-accent);
    color: white;
    border-color: var(--color-accent);
}

.mc-pagination-ellipsis {
    padding: 0 var(--spacing-xs);
    color: var(--color-text-muted);
}

/* Empty State */
.mc-empty-state {
    text-align: center;
    padding: var(--spacing-3xl) var(--spacing-xl);
}

.mc-empty-icon {
    font-size: 48px;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-lg);
}

.mc-empty-state h3 {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-sm);
}

.mc-empty-state p {
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-xl);
}

/* Breadcrumb */
.mc-breadcrumb {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-2xl);
}

.mc-breadcrumb-back {
    background: none !important;
    border: none !important;
    width: auto;
    height: auto;
    border-radius: 0;
    color: #656d76;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s ease;
}

.mc-breadcrumb-back:hover {
    color: var(--color-text-primary);
}

.mc-breadcrumb-back::before {
    content: '\2190';
    font-size: 14px;
    margin-right: 6px;
}

.mc-breadcrumb-back i,
.mc-breadcrumb-back svg {
    display: none !important;
}

.mc-breadcrumb-trail {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: 14px;
}

.mc-breadcrumb-link {
    color: var(--color-text-muted);
}

.mc-breadcrumb-sep {
    color: var(--color-text-muted);
    font-size: 10px;
}

.mc-breadcrumb-current {
    color: var(--color-text-primary);
    font-weight: 500;
}

/* ========================================
   GLOBAL MODAL — Anthropic Style (used by AppModal utility)
   ======================================== */
.kanban-modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 20000;
    background: rgba(0, 0, 0, 0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    animation: appModalOverlayIn 0.15s ease;
}
@keyframes appModalOverlayIn { from { opacity: 0; } to { opacity: 1; } }

.kanban-modal {
    background: var(--color-surface);
    border-radius: 12px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    width: 420px;
    max-width: 90vw;
    animation: appModalIn 0.2s ease;
}
@keyframes appModalIn { from { opacity: 0; transform: scale(0.95) translateY(-10px); } to { opacity: 1; transform: scale(1) translateY(0); } }

.kanban-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--color-border); }
.kanban-modal-header h3 { margin: 0; font-size: 16px; font-weight: 600; color: var(--color-text-primary); }
.kanban-modal-close { background: none; border: none; cursor: pointer; color: var(--color-text-secondary); font-size: 14px; padding: 4px; border-radius: 4px; }
.kanban-modal-close:hover { background: var(--color-surface-subtle); color: var(--color-text-primary); }
.kanban-modal-body { padding: 20px; }
.kanban-modal-body p { margin: 0 0 8px 0; font-size: 14px; color: var(--color-text-primary); line-height: 1.5; }
.kanban-modal-label { display: block; font-size: 13px; font-weight: 500; color: var(--color-text-secondary); margin-bottom: 6px; }
.kanban-modal-input { width: 100%; padding: 8px 12px; border: 1px solid var(--color-border); border-radius: 6px; font-size: 14px; color: var(--color-text-primary); background: var(--color-surface); outline: none; transition: border-color 0.15s ease; box-sizing: border-box; }
.kanban-modal-input:focus { border-color: #1E3A5F; box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.12); }
select.kanban-modal-input { cursor: pointer; }
.kanban-modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 20px 16px; }
.kanban-modal-btn { padding: 8px 16px; border-radius: 20px; font-size: 13px; font-weight: 500; cursor: pointer; border: 1px solid var(--color-border); transition: all 0.15s ease; }
.kanban-modal-btn.cancel { background: var(--color-surface); color: var(--color-text-primary); }
.kanban-modal-btn.cancel:hover { background: var(--color-surface-subtle); }
.kanban-modal-btn.confirm { background: var(--color-brand); color: #ffffff; border-color: var(--color-brand); }
.kanban-modal-btn.confirm:hover { background: var(--color-brand-hover); }
.kanban-modal-btn.confirm.danger { background: #cf222e; border-color: #cf222e; }
.kanban-modal-btn.confirm.danger:hover { background: #a40e26; }

/* ========================================
   HELP PANEL — Right Slide-Out
   ======================================== */
.help-panel-overlay {
    position: fixed;
    inset: 0;
    z-index: 9998;
    background: rgba(0, 0, 0, 0.2);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.25s ease;
}
.help-panel-overlay.open {
    opacity: 1;
    pointer-events: auto;
}

.help-panel {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 380px;
    max-width: 90vw;
    background: var(--color-surface);
    z-index: 9999;
    box-shadow: -8px 0 30px rgba(0, 0, 0, 0.12);
    transform: translateX(100%);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
}
.help-panel.open {
    transform: translateX(0);
}

.help-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--color-border);
    flex-shrink: 0;
}

.help-panel-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.help-panel-title i {
    color: #1E3A5F;
    font-size: 16px;
}

.help-panel-close {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--color-text-secondary);
    font-size: 14px;
    padding: 4px 8px;
    border-radius: 4px;
}
.help-panel-close:hover {
    background: var(--color-surface-subtle);
    color: var(--color-text-primary);
}

.help-panel-body {
    flex: 1;
    overflow-y: auto;
    padding: 16px 20px;
}

.help-panel-loading {
    text-align: center;
    padding: 40px 0;
    color: #8b949e;
    font-size: 13px;
}

.help-section-overview {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--color-border-light);
}

.help-subsection {
    margin-bottom: 4px;
}

.help-subsection-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 10px 12px;
    background: var(--color-surface-subtle);
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-primary);
    transition: background 0.15s;
}
.help-subsection-toggle:hover {
    background: var(--color-border-light);
}
.help-subsection-toggle i {
    font-size: 10px;
    color: #8b949e;
    transition: transform 0.2s;
}
.help-subsection-toggle.active i {
    transform: rotate(180deg);
}

.help-subsection-content {
    display: none;
    padding: 8px 0;
}
.help-subsection-content.expanded {
    display: block;
}

.help-item {
    padding: 8px 12px;
    border-bottom: 1px solid var(--color-border-light);
}
.help-item:last-child {
    border-bottom: none;
}

.help-item-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}

.help-item-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.help-item-type {
    font-size: 10px;
    padding: 1px 6px;
    border-radius: 8px;
    background: var(--color-border-light);
    color: var(--color-text-secondary);
    font-weight: 500;
    text-transform: lowercase;
}

.help-item-text {
    font-size: 12px;
    color: var(--color-text-secondary);
    line-height: 1.5;
}

.help-item-options {
    font-size: 11px;
    color: #8b949e;
    margin-top: 4px;
    font-style: italic;
}

.help-steps {
    padding-left: 20px;
    margin: 8px 0;
}
.help-steps li {
    font-size: 12px;
    color: #656d76;
    line-height: 1.6;
    margin-bottom: 4px;
}

.help-fallback {
    text-align: center;
    padding: 40px 20px;
    color: #8b949e;
    font-size: 13px;
}

/* ========================================
   GLOBAL BREADCRUMB — Anthropic Text Link Style
   ======================================== */
.anthropic-breadcrumb {
    margin-bottom: 16px;
}

.breadcrumb-container {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
}

.breadcrumb-back-btn {
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    color: #656d76;
    cursor: pointer;
    font-size: 14px;
    font-weight: 400;
    padding: 0 !important;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: color 0.15s ease;
    border-radius: 0 !important;
}

/* Hide any embedded SVG/icon arrows — the text itself is the link */
.breadcrumb-back-btn svg,
.breadcrumb-back-btn i.fas.fa-arrow-left {
    display: none !important;
}

.breadcrumb-back-btn::before {
    content: '\2190';
    font-size: 14px;
}

.breadcrumb-back-btn:hover {
    color: var(--color-text-primary);
    background: none !important;
    transform: none !important;
}

.breadcrumb-separator {
    color: var(--color-border);
    font-size: 14px;
    user-select: none;
}

.breadcrumb-current {
    color: var(--color-text-primary);
    font-size: 14px;
    font-weight: 600;
}

/* Form Styles */
.mc-form-container {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-2xl);
}

.mc-form-section {
    margin-bottom: var(--spacing-2xl);
    padding-bottom: var(--spacing-2xl);
    border-bottom: 1px solid var(--color-border);
}

.mc-form-section:last-of-type {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.mc-form-section-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-lg);
}

.mc-form-row {
    display: flex;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-lg);
}

.mc-form-row:last-child {
    margin-bottom: 0;
}

.mc-form-group {
    flex: 1;
    min-width: 0;
}

.mc-form-group-full {
    flex: 1 0 100%;
}

.mc-form-group-checkbox {
    flex: none;
}

.mc-form-label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-xs);
}

.mc-form-label .required {
    color: var(--color-danger);
}

.mc-form-input,
.mc-form-select,
.mc-form-textarea {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 14px;
    background: var(--color-surface);
    color: var(--color-text-primary);
    transition: all 0.15s ease;
}

.mc-form-input:focus,
.mc-form-select:focus,
.mc-form-textarea:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(25, 25, 25, 0.08);
}

.mc-form-textarea {
    resize: vertical;
    min-height: 80px;
}

.mc-input-group {
    display: flex;
    align-items: stretch;
}

.mc-input-prefix {
    display: flex;
    align-items: center;
    padding: 0 var(--spacing-md);
    background: var(--color-border-light);
    border: 1px solid var(--color-border);
    border-right: none;
    border-radius: var(--radius) 0 0 var(--radius);
    color: var(--color-text-muted);
    font-size: 14px;
}

.mc-form-input-currency {
    border-radius: 0 var(--radius) var(--radius) 0;
}

.mc-checkbox-label {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    cursor: pointer;
    font-size: 14px;
    color: var(--color-text-primary);
}

.mc-checkbox-label input {
    width: 16px;
    height: 16px;
    cursor: pointer;
}

.mc-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-md);
    padding-top: var(--spacing-xl);
    margin-top: var(--spacing-xl);
    border-top: 1px solid var(--color-border);
}

/* Features List */
.mc-features-list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.mc-feature-row {
    display: flex;
    gap: var(--spacing-sm);
    align-items: center;
}

.mc-feature-name {
    flex: 2;
}

.mc-feature-value {
    flex: 1;
}

/* Detail View */
.mc-detail-container {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--spacing-2xl);
}

.mc-detail-header {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-lg);
    padding-bottom: var(--spacing-2xl);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--spacing-2xl);
}

.mc-detail-icon {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.mc-detail-icon i {
    font-size: 24px;
}

.mc-detail-info {
    flex: 1;
    min-width: 0;
}

.mc-detail-info h2 {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-sm) 0;
}

.mc-detail-meta {
    display: flex;
    gap: var(--spacing-sm);
}

.mc-detail-actions {
    flex-shrink: 0;
}

.mc-detail-section {
    margin-bottom: var(--spacing-2xl);
}

.mc-detail-section:last-child {
    margin-bottom: 0;
}

.mc-detail-section h3 {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--spacing-md);
}

.mc-detail-section p {
    font-size: 14px;
    color: var(--color-text-primary);
    line-height: 1.6;
}

.mc-pricing-cards {
    display: flex;
    gap: var(--spacing-lg);
}

.mc-pricing-card {
    background: var(--color-border-light);
    border-radius: var(--radius);
    padding: var(--spacing-lg);
    min-width: 120px;
}

.mc-pricing-label {
    font-size: 12px;
    color: var(--color-text-muted);
    margin-bottom: var(--spacing-xs);
}

.mc-pricing-amount {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.mc-pricing-savings {
    font-size: 12px;
    color: var(--color-success);
    margin-top: var(--spacing-xs);
}

.mc-pricing-note {
    font-size: 13px;
    color: var(--color-text-muted);
    margin-top: var(--spacing-md);
}

.mc-pricing-note i {
    margin-right: var(--spacing-xs);
}

.mc-features-list-detail {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mc-features-list-detail li {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) 0;
    font-size: 14px;
    color: var(--color-text-primary);
}

.mc-features-list-detail li i {
    color: var(--color-success);
    width: 16px;
}

.mc-subscriber-stat {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
}

.mc-subscriber-stat i {
    color: var(--color-text-muted);
}

.mc-subscriber-count-large {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
}

/* Loading State */
.mc-table .loading-state {
    padding: var(--spacing-3xl);
    text-align: center;
}

.mc-table .loading-state .spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--color-border);
    border-top-color: var(--color-accent);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin: 0 auto var(--spacing-lg);
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Responsive adjustments */
@media (max-width: 1024px) {
    .mc-table-header,
    .mc-row {
        grid-template-columns: 2fr 1fr 1fr 80px;
    }

    .mc-cell-subscribers,
    .mc-header-cell.mc-cell-subscribers {
        display: none;
    }
}

@media (max-width: 768px) {
    .mc-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .mc-search-container {
        max-width: none;
    }

    .mc-toolbar-actions {
        justify-content: flex-start;
    }

    .mc-table-header,
    .mc-row {
        grid-template-columns: 1fr 1fr 60px;
    }

    .mc-cell-type,
    .mc-header-cell.mc-cell-type,
    .mc-cell-pricing,
    .mc-header-cell.mc-cell-pricing {
        display: none;
    }

    .mc-form-row {
        flex-direction: column;
    }

    .mc-pricing-cards {
        flex-direction: column;
    }
}

/* ============================================
   Payment Module Styles (mp- prefix aliases)
   Maps mp- classes to mc- styles for consistency
   ============================================ */

/* Header */
.mp-header { margin-bottom: var(--spacing-2xl); }
.mp-title { font-size: 24px; font-weight: 600; color: var(--color-text-primary); margin: 0; letter-spacing: -0.01em; }

/* Toolbar */
.mp-toolbar { display: flex; align-items: center; gap: var(--spacing-lg); margin-bottom: var(--spacing-xl); flex-wrap: wrap; }
.mp-search-container { flex: 1; min-width: 200px; max-width: 400px; position: relative; }
.mp-search-icon { position: absolute; left: var(--spacing-md); top: 50%; transform: translateY(-50%); color: var(--color-text-muted); font-size: 14px; }
.mp-search-input { width: 100%; padding: var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 36px; border: 1px solid var(--color-border); border-radius: var(--radius); font-size: 14px; background: var(--color-surface); color: var(--color-text-primary); transition: all 0.15s ease; }
.mp-search-input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px rgba(25, 25, 25, 0.08); }
.mp-search-input::placeholder { color: var(--color-text-muted); }
.mp-toolbar-actions { display: flex; gap: var(--spacing-sm); flex-wrap: wrap; }

/* Buttons */
.mp-btn { display: inline-flex; align-items: center; gap: var(--spacing-xs); padding: var(--spacing-sm) var(--spacing-lg); border-radius: var(--radius); font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.15s ease; border: 1px solid transparent; white-space: nowrap; }
.mp-btn i { font-size: 12px; }
.mp-btn-primary { background-color: var(--color-accent); color: white; border-color: var(--color-accent); }
.mp-btn-primary:hover { background-color: var(--color-accent-hover); border-color: var(--color-accent-hover); transform: translateY(-1px); box-shadow: var(--shadow-soft); }
.mp-btn-outline { background-color: var(--color-surface); color: var(--color-text-secondary); border-color: var(--color-border); }
.mp-btn-outline:hover { background-color: var(--color-border-light); border-color: var(--color-text-muted); color: var(--color-text-primary); }
.mp-btn-text { background: transparent; color: var(--color-text-secondary); border: none; padding: var(--spacing-sm); }
.mp-btn-text:hover { color: var(--color-text-primary); background-color: var(--color-border-light); }

/* Filter Panel */
.mp-filter-panel { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius); padding: var(--spacing-lg); margin-bottom: var(--spacing-xl); }
.mp-filter-row { display: flex; gap: var(--spacing-md); flex-wrap: wrap; align-items: center; }
.mp-filter-select, .mp-filter-date { padding: var(--spacing-sm) var(--spacing-md); border: 1px solid var(--color-border); border-radius: var(--radius); font-size: 14px; background: var(--color-surface); color: var(--color-text-primary); min-width: 150px; }
.mp-filter-select:focus, .mp-filter-date:focus { outline: none; border-color: var(--color-accent); }

/* Table */
.mp-table-container { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.mp-table { width: 100%; }
.mp-pagination { display: flex; justify-content: center; padding: var(--spacing-lg); border-top: 1px solid var(--color-border); }

/* Breadcrumb */
.mp-breadcrumb { display: flex; align-items: center; gap: var(--spacing-md); margin-bottom: var(--spacing-2xl); }
.mp-breadcrumb-back { width: 36px; height: 36px; border-radius: var(--radius); border: 1px solid var(--color-border); background: var(--color-surface); color: var(--color-text-secondary); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s ease; }
.mp-breadcrumb-back:hover { border-color: var(--color-text-muted); color: var(--color-text-primary); }
.mp-breadcrumb-trail { display: flex; align-items: center; gap: var(--spacing-sm); font-size: 14px; }
.mp-breadcrumb-link { color: var(--color-text-muted); }
.mp-breadcrumb-sep { color: var(--color-text-muted); font-size: 10px; }
.mp-breadcrumb-current { color: var(--color-text-primary); font-weight: 500; }

/* ============================================
   Activity Calendar Widget Styles
   Colored rounded square backgrounds on days with activity
   ============================================ */

/* Remove padding from widget-content for activity calendar */
.widget-content:has(.activity-calendar-widget) {
    padding: 0 !important;
    overflow: hidden !important;
}

.activity-calendar-widget {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 12px;
    gap: 4px;
    box-sizing: border-box;
    overflow: hidden;
}

.activity-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
}

.cal-nav-btn {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: var(--radius);
    cursor: pointer;
    color: var(--color-text-muted);
    transition: all 0.15s ease;
}

.cal-nav-btn:hover {
    background: var(--color-border-light);
    color: var(--color-text-primary);
}

.cal-dropdowns {
    display: flex;
    align-items: center;
    gap: 6px;
}

.cal-month-select,
.cal-year-select {
    padding: 2px 6px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    color: var(--color-text-primary);
    font-size: 12px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 4px center;
    padding-right: 18px;
}

.cal-month-select:focus,
.cal-year-select:focus {
    outline: none;
    border-color: var(--color-accent);
}

.activity-cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    text-align: center;
    font-size: 10px;
    font-weight: 500;
    color: var(--color-text-muted);
    padding: 4px 0;
    flex-shrink: 0;
}

.activity-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-template-rows: repeat(6, 1fr);
    gap: 3px;
    flex: 1;
    min-height: 0;
}

.activity-cal-day {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    position: relative;
    min-height: 0;
}

.activity-cal-day.empty {
    background: transparent;
}

.activity-cal-day .day-number {
    font-size: 11px;
    color: var(--color-text-secondary);
    font-weight: 500;
}

/* Status colored backgrounds - full rounded squares */
.activity-cal-day.status-completed {
    background: #fbbf24;
}

.activity-cal-day.status-completed .day-number {
    color: #1a1a1a;
    font-weight: 600;
}

.activity-cal-day.status-scheduled {
    background: #2A4F7A;
}

.activity-cal-day.status-scheduled .day-number {
    color: #1a1a1a;
    font-weight: 600;
}

.activity-cal-day.status-noshow {
    background: #d946ef;
}

.activity-cal-day.status-noshow .day-number {
    color: #1a1a1a;
    font-weight: 600;
}

.activity-cal-day.status-cancelled {
    background: transparent;
    border: 2px solid var(--color-border);
}

/* Today: dark background */
.activity-cal-day.today {
    background: #1a1a1a;
}

.activity-cal-day.today .day-number {
    color: white;
    font-weight: 600;
}

/* Legend with pill badges */
.activity-cal-legend {
    display: flex;
    flex-wrap: nowrap;
    gap: 4px;
    padding: 8px 0 4px;
    justify-content: center;
    flex-shrink: 0;
}

.legend-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 9px;
    font-weight: 500;
    white-space: nowrap;
}

.legend-badge.completed {
    background: #EBF0F7;
    color: #1E3A5F;
}

.legend-badge.scheduled {
    background: #D6E1F0;
    color: #1E3A5F;
}

.legend-badge.noshow {
    background: #f5d0fe;
    color: #86198f;
}

.legend-badge.cancelled {
    background: var(--color-surface);
    color: var(--color-text-muted);
    border: 1px solid var(--color-border);
}

/* See Full Calendar link */
.activity-cal-link {
    display: block;
    text-align: center;
    font-size: 11px;
    color: var(--color-text-muted);
    text-decoration: none;
    padding: 6px 0 0;
    border-top: 1px solid var(--color-border-light);
    flex-shrink: 0;
}

.activity-cal-link:hover {
    color: var(--color-text-primary);
}

/* ============================================
   Performance Breakdown Widget Styles
   Semi-circular donut chart with status breakdown
   ============================================ */

/* Remove padding from widget-content for performance breakdown */
.widget-content:has(.performance-breakdown-widget) {
    padding: 0 !important;
    overflow: hidden !important;
}

.performance-breakdown-widget {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 16px;
    gap: 12px;
    box-sizing: border-box;
    overflow: visible;
}

.perf-header {
    display: flex;
    justify-content: flex-end;
    flex-shrink: 0;
}

.perf-timeframe-select {
    padding: 6px 28px 6px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    color: var(--color-text-primary);
    font-size: 12px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

.perf-timeframe-select:focus {
    outline: none;
    border-color: var(--color-accent);
}

.perf-metrics {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-shrink: 0;
}

.perf-metrics-left {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.perf-label {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.perf-value {
    font-size: 36px;
    font-weight: 700;
    color: var(--color-text-primary);
    line-height: 1;
}

.perf-metrics-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}

.perf-change {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 14px;
    font-weight: 600;
}

.perf-change.positive {
    color: #22c55e;
}

.perf-change.negative {
    color: #ef4444;
}

.perf-change i {
    font-size: 12px;
}

.perf-comparison {
    font-size: 11px;
    color: var(--color-text-muted);
}

.perf-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    flex-shrink: 0;
}

.perf-legend-item {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    font-weight: 600;
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.perf-legend-item .legend-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.perf-legend-item.complete .legend-dot {
    background: #22c55e;
}

.perf-legend-item.scheduled .legend-dot {
    background: #fbbf24;
}

.perf-legend-item.rearranged .legend-dot {
    background: #d946ef;
}

.perf-legend-item.cancelled .legend-dot {
    background: #1a1a1a;
}

.perf-legend-item.noshow .legend-dot {
    background: #6b7280;
}

.perf-chart {
    flex: 1;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    min-height: 120px;
    padding: 12px 0;
    overflow: visible;
}

.perf-donut-svg {
    width: 100%;
    max-width: 200px;
    height: auto;
}

.perf-donut-chart {
    width: 100%;
    max-width: 240px;
    height: auto;
    min-height: 80px;
}

.perf-donut-chart.empty {
    opacity: 0.6;
}

.perf-donut-chart .empty-arc {
    stroke-dasharray: 8 4;
}

/* Performance Breakdown - Empty State */
.performance-breakdown-widget.no-data {
    position: relative;
}

.performance-breakdown-widget.no-data .perf-legend.dimmed {
    opacity: 0.4;
}

.perf-no-change {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-muted);
}

.perf-no-change .no-data-indicator {
    display: inline-block;
    opacity: 0.5;
}

.perf-donut-chart.empty {
    opacity: 0.6;
}

.perf-donut-chart.empty .empty-arc {
    stroke-dasharray: 8 4;
}

.perf-empty-message {
    position: absolute;
    bottom: 16px;
    left: 0;
    right: 0;
    text-align: center;
    padding: 0 16px;
}

.perf-empty-message p {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin: 0 0 4px 0;
}

.perf-empty-message span {
    font-size: 11px;
    color: var(--color-text-muted);
}

/* ============================================
   Sales Chart Widget Styles
   Lollipop chart with team member avatars
   ============================================ */

/* Remove padding from widget-content for sales chart */
.widget-content:has(.sales-chart-widget) {
    padding: 0 !important;
    overflow: hidden !important;
}

.sales-chart-widget {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 16px;
    gap: 12px;
    box-sizing: border-box;
    overflow: hidden;
}

.sales-header {
    display: flex;
    justify-content: flex-end;
    flex-shrink: 0;
}

.sales-quarter-select {
    padding: 6px 28px 6px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: var(--color-surface);
    color: var(--color-text-primary);
    font-size: 12px;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
}

.sales-quarter-select:focus {
    outline: none;
    border-color: var(--color-accent);
}

.sales-chart-container {
    display: flex;
    flex: 1;
    min-height: 0;
    gap: 8px;
}

.sales-y-axis {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding-bottom: 40px;
    flex-shrink: 0;
}

.sales-y-label {
    font-size: 11px;
    color: var(--color-text-muted);
    text-align: right;
    min-width: 20px;
}

.sales-chart-area {
    flex: 1;
    display: flex;
    flex-direction: column;
    position: relative;
    min-width: 0;
}

.sales-grid-lines {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 40px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    pointer-events: none;
}

.sales-grid-line {
    border-bottom: 1px solid var(--color-border-light);
    height: 0;
}

.sales-grid-line:last-child {
    border-bottom: none;
}

.sales-bars {
    display: flex;
    align-items: flex-end;
    justify-content: space-around;
    flex: 1;
    padding-bottom: 40px;
    gap: 8px;
}

.sales-bar-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    max-width: 50px;
    height: 100%;
}

.sales-bar-wrapper {
    flex: 1;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
}

.sales-lollipop {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 10px;
}

.sales-lollipop-dot {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #1E3A5F;
    flex-shrink: 0;
}

.sales-lollipop-stick {
    width: 4px;
    flex: 1;
    background: #1E3A5F;
    border-radius: 0 0 2px 2px;
    min-height: 2px;
}

.sales-bar-avatar {
    margin-top: 8px;
    flex-shrink: 0;
}

.sales-avatar-img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--color-border-light);
}

.sales-avatar-initials {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-border-light);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 10px;
    font-weight: 600;
    color: var(--color-text-secondary);
}

/* Sales Chart - Empty State */
.sales-chart-widget.no-data {
    position: relative;
}

.sales-empty-state {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.sales-empty-chart {
    display: flex;
    width: 100%;
    max-width: 200px;
    height: 80px;
    margin-bottom: 16px;
    opacity: 0.4;
}

.sales-empty-y-axis {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding-right: 8px;
    font-size: 10px;
    color: var(--color-text-muted);
}

.sales-empty-grid {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border-left: 1px solid var(--color-border-light);
    border-bottom: 1px solid var(--color-border-light);
}

.sales-empty-grid-line {
    border-bottom: 1px dashed var(--color-border-light);
    height: 0;
}

.sales-empty-grid-line:last-child {
    border-bottom: none;
}

.sales-empty-message {
    text-align: center;
}

.sales-empty-message i {
    font-size: 24px;
    color: var(--color-text-muted);
    opacity: 0.5;
    margin-bottom: 8px;
}

.sales-empty-message p {
    font-size: 13px;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin: 0 0 4px 0;
}

.sales-empty-message span {
    font-size: 11px;
    color: var(--color-text-muted);
}

/* ========================================
   Meetings Team Chart Widget
   ======================================== */

.meetings-chart-widget {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0;
}

.meetings-header {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 16px;
}

.meetings-timeframe-select {
    padding: 6px 28px 6px 12px;
    font-size: 12px;
    font-weight: 500;
    color: var(--color-text-primary);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M3 5l3 3 3-3'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 8px center;
}

.meetings-chart-container {
    display: flex;
    flex: 1;
    gap: 8px;
    height: 100%;
    min-height: 0;
}

.meetings-y-axis {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding-bottom: 40px;
    width: 30px;
    flex-shrink: 0;
}

.meetings-y-label {
    font-size: 11px;
    color: var(--color-text-muted);
    text-align: right;
    line-height: 1;
}

.meetings-chart-area {
    flex: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
    min-height: 0;
}

.meetings-grid-lines {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 40px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    pointer-events: none;
}

.meetings-grid-line {
    height: 1px;
    background: var(--color-border-light);
}

.meetings-bars {
    flex: 1;
    display: flex;
    align-items: stretch;
    gap: 12px;
    padding-bottom: 40px;
    height: 100%;
    min-height: 0;
}

.meetings-bar-item {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    min-width: 0;
    height: 100%;
}

.meetings-lollipop {
    width: 4px;
    background: transparent;
    position: relative;
    min-height: 4px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.meetings-lollipop-dot {
    width: 14px;
    height: 14px;
    background: #1E3A5F;
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 2px 4px rgba(30, 58, 95, 0.3);
}

.meetings-lollipop-stick {
    width: 4px;
    flex: 1;
    background: linear-gradient(to bottom, #1E3A5F, #2A4F7A);
    border-radius: 0 0 2px 2px;
    min-height: 2px;
}

.meetings-bar-avatar {
    margin-top: 8px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    border: 2px solid var(--color-border-light);
}

.meetings-avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.meetings-avatar-initials {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-border-light);
    color: var(--color-text-secondary);
    font-size: 11px;
    font-weight: 600;
}

.meetings-empty-state {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 24px;
    color: var(--color-text-muted);
}

.meetings-empty-state i {
    font-size: 32px;
    margin-bottom: 12px;
    opacity: 0.5;
}

.meetings-empty-state p {
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-secondary);
    margin: 0 0 4px 0;
}

.meetings-empty-state span {
    font-size: 12px;
    color: var(--color-text-muted);
}

/* ========================================
   Performance Insights Widget
   ======================================== */

.performance-insights-widget {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0;
}

.insights-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.performance-insight-card {
    display: flex;
    background: var(--color-surface);
    border: 1px solid var(--color-border-light);
    border-left: 4px solid #1E3A5F;
    border-radius: var(--radius-lg);
    padding: 16px 20px;
    transition: all 0.15s ease;
}

.performance-insight-card:hover {
    border-color: var(--color-border);
    box-shadow: var(--shadow-soft);
}

.insight-content {
    flex: 1;
}

.insight-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: 4px;
    line-height: 1.3;
}

.insight-message {
    font-size: 13px;
    color: var(--color-text-secondary);
    line-height: 1.5;
}

.insight-highlight {
    color: #1E3A5F;
    font-weight: 600;
}

.insight-link {
    color: var(--color-text-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}

.insight-link:hover {
    color: #1E3A5F;
}

/* ========================================
   Appoiint Card Header Section
   ======================================== */

.appoiint-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--spacing-2xl) var(--spacing-3xl);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    margin-bottom: var(--spacing-2xl);
}

.appoiint-card-header-content {
    flex: 1;
}

.appoiint-card-title {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-text-primary);
    margin: 0 0 var(--spacing-sm) 0;
    line-height: 1.2;
}

.appoiint-card-subtitle {
    font-size: 14px;
    font-weight: 400;
    color: var(--color-text-secondary);
    margin: 0;
    line-height: 1.5;
}

.appoiint-card-header-qr {
    display: flex;
    align-items: flex-start;
    flex-shrink: 0;
}

.appoiint-card-qr-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.appoiint-card-qr-container {
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.appoiint-card-qr-container canvas,
.appoiint-card-qr-container svg {
    width: 100% !important;
    height: 100% !important;
}

.appoiint-card-dropdown {
    position: absolute;
    top: -4px;
    right: -4px;
    z-index: 10;
}

.appoiint-card-dropdown-btn {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    cursor: pointer;
    color: var(--color-text-muted);
    transition: all 0.15s ease;
    box-shadow: var(--shadow-small);
}

.appoiint-card-dropdown-btn:hover {
    color: var(--color-text-primary);
    background: var(--color-surface);
    border-color: var(--color-border-dark);
}

.appoiint-card-dropdown-menu {
    position: absolute;
    right: 0;
    top: 100%;
    margin-top: 4px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-medium);
    min-width: 160px;
    z-index: 1000;
    display: none;
    overflow: hidden;
}

.appoiint-card-dropdown.open .appoiint-card-dropdown-menu {
    display: block;
}

.appoiint-card-dropdown-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--color-text-primary);
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background 0.15s ease;
}

.appoiint-card-dropdown-item:hover {
    background: var(--color-border-light);
}

.appoiint-card-dropdown-item i {
    width: 16px;
    color: var(--color-text-secondary);
}

/* Responsive adjustments for Appoiint Card Header */
@media (max-width: 640px) {
    .appoiint-card-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-lg);
        padding: var(--spacing-xl);
    }

    .appoiint-card-header-qr {
        align-self: flex-start;
    }

    .appoiint-card-title {
        font-size: 20px;
    }
}

/* ========================================
   ADVANCED COLOR PICKER (Edit Form)
   Matches wizard step 3 color picker
   ======================================== */

.wizard-color-picker-section {
    background: #fff;
    border-radius: 12px;
    padding: 20px;
    border: 1px solid #e5e7eb;
    margin-bottom: 20px;
}

.wizard-color-picker-title {
    margin: 0 0 4px 0;
    font-size: 15px;
    font-weight: 600;
    color: #1a1a1a;
}

.wizard-color-picker-subtitle {
    margin: 0 0 16px 0;
    font-size: 13px;
    color: #656d76;
}

/* Color Picker Body - Two Column Layout */
.wizard-color-picker-body {
    display: flex;
    gap: 24px;
}

.wizard-color-picker-left {
    flex: 1;
    min-width: 200px;
}

.wizard-color-picker-right {
    flex: 1;
    min-width: 180px;
}

/* Gradient Picker */
.wizard-color-gradient-picker {
    width: 100%;
    height: 150px;
    border-radius: 8px;
    position: relative;
    cursor: crosshair;
    background: linear-gradient(to right, #fff 0%, hsl(217, 100%, 50%) 100%);
    margin-bottom: 12px;
}

.wizard-color-gradient-picker::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 0%, #000 100%);
    border-radius: 8px;
    pointer-events: none;
}

.wizard-color-gradient-cursor {
    position: absolute;
    width: 16px;
    height: 16px;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 0 4px rgba(0,0,0,0.4);
    transform: translate(-50%, -50%);
    top: 40%;
    left: 72%;
    z-index: 1;
    pointer-events: none;
}

/* Hue Slider */
.wizard-color-hue-slider {
    margin-bottom: 16px;
}

.wizard-hue-range {
    width: 100%;
    height: 12px;
    border-radius: 6px;
    -webkit-appearance: none;
    appearance: none;
    background: linear-gradient(to right,
        hsl(0, 100%, 50%),
        hsl(60, 100%, 50%),
        hsl(120, 100%, 50%),
        hsl(180, 100%, 50%),
        hsl(240, 100%, 50%),
        hsl(300, 100%, 50%),
        hsl(360, 100%, 50%)
    );
    cursor: pointer;
}

.wizard-hue-range::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,0.3);
    cursor: pointer;
}

.wizard-hue-range::-moz-range-thumb {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid #fff;
    box-shadow: 0 2px 6px rgba(0,0,0,0.3);
    cursor: pointer;
}

/* Hex Input */
.wizard-color-hex-input {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    padding: 8px 12px;
    background: #f9fafb;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
}

.wizard-hex-label {
    font-size: 12px;
    color: #6b7280;
    font-weight: 500;
}

.wizard-hex-hash {
    font-size: 14px;
    color: #9ca3af;
}

.wizard-hex-value {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 14px;
    font-weight: 600;
    color: #1f2937;
    font-family: 'SF Mono', 'Monaco', 'Consolas', monospace;
    text-transform: uppercase;
    width: 70px;
}

.wizard-hex-value:focus {
    outline: none;
}

.wizard-hex-opacity {
    font-size: 12px;
    color: #9ca3af;
}

/* Saved Colors */
.wizard-saved-colors-section {
    margin-top: 8px;
}

.wizard-saved-colors-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.wizard-saved-colors-header span {
    font-size: 12px;
    color: #6b7280;
}

.wizard-add-color-btn {
    font-size: 12px;
    color: #1E3A5F;
    background: none;
    border: none;
    cursor: pointer;
    font-weight: 500;
}

.wizard-add-color-btn:hover {
    text-decoration: underline;
}

.wizard-saved-colors-grid {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.wizard-saved-color {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    cursor: pointer;
    border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
    transition: transform 0.15s ease;
}

.wizard-saved-color:hover {
    transform: scale(1.15);
}

/* Color Palette Grid */
.wizard-color-palette-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 6px;
}

.wizard-palette-color {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 6px;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    border: 1px solid rgba(0,0,0,0.05);
}

.wizard-palette-color:hover {
    transform: scale(1.1);
    box-shadow: 0 2px 8px rgba(0,0,0,0.15);
    z-index: 1;
}

/* Current Color Preview */
.wizard-current-color-preview {
    margin-top: 16px;
    display: flex;
    justify-content: center;
}

.wizard-color-preview-swatch {
    width: 50px;
    height: 50px;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    border: 3px solid #fff;
}

/* Responsive - Stack on smaller screens */
@media (max-width: 768px) {
    .wizard-color-picker-body {
        flex-direction: column;
    }

    .wizard-color-picker-left,
    .wizard-color-picker-right {
        min-width: 100%;
    }
}

/* ========================================
   LOCATION MAP STYLES
   ======================================== */

.location-map-container {
    margin-top: 1rem;
}

.location-map {
    height: 300px;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
}

.map-hint {
    margin-top: 0.5rem;
    display: block;
    font-size: 12px;
    color: #656d76;
}

.map-hint i {
    margin-right: 4px;
    color: #3b82f6;
}

/* Availability Link Hint */
.availability-link-hint {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: #f0f9ff;
    border: 1px solid #bae6fd;
    border-radius: 8px;
    font-size: 13px;
    color: #0369a1;
    margin-top: 16px;
}

.availability-link-hint i {
    color: #0ea5e9;
}

.availability-link-hint .text-link {
    color: #0284c7;
    font-weight: 500;
    text-decoration: underline;
}

.availability-link-hint .text-link:hover {
    color: #0369a1;
}

/* ========================================
   PLAN USAGE WIDGET (Top Nav)
   ======================================== */

.plan-usage-widget {
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
    margin-right: auto;
}

.plan-trigger {
    display: flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 6px 10px;
    border-radius: var(--radius);
    transition: background 0.2s;
}

.plan-trigger:hover {
    background: var(--color-border-light);
}

.plan-badge {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 10px;
    color: #fff;
    font-weight: 600;
    white-space: nowrap;
    letter-spacing: 0.3px;
    background: #1E3A5F;
}

.usage-indicator {
    display: flex;
    flex-direction: column;
    gap: 2px;
    align-items: flex-start;
}

.usage-bar {
    width: 60px;
    height: 4px;
    background: #E2E8F0;
    border-radius: 2px;
    overflow: hidden;
}

.usage-fill {
    height: 100%;
    border-radius: 2px;
    transition: width 0.3s ease;
}

.usage-text {
    font-size: 11px;
    color: var(--color-text-muted, #718096);
    white-space: nowrap;
}

/* Plan Usage Dropdown */
.plan-usage-dropdown {
    width: 320px;
    background: var(--color-surface, #fff);
    border: 1px solid var(--color-border, #e1e5e9);
    border-radius: var(--radius-xl, 12px);
    box-shadow: var(--shadow-medium);
    overflow: hidden;
}

.plan-usage-dropdown .dropdown-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid var(--color-border-light, #f1f3f5);
}

.plan-usage-dropdown .dropdown-header h4 {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-primary);
}

.plan-name-badge {
    font-size: 11px;
    padding: 2px 10px;
    border-radius: 10px;
    color: #fff;
    font-weight: 600;
}

.usage-metrics {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 12px 16px;
}

.usage-metric-row {
    display: flex;
    align-items: center;
    gap: 8px;
}

.metric-label {
    flex: 0 0 120px;
    font-size: 13px;
    color: var(--color-text-secondary, #656d76);
    display: flex;
    align-items: center;
    gap: 6px;
}

.metric-label i {
    width: 14px;
    text-align: center;
    font-size: 12px;
    color: var(--color-text-muted, #8b949e);
}

.metric-bar {
    flex: 1;
    height: 6px;
    background: #E2E8F0;
    border-radius: 3px;
    overflow: hidden;
}

.metric-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.3s ease;
}

.metric-value {
    flex: 0 0 80px;
    text-align: right;
    font-size: 12px;
    font-weight: 600;
    color: var(--color-text-primary);
    white-space: nowrap;
}

.metric-unlimited {
    color: var(--color-text-muted, #8b949e);
    font-style: italic;
    font-weight: 400;
}

.plan-usage-dropdown .dropdown-footer {
    padding: 12px 16px;
    border-top: 1px solid var(--color-border-light, #f1f3f5);
}

.plan-usage-dropdown .dropdown-footer {
    display: flex;
    gap: 8px;
}

.plan-cta-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    flex: 1;
    padding: 8px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.15s ease;
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    color: var(--color-text-primary);
}

.plan-cta-btn:hover {
    background: var(--color-surface-subtle);
    border-color: var(--color-text-muted);
    text-decoration: none;
}

.plan-cta-btn.upgrade {
    background: #1E3A5F;
    color: #ffffff;
    border-color: #1E3A5F;
}

.plan-cta-btn.upgrade:hover {
    background: #152C4A;
    color: #ffffff;
}

.plan-cta-btn i {
    font-size: 11px;
}

@keyframes upgradePulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(30, 58, 95, 0.3); }
    50% { box-shadow: 0 0 0 6px rgba(30, 58, 95, 0); }
}

.plan-cta-btn.pulse {
    animation: upgradePulse 2s infinite;
}

/* Responsive: hide usage text on small screens */
@media (max-width: 768px) {
    .usage-text { display: none; }
    .usage-bar { width: 40px; }
    .plan-usage-dropdown { width: 280px; }
    .metric-label { flex: 0 0 100px; font-size: 12px; }
    .metric-value { flex: 0 0 60px; font-size: 11px; }
}

/* Dark mode for plan usage widget */
[data-theme="dark"] .plan-usage-dropdown {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-theme="dark"] .usage-bar,
[data-theme="dark"] .metric-bar {
    background: var(--color-border);
}

[data-theme="dark"] .plan-trigger:hover {
    background: var(--color-border-light);
}

/* ========================================
   PLAN COMPARISON CARDS (Billing Section)
   ======================================== */

.plan-comparison-section {
    margin-top: 32px;
}

.plan-comparison-section > h3 {
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text-primary, #1a1a1a);
    margin: 0 0 20px 0;
}

.plan-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 20px;
}

.plan-card {
    background: var(--color-surface, #fff);
    border: 2px solid var(--color-border, #e1e5e9);
    border-radius: 12px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    transition: border-color 0.2s, box-shadow 0.2s;
    position: relative;
}

.plan-card:hover {
    box-shadow: var(--shadow-medium);
}

.plan-card.current-plan {
    border-color: #1E3A5F;
}

.plan-card.popular {
    border-color: #3182CE;
}

.plan-card-badge {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 11px;
    font-weight: 600;
    padding: 2px 12px;
    border-radius: 10px;
    color: #fff;
    white-space: nowrap;
}

.plan-card-badge.current { background: #1E3A5F; color: #fff; }
.plan-card-badge.popular { background: #3182CE; }

.plan-card-name {
    font-size: 18px;
    font-weight: 700;
    color: var(--color-text-primary, #1a1a1a);
    margin: 8px 0 4px 0;
}

.plan-card-price {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-text-primary, #1a1a1a);
    margin: 8px 0;
}

.plan-card-price .currency {
    font-size: 16px;
    vertical-align: top;
    position: relative;
    top: 4px;
}

.plan-card-price .period {
    font-size: 14px;
    font-weight: 400;
    color: var(--color-text-secondary, #656d76);
}

.plan-card-features {
    list-style: none;
    padding: 0;
    margin: 16px 0;
    flex: 1;
}

.plan-card-features li {
    padding: 6px 0;
    font-size: 13px;
    color: var(--color-text-secondary, #656d76);
    display: flex;
    align-items: center;
    gap: 8px;
}

.plan-card-features li i {
    color: #38A169;
    font-size: 12px;
    flex-shrink: 0;
}

.plan-card-btn {
    display: block;
    width: 100%;
    padding: 10px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all 0.2s;
}

.plan-card-btn.upgrade {
    background: #1E3A5F;
    color: #fff;
    border-color: #1E3A5F;
}

.plan-card-btn.upgrade:hover {
    background: #152C4A;
    border-color: #152C4A;
}

.plan-card-btn.downgrade {
    background: transparent;
    color: var(--color-text-secondary, #656d76);
    border-color: var(--color-border, #e1e5e9);
}

.plan-card-btn.downgrade:hover {
    border-color: var(--color-text-secondary, #656d76);
    color: var(--color-text-primary, #1a1a1a);
}

.plan-card-btn.current {
    background: transparent;
    color: var(--color-text-muted, #8b949e);
    border-color: var(--color-border, #e1e5e9);
    cursor: default;
    opacity: 0.7;
}

/* Plan change confirmation modal */
.plan-change-modal {
    background: var(--color-surface, #fff);
    border-radius: 12px;
    max-width: 500px;
    width: 90%;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    animation: modalSlideIn 0.3s ease;
    overflow: hidden;
}

.plan-change-modal .modal-header {
    padding: 24px;
    border-bottom: 1px solid var(--color-border-light, #f1f3f5);
}

.plan-change-modal .modal-header.upgrade-header {
    background: linear-gradient(135deg, #1E3A5F, #152C4A);
    color: #fff;
}

.plan-change-modal .modal-header.downgrade-header {
    background: linear-gradient(135deg, #718096, #4A5568);
    color: #fff;
}

.plan-change-modal .modal-body {
    padding: 24px;
}

.plan-change-summary {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 20px;
}

.plan-change-arrow {
    font-size: 20px;
    color: var(--color-text-muted, #8b949e);
}

.plan-change-item {
    text-align: center;
}

.plan-change-item .plan-name {
    font-weight: 600;
    font-size: 16px;
    color: var(--color-text-primary);
}

.plan-change-item .plan-price {
    font-size: 13px;
    color: var(--color-text-secondary);
}

.plan-change-modal .modal-footer {
    padding: 16px 24px;
    border-top: 1px solid var(--color-border-light, #f1f3f5);
    display: flex;
    justify-content: flex-end;
    gap: 12px;
}

/* Dark mode for plan cards */
[data-theme="dark"] .plan-card {
    background: var(--color-surface);
    border-color: var(--color-border);
}

[data-theme="dark"] .plan-card-name,
[data-theme="dark"] .plan-card-price {
    color: var(--color-text-primary);
}

[data-theme="dark"] .plan-change-modal {
    background: var(--color-surface);
}

@media (max-width: 768px) {
    .plan-cards-grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   DARK MODE: Sub-Section Module Overrides
   Covers inline CSS from all JS modules
   ======================================== */

/* --- Panels, Cards, Containers --- */
[data-theme="dark"] .anthropic-org-panel,
[data-theme="dark"] .anthropic-detail-section,
[data-theme="dark"] .organizations-panel,
[data-theme="dark"] .organization-card,
[data-theme="dark"] .workspace-card,
[data-theme="dark"] .member-card,
[data-theme="dark"] .ticket-card,
[data-theme="dark"] .invoice-card,
[data-theme="dark"] .payment-card,
[data-theme="dark"] .lead-card,
[data-theme="dark"] .opportunity-card,
[data-theme="dark"] .pipeline-card,
[data-theme="dark"] .integration-card,
[data-theme="dark"] .webhook-card,
[data-theme="dark"] .apikey-card,
[data-theme="dark"] .customer-card,
[data-theme="dark"] .payout-card,
[data-theme="dark"] .subscription-card,
[data-theme="dark"] .gamification-card,
[data-theme="dark"] .section-header,
[data-theme="dark"] .detail-panel,
[data-theme="dark"] .info-card,
[data-theme="dark"] .settings-card,
[data-theme="dark"] .profile-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary);
}

/* --- Profile Headers & Card Headers with subtle bg --- */
[data-theme="dark"] .anthropic-profile-header,
[data-theme="dark"] .org-card-header,
[data-theme="dark"] .card-header-subtle,
[data-theme="dark"] .panel-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Stat Cards --- */
[data-theme="dark"] .stat-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .stat-value,
[data-theme="dark"] .stat-number {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .stat-label {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .stat-icon {
    color: var(--color-text-secondary) !important;
}

/* --- Org Stats Boxes (MEMBERS, STORAGE etc.) --- */
[data-theme="dark"] .org-stats,
[data-theme="dark"] .org-stat,
[data-theme="dark"] .org-stat-item,
[data-theme="dark"] .org-card-stats,
[data-theme="dark"] .detail-stat {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

/* --- Grid & List Backgrounds --- */
[data-theme="dark"] .organizations-grid,
[data-theme="dark"] .members-grid,
[data-theme="dark"] .workspaces-grid,
[data-theme="dark"] .cards-grid,
[data-theme="dark"] .content-grid,
[data-theme="dark"] .list-container,
[data-theme="dark"] .table-container {
    background: transparent !important;
}

/* --- Content Section & Page Headers --- */
[data-theme="dark"] .content-section,
[data-theme="dark"] .page-header,
[data-theme="dark"] .section-title-bar {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Form Controls (Search, Select, Input) --- */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select,
[data-theme="dark"] .search-box,
[data-theme="dark"] .search-input,
[data-theme="dark"] .filter-input,
[data-theme="dark"] input[type="text"],
[data-theme="dark"] input[type="email"],
[data-theme="dark"] input[type="password"],
[data-theme="dark"] input[type="search"],
[data-theme="dark"] input[type="number"],
[data-theme="dark"] input[type="url"],
[data-theme="dark"] input[type="tel"],
[data-theme="dark"] textarea,
[data-theme="dark"] select {
    background-color: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .form-control::placeholder,
[data-theme="dark"] .search-box::placeholder,
[data-theme="dark"] .search-input::placeholder,
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
    color: var(--color-text-muted) !important;
}

/* --- Filter Groups & Toolbars --- */
[data-theme="dark"] .filter-group,
[data-theme="dark"] .filter-bar,
[data-theme="dark"] .toolbar,
[data-theme="dark"] .actions-bar {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .filter-group label,
[data-theme="dark"] .filter-label {
    color: var(--color-text-secondary) !important;
}

/* --- Buttons (outline, secondary, pill) --- */
[data-theme="dark"] .btn-outline,
[data-theme="dark"] .btn-secondary,
[data-theme="dark"] .anthropic-btn-secondary,
[data-theme="dark"] .btn-pill-dark {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .btn-outline:hover,
[data-theme="dark"] .btn-secondary:hover,
[data-theme="dark"] .anthropic-btn-secondary:hover {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-text-muted) !important;
}

/* --- Icon Buttons --- */
[data-theme="dark"] .btn-icon,
[data-theme="dark"] .action-btn,
[data-theme="dark"] .appoiint-icon-btn {
    background: var(--color-surface) !important;
    color: var(--color-text-secondary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .btn-icon:hover,
[data-theme="dark"] .action-btn:hover,
[data-theme="dark"] .appoiint-icon-btn:hover {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

/* --- Text Colors --- */
[data-theme="dark"] .org-name,
[data-theme="dark"] .workspace-name,
[data-theme="dark"] .member-name,
[data-theme="dark"] .card-title,
[data-theme="dark"] .section-title,
[data-theme="dark"] .panel-title,
[data-theme="dark"] .detail-label,
[data-theme="dark"] .anthropic-detail-item strong,
[data-theme="dark"] .breadcrumb-current,
[data-theme="dark"] h1, [data-theme="dark"] h2, [data-theme="dark"] h3, [data-theme="dark"] h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .org-description,
[data-theme="dark"] .workspace-description,
[data-theme="dark"] .member-role,
[data-theme="dark"] .card-subtitle,
[data-theme="dark"] .detail-value,
[data-theme="dark"] .anthropic-detail-item span,
[data-theme="dark"] .breadcrumb-container,
[data-theme="dark"] .breadcrumb-back-btn,
[data-theme="dark"] .info-text,
[data-theme="dark"] .description-text {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .breadcrumb-separator {
    color: var(--color-border) !important;
}

/* --- Dropdowns --- */
[data-theme="dark"] .anthropic-dropdown-menu,
[data-theme="dark"] .dropdown-menu,
[data-theme="dark"] .context-menu {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
}

[data-theme="dark"] .anthropic-dropdown-item,
[data-theme="dark"] .dropdown-item {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .anthropic-dropdown-item:hover,
[data-theme="dark"] .dropdown-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .anthropic-dropdown-divider,
[data-theme="dark"] .dropdown-divider,
[data-theme="dark"] .menu-divider {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .anthropic-dropdown-item-danger {
    color: var(--color-danger) !important;
}

/* --- Tables --- */
[data-theme="dark"] table,
[data-theme="dark"] .data-table {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] thead tr,
[data-theme="dark"] .table-header-row,
[data-theme="dark"] .opportunity-row[style*="font-weight: 600"] {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] th {
    color: var(--color-text-secondary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] td {
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] tbody tr:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Pagination --- */
[data-theme="dark"] .pagination-btn,
[data-theme="dark"] .page-btn {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .pagination-btn:hover,
[data-theme="dark"] .page-btn:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Empty States --- */
[data-theme="dark"] .empty-state,
[data-theme="dark"] .anthropic-empty-state,
[data-theme="dark"] .no-data {
    color: var(--color-text-muted) !important;
}

/* --- Status Badges (dark-aware) --- */
[data-theme="dark"] .status-badge.active,
[data-theme="dark"] .org-status.active {
    background: rgba(63, 185, 80, 0.15) !important;
    color: #3fb950 !important;
}

[data-theme="dark"] .status-badge.inactive,
[data-theme="dark"] .org-status.inactive {
    background: rgba(248, 81, 73, 0.15) !important;
    color: #f85149 !important;
}

[data-theme="dark"] .status-badge.pending,
[data-theme="dark"] .org-status.pending {
    background: rgba(210, 153, 34, 0.15) !important;
    color: #d29922 !important;
}

[data-theme="dark"] .status-badge.trial,
[data-theme="dark"] .org-status.trial {
    background: rgba(210, 153, 34, 0.15) !important;
    color: #d29922 !important;
}

/* --- Inline style overrides for common module patterns --- */
[data-theme="dark"] [style*="background: #ffffff"],
[data-theme="dark"] [style*="background:#ffffff"],
[data-theme="dark"] [style*="background: #fff;"],
[data-theme="dark"] [style*="background:#fff;"],
[data-theme="dark"] [style*="background: white"],
[data-theme="dark"] [style*="background:white"],
[data-theme="dark"] [style*="background-color: #ffffff"],
[data-theme="dark"] [style*="background-color:#ffffff"],
[data-theme="dark"] [style*="background-color: white"],
[data-theme="dark"] [style*="background-color:white"] {
    background: var(--color-surface) !important;
}

[data-theme="dark"] [style*="background: #fafafa"],
[data-theme="dark"] [style*="background:#fafafa"],
[data-theme="dark"] [style*="background: #f9fafb"],
[data-theme="dark"] [style*="background:#f9fafb"],
[data-theme="dark"] [style*="background: #f8f9fa"],
[data-theme="dark"] [style*="background:#f8f9fa"],
[data-theme="dark"] [style*="background: #f3f4f6"],
[data-theme="dark"] [style*="background:#f3f4f6"],
[data-theme="dark"] [style*="background-color: #f8f9fa"],
[data-theme="dark"] [style*="background-color:#f8f9fa"],
[data-theme="dark"] [style*="background-color: #fafafa"],
[data-theme="dark"] [style*="background-color:#fafafa"] {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] [style*="color: #111827"],
[data-theme="dark"] [style*="color:#111827"],
[data-theme="dark"] [style*="color: #1a1a1a"],
[data-theme="dark"] [style*="color:#1a1a1a"],
[data-theme="dark"] [style*="color: #24292f"],
[data-theme="dark"] [style*="color:#24292f"],
[data-theme="dark"] [style*="color: #374151"],
[data-theme="dark"] [style*="color:#374151"] {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] [style*="color: #6b7280"],
[data-theme="dark"] [style*="color:#6b7280"],
[data-theme="dark"] [style*="color: #6c757d"],
[data-theme="dark"] [style*="color:#6c757d"],
[data-theme="dark"] [style*="color: #495057"],
[data-theme="dark"] [style*="color:#495057"] {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] [style*="border: 1px solid #e5e7eb"],
[data-theme="dark"] [style*="border:1px solid #e5e7eb"],
[data-theme="dark"] [style*="border: 1px solid #e8e8e8"],
[data-theme="dark"] [style*="border:1px solid #e8e8e8"],
[data-theme="dark"] [style*="border: 1px solid #e9ecef"],
[data-theme="dark"] [style*="border:1px solid #e9ecef"],
[data-theme="dark"] [style*="border: 1px solid #dee2e6"],
[data-theme="dark"] [style*="border:1px solid #dee2e6"],
[data-theme="dark"] [style*="border: 1px solid #d0d7de"],
[data-theme="dark"] [style*="border:1px solid #d0d7de"] {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] [style*="border-bottom: 1px solid #f3f4f6"],
[data-theme="dark"] [style*="border-bottom:1px solid #f3f4f6"],
[data-theme="dark"] [style*="border-bottom: 1px solid #e5e7eb"],
[data-theme="dark"] [style*="border-bottom:1px solid #e5e7eb"],
[data-theme="dark"] [style*="border-bottom: 1px solid #e8e8e8"],
[data-theme="dark"] [style*="border-bottom:1px solid #e8e8e8"],
[data-theme="dark"] [style*="border-top: 1px solid #e5e7eb"],
[data-theme="dark"] [style*="border-top:1px solid #e5e7eb"],
[data-theme="dark"] [style*="border-top: 1px solid #f3f4f6"],
[data-theme="dark"] [style*="border-top:1px solid #f3f4f6"] {
    border-color: var(--color-border) !important;
}

/* --- Gradients used in inline styles --- */
[data-theme="dark"] [style*="linear-gradient(135deg, #fafbfc"],
[data-theme="dark"] [style*="linear-gradient(135deg, #ffffff"],
[data-theme="dark"] [style*="linear-gradient(180deg, #ffffff"],
[data-theme="dark"] [style*="linear-gradient(180deg, #fafafa"],
[data-theme="dark"] [style*="linear-gradient(135deg, #f9fafb"] {
    background: var(--color-surface) !important;
}

/* --- Dashed borders (setup prompts, empty areas) --- */
[data-theme="dark"] [style*="border: 2px dashed"] {
    border-color: var(--color-border) !important;
    background: var(--color-surface-subtle) !important;
}

/* --- Info boxes with left border --- */
[data-theme="dark"] [style*="border-left: 4px solid"] {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

/* --- Breadcrumb hover in dark mode --- */
[data-theme="dark"] .breadcrumb-back-btn:hover {
    background-color: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

/* --- Org card actions area --- */
[data-theme="dark"] .org-actions,
[data-theme="dark"] .card-actions,
[data-theme="dark"] .card-footer {
    border-color: var(--color-border) !important;
    background: var(--color-surface) !important;
}

/* --- Password/Edit forms --- */
[data-theme="dark"] .password-change-form,
[data-theme="dark"] .edit-form,
[data-theme="dark"] .settings-form {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Profile details --- */
[data-theme="dark"] .anthropic-profile-details {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .anthropic-detail-grid {
    border-color: var(--color-border) !important;
}

/* --- Sub sidebar --- */
[data-theme="dark"] .sub-sidebar {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Organization Card (inline CSS overrides) --- */
[data-theme="dark"] .organization-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3), 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .organization-card:hover {
    border-color: var(--color-text-muted) !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3), 0 4px 10px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .organization-card.selected {
    border-color: var(--color-text-muted) !important;
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .org-content,
[data-theme="dark"] .workspace-content {
    background: var(--color-surface) !important;
    box-shadow: none !important;
}

[data-theme="dark"] .org-name,
[data-theme="dark"] .tyga-org-name,
[data-theme="dark"] .workspace-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .org-description,
[data-theme="dark"] .tyga-org-description,
[data-theme="dark"] .workspace-description {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .org-stats,
[data-theme="dark"] .workspace-stats {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .org-stats .stat-value,
[data-theme="dark"] .workspace-stats .stat-value {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .org-stats .stat-label,
[data-theme="dark"] .workspace-stats .stat-label {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .org-actions,
[data-theme="dark"] .workspace-actions {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .btn-icon {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .btn-icon:hover {
    background: var(--color-text-primary) !important;
    color: var(--color-bg) !important;
    border-color: var(--color-text-primary) !important;
}

[data-theme="dark"] .org-logo,
[data-theme="dark"] .workspace-logo {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .org-logo i,
[data-theme="dark"] .workspace-logo i {
    color: var(--color-text-secondary) !important;
}

/* --- Status badges (org & workspace) --- */
[data-theme="dark"] .workspace-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3), 0 1px 2px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .workspace-card:hover {
    border-color: var(--color-text-muted) !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3), 0 4px 10px rgba(0, 0, 0, 0.2) !important;
}

[data-theme="dark"] .workspace-card.selected {
    border-color: var(--color-text-muted) !important;
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .workspace-status.trial,
[data-theme="dark"] .org-status.trial {
    background: rgba(251, 191, 36, 0.15) !important;
    color: #fbbf24 !important;
    border-color: rgba(251, 191, 36, 0.3) !important;
}

[data-theme="dark"] .workspace-status.active,
[data-theme="dark"] .org-status.active {
    background: rgba(52, 211, 153, 0.15) !important;
    color: #34d399 !important;
    border-color: rgba(52, 211, 153, 0.3) !important;
}

[data-theme="dark"] .workspace-status.inactive,
[data-theme="dark"] .org-status.inactive {
    background: rgba(248, 81, 73, 0.15) !important;
    color: #f85149 !important;
    border-color: rgba(248, 81, 73, 0.3) !important;
}

/* --- Workspace, Member, and generic sub-section cards --- */
[data-theme="dark"] .workspace-card,
[data-theme="dark"] .member-card,
[data-theme="dark"] .team-member-card,
[data-theme="dark"] .customer-card,
[data-theme="dark"] .booking-card,
[data-theme="dark"] .meeting-card,
[data-theme="dark"] .event-type-card,
[data-theme="dark"] .template-card,
[data-theme="dark"] .integration-card,
[data-theme="dark"] .ticket-card,
[data-theme="dark"] .lead-card,
[data-theme="dark"] .opportunity-card,
[data-theme="dark"] .pipeline-card,
[data-theme="dark"] .invoice-card,
[data-theme="dark"] .payment-card,
[data-theme="dark"] .payout-card,
[data-theme="dark"] .subscription-card,
[data-theme="dark"] .apikey-card,
[data-theme="dark"] .webhook-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
}

[data-theme="dark"] .workspace-card:hover,
[data-theme="dark"] .member-card:hover,
[data-theme="dark"] .team-member-card:hover,
[data-theme="dark"] .customer-card:hover,
[data-theme="dark"] .booking-card:hover,
[data-theme="dark"] .meeting-card:hover,
[data-theme="dark"] .event-type-card:hover,
[data-theme="dark"] .template-card:hover,
[data-theme="dark"] .integration-card:hover,
[data-theme="dark"] .ticket-card:hover {
    border-color: var(--color-text-muted) !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.3) !important;
}

/* --- Card inner sections that use rgba white --- */
[data-theme="dark"] [style*="background: rgba(255, 255, 255"],
[data-theme="dark"] [style*="background:rgba(255, 255, 255"],
[data-theme="dark"] [style*="background: rgba(255,255,255"],
[data-theme="dark"] [style*="background:rgba(255,255,255"] {
    background: var(--color-surface) !important;
}

/* --- Avatar placeholders --- */
[data-theme="dark"] .avatar-placeholder {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Dashboard widget cards --- */
[data-theme="dark"] .overview-booking-item {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .overview-booking-item:hover {
    background-color: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .ua-widget {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .ua-select {
    background-color: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%238b949e'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E") !important;
}

[data-theme="dark"] .ua-btn-reschedule,
[data-theme="dark"] .ua-btn-details {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .ua-btn-reschedule:hover,
[data-theme="dark"] .ua-btn-details:hover {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .ua-empty-icon {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .ua-empty-title {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .ua-empty-text {
    color: var(--color-text-secondary) !important;
}

/* --- Widget header & count badge --- */
[data-theme="dark"] .widget-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .widget-title {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .widget-count-badge {
    background: var(--color-border-light) !important;
    color: var(--color-text-secondary) !important;
}

/* --- Stat icon backgrounds (dark-aware) --- */
[data-theme="dark"] .stat-icon.primary {
    background-color: rgba(88, 166, 255, 0.12) !important;
}

[data-theme="dark"] .stat-icon.success {
    background-color: rgba(63, 185, 80, 0.12) !important;
}

[data-theme="dark"] .stat-icon.warning {
    background-color: rgba(210, 153, 34, 0.12) !important;
}

[data-theme="dark"] .stat-icon.danger {
    background-color: rgba(248, 81, 73, 0.12) !important;
}

/* --- Module panels (teammembers, bookings, etc.) --- */
[data-theme="dark"] .teammembers-panel,
[data-theme="dark"] .bookings-panel,
[data-theme="dark"] .meetings-panel,
[data-theme="dark"] .customers-panel,
[data-theme="dark"] .tickets-panel,
[data-theme="dark"] .leads-panel,
[data-theme="dark"] .pipelines-panel,
[data-theme="dark"] .invoices-panel,
[data-theme="dark"] .payments-panel,
[data-theme="dark"] .subscriptions-panel,
[data-theme="dark"] .apikeys-panel,
[data-theme="dark"] .webhooks-panel,
[data-theme="dark"] .integrations-panel,
[data-theme="dark"] .gamification-panel,
[data-theme="dark"] .payouts-panel,
[data-theme="dark"] .billing-panel,
[data-theme="dark"] .support-panel,
[data-theme="dark"] .workspaces-panel,
[data-theme="dark"] .left-panel,
[data-theme="dark"] .right-panel {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
}

/* --- Panel header & content --- */
[data-theme="dark"] .panel-header {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .panel-header h3,
[data-theme="dark"] .panel-header h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .panel-content {
    background: var(--color-surface) !important;
}

/* --- Members grid container --- */
[data-theme="dark"] .members-grid,
[data-theme="dark"] .workspaces-grid,
[data-theme="dark"] .bookings-grid,
[data-theme="dark"] .items-grid {
    background: var(--color-bg) !important;
}

/* --- Member card specifics --- */
[data-theme="dark"] .member-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .member-card:hover {
    border-color: #58a6ff !important;
    box-shadow: 0 4px 12px rgba(88, 166, 255, 0.15) !important;
}

[data-theme="dark"] .member-card.selected {
    border-color: #58a6ff !important;
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .member-card-details h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .member-card-details p {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .member-card-avatar {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .member-card-meta {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .member-card-actions .btn-icon {
    color: var(--color-text-secondary) !important;
}

/* --- Search box --- */
[data-theme="dark"] .search-box input {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .search-box input:focus {
    border-color: #58a6ff !important;
    box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.15) !important;
}

[data-theme="dark"] .search-box i {
    color: var(--color-text-muted) !important;
}

/* --- Form select --- */
[data-theme="dark"] .form-select {
    background-color: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .form-select:hover {
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .form-select:focus {
    border-color: #58a6ff !important;
    box-shadow: 0 0 0 3px rgba(88, 166, 255, 0.15) !important;
}

[data-theme="dark"] .form-select option {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
}

/* --- Role badges (dark-aware) --- */
[data-theme="dark"] .role-badge.owner {
    background: rgba(251, 191, 36, 0.15) !important;
    color: #fbbf24 !important;
}

[data-theme="dark"] .role-badge.admin {
    background: rgba(248, 81, 73, 0.15) !important;
    color: #f85149 !important;
}

[data-theme="dark"] .role-badge.manager {
    background: rgba(88, 166, 255, 0.15) !important;
    color: #58a6ff !important;
}

[data-theme="dark"] .role-badge.member {
    background: rgba(63, 185, 80, 0.15) !important;
    color: #3fb950 !important;
}

[data-theme="dark"] .role-badge.guest {
    background: rgba(137, 87, 229, 0.15) !important;
    color: #a371f7 !important;
}

[data-theme="dark"] .role-badge.viewer {
    background: var(--color-border-light) !important;
    color: var(--color-text-secondary) !important;
}

/* --- Status badges (dark-aware) --- */
[data-theme="dark"] .status-badge.active {
    background: rgba(63, 185, 80, 0.15) !important;
    color: #3fb950 !important;
}

[data-theme="dark"] .status-badge.inactive,
[data-theme="dark"] .status-badge.suspended,
[data-theme="dark"] .status-badge.archived {
    background: rgba(248, 81, 73, 0.15) !important;
    color: #f85149 !important;
}

[data-theme="dark"] .status-badge.pending {
    background: rgba(210, 153, 34, 0.15) !important;
    color: #d29922 !important;
}

/* --- Empty state --- */
[data-theme="dark"] .anthropic-empty-state {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .empty-state-title {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .empty-state-content p {
    color: var(--color-text-secondary) !important;
}

/* --- Edit forms --- */
[data-theme="dark"] .edit-form-container,
[data-theme="dark"] .edit-form,
[data-theme="dark"] .form-section {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .form-header {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .form-header p {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .form-section h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .form-group label {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .form-grid input,
[data-theme="dark"] .form-grid select,
[data-theme="dark"] .form-grid textarea {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

/* --- Scheduling / Event Types Section --- */
[data-theme="dark"] .appoiint-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .appoiint-row:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .appoiint-row.selected {
    background: rgba(30, 58, 95, 0.2) !important;
    border-color: rgba(30, 58, 95, 0.5) !important;
}

[data-theme="dark"] .appoiint-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .appoiint-description {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .duration-badge {
    background: rgba(30, 58, 95, 0.25) !important;
    color: #7eb0e6 !important;
}

[data-theme="dark"] .tab-btn {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .tab-btn:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .tab-btn.active {
    background: #1E3A5F !important;
    color: #fff !important;
    border-color: #1E3A5F !important;
}

[data-theme="dark"] .template-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .template-title {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .template-description {
    color: var(--color-text-secondary) !important;
}

/* --- Quick Create Sidebar --- */
[data-theme="dark"] .quick-create-sidebar {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .quick-template-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .quick-template-card:hover {
    background: var(--color-surface-subtle) !important;
    border-color: #1E3A5F !important;
}

[data-theme="dark"] .quick-template-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .quick-template-desc {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .sidebar-content {
    background: var(--color-surface) !important;
}

/* --- Pagination buttons --- */
[data-theme="dark"] .pagination-btn,
[data-theme="dark"] .page-btn,
[data-theme="dark"] .table-pagination button {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .pagination-btn:hover,
[data-theme="dark"] .page-btn:hover,
[data-theme="dark"] .table-pagination button:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Filter/Sort Dropdowns --- */
[data-theme="dark"] .filter-dropdown,
[data-theme="dark"] .sort-dropdown,
[data-theme="dark"] .menu-dropdown {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4) !important;
}

[data-theme="dark"] .filter-dropdown-header,
[data-theme="dark"] .sort-dropdown-header {
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .filter-select {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .sort-option:hover,
[data-theme="dark"] .menu-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .sort-option.active {
    background: rgba(30, 58, 95, 0.2) !important;
    color: #7eb0e6 !important;
}

[data-theme="dark"] .sort-order-toggle {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .sort-order-btn {
    background: var(--color-border-light) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .sort-order-btn:hover {
    background: var(--color-border) !important;
}

[data-theme="dark"] .menu-item {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .menu-item i {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .menu-item.danger {
    color: var(--color-danger) !important;
}

[data-theme="dark"] .menu-item.danger i {
    color: var(--color-danger) !important;
}

[data-theme="dark"] .menu-item.danger:hover {
    background: rgba(248, 81, 73, 0.1) !important;
}

/* --- Pagination --- */
[data-theme="dark"] .table-pagination {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

/* --- Sort/filter button hover in dark --- */
[data-theme="dark"] .sort-btn:hover {
    color: var(--color-text-primary) !important;
}

/* --- Scheduling header stat cards (inline CSS) --- */
[data-theme="dark"] .scheduling-stats .stat-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Search input --- */
[data-theme="dark"] .scheduling-search .search-input,
[data-theme="dark"] .search-input {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .search-icon {
    color: var(--color-text-muted) !important;
}

/* --- Status badge inactive --- */
[data-theme="dark"] .status-badge.inactive {
    background: var(--color-border-light) !important;
    color: var(--color-text-secondary) !important;
}

/* ========================================
   DARK MODE: Bookings Section
   ======================================== */

/* --- Filters bar --- */
[data-theme="dark"] .bookings-filters,
[data-theme="dark"] .filters-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .filter-group label {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .filter-actions .btn {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

/* --- View toggle (Calendar/List) --- */
[data-theme="dark"] .view-toggle,
[data-theme="dark"] .calendar-view-toggle {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .view-toggle .btn,
[data-theme="dark"] .calendar-view-toggle .btn {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .view-toggle .btn.active,
[data-theme="dark"] .calendar-view-toggle .btn.active {
    background: #1E3A5F !important;
    color: #fff !important;
    border-color: #1E3A5F !important;
}

/* --- Bookings stat cards --- */
[data-theme="dark"] .bookings-stats .stat-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Calendar container --- */
[data-theme="dark"] .calendar-container,
[data-theme="dark"] .calendar-view-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Calendar header & nav --- */
[data-theme="dark"] .calendar-header {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-nav .btn,
[data-theme="dark"] .calendar-nav button {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-nav .btn:hover,
[data-theme="dark"] .calendar-nav button:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .calendar-month {
    color: var(--color-text-primary) !important;
}

/* --- Calendar weekday header --- */
[data-theme="dark"] .calendar-weekdays,
[data-theme="dark"] .calendar-weekday {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-secondary) !important;
    border-color: var(--color-border) !important;
}

/* --- Calendar day cells --- */
[data-theme="dark"] .calendar-day {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-day:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .calendar-day.other-month {
    background: var(--color-bg) !important;
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .calendar-day.today {
    background: rgba(30, 58, 95, 0.15) !important;
}

[data-theme="dark"] .calendar-day-number {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .calendar-day.other-month .calendar-day-number {
    color: var(--color-text-muted) !important;
}

/* --- Calendar days grid --- */
[data-theme="dark"] .calendar-days {
    border-color: var(--color-border) !important;
}

/* --- Week view --- */
[data-theme="dark"] .week-table,
[data-theme="dark"] .week-time-cell,
[data-theme="dark"] .week-slot-cell,
[data-theme="dark"] .week-day-header,
[data-theme="dark"] .week-time-header {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .week-day-name {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .week-day-number {
    color: var(--color-text-primary) !important;
}

/* --- Day view --- */
[data-theme="dark"] .calendar-day-view {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .calendar-day-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-day-header h3 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .calendar-day-body {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .calendar-day-content .calendar-hour-slot {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .calendar-day-content .calendar-booking {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-day-content .calendar-booking:hover {
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .calendar-day-content .booking-time {
    color: #58a6ff !important;
}

[data-theme="dark"] .calendar-day-content .booking-customer {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .calendar-day-content .booking-duration {
    color: var(--color-text-secondary) !important;
}

/* --- Time column & slots (shared day/week) --- */
[data-theme="dark"] .calendar-time-column,
[data-theme="dark"] .calendar-time-slot {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border-light) !important;
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .calendar-hour-slot {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .calendar-empty-slot {
    color: var(--color-text-muted) !important;
}

/* --- Week view --- */
[data-theme="dark"] .week-table th,
[data-theme="dark"] .week-table td {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .week-time-header,
[data-theme="dark"] .week-day-header {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .week-day-header.today {
    background: rgba(30, 58, 95, 0.2) !important;
}

[data-theme="dark"] .week-day-name {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .week-day-number {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .week-time-cell {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .week-slot-cell {
    border-color: var(--color-border-light) !important;
}

/* --- Week/Hour booking cards --- */
[data-theme="dark"] .week-booking,
[data-theme="dark"] .calendar-hour-slot .calendar-booking {
    background: var(--color-surface-subtle) !important;
    border-color: #1E3A5F !important;
}

[data-theme="dark"] .week-booking:hover,
[data-theme="dark"] .calendar-hour-slot .calendar-booking:hover {
    background: var(--color-border-light) !important;
}

[data-theme="dark"] .wb-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .wb-time {
    color: #58a6ff !important;
}

[data-theme="dark"] .calendar-hour-slot .booking-time {
    color: #58a6ff !important;
}

[data-theme="dark"] .calendar-hour-slot .booking-customer {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .calendar-hour-slot .booking-duration {
    color: var(--color-text-secondary) !important;
}

/* --- Week day columns --- */
[data-theme="dark"] .calendar-week-day-column {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .calendar-week-day {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .calendar-week-day.today {
    background: rgba(30, 58, 95, 0.15) !important;
    color: #58a6ff !important;
}

/* --- Month view booking cards --- */
[data-theme="dark"] .calendar-booking {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-booking:hover {
    background: var(--color-border-light) !important;
}

[data-theme="dark"] .calendar-booking.confirmed {
    border-left-color: var(--color-success) !important;
}

[data-theme="dark"] .calendar-booking.pending {
    border-left-color: var(--color-warning) !important;
}

[data-theme="dark"] .calendar-booking.cancelled {
    border-left-color: var(--color-danger) !important;
}

[data-theme="dark"] .calendar-booking.completed {
    border-left-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .calendar-booking-more {
    color: var(--color-text-secondary) !important;
}

/* --- Calendar container wrapper --- */
[data-theme="dark"] .calendar-view-container {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .calendar-week-body {
    background: var(--color-surface) !important;
}

/* --- Integration Wizard Modal --- */
[data-theme="dark"] .integration-wizard-modal {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .wizard-steps-indicator {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .wizard-step-item span {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .wizard-content {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .wizard-step-content h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .wizard-step-content > p {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .provider-option {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .provider-option:hover {
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .provider-option.selected {
    border-color: #1E3A5F !important;
    background: rgba(30, 58, 95, 0.2) !important;
}

[data-theme="dark"] .provider-details h5 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .provider-details p {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .provider-tags .tag {
    background: var(--color-border-light) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .provider-check {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .provider-icon.google {
    background: var(--color-border-light) !important;
}

[data-theme="dark"] .wizard-actions {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .btn-wizard-cancel {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .btn-wizard-prev {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .wizard-form label {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .wizard-form input,
[data-theme="dark"] .wizard-form textarea,
[data-theme="dark"] .wizard-form select {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .wizard-form small {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .caldav-fields {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .caldav-fields h5 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .connect-prompt h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .connect-prompt p {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .connect-error p {
    color: var(--color-text-secondary) !important;
}

/* ========================================
   DARK MODE: Meetings / Appoiints Section
   ======================================== */

[data-theme="dark"] .meetings-filters {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .meetings-table-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .meetings-table {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .meeting-row {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .meeting-row:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .meetings-stats .stat-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .stat-icon.scheduled {
    background-color: rgba(9, 105, 218, 0.12) !important;
}

[data-theme="dark"] .stat-icon.active {
    background-color: rgba(26, 127, 55, 0.12) !important;
}

[data-theme="dark"] .stat-icon.ended {
    background-color: var(--color-border-light) !important;
}

[data-theme="dark"] .stat-icon.participants {
    background-color: var(--color-border-light) !important;
}

/* Date range select */
[data-theme="dark"] .date-range-select {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

/* Filter action buttons (Export, Filter, Clear) */
[data-theme="dark"] .filter-actions .btn {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .filter-actions .btn:hover {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-text-muted) !important;
    color: var(--color-text-primary) !important;
}

/* --- Appoiints-specific classes --- */
[data-theme="dark"] .appoiints-tab {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .appoiints-tab:hover:not(.active) {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .appoiints-tab.active {
    background: #1E3A5F !important;
    color: #fff !important;
    border-color: #1E3A5F !important;
}

[data-theme="dark"] .appoiints-select {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .appoiints-action-btn {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .appoiints-action-btn:hover {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .appoiints-action-btn i {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .appoiint-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .appoiint-card:hover {
    border-color: var(--color-text-muted) !important;
    border-left-color: #1E3A5F !important;
}

[data-theme="dark"] .appoiints-pagination {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .pagination-info {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .pagination-info strong {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .appoiints-list .empty-state,
[data-theme="dark"] .appoiints-list .loading-state {
    color: var(--color-text-muted) !important;
}

/* --- Meetings/Booking Wizard --- */
[data-theme="dark"] .meetings-wizard-content {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .appoiints-breadcrumb-back {
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .appoiints-breadcrumb-back:hover {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-text-muted) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .appoiints-breadcrumb-separator {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .appoiints-breadcrumb-current {
    color: var(--color-text-primary) !important;
}

/* Active step label in wizard */
[data-theme="dark"] .wizard-step-indicator.active .step-label {
    color: var(--color-text-primary) !important;
}

/* ========================================
   DARK MODE: Appoiint Card / User Profile
   ======================================== */

/* Profile header card */
[data-theme="dark"] .organization-profile-header {
    background: var(--color-surface) !important;
}

/* Detail sections (Personal Info, Privacy, Social Links, etc.) */
[data-theme="dark"] .detail-section {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .section-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .section-content {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .info-item label,
[data-theme="dark"] .info-item .label {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .info-item .value,
[data-theme="dark"] .info-item p {
    color: var(--color-text-primary) !important;
}

/* Logo upload area */
[data-theme="dark"] .logo-upload-section {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .logo-placeholder {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

/* Dropzone */
[data-theme="dark"] .dropzone-upload {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

/* Image menu dropdown */
[data-theme="dark"] .image-menu-dropdown {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .image-menu-item {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .image-menu-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .image-menu-item i {
    color: var(--color-text-secondary) !important;
}

/* Cover gallery modal */
[data-theme="dark"] .cover-gallery-dialog {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .cover-gallery-header {
    color: var(--color-text-primary) !important;
}

/* Toggle items (Privacy settings) */
[data-theme="dark"] .toggle-item {
    background: var(--color-surface-subtle) !important;
}

/* Branding section */
[data-theme="dark"] .branding-section,
[data-theme="dark"] .branding-subsection {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .branding-info-item {
    color: var(--color-text-primary) !important;
}

/* Social links */
[data-theme="dark"] .social-links-section {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* Color picker section */
[data-theme="dark"] .color-picker-section {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .saved-colors-section {
    background: var(--color-surface-subtle) !important;
}

/* Live preview panel */
[data-theme="dark"] .vcard-preview-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .live-preview-header {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .live-preview-subtitle {
    color: var(--color-text-secondary) !important;
}

/* Edit form fields */
[data-theme="dark"] .detail-section input,
[data-theme="dark"] .detail-section select,
[data-theme="dark"] .detail-section textarea {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

/* Cards column layout */
[data-theme="dark"] .cards-column .detail-section {
    background: var(--color-surface) !important;
}

/* Color picker tabs */
[data-theme="dark"] .color-tab {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .color-tab:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .color-tab.active {
    background: linear-gradient(135deg, #1E3A5F 0%, #2A4F7A 100%) !important;
    color: #fff !important;
    border-color: transparent !important;
}

/* Hex input area */
[data-theme="dark"] .color-hex-input {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .hex-value {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .hex-label,
[data-theme="dark"] .hex-hash,
[data-theme="dark"] .hex-opacity {
    color: var(--color-text-muted) !important;
}

/* Saved colors header */
[data-theme="dark"] .saved-colors-header span {
    color: var(--color-text-muted) !important;
}

/* Branding subsection & info items */
[data-theme="dark"] .branding-subsection {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .branding-subtitle {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .branding-info-item label {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .branding-info-item span {
    color: var(--color-text-primary) !important;
}

/* Event types section (inline styles) */
[data-theme="dark"] #eventTypesSection {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] #eventTypesSection h4 {
    color: var(--color-text-primary) !important;
}

/* Event type cards in appoiint card */
[data-theme="dark"] .event-type-item,
[data-theme="dark"] .eventype-list-item {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .event-type-item:hover {
    background: var(--color-surface-subtle) !important;
}

/* ========================================
   DARK MODE: Business Hub, Customers,
   Subscription Plans & All Remaining Modules
   ======================================== */

/* --- Generic containers with white bg --- */
[data-theme="dark"] .customer-form-container,
[data-theme="dark"] .customer-detail-section,
[data-theme="dark"] .customer-detail-header,
[data-theme="dark"] .customer-modal,
[data-theme="dark"] .customer-modal-body,
[data-theme="dark"] .customer-form,
[data-theme="dark"] .business-hub-container,
[data-theme="dark"] .stripe-connect-card,
[data-theme="dark"] .setup-card,
[data-theme="dark"] .onboarding-card,
[data-theme="dark"] .subscription-plans-container,
[data-theme="dark"] .plan-form-container,
[data-theme="dark"] .plan-detail-section {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

/* --- Customer list table --- */
[data-theme="dark"] .customers-table-container,
[data-theme="dark"] .customers-table,
[data-theme="dark"] .plans-table-container,
[data-theme="dark"] .plans-table,
[data-theme="dark"] .plans-list-container,
[data-theme="dark"] .plans-grid {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .customer-row,
[data-theme="dark"] .plan-row {
    border-color: var(--color-border-light) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .customer-row:hover,
[data-theme="dark"] .plan-row:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .customer-name,
[data-theme="dark"] .plan-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .customer-company,
[data-theme="dark"] .customer-email,
[data-theme="dark"] .plan-description {
    color: var(--color-text-secondary) !important;
}

/* --- Table headers --- */
[data-theme="dark"] .customers-table-header,
[data-theme="dark"] .plans-table-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

/* --- Customer/plan detail items --- */
[data-theme="dark"] .customer-detail-item label,
[data-theme="dark"] .customer-detail-item .label {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .customer-detail-value {
    color: var(--color-text-primary) !important;
}

/* --- Customer modal --- */
[data-theme="dark"] .customer-modal-footer {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .customer-modal-close {
    color: var(--color-text-secondary) !important;
}

/* --- Customer action buttons --- */
[data-theme="dark"] .customer-action-btn {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .customer-action-btn:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Business Hub specific --- */
[data-theme="dark"] .setup-step,
[data-theme="dark"] .onboarding-step,
[data-theme="dark"] .feature-card,
[data-theme="dark"] .benefit-item,
[data-theme="dark"] .info-card-item {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .setup-step h3,
[data-theme="dark"] .feature-card h3,
[data-theme="dark"] .benefit-item strong {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .setup-step p,
[data-theme="dark"] .feature-card p,
[data-theme="dark"] .benefit-item p {
    color: var(--color-text-secondary) !important;
}

/* --- Step indicators (Business Hub wizard) --- */
[data-theme="dark"] .step-indicator,
[data-theme="dark"] .progress-step {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .step-indicator.active,
[data-theme="dark"] .progress-step.active {
    color: var(--color-text-primary) !important;
}

/* --- Subscription plan cards --- */
[data-theme="dark"] .plan-card,
[data-theme="dark"] .subscription-plan-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .plan-card:hover,
[data-theme="dark"] .subscription-plan-card:hover {
    border-color: var(--color-text-muted) !important;
}

/* --- Generic catch-all for remaining module containers --- */
[data-theme="dark"] [class*="-container"]:not(.sidebar):not(.nav):not(.dashboard) {
    color: var(--color-text-primary);
}

[data-theme="dark"] [class*="-section"] h3,
[data-theme="dark"] [class*="-section"] h4,
[data-theme="dark"] [class*="-header"] h3,
[data-theme="dark"] [class*="-header"] h4 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] [class*="-section"] p,
[data-theme="dark"] [class*="-header"] p {
    color: var(--color-text-secondary) !important;
}

/* --- All remaining white inline-style containers --- */
[data-theme="dark"] [style*="background: linear-gradient(180deg, #fafafa"],
[data-theme="dark"] [style*="background: linear-gradient(180deg,#fafafa"] {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] [style*="border-top: 2px solid #e9ecef"],
[data-theme="dark"] [style*="border-top:2px solid #e9ecef"],
[data-theme="dark"] [style*="border-top: 2px solid #e5e7eb"],
[data-theme="dark"] [style*="border-top:2px solid #e5e7eb"] {
    border-color: var(--color-border) !important;
}

/* ========================================
   DARK MODE: Helpdesk (Live Chat, Tickets,
   Knowledgebase, Surveys) & CRM
   ======================================== */

/* --- Status cards (stat badges bar) --- */
[data-theme="dark"] .status-cards {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .status-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .status-info h3 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .status-info p {
    color: var(--color-text-secondary) !important;
}

/* --- Filters section --- */
[data-theme="dark"] .filters-section {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Chat items --- */
[data-theme="dark"] .chat-item {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .chat-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .chat-item-header {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .chat-item-preview {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .chat-item-meta {
    color: var(--color-text-muted) !important;
}

/* --- Chat view container --- */
[data-theme="dark"] .chat-view-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .chat-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .chat-details {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Messages --- */
[data-theme="dark"] .messages-container,
[data-theme="dark"] .messages-section {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .message-item {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .message-content {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .message-author {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .message-date {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .no-messages {
    color: var(--color-text-muted) !important;
}

/* --- Chat metadata --- */
[data-theme="dark"] .metadata-grid {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .metadata-item {
    color: var(--color-text-primary) !important;
    border-color: var(--color-border-light) !important;
}

/* --- Send message form --- */
[data-theme="dark"] .send-message-form {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Chat count badge --- */
[data-theme="dark"] .chat-count {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

/* --- Quick actions --- */
[data-theme="dark"] .quick-actions .btn {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .quick-actions .btn:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Create form --- */
[data-theme="dark"] .create-form {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Tickets --- */
[data-theme="dark"] .ticket-item,
[data-theme="dark"] .ticket-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .ticket-item:hover,
[data-theme="dark"] .ticket-row:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Knowledgebase --- */
[data-theme="dark"] .kb-article,
[data-theme="dark"] .kb-category,
[data-theme="dark"] .article-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .kb-article:hover,
[data-theme="dark"] .article-card:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- CRM (Pipelines, Leads, Opportunities) --- */
[data-theme="dark"] .pipeline-column,
[data-theme="dark"] .pipeline-header,
[data-theme="dark"] .deal-card,
[data-theme="dark"] .lead-item,
[data-theme="dark"] .opportunity-item {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .pipeline-column {
    background: var(--color-bg) !important;
}

[data-theme="dark"] .deal-card:hover,
[data-theme="dark"] .lead-item:hover,
[data-theme="dark"] .opportunity-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .pipeline-header {
    background: var(--color-surface-subtle) !important;
}

/* --- Tickets table & filters --- */
[data-theme="dark"] .tickets-table-container,
[data-theme="dark"] .tickets-table,
[data-theme="dark"] .customers-table-container,
[data-theme="dark"] .customers-table,
[data-theme="dark"] .ticket-details-container,
[data-theme="dark"] .ticket-view-container,
[data-theme="dark"] .article-view-container,
[data-theme="dark"] .search-results-container,
[data-theme="dark"] .mc-table-container,
[data-theme="dark"] .mc-table {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .tickets-filters {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .ticket-row,
[data-theme="dark"] .customer-row,
[data-theme="dark"] .mc-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border-light) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .ticket-row:hover,
[data-theme="dark"] .customer-row:hover,
[data-theme="dark"] .mc-row:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Table headers for tickets/customers/kb --- */
[data-theme="dark"] .tickets-table-container .table-header,
[data-theme="dark"] .customers-table-container .table-header,
[data-theme="dark"] .mc-table-container .table-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Knowledgebase articles list --- */
[data-theme="dark"] .article-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .article-row:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .article-title {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .article-excerpt,
[data-theme="dark"] .article-description {
    color: var(--color-text-secondary) !important;
}

/* --- Related articles --- */
[data-theme="dark"] .related-articles-container {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Notes/Quill editor containers --- */
[data-theme="dark"] .notes-container,
[data-theme="dark"] .ql-container,
[data-theme="dark"] .quill-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

/* --- Business hub chart container --- */
[data-theme="dark"] .bh-chart-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- MC (manage customers) search & filters --- */
[data-theme="dark"] .mc-search-container,
[data-theme="dark"] .mc-filter-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* ========================================
   DARK MODE: CRM — Leads, Opportunities,
   Pipelines
   ======================================== */

/* --- Leads --- */
[data-theme="dark"] .leads-filters,
[data-theme="dark"] .leads-grid-container,
[data-theme="dark"] .leads-stats {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .lead-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .lead-card:hover {
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .lead-card-header {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .lead-card-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .lead-card-company,
[data-theme="dark"] .lead-company {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .lead-card-detail {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .lead-card-footer {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .lead-card-footer .btn,
[data-theme="dark"] .lead-card-footer button {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .lead-card-footer .btn:hover,
[data-theme="dark"] .lead-card-footer button:hover {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .lead-card-avatar {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .lead-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .lead-row:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Leads toolbar --- */
[data-theme="dark"] .leads-toolbar {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .view-toggle-btn {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .view-toggle-btn.active,
[data-theme="dark"] .view-toggle-btn:hover {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

/* --- Opportunities --- */
[data-theme="dark"] .opportunities-filters,
[data-theme="dark"] .opportunities-grid-container,
[data-theme="dark"] .opportunities-table-container,
[data-theme="dark"] .opportunities-table,
[data-theme="dark"] .opportunities-stats {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .opportunity-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .opportunity-card:hover {
    border-color: var(--color-text-muted) !important;
}

[data-theme="dark"] .opportunity-card-header {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .opportunity-card-name {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .opportunity-card-company,
[data-theme="dark"] .opportunity-card-amount {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .opportunity-card-detail {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .opportunity-card-footer {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .opportunity-card-footer .btn,
[data-theme="dark"] .opportunity-card-footer button {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .opportunity-card-footer .btn:hover,
[data-theme="dark"] .opportunity-card-footer button:hover {
    background: var(--color-surface-subtle) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .opportunity-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .opportunity-row:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .opportunity-form-container,
[data-theme="dark"] .opportunity-form {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Opportunities toolbar --- */
[data-theme="dark"] .opportunities-toolbar {
    border-color: var(--color-border) !important;
}

/* --- Lead/Opportunity score badge --- */
[data-theme="dark"] .lead-card-score,
[data-theme="dark"] .lead-score {
    border-color: var(--color-border) !important;
}

/* ========================================
   DARK MODE: ALL Create/New/Edit Forms,
   Toolbars, View Toggles — Global Catch-All
   ======================================== */

/* --- Toolbars with white bg --- */
[data-theme="dark"] .leads-toolbar,
[data-theme="dark"] .opportunities-toolbar,
[data-theme="dark"] .bookings-toolbar {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- View toggle container --- */
[data-theme="dark"] .view-toggle {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- All stat cards from inline CSS modules --- */
[data-theme="dark"] .leads-stats .stat-card,
[data-theme="dark"] .opportunities-stats .stat-card {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- All create/new form containers --- */
[data-theme="dark"] .create-form-container,
[data-theme="dark"] .new-form-container,
[data-theme="dark"] .lead-form-container,
[data-theme="dark"] .lead-form,
[data-theme="dark"] .opportunity-form-container,
[data-theme="dark"] .opportunity-form,
[data-theme="dark"] .pipeline-form-container,
[data-theme="dark"] .pipeline-form,
[data-theme="dark"] .ticket-form-container,
[data-theme="dark"] .ticket-form,
[data-theme="dark"] .article-form-container,
[data-theme="dark"] .article-form,
[data-theme="dark"] .customer-form-container,
[data-theme="dark"] .customer-form,
[data-theme="dark"] .plan-form-container,
[data-theme="dark"] .plan-form {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Form headers (Create New X) --- */
[data-theme="dark"] .form-header,
[data-theme="dark"] .create-header {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .form-header h2,
[data-theme="dark"] .form-header h3,
[data-theme="dark"] .create-header h2,
[data-theme="dark"] .create-header h3 {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .form-header p,
[data-theme="dark"] .create-header p {
    color: var(--color-text-secondary) !important;
}

/* --- Form sections (Basic Information, Contact, etc.) --- */
[data-theme="dark"] .form-section {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .form-section h3,
[data-theme="dark"] .form-section h4 {
    color: var(--color-text-primary) !important;
}

/* --- Form labels --- */
[data-theme="dark"] .form-group label,
[data-theme="dark"] .form-label {
    color: var(--color-text-secondary) !important;
}

/* --- Form help text --- */
[data-theme="dark"] .form-help,
[data-theme="dark"] .form-text {
    color: var(--color-text-muted) !important;
}

/* --- Form action buttons bar --- */
[data-theme="dark"] .form-actions {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Detail/view containers --- */
[data-theme="dark"] .lead-detail-container,
[data-theme="dark"] .opportunity-detail-container,
[data-theme="dark"] .ticket-detail-container,
[data-theme="dark"] .article-detail-container,
[data-theme="dark"] .customer-detail-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Detail headers --- */
[data-theme="dark"] .detail-header,
[data-theme="dark"] .customer-detail-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Detail grids --- */
[data-theme="dark"] .detail-grid,
[data-theme="dark"] .customer-detail-grid,
[data-theme="dark"] .lead-detail-grid,
[data-theme="dark"] .opportunity-detail-grid {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .detail-item label,
[data-theme="dark"] .detail-item .label {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .detail-item .value,
[data-theme="dark"] .detail-item p {
    color: var(--color-text-primary) !important;
}

/* ========================================
   DARK MODE: Helpdesk Support Tickets &
   Knowledgebase (Tier 1 user-facing pages)
   ======================================== */

/* --- Ticket items --- */
[data-theme="dark"] .ticket-item {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .ticket-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .ticket-item-header {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .ticket-item-description,
[data-theme="dark"] .ticket-description {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .ticket-item-meta,
[data-theme="dark"] .ticket-meta {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .ticket-item-footer {
    border-color: var(--color-border) !important;
}

/* --- Ticket view/details --- */
[data-theme="dark"] .ticket-view-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .ticket-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .ticket-details {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .ticket-metadata {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Article items --- */
[data-theme="dark"] .article-item {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .article-item:hover {
    background: var(--color-surface-subtle) !important;
}

[data-theme="dark"] .article-item-header {
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .article-item-summary {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .article-item-meta {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .article-item-footer {
    border-color: var(--color-border) !important;
}

/* --- Article view --- */
[data-theme="dark"] .article-view-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .article-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .article-content {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .article-metadata {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Search header/results --- */
[data-theme="dark"] .search-header {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .search-results {
    background: var(--color-surface) !important;
}

/* --- Attachment cards --- */
[data-theme="dark"] .attachment-card {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

/* --- Content card (shared component) --- */
[data-theme="dark"] .content-card .card-body {
    background: var(--color-surface) !important;
}

/* --- Ticket count / article count badges --- */
[data-theme="dark"] .ticket-count,
[data-theme="dark"] .article-count {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

/* --- Security sessions: dark mode for history items --- */
[data-theme="dark"] .history-item.success {
    background: linear-gradient(135deg, rgba(30, 58, 95, 0.15) 0%, var(--color-surface) 100%) !important;
}

[data-theme="dark"] .history-item.failed {
    background: linear-gradient(135deg, rgba(248, 81, 73, 0.1) 0%, var(--color-surface) 100%) !important;
}

/* --- Bookings table (list view) --- */
[data-theme="dark"] .bookings-table-container,
[data-theme="dark"] .bookings-table {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .bookings-grid-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .bookings-grid-row {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}

[data-theme="dark"] .bookings-grid-row:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Booking details panel --- */
[data-theme="dark"] .booking-details-container,
[data-theme="dark"] .booking-details-body {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .details-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .details-section {
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .detail-row {
    color: var(--color-text-primary) !important;
}

/* --- Booking form --- */
[data-theme="dark"] .booking-form-container,
[data-theme="dark"] .booking-form {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

/* --- Table controls & pagination --- */
[data-theme="dark"] .table-controls,
[data-theme="dark"] .bookings-toolbar {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .table-pagination {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-secondary) !important;
}

/* --- Header action buttons --- */
[data-theme="dark"] .header-actions .btn,
[data-theme="dark"] .toolbar-actions .btn,
[data-theme="dark"] .btn-outline-secondary {
    background: var(--color-surface) !important;
    color: var(--color-text-primary) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .header-actions .btn:hover,
[data-theme="dark"] .toolbar-actions .btn:hover,
[data-theme="dark"] .btn-outline-secondary:hover {
    background: var(--color-surface-subtle) !important;
}

/* --- Bookings table container & header --- */
[data-theme="dark"] .bookings-table-container {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .table-header {
    background: var(--color-surface-subtle) !important;
    border-color: var(--color-border) !important;
}

[data-theme="dark"] .bookings-table {
    background: var(--color-surface) !important;
}

[data-theme="dark"] .bookings-grid-row {
    border-color: var(--color-border-light) !important;
}

[data-theme="dark"] .empty-state {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .empty-state i {
    color: var(--color-text-muted) !important;
}

[data-theme="dark"] .empty-state h3 {
    color: var(--color-text-secondary) !important;
}

[data-theme="dark"] .empty-state p {
    color: var(--color-text-muted) !important;
}

/* --- Loading skeleton --- */
[data-theme="dark"] .skeleton {
    background: linear-gradient(90deg,
        var(--color-border-light) 0%,
        var(--color-border) 20%,
        var(--color-border) 40%,
        var(--color-border-light) 100%
    ) !important;
    background-size: 200% 100% !important;
}

/* --- Analytics section --- */
[data-theme="dark"] .analytics-content,
[data-theme="dark"] .analytics-header {
    background: var(--color-surface) !important;
    border-color: var(--color-border) !important;
    color: var(--color-text-primary) !important;
}
