/* Theme Toggle Variables setup */
:root {
  --cyberBg: #08111F;
  --cyberDark: #0F172A;
  --cyberGrey: #111827;
  --cyberText: #FFFFFF;
  --cyberTextSecondary: #94A3B8;
  --glassBg: rgba(15, 23, 42, 0.7);
  --glassBorder: rgba(255, 255, 255, 0.05);
  --neonGreen: #00FF88;
  --neonCyan: #00E5FF;
  --neonGreenGlow: rgba(0, 255, 136, 0.6);
  --neonCyanGlow: rgba(0, 229, 255, 0.6);
  --matrixOpacity: 0.15;
}

/* Light high-contrast theme overrides definition */
body.light-mode {
  --cyberBg: #F8FAFC;
  --cyberDark: #FFFFFF;
  --cyberGrey: #F1F5F9;
  --cyberText: #0F172A;
  --cyberTextSecondary: #475569;
  --glassBg: rgba(255, 255, 255, 0.9);
  --glassBorder: rgba(15, 23, 42, 0.1);
  --neonGreen: #059669; /* Emerald green */
  --neonCyan: #0284C7;  /* Deep ocean blue */
  --neonGreenGlow: rgba(5, 150, 105, 0.15);
  --neonCyanGlow: rgba(2, 132, 199, 0.15);
  --matrixOpacity: 0.05;
}

/* Main background and custom scrollbar design */
body {
  background-color: var(--cyberBg) !important;
  color: var(--cyberText) !important;
  font-family: 'Inter', sans-serif;
  overflow-x: hidden;
  transition: background-color 0.25s ease, color 0.25s ease;
}

::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background: var(--cyberBg);
}
::-webkit-scrollbar-thumb {
  background: var(--neonGreen);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--neonCyan);
}

/* Cyber flat crisp style controls */
.neon-glow-green,
.neon-glow-cyan,
.neon-glow-green,
.neon-glow-cyan,
[class*="shadow-["],
[class*="shadow-"] {
  text-shadow: none !important;
  box-shadow: none !important;
}

.neon-border-green {
  border: 1px solid var(--neonGreen);
}
.neon-border-green:hover {
  border: 1px solid var(--neonGreen);
}
.neon-btn-cyan {
  border: 1px solid var(--neonCyan);
  transition: all 0.3s ease;
}
.neon-btn-cyan:hover {
  background-color: var(--neonCyan);
  color: var(--cyberBg) !important;
}

/* Glassmorphism card templates */
.glass-card {
  background: var(--glassBg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--glassBorder);
  transition: background 0.25s ease, border-color 0.25s ease;
  box-shadow: none !important;
}
.glass-card:hover {
  border-color: var(--neonGreen);
}

/* Animation keyframes and transition classes */
@keyframes float {
  0%, 100% { transform: translateY(0px) rotate(0deg); }
  50% { transform: translateY(-10px) rotate(2deg); }
}
.float-animation {
  animation: float 6s ease-in-out infinite;
}

/* Matrix effect background utility style */
#matrix-canvas {
  display: none !important;
}

/* Icon visibility rules based on theme */
body .theme-icon-sun {
  display: none !important;
}
body .theme-icon-moon {
  display: block !important;
  color: #00E5FF;
}

body.light-mode .theme-icon-sun {
  display: block !important;
  color: #F59E0B; /* Warm golden sun */
}
body.light-mode .theme-icon-moon {
  display: none !important;
}

/* Global transitions for theme swap */
body, 
.glass-card, 
header, 
footer, 
nav a, 
button, 
input, 
textarea, 
select {
  transition: background-color 0.25s ease, border-color 0.25s ease, color 0.15s ease, box-shadow 0.25s ease;
}

/* --- LIGHT MODE COMPONENT & UTILITY OVERRIDES --- */
body.light-mode #matrix-canvas {
  opacity: var(--matrixOpacity) !important;
}

