/* ==========================================================================
   VepDec Security Platform — Pure CSS Theme System
   No Tailwind, No Frameworks — Production-ready for cPanel/Apache
   Two toggleable themes:
     1. Executive (Admin Default)  — Premium, corporate, gold-accented
     2. Cyber Neon (User Default)  — Cutting-edge, dark, cyan-accented
   ========================================================================== */

/* ---------- Google Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap');

/* ==========================================================================
   THEME 1: EXECUTIVE — Dark Mode (Default for Admin)
   ========================================================================== */
[data-theme="executive"] {
  --background: #0c0f1a;
  --foreground: #f0e6d3;
  --card: #141827;
  --card-foreground: #f0e6d3;
  --card-border: #1e2340;
  --popover: #141827;
  --popover-foreground: #f0e6d3;
  --primary: #d4a853;
  --primary-foreground: #0c0f1a;
  --secondary: #f59e0b;
  --secondary-foreground: #0c0f1a;
  --muted: #1a1e30;
  --muted-foreground: #8b8a97;
  --accent: #d4a853;
  --accent-foreground: #0c0f1a;
  --destructive: #ef4444;
  --border: rgba(212, 168, 83, 0.15);
  --input: rgba(212, 168, 83, 0.15);
  --ring: #d4a853;
  --sidebar: #0a0d17;
  --sidebar-foreground: #f0e6d3;
  --sidebar-primary: #d4a853;
  --sidebar-primary-foreground: #0c0f1a;
  --sidebar-accent: #1a1e30;
  --sidebar-accent-foreground: #d4a853;
  --sidebar-border: #1e2340;
  --sidebar-ring: #d4a853;
  --color-success: #22c55e;
  --color-danger: #ef4444;
  --color-warning: #f59e0b;
  --color-info: #3b82f6;
  --accent-primary: #d4a853;
  --accent-secondary: #f59e0b;
  --glow: rgba(212, 168, 83, 0.3);
  --glow-strong: rgba(212, 168, 83, 0.5);
  --btn-gradient-from: #d4a853;
  --btn-gradient-to: #b8941f;
  --card-hover-glow: rgba(212, 168, 83, 0.2);
  --card-shadow: 0 4px 24px rgba(0,0,0,0.3), 0 0 0 1px rgba(212,168,83,0.08);
  --card-hover-shadow: 0 8px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(212,168,83,0.25), 0 0 20px rgba(212,168,83,0.08);
  --chart-1: #d4a853; --chart-2: #f59e0b; --chart-3: #22c55e; --chart-4: #ef4444; --chart-5: #3b82f6;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-heading: 'Inter', system-ui, sans-serif;
  --heading-weight: 700;
  --radius: 0.625rem;
  --transition-fast: 150ms cubic-bezier(0.4,0,0.2,1);
  --transition-base: 300ms cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 500ms cubic-bezier(0.4,0,0.2,1);
  --overlay: rgba(0,0,0,0.6);
  --selection-bg: rgba(212,168,83,0.3);
  --selection-fg: #f0e6d3;
  --scrollbar-thumb: rgba(212,168,83,0.3);
  --scrollbar-thumb-hover: rgba(212,168,83,0.5);
  --scrollbar-track: transparent;
  --skeleton-from: #1a1e30; --skeleton-via: #1e2340; --skeleton-to: #1a1e30;
  --noise-opacity: 0;
}

/* ==========================================================================
   THEME 1: EXECUTIVE — Light Mode
   ========================================================================== */
