/* ═══════════════════════════════════════════════════════════════════════════════
   DALATIC PORTAL - ENTERPRISE DESIGN SYSTEM
   
   Estilo: Ultra Corporativo Minimalista
   Paleta: Deep Blue-Violet + Slate Neutrals
   Inspiración: Stripe, Linear, Notion Enterprise
═══════════════════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════════
   CSS VARIABLES - DESIGN TOKENS
═══════════════════════════════════════════════════════════════════════════════ */

:root {
    /* ━━━━━ CORE PALETTE: Deep Blue-Violet ━━━━━ */
    --dalatic-primary-50: #EEF2FF;
    --dalatic-primary-100: #E0E7FF;
    --dalatic-primary-200: #C7D2FE;
    --dalatic-primary-300: #A5B4FC;
    --dalatic-primary-400: #818CF8;
    --dalatic-primary-500: #6366F1;
    --dalatic-primary-600: #4F46E5;
    --dalatic-primary-700: #4338CA;
    --dalatic-primary-800: #3730A3;
    --dalatic-primary-900: #312E81;
    --dalatic-primary-950: #1E1B4B;

    /* ━━━━━ ACCENT: Violet ━━━━━ */
    --dalatic-accent-50: #F5F3FF;
    --dalatic-accent-100: #EDE9FE;
    --dalatic-accent-200: #DDD6FE;
    --dalatic-accent-300: #C4B5FD;
    --dalatic-accent-400: #A78BFA;
    --dalatic-accent-500: #8B5CF6;
    --dalatic-accent-600: #7C3AED;
    --dalatic-accent-700: #6D28D9;
    --dalatic-accent-800: #5B21B6;
    --dalatic-accent-900: #4C1D95;

    /* ━━━━━ NEUTRALS: Refined Slate ━━━━━ */
    --rz-white: #FFFFFF;
    --rz-black: #000000;
    --rz-base-50: #F8FAFC;
    --rz-base-100: #F1F5F9;
    --rz-base-200: #E2E8F0;
    --rz-base-300: #CBD5E1;
    --rz-base-400: #94A3B8;
    --rz-base-500: #64748B;
    --rz-base-600: #475569;
    --rz-base-700: #334155;
    --rz-base-800: #1E293B;
    --rz-base-900: #0F172A;
    --rz-base-950: #020617;
    --rz-base-lighter: #F8FAFC;
    --rz-base-light: #F1F5F9;
    --rz-base-dark: #0F172A;
    --rz-base-darker: #020617;

    /* ━━━━━ PRIMARY (Indigo Corporate) ━━━━━ */
    --rz-primary: #4F46E5;
    --rz-primary-light: #6366F1;
    --rz-primary-lighter: rgba(79, 70, 229, 0.06);
    --rz-primary-dark: #4338CA;
    --rz-primary-darker: #3730A3;
    --rz-on-primary: #FFFFFF;
    --rz-on-primary-lighter: #4F46E5;

    /* ━━━━━ SECONDARY (Slate Professional) ━━━━━ */
    --rz-secondary: #475569;
    --rz-secondary-light: #64748B;
    --rz-secondary-lighter: rgba(71, 85, 105, 0.06);
    --rz-secondary-dark: #334155;
    --rz-secondary-darker: #1E293B;
    --rz-on-secondary: #FFFFFF;

    /* ━━━━━ INFO (Violet Accent) ━━━━━ */
    --rz-info: #7C3AED;
    --rz-info-light: #8B5CF6;
    --rz-info-lighter: rgba(124, 58, 237, 0.06);
    --rz-info-dark: #6D28D9;
    --rz-info-darker: #5B21B6;
    --rz-on-info: #FFFFFF;

    /* ━━━━━ SUCCESS (Emerald Muted) ━━━━━ */
    --rz-success: #059669;
    --rz-success-light: #10B981;
    --rz-success-lighter: rgba(5, 150, 105, 0.06);
    --rz-success-dark: #047857;
    --rz-success-darker: #065F46;
    --rz-on-success: #FFFFFF;

    /* ━━━━━ WARNING (Muted Amber - Corporate) ━━━━━ */
    --rz-warning: #B98900;
    --rz-warning-light: #D4A017;
    --rz-warning-lighter: rgba(185, 137, 0, 0.06);
    --rz-warning-dark: #9A7200;
    --rz-warning-darker: #7A5A00;
    --rz-on-warning: #FFFFFF;

    /* ━━━━━ DANGER (Rose Muted) ━━━━━ */
    --rz-danger: #DC2626;
    --rz-danger-light: #EF4444;
    --rz-danger-lighter: rgba(220, 38, 38, 0.06);
    --rz-danger-dark: #B91C1C;
    --rz-danger-darker: #991B1B;
    --rz-on-danger: #FFFFFF;

    /* ━━━━━ SEMANTIC: Tasks & Status ━━━━━ */
    --task-todo: #64748B;
    --task-in-progress: #4F46E5;
    --task-in-review: #7C3AED;
    --task-done: #059669;
    --task-blocked: #DC2626;
    --task-backlog: #94A3B8;

    --priority-critical: #DC2626;
    --priority-high: #D97706;
    --priority-medium: #4F46E5;
    --priority-low: #64748B;

    --type-bug: #DC2626;
    --type-feature: #7C3AED;
    --type-improvement: #4F46E5;
    --type-task: #475569;
    --type-story: #059669;
    --type-epic: #4338CA;

    /* ━━━━━ SEMANTIC: Ticket Status ━━━━━ */
    --ticket-new: var(--rz-info);
    --ticket-open: var(--rz-primary);
    --ticket-in-progress: #0891B2;
    --ticket-on-hold: var(--rz-warning);
    --ticket-pending: #CA8A04;
    --ticket-resolved: var(--rz-success);
    --ticket-closed: var(--rz-base-500);
    --ticket-cancelled: var(--rz-base-400);

    /* ━━━━━ SEMANTIC: Ticket Priority ━━━━━ */
    --ticket-priority-critical: var(--rz-danger-darker);
    --ticket-priority-urgent: var(--rz-danger);
    --ticket-priority-high: var(--rz-warning);
    --ticket-priority-medium: var(--rz-primary);
    --ticket-priority-low: var(--rz-base-500);

    /* ━━━━━ TYPOGRAPHY ━━━━━ */
    --rz-text-font-family: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
    --rz-text-color: #1E293B;
    --rz-text-title-color: #0F172A;
    --rz-text-secondary-color: #64748B;
    --rz-text-tertiary-color: #94A3B8;
    --rz-text-disabled-color: #CBD5E1;
    --rz-text-contrast-color: #FFFFFF;
    --rz-body-font-size: 0.875rem;
    --rz-body-line-height: 1.6;

    /* ━━━━━ LAYOUT ━━━━━ */
    --rz-body-background-color: #F8FAFC;
    --rz-base-background-color: #FFFFFF;
    --rz-layout-body-background-color: #F1F5F9;

    /* ━━━━━ HEADER (Deep Indigo Gradient) ━━━━━ */
    --rz-header-background-color: linear-gradient(135deg, #1E1B4B 0%, #312E81 50%, #3730A3 100%);
    --rz-header-color: #FFFFFF;
    --rz-header-min-height: 56px;
    --rz-header-shadow: 0 1px 0 rgba(0, 0, 0, 0.05);

    /* ━━━━━ SIDEBAR (Clean White) ━━━━━ */
    --rz-sidebar-background-color: #FFFFFF;
    --rz-sidebar-color: #1E293B;
    --rz-sidebar-width: 240px;
    --rz-sidebar-border-inline-end: 1px solid #E2E8F0;

    /* ━━━━━ PANEL MENU ━━━━━ */
    --rz-panel-menu-item-color: #64748B;
    --rz-panel-menu-item-background-color: transparent;
    --rz-panel-menu-item-hover-color: #1E293B;
    --rz-panel-menu-item-hover-background-color: #F1F5F9;
    --rz-panel-menu-item-active-color: #4F46E5;
    --rz-panel-menu-item-active-background-color: rgba(79, 70, 229, 0.06);
    --rz-panel-menu-item-padding-block: 10px;
    --rz-panel-menu-item-padding-inline: 14px;
    --rz-panel-menu-item-border-radius: 8px;
    --rz-panel-menu-font-size: 0.875rem;

    /* ━━━━━ PROFILE MENU ━━━━━ */
    --rz-profile-menu-padding-block: 0;
    --rz-profile-menu-padding-inline: 0;
    --rz-profile-menu-border: none;
    --rz-profile-menu-top-item-background-color: transparent;
    --rz-profile-menu-background-color: var(--rz-base-background-color);
    --rz-profile-menu-color: var(--rz-text-color);
    --rz-profile-menu-hover-background-color: rgba(0, 0, 0, 0.04);
    --rz-profile-menu-item-color: var(--rz-text-secondary-color);
    --rz-profile-menu-item-hover-color: var(--rz-text-color);

    /* ━━━━━ BUTTONS ━━━━━ */
    --rz-button-border-radius: 8px;
    --rz-button-padding-inline: 18px;
    --rz-button-padding-block: 10px;
    --rz-button-font-size: 0.875rem;
    --rz-button-font-weight: 500;

    /* ━━━━━ BORDERS ━━━━━ */
    --rz-border-radius: 8px;
    --rz-border-radius-sm: 6px;
    --rz-border-radius-lg: 12px;
    --rz-border-radius-xl: 16px;
    --rz-border-base-200: 1px solid #E2E8F0;
    --rz-border-base-300: 1px solid #CBD5E1;
    --rz-border-normal: 1px solid #E2E8F0;
    --rz-border-hover: 1px solid #CBD5E1;
    --rz-border-focus: 2px solid var(--rz-primary);

    /* ━━━━━ SHADOWS (Ultra Subtle) ━━━━━ */
    --rz-shadow-0: none;
    --rz-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.03);
    --rz-shadow-1: 0 1px 3px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.02);
    --rz-shadow-4: 0 4px 6px rgba(0, 0, 0, 0.04), 0 2px 4px rgba(0, 0, 0, 0.02);
    --rz-shadow-6: 0 10px 15px rgba(0, 0, 0, 0.04), 0 4px 6px rgba(0, 0, 0, 0.02);
    --rz-shadow-lg: 0 20px 25px rgba(0, 0, 0, 0.06), 0 8px 10px rgba(0, 0, 0, 0.03);
    --rz-shadow-xl: 0 25px 50px rgba(0, 0, 0, 0.08);
    --rz-shadow-glow: 0 0 0 3px rgba(79, 70, 229, 0.12);

    /* ━━━━━ TRANSITIONS ━━━━━ */
    --rz-transition: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --rz-transition-fast: 100ms cubic-bezier(0.4, 0, 0.2, 1);
    --rz-transition-slow: 300ms cubic-bezier(0.4, 0, 0.2, 1);
    --rz-transition-all: all var(--rz-transition);

    /* ━━━━━ GRID / DATAGRID ━━━━━ */
    --rz-grid-background-color: var(--rz-base-background-color);
    --rz-grid-header-background-color: #FAFBFC;
    --rz-grid-border: var(--rz-border-base-200);
    --rz-grid-row-hover-background-color: #F8FAFC;

    /* ━━━━━ INPUTS ━━━━━ */
    --rz-input-background-color: var(--rz-base-background-color);
    --rz-input-border: 1px solid #E2E8F0;
    --rz-input-hover-border: 1px solid #CBD5E1;
    --rz-input-focus-border: 2px solid var(--rz-primary);
    --rz-input-border-radius: 8px;
    --rz-input-padding: 10px 14px;

    /* ━━━━━ CARDS ━━━━━ */
    --rz-card-background-color: var(--rz-base-background-color);
    --rz-card-border: 1px solid #E2E8F0;
    --rz-card-shadow: var(--rz-shadow-1);
    --rz-card-border-radius: 12px;

    /* ━━━━━ BADGES ━━━━━ */
    --rz-badge-border-radius: 6px;
    --rz-badge-font-weight: 500;
    --rz-badge-font-size: 0.6875rem;
    --rz-badge-padding: 4px 8px;

    /* ━━━━━ SPACING SCALE ━━━━━ */
    --space-1: 4px;
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-8: 32px;
    --space-10: 40px;
    --space-12: 48px;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   DARK MODE
   Supports both Radzen (.rz-dark) and Bootstrap 5.3 ([data-bs-theme="dark"])