/* Background Utility Overrides */
body.light-mode .bg-cyberBg { background-color: #F8FAFC !important; }
body.light-mode .bg-cyberDark { background-color: #FFFFFF !important; }
body.light-mode .bg-cyberGrey { background-color: #F1F5F9 !important; }
body.light-mode .bg-slate-900 { background-color: #F1F5F9 !important; }
body.light-mode .bg-slate-950 { background-color: #E2E8F0 !important; }
body.light-mode .bg-slate-800 { background-color: #F1F5F9 !important; }
body.light-mode .bg-slate-800\/50 { background-color: rgba(241, 245, 249, 0.6) !important; }
body.light-mode .bg-slate-900\/50 { background-color: rgba(241, 245, 249, 0.6) !important; }
body.light-mode .bg-slate-950\/50 { background-color: rgba(241, 245, 249, 0.6) !important; }
body.light-mode .bg-amber-950\/20 { background-color: #FEF3C7 !important; }
body.light-mode .bg-red-950\/40 { background-color: #FEE2E2 !important; }
body.light-mode .bg-emerald-950\/30 { background-color: #D1FAE5 !important; }

/* Text Utility Overrides */
body.light-mode .text-white { color: #0F172A !important; }
body.light-mode .text-slate-100 { color: #1E293B !important; }
body.light-mode .text-slate-200 { color: #334155 !important; }
body.light-mode .text-slate-300 { color: #475569 !important; }
body.light-mode .text-slate-400 { color: #64748B !important; }
body.light-mode .text-slate-500 { color: #64748B !important; }
body.light-mode .text-emerald-400 { color: #059669 !important; }
body.light-mode .text-cyberGreen { color: var(--neonGreen) !important; }
body.light-mode .text-cyberCyan { color: var(--neonCyan) !important; }
body.light-mode .text-amber-200 { color: #92400E !important; }
body.light-mode .text-rose-400 { color: #DC2626 !important; }

/* Borders Overrides */
body.light-mode .border-slate-800 { border-color: #CBD5E1 !important; }
body.light-mode .border-slate-700 { border-color: #CBD5E1 !important; }
body.light-mode .border-slate-950 { border-color: #CBD5E1 !important; }
body.light-mode .border-slate-900 { border-color: #CBD5E1 !important; }
body.light-mode .border-white\/10 { border-color: rgba(15, 23, 42, 0.1) !important; }
body.light-mode .border-white\/5 { border-color: rgba(15, 23, 42, 0.05) !important; }
body.light-mode .border-cyberGreen\/40 { border-color: rgba(5, 150, 105, 0.4) !important; }

/* Interactive elements in light mode */
body.light-mode input, 
body.light-mode textarea, 
body.light-mode select {
  background-color: #FFFFFF !important;
  color: #0F172A !important;
  border: 1px solid #CBD5E1 !important;
}
body.light-mode input::placeholder, 
body.light-mode textarea::placeholder {
  color: #94A3B8 !important;
}

/* Navigation items hover states */
body.light-mode .hover\:text-cyberCyan:hover { color: var(--neonCyan) !important; }
body.light-mode .hover\:bg-slate-800\/50:hover { background-color: rgba(241, 245, 249, 0.8) !important; }
body.light-mode .hover\:border-cyberGreen:hover { border-color: var(--neonGreen) !important; }

/* Footer Overrides */
body.light-mode #footer,
body.light-mode footer {
  background-color: #E2E8F0 !important;
  border-top: 1px solid #CBD5E1 !important;
}

/* Custom styles for components in light-mode to enforce premium feel */
body.light-mode .glass-card {
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -1px rgba(0, 0, 0, 0.02) !important;
}
body.light-mode #mobile-menu {
  background-color: #FFFFFF !important;
  border-top: 1px solid #E2E8F0 !important;
}

/* ==========================================================================
   PREMIUM 3-DOTS HEADER OPTIONS DROPDOWN SYSTEM
   ========================================================================== */

#header-options-wrapper {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  z-index: 9999 !important;
  margin-left: auto !important;
}

#header-options-trigger {
  width: 42px !important;
  height: 42px !important;
  padding: 0 !important;
  border-radius: 10px !important;
  background-color: var(--cyberDark) !important;
  border: 1.5px solid var(--glassBorder) !important;
  color: var(--cyberText) !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
  transition: all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

#header-options-trigger:hover {
  background-color: var(--cyberGrey) !important;
  border-color: var(--neonGreen) !important;
  color: var(--neonGreen) !important;
  transform: translateY(-1px) scale(1.03) !important;
  box-shadow: 0 6px 16px var(--neonGreenGlow) !important;
}

#header-options-trigger:active {
  transform: translateY(1px) scale(0.98) !important;
}

#header-options-dropdown {
  position: absolute !important;
  right: 0 !important;
  top: calc(100% + 8px) !important;
  background-color: var(--cyberDark) !important;
  border: 1.5px solid var(--glassBorder) !important;
  border-radius: 14px !important;
  padding: 18px !important;
  width: 300px !important;
  box-shadow: 0 10px 30px -5px rgba(0, 0, 0, 0.45), 0 8px 16px -8px rgba(0, 0, 0, 0.35) !important;
  z-index: 99999 !important;
  opacity: 0;
  visibility: hidden;
  transform: translateY(14px) scale(0.95);
  transition: opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1), 
              visibility 0.25s cubic-bezier(0.16, 1, 0.3, 1), 
              transform 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
  pointer-events: none;
}

#header-options-dropdown.show {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) scale(1) !important;
  pointer-events: auto !important;
}

body.light-mode #header-options-dropdown {
  box-shadow: 0 10px 30px -5px rgba(15, 23, 42, 0.08), 0 8px 16px -8px rgba(15, 23, 42, 0.05) !important;
  background-color: #FFFFFF !important;
}

#header-options-dropdown a.portal-nav-link {
  display: block !important;
  padding: 8px 12px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 550 !important;
  color: var(--cyberTextSecondary) !important;
  transition: all 0.2s ease !important;
  background: transparent !important;
  border: none !important;
  opacity: 0.9 !important;
}

#header-options-dropdown a.portal-nav-link:hover {
  background-color: var(--cyberGrey) !important;
  color: var(--neonCyan) !important;
  opacity: 1 !important;
  padding-left: 16px !important;
}

#header-options-dropdown a.portal-nav-link.active-link {
  color: var(--neonGreen) !important;
  background-color: var(--neonGreenGlow) !important;
  border-left: 3px solid var(--neonGreen) !important;
  border-radius: 0 8px 8px 0 !important;
  font-weight: 700 !important;
  opacity: 1 !important;
  padding-left: 16px !important;
}

.options-menu-header {
  border-bottom: 1px solid var(--glassBorder) !important;
  padding-bottom: 10px !important;
  margin-bottom: 10px !important;
}

.options-menu-header h4 {
  color: var(--cyberText) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

.options-menu-header p {
  color: var(--cyberTextSecondary) !important;
  font-size: 10px !important;
}

.options-section-title {
  color: var(--cyberTextSecondary) !important;
  font-size: 9px !important;
  letter-spacing: 0.1em !important;
  margin-bottom: 6px !important;
}

.options-divider {
  border-top: 1px solid var(--glassBorder) !important;
  margin: 12px 0 8px 0 !important;
}

.custom-nav-scroll::-webkit-scrollbar {
  width: 4px;
}
.custom-nav-scroll::-webkit-scrollbar-track {
  background: var(--cyberBg);
  border-radius: 4px;
}
.custom-nav-scroll::-webkit-scrollbar-thumb {
  background: var(--neonCyanGlow);
  border-radius: 4px;
}
.custom-nav-scroll::-webkit-scrollbar-thumb:hover {
  background: var(--neonCyan);
}

/* ==========================================================================
   GLOBAL HEADER & FOOTER LIGHT MODE COLOR CONTRAST UNIFIERS
   ========================================================================== */

body.light-mode header,
body.light-mode .glass-card,
body.light-mode nav {
  background-color: #FFFFFF !important;
  color: #0F172A !important;
  border-color: #E2E8F0 !important;
}

body.light-mode footer {
  background-color: #F8FAFC !important;
  color: #0F172A !important;
  border-color: #E2E8F0 !important;
}

body.light-mode footer .border-t,
body.light-mode footer .border-slate-900 {
  border-color: #E2E8F0 !important;
}

body.light-mode footer p,
body.light-mode footer span,
body.light-mode footer div {
  color: #475569 !important;
}

body.light-mode footer strong {
  color: #0F172A !important;
}

body.light-mode footer .text-slate-300,
body.light-mode footer .text-slate-400,
body.light-mode footer .text-slate-500 {
  color: #475569 !important;
}

body.light-mode footer a {
  color: #0284C7 !important;
  text-decoration: underline;
  text-decoration-color: rgba(2, 132, 199, 0.3);
}

body.light-mode footer a:hover {
  color: #059669 !important;
}

body.light-mode #header-options-trigger {
  background-color: #FFFFFF !important;
  color: #0F172A !important;
  border-color: #CBD5E1 !important;
}

body.light-mode #header-options-trigger:hover {
  background-color: #F1F5F9 !important;
  color: #059669 !important;
  border-color: #059669 !important;
}

/* ==========================================================================
   SAFETY TOOLS PREMIUM DROPDOWN SYSTEM
   ========================================================================== */

.nav-dropdown {
  position: relative !important;
  display: inline-block !important;
}

.nav-dropdown-menu {
  position: absolute !important;
  top: 100% !important;
  left: 50% !important;
  transform: translateX(-50%) translateY(14px) !important;
  background-color: var(--cyberDark) !important;
  border: 1.5px solid var(--glassBorder) !important;
  border-radius: 12px !important;
  padding: 8px 0 !important;
  width: 200px !important;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 16px -8px rgba(0, 0, 0, 0.3) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease !important;
  z-index: 99999 !important;
  pointer-events: none !important;
}

body.light-mode .nav-dropdown-menu {
  background-color: #FFFFFF !important;
  border-color: #E2E8F0 !important;
  box-shadow: 0 10px 25px -5px rgba(15, 23, 42, 0.08), 0 8px 16px -8px rgba(15, 23, 42, 0.04) !important;
}

.nav-dropdown:hover .nav-dropdown-menu {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateX(-50%) translateY(4px) !important;
  pointer-events: auto !important;
}

.nav-dropdown-item {
  display: block !important;
  padding: 10px 18px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  color: var(--cyberTextSecondary) !important;
  transition: all 0.15s ease !important;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.02) !important;
}

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

body.light-mode .nav-dropdown-item {
  border-bottom: 1px solid rgba(15, 23, 42, 0.03) !important;
}

.nav-dropdown-item:hover {
  background-color: var(--cyberGrey) !important;
  color: var(--neonCyan) !important;
}

body.light-mode .nav-dropdown-item:hover {
  background-color: #F1F5F9 !important;
  color: var(--neonCyan) !important;
}

.nav-dropdown-item.active-item {
  color: var(--neonGreen) !important;
  font-weight: 700 !important;
  background-color: var(--neonGreenGlow) !important;
}

/* ==========================================================================
   CUSTOM IN-APP PREMIUM NOTIFICATION GLASS TOASTS
   ========================================================================== */

#safepk-toast-container {
  pointer-events: none;
}

#safepk-toast-container .toast-card {
  pointer-events: auto;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.45) !important;
}

body.light-mode #safepk-toast-container .toast-card {
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.1) !important;
}