[data-theme="executive"][data-mode="light"] {
  --background: #f8f6f1;
  --foreground: #1a1d2e;
  --card: #ffffff;
  --card-foreground: #1a1d2e;
  --card-border: #e8e0d0;
  --popover: #ffffff;
  --popover-foreground: #1a1d2e;
  --primary: #b8941f;
  --primary-foreground: #ffffff;
  --secondary: #d4a853;
  --secondary-foreground: #1a1d2e;
  --muted: #f0ece3;
  --muted-foreground: #6b7280;
  --accent: #b8941f;
  --accent-foreground: #ffffff;
  --destructive: #dc2626;
  --border: #e8e0d0;
  --input: #e8e0d0;
  --ring: #b8941f;
  --sidebar: #1a1d2e;
  --sidebar-foreground: #f0e6d3;
  --sidebar-primary: #d4a853;
  --sidebar-primary-foreground: #0c0f1a;
  --sidebar-accent: #242840;
  --sidebar-accent-foreground: #d4a853;
  --sidebar-border: #2e3350;
  --sidebar-ring: #d4a853;
  --color-success: #16a34a; --color-danger: #dc2626; --color-warning: #d97706; --color-info: #2563eb;
  --accent-primary: #b8941f;
  --accent-secondary: #d4a853;
  --glow: rgba(184,148,31,0.2);
  --glow-strong: rgba(184,148,31,0.35);
  --btn-gradient-from: #d4a853;
  --btn-gradient-to: #b8941f;
  --card-hover-glow: rgba(184,148,31,0.15);
  --card-shadow: 0 4px 24px rgba(0,0,0,0.08), 0 0 0 1px rgba(184,148,31,0.1);
  --card-hover-shadow: 0 8px 40px rgba(0,0,0,0.12), 0 0 0 1px rgba(184,148,31,0.3), 0 0 20px rgba(184,148,31,0.06);
  --heading-weight: 700;
  --overlay: rgba(0,0,0,0.4);
  --selection-bg: rgba(184,148,31,0.25);
  --selection-fg: #1a1d2e;
  --scrollbar-thumb: rgba(184,148,31,0.3);
  --scrollbar-thumb-hover: rgba(184,148,31,0.5);
  --scrollbar-track: rgba(0,0,0,0.03);
  --skeleton-from: #e8e0d0; --skeleton-via: #f0ece3; --skeleton-to: #e8e0d0;
  --noise-opacity: 0;
}

/* ==========================================================================
   THEME 2: CYBER NEON — Dark Mode (Default for Users)
   ========================================================================== */
[data-theme="cyber-neon"] {
  --background: #06080d;
  --foreground: #e0f0ff;
  --card: #0d1117;
  --card-foreground: #e0f0ff;
  --card-border: rgba(0,200,255,0.1);
  --popover: #0d1117;
  --popover-foreground: #e0f0ff;
  --primary: #00c8ff;
  --primary-foreground: #06080d;
  --secondary: #0080ff;
  --secondary-foreground: #e0f0ff;
  --muted: #0d1117;
  --muted-foreground: #6b7fa3;
  --accent: #00c8ff;
  --accent-foreground: #06080d;
  --destructive: #ff3366;
  --border: rgba(0,200,255,0.1);
  --input: rgba(0,200,255,0.1);
  --ring: #00c8ff;
  --sidebar: #080b12;
  --sidebar-foreground: #e0f0ff;
  --sidebar-primary: #00c8ff;
  --sidebar-primary-foreground: #06080d;
  --sidebar-accent: #0d1520;
  --sidebar-accent-foreground: #00c8ff;
  --sidebar-border: rgba(0,200,255,0.08);
  --sidebar-ring: #00c8ff;
  --color-success: #00ff88;
  --color-danger: #ff3366;
  --color-warning: #ffaa00;
  --color-info: #00c8ff;
  --accent-primary: #00c8ff;
  --accent-secondary: #0080ff;
  --neon-glow: #00f0ff;
  --glow: rgba(0,200,255,0.4);
  --glow-strong: rgba(0,200,255,0.6);
  --btn-gradient-from: #00c8ff;
  --btn-gradient-to: #0080ff;
  --card-hover-glow: rgba(0,200,255,0.15);
  --card-shadow: 0 4px 24px rgba(0,0,0,0.4), 0 0 0 1px rgba(0,200,255,0.08);
  --card-hover-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(0,200,255,0.3), 0 0 30px rgba(0,200,255,0.1);
  --chart-1: #00c8ff; --chart-2: #0080ff; --chart-3: #00ff88; --chart-4: #ff3366; --chart-5: #ffaa00;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-heading: 'Space Grotesk', system-ui, sans-serif;
  --heading-weight: 600;
  --radius: 0.75rem;
  --transition-fast: 150ms cubic-bezier(0.4,0,0.2,1);
  --transition-base: 300ms cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 500ms cubic-bezier(0.4,0,0.2,1);
  --overlay: rgba(0,0,0,0.7);
  --selection-bg: rgba(0,200,255,0.3);
  --selection-fg: #e0f0ff;
  --scrollbar-thumb: rgba(0,200,255,0.25);
  --scrollbar-thumb-hover: rgba(0,200,255,0.45);
  --scrollbar-track: transparent;
  --skeleton-from: #0d1520; --skeleton-via: #111828; --skeleton-to: #0d1520;
  --noise-opacity: 0.035;
}