═══════════════════════════════════════════════════════════════════════════════ */

:root.rz-dark,
[data-bs-theme="dark"],
html[data-bs-theme="dark"] {
    color-scheme: dark;
    --rz-text-color: #E2E8F0;
    --rz-text-title-color: #F8FAFC;
    --rz-text-secondary-color: #CBD5E1;
    --rz-text-tertiary-color: #94A3B8;
    --rz-text-disabled-color: #64748B;

    --rz-base-50: #0F172A;
    --rz-base-100: #1E293B;
    --rz-base-200: #334155;
    --rz-base-300: #475569;
    --rz-base-400: #64748B;
    --rz-base-500: #94A3B8;
    --rz-base-600: #CBD5E1;
    --rz-base-700: #E2E8F0;
    --rz-base-800: #F1F5F9;
    --rz-base-900: #F8FAFC;

    --rz-body-background-color: #020617;
    --rz-base-background-color: #0F172A;
    --rz-layout-body-background-color: #020617;

    --rz-header-background-color: linear-gradient(135deg, #0F172A 0%, #1E1B4B 100%);
    --rz-header-shadow: 0 1px 0 rgba(0, 0, 0, 0.3);

    --rz-sidebar-background-color: #0F172A;
    --rz-sidebar-color: #E2E8F0;
    --rz-sidebar-border-inline-end: 1px solid #1E293B;

    --rz-panel-menu-item-color: #94A3B8;
    --rz-panel-menu-item-hover-color: #F1F5F9;
    --rz-panel-menu-item-hover-background-color: #1E293B;
    --rz-panel-menu-item-active-color: #818CF8;
    --rz-panel-menu-item-active-background-color: rgba(129, 140, 248, 0.08);

    --rz-profile-menu-background-color: #1E1B4B;
    --rz-profile-menu-color: #FFFFFF;
    --rz-profile-menu-hover-background-color: rgba(255, 255, 255, 0.08);
    --rz-profile-menu-item-color: rgba(255, 255, 255, 0.9);
    --rz-profile-menu-item-hover-color: #FFFFFF;

    --rz-border-base-200: 1px solid #1E293B;
    --rz-border-base-300: 1px solid #334155;
    --rz-border-normal: 1px solid #334155;
    --rz-input-border: 1px solid #334155;
    --rz-card-border: 1px solid #1E293B;

    --rz-shadow-1: 0 1px 3px rgba(0, 0, 0, 0.2);
    --rz-shadow-4: 0 4px 6px rgba(0, 0, 0, 0.3);
    --rz-shadow-6: 0 10px 15px rgba(0, 0, 0, 0.4);

    --rz-grid-header-background-color: #1E293B;
    --rz-grid-row-hover-background-color: #1E293B;

    --rz-primary: #6366F1;
    --rz-primary-light: #818CF8;
    --rz-primary-lighter: rgba(99, 102, 241, 0.1);
    --rz-info: #8B5CF6;
    --rz-info-lighter: rgba(139, 92, 246, 0.1);
    
    /* Secondary color - lighter for dark mode contrast */
    --rz-secondary: #94A3B8;
    --rz-secondary-lighter: rgba(148, 163, 184, 0.15);
}

/* ━━━━━ DARK MODE: Button Overrides ━━━━━ */
:root.rz-dark,
[data-bs-theme="dark"],
html[data-bs-theme="dark"] {
    /* Secondary buttons should have white/light text in dark mode */
    --rz-button-secondary-text: #F8FAFC;
    --rz-button-secondary-border: #475569;
    --rz-button-secondary-hover-bg: #334155;
    --rz-button-secondary-hover-border: #64748B;
}

/* Dark mode button text overrides */
:root.rz-dark .rz-button-secondary,
:root.rz-dark .rz-button.rz-variant-filled.rz-secondary,
:root.rz-dark .rz-button.rz-variant-flat.rz-secondary,
:root.rz-dark .rz-button.rz-variant-outlined,
[data-bs-theme="dark"] .rz-button-secondary,
[data-bs-theme="dark"] .rz-button.rz-variant-filled.rz-secondary,
[data-bs-theme="dark"] .rz-button.rz-variant-flat.rz-secondary,
[data-bs-theme="dark"] .rz-button.rz-variant-outlined {
    color: #F8FAFC !important;
    border-color: #475569 !important;
}

:root.rz-dark .rz-button-secondary:hover,
:root.rz-dark .rz-button.rz-variant-filled.rz-secondary:hover,
:root.rz-dark .rz-button.rz-variant-flat.rz-secondary:hover,
:root.rz-dark .rz-button.rz-variant-outlined:hover,
[data-bs-theme="dark"] .rz-button-secondary:hover,
[data-bs-theme="dark"] .rz-button.rz-variant-filled.rz-secondary:hover,
[data-bs-theme="dark"] .rz-button.rz-variant-flat.rz-secondary:hover,
[data-bs-theme="dark"] .rz-button.rz-variant-outlined:hover {
    background: #334155 !important;
    border-color: #64748B !important;
    color: #FFFFFF !important;
}

/* Dark mode light/ghost button text */
:root.rz-dark .rz-button-light,
:root.rz-dark .rz-button.rz-variant-text,
[data-bs-theme="dark"] .rz-button-light,
[data-bs-theme="dark"] .rz-button.rz-variant-text {
    color: #E2E8F0 !important;
}

:root.rz-dark .rz-button-light:hover,
:root.rz-dark .rz-button.rz-variant-text:hover,
[data-bs-theme="dark"] .rz-button-light:hover,
[data-bs-theme="dark"] .rz-button.rz-variant-text:hover {
    background: #1E293B !important;
    color: #FFFFFF !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   GLOBAL TYPOGRAPHY
═══════════════════════════════════════════════════════════════════════════════ */

body {
    font-family: var(--rz-text-font-family);
    font-size: var(--rz-body-font-size);
    line-height: var(--rz-body-line-height);
    color: var(--rz-text-color);
    background-color: var(--rz-body-background-color);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "cv02", "cv03", "cv04", "cv11";
}

/* ═══════════════════════════════════════════════════════════════════════════════
   PAGE HEADERS - Enterprise Style
═══════════════════════════════════════════════════════════════════════════════ */

.page-header {
    margin-bottom: var(--space-8);
    padding-bottom: var(--space-6);
    border-bottom: 1px solid var(--rz-base-200);
}

.page-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--rz-text-title-color);
    letter-spacing: -0.02em;
    margin: 0 0 var(--space-2) 0;
    line-height: 1.3;
}

