/* ═══════════════════════════════════════════════════════════════════════════
   VICO DESIGN SYSTEM - Unified Design Tokens
   
   USAGE: Set theme on <html> element:
     document.documentElement.dataset.theme = 'midnight';
   
   Available themes: default, midnight, ember, forest, ocean, monochrome
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    /* Typography */
    --primary-font: 'Roboto-Bold', sans-serif;
    --secondary-font: Arial, monospace;

    /* ═══════════════════════════════════════════════════════════════════════
       DEFAULT THEME - Blue/Cyan Dark
       ═══════════════════════════════════════════════════════════════════════ */
    
    /* Surface Colors */
    --vico-bg-deep: #12141a;
    --vico-bg-base: #1a1d24;
    --vico-bg-raised: #22262f;
    --vico-bg-elevated: #282d38;
    --vico-bg-hover: #3a4150;
    
    /* Border Colors */
    --vico-border: #2d3340;
    --vico-border-hover: #3a4150;
    --vico-border-focus: #61afef;
    
    /* Text Colors */
    --vico-text-primary: #e4e8ef;
    --vico-text-secondary: #8891a0;
    --vico-text-muted: #5c6370;
    
    /* Accent Colors */
    --vico-accent-blue: #61afef;
    --vico-accent-blue-light: #7cc4ff;
    --vico-accent-green: #98c379;
    --vico-accent-green-light: #a8d389;
    --vico-accent-amber: #e5c07b;
    --vico-accent-amber-light: #f0d090;
    --vico-accent-red: #e06c75;
    --vico-accent-red-dark: #c55a62;
    --vico-accent-purple: #c678dd;
    --vico-accent-purple-light: #d688ed;
    --vico-accent-cyan: #56b6c2;
    
    /* Accent Glows (for focus/shadows) */
    --vico-glow-blue: rgba(97, 175, 239, 0.2);
    --vico-glow-green: rgba(152, 195, 121, 0.2);
    --vico-glow-amber: rgba(229, 192, 123, 0.2);
    --vico-glow-red: rgba(224, 108, 117, 0.2);
    --vico-glow-purple: rgba(198, 120, 221, 0.2);
    --vico-glow-cyan: rgba(86, 182, 194, 0.2);
    
    /* Gradients */
    --vico-gradient-header: linear-gradient(180deg, #22262f 0%, #1a1d24 100%);
    --vico-gradient-blue: linear-gradient(135deg, #61afef 0%, #4a9be0 100%);
    --vico-gradient-green: linear-gradient(135deg, #98c379 0%, #7eb863 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e5c07b 0%, #d4a055 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c678dd 0%, #a855c0 100%);
    
    /* Spacing */
    --vico-space-xs: 4px;
    --vico-space-sm: 8px;
    --vico-space-md: 12px;
    --vico-space-lg: 16px;
    --vico-space-xl: 20px;
    --vico-space-xxl: 32px;
    
    /* Border Radius */
    --vico-radius-sm: 4px;
    --vico-radius-md: 6px;
    --vico-radius-lg: 8px;
    --vico-radius-xl: 12px;
    
    /* Transitions */
    --vico-transition-fast: 0.15s ease;
    --vico-transition-normal: 0.2s ease;
    
    /* Shadows */
    --vico-shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.2);
    --vico-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
    --vico-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);
    --vico-shadow-xl: 0 20px 60px rgba(0, 0, 0, 0.5);
    
    /* Scrollbar */
    --vico-scrollbar-width: 6px;
    --vico-scrollbar-thumb: rgba(97, 175, 239, 0.3);
    --vico-scrollbar-thumb-hover: rgba(97, 175, 239, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MIDNIGHT THEME - Deep Purple/Violet
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="midnight"] {
    --vico-bg-deep: #0d0d14;
    --vico-bg-base: #13131f;
    --vico-bg-raised: #1a1a2e;
    --vico-bg-elevated: #22223a;
    --vico-bg-hover: #2d2d4a;
    
    --vico-border: #2a2a45;
    --vico-border-hover: #3d3d5c;
    --vico-border-focus: #a78bfa;
    
    --vico-text-primary: #e8e6f2;
    --vico-text-secondary: #9590b0;
    --vico-text-muted: #6b6785;
    
    --vico-accent-blue: #818cf8;
    --vico-accent-blue-light: #a5b4fc;
    --vico-accent-green: #86efac;
    --vico-accent-green-light: #a7f3d0;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #fb7185;
    --vico-accent-red-dark: #e11d48;
    --vico-accent-purple: #a78bfa;
    --vico-accent-purple-light: #c4b5fd;
    --vico-accent-cyan: #67e8f9;
    
    --vico-glow-blue: rgba(129, 140, 248, 0.25);
    --vico-glow-green: rgba(134, 239, 172, 0.2);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(251, 113, 133, 0.2);
    --vico-glow-purple: rgba(167, 139, 250, 0.25);
    --vico-glow-cyan: rgba(103, 232, 249, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #1a1a2e 0%, #13131f 100%);
    --vico-gradient-blue: linear-gradient(135deg, #818cf8 0%, #6366f1 100%);
    --vico-gradient-green: linear-gradient(135deg, #86efac 0%, #4ade80 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
    
    --vico-scrollbar-thumb: rgba(167, 139, 250, 0.3);
    --vico-scrollbar-thumb-hover: rgba(167, 139, 250, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   EMBER THEME - Warm Orange/Red
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="ember"] {
    --vico-bg-deep: #140c08;
    --vico-bg-base: #1c1210;
    --vico-bg-raised: #291a16;
    --vico-bg-elevated: #35221c;
    --vico-bg-hover: #4a3028;
    
    --vico-border: #3d2820;
    --vico-border-hover: #5a3d32;
    --vico-border-focus: #f97316;
    
    --vico-text-primary: #fef3e8;
    --vico-text-secondary: #c9a892;
    --vico-text-muted: #8b7263;
    
    --vico-accent-blue: #38bdf8;
    --vico-accent-blue-light: #7dd3fc;
    --vico-accent-green: #84cc16;
    --vico-accent-green-light: #a3e635;
    --vico-accent-amber: #f97316;
    --vico-accent-amber-light: #fb923c;
    --vico-accent-red: #ef4444;
    --vico-accent-red-dark: #dc2626;
    --vico-accent-purple: #e879f9;
    --vico-accent-purple-light: #f0abfc;
    --vico-accent-cyan: #22d3ee;
    
    --vico-glow-blue: rgba(56, 189, 248, 0.2);
    --vico-glow-green: rgba(132, 204, 22, 0.2);
    --vico-glow-amber: rgba(249, 115, 22, 0.25);
    --vico-glow-red: rgba(239, 68, 68, 0.25);
    --vico-glow-purple: rgba(232, 121, 249, 0.2);
    --vico-glow-cyan: rgba(34, 211, 238, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #291a16 0%, #1c1210 100%);
    --vico-gradient-blue: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
    --vico-gradient-green: linear-gradient(135deg, #84cc16 0%, #65a30d 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fb923c 0%, #f97316 100%);
    --vico-gradient-purple: linear-gradient(135deg, #e879f9 0%, #d946ef 100%);
    
    --vico-scrollbar-thumb: rgba(249, 115, 22, 0.3);
    --vico-scrollbar-thumb-hover: rgba(249, 115, 22, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FOREST THEME - Natural Green
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="forest"] {
    --vico-bg-deep: #0a120e;
    --vico-bg-base: #101a14;
    --vico-bg-raised: #16241c;
    --vico-bg-elevated: #1c2e24;
    --vico-bg-hover: #284030;
    
    --vico-border: #243828;
    --vico-border-hover: #345238;
    --vico-border-focus: #4ade80;
    
    --vico-text-primary: #ecfdf5;
    --vico-text-secondary: #a3c4b0;
    --vico-text-muted: #6b8f78;
    
    --vico-accent-blue: #60a5fa;
    --vico-accent-blue-light: #93c5fd;
    --vico-accent-green: #4ade80;
    --vico-accent-green-light: #86efac;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #f87171;
    --vico-accent-red-dark: #ef4444;
    --vico-accent-purple: #c084fc;
    --vico-accent-purple-light: #d8b4fe;
    --vico-accent-cyan: #2dd4bf;
    
    --vico-glow-blue: rgba(96, 165, 250, 0.2);
    --vico-glow-green: rgba(74, 222, 128, 0.25);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(248, 113, 113, 0.2);
    --vico-glow-purple: rgba(192, 132, 252, 0.2);
    --vico-glow-cyan: rgba(45, 212, 191, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #16241c 0%, #101a14 100%);
    --vico-gradient-blue: linear-gradient(135deg, #4ade80 0%, #22c55e 100%);
    --vico-gradient-green: linear-gradient(135deg, #86efac 0%, #4ade80 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c084fc 0%, #a855f7 100%);
    
    --vico-scrollbar-thumb: rgba(74, 222, 128, 0.3);
    --vico-scrollbar-thumb-hover: rgba(74, 222, 128, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   OCEAN THEME - Deep Teal/Aqua
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="ocean"] {
    --vico-bg-deep: #071318;
    --vico-bg-base: #0c1a20;
    --vico-bg-raised: #12252d;
    --vico-bg-elevated: #183038;
    --vico-bg-hover: #234248;
    
    --vico-border: #1e3a42;
    --vico-border-hover: #2d5560;
    --vico-border-focus: #22d3ee;
    
    --vico-text-primary: #e0f7fa;
    --vico-text-secondary: #90cad5;
    --vico-text-muted: #5a9aa5;
    
    --vico-accent-blue: #06b6d4;
    --vico-accent-blue-light: #22d3ee;
    --vico-accent-green: #10b981;
    --vico-accent-green-light: #34d399;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #f43f5e;
    --vico-accent-red-dark: #e11d48;
    --vico-accent-purple: #a78bfa;
    --vico-accent-purple-light: #c4b5fd;
    --vico-accent-cyan: #22d3ee;
    
    --vico-glow-blue: rgba(6, 182, 212, 0.25);
    --vico-glow-green: rgba(16, 185, 129, 0.2);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(244, 63, 94, 0.2);
    --vico-glow-purple: rgba(167, 139, 250, 0.2);
    --vico-glow-cyan: rgba(34, 211, 238, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #12252d 0%, #0c1a20 100%);
    --vico-gradient-blue: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);
    --vico-gradient-green: linear-gradient(135deg, #10b981 0%, #059669 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
    
    --vico-scrollbar-thumb: rgba(34, 211, 238, 0.3);
    --vico-scrollbar-thumb-hover: rgba(34, 211, 238, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MONOCHROME THEME - Elegant Grayscale
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="monochrome"] {
    --vico-bg-deep: #0a0a0a;
    --vico-bg-base: #121212;
    --vico-bg-raised: #1e1e1e;
    --vico-bg-elevated: #2a2a2a;
    --vico-bg-hover: #3a3a3a;
    
    --vico-border: #333333;
    --vico-border-hover: #4a4a4a;
    --vico-border-focus: #888888;
    
    --vico-text-primary: #f0f0f0;
    --vico-text-secondary: #a0a0a0;
    --vico-text-muted: #666666;
    
    --vico-accent-blue: #a0a0a0;
    --vico-accent-blue-light: #c0c0c0;
    --vico-accent-green: #90ee90;
    --vico-accent-green-light: #b0ffb0;
    --vico-accent-amber: #e0c080;
    --vico-accent-amber-light: #f0d090;
    --vico-accent-red: #e07070;
    --vico-accent-red-dark: #c05050;
    --vico-accent-purple: #c0a0d0;
    --vico-accent-purple-light: #d0b0e0;
    --vico-accent-cyan: #80d0d0;
    
    --vico-glow-blue: rgba(160, 160, 160, 0.15);
    --vico-glow-green: rgba(144, 238, 144, 0.15);
    --vico-glow-amber: rgba(224, 192, 128, 0.15);
    --vico-glow-red: rgba(224, 112, 112, 0.15);
    --vico-glow-purple: rgba(192, 160, 208, 0.15);
    --vico-glow-cyan: rgba(128, 208, 208, 0.15);
    
    --vico-gradient-header: linear-gradient(180deg, #1e1e1e 0%, #121212 100%);
    --vico-gradient-blue: linear-gradient(135deg, #888888 0%, #666666 100%);
    --vico-gradient-green: linear-gradient(135deg, #90ee90 0%, #70c070 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e0c080 0%, #c0a060 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c0a0d0 0%, #a080b0 100%);
    
    --vico-scrollbar-thumb: rgba(160, 160, 160, 0.3);
    --vico-scrollbar-thumb-hover: rgba(160, 160, 160, 0.5);
}

/* ═══════════════════════════════════════════════════════════════════════════
   NORD THEME - Arctic, North-Bluish
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="nord"] {
    --vico-bg-deep: #242933;
    --vico-bg-base: #2e3440;
    --vico-bg-raised: #3b4252;
    --vico-bg-elevated: #434c5e;
    --vico-bg-hover: #4c566a;
    
    --vico-border: #4c566a;
    --vico-border-hover: #5e6779;
    --vico-border-focus: #88c0d0;
    
    --vico-text-primary: #eceff4;
    --vico-text-secondary: #d8dee9;
    --vico-text-muted: #7b88a1;
    
    --vico-accent-blue: #81a1c1;
    --vico-accent-blue-light: #88c0d0;
    --vico-accent-green: #a3be8c;
    --vico-accent-green-light: #b5d19c;
    --vico-accent-amber: #ebcb8b;
    --vico-accent-amber-light: #f0d8a8;
    --vico-accent-red: #bf616a;
    --vico-accent-red-dark: #a54e56;
    --vico-accent-purple: #b48ead;
    --vico-accent-purple-light: #c9a8c4;
    --vico-accent-cyan: #8fbcbb;
    
    --vico-glow-blue: rgba(129, 161, 193, 0.2);
    --vico-glow-green: rgba(163, 190, 140, 0.2);
    --vico-glow-amber: rgba(235, 203, 139, 0.2);
    --vico-glow-red: rgba(191, 97, 106, 0.2);
    --vico-glow-purple: rgba(180, 142, 173, 0.2);
    --vico-glow-cyan: rgba(143, 188, 187, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #3b4252 0%, #2e3440 100%);
    --vico-gradient-blue: linear-gradient(135deg, #81a1c1 0%, #5e81ac 100%);
    --vico-gradient-green: linear-gradient(135deg, #a3be8c 0%, #8fbf7f 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ebcb8b 0%, #d7b56a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #b48ead 0%, #9d7496 100%);
    
    --vico-scrollbar-thumb: rgba(136, 192, 208, 0.3);
    --vico-scrollbar-thumb-hover: rgba(136, 192, 208, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CYBERPUNK THEME - Neon Future
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="cyberpunk"] {
    --vico-bg-deep: #0a0a0f;
    --vico-bg-base: #0f0f1a;
    --vico-bg-raised: #1a1a2e;
    --vico-bg-elevated: #252542;
    --vico-bg-hover: #2f2f55;
    
    --vico-border: #ff00ff30;
    --vico-border-hover: #ff00ff60;
    --vico-border-focus: #00ffff;
    
    --vico-text-primary: #ffffff;
    --vico-text-secondary: #b0b0d0;
    --vico-text-muted: #6060a0;
    
    --vico-accent-blue: #00ffff;
    --vico-accent-blue-light: #66ffff;
    --vico-accent-green: #00ff88;
    --vico-accent-green-light: #66ffaa;
    --vico-accent-amber: #ffff00;
    --vico-accent-amber-light: #ffff66;
    --vico-accent-red: #ff0055;
    --vico-accent-red-dark: #cc0044;
    --vico-accent-purple: #ff00ff;
    --vico-accent-purple-light: #ff66ff;
    --vico-accent-cyan: #00ffff;
    
    --vico-glow-blue: rgba(0, 255, 255, 0.3);
    --vico-glow-green: rgba(0, 255, 136, 0.3);
    --vico-glow-amber: rgba(255, 255, 0, 0.3);
    --vico-glow-red: rgba(255, 0, 85, 0.3);
    --vico-glow-purple: rgba(255, 0, 255, 0.3);
    --vico-glow-cyan: rgba(0, 255, 255, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #1a1a2e 0%, #0f0f1a 100%);
    --vico-gradient-blue: linear-gradient(135deg, #00ffff 0%, #0088ff 100%);
    --vico-gradient-green: linear-gradient(135deg, #00ff88 0%, #00cc66 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ffff00 0%, #ffcc00 100%);
    --vico-gradient-purple: linear-gradient(135deg, #ff00ff 0%, #cc00cc 100%);
    
    --vico-scrollbar-thumb: rgba(255, 0, 255, 0.4);
    --vico-scrollbar-thumb-hover: rgba(255, 0, 255, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   DRACULA THEME - Famous Dark Theme
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="dracula"] {
    --vico-bg-deep: #1e1f29;
    --vico-bg-base: #282a36;
    --vico-bg-raised: #343746;
    --vico-bg-elevated: #3d4056;
    --vico-bg-hover: #44475a;
    
    --vico-border: #44475a;
    --vico-border-hover: #5a5e73;
    --vico-border-focus: #bd93f9;
    
    --vico-text-primary: #f8f8f2;
    --vico-text-secondary: #bfc0c5;
    --vico-text-muted: #6272a4;
    
    --vico-accent-blue: #8be9fd;
    --vico-accent-blue-light: #a4edfd;
    --vico-accent-green: #50fa7b;
    --vico-accent-green-light: #73fb95;
    --vico-accent-amber: #f1fa8c;
    --vico-accent-amber-light: #f4fba3;
    --vico-accent-red: #ff5555;
    --vico-accent-red-dark: #e64545;
    --vico-accent-purple: #bd93f9;
    --vico-accent-purple-light: #caa8fa;
    --vico-accent-cyan: #8be9fd;
    
    --vico-glow-blue: rgba(139, 233, 253, 0.25);
    --vico-glow-green: rgba(80, 250, 123, 0.25);
    --vico-glow-amber: rgba(241, 250, 140, 0.2);
    --vico-glow-red: rgba(255, 85, 85, 0.25);
    --vico-glow-purple: rgba(189, 147, 249, 0.25);
    --vico-glow-cyan: rgba(139, 233, 253, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #343746 0%, #282a36 100%);
    --vico-gradient-blue: linear-gradient(135deg, #bd93f9 0%, #9a6dd7 100%);
    --vico-gradient-green: linear-gradient(135deg, #50fa7b 0%, #3dd968 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f1fa8c 0%, #e6ef6a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #ff79c6 0%, #e066a8 100%);
    
    --vico-scrollbar-thumb: rgba(189, 147, 249, 0.4);
    --vico-scrollbar-thumb-hover: rgba(189, 147, 249, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   ROSE PINE THEME - Soft Romantic
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="rosepine"] {
    --vico-bg-deep: #131020;
    --vico-bg-base: #191724;
    --vico-bg-raised: #1f1d2e;
    --vico-bg-elevated: #26233a;
    --vico-bg-hover: #2a2740;
    
    --vico-border: #403d52;
    --vico-border-hover: #524f67;
    --vico-border-focus: #c4a7e7;
    
    --vico-text-primary: #e0def4;
    --vico-text-secondary: #908caa;
    --vico-text-muted: #6e6a86;
    
    --vico-accent-blue: #9ccfd8;
    --vico-accent-blue-light: #b4d9df;
    --vico-accent-green: #31748f;
    --vico-accent-green-light: #4a8da8;
    --vico-accent-amber: #f6c177;
    --vico-accent-amber-light: #f8ce92;
    --vico-accent-red: #eb6f92;
    --vico-accent-red-dark: #d9587c;
    --vico-accent-purple: #c4a7e7;
    --vico-accent-purple-light: #d1b9ed;
    --vico-accent-cyan: #9ccfd8;
    
    --vico-glow-blue: rgba(156, 207, 216, 0.2);
    --vico-glow-green: rgba(49, 116, 143, 0.25);
    --vico-glow-amber: rgba(246, 193, 119, 0.2);
    --vico-glow-red: rgba(235, 111, 146, 0.25);
    --vico-glow-purple: rgba(196, 167, 231, 0.25);
    --vico-glow-cyan: rgba(156, 207, 216, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #1f1d2e 0%, #191724 100%);
    --vico-gradient-blue: linear-gradient(135deg, #c4a7e7 0%, #a78bcc 100%);
    --vico-gradient-green: linear-gradient(135deg, #31748f 0%, #285e74 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f6c177 0%, #eba855 100%);
    --vico-gradient-purple: linear-gradient(135deg, #eb6f92 0%, #d9587c 100%);
    
    --vico-scrollbar-thumb: rgba(196, 167, 231, 0.3);
    --vico-scrollbar-thumb-hover: rgba(196, 167, 231, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   TOKYO NIGHT THEME - Japanese City Nights
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="tokyo"] {
    --vico-bg-deep: #16161e;
    --vico-bg-base: #1a1b26;
    --vico-bg-raised: #24283b;
    --vico-bg-elevated: #2a2e42;
    --vico-bg-hover: #343b58;
    
    --vico-border: #3b4261;
    --vico-border-hover: #4a5075;
    --vico-border-focus: #7aa2f7;
    
    --vico-text-primary: #c0caf5;
    --vico-text-secondary: #9aa5ce;
    --vico-text-muted: #565f89;
    
    --vico-accent-blue: #7aa2f7;
    --vico-accent-blue-light: #99b4f9;
    --vico-accent-green: #9ece6a;
    --vico-accent-green-light: #b3d888;
    --vico-accent-amber: #e0af68;
    --vico-accent-amber-light: #e6bf86;
    --vico-accent-red: #f7768e;
    --vico-accent-red-dark: #e5667c;
    --vico-accent-purple: #bb9af7;
    --vico-accent-purple-light: #c9aef9;
    --vico-accent-cyan: #7dcfff;
    
    --vico-glow-blue: rgba(122, 162, 247, 0.25);
    --vico-glow-green: rgba(158, 206, 106, 0.2);
    --vico-glow-amber: rgba(224, 175, 104, 0.2);
    --vico-glow-red: rgba(247, 118, 142, 0.25);
    --vico-glow-purple: rgba(187, 154, 247, 0.25);
    --vico-glow-cyan: rgba(125, 207, 255, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #24283b 0%, #1a1b26 100%);
    --vico-gradient-blue: linear-gradient(135deg, #7aa2f7 0%, #5d8ae0 100%);
    --vico-gradient-green: linear-gradient(135deg, #9ece6a 0%, #7eb852 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e0af68 0%, #d19a4a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #bb9af7 0%, #a07de0 100%);
    
    --vico-scrollbar-thumb: rgba(122, 162, 247, 0.3);
    --vico-scrollbar-thumb-hover: rgba(122, 162, 247, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SYNTHWAVE THEME - 80s Retro Neon
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="synthwave"] {
    --vico-bg-deep: #12091f;
    --vico-bg-base: #1a1025;
    --vico-bg-raised: #241734;
    --vico-bg-elevated: #2e1f42;
    --vico-bg-hover: #3a2850;
    
    --vico-border: #4a3060;
    --vico-border-hover: #5e4078;
    --vico-border-focus: #f92aad;
    
    --vico-text-primary: #fff0f5;
    --vico-text-secondary: #c8a8d0;
    --vico-text-muted: #7a5988;
    
    --vico-accent-blue: #36f9f6;
    --vico-accent-blue-light: #5ffaf8;
    --vico-accent-green: #72f1b8;
    --vico-accent-green-light: #8ef4c7;
    --vico-accent-amber: #fede5d;
    --vico-accent-amber-light: #fee57d;
    --vico-accent-red: #fe4450;
    --vico-accent-red-dark: #e03a45;
    --vico-accent-purple: #f92aad;
    --vico-accent-purple-light: #fa55bd;
    --vico-accent-cyan: #36f9f6;
    
    --vico-glow-blue: rgba(54, 249, 246, 0.3);
    --vico-glow-green: rgba(114, 241, 184, 0.25);
    --vico-glow-amber: rgba(254, 222, 93, 0.25);
    --vico-glow-red: rgba(254, 68, 80, 0.3);
    --vico-glow-purple: rgba(249, 42, 173, 0.35);
    --vico-glow-cyan: rgba(54, 249, 246, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #241734 0%, #1a1025 100%);
    --vico-gradient-blue: linear-gradient(135deg, #f92aad 0%, #d91e94 100%);
    --vico-gradient-green: linear-gradient(135deg, #72f1b8 0%, #50d89a 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fede5d 0%, #f5c840 100%);
    --vico-gradient-purple: linear-gradient(135deg, #36f9f6 0%, #20d4d1 100%);
    
    --vico-scrollbar-thumb: rgba(249, 42, 173, 0.4);
    --vico-scrollbar-thumb-hover: rgba(249, 42, 173, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   GRUVBOX THEME - Retro Warm
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="gruvbox"] {
    --vico-bg-deep: #1d2021;
    --vico-bg-base: #282828;
    --vico-bg-raised: #32302f;
    --vico-bg-elevated: #3c3836;
    --vico-bg-hover: #504945;
    
    --vico-border: #504945;
    --vico-border-hover: #665c54;
    --vico-border-focus: #fabd2f;
    
    --vico-text-primary: #ebdbb2;
    --vico-text-secondary: #bdae93;
    --vico-text-muted: #928374;
    
    --vico-accent-blue: #83a598;
    --vico-accent-blue-light: #9bb8ac;
    --vico-accent-green: #b8bb26;
    --vico-accent-green-light: #c5c84a;
    --vico-accent-amber: #fabd2f;
    --vico-accent-amber-light: #fbca55;
    --vico-accent-red: #fb4934;
    --vico-accent-red-dark: #cc241d;
    --vico-accent-purple: #d3869b;
    --vico-accent-purple-light: #dda0af;
    --vico-accent-cyan: #8ec07c;
    
    --vico-glow-blue: rgba(131, 165, 152, 0.25);
    --vico-glow-green: rgba(184, 187, 38, 0.2);
    --vico-glow-amber: rgba(250, 189, 47, 0.25);
    --vico-glow-red: rgba(251, 73, 52, 0.25);
    --vico-glow-purple: rgba(211, 134, 155, 0.25);
    --vico-glow-cyan: rgba(142, 192, 124, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #32302f 0%, #282828 100%);
    --vico-gradient-blue: linear-gradient(135deg, #fabd2f 0%, #d79921 100%);
    --vico-gradient-green: linear-gradient(135deg, #b8bb26 0%, #98971a 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fe8019 0%, #d65d0e 100%);
    --vico-gradient-purple: linear-gradient(135deg, #d3869b 0%, #b16286 100%);
    
    --vico-scrollbar-thumb: rgba(250, 189, 47, 0.35);
    --vico-scrollbar-thumb-hover: rgba(250, 189, 47, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CATPPUCCIN MOCHA THEME - Cozy Pastel
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="catppuccin"] {
    --vico-bg-deep: #11111b;
    --vico-bg-base: #1e1e2e;
    --vico-bg-raised: #313244;
    --vico-bg-elevated: #45475a;
    --vico-bg-hover: #585b70;
    
    --vico-border: #45475a;
    --vico-border-hover: #585b70;
    --vico-border-focus: #cba6f7;
    
    --vico-text-primary: #cdd6f4;
    --vico-text-secondary: #bac2de;
    --vico-text-muted: #6c7086;
    
    --vico-accent-blue: #89b4fa;
    --vico-accent-blue-light: #a4c3fb;
    --vico-accent-green: #a6e3a1;
    --vico-accent-green-light: #b8e9b4;
    --vico-accent-amber: #f9e2af;
    --vico-accent-amber-light: #fae8bf;
    --vico-accent-red: #f38ba8;
    --vico-accent-red-dark: #e06c88;
    --vico-accent-purple: #cba6f7;
    --vico-accent-purple-light: #d6b8f9;
    --vico-accent-cyan: #94e2d5;
    
    --vico-glow-blue: rgba(137, 180, 250, 0.25);
    --vico-glow-green: rgba(166, 227, 161, 0.2);
    --vico-glow-amber: rgba(249, 226, 175, 0.2);
    --vico-glow-red: rgba(243, 139, 168, 0.25);
    --vico-glow-purple: rgba(203, 166, 247, 0.25);
    --vico-glow-cyan: rgba(148, 226, 213, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #313244 0%, #1e1e2e 100%);
    --vico-gradient-blue: linear-gradient(135deg, #cba6f7 0%, #b48bdf 100%);
    --vico-gradient-green: linear-gradient(135deg, #a6e3a1 0%, #8bd787 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f9e2af 0%, #f5d38a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #f5c2e7 0%, #e8a8d5 100%);
    
    --vico-scrollbar-thumb: rgba(203, 166, 247, 0.35);
    --vico-scrollbar-thumb-hover: rgba(203, 166, 247, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   AURORA THEME - Northern Lights
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="aurora"] {
    --vico-bg-deep: #0a1014;
    --vico-bg-base: #0f171c;
    --vico-bg-raised: #152028;
    --vico-bg-elevated: #1c2a34;
    --vico-bg-hover: #243540;
    
    --vico-border: #2a4050;
    --vico-border-hover: #3a5568;
    --vico-border-focus: #88ffcc;
    
    --vico-text-primary: #e8f4f0;
    --vico-text-secondary: #a8c8c0;
    --vico-text-muted: #607878;
    
    --vico-accent-blue: #5588ff;
    --vico-accent-blue-light: #77a0ff;
    --vico-accent-green: #88ffcc;
    --vico-accent-green-light: #a0ffd8;
    --vico-accent-amber: #ffdd88;
    --vico-accent-amber-light: #ffe4a0;
    --vico-accent-red: #ff6688;
    --vico-accent-red-dark: #e05070;
    --vico-accent-purple: #cc88ff;
    --vico-accent-purple-light: #d8a0ff;
    --vico-accent-cyan: #66eeff;
    
    --vico-glow-blue: rgba(85, 136, 255, 0.25);
    --vico-glow-green: rgba(136, 255, 204, 0.3);
    --vico-glow-amber: rgba(255, 221, 136, 0.2);
    --vico-glow-red: rgba(255, 102, 136, 0.25);
    --vico-glow-purple: rgba(204, 136, 255, 0.25);
    --vico-glow-cyan: rgba(102, 238, 255, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #152028 0%, #0f171c 100%);
    --vico-gradient-blue: linear-gradient(135deg, #88ffcc 0%, #55ddaa 100%);
    --vico-gradient-green: linear-gradient(135deg, #66eeff 0%, #44ccdd 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ffdd88 0%, #f0c060 100%);
    --vico-gradient-purple: linear-gradient(135deg, #cc88ff 0%, #aa66dd 100%);
    
    --vico-scrollbar-thumb: rgba(136, 255, 204, 0.35);
    --vico-scrollbar-thumb-hover: rgba(136, 255, 204, 0.6);
}

@font-face {
    font-family: 'Roboto-Bold';
    src: url(f80816a5455d171f948d.ttf) format('truetype');
}

body, html {
    margin: 0;
    padding: 0;
    overflow: hidden;
    font-family: var(--primary-font);
}

#scene-container {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

/* ============================================
   GLOBAL TEXT SELECTION CONTROL
   Prevents accidental text selection during 
   interactions (drag, click, etc.)
   ============================================ */

/* Disable text selection globally */
*, *::before, *::after {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/* Re-enable text selection for inputs and editable content */
input,
textarea,
[contenteditable="true"],
.selectable-text,
pre,
code {
    -webkit-user-select: text;
    -moz-user-select: text;
    -ms-user-select: text;
    user-select: text;
}

/* Ensure cursor shows text selection is available */
input,
textarea,
[contenteditable="true"] {
    cursor: text;
}

/* Utility class for enabling selection on specific elements */
.allow-select {
    -webkit-user-select: text !important;
    -moz-user-select: text !important;
    -ms-user-select: text !important;
    user-select: text !important;
}

/* Utility class for all selection (copy-paste entire blocks) */
.allow-select-all {
    -webkit-user-select: all !important;
    -moz-user-select: all !important;
    -ms-user-select: all !important;
    user-select: all !important;
}
#dot-cursor {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 6px;
    height: 6px;
    background-color: var(--vico-text-primary);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    z-index: 1000;
}

#startExperienceButton {
    display: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 20px 40px;
    background-color: var(--vico-accent-blue);
    color: var(--vico-text-primary);
    border: none;
    border-radius: 50px;
    box-shadow: var(--vico-shadow-lg);
    cursor: pointer;
    font-family: var(--primary-font);
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 2px;
    transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
    z-index: 99999;
    overflow: hidden;
}

#startExperienceButton::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        120deg,
        transparent,
        rgba(255, 255, 255, 0.3),
        transparent
    );
    transition: left 0.5s ease;
}

#startExperienceButton:hover {
    background-color: var(--vico-accent-blue-light);
    transform: translate(-50%, -50%) scale(1.05);
    box-shadow: var(--vico-shadow-xl);
}

#startExperienceButton:hover::before {
    left: 100%;
}

@keyframes pulse {
    0%, 100% {
        transform: translate(-50%, -50%) scale(1);
    }
    50% {
        transform: translate(-50%, -50%) scale(1.05);
    }
}

@keyframes fadeInScale {
    0% {
        opacity: 0;
        transform: translate(-50%, -50%) scale(0.0);
    }

    100% {
        opacity: 1;
        transform: translate(-50%, -50%) scale(1);
    }
}

.cog-container {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 100;
    -webkit-tap-highlight-color: transparent;
    outline: none;
}

#cog-icon {
    background: none;
    border: none;
    cursor: pointer;
    animation: float 3s ease-in-out infinite;
}

.esc-container {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 100;
    -webkit-tap-highlight-color: transparent;
    outline: none;
    display: flex;
    align-items: center;
}

#esc-icon {
    background: none;
    width: 35px;
    height: 35px;
    border: none;
    display: inline-block;
    vertical-align: middle;
    background-color: transparent;
}

#esc-text {
    font-family: var(--primary-font);
    font-size: 12px;
    color: var(--vico-text-primary);
    margin-left: 8px;
    display: inline-block;
    vertical-align: middle; 
}

.tooltip-icon {
    cursor: pointer;
    display: inline-block;
    position: relative;
    transform: translateY(-2px);
    font-size: 12px;    
    margin-left: 5px;
}

.tooltip-text {
    visibility: hidden;
    width: 200px;
    max-width: 200px; 
    background-color: var(--vico-bg-deep);
    font-size: 12px;
    color: var(--vico-text-primary);
    text-align: center;
    border-radius: var(--vico-radius-md);
    padding: 5px;
    position: absolute;
    z-index: 100;
    white-space: normal;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
}

.tooltip-icon:hover .tooltip-text,
.tooltip-icon:focus .tooltip-text {
    visibility: visible;
    opacity: 1;
}

@keyframes float {
    0%, 100% {
        transform: translateY(-5px);
    }
    50% {
        transform: translateY(5px);
    }
}

/* Base Container Styles */
.loading-background {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle at center, var(--vico-bg-base) 0%, var(--vico-bg-deep) 100%);
    z-index: 2000;
    opacity: 0;
    transition: opacity 2s;
}

.loading-container {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: none;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: 2001;
    text-align: center;
    width: min(90vw, 600px);
    padding: 2rem;
}

/* Logo Styles */
.loading-logo {
    width: clamp(160px, 30vw, 220px);
    height: auto;
    margin-bottom: 2rem;
    animation: logoFloat 3s infinite cubic-bezier(0.4, 0, 0.2, 1);
    transform-origin: center center;
    will-change: transform;
}

/* Loading Text Styles */
.loading-text {
    color: var(--vico-text-primary);
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 700;
    margin: 1.5rem 0;
    font-family: var(--primary-font);
    text-transform: uppercase;
    letter-spacing: 0.5em;
    opacity: 0.9;
    transform: translateX(0.25em); /* Offset for letter-spacing */
    animation: textPulse 3s infinite cubic-bezier(0.4, 0, 0.2, 1);
}

/* Progress Bar Styles */
.loading-progress-container {
    width: 100%;
    height: 6px;
    background-color: rgba(255, 255, 255, 0.08);
    border-radius: var(--vico-radius-lg);
    overflow: hidden;
    margin: 2rem 0;
    position: relative;
    box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.2);
}

.loading-progress-bar {
    width: 0;
    height: 100%;
    background: var(--vico-gradient-blue);
    transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    border-radius: var(--vico-radius-lg);
    position: relative;
    overflow: hidden;
}

.loading-progress-bar::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        90deg,
        transparent 0%,
        rgba(255, 255, 255, 0.2) 50%,
        transparent 100%
    );
    animation: progressShimmer 2s infinite;
}

/* Percentage Text Styles */
.loading-percentage {
    color: var(--vico-text-secondary);
    font-size: 1.1rem;
    font-family: var(--primary-font);
    margin-top: 1rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    opacity: 0.8;
}

/* Animations */
@keyframes logoFloat {
    0%, 100% {
        transform: translateY(0) scale(1);
    }
    50% {
        transform: translateY(-10px) scale(1.02);
    }
}

@keyframes textPulse {
    0%, 100% {
        opacity: 0.9;
        transform: translateX(0.25em) scale(1);
    }
    50% {
        opacity: 1;
        transform: translateX(0.25em) scale(1.02);
    }
}

@keyframes progressShimmer {
    0% {
        transform: translateX(0%);
    }
    100% {
        transform: translateX(200%);
    }
}

/* Responsive Design */
@media (max-width: 768px) {
    .loading-container {
        padding: 1.5rem;
    }

    .loading-text {
        font-size: clamp(1.5rem, 4vw, 2rem);
        letter-spacing: 0.3em;
    }

    .loading-progress-container {
        height: 5px;
        margin: 1.5rem 0;
    }

    .loading-percentage {
        font-size: 1rem;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   VICO DESIGN SYSTEM - Unified Design Tokens
   
   USAGE: Set theme on <html> element:
     document.documentElement.dataset.theme = 'midnight';
   
   Available themes: default, midnight, ember, forest, ocean, monochrome
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    /* Typography */
    --primary-font: 'Roboto-Bold', sans-serif;
    --secondary-font: Arial, monospace;

    /* ═══════════════════════════════════════════════════════════════════════
       DEFAULT THEME - Blue/Cyan Dark
       ═══════════════════════════════════════════════════════════════════════ */
    
    /* Surface Colors */
    --vico-bg-deep: #12141a;
    --vico-bg-base: #1a1d24;
    --vico-bg-raised: #22262f;
    --vico-bg-elevated: #282d38;
    --vico-bg-hover: #3a4150;
    
    /* Border Colors */
    --vico-border: #2d3340;
    --vico-border-hover: #3a4150;
    --vico-border-focus: #61afef;
    
    /* Text Colors */
    --vico-text-primary: #e4e8ef;
    --vico-text-secondary: #8891a0;
    --vico-text-muted: #5c6370;
    
    /* Accent Colors */
    --vico-accent-blue: #61afef;
    --vico-accent-blue-light: #7cc4ff;
    --vico-accent-green: #98c379;
    --vico-accent-green-light: #a8d389;
    --vico-accent-amber: #e5c07b;
    --vico-accent-amber-light: #f0d090;
    --vico-accent-red: #e06c75;
    --vico-accent-red-dark: #c55a62;
    --vico-accent-purple: #c678dd;
    --vico-accent-purple-light: #d688ed;
    --vico-accent-cyan: #56b6c2;
    
    /* Accent Glows (for focus/shadows) */
    --vico-glow-blue: rgba(97, 175, 239, 0.2);
    --vico-glow-green: rgba(152, 195, 121, 0.2);
    --vico-glow-amber: rgba(229, 192, 123, 0.2);
    --vico-glow-red: rgba(224, 108, 117, 0.2);
    --vico-glow-purple: rgba(198, 120, 221, 0.2);
    --vico-glow-cyan: rgba(86, 182, 194, 0.2);
    
    /* Gradients */
    --vico-gradient-header: linear-gradient(180deg, #22262f 0%, #1a1d24 100%);
    --vico-gradient-blue: linear-gradient(135deg, #61afef 0%, #4a9be0 100%);
    --vico-gradient-green: linear-gradient(135deg, #98c379 0%, #7eb863 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e5c07b 0%, #d4a055 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c678dd 0%, #a855c0 100%);
    
    /* Spacing */
    --vico-space-xs: 4px;
    --vico-space-sm: 8px;
    --vico-space-md: 12px;
    --vico-space-lg: 16px;
    --vico-space-xl: 20px;
    --vico-space-xxl: 32px;
    
    /* Border Radius */
    --vico-radius-sm: 4px;
    --vico-radius-md: 6px;
    --vico-radius-lg: 8px;
    --vico-radius-xl: 12px;
    
    /* Transitions */
    --vico-transition-fast: 0.15s ease;
    --vico-transition-normal: 0.2s ease;
    
    /* Shadows */
    --vico-shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.2);
    --vico-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
    --vico-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);
    --vico-shadow-xl: 0 20px 60px rgba(0, 0, 0, 0.5);
    
    /* Scrollbar */
    --vico-scrollbar-width: 6px;
    --vico-scrollbar-thumb: rgba(97, 175, 239, 0.3);
    --vico-scrollbar-thumb-hover: rgba(97, 175, 239, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MIDNIGHT THEME - Deep Purple/Violet
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="midnight"] {
    --vico-bg-deep: #0d0d14;
    --vico-bg-base: #13131f;
    --vico-bg-raised: #1a1a2e;
    --vico-bg-elevated: #22223a;
    --vico-bg-hover: #2d2d4a;
    
    --vico-border: #2a2a45;
    --vico-border-hover: #3d3d5c;
    --vico-border-focus: #a78bfa;
    
    --vico-text-primary: #e8e6f2;
    --vico-text-secondary: #9590b0;
    --vico-text-muted: #6b6785;
    
    --vico-accent-blue: #818cf8;
    --vico-accent-blue-light: #a5b4fc;
    --vico-accent-green: #86efac;
    --vico-accent-green-light: #a7f3d0;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #fb7185;
    --vico-accent-red-dark: #e11d48;
    --vico-accent-purple: #a78bfa;
    --vico-accent-purple-light: #c4b5fd;
    --vico-accent-cyan: #67e8f9;
    
    --vico-glow-blue: rgba(129, 140, 248, 0.25);
    --vico-glow-green: rgba(134, 239, 172, 0.2);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(251, 113, 133, 0.2);
    --vico-glow-purple: rgba(167, 139, 250, 0.25);
    --vico-glow-cyan: rgba(103, 232, 249, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #1a1a2e 0%, #13131f 100%);
    --vico-gradient-blue: linear-gradient(135deg, #818cf8 0%, #6366f1 100%);
    --vico-gradient-green: linear-gradient(135deg, #86efac 0%, #4ade80 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
    
    --vico-scrollbar-thumb: rgba(167, 139, 250, 0.3);
    --vico-scrollbar-thumb-hover: rgba(167, 139, 250, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   EMBER THEME - Warm Orange/Red
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="ember"] {
    --vico-bg-deep: #140c08;
    --vico-bg-base: #1c1210;
    --vico-bg-raised: #291a16;
    --vico-bg-elevated: #35221c;
    --vico-bg-hover: #4a3028;
    
    --vico-border: #3d2820;
    --vico-border-hover: #5a3d32;
    --vico-border-focus: #f97316;
    
    --vico-text-primary: #fef3e8;
    --vico-text-secondary: #c9a892;
    --vico-text-muted: #8b7263;
    
    --vico-accent-blue: #38bdf8;
    --vico-accent-blue-light: #7dd3fc;
    --vico-accent-green: #84cc16;
    --vico-accent-green-light: #a3e635;
    --vico-accent-amber: #f97316;
    --vico-accent-amber-light: #fb923c;
    --vico-accent-red: #ef4444;
    --vico-accent-red-dark: #dc2626;
    --vico-accent-purple: #e879f9;
    --vico-accent-purple-light: #f0abfc;
    --vico-accent-cyan: #22d3ee;
    
    --vico-glow-blue: rgba(56, 189, 248, 0.2);
    --vico-glow-green: rgba(132, 204, 22, 0.2);
    --vico-glow-amber: rgba(249, 115, 22, 0.25);
    --vico-glow-red: rgba(239, 68, 68, 0.25);
    --vico-glow-purple: rgba(232, 121, 249, 0.2);
    --vico-glow-cyan: rgba(34, 211, 238, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #291a16 0%, #1c1210 100%);
    --vico-gradient-blue: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
    --vico-gradient-green: linear-gradient(135deg, #84cc16 0%, #65a30d 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fb923c 0%, #f97316 100%);
    --vico-gradient-purple: linear-gradient(135deg, #e879f9 0%, #d946ef 100%);
    
    --vico-scrollbar-thumb: rgba(249, 115, 22, 0.3);
    --vico-scrollbar-thumb-hover: rgba(249, 115, 22, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FOREST THEME - Natural Green
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="forest"] {
    --vico-bg-deep: #0a120e;
    --vico-bg-base: #101a14;
    --vico-bg-raised: #16241c;
    --vico-bg-elevated: #1c2e24;
    --vico-bg-hover: #284030;
    
    --vico-border: #243828;
    --vico-border-hover: #345238;
    --vico-border-focus: #4ade80;
    
    --vico-text-primary: #ecfdf5;
    --vico-text-secondary: #a3c4b0;
    --vico-text-muted: #6b8f78;
    
    --vico-accent-blue: #60a5fa;
    --vico-accent-blue-light: #93c5fd;
    --vico-accent-green: #4ade80;
    --vico-accent-green-light: #86efac;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #f87171;
    --vico-accent-red-dark: #ef4444;
    --vico-accent-purple: #c084fc;
    --vico-accent-purple-light: #d8b4fe;
    --vico-accent-cyan: #2dd4bf;
    
    --vico-glow-blue: rgba(96, 165, 250, 0.2);
    --vico-glow-green: rgba(74, 222, 128, 0.25);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(248, 113, 113, 0.2);
    --vico-glow-purple: rgba(192, 132, 252, 0.2);
    --vico-glow-cyan: rgba(45, 212, 191, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #16241c 0%, #101a14 100%);
    --vico-gradient-blue: linear-gradient(135deg, #4ade80 0%, #22c55e 100%);
    --vico-gradient-green: linear-gradient(135deg, #86efac 0%, #4ade80 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c084fc 0%, #a855f7 100%);
    
    --vico-scrollbar-thumb: rgba(74, 222, 128, 0.3);
    --vico-scrollbar-thumb-hover: rgba(74, 222, 128, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   OCEAN THEME - Deep Teal/Aqua
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="ocean"] {
    --vico-bg-deep: #071318;
    --vico-bg-base: #0c1a20;
    --vico-bg-raised: #12252d;
    --vico-bg-elevated: #183038;
    --vico-bg-hover: #234248;
    
    --vico-border: #1e3a42;
    --vico-border-hover: #2d5560;
    --vico-border-focus: #22d3ee;
    
    --vico-text-primary: #e0f7fa;
    --vico-text-secondary: #90cad5;
    --vico-text-muted: #5a9aa5;
    
    --vico-accent-blue: #06b6d4;
    --vico-accent-blue-light: #22d3ee;
    --vico-accent-green: #10b981;
    --vico-accent-green-light: #34d399;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #f43f5e;
    --vico-accent-red-dark: #e11d48;
    --vico-accent-purple: #a78bfa;
    --vico-accent-purple-light: #c4b5fd;
    --vico-accent-cyan: #22d3ee;
    
    --vico-glow-blue: rgba(6, 182, 212, 0.25);
    --vico-glow-green: rgba(16, 185, 129, 0.2);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(244, 63, 94, 0.2);
    --vico-glow-purple: rgba(167, 139, 250, 0.2);
    --vico-glow-cyan: rgba(34, 211, 238, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #12252d 0%, #0c1a20 100%);
    --vico-gradient-blue: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);
    --vico-gradient-green: linear-gradient(135deg, #10b981 0%, #059669 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
    
    --vico-scrollbar-thumb: rgba(34, 211, 238, 0.3);
    --vico-scrollbar-thumb-hover: rgba(34, 211, 238, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MONOCHROME THEME - Elegant Grayscale
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="monochrome"] {
    --vico-bg-deep: #0a0a0a;
    --vico-bg-base: #121212;
    --vico-bg-raised: #1e1e1e;
    --vico-bg-elevated: #2a2a2a;
    --vico-bg-hover: #3a3a3a;
    
    --vico-border: #333333;
    --vico-border-hover: #4a4a4a;
    --vico-border-focus: #888888;
    
    --vico-text-primary: #f0f0f0;
    --vico-text-secondary: #a0a0a0;
    --vico-text-muted: #666666;
    
    --vico-accent-blue: #a0a0a0;
    --vico-accent-blue-light: #c0c0c0;
    --vico-accent-green: #90ee90;
    --vico-accent-green-light: #b0ffb0;
    --vico-accent-amber: #e0c080;
    --vico-accent-amber-light: #f0d090;
    --vico-accent-red: #e07070;
    --vico-accent-red-dark: #c05050;
    --vico-accent-purple: #c0a0d0;
    --vico-accent-purple-light: #d0b0e0;
    --vico-accent-cyan: #80d0d0;
    
    --vico-glow-blue: rgba(160, 160, 160, 0.15);
    --vico-glow-green: rgba(144, 238, 144, 0.15);
    --vico-glow-amber: rgba(224, 192, 128, 0.15);
    --vico-glow-red: rgba(224, 112, 112, 0.15);
    --vico-glow-purple: rgba(192, 160, 208, 0.15);
    --vico-glow-cyan: rgba(128, 208, 208, 0.15);
    
    --vico-gradient-header: linear-gradient(180deg, #1e1e1e 0%, #121212 100%);
    --vico-gradient-blue: linear-gradient(135deg, #888888 0%, #666666 100%);
    --vico-gradient-green: linear-gradient(135deg, #90ee90 0%, #70c070 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e0c080 0%, #c0a060 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c0a0d0 0%, #a080b0 100%);
    
    --vico-scrollbar-thumb: rgba(160, 160, 160, 0.3);
    --vico-scrollbar-thumb-hover: rgba(160, 160, 160, 0.5);
}

/* ═══════════════════════════════════════════════════════════════════════════
   NORD THEME - Arctic, North-Bluish
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="nord"] {
    --vico-bg-deep: #242933;
    --vico-bg-base: #2e3440;
    --vico-bg-raised: #3b4252;
    --vico-bg-elevated: #434c5e;
    --vico-bg-hover: #4c566a;
    
    --vico-border: #4c566a;
    --vico-border-hover: #5e6779;
    --vico-border-focus: #88c0d0;
    
    --vico-text-primary: #eceff4;
    --vico-text-secondary: #d8dee9;
    --vico-text-muted: #7b88a1;
    
    --vico-accent-blue: #81a1c1;
    --vico-accent-blue-light: #88c0d0;
    --vico-accent-green: #a3be8c;
    --vico-accent-green-light: #b5d19c;
    --vico-accent-amber: #ebcb8b;
    --vico-accent-amber-light: #f0d8a8;
    --vico-accent-red: #bf616a;
    --vico-accent-red-dark: #a54e56;
    --vico-accent-purple: #b48ead;
    --vico-accent-purple-light: #c9a8c4;
    --vico-accent-cyan: #8fbcbb;
    
    --vico-glow-blue: rgba(129, 161, 193, 0.2);
    --vico-glow-green: rgba(163, 190, 140, 0.2);
    --vico-glow-amber: rgba(235, 203, 139, 0.2);
    --vico-glow-red: rgba(191, 97, 106, 0.2);
    --vico-glow-purple: rgba(180, 142, 173, 0.2);
    --vico-glow-cyan: rgba(143, 188, 187, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #3b4252 0%, #2e3440 100%);
    --vico-gradient-blue: linear-gradient(135deg, #81a1c1 0%, #5e81ac 100%);
    --vico-gradient-green: linear-gradient(135deg, #a3be8c 0%, #8fbf7f 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ebcb8b 0%, #d7b56a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #b48ead 0%, #9d7496 100%);
    
    --vico-scrollbar-thumb: rgba(136, 192, 208, 0.3);
    --vico-scrollbar-thumb-hover: rgba(136, 192, 208, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CYBERPUNK THEME - Neon Future
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="cyberpunk"] {
    --vico-bg-deep: #0a0a0f;
    --vico-bg-base: #0f0f1a;
    --vico-bg-raised: #1a1a2e;
    --vico-bg-elevated: #252542;
    --vico-bg-hover: #2f2f55;
    
    --vico-border: #ff00ff30;
    --vico-border-hover: #ff00ff60;
    --vico-border-focus: #00ffff;
    
    --vico-text-primary: #ffffff;
    --vico-text-secondary: #b0b0d0;
    --vico-text-muted: #6060a0;
    
    --vico-accent-blue: #00ffff;
    --vico-accent-blue-light: #66ffff;
    --vico-accent-green: #00ff88;
    --vico-accent-green-light: #66ffaa;
    --vico-accent-amber: #ffff00;
    --vico-accent-amber-light: #ffff66;
    --vico-accent-red: #ff0055;
    --vico-accent-red-dark: #cc0044;
    --vico-accent-purple: #ff00ff;
    --vico-accent-purple-light: #ff66ff;
    --vico-accent-cyan: #00ffff;
    
    --vico-glow-blue: rgba(0, 255, 255, 0.3);
    --vico-glow-green: rgba(0, 255, 136, 0.3);
    --vico-glow-amber: rgba(255, 255, 0, 0.3);
    --vico-glow-red: rgba(255, 0, 85, 0.3);
    --vico-glow-purple: rgba(255, 0, 255, 0.3);
    --vico-glow-cyan: rgba(0, 255, 255, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #1a1a2e 0%, #0f0f1a 100%);
    --vico-gradient-blue: linear-gradient(135deg, #00ffff 0%, #0088ff 100%);
    --vico-gradient-green: linear-gradient(135deg, #00ff88 0%, #00cc66 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ffff00 0%, #ffcc00 100%);
    --vico-gradient-purple: linear-gradient(135deg, #ff00ff 0%, #cc00cc 100%);
    
    --vico-scrollbar-thumb: rgba(255, 0, 255, 0.4);
    --vico-scrollbar-thumb-hover: rgba(255, 0, 255, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   DRACULA THEME - Famous Dark Theme
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="dracula"] {
    --vico-bg-deep: #1e1f29;
    --vico-bg-base: #282a36;
    --vico-bg-raised: #343746;
    --vico-bg-elevated: #3d4056;
    --vico-bg-hover: #44475a;
    
    --vico-border: #44475a;
    --vico-border-hover: #5a5e73;
    --vico-border-focus: #bd93f9;
    
    --vico-text-primary: #f8f8f2;
    --vico-text-secondary: #bfc0c5;
    --vico-text-muted: #6272a4;
    
    --vico-accent-blue: #8be9fd;
    --vico-accent-blue-light: #a4edfd;
    --vico-accent-green: #50fa7b;
    --vico-accent-green-light: #73fb95;
    --vico-accent-amber: #f1fa8c;
    --vico-accent-amber-light: #f4fba3;
    --vico-accent-red: #ff5555;
    --vico-accent-red-dark: #e64545;
    --vico-accent-purple: #bd93f9;
    --vico-accent-purple-light: #caa8fa;
    --vico-accent-cyan: #8be9fd;
    
    --vico-glow-blue: rgba(139, 233, 253, 0.25);
    --vico-glow-green: rgba(80, 250, 123, 0.25);
    --vico-glow-amber: rgba(241, 250, 140, 0.2);
    --vico-glow-red: rgba(255, 85, 85, 0.25);
    --vico-glow-purple: rgba(189, 147, 249, 0.25);
    --vico-glow-cyan: rgba(139, 233, 253, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #343746 0%, #282a36 100%);
    --vico-gradient-blue: linear-gradient(135deg, #bd93f9 0%, #9a6dd7 100%);
    --vico-gradient-green: linear-gradient(135deg, #50fa7b 0%, #3dd968 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f1fa8c 0%, #e6ef6a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #ff79c6 0%, #e066a8 100%);
    
    --vico-scrollbar-thumb: rgba(189, 147, 249, 0.4);
    --vico-scrollbar-thumb-hover: rgba(189, 147, 249, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   ROSE PINE THEME - Soft Romantic
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="rosepine"] {
    --vico-bg-deep: #131020;
    --vico-bg-base: #191724;
    --vico-bg-raised: #1f1d2e;
    --vico-bg-elevated: #26233a;
    --vico-bg-hover: #2a2740;
    
    --vico-border: #403d52;
    --vico-border-hover: #524f67;
    --vico-border-focus: #c4a7e7;
    
    --vico-text-primary: #e0def4;
    --vico-text-secondary: #908caa;
    --vico-text-muted: #6e6a86;
    
    --vico-accent-blue: #9ccfd8;
    --vico-accent-blue-light: #b4d9df;
    --vico-accent-green: #31748f;
    --vico-accent-green-light: #4a8da8;
    --vico-accent-amber: #f6c177;
    --vico-accent-amber-light: #f8ce92;
    --vico-accent-red: #eb6f92;
    --vico-accent-red-dark: #d9587c;
    --vico-accent-purple: #c4a7e7;
    --vico-accent-purple-light: #d1b9ed;
    --vico-accent-cyan: #9ccfd8;
    
    --vico-glow-blue: rgba(156, 207, 216, 0.2);
    --vico-glow-green: rgba(49, 116, 143, 0.25);
    --vico-glow-amber: rgba(246, 193, 119, 0.2);
    --vico-glow-red: rgba(235, 111, 146, 0.25);
    --vico-glow-purple: rgba(196, 167, 231, 0.25);
    --vico-glow-cyan: rgba(156, 207, 216, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #1f1d2e 0%, #191724 100%);
    --vico-gradient-blue: linear-gradient(135deg, #c4a7e7 0%, #a78bcc 100%);
    --vico-gradient-green: linear-gradient(135deg, #31748f 0%, #285e74 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f6c177 0%, #eba855 100%);
    --vico-gradient-purple: linear-gradient(135deg, #eb6f92 0%, #d9587c 100%);
    
    --vico-scrollbar-thumb: rgba(196, 167, 231, 0.3);
    --vico-scrollbar-thumb-hover: rgba(196, 167, 231, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   TOKYO NIGHT THEME - Japanese City Nights
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="tokyo"] {
    --vico-bg-deep: #16161e;
    --vico-bg-base: #1a1b26;
    --vico-bg-raised: #24283b;
    --vico-bg-elevated: #2a2e42;
    --vico-bg-hover: #343b58;
    
    --vico-border: #3b4261;
    --vico-border-hover: #4a5075;
    --vico-border-focus: #7aa2f7;
    
    --vico-text-primary: #c0caf5;
    --vico-text-secondary: #9aa5ce;
    --vico-text-muted: #565f89;
    
    --vico-accent-blue: #7aa2f7;
    --vico-accent-blue-light: #99b4f9;
    --vico-accent-green: #9ece6a;
    --vico-accent-green-light: #b3d888;
    --vico-accent-amber: #e0af68;
    --vico-accent-amber-light: #e6bf86;
    --vico-accent-red: #f7768e;
    --vico-accent-red-dark: #e5667c;
    --vico-accent-purple: #bb9af7;
    --vico-accent-purple-light: #c9aef9;
    --vico-accent-cyan: #7dcfff;
    
    --vico-glow-blue: rgba(122, 162, 247, 0.25);
    --vico-glow-green: rgba(158, 206, 106, 0.2);
    --vico-glow-amber: rgba(224, 175, 104, 0.2);
    --vico-glow-red: rgba(247, 118, 142, 0.25);
    --vico-glow-purple: rgba(187, 154, 247, 0.25);
    --vico-glow-cyan: rgba(125, 207, 255, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #24283b 0%, #1a1b26 100%);
    --vico-gradient-blue: linear-gradient(135deg, #7aa2f7 0%, #5d8ae0 100%);
    --vico-gradient-green: linear-gradient(135deg, #9ece6a 0%, #7eb852 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e0af68 0%, #d19a4a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #bb9af7 0%, #a07de0 100%);
    
    --vico-scrollbar-thumb: rgba(122, 162, 247, 0.3);
    --vico-scrollbar-thumb-hover: rgba(122, 162, 247, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SYNTHWAVE THEME - 80s Retro Neon
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="synthwave"] {
    --vico-bg-deep: #12091f;
    --vico-bg-base: #1a1025;
    --vico-bg-raised: #241734;
    --vico-bg-elevated: #2e1f42;
    --vico-bg-hover: #3a2850;
    
    --vico-border: #4a3060;
    --vico-border-hover: #5e4078;
    --vico-border-focus: #f92aad;
    
    --vico-text-primary: #fff0f5;
    --vico-text-secondary: #c8a8d0;
    --vico-text-muted: #7a5988;
    
    --vico-accent-blue: #36f9f6;
    --vico-accent-blue-light: #5ffaf8;
    --vico-accent-green: #72f1b8;
    --vico-accent-green-light: #8ef4c7;
    --vico-accent-amber: #fede5d;
    --vico-accent-amber-light: #fee57d;
    --vico-accent-red: #fe4450;
    --vico-accent-red-dark: #e03a45;
    --vico-accent-purple: #f92aad;
    --vico-accent-purple-light: #fa55bd;
    --vico-accent-cyan: #36f9f6;
    
    --vico-glow-blue: rgba(54, 249, 246, 0.3);
    --vico-glow-green: rgba(114, 241, 184, 0.25);
    --vico-glow-amber: rgba(254, 222, 93, 0.25);
    --vico-glow-red: rgba(254, 68, 80, 0.3);
    --vico-glow-purple: rgba(249, 42, 173, 0.35);
    --vico-glow-cyan: rgba(54, 249, 246, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #241734 0%, #1a1025 100%);
    --vico-gradient-blue: linear-gradient(135deg, #f92aad 0%, #d91e94 100%);
    --vico-gradient-green: linear-gradient(135deg, #72f1b8 0%, #50d89a 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fede5d 0%, #f5c840 100%);
    --vico-gradient-purple: linear-gradient(135deg, #36f9f6 0%, #20d4d1 100%);
    
    --vico-scrollbar-thumb: rgba(249, 42, 173, 0.4);
    --vico-scrollbar-thumb-hover: rgba(249, 42, 173, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   GRUVBOX THEME - Retro Warm
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="gruvbox"] {
    --vico-bg-deep: #1d2021;
    --vico-bg-base: #282828;
    --vico-bg-raised: #32302f;
    --vico-bg-elevated: #3c3836;
    --vico-bg-hover: #504945;
    
    --vico-border: #504945;
    --vico-border-hover: #665c54;
    --vico-border-focus: #fabd2f;
    
    --vico-text-primary: #ebdbb2;
    --vico-text-secondary: #bdae93;
    --vico-text-muted: #928374;
    
    --vico-accent-blue: #83a598;
    --vico-accent-blue-light: #9bb8ac;
    --vico-accent-green: #b8bb26;
    --vico-accent-green-light: #c5c84a;
    --vico-accent-amber: #fabd2f;
    --vico-accent-amber-light: #fbca55;
    --vico-accent-red: #fb4934;
    --vico-accent-red-dark: #cc241d;
    --vico-accent-purple: #d3869b;
    --vico-accent-purple-light: #dda0af;
    --vico-accent-cyan: #8ec07c;
    
    --vico-glow-blue: rgba(131, 165, 152, 0.25);
    --vico-glow-green: rgba(184, 187, 38, 0.2);
    --vico-glow-amber: rgba(250, 189, 47, 0.25);
    --vico-glow-red: rgba(251, 73, 52, 0.25);
    --vico-glow-purple: rgba(211, 134, 155, 0.25);
    --vico-glow-cyan: rgba(142, 192, 124, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #32302f 0%, #282828 100%);
    --vico-gradient-blue: linear-gradient(135deg, #fabd2f 0%, #d79921 100%);
    --vico-gradient-green: linear-gradient(135deg, #b8bb26 0%, #98971a 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fe8019 0%, #d65d0e 100%);
    --vico-gradient-purple: linear-gradient(135deg, #d3869b 0%, #b16286 100%);
    
    --vico-scrollbar-thumb: rgba(250, 189, 47, 0.35);
    --vico-scrollbar-thumb-hover: rgba(250, 189, 47, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CATPPUCCIN MOCHA THEME - Cozy Pastel
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="catppuccin"] {
    --vico-bg-deep: #11111b;
    --vico-bg-base: #1e1e2e;
    --vico-bg-raised: #313244;
    --vico-bg-elevated: #45475a;
    --vico-bg-hover: #585b70;
    
    --vico-border: #45475a;
    --vico-border-hover: #585b70;
    --vico-border-focus: #cba6f7;
    
    --vico-text-primary: #cdd6f4;
    --vico-text-secondary: #bac2de;
    --vico-text-muted: #6c7086;
    
    --vico-accent-blue: #89b4fa;
    --vico-accent-blue-light: #a4c3fb;
    --vico-accent-green: #a6e3a1;
    --vico-accent-green-light: #b8e9b4;
    --vico-accent-amber: #f9e2af;
    --vico-accent-amber-light: #fae8bf;
    --vico-accent-red: #f38ba8;
    --vico-accent-red-dark: #e06c88;
    --vico-accent-purple: #cba6f7;
    --vico-accent-purple-light: #d6b8f9;
    --vico-accent-cyan: #94e2d5;
    
    --vico-glow-blue: rgba(137, 180, 250, 0.25);
    --vico-glow-green: rgba(166, 227, 161, 0.2);
    --vico-glow-amber: rgba(249, 226, 175, 0.2);
    --vico-glow-red: rgba(243, 139, 168, 0.25);
    --vico-glow-purple: rgba(203, 166, 247, 0.25);
    --vico-glow-cyan: rgba(148, 226, 213, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #313244 0%, #1e1e2e 100%);
    --vico-gradient-blue: linear-gradient(135deg, #cba6f7 0%, #b48bdf 100%);
    --vico-gradient-green: linear-gradient(135deg, #a6e3a1 0%, #8bd787 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f9e2af 0%, #f5d38a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #f5c2e7 0%, #e8a8d5 100%);
    
    --vico-scrollbar-thumb: rgba(203, 166, 247, 0.35);
    --vico-scrollbar-thumb-hover: rgba(203, 166, 247, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   AURORA THEME - Northern Lights
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="aurora"] {
    --vico-bg-deep: #0a1014;
    --vico-bg-base: #0f171c;
    --vico-bg-raised: #152028;
    --vico-bg-elevated: #1c2a34;
    --vico-bg-hover: #243540;
    
    --vico-border: #2a4050;
    --vico-border-hover: #3a5568;
    --vico-border-focus: #88ffcc;
    
    --vico-text-primary: #e8f4f0;
    --vico-text-secondary: #a8c8c0;
    --vico-text-muted: #607878;
    
    --vico-accent-blue: #5588ff;
    --vico-accent-blue-light: #77a0ff;
    --vico-accent-green: #88ffcc;
    --vico-accent-green-light: #a0ffd8;
    --vico-accent-amber: #ffdd88;
    --vico-accent-amber-light: #ffe4a0;
    --vico-accent-red: #ff6688;
    --vico-accent-red-dark: #e05070;
    --vico-accent-purple: #cc88ff;
    --vico-accent-purple-light: #d8a0ff;
    --vico-accent-cyan: #66eeff;
    
    --vico-glow-blue: rgba(85, 136, 255, 0.25);
    --vico-glow-green: rgba(136, 255, 204, 0.3);
    --vico-glow-amber: rgba(255, 221, 136, 0.2);
    --vico-glow-red: rgba(255, 102, 136, 0.25);
    --vico-glow-purple: rgba(204, 136, 255, 0.25);
    --vico-glow-cyan: rgba(102, 238, 255, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #152028 0%, #0f171c 100%);
    --vico-gradient-blue: linear-gradient(135deg, #88ffcc 0%, #55ddaa 100%);
    --vico-gradient-green: linear-gradient(135deg, #66eeff 0%, #44ccdd 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ffdd88 0%, #f0c060 100%);
    --vico-gradient-purple: linear-gradient(135deg, #cc88ff 0%, #aa66dd 100%);
    
    --vico-scrollbar-thumb: rgba(136, 255, 204, 0.35);
    --vico-scrollbar-thumb-hover: rgba(136, 255, 204, 0.6);
}

/* Generic spin centered on element already translated to center */
@keyframes spin-center {
  0% { transform: translate(-50%, -50%) rotate(0deg); }
  100% { transform: translate(-50%, -50%) rotate(360deg); }
}

/* Blink utility */
@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}

.is-spinning {
  animation: spin-center 1s linear infinite;
}

.is-blinking {
  animation: blink 1s infinite;
}

/* Pulsing outline for attention cues (used by pulseUIElement) */
.ui-pulse-outline {
  position: relative;
  outline: 2px solid #ffb800 !important;
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(255, 184, 0, 0.6) !important;
  animation: uiPulseOutlineAnim 0.95s ease-in-out infinite alternate;
  transform-origin: center;
}

@keyframes uiPulseOutlineAnim {
  0% {
    box-shadow: 0 0 0 2px rgba(255, 184, 0, 0.65);
    transform: scale(1);
    filter: drop-shadow(0 0 6px rgba(255, 184, 0, 0.6));
  }
  50% {
    box-shadow: 0 0 0 12px rgba(255, 184, 0, 0.0);
    transform: scale(1.03);
    filter: drop-shadow(0 0 12px rgba(255, 184, 0, 0.35));
  }
  100% {
    box-shadow: 0 0 0 2px rgba(255, 184, 0, 0.65);
    transform: scale(1);
    filter: drop-shadow(0 0 6px rgba(255, 184, 0, 0.6));
  }
}


.loading-spinner {
    border: 5px solid var(--vico-accent-blue);
    border-top: 5px solid var(--vico-accent-blue-light, rgba(96, 165, 250, 0.3));
    border-radius: 50%;
    width: 80px;
    height: 80px;
    animation: spin-center 0.8s linear infinite;
    position: fixed;
    z-index: 9999;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

/* Base button primitive */
.btn,
.popup-button,
.abp-button,
.quiz-submit,
.step-details-ok-button,
.step-nav-back,
.step-nav-replay,
.step-nav-proceed,
.join-room-btn,
.create-now-btn,
.abp-select-button,
.abp-delete-button,
.um-button,
.popup-button.edit-user-btn,
.ss-details-btn,
.ss-room-join-btn,
.lesp-btn,
.lesp-add-btn,
.lesp-action-btn,
.lesp-edit-btn,
.lesp-delete-btn,
.lesp-test-btn,
.lesp-test-step-btn,
.lesp-stop-step-btn,
.lp-button,
.lp-button-secondary,
.adm-button,
.settings-ar-button,
.settings-reset-button,
.ufm-button,
.ufm-delete-button,
.uap-button.uap-submit-btn,
.settings-cache-button,
.settings-clear-button,
.dropdown-item,
.qesp-remove-question-btn,
.qesp-remove-answer-btn,
.qesp-browse-image-btn,
.qesp-clear-image-btn,
.qesp-add-question-btn,
.qesp-add-answer-btn,
.qesp-collapse-btn {
  padding: var(--vico-space-md) var(--vico-space-xl);
  border: none;
  border-radius: var(--vico-radius-md);
  cursor: pointer;
  font-size: 1rem;
  font-weight: 600;
  font-family: var(--primary-font);
  transition: background var(--vico-transition-fast), color var(--vico-transition-fast), transform 0.1s ease, box-shadow var(--vico-transition-fast);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  pointer-events: auto;
  box-sizing: border-box;
}

/* Primary */
.btn-primary,
.popup-button,
.quiz-submit {
  background: var(--vico-gradient-blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(97, 175, 239, 0.3);
}

.btn-primary:hover,
.popup-button:hover:not(:disabled),
.quiz-submit:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--vico-accent-blue-light) 0%, var(--vico-accent-blue) 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(97, 175, 239, 0.4);
}

.btn-primary:disabled,
.popup-button:disabled,
.quiz-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

/* Ghost / neutral */
.btn-ghost {
  background: var(--vico-bg-raised);
  color: var(--vico-text-secondary);
  border: 1px solid var(--vico-border);
  text-align: start;
}

.btn-ghost:hover {
  background: var(--vico-bg-elevated);
  color: var(--vico-text-primary);
  box-shadow: var(--vico-shadow-sm);
  transform: translateY(-1px);
}

/* Blink utility */
.btn.blink {
  animation: blink 1s infinite;
}

@keyframes blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   VICO DESIGN SYSTEM - Unified Design Tokens
   
   USAGE: Set theme on <html> element:
     document.documentElement.dataset.theme = 'midnight';
   
   Available themes: default, midnight, ember, forest, ocean, monochrome
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    /* Typography */
    --primary-font: 'Roboto-Bold', sans-serif;
    --secondary-font: Arial, monospace;

    /* ═══════════════════════════════════════════════════════════════════════
       DEFAULT THEME - Blue/Cyan Dark
       ═══════════════════════════════════════════════════════════════════════ */
    
    /* Surface Colors */
    --vico-bg-deep: #12141a;
    --vico-bg-base: #1a1d24;
    --vico-bg-raised: #22262f;
    --vico-bg-elevated: #282d38;
    --vico-bg-hover: #3a4150;
    
    /* Border Colors */
    --vico-border: #2d3340;
    --vico-border-hover: #3a4150;
    --vico-border-focus: #61afef;
    
    /* Text Colors */
    --vico-text-primary: #e4e8ef;
    --vico-text-secondary: #8891a0;
    --vico-text-muted: #5c6370;
    
    /* Accent Colors */
    --vico-accent-blue: #61afef;
    --vico-accent-blue-light: #7cc4ff;
    --vico-accent-green: #98c379;
    --vico-accent-green-light: #a8d389;
    --vico-accent-amber: #e5c07b;
    --vico-accent-amber-light: #f0d090;
    --vico-accent-red: #e06c75;
    --vico-accent-red-dark: #c55a62;
    --vico-accent-purple: #c678dd;
    --vico-accent-purple-light: #d688ed;
    --vico-accent-cyan: #56b6c2;
    
    /* Accent Glows (for focus/shadows) */
    --vico-glow-blue: rgba(97, 175, 239, 0.2);
    --vico-glow-green: rgba(152, 195, 121, 0.2);
    --vico-glow-amber: rgba(229, 192, 123, 0.2);
    --vico-glow-red: rgba(224, 108, 117, 0.2);
    --vico-glow-purple: rgba(198, 120, 221, 0.2);
    --vico-glow-cyan: rgba(86, 182, 194, 0.2);
    
    /* Gradients */
    --vico-gradient-header: linear-gradient(180deg, #22262f 0%, #1a1d24 100%);
    --vico-gradient-blue: linear-gradient(135deg, #61afef 0%, #4a9be0 100%);
    --vico-gradient-green: linear-gradient(135deg, #98c379 0%, #7eb863 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e5c07b 0%, #d4a055 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c678dd 0%, #a855c0 100%);
    
    /* Spacing */
    --vico-space-xs: 4px;
    --vico-space-sm: 8px;
    --vico-space-md: 12px;
    --vico-space-lg: 16px;
    --vico-space-xl: 20px;
    --vico-space-xxl: 32px;
    
    /* Border Radius */
    --vico-radius-sm: 4px;
    --vico-radius-md: 6px;
    --vico-radius-lg: 8px;
    --vico-radius-xl: 12px;
    
    /* Transitions */
    --vico-transition-fast: 0.15s ease;
    --vico-transition-normal: 0.2s ease;
    
    /* Shadows */
    --vico-shadow-sm: 0 2px 6px rgba(0, 0, 0, 0.2);
    --vico-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
    --vico-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);
    --vico-shadow-xl: 0 20px 60px rgba(0, 0, 0, 0.5);
    
    /* Scrollbar */
    --vico-scrollbar-width: 6px;
    --vico-scrollbar-thumb: rgba(97, 175, 239, 0.3);
    --vico-scrollbar-thumb-hover: rgba(97, 175, 239, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MIDNIGHT THEME - Deep Purple/Violet
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="midnight"] {
    --vico-bg-deep: #0d0d14;
    --vico-bg-base: #13131f;
    --vico-bg-raised: #1a1a2e;
    --vico-bg-elevated: #22223a;
    --vico-bg-hover: #2d2d4a;
    
    --vico-border: #2a2a45;
    --vico-border-hover: #3d3d5c;
    --vico-border-focus: #a78bfa;
    
    --vico-text-primary: #e8e6f2;
    --vico-text-secondary: #9590b0;
    --vico-text-muted: #6b6785;
    
    --vico-accent-blue: #818cf8;
    --vico-accent-blue-light: #a5b4fc;
    --vico-accent-green: #86efac;
    --vico-accent-green-light: #a7f3d0;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #fb7185;
    --vico-accent-red-dark: #e11d48;
    --vico-accent-purple: #a78bfa;
    --vico-accent-purple-light: #c4b5fd;
    --vico-accent-cyan: #67e8f9;
    
    --vico-glow-blue: rgba(129, 140, 248, 0.25);
    --vico-glow-green: rgba(134, 239, 172, 0.2);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(251, 113, 133, 0.2);
    --vico-glow-purple: rgba(167, 139, 250, 0.25);
    --vico-glow-cyan: rgba(103, 232, 249, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #1a1a2e 0%, #13131f 100%);
    --vico-gradient-blue: linear-gradient(135deg, #818cf8 0%, #6366f1 100%);
    --vico-gradient-green: linear-gradient(135deg, #86efac 0%, #4ade80 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
    
    --vico-scrollbar-thumb: rgba(167, 139, 250, 0.3);
    --vico-scrollbar-thumb-hover: rgba(167, 139, 250, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   EMBER THEME - Warm Orange/Red
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="ember"] {
    --vico-bg-deep: #140c08;
    --vico-bg-base: #1c1210;
    --vico-bg-raised: #291a16;
    --vico-bg-elevated: #35221c;
    --vico-bg-hover: #4a3028;
    
    --vico-border: #3d2820;
    --vico-border-hover: #5a3d32;
    --vico-border-focus: #f97316;
    
    --vico-text-primary: #fef3e8;
    --vico-text-secondary: #c9a892;
    --vico-text-muted: #8b7263;
    
    --vico-accent-blue: #38bdf8;
    --vico-accent-blue-light: #7dd3fc;
    --vico-accent-green: #84cc16;
    --vico-accent-green-light: #a3e635;
    --vico-accent-amber: #f97316;
    --vico-accent-amber-light: #fb923c;
    --vico-accent-red: #ef4444;
    --vico-accent-red-dark: #dc2626;
    --vico-accent-purple: #e879f9;
    --vico-accent-purple-light: #f0abfc;
    --vico-accent-cyan: #22d3ee;
    
    --vico-glow-blue: rgba(56, 189, 248, 0.2);
    --vico-glow-green: rgba(132, 204, 22, 0.2);
    --vico-glow-amber: rgba(249, 115, 22, 0.25);
    --vico-glow-red: rgba(239, 68, 68, 0.25);
    --vico-glow-purple: rgba(232, 121, 249, 0.2);
    --vico-glow-cyan: rgba(34, 211, 238, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #291a16 0%, #1c1210 100%);
    --vico-gradient-blue: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
    --vico-gradient-green: linear-gradient(135deg, #84cc16 0%, #65a30d 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fb923c 0%, #f97316 100%);
    --vico-gradient-purple: linear-gradient(135deg, #e879f9 0%, #d946ef 100%);
    
    --vico-scrollbar-thumb: rgba(249, 115, 22, 0.3);
    --vico-scrollbar-thumb-hover: rgba(249, 115, 22, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FOREST THEME - Natural Green
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="forest"] {
    --vico-bg-deep: #0a120e;
    --vico-bg-base: #101a14;
    --vico-bg-raised: #16241c;
    --vico-bg-elevated: #1c2e24;
    --vico-bg-hover: #284030;
    
    --vico-border: #243828;
    --vico-border-hover: #345238;
    --vico-border-focus: #4ade80;
    
    --vico-text-primary: #ecfdf5;
    --vico-text-secondary: #a3c4b0;
    --vico-text-muted: #6b8f78;
    
    --vico-accent-blue: #60a5fa;
    --vico-accent-blue-light: #93c5fd;
    --vico-accent-green: #4ade80;
    --vico-accent-green-light: #86efac;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #f87171;
    --vico-accent-red-dark: #ef4444;
    --vico-accent-purple: #c084fc;
    --vico-accent-purple-light: #d8b4fe;
    --vico-accent-cyan: #2dd4bf;
    
    --vico-glow-blue: rgba(96, 165, 250, 0.2);
    --vico-glow-green: rgba(74, 222, 128, 0.25);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(248, 113, 113, 0.2);
    --vico-glow-purple: rgba(192, 132, 252, 0.2);
    --vico-glow-cyan: rgba(45, 212, 191, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #16241c 0%, #101a14 100%);
    --vico-gradient-blue: linear-gradient(135deg, #4ade80 0%, #22c55e 100%);
    --vico-gradient-green: linear-gradient(135deg, #86efac 0%, #4ade80 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c084fc 0%, #a855f7 100%);
    
    --vico-scrollbar-thumb: rgba(74, 222, 128, 0.3);
    --vico-scrollbar-thumb-hover: rgba(74, 222, 128, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   OCEAN THEME - Deep Teal/Aqua
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="ocean"] {
    --vico-bg-deep: #071318;
    --vico-bg-base: #0c1a20;
    --vico-bg-raised: #12252d;
    --vico-bg-elevated: #183038;
    --vico-bg-hover: #234248;
    
    --vico-border: #1e3a42;
    --vico-border-hover: #2d5560;
    --vico-border-focus: #22d3ee;
    
    --vico-text-primary: #e0f7fa;
    --vico-text-secondary: #90cad5;
    --vico-text-muted: #5a9aa5;
    
    --vico-accent-blue: #06b6d4;
    --vico-accent-blue-light: #22d3ee;
    --vico-accent-green: #10b981;
    --vico-accent-green-light: #34d399;
    --vico-accent-amber: #fbbf24;
    --vico-accent-amber-light: #fcd34d;
    --vico-accent-red: #f43f5e;
    --vico-accent-red-dark: #e11d48;
    --vico-accent-purple: #a78bfa;
    --vico-accent-purple-light: #c4b5fd;
    --vico-accent-cyan: #22d3ee;
    
    --vico-glow-blue: rgba(6, 182, 212, 0.25);
    --vico-glow-green: rgba(16, 185, 129, 0.2);
    --vico-glow-amber: rgba(251, 191, 36, 0.2);
    --vico-glow-red: rgba(244, 63, 94, 0.2);
    --vico-glow-purple: rgba(167, 139, 250, 0.2);
    --vico-glow-cyan: rgba(34, 211, 238, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #12252d 0%, #0c1a20 100%);
    --vico-gradient-blue: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%);
    --vico-gradient-green: linear-gradient(135deg, #10b981 0%, #059669 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%);
    --vico-gradient-purple: linear-gradient(135deg, #a78bfa 0%, #8b5cf6 100%);
    
    --vico-scrollbar-thumb: rgba(34, 211, 238, 0.3);
    --vico-scrollbar-thumb-hover: rgba(34, 211, 238, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MONOCHROME THEME - Elegant Grayscale
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="monochrome"] {
    --vico-bg-deep: #0a0a0a;
    --vico-bg-base: #121212;
    --vico-bg-raised: #1e1e1e;
    --vico-bg-elevated: #2a2a2a;
    --vico-bg-hover: #3a3a3a;
    
    --vico-border: #333333;
    --vico-border-hover: #4a4a4a;
    --vico-border-focus: #888888;
    
    --vico-text-primary: #f0f0f0;
    --vico-text-secondary: #a0a0a0;
    --vico-text-muted: #666666;
    
    --vico-accent-blue: #a0a0a0;
    --vico-accent-blue-light: #c0c0c0;
    --vico-accent-green: #90ee90;
    --vico-accent-green-light: #b0ffb0;
    --vico-accent-amber: #e0c080;
    --vico-accent-amber-light: #f0d090;
    --vico-accent-red: #e07070;
    --vico-accent-red-dark: #c05050;
    --vico-accent-purple: #c0a0d0;
    --vico-accent-purple-light: #d0b0e0;
    --vico-accent-cyan: #80d0d0;
    
    --vico-glow-blue: rgba(160, 160, 160, 0.15);
    --vico-glow-green: rgba(144, 238, 144, 0.15);
    --vico-glow-amber: rgba(224, 192, 128, 0.15);
    --vico-glow-red: rgba(224, 112, 112, 0.15);
    --vico-glow-purple: rgba(192, 160, 208, 0.15);
    --vico-glow-cyan: rgba(128, 208, 208, 0.15);
    
    --vico-gradient-header: linear-gradient(180deg, #1e1e1e 0%, #121212 100%);
    --vico-gradient-blue: linear-gradient(135deg, #888888 0%, #666666 100%);
    --vico-gradient-green: linear-gradient(135deg, #90ee90 0%, #70c070 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e0c080 0%, #c0a060 100%);
    --vico-gradient-purple: linear-gradient(135deg, #c0a0d0 0%, #a080b0 100%);
    
    --vico-scrollbar-thumb: rgba(160, 160, 160, 0.3);
    --vico-scrollbar-thumb-hover: rgba(160, 160, 160, 0.5);
}

/* ═══════════════════════════════════════════════════════════════════════════
   NORD THEME - Arctic, North-Bluish
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="nord"] {
    --vico-bg-deep: #242933;
    --vico-bg-base: #2e3440;
    --vico-bg-raised: #3b4252;
    --vico-bg-elevated: #434c5e;
    --vico-bg-hover: #4c566a;
    
    --vico-border: #4c566a;
    --vico-border-hover: #5e6779;
    --vico-border-focus: #88c0d0;
    
    --vico-text-primary: #eceff4;
    --vico-text-secondary: #d8dee9;
    --vico-text-muted: #7b88a1;
    
    --vico-accent-blue: #81a1c1;
    --vico-accent-blue-light: #88c0d0;
    --vico-accent-green: #a3be8c;
    --vico-accent-green-light: #b5d19c;
    --vico-accent-amber: #ebcb8b;
    --vico-accent-amber-light: #f0d8a8;
    --vico-accent-red: #bf616a;
    --vico-accent-red-dark: #a54e56;
    --vico-accent-purple: #b48ead;
    --vico-accent-purple-light: #c9a8c4;
    --vico-accent-cyan: #8fbcbb;
    
    --vico-glow-blue: rgba(129, 161, 193, 0.2);
    --vico-glow-green: rgba(163, 190, 140, 0.2);
    --vico-glow-amber: rgba(235, 203, 139, 0.2);
    --vico-glow-red: rgba(191, 97, 106, 0.2);
    --vico-glow-purple: rgba(180, 142, 173, 0.2);
    --vico-glow-cyan: rgba(143, 188, 187, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #3b4252 0%, #2e3440 100%);
    --vico-gradient-blue: linear-gradient(135deg, #81a1c1 0%, #5e81ac 100%);
    --vico-gradient-green: linear-gradient(135deg, #a3be8c 0%, #8fbf7f 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ebcb8b 0%, #d7b56a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #b48ead 0%, #9d7496 100%);
    
    --vico-scrollbar-thumb: rgba(136, 192, 208, 0.3);
    --vico-scrollbar-thumb-hover: rgba(136, 192, 208, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CYBERPUNK THEME - Neon Future
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="cyberpunk"] {
    --vico-bg-deep: #0a0a0f;
    --vico-bg-base: #0f0f1a;
    --vico-bg-raised: #1a1a2e;
    --vico-bg-elevated: #252542;
    --vico-bg-hover: #2f2f55;
    
    --vico-border: #ff00ff30;
    --vico-border-hover: #ff00ff60;
    --vico-border-focus: #00ffff;
    
    --vico-text-primary: #ffffff;
    --vico-text-secondary: #b0b0d0;
    --vico-text-muted: #6060a0;
    
    --vico-accent-blue: #00ffff;
    --vico-accent-blue-light: #66ffff;
    --vico-accent-green: #00ff88;
    --vico-accent-green-light: #66ffaa;
    --vico-accent-amber: #ffff00;
    --vico-accent-amber-light: #ffff66;
    --vico-accent-red: #ff0055;
    --vico-accent-red-dark: #cc0044;
    --vico-accent-purple: #ff00ff;
    --vico-accent-purple-light: #ff66ff;
    --vico-accent-cyan: #00ffff;
    
    --vico-glow-blue: rgba(0, 255, 255, 0.3);
    --vico-glow-green: rgba(0, 255, 136, 0.3);
    --vico-glow-amber: rgba(255, 255, 0, 0.3);
    --vico-glow-red: rgba(255, 0, 85, 0.3);
    --vico-glow-purple: rgba(255, 0, 255, 0.3);
    --vico-glow-cyan: rgba(0, 255, 255, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #1a1a2e 0%, #0f0f1a 100%);
    --vico-gradient-blue: linear-gradient(135deg, #00ffff 0%, #0088ff 100%);
    --vico-gradient-green: linear-gradient(135deg, #00ff88 0%, #00cc66 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ffff00 0%, #ffcc00 100%);
    --vico-gradient-purple: linear-gradient(135deg, #ff00ff 0%, #cc00cc 100%);
    
    --vico-scrollbar-thumb: rgba(255, 0, 255, 0.4);
    --vico-scrollbar-thumb-hover: rgba(255, 0, 255, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   DRACULA THEME - Famous Dark Theme
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="dracula"] {
    --vico-bg-deep: #1e1f29;
    --vico-bg-base: #282a36;
    --vico-bg-raised: #343746;
    --vico-bg-elevated: #3d4056;
    --vico-bg-hover: #44475a;
    
    --vico-border: #44475a;
    --vico-border-hover: #5a5e73;
    --vico-border-focus: #bd93f9;
    
    --vico-text-primary: #f8f8f2;
    --vico-text-secondary: #bfc0c5;
    --vico-text-muted: #6272a4;
    
    --vico-accent-blue: #8be9fd;
    --vico-accent-blue-light: #a4edfd;
    --vico-accent-green: #50fa7b;
    --vico-accent-green-light: #73fb95;
    --vico-accent-amber: #f1fa8c;
    --vico-accent-amber-light: #f4fba3;
    --vico-accent-red: #ff5555;
    --vico-accent-red-dark: #e64545;
    --vico-accent-purple: #bd93f9;
    --vico-accent-purple-light: #caa8fa;
    --vico-accent-cyan: #8be9fd;
    
    --vico-glow-blue: rgba(139, 233, 253, 0.25);
    --vico-glow-green: rgba(80, 250, 123, 0.25);
    --vico-glow-amber: rgba(241, 250, 140, 0.2);
    --vico-glow-red: rgba(255, 85, 85, 0.25);
    --vico-glow-purple: rgba(189, 147, 249, 0.25);
    --vico-glow-cyan: rgba(139, 233, 253, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #343746 0%, #282a36 100%);
    --vico-gradient-blue: linear-gradient(135deg, #bd93f9 0%, #9a6dd7 100%);
    --vico-gradient-green: linear-gradient(135deg, #50fa7b 0%, #3dd968 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f1fa8c 0%, #e6ef6a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #ff79c6 0%, #e066a8 100%);
    
    --vico-scrollbar-thumb: rgba(189, 147, 249, 0.4);
    --vico-scrollbar-thumb-hover: rgba(189, 147, 249, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   ROSE PINE THEME - Soft Romantic
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="rosepine"] {
    --vico-bg-deep: #131020;
    --vico-bg-base: #191724;
    --vico-bg-raised: #1f1d2e;
    --vico-bg-elevated: #26233a;
    --vico-bg-hover: #2a2740;
    
    --vico-border: #403d52;
    --vico-border-hover: #524f67;
    --vico-border-focus: #c4a7e7;
    
    --vico-text-primary: #e0def4;
    --vico-text-secondary: #908caa;
    --vico-text-muted: #6e6a86;
    
    --vico-accent-blue: #9ccfd8;
    --vico-accent-blue-light: #b4d9df;
    --vico-accent-green: #31748f;
    --vico-accent-green-light: #4a8da8;
    --vico-accent-amber: #f6c177;
    --vico-accent-amber-light: #f8ce92;
    --vico-accent-red: #eb6f92;
    --vico-accent-red-dark: #d9587c;
    --vico-accent-purple: #c4a7e7;
    --vico-accent-purple-light: #d1b9ed;
    --vico-accent-cyan: #9ccfd8;
    
    --vico-glow-blue: rgba(156, 207, 216, 0.2);
    --vico-glow-green: rgba(49, 116, 143, 0.25);
    --vico-glow-amber: rgba(246, 193, 119, 0.2);
    --vico-glow-red: rgba(235, 111, 146, 0.25);
    --vico-glow-purple: rgba(196, 167, 231, 0.25);
    --vico-glow-cyan: rgba(156, 207, 216, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #1f1d2e 0%, #191724 100%);
    --vico-gradient-blue: linear-gradient(135deg, #c4a7e7 0%, #a78bcc 100%);
    --vico-gradient-green: linear-gradient(135deg, #31748f 0%, #285e74 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f6c177 0%, #eba855 100%);
    --vico-gradient-purple: linear-gradient(135deg, #eb6f92 0%, #d9587c 100%);
    
    --vico-scrollbar-thumb: rgba(196, 167, 231, 0.3);
    --vico-scrollbar-thumb-hover: rgba(196, 167, 231, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   TOKYO NIGHT THEME - Japanese City Nights
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="tokyo"] {
    --vico-bg-deep: #16161e;
    --vico-bg-base: #1a1b26;
    --vico-bg-raised: #24283b;
    --vico-bg-elevated: #2a2e42;
    --vico-bg-hover: #343b58;
    
    --vico-border: #3b4261;
    --vico-border-hover: #4a5075;
    --vico-border-focus: #7aa2f7;
    
    --vico-text-primary: #c0caf5;
    --vico-text-secondary: #9aa5ce;
    --vico-text-muted: #565f89;
    
    --vico-accent-blue: #7aa2f7;
    --vico-accent-blue-light: #99b4f9;
    --vico-accent-green: #9ece6a;
    --vico-accent-green-light: #b3d888;
    --vico-accent-amber: #e0af68;
    --vico-accent-amber-light: #e6bf86;
    --vico-accent-red: #f7768e;
    --vico-accent-red-dark: #e5667c;
    --vico-accent-purple: #bb9af7;
    --vico-accent-purple-light: #c9aef9;
    --vico-accent-cyan: #7dcfff;
    
    --vico-glow-blue: rgba(122, 162, 247, 0.25);
    --vico-glow-green: rgba(158, 206, 106, 0.2);
    --vico-glow-amber: rgba(224, 175, 104, 0.2);
    --vico-glow-red: rgba(247, 118, 142, 0.25);
    --vico-glow-purple: rgba(187, 154, 247, 0.25);
    --vico-glow-cyan: rgba(125, 207, 255, 0.25);
    
    --vico-gradient-header: linear-gradient(180deg, #24283b 0%, #1a1b26 100%);
    --vico-gradient-blue: linear-gradient(135deg, #7aa2f7 0%, #5d8ae0 100%);
    --vico-gradient-green: linear-gradient(135deg, #9ece6a 0%, #7eb852 100%);
    --vico-gradient-amber: linear-gradient(135deg, #e0af68 0%, #d19a4a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #bb9af7 0%, #a07de0 100%);
    
    --vico-scrollbar-thumb: rgba(122, 162, 247, 0.3);
    --vico-scrollbar-thumb-hover: rgba(122, 162, 247, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SYNTHWAVE THEME - 80s Retro Neon
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="synthwave"] {
    --vico-bg-deep: #12091f;
    --vico-bg-base: #1a1025;
    --vico-bg-raised: #241734;
    --vico-bg-elevated: #2e1f42;
    --vico-bg-hover: #3a2850;
    
    --vico-border: #4a3060;
    --vico-border-hover: #5e4078;
    --vico-border-focus: #f92aad;
    
    --vico-text-primary: #fff0f5;
    --vico-text-secondary: #c8a8d0;
    --vico-text-muted: #7a5988;
    
    --vico-accent-blue: #36f9f6;
    --vico-accent-blue-light: #5ffaf8;
    --vico-accent-green: #72f1b8;
    --vico-accent-green-light: #8ef4c7;
    --vico-accent-amber: #fede5d;
    --vico-accent-amber-light: #fee57d;
    --vico-accent-red: #fe4450;
    --vico-accent-red-dark: #e03a45;
    --vico-accent-purple: #f92aad;
    --vico-accent-purple-light: #fa55bd;
    --vico-accent-cyan: #36f9f6;
    
    --vico-glow-blue: rgba(54, 249, 246, 0.3);
    --vico-glow-green: rgba(114, 241, 184, 0.25);
    --vico-glow-amber: rgba(254, 222, 93, 0.25);
    --vico-glow-red: rgba(254, 68, 80, 0.3);
    --vico-glow-purple: rgba(249, 42, 173, 0.35);
    --vico-glow-cyan: rgba(54, 249, 246, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #241734 0%, #1a1025 100%);
    --vico-gradient-blue: linear-gradient(135deg, #f92aad 0%, #d91e94 100%);
    --vico-gradient-green: linear-gradient(135deg, #72f1b8 0%, #50d89a 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fede5d 0%, #f5c840 100%);
    --vico-gradient-purple: linear-gradient(135deg, #36f9f6 0%, #20d4d1 100%);
    
    --vico-scrollbar-thumb: rgba(249, 42, 173, 0.4);
    --vico-scrollbar-thumb-hover: rgba(249, 42, 173, 0.7);
}

/* ═══════════════════════════════════════════════════════════════════════════
   GRUVBOX THEME - Retro Warm
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="gruvbox"] {
    --vico-bg-deep: #1d2021;
    --vico-bg-base: #282828;
    --vico-bg-raised: #32302f;
    --vico-bg-elevated: #3c3836;
    --vico-bg-hover: #504945;
    
    --vico-border: #504945;
    --vico-border-hover: #665c54;
    --vico-border-focus: #fabd2f;
    
    --vico-text-primary: #ebdbb2;
    --vico-text-secondary: #bdae93;
    --vico-text-muted: #928374;
    
    --vico-accent-blue: #83a598;
    --vico-accent-blue-light: #9bb8ac;
    --vico-accent-green: #b8bb26;
    --vico-accent-green-light: #c5c84a;
    --vico-accent-amber: #fabd2f;
    --vico-accent-amber-light: #fbca55;
    --vico-accent-red: #fb4934;
    --vico-accent-red-dark: #cc241d;
    --vico-accent-purple: #d3869b;
    --vico-accent-purple-light: #dda0af;
    --vico-accent-cyan: #8ec07c;
    
    --vico-glow-blue: rgba(131, 165, 152, 0.25);
    --vico-glow-green: rgba(184, 187, 38, 0.2);
    --vico-glow-amber: rgba(250, 189, 47, 0.25);
    --vico-glow-red: rgba(251, 73, 52, 0.25);
    --vico-glow-purple: rgba(211, 134, 155, 0.25);
    --vico-glow-cyan: rgba(142, 192, 124, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #32302f 0%, #282828 100%);
    --vico-gradient-blue: linear-gradient(135deg, #fabd2f 0%, #d79921 100%);
    --vico-gradient-green: linear-gradient(135deg, #b8bb26 0%, #98971a 100%);
    --vico-gradient-amber: linear-gradient(135deg, #fe8019 0%, #d65d0e 100%);
    --vico-gradient-purple: linear-gradient(135deg, #d3869b 0%, #b16286 100%);
    
    --vico-scrollbar-thumb: rgba(250, 189, 47, 0.35);
    --vico-scrollbar-thumb-hover: rgba(250, 189, 47, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   CATPPUCCIN MOCHA THEME - Cozy Pastel
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="catppuccin"] {
    --vico-bg-deep: #11111b;
    --vico-bg-base: #1e1e2e;
    --vico-bg-raised: #313244;
    --vico-bg-elevated: #45475a;
    --vico-bg-hover: #585b70;
    
    --vico-border: #45475a;
    --vico-border-hover: #585b70;
    --vico-border-focus: #cba6f7;
    
    --vico-text-primary: #cdd6f4;
    --vico-text-secondary: #bac2de;
    --vico-text-muted: #6c7086;
    
    --vico-accent-blue: #89b4fa;
    --vico-accent-blue-light: #a4c3fb;
    --vico-accent-green: #a6e3a1;
    --vico-accent-green-light: #b8e9b4;
    --vico-accent-amber: #f9e2af;
    --vico-accent-amber-light: #fae8bf;
    --vico-accent-red: #f38ba8;
    --vico-accent-red-dark: #e06c88;
    --vico-accent-purple: #cba6f7;
    --vico-accent-purple-light: #d6b8f9;
    --vico-accent-cyan: #94e2d5;
    
    --vico-glow-blue: rgba(137, 180, 250, 0.25);
    --vico-glow-green: rgba(166, 227, 161, 0.2);
    --vico-glow-amber: rgba(249, 226, 175, 0.2);
    --vico-glow-red: rgba(243, 139, 168, 0.25);
    --vico-glow-purple: rgba(203, 166, 247, 0.25);
    --vico-glow-cyan: rgba(148, 226, 213, 0.2);
    
    --vico-gradient-header: linear-gradient(180deg, #313244 0%, #1e1e2e 100%);
    --vico-gradient-blue: linear-gradient(135deg, #cba6f7 0%, #b48bdf 100%);
    --vico-gradient-green: linear-gradient(135deg, #a6e3a1 0%, #8bd787 100%);
    --vico-gradient-amber: linear-gradient(135deg, #f9e2af 0%, #f5d38a 100%);
    --vico-gradient-purple: linear-gradient(135deg, #f5c2e7 0%, #e8a8d5 100%);
    
    --vico-scrollbar-thumb: rgba(203, 166, 247, 0.35);
    --vico-scrollbar-thumb-hover: rgba(203, 166, 247, 0.6);
}

/* ═══════════════════════════════════════════════════════════════════════════
   AURORA THEME - Northern Lights
   ═══════════════════════════════════════════════════════════════════════════ */
[data-theme="aurora"] {
    --vico-bg-deep: #0a1014;
    --vico-bg-base: #0f171c;
    --vico-bg-raised: #152028;
    --vico-bg-elevated: #1c2a34;
    --vico-bg-hover: #243540;
    
    --vico-border: #2a4050;
    --vico-border-hover: #3a5568;
    --vico-border-focus: #88ffcc;
    
    --vico-text-primary: #e8f4f0;
    --vico-text-secondary: #a8c8c0;
    --vico-text-muted: #607878;
    
    --vico-accent-blue: #5588ff;
    --vico-accent-blue-light: #77a0ff;
    --vico-accent-green: #88ffcc;
    --vico-accent-green-light: #a0ffd8;
    --vico-accent-amber: #ffdd88;
    --vico-accent-amber-light: #ffe4a0;
    --vico-accent-red: #ff6688;
    --vico-accent-red-dark: #e05070;
    --vico-accent-purple: #cc88ff;
    --vico-accent-purple-light: #d8a0ff;
    --vico-accent-cyan: #66eeff;
    
    --vico-glow-blue: rgba(85, 136, 255, 0.25);
    --vico-glow-green: rgba(136, 255, 204, 0.3);
    --vico-glow-amber: rgba(255, 221, 136, 0.2);
    --vico-glow-red: rgba(255, 102, 136, 0.25);
    --vico-glow-purple: rgba(204, 136, 255, 0.25);
    --vico-glow-cyan: rgba(102, 238, 255, 0.3);
    
    --vico-gradient-header: linear-gradient(180deg, #152028 0%, #0f171c 100%);
    --vico-gradient-blue: linear-gradient(135deg, #88ffcc 0%, #55ddaa 100%);
    --vico-gradient-green: linear-gradient(135deg, #66eeff 0%, #44ccdd 100%);
    --vico-gradient-amber: linear-gradient(135deg, #ffdd88 0%, #f0c060 100%);
    --vico-gradient-purple: linear-gradient(135deg, #cc88ff 0%, #aa66dd 100%);
    
    --vico-scrollbar-thumb: rgba(136, 255, 204, 0.35);
    --vico-scrollbar-thumb-hover: rgba(136, 255, 204, 0.6);
}

/* Containers */
.popup-base,
.fullscreen-overlay-container {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 998;
  justify-content: center;
  align-items: center;
  font-family: var(--primary-font);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.popup-base.active,
.fullscreen-overlay-container.active {
  opacity: 1;
  visibility: visible;
  display: flex;
  pointer-events: auto;
}

/* Overlay */
.popup-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.6);
  z-index: 998;
}

/* Content shells */
.popup-content {
  position: relative;
  pointer-events: all;
  background-color: var(--vico-bg-base);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-xl);
  box-shadow: var(--vico-shadow-xl);
  width: 100%;
  max-width: 90vh;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: var(--vico-text-primary);
  transform: scale(0.1);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.3s ease;
}

.popup-base.active .popup-content,
.fullscreen-overlay-container.active .popup-content {
  transform: scale(1);
}

/* Shared scrollbars */
:where(.popup-content, .popup-body, .ui-frame, [class*="popup-body"], [class*="popup-content"])::-webkit-scrollbar {
  width: var(--vico-scrollbar-width);
}

:where(.popup-content, .popup-body, .ui-frame, [class*="popup-body"], [class*="popup-content"])::-webkit-scrollbar-track {
  background: transparent;
}

:where(.popup-content, .popup-body, .ui-frame, [class*="popup-body"], [class*="popup-content"])::-webkit-scrollbar-thumb {
  background: var(--vico-scrollbar-thumb);
  border-radius: 3px;
}

:where(.popup-content, .popup-body, .ui-frame, [class*="popup-body"], [class*="popup-content"])::-webkit-scrollbar-thumb:hover {
  background: var(--vico-scrollbar-thumb-hover);
}

/* Occluded state */
.popup-base.popup-occluded > .popup-content {
  opacity: 0.4;
  pointer-events: none;
}

/* Utility: shared scrollable area */
.scrollable {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}


/* Popup Header */
.popup-header {
  padding: var(--vico-space-md) var(--vico-space-xl);
  border-bottom: 1px solid var(--vico-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--vico-gradient-header);
}

.popup-header h2 {
  margin: 0;
  color: var(--vico-text-primary);
  font-size: 1.25rem;
  font-weight: 600;
  background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.header-buttons {
  display: flex;
  gap: var(--vico-space-md);
}

/* Close Button */
.close-btn {
  background: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  cursor: pointer;
  color: var(--vico-text-muted);
  transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast), transform 0.2s ease;
  padding: var(--vico-space-sm);
  border-radius: var(--vico-radius-md);
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.close-btn:hover {
  background: var(--vico-bg-elevated);
  border-color: var(--vico-accent-red);
  color: var(--vico-accent-red);
  transform: rotate(90deg);
}

.close-btn svg {
  display: block;
  width: 18px;
  height: 18px;
}

.popup-body {
  padding: var(--vico-space-xl);
  background-color: var(--vico-bg-deep);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
}

/* Form Elements */
.popup-input {
  width: 100%;
  padding: var(--vico-space-md) var(--vico-space-lg);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  background-color: var(--vico-bg-raised);
  color: var(--vico-text-primary);
  margin-bottom: var(--vico-space-lg);
  transition: border-color var(--vico-transition-fast), background-color var(--vico-transition-fast);
}

.popup-input:focus {
  outline: none;
  border-color: var(--vico-accent-blue);
  background-color: var(--vico-bg-elevated);
  box-shadow: 0 0 0 2px var(--vico-glow-blue);
}
  
  /* Minimal Style Variant */
  /* Used for e-learning content - providing space for a content table to the right while keeping the popup minimalistic */

  .popup-base.style-minimal {
    
    /* no rounded corners */
    pointer-events: none;
    margin: 10px;
  }

  .popup-base.style-minimal .popup-content {
    background-color: transparent;
    box-shadow: none;
    max-width: 73%;
    max-height: 100%;
    height: 100%;
    pointer-events: auto;
  }

  .popup-base.style-minimal .popup-overlay {
    background-color: rgba(0, 0, 0, 0);
    /* no backdrop filter */
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  
  .popup-base.style-minimal .popup-header {
    background-color: transparent;
    border-bottom: none;
    padding: 0;
  }

  .popup-base.style-minimal .popup-button {
    width: 100px;
  }

  .popup-base.style-minimal .close-btn {
    padding: 0;
  }

  .popup-base.style-minimal .close-btn svg {
    width: 15px;
    height: 15px;
  }

  /* Close Button not visible in minimal style */
  .popup-base.style-minimal .close-btn {
    display: none;
}
  
  @media (max-width: 768px) {

    .popup-content {
      max-width: 95%;
      max-height: 95%;
    }

    .popup-header {
      padding: 15px;
    }
  
    .popup-header h2 {
      font-size: 16px;
    }

    .popup-body {
      margin: 2%;
    }
  
    .popup-button {
      width: 100%;
      margin-bottom: 10px;
    }

    .popup-base.style-minimal .popup-body {
      margin: 0;
    }

    .popup-base.style-minimal .text-content {
      margin: 0;
    }
  }
  
/* Cog Container Styles */
.cog-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 999;
    border-radius: 10%;
}

.cog-icon {
    width: 48px;
    height: 48px;
    padding: 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cog-icon img {
    transition: filter 0.3s ease;
}

.cog-icon:hover {
    transform: rotate(90deg);
    background-color: var(--vico-accent-blue);
}

.cog-icon:hover img {
    filter: brightness(5);
}

/* Dropdown Menu Styles */
.dropdown-menu {
    display: none;
    position: absolute;
    right: 0;
    top: calc(100% + 15px);
    background-color: var(--vico-bg-base);
    border-radius: var(--vico-radius-lg);
    overflow: hidden;
    box-shadow: var(--vico-shadow-lg);
    font-family: var(--primary-font);
    width: 220px;
    z-index: 1001;
    border: 1px solid var(--vico-border);
    transform: translateY(-20px);
    opacity: 0;
    flex-direction: column;
}

.dropdown-menu.show {
    display: flex;
    transform: translateY(0);
    opacity: 1;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease;
}

/* Dropdown Arrow */
.dropdown-menu::before {
    content: '';
    position: absolute;
    top: -10px;
    right: 30px;
    width: 20px;
    height: 20px;
    background-color: var(--vico-bg-base);
    transform: rotate(45deg);
    box-shadow: -3px -3px 7px rgba(0, 0, 0, 0.05);
}

/* Dropdown Items */
.dropdown-item {
    padding: 15px 20px;
    width: 100%;
    display: flex;
    align-items: center;
    font-size: 16px;
    font-weight: 500;
    color: var(--vico-text-secondary);
    background-color: transparent;
    border-bottom: 1px solid var(--vico-border);
    text-align: left;
    transition: background-color 0.2s ease, color 0.2s ease;
}

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

.dropdown-item:hover {
    background-color: var(--vico-accent-blue);
    color: var(--vico-text-primary);
}

.dropdown-item:hover .dropdown-icon {
    fill: var(--vico-text-primary);
}

/* Styles for Icons within Dropdown Items */
.dropdown-icon {
    margin-right: 10px;
    width: 18px;
    height: 18px;
    fill: var(--vico-text-secondary);
}

.dropdown-item:hover .dropdown-icon {
    fill: var(--vico-text-primary);
}

/* Mobile Optimization */
@media (max-width: 768px) {
    .cog-container {
        top: 10px;
        right: 10px;
    }

    .cog-icon {
        width: 40px;
        height: 40px;
        padding: 8px;
    }

    .cog-icon img {
        width: 40px;
        height: 40px;
    }

    .dropdown-menu {
        width: 180px;
    }
    
    .dropdown-item {
        padding: 12px 16px;
        font-size: 14px;
    }

    .dropdown-icon {
        width: 16px;
        height: 16px;
        margin-right: 8px;
    }
}

/* infoPopupManager.css - Uses Vico design tokens */

.info-popup-container {
    display: flex;
    background-color: var(--vico-bg-deep);
    flex-direction: column;
    align-items: center;
    padding: var(--vico-space-xl);
    gap: 1.5rem;
}

.info-popup-text {
    width: 100%;
    text-align: center;
}

.info-popup-text h3 {
    color: var(--vico-text-primary);
    font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 600;
    margin-bottom: 1.5rem;
    background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.info-popup-text p {
    color: var(--vico-text-secondary);
    font-size: 1rem;
    line-height: 1.6;
    margin: 0.75rem 0;
}

.info-popup-text img {
    width: auto;
    height: clamp(30px, 8vw, 50px);
    margin: 1rem auto;
    transition: transform var(--vico-transition-fast);
}

.info-popup-text img:hover {
    transform: scale(1.1);
}

/* multiplayerPopupManager.css - Uses Vico design tokens */

.multiplayer-popup-body {
    padding: var(--vico-space-lg);
    display: flex;
    flex: 1;
    flex-direction: column;
    overflow-y: auto;
    overflow-x: hidden;
    background: var(--vico-bg-deep);
    min-height: 0;
}

/* Scrollbar styling */
.multiplayer-popup-body::-webkit-scrollbar,
.room-list::-webkit-scrollbar,
.player-list::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}
.multiplayer-popup-body::-webkit-scrollbar-track,
.room-list::-webkit-scrollbar-track,
.player-list::-webkit-scrollbar-track {
    background: transparent;
}
.multiplayer-popup-body::-webkit-scrollbar-thumb,
.room-list::-webkit-scrollbar-thumb,
.player-list::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: 3px;
}
.multiplayer-popup-body::-webkit-scrollbar-thumb:hover,
.room-list::-webkit-scrollbar-thumb:hover,
.player-list::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

.multiplayer-description {
    margin-bottom: var(--vico-space-xl);
    color: var(--vico-text-secondary);
    font-size: 16px;
}

.multiplayer-form {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-lg);
    width: 100%;
    box-sizing: border-box;
}

.multiplayer-input-group {
    position: relative;
    margin-bottom: var(--vico-space-sm);
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-sm);
    width: 100%;
    box-sizing: border-box;
}

.multiplayer-input-group label {
    color: var(--vico-text-secondary);
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.multiplayer-input-group input {
    width: 100%;
    padding: var(--vico-space-md) var(--vico-space-lg);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    font-size: 16px;
    background-color: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    transition: border-color var(--vico-transition-fast), background-color var(--vico-transition-fast);
    box-sizing: border-box;
}

.multiplayer-input-group input::placeholder {
    color: var(--vico-text-muted);
    font-size: 12px;
}

.multiplayer-input-group input:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    background-color: var(--vico-bg-elevated);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.multiplayer-room-info {
    background-color: var(--vico-bg-raised);
    padding: var(--vico-space-lg);
    border-radius: var(--vico-radius-md);
    margin-bottom: var(--vico-space-xl);
    border: 1px solid var(--vico-border);
}

.multiplayer-room-id {
    display: block;
    color: var(--vico-text-primary);
    font-size: 16px;
    margin-bottom: var(--vico-space-md);
    word-break: break-all;
}

#multiplayer-session-container .multiplayer-room-info {
    text-align: center;
}

/* Error state styles */
.multiplayer-input-group.error input {
    border-color: var(--vico-accent-red);
}

.multiplayer-input-group.error .error-message {
    color: var(--vico-accent-red);
    font-size: 14px;
    margin-top: var(--vico-space-sm);
}

/* Success state styles */
.multiplayer-input-group.success input {
    border-color: var(--vico-accent-green);
}

/* Room list specific styles */
.room-list-container {
    margin-top: var(--vico-space-lg);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    padding: var(--vico-space-md);
    background-color: var(--vico-bg-raised);
    box-sizing: border-box;
    width: 100%;
}

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

.room-list-header h3 {
    margin: 0;
    font-size: 1.1rem;
    color: var(--vico-text-primary);
}

.refresh-button {
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    cursor: pointer;
    padding: var(--vico-space-sm);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast);
    color: var(--vico-text-secondary);
}

.refresh-button:hover {
    background-color: var(--vico-bg-hover);
    border-color: var(--vico-border-hover);
    color: var(--vico-accent-blue);
}

.refresh-button.refreshing svg {
    animation: spin 1s linear infinite;
}

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

.room-list {
    overflow-y: auto;
    gap: var(--vico-space-sm);
    display: flex;
    flex-direction: column;
    max-height: 300px;
}

.room-item {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-md);
    background-color: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast), transform 0.1s ease;
}

.room-item:hover {
    background-color: var(--vico-bg-elevated);
    border-color: var(--vico-border-hover);
    transform: translateY(-1px);
}

.room-info {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-xs);
}

.room-id {
    font-weight: 500;
    color: var(--vico-text-primary);
}

.player-count {
    font-size: 0.9rem;
    color: var(--vico-text-secondary);
}

.join-room-btn {
    background: var(--vico-gradient-green);
    color: var(--vico-bg-base);
    padding: var(--vico-space-sm) var(--vico-space-md);
    border: none;
    border-radius: var(--vico-radius-md);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
    box-shadow: 0 2px 6px rgba(152, 195, 121, 0.2);
}

.join-room-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, var(--vico-accent-green-light) 0%, var(--vico-accent-green) 100%);
    box-shadow: 0 3px 10px rgba(152, 195, 121, 0.3);
}

.no-rooms-message {
    text-align: center;
    padding: var(--vico-space-lg);
    color: var(--vico-text-muted);
    font-style: italic;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--vico-space-md);
    box-sizing: border-box;
}

.button-group {
    display: flex;
    gap: var(--vico-space-lg);
    margin-top: var(--vico-space-lg);
}

.button-group button {
    flex: 1;
}

.room-count {
    padding: var(--vico-space-sm);
    color: var(--vico-text-secondary);
    font-size: 0.9rem;
    border-bottom: 1px solid var(--vico-border);
}

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

.room-status {
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 12px;
    font-weight: 600;
}

.room-status.available {
    background-color: rgba(152, 195, 121, 0.15);
    color: var(--vico-accent-green);
}

.room-status.full {
    background-color: var(--vico-bg-elevated);
    color: var(--vico-text-muted);
}

.player-info {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--vico-space-xs);
}

.player-avatars {
    display: flex;
    margin-left: var(--vico-space-sm);
}

.player-avatar {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: var(--vico-gradient-blue);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 600;
    border: 2px solid var(--vico-bg-raised);
    margin-left: -8px;
}

.player-avatar:first-child {
    margin-left: 0;
}

.player-avatar.more {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-secondary);
    font-size: 0.7rem;
}

.create-now-btn {
    background: none;
    border: none;
    color: var(--vico-accent-blue);
    text-decoration: underline;
    cursor: pointer;
    transition: color var(--vico-transition-fast);
}

.create-now-btn:hover {
    color: var(--vico-accent-blue-light);
}

/* Session players section styling */
.scene-group {
    margin-bottom: var(--vico-space-lg);
}

.scene-group:last-child {
    margin-bottom: 0;
}

.scene-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-sm);
    margin-bottom: var(--vico-space-sm);
    background-color: var(--vico-bg-elevated);
    border-radius: var(--vico-radius-sm);
}

.scene-name {
    font-weight: 500;
    color: var(--vico-text-primary);
}

.scene-count {
    font-size: 0.8rem;
    color: var(--vico-text-secondary);
    padding: 2px 8px;
    background-color: var(--vico-bg-base);
    border-radius: 12px;
}

.player-name {
    color: var(--vico-text-primary);
    font-weight: 500;
}

.player-id {
    font-size: 0.8rem;
    color: var(--vico-text-muted);
    opacity: 0.8;
}

.session-players {
    margin-top: 1.5rem;
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    padding: var(--vico-space-lg);
    background-color: var(--vico-bg-raised);
}

.session-players-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--vico-space-lg);
    padding-bottom: var(--vico-space-sm);
    border-bottom: 1px solid var(--vico-border);
}

.session-players-header h3 {
    margin: 0;
    font-size: 1.1rem;
    color: var(--vico-text-primary);
}

.session-players .player-count {
    font-size: 0.9rem;
    color: var(--vico-text-secondary);
    background-color: var(--vico-bg-elevated);
    padding: 2px 8px;
    border-radius: 12px;
}

.player-list {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-sm);
    max-height: 200px;
    overflow-y: auto;
}

.player-item {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
    padding: var(--vico-space-md);
    background-color: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.player-item:hover {
    background-color: var(--vico-bg-elevated);
    border-color: var(--vico-border-hover);
}

.player-item .player-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--vico-gradient-blue);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 600;
    border: 2px solid var(--vico-bg-raised);
}

.player-item .player-name {
    color: var(--vico-text-primary);
    font-size: 0.95rem;
    font-weight: 500;
}

/* Media Queries */
@media (max-width: 768px) {

    .multiplayer-form {
        gap: 15px;
    }

    .multiplayer-input-group input {
        padding: 10px 12px;
        font-size: 15px;
    }

    .multiplayer-description {
        font-size: 14px;
    }

    .room-item {
        flex-direction: column;
    }

    .session-players {
        margin-top: 1rem;
        padding: 0.75rem;
    }

    .player-item {
        padding: 0.5rem;
    }

    .player-item .player-avatar {
        width: 28px;
        height: 28px;
        font-size: 0.9rem;
    }
}

/* userManagementPopupManager.css - Modern User Management UI */

/* ═══════════════════════════════════════════════════════════════════════════
   POPUP CONTAINER
   ═══════════════════════════════════════════════════════════════════════════ */
.um-popup-content {
    position: relative;
    z-index: 2;
    background-color: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-xl);
    box-shadow: var(--vico-shadow-xl);
    width: 90%;
    max-width: 700px;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    color: var(--vico-text-primary);
}

/* ═══════════════════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════════════════ */
.um-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-lg) var(--vico-space-xl);
    background: var(--vico-gradient-header);
    border-bottom: 1px solid var(--vico-border);
    box-shadow: inset 0 1px 0 rgba(97, 175, 239, 0.1);
}

.um-header-title {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
}

.um-header-title i {
    font-size: 1.25rem;
    color: var(--vico-accent-blue);
}

.um-header-title h2 {
    margin: 0;
    font-size: 1.15rem;
    font-weight: 600;
    background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.um-close-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-muted);
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.um-close-btn:hover {
    background: rgba(224, 108, 117, 0.1);
    border-color: var(--vico-accent-red);
    color: var(--vico-accent-red);
}

/* ═══════════════════════════════════════════════════════════════════════════
   BODY
   ═══════════════════════════════════════════════════════════════════════════ */
.um-popup-body {
    padding: var(--vico-space-lg);
    display: flex;
    flex-direction: column;
    flex: 1;
    overflow: hidden;
    background: var(--vico-bg-deep);
    min-height: 0;
}

.um-user-list-section {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   TOOLBAR
   ═══════════════════════════════════════════════════════════════════════════ */
.um-toolbar {
    display: flex;
    gap: var(--vico-space-lg);
    margin-bottom: var(--vico-space-lg);
    align-items: center;
    flex-wrap: nowrap;
}

.um-search-wrapper {
    flex: 1 1 0;
    min-width: 120px;
    position: relative;
    overflow: hidden;
}

.um-search-wrapper i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--vico-text-muted);
    font-size: 0.85rem;
    pointer-events: none;
}

.um-search-input {
    width: 100%;
    padding: var(--vico-space-md) var(--vico-space-lg);
    padding-left: 40px;
    box-sizing: border-box;
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    font-size: 14px;
    background-color: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    transition: border-color var(--vico-transition-fast), background-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.um-search-input:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    background-color: var(--vico-bg-elevated);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.um-search-input::placeholder {
    color: var(--vico-text-muted);
}

.um-add-user-btn {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    padding: var(--vico-space-md) var(--vico-space-lg);
    border: none;
    border-radius: var(--vico-radius-md);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    background: var(--vico-gradient-green);
    color: var(--vico-bg-deep);
    box-shadow: 0 2px 8px rgba(152, 195, 121, 0.25);
    transition: transform 0.1s ease, box-shadow var(--vico-transition-fast);
    white-space: nowrap;
    flex-shrink: 0;
}

.um-add-user-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(152, 195, 121, 0.35);
}

.um-add-user-btn i {
    font-size: 0.9rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   USER LIST
   ═══════════════════════════════════════════════════════════════════════════ */
.um-user-list-container {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    border-radius: var(--vico-radius-lg);
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
}

/* Scrollbar */
.um-user-list-container::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}
.um-user-list-container::-webkit-scrollbar-track {
    background: transparent;
}
.um-user-list-container::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: 3px;
}
.um-user-list-container::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

/* List Headers */
.um-list-headers {
    display: grid;
    grid-template-columns: 1fr 120px 50px;
    gap: var(--vico-space-md);
    padding: var(--vico-space-md) var(--vico-space-lg);
    background: var(--vico-bg-base);
    border-bottom: 1px solid var(--vico-border);
    font-weight: 600;
    color: var(--vico-text-muted);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    position: sticky;
    top: 0;
    z-index: 1;
}

.um-user-list {
    list-style-type: none;
    padding: 0;
    margin: 0;
}

.um-user-list li {
    display: grid;
    grid-template-columns: 1fr 120px 50px;
    gap: var(--vico-space-md);
    align-items: center;
    padding: var(--vico-space-md) var(--vico-space-lg);
    border-bottom: 1px solid var(--vico-border);
    transition: background-color var(--vico-transition-fast);
}

.um-user-list li:last-child {
    border-bottom: none;
}

.um-user-list li:hover {
    background-color: var(--vico-bg-elevated);
}

/* User Info Cell */
.um-user-info {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
    min-width: 0;
}

.um-user-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--vico-gradient-blue);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 600;
    flex-shrink: 0;
}

.um-user-details {
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.um-user-email {
    font-weight: 500;
    color: var(--vico-text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 0.9rem;
}

.um-user-name {
    font-size: 0.8rem;
    color: var(--vico-text-muted);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Role Badge */
.um-user-role {
    padding: var(--vico-space-xs) var(--vico-space-sm);
    border-radius: var(--vico-radius-sm);
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    text-align: center;
    white-space: nowrap;
}

.um-user-role.role-admin {
    background: rgba(224, 108, 117, 0.15);
    color: var(--vico-accent-red);
}

.um-user-role.role-editor {
    background: rgba(229, 192, 123, 0.15);
    color: var(--vico-accent-amber);
}

.um-user-role.role-user {
    background: var(--vico-glow-blue);
    color: var(--vico-accent-blue);
}

.um-user-role.role-viewer {
    background: rgba(198, 120, 221, 0.15);
    color: var(--vico-accent-purple);
}

.um-user-role.role-default {
    background: var(--vico-bg-hover);
    color: var(--vico-text-secondary);
}

/* Edit Button */
.um-edit-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-muted);
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.um-edit-btn:hover {
    background: var(--vico-bg-hover);
    border-color: var(--vico-accent-blue);
    color: var(--vico-accent-blue);
}

.um-edit-btn i {
    font-size: 0.8rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
    .um-popup-body {
        padding: var(--vico-space-md);
    }

    .um-toolbar {
        flex-direction: column;
    }

    .um-add-user-btn {
        width: 100%;
        justify-content: center;
    }

    .um-list-headers {
        grid-template-columns: 1fr 50px;
    }

    .um-list-headers span:nth-child(2) {
        display: none;
    }

    .um-user-list li {
        grid-template-columns: 1fr 50px;
    }

    .um-user-role {
        display: none;
    }

    .um-user-avatar {
        width: 32px;
        height: 32px;
        font-size: 0.75rem;
    }
}

/* settingsPopupManager.css - Uses Vico design tokens */

.settings-description {
    color: var(--vico-text-secondary);
    font-size: 1rem;
    margin: 0;
    padding-bottom: var(--vico-space-lg);
}

/* Control Groups */
.settings-control {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-sm);
    padding: var(--vico-space-md) 0;
    border-bottom: 1px solid var(--vico-border);
}

.settings-control:last-child {
    border-bottom: none;
}

/* Compact variant for dense layouts (AI settings) */
.settings-control.compact {
    padding: var(--vico-space-xs) 0;
    gap: var(--vico-space-xs);
}

/* AI settings arranged in responsive grid */
.ai-settings-group {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--vico-space-md);
    margin: var(--vico-space-sm) 0 var(--vico-space-lg);
}

@media (max-width: 600px) {
    .ai-settings-group {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 400px) {
    .ai-settings-group {
        grid-template-columns: 1fr;
    }
}

.settings-label {
    color: var(--vico-text-primary);
    font-size: 1rem;
    font-weight: 500;
}

/* Volume Slider */
.settings-slider-container {
    display: flex;
    align-items: center;
    gap: var(--vico-space-lg);
}

.settings-slider {
    flex: 1;
    height: 6px;
    -webkit-appearance: none;
    background: linear-gradient(
        to right,
        var(--vico-accent-blue) 0%,
        var(--vico-accent-blue) var(--volume-percentage, 50%),
        var(--vico-bg-elevated) var(--volume-percentage, 50%),
        var(--vico-bg-elevated) 100%
    );
    border-radius: 3px;
    outline: none;
}

.settings-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    background: var(--vico-accent-blue);
    border-radius: 50%;
    cursor: pointer;
    transition: transform 0.1s ease, background var(--vico-transition-fast);
    box-shadow: 0 2px 6px rgba(97, 175, 239, 0.3);
}

.settings-slider::-webkit-slider-thumb:hover,
.settings-slider.settings-slider-active::-webkit-slider-thumb {
    transform: scale(1.2);
    background: var(--vico-accent-blue-light);
}

.settings-value {
    min-width: 45px;
    color: var(--vico-text-primary);
    font-size: 0.875rem;
    font-weight: 600;
}

/* Toggle Switch */
.settings-toggle-wrapper {
    position: relative;
    width: 60px;
    height: 30px;
    flex-shrink: 0; 
}

.settings-toggle-wrapper input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    cursor: pointer;
    height: 0;
    width: 0;
    z-index: -1; 
}

.settings-toggle-label {
    position: absolute;
    inset: 0;
    background-color: var(--vico-bg-elevated);
    border-radius: 15px;
    cursor: pointer;
    transition: background-color var(--vico-transition-fast);
    border: 1px solid var(--vico-border);
}

.settings-toggle-label:before {
    content: "";
    position: absolute;
    height: 22px;
    width: 22px;
    left: 4px;
    bottom: 3px;
    background-color: var(--vico-text-muted);
    border-radius: 50%;
    transition: transform var(--vico-transition-fast), background-color var(--vico-transition-fast);
}

input[type="checkbox"]:checked + .settings-toggle-label {
    background-color: rgba(152, 195, 121, 0.2);
    border-color: var(--vico-accent-green);
}

input[type="checkbox"]:checked + .settings-toggle-label:before {
    transform: translateX(30px);
    background-color: var(--vico-accent-green);
}

input[type="checkbox"]:disabled + .settings-toggle-label {
    opacity: 0.5;
    cursor: not-allowed;
}

/* Buttons */
.settings-ar-button,
.settings-reset-button {
    width: 100%;
    padding: var(--vico-space-md) var(--vico-space-xl);
    border: none;
    border-radius: var(--vico-radius-md);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vico-transition-fast), transform 0.1s ease, box-shadow var(--vico-transition-fast);
}

.settings-ar-button {
    background: var(--vico-gradient-purple);
    color: #fff;
    box-shadow: 0 2px 8px rgba(198, 120, 221, 0.3);
}

.settings-reset-button {
    background: var(--vico-bg-raised);
    color: var(--vico-text-secondary);
    border: 1px solid var(--vico-border);
}

.settings-ar-button:hover:not(:disabled) {
    background: linear-gradient(135deg, var(--vico-accent-purple-light) 0%, var(--vico-accent-purple) 100%);
    box-shadow: 0 4px 12px var(--vico-glow-purple);
    transform: translateY(-2px);
}

.settings-reset-button:hover {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
    transform: translateY(-2px);
}

.settings-ar-button:disabled {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-muted);
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

/* Loading State */
.settings-ar-button.loading {
    color: transparent;
    position: relative;
}

.settings-ar-button.loading::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 -10px;
    border: 2px solid var(--vico-text-primary);
    border-radius: 50%;
    border-right-color: transparent;
    animation: button-loading 0.8s linear infinite;
}

@keyframes button-loading {
    to { transform: rotate(360deg); }
}

/* Focus States */
.settings-ar-button:focus-visible,
.settings-reset-button:focus-visible,
.settings-close-btn:focus-visible,
.settings-slider:focus-visible {
    outline: 2px solid var(--vico-accent-blue);
    outline-offset: 2px;
}

/* Mobile Adjustments */
@media (max-width: 768px) {

    .settings-ar-button,
    .settings-reset-button {
        padding: 0.625rem 1rem;
        font-size: 0.9375rem;
    }
}

/* Cache Management Styles */
.cache-buttons-container {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.settings-cache-button,
.settings-clear-button {
    flex: 1;
    min-width: 120px;
    font-size: 0.875rem;
    font-weight: 500;
    transition: background-color 0.3s ease, transform 0.1s ease, box-shadow 0.3s ease;
}

.settings-cache-button {
    background-color: var(--vico-accent-blue);
    color: var(--vico-text-primary);
}

.settings-clear-button {
    background-color: var(--vico-accent-red);
    color: var(--vico-text-primary);
}

.settings-cache-button:hover,
.settings-clear-button:hover {
    transform: translateY(-1px);
    box-shadow: 0px 3px 8px rgba(0, 0, 0, 0.15);
}

.settings-cache-button:hover {
    background-color: var(--vico-accent-blue-light);
}

.settings-clear-button:hover {
    background-color: var(--vico-accent-red-dark);
}

.settings-cache-button:active,
.settings-clear-button:active {
    transform: translateY(0);
}

@media (max-width: 480px) {
    .cache-buttons-container {
        flex-direction: column;
    }
    
    .settings-cache-button,
    .settings-clear-button {
        min-width: unset;
    }
}

.ai-settings-group input {
    width: 100%;
    box-sizing: border-box;
}

.ai-settings-group .settings-control {
    min-width: 0;
    overflow: hidden;
}

/* Collapsible */
.settings-collapsible {
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    margin: var(--vico-space-lg) 0;
    background: var(--vico-bg-raised);
}

/* Collapsible header is now a button for accessibility */
.collapsible-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    cursor: pointer;
    padding: var(--vico-space-sm) var(--vico-space-md);
    user-select: none;
    color: var(--vico-text-secondary);
    font-weight: 600;
    font-size: inherit;
    font-family: inherit;
    background: transparent;
    border: none;
    border-radius: var(--vico-radius-md) var(--vico-radius-md) 0 0;
    text-align: left;
    transition: background var(--vico-transition-fast), color var(--vico-transition-fast);
}

.collapsible-header:hover {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
}

.collapsible-header:focus-visible {
    outline: 2px solid var(--vico-accent-blue);
    outline-offset: -2px;
}

.chevron-icon {
    width: 16px;
    height: 16px;
    transition: transform 0.3s ease;
    color: var(--vico-accent-blue);
}

.collapsible-header.open .chevron-icon {
    transform: rotate(90deg);
}

.collapsible-content {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.35s ease;
    padding: 0 var(--vico-space-md);
}

.collapsible-content.open {
    padding: var(--vico-space-sm) var(--vico-space-md) var(--vico-space-md);
}

.ai-settings-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--vico-space-md);
}

@media (max-width: 600px) {
    .ai-settings-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 400px) {
    .ai-settings-grid {
        grid-template-columns: 1fr;
    }
}

/* Settings Input */
.settings-input {
    width: 100%;
    padding: var(--vico-space-sm) var(--vico-space-md);
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-text-primary);
    font-size: 0.85rem;
    transition: border-color var(--vico-transition-fast), background var(--vico-transition-fast);
    box-sizing: border-box;
    min-width: 0;
}

.settings-input:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    background: var(--vico-bg-elevated);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

/* Theme Select Dropdown */
.settings-select {
    width: 100%;
    padding: var(--vico-space-sm) var(--vico-space-md);
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-primary);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: border-color var(--vico-transition-fast), background var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%238891a0%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3E%3Cpolyline points=%276 9 12 15 18 9%27%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--vico-space-md) center;
    padding-right: calc(var(--vico-space-lg) + 16px);
}

.settings-select:hover {
    border-color: var(--vico-border-hover);
    background-color: var(--vico-bg-elevated);
}

.settings-select:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.settings-select option {
    background: var(--vico-bg-base);
    color: var(--vico-text-primary);
    padding: var(--vico-space-sm);
}

.settings-control.compact label {
    font-size: 0.75rem;
    color: var(--vico-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   AI Settings - Enhanced Styles
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Mode Toggle Section */
.ai-settings-mode-toggle {
    padding: var(--vico-space-sm) 0;
    margin-bottom: var(--vico-space-md);
    border-bottom: 1px solid var(--vico-border);
}

.ai-settings-mode-toggle .settings-control {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    border-bottom: none;
    padding: 0;
}

.settings-help-text {
    font-size: 0.75rem;
    color: var(--vico-text-muted);
    margin-top: var(--vico-space-xs);
    padding-left: var(--vico-space-xs);
}

.settings-help-text .mode-backend {
    color: var(--vico-accent-green);
}

.settings-help-text .mode-direct {
    color: var(--vico-accent-orange);
}

/* AI Settings Sections */
.ai-settings-section {
    margin: var(--vico-space-md) 0;
    padding: var(--vico-space-sm) 0;
}

.ai-settings-section h4 {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--vico-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--vico-space-sm) 0;
    padding-left: var(--vico-space-xs);
}

.ai-settings-section:not(:last-child) {
    border-bottom: 1px solid var(--vico-border);
    padding-bottom: var(--vico-space-md);
}

/* Input Group with Button */
.settings-input-group {
    display: flex;
    gap: var(--vico-space-xs);
    align-items: stretch;
}

.settings-input-group .settings-input {
    flex: 1;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.settings-input-btn {
    padding: var(--vico-space-sm) var(--vico-space-md);
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-left: none;
    border-top-right-radius: var(--vico-radius-sm);
    border-bottom-right-radius: var(--vico-radius-sm);
    color: var(--vico-text-secondary);
    cursor: pointer;
    transition: background var(--vico-transition-fast), color var(--vico-transition-fast);
}

.settings-input-btn:hover {
    background: var(--vico-bg-raised);
    color: var(--vico-text-primary);
}

.settings-input-btn i {
    font-size: 0.875rem;
}

/* Provider name badge */
.provider-name {
    font-size: 0.65rem;
    color: var(--vico-accent-blue);
    font-weight: 400;
    opacity: 0.8;
}

/* AI Key Field visibility */
.ai-key-field {
    transition: opacity var(--vico-transition-fast), max-height var(--vico-transition-fast);
}

.ai-key-field[style*="display: none"] {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   AI Usage Statistics
   ═══════════════════════════════════════════════════════════════════════════════ */

.ai-usage-section {
    padding: var(--vico-space-md) 0;
}

.ai-usage-section h4 {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--vico-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--vico-space-sm) 0;
}

.ai-usage-section:not(:last-child) {
    border-bottom: 1px solid var(--vico-border);
}

/* Usage Stats Grid */
.ai-usage-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--vico-space-sm);
}

.ai-usage-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--vico-space-sm);
    background: var(--vico-bg-base);
    border-radius: var(--vico-radius-sm);
    border: 1px solid var(--vico-border);
}

.ai-usage-label {
    font-size: 0.65rem;
    color: var(--vico-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--vico-space-xs);
}

.ai-usage-value {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--vico-text-primary);
    font-variant-numeric: tabular-nums;
}

/* Cost highlighting - uses theme tokens */
.ai-usage-stat:first-child .ai-usage-value {
    color: var(--vico-accent-green);
}

/* Requests highlighting */
.ai-usage-stat:nth-child(2) .ai-usage-value {
    color: var(--vico-accent-blue);
}

/* Tokens highlighting */
.ai-usage-stat:nth-child(3) .ai-usage-value {
    color: var(--vico-accent-amber);
}

/* Provider Breakdown */
.ai-usage-breakdown {
    margin-top: var(--vico-space-md);
}

.ai-usage-breakdown-item {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--vico-space-md);
    padding: var(--vico-space-xs) var(--vico-space-sm);
    font-size: 0.8rem;
    border-bottom: 1px solid var(--vico-border);
}

.ai-usage-breakdown-item:last-child {
    border-bottom: none;
}

.breakdown-provider {
    color: var(--vico-text-primary);
    font-weight: 500;
}

.breakdown-cost {
    color: var(--vico-accent-green);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
}

.breakdown-requests {
    color: var(--vico-text-muted);
    font-size: 0.75rem;
}

.ai-usage-empty {
    text-align: center;
    color: var(--vico-text-muted);
    font-size: 0.8rem;
    padding: var(--vico-space-md);
    font-style: italic;
}

/* Usage Actions */
.ai-usage-actions {
    display: flex;
    gap: var(--vico-space-sm);
    margin-top: var(--vico-space-md);
    padding-top: var(--vico-space-md);
    border-top: 1px solid var(--vico-border);
}

.settings-btn-sm {
    flex: 1;
    padding: var(--vico-space-xs) var(--vico-space-sm);
    font-size: 0.75rem;
    font-weight: 500;
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-text-secondary);
    cursor: pointer;
    transition: all var(--vico-transition-fast);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--vico-space-xs);
}

.settings-btn-sm:hover {
    background: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    border-color: var(--vico-border-hover);
}

.settings-btn-sm.settings-btn-danger {
    border-color: var(--vico-accent-red);
    color: var(--vico-accent-red);
}

.settings-btn-sm.settings-btn-danger:hover {
    background: rgba(224, 108, 117, 0.15);
    color: var(--vico-accent-red);
}

.settings-btn-sm i {
    font-size: 0.7rem;
}

/* Collapsible header icon enhancement */
.collapsible-header span {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
}

.collapsible-header span i {
    font-size: 0.9rem;
    color: var(--vico-accent-blue);
    opacity: 0.8;
}

.collapsible-header.open span i {
    opacity: 1;
}

/* Responsive adjustments */
@media (max-width: 500px) {
    .ai-usage-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    
    .ai-usage-stat {
        padding: var(--vico-space-xs);
    }
    
    .ai-usage-value {
        font-size: 0.95rem;
    }
    
    .ai-usage-breakdown-item {
        grid-template-columns: 1fr auto;
    }
    
    .breakdown-requests {
        display: none;
    }
}

@media (max-width: 380px) {
    .ai-settings-mode-toggle .settings-control {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--vico-space-sm);
    }
}
#cpm-media-container {
    margin-bottom: 24px;
    background-color: var(--vico-bg-raised);
    border-radius: var(--vico-radius-lg);
    box-shadow: var(--vico-shadow-sm);
    transition: flex 0.3s ease;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden; 
    max-height: 100%; 
}

#cpm-media-container img {
    width: 100%;
    height: 40vh;
    object-fit: contain;
    border-radius: var(--vico-radius-lg) var(--vico-radius-lg) 0 0;
    background-color: transparent;
}

#cpm-media-container video {
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  display: block;
}

/*/ subtitles */
#cpm-media-container video::cue {
    color: var(--vico-text-primary);
    background-color: rgba(0, 0, 0, 0.8);
    font-size: 22px;
    font-weight: 600;
}

#cpm-media-container iframe {
    width: 100%;
    height: 60vh;
    border-radius: var(--vico-radius-lg) var(--vico-radius-lg) 0 0;
}

#cpm-text-content {
    margin-bottom: 0px;
    font-size: 16px;
    line-height: 1.6;
    flex: 1 1 auto;}

#cpm-text-content p {
    margin-bottom: 16px;
}

#cpm-text-content ul, #cpm-text-content ol {
    margin-bottom: 16px;
    padding-left: 24px;
}

#cpm-text-content li {
    margin-bottom: 8px;
}

#cpm-header-buttons {

    justify-content: flex-end;

    width: fit-content;
    margin-left: auto;
    margin-right: 0;
}

.cpm-button-container {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    justify-content: flex-start;
    align-items: center;
}


.cpm-button {
    padding: 12px 24px;
    background-color: var(--vico-accent-blue);
    color: var(--vico-text-primary);
    border: none;
    border-radius: var(--vico-radius-lg);
    cursor: pointer;
    font-size: 16px;
    font-weight: 600;
    transition: background-color 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
    box-shadow: var(--vico-shadow-sm);
    display: inline-block;
    width: 40%;
    word-wrap: break-word;
}

.cpm-button:hover {
    background-color: var(--vico-accent-blue-light);
    transform: translateY(-2px);
    box-shadow: var(--vico-shadow-md);
}

.cpm-button-alt {
    background-color: var(--vico-accent-purple);
}

.cpm-button-alt:hover {
    background-color: var(--vico-accent-cyan);
}

/* Input textarea styling */
.cpm-textarea-container {
    position: relative;
    width: 100%;
    margin: 1rem 0;
}

.cpm-textarea-field {
    width: 100%;
    min-height: 20vh;
    padding: 12px;
    font-size: 14px;
    line-height: 1.5;
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    background-color: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    resize: vertical;
    transition: border-color 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

.cpm-textarea-field:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    box-shadow: 0 0 0 3px var(--vico-glow-blue);
}

.cpm-textarea-field::placeholder {
    color: var(--vico-text-muted);
}

.cpm-textarea-label {
    display: block;
    margin-bottom: 0.5rem;
    font-size: 14px;
    font-weight: 500;
    color: var(--vico-text-secondary);
}

.cpm-char-count {
    position: absolute;
    bottom: 8px;
    right: 8px;
    font-size: 12px;
    color: var(--vico-text-muted);
}

/* Class to define layout properties for the media container when showing a PDF */
.cpm-media-pdf-mode {
  display: block !important;
  flex-grow: 1 !important; /* Allow it to take space in popup-body */
  flex-shrink: 1 !important;
  height: 400px !important; /* User-defined working height */
  margin-bottom: 20px !important; /* User-defined working margin */
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  overflow: visible !important; /* Crucial for controls/loading inside child */
}

/* =========================================
   MEDIA-ONLY OVERRIDES
   ========================================= */

/* When the popup has 'style-media-only', it means there's only media and no text/headline/buttons. 
   We expand the popup to nearly fill the screen, letting media occupy all the space. */

   /* Hide the header */
  .popup-base.style-media-only .popup-header {
    display: none;
  }

   .popup-base.style-media-only .popup-content {
    /* Expand the popup to a large portion of the screen */
    border-radius: 0; /* remove if you don't want corners squared off */
    max-height: 100%; /* fill the screen */
  }

  .popup-base.style-media-only #close-content-popup {
    /* Hide the close button */
    display: none;
  }

  /* Hide scrollbar in media-only mode */
  .popup-base.style-media-only #cpm-media-container {
    overflow: hidden;
}

  
  /* Hide the headline if it's "media only" */
  .popup-base.style-media-only .popup-header h2 {
    display: none !important;
  }
  
  /* We still keep the close button visible, but you can float it if desired */
  .popup-base.style-media-only .popup-header {
    background-color: transparent;
    border-bottom: none;
    display: flex;
    justify-content: flex-end;
  }
  
  /* Remove padding from the body so media can occupy full height */
  .popup-base.style-media-only .popup-body {
    padding: 0 !important;
    display: flex;
    flex: 1 1 auto;
  }
  
  /* Make the media container fill the rest */
  .popup-base.style-media-only #cpm-media-container {
    flex: 1 1 auto;
    margin: 0;
    width: 100%;
    height: 100%;
  }
  
  /* Force the media elements to fill their container (with object-fit as needed) */
  .popup-base.style-media-only #cpm-media-container img,
  .popup-base.style-media-only #cpm-media-container video,
  .popup-base.style-media-only #cpm-media-container iframe {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain; /* or cover, if you prefer cropping */
  }
  
  /* Hide text content container entirely in media-only mode */
  .popup-base.style-media-only #cpm-text-content {
    display: none !important;
  }
  
  .popup-base.style-media-only #cpm-button-container {
    display: none !important;
  }


  /* =========================================
   MOBILE STYLES
   ========================================= */

   @media screen and (max-width: 768px) {
    /* Buttons */
    .cpm-button {
        padding: 12px 16px;
        font-size: 14px;
        width: 90%;
        word-wrap: break-word;
    }

    /* Text content */
    .popup-base.style-minimal #cpm-text-content {
        font-size: 12px
    }

    /* Subtitles */
    #cpm-media-container video::cue {
        font-size: 14px;
    }
  }

/* EditContentPopupManager.css - Uses Vico design tokens */

/* --------------------------------------------------
   POPUP LAYOUT
-------------------------------------------------- */

/* Object name highlight */
#ecpm-object-name-placeholder {
  background: linear-gradient(135deg, var(--vico-accent-blue) 0%, var(--vico-accent-cyan) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
}

.ecpm-popup-body {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  background-color: var(--vico-bg-deep);
  padding: 0;
  max-height: 70vh;
}

/* Scrollbar styling */
.ecpm-popup-body::-webkit-scrollbar {
  width: var(--vico-scrollbar-width);
}
.ecpm-popup-body::-webkit-scrollbar-track {
  background: transparent;
}
.ecpm-popup-body::-webkit-scrollbar-thumb {
  background: var(--vico-scrollbar-thumb);
  border-radius: 3px;
}
.ecpm-popup-body::-webkit-scrollbar-thumb:hover {
  background: var(--vico-scrollbar-thumb-hover);
}

/* --------------------------------------------------
   GENERAL FORM STYLING
-------------------------------------------------- */
#edit-content-form {
  width: 100%;
  margin: 0;
  padding: var(--vico-space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--vico-space-lg);
  box-sizing: border-box;
}

#edit-content-form *,
#edit-content-form *::before,
#edit-content-form *::after {
  box-sizing: border-box;
}

.ecpm-form-group {
  margin-bottom: 0;
  max-width: 100%;
  overflow: hidden;
}

.ecpm-form-group > label {
  display: flex;
  align-items: center;
  gap: var(--vico-space-sm);
  margin-bottom: var(--vico-space-sm);
  color: var(--vico-text-secondary);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ecpm-form-group input[type="text"],
.ecpm-form-group input[type="url"],
.ecpm-form-group textarea,
.ecpm-form-group select {
  width: 100%;
  max-width: 100%;
  padding: var(--vico-space-sm) var(--vico-space-md);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  background-color: var(--vico-bg-raised);
  color: var(--vico-text-primary);
  font-size: 0.9rem;
  line-height: 1.5;
  transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.ecpm-form-group input[type="text"]::placeholder,
.ecpm-form-group input[type="url"]::placeholder,
.ecpm-form-group textarea::placeholder {
  color: var(--vico-text-muted);
}

.ecpm-form-group input[type="text"]:hover,
.ecpm-form-group input[type="url"]:hover,
.ecpm-form-group textarea:hover,
.ecpm-form-group select:hover {
  border-color: var(--vico-border-hover);
}

.ecpm-form-group input[type="text"]:focus,
.ecpm-form-group input[type="url"]:focus,
.ecpm-form-group textarea:focus,
.ecpm-form-group select:focus {
  outline: none;
  background-color: var(--vico-bg-elevated);
  border-color: var(--vico-accent-blue);
  box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.ecpm-form-group textarea {
  resize: vertical;
  min-height: 80px;
  font-family: inherit;
}

/* --------------------------------------------------
   SPECIFIC COMPONENT STYLING
-------------------------------------------------- */

/* SUBMIT BUTTON (SAVE CHANGES) */
.ecpm-submit-btn {
  display: flex;
  align-items: center;
  gap: var(--vico-space-xs);
  padding: var(--vico-space-sm) var(--vico-space-md);
  background: var(--vico-gradient-green);
  color: var(--vico-bg-base);
  border: none;
  border-radius: var(--vico-radius-md);
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--vico-transition-fast), box-shadow var(--vico-transition-fast), transform 0.1s ease;
  box-shadow: 0 2px 8px var(--vico-glow-green);
  flex-shrink: 0;
}
.ecpm-submit-btn:hover:not(.ecpm-submit-btn-disabled) {
  background: linear-gradient(135deg, var(--vico-accent-green-light) 0%, var(--vico-accent-green) 100%);
  box-shadow: 0 4px 12px rgba(152, 195, 121, 0.4);
  transform: translateY(-1px);
}
.ecpm-submit-btn:active:not(.ecpm-submit-btn-disabled) {
  transform: scale(0.98);
}
.ecpm-submit-btn-disabled {
  background: var(--vico-bg-elevated);
  color: var(--vico-text-muted);
  opacity: 0.6;
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}
.ecpm-save-icon {
  stroke: currentColor;
  width: 16px;
  height: 16px;
}

/* ASSET CONTROLS */
.ecpm-asset-controls {
  display: flex;
  flex-direction: column;
  gap: var(--vico-space-md);
  padding: var(--vico-space-md);
  background-color: var(--vico-bg-base);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-lg);
  margin-top: var(--vico-space-sm);
  max-width: 100%;
}

/* Media asset details block */
.ecpm-asset-controls .ecpm-media-asset-details,
.ecpm-asset-controls .ecpm-asset-display {
  display: flex;
  flex-direction: column;
  gap: var(--vico-space-xs);
  font-size: 0.8rem;
  padding: var(--vico-space-sm) var(--vico-space-md);
  background: var(--vico-bg-raised);
  border-radius: var(--vico-radius-md);
  border: 1px solid var(--vico-border);
  max-width: 100%;
  overflow: hidden;
}

.ecpm-asset-controls .ecpm-media-asset-details > div,
.ecpm-asset-controls .ecpm-asset-display > div {
  display: flex;
  align-items: center;
  gap: var(--vico-space-sm);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ecpm-asset-controls .ecpm-current-asset-id {
  font-weight: 600;
  color: var(--vico-accent-cyan);
  font-family: 'Courier New', monospace;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ecpm-asset-controls .ecpm-media-asset-info-bit,
.ecpm-asset-controls .ecpm-asset-info-bit {
  color: var(--vico-text-muted);
}

/* Asset action buttons row */
.ecpm-asset-controls .ecpm-browse-btn,
.ecpm-asset-controls .ecpm-clear-btn {
  padding: var(--vico-space-sm) var(--vico-space-md);
  font-size: 0.85rem;
  font-weight: 600;
  border-radius: var(--vico-radius-md);
  border: 1px solid var(--vico-border);
  background-color: var(--vico-bg-elevated);
  color: var(--vico-text-primary);
  cursor: pointer;
  transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast), transform 0.1s ease, box-shadow var(--vico-transition-fast);
  width: 100%;
  text-align: center;
}

.ecpm-asset-controls .ecpm-browse-btn:hover {
  background-color: var(--vico-bg-hover);
  border-color: var(--vico-accent-blue);
  color: var(--vico-accent-blue);
  box-shadow: 0 2px 8px var(--vico-glow-blue);
  transform: translateY(-1px);
}

.ecpm-asset-controls .ecpm-clear-btn {
  background-color: rgba(224, 108, 117, 0.08);
  border-color: rgba(224, 108, 117, 0.3);
  color: var(--vico-accent-red);
}

.ecpm-asset-controls .ecpm-clear-btn:hover {
  background-color: rgba(224, 108, 117, 0.15);
  border-color: var(--vico-accent-red);
  box-shadow: 0 2px 8px var(--vico-glow-red);
  transform: translateY(-1px);
}

/* DYNAMICALLY ADDED BUTTONS SECTION */
#ecpm-buttons-container {
  margin-top: var(--vico-space-md);
  padding-top: var(--vico-space-lg);
  border-top: 1px solid var(--vico-border);
}

#ecpm-buttons-container > label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--vico-space-md);
}

.ecpm-add-button {
  background: var(--vico-bg-raised);
  border: 1px dashed rgba(97, 175, 239, 0.4);
  color: var(--vico-accent-blue);
  padding: var(--vico-space-xs) var(--vico-space-md);
  cursor: pointer;
  border-radius: var(--vico-radius-md);
  font-weight: 600;
  font-size: 0.85rem;
  transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.ecpm-add-button:hover {
  background: rgba(97, 175, 239, 0.1);
  border-color: var(--vico-accent-blue);
  color: var(--vico-accent-blue-light);
}

#ecpm-buttons-list {
  display: flex;
  flex-direction: column;
  gap: var(--vico-space-md);
}

.ecpm-button-row {
  display: flex;
  flex-direction: column;
  background-color: var(--vico-bg-base);
  padding: var(--vico-space-md);
  border-radius: var(--vico-radius-lg);
  gap: var(--vico-space-md);
  border: 1px solid var(--vico-border);
  transition: border-color var(--vico-transition-fast);
  max-width: 100%;
}

.ecpm-button-row:hover {
  border-color: var(--vico-border-hover);
}

.ecpm-button-row-first {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--vico-space-md);
}

.ecpm-button-name-label {
  font-size: 0.75rem;
  color: var(--vico-text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ecpm-button-row input[type="text"].ecpm-button-name,
.ecpm-button-row input[type="text"].ecpm-button-event {
  width: 100%;
  max-width: 100%;
  background-color: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  color: var(--vico-text-primary);
  border-radius: var(--vico-radius-md);
  padding: var(--vico-space-sm) var(--vico-space-md);
  font-size: 0.85rem;
  transition: border-color var(--vico-transition-fast), background-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.ecpm-button-row input[type="text"]:hover {
  border-color: var(--vico-border-hover);
}

.ecpm-button-row input[type="text"].ecpm-button-name:focus,
.ecpm-button-row input[type="text"].ecpm-button-event:focus {
  border-color: var(--vico-accent-blue);
  background-color: var(--vico-bg-elevated);
  box-shadow: 0 0 0 2px var(--vico-glow-blue);
  outline: none;
}

.ecpm-remove-button {
  background-color: transparent;
  border: 1px solid rgba(224, 108, 117, 0.3);
  color: var(--vico-accent-red);
  padding: var(--vico-space-xs) var(--vico-space-md);
  cursor: pointer;
  border-radius: var(--vico-radius-md);
  font-size: 0.8rem;
  font-weight: 600;
  transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast), transform 0.1s ease;
  white-space: nowrap;
}

.ecpm-remove-button:hover {
  background-color: rgba(224, 108, 117, 0.12);
  border-color: var(--vico-accent-red);
  transform: translateY(-1px);
}

.ecpm-chain-btn {
  padding: var(--vico-space-sm) var(--vico-space-md);
  background-color: var(--vico-bg-raised);
  width: 100%;
  max-width: 100%;
  color: var(--vico-text-secondary);
  border: 1px dashed var(--vico-border);
  border-radius: var(--vico-radius-md);
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 500;
  transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
  text-align: left;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ecpm-chain-btn:hover {
  background-color: var(--vico-bg-elevated);
  border-color: var(--vico-accent-purple);
  color: var(--vico-accent-purple);
}

/* EVENT CHAIN EDITOR */
.ecpm-eventchain-editor {
  width: 100%;
  margin-top: var(--vico-space-md);
  padding: var(--vico-space-md);
  background-color: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
}

/* SELECT DROPDOWN STYLING */
.ecpm-form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%238891a0%27 stroke-width=%272%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27%3E%3Cpolyline points=%276 9 12 15 18 9%27%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--vico-space-md) center;
  padding-right: calc(var(--vico-space-lg) + 16px);
  cursor: pointer;
}

/* --------------------------------------------------
   UTILITY CLASSES
-------------------------------------------------- */
.hidden {
  display: none !important;
}


/* --------------------------------------------------
   MEDIA QUERIES / RESPONSIVE DESIGN
-------------------------------------------------- */
@media (max-width: 600px) {
  #edit-content-popup .popup-header {
    padding: var(--vico-space-md) var(--vico-space-lg);
  }

  #edit-content-popup .popup-header h2 {
    font-size: 0.9rem;
  }

  #edit-content-form {
    padding: var(--vico-space-lg);
  }

  .ecpm-submit-btn {
    padding: var(--vico-space-sm) var(--vico-space-md);
    font-size: 0.8rem;
  }

  .ecpm-save-icon {
    width: 14px;
    height: 14px;
  }

  .ecpm-asset-controls .ecpm-browse-btn,
  .ecpm-asset-controls .ecpm-clear-btn {
    width: 100%;
    text-align: center;
  }
  
  .ecpm-popup-body {
    max-height: 85vh;
  }
}

@media (max-width: 480px) {
  .ecpm-button-row-first {
    flex-direction: column;
    align-items: stretch;
  }

  .ecpm-remove-button {
    align-self: flex-end;
  }

  #ecpm-buttons-container > label {
    flex-wrap: wrap;
  }
}


/* loginPopupManager.css - Uses Vico design tokens */

.lp-login-section {
    display: none;
    margin-bottom: var(--vico-space-xl);
}

.lp-description {
    margin-bottom: var(--vico-space-xl);
    color: var(--vico-text-secondary);
    font-size: 16px;
}

.lp-input-group {
    position: relative;
    margin-bottom: 25px;
    display: flex;
}

.lp-input {
    width: 100%;
    padding: var(--vico-space-md) var(--vico-space-lg);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    font-size: 16px;
    background-color: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    transition: border-color var(--vico-transition-fast), background-color var(--vico-transition-fast);
}

.lp-input:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    background-color: var(--vico-bg-elevated);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.lp-input-label {
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 16px;
    color: var(--vico-text-muted);
    pointer-events: none;
    transition: top var(--vico-transition-fast), left var(--vico-transition-fast), font-size var(--vico-transition-fast), color var(--vico-transition-fast);
}

.lp-input:focus + .lp-input-label,
.lp-input:not(:placeholder-shown) + .lp-input-label {
    top: -10px;
    left: 10px;
    font-size: 14px;
    background-color: var(--vico-bg-base);
    padding: 0 5px;
    color: var(--vico-accent-blue);
}

.lp-button {
    width: 100%;
    background: var(--vico-gradient-blue);
    color: #fff;
    padding: var(--vico-space-md) var(--vico-space-xl);
    border: none;
    border-radius: var(--vico-radius-md);
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vico-transition-fast), transform 0.1s ease, box-shadow var(--vico-transition-fast);
    box-shadow: 0 2px 8px rgba(97, 175, 239, 0.3);
}

.lp-button:hover {
    background: linear-gradient(135deg, var(--vico-accent-blue-light) 0%, var(--vico-accent-blue) 100%);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(97, 175, 239, 0.4);
}

.lp-button-secondary {
    margin-top: var(--vico-space-lg);
    background: var(--vico-bg-raised);
    color: var(--vico-text-secondary);
    border: 1px solid var(--vico-border);
    box-shadow: none;
}

.lp-button-secondary:hover {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
    box-shadow: none;
}

#logged-in-username {
    font-weight: bold;
    color: var(--vico-accent-blue);
}
/* selectPopupAvatarManager.css - Uses Vico design tokens */

.avatar-description {
    margin-bottom: var(--vico-space-xl);
    color: var(--vico-text-secondary);
    font-size: 16px;
    text-align: center;
    max-width: 400px;
    align-self: center;
}

.avatar-selection-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: var(--vico-space-md);
    width: 100%;
    max-width: 500px;
    padding: var(--vico-space-md);
    align-self: center;
}

.avatar-button {
    position: relative;
    padding: 0;
    border: 2px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s ease, border-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
    aspect-ratio: 1;
    background: var(--vico-bg-raised);
}

.avatar-button img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--vico-transition-fast);
}

/* Hover Effects */
.avatar-button:hover {
    transform: translateY(-4px);
    border-color: var(--vico-accent-blue);
    box-shadow: 0 8px 20px rgba(97, 175, 239, 0.25);
}

.avatar-button:hover img {
    transform: scale(1.05);
}

/* Focus States */
.avatar-button:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    box-shadow: 0 0 0 3px var(--vico-glow-blue);
}

.avatar-button:focus:not(:focus-visible) {
    box-shadow: none;
}

/* Active/Selected State */
.avatar-button:active {
    transform: translateY(1px);
}

/* Selection Indicator */
.avatar-button::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, var(--vico-accent-blue) 0%, var(--vico-accent-purple) 100%);
    opacity: 0;
    transition: opacity var(--vico-transition-fast);
}

.avatar-button:hover::after {
    opacity: 0.1;
}

.avatar-button.selected {
    border-color: var(--vico-accent-green);
}

.avatar-button.selected::after {
    background: var(--vico-accent-green);
    opacity: 0.2;
}

/* Loading State */
.avatar-button.loading {
    cursor: wait;
    opacity: 0.7;
}

/* Mobile Optimization */
@media (max-width: 768px) {
    .avatar-popup-body {
        padding: var(--vico-space-xl);
    }

    .avatar-selection-container {
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        gap: var(--vico-space-lg);
    }

    .avatar-description {
        font-size: 14px;
        margin-bottom: var(--vico-space-xl);
    }
}
/*
  ============================================================================
  Base Container & Visibility
  ============================================================================
*/
.ss-container {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  background-color: var(--vico-bg-base);
  color: var(--vico-text-secondary);
  transition: opacity 0.3s ease;
  opacity: 0;
  pointer-events: none;
  z-index: 997;
}

.ss-container.ss-visible {
  opacity: 1;
  pointer-events: auto;
}

/*
  ============================================================================
  Header
  ============================================================================
*/
.ss-header {
  height: 52px;
  background-color: var(--vico-bg-raised);
  border-bottom: 1px solid var(--vico-border);
  display: flex;
  align-items: center;
  padding: 0 var(--vico-space-lg);
  justify-content: space-between;
  flex-shrink: 0;
}

.ss-header-left {
  display: flex;
  align-items: center;
}

.ss-header-logo {
  height: 28px;
  margin-right: var(--vico-space-sm);
  cursor: pointer;
  transition: opacity var(--vico-transition-fast);
}

.ss-header-logo:hover {
  opacity: 0.8;
}

.ss-header-title {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--vico-text-primary);
}

.ss-header-right {
  display: flex;
  align-items: center;
  gap: var(--vico-space-md);
}

/* Hamburger icon */
.ss-header-toggle {
  background: none;
  border: none;
  cursor: pointer;
  display: none;
  color: var(--vico-text-secondary);
  padding: var(--vico-space-sm);
  border-radius: var(--vico-radius-sm);
  transition: background-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.ss-header-toggle:hover {
  background-color: var(--vico-bg-hover);
  color: var(--vico-text-primary);
}

/*
  ============================================================================
  Overlay
  ============================================================================
*/
.ss-overlay {
  display: none;
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 10;
}
.ss-overlay.ss-overlay-show {
  display: block;
  pointer-events: auto;
  opacity: 1;
}

/*
  ============================================================================
  Content Wrapper
  ============================================================================
*/
.ss-content-wrapper {
  flex: 1;
  display: flex;
  position: relative;
  overflow: hidden;
}

/*
  ============================================================================
  Sidebar
  ============================================================================
*/
.ss-sidebar {
  width: 180px;
  background-color: var(--vico-bg-raised);
  flex-shrink: 0;
  transition: transform 0.3s ease;
  overflow-x: hidden;
  overflow-y: auto;
  position: relative;
  border-right: 1px solid var(--vico-border);
  box-sizing: border-box;
}

/* Hide scrollbar when not needed */
.ss-sidebar::-webkit-scrollbar {
  width: 0;
  background: transparent;
}

.ss-sidebar.ss-sidebar-open {
  transform: translateX(0);
}

.ss-search-wrapper {
  padding: var(--vico-space-md);
  box-sizing: border-box;
}

.ss-search {
  width: 100%;
  padding: var(--vico-space-sm) var(--vico-space-md);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  background-color: var(--vico-bg-elevated);
  color: var(--vico-text-primary);
  font-size: 0.85rem;
  box-sizing: border-box;
  transition: border-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.ss-search::placeholder {
  color: var(--vico-text-muted);
  font-size: 0.8rem;
}

.ss-search:focus {
  outline: none;
  border-color: var(--vico-accent-blue);
  box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.ss-sort-wrapper {
  padding: 0 var(--vico-space-md) var(--vico-space-md);
  box-sizing: border-box;
}

.ss-sort-select {
  width: 100%;
  padding: var(--vico-space-sm);
  border-radius: var(--vico-radius-md);
  background-color: var(--vico-bg-elevated);
  color: var(--vico-text-primary);
  border: 1px solid var(--vico-border);
  font-size: 0.85rem;
  box-sizing: border-box;
  cursor: pointer;
  transition: border-color var(--vico-transition-fast);
}

.ss-sort-select:hover {
  border-color: var(--vico-border-hover);
}

.ss-sort-select:focus {
  outline: none;
  border-color: var(--vico-accent-blue);
}

.ss-category-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--vico-border);
}

.ss-category-item {
  padding: var(--vico-space-sm) var(--vico-space-md);
  border-left: 3px solid transparent;
  cursor: pointer;
  transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
  color: var(--vico-text-secondary);
  font-size: 0.9rem;
}

.ss-category-item:hover {
  background-color: var(--vico-bg-hover);
  color: var(--vico-text-primary);
}

.ss-category-item.active {
  background-color: rgba(97, 175, 239, 0.1);
  border-left-color: var(--vico-accent-blue);
  font-weight: 600;
  color: var(--vico-accent-blue);
}


/* Off-canvas on smaller screens */
@media (max-width: 992px) {
  .ss-header-toggle {
    display: block;
  }
  .ss-sidebar {
    position: fixed;
    top: 56px;
    left: 0;
    bottom: 0;
    width: 220px;
    transform: translateX(-100%);
    z-index: 11;
    background-color: var(--vico-bg-raised);
    box-shadow: var(--vico-shadow-lg);
  }
}

/*
  ============================================================================
  Main / Grid
  ============================================================================
*/
.ss-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  background-color: var(--vico-bg-deep);
  overflow: hidden;
}

.ss-grid {
  flex: 1;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--vico-space-lg);
  padding: var(--vico-space-lg);
  overflow-y: auto;
  align-content: start;
}

/* Empty state */
.ss-empty-state {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--vico-text-muted);
  padding: var(--vico-space-xxl);
}

.ss-empty-state p {
  margin: 0;
  font-size: 1rem;
}

/* Error state */
.ss-error-state {
  grid-column: 1 / -1;
  text-align: center;
  color: var(--vico-accent-red);
  padding: var(--vico-space-xxl);
}

/*
  ============================================================================
  Cards
  ============================================================================
*/
.ss-card {
  background-color: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-lg);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  transition: box-shadow 0.2s ease, transform 0.2s ease, border-color 0.2s ease;
  overflow: hidden;
}

.ss-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--vico-shadow-lg);
  border-color: var(--vico-border-hover);
}

.ss-card-thumb {
  width: 100%;
  height: 150px;
  background-position: center center;
  background-size: cover;
  position: relative;
  background-color: var(--vico-bg-elevated);
}

/* Players online badge on card thumbnail */
.ss-presence-badge {
  position: absolute;
  left: 8px;
  bottom: 8px;
  padding: 0.2rem 0.5rem;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 999px;
  background: rgba(152, 195, 121, 0.9);
  color: var(--vico-bg-deep);
  border: none;
}

.ss-featured-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: var(--vico-gradient-blue);
  color: var(--vico-text-primary);
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.25rem 0.5rem;
  border-radius: var(--vico-radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.ss-card-body {
  padding: var(--vico-space-md);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.ss-card-title {
  margin: 0 0 var(--vico-space-xs) 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--vico-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ss-card-desc {
  flex: 1;
  font-size: 0.8rem;
  word-wrap: break-word;
  margin: 0;
  line-height: 1.4;
  color: var(--vico-text-muted);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ss-details-btn {
  background: var(--vico-gradient-blue);
  color: var(--vico-text-primary);
  font-size: 0.8rem;
  font-weight: 600;
  border: none;
  border-radius: var(--vico-radius-md);
  padding: var(--vico-space-sm) var(--vico-space-md);
  cursor: pointer;
  transition: opacity var(--vico-transition-fast), transform 0.1s ease;
}

.ss-details-btn:hover {
  opacity: 0.9;
}

.ss-details-btn:active {
  transform: translateY(1px);
}

/*
  ============================================================================
  Detail Panel
  ============================================================================
*/
.ss-detail-panel {
  position: fixed;
  top: 0;
  right: -420px;
  width: 420px;
  height: 100%;
  background-color: var(--vico-bg-deep);
  box-shadow: var(--vico-shadow-xl);
  transition: right 0.3s ease;
  z-index: 10000;
  display: flex;
  flex-direction: column;
}

.ss-detail-panel.open {
  right: 0;
}

.ss-detail-close {
  background: none;
  border: none;
  cursor: pointer;
  padding: 1rem;
  align-self: flex-end;
  color: var(--vico-text-secondary);
  transition: color var(--vico-transition-fast);
}

.ss-detail-close:hover {
  color: var(--vico-accent-blue);
}

.ss-detail-thumb {
  height: 220px;
  background-position: center center;
  background-size: cover;
}

.ss-detail-content {
  padding: 1rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}

/* Multiplayer section inside the scene detail panel */
.ss-detail-multiplayer {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--vico-border);
}

.ss-detail-multiplayer h3 {
  margin: 0 0 0.75rem 0;
  font-size: 1rem;
  color: var(--vico-text-primary);
}

.ss-join-name-group {
  margin-bottom: 0.75rem;
}

.ss-join-name-group input[type="text"] {
  width: 100%;
  padding: 0.55rem 0.75rem;
  border-radius: var(--vico-radius-md);
  border: 1px solid var(--vico-border);
  background: var(--vico-bg-raised);
  color: var(--vico-text-primary);
}

.ss-join-name-group input[type="text"]::placeholder {
  color: var(--vico-text-muted);
}

.ss-join-name-group input[type="text"]:focus {
  outline: 2px solid var(--vico-accent-blue);
  outline-offset: 0;
  border-color: var(--vico-accent-blue);
}

.ss-active-rooms {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ss-room-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.6rem 0.75rem;
  border-radius: var(--vico-radius-lg);
  background: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
}

.ss-room-info {
  color: var(--vico-text-secondary);
  font-size: 0.9rem;
}

.ss-room-join-btn {
  background-color: var(--vico-accent-blue);
  color: var(--vico-text-primary);
  font-size: 0.85rem;
  transition: background-color 0.2s ease, transform 0.05s ease;
  border: none;
  border-radius: var(--vico-radius-sm);
  padding: 0.4rem 0.8rem;
  cursor: pointer;
}

.ss-room-join-btn:hover {
  background-color: var(--vico-accent-blue-light);
}

.ss-room-join-btn:active {
  transform: translateY(1px);
}

.ss-no-rooms {
  color: var(--vico-text-muted);
  font-size: 0.9rem;
}

.ss-detail-content h2 {
  margin: 0.5rem 0;
  font-size: 1.4rem;
  color: var(--vico-text-primary);
}

.ss-detail-desc {
  margin: 1rem 0;
  font-size: 0.95rem;
  line-height: 1.4;
  color: var(--vico-text-secondary);
}

.ss-detail-enter {
  background-color: var(--vico-accent-blue);
  color: var(--vico-text-primary);
  border: none;
  padding: 0.7rem 1.2rem;
  border-radius: var(--vico-radius-sm);
  font-size: 0.95rem;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.ss-detail-enter:hover {
  background-color: var(--vico-accent-blue-light);
}

/* Scrollbar styling for grid only - sidebar has hidden scrollbar */
.ss-grid::-webkit-scrollbar {
  width: var(--vico-scrollbar-width);
}

.ss-grid::-webkit-scrollbar-track {
  background: transparent;
}

.ss-grid::-webkit-scrollbar-thumb {
  background: var(--vico-scrollbar-thumb);
  border-radius: 3px;
}

.ss-grid::-webkit-scrollbar-thumb:hover {
  background: var(--vico-scrollbar-thumb-hover);
}

/* Responsive Tweaks */
@media (max-width: 768px) {
  .ss-sidebar {
    width: 220px;
  }

  .ss-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: var(--vico-space-md);
    padding: var(--vico-space-md);
  }

  .ss-detail-panel {
    width: 85%;
    right: -100%;
  }
  .ss-detail-panel.open {
    right: 0;
  }
  .ss-detail-thumb {
    height: 160px;
  }
  .ss-card {
    min-height: 140px;
  }

  .ss-card-thumb {
    height: 120px;
  }

  .ss-card-title {
    font-size: 0.9rem;
  }

  .ss-card-desc {
    font-size: 0.75rem;
  }
}

@media (max-width: 480px) {
  .ss-grid {
    grid-template-columns: 1fr;
  }

  .ss-detail-panel {
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   ASSET BROWSER MODAL - Modern UI matching Vico design system
   Uses shared tokens from tokens.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Container */
.asset-browser-modal-container {
    z-index: 1200;
}

.asset-browser-modal-container,
.asset-browser-modal-container.active {
    pointer-events: none;
}

/* Main Popup Content */
.abp-popup-content {
    padding: 0;
    width: 90%;
    max-width: 750px;
    max-height: 85vh;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-xl);
    box-shadow: var(--vico-shadow-xl);
    display: flex;
    flex-direction: column;
    pointer-events: auto;
}

/* Header */
.abp-popup-content .popup-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-lg) var(--vico-space-xl);
    background: var(--vico-gradient-header);
    border-bottom: 1px solid var(--vico-border);
    box-shadow: inset 0 1px 0 rgba(97, 175, 239, 0.1);
}

.abp-popup-content .popup-header h2 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.abp-popup-content .popup-header .close-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    color: var(--vico-text-secondary);
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.abp-popup-content .popup-header .close-btn:hover {
    background: var(--vico-bg-elevated);
    border-color: var(--vico-accent-red);
    color: var(--vico-accent-red);
}

.abp-popup-content .popup-header .close-btn svg {
    width: 16px;
    height: 16px;
}

/* Body */
.abp-popup-body {
    overflow-y: auto;
    padding: var(--vico-space-lg) var(--vico-space-xl);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 14px;
    background: var(--vico-bg-deep);
}

/* Minimal scrollbar */
.abp-popup-body::-webkit-scrollbar,
.abp-list::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}

.abp-popup-body::-webkit-scrollbar-track,
.abp-list::-webkit-scrollbar-track {
    background: transparent;
}

.abp-popup-body::-webkit-scrollbar-thumb,
.abp-list::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: 3px;
}

.abp-popup-body::-webkit-scrollbar-thumb:hover,
.abp-list::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

/* Description */
.abp-description {
    margin: 0;
    font-size: 0.9rem;
    color: var(--vico-text-secondary);
    line-height: 1.4;
}

/* Header Controls */
.abp-header-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
}

.abp-filter-container {
    display: flex;
    align-items: center;
    gap: 10px;
}

.abp-filter-container label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--vico-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    white-space: nowrap;
}

#abp-type-filter {
    padding: 8px 12px;
    border-radius: var(--vico-radius-md);
    border: 1px solid var(--vico-border);
    background: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    font-size: 0.9rem;
    min-width: 160px;
    cursor: pointer;
    transition: border-color var(--vico-transition-fast);
}

#abp-type-filter:hover {
    border-color: var(--vico-border-hover);
}

#abp-type-filter:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
}

/* Upload Button */
.abp-button {
    padding: 8px 14px;
    border: none;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s, transform 0.1s, box-shadow 0.15s;
}

.abp-button:active {
    transform: scale(0.98);
}

.abp-upload-trigger-btn {
    background: var(--vico-gradient-blue);
    color: #fff;
    white-space: nowrap;
    box-shadow: 0 2px 8px rgba(97, 175, 239, 0.3);
}

.abp-upload-trigger-btn:hover:not(:disabled) {
    background: linear-gradient(135deg, var(--vico-accent-blue-light) 0%, var(--vico-accent-blue) 100%);
    box-shadow: 0 4px 12px rgba(97, 175, 239, 0.4);
}

.abp-upload-trigger-btn:disabled {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-muted);
    box-shadow: none;
    cursor: not-allowed;
}

/* Storage Usage */
.abp-storage-usage-info {
    padding: 10px 14px;
    font-size: 0.85rem;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
}

.abp-storage-usage-info .abp-storage-label {
    color: var(--vico-text-secondary);
}

.abp-storage-usage-info .abp-storage-values {
    font-weight: 600;
    color: var(--vico-text-primary);
}

.abp-storage-usage-info.storage-low .abp-storage-values {
    color: var(--vico-accent-green);
}

.abp-storage-usage-info.storage-medium .abp-storage-values {
    color: var(--vico-accent-amber);
}

.abp-storage-usage-info.storage-high .abp-storage-values {
    color: var(--vico-accent-red);
}

/* Search Container */
.abp-search-container {
    margin: 0;
}

#abp-search-input {
    width: 100%;
    padding: 10px 14px;
    border-radius: var(--vico-radius-md);
    border: 1px solid var(--vico-border);
    background: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    font-size: 0.9rem;
    box-sizing: border-box;
    transition: border-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

#abp-search-input:hover {
    border-color: var(--vico-border-hover);
}

#abp-search-input:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

#abp-search-input::placeholder {
    color: var(--vico-text-muted);
}

/* Asset List */
.abp-list {
    list-style: none;
    padding: 0;
    margin: 0;
    flex: 1;
    overflow-y: auto;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
}

.abp-list-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    align-items: center;
    padding: 12px 14px;
    border-bottom: 1px solid var(--vico-border);
    transition: background 0.1s;
}

.abp-list-item:hover {
    background: var(--vico-bg-raised);
}

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

/* Currently Selected Highlight */
.abp-list-item.currently-selected {
    background: rgba(97, 175, 239, 0.1) !important;
    border-left: 3px solid var(--vico-accent-blue);
    padding-left: 11px;
}

.abp-list-item.currently-selected .abp-asset-name {
    color: var(--vico-accent-blue) !important;
}

/* Asset Preview Image */
.abp-asset-preview-image {
    grid-column: 1 / 2;
    width: 56px;
    height: 42px;
    border-radius: var(--vico-radius-sm);
    border: 1px solid var(--vico-border);
    object-fit: cover;
    background: var(--vico-bg-raised);
}

/* Asset Info */
.abp-asset-info {
    grid-column: 2 / 3;
    display: flex;
    flex-direction: column;
    gap: 2px;
    overflow: hidden;
    min-width: 0;
}

.abp-asset-name {
    font-weight: 600;
    font-size: 0.95rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--vico-text-primary);
}

.abp-asset-type,
.abp-asset-size {
    font-size: 0.7rem;
    color: var(--vico-text-muted);
    margin-left: 8px;
    font-weight: 400;
}

.abp-asset-type {
    color: var(--vico-accent-purple);
}

.abp-asset-description {
    font-size: 0.8rem;
    color: var(--vico-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Asset Actions */
.abp-asset-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    grid-column: 3 / 4;
}

.abp-select-button {
    padding: 6px 12px;
    background: var(--vico-gradient-green);
    color: var(--vico-bg-base);
    border: none;
    border-radius: var(--vico-radius-md);
    font-size: 0.8rem;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.abp-select-button:hover {
    background: linear-gradient(135deg, var(--vico-accent-green-light) 0%, var(--vico-accent-green) 100%);
    box-shadow: 0 2px 8px var(--vico-glow-green);
}

.abp-edit-quiz-button {
    padding: 6px 12px;
    background: var(--vico-bg-elevated);
    color: var(--vico-accent-blue);
    border: 1px solid rgba(97, 175, 239, 0.3);
    border-radius: var(--vico-radius-md);
    cursor: pointer;
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.abp-edit-quiz-button:hover {
    background: rgba(97, 175, 239, 0.1);
    border-color: var(--vico-accent-blue);
}

.abp-delete-button {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    color: var(--vico-text-muted);
    border: 1px solid transparent;
    border-radius: var(--vico-radius-md);
    cursor: pointer;
    font-size: 1rem;
    transition: background var(--vico-transition-fast), color var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.abp-delete-button:hover {
    background: rgba(224, 108, 117, 0.1);
    color: var(--vico-accent-red);
    border-color: rgba(224, 108, 117, 0.3);
}

/* Public Status */
.abp-public-checkbox-label {
    display: flex;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    font-size: 0.8rem;
    color: var(--vico-text-secondary);
}

.abp-public-checkbox {
    appearance: none;
    width: 16px;
    height: 16px;
    background: var(--vico-bg-raised);
    border: 2px solid var(--vico-border);
    border-radius: 3px;
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.abp-public-checkbox:hover {
    border-color: var(--vico-accent-blue);
}

.abp-public-checkbox:checked {
    background: var(--vico-accent-blue);
    border-color: var(--vico-accent-blue);
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27white%27%3E%3Cpath d=%27M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z%27/%3E%3C/svg%3E");
    background-size: 10px;
    background-repeat: no-repeat;
    background-position: center;
}

.abp-public-checkbox:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}

.abp-public-label {
    user-select: none;
    font-size: 0.75rem;
}

.abp-public-indicator {
    font-size: 0.9rem;
    padding: 2px 6px;
    border-radius: var(--vico-radius-sm);
}

.abp-public-indicator.public {
    color: var(--vico-accent-green);
    background: rgba(152, 195, 121, 0.1);
}

.abp-public-indicator.private {
    color: var(--vico-accent-amber);
    background: rgba(229, 192, 123, 0.1);
}

/* Loading & Empty States */
#abp-loading-state {
    padding: 40px 20px;
    text-align: center;
    color: var(--vico-text-secondary);
    font-size: 0.9rem;
}

.abp-list-item-empty,
.abp-list-item-error {
    padding: 40px 20px;
    text-align: center;
    color: var(--vico-text-muted);
    font-style: italic;
    font-size: 0.9rem;
}

/* Responsive */
@media screen and (max-width: 600px) {
    .abp-popup-content {
        max-width: 95%;
    }
    
    .abp-popup-body {
        padding: 12px 14px;
    }

    .abp-header-controls {
        flex-direction: column;
        align-items: stretch;
    }

    .abp-filter-container {
        flex-direction: column;
        align-items: stretch;
        gap: 6px;
    }

    #abp-type-filter {
        min-width: auto;
        width: 100%;
    }

    .abp-list-item {
        grid-template-columns: auto 1fr;
        gap: 10px;
    }
    
    .abp-asset-info {
        grid-column: 2 / 3;
    }

    .abp-asset-actions {
        grid-column: 1 / -1;
        grid-row: 2 / 3;
        justify-content: flex-start;
        margin-top: 8px;
    }

    .abp-asset-preview-image {
        width: 48px;
        height: 36px;
    }
}

/* FRONTEND/src/css/uploadAssetModal.css */

/* Container overrides */
.upload-asset-modal-container {
    z-index: 1200;
}

.upload-asset-modal-container,
.upload-asset-modal-container.active {
    pointer-events: none;
}

.uap-popup-content {
    padding: 0;
    width: 90%;
    max-width: 500px;
    max-height: 85vh;
}

/* Inherit header styles */
.uap-popup-content .popup-header {
    border-bottom: 1px solid var(--vico-border);
    padding: 15px 20px;
}

.uap-popup-body {
    padding: 20px;
}

#upload-asset-form {
    display: flex;
    flex-direction: column;
    gap: 15px; /* Spacing between form groups */
}

#uap-description {
    margin-bottom: 10px;
    font-size: 14px;
    color: var(--vico-text-secondary);
}

.uap-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.uap-form-group label {
    font-size: 13px;
    font-weight: 500;
    color: var(--vico-text-secondary);
}

.uap-form-group input[type="text"],
.uap-form-group input[type="file"] {
    padding: 10px 12px;
    border-radius: var(--vico-radius-sm);
    border: 1px solid var(--vico-border);
    background-color: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    font-size: 14px;
    width: 100%; 
    box-sizing: border-box;
}

.uap-form-group input[type="file"] {
    padding: 8px; /* Slightly less padding for file input */
}

.uap-form-group input[type="file"]::file-selector-button {
    padding: 6px 12px;
    margin-right: 10px;
    border: none;
    background-color: var(--vico-bg-hover);
    color: var(--vico-text-primary);
    border-radius: var(--vico-radius-sm);
    cursor: pointer;
    transition: background-color var(--vico-transition-fast);
}

.uap-form-group input[type="file"]::file-selector-button:hover {
    background-color: var(--vico-bg-elevated);
}

.uap-button.uap-submit-btn {
    padding: 12px 20px; /* Larger button */
    margin-top: 10px;
    background-color: var(--vico-accent-green);
    color: var(--vico-text-primary);
    font-size: 15px;
    transition: background-color var(--vico-transition-fast), transform 0.1s ease;
    border: none;
    border-radius: var(--vico-radius-md);
    cursor: pointer;
}

.uap-button.uap-submit-btn:hover:not(:disabled) {
    background-color: var(--vico-accent-green-light);
    transform: translateY(-1px);
}

.uap-button.uap-submit-btn:disabled {
    background-color: var(--vico-bg-hover);
    opacity: 0.6;
    cursor: not-allowed;
}

.uap-upload-status {
    margin-top: 10px;
    font-size: 13px;
    min-height: 1.2em; 
    text-align: center;
    color: var(--vico-text-secondary);
}

/* New styles for storage usage info */
.uap-storage-usage-info {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid var(--vico-border);
}

.uap-storage-label {
    font-size: 13px;
    color: var(--vico-text-secondary);
    margin-bottom: 8px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.uap-storage-values {
    font-weight: 600;
    color: var(--vico-text-primary);
}

.uap-storage-progress-bar-container {
    width: 100%;
    height: 10px; /* Slimmer progress bar */
    background-color: var(--vico-bg-raised);
    border-radius: var(--vico-radius-sm);
    overflow: hidden;
    border: 1px solid var(--vico-border);
}

.uap-storage-progress-bar {
    height: 100%;
    /* background-color is set inline by JS */
    border-radius: var(--vico-radius-sm);
    transition: width 0.3s ease-in-out, background-color 0.3s ease-in-out;
    text-align: right;
    line-height: 10px; /* Match height */
    font-size: 8px; /* Very small text for percentage, if ever needed inside */
    color: var(--vico-text-primary);
}

/* Responsive adjustments if needed */
@media screen and (max-width: 600px) {
    .uap-popup-content {
        max-width: 95%;
    }
    .uap-popup-body {
        padding: 15px;
    }
}

/* adminDashboardManager.css */

.adm-popup-section {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-lg);
    margin-bottom: var(--vico-space-xl);
}

.adm-button {
    width: 100%;
    text-align: center;
}

/* Ensuring the popup content itself has some padding if not already handled by popup-base */
.admin-dashboard-popup-content .popup-body {
    padding-top: var(--vico-space-xl);
}

/* userFormModalManager.css - Modern User Form Modal */

/* ═══════════════════════════════════════════════════════════════════════════
   CONTAINER
   ═══════════════════════════════════════════════════════════════════════════ */
.user-form-modal-container {
    z-index: 1200;
}

.user-form-modal-container,
.user-form-modal-container.active {
    pointer-events: none;
}

.ufm-modal-content {
    pointer-events: auto;
    padding: 0;
    width: 90%;
    max-width: 560px;
    /* Use dvh with vh fallback for proper mobile viewport handling */
    max-height: 85vh;
    max-height: 85dvh;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-xl);
    box-shadow: var(--vico-shadow-xl);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════════════════ */
.ufm-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-lg) var(--vico-space-xl);
    background: var(--vico-gradient-header);
    border-bottom: 1px solid var(--vico-border);
    box-shadow: inset 0 1px 0 rgba(97, 175, 239, 0.1);
}

.ufm-header-title {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
}

.ufm-header-title i {
    font-size: 1.15rem;
    color: var(--vico-accent-blue);
}

.ufm-header-title h3,
.ufm-modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.ufm-close-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-muted);
    cursor: pointer;
    font-size: 0.9rem;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.ufm-close-btn:hover {
    background: rgba(224, 108, 117, 0.1);
    border-color: var(--vico-accent-red);
    color: var(--vico-accent-red);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FORM
   ═══════════════════════════════════════════════════════════════════════════ */
.ufm-form {
    display: flex;
    flex-direction: column;
    padding: var(--vico-space-lg);
    overflow-y: auto;
    background: var(--vico-bg-deep);
    flex: 1;
    min-height: 0;
}

/* Scrollbar */
.ufm-form::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}
.ufm-form::-webkit-scrollbar-track {
    background: transparent;
}
.ufm-form::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: 3px;
}
.ufm-form::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

/* Sections */
.ufm-section {
    margin-bottom: var(--vico-space-lg);
    padding: var(--vico-space-md);
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    flex-shrink: 0;
}

.ufm-section:last-of-type {
    margin-bottom: var(--vico-space-md);
}

.ufm-section-label {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    margin-bottom: var(--vico-space-md);
    padding-bottom: var(--vico-space-xs);
    border-bottom: 1px solid var(--vico-border);
}

.ufm-section-label i {
    font-size: 0.85rem;
    color: var(--vico-accent-blue);
}

.ufm-section-label span {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--vico-text-secondary);
}

/* Fields */
.ufm-field {
    margin-bottom: var(--vico-space-md);
}

.ufm-field:last-child {
    margin-bottom: 0;
}

.ufm-field label {
    display: block;
    margin-bottom: var(--vico-space-xs);
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--vico-text-secondary);
}

.ufm-required {
    color: var(--vico-accent-red);
}

.ufm-form-row {
    display: flex;
    gap: var(--vico-space-lg);
    flex-wrap: wrap;
}

.ufm-form-row .ufm-field {
    margin-bottom: var(--vico-space-lg);
}

.ufm-half-width {
    flex: 1;
    min-width: 140px;
}

/* Inputs */
.ufm-input,
.ufm-select,
.ufm-textarea {
    width: 100%;
    padding: var(--vico-space-sm) var(--vico-space-md);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    font-size: 13px;
    background-color: var(--vico-bg-base);
    color: var(--vico-text-primary);
    transition: border-color var(--vico-transition-fast), background-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
    box-sizing: border-box;
}

.ufm-input::placeholder,
.ufm-textarea::placeholder {
    color: var(--vico-text-muted);
}

.ufm-input:hover,
.ufm-select:hover,
.ufm-textarea:hover {
    border-color: var(--vico-border-hover);
}

.ufm-input:focus,
.ufm-select:focus,
.ufm-textarea:focus {
    outline: none;
    border-color: var(--vico-accent-blue);
    background-color: var(--vico-bg-elevated);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.ufm-textarea {
    min-height: 60px;
    resize: vertical;
    font-family: inherit;
}

.ufm-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27%238891a0%27%3E%3Cpath d=%27M7 10l5 5 5-5z%27/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 18px;
    padding-right: 40px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ACTIONS
   ═══════════════════════════════════════════════════════════════════════════ */
.ufm-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: var(--vico-space-md);
    padding-top: var(--vico-space-lg);
    border-top: 1px solid var(--vico-border);
    margin-top: var(--vico-space-sm);
}

.ufm-button {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    padding: var(--vico-space-md) var(--vico-space-xl);
    font-size: 14px;
    font-weight: 600;
    border: none;
    border-radius: var(--vico-radius-md);
    cursor: pointer;
    transition: background var(--vico-transition-fast), transform 0.1s ease, box-shadow var(--vico-transition-fast);
}

.ufm-button i {
    font-size: 0.85rem;
}

.ufm-primary-button {
    background: var(--vico-gradient-blue);
    color: #fff;
    box-shadow: 0 2px 8px rgba(97, 175, 239, 0.3);
}

.ufm-primary-button:hover:not(:disabled) {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(97, 175, 239, 0.4);
}

.ufm-primary-button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.ufm-delete-button {
    background: rgba(224, 108, 117, 0.1);
    color: var(--vico-accent-red);
    border: 1px solid rgba(224, 108, 117, 0.3);
}

.ufm-delete-button:hover:not(:disabled) {
    background: rgba(224, 108, 117, 0.2);
    border-color: var(--vico-accent-red);
    box-shadow: 0 4px 12px rgba(224, 108, 117, 0.2);
}

.ufm-delete-button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

/* Hide delete button by default */
#ufm-delete-user-btn {
    display: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 500px) {
    .ufm-modal-content {
        width: 95%;
        max-width: none;
        /* Use dvh with vh fallback for proper mobile viewport handling */
        max-height: 90vh;
        max-height: 90dvh;
        /* Account for safe areas on notched devices */
        margin-top: env(safe-area-inset-top, 0);
        margin-bottom: env(safe-area-inset-bottom, 0);
    }

    .ufm-modal-header {
        padding: var(--vico-space-md) var(--vico-space-lg);
        flex-shrink: 0;
    }

    .ufm-header-title h3 {
        font-size: 1rem;
    }

    .ufm-form {
        padding: var(--vico-space-md);
        /* Ensure proper scrolling with flex layout */
        flex: 1 1 auto;
        min-height: 0;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }

    .ufm-section {
        padding: var(--vico-space-md);
        margin-bottom: var(--vico-space-md);
    }

    .ufm-form-row {
        flex-direction: column;
        gap: 0;
    }

    .ufm-half-width {
        min-width: 100%;
    }

    .ufm-form-actions {
        flex-direction: column-reverse;
        padding-top: var(--vico-space-md);
        flex-shrink: 0;
    }

    .ufm-button {
        width: 100%;
        justify-content: center;
    }
}

.notification {
    padding: 5px 10px;
    font-family: var(--primary-font);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-text-primary);
    background-color: var(--vico-bg-elevated);
    position: fixed;
    z-index: 1000;
    box-shadow: var(--vico-shadow-md);
}

.notification-flex-container {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.notification-text {
    margin-right: 10px;
}

/* Leverage shared panel container/overlay */
.mic-modal-base {
    z-index: 9999;
}

/* Overlay */
.mic-modal-overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.75);
}

/* Modal Content Container */
.mic-modal-content {
    font-family: var(--secondary-font);
    color: var(--vico-text-secondary);
    width: 90%;
    max-width: 500px;
}

/* Modal Header */
.mic-modal-header {
    padding: 30px;
    background-color: var(--vico-bg-raised);
    text-align: center;
    border-bottom: 1px solid var(--vico-border);
}

.mic-modal-header h3 {
    margin: 0;
    font-size: 24px;
    color: var(--vico-text-primary);
}

/* Modal Body */
.mic-modal-body {
    padding: 30px;
    background-color: transparent;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.mic-modal-context {
    font-size: 16px;
    margin-bottom: 20px;
}

.mic-modal-privacy-container {
    margin-bottom: 20px;
}

.mic-modal-privacy-header {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}

.mic-modal-privacy-header svg {
    margin-right: 8px;
}

.mic-modal-privacy-header span {
    font-weight: bold;
    font-size: 18px;
}

.mic-modal-privacy-list {
    list-style: disc;
    margin-left: 20px;
}

.mic-modal-privacy-list li {
    margin-bottom: 8px;
}

/* Button Group */
.mic-modal-button-group {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
}

.mic-modal-primary-button {
    background-color: var(--vico-accent-blue);
    color: var(--vico-text-primary);
}

.mic-modal-primary-button:hover {
    background-color: var(--vico-accent-blue-light);
}

.mic-modal-secondary-button {
    background-color: var(--vico-accent-purple);
    color: var(--vico-text-primary);
}

.mic-modal-secondary-button:hover {
    background-color: var(--vico-accent-cyan);
}

/* Loader inside the button */
.mic-modal-button-loader {
    display: none;
    margin-left: 10px;
    border: 2px solid var(--vico-text-primary);
    border-top: 2px solid transparent;
    border-radius: 50%;
    width: 16px;
    height: 16px;
    animation: mic-modal-spinner 0.6s linear infinite;
}

.mic-modal-primary-button.loading .mic-modal-button-text {
    visibility: hidden;
}

.mic-modal-primary-button.loading .mic-modal-button-loader {
    display: inline-block;
}

@keyframes mic-modal-spinner {
    to {
        transform: rotate(360deg);
    }
}

/* Responsive Design */
@media (max-width: 600px) {
    .mic-modal-content {
        width: 95%;
    }

    .mic-modal-header h3 {
        font-size: 20px;
    }

    .mic-modal-context {
        font-size: 14px;
    }

    .mic-modal-privacy-header span {
        font-size: 16px;
    }
}

/* iframePopup.css */

.iframePopup-content-container {
    background-color: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    box-shadow: var(--vico-shadow-xl);
    z-index: 1000;
    overflow: hidden;
    position: fixed;
    top: 10px;
    right: 10px;
    width: 48%;
    height: 95%;
    animation: fadeInIframe 0.5s ease-in-out;
    border-radius: var(--vico-radius-lg);
}

@keyframes fadeInIframe {
    from {
        opacity: 0;
        transform: scale(0.0);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.iframePopup-buttons {
    position: absolute;
    top: 5px;
    left: 5px;
    display: flex;
    gap: var(--vico-space-sm);
    z-index: 1001;
}

.iframePopup-close-button,
.iframePopup-fullscreen-button {
    background-color: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
    border: 1px solid var(--vico-border);
    padding: var(--vico-space-sm) var(--vico-space-md);
    border-radius: var(--vico-radius-sm);
    cursor: pointer;
    font-size: 14px;
    transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.iframePopup-close-button:hover,
.iframePopup-fullscreen-button:hover {
    background-color: var(--vico-bg-hover);
    border-color: var(--vico-accent-blue);
}

.iframePopup-close-button {
    background-color: var(--vico-accent-red);
    border-color: var(--vico-accent-red);
}

.iframePopup-close-button:hover {
    background-color: var(--vico-accent-red-dark);
    border-color: var(--vico-accent-red-dark);
}

.iframePopup-iframe {
    width: 100%;
    height: 100%;
    border: none;
}

/* Fullscreen mode */
.iframePopup-content-container.fullscreen {
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
}

/* Quiz UI Manager - Vico Design System */

/* ============================================
   QUIZ CONTAINER & LAYOUT
============================================ */

#quiz-container .popup-content {
  background: var(--vico-bg-base);
  border: 1px solid var(--vico-border);
  max-width: 700px;
}

#quiz-container .popup-header {
  padding: var(--vico-space-md) var(--vico-space-xl);
  border-bottom: 1px solid var(--vico-border);
  background: var(--vico-gradient-header);
}

#quiz-container .popup-header h2 {
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--vico-text-secondary);
  margin: 0;
}

.header-buttons-quiz {
  display: flex;
  align-items: center;
  gap: var(--vico-space-md);
}

#quiz-container .popup-body {
  max-height: 70vh;
  background-color: var(--vico-bg-deep);
  padding: var(--vico-space-lg);
}

/* ============================================
   QUESTION SECTION
============================================ */

.quiz-question-wrapper {
  padding: var(--vico-space-md);
  background-color: transparent;
  border-radius: var(--vico-radius-lg);
  margin-bottom: var(--vico-space-md);
}

.quiz-question {
  display: flex;
  align-items: center;
  flex-direction: row;
  justify-content: space-between;
  gap: var(--vico-space-lg);
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--vico-text-primary);
  line-height: 1.4;
  padding: var(--vico-space-sm);
}

.quiz-question p {
  font-size: 0.85rem;
  color: var(--vico-text-muted);
  margin-top: var(--vico-space-sm);
}

.quiz-question img {
  max-width: 40%;
  height: auto;
  max-height: 150px;
  border-radius: var(--vico-radius-lg);
  box-shadow: var(--vico-shadow-md);
  cursor: zoom-in;
  transition: transform var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.quiz-question img:hover {
  transform: scale(1.02);
  box-shadow: var(--vico-shadow-lg);
}

.quiz-instruction {
  font-size: 0.85rem;
  color: var(--vico-accent-amber);
  font-style: italic;
  margin-top: var(--vico-space-sm);
}

/* ============================================
   ANSWERS SECTION
============================================ */

.quiz-answers-wrapper {
  flex: 1;
  overflow-y: auto;
  max-height: 45vh;
  padding: var(--vico-space-xs);
  margin-bottom: var(--vico-space-lg);
}

/* Scrollbar for answers */
.quiz-answers-wrapper::-webkit-scrollbar {
  width: var(--vico-scrollbar-width);
}
.quiz-answers-wrapper::-webkit-scrollbar-track {
  background: transparent;
}
.quiz-answers-wrapper::-webkit-scrollbar-thumb {
  background: var(--vico-scrollbar-thumb);
  border-radius: 3px;
}
.quiz-answers-wrapper::-webkit-scrollbar-thumb:hover {
  background: var(--vico-scrollbar-thumb-hover);
}

.quiz-answers {
  display: flex;
  flex-direction: column;
  gap: var(--vico-space-md);
  width: 100%;
}

/* Answer Button - Default State */
.quiz-answer {
  background-color: var(--vico-bg-raised);
  color: var(--vico-text-secondary);
  box-shadow: var(--vico-shadow-sm);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-lg);
  padding: var(--vico-space-md) var(--vico-space-lg);
  cursor: pointer;
  transition: background-color var(--vico-transition-fast), 
              border-color var(--vico-transition-fast), 
              transform 0.15s ease,
              box-shadow var(--vico-transition-fast);
  width: 100%;
  font-size: 1.1rem;
  line-height: 1.3;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  text-align: left;
}

.quiz-answer span {
  flex: 1;
}

.quiz-answer img {
  max-height: 80px;
  margin-left: auto;
  border-radius: var(--vico-radius-md);
  cursor: zoom-in;
}

/* Answer - Hover State */
.quiz-answer:hover {
  background-color: var(--vico-bg-hover);
  border-color: var(--vico-border-hover);
  transform: translateY(-2px);
  box-shadow: var(--vico-shadow-md);
}

/* Answer - Selected State (before submission) */
.quiz-answer.selected {
  background-color: var(--vico-bg-elevated);
  border: 2px solid var(--vico-accent-blue);
  color: var(--vico-text-primary);
  box-shadow: 0 0 0 3px var(--vico-glow-blue);
}

/* Answer - Correct State */
.quiz-answer.correct {
  background: var(--vico-gradient-green);
  color: var(--vico-text-primary);
  border: 2px solid var(--vico-accent-green);
  box-shadow: 0 4px 12px var(--vico-glow-green);
  cursor: default;
}

/* Answer - Incorrect State */
.quiz-answer.incorrect {
  background: linear-gradient(135deg, var(--vico-accent-red) 0%, var(--vico-accent-red-dark) 100%);
  color: var(--vico-text-primary);
  border: 2px solid var(--vico-accent-red);
  box-shadow: 0 4px 12px var(--vico-glow-red);
  cursor: default;
}

/* Disable hover on answered */
.quiz-answer.correct:hover,
.quiz-answer.incorrect:hover {
  transform: none;
}

/* ============================================
   MINIMAL STYLE VARIANT
============================================ */

#quiz-container.popup-base.style-minimal .popup-content {
  background: transparent;
  border: none;
  box-shadow: none;
  max-width: 73%;
  max-height: 100%;
}

#quiz-container.popup-base.style-minimal .popup-header {
  background-color: transparent;
  border-bottom: none;
}

#quiz-container.style-minimal .quiz-answer {
  background-color: rgba(26, 29, 36, 0.8);
  width: 60%;
  border: 2px solid var(--vico-border);
}

#quiz-container.style-minimal .quiz-answer:hover {
  border-color: var(--vico-accent-blue);
}

/* ============================================
   SUBMIT BUTTON
============================================ */

.quiz-submit {
  margin-top: var(--vico-space-md);
  width: 50%;
  align-self: center;
  padding: var(--vico-space-md) var(--vico-space-xl);
  background: var(--vico-gradient-blue);
  color: var(--vico-text-primary);
  border: none;
  border-radius: var(--vico-radius-lg);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--vico-transition-fast), 
              transform 0.15s ease, 
              box-shadow var(--vico-transition-fast);
  box-shadow: 0 4px 12px var(--vico-glow-blue);
}

.quiz-submit:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(97, 175, 239, 0.4);
}

.quiz-submit:disabled {
  background: var(--vico-bg-elevated);
  color: var(--vico-text-muted);
  cursor: not-allowed;
  box-shadow: none;
}

/* ============================================
   PROGRESS BAR
============================================ */

.quiz-progress-bar {
  width: 100%;
  height: 8px;
  background-color: var(--vico-bg-raised);
  border-radius: var(--vico-radius-xl);
  overflow: hidden;
  display: flex;
  margin-top: var(--vico-space-lg);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.2);
}

.quiz-progress-segment {
  flex: 1;
  height: 100%;
  position: relative;
  background-color: transparent;
  transition: background-color 0.3s ease;
}

.quiz-progress-segment + .quiz-progress-segment {
  border-left: 1px solid var(--vico-bg-base);
}

.quiz-progress-segment.correct {
  background: var(--vico-gradient-green);
}

.quiz-progress-segment.incorrect {
  background: linear-gradient(90deg, var(--vico-accent-red) 0%, var(--vico-accent-red-dark) 100%);
}

.quiz-progress-segment.filled {
  animation: segmentFill 0.4s ease-out forwards;
}

@keyframes segmentFill {
  from { opacity: 0; transform: scaleX(0); }
  to { opacity: 1; transform: scaleX(1); }
}

.question-number {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--vico-text-primary);
  font-size: 10px;
  font-weight: 700;
  opacity: 0;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
}

.quiz-progress-segment.show-number .question-number {
  animation: numberPop 0.4s ease-out forwards;
}

@keyframes numberPop {
  0% { opacity: 0; transform: translate(-50%, -50%) scale(0); }
  70% { transform: translate(-50%, -50%) scale(1.3); }
  100% { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

/* ============================================
   RESULTS SCREEN
============================================ */

.quiz-results {
  text-align: center;
  padding: var(--vico-space-xl);
}

.quiz-results h2 {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: var(--vico-space-lg);
  background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.quiz-results p {
  font-size: 1.2rem;
  color: var(--vico-text-secondary);
  margin-bottom: var(--vico-space-xl);
  line-height: 1.5;
}

.quiz-results-progress {
  margin-top: var(--vico-space-xl);
}

/* Score Circle */
.quiz-score-circle {
  width: 160px;
  height: 160px;
  margin: 0 auto var(--vico-space-xl);
}

.circular-chart {
  display: block;
  margin: 0 auto;
  max-width: 100%;
}

.circle-bg {
  fill: none;
  stroke: var(--vico-bg-elevated);
  stroke-width: 3.8;
}

.circle {
  fill: none;
  stroke: var(--vico-accent-blue);
  stroke-width: 3;
  stroke-linecap: round;
  transform-origin: center;
  animation: circleProgress 1s ease-out forwards;
}

@keyframes circleProgress {
  from { stroke-dasharray: 0, 100; }
}

.quiz-percentage {
  fill: var(--vico-text-primary);
  font-family: inherit;
  font-size: 0.5em;
  font-weight: 700;
  text-anchor: middle;
}

/* ============================================
   FEEDBACK (if used)
============================================ */

.quiz-feedback {
  display: none;
  padding: var(--vico-space-md);
  border-radius: var(--vico-radius-md);
  margin-top: var(--vico-space-md);
  font-weight: 600;
  text-align: center;
}

.quiz-feedback.show {
  display: block;
  animation: feedbackSlide 0.3s ease-out;
}

@keyframes feedbackSlide {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

.quiz-feedback.correct {
  background-color: rgba(152, 195, 121, 0.2);
  color: var(--vico-accent-green);
  border: 1px solid var(--vico-accent-green);
}

.quiz-feedback.incorrect {
  background-color: rgba(224, 108, 117, 0.2);
  color: var(--vico-accent-red);
  border: 1px solid var(--vico-accent-red);
}

/* ============================================
   IMAGE ZOOM OVERLAY
============================================ */

.quiz-image-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  cursor: zoom-out;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--vico-transition-normal), visibility var(--vico-transition-normal);
}

.quiz-image-overlay.visible {
  opacity: 1;
  visibility: visible;
}

.quiz-image-overlay img {
  max-width: 85vw;
  max-height: 85vh;
  object-fit: contain;
  box-shadow: var(--vico-shadow-xl);
  border-radius: var(--vico-radius-lg);
  cursor: zoom-out;
  animation: zoomIn 0.3s ease-out;
}

@keyframes zoomIn {
  from { transform: scale(0.9); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

/* ============================================
   RESPONSIVE DESIGN
============================================ */

@media (max-width: 768px) {
  #quiz-container .popup-content {
    max-width: 95%;
    max-height: 95vh;
  }

  #quiz-container .popup-header {
    padding: var(--vico-space-sm) var(--vico-space-md);
  }

  #quiz-container .popup-header h2 {
    font-size: 0.85rem;
  }

  #quiz-container .popup-body {
    padding: var(--vico-space-md);
  }

  .quiz-question-wrapper {
    padding: var(--vico-space-sm);
  }

  .quiz-question {
    font-size: 1.1rem;
    flex-direction: column;
    align-items: flex-start;
  }

  .quiz-question img {
    max-width: 100%;
    max-height: 150px;
    margin-top: var(--vico-space-md);
  }

  .quiz-answers-wrapper {
    max-height: 50vh;
  }

  .quiz-answer {
    padding: var(--vico-space-md);
    font-size: 1rem;
    min-height: 48px;
  }

  .quiz-answer img {
    max-width: 30%;
    max-height: 60px;
  }

  .quiz-submit {
    width: 80%;
    padding: var(--vico-space-md);
  }

  .quiz-progress-bar {
    height: 6px;
  }

  .question-number {
    font-size: 8px;
  }

  .quiz-results h2 {
    font-size: 1.6rem;
  }

  .quiz-results p {
    font-size: 1rem;
  }

  .quiz-score-circle {
    width: 120px;
    height: 120px;
  }

  #quiz-container.style-minimal .quiz-answer {
    width: 90%;
  }
}

@media (max-width: 480px) {
  .quiz-question {
    font-size: 1rem;
  }

  .quiz-answer {
    font-size: 0.95rem;
    padding: var(--vico-space-sm) var(--vico-space-md);
  }

  .quiz-submit {
    width: 100%;
    font-size: 0.95rem;
  }

  .quiz-results h2 {
    font-size: 1.4rem;
  }

  .quiz-score-circle {
    width: 100px;
    height: 100px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   VICO BASE STYLES - Shared components for modern UI
   Import tokens.css before this file
   ═══════════════════════════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────────────────────────────
   SCROLLBARS - Minimal accent style
   ───────────────────────────────────────────────────────────────────────────── */
.vico-scroll::-webkit-scrollbar,
.vico-modal-body::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}

.vico-scroll::-webkit-scrollbar-track,
.vico-modal-body::-webkit-scrollbar-track {
    background: transparent;
}

.vico-scroll::-webkit-scrollbar-thumb,
.vico-modal-body::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: 3px;
}

.vico-scroll::-webkit-scrollbar-thumb:hover,
.vico-modal-body::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

/* ─────────────────────────────────────────────────────────────────────────────
   BUTTONS - Modern gradient styles
   ───────────────────────────────────────────────────────────────────────────── */

/* Base button reset for Vico */
.vico-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 14px;
    border: none;
    border-radius: var(--vico-radius-md);
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--vico-transition-fast), 
                transform 0.1s ease, 
                box-shadow var(--vico-transition-fast);
}

.vico-btn:active {
    transform: scale(0.98);
}

.vico-btn i {
    font-size: 0.8rem;
}

/* Primary - Blue gradient */
.vico-btn-primary {
    background: var(--vico-gradient-blue);
    color: #fff;
    box-shadow: 0 2px 8px rgba(97, 175, 239, 0.3);
}

.vico-btn-primary:hover {
    background: linear-gradient(135deg, var(--vico-accent-blue-light) 0%, var(--vico-accent-blue) 100%);
    box-shadow: 0 4px 12px rgba(97, 175, 239, 0.4);
}

/* Success - Green gradient */
.vico-btn-success {
    background: var(--vico-gradient-green);
    color: var(--vico-bg-base);
    box-shadow: 0 2px 8px rgba(152, 195, 121, 0.3);
}

.vico-btn-success:hover {
    background: linear-gradient(135deg, var(--vico-accent-green-light) 0%, var(--vico-accent-green) 100%);
    box-shadow: 0 4px 12px rgba(152, 195, 121, 0.4);
}

/* Warning - Amber gradient */
.vico-btn-warning {
    background: var(--vico-gradient-amber);
    color: var(--vico-bg-base);
    box-shadow: 0 2px 8px rgba(229, 192, 123, 0.3);
}

.vico-btn-warning:hover {
    box-shadow: 0 4px 12px rgba(229, 192, 123, 0.4);
}

/* Secondary - Ghost style */
.vico-btn-secondary {
    background: var(--vico-bg-raised);
    color: var(--vico-text-secondary);
    border: 1px solid var(--vico-border);
}

.vico-btn-secondary:hover {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
}

/* Utility - Purple */
.vico-btn-utility {
    background: var(--vico-bg-elevated);
    color: var(--vico-accent-purple);
    border: 1px solid rgba(198, 120, 221, 0.3);
}

.vico-btn-utility:hover {
    background: rgba(198, 120, 221, 0.1);
    border-color: var(--vico-accent-purple);
}

/* Icon-only button */
.vico-btn-icon {
    width: 32px;
    height: 32px;
    padding: 0;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    color: var(--vico-text-secondary);
}

.vico-btn-icon:hover {
    background: var(--vico-bg-elevated);
    border-color: var(--vico-border-hover);
    color: var(--vico-text-primary);
}

/* Danger variant */
.vico-btn-danger:hover {
    background: rgba(224, 108, 117, 0.1);
    border-color: rgba(224, 108, 117, 0.3);
    color: var(--vico-accent-red);
}

/* ─────────────────────────────────────────────────────────────────────────────
   INPUTS - Form elements
   ───────────────────────────────────────────────────────────────────────────── */
.vico-input,
.vico-textarea,
.vico-select {
    width: 100%;
    padding: 10px 12px;
    background: var(--vico-bg-raised);
    color: var(--vico-text-primary);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    font-size: 0.9rem;
    transition: border-color var(--vico-transition-fast), 
                box-shadow var(--vico-transition-fast);
}

.vico-input:hover,
.vico-textarea:hover,
.vico-select:hover {
    border-color: var(--vico-border-hover);
}

.vico-input:focus,
.vico-textarea:focus,
.vico-select:focus {
    outline: none;
    border-color: var(--vico-border-focus);
    box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.vico-textarea {
    resize: vertical;
    min-height: 60px;
    font-family: inherit;
}

/* ─────────────────────────────────────────────────────────────────────────────
   CHECKBOX - Custom styled
   ───────────────────────────────────────────────────────────────────────────── */
.vico-checkbox {
    appearance: none;
    width: 18px;
    height: 18px;
    background: var(--vico-bg-raised);
    border: 2px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    cursor: pointer;
    transition: background var(--vico-transition-fast), 
                border-color var(--vico-transition-fast);
}

.vico-checkbox:hover {
    border-color: var(--vico-accent-blue);
}

.vico-checkbox:checked {
    background: var(--vico-accent-blue);
    border-color: var(--vico-accent-blue);
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27white%27%3E%3Cpath d=%27M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z%27/%3E%3C/svg%3E");
    background-size: 12px;
    background-repeat: no-repeat;
    background-position: center;
}

/* ─────────────────────────────────────────────────────────────────────────────
   LABELS
   ───────────────────────────────────────────────────────────────────────────── */
.vico-label {
    display: block;
    color: var(--vico-text-secondary);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 6px;
}

/* ─────────────────────────────────────────────────────────────────────────────
   CARDS / BLOCKS
   ───────────────────────────────────────────────────────────────────────────── */
.vico-card {
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    transition: border-color var(--vico-transition-fast);
}

.vico-card:hover {
    border-color: var(--vico-border-hover);
}

.vico-card-header {
    padding: 12px 14px;
    background: var(--vico-bg-raised);
    border-bottom: 1px solid var(--vico-border);
    border-radius: calc(var(--vico-radius-lg) - 1px) calc(var(--vico-radius-lg) - 1px) 0 0;
}

.vico-card-body {
    padding: 14px;
}

/* ─────────────────────────────────────────────────────────────────────────────
   MODAL CONTAINER
   ───────────────────────────────────────────────────────────────────────────── */
.vico-modal {
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-xl);
    box-shadow: var(--vico-shadow-xl);
    display: flex;
    flex-direction: column;
    pointer-events: auto;
}

.vico-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    background: var(--vico-gradient-header);
    border-bottom: 1px solid var(--vico-border);
    box-shadow: inset 0 1px 0 rgba(97, 175, 239, 0.1);
}

.vico-modal-title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    background: linear-gradient(135deg, var(--vico-text-primary) 0%, var(--vico-accent-blue) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.vico-modal-body {
    padding: 16px 20px;
    overflow-y: auto;
    flex: 1;
    background: var(--vico-bg-deep);
}

.vico-modal-footer {
    padding: 14px 20px;
    border-top: 1px solid var(--vico-border);
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    background: var(--vico-bg-base);
}

/* ─────────────────────────────────────────────────────────────────────────────
   LIST ITEMS
   ───────────────────────────────────────────────────────────────────────────── */
.vico-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    margin-bottom: 8px;
    cursor: pointer;
    transition: background var(--vico-transition-fast), 
                border-color var(--vico-transition-fast);
}

.vico-list-item:hover {
    background: var(--vico-bg-elevated);
    border-color: var(--vico-border-hover);
}

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

.vico-list-item-title {
    color: var(--vico-text-primary);
    font-weight: 500;
    font-size: 0.9rem;
}

.vico-list-item-actions {
    display: flex;
    gap: 6px;
}

/* ─────────────────────────────────────────────────────────────────────────────
   EMPTY STATE
   ───────────────────────────────────────────────────────────────────────────── */
.vico-empty-state {
    text-align: center;
    padding: 40px 20px;
    color: var(--vico-text-muted);
}

.vico-empty-state i {
    font-size: 2.5rem;
    margin-bottom: 12px;
    opacity: 0.5;
}

.vico-empty-state-title {
    color: var(--vico-text-secondary);
    font-size: 1rem;
    margin-bottom: 8px;
}

.vico-empty-state-message {
    font-size: 0.85rem;
}

/* ─────────────────────────────────────────────────────────────────────────────
   SEPARATOR
   ───────────────────────────────────────────────────────────────────────────── */
.vico-separator {
    height: 1px;
    background: var(--vico-border);
    border: none;
    margin: 16px 0;
}

/* ─────────────────────────────────────────────────────────────────────────────
   BADGE
   ───────────────────────────────────────────────────────────────────────────── */
.vico-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    font-size: 0.7rem;
    font-weight: 600;
    border-radius: var(--vico-radius-sm);
    text-transform: uppercase;
}

.vico-badge-blue {
    background: rgba(97, 175, 239, 0.15);
    color: var(--vico-accent-blue);
}

.vico-badge-green {
    background: rgba(152, 195, 121, 0.15);
    color: var(--vico-accent-green);
}

.vico-badge-amber {
    background: rgba(229, 192, 123, 0.15);
    color: var(--vico-accent-amber);
}

.vico-badge-red {
    background: rgba(224, 108, 117, 0.15);
    color: var(--vico-accent-red);
}


/* learningUI.css - Vico Design System */

/* Learning UI specific tokens - aliased from Vico tokens */
:root {
  --learning-bg: rgba(26, 29, 36, 0.95);
  --learning-bg-secondary: var(--vico-bg-raised);
  --learning-border: var(--vico-border);
  --learning-text-primary: var(--vico-text-primary);
  --learning-text-secondary: var(--vico-text-secondary);
  --learning-text-muted: var(--vico-text-muted);
  --learning-accent-primary: var(--vico-accent-blue);
  --learning-accent-secondary: var(--vico-accent-cyan);
  --learning-success: var(--vico-accent-green);
  --learning-success-bg: rgba(152, 195, 121, 0.15);
  --learning-current-bg: rgba(97, 175, 239, 0.12);
  --learning-hover-bg: var(--vico-bg-hover);
  --learning-shadow: var(--vico-shadow-lg);
  --learning-radius: var(--vico-radius-xl);
  
  /* Exit button danger tokens - derived from vico-accent-red */
  --learning-exit-color: var(--vico-accent-red);
  --learning-exit-bg: var(--vico-glow-red);
  --learning-exit-border: rgba(224, 108, 117, 0.4);
  --learning-exit-bg-hover: rgba(224, 108, 117, 0.3);
  --learning-exit-border-hover: rgba(224, 108, 117, 0.6);
}

.learning-steps-container {
  position: fixed;
  top: 1%;
  left: 0.5%;
  width: 20%;
  height: 100%;
  overflow: hidden;
  z-index: 998;
  font-family: var(--primary-font), 'Segoe UI', sans-serif;
  transform: translateY(0);
  transition: transform 0.4s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.4s ease, width 0.3s ease;
  opacity: 1;
}


.learning-steps-container.showing {
  animation: fadeInUp 0.4s cubic-bezier(0.23, 1, 0.32, 1) forwards;
}

.learning-steps-container.hiding {
  animation: fadeOutDown 0.4s cubic-bezier(0.6, -0.28, 0.735, 0.045) forwards;
}

@keyframes fadeInUp {
  from {
    transform: translateY(20px) scale(0.98);
    opacity: 0;
  }
  to {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}

@keyframes fadeOutDown {
  from {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
  to {
    transform: translateY(20px) scale(0.98);
    opacity: 0;
  }
}

.learning-steps-panel {
  background: var(--learning-bg);
  border-radius: var(--learning-radius);
  box-shadow: var(--learning-shadow);
  overflow: hidden;
  border: 1px solid var(--learning-border);
  transition: background var(--vico-transition-normal), box-shadow var(--vico-transition-normal), border-color var(--vico-transition-normal);
  display: flex;
  height: 98%;
  flex-direction: column;
  position: relative;
}

.learning-steps-header {
  display: flex;
  align-items: center;
  padding: 14px 16px;
  background: linear-gradient(180deg, var(--vico-bg-raised) 0%, var(--vico-bg-base) 100%);
  border-bottom: 1px solid var(--learning-border);
  flex-shrink: 0;
}

.module-info {
  flex-grow: 1;
  margin-right: 12px; /* Increased spacing */
  overflow: hidden; /* Prevent text overflow */
}

.learning-steps-header h2 {
  margin: 0;
  font-size: 1rem; /* Slightly larger */
  font-weight: 600;
  color: var(--learning-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.module-progress {
  font-size: 0.7rem;
  color: var(--learning-accent-primary);
  background: rgba(97, 175, 239, 0.15);
  padding: 4px 10px;
  border-radius: 20px;
  margin-top: 4px;
  display: inline-block;
  font-weight: 600;
  letter-spacing: 0.3px;
}

/* Header actions - keeps buttons on the right */
.header-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-left: auto;
}

/* Learning panel buttons - extend vico-btn-icon */
.learning-steps-panel .collapse-toggle,
.learning-steps-panel .exit-toggle {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}

/* Exit button - danger styling */
.learning-steps-panel .exit-toggle {
  background: var(--learning-exit-bg);
  border-color: var(--learning-exit-border);
  color: var(--learning-exit-color);
}

.learning-steps-panel .exit-toggle:hover {
  background: var(--learning-exit-bg-hover);
  border-color: var(--learning-exit-border-hover);
}

/* Collapse icon rotation */
.collapse-toggle .collapse-icon {
  transition: transform 0.3s ease;
}

.collapse-toggle.collapsed .collapse-icon {
  transform: rotate(-180deg);
}

.collapsible-content {
  transition: max-height 0.4s ease, opacity 0.3s ease-out 0.1s; /* Adjusted transition */
  opacity: 1;
  overflow: hidden;
  max-height: 1000px; /* large default */
  display: flex;
  flex-direction: column;
  flex-grow: 1; /* Allow content to take remaining space */
}

.learning-steps-content {
  overflow-y: auto;
  flex-grow: 1; /* Allow list to scroll */
  padding: 8px 0; /* Add vertical padding */
}

/* Steps list items */
.learning-step {
  display: flex;
  align-items: flex-start; /* Align items to the top */
  padding: 10px 16px; /* Adjusted padding */
  gap: 12px; /* Increased gap */
  position: relative;
  cursor: default; /* Default cursor, clickable items will override */
  border-left: 4px solid transparent; /* Thicker border */
  transition: background 0.2s ease, border-color 0.2s ease;
  background-color: transparent;
}

.learning-step:not(.current):hover {
  background: var(--learning-hover-bg);
}

.learning-step.current {
  background: var(--learning-current-bg);
  border-left-color: var(--learning-accent-primary);
}

.learning-step.completed {
  border-left-color: var(--learning-success);
  /* Removed background flash application here, handled by animation */
}

.step-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  color: var(--learning-text-secondary);
  font-weight: 600;
  font-size: 0.8rem;
  flex-shrink: 0;
  margin-top: 2px;
  transition: background var(--vico-transition-normal), color var(--vico-transition-normal), box-shadow var(--vico-transition-normal);
}

.learning-step.current .step-indicator {
  background: var(--vico-gradient-blue);
  color: #fff;
  box-shadow: 0 0 0 3px var(--vico-glow-blue), 0 2px 8px rgba(97, 175, 239, 0.4);
}

.learning-step.completed .step-indicator {
  background: var(--learning-success);
  color: #fff;
}

.check-icon {
  width: 16px; /* Adjusted size */
  height: 16px;
  fill: currentColor;
}

.step-content {
  flex-grow: 1;
  padding-top: 2px; /* Align text baseline */
}

.step-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 4px; /* Space between header and potential instructions */
}

.step-title {
  font-size: 0.9rem; /* Slightly larger step title */
  font-weight: 400;
  color: var(--learning-text-secondary);
  line-height: 1.4;
}

.learning-step.current .step-title {
  color: var(--learning-accent-primary);
  font-weight: 600;
}

.learning-step.completed .step-title {
  color: var(--learning-success);
  font-weight: 500;
  /* text-decoration: line-through; /* Optional: strike-through completed */
  /* opacity: 0.8; */
}

/* Info button */
.info-button {
  background: transparent;
  border: 1px solid var(--learning-accent-secondary);
  border-radius: 50%;
  width: 26px;
  height: 26px;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease, transform 0.2s ease;
  flex-shrink: 0;
}

.info-button:hover {
  background: rgba(86, 182, 194, 0.2);
  transform: scale(1.1);
}

.info-button svg {
  fill: var(--learning-accent-secondary);
  width: 14px; /* Adjusted size */
  height: 14px;
}

/* Current Step details at the bottom */
.current-step-details {
  padding: 16px;
  background: linear-gradient(180deg, var(--vico-bg-base) 0%, var(--vico-bg-raised) 100%);
  border-top: 1px solid var(--learning-border);
  flex-shrink: 0;
}

.current-step-header {
  font-size: 0.75rem;
  font-weight: 700; /* Bolder */
  color: var(--learning-accent-primary);
  text-transform: uppercase;
  letter-spacing: 0.8px; /* Increased spacing */
  margin-bottom: 10px; /* More space */
}

.current-step-title {
  font-size: 1rem; /* Larger title */
  font-weight: 600;
  color: var(--learning-text-primary);
  margin-bottom: 8px; /* More space */
}

.current-step-instructions {
  font-size: 0.85rem; /* Slightly larger instructions */
  color: var(--learning-text-secondary);
  line-height: 1.6;
  white-space: pre-line;
  opacity: 1;
  transition: opacity 0.3s ease-out; /* Base transition */
}

.learning-steps-panel.collapsed .collapsible-content {
  max-height: 0;
  opacity: 0;
  transition: max-height 0.3s ease-in, opacity 0.2s ease-in;
}

.learning-steps-panel.collapsed {
  height: auto;
  /* Subtle semi-transparent when collapsed to not distract */
  background: rgba(26, 29, 36, 0.5);
  backdrop-filter: blur(8px);
  border-color: rgba(255, 255, 255, 0.08);
}

.learning-steps-panel.collapsed .learning-steps-header {
  border-radius: 0 0 var(--learning-radius) var(--learning-radius);
  border-bottom: none;
  padding: 6px 10px;
  background: transparent;
}

/* Hide module info when collapsed - just show buttons */
.learning-steps-panel.collapsed .module-info {
  display: none;
}

/* Smaller, more subtle buttons when collapsed */
.learning-steps-panel.collapsed .collapse-toggle,
.learning-steps-panel.collapsed .exit-toggle {
  width: 24px;
  height: 24px;
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.1);
  opacity: 0.7;
}

.learning-steps-panel.collapsed .collapse-toggle:hover,
.learning-steps-panel.collapsed .exit-toggle:hover {
  opacity: 1;
  background: rgba(255, 255, 255, 0.15);
}

/* Step completion animation for the checkmark */
@keyframes checkmarkPop {
  0% {
    transform: scale(0.3) rotate(-90deg);
    opacity: 0;
  }
  50% {
    transform: scale(1.5) rotate(15deg);
    opacity: 1;
  }
  70% {
    transform: scale(0.8) rotate(-10deg);
  }
  90% {
    transform: scale(1.1) rotate(5deg);
  }
  100% {
    transform: scale(1) rotate(0deg);
    opacity: 1;
  }
}

/* Background flash animation */
@keyframes stepCompleteFlash {
  0% {
    background-color: transparent; /* Start transparent */
  }
  50% {
    background-color: var(--learning-success-bg); /* Flash success color */
  }
  100% {
    background-color: transparent; /* End transparent */
  }
}

/* Apply the animation to the checkmark icon within a just-completed step */
.learning-step.step-just-completed .check-icon {
  animation: checkmarkPop 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.4) forwards;
  transform-origin: center;
}

/* Apply background flash to the just-completed step item */
.learning-step.step-just-completed {
  /* Apply flash animation. Note: This will override hover background during animation */
  animation: stepCompleteFlash 0.8s ease-out forwards;
}

/* Ensure the target container has some base styling */
.current-step-content {
    padding: 10px; /* Adjust as needed */
    margin: 5px 0; /* Adjust as needed */
    border-radius: 4px; /* Optional: for rounded corners */
    /* background-color: #333; */ /* Let existing theme handle background */
    transition: background-color 0.3s ease-out, outline 0.3s ease-out; /* Smooth transitions back */
}

/* Fade animations for instructions text */
.current-step-instructions {
    opacity: 1;
    transition: opacity 0.3s ease-out; /* Base transition */
}

.fade-out-text {
    animation: fadeOutInstructions 0.3s ease-out forwards;
}

.fade-in-text {
    animation: fadeInInstructions 0.4s ease-in forwards;
}

@keyframes fadeOutInstructions {
    from { opacity: 1; }
    to { opacity: 0; }
}

@keyframes fadeInInstructions {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* Tablet breakpoint */
@media (max-width: 1030px) {
  .learning-steps-container {
    width: 28%;
  }

  .module-title {
    display: none;
  }

  .module-progress {
    display: none;
  }

  .header-actions {
    gap: 6px;
  }

  .learning-steps-header {
    padding: 8px 10px;
  }

  .learning-step {
    padding: 8px 12px;
    gap: 8px;
  }

  .step-indicator {
    width: 22px;
    height: 22px;
    font-size: 0.7rem;
  }

  .step-title {
    font-size: 0.8rem;
  }

  .current-step-details {
    padding: 12px;
  }

  .current-step-header {
    font-size: 0.7rem;
    margin-bottom: 6px;
  }

  .current-step-title {
    font-size: 0.9rem;
    margin-bottom: 6px;
  }

  .current-step-instructions {
    font-size: 0.8rem;
    line-height: 1.4;
  }

}

/* Mobile breakpoint */
@media (max-width: 768px) {
  .learning-steps-container {
    width: 35%;
    left: 0.5%;
  }

  .learning-steps-panel {
    height: auto;
    max-height: 80vh;
    max-height: 80dvh;
  }

  /* Compact header on mobile */
  .learning-steps-header {
    padding: 6px 10px;
    gap: 6px;
  }

  .learning-steps-header h2 {
    font-size: 0.75rem;
  }

  .module-progress {
    font-size: 0.6rem;
    padding: 2px 6px;
  }

  .header-actions {
    gap: 4px;
  }

  /* Smaller buttons on mobile */
  .learning-steps-panel .collapse-toggle,
  .learning-steps-panel .exit-toggle {
    width: 26px;
    height: 26px;
  }

  .learning-steps-content {
    padding: 4px 0;
    overflow-x: hidden;
    max-height: 30vh;
    max-height: 30dvh;
  }

  .collapsible-content {
    max-height: 60vh;
    max-height: 60dvh;
  }

  .learning-step {
    padding: 6px 10px;
    gap: 6px;
    border-left-width: 2px;
  }

  .step-indicator {
    width: 18px;
    height: 18px;
    font-size: 0.6rem;
  }

  .step-title {
    font-size: 0.7rem;
    line-height: 1.3;
  }

  .current-step-header {
    display: none;
  }

  .current-step-details {
    padding: 8px 10px;
  }

  .current-step-title {
    font-size: 0.8rem;
    margin-top: 4px;
    margin-bottom: 4px;
  }

  .current-step-instructions {
    font-size: 0.7rem;
    line-height: 1.3;
    margin-bottom: 6px;
  }

  .current-step-content {
    padding: 4px;
    margin: 2px 0;
  }

  /* Navigation buttons on mobile - compact inline layout */
  .current-step-navigation {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 6px;
    padding: 4px 0;
    justify-content: center;
  }

  .current-step-navigation .step-nav-back,
  .current-step-navigation .step-nav-replay,
  .current-step-navigation .step-nav-proceed {
    padding: 0;
    flex: 0 0 auto;
    min-width: 36px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    overflow: visible;
  }

  .current-step-navigation .step-nav-back .sr-only,
  .current-step-navigation .step-nav-replay .sr-only,
  .current-step-navigation .step-nav-proceed .sr-only {
    display: none;
  }

  .current-step-navigation .nav-icon {
    width: 18px;
    height: 18px;
    display: block;
    flex-shrink: 0;
  }

  .current-step-navigation .nav-icon path {
    stroke: #fff !important;
    stroke-width: 2.5;
  }

}

/* Small mobile breakpoint */
@media (max-width: 480px) {
  .learning-steps-container {
    width: 45%;
    top: 0.5%;
    left: 0.5%;
  }

  .learning-steps-panel {
    max-height: 75vh;
    max-height: 75dvh;
  }

  /* Even more compact header on small mobile */
  .learning-steps-header {
    padding: 5px 8px;
    gap: 4px;
  }

  .learning-steps-header h2 {
    font-size: 0.7rem;
  }

  .module-progress {
    display: none;
  }

  .header-actions {
    gap: 4px;
  }

  /* Smaller buttons on small mobile */
  .learning-steps-panel .collapse-toggle,
  .learning-steps-panel .exit-toggle {
    width: 24px;
    height: 24px;
  }

  .learning-steps-content {
    max-height: 25vh;
    max-height: 25dvh;
  }

  .learning-step {
    padding: 5px 8px;
    gap: 5px;
  }

  .step-indicator {
    width: 16px;
    height: 16px;
    font-size: 0.55rem;
  }

  .check-icon {
    width: 10px;
    height: 10px;
  }

  .step-title {
    font-size: 0.65rem;
  }

  .current-step-details {
    padding: 6px 8px;
  }

  .current-step-title {
    font-size: 0.75rem;
  }

  .current-step-instructions {
    font-size: 0.65rem;
    line-height: 1.25;
  }

  /* Keep navigation buttons inline on very small screens - even more compact */
  .current-step-navigation {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 4px;
    padding: 2px 0;
    justify-content: center;
  }

  .current-step-navigation .step-nav-back,
  .current-step-navigation .step-nav-replay,
  .current-step-navigation .step-nav-proceed {
    padding: 0;
    min-width: 32px;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    color: #fff;
  }

  .current-step-navigation .nav-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
  }

  .current-step-navigation .nav-icon path {
    stroke: #fff !important;
    stroke-width: 2.5;
  }

}

/* Highlight effect for the current step content box */
.highlight-step-content {
  animation: blink-border 0.4s 10; /* Blink border 3 times */
}

/* Keyframes for a border blink effect */
@keyframes blink-border {
  0%, 100% {
    outline: 2px solid transparent; /* Start/end with no outline */
    outline-offset: 2px;
  }
  50% {
    outline: 2px solid rgba(0, 150, 255, 0.8); /* Bright blue outline */
     outline-offset: 2px;
  }
}

/* Step Details as Full Panel Overlay */
.step-details-expanded {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent; /* Changed from rgba(20, 24, 32, 0.65) */
  pointer-events: auto;
  /* Remove border-radius and box-shadow from overlay, move to content */
  border-radius: 0;
  box-shadow: none;
  opacity: 1;
  transform: none;
}

.step-details-modal-content {
  background: linear-gradient(135deg, var(--learning-bg) 0%, rgba(40, 44, 52, 0.98) 100%);
  border-radius: var(--learning-radius);
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  max-width: 420px;
  min-width: 320px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  display: flex;
  flex-direction: column;
}

/* Remove previous centering rules for > .step-details-header, > .step-details-content */
.step-details-expanded > .step-details-header,
.step-details-expanded > .step-details-content {
  background: none;
  border-radius: 0;
  box-shadow: none;
  max-width: none;
  min-width: 0;
  width: auto;
  margin: 0;
  position: static;
  padding: 0;
}


.step-details-header {
  padding: 20px 24px 16px;
  background: linear-gradient(135deg, var(--learning-bg) 0%, rgba(40, 44, 52, 0.9) 100%);
  border-bottom: 1px solid var(--learning-border);
  position: relative;
  flex-shrink: 0; /* Prevent header from shrinking */
  min-height: 80px; /* Use min-height instead of fixed height to allow expansion */
  display: flex;
  align-items: center;
}

.step-details-header::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 24px;
  right: 24px;
  height: 1px;
  background: linear-gradient(90deg, 
    transparent 0%, 
    var(--learning-border) 20%, 
    var(--learning-accent-primary) 50%, 
    var(--learning-border) 80%, 
    transparent 100%
  );
}

.step-details-title-section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
}

.step-details-step-title {
  margin: 0;
  font-size: 1rem; /* Keep the reduced size for better fit */
  font-weight: 700;
  color: var(--learning-text-primary);
  line-height: 1.3; /* Slightly increased for better readability when wrapping */
  flex-grow: 1;
  /* Restore the beautiful gradient text effect */
  background: linear-gradient(135deg, var(--learning-text-primary) 0%, var(--learning-accent-primary) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
  /* Keep the spacing that prevents cutoff */
  padding-left: 30px; /* Space for sparkle icon */
  margin-left: 10px; /* Extra margin to prevent sparkle cutoff */
  /* Allow wrapping for variable length titles */
  word-wrap: break-word;
  overflow-wrap: break-word;
  max-width: calc(100% - 40px); /* Ensure it doesn't push into the step number */
}

.step-details-step-title::before {
  content: '✨';
  position: absolute;
  left: -24px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  animation: sparkle 2s ease-in-out;
}

@keyframes sparkle {
  0%, 100% { opacity: 0.6; transform: translateY(-50%) scale(1); }
  50% { opacity: 1; transform: translateY(-50%) scale(1.1); }
}

.step-details-number {
  background: linear-gradient(135deg, var(--learning-accent-primary) 0%, var(--learning-accent-secondary) 100%);
  color: white;
  padding: 6px 16px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 700;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(97, 175, 239, 0.3);
  position: relative;
  overflow: hidden;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.step-details-number::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  transition: left 0.6s ease;
}

.step-details-expanded.flashing .step-details-number::before {
  animation: shimmer 1.5s ease-in-out;
}

@keyframes shimmer {
  0% { left: -100%; }
  100% { left: 100%; }
}

.step-details-content {
  padding: 0;
  position: relative;
  flex: 1; /* Use flex: 1 instead of flex-grow: 1 for better space distribution */
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  min-height: 0; /* Important: allows flex item to shrink below content size */
}

.step-details-content::before {
  content: '';
  position: absolute;
  top: 0;
  left: 24px;
  width: 4px;
  height: 100%;
  background: linear-gradient(180deg, 
    var(--learning-accent-primary) 0%, 
    var(--learning-accent-secondary) 50%, 
    transparent 100%
  );
  border-radius: 2px;
  opacity: 0.6;
  pointer-events: none; /* Don't interfere with scrolling */
}

.step-details-instructions {
  margin: 24px 24px 20px 44px; /* Add proper margins */
  font-size: 0.9rem !important;
  color: var(--learning-text-secondary);
  line-height: 1.7;
  white-space: pre-line;
  position: relative;
  padding-left: 8px;
  word-wrap: break-word; /* Ensure long words wrap */
  flex-grow: 1;
}

.step-details-footer {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin: 16px 24px 24px 24px; /* Proper margins */
  flex-shrink: 0; /* Prevent footer from shrinking */
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.step-details-ok-button {
  background: linear-gradient(135deg, var(--learning-accent-primary) 0%, var(--learning-accent-secondary) 100%);
  color: white;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease;
  min-width: 140px;
  position: relative;
  overflow: hidden;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 6px 20px rgba(97, 175, 239, 0.4);
  border: none;
  border-radius: var(--vico-radius-lg);
  padding: 14px 28px;
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
}

.step-details-ok-button::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  transition: left 0.6s ease;
}

.step-details-ok-button:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow: 0 10px 30px rgba(97, 175, 239, 0.6);
}

.step-details-ok-button:hover::before {
  left: 100%;
}

.step-details-ok-button:active {
  transform: translateY(-1px) scale(0.95) !important;
  transition: transform 0.1s ease !important;
}

.step-details-ok-button:focus {
  outline: none;
  box-shadow: 0 6px 20px rgba(97, 175, 239, 0.4), 0 0 0 4px rgba(97, 175, 239, 0.3) !important;
  transition: box-shadow 0.3s ease;
}

/* Add a subtle pulse animation to the entire section when flashing */
.step-details-expanded.flashing .step-details-content {
  animation: contentPulse 2s ease-in-out infinite;
}

@keyframes contentPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.005); }
}

/* Add sparkle animation for particle effects */
@keyframes sparkleFloat {
  0% {
    opacity: 1;
    transform: translate(0, 0) scale(1);
  }
  100% {
    opacity: 0;
    transform: translate(var(--end-x), var(--end-y)) scale(0);
  }
}

/* Step details modal - responsive styles */
@media (max-width: 768px) {
  .step-details-modal-content {
    max-width: 90%;
    min-width: 280px;
    margin: 0 5%;
  }

  .step-details-header {
    padding: 14px 16px 10px;
    min-height: 50px;
  }

  .step-details-step-title {
    font-size: 0.85rem;
    padding-left: 24px;
    margin-left: 8px;
  }

  .step-details-step-title::before {
    left: -18px;
    font-size: 0.75rem;
  }

  .step-details-number {
    font-size: 0.7rem;
    padding: 3px 10px;
  }

  .step-details-content::before {
    left: 16px;
    width: 3px;
  }

  .step-details-instructions {
    font-size: 0.8rem;
    margin: 16px 16px 14px 32px;
    line-height: 1.5;
  }

  .step-details-footer {
    margin: 10px 16px 16px 16px;
    padding-top: 12px;
  }

  .step-details-ok-button {
    padding: 10px 20px;
    font-size: 0.8rem;
    min-width: 100px;
  }
}

@media (max-width: 480px) {
  .step-details-modal-content {
    max-width: 95%;
    min-width: 260px;
    margin: 0 2.5%;
  }

  .step-details-header {
    padding: 10px 12px 8px;
    min-height: 44px;
  }

  .step-details-title-section {
    gap: 10px;
  }

  .step-details-step-title {
    font-size: 0.8rem;
    padding-left: 20px;
    margin-left: 6px;
  }

  .step-details-step-title::before {
    left: -16px;
    font-size: 0.7rem;
  }

  .step-details-number {
    font-size: 0.65rem;
    padding: 2px 8px;
  }

  .step-details-content::before {
    left: 12px;
    width: 2px;
  }

  .step-details-instructions {
    font-size: 0.75rem;
    margin: 12px 12px 10px 26px;
    line-height: 1.4;
  }

  .step-details-footer {
    margin: 8px 12px 12px 12px;
    padding-top: 10px;
    gap: 8px;
  }

  .step-details-ok-button {
    padding: 8px 16px;
    font-size: 0.75rem;
    min-width: 80px;
  }
}

/* Speaker icon */
.speaker-icon {
  background: transparent;
  border: none;
  color: var(--learning-accent-primary);
  cursor: pointer;
  padding: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease, opacity 0.2s ease;
  opacity: 0.8;
}
.speaker-icon:hover {
  transform: scale(1.1);
  opacity: 1;
}
.speaker-icon.disabled {
  color: var(--learning-text-muted);
  opacity: 0.4;
}
.speaker-icon.active {
  animation: pulseSpeaker 1s infinite;
}
@keyframes pulseSpeaker {
  0% { transform: scale(1); color: var(--learning-accent-primary); }
  50% { transform: scale(1.15); color: var(--learning-accent-secondary); }
  100% { transform: scale(1); color: var(--learning-accent-primary); }
}

/* Proceed button attention cue (more eye-catching on first blink, then gentle pulse) */
.blink-proceed-btn {
  position: relative; /* enable ::after halo */
  z-index: 0;
  animation: proceed-pulse 1.2s ease-in-out infinite;
}

/* one-time expanding halo when the class is first applied */
.blink-proceed-btn::after {
  content: '';
  position: absolute;
  inset: -6px; /* extend slightly beyond button */
  border-radius: 24px; /* match rounded button */
  pointer-events: none;
  z-index: -1;
  opacity: 0;
  box-shadow: 0 0 0 0 rgba(97, 175, 239, 0.8);
  animation: proceed-halo 650ms ease-out 1;
}

@keyframes proceed-halo {
  0% { opacity: 0.9; box-shadow: 0 0 0 0 rgba(97, 175, 239, 0.8); transform: scale(0.9); }
  60% { opacity: 0.5; box-shadow: 0 0 0 10px rgba(86, 182, 194, 0.35); transform: scale(1.08); }
  100% { opacity: 0; box-shadow: 0 0 0 18px rgba(97, 175, 239, 0); transform: scale(1.12); }
}

@keyframes proceed-pulse {
  0%, 100% { transform: translateY(0) scale(1); box-shadow: 0 0 0 rgba(0,0,0,0); }
  50% { transform: translateY(-1px) scale(1.04); box-shadow: 0 6px 16px rgba(97, 175, 239, 0.45); }
}

/* Navigation buttons container (controlled mode) */
.current-step-navigation {
  display: none; /* Shown via JS when in controlled mode */
  justify-content: center;
  gap: 16px;
  padding: 8px 0;
}

/* Style for navigation buttons */
.current-step-navigation .step-nav-back,
.current-step-navigation .step-nav-replay,
.current-step-navigation .step-nav-proceed {
  background: var(--vico-gradient-blue);
  color: #fff;
  border: none;
  border-radius: var(--vico-radius-lg);
  padding: 10px 20px;
  font-weight: 600;
  font-size: 0.85rem;
  cursor: pointer;
  transition: transform var(--vico-transition-fast), opacity var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
  box-shadow: 0 2px 8px var(--vico-glow-blue);
}

.current-step-navigation .step-nav-back:hover,
.current-step-navigation .step-nav-replay:hover,
.current-step-navigation .step-nav-proceed:hover {
  transform: translateY(-2px);
  opacity: 0.9;
}

.current-step-navigation .step-nav-back:disabled,
.current-step-navigation .step-nav-replay:disabled,
.current-step-navigation .step-nav-proceed:disabled {
  opacity: 0.4;
  cursor: default;
}

/* Icon style inside navigation buttons */
.current-step-navigation .nav-icon {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
}

/* Visually hidden text for accessibility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Minimal custom scrollbar styling */
.learning-steps-content::-webkit-scrollbar,
.step-details-content::-webkit-scrollbar {
  width: 6px;
}

.learning-steps-content::-webkit-scrollbar-track,
.step-details-content::-webkit-scrollbar-track {
  background: transparent;
}

.learning-steps-content::-webkit-scrollbar-thumb,
.step-details-content::-webkit-scrollbar-thumb {
  background: rgba(97, 175, 239, 0.3);
  border-radius: 3px;
  transition: background 0.2s ease;
}

.learning-steps-content::-webkit-scrollbar-thumb:hover,
.step-details-content::-webkit-scrollbar-thumb:hover {
  background: rgba(97, 175, 239, 0.6);
}

.learning-steps-content::-webkit-scrollbar-thumb:active,
.step-details-content::-webkit-scrollbar-thumb:active {
  background: var(--learning-accent-primary);
}

.learning-steps-content::-webkit-scrollbar-corner,
.step-details-content::-webkit-scrollbar-corner {
  background: transparent;
}

/* ═══════════════════════════════════════════════════════════════════════════
   NARRATION SUBTITLES
   ═══════════════════════════════════════════════════════════════════════════ */

.narration-subtitle {
  position: fixed;
  bottom: 1.5vh;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.85);
  color: #fff;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: clamp(0.75rem, 1.3vw, 0.9rem);
  width: 96vw;
  max-width: 700px;
  line-height: 1.4;
  overflow: hidden;
  overflow-wrap: break-word;
  word-wrap: break-word;
  word-break: break-word;
  hyphens: auto;
  max-height: 10vh;
  text-align: center;
  z-index: 940;
  pointer-events: none;
  backdrop-filter: blur(4px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  opacity: 0;
  transition: opacity 0.3s ease;
  display: none;
  box-sizing: border-box;
}

.narration-subtitle.visible {
  display: block;
  opacity: 1;
}

/* Mobile: go edge-to-edge, larger text */
@media (max-width: 768px) {
  .narration-subtitle {
    width: 96vw;
    max-width: none;
    padding: 8px 12px;
    font-size: 0.95rem;
    max-height: 12vh;
    bottom: 1vh;
  }
}
/**
 * Learning Editor Side Panel Styles
 * A modern, polished editor interface matching Vico's design language
 */

/* ═══════════════════════════════════════════════════════════════════════════
   DESIGN TOKENS - Aliases to shared Vico tokens (from tokens.css)
   This ensures consistency across all editors/modals
   ═══════════════════════════════════════════════════════════════════════════ */
:root {
    /* Surface colors - aliased from vico tokens */
    --lesp-bg: var(--vico-bg-deep);
    --lesp-surface: var(--vico-bg-base);
    --lesp-surface-light: var(--vico-bg-raised);
    --lesp-surface-elevated: var(--vico-bg-elevated);
    
    /* Borders & lines */
    --lesp-border: var(--vico-border);
    --lesp-border-light: var(--vico-border-hover);
    
    /* Text hierarchy */
    --lesp-text: var(--vico-text-primary);
    --lesp-text-muted: var(--vico-text-secondary);
    --lesp-text-subtle: var(--vico-text-muted);
    
    /* Accent colors */
    --lesp-accent: var(--vico-accent-blue);
    --lesp-accent-hover: var(--vico-accent-blue-light);
    --lesp-accent-glow: var(--vico-glow-blue);
    
    /* Semantic colors */
    --lesp-success: var(--vico-accent-green);
    --lesp-warning: var(--vico-accent-amber);
    --lesp-danger: var(--vico-accent-red);
    --lesp-purple: var(--vico-accent-purple);
    --lesp-cyan: var(--vico-accent-cyan);
    
    /* Sizing */
    --lesp-radius-sm: var(--vico-radius-sm);
    --lesp-radius-md: var(--vico-radius-lg);
    --lesp-radius-lg: var(--vico-radius-xl);
    
    /* Transitions */
    --lesp-transition-fast: var(--vico-transition-fast);
    --lesp-transition-normal: var(--vico-transition-normal);
    
    /* Overlay for locked states (testing/capture) */
    --lesp-overlay-locked: rgba(18, 20, 26, 0.6); /* --vico-bg-deep with 60% alpha */
}

/* ═══════════════════════════════════════════════════════════════════════════
   SIDE PANEL CONTAINER
   ═══════════════════════════════════════════════════════════════════════════ */
.learning-editor-sidepanel {
    position: fixed;
    top: 80px; /* Leave room for cog icon (48px + 20px padding + 12px extra) */
    right: 0;
    width: 30%;
    min-width: 380px;
    height: calc(100% - 80px);
    
    background: linear-gradient(180deg, var(--lesp-surface) 0%, var(--lesp-bg) 100%);
    box-shadow: 
        -4px 0 24px rgba(0, 0, 0, 0.5),
        -1px 0 0 var(--lesp-border);
    
    /* Initial hidden state */
    transform: translateX(100%);
    opacity: 0;
    visibility: hidden;
    transition: 
        transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
        opacity 0.25s ease,
        visibility 0.25s ease;
    
    z-index: 998; /* Below cog icon (999) */
    display: flex;
    flex-direction: column;
    pointer-events: auto;
    
    /* Subtle inner glow */
    border-left: 1px solid rgba(97, 175, 239, 0.1);
    border-top-left-radius: var(--lesp-radius-lg);
}

.learning-editor-sidepanel.active {
    transform: translateX(0);
    opacity: 1;
    visibility: visible;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    
    background: linear-gradient(180deg, 
        var(--lesp-surface-elevated) 0%, 
        var(--lesp-surface-light) 100%);
    border-bottom: 1px solid var(--lesp-border);
    
    /* Subtle top accent line */
    box-shadow: inset 0 2px 0 rgba(97, 175, 239, 0.15);
}

.lesp-header-title {
    flex: 1;
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--lesp-text);
    letter-spacing: -0.01em;
    
    /* Gradient text effect */
    background: linear-gradient(135deg, var(--lesp-text) 0%, var(--lesp-accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Header buttons */
.lesp-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    color: var(--lesp-text-muted);
    cursor: pointer;
    
    transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.15s, box-shadow 0.15s;
}

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

#lesp-back-btn:hover {
    color: var(--lesp-accent);
    border-color: var(--lesp-accent);
    box-shadow: 0 0 12px var(--lesp-accent-glow);
}

#lesp-close-btn:hover {
    color: var(--lesp-danger);
    border-color: var(--lesp-danger);
    box-shadow: 0 0 12px rgba(224, 108, 117, 0.2);
}

.lesp-icon-btn i {
    font-size: 16px;
    line-height: 1;
    pointer-events: none;
}

#lesp-close-btn i {
    font-size: 18px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BODY / CONTENT AREA
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-body {
    flex: 1;
    padding: 20px;
    overflow-y: auto;
    overflow-x: hidden;
    background: var(--lesp-bg);
}

/* Minimal scrollbar - matches learningUISystem.css */
.lesp-body::-webkit-scrollbar,
.lesp-subtitles-textarea::-webkit-scrollbar,
.lesp-object-list-container::-webkit-scrollbar,
.ai-wizard-json-preview::-webkit-scrollbar {
    width: 6px;
}

.lesp-body::-webkit-scrollbar-track,
.lesp-subtitles-textarea::-webkit-scrollbar-track,
.lesp-object-list-container::-webkit-scrollbar-track,
.ai-wizard-json-preview::-webkit-scrollbar-track {
    background: transparent;
}

.lesp-body::-webkit-scrollbar-thumb,
.lesp-subtitles-textarea::-webkit-scrollbar-thumb,
.lesp-object-list-container::-webkit-scrollbar-thumb,
.ai-wizard-json-preview::-webkit-scrollbar-thumb {
    background: rgba(97, 175, 239, 0.3);
    border-radius: 3px;
}

.lesp-body::-webkit-scrollbar-thumb:hover,
.lesp-subtitles-textarea::-webkit-scrollbar-thumb:hover,
.lesp-object-list-container::-webkit-scrollbar-thumb:hover,
.ai-wizard-json-preview::-webkit-scrollbar-thumb:hover {
    background: rgba(97, 175, 239, 0.6);
}

/* Screen container */
.lesp-screen-container {
    display: flex;
    flex-direction: column;
    gap: 20px;
    animation: lesp-fade-in 0.25s ease-out;
}

@keyframes lesp-fade-in {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS - Base & Variants
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 16px;
    
    font-size: 0.875rem;
    font-weight: 600;
    font-family: var(--primary-font);
    
    background: var(--lesp-surface-light);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    color: var(--lesp-text);
    cursor: pointer;
    
    transition: background 0.15s, border-color 0.15s, transform 0.15s, box-shadow 0.15s;
}

.lesp-btn:hover {
    background: var(--lesp-surface-elevated);
    border-color: var(--lesp-border-light);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

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

.lesp-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}

.lesp-btn i {
    font-size: 0.9em;
    opacity: 0.9;
    flex-shrink: 0;
}

.lesp-btn span {
    white-space: nowrap;
}

/* Icon-only buttons (via :has selector - modern browsers) */
.lesp-btn:has(i):not(:has(span)) {
    padding: 8px 10px;
}

/* Icon-only buttons (explicit class for broader support) */
.lesp-btn-icon-only {
    padding: 8px 10px !important;
    min-width: 36px;
}

/* Primary button - accent blue gradient */
.lesp-add-btn {
    background: linear-gradient(135deg, var(--lesp-accent) 0%, #4a9be0 100%);
    border: none;
    color: #fff;
    box-shadow: 0 2px 8px rgba(97, 175, 239, 0.3);
}

.lesp-add-btn:hover {
    background: linear-gradient(135deg, var(--lesp-accent-hover) 0%, var(--lesp-accent) 100%);
    box-shadow: 0 4px 16px rgba(97, 175, 239, 0.4);
}

/* Action button - ghost style */
.lesp-action-btn {
    background: transparent;
    border-color: var(--lesp-border);
    color: var(--lesp-text-muted);
    padding: 6px 12px;
}

.lesp-action-btn:hover {
    background: var(--lesp-surface-light);
    color: var(--lesp-text);
}

/* Edit button */
.lesp-edit-btn {
    color: var(--lesp-accent);
    border-color: rgba(97, 175, 239, 0.3);
    padding: 6px 12px;
}

.lesp-edit-btn:hover {
    background: var(--lesp-accent-glow);
    border-color: var(--lesp-accent);
}

/* Accent button - highlighted action (e.g., Sync Camera) */
.lesp-btn-accent {
    background: linear-gradient(135deg, rgba(229, 192, 123, 0.15) 0%, rgba(229, 192, 123, 0.08) 100%);
    border-color: rgba(229, 192, 123, 0.4);
    color: #e5c07b;
}

.lesp-btn-accent:hover {
    background: linear-gradient(135deg, rgba(229, 192, 123, 0.25) 0%, rgba(229, 192, 123, 0.15) 100%);
    border-color: rgba(229, 192, 123, 0.6);
    box-shadow: 0 4px 16px rgba(229, 192, 123, 0.2);
}

.lesp-btn-accent i {
    color: #e5c07b;
}

/* Delete button */
.lesp-delete-btn {
    color: var(--lesp-danger);
    border-color: rgba(224, 108, 117, 0.3);
    padding: 6px 12px;
}

.lesp-delete-btn:hover {
    background: rgba(224, 108, 117, 0.1);
    border-color: var(--lesp-danger);
}

/* Duplicate button */
.lesp-duplicate-btn {
    color: var(--lesp-purple);
    border-color: rgba(198, 120, 221, 0.3);
    padding: 6px 12px;
}

.lesp-duplicate-btn:hover {
    background: rgba(198, 120, 221, 0.1);
    border-color: var(--lesp-purple);
}

/* Test/Play button */
.lesp-test-btn,
.lesp-test-step-btn {
    background: linear-gradient(135deg, var(--lesp-success) 0%, #7eb863 100%);
    border: none;
    color: #1a1d24;
    padding: 6px 12px;
    box-shadow: 0 2px 8px rgba(152, 195, 121, 0.3);
}

.lesp-test-btn:hover,
.lesp-test-step-btn:hover {
    background: linear-gradient(135deg, #a8d389 0%, var(--lesp-success) 100%);
    box-shadow: 0 4px 16px rgba(152, 195, 121, 0.4);
}

/* Stop button */
.lesp-stop-step-btn {
    color: var(--lesp-danger);
    border-color: rgba(224, 108, 117, 0.3);
    padding: 6px 12px;
}

.lesp-stop-step-btn:hover {
    background: var(--lesp-danger);
    border-color: var(--lesp-danger);
    color: #fff;
}

/* Blinking stop button (active test) */
.lesp-stop-btn-blinking,
.lesp-stop-btn-blinking:hover {
    background: var(--lesp-warning) !important;
    border-color: var(--lesp-warning) !important;
    color: #1a1d24 !important;
    animation: lesp-pulse 1.5s ease-in-out infinite;
}

@keyframes lesp-pulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(229, 192, 123, 0.5);
        transform: scale(1);
    }
    50% {
        box-shadow: 0 0 0 8px rgba(229, 192, 123, 0);
        transform: scale(1.02);
    }
}

/* Submit button - green success */
.lesp-submit-btn {
    background: linear-gradient(135deg, var(--lesp-success) 0%, #7eb863 100%);
    border: none;
    color: #1a1d24;
    box-shadow: 0 2px 8px rgba(152, 195, 121, 0.3);
}

.lesp-submit-btn:hover {
    background: linear-gradient(135deg, #a8d389 0%, var(--lesp-success) 100%);
    box-shadow: 0 4px 16px rgba(152, 195, 121, 0.4);
}

/* Cancel button */
.lesp-cancel-btn {
    background: var(--lesp-surface-light);
    color: var(--lesp-text-muted);
}

.lesp-cancel-btn:hover {
    background: var(--lesp-surface-elevated);
    color: var(--lesp-text);
}

/* ═══════════════════════════════════════════════════════════════════════════
   LISTS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-list {
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
    overflow: hidden;
}

.lesp-list-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    
    background: transparent;
    border-bottom: 1px solid var(--lesp-border);
    cursor: pointer;
    
    transition: background 0.15s, transform 0.1s;
}

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

.lesp-list-item:hover {
    background: linear-gradient(90deg, 
        var(--lesp-accent-glow) 0%, 
        transparent 100%);
}

.lesp-list-item:active {
    background: var(--lesp-surface-light);
    transform: scale(0.995);
}

/* Selected state for list items */
.lesp-list-item.selected {
    background: linear-gradient(90deg, 
        rgba(97, 175, 239, 0.15) 0%, 
        transparent 100%);
    border-left: 3px solid var(--lesp-accent);
    padding-left: 13px;
}

.lesp-item-content {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
    min-width: 0;
}

.lesp-item-title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--lesp-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lesp-item-status {
    font-size: 0.75rem;
    color: var(--lesp-text-muted);
    display: flex;
    align-items: center;
    gap: 6px;
}

.lesp-item-status i {
    font-size: 0.7rem;
}

/* Step number badge */
.lesp-item-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 6px;
    
    background: var(--lesp-accent-glow);
    border: 1px solid var(--lesp-accent);
    border-radius: 12px;
    
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--lesp-accent);
}

.lesp-item-actions {
    display: flex;
    gap: 6px;
    flex-shrink: 0;
    opacity: 0.7;
    transition: opacity var(--lesp-transition-fast);
}

.lesp-list-item:hover .lesp-item-actions {
    opacity: 1;
}

/* ═══════════════════════════════════════════════════════════════════════════
   STEP LIST - Draggable Items
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-drag-handle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    
    color: var(--lesp-text-subtle);
    cursor: grab;
    border-radius: var(--lesp-radius-sm);
    
    transition: color 0.15s, background 0.15s;
}

.lesp-drag-handle:hover {
    color: var(--lesp-accent);
    background: var(--lesp-accent-glow);
}

.lesp-drag-handle:active {
    cursor: grabbing;
    color: var(--lesp-accent);
}

/* Dragging state */
.lesp-list-item.dragging {
    opacity: 0.5;
    background: var(--lesp-surface-light);
}

.lesp-list-item.drag-over {
    border-top: 2px solid var(--lesp-accent);
}

/* ═══════════════════════════════════════════════════════════════════════════
   FORMS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-course-form-container,
.lesp-module-form-container,
.lesp-step-form-container {
    padding: 4px;
}

.lesp-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.lesp-form-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.lesp-form-group label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--lesp-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.lesp-form input[type="text"],
.lesp-form input[type="number"],
.lesp-form input[type="url"],
.lesp-form textarea,
.lesp-form select {
    width: 100%;
    padding: 12px 14px;
    
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    color: var(--lesp-text);
    font-size: 0.9rem;
    font-family: inherit;
    
    transition: border-color 0.15s, box-shadow 0.15s;
    box-sizing: border-box;
}

.lesp-form input:hover,
.lesp-form textarea:hover,
.lesp-form select:hover {
    border-color: var(--lesp-border-light);
}

.lesp-form input:focus,
.lesp-form textarea:focus,
.lesp-form select:focus {
    outline: none;
    border-color: var(--lesp-accent);
    box-shadow: 0 0 0 2px rgba(97, 175, 239, 0.2);
}

.lesp-form textarea {
    resize: vertical;
    min-height: 100px;
    line-height: 1.5;
}

.lesp-form input[type="number"] {
    width: auto;
    min-width: 80px;
    font-family: 'Courier New', monospace;
}

.lesp-form input:disabled,
.lesp-form textarea:disabled,
.lesp-form select:disabled {
    background: var(--lesp-surface-elevated);
    color: var(--lesp-text-subtle);
    cursor: not-allowed;
    opacity: 0.6;
}

/* Help text under form fields */
.lesp-form-help {
    font-size: 0.75rem;
    color: var(--lesp-text-subtle);
    line-height: 1.4;
    margin-top: 4px;
}

/* Checkbox styling */
.lesp-form-group.inline-checkbox {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 12px;
}

.lesp-form-group.inline-checkbox label {
    flex: 1;
    text-transform: none;
    font-weight: 500;
    color: var(--lesp-text);
}

.lesp-checkbox {
    appearance: none;
    width: 20px;
    height: 20px;
    background: var(--lesp-surface);
    border: 2px solid var(--lesp-border);
    border-radius: var(--lesp-radius-sm);
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    flex-shrink: 0;
}

.lesp-checkbox:hover {
    border-color: var(--lesp-accent);
}

.lesp-checkbox:checked {
    background: var(--lesp-accent);
    border-color: var(--lesp-accent);
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27white%27%3E%3Cpath d=%27M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z%27/%3E%3C/svg%3E");
    background-size: 14px;
    background-repeat: no-repeat;
    background-position: center;
}

/* Form section headers */
.lesp-form h3,
.lesp-form h4 {
    color: var(--lesp-text);
    margin: 8px 0;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--lesp-border);
    font-weight: 600;
}

.lesp-form h3 {
    font-size: 1rem;
}

.lesp-form h4 {
    font-size: 0.9rem;
    color: var(--lesp-text-muted);
}

/* Instructions text */
.lesp-instructions {
    font-size: 0.8rem;
    color: var(--lesp-text-subtle);
    line-height: 1.5;
    padding: 10px 12px;
    background: var(--lesp-surface);
    border-radius: var(--lesp-radius-md);
    border-left: 3px solid var(--lesp-accent);
}

/* Form actions */
.lesp-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    margin-top: 8px;
    padding-top: 20px;
    border-top: 1px solid var(--lesp-border);
}

/* Form separator */
.lesp-form-separator {
    border: none;
    border-top: 1px solid var(--lesp-border);
    margin: 8px 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   EVENT CHAIN DISPLAY
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-chain-display {
    background: var(--lesp-surface);
    padding: 12px 14px;
    border-radius: var(--lesp-radius-md);
    border: 1px solid var(--lesp-border);
    
    font-family: 'Courier New', monospace;
    font-size: 0.85rem;
    color: var(--lesp-cyan);
    line-height: 1.5;
    
    min-height: 24px;
    word-break: break-all;
}

.lesp-chain-display:empty::before {
    content: 'No events configured';
    color: var(--lesp-text-subtle);
    font-style: italic;
    font-family: var(--primary-font);
}

/* ═══════════════════════════════════════════════════════════════════════════
   AI WIZARD SECTION
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-module-actions-header {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 16px;
    
    background: linear-gradient(135deg, 
        var(--lesp-surface-light) 0%, 
        var(--lesp-surface) 100%);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
}

.lesp-ai-wizard-btn {
    background: linear-gradient(135deg, var(--lesp-purple) 0%, #a855c2 100%);
    border: none;
    color: #fff;
    box-shadow: 0 2px 8px rgba(198, 120, 221, 0.3);
}

.lesp-ai-wizard-btn:hover {
    background: linear-gradient(135deg, #d48ee8 0%, var(--lesp-purple) 100%);
    box-shadow: 0 4px 16px rgba(198, 120, 221, 0.4);
}

/* AI Wizard container */
.ai-wizard-container {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.ai-wizard-step {
    padding: 20px;
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
    
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.ai-wizard-step h3 {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 0;
    border: none;
    font-size: 1rem;
    color: var(--lesp-text);
}

.ai-wizard-step h3 i {
    color: var(--lesp-purple);
}

/* AI decide steps group */
.lesp-ai-decide-steps-group {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 16px;
    
    background: var(--lesp-surface-light);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
}

.lesp-ai-decide-steps-group label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    color: var(--lesp-text);
    cursor: pointer;
}

/* AI decide objects group */
.lesp-ai-decide-objects-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 14px 16px;
    
    background: var(--lesp-surface-light);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
}

.lesp-ai-decide-objects-group label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.9rem;
    color: var(--lesp-text);
}

/* Object list - single scrollable container */
.lesp-object-list-container {
    max-height: 200px;
    overflow-y: auto;
    overflow-x: hidden;
    padding: var(--vico-space-md);
    
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
}

/* Inner div should NOT scroll - only container scrolls */
.lesp-object-list-container > div {
    overflow: visible !important;
    max-height: none !important;
}

.ai-wizard-object-label {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    padding: var(--vico-space-sm) var(--vico-space-md);
    margin: 2px 0;
    font-size: 0.85rem;
    color: var(--lesp-text-muted);
    cursor: pointer;
    border-radius: var(--lesp-radius-sm);
    transition: color var(--lesp-transition-fast), background var(--lesp-transition-fast);
}

.ai-wizard-object-label:hover {
    color: var(--lesp-text);
    background: var(--lesp-surface-light);
}

/* Object row wrapper */
.ai-wizard-object-row {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    padding: var(--vico-space-xs) 0;
}

.ai-wizard-object-row:last-child {
    margin-bottom: 0;
}

/* Inner list container - no scrolling */
.ai-wizard-object-list-inner {
    display: flex;
    flex-direction: column;
    transition: opacity var(--vico-transition-normal);
}

/* Dimmed state when AI decides */
.ai-wizard-object-list-inner.ai-wizard-list-dimmed {
    opacity: 0.5;
}

/* AI Wizard Progress Indicator - Enhanced */
.ai-wizard-progress {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--vico-space-md);
    padding: var(--vico-space-xl) var(--vico-space-xxl);
    
    background: linear-gradient(135deg, 
        var(--lesp-surface-light) 0%, 
        var(--lesp-surface) 100%);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
    
    /* Subtle accent glow at top */
    box-shadow: 
        inset 0 1px 0 var(--vico-glow-purple),
        var(--vico-shadow-sm);
}

.ai-wizard-progress::before {
    content: 'Step';
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--lesp-text-subtle);
}

.ai-wizard-progress span {
    display: flex;
    align-items: baseline;
    gap: var(--vico-space-sm);
    font-size: 2rem;
    font-weight: 700;
    color: var(--lesp-purple);
    
    /* Gradient text effect */
    background: linear-gradient(135deg, var(--lesp-purple) 0%, var(--lesp-accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.ai-wizard-progress span::after {
    content: 'of 3';
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--lesp-text-muted);
    -webkit-text-fill-color: var(--lesp-text-muted);
}

/* AI prompt preview */
.ai-wizard-prompt-group pre,
.ai-wizard-prompt-preview {
    margin: 0;
    padding: var(--vico-space-lg);
    
    background: var(--lesp-bg);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    
    font-family: 'Courier New', monospace;
    font-size: 0.8rem;
    color: var(--lesp-text-muted);
    white-space: pre-wrap;
    word-break: break-word;
    
    max-height: 180px;
    overflow-y: auto;
    overflow-x: hidden;
}

/* Scrollbar styling for prompt preview - uses shared vico tokens */
.ai-wizard-prompt-preview::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}

.ai-wizard-prompt-preview::-webkit-scrollbar-track {
    background: transparent;
}

.ai-wizard-prompt-preview::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: var(--vico-radius-sm);
}

.ai-wizard-prompt-preview::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

/* AI JSON preview */
.ai-wizard-json-preview {
    padding: 14px;
    background: var(--lesp-bg);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    max-height: 300px;
    overflow-y: auto;
}

.ai-wizard-json-preview code {
    font-family: 'Courier New', monospace;
    font-size: 0.8rem;
    color: var(--lesp-cyan);
    white-space: pre-wrap;
    word-break: break-word;
}

/* AI Wizard Validation Messages */
.ai-wizard-validation-errors,
.ai-wizard-validation-warnings {
    margin-bottom: 16px;
    padding: 12px 16px;
    border-radius: var(--lesp-radius-md);
    font-size: 0.85rem;
}

.ai-wizard-validation-errors {
    background: rgba(224, 108, 117, 0.1);
    border: 1px solid rgba(224, 108, 117, 0.3);
}

.ai-wizard-validation-errors h4 {
    margin: 0 0 8px 0;
    font-size: 0.9rem;
    color: var(--lesp-danger);
    display: flex;
    align-items: center;
    gap: 8px;
}

.ai-wizard-validation-errors ul {
    margin: 0;
    padding-left: 20px;
    color: var(--lesp-text);
}

.ai-wizard-validation-errors li {
    margin-bottom: 4px;
}

.ai-wizard-validation-warnings {
    background: rgba(229, 192, 123, 0.1);
    border: 1px solid rgba(229, 192, 123, 0.3);
}

.ai-wizard-validation-warnings summary {
    cursor: pointer;
    color: var(--lesp-warning);
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 500;
}

.ai-wizard-validation-warnings ul {
    margin: 8px 0 0 0;
    padding-left: 20px;
    color: var(--lesp-text-muted);
}

.ai-wizard-validation-warnings li {
    margin-bottom: 4px;
    font-size: 0.8rem;
}

/* AI Wizard Summary */
.ai-wizard-summary {
    margin-bottom: 12px;
    padding: 12px 16px;
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
}

.ai-wizard-summary p {
    margin: 4px 0;
    font-size: 0.9rem;
    color: var(--lesp-text-muted);
}

.ai-wizard-summary strong {
    color: var(--lesp-text);
}

/* ═══════════════════════════════════════════════════════════════════════════
   AI Wizard - Status Badge & Workflow Cards
   Two equal-priority workflows: Direct generation & Copy/Paste
   ═══════════════════════════════════════════════════════════════════════════ */

/* AI Status Badge - Shows current provider/model */
.ai-wizard-status-badge {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
    padding: var(--vico-space-sm) var(--vico-space-md);
    margin-bottom: var(--vico-space-md);
    background: var(--lesp-surface-light);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
}

.ai-status-provider {
    display: flex;
    align-items: center;
    gap: var(--vico-space-xs);
    font-size: 0.85rem;
    font-weight: 600;
}

.ai-status-provider.status-ready {
    color: var(--lesp-success);
}

.ai-status-provider.status-proxy {
    color: var(--lesp-accent);
}

.ai-status-provider .provider-name {
    color: var(--lesp-text);
}

.ai-status-provider .model-name {
    color: var(--lesp-text-muted);
    font-weight: 400;
    font-size: 0.8rem;
}

.ai-status-mode {
    font-size: 0.7rem;
    color: var(--lesp-text-subtle);
    padding: 2px 8px;
    background: var(--lesp-bg);
    border-radius: var(--lesp-radius-sm);
}

.ai-status-config {
    margin-left: auto;
    padding: var(--vico-space-xs) var(--vico-space-sm);
    background: transparent;
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-sm);
    color: var(--lesp-text-muted);
    cursor: pointer;
    transition: all var(--lesp-transition-fast);
}

.ai-status-config:hover {
    background: var(--lesp-surface-elevated);
    color: var(--lesp-accent);
    border-color: var(--lesp-accent);
}

/* Workflow Options Container */
.ai-wizard-workflow-options {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--vico-space-md);
    margin-bottom: var(--vico-space-lg);
}

@media (max-width: 500px) {
    .ai-wizard-workflow-options {
        grid-template-columns: 1fr;
    }
}

/* Workflow Card */
.ai-wizard-workflow-card {
    display: flex;
    flex-direction: column;
    padding: var(--vico-space-lg);
    background: var(--lesp-surface-light);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    transition: border-color var(--lesp-transition-fast), box-shadow var(--lesp-transition-fast);
}

.ai-wizard-workflow-card:hover {
    border-color: var(--lesp-accent);
    box-shadow: 0 0 0 1px var(--lesp-accent-glow);
}

.workflow-card-header {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    margin-bottom: var(--vico-space-sm);
}

.workflow-card-header i {
    font-size: 1.2rem;
    color: var(--lesp-purple);
}

.workflow-card-header h4 {
    margin: 0;
    font-size: 0.95rem;
    color: var(--lesp-text);
}

.workflow-card-desc {
    margin: 0 0 var(--vico-space-md) 0;
    font-size: 0.8rem;
    color: var(--lesp-text-muted);
    line-height: 1.4;
    flex: 1;
}

.workflow-card-status {
    display: flex;
    gap: var(--vico-space-sm);
    margin-bottom: var(--vico-space-sm);
    flex-wrap: wrap;
}

.workflow-card-status span {
    font-size: 0.7rem;
    padding: 2px 8px;
    background: var(--lesp-bg);
    border-radius: var(--lesp-radius-sm);
    color: var(--lesp-text-subtle);
}

.workflow-card-status .status-provider {
    color: var(--lesp-accent);
}

.workflow-card-btn {
    width: 100%;
    margin-top: auto;
}

.workflow-card-hint {
    margin: 0 0 var(--vico-space-sm) 0;
    font-size: 0.75rem;
    color: var(--lesp-warning);
    display: flex;
    align-items: center;
    gap: var(--vico-space-xs);
}

.workflow-card-hint i {
    font-size: 0.75rem;
}

/* Prompt Preview - Collapsible */
.ai-wizard-prompt-details {
    margin-bottom: var(--vico-space-md);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    overflow: hidden;
}

.ai-wizard-prompt-details summary {
    padding: var(--vico-space-sm) var(--vico-space-md);
    background: var(--lesp-surface-light);
    color: var(--lesp-text-muted);
    cursor: pointer;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    transition: background var(--lesp-transition-fast);
}

.ai-wizard-prompt-details summary:hover {
    background: var(--lesp-surface-elevated);
    color: var(--lesp-text);
}

.ai-wizard-prompt-details summary i {
    color: var(--lesp-accent);
}

.ai-wizard-prompt-details[open] summary {
    border-bottom: 1px solid var(--lesp-border);
}

.ai-wizard-prompt-details .ai-wizard-prompt-preview {
    max-height: 200px;
    border-radius: 0;
    border: none;
}

/* Paste Section */
.ai-wizard-paste-section {
    border: 1px dashed var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    padding: var(--vico-space-md);
    background: var(--lesp-bg);
}

.ai-wizard-paste-section label {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    color: var(--lesp-text-muted);
}

.ai-wizard-paste-section label i {
    color: var(--lesp-accent);
}

.ai-wizard-paste-section textarea {
    margin-top: var(--vico-space-sm);
}

/* Form help text for prompt style descriptions */
.lesp-form-help {
    margin-top: 6px;
    font-size: 0.8rem;
    color: var(--lesp-text-subtle);
    font-style: italic;
}

/* ═══════════════════════════════════════════════════════════════════════════
   NARRATOR & SUBTITLES SECTION
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-narrator-container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    
    padding: 16px;
    margin: 16px 0;
    
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
}

.lesp-narrator-label {
    font-weight: 600;
    color: var(--lesp-accent);
    font-size: 0.9rem;
}

.lesp-narrator-hint {
    flex-basis: 100%;
    margin-top: 4px;
    font-size: 0.75rem;
    color: var(--lesp-text-subtle);
}

.lesp-narrator-container small {
    margin-left: auto;
    font-size: 0.8rem;
    color: var(--lesp-accent);
    opacity: 0.8;
}

/* Subtitles textarea */
.lesp-subtitles-container {
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1 1 100%;
    margin-top: 8px;
}

.lesp-subtitles-textarea {
    width: 100%;
    padding: 12px;
    min-height: 80px;
    resize: vertical;
    
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    
    font-family: 'Courier New', monospace;
    font-size: 0.85rem;
    color: var(--lesp-text);
    line-height: 1.5;
    
    /* Only transition border/shadow, NOT size - prevents resize lag */
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.lesp-subtitles-textarea:focus {
    outline: none;
    border-color: var(--lesp-accent);
    box-shadow: 0 0 0 2px rgba(97, 175, 239, 0.2);
}

.lesp-subtitles-container small {
    font-size: 0.75rem;
    color: var(--lesp-text-subtle);
}

/* ═══════════════════════════════════════════════════════════════════════════
   OVERLAYS & SPINNERS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-dedicated-overlay {
    position: absolute;
    inset: 0;
    background: rgba(18, 20, 26, 0.92);
    /* Removed backdrop-filter - expensive, causes lag */
    z-index: 10;
    display: none;
}

.learning-editor-sidepanel .spinner-container {
    z-index: 20;
}

/* ═══════════════════════════════════════════════════════════════════════════
   FORM LOCKED STATE (during testing/capture)
   Disables all interactions except the stop button
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-form-locked {
    position: relative;
}

.lesp-form-locked::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--lesp-overlay-locked);
    z-index: 5;
    pointer-events: all;
}

/* Keep testing controls accessible above the lock overlay */
.lesp-form-locked .lesp-step-testing-container {
    position: relative;
    z-index: 10;
}

/* Keep form actions (Save/Cancel) accessible - user may want to cancel/leave */
.lesp-form-locked .lesp-form-actions {
    position: relative;
    z-index: 10;
}

/* Visual indicator that form is locked - dims non-essential sections */
.lesp-form-locked .lesp-form-group,
.lesp-form-locked .lesp-events-section,
.lesp-form-locked .lesp-narrator-container {
    opacity: 0.5;
    pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PANEL RESIZE HANDLE
   ═══════════════════════════════════════════════════════════════════════════ */
.panel-resize-handle {
    position: absolute;
    left: 0;
    top: 0;
    width: 6px;
    height: 100%;
    cursor: ew-resize;
    background: transparent;
    z-index: 1000;
    transition: background var(--lesp-transition-fast);
}

.panel-resize-handle:hover {
    background: linear-gradient(90deg, 
        rgba(97, 175, 239, 0.3) 0%, 
        transparent 100%);
}

.panel-resize-handle::before {
    content: '';
    position: absolute;
    left: 1px;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 48px;
    background: var(--lesp-border);
    border-radius: 2px;
    transition: background 0.15s, height 0.15s, box-shadow 0.15s;
}

.panel-resize-handle:hover::before {
    background: var(--lesp-accent);
    height: 72px;
    box-shadow: 0 0 12px var(--lesp-accent-glow);
}

.panel-resizing .panel-resize-handle {
    background: linear-gradient(90deg, 
        rgba(97, 175, 239, 0.4) 0%, 
        transparent 100%);
}

.panel-resizing .panel-resize-handle::before {
    background: var(--lesp-accent);
    height: 100px;
}

/* Prevent interactions during resize */
body.panel-resize-active {
    cursor: ew-resize !important;
}

body.panel-resize-active * {
    cursor: ew-resize !important;
}

body.panel-resize-active .learning-editor-sidepanel .lesp-body {
    pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOADING STATES & MICRO-INTERACTIONS
   ═══════════════════════════════════════════════════════════════════════════ */

/* Button loading state */
.lesp-btn.loading {
    position: relative;
    color: transparent !important;
    pointer-events: none;
}

.lesp-btn.loading::after {
    content: '';
    position: absolute;
    width: 16px;
    height: 16px;
    top: 50%;
    left: 50%;
    margin: -8px 0 0 -8px;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: lesp-spin 0.8s linear infinite;
}

@keyframes lesp-spin {
    to { transform: rotate(360deg); }
}

/* Ripple effect on buttons */
.lesp-btn {
    position: relative;
    overflow: hidden;
}

.lesp-btn::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    transition: width 0.4s ease, height 0.4s ease;
}

.lesp-btn:active::before {
    width: 200%;
    height: 200%;
}

/* Focus ring for accessibility */
.lesp-btn:focus-visible,
.lesp-form input:focus-visible,
.lesp-form textarea:focus-visible,
.lesp-form select:focus-visible {
    outline: 2px solid var(--lesp-accent);
    outline-offset: 2px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SECTION HEADERS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-section-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 0;
    margin-bottom: 12px;
    border-bottom: 1px solid var(--lesp-border);
}

.lesp-section-header i {
    color: var(--lesp-accent);
    font-size: 1rem;
}

.lesp-section-header h3 {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--lesp-text);
}

.lesp-section-header span {
    margin-left: auto;
    font-size: 0.75rem;
    color: var(--lesp-text-subtle);
}

/* ═══════════════════════════════════════════════════════════════════════════
   COLLAPSIBLE SECTIONS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-collapsible {
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    margin-bottom: 12px;
    overflow: hidden;
}

.lesp-collapsible-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    background: var(--lesp-surface-light);
    cursor: pointer;
    transition: background var(--lesp-transition-fast);
}

.lesp-collapsible-header:hover {
    background: var(--lesp-surface-elevated);
}

.lesp-collapsible-header i.chevron {
    margin-left: auto;
    transition: transform var(--lesp-transition-normal);
}

.lesp-collapsible.open .lesp-collapsible-header i.chevron {
    transform: rotate(90deg);
}

.lesp-collapsible-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out, padding 0.3s ease-out;
    padding: 0 14px;
}

.lesp-collapsible.open .lesp-collapsible-content {
    max-height: 1000px;
    padding: 14px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE ADJUSTMENTS
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1200px) {
    .learning-editor-sidepanel {
        width: 40%;
    }
}

@media (max-width: 900px) {
    .learning-editor-sidepanel {
        width: 50%;
    }
}

@media (max-width: 768px) {
    .learning-editor-sidepanel {
        width: 100%;
        min-width: unset;
        top: 60px; /* Smaller offset on mobile */
        height: calc(100% - 60px);
        border-top-left-radius: 0;
    }
    
    .lesp-header {
        padding: 12px 16px;
    }
    
    .lesp-body {
        padding: 16px;
    }
    
    .lesp-form-actions {
        flex-direction: column;
    }
    
    .lesp-form-actions .lesp-btn {
        width: 100%;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   EMPTY STATES
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 48px 24px;
    text-align: center;
}

.lesp-empty-state-icon {
    font-size: 3rem;
    color: var(--lesp-border);
}

.lesp-empty-state-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--lesp-text);
    margin: 0;
}

.lesp-empty-state-text {
    font-size: 0.9rem;
    color: var(--lesp-text-muted);
    max-width: 280px;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BADGES & INDICATORS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 8px;
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: 4px;
}

.lesp-badge-success {
    background: rgba(152, 195, 121, 0.15);
    color: var(--lesp-success);
}

.lesp-badge-warning {
    background: rgba(229, 192, 123, 0.15);
    color: var(--lesp-warning);
}

.lesp-badge-info {
    background: var(--lesp-accent-glow);
    color: var(--lesp-accent);
}

/* ═══════════════════════════════════════════════════════════════════════════
   TOOLTIPS (Optional hover hints)
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-tooltip {
    position: relative;
}

.lesp-tooltip::after {
    content: attr(data-tooltip);
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
    
    padding: 6px 10px;
    background: var(--lesp-surface-elevated);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-sm);
    
    font-size: 0.75rem;
    color: var(--lesp-text);
    white-space: nowrap;
    
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.15s, transform 0.15s, visibility 0.15s;
    z-index: 100;
}

.lesp-tooltip:hover::after {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(-8px);
}

/* ═══════════════════════════════════════════════════════════════════════════
   STEP FORM - Context Info
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-step-context-info {
    background: linear-gradient(135deg, 
        rgba(97, 175, 239, 0.1) 0%, 
        rgba(97, 175, 239, 0.05) 100%);
    border: 1px solid rgba(97, 175, 239, 0.3);
    border-radius: var(--lesp-radius-md);
    padding: 14px 16px;
    margin-bottom: 16px;
    font-size: 0.85rem;
    color: var(--lesp-accent);
    line-height: 1.5;
}

.lesp-step-context-info strong {
    color: var(--lesp-text);
}

.lesp-step-context-info small {
    opacity: 0.75;
    display: block;
    margin-top: 6px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   STEP FORM - Testing Container
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-step-testing-container {
    background: linear-gradient(135deg, 
        rgba(152, 195, 121, 0.1) 0%, 
        rgba(152, 195, 121, 0.05) 100%);
    border: 1px solid rgba(152, 195, 121, 0.3);
    border-radius: var(--lesp-radius-md);
    padding: 14px 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.lesp-step-testing-container span {
    font-weight: 500;
    color: var(--lesp-success);
}

.lesp-step-testing-container small {
    margin-left: auto;
    font-size: 0.8rem;
    color: rgba(152, 195, 121, 0.8);
}

/* ═══════════════════════════════════════════════════════════════════════════
   EVENTS SECTION - Mode Toggle & Content
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-events-section {
    margin-bottom: 16px;
}

.lesp-events-section > label {
    font-weight: 600;
    display: block;
    margin-bottom: 8px;
    font-size: 0.85rem;
    color: var(--lesp-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.lesp-events-mode-toggle {
    display: flex;
    gap: 4px;
    margin-bottom: 12px;
    background: var(--lesp-surface);
    border-radius: var(--lesp-radius-md);
    padding: 4px;
    border: 1px solid var(--lesp-border);
}

.lesp-mode-btn {
    flex: 1;
    padding: 10px 12px;
    border: none;
    border-radius: var(--lesp-radius-sm);
    cursor: pointer;
    font-size: 0.85rem;
    font-weight: 500;
    font-family: var(--primary-font);
    transition: background 0.15s, color 0.15s;
    background: transparent;
    color: var(--lesp-text-muted);
}

.lesp-mode-btn:hover {
    background: var(--lesp-surface-light);
    color: var(--lesp-text);
}

.lesp-mode-btn.active {
    color: var(--lesp-accent);
    background: var(--lesp-accent-glow);
}

.lesp-mode-btn.active.sequence-mode {
    color: var(--lesp-success);
    background: rgba(152, 195, 121, 0.15);
}

.lesp-events-content {
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    padding: 14px;
}

/* Event Chain Display */
.lesp-events-content .lesp-chain-display {
    background: var(--lesp-surface-light);
    border: 1px solid rgba(97, 175, 239, 0.2);
    margin-bottom: 10px;
    max-height: 80px;
    overflow-y: auto;
}

/* Sequence Display */
.lesp-sequence-display {
    background: var(--lesp-surface-light);
    border: 1px solid rgba(152, 195, 121, 0.2);
    border-radius: var(--lesp-radius-md);
    padding: 12px 14px;
    font-size: 0.85rem;
    margin-bottom: 10px;
}

.lesp-sequence-display .lesp-clear-seq-btn {
    padding: 4px 8px !important;
    font-size: 0.75rem !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   REMOVE AUDIO BUTTON (Special variant)
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-remove-audio-btn {
    color: var(--lesp-danger) !important;
    border-color: rgba(224, 108, 117, 0.3);
    margin-left: 8px;
}

.lesp-remove-audio-btn:hover {
    background: rgba(224, 108, 117, 0.1);
    border-color: var(--lesp-danger);
}

/* ═══════════════════════════════════════════════════════════════════════════
   PLACEHOLDER STYLES
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-form input::placeholder,
.lesp-form textarea::placeholder {
    color: var(--lesp-text-subtle);
    opacity: 0.7;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SELECT DROPDOWN STYLING
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-form select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 12 12%27%3E%3Cpath fill=%27%238891a0%27 d=%27M6 8L1 3h10z%27/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
    cursor: pointer;
}

.lesp-form select option {
    background: var(--lesp-surface);
    color: var(--lesp-text);
    padding: 8px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTON ROW LAYOUTS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-btn-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.lesp-btn-row .lesp-btn {
    flex: 0 1 auto;
}

/* Small button variant */
.lesp-btn-small,
.lesp-btn.lesp-btn-small {
    padding: 6px 10px;
    font-size: 0.8rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HORIZONTAL RULE IN FORMS
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-form hr {
    border: none;
    border-top: 1px solid var(--lesp-border);
    margin: 20px 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SEQUENCE EDITOR PANEL (Bottom dock)
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-sequence-editor-panel {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 30%;
    height: 320px;
    background: var(--lesp-bg);
    border-top: 2px solid var(--lesp-accent);
    border-right: 2px solid var(--lesp-accent);
    z-index: 800;
    display: flex;
    flex-direction: column;
    box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.4);
}

.lesp-sequence-editor-container {
    flex: 1;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SLIDER RANGE INPUT STYLING
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-narrator-container input[type="range"],
.lesp-form input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    height: 6px;
    background: var(--lesp-surface-light);
    border-radius: 3px;
    outline: none;
    cursor: pointer;
}

.lesp-narrator-container input[type="range"]::-webkit-slider-thumb,
.lesp-form input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 16px;
    height: 16px;
    background: var(--lesp-accent);
    border-radius: 50%;
    cursor: pointer;
    transition: transform var(--lesp-transition-fast), background var(--lesp-transition-fast);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}

.lesp-narrator-container input[type="range"]::-webkit-slider-thumb:hover,
.lesp-form input[type="range"]::-webkit-slider-thumb:hover {
    transform: scale(1.2);
    background: var(--lesp-accent-hover);
}

.lesp-narrator-container input[type="range"]::-moz-range-thumb,
.lesp-form input[type="range"]::-moz-range-thumb {
    width: 16px;
    height: 16px;
    background: var(--lesp-accent);
    border-radius: 50%;
    cursor: pointer;
    border: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PREVIEW CONTROLS ROW
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-narrator-container > div[style*="display:flex"] {
    display: flex !important;
    align-items: center;
    gap: 8px;
    width: 100%;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(97, 175, 239, 0.15);
}

/* ═══════════════════════════════════════════════════════════════════════════
   LEGACY EMPTY STATE (backwards compatibility)
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-empty {
    padding: 32px 24px;
    text-align: center;
    color: var(--lesp-text-muted);
    font-size: 0.9rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   VOICE GENERATION - StepList Button & Modal
   ═══════════════════════════════════════════════════════════════════════════ */
.lesp-voice-gen-wrapper {
    display: flex;
    align-items: center;
}

.lesp-voice-gen-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: linear-gradient(135deg, rgba(97, 175, 239, 0.12) 0%, rgba(97, 175, 239, 0.05) 100%);
    border-color: rgba(97, 175, 239, 0.35);
    color: var(--lesp-accent);
    transition: all 0.2s ease;
}

.lesp-voice-gen-btn:hover {
    background: linear-gradient(135deg, rgba(97, 175, 239, 0.22) 0%, rgba(97, 175, 239, 0.12) 100%);
    border-color: var(--lesp-accent);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(97, 175, 239, 0.2);
}

.lesp-voice-gen-btn .lesp-badge {
    background: var(--lesp-accent);
    color: #fff;
    font-size: 0.7rem;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    min-width: 18px;
    text-align: center;
}

.lesp-voice-gen-btn.all-done {
    background: rgba(152, 195, 121, 0.1);
    border-color: rgba(152, 195, 121, 0.3);
    color: var(--lesp-success);
}

.lesp-voice-gen-btn.needs-config {
    background: rgba(229, 192, 123, 0.1);
    border-color: rgba(229, 192, 123, 0.4);
    color: var(--lesp-warning);
}

.lesp-voice-gen-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Voice Modal Overlay */
.lesp-voice-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(10, 12, 16, 0.9);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    animation: lesp-fade-in 0.15s ease-out;
}

.lesp-voice-modal {
    width: 90%;
    max-width: 400px;
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
    overflow: hidden;
    animation: lesp-slide-up 0.2s ease-out;
}

.lesp-voice-modal-compact {
    max-width: 340px;
}

@keyframes lesp-slide-up {
    from { opacity: 0; transform: translateY(16px) scale(0.98); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

.lesp-voice-modal-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 14px 16px;
    background: var(--lesp-surface-light);
    border-bottom: 1px solid var(--lesp-border);
}

.lesp-voice-modal-header h3 {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    flex: 1;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--lesp-text);
}

.lesp-voice-modal-header h3 i {
    color: var(--lesp-accent);
    font-size: 0.85rem;
}

.lesp-voice-modal-close {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: var(--lesp-radius-sm);
    color: var(--lesp-text-muted);
    cursor: pointer;
    transition: color 0.15s, background 0.15s;
}

.lesp-voice-modal-close:hover {
    background: var(--lesp-surface-elevated);
    color: var(--lesp-danger);
}

.lesp-voice-modal-body {
    padding: 16px;
    max-height: 50vh;
    overflow-y: auto;
}

.lesp-voice-modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 12px 16px;
    background: var(--lesp-bg);
    border-top: 1px solid var(--lesp-border);
}

/* Step Preview List */
.lesp-voice-step-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.lesp-voice-step-preview {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    background: var(--lesp-bg);
    border-radius: var(--lesp-radius-sm);
    font-size: 0.8rem;
}

.lesp-voice-step-preview .step-num {
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--lesp-surface-light);
    border-radius: 50%;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--lesp-text-muted);
}

.lesp-voice-step-preview .step-title {
    flex: 1;
    color: var(--lesp-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lesp-voice-step-preview i {
    font-size: 0.65rem;
    color: var(--lesp-text-subtle);
}

.lesp-voice-step-preview.has-audio i {
    color: var(--lesp-success);
}

.lesp-voice-step-more {
    padding: 6px 10px;
    font-size: 0.75rem;
    color: var(--lesp-text-muted);
    text-align: center;
}

/* Live Step Tracker */
.lesp-voice-live-tracker {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.lesp-voice-live-step {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    background: var(--lesp-bg);
    border-radius: var(--lesp-radius-sm);
    transition: background 0.2s, transform 0.2s;
}

.lesp-voice-live-step .live-step-status {
    width: 22px;
    height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.lesp-voice-live-step .live-step-status i {
    font-size: 0.6rem;
    color: var(--lesp-text-subtle);
    transition: color 0.2s;
}

.lesp-voice-live-step .live-step-info {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1px;
    min-width: 0;
}

.lesp-voice-live-step .live-step-title {
    font-size: 0.8rem;
    color: var(--lesp-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lesp-voice-live-step .live-step-action {
    font-size: 0.7rem;
    color: var(--lesp-accent);
    min-height: 14px;
}

.lesp-voice-live-step.active {
    background: rgba(97, 175, 239, 0.08);
    transform: scale(1.01);
}

.lesp-voice-live-step.active .live-step-status i {
    color: var(--lesp-accent);
}

.lesp-voice-live-step.done .live-step-status i {
    color: var(--lesp-success);
}

.lesp-voice-live-step.skipped {
    opacity: 0.5;
}

.lesp-voice-live-step.error .live-step-status i {
    color: var(--lesp-danger);
}

/* Full width button */
.lesp-btn-full {
    width: 100%;
    justify-content: center;
}

.lesp-btn-sm {
    padding: 6px 12px;
    font-size: 0.8rem;
}

/* Success message */
.lesp-voice-success-msg {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    color: var(--lesp-success);
    font-size: 0.85rem;
    font-weight: 500;
}

/* Result summary inline */
.lesp-voice-result-summary {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.lesp-voice-result-summary span {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 0.8rem;
}

.lesp-voice-result-summary .result-generated { color: var(--lesp-success); }
.lesp-voice-result-summary .result-skipped { color: var(--lesp-text-muted); }
.lesp-voice-result-summary .result-failed { color: var(--lesp-danger); }

/* Option highlight */
.lesp-voice-option-highlight {
    margin-top: 12px;
    background: rgba(229, 192, 123, 0.08);
    border: 1px solid rgba(229, 192, 123, 0.2);
    border-radius: var(--lesp-radius-sm);
    padding: 10px 12px;
}

/* Pulse animation for waveform */
@keyframes fa-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

.fa-pulse {
    animation: fa-pulse 0.8s ease-in-out infinite;
}

/* Voice Options (regenerate checkbox) */
.lesp-voice-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 12px;
}

.lesp-voice-option {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: var(--lesp-bg);
    border-radius: var(--lesp-radius-sm);
    cursor: pointer;
    transition: background 0.15s;
}

.lesp-voice-option:hover {
    background: var(--lesp-surface-light);
}

.lesp-voice-option input[type="checkbox"] {
    appearance: none;
    width: 16px;
    height: 16px;
    background: var(--lesp-surface);
    border: 2px solid var(--lesp-border);
    border-radius: 3px;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
    flex-shrink: 0;
}

.lesp-voice-option input[type="checkbox"]:checked {
    background: var(--lesp-accent);
    border-color: var(--lesp-accent);
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27white%27%3E%3Cpath d=%27M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z%27/%3E%3C/svg%3E");
    background-size: 10px;
    background-repeat: no-repeat;
    background-position: center;
}

.lesp-voice-option span {
    color: var(--lesp-text);
    font-size: 0.8rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   AI WIZARD - Voice Generation Toggle (Step 3)
   ═══════════════════════════════════════════════════════════════════════════ */
.ai-wizard-voice-toggle {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
    padding: 14px 16px;
    background: var(--lesp-bg);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-md);
    cursor: pointer;
    transition: border-color 0.2s, background 0.2s;
}

.ai-wizard-voice-toggle:hover {
    border-color: var(--lesp-accent);
    background: rgba(97, 175, 239, 0.03);
}

.ai-wizard-voice-toggle.active {
    border-color: var(--lesp-accent);
    background: rgba(97, 175, 239, 0.06);
}

.ai-wizard-voice-toggle.needs-config {
    border-color: rgba(229, 192, 123, 0.4);
}

.ai-wizard-voice-toggle.needs-config:hover {
    background: rgba(229, 192, 123, 0.05);
}

.ai-wizard-voice-toggle .voice-toggle-content {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.ai-wizard-voice-toggle .voice-toggle-content > i {
    font-size: 1.2rem;
    color: var(--lesp-accent);
    width: 24px;
    text-align: center;
}

.ai-wizard-voice-toggle.needs-config .voice-toggle-content > i {
    color: var(--lesp-warning);
}

.ai-wizard-voice-toggle .voice-toggle-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ai-wizard-voice-toggle .voice-toggle-label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--lesp-text);
}

.ai-wizard-voice-toggle .voice-toggle-desc {
    font-size: 0.75rem;
    color: var(--lesp-text-muted);
}

.ai-wizard-voice-toggle .voice-toggle-switch {
    width: 40px;
    height: 22px;
    background: var(--lesp-surface-light);
    border-radius: 11px;
    position: relative;
    transition: background 0.2s;
}

.ai-wizard-voice-toggle .voice-toggle-switch.on {
    background: var(--lesp-accent);
}

.ai-wizard-voice-toggle .voice-toggle-knob {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 16px;
    height: 16px;
    background: #fff;
    border-radius: 50%;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}

.ai-wizard-voice-toggle .voice-toggle-switch.on .voice-toggle-knob {
    transform: translateX(18px);
}

.ai-wizard-voice-toggle .voice-toggle-warning {
    color: var(--lesp-warning);
    font-size: 0.9rem;
}

/* AI Wizard Voice Progress Overlay (within wizard) */
.ai-wizard-voice-progress-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 12, 16, 0.95);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    border-radius: var(--lesp-radius-lg);
}

.ai-wizard-voice-progress-card {
    width: 85%;
    max-width: 300px;
    padding: 24px;
    background: var(--lesp-surface);
    border: 1px solid var(--lesp-border);
    border-radius: var(--lesp-radius-lg);
}

.voice-progress-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    margin-bottom: 20px;
}

.voice-progress-header i {
    color: var(--lesp-accent);
    font-size: 1.1rem;
}

.voice-progress-header h4 {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--lesp-text);
}

.voice-progress-content {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.voice-progress-content .voice-progress-bar {
    height: 5px;
    background: var(--lesp-bg);
    border-radius: 3px;
    overflow: hidden;
}

.voice-progress-content .voice-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--lesp-accent) 0%, var(--lesp-success) 100%);
    border-radius: 3px;
    transition: width 0.25s ease-out;
}

.voice-progress-content .voice-progress-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.voice-progress-content .progress-step {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--lesp-text);
    text-align: center;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.voice-progress-content .progress-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--lesp-accent);
}

.voice-progress-content .progress-status i {
    font-size: 0.8rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   DARK MODE OPTIMIZATIONS (improved contrast)
   ═══════════════════════════════════════════════════════════════════════════ */
.learning-editor-sidepanel ::selection {
    background: var(--lesp-accent);
    color: #fff;
}

/* Ensure Font Awesome icons are properly sized */
.lesp-btn i.fas,
.lesp-btn i.far,
.lesp-btn i.fab {
    width: 1em;
    text-align: center;
}

/* Gap between icon and text in buttons */
.lesp-btn i + span,
.lesp-btn span + i {
    margin-left: 0; /* gap is handled by flex gap */
}

/* infoTooltip.css - Info tooltip component using Vico design tokens */

#tooltip-root {
    position: relative;
    z-index: 99999;
}

/* Container that holds the info icon */
.info-tooltip-container {
    display: inline-flex;
    align-items: center;
    margin-left: var(--vico-space-sm);
    position: relative;
}

/* The icon/button itself */
.info-tooltip-icon {
    background: none;
    border: none;
    padding: var(--vico-space-xs);
    cursor: pointer;
    color: var(--vico-text-muted);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color var(--vico-transition-fast), background-color var(--vico-transition-fast);
}

.info-tooltip-icon:hover {
    color: var(--vico-text-secondary);
    background-color: rgba(255, 255, 255, 0.1);
}

.info-tooltip-icon.active {
    color: var(--vico-accent-blue);
    background-color: var(--vico-glow-blue);
}

.info-tooltip-icon.urgent-continuous-blink {
    color: var(--vico-accent-amber);
    animation: info-pulse 1.2s infinite;
    box-shadow: 0 0 0 0 var(--vico-glow-amber);
}

.info-tooltip-icon.urgent-single-blink {
    color: var(--vico-accent-amber);
    animation: info-pulse 1.2s 1;
    box-shadow: 0 0 0 0 var(--vico-glow-amber);
}

@keyframes info-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(229, 192, 123, 0.7);
        transform: scale(1);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(229, 192, 123, 0);
        transform: scale(1.15);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(229, 192, 123, 0);
        transform: scale(1);
    }
}

/* The content box that pops up */
.info-tooltip-content {
    position: fixed;
    background-color: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    padding: var(--vico-space-lg);
    width: 280px;
    box-shadow: var(--vico-shadow-lg);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--vico-transition-fast), visibility var(--vico-transition-fast);
}

/* Class to show content */
.info-tooltip-content.visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    z-index: 10000;
}

/* Tooltip content styling */
.info-tooltip-content h3 {
    color: var(--vico-text-primary);
    font-size: 16px;
    margin: 0 0 var(--vico-space-md) 0;
    font-weight: 600;
}

.info-tooltip-content p {
    color: var(--vico-text-secondary);
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 var(--vico-space-md) 0;
}

.info-tooltip-content ul {
    color: var(--vico-text-secondary);
    font-size: 14px;
    line-height: 1.5;
    margin: 0;
    padding-left: var(--vico-space-xl);
}

.info-tooltip-content li {
    margin-bottom: var(--vico-space-sm);
}

.info-tooltip-content li:last-child {
    margin-bottom: 0;
}

.info-tooltip-content strong {
    color: var(--vico-text-primary);
    font-weight: 600;
}
  
/* ═══════════════════════════════════════════════════════════════════════════
   QUIZ EDITOR SIDE PANEL - Vico Design System
   Reuses lesp-* classes from learningEditorSidePanel.css
   Uses shared tokens from tokens.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Questions Container */
.qesp-questions-container {
  display: flex;
  flex-direction: column;
  gap: var(--vico-space-md);
  margin-bottom: var(--vico-space-lg);
}

/* Question Block */
.qesp-question-block {
  background: var(--vico-bg-base);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-lg);
  padding: 0;
  display: flex;
  flex-direction: column;
  transition: border-color var(--vico-transition-fast);
}

.qesp-question-block:hover {
  border-color: var(--vico-border-hover);
}

/* Question Header */
.qesp-question-header {
  display: flex;
  align-items: center;
  gap: var(--vico-space-sm);
  padding: var(--vico-space-md) 14px;
  background: var(--vico-bg-raised);
  border-radius: 7px 7px 0 0;
  border-bottom: 1px solid var(--vico-border);
}

.qesp-question-title {
  color: var(--vico-accent-amber);
  font-size: 0.9rem;
  font-weight: 600;
  margin: 0;
  flex: 1;
}

/* Question Content (collapsible) */
.qesp-question-content {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.qesp-question-block.qesp-collapsed .qesp-question-content {
  display: none;
}

/* Collapse Button */
.qesp-collapse-btn {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--vico-text-secondary);
  cursor: pointer;
  font-size: 0.85rem;
  transition: color var(--vico-transition-fast), transform 0.2s;
}

.qesp-collapse-btn:hover {
  color: var(--vico-accent-amber);
}

/* Drag Handle */
.qesp-drag-handle {
  cursor: grab;
  padding: 0 6px;
  font-size: 1rem;
  color: var(--vico-text-muted);
  user-select: none;
  transition: color var(--vico-transition-fast);
}

.qesp-drag-handle:hover {
  color: var(--vico-text-secondary);
}

.qesp-drag-handle:active {
  cursor: grabbing;
  color: var(--vico-accent-blue);
}

/* Remove Question Button */
.qesp-remove-question-btn {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--vico-radius-sm);
  color: var(--vico-text-muted);
  cursor: pointer;
  transition: background var(--vico-transition-fast), color var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.qesp-remove-question-btn:hover {
  background: rgba(224, 108, 117, 0.1);
  border-color: rgba(224, 108, 117, 0.3);
  color: var(--vico-accent-red);
}

/* Question Block Answers Section Title */
.qesp-question-block h6 {
  color: var(--vico-text-secondary);
  margin: 8px 0 4px;
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-top: 1px solid var(--vico-border);
  padding-top: 12px;
}

/* Answers Container */
.qesp-answers-container {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-left: 0;
}

/* Answer Block */
.qesp-answer-block {
  background: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  padding: 10px 12px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--vico-space-md);
  transition: border-color var(--vico-transition-fast);
}

.qesp-answer-block:hover {
  border-color: var(--vico-border-hover);
}

/* Answer Content */
.qesp-answer-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}

.qesp-answer-text-group label,
.qesp-answer-image-group label {
  font-size: 0.75rem;
  color: var(--vico-text-muted);
  margin-bottom: 2px;
}

/* Answer Controls */
.qesp-answer-controls {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  min-width: 70px;
}

/* Correct Answer Checkbox */
.qesp-correct-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: var(--vico-text-secondary);
  cursor: pointer;
  padding: 4px 8px;
  background: var(--vico-bg-base);
  border-radius: var(--vico-radius-sm);
  transition: background var(--vico-transition-fast);
}

.qesp-correct-label:hover {
  background: var(--vico-bg-elevated);
}

.qesp-correct-checkbox {
  appearance: none;
  width: 16px;
  height: 16px;
  background: var(--vico-bg-base);
  border: 2px solid var(--vico-border);
  border-radius: 3px;
  cursor: pointer;
  transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.qesp-correct-checkbox:hover {
  border-color: var(--vico-accent-green);
}

.qesp-correct-checkbox:checked {
  background: var(--vico-accent-green);
  border-color: var(--vico-accent-green);
  background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27 fill=%27%231a1d24%27%3E%3Cpath d=%27M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z%27/%3E%3C/svg%3E");
  background-size: 10px;
  background-repeat: no-repeat;
  background-position: center;
}

/* Remove Answer Button */
.qesp-remove-answer-btn {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: var(--vico-text-muted);
  cursor: pointer;
  font-size: 0.85rem;
  transition: color var(--vico-transition-fast);
}

.qesp-remove-answer-btn:hover {
  color: var(--vico-accent-red);
}

/* Image Selector */
.qesp-image-selector {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.qesp-image-id-display {
  background: var(--vico-bg-base);
  padding: 4px 10px;
  border-radius: var(--vico-radius-sm);
  font-size: 0.75rem;
  color: var(--vico-accent-cyan);
  font-family: 'Courier New', monospace;
  min-width: 50px;
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 120px;
  border: 1px solid var(--vico-border);
}

.qesp-browse-image-btn,
.qesp-clear-image-btn {
  padding: 4px 10px;
  font-size: 0.75rem;
  background: var(--vico-bg-elevated);
  color: var(--vico-text-secondary);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-sm);
  cursor: pointer;
  transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.qesp-browse-image-btn:hover {
  background: var(--vico-bg-hover);
  border-color: var(--vico-accent-blue);
  color: var(--vico-accent-blue);
}

.qesp-clear-image-btn:hover {
  background: rgba(224, 108, 117, 0.1);
  border-color: rgba(224, 108, 117, 0.3);
  color: var(--vico-accent-red);
}

.qesp-image-preview {
  max-width: 50px;
  max-height: 36px;
  border-radius: var(--vico-radius-sm);
  border: 1px solid var(--vico-border);
  object-fit: cover;
}

/* Add Buttons */
.qesp-add-question-btn,
.qesp-add-answer-btn {
  margin-top: 8px;
  padding: 8px 14px;
  font-size: 0.85rem;
  background: var(--vico-bg-raised);
  color: var(--vico-accent-blue);
  border: 1px dashed rgba(97, 175, 239, 0.4);
  border-radius: var(--vico-radius-md);
  width: fit-content;
  align-self: flex-start;
  cursor: pointer;
  transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.qesp-add-question-btn:hover,
.qesp-add-answer-btn:hover {
  background: rgba(97, 175, 239, 0.1);
  border-color: var(--vico-accent-blue);
  color: var(--vico-accent-blue-light);
}

.qesp-add-question-btn i,
.qesp-add-answer-btn i {
  margin-right: 6px;
}

/* Inputs within question/answer blocks */
.qesp-question-block textarea,
.qesp-answer-block input[type="text"] {
  padding: 10px 12px;
  background: var(--vico-bg-raised);
  color: var(--vico-text-primary);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  font-size: 0.9rem;
  width: 100%;
  box-sizing: border-box;
  transition: border-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.qesp-question-block textarea:hover,
.qesp-answer-block input[type="text"]:hover {
  border-color: var(--vico-border-hover);
}

.qesp-question-block textarea:focus,
.qesp-answer-block input[type="text"]:focus {
  outline: none;
  border-color: var(--vico-accent-blue);
  box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

.qesp-question-block textarea {
  resize: vertical;
  min-height: 50px;
  font-family: inherit;
}

/* Panel Resize Handle - Prevent interactions during resize */
body.panel-resize-active #quiz-editor-sidepanel .lesp-body {
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CUSTOM HTML EDITOR SIDE PANEL - Vico Design System
   Reuses lesp-* classes from learningEditorSidePanel.css
   Uses shared tokens from tokens.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Panel Container */
.html-editor-sidepanel {
  position: fixed;
  top: 10%;
  right: 0;
  width: 35%;
  height: 90%;
  background: var(--vico-bg-base);
  border-left: 1px solid var(--vico-border);
  box-shadow: var(--vico-shadow-lg);
  
  /* Initial state for popupManager */
  transform: translateX(110%);
  opacity: 0;
  visibility: hidden;
  transition: transform 0.3s ease, opacity 0.3s ease, visibility 0.3s ease;

  z-index: 999;
  display: flex;
  flex-direction: column;
  pointer-events: auto;
}

.html-editor-sidepanel.active {
  transform: translateX(0%);
  opacity: 1;
  visibility: visible;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CONTROLS TOOLBAR - Always visible in side panel
   ═══════════════════════════════════════════════════════════════════════════ */
.hesp-controls-toolbar {
  display: flex;
  gap: 8px;
  padding: var(--vico-space-md);
  background: var(--vico-bg-deep);
  border-bottom: 1px solid var(--vico-border);
  flex-shrink: 0;
}

.hesp-toolbar-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  justify-content: center;
  padding: var(--vico-space-sm) var(--vico-space-md);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  background: var(--vico-bg-raised);
  color: var(--vico-text-secondary);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--vico-transition-fast), color var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.hesp-toolbar-btn:hover {
  background: var(--vico-bg-elevated);
  color: var(--vico-text-primary);
  border-color: var(--vico-border-hover);
}

.hesp-toolbar-btn i {
  font-size: 0.8rem;
}

/* Preview visible state (cyan) */
.hesp-toolbar-btn.hesp-preview-visible {
  background: var(--vico-accent-cyan);
  color: var(--vico-bg-base);
  border-color: var(--vico-accent-cyan);
}

.hesp-toolbar-btn.hesp-preview-visible:hover {
  background: #66c6d2;
}

/* Edit mode state (purple gradient) */
.hesp-toolbar-btn.hesp-mode-edit {
  background: var(--vico-gradient-purple);
  color: #fff;
  border-color: var(--vico-accent-purple);
}

.hesp-toolbar-btn.hesp-mode-edit:hover {
  background: linear-gradient(135deg, var(--vico-accent-purple-light) 0%, var(--vico-accent-purple) 100%);
}

/* Test mode state (blue gradient) */
.hesp-toolbar-btn.hesp-mode-test {
  background: var(--vico-gradient-blue);
  color: #fff;
  border-color: var(--vico-accent-blue);
}

.hesp-toolbar-btn.hesp-mode-test:hover {
  background: linear-gradient(135deg, var(--vico-accent-blue-light) 0%, var(--vico-accent-blue) 100%);
}

/* Editor Container */
.hesp-editor-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 12px;
}

/* Editor Layout */
.hesp-editor-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  flex: 1;
  overflow: hidden;
}

/* Inspector Panel */
.hesp-inspector-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  flex: 1;
  background: var(--vico-bg-deep);
  border-radius: var(--vico-radius-lg);
  border: 1px solid var(--vico-border);
}

.hesp-panel-header {
  padding: var(--vico-space-md) var(--vico-space-lg);
  background: var(--vico-gradient-header);
  border-bottom: 1px solid var(--vico-border);
  border-radius: 7px 7px 0 0;
}

.hesp-panel-header h3 {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--vico-text-primary);
}

/* Preview Overlay */
.hesp-preview-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 35%;
  bottom: 0;
  z-index: 9999;
  pointer-events: none;
  transition: right 0.05s ease-out;
}

/* Overlay Hint Banner */
.hesp-overlay-hint {
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 8px 14px;
  background: var(--vico-bg-base);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  color: var(--vico-text-secondary);
  font-size: 0.85rem;
  pointer-events: none;
  box-shadow: var(--vico-shadow-md);
}

/* Preview Container */
.html-preview-container {
  position: relative;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.html-preview-container > * {
  pointer-events: auto;
}

/* Hide scene elements when editor active */
.html-editor-hidden {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Interactive Element Highlighting */
.html-preview-container .html-editor-interactive {
  position: relative;
  outline: 2px dashed var(--vico-accent-green) !important;
  outline-offset: 3px;
  cursor: pointer !important;
  transition: outline-color 0.2s, background-color 0.2s;
}

.html-preview-container .html-editor-interactive:hover {
  outline-color: var(--vico-accent-blue) !important;
  background-color: rgba(97, 175, 239, 0.1) !important;
}

.html-preview-container .html-editor-interactive.selected {
  outline: 2px solid var(--vico-accent-amber) !important;
  background-color: rgba(229, 192, 123, 0.1) !important;
}

/* Inspector */
.html-editor-inspector {
  background: var(--vico-bg-base);
  padding: 16px;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}

/* Inspector Scrollbar */
.html-editor-inspector::-webkit-scrollbar {
  width: var(--vico-scrollbar-width);
}

.html-editor-inspector::-webkit-scrollbar-track {
  background: transparent;
}

.html-editor-inspector::-webkit-scrollbar-thumb {
  background: var(--vico-scrollbar-thumb);
  border-radius: 3px;
}

.html-editor-inspector::-webkit-scrollbar-thumb:hover {
  background: var(--vico-scrollbar-thumb-hover);
}

/* Inspector Sections */
.hesp-inspector-section {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--vico-border);
}

.hesp-inspector-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.hesp-inspector-section h4 {
  margin: 0 0 10px 0;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--vico-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Element Info Display */
.hesp-element-identifier {
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  color: var(--vico-accent-green);
  margin: 0 0 8px 0;
  word-break: break-all;
}

.hesp-element-name {
  margin: 0;
  color: var(--vico-text-primary);
}

.hesp-element-name span {
  color: var(--vico-accent-cyan);
}

/* Quick Actions */
.hesp-quick-label {
  margin: 12px 0 8px 0;
  font-size: 0.75rem;
  color: var(--vico-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.hesp-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}

.hesp-quick-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  background: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-sm);
  color: var(--vico-text-secondary);
  font-size: 0.75rem;
  cursor: pointer;
  transition: background var(--vico-transition-fast), color var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.hesp-quick-btn i {
  font-size: 0.7rem;
  color: var(--vico-accent-blue);
}

.hesp-quick-btn:hover {
  background: var(--vico-bg-elevated);
  color: var(--vico-text-primary);
  border-color: var(--vico-accent-blue);
}

.hesp-quick-btn:active {
  background: var(--vico-accent-blue);
  color: #fff;
}

.hesp-quick-btn:active i {
  color: #fff;
}

/* Attribute Preview */
.hesp-attribute-preview {
  background: var(--vico-bg-raised);
  padding: 10px 12px;
  border-radius: var(--vico-radius-md);
  margin-bottom: 10px;
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  color: var(--vico-accent-cyan);
  word-wrap: break-word;
  max-height: 80px;
  overflow-y: auto;
  border: 1px solid var(--vico-border);
}

/* Attribute Textarea */
.hesp-attribute-textarea {
  width: 100%;
  min-height: 70px;
  padding: 10px 12px;
  background: var(--vico-bg-raised);
  border: 1px solid var(--vico-border);
  border-radius: var(--vico-radius-md);
  color: var(--vico-text-primary);
  font-family: 'Courier New', monospace;
  font-size: 0.85rem;
  resize: vertical;
  margin-bottom: 10px;
  transition: border-color var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.hesp-attribute-textarea:hover {
  border-color: var(--vico-border-hover);
}

.hesp-attribute-textarea:focus {
  outline: none;
  border-color: var(--vico-accent-blue);
  box-shadow: 0 0 0 2px var(--vico-glow-blue);
}

/* Edit/Update Buttons */
.hesp-edit-btn,
.hesp-update-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: var(--vico-space-sm) var(--vico-space-lg);
  border: none;
  border-radius: var(--vico-radius-md);
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
  transition: background var(--vico-transition-fast), box-shadow var(--vico-transition-fast);
}

.hesp-edit-btn i,
.hesp-update-btn i {
  font-size: 0.8rem;
}

.hesp-edit-btn {
  background: var(--vico-gradient-blue);
  color: #fff;
  box-shadow: 0 2px 6px rgba(97, 175, 239, 0.25);
}

.hesp-edit-btn:hover {
  background: linear-gradient(135deg, var(--vico-accent-blue-light) 0%, var(--vico-accent-blue) 100%);
  box-shadow: 0 3px 10px rgba(97, 175, 239, 0.35);
}

.hesp-update-btn {
  background: var(--vico-gradient-green);
  color: var(--vico-bg-base);
  box-shadow: 0 2px 6px rgba(152, 195, 121, 0.25);
}

.hesp-update-btn:hover {
  background: linear-gradient(135deg, var(--vico-accent-green-light) 0%, var(--vico-accent-green) 100%);
  box-shadow: 0 3px 10px rgba(152, 195, 121, 0.35);
}

/* Save Container */
.hesp-save-container {
  padding: 14px 16px;
  background: var(--vico-bg-base);
  border-top: 1px solid var(--vico-border);
  display: flex;
  justify-content: flex-end;
}

/* Responsive */
@media (max-width: 1400px) {
  .html-editor-sidepanel {
    width: 40%;
  }
}

@media (max-width: 1024px) {
  .html-editor-sidepanel {
    width: 100%;
    transform: translateY(110%);
    top: auto;
    bottom: 0;
    height: 50%;
  }
  
  .html-editor-sidepanel.active {
    transform: translateY(0%);
  }
  
  .hesp-preview-overlay {
    right: 0;
    bottom: 50vh;
  }
  
  .html-editor-sidepanel .panel-resize-handle {
    display: none;
  }
}

/* Prevent interactions during resize */
body.panel-resize-active .html-editor-sidepanel .lesp-body,
body.panel-resize-active .html-editor-sidepanel #hesp-body {
  pointer-events: none;
}

@media (max-width: 768px) {
  .learning-editor-sidepanel .panel-resize-handle,
  #quiz-editor-sidepanel .panel-resize-handle {
    display: none;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   EVENT CHAIN MODAL - Modern UX with Split Layout & Command Palette
   Uses shared tokens from tokens.css
   ═══════════════════════════════════════════════════════════════════════════ */

/* Container */
.event-chain-modal-container {
    z-index: 1200;
}

.event-chain-modal-container,
.event-chain-modal-container.active {
    pointer-events: none;
}

/* Main Popup Content */
#event-chain-modal .ecm-popup-content {
    padding: 0;
    width: 95%;
    max-width: 1100px;
    max-height: 90vh;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-xl);
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.4), 0 0 1px rgba(0, 0, 0, 0.2);
    display: flex;
    flex-direction: column;
    pointer-events: auto;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════════════
   HEADER
   ═══════════════════════════════════════════════════════════════════════════ */

#event-chain-modal .popup-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-md) var(--vico-space-lg);
    background: var(--vico-gradient-header);
    border-bottom: 1px solid var(--vico-border);
    flex-shrink: 0;
}

#event-chain-modal .popup-header h2 {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
    color: var(--vico-text-primary);
}

.ecm-header-actions {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
}

.ecm-header-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-secondary);
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

.ecm-header-btn:hover:not(:disabled) {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
}

.ecm-header-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

#event-chain-modal .popup-header .close-btn {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-secondary);
    font-size: 18px;
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast), color var(--vico-transition-fast);
}

#event-chain-modal .popup-header .close-btn:hover {
    background: var(--vico-bg-elevated);
    border-color: var(--vico-accent-red);
    color: var(--vico-accent-red);
}

/* ═══════════════════════════════════════════════════════════════════════════
   BODY - Main Layout
   ═══════════════════════════════════════════════════════════════════════════ */

.ecm-popup-body {
    flex: 1;
    overflow: hidden;
    overflow-x: hidden;
    background: var(--vico-bg-deep);
}

.ecm-main-layout {
    display: flex;
    height: 100%;
    min-height: 500px;
    max-height: calc(90vh - 130px);
    position: relative;
}

/* ═══════════════════════════════════════════════════════════════════════════
   SEARCH SECTION (within chain panel)
   ═══════════════════════════════════════════════════════════════════════════ */

.ecm-search-section {
    border-bottom: 1px solid var(--vico-border);
    background: var(--vico-bg-base);
}

.ecm-palette-search-wrapper {
    position: relative;
    padding: var(--vico-space-md) var(--vico-space-lg);
    background: var(--vico-bg-raised);
}

.ecm-palette-search-icon {
    position: absolute;
    left: 28px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--vico-text-muted);
    font-size: 0.9rem;
}

.ecm-palette-search {
    width: 90%;
    padding: 12px 14px 12px 40px;
    background: var(--vico-bg-base);
    border: 2px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    color: var(--vico-text-primary);
    font-size: 0.95rem;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ecm-palette-search::placeholder {
    color: var(--vico-text-muted);
}

.ecm-palette-search:focus {
    border-color: var(--vico-accent-blue);
    box-shadow: 0 0 0 3px var(--vico-glow-blue);
}

.ecm-palette-kbd {
    position: absolute;
    right: 28px;
    top: 50%;
    transform: translateY(-50%);
    padding: 3px 8px;
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-text-muted);
    font-size: 0.75rem;
    font-family: 'SF Mono', 'Fira Code', monospace;
}

.ecm-palette-results {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    max-height: 220px;
}

.ecm-palette-categories {
    padding: var(--vico-space-sm) var(--vico-space-md);
}

.ecm-palette-category {
    margin-bottom: var(--vico-space-md);
}

.ecm-palette-category-header {
    padding: var(--vico-space-sm) var(--vico-space-sm);
    color: var(--vico-accent-blue);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    border-bottom: 1px solid var(--vico-border);
    margin-bottom: var(--vico-space-xs);
}

.ecm-palette-items {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ecm-palette-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 12px;
    cursor: pointer;
    border-radius: var(--vico-radius-md);
    border: 1px solid transparent;
    transition: background 0.12s ease, border-color 0.12s ease;
}

.ecm-palette-item:hover,
.ecm-palette-item.highlighted {
    background: var(--vico-bg-raised);
    border-color: var(--vico-border);
}

.ecm-palette-item.selected {
    background: rgba(97, 175, 239, 0.12);
    border-color: var(--vico-accent-blue);
}

.ecm-palette-item-title {
    color: var(--vico-text-primary);
    font-size: 0.9rem;
    font-weight: 500;
}

.ecm-palette-item-name {
    color: var(--vico-text-muted);
    font-size: 0.75rem;
    font-family: 'SF Mono', 'Fira Code', monospace;
    background: var(--vico-bg-elevated);
    padding: 2px 6px;
    border-radius: var(--vico-radius-sm);
}

/* Action Info & Category Badge (shared styles) */
.ecm-action-info {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-xs);
}

.ecm-action-category-badge {
    display: inline-block;
    padding: 4px 10px;
    background: rgba(97, 175, 239, 0.15);
    border-radius: var(--vico-radius-md);
    color: var(--vico-accent-blue);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    width: fit-content;
}

.ecm-action-description {
    margin: 0 0 var(--vico-space-lg) 0;
    color: var(--vico-text-secondary);
    font-size: 0.85rem;
    line-height: 1.5;
}

.ecm-icon-btn {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--vico-radius-sm);
    color: var(--vico-text-muted);
    cursor: pointer;
    transition: background var(--vico-transition-fast), color var(--vico-transition-fast);
}

.ecm-icon-btn:hover {
    background: var(--vico-bg-base);
    color: var(--vico-text-primary);
}

.ecm-icon-btn-danger:hover {
    color: var(--vico-accent-red);
}

/* Parameters Form */
.ecm-params-form {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-md);
    margin-bottom: var(--vico-space-lg);
}

.ecm-no-params {
    color: var(--vico-text-muted);
    font-style: italic;
    font-size: 0.9rem;
    text-align: center;
    padding: var(--vico-space-lg);
    background: var(--vico-bg-base);
    border-radius: var(--vico-radius-md);
    border: 1px dashed var(--vico-border);
}

.ecm-param-group {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-sm);
}

.ecm-param-label {
    color: var(--vico-text-secondary);
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: capitalize;
}

.ecm-param-input {
    padding: 10px 12px;
    background: var(--vico-bg-base);
    border: 2px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-primary);
    font-size: 0.9rem;
    outline: none;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ecm-param-input::placeholder {
    color: var(--vico-text-muted);
}

.ecm-param-input:focus {
    border-color: var(--vico-accent-blue);
    box-shadow: 0 0 0 3px var(--vico-glow-blue);
}

.ecm-param-textarea {
    resize: vertical;
    min-height: 80px;
    font-family: inherit;
    line-height: 1.5;
}

.ecm-param-select {
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 12 12%27%3E%3Cpath fill=%27%236b7280%27 d=%27M6 8L2 4h8z%27/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

/* Autocomplete Dropdown */
.ecm-param-autocomplete-wrapper {
    position: relative;
}

.ecm-autocomplete-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    max-height: 150px;
    overflow-y: auto;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-top: none;
    border-radius: 0 0 var(--vico-radius-sm) var(--vico-radius-sm);
    box-shadow: var(--vico-shadow-md);
    z-index: 100;
}

.ecm-autocomplete-item {
    padding: 8px 10px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--vico-text-primary);
    transition: background var(--vico-transition-fast);
}

.ecm-autocomplete-item:hover {
    background: var(--vico-bg-raised);
}

.ecm-autocomplete-item.hidden-object {
    opacity: 0.5;
    font-style: italic;
}

.ecm-autocomplete-empty {
    padding: 8px 10px;
    color: var(--vico-text-muted);
    font-style: italic;
    font-size: 0.85rem;
}

/* Browse Button */
.ecm-param-browse-wrapper {
    display: flex;
    gap: var(--vico-space-xs);
}

.ecm-param-browse-wrapper .ecm-param-input {
    flex: 1;
}

.ecm-param-browse-btn {
    padding: 8px 12px;
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-accent-purple);
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.ecm-param-browse-btn:hover {
    background: rgba(198, 120, 221, 0.1);
    border-color: var(--vico-accent-purple);
}

/* Toggle Switch */
.ecm-param-toggle-wrapper {
    display: flex;
    align-items: center;
}

.ecm-toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
    cursor: pointer;
}

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

.ecm-toggle-slider {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-radius: 12px;
    transition: background var(--vico-transition-fast);
}

.ecm-toggle-slider::before {
    content: '';
    position: absolute;
    height: 18px;
    width: 18px;
    left: 2px;
    bottom: 2px;
    background: var(--vico-text-secondary);
    border-radius: 50%;
    transition: transform var(--vico-transition-fast), background var(--vico-transition-fast);
}

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

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

/* Action Buttons */
.ecm-action-buttons {
    display: flex;
    gap: var(--vico-space-md);
    flex-wrap: wrap;
    padding-top: var(--vico-space-sm);
}

/* Contextual Tools */
.ecm-contextual-tools {
    display: flex;
    gap: var(--vico-space-sm);
    margin-top: var(--vico-space-sm);
    padding-top: var(--vico-space-sm);
    border-top: 1px solid var(--vico-border);
}

.ecm-tool-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--vico-space-xs);
    padding: 6px 10px;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-accent-purple);
    font-size: 0.8rem;
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.ecm-tool-btn:hover {
    background: rgba(198, 120, 221, 0.1);
    border-color: var(--vico-accent-purple);
}

/* Templates Section */
.ecm-templates-section,
.ecm-import-section {
    border-bottom: 1px solid var(--vico-border);
}

.ecm-templates-section summary,
.ecm-import-section summary {
    padding: var(--vico-space-sm) var(--vico-space-md);
    color: var(--vico-text-secondary);
    font-size: 0.8rem;
    font-weight: 500;
    cursor: pointer;
    user-select: none;
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    transition: background var(--vico-transition-fast);
}

.ecm-templates-section summary:hover,
.ecm-import-section summary:hover {
    background: var(--vico-bg-raised);
}

.ecm-templates-section summary i,
.ecm-import-section summary i {
    color: var(--vico-accent-blue);
}

.ecm-templates-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--vico-space-xs);
    padding: var(--vico-space-sm) var(--vico-space-md) var(--vico-space-md);
}

.ecm-template-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--vico-space-xs);
    padding: var(--vico-space-sm);
    background: var(--vico-bg-raised);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-primary);
    font-size: 0.75rem;
    cursor: pointer;
    transition: background var(--vico-transition-fast), border-color var(--vico-transition-fast);
}

.ecm-template-btn:hover {
    background: var(--vico-bg-elevated);
    border-color: var(--vico-accent-blue);
}

.ecm-template-btn i {
    font-size: 1rem;
    color: var(--vico-accent-blue);
}

/* Import Content */
.ecm-import-content {
    padding: var(--vico-space-sm) var(--vico-space-md) var(--vico-space-md);
}

.ecm-import-content textarea {
    width: 100%;
    padding: 8px 10px;
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    color: var(--vico-text-primary);
    font-size: 0.8rem;
    font-family: monospace;
    resize: vertical;
    margin-bottom: var(--vico-space-sm);
    outline: none;
}

.ecm-import-content textarea:focus {
    border-color: var(--vico-accent-blue);
}

.ecm-import-actions {
    display: flex;
    gap: var(--vico-space-sm);
}

/* ═══════════════════════════════════════════════════════════════════════════
   MAIN PANEL - Chain List (always visible)
   ═══════════════════════════════════════════════════════════════════════════ */

.ecm-chain-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: var(--vico-bg-deep);
    overflow: hidden;
    overflow-x: hidden;
    min-width: 0; /* Prevent flex overflow */
}

.ecm-chain-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-md) var(--vico-space-lg);
    background: var(--vico-bg-base);
    border-bottom: 1px solid var(--vico-border);
}

.ecm-chain-header h3 {
    margin: 0;
    color: var(--vico-text-primary);
    font-size: 1rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
}

.ecm-chain-header h3 i {
    color: var(--vico-accent-blue);
    font-size: 0.9rem;
}

.ecm-chain-actions {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
}

.ecm-chain-count {
    color: var(--vico-text-secondary);
    font-size: 0.85rem;
    font-weight: 500;
    background: var(--vico-bg-elevated);
    padding: 4px 10px;
    border-radius: var(--vico-radius-md);
}

/* Duration badge - shows total wait time */
.ecm-chain-duration {
    display: none;
    align-items: center;
    gap: 4px;
    color: var(--vico-accent-amber);
    font-size: 0.8rem;
    font-weight: 600;
    background: rgba(229, 192, 123, 0.12);
    padding: 4px 10px;
    border-radius: var(--vico-radius-md);
    border: 1px solid rgba(229, 192, 123, 0.2);
}

.ecm-chain-duration.has-duration {
    display: inline-flex;
}

.ecm-chain-duration i {
    font-size: 0.7rem;
    opacity: 0.8;
}

.ecm-duration-value {
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-size: 0.75rem;
}

/* Chain List */
.ecm-chain-list {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: var(--vico-space-md) var(--vico-space-lg);
}

.ecm-chain-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--vico-text-muted);
    text-align: center;
    padding: var(--vico-space-xl) var(--vico-space-lg);
}

.ecm-chain-empty i {
    font-size: 3rem;
    margin-bottom: var(--vico-space-lg);
    opacity: 0.3;
    color: var(--vico-accent-blue);
}

.ecm-chain-empty p {
    margin: 0 0 var(--vico-space-sm) 0;
    font-size: 1rem;
    font-weight: 500;
    color: var(--vico-text-secondary);
}

.ecm-chain-empty span {
    font-size: 0.85rem;
    opacity: 0.7;
}

/* Chain Item */
.ecm-chain-item {
    display: flex;
    align-items: center;
    gap: var(--vico-space-md);
    padding: var(--vico-space-md);
    margin-bottom: var(--vico-space-sm);
    background: var(--vico-bg-base);
    border: 2px solid var(--vico-border);
    border-radius: var(--vico-radius-lg);
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease, background 0.15s ease;
    position: relative;
}

.ecm-chain-item:hover {
    background: var(--vico-bg-raised);
    border-color: var(--vico-border-hover);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.ecm-chain-item.editing {
    border-color: var(--vico-accent-amber);
    background: rgba(229, 192, 123, 0.08);
    box-shadow: 0 0 0 3px rgba(229, 192, 123, 0.2);
}

/* Wait/Timing event - subtle amber accent */
.ecm-chain-item.ecm-chain-item-wait {
    border-left: 3px solid var(--vico-accent-amber);
}

.ecm-chain-item.ecm-chain-item-wait .ecm-chain-item-index {
    background: linear-gradient(135deg, var(--vico-accent-amber), #d4a656);
}

.ecm-chain-item.ecm-chain-item-wait .ecm-chain-param-value {
    color: var(--vico-accent-amber-light);
}

.ecm-chain-item.dragging {
    opacity: 0.4;
    transform: scale(0.98);
    box-shadow: none;
}

/* Drag Handle - First element, prominent */
.ecm-chain-drag-handle {
    flex-shrink: 0;
    width: 28px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: grab;
    color: var(--vico-text-muted);
    border-radius: var(--vico-radius-sm);
    transition: color 0.15s ease, background 0.15s ease;
    margin: -4px 0;
}

.ecm-chain-drag-handle:hover {
    color: var(--vico-accent-blue);
    background: rgba(97, 175, 239, 0.1);
}

.ecm-chain-drag-handle:active {
    cursor: grabbing;
    color: var(--vico-accent-blue);
}

.ecm-chain-drag-handle i {
    font-size: 1rem;
}

/* Index Number */
.ecm-chain-item-index {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--vico-accent-blue), #4a90d9);
    border-radius: 50%;
    color: #fff;
    font-size: 0.8rem;
    font-weight: 700;
    box-shadow: 0 2px 4px rgba(97, 175, 239, 0.3);
}

.ecm-chain-item-content {
    flex: 1;
    min-width: 0;
    padding: 2px 0;
}

.ecm-chain-item-header {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
    margin-bottom: 4px;
}

.ecm-chain-item-title {
    color: var(--vico-text-primary);
    font-size: 0.9rem;
    font-weight: 600;
}

.ecm-chain-item-action {
    color: var(--vico-text-muted);
    font-size: 0.7rem;
    font-family: 'SF Mono', 'Fira Code', monospace;
    background: var(--vico-bg-elevated);
    padding: 2px 6px;
    border-radius: var(--vico-radius-sm);
}

.ecm-chain-item-params {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}

.ecm-chain-param {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    background: var(--vico-bg-elevated);
    border-radius: var(--vico-radius-sm);
    font-size: 0.75rem;
    border: 1px solid transparent;
}

.ecm-chain-param-name {
    color: var(--vico-text-muted);
    font-weight: 500;
}

.ecm-chain-param-value {
    color: var(--vico-accent-cyan);
    font-family: 'SF Mono', 'Fira Code', monospace;
    font-size: 0.7rem;
}

.ecm-chain-param-more {
    color: var(--vico-text-muted);
    font-style: italic;
    background: transparent;
    border: 1px dashed var(--vico-border);
}

.ecm-chain-no-params {
    color: var(--vico-text-muted);
    font-size: 0.75rem;
    font-style: italic;
    opacity: 0.7;
}

/* Chain Item Actions */
.ecm-chain-item-actions {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    opacity: 0.5;
    transition: opacity 0.15s ease;
}

.ecm-chain-item:hover .ecm-chain-item-actions {
    opacity: 1;
}

.ecm-chain-btn {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: 1px solid transparent;
    border-radius: var(--vico-radius-md);
    color: var(--vico-text-muted);
    font-size: 0.8rem;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.ecm-chain-btn:hover {
    background: var(--vico-bg-elevated);
    border-color: var(--vico-border);
}

.ecm-chain-edit-btn:hover {
    color: var(--vico-accent-blue);
    border-color: var(--vico-accent-blue);
}

.ecm-chain-duplicate-btn:hover {
    color: var(--vico-accent-green);
    border-color: var(--vico-accent-green);
}

.ecm-chain-delete-btn:hover {
    color: var(--vico-accent-red);
    border-color: var(--vico-accent-red);
}

/* Drop indicators - More prominent with animation */
.ecm-chain-item.drop-indicator-above {
    border-top-color: var(--vico-accent-blue);
    margin-top: 8px;
    transition: margin-top 0.15s ease;
}

.ecm-chain-item.drop-indicator-above::before {
    content: '';
    position: absolute;
    top: -8px;
    left: 10px;
    right: 10px;
    height: 4px;
    background: linear-gradient(90deg, transparent, var(--vico-accent-blue), transparent);
    border-radius: 2px;
    box-shadow: 0 0 12px var(--vico-accent-blue);
    animation: dropPulse 0.8s ease-in-out infinite;
}

.ecm-chain-item.drop-indicator-below {
    border-bottom-color: var(--vico-accent-blue);
    margin-bottom: 8px;
    transition: margin-bottom 0.15s ease;
}

.ecm-chain-item.drop-indicator-below::after {
    content: '';
    position: absolute;
    bottom: -8px;
    left: 10px;
    right: 10px;
    height: 4px;
    background: linear-gradient(90deg, transparent, var(--vico-accent-blue), transparent);
    border-radius: 2px;
    box-shadow: 0 0 12px var(--vico-accent-blue);
    animation: dropPulse 0.8s ease-in-out infinite;
}

@keyframes dropPulse {
    0%, 100% { opacity: 0.7; }
    50% { opacity: 1; }
}

/* Smooth entry animation for new items */
@keyframes slideIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ecm-chain-item {
    animation: slideIn 0.2s ease-out;
}

/* Bottom Tools (Templates & Import) */
.ecm-bottom-tools {
    flex-shrink: 0;
    border-top: 1px solid var(--vico-border);
    background: var(--vico-bg-base);
}

.ecm-bottom-tools .ecm-templates-section,
.ecm-bottom-tools .ecm-import-section {
    border-bottom: none;
}

.ecm-bottom-tools .ecm-templates-grid {
    grid-template-columns: repeat(4, 1fr);
}

.ecm-bottom-tools .ecm-template-btn span {
    font-size: 0.65rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   EDITOR PANEL - Slide-in from Right
   ═══════════════════════════════════════════════════════════════════════════ */

.ecm-editor-panel {
    position: absolute;
    top: 0;
    right: 0;
    width: 360px;
    height: 100%;
    background: var(--vico-bg-base);
    border-left: 1px solid var(--vico-border);
    box-shadow: -8px 0 24px rgba(0, 0, 0, 0.25);
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 10;
    overflow-y: auto;
    overflow-x: hidden;
}

.ecm-editor-panel.active {
    transform: translateX(0);
}

.ecm-editor-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: var(--vico-space-lg);
    background: var(--vico-gradient-header);
    border-bottom: 1px solid var(--vico-border);
    flex-shrink: 0;
}

.ecm-editor-header .ecm-action-info {
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-xs);
}

.ecm-editor-panel h3 {
    margin: 0;
    color: var(--vico-text-primary);
    font-size: 1rem;
    font-weight: 600;
}

.ecm-editor-panel .ecm-action-description {
    margin: 0;
    padding: 0 var(--vico-space-lg);
    color: var(--vico-text-secondary);
    font-size: 0.85rem;
    line-height: 1.5;
    padding-top: var(--vico-space-sm);
}

.ecm-editor-panel .ecm-params-form {
    flex: 1;
    padding: var(--vico-space-lg);
    overflow-y: auto;
}

.ecm-editor-panel .ecm-contextual-tools {
    margin: 0 var(--vico-space-lg);
    padding: var(--vico-space-sm) 0;
}

.ecm-editor-panel .ecm-action-buttons {
    padding: var(--vico-space-lg);
    background: var(--vico-bg-raised);
    border-top: 1px solid var(--vico-border);
    flex-shrink: 0;
    gap: var(--vico-space-sm);
}

.ecm-editor-panel .ecm-btn {
    flex: 1;
}

/* ═══════════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════════ */

#event-chain-modal .popup-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--vico-space-md) var(--vico-space-lg);
    background: var(--vico-bg-base);
    border-top: 1px solid var(--vico-border);
    flex-shrink: 0;
}

.ecm-footer-left {
    display: flex;
    gap: var(--vico-space-lg);
}

.ecm-footer-right {
    display: flex;
    gap: var(--vico-space-md);
}

.ecm-kbd-hint {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--vico-text-muted);
    font-size: 0.8rem;
}

.ecm-kbd-hint kbd {
    padding: 3px 7px;
    background: var(--vico-bg-elevated);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-sm);
    font-size: 0.75rem;
    font-family: 'SF Mono', 'Fira Code', monospace;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════════════════ */

.ecm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 10px 18px;
    border: none;
    border-radius: var(--vico-radius-md);
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.1s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.ecm-btn:active {
    transform: scale(0.97);
}

.ecm-btn i {
    font-size: 0.85rem;
}

.ecm-btn-sm {
    padding: 8px 14px;
    font-size: 0.85rem;
}

.ecm-btn-primary {
    background: var(--vico-gradient-blue);
    color: #fff;
    box-shadow: 0 3px 10px var(--vico-glow-blue);
}

.ecm-btn-primary:hover {
    box-shadow: 0 5px 16px rgba(97, 175, 239, 0.5);
    transform: translateY(-1px);
}

.ecm-btn-success {
    background: var(--vico-gradient-green);
    color: var(--vico-bg-base);
    box-shadow: 0 3px 10px var(--vico-glow-green);
}

.ecm-btn-success:hover {
    box-shadow: 0 5px 16px rgba(152, 195, 121, 0.5);
    transform: translateY(-1px);
}

.ecm-btn-warning {
    background: var(--vico-gradient-amber);
    color: var(--vico-bg-base);
    box-shadow: 0 3px 10px var(--vico-glow-amber);
}

.ecm-btn-warning:hover {
    box-shadow: 0 5px 16px rgba(229, 192, 123, 0.5);
    transform: translateY(-1px);
}

.ecm-btn-ghost {
    background: var(--vico-bg-raised);
    color: var(--vico-text-secondary);
    border: 2px solid var(--vico-border);
}

.ecm-btn-ghost:hover {
    background: var(--vico-bg-elevated);
    color: var(--vico-text-primary);
    border-color: var(--vico-border-hover);
}

/* ═══════════════════════════════════════════════════════════════════════════
   SCROLLBARS
   ═══════════════════════════════════════════════════════════════════════════ */

.ecm-editor-panel::-webkit-scrollbar,
.ecm-chain-list::-webkit-scrollbar,
.ecm-palette-results::-webkit-scrollbar,
.ecm-autocomplete-dropdown::-webkit-scrollbar {
    width: var(--vico-scrollbar-width);
}

.ecm-editor-panel::-webkit-scrollbar-track,
.ecm-chain-list::-webkit-scrollbar-track,
.ecm-palette-results::-webkit-scrollbar-track,
.ecm-autocomplete-dropdown::-webkit-scrollbar-track {
    background: transparent;
}

.ecm-editor-panel::-webkit-scrollbar-thumb,
.ecm-chain-list::-webkit-scrollbar-thumb,
.ecm-palette-results::-webkit-scrollbar-thumb,
.ecm-autocomplete-dropdown::-webkit-scrollbar-thumb {
    background: var(--vico-scrollbar-thumb);
    border-radius: 3px;
}

.ecm-editor-panel::-webkit-scrollbar-thumb:hover,
.ecm-chain-list::-webkit-scrollbar-thumb:hover,
.ecm-palette-results::-webkit-scrollbar-thumb:hover,
.ecm-autocomplete-dropdown::-webkit-scrollbar-thumb:hover {
    background: var(--vico-scrollbar-thumb-hover);
}

/* ═══════════════════════════════════════════════════════════════════════════
   ANCHORED RIGHT MODE - Compact layout for side panel usage
   ═══════════════════════════════════════════════════════════════════════════ */

#event-chain-modal.anchored-right {
    justify-content: flex-end;
    align-items: stretch;
    pointer-events: none;
}

#event-chain-modal.anchored-right .ecm-popup-content {
    position: absolute;
    /* Position to match parent side panel - starts at top of side panel */
    top: 10%; /* Match side panel top position */
    right: 0;
    height: 90%; /* Match side panel height */
    max-height: none;
    /* Width is set dynamically by JS to match parent panel */
    /* Fallback width if no parent panel detected */
    width: var(--ecm-panel-width, 35%);
    max-width: var(--ecm-panel-width, 70%);
    min-width: 320px;
    border-radius: var(--vico-radius-lg) 0 0 var(--vico-radius-lg);
    box-shadow: -4px 0 20px rgba(0, 0, 0, 0.4);
    pointer-events: auto;
    /* Ensure it's above the parent panel */
    z-index: 1;
}

/* Full-width chain panel in anchored mode */
#event-chain-modal.anchored-right .ecm-main-layout {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

/* Chain list - scrollable, takes most space */
#event-chain-modal.anchored-right .ecm-chain-panel {
    flex: 1;
    min-height: 150px;
    overflow: hidden;
}

/* Editor panel in anchored mode - full width overlay */
#event-chain-modal.anchored-right .ecm-editor-panel {
    position: fixed;
    top: 10%;
    right: 0;
    width: var(--ecm-panel-width, 35%);
    max-width: var(--ecm-panel-width, 70%);
    min-width: 320px;
    height: 90%;
    border-radius: var(--vico-radius-lg) 0 0 var(--vico-radius-lg);
    box-shadow: -8px 0 24px rgba(0, 0, 0, 0.4);
    z-index: 100;
}

/* Compact spacing in anchored mode */
#event-chain-modal.anchored-right .ecm-palette-search-wrapper {
    padding: var(--vico-space-sm) var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-palette-search {
    padding: 8px 10px 8px 32px;
    font-size: 0.85rem;
}

#event-chain-modal.anchored-right .ecm-palette-search-icon {
    left: 20px;
    font-size: 0.8rem;
}

#event-chain-modal.anchored-right .ecm-palette-kbd {
    display: none;
}

#event-chain-modal.anchored-right .ecm-palette-results {
    max-height: 160px;
    border-bottom: 1px solid var(--vico-border);
}

#event-chain-modal.anchored-right .ecm-palette-categories {
    padding: var(--vico-space-xs) var(--vico-space-sm);
}

#event-chain-modal.anchored-right .ecm-palette-category {
    margin-bottom: var(--vico-space-xs);
}

#event-chain-modal.anchored-right .ecm-palette-category-header {
    padding: 4px var(--vico-space-xs);
    font-size: 0.65rem;
}

#event-chain-modal.anchored-right .ecm-palette-item {
    padding: 6px 10px;
}

#event-chain-modal.anchored-right .ecm-palette-item-title {
    font-size: 0.8rem;
}

#event-chain-modal.anchored-right .ecm-palette-item-name {
    font-size: 0.7rem;
}

/* Editor panel compact styling in anchored mode */
#event-chain-modal.anchored-right .ecm-editor-header {
    padding: var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-action-category-badge {
    padding: 2px 6px;
    font-size: 0.6rem;
}

#event-chain-modal.anchored-right .ecm-editor-panel h3 {
    font-size: 0.9rem;
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-action-description {
    font-size: 0.75rem;
    line-height: 1.4;
    padding: var(--vico-space-xs) var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-params-form {
    gap: var(--vico-space-sm);
    padding: var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-param-input {
    padding: 8px 10px;
    font-size: 0.85rem;
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-param-label {
    font-size: 0.75rem;
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-action-buttons {
    gap: var(--vico-space-sm);
    padding: var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-btn {
    padding: 8px 12px;
    font-size: 0.8rem;
}

#event-chain-modal.anchored-right .ecm-editor-panel .ecm-no-params {
    padding: var(--vico-space-sm);
    font-size: 0.8rem;
}

#event-chain-modal.anchored-right .ecm-bottom-tools,
#event-chain-modal.anchored-right .ecm-templates-section,
#event-chain-modal.anchored-right .ecm-import-section {
    display: none; /* Hide in compact mode */
}

/* Compact chain header */
#event-chain-modal.anchored-right .ecm-chain-header {
    padding: 8px var(--vico-space-md);
    background: var(--vico-bg-raised);
}

#event-chain-modal.anchored-right .ecm-chain-header h3 {
    font-size: 0.85rem;
}

#event-chain-modal.anchored-right .ecm-chain-count {
    font-size: 0.7rem;
    padding: 2px 6px;
}

#event-chain-modal.anchored-right .ecm-chain-duration {
    font-size: 0.7rem;
    padding: 2px 6px;
}

/* Compact chain list */
#event-chain-modal.anchored-right .ecm-chain-list {
    padding: var(--vico-space-sm);
    flex: 1;
    overflow-y: auto;
}

/* Compact empty state */
#event-chain-modal.anchored-right .ecm-chain-empty {
    padding: var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-chain-empty i {
    font-size: 2rem;
    margin-bottom: var(--vico-space-sm);
}

#event-chain-modal.anchored-right .ecm-chain-empty p {
    font-size: 0.85rem;
    margin-bottom: 4px;
}

#event-chain-modal.anchored-right .ecm-chain-empty span {
    font-size: 0.75rem;
}

#event-chain-modal.anchored-right .ecm-chain-item {
    padding: var(--vico-space-sm);
    gap: var(--vico-space-sm);
    margin-bottom: 6px;
}

#event-chain-modal.anchored-right .ecm-chain-drag-handle {
    width: 20px;
    height: 32px;
    margin: -2px 0;
}

#event-chain-modal.anchored-right .ecm-chain-drag-handle i {
    font-size: 0.85rem;
}

#event-chain-modal.anchored-right .ecm-chain-item-index {
    width: 22px;
    height: 22px;
    font-size: 0.7rem;
}

#event-chain-modal.anchored-right .ecm-chain-item-title {
    font-size: 0.8rem;
}

#event-chain-modal.anchored-right .ecm-chain-item-action {
    font-size: 0.65rem;
    padding: 1px 4px;
}

#event-chain-modal.anchored-right .ecm-chain-item-params {
    gap: 4px;
}

#event-chain-modal.anchored-right .ecm-chain-param {
    padding: 2px 5px;
    font-size: 0.65rem;
}

#event-chain-modal.anchored-right .ecm-chain-btn {
    width: 24px;
    height: 24px;
    font-size: 0.7rem;
}

/* Compact footer */
#event-chain-modal.anchored-right .popup-footer {
    padding: var(--vico-space-sm) var(--vico-space-md);
}

#event-chain-modal.anchored-right .ecm-footer-left {
    display: none;
}

#event-chain-modal.anchored-right .ecm-footer-right {
    width: 100%;
    justify-content: flex-end;
}

#event-chain-modal.anchored-right .ecm-footer-right .ecm-btn {
    flex: 1;
    max-width: 140px;
}

/* Compact header */
#event-chain-modal.anchored-right .popup-header {
    padding: var(--vico-space-sm) var(--vico-space-md);
}

#event-chain-modal.anchored-right .popup-header h2 {
    font-size: 0.9rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
    .ecm-main-layout {
        grid-template-columns: 1fr;
        grid-template-rows: 1fr 1fr;
    }
    
    .ecm-builder-panel {
        border-right: none;
        border-bottom: 1px solid var(--vico-border);
    }
}

@media (max-width: 600px) {
    #event-chain-modal .ecm-popup-content {
        width: 100%;
        max-width: 100%;
        height: 100%;
        max-height: 100%;
        border-radius: 0;
    }
    
    .ecm-footer-left {
        display: none;
    }
    
    .ecm-templates-grid {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 768px) {
    #event-chain-modal.anchored-right .ecm-popup-content {
        /* On mobile, take full width when no parent panel */
        width: var(--ecm-panel-width, 100%) !important;
        max-width: var(--ecm-panel-width, 100%) !important;
        top: 0;
        height: 100%;
        border-radius: 0;
    }
    
    #event-chain-modal.anchored-right .ecm-chain-panel {
        max-height: 40vh;
    }
}



/* 
  DraggableListManager.css
  Styles for the generic draggable list manager.
*/

/* Applied to the item being dragged */
.dragging {
  opacity: 0.5;
  background: var(--vico-glow-blue);
}

/* Style for the drop indicator when dropping ABOVE the target item */
.drop-indicator-above {
  border-top: 2px solid var(--vico-accent-blue);
  box-shadow: 0 -4px 5px -3px var(--vico-glow-blue);
  transition: border-top 0.1s ease-in-out, box-shadow 0.1s ease-in-out;
}

/* Style for the drop indicator when dropping BELOW the target item */
.drop-indicator-below {
  border-bottom: 2px solid var(--vico-accent-blue);
  box-shadow: 0 4px 5px -3px var(--vico-glow-blue);
  transition: border-bottom 0.1s ease-in-out, box-shadow 0.1s ease-in-out;
}

.objective-hud {
    position: fixed;
    top: 84px;
    right: 24px;
    left: auto;
    width: clamp(300px, 30vw, 420px);
    background: var(--vico-bg-base);
    border: 1px solid var(--vico-border);
    border-radius: var(--vico-radius-xl);
    font-family: var(--primary-font);
    z-index: 1200;
    pointer-events: auto;
    box-shadow: var(--vico-shadow-lg);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.objective-hud.minimized .objective-hud-list {
    max-height: 0;
    padding: 0;
    overflow: hidden;
}

.objective-hud.minimized .objective-hud-toggle { transform: rotate(-90deg); }

.objective-hud.hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateY(-8px);
}

.objective-hud-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--vico-border);
    background: var(--vico-gradient-header);
    cursor: default;
    border-radius: var(--vico-radius-xl) var(--vico-radius-xl) 0 0;
}

.objective-hud-icon {
    color: var(--vico-accent-cyan);
    font-size: 14px;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--vico-radius-lg);
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.2), rgba(255,255,255,0.05));
    border: 1px solid var(--vico-border);
}
.objective-hud-title {
    flex: 1;
    font-size: 12px;
    color: var(--vico-text-primary);
    text-transform: uppercase;
    letter-spacing: 0.6px;
}
.objective-hud-toggle {
    background: var(--vico-bg-hover);
    border: 1px solid var(--vico-border);
    color: var(--vico-text-secondary);
    cursor: pointer;
    padding: 6px;
    width: 30px;
    height: 30px;
    border-radius: var(--vico-radius-lg);
    font-size: 11px;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
.objective-hud-toggle:hover {
    color: var(--vico-accent-cyan);
    background: var(--vico-bg-elevated);
    border-color: var(--vico-border-hover);
}

.objective-hud-list {
    padding: 14px 10px 10px;
    max-height: 480px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.objective-hud-list:empty::before {
    content: 'No objectives';
    display: block;
    text-align: center;
    color: var(--vico-text-muted);
    font-size: 11px;
    padding: 12px;
}

.objective-item {
    position: relative;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 10px;
    padding: 10px;
    background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02));
    border-radius: var(--vico-radius-lg);
    border: 1px solid var(--vico-border);
    box-shadow: var(--vico-shadow-md);
    animation: obj-in 0.2s ease-out;
}
@keyframes obj-in { from { opacity: 0; transform: translateX(-10px); } }
.objective-item:last-child { margin-bottom: 0; }
.objective-item.objective-main { border-left: 2px solid var(--vico-accent-amber); }
.objective-item.objective-side { border-left: 2px solid var(--vico-accent-cyan); }
.objective-item.objective-bonus { border-left: 2px solid var(--vico-accent-purple); }
.objective-item.objective-completed { border-left: 2px solid var(--vico-accent-green); animation: obj-done 0.4s forwards; }
.objective-item.objective-failed { border-left: 2px solid var(--vico-accent-red); animation: obj-fail 0.4s forwards; }
@keyframes obj-done { to { opacity: 0; transform: translateX(20px); } }
@keyframes obj-fail { 25%,75% { transform: translateX(-2px); } 50% { transform: translateX(2px); } to { opacity: 0; } }

.objective-icon {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vico-bg-hover);
    border-radius: var(--vico-radius-lg);
    font-size: 13px;
    flex-shrink: 0;
    border: 1px solid var(--vico-border);
    color: var(--vico-text-primary);
}
.objective-content { flex: 1; min-width: 0; }
.objective-title {
    font-size: 13px;
    color: var(--vico-text-primary);
    margin-bottom: 4px;
    line-height: 1.3;
    font-weight: 600;
}
.objective-desc {
    font-size: 12px;
    color: var(--vico-text-secondary);
    line-height: 1.35;
}
.objective-progress {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    color: var(--vico-text-secondary);
}
.objective-progress-bar {
    flex: 1;
    height: 6px;
    background: var(--vico-bg-hover);
    border-radius: var(--vico-radius-md);
    overflow: hidden;
    border: 1px solid var(--vico-border);
}
.objective-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--vico-accent-cyan), var(--vico-accent-purple));
    transition: width 0.2s;
}
.objective-progress-text { font-variant-numeric: tabular-nums; min-width: 28px; text-align: right; }
.objective-progress-text { color: var(--vico-text-secondary); }
.objective-timer { font-size: 11px; color: var(--vico-accent-amber); margin-top: 4px; }
.objective-timer.urgent { color: var(--vico-accent-red); animation: pulse 0.5s infinite; }
@keyframes pulse { 50% { opacity: 0.5; } }
.objective-new-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    font-size: 9px;
    background: var(--vico-accent-amber);
    color: var(--vico-bg-deep);
    padding: 2px 6px;
    border-radius: 10px;
    font-weight: 700;
    letter-spacing: 0.3px;
}
.objective-hud-list::-webkit-scrollbar { width: var(--vico-scrollbar-width); }
.objective-hud-list::-webkit-scrollbar-track { background: transparent; }
.objective-hud-list::-webkit-scrollbar-thumb { background: var(--vico-scrollbar-thumb); border-radius: 3px; }
.objective-hud-list::-webkit-scrollbar-thumb:hover { background: var(--vico-scrollbar-thumb-hover); }

/* playerListUI.css - Player list component using Vico design tokens */

.player-notification-container {
    position: absolute;
    top: 60px;
    left: 10px;
    height: 30px;
    width: 100%;
    background-color: transparent;
    overflow: hidden;
    transition: height 0.3s ease;
    z-index: 10;
    pointer-events: none;
}

.toggle-button {
    position: fixed;
    margin-top: 10px;
    left: 10px;
    width: 170px;
    height: 20px;
    z-index: 1000;
    border: none;
    background-color: transparent;
    color: var(--vico-text-primary);
    font-family: var(--primary-font);
    font-size: 0.85rem;
    transition: color var(--vico-transition-fast);
    text-align: left;
    cursor: pointer;
    pointer-events: auto;
}

.toggle-button:hover {
    color: var(--vico-accent-blue);
}

.notification {
    position: absolute;
    padding: 5px 10px;
    width: 150px;
}

.notification-flex-container {
    display: flex;
    align-items: center;
    gap: var(--vico-space-sm);
}

.notification-text {
    font-family: var(--primary-font);
    width: 100px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    color: var(--vico-text-primary);
}

.player-notification-container > * {
    pointer-events: auto;
}

.mute-button {
    padding: var(--vico-space-xs) var(--vico-space-sm);
    border-radius: var(--vico-radius-sm);
    border: 1px solid var(--vico-border);
    background: transparent;
    color: var(--vico-text-secondary);
    cursor: pointer;
    transition: background-color var(--vico-transition-fast), border-color var(--vico-transition-fast);
    pointer-events: auto;
}

.mute-button:hover {
    background-color: var(--vico-bg-raised);
    border-color: var(--vico-border-hover);
}

.mute-button.muted {
    background-color: rgba(224, 108, 117, 0.1);
    border-color: rgba(224, 108, 117, 0.3);
    color: var(--vico-accent-red);
}

.player-roster-list {
    margin: 40px 10px 10px;
    display: flex;
    flex-direction: column;
    gap: var(--vico-space-sm);
    pointer-events: auto;
}

.roster-entry {
    display: flex;
    justify-content: space-between;
    gap: var(--vico-space-md);
    font-family: var(--primary-font);
    font-size: 14px;
    padding: var(--vico-space-sm) var(--vico-space-md);
    background: var(--vico-bg-raised);
    border-radius: var(--vico-radius-sm);
    border: 1px solid var(--vico-border);
}

.roster-name {
    font-weight: 600;
    color: var(--vico-text-primary);
}

.roster-scene {
    opacity: 0.7;
    color: var(--vico-text-secondary);
}

.roster-empty {
    font-style: italic;
    opacity: 0.6;
    color: var(--vico-text-muted);
}


/* FRONTEND/src/css/pdfUIManager.css */

#cpm-media-container .pdf-controls {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  width: auto;
  flex-shrink: 0;
  padding: 8px;
  min-height: 10%;
  box-sizing: border-box;
  background-color: var(--vico-bg-elevated); 
  border-bottom: 1px solid var(--vico-border);
  text-align: center;
  color: var(--vico-text-primary); 
  z-index: 20;
}

.pdf-nav-button {
  padding: 5px 12px;
  margin: 0 5px;
  background-color: var(--vico-accent-blue);
  color: var(--vico-text-primary);
  border: none;
  border-radius: var(--vico-radius-sm);
  cursor: pointer;
  transition: background-color var(--vico-transition-fast);
}

.pdf-nav-button:hover {
  background-color: var(--vico-accent-blue-light);
}

.pdf-nav-button:disabled {
  background-color: var(--vico-bg-hover);
  color: var(--vico-text-muted);
  cursor: not-allowed;
}

.pdf-nav-button svg {
  width: 10px;
  height: 10px;
  vertical-align: middle;
}

#cpm-media-container .pdf-canvas {
  margin: auto; 
}

#cpm-media-container .pdf-loading-container {
  display: block;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 15px 20px;
  background-color: var(--vico-bg-deep);
  color: var(--vico-text-primary);
  border-radius: var(--vico-radius-md);
  z-index: 3000;
  width: 80%;
  max-width: 300px;
  text-align: center;
}

.pdf-progress-bar {
  width: 100%;
  height: 10px;
  background-color: var(--vico-bg-hover);
  border-radius: var(--vico-radius-md);
  overflow: hidden; 
  margin-bottom: 8px;
}

.pdf-progress-bar-fill {
  width: 0%; 
  height: 100%;
  background-color: var(--vico-accent-green); 
  border-radius: var(--vico-radius-md);
  transition: width 0.1s linear;
}

.pdf-loading-text {
  font-size: 0.9em;
}

.pdf-error-indicator {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 15px 20px;
  background-color: rgba(224, 108, 117, 0.85);
  color: var(--vico-text-primary);
  border-radius: var(--vico-radius-md);
  z-index: 999;
  font-size: 1.1em;
  text-align: center;
}

.cpm-pdf-viewer-container:fullscreen {
  background: var(--vico-bg-deep);
  z-index: 9999;
}