/* ==========================================================================
   THEME 2: CYBER NEON — Light Mode
   ========================================================================== */
[data-theme="cyber-neon"][data-mode="light"] {
  --background: #f0f4f8;
  --foreground: #0a1628;
  --card: #ffffff;
  --card-foreground: #0a1628;
  --card-border: #d0e0f0;
  --popover: #ffffff;
  --popover-foreground: #0a1628;
  --primary: #0088cc;
  --primary-foreground: #ffffff;
  --secondary: #0066aa;
  --secondary-foreground: #ffffff;
  --muted: #e4eaf0;
  --muted-foreground: #6b7fa3;
  --accent: #0088cc;
  --accent-foreground: #ffffff;
  --destructive: #e11d48;
  --border: #d0e0f0;
  --input: #d0e0f0;
  --ring: #0088cc;
  --sidebar: #0a0e18;
  --sidebar-foreground: #e0f0ff;
  --sidebar-primary: #00c8ff;
  --sidebar-primary-foreground: #06080d;
  --sidebar-accent: #0f1525;
  --sidebar-accent-foreground: #00c8ff;
  --sidebar-border: rgba(0,200,255,0.1);
  --sidebar-ring: #00c8ff;
  --color-success: #059669; --color-danger: #e11d48; --color-warning: #d97706; --color-info: #0088cc;
  --accent-primary: #0088cc;
  --accent-secondary: #0066aa;
  --neon-glow: #00c8ff;
  --glow: rgba(0,136,204,0.2);
  --glow-strong: rgba(0,136,204,0.35);
  --btn-gradient-from: #00c8ff;
  --btn-gradient-to: #0080ff;
  --card-hover-glow: rgba(0,136,204,0.12);
  --card-shadow: 0 4px 24px rgba(0,0,0,0.06), 0 0 0 1px rgba(0,136,204,0.1);
  --card-hover-shadow: 0 8px 40px rgba(0,0,0,0.1), 0 0 0 1px rgba(0,136,204,0.25), 0 0 20px rgba(0,136,204,0.06);
  --heading-weight: 600;
  --overlay: rgba(0,0,0,0.4);
  --selection-bg: rgba(0,136,204,0.25);
  --selection-fg: #0a1628;
  --scrollbar-thumb: rgba(0,136,204,0.25);
  --scrollbar-thumb-hover: rgba(0,136,204,0.45);
  --scrollbar-track: rgba(0,0,0,0.03);
  --skeleton-from: #d0e0f0; --skeleton-via: #e4eaf0; --skeleton-to: #d0e0f0;
  --noise-opacity: 0;
}

/* ==========================================================================
   BASE STYLES
   ========================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
* { transition-property: background-color, color, border-color, box-shadow, fill, stroke; transition-duration: 0.3s; transition-timing-function: cubic-bezier(0.4,0,0.2,1); }
input, textarea, select, video, canvas, img, svg, [data-no-transition] { transition: none !important; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; scroll-behavior: smooth; }
body { font-family: var(--font-body); background-color: var(--background); color: var(--foreground); min-height: 100vh; line-height: 1.6; overflow-x: hidden; }
h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); font-weight: var(--heading-weight); line-height: 1.2; color: var(--foreground); }
a { color: var(--accent-primary); text-decoration: none; }
a:hover { color: var(--accent-secondary, var(--accent-primary)); }
::selection { background-color: var(--selection-bg); color: var(--selection-fg); }
::-moz-selection { background-color: var(--selection-bg); color: var(--selection-fg); }
:focus-visible { outline: 2px solid var(--ring); outline-offset: 2px; border-radius: 4px; }
:focus:not(:focus-visible) { outline: none; }
img { max-width: 100%; display: block; }

/* ==========================================================================
   SMOKY TEXTURE OVERLAY — Cyber Neon Dark Only
   ========================================================================== */