.page-subtitle {
    font-size: 0.9375rem;
    color: var(--rz-text-secondary-color);
    margin: 0;
    line-height: 1.5;
}

.page-breadcrumb {
    font-size: 0.8125rem;
    color: var(--rz-text-tertiary-color);
    margin-bottom: var(--space-3);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.page-breadcrumb a {
    color: var(--rz-text-secondary-color);
    text-decoration: none;
    transition: color var(--rz-transition);
}

.page-breadcrumb a:hover {
    color: var(--rz-primary);
}

.page-breadcrumb .separator {
    color: var(--rz-base-300);
}

/* Section Headers */
.section-header {
    margin-bottom: var(--space-5);
}

.section-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--rz-text-title-color);
    letter-spacing: -0.01em;
    margin: 0 0 var(--space-1) 0;
}

.section-subtitle {
    font-size: 0.875rem;
    color: var(--rz-text-secondary-color);
    margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   HEADER - Deep Indigo Gradient
═══════════════════════════════════════════════════════════════════════════════ */

.rz-header {
    background: var(--rz-header-background-color) !important;
    box-shadow: var(--rz-header-shadow) !important;
    color: var(--rz-header-color) !important;
    backdrop-filter: blur(8px);
}

:root.rz-dark .rz-header {
    background: var(--rz-header-background-color) !important;
    box-shadow: var(--rz-header-shadow) !important;
}

/* Header icons - always use header color (white on dark header) */
.rz-header .rz-button.rz-variant-text {
    color: var(--rz-header-color) !important;
}

.rz-header .rz-button.rz-variant-text:hover {
    background: rgba(255, 255, 255, 0.1) !important;
    color: var(--rz-header-color) !important;
}

.rz-header .rz-button.rz-variant-text .rz-button-icon,
.rz-header .rz-button.rz-variant-text .material-icons {
    color: var(--rz-header-color) !important;
}

/* Profile menu in header */
.rz-header .profile-menu-custom,
.rz-header .rz-profilemenu {
    color: var(--rz-header-color) !important;
}

/* Logo Area */
.header-logo {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-weight: 600;
    font-size: 1rem;
    letter-spacing: -0.01em;
}

.header-logo img {
    height: 28px;
    width: auto;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SIDEBAR - Clean & Minimal
═══════════════════════════════════════════════════════════════════════════════ */

.rz-sidebar {
    background: var(--rz-sidebar-background-color) !important;
    border-right: 1px solid var(--rz-base-200) !important;
}

/* Active menu item indicator */
.rz-panel-menu-item.rz-state-active {
    position: relative;
}

.rz-panel-menu-item.rz-state-active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 20px;
    background: var(--rz-primary);
    border-radius: 0 2px 2px 0;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   BUTTONS - Enterprise Polish
═══════════════════════════════════════════════════════════════════════════════ */

/* Primary Button */
.rz-button-primary,
.rz-button.rz-variant-filled.rz-primary,
.rz-button.rz-variant-flat.rz-primary {
    background: linear-gradient(135deg, var(--rz-primary) 0%, var(--rz-primary-dark) 100%) !important;
    border: none !important;
    color: var(--rz-on-primary) !important;
    font-weight: 500;
    letter-spacing: 0.01em;
    box-shadow: var(--rz-shadow-1);
    transition: all var(--rz-transition);
}

.rz-button-primary:hover,
.rz-button.rz-variant-filled.rz-primary:hover,
.rz-button.rz-variant-flat.rz-primary:hover {
    background: linear-gradient(135deg, var(--rz-primary-dark) 0%, var(--rz-primary-darker) 100%) !important;
    box-shadow: var(--rz-shadow-4);
    transform: translateY(-1px);
}

.rz-button-primary:active,
.rz-button.rz-variant-filled.rz-primary:active,
.rz-button.rz-variant-flat.rz-primary:active {
    background: linear-gradient(135deg, var(--rz-primary-darker) 0%, var(--dalatic-primary-900) 100%) !important;
    transform: translateY(0);
    box-shadow: var(--rz-shadow-1);
}

/* Secondary Button */
.rz-button-secondary,
.rz-button.rz-variant-filled.rz-secondary,
.rz-button.rz-variant-flat.rz-secondary,
.rz-button.rz-variant-outlined {
    background: transparent !important;
    border: 1px solid var(--rz-base-300) !important;
    color: var(--rz-text-color) !important;
    font-weight: 500;
    transition: all var(--rz-transition);
}

.rz-button-secondary:hover,
.rz-button.rz-variant-filled.rz-secondary:hover,
.rz-button.rz-variant-flat.rz-secondary:hover,
.rz-button.rz-variant-outlined:hover {
    background: var(--rz-base-100) !important;
    border-color: var(--rz-base-400) !important;
}

/* Ghost/Light Button */
.rz-button-light,
.rz-button.rz-variant-text {
    background: transparent !important;
    border: none !important;
    color: var(--rz-text-secondary-color) !important;
    font-weight: 500;
}

.rz-button-light:hover,
.rz-button.rz-variant-text:hover {
    background: var(--rz-base-100) !important;
    color: var(--rz-text-color) !important;
}

/* Icon Button */
.btn-icon {
    width: 36px;
    height: 36px;
    padding: 0 !important;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--rz-border-radius);
}

.btn-icon-sm {
    width: 32px;
    height: 32px;
}

.btn-icon-lg {
    width: 40px;
    height: 40px;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   PROFILE MENU
═══════════════════════════════════════════════════════════════════════════════ */

ul.rz-profilemenu,
ul.rz-profile-menu {
    box-sizing: border-box !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: inline-block !important;
    background-color: transparent !important;
    border: none !important;
    position: relative !important;
    z-index: 3 !important;
    color: var(--rz-profile-menu-color) !important;
}

.rz-profilemenu .rz-button,
.rz-profile-menu .rz-button {
    background-color: transparent !important;
    color: var(--rz-profile-menu-item-color) !important;
    border: none !important;
    transition: all var(--rz-transition);
}

.rz-profilemenu .rz-button:hover,
.rz-profile-menu .rz-button:hover {
    background-color: var(--rz-profile-menu-hover-background-color) !important;
    color: var(--rz-profile-menu-item-hover-color) !important;
}

.rz-profilemenu .rz-dropdown-panel,
.rz-profile-menu .rz-dropdown-panel {
    background: var(--rz-profile-menu-background-color) !important;
    border: 1px solid var(--rz-base-300) !important;
    border-radius: var(--rz-border-radius-lg) !important;
    box-shadow: var(--rz-shadow-xl) !important;
    overflow: hidden;
}

.rz-profilemenu .rz-dropdown-item,
.rz-profile-menu .rz-dropdown-item {
    color: var(--rz-profile-menu-item-color) !important;
    transition: all var(--rz-transition);
}

.rz-profilemenu .rz-dropdown-item:hover,
.rz-profile-menu .rz-dropdown-item:hover {
    background: var(--rz-profile-menu-hover-background-color) !important;
    color: var(--rz-profile-menu-item-hover-color) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   CARDS - Enterprise Style
═══════════════════════════════════════════════════════════════════════════════ */

.rz-card,
.card,
.dashboard-card {
    background: var(--rz-card-background-color) !important;
    border: var(--rz-card-border) !important;
    border-radius: var(--rz-card-border-radius) !important;
    box-shadow: var(--rz-shadow-xs) !important;
    transition: all var(--rz-transition);
}

.rz-card:hover,
.card:hover,
.dashboard-card:hover {
    box-shadow: var(--rz-shadow-4) !important;
}

.card-header {
    padding: var(--space-5) var(--space-6);
    border-bottom: 1px solid var(--rz-base-100);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.card-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--rz-text-title-color);
    margin: 0;
}

.card-body {
    padding: var(--space-6);
}

.card-footer {
    padding: var(--space-4) var(--space-6);
    border-top: 1px solid var(--rz-base-100);
    background: var(--rz-base-50);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   STAT CARDS - Dashboard Metrics
═══════════════════════════════════════════════════════════════════════════════ */

.stat-card {
    background: var(--rz-base-background-color);
    border: 1px solid var(--rz-base-200);
    border-radius: var(--rz-border-radius-lg);
    padding: var(--space-6);
    position: relative;
    overflow: hidden;
}

.stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--rz-primary) 0%, var(--rz-info) 100%);
    opacity: 0;
    transition: opacity var(--rz-transition);
}

