/* ========================================
   GeoQR Theme System
   Dark Pro & Soft Light Pro Themes
   True Glassmorphism with WCAG AA+ Contrast
   ======================================== */

/* ========================================
   Universal Properties
   ======================================== */
:root {
    /* Glassmorphism */
    --glass-blur: blur(20px);
    --focus-ring: 0 0 0 3px rgba(99, 102, 241, 0.5);

    /* Spacing (theme-independent) */
    --space-1: 0.25rem;
    --space-2: 0.5rem;
    --space-3: 0.75rem;
    --space-4: 1rem;
    --space-5: 1.25rem;
    --space-6: 1.5rem;
    --space-8: 2rem;
    --space-10: 2.5rem;
    --space-12: 3rem;
    --space-16: 4rem;

    /* Border Radius */
    --radius-sm: 0.5rem;
    --radius-md: 0.75rem;
    --radius-lg: 1rem;
    --radius-xl: 1.25rem;
    --radius-2xl: 1.5rem;
    --radius-full: 9999px;

    /* Transitions */
    --transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-normal: 250ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-slow: 400ms cubic-bezier(0.4, 0, 0.2, 1);
    --transition-bounce: 500ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ========================================
   Dark Pro Theme (Default)
   Premium dark theme for faculty/admin
   Optimized for long sessions (~15:1 contrast)
   ======================================== */
:root,
:root[data-theme="dark-pro"] {
    /* Background Layers */
    --bg-dark: #020617;
    --bg-primary: #0b1220;
    --bg-secondary: #111827;
    --bg-tertiary: #1e293b;

    /* Glass System */
    --glass-bg: rgba(30, 41, 59, 0.75);
    --glass-border: rgba(148, 163, 184, 0.25);
    --glass-shadow: 0 16px 40px rgba(0, 0, 0, 0.6);

    /* Text Colors */
    --text-primary: #f8fafc;
    --text-secondary: #cbd5f5;
    --text-muted: #94a3b8;
    --text-disabled: #64748b;

    /* Primary Colors */
    --primary-50: #eef2ff;
    --primary-100: #e0e7ff;
    --primary-200: #c7d2fe;
    --primary-300: #a5b4fc;
    --primary-400: #818cf8;
    --primary-500: #6366f1;
    --primary-600: #4f46e5;
    --primary-700: #4338ca;

    /* Accent Colors */
    --accent-purple: #a855f7;
    --accent-pink: #ec4899;
    --accent-cyan: #06b6d4;

    /* Status Colors */
    --success: #22c55e;
    --success-light: #34d399;
    --warning: #facc15;
    --warning-light: #fde047;
    --danger: #ef4444;
    --danger-light: #f87171;
    --info: #38bdf8;

    /* Borders */
    --border-color: rgba(148, 163, 184, 0.2);
    --border-light: rgba(148, 163, 184, 0.12);

    /* Shadows */
    --shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.4);
    --shadow-md: 0 8px 24px rgba(0, 0, 0, 0.5);
    --shadow-lg: 0 20px 50px rgba(0, 0, 0, 0.7);
    --shadow-xl: 0 25px 60px rgba(0, 0, 0, 0.8);
    --shadow-glow: 0 0 40px rgba(99, 102, 241, 0.35);
    --shadow-glow-success: 0 0 40px rgba(34, 197, 94, 0.35);

    /* Card Shadows */
    --card-shadow: 0 4px 20px rgba(0, 0, 0, 0.25), 0 0 0 1px var(--glass-border);
    --card-shadow-hover: 0 16px 48px rgba(0, 0, 0, 0.35), 0 0 0 1px var(--glass-border);

    /* Gradients */
    --gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
    --gradient-success: linear-gradient(135deg, #22c55e 0%, #06b6d4 100%);
    --gradient-danger: linear-gradient(135deg, #ef4444 0%, #ec4899 100%);
    --gradient-dark: linear-gradient(180deg, #0f172a 0%, #020617 100%);

    /* Background Animation Colors */
    --orb-1: rgba(99, 102, 241, 0.3);
    --orb-2: rgba(168, 85, 247, 0.2);
    --orb-3: rgba(6, 182, 212, 0.2);
    --grid-line: rgba(99, 102, 241, 0.03);

    /* Scrollbar */
    --scrollbar-track: var(--bg-secondary);
    --scrollbar-thumb: var(--primary-500);
}

/* ========================================
   Soft Light Pro Theme
   Fresh, modern academic theme
   Soft tinted whites - NO GREY backgrounds
   ======================================== */
:root[data-theme="soft-light-pro"] {
    /* Background Layers - Soft Blue-White (NO GREY) */
    --bg-dark: #f3f6fd;
    --bg-primary: #eef2ff;
    --bg-secondary: #f8faff;
    --bg-tertiary: #edf1f7;

    /* Glass System - White Cards with Indigo Tint */
    --glass-bg: rgba(255, 255, 255, 0.95);
    --glass-border: rgba(99, 102, 241, 0.18);
    --glass-shadow: 0 12px 30px rgba(79, 70, 229, 0.12);

    /* Text Colors - High Contrast on Light */
    --text-primary: #0f172a;
    --text-secondary: #334155;
    --text-muted: #64748b;
    --text-disabled: #94a3b8;

    /* Primary Colors - Indigo Accent */
    --primary-50: #eef2ff;
    --primary-100: #e0e7ff;
    --primary-200: #c7d2fe;
    --primary-300: #a5b4fc;
    --primary-400: #6366f1;
    --primary-500: #4f46e5;
    --primary-600: #4338ca;
    --primary-700: #3730a3;

    /* Accent Colors */
    --accent-purple: #7c3aed;
    --accent-pink: #db2777;
    --accent-cyan: #0891b2;

    /* Status Colors */
    --success: #16a34a;
    --success-light: #22c55e;
    --warning: #f59e0b;
    --warning-light: #fbbf24;
    --danger: #dc2626;
    --danger-light: #ef4444;
    --info: #0284c7;

    /* Borders - Subtle Indigo Tint */
    --border-color: rgba(99, 102, 241, 0.15);
    --border-light: rgba(99, 102, 241, 0.08);

    /* Shadows - Indigo Tinted (NOT Grey) */
    --shadow-sm: 0 2px 8px rgba(79, 70, 229, 0.08);
    --shadow-md: 0 8px 24px rgba(79, 70, 229, 0.12);
    --shadow-lg: 0 16px 40px rgba(79, 70, 229, 0.15);
    --shadow-xl: 0 24px 60px rgba(79, 70, 229, 0.18);
    --shadow-glow: 0 0 40px rgba(79, 70, 229, 0.25);
    --shadow-glow-success: 0 0 30px rgba(22, 163, 74, 0.25);

    /* Card Shadows - Premium White Cards */
    --card-shadow: 0 4px 20px rgba(79, 70, 229, 0.1), 0 0 0 1px rgba(99, 102, 241, 0.12);
    --card-shadow-hover: 0 12px 36px rgba(79, 70, 229, 0.18), 0 0 0 1px rgba(99, 102, 241, 0.2);

    /* Gradients - Clean Light Gradients */
    --gradient-primary: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%);
    --gradient-success: linear-gradient(135deg, #16a34a 0%, #0891b2 100%);
    --gradient-danger: linear-gradient(135deg, #dc2626 0%, #db2777 100%);
    --gradient-dark: linear-gradient(180deg, #eef2ff 0%, #f3f6fd 100%);
    --gradient-card: linear-gradient(180deg, #ffffff 0%, #f8faff 100%);

    /* Sidebar - Soft Indigo Gradient */
    --sidebar-bg: linear-gradient(180deg, #eef2ff 0%, #e0e7ff 100%);
    --sidebar-active: rgba(79, 70, 229, 0.15);
    --sidebar-hover: rgba(79, 70, 229, 0.08);

    /* Table Styling */
    --table-header-bg: #eef2ff;
    --table-row-hover: rgba(79, 70, 229, 0.06);
    --table-border: rgba(99, 102, 241, 0.1);

    /* Button Secondary */
    --btn-secondary-bg: #eef2ff;
    --btn-secondary-text: #4338ca;
    --btn-secondary-border: rgba(79, 70, 229, 0.2);

    /* Empty State */
    --empty-bg: linear-gradient(180deg, #ffffff 0%, #f1f5ff 100%);
    --empty-border: rgba(79, 70, 229, 0.3);

    /* Input Styling */
    --input-bg: #ffffff;
    --input-border: rgba(99, 102, 241, 0.2);
    --input-focus-border: #4f46e5;
    --input-focus-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15);

    /* Background Animation Colors */
    --orb-1: rgba(99, 102, 241, 0.12);
    --orb-2: rgba(124, 58, 237, 0.08);
    --orb-3: rgba(8, 145, 178, 0.08);
    --grid-line: rgba(99, 102, 241, 0.04);

    /* Scrollbar */
    --scrollbar-track: #f1f5f9;
    --scrollbar-thumb: var(--primary-500);
}

/* ========================================
   Theme Transition
   Smooth transition when switching themes
   ======================================== */
html {
    transition: background-color 0.3s ease, color 0.3s ease;
}

html.theme-transitioning,
html.theme-transitioning *,
html.theme-transitioning *::before,
html.theme-transitioning *::after {
    transition: background-color 0.3s ease,
        color 0.3s ease,
        border-color 0.3s ease,
        box-shadow 0.3s ease !important;
}

/* ========================================
   Theme Toggle Button
   ======================================== */
.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-full);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all var(--transition-normal);
    box-shadow: var(--shadow-sm);
}

.theme-toggle:hover {
    background: var(--primary-500);
    color: white;
    border-color: var(--primary-500);
    transform: scale(1.05);
    box-shadow: var(--shadow-glow);
}

.theme-toggle:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring), var(--shadow-sm);
}

.theme-toggle svg {
    width: 22px;
    height: 22px;
    transition: transform var(--transition-normal);
}

.theme-toggle:hover svg {
    transform: rotate(15deg);
}

/* Icon visibility based on theme */
.theme-icon-sun {
    display: none;
}

.theme-icon-moon {
    display: block;
}

[data-theme="soft-light-pro"] .theme-icon-sun {
    display: block;
}

[data-theme="soft-light-pro"] .theme-icon-moon {
    display: none;
}

/* ========================================
   Universal Glassmorphism Enhancement
   Apply to all card-like elements
   ======================================== */
.glass-card,
.card,
.stat-card,
.table-container,
.modal-content,
.profile-card,
.settings-section,
.chart-container,
.breakdown-card,
.overview-card,
.device-info-card,
.login-card,
.feature-card,
.role-card,
.step-content,
.tech-item,
.cta-card {
    background: var(--glass-bg);
    backdrop-filter: var(--glass-blur);
    -webkit-backdrop-filter: var(--glass-blur);
    border: 1px solid var(--glass-border);
    box-shadow: var(--card-shadow);
    border-radius: 16px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.glass-card:hover,
.card:hover,
.stat-card:hover,
.feature-card:hover,
.role-card:hover,
.tech-item:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--card-shadow-hover);
}

/* Focus visible for accessibility */
:focus-visible {
    outline: none;
    box-shadow: var(--focus-ring), var(--shadow-md);
}

/* ========================================
   Mobile Optimizations
   ======================================== */
@media (max-width: 768px) {
    :root {
        --glass-blur: blur(16px);
    }

    .glass-card,
    .card,
    .stat-card,
    .feature-card,
    .role-card {
        border-radius: 12px;
    }

    .glass-card:hover,
    .card:hover,
    .stat-card:hover,
    .feature-card:hover,
    .role-card:hover {
        transform: translateY(-2px);
    }

    .theme-toggle {
        width: 40px;
        height: 40px;
    }

    .theme-toggle svg {
        width: 20px;
        height: 20px;
    }
}

/* ========================================
   Reduced Motion Support
   ======================================== */
@media (prefers-reduced-motion: reduce) {

    html.theme-transitioning,
    html.theme-transitioning *,
    html.theme-transitioning *::before,
    html.theme-transitioning *::after {
        transition: none !important;
    }

    .glass-card:hover,
    .card:hover,
    .stat-card:hover,
    .feature-card:hover,
    .role-card:hover,
    .tech-item:hover {
        transform: none;
    }

    .theme-toggle:hover svg {
        transform: none;
    }
}

/* ========================================
   Background Animation Theme Support
   ======================================== */
.bg-gradient {
    background:
        radial-gradient(ellipse at 20% 20%, var(--orb-1) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 80%, var(--orb-2) 0%, transparent 50%),
        radial-gradient(ellipse at 50% 50%, var(--orb-3) 0%, transparent 70%);
}

.bg-grid {
    background-image:
        linear-gradient(var(--grid-line) 1px, transparent 1px),
        linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
}

.orb-1 {
    background: var(--orb-1);
}

.orb-2 {
    background: var(--orb-2);
}

.orb-3 {
    background: var(--orb-3);
}

/* ========================================
   Scrollbar Theme Support
   ======================================== */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: var(--scrollbar-track);
    border-radius: var(--radius-full);
}

::-webkit-scrollbar-thumb {
    background: linear-gradient(135deg, var(--primary-500) 0%, var(--accent-purple) 100%);
    border-radius: var(--radius-full);
    border: 2px solid var(--scrollbar-track);
}

::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(135deg, var(--primary-400) 0%, var(--accent-purple) 100%);
}