[data-theme="cyber-neon"][data-mode="dark"]::before {
  content: ''; position: fixed; inset: 0; z-index: 9999; pointer-events: none;
  opacity: var(--noise-opacity);
  background-image: repeating-conic-gradient(rgba(0,200,255,0.02) 0% 25%, transparent 0% 50%);
  background-size: 4px 4px; animation: smoke 20s ease-in-out infinite; mix-blend-mode: overlay;
}

/* ==========================================================================
   SCROLLBAR
   ========================================================================== */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--scrollbar-track); border-radius: 3px; }
::-webkit-scrollbar-thumb { background: var(--scrollbar-thumb); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--scrollbar-thumb-hover); }
::-webkit-scrollbar-corner { background: transparent; }
* { scrollbar-width: thin; scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track); }

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */
@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }
@keyframes pulse-glow { 0%, 100% { box-shadow: 0 0 5px var(--glow), 0 0 10px transparent; opacity: 1; } 50% { box-shadow: 0 0 10px var(--glow), 0 0 25px var(--glow); opacity: 0.9; } }
@keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
@keyframes slideInLeft { from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: translateX(0); } }
@keyframes scaleIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
@keyframes progress { from { width: 0%; } to { width: 100%; } }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes gradientShift { 0%, 100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
@keyframes smoke { 0%, 100% { transform: translate(0,0) scale(1); opacity: var(--noise-opacity); } 25% { transform: translate(10px,-5px) scale(1.02); opacity: calc(var(--noise-opacity) * 1.3); } 50% { transform: translate(-5px,10px) scale(0.98); opacity: calc(var(--noise-opacity) * 0.8); } 75% { transform: translate(-10px,-10px) scale(1.01); opacity: calc(var(--noise-opacity) * 1.1); } }
@keyframes borderGlow { 0%, 100% { border-color: var(--card-border); box-shadow: 0 0 0 1px var(--card-border); } 50% { border-color: var(--accent-primary); box-shadow: 0 0 12px var(--glow), 0 0 0 1px var(--accent-primary); } }
@keyframes livePulse { 0%, 100% { box-shadow: 0 0 4px var(--color-success); transform: scale(1); } 50% { box-shadow: 0 0 12px var(--color-success), 0 0 20px var(--color-success); transform: scale(1.15); } }
@keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(0.8,0,1,1); } 50% { transform: none; animation-timing-function: cubic-bezier(0,0,0.2,1); } }

/* ==========================================================================
   UTILITY CLASSES
   ========================================================================== */
.glass-card { background: var(--card); border: 1px solid var(--card-border); border-radius: var(--radius); box-shadow: var(--card-shadow); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); transition: box-shadow var(--transition-base), border-color var(--transition-base), transform var(--transition-base); }
.glass-card:hover { box-shadow: var(--card-hover-shadow); border-color: var(--accent-primary); transform: translateY(-1px); }
[data-theme="cyber-neon"][data-mode="dark"] .glass-card { background: rgba(13,17,23,0.7); backdrop-filter: blur(16px) saturate(1.4); -webkit-backdrop-filter: blur(16px) saturate(1.4); }
[data-theme="cyber-neon"][data-mode="dark"] .glass-card:hover { background: rgba(13,17,23,0.85); box-shadow: 0 8px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(0,200,255,0.3), 0 0 40px rgba(0,200,255,0.08), inset 0 1px 0 rgba(0,200,255,0.05); }