.stat-card:hover::before {
    opacity: 1;
}

.stat-card-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--rz-border-radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--rz-primary-lighter);
    color: var(--rz-primary);
    margin-bottom: var(--space-4);
}

.stat-card-icon.violet {
    background: var(--rz-info-lighter);
    color: var(--rz-info);
}

.stat-card-icon.success {
    background: var(--rz-success-lighter);
    color: var(--rz-success);
}

.stat-card-icon.warning {
    background: var(--rz-warning-lighter);
    color: var(--rz-warning);
}

.stat-card-value {
    font-size: 1.625rem;
    font-weight: 600;
    color: var(--rz-text-title-color);
    line-height: 1.1;
    margin-bottom: var(--space-2);
    letter-spacing: -0.01em;
}

.stat-card-label {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--rz-text-secondary-color);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.stat-card-trend {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    font-size: 0.8125rem;
    font-weight: 500;
    margin-top: var(--space-3);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--rz-border-radius-sm);
}

.stat-card-trend.positive {
    background: var(--rz-success-lighter);
    color: var(--rz-success);
}

.stat-card-trend.negative {
    background: var(--rz-danger-lighter);
    color: var(--rz-danger);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   DATA TABLES - Enterprise Grid
═══════════════════════════════════════════════════════════════════════════════ */

.rz-datatable,
.rz-data-grid {
    border: 1px solid var(--rz-base-200) !important;
    border-radius: var(--rz-border-radius-lg) !important;
    overflow: hidden;
    background: var(--rz-base-background-color) !important;
    width: 100%;
    max-width: 100%;
    table-layout: auto;
}

/* Prevent horizontal overflow on grid wrapper */
.rz-data-grid-data {
    overflow-x: auto;
    max-width: 100%;
}

/* Ensure columns don't exceed container */
.rz-data-grid .rz-grid-table {
    table-layout: auto;
    width: 100%;
    min-width: 100%;
}

.rz-datatable thead tr th,
.rz-data-grid .rz-data-grid-header {
    background: var(--rz-base-50) !important;
    color: var(--rz-text-secondary-color) !important;
    font-weight: 600 !important;
    font-size: 0.75rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    border-bottom: 1px solid var(--rz-base-200) !important;
    padding: var(--space-4) var(--space-5) !important;
}

.rz-datatable tbody tr td {
    border-bottom: 1px solid var(--rz-base-100) !important;
    padding: var(--space-4) var(--space-5) !important;
    font-size: 0.875rem;
}

.rz-datatable tbody tr:last-child td {
    border-bottom: none !important;
}

.rz-datatable tbody tr:hover td {
    background: var(--rz-base-50) !important;
}

/* Row selection */
.rz-datatable tbody tr.rz-state-selected td {
    background: var(--rz-primary-lighter) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   BADGES - Refined Status Indicators
═══════════════════════════════════════════════════════════════════════════════ */

.badge,
.rz-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 5px 10px;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 500;
    letter-spacing: 0.01em;
    text-transform: capitalize;
    border: none;
}

/* Status Badges */
.badge-active,
.badge-status-active {
    background: rgba(5, 150, 105, 0.08);
    color: #059669;
}

.badge-pending,
.badge-status-pending {
    background: rgba(79, 70, 229, 0.08);
    color: #4F46E5;
}

.badge-inactive,
.badge-status-inactive {
    background: var(--rz-base-100);
    color: var(--rz-base-500);
}

.badge-warning,
.badge-status-suspended {
    background: rgba(217, 119, 6, 0.08);
    color: #B45309;
}

.badge-danger,
.badge-status-expired,
.badge-status-cancelled {
    background: rgba(220, 38, 38, 0.08);
    color: #DC2626;
}

.badge-info,
.badge-status-info {
    background: rgba(124, 58, 237, 0.08);
    color: #7C3AED;
}

/* Type Badges */
.badge-license-type {
    background: var(--rz-base-100);
    color: var(--rz-base-600);
    text-transform: uppercase;
    font-size: 0.6875rem;
    letter-spacing: 0.03em;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   KANBAN / TASK CARDS
═══════════════════════════════════════════════════════════════════════════════ */

.kanban-board {
    display: flex;
    gap: var(--space-5);
    overflow-x: auto;
    padding-bottom: var(--space-4);
}

.kanban-column {
    flex: 0 0 320px;
    background: var(--rz-base-50);
    border-radius: var(--rz-border-radius-lg);
    padding: var(--space-4);
    border: 1px solid var(--rz-base-200);
}

.kanban-column-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-2) var(--space-2) var(--space-4);
}

.kanban-column-title {
    font-weight: 600;
    font-size: 0.875rem;
    color: var(--rz-text-title-color);
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.kanban-column-count {
    background: var(--rz-base-200);
    color: var(--rz-text-secondary-color);
    padding: 2px 8px;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
}

.task-card {
    background: var(--rz-base-background-color);
    border: 1px solid var(--rz-base-200);
    border-radius: var(--rz-border-radius);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
    cursor: grab;
    transition: all var(--rz-transition);
    box-shadow: var(--rz-shadow-xs);
}

.task-card:hover {
    border-color: var(--rz-base-300);
    box-shadow: var(--rz-shadow-4);
    transform: translateY(-2px);
}

.task-card:active {
    cursor: grabbing;
    transform: scale(1.02);
    box-shadow: var(--rz-shadow-lg);
}

.task-card-key {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--rz-text-secondary-color);
    margin-bottom: var(--space-2);
}

.task-card-title {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--rz-text-title-color);
    margin-bottom: var(--space-3);
    line-height: 1.4;
}

.task-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.task-card-assignee {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--rz-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.625rem;
    font-weight: 600;
}

/* Status colors for column headers */
.kanban-status-todo { border-left: 3px solid var(--rz-base-400); }
.kanban-status-in-progress { border-left: 3px solid var(--rz-primary); }
.kanban-status-in-review { border-left: 3px solid var(--rz-info); }
.kanban-status-done { border-left: 3px solid var(--rz-success); }

/* ═══════════════════════════════════════════════════════════════════════════════
   FORMS & INPUTS
═══════════════════════════════════════════════════════════════════════════════ */