::-webkit-scrollbar-corner {
    background: var(--scrollbar-track);
}

* {
    scrollbar-width: thin;
    scrollbar-color: var(--primary-500) var(--scrollbar-track);
}

/* ========================================
   Soft Light Pro - Component Overrides
   Premium white cards, no grey anywhere
   ======================================== */

/* Card backgrounds in light theme - white with gradient */
[data-theme="soft-light-pro"] .glass-card,
[data-theme="soft-light-pro"] .card,
[data-theme="soft-light-pro"] .stat-card,
[data-theme="soft-light-pro"] .table-container,
[data-theme="soft-light-pro"] .modal-content,
[data-theme="soft-light-pro"] .profile-card,
[data-theme="soft-light-pro"] .settings-section,
[data-theme="soft-light-pro"] .chart-container,
[data-theme="soft-light-pro"] .breakdown-card,
[data-theme="soft-light-pro"] .overview-card,
[data-theme="soft-light-pro"] .login-card,
[data-theme="soft-light-pro"] .feature-card,
[data-theme="soft-light-pro"] .role-card,
[data-theme="soft-light-pro"] .step-content,
[data-theme="soft-light-pro"] .tech-item,
[data-theme="soft-light-pro"] .cta-card,
[data-theme="soft-light-pro"] .session-card {
    background: #ffffff !important;
    border: 1px solid rgba(99, 102, 241, 0.1) !important;
    box-shadow: none !important;
}