.neon-text { color: var(--neon-glow, var(--accent-primary)); text-shadow: 0 0 7px var(--glow), 0 0 15px var(--glow), 0 0 30px var(--glow); }
.gold-text { color: var(--accent-primary); text-shadow: 0 0 20px var(--glow); }
.gold-text-bright { background: linear-gradient(135deg, #d4a853 0%, #f5d485 50%, #b8941f 100%); background-size: 200% auto; -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; animation: gradientShift 6s ease infinite; }

/* ---------- Buttons ---------- */
.btn-primary { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.625rem 1.25rem; font-size: 0.875rem; font-weight: 600; line-height: 1; color: var(--primary-foreground); background: linear-gradient(135deg, var(--btn-gradient-from), var(--btn-gradient-to)); border: none; border-radius: 0.5rem; cursor: pointer; transition: all var(--transition-fast); box-shadow: 0 2px 8px rgba(0,0,0,0.2); position: relative; overflow: hidden; text-decoration: none; }
.btn-primary::before { content: ''; position: absolute; inset: 0; background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 50%); opacity: 0; transition: opacity var(--transition-fast); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 16px var(--glow), 0 2px 8px rgba(0,0,0,0.3); }
.btn-primary:hover::before { opacity: 1; }
.btn-primary:active { transform: translateY(0); box-shadow: 0 1px 4px var(--glow); }
.btn-primary:disabled { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }

.btn-ghost { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.625rem 1.25rem; font-size: 0.875rem; font-weight: 500; line-height: 1; color: var(--foreground); background: transparent; border: 1px solid var(--border); border-radius: 0.5rem; cursor: pointer; transition: all var(--transition-fast); text-decoration: none; }
.btn-ghost:hover { background: var(--muted); border-color: var(--accent-primary); color: var(--accent-primary); }
.btn-ghost:active { background: var(--card); }
.btn-ghost:disabled { opacity: 0.5; cursor: not-allowed; }

.btn-danger { display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.625rem 1.25rem; font-size: 0.875rem; font-weight: 600; line-height: 1; color: #fff; background: var(--color-danger); border: none; border-radius: 0.5rem; cursor: pointer; transition: all var(--transition-fast); }
.btn-danger:hover { transform: translateY(-1px); filter: brightness(1.1); }

/* ---------- Input Field ---------- */
.input-field { width: 100%; padding: 0.625rem 0.875rem; font-size: 0.875rem; font-family: var(--font-body); color: var(--foreground); background: var(--muted); border: 1px solid var(--border); border-radius: 0.5rem; outline: none; transition: all var(--transition-fast); }
.input-field::placeholder { color: var(--muted-foreground); }
.input-field:hover { border-color: var(--accent-primary); }
.input-field:focus { border-color: var(--accent-primary); box-shadow: 0 0 0 3px var(--glow); background: var(--card); }
.input-field:disabled { opacity: 0.5; cursor: not-allowed; }

/* ---------- Stat Card ---------- */
.stat-card { position: relative; background: var(--card); border: 1px solid var(--card-border); border-radius: var(--radius); padding: 1.5rem; box-shadow: var(--card-shadow); overflow: hidden; transition: all var(--transition-base); }
.stat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--btn-gradient-from), var(--btn-gradient-to)); opacity: 0; transition: opacity var(--transition-base); }
.stat-card:hover { transform: translateY(-2px); box-shadow: var(--card-hover-shadow); border-color: var(--accent-primary); }
.stat-card:hover::before { opacity: 1; }

/* ---------- Sidebar Link ---------- */
.sidebar-link { display: flex; align-items: center; gap: 0.75rem; padding: 0.625rem 0.875rem; font-size: 0.875rem; font-weight: 500; color: var(--sidebar-foreground); border-radius: 0.5rem; transition: all var(--transition-fast); cursor: pointer; text-decoration: none; position: relative; overflow: hidden; border-left: 3px solid transparent; }
.sidebar-link:hover { background: var(--sidebar-accent); color: var(--sidebar-accent-foreground); }
.sidebar-link.active { background: var(--sidebar-accent); color: var(--sidebar-accent-foreground); font-weight: 600; border-left-color: var(--sidebar-primary); }
[data-theme="cyber-neon"] .sidebar-link.active { box-shadow: inset 0 0 20px rgba(0,200,255,0.05), 0 0 10px rgba(0,200,255,0.05); }
[data-theme="executive"] .sidebar-link.active { box-shadow: inset 0 0 20px rgba(212,168,83,0.05); }