.rz-textbox,
.rz-dropdown,
.rz-datepicker,
.rz-numeric,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
textarea,
select {
    border: 1px solid var(--rz-base-300) !important;
    border-radius: var(--rz-border-radius) !important;
    background: var(--rz-base-background-color) !important;
    transition: all var(--rz-transition) !important;
    font-size: 0.875rem !important;
}

.rz-textbox:hover,
.rz-dropdown:hover,
input:hover {
    border-color: var(--rz-base-400) !important;
}

.rz-textbox:focus,
.rz-dropdown:focus,
input:focus {
    border-color: var(--rz-primary) !important;
    box-shadow: var(--rz-shadow-glow) !important;
    outline: none !important;
}

/* Dropdown & Autocomplete Panels - Dark/Light mode support */
.rz-dropdown-panel,
.rz-autocomplete-panel {
    background-color: var(--rz-base-background-color) !important;
    border: 1px solid var(--rz-base-300) !important;
    box-shadow: var(--rz-shadow-6) !important;
    border-radius: var(--rz-border-radius) !important;
}

/* User autocomplete panel - wider for user selection */
.rz-autocomplete-panel {
    min-width: 280px !important;
    max-width: 350px !important;
}

.rz-autocomplete-panel .rz-autocomplete-list-item {
    padding: 0.5rem 0.75rem !important;
    white-space: normal !important;
}

/* User option item in autocomplete */
.rz-autocomplete-panel .user-option-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
}

.rz-autocomplete-panel .user-option-item .user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    color: white;
    flex-shrink: 0;
    object-fit: cover;
}

.rz-autocomplete-panel .user-option-item .user-info {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
}

.rz-autocomplete-panel .user-option-item .user-name {
    font-weight: 500;
    color: var(--rz-text-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rz-autocomplete-panel .user-option-item .user-email {
    font-size: 0.75rem;
    color: var(--rz-text-secondary-color);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.rz-dropdown-panel .rz-dropdown-item,
.rz-dropdown-panel .rz-dropdown-items .rz-listbox-item,
.rz-autocomplete-panel .rz-autocomplete-list-item {
    color: var(--rz-text-color) !important;
    background-color: var(--rz-base-background-color) !important;
}

.rz-dropdown-panel .rz-dropdown-item:hover,
.rz-dropdown-panel .rz-dropdown-items .rz-listbox-item:hover,
.rz-dropdown-panel .rz-dropdown-item.rz-state-highlight,
.rz-dropdown-panel .rz-listbox-item.rz-state-highlight,
.rz-autocomplete-panel .rz-autocomplete-list-item:hover,
.rz-autocomplete-panel .rz-autocomplete-list-item.rz-state-highlight {
    background-color: var(--rz-base-100) !important;
    color: var(--rz-text-color) !important;
}

/* Dropdown filter input */
.rz-dropdown-panel .rz-dropdown-filter-container input {
    background-color: var(--rz-base-background-color) !important;
    color: var(--rz-text-color) !important;
    border-color: var(--rz-base-300) !important;
}

/* Form Groups */
.form-group {
    margin-bottom: var(--space-5);
}

.form-label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--rz-text-color);
    margin-bottom: var(--space-2);
}

.form-label.required::after {
    content: '*';
    color: var(--rz-danger);
    margin-left: var(--space-1);
}

.form-hint {
    font-size: 0.75rem;
    color: var(--rz-text-tertiary-color);
    margin-top: var(--space-1);
}

/* Form Sections */
.form-section {
    background: var(--rz-base-background-color);
    border: 1px solid var(--rz-base-200);
    border-radius: var(--rz-border-radius-lg);
    padding: var(--space-6);
    margin-bottom: var(--space-6);
}

.form-section-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--rz-text-title-color);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-4);
    border-bottom: 1px solid var(--rz-base-100);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   AVATARS
═══════════════════════════════════════════════════════════════════════════════ */

.avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 0.8125rem;
    background: linear-gradient(135deg, var(--rz-primary) 0%, var(--rz-info) 100%);
    color: white;
    flex-shrink: 0;
}

.avatar-xs { width: 24px; height: 24px; font-size: 0.625rem; }
.avatar-sm { width: 32px; height: 32px; font-size: 0.75rem; }
.avatar-md { width: 40px; height: 40px; font-size: 0.875rem; }
.avatar-lg { width: 48px; height: 48px; font-size: 1rem; }
.avatar-xl { width: 64px; height: 64px; font-size: 1.25rem; }

.avatar-group {
    display: flex;
}

.avatar-group .avatar {
    margin-left: -8px;
    border: 2px solid var(--rz-base-background-color);
}

.avatar-group .avatar:first-child {
    margin-left: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   IMPERSONATION BAR - Corporate Violet (not Orange)
═══════════════════════════════════════════════════════════════════════════════ */

.impersonation-bar {
    background: linear-gradient(90deg, var(--dalatic-accent-600) 0%, var(--dalatic-accent-700) 100%);
    color: #FFFFFF;
    padding: var(--space-2) var(--space-6);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    font-size: 0.8125rem;
    font-weight: 500;
    position: sticky;
    top: 0;
    z-index: 1000;
}

.impersonation-bar button {
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid rgba(255, 255, 255, 0.3);
    color: #FFFFFF;
    padding: var(--space-1) var(--space-4);
    border-radius: var(--rz-border-radius-sm);
    cursor: pointer;
    font-weight: 500;
    font-size: 0.75rem;
    transition: all var(--rz-transition);
}

.impersonation-bar button:hover {
    background: rgba(255, 255, 255, 0.25);
    border-color: rgba(255, 255, 255, 0.5);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SKELETON LOADING
═══════════════════════════════════════════════════════════════════════════════ */

.skeleton {
    background: linear-gradient(
        90deg,
        var(--rz-base-200) 0%,
        var(--rz-base-100) 50%,
        var(--rz-base-200) 100%
    );
    background-size: 200% 100%;
    animation: skeleton-shimmer 1.5s ease-in-out infinite;
    border-radius: var(--rz-border-radius-sm);
}

@keyframes skeleton-shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.skeleton-text {
    height: 1em;
    margin-bottom: var(--space-2);
}

.skeleton-text:last-child {
    width: 60%;
}

.skeleton-avatar {
    border-radius: 50%;
}

.skeleton-card {
    height: 200px;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   EMPTY STATES
═══════════════════════════════════════════════════════════════════════════════ */

.empty-state {
    text-align: center;
    padding: var(--space-12) var(--space-8);
}

.empty-state-icon {
    width: 64px;
    height: 64px;
    margin: 0 auto var(--space-5);
    background: var(--rz-base-100);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--rz-base-400);
}

.empty-state-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--rz-text-title-color);
    margin-bottom: var(--space-2);
}