[data-theme="soft-light-pro"] .glass-card:hover,
[data-theme="soft-light-pro"] .card:hover,
[data-theme="soft-light-pro"] .stat-card:hover,
[data-theme="soft-light-pro"] .feature-card:hover,
[data-theme="soft-light-pro"] .role-card:hover,
[data-theme="soft-light-pro"] .tech-item:hover {
    box-shadow: 0 12px 36px rgba(79, 70, 229, 0.18) !important;
}

/* Sidebar in light theme */
[data-theme="soft-light-pro"] .sidebar {
    background: linear-gradient(180deg, #eef2ff 0%, #e0e7ff 100%);
}

[data-theme="soft-light-pro"] .nav-item.active {
    background: rgba(79, 70, 229, 0.15);
    color: #4338ca;
}

[data-theme="soft-light-pro"] .nav-item:hover {
    background: rgba(79, 70, 229, 0.08);
}

/* Tables in light theme */
[data-theme="soft-light-pro"] .data-table thead,
[data-theme="soft-light-pro"] .table-header {
    background: #eef2ff;
}

[data-theme="soft-light-pro"] .data-table thead th {
    color: #334155;
    font-weight: 600;
    background: #eef2ff;
}

[data-theme="soft-light-pro"] .data-table tbody tr {
    background: transparent;
}

[data-theme="soft-light-pro"] .data-table tbody tr:hover {
    background: rgba(79, 70, 229, 0.06);
}

[data-theme="soft-light-pro"] .data-table td,
[data-theme="soft-light-pro"] .data-table th {
    border-color: rgba(99, 102, 241, 0.1);
}

/* KPI/Stat icons in light theme */
[data-theme="soft-light-pro"] .stat-icon {
    background: rgba(79, 70, 229, 0.12);
}

[data-theme="soft-light-pro"] .stat-icon.primary {
    background: rgba(99, 102, 241, 0.12);
    color: #4f46e5;
}

[data-theme="soft-light-pro"] .stat-icon.success {
    background: rgba(22, 163, 74, 0.12);
    color: #16a34a;
}

[data-theme="soft-light-pro"] .stat-icon.warning {
    background: rgba(245, 158, 11, 0.12);
    color: #f59e0b;
}

[data-theme="soft-light-pro"] .stat-icon.danger {
    background: rgba(220, 38, 38, 0.12);
    color: #dc2626;
}

/* Buttons in light theme */
[data-theme="soft-light-pro"] .btn-primary {
    background: linear-gradient(135deg, #4f46e5, #6366f1);
    color: #ffffff;
    box-shadow: 0 8px 24px rgba(79, 70, 229, 0.35);
}

[data-theme="soft-light-pro"] .btn-secondary,
[data-theme="soft-light-pro"] .btn-ghost {
    background: #eef2ff;
    color: #4338ca;
    border: 1px solid rgba(79, 70, 229, 0.2);
}

[data-theme="soft-light-pro"] .btn-secondary:hover,
[data-theme="soft-light-pro"] .btn-ghost:hover {
    background: rgba(79, 70, 229, 0.15);
    border-color: rgba(79, 70, 229, 0.3);
}

[data-theme="soft-light-pro"] .action-btn {
    background: #ffffff;
    color: #334155;
    border: 1px solid rgba(99, 102, 241, 0.15);
}

[data-theme="soft-light-pro"] .action-btn:hover {
    background: #eef2ff;
    border-color: rgba(99, 102, 241, 0.25);
}

[data-theme="soft-light-pro"] .action-btn.primary {
    background: linear-gradient(135deg, #4f46e5, #6366f1);
    color: #ffffff;
    border: none;
}

/* Empty states in light theme */
[data-theme="soft-light-pro"] .empty-state,
[data-theme="soft-light-pro"] .no-data {
    background: linear-gradient(180deg, #ffffff 0%, #f1f5ff 100%);
    border: 1px dashed rgba(79, 70, 229, 0.3);
    color: #475569;
}

/* Inputs in light theme - COMPREHENSIVE */
[data-theme="soft-light-pro"] input,
[data-theme="soft-light-pro"] select,
[data-theme="soft-light-pro"] textarea,
[data-theme="soft-light-pro"] .form-input,
[data-theme="soft-light-pro"] .form-select,
[data-theme="soft-light-pro"] .filter-select,
[data-theme="soft-light-pro"] .form-group input,
[data-theme="soft-light-pro"] .input-wrapper input,
[data-theme="soft-light-pro"] .otp-input,
[data-theme="soft-light-pro"] .search-input input,
[data-theme="soft-light-pro"] .form-control {
    background: #ffffff !important;
    border: 1px solid rgba(99, 102, 241, 0.25) !important;
    color: #0f172a !important;
}

[data-theme="soft-light-pro"] input::placeholder,
[data-theme="soft-light-pro"] textarea::placeholder,
[data-theme="soft-light-pro"] .form-input::placeholder {
    color: #94a3b8 !important;
}

[data-theme="soft-light-pro"] input:hover,
[data-theme="soft-light-pro"] select:hover,
[data-theme="soft-light-pro"] .form-group input:hover {
    border-color: #6366f1 !important;
}

[data-theme="soft-light-pro"] input:focus,
[data-theme="soft-light-pro"] select:focus,
[data-theme="soft-light-pro"] textarea:focus,
[data-theme="soft-light-pro"] .form-input:focus,
[data-theme="soft-light-pro"] .form-select:focus,
[data-theme="soft-light-pro"] .form-group input:focus {
    border-color: #4f46e5 !important;
    box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.15) !important;
    background: #ffffff !important;
}

/* Badges in light theme */
[data-theme="soft-light-pro"] .status-badge.success {
    background: rgba(22, 163, 74, 0.12);
    color: #16a34a;
}

[data-theme="soft-light-pro"] .status-badge.warning {
    background: rgba(245, 158, 11, 0.12);
    color: #b45309;
}

[data-theme="soft-light-pro"] .status-badge.danger {
    background: rgba(220, 38, 38, 0.12);
    color: #dc2626;
}

/* Hero section in light theme */
[data-theme="soft-light-pro"] .hero-section {
    background: linear-gradient(180deg, #f3f6fd 0%, #eef2ff 100%);
}

/* Navigation in light theme */
[data-theme="soft-light-pro"] .landing-nav {
    background: rgba(255, 255, 255, 0.85);
}

[data-theme="soft-light-pro"] .landing-nav.scrolled {
    background: rgba(255, 255, 255, 0.95);
    box-shadow: 0 4px 20px rgba(79, 70, 229, 0.1);
}

/* Mobile header in light theme */
[data-theme="soft-light-pro"] .mobile-header {
    background: rgba(255, 255, 255, 0.95);
    border-color: rgba(99, 102, 241, 0.1);
}

/* Footer in light theme */
[data-theme="soft-light-pro"] .footer,
[data-theme="soft-light-pro"] .landing-footer {
    background: linear-gradient(180deg, #eef2ff 0%, #e0e7ff 100%);
}

/* ========================================
   Soft Light Pro - Dashboard Fixes
   Override ALL hardcoded dark backgrounds
   ======================================== */

/* Dashboard sidebar */
[data-theme="soft-light-pro"] .dashboard-sidebar,
[data-theme="soft-light-pro"] .sidebar-nav {
    background: linear-gradient(180deg, #eef2ff 0%, #e0e7ff 100%) !important;
}

/* Main content area */
[data-theme="soft-light-pro"] .dashboard-content,
[data-theme="soft-light-pro"] .main-content,
[data-theme="soft-light-pro"] .content-area {
    background: #f3f6fd !important;
}

/* All card-like containers */
/* ========================================
   Soft Light Pro - GLOBAL DESIGN SYSTEM RESET
   Enforce rounded cards, eliminate square backgrounds
   ======================================== */

/* 1. Global Radius System */
:root {
    --radius-sm: 12px;
    --radius-md: 16px;
    --radius-lg: 20px;
}

/* 2. Global Container Transparency (Kill Square Boxes) */
[data-theme="soft-light-pro"] .section,
[data-theme="soft-light-pro"] .dashboard-section,
[data-theme="soft-light-pro"] .content-wrapper,
[data-theme="soft-light-pro"] .panel,
[data-theme="soft-light-pro"] .layout-block,
[data-theme="soft-light-pro"] .control-panel,
[data-theme="soft-light-pro"] .analytics-row,
[data-theme="soft-light-pro"] .quick-actions,
[data-theme="soft-light-pro"] .chart-wrapper,
[data-theme="soft-light-pro"] .metric-wrapper,
[data-theme="soft-light-pro"] .dashboard-group,
[data-theme="soft-light-pro"] .health-grid,
[data-theme="soft-light-pro"] .quick-stats-grid {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    backdrop-filter: none !important;
}

/* 3. Universal Card System (Apply to all visible surfaces) */
[data-theme="soft-light-pro"] .card,
[data-theme="soft-light-pro"] .glass-card,
[data-theme="soft-light-pro"] .stat-card,
[data-theme="soft-light-pro"] .metric-card,
[data-theme="soft-light-pro"] .widget,
[data-theme="soft-light-pro"] .session-card,
[data-theme="soft-light-pro"] .activity-card,
[data-theme="soft-light-pro"] .info-card,
[data-theme="soft-light-pro"] .table-container,
[data-theme="soft-light-pro"] .health-card,
[data-theme="soft-light-pro"] .quick-stats-card,
[data-theme="soft-light-pro"] .health-gauge-card,
[data-theme="soft-light-pro"] .analytics-card,
[data-theme="soft-light-pro"] .chart-card,
[data-theme="soft-light-pro"] .control-stat,
[data-theme="soft-light-pro"] .quick-stat,
[data-theme="soft-light-pro"] .health-item,
[data-theme="soft-light-pro"] .role-option,
[data-theme="soft-light-pro"] .user-card,
[data-theme="soft-light-pro"] .profile-card,
[data-theme="soft-light-pro"] .settings-section,
[data-theme="soft-light-pro"] .login-card,
[data-theme="soft-light-pro"] .modal-content,
[data-theme="soft-light-pro"] .timeline-item,
[data-theme="soft-light-pro"] .feature-card,
[data-theme="soft-light-pro"] .device-info-card,
[data-theme="soft-light-pro"] .log-entry {
    background: #ffffff !important;
    border-radius: var(--radius-lg) !important;
    border: 1px solid rgba(99, 102, 241, 0.12) !important;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.03) !important;
    backdrop-filter: none !important;
    overflow: hidden !important;
    /* Ensures contents don't bleed out */
}

/* Hover effects for interactive cards */
[data-theme="soft-light-pro"] .card:hover,
[data-theme="soft-light-pro"] .stat-card:hover,
[data-theme="soft-light-pro"] .control-stat:hover,
[data-theme="soft-light-pro"] .quick-stat:hover,
[data-theme="soft-light-pro"] .role-option:hover,
[data-theme="soft-light-pro"] .feature-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 20px -5px rgba(99, 102, 241, 0.15) !important;
    border-color: rgba(99, 102, 241, 0.4) !important;
}

/* 4. Sidebar Specifics */
[data-theme="soft-light-pro"] .sidebar {
    background: linear-gradient(180deg, #f8faff 0%, #ffffff 100%) !important;
    border-right: 1px solid rgba(99, 102, 241, 0.08) !important;
    border-radius: 0 !important;
    /* Full height */
}

[data-theme="soft-light-pro"] .nav-item {
    border-radius: var(--radius-sm) !important;
    color: #64748b !important;
}

[data-theme="soft-light-pro"] .nav-item.active {
    background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(79, 70, 229, 0.3) !important;
}

/* 5. Mobile Headers & Nav */
[data-theme="soft-light-pro"] .mobile-header,
[data-theme="soft-light-pro"] .bottom-nav {
    background: rgba(255, 255, 255, 0.95) !important;
    border-color: rgba(99, 102, 241, 0.1) !important;
    backdrop-filter: blur(10px) !important;
}

/* 6. Form Elements (Inputs & Selects) */
[data-theme="soft-light-pro"] input:not([type="radio"]):not([type="checkbox"]),
[data-theme="soft-light-pro"] select,
[data-theme="soft-light-pro"] textarea,
[data-theme="soft-light-pro"] .form-input,
[data-theme="soft-light-pro"] .form-select,
[data-theme="soft-light-pro"] .search-input {
    background: #f8fafc !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: var(--radius-sm) !important;
    color: #0f172a !important;
    box-shadow: none !important;
}

[data-theme="soft-light-pro"] input:focus,
[data-theme="soft-light-pro"] select:focus,
[data-theme="soft-light-pro"] textarea:focus {
    background: #ffffff !important;
    border-color: #6366f1 !important;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1) !important;
}

/* 7. Action Buttons */
[data-theme="soft-light-pro"] .action-btn {
    border-radius: var(--radius-sm) !important;
    background: rgba(99, 102, 241, 0.1) !important;
    color: #4338ca !important;
    border: 1px solid transparent !important;
}

[data-theme="soft-light-pro"] .action-btn:hover {
    background: rgba(99, 102, 241, 0.15) !important;
    transform: translateY(-2px);
}

[data-theme="soft-light-pro"] .action-btn.primary {
    background: linear-gradient(135deg, #4f46e5 0%, #6366f1 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25) !important;
}

[data-theme="soft-light-pro"] .action-btn.primary:hover {
    box-shadow: 0 6px 16px rgba(99, 102, 241, 0.35) !important;
}

/* 8. Text Colors & Typography */
[data-theme="soft-light-pro"] h1,
[data-theme="soft-light-pro"] h2,
[data-theme="soft-light-pro"] h3,
[data-theme="soft-light-pro"] h4,
[data-theme="soft-light-pro"] .stat-value,
[data-theme="soft-light-pro"] .control-value {
    color: #1e293b !important;
}

[data-theme="soft-light-pro"] p,
[data-theme="soft-light-pro"] span,
[data-theme="soft-light-pro"] label,
[data-theme="soft-light-pro"] .text-muted {
    color: #64748b !important;
}

/* 9. Empty State Specifics */
[data-theme="soft-light-pro"] .empty-state {
    background: linear-gradient(180deg, #ffffff 0%, #f1f5f9 100%) !important;
    border-radius: var(--radius-lg) !important;
    border: 2px dashed #cbd5e1 !important;
    box-shadow: none !important;
}

/* 10. Table Specifics */
[data-theme="soft-light-pro"] .table-header {
    background: transparent !important;
    border-bottom: 1px solid rgba(99, 102, 241, 0.08) !important;
}

[data-theme="soft-light-pro"] .data-table th {
    background: #f1f5f9 !important;
    color: #475569 !important;
    font-weight: 600 !important;
}

[data-theme="soft-light-pro"] .data-table td {
    border-bottom: 1px solid #f1f5f9 !important;
}

[data-theme="soft-light-pro"] .data-table tbody tr:hover {
    background: #f8fafc !important;
}