/* ---------- Table Container ---------- */
.table-container { width: 100%; overflow-x: auto; border: 1px solid var(--card-border); border-radius: var(--radius); background: var(--card); }
.table-container table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.table-container thead { background: var(--muted); border-bottom: 1px solid var(--card-border); }
.table-container th { padding: 0.75rem 1rem; text-align: left; font-weight: 600; font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--muted-foreground); white-space: nowrap; }
.table-container td { padding: 0.75rem 1rem; border-bottom: 1px solid var(--border); color: var(--foreground); white-space: nowrap; }
.table-container tbody tr { transition: background-color var(--transition-fast); }
.table-container tbody tr:hover { background: var(--muted); }
.table-container tbody tr:last-child td { border-bottom: none; }

/* ---------- Badges ---------- */
.badge { display: inline-flex; align-items: center; gap: 0.375rem; padding: 0.25rem 0.625rem; font-size: 0.75rem; font-weight: 600; border-radius: 9999px; line-height: 1; white-space: nowrap; letter-spacing: 0.01em; }
.badge-clickjacking { color: #fff; background: #3b82f6; box-shadow: 0 0 8px rgba(59,130,246,0.3); }
[data-theme="cyber-neon"] .badge-clickjacking { background: #0080ff; box-shadow: 0 0 8px rgba(0,128,255,0.3); }
.badge-dmarc-red { color: #fff; background: #ef4444; box-shadow: 0 0 8px rgba(239,68,68,0.3); }
[data-theme="cyber-neon"] .badge-dmarc-red { background: #ff3366; box-shadow: 0 0 8px rgba(255,51,102,0.3); }
.badge-dmarc-yellow { color: #1a1d2e; background: #f59e0b; box-shadow: 0 0 8px rgba(245,158,11,0.3); }
[data-theme="cyber-neon"] .badge-dmarc-yellow { color: #0a1628; background: #ffaa00; box-shadow: 0 0 8px rgba(255,170,0,0.3); }
.badge-tls { color: #fff; background: #22c55e; box-shadow: 0 0 8px rgba(34,197,94,0.3); }
[data-theme="cyber-neon"] .badge-tls { background: #00ff88; color: #06080d; box-shadow: 0 0 8px rgba(0,255,136,0.3); }
.badge-ticket { color: #fff; background: #8b5cf6; box-shadow: 0 0 8px rgba(139,92,246,0.3); }
[data-theme="cyber-neon"] .badge-ticket { box-shadow: 0 0 8px rgba(139,92,246,0.4); }

/* ---------- Skeleton ---------- */
.skeleton { background: linear-gradient(90deg, var(--skeleton-from) 0%, var(--skeleton-via) 50%, var(--skeleton-to) 100%); background-size: 400% 100%; animation: shimmer 2s ease-in-out infinite; border-radius: 0.5rem; }

/* ---------- Modal ---------- */
.modal-overlay { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; background: var(--overlay); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); z-index: 100; animation: fadeIn 0.2s ease-out; padding: 1rem; }
.modal-content { width: 100%; max-width: 32rem; max-height: calc(100vh - 4rem); overflow-y: auto; background: var(--card); border: 1px solid var(--card-border); border-radius: calc(var(--radius) + 4px); box-shadow: 0 20px 60px rgba(0,0,0,0.5); animation: scaleIn 0.2s ease-out; }

/* ---------- Live Indicator ---------- */
.live-indicator { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.75rem; font-weight: 600; color: var(--color-success); text-transform: uppercase; letter-spacing: 0.05em; }
.live-indicator::before { content: ''; width: 8px; height: 8px; border-radius: 50%; background: var(--color-success); animation: livePulse 2s ease-in-out infinite; flex-shrink: 0; }

/* ---------- Status Dot ---------- */
.status-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.status-dot.success { background: var(--color-success); box-shadow: 0 0 6px var(--color-success); }
.status-dot.danger { background: var(--color-danger); box-shadow: 0 0 6px var(--color-danger); }
.status-dot.warning { background: var(--color-warning); box-shadow: 0 0 6px var(--color-warning); }
.status-dot.info { background: var(--color-info); box-shadow: 0 0 6px var(--color-info); }

/* ---------- Toast ---------- */
.toast-container { position: fixed; top: 1rem; right: 1rem; z-index: 9999; display: flex; flex-direction: column; gap: 0.5rem; }
.toast { padding: 0.75rem 1.25rem; border-radius: 0.5rem; font-size: 0.875rem; font-weight: 500; color: #fff; animation: slideInLeft 0.3s ease-out; box-shadow: 0 4px 20px rgba(0,0,0,0.3); max-width: 360px; }
.toast.success { background: var(--color-success); }
.toast.error { background: var(--color-danger); }
.toast.info { background: var(--color-info); }
.toast.warning { background: var(--color-warning); }

/* ---------- Animation Utilities ---------- */
.animate-fade-in { animation: fadeIn 0.3s ease-out both; }
.animate-slide-up { animation: slideUp 0.4s ease-out both; }
.animate-slide-in-left { animation: slideInLeft 0.3s ease-out both; }
.animate-scale-in { animation: scaleIn 0.2s ease-out both; }
.animate-spin { animation: spin 1s linear infinite; }
.animate-bounce { animation: bounce 1s infinite; }
.animate-pulse-glow { animation: pulse-glow 2s ease-in-out infinite; }
.animate-float { animation: float 6s ease-in-out infinite; }
.animate-progress { animation: progress 10s linear forwards; }
.animate-gradient-shift { animation: gradientShift 15s ease infinite; background-size: 400% 400%; }

/* ---------- Layout Helpers ---------- */
.flex { display: flex; } .flex-col { flex-direction: column; } .flex-1 { flex: 1; } .flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; } .items-start { align-items: flex-start; } .items-end { align-items: flex-end; }
.justify-center { justify-content: center; } .justify-between { justify-content: space-between; } .justify-end { justify-content: flex-end; }
.gap-1 { gap: 0.25rem; } .gap-2 { gap: 0.5rem; } .gap-3 { gap: 0.75rem; } .gap-4 { gap: 1rem; } .gap-6 { gap: 1.5rem; }
.grid { display: grid; }
.text-center { text-align: center; } .text-left { text-align: left; } .text-right { text-align: right; }
.font-bold { font-weight: 700; } .font-semibold { font-weight: 600; } .font-medium { font-weight: 500; }
.text-xs { font-size: 0.75rem; } .text-sm { font-size: 0.875rem; } .text-base { font-size: 1rem; } .text-lg { font-size: 1.125rem; } .text-xl { font-size: 1.25rem; } .text-2xl { font-size: 1.5rem; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hidden { display: none !important; }
.w-full { width: 100%; } .min-w-0 { min-width: 0; } .shrink-0 { flex-shrink: 0; }
.relative { position: relative; } .absolute { position: absolute; } .fixed { position: fixed; }
.overflow-hidden { overflow: hidden; } .overflow-y-auto { overflow-y: auto; } .overflow-x-auto { overflow-x: auto; }
.rounded-lg { border-radius: 0.5rem; } .rounded-xl { border-radius: 0.75rem; } .rounded-2xl { border-radius: 1rem; } .rounded-full { border-radius: 9999px; }
.p-1 { padding: 0.25rem; } .p-2 { padding: 0.5rem; } .p-3 { padding: 0.75rem; } .p-4 { padding: 1rem; } .p-5 { padding: 1.25rem; } .p-6 { padding: 1.5rem; }
.px-2 { padding-left: 0.5rem; padding-right: 0.5rem; } .px-3 { padding-left: 0.75rem; padding-right: 0.75rem; } .px-4 { padding-left: 1rem; padding-right: 1rem; }
.py-1 { padding-top: 0.25rem; padding-bottom: 0.25rem; } .py-2 { padding-top: 0.5rem; padding-bottom: 0.5rem; } .py-3 { padding-top: 0.75rem; padding-bottom: 0.75rem; }
.mb-1 { margin-bottom: 0.25rem; } .mb-2 { margin-bottom: 0.5rem; } .mb-3 { margin-bottom: 0.75rem; } .mb-4 { margin-bottom: 1rem; } .mb-6 { margin-bottom: 1.5rem; } .mb-8 { margin-bottom: 2rem; }
.mt-0 { margin-top: 0; } .mt-1 { margin-top: 0.25rem; } .mt-2 { margin-top: 0.5rem; } .mt-auto { margin-top: auto; }
.ml-auto { margin-left: auto; } .mr-3 { margin-right: 0.75rem; } .mx-auto { margin-left: auto; margin-right: auto; }
.space-y-1 > * + * { margin-top: 0.25rem; } .space-y-2 > * + * { margin-top: 0.5rem; } .space-y-3 > * + * { margin-top: 0.75rem; } .space-y-4 > * + * { margin-top: 1rem; } .space-y-6 > * + * { margin-top: 1.5rem; }
.max-w-md { max-width: 28rem; } .max-w-3xl { max-width: 48rem; } .max-w-4xl { max-width: 56rem; } .max-w-5xl { max-width: 64rem; } .max-w-8xl { max-width: 80rem; }
.min-h-screen { min-height: 100vh; } .h-screen { height: 100vh; }
.z-10 { z-index: 10; } .z-40 { z-index: 40; } .z-50 { z-index: 50; }
.cursor-pointer { cursor: pointer; } .cursor-default { cursor: default; }
.opacity-30 { opacity: 0.3; } .opacity-50 { opacity: 0.5; }
.select-none { user-select: none; } .whitespace-nowrap { white-space: nowrap; }
.pointer-events-none { pointer-events: none; }
.font-mono { font-family: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, monospace; }
.max-h-96 { max-height: 24rem; }
.inset-0 { top: 0; right: 0; bottom: 0; left: 0; }

/* ---------- Responsive Grid ---------- */
.grid-cols-1 { grid-template-columns: repeat(1, 1fr); }
.grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
.grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
.grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
.grid-cols-6 { grid-template-columns: repeat(6, 1fr); }

@media (max-width: 640px) {
  .sm\:flex-row { flex-direction: row; }
  .sm\:hidden { display: none !important; }
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .sm\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .sm\:w-64 { width: 16rem; }
  .sm\:items-center { align-items: center; }
  .sm\:justify-between { justify-content: space-between; }
  .sm\:p-4 { padding: 1rem; }
  .sm\:p-6 { padding: 1.5rem; }
}
@media (min-width: 640px) {
  .sm\:flex-row { flex-direction: row; }
  .sm\:hidden { display: none !important; }
  .sm\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .sm\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .sm\:w-64 { width: 16rem; }
}
@media (min-width: 768px) {
  .md\:flex { display: flex; }
  .md\:hidden { display: none !important; }
  .md\:w-64 { width: 16rem; }
  .md\:ml-64 { margin-left: 16rem; }
  .md\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .md\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .md\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
  .md\:grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
  .md\:p-4 { padding: 1rem; }
  .md\:p-6 { padding: 1.5rem; }
}
@media (min-width: 1024px) {
  .lg\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .lg\:grid-cols-4 { grid-template-columns: repeat(4, 1fr); }
  .lg\:col-span-2 { grid-column: span 2; }
  .lg\:p-6 { padding: 1.5rem; }
}
@media (min-width: 1280px) {
  .xl\:grid-cols-2 { grid-template-columns: repeat(2, 1fr); }
  .xl\:grid-cols-3 { grid-template-columns: repeat(3, 1fr); }
  .xl\:grid-cols-6 { grid-template-columns: repeat(6, 1fr); }
  .xl\:col-span-2 { grid-column: span 2; }
}