.empty-state-description {
    font-size: 0.875rem;
    color: var(--rz-text-secondary-color);
    max-width: 400px;
    margin: 0 auto var(--space-6);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   PROGRESS BARS
═══════════════════════════════════════════════════════════════════════════════ */

.rz-progressbar {
    background: var(--rz-base-200) !important;
    border-radius: 9999px !important;
    overflow: hidden;
    height: 8px !important;
}

.rz-progressbar-value {
    background: linear-gradient(90deg, var(--rz-primary) 0%, var(--rz-info) 100%) !important;
    border-radius: 9999px !important;
    transition: width var(--rz-transition-slow);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   TABS
═══════════════════════════════════════════════════════════════════════════════ */

.rz-tabs {
    border-bottom: 1px solid var(--rz-base-200);
}

.rz-tabview-nav-link {
    padding: var(--space-4) var(--space-5) !important;
    font-weight: 500 !important;
    color: var(--rz-text-secondary-color) !important;
    border-bottom: 2px solid transparent !important;
    transition: all var(--rz-transition) !important;
}

.rz-tabview-nav-link:hover {
    color: var(--rz-text-color) !important;
}

.rz-tabview-nav-link.rz-state-active {
    color: var(--rz-primary) !important;
    border-bottom-color: var(--rz-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   ALERTS / NOTIFICATIONS
═══════════════════════════════════════════════════════════════════════════════ */

.alert {
    padding: var(--space-4) var(--space-5);
    border-radius: var(--rz-border-radius);
    display: flex;
    align-items: flex-start;
    gap: var(--space-3);
    font-size: 0.875rem;
}

.alert-info {
    background: var(--rz-base-50);
    border: 1px solid var(--rz-base-200);
    color: var(--rz-text-secondary-color);
}

.alert-success {
    background: var(--rz-success-lighter);
    border: 1px solid rgba(5, 150, 105, 0.15);
    color: var(--rz-success-dark);
}

.alert-warning {
    background: var(--rz-base-50);
    border: 1px solid var(--rz-base-300);
    color: var(--rz-text-secondary-color);
}

.alert-danger {
    background: var(--rz-danger-lighter);
    border: 1px solid rgba(220, 38, 38, 0.15);
    color: var(--rz-danger-dark);
}

/* Radzen Alert component override - corporate minimal style */
.rz-alert {
    background: var(--rz-base-50) !important;
    border: 1px solid var(--rz-base-200) !important;
    color: var(--rz-text-secondary-color) !important;
    border-radius: var(--rz-border-radius) !important;
}

.rz-alert.rz-warning {
    background: var(--rz-base-50) !important;
    border: 1px solid var(--rz-base-300) !important;
    color: var(--rz-text-secondary-color) !important;
}

.rz-alert.rz-info {
    background: var(--rz-base-50) !important;
    border: 1px solid var(--rz-base-200) !important;
    color: var(--rz-text-secondary-color) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SCROLLBAR - Minimal
═══════════════════════════════════════════════════════════════════════════════ */

::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: var(--rz-base-300);
    border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--rz-base-400);
}

/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--rz-base-300) transparent;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   FOCUS STATES
═══════════════════════════════════════════════════════════════════════════════ */

:focus-visible {
    outline: 2px solid var(--rz-primary);
    outline-offset: 2px;
}

.rz-button:focus-visible {
    box-shadow: var(--rz-shadow-glow);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   UTILITY CLASSES
═══════════════════════════════════════════════════════════════════════════════ */

.text-title { color: var(--rz-text-title-color) !important; }
.text-primary { color: var(--rz-text-color) !important; }
.text-secondary { color: var(--rz-text-secondary-color) !important; }
.text-muted { color: var(--rz-text-tertiary-color) !important; }
.text-accent { color: var(--rz-primary) !important; }

.bg-surface { background-color: var(--rz-base-background-color) !important; }
.bg-muted { background-color: var(--rz-base-50) !important; }

.border-subtle { border-color: var(--rz-base-200) !important; }

.rounded-sm { border-radius: var(--rz-border-radius-sm) !important; }
.rounded { border-radius: var(--rz-border-radius) !important; }
.rounded-lg { border-radius: var(--rz-border-radius-lg) !important; }
.rounded-xl { border-radius: var(--rz-border-radius-xl) !important; }
.rounded-full { border-radius: 9999px !important; }

.shadow-xs { box-shadow: var(--rz-shadow-xs) !important; }
.shadow-sm { box-shadow: var(--rz-shadow-1) !important; }
.shadow { box-shadow: var(--rz-shadow-4) !important; }
.shadow-lg { box-shadow: var(--rz-shadow-lg) !important; }

/* ═══════════════════════════════════════════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════════════════════════════════════════ */

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes slideInRight {
    from { opacity: 0; transform: translateX(16px); }
    to { opacity: 1; transform: translateX(0); }
}

@keyframes scaleIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

.animate-fade-in {
    animation: fadeIn 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-slide-in {
    animation: slideInRight 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.animate-scale-in {
    animation: scaleIn 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LOADING STATES
═══════════════════════════════════════════════════════════════════════════════ */

.loading-container,
.chat-loader {
    display: flex;
    justify-content: center;
    align-items: center;
}

.loading-container {
    height: 85vh;
}

@keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}

.fade-in {
    animation: fadeIn 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.slide-in {
    animation: slideInRight 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.pulse {
    animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   CORPORATE ALIASES (Compatibility Layer)
═══════════════════════════════════════════════════════════════════════════════ */

:root {
    --corp-primary: var(--rz-primary);
    --corp-primary-light: var(--rz-primary-light);
    --corp-primary-dark: var(--rz-primary-dark);
    --corp-accent: var(--rz-info);
    --corp-bg-main: var(--rz-base-100);
    --corp-bg-surface: var(--rz-base-background-color);
    --corp-bg-card: var(--rz-base-background-color);
    --corp-border: var(--rz-base-300);
    --corp-border-light: var(--rz-base-200);
    --corp-text-primary: var(--rz-text-title-color);
    --corp-text-secondary: var(--rz-text-secondary-color);
    --corp-text-muted: var(--rz-text-tertiary-color);
    --corp-success: var(--rz-success);
    --corp-success-bg: var(--rz-success-lighter);
    --corp-warning: var(--rz-warning);
    --corp-warning-bg: var(--rz-warning-lighter);
    --corp-danger: var(--rz-danger);
    --corp-danger-bg: var(--rz-danger-lighter);
    --corp-info: var(--rz-info);
    --corp-info-bg: var(--rz-info-lighter);
}

.border-corp { border: var(--rz-border-normal) !important; }

/* ═══════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════════════════════════ */

@media (max-width: 768px) {
    .page-title {
        font-size: 1.25rem;
    }
    
    .stat-card-value {
        font-size: 1.375rem;
    }
    
    .kanban-column {
        flex: 0 0 280px;
    }
}
/* ═══════════════════════════════════════════════════════════════════════════════
   DALATIC PORTAL - THEME OVERRIDES
   
   Este archivo DEBE cargarse DESPUÉS de los estilos de Radzen Material.
   Proporciona overrides con !important para garantizar que el theme corporativo
   siempre gane sobre Radzen Material.
   
   REGLA: Si Radzen Material compite, pierde.
═══════════════════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════════
   BUTTONS - Force corporate colors over Radzen Material
═══════════════════════════════════════════════════════════════════════════════ */

/* Primary Button - Filled variants only (exclude text/outlined/flat) */
.rz-button.rz-primary:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-primary.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-primary.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-primary.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-primary.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-primary.rz-shade-darker:not(.rz-variant-text) {
    background-color: var(--rz-primary) !important;
    color: var(--rz-on-primary) !important;
    border-color: var(--rz-primary) !important;
}

.rz-button.rz-primary:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-primary.rz-shade-default:not(.rz-variant-text):hover:not(:disabled) {
    background-color: var(--rz-primary-dark) !important;
    border-color: var(--rz-primary-dark) !important;
}

.rz-button.rz-primary:focus:not(:disabled),
.rz-button.rz-primary:active:not(:disabled) {
    background-color: var(--rz-primary-darker) !important;
    border-color: var(--rz-primary-darker) !important;
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.2) !important;
}

/* Info Button - Filled variants only (exclude text/outlined/flat) */
.rz-button.rz-info:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-info.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-info.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-info.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-info.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-info.rz-shade-darker:not(.rz-variant-text) {
    background-color: var(--rz-info) !important;
    color: var(--rz-on-info) !important;
    border-color: var(--rz-info) !important;
}

.rz-button.rz-info:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-info.rz-shade-default:not(.rz-variant-text):hover:not(:disabled) {
    background-color: var(--rz-info-dark) !important;
    border-color: var(--rz-info-dark) !important;
}

.rz-button.rz-info:focus:not(:disabled),
.rz-button.rz-info:active:not(:disabled) {
    background-color: var(--rz-info-darker) !important;
    border-color: var(--rz-info-darker) !important;
    box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.2) !important;
}

/* Success Button - Filled variants only (exclude text/outlined/flat) */
.rz-button.rz-success:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-success.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-success.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-success.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-success.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-success.rz-shade-darker:not(.rz-variant-text) {
    background-color: var(--rz-success) !important;
    color: var(--rz-on-success) !important;
    border-color: var(--rz-success) !important;
}

.rz-button.rz-success:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-success.rz-shade-default:not(.rz-variant-text):hover:not(:disabled) {
    background-color: var(--rz-success-dark) !important;
    border-color: var(--rz-success-dark) !important;
}

/* Warning Button - Filled variants only (exclude text/outlined/flat) */
.rz-button.rz-warning:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-warning.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-warning.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-warning.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-warning.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-warning.rz-shade-darker:not(.rz-variant-text) {
    background-color: var(--rz-warning) !important;
    color: var(--rz-on-warning) !important;
    border-color: var(--rz-warning) !important;
}

.rz-button.rz-warning:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-warning.rz-shade-default:not(.rz-variant-text):hover:not(:disabled) {
    background-color: var(--rz-warning-dark) !important;
    border-color: var(--rz-warning-dark) !important;
}

/* Danger Button - Filled variants only (exclude text/outlined/flat) */
.rz-button.rz-danger:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-danger.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-danger.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-danger.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-danger.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-danger.rz-shade-darker:not(.rz-variant-text) {
    background-color: var(--rz-danger) !important;
    color: var(--rz-on-danger) !important;
    border-color: var(--rz-danger) !important;
}

.rz-button.rz-danger:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-danger.rz-shade-default:not(.rz-variant-text):hover:not(:disabled) {
    background-color: var(--rz-danger-dark) !important;
    border-color: var(--rz-danger-dark) !important;
}

/* Secondary/Light Button - Filled variants only (exclude text/outlined/flat) */
.rz-button.rz-secondary:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-light:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat),
.rz-button.rz-secondary.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-secondary.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-secondary.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-secondary.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-secondary.rz-shade-darker:not(.rz-variant-text),
.rz-button.rz-light.rz-shade-default:not(.rz-variant-text),
.rz-button.rz-light.rz-shade-light:not(.rz-variant-text),
.rz-button.rz-light.rz-shade-lighter:not(.rz-variant-text),
.rz-button.rz-light.rz-shade-dark:not(.rz-variant-text),
.rz-button.rz-light.rz-shade-darker:not(.rz-variant-text) {
    background-color: var(--rz-base-100) !important;
    color: var(--rz-text-color) !important;
    border-color: var(--rz-base-300) !important;
}

.rz-button.rz-secondary:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-light:not(.rz-variant-text):not(.rz-variant-outlined):not(.rz-variant-flat):hover:not(:disabled),
.rz-button.rz-secondary.rz-shade-default:not(.rz-variant-text):hover:not(:disabled),
.rz-button.rz-light.rz-shade-default:not(.rz-variant-text):hover:not(:disabled) {
    background-color: var(--rz-base-200) !important;
    border-color: var(--rz-base-400) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   BADGES - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-badge.rz-primary,
.rz-badge.rz-shade-default.rz-primary {
    background-color: var(--rz-primary) !important;
    color: var(--rz-on-primary) !important;
}

.rz-badge.rz-info,
.rz-badge.rz-shade-default.rz-info {
    background-color: var(--rz-info) !important;
    color: var(--rz-on-info) !important;
}

.rz-badge.rz-success,
.rz-badge.rz-shade-default.rz-success {
    background-color: var(--rz-success) !important;
    color: var(--rz-on-success) !important;
}

.rz-badge.rz-warning,
.rz-badge.rz-shade-default.rz-warning {
    background-color: var(--rz-warning) !important;
    color: var(--rz-on-warning) !important;
}

.rz-badge.rz-danger,
.rz-badge.rz-shade-default.rz-danger {
    background-color: var(--rz-danger) !important;
    color: var(--rz-on-danger) !important;
}

.rz-badge.rz-light,
.rz-badge.rz-shade-default.rz-light {
    background-color: var(--rz-base-100) !important;
    color: var(--rz-text-color) !important;
}

/* Light badge with Lighter shade - ensure text contrast */
.rz-badge.rz-shade-lighter.rz-light {
    background-color: var(--rz-base-200) !important;
    color: var(--rz-text-color) !important;
}

/* Lighter shade badges */
.rz-badge.rz-shade-lighter.rz-primary {
    background-color: var(--rz-primary-lighter) !important;
    color: var(--rz-primary) !important;
}

.rz-badge.rz-shade-lighter.rz-info {
    background-color: var(--rz-info-lighter) !important;
    color: var(--rz-info) !important;
}

.rz-badge.rz-shade-lighter.rz-success {
    background-color: var(--rz-success-lighter) !important;
    color: var(--rz-success) !important;
}

.rz-badge.rz-shade-lighter.rz-warning {
    background-color: var(--rz-warning-lighter) !important;
    color: var(--rz-warning) !important;
}

.rz-badge.rz-shade-lighter.rz-danger {
    background-color: var(--rz-danger-lighter) !important;
    color: var(--rz-danger) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   ALERTS - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

/* Default shade alerts */
.rz-alert.rz-info,
.rz-alert.rz-shade-default.rz-info {
    background-color: var(--rz-info-lighter) !important;
    border-color: var(--rz-info) !important;
    color: var(--rz-info-darker) !important;
}

.rz-alert.rz-info .rz-alert-icon {
    color: var(--rz-info) !important;
}

.rz-alert.rz-primary,
.rz-alert.rz-shade-default.rz-primary {
    background-color: var(--rz-primary-lighter) !important;
    border-color: var(--rz-primary) !important;
    color: var(--rz-primary-darker) !important;
}

.rz-alert.rz-success,
.rz-alert.rz-shade-default.rz-success {
    background-color: var(--rz-success-lighter) !important;
    border-color: var(--rz-success) !important;
    color: var(--rz-success-darker) !important;
}

.rz-alert.rz-warning,
.rz-alert.rz-shade-default.rz-warning {
    background-color: var(--rz-warning-lighter) !important;
    border-color: var(--rz-warning) !important;
    color: var(--rz-warning-darker) !important;
}

.rz-alert.rz-danger,
.rz-alert.rz-shade-default.rz-danger {
    background-color: var(--rz-danger-lighter) !important;
    border-color: var(--rz-danger) !important;
    color: var(--rz-danger-darker) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   ALERTS - Shade Lighter (CRITICAL: Force high contrast text)
   El Shade.Lighter de Radzen usa fondos muy claros con texto del mismo tono
   lo que resulta en bajo contraste. Forzamos texto oscuro para legibilidad.
═══════════════════════════════════════════════════════════════════════════════ */

.rz-alert.rz-shade-lighter.rz-info {
    background-color: var(--rz-info-lighter) !important;
    border-color: var(--rz-info-light) !important;
    color: var(--rz-info-darker) !important;
}

.rz-alert.rz-shade-lighter.rz-info .rz-alert-icon {
    color: var(--rz-info-dark) !important;
}

.rz-alert.rz-shade-lighter.rz-primary {
    background-color: var(--rz-primary-lighter) !important;
    border-color: var(--rz-primary-light) !important;
    color: var(--rz-primary-darker) !important;
}

.rz-alert.rz-shade-lighter.rz-primary .rz-alert-icon {
    color: var(--rz-primary-dark) !important;
}

.rz-alert.rz-shade-lighter.rz-success {
    background-color: var(--rz-success-lighter) !important;
    border-color: var(--rz-success-light) !important;
    color: var(--rz-success-darker) !important;
}

.rz-alert.rz-shade-lighter.rz-success .rz-alert-icon {
    color: var(--rz-success-dark) !important;
}

.rz-alert.rz-shade-lighter.rz-warning {
    background-color: var(--rz-warning-lighter) !important;
    border-color: var(--rz-warning-light) !important;
    color: var(--rz-warning-darker) !important;
}

.rz-alert.rz-shade-lighter.rz-warning .rz-alert-icon {
    color: var(--rz-warning-dark) !important;
}

.rz-alert.rz-shade-lighter.rz-danger {
    background-color: var(--rz-danger-lighter) !important;
    border-color: var(--rz-danger-light) !important;
    color: var(--rz-danger-darker) !important;
}

.rz-alert.rz-shade-lighter.rz-danger .rz-alert-icon {
    color: var(--rz-danger-dark) !important;
}

/* Ensure all text inside Shade.Lighter alerts has proper contrast */
.rz-alert.rz-shade-lighter strong,
.rz-alert.rz-shade-lighter small,
.rz-alert.rz-shade-lighter span,
.rz-alert.rz-shade-lighter p {
    color: inherit !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   PROGRESS BARS - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-progressbar-value.rz-primary,
.rz-progressbar-circular-value.rz-primary {
    background-color: var(--rz-primary) !important;
    stroke: var(--rz-primary) !important;
}

.rz-progressbar-value.rz-info,
.rz-progressbar-circular-value.rz-info {
    background-color: var(--rz-info) !important;
    stroke: var(--rz-info) !important;
}

.rz-progressbar-value.rz-success,
.rz-progressbar-circular-value.rz-success {
    background-color: var(--rz-success) !important;
    stroke: var(--rz-success) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   INPUTS - Force focus colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-textbox:focus,
.rz-textarea:focus,
.rz-dropdown:focus,
.rz-autocomplete.rz-state-focused,
.rz-textbox:focus-within,
.rz-inputtext:focus {
    border-color: var(--rz-primary) !important;
    box-shadow: 0 0 0 2px var(--rz-primary-lighter) !important;
    outline: none !important;
}

/* Remove double border on search inputs */
.rz-autocomplete .rz-inputtext,
.rz-dropdown .rz-inputtext,
.search-input-wrapper .rz-textbox,
.rz-textbox-box .rz-inputtext,
.corp-search .rz-textbox,
.corp-search .rz-inputtext,
.corp-search input,
.filter-bar .corp-search .rz-textbox {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
    background: transparent !important;
}

.rz-autocomplete,
.rz-dropdown,
.search-input-wrapper,
.rz-textbox-box {
    border: 1px solid var(--rz-base-300) !important;
    border-radius: var(--rz-border-radius) !important;
}

.rz-autocomplete:focus-within,
.rz-dropdown:focus-within,
.search-input-wrapper:focus-within,
.rz-textbox-box:focus-within {
    border-color: var(--rz-primary) !important;
    box-shadow: 0 0 0 2px var(--rz-primary-lighter) !important;
}

/* Corp search wrapper - inner input has no border */
.corp-search .rz-textbox,
.corp-search .rz-textbox input {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    background: transparent !important;
    padding: 0.5rem 0 !important;
}

.corp-search:focus-within .rz-textbox,
.corp-search:focus-within .rz-textbox input {
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SWITCHES/TOGGLES - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-switch.rz-switch-checked .rz-switch-circle,
.rz-switch-checked .rz-switch-circle {
    background-color: var(--rz-primary) !important;
}

.rz-switch.rz-switch-checked,
.rz-switch-checked {
    background-color: var(--rz-primary-lighter) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LINKS - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-link,
a.rz-link {
    color: var(--rz-primary) !important;
}

.rz-link:hover,
a.rz-link:hover {
    color: var(--rz-primary-dark) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   TABS - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-tabview-nav .rz-tabview-selected,
.rz-tabview-nav .rz-tabview-nav-link.rz-state-active,
.rz-tabs .rz-tab.rz-state-active {
    color: var(--rz-primary) !important;
    border-bottom-color: var(--rz-primary) !important;
}

.rz-tabview-ink-bar,
.rz-tabs-ink-bar {
    background-color: var(--rz-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   MENU ITEMS - Force corporate active state
═══════════════════════════════════════════════════════════════════════════════ */

.rz-navigation-item-active,
.rz-panelmenu-header.rz-state-active,
.rz-menu-item.rz-state-active {
    background-color: var(--rz-primary-lighter) !important;
    color: var(--rz-primary) !important;
}

.rz-navigation-item-active .rz-navigation-item-icon,
.rz-panelmenu-header.rz-state-active .rz-menuitem-icon {
    color: var(--rz-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   CHIPS/TAGS - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-chip.rz-primary {
    background-color: var(--rz-primary-lighter) !important;
    color: var(--rz-primary) !important;
}

.rz-chip.rz-info {
    background-color: var(--rz-info-lighter) !important;
    color: var(--rz-info) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   DIALOG OVERLAY - Ensure proper backdrop
═══════════════════════════════════════════════════════════════════════════════ */

.rz-dialog-mask {
    background-color: rgba(15, 23, 42, 0.5) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   TOOLTIP - Corporate styling
═══════════════════════════════════════════════════════════════════════════════ */

.rz-tooltip {
    background-color: var(--rz-base-900) !important;
    color: var(--rz-base-50) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   CHECKBOX/RADIO - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-checkbox-box.rz-state-active,
.rz-checkbox.rz-state-checked .rz-checkbox-box,
.rz-radiobutton-box.rz-state-active {
    background-color: var(--rz-primary) !important;
    border-color: var(--rz-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   DATEPICKER/CALENDAR - Force corporate colors  
═══════════════════════════════════════════════════════════════════════════════ */

.rz-datepicker-calendar .rz-state-active,
.rz-calendar .rz-state-active,
.rz-calendar-day.rz-state-active {
    background-color: var(--rz-primary) !important;
    color: var(--rz-on-primary) !important;
}

.rz-datepicker-today,
.rz-calendar-today {
    color: var(--rz-primary) !important;
    font-weight: 600 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   SPLITBUTTON - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-splitbutton .rz-button.rz-primary,
.rz-splitbutton.rz-primary .rz-button {
    background-color: var(--rz-primary) !important;
    color: var(--rz-on-primary) !important;
    border-color: var(--rz-primary) !important;
}

.rz-splitbutton .rz-button.rz-secondary,
.rz-splitbutton.rz-secondary .rz-button {
    background-color: var(--rz-base-100) !important;
    color: var(--rz-text-color) !important;
    border-color: var(--rz-base-300) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   DATAGRID - Force corporate header and selection colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-grid-table .rz-state-highlight,
.rz-data-grid-row.rz-state-highlight {
    background-color: var(--rz-primary-lighter) !important;
}

.rz-sortable-column.rz-state-sorted {
    color: var(--rz-primary) !important;
}

.rz-paginator .rz-state-active {
    background-color: var(--rz-primary) !important;
    color: var(--rz-on-primary) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   NOTIFICATION/TOAST - Force corporate colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-notification.rz-info {
    border-left-color: var(--rz-info) !important;
}

.rz-notification.rz-info .rz-notification-icon {
    color: var(--rz-info) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   CARD HOVER STATES - Force consistent behavior
═══════════════════════════════════════════════════════════════════════════════ */

.rz-card:hover {
    border-color: var(--rz-base-300) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   OUTLINE BUTTONS - Force corporate outline colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-button.rz-variant-outlined.rz-primary {
    background-color: transparent !important;
    color: var(--rz-primary) !important;
    border-color: var(--rz-primary) !important;
}

.rz-button.rz-variant-outlined.rz-primary:hover:not(:disabled) {
    background-color: var(--rz-primary-lighter) !important;
}

.rz-button.rz-variant-outlined.rz-info {
    background-color: transparent !important;
    color: var(--rz-info) !important;
    border-color: var(--rz-info) !important;
}

.rz-button.rz-variant-outlined.rz-info:hover:not(:disabled) {
    background-color: var(--rz-info-lighter) !important;
}

.rz-button.rz-variant-outlined.rz-success {
    background-color: transparent !important;
    color: var(--rz-success) !important;
    border-color: var(--rz-success) !important;
}

.rz-button.rz-variant-outlined.rz-danger {
    background-color: transparent !important;
    color: var(--rz-danger) !important;
    border-color: var(--rz-danger) !important;
}

.rz-button.rz-variant-outlined.rz-danger:hover:not(:disabled) {
    background-color: var(--rz-danger-lighter) !important;
}

.rz-button.rz-variant-outlined.rz-warning {
    background-color: transparent !important;
    color: var(--rz-warning) !important;
    border-color: var(--rz-warning) !important;
}

.rz-button.rz-variant-outlined.rz-warning:hover:not(:disabled) {
    background-color: var(--rz-warning-lighter) !important;
}

.rz-button.rz-variant-outlined.rz-success:hover:not(:disabled) {
    background-color: var(--rz-success-lighter) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   TEXT BUTTONS - Force corporate text colors
═══════════════════════════════════════════════════════════════════════════════ */

.rz-button.rz-variant-text.rz-primary {
    color: var(--rz-primary) !important;
}

.rz-button.rz-variant-text.rz-primary:hover:not(:disabled) {
    background-color: var(--rz-primary-lighter) !important;
}

.rz-button.rz-variant-text.rz-info {
    color: var(--rz-info) !important;
}

.rz-button.rz-variant-text.rz-info:hover:not(:disabled) {
    background-color: var(--rz-info-lighter) !important;
}

.rz-button.rz-variant-text.rz-danger {
    color: var(--rz-danger) !important;
}

.rz-button.rz-variant-text.rz-danger:hover:not(:disabled) {
    background-color: var(--rz-danger-lighter) !important;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   KNOWLEDGE BASE MENU - Confluence-style navigation
═══════════════════════════════════════════════════════════════════════════════ */

/* Menu item container with hover actions */
.kb-menu-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding-right: 0.25rem;
}

.kb-menu-title {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Hide actions by default, show on hover */
.kb-menu-actions {
    opacity: 0;
    transition: opacity 0.15s ease;
    min-width: 24px;
    height: 24px;
    padding: 0 !important;
}

.kb-menu-item:hover .kb-menu-actions,
.kb-menu-actions:focus {
    opacity: 1;
}

/* Context menu styling */
.rz-context-menu .rz-menu-item[data-value="delete"] {
    color: var(--rz-danger);
}
