/* ============================================================
   FUTURISTIC UI — Global Design Override
   Deep-space glassmorphism + neon SaaS aesthetic
   ============================================================ */

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

/* ═══════════════════════════════════════════════════════════
   1. DESIGN TOKENS — override everything
   ═══════════════════════════════════════════════════════════ */
:root {
  /* Neon palette */
  --neon-blue:   #00d4ff;
  --neon-violet: #8b5cf6;
  --neon-cyan:   #22d3ee;
  --neon-pink:   #f472b6;
  --neon-green:  #34d399;
  --neon-amber:  #fbbf24;

  /* Deep-space backgrounds */
  --space-900: #04060d;
  --space-800: #080b14;
  --space-700: #0d1117;
  --space-600: #111827;
  --space-500: #161b26;
  --space-400: #1e2a3a;
  --space-300: #263347;

  /* Glass surfaces */
  --glass-1: rgba(255,255,255,0.03);
  --glass-2: rgba(255,255,255,0.06);
  --glass-3: rgba(255,255,255,0.10);
  --glass-border: rgba(255,255,255,0.09);
  --glass-border-accent: rgba(0,212,255,0.25);
  --glass-border-hover: rgba(0,212,255,0.50);

  /* Neon glow shadows */
  --glow-blue:   0 0 20px rgba(0,212,255,0.25),   0 0 40px rgba(0,212,255,0.10);
  --glow-violet: 0 0 20px rgba(139,92,246,0.30),  0 0 40px rgba(139,92,246,0.12);
  --glow-cyan:   0 0 20px rgba(34,211,238,0.25),  0 0 40px rgba(34,211,238,0.10);
  --glow-pink:   0 0 20px rgba(244,114,182,0.25), 0 0 40px rgba(244,114,182,0.10);

  /* Depth shadows */
  --depth-sm:  0 2px 8px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.04);
  --depth-md:  0 4px 20px rgba(0,0,0,0.5), inset 0 1px 0 rgba(255,255,255,0.05);
  --depth-lg:  0 8px 40px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.06);
  --depth-xl:  0 16px 60px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.07);

  /* Gradients */
  --grad-primary:   linear-gradient(135deg, #0ea5e9 0%, #8b5cf6 100%);
  --grad-blue-cyan: linear-gradient(135deg, #00d4ff 0%, #0072ff 100%);
  --grad-violet:    linear-gradient(135deg, #8b5cf6 0%, #ec4899 100%);
  --grad-aurora:    linear-gradient(135deg, #00c6ff 0%, #a855f7 50%, #ec4899 100%);
  --grad-cyber:     linear-gradient(135deg, #00d4ff 0%, #7c3aed 100%);
  --grad-mesh: radial-gradient(at 20% 30%, rgba(0,212,255,0.12) 0%, transparent 55%),
               radial-gradient(at 80% 10%, rgba(139,92,246,0.12) 0%, transparent 50%),
               radial-gradient(at 60% 80%, rgba(244,114,182,0.08) 0%, transparent 45%);

  /* Easing */
  --ease-out:   cubic-bezier(0.22, 1, 0.36, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Override CSS framework vars to futuristic dark theme */
[data-theme="dark"],
:root {
  --bg-primary:   var(--space-800);
  --bg-secondary: var(--space-700);
  --bg-tertiary:  var(--space-600);
  --card-bg:      var(--glass-2);
  --border-color: var(--glass-border);
  --text-primary:    #f1f5f9;
  --text-secondary:  #94a3b8;
  --text-tertiary:   #64748b;
  --text-muted:      #475569;
  --color-primary-500: var(--neon-blue);
  --color-primary-400: #38bdf8;
  --color-primary-600: #0284c7;
  --navbar-bg: rgba(8,11,20,0.80);
  --footer-bg: var(--space-900);
  --sidebar-bg: var(--space-800);
  --shadow-lg: var(--depth-lg);
  --shadow-xl: var(--depth-xl);
  --gradient-primary: var(--grad-primary);
}

/* ═══════════════════════════════════════════════════════════
   2. BASE RESET & BODY
   ═══════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--space-800);
  background-image: var(--grad-mesh);
  background-attachment: fixed;
  color: var(--text-primary);
  font-family: 'Space Grotesk', 'Inter', 'Cairo', system-ui, sans-serif;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Futuristic scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--space-800); }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--neon-blue), var(--neon-violet));
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover { background: var(--neon-cyan); }

/* Selection */
::selection {
  background: rgba(0,212,255,0.25);
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════
   3. ANIMATION LIBRARY
   ═══════════════════════════════════════════════════════════ */
@keyframes fu-fade-in    { from { opacity:0; transform:translateY(16px); } to { opacity:1; transform:none; } }
@keyframes fu-slide-left { from { opacity:0; transform:translateX(24px); } to { opacity:1; transform:none; } }
@keyframes fu-float      { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-10px); } }
@keyframes fu-glow-pulse { 0%,100% { opacity:0.6; } 50% { opacity:1; } }
@keyframes fu-spin-slow  { to { transform:rotate(360deg); } }
@keyframes fu-shimmer    {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}
@keyframes fu-border-glow {
  0%,100% { border-color: rgba(0,212,255,0.2); box-shadow: 0 0 0 transparent; }
  50%      { border-color: rgba(0,212,255,0.6); box-shadow: 0 0 20px rgba(0,212,255,0.2); }
}
@keyframes fu-scan-line {
  0%   { top: -2px; }
  100% { top: 100%; }
}
@keyframes fu-orb-move {
  0%,100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(30px,-20px) scale(1.05); }
  66%      { transform: translate(-20px,15px) scale(0.95); }
}
@keyframes fu-gradient-shift {
  0%,100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}
@keyframes fu-count-up {
  from { opacity:0; transform:translateY(10px); }
  to   { opacity:1; transform:none; }
}

/* Utility animation classes */
.fu-fade-in    { animation: fu-fade-in    0.6s var(--ease-out) both; }
.fu-slide-left { animation: fu-slide-left 0.5s var(--ease-out) both; }
.fu-float      { animation: fu-float      4s ease-in-out infinite; }
.fu-shimmer    {
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.08) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: fu-shimmer 2s linear infinite;
}

/* Delay helpers */
.delay-100 { animation-delay: 0.1s; }
.delay-200 { animation-delay: 0.2s; }
.delay-300 { animation-delay: 0.3s; }
.delay-400 { animation-delay: 0.4s; }
.delay-500 { animation-delay: 0.5s; }

/* ═══════════════════════════════════════════════════════════
   4. NAVBAR / NAVIGATION
   ═══════════════════════════════════════════════════════════ */
nav,
.navbar,
header nav {
  background: rgba(8,11,20,0.75) !important;
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom: 1px solid var(--glass-border) !important;
  box-shadow: 0 1px 0 rgba(255,255,255,0.04), 0 8px 32px rgba(0,0,0,0.3);
  transition: all 0.3s var(--ease-smooth);
  position: sticky;
  top: 0;
  z-index: 1030;
}

/* Nav links */
.nav-link,
nav a {
  color: var(--text-secondary) !important;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: color 0.2s, text-shadow 0.2s;
  position: relative;
}
.nav-link:hover,
nav a:hover {
  color: var(--neon-cyan) !important;
  text-shadow: 0 0 12px rgba(34,211,238,0.6);
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0;
  width: 0; height: 2px;
  background: var(--grad-blue-cyan);
  border-radius: 2px;
  transition: width 0.3s var(--ease-out);
}
.nav-link:hover::after { width: 100%; }

/* Logo glow */
nav .brand-logo,
nav .logo-glow {
  filter: drop-shadow(0 0 8px rgba(0,212,255,0.5));
}

/* ═══════════════════════════════════════════════════════════
   5. GLASS CARD COMPONENT
   ═══════════════════════════════════════════════════════════ */
.card,
.service-card,
.dashboard-card,
.stats-card,
.glass,
.glass-effect {
  background: var(--glass-1) !important;
  backdrop-filter: blur(20px) saturate(150%);
  -webkit-backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid var(--glass-border) !important;
  border-radius: 16px !important;
  box-shadow: var(--depth-md);
  transition: transform 0.35s var(--ease-spring), box-shadow 0.35s var(--ease-smooth), border-color 0.35s;
  position: relative;
  overflow: hidden;
}

/* Subtle inner-highlight line on top */
.card::before,
.service-card::before,
.dashboard-card::before {
  content: '';
  position: absolute;
  top: 0; left: 10%; right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
  pointer-events: none;
}

.card:hover,
.service-card:hover,
.dashboard-card:hover {
  transform: translateY(-6px) scale(1.005);
  border-color: var(--glass-border-accent) !important;
  box-shadow: var(--depth-xl), var(--glow-blue);
}

/* ═══════════════════════════════════════════════════════════
   6. BUTTONS
   ═══════════════════════════════════════════════════════════ */
.btn,
button.btn,
a.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.375rem;
  border-radius: 10px;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.25s var(--ease-smooth);
  position: relative;
  overflow: hidden;
  white-space: nowrap;
}

/* Shimmer sweep on hover */
.btn::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  transition: left 0.4s var(--ease-smooth);
  pointer-events: none;
}
.btn:hover::after { left: 150%; }

/* Primary */
.btn-primary,
.btn.primary,
.btn.bl {
  background: var(--grad-blue-cyan) !important;
  border-color: rgba(0,212,255,0.3) !important;
  color: #fff !important;
  box-shadow: 0 4px 15px rgba(0,212,255,0.25);
}
.btn-primary:hover,
.btn.primary:hover,
.btn.bl:hover {
  box-shadow: 0 6px 25px rgba(0,212,255,0.45), var(--glow-blue);
  transform: translateY(-2px);
  color: #fff !important;
}

/* Secondary */
.btn-secondary,
.btn.secondary {
  background: var(--glass-2) !important;
  border-color: var(--glass-border) !important;
  color: var(--text-secondary) !important;
  backdrop-filter: blur(10px);
}
.btn-secondary:hover,
.btn.secondary:hover {
  border-color: var(--glass-border-accent) !important;
  color: var(--neon-cyan) !important;
  background: var(--glass-3) !important;
}

/* Danger */
.btn-danger,
.btn.rd,
.btn.danger {
  background: linear-gradient(135deg, #ef4444, #dc2626) !important;
  border-color: rgba(239,68,68,0.3) !important;
  color: #fff !important;
}
.btn-danger:hover,
.btn.rd:hover { box-shadow: 0 6px 20px rgba(239,68,68,0.4); transform: translateY(-2px); }

/* Success / Green */
.btn-success,
.btn.gr,
.btn.success {
  background: linear-gradient(135deg, #10b981, #059669) !important;
  border-color: rgba(16,185,129,0.3) !important;
  color: #fff !important;
}
.btn-success:hover,
.btn.gr:hover { box-shadow: 0 6px 20px rgba(16,185,129,0.4); transform: translateY(-2px); }

/* Ghost / outline */
.btn-ghost,
.btn.ghost {
  background: transparent !important;
  border-color: var(--glass-border-accent) !important;
  color: var(--neon-cyan) !important;
}
.btn-ghost:hover,
.btn.ghost:hover {
  background: rgba(0,212,255,0.08) !important;
  box-shadow: var(--glow-blue);
}

/* Small / Large */
.btn-sm { padding: 0.375rem 0.875rem !important; font-size: 0.8rem !important; border-radius: 7px !important; }
.btn-lg { padding: 0.875rem 2rem !important; font-size: 1rem !important; border-radius: 14px !important; }

/* ═══════════════════════════════════════════════════════════
   7. FORMS & INPUTS
   ═══════════════════════════════════════════════════════════ */
input, textarea, select,
.finp,
.form-control,
.form-input {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  color: var(--text-primary) !important;
  font-family: inherit;
  font-size: 0.9rem;
  padding: 0.625rem 0.875rem;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  backdrop-filter: blur(8px);
  outline: none;
  width: 100%;
}
input::placeholder, textarea::placeholder { color: var(--text-muted) !important; }
input:focus, textarea:focus, select:focus,
.finp:focus {
  border-color: var(--neon-blue) !important;
  box-shadow: 0 0 0 3px rgba(0,212,255,0.15), var(--glow-blue) !important;
  background: rgba(0,212,255,0.03) !important;
}

label,
.form-label { color: var(--text-secondary); font-size: 0.8rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.35rem; display: block; }

/* ═══════════════════════════════════════════════════════════
   8. TABLES
   ═══════════════════════════════════════════════════════════ */
table {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 14px !important;
  overflow: hidden;
  backdrop-filter: blur(16px);
  box-shadow: var(--depth-md);
}
th {
  background: rgba(255,255,255,0.04) !important;
  color: var(--neon-cyan) !important;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--glass-border) !important;
  padding: 0.875rem 1rem;
}
td {
  border-bottom: 1px solid rgba(255,255,255,0.04) !important;
  color: var(--text-secondary) !important;
  padding: 0.875rem 1rem;
  transition: background 0.15s;
}
tr:last-child td { border-bottom: none !important; }
tr:hover td { background: rgba(0,212,255,0.04) !important; }

/* ═══════════════════════════════════════════════════════════
   9. BADGES
   ═══════════════════════════════════════════════════════════ */
.badge {
  padding: 0.2rem 0.65rem;
  border-radius: 9999px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  backdrop-filter: blur(8px);
}
.badge-success { background: rgba(52,211,153,0.15) !important; color: var(--neon-green) !important; border: 1px solid rgba(52,211,153,0.3); }
.badge-warning { background: rgba(251,191,36,0.15) !important; color: var(--neon-amber) !important; border: 1px solid rgba(251,191,36,0.3); }
.badge-error   { background: rgba(248,113,113,0.15) !important; color: #f87171 !important; border: 1px solid rgba(248,113,113,0.3); }
.badge-info    { background: rgba(0,212,255,0.12) !important; color: var(--neon-blue) !important; border: 1px solid rgba(0,212,255,0.3); }

/* ═══════════════════════════════════════════════════════════
   10. MODALS
   ═══════════════════════════════════════════════════════════ */
.modal-bg,
.modal-backdrop,
.modal-overlay {
  background: rgba(4,6,13,0.85) !important;
  backdrop-filter: blur(8px);
}
.modal,
.modal-box,
.modal-content,
[class*="modal-"] > div:first-child {
  /* background: var(--space-600) !important; */
  border: 1px solid var(--glass-border) !important;
  border-radius: 20px !important;
  box-shadow: var(--depth-xl), 0 0 60px rgba(0,0,0,0.5);
}

/* ═══════════════════════════════════════════════════════════
   11. DROPDOWNS
   ═══════════════════════════════════════════════════════════ */
.dropdown-content,
.dropdown-menu,
[class*="dropdown"] > div {
  background: rgba(13,17,23,0.95) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 14px !important;
  backdrop-filter: blur(24px) saturate(180%);
  box-shadow: var(--depth-xl);
  overflow: hidden;
}
.dropdown-content a,
.dropdown-menu a,
.dropdown-item {
  color: var(--text-secondary) !important;
  padding: 0.625rem 1rem;
  transition: background 0.15s, color 0.15s;
  display: block;
}
.dropdown-content a:hover,
.dropdown-menu a:hover,
.dropdown-item:hover {
  background: rgba(0,212,255,0.08) !important;
  color: var(--neon-cyan) !important;
}

/* ═══════════════════════════════════════════════════════════
   12. HERO SECTIONS
   ═══════════════════════════════════════════════════════════ */
.hero-bg,
.hero-section,
.hero {
  background:
    var(--grad-mesh),
    linear-gradient(160deg, #0a0e1a 0%, #0d1117 40%, #0e0814 100%) !important;
  background-size: cover;
  position: relative;
  overflow: hidden;
}

/* Animated grid overlay */
.hero-bg::before,
.hero-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,212,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
  animation: fu-scan-line 0 linear; /* no animation by default */
  pointer-events: none;
}

/* Floating orbs */
.hero-bg::after,
.hero-section::after {
  content: '';
  position: absolute;
  width: 600px; height: 600px;
  top: -200px; right: -150px;
  background: radial-gradient(circle, rgba(139,92,246,0.12) 0%, transparent 70%);
  border-radius: 50%;
  animation: fu-orb-move 12s ease-in-out infinite;
  pointer-events: none;
}

/* Gradient text */
.gradient-text,
.text-gradient,
h1 .highlight {
  background: var(--grad-aurora);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: fu-gradient-shift 6s ease infinite;
}

/* ═══════════════════════════════════════════════════════════
   13. SERVICE CARDS (specific to landing)
   ═══════════════════════════════════════════════════════════ */
.service-card {
  background: linear-gradient(145deg, var(--glass-2), var(--glass-1)) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 20px !important;
  padding: 1.75rem;
  transition: transform 0.4s var(--ease-spring), box-shadow 0.4s var(--ease-smooth), border-color 0.3s;
  position: relative;
  overflow: hidden;
}

/* Glow corner accent */
.service-card::after {
  content: '';
  position: absolute;
  bottom: -30px; right: -30px;
  width: 120px; height: 120px;
  background: radial-gradient(circle, rgba(0,212,255,0.15) 0%, transparent 70%);
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
  border-radius: 50%;
}
.service-card:hover::after { opacity: 1; }

.service-card:hover {
  transform: translateY(-10px) scale(1.02) !important;
  border-color: var(--glass-border-accent) !important;
  box-shadow: var(--depth-xl), var(--glow-blue) !important;
}

/* Service icon */
.service-icon,
.service-card .icon-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  padding: 0.75rem;
  background: var(--glass-2);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(8px);
  transition: all 0.3s;
}
.service-card:hover .service-icon,
.service-card:hover .icon-wrapper {
  box-shadow: var(--glow-blue);
  border-color: var(--glass-border-accent);
}

/* ═══════════════════════════════════════════════════════════
   14. STATS / METRICS CARDS
   ═══════════════════════════════════════════════════════════ */
.scard,
.stat-card,
.metric-card,
.stats-card {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 14px !important;
  backdrop-filter: blur(16px);
  box-shadow: var(--depth-sm);
  padding: 1.25rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.scard:hover,
.stat-card:hover { border-color: var(--glass-border-accent) !important; }

/* Insight cards inside ARK dashboard */
.ov-insight { background: var(--glass-1) !important; border: 1px solid var(--glass-border) !important; border-radius: 12px !important; padding: 1rem; text-align: center; backdrop-filter: blur(10px); }
.ov-insight .val { font-size: 1.5rem; font-weight: 800; }
.ov-insight .lbl { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-top: 0.2rem; }

/* ═══════════════════════════════════════════════════════════
   15. SIDEBAR / SERVER MANAGE
   ═══════════════════════════════════════════════════════════ */
.sidebar,
[class*="sidebar"],
.sm-sidebar {
  background: rgba(8,11,20,0.9) !important;
  border-color: var(--glass-border) !important;
  backdrop-filter: blur(24px);
}

/* Tab system */
.tab-btn,
.tab-link,
[class*="tab-btn"] {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 10px !important;
  color: var(--text-secondary) !important;
  transition: all 0.2s;
}
.tab-btn:hover,
[class*="tab-btn"]:hover { background: var(--glass-2) !important; color: var(--text-primary) !important; }
.tab-btn.active,
[class*="tab-btn"].active {
  background: rgba(0,212,255,0.12) !important;
  border-color: rgba(0,212,255,0.35) !important;
  color: var(--neon-blue) !important;
  box-shadow: var(--glow-blue);
}

/* ═══════════════════════════════════════════════════════════
   16. NOTIFICATIONS / NOTI TOAST
   ═══════════════════════════════════════════════════════════ */
.noti,
.notification,
.toast,
#notiContainer > div {
  background: rgba(13,17,23,0.95) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 14px !important;
  backdrop-filter: blur(20px);
  box-shadow: var(--depth-lg);
  color: var(--text-primary) !important;
}

/* ═══════════════════════════════════════════════════════════
   17. CHARTS / CANVAS CONTAINERS
   ═══════════════════════════════════════════════════════════ */
.ov-chart-card,
[class*="chart-card"],
.chart-container {
  background: var(--glass-1) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(16px);
  padding: 1.25rem;
}
.ov-chart-title,
[class*="chart-title"] { font-size: 0.875rem; font-weight: 700; color: var(--text-primary); margin-bottom: 0.25rem; }
.ov-chart-sub,
[class*="chart-sub"] { font-size: 0.7rem; color: var(--text-muted); margin-bottom: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; }

/* ═══════════════════════════════════════════════════════════
   18. PAGE SECTIONS
   ═══════════════════════════════════════════════════════════ */
section { padding: 4rem 0; }

/* Section headings */
.section-title,
section h2,
.section h2 {
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  line-height: 1.15;
}

/* Divider line with gradient */
.section-divider,
hr {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--glass-border-accent), transparent);
  margin: 2rem 0;
}

/* ═══════════════════════════════════════════════════════════
   19. FOOTER
   ═══════════════════════════════════════════════════════════ */
footer {
  background: var(--space-900) !important;
  border-top: 1px solid var(--glass-border) !important;
  color: var(--text-secondary);
}
footer h4, footer h5 { color: var(--text-primary) !important; }
footer p, footer a { color: var(--text-secondary) !important; }
footer a:hover { color: var(--neon-cyan) !important; }

/* ═══════════════════════════════════════════════════════════
   20. PROGRESS BARS
   ═══════════════════════════════════════════════════════════ */
.progress,
[class*="progress-bar"],
progress {
  background: var(--glass-2);
  border-radius: 9999px;
  overflow: hidden;
  height: 6px;
}
.progress-fill,
.progress > * {
  background: var(--grad-blue-cyan);
  height: 100%;
  border-radius: 9999px;
  box-shadow: 0 0 8px rgba(0,212,255,0.5);
  transition: width 0.8s var(--ease-out);
}

/* ═══════════════════════════════════════════════════════════
   21. LEADERBOARD LIST ITEMS
   ═══════════════════════════════════════════════════════════ */
.litem {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: background 0.15s;
}
.litem:hover { background: rgba(0,212,255,0.04); }
.litem:last-child { border-bottom: none; }

/* Player avatar bubble */
.pav {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--grad-primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; font-weight: 700; color: #fff;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   22. MOBILE MENU & SIDEBAR OVERLAY
   ═══════════════════════════════════════════════════════════ */
#mobile-menu,
.mobile-sidebar,
.side-menu {
  background: rgba(8,11,20,0.97) !important;
  border-right: 1px solid var(--glass-border);
  backdrop-filter: blur(32px);
}

/* ═══════════════════════════════════════════════════════════
   23. TOGGLE SWITCHES
   ═══════════════════════════════════════════════════════════ */
.toggle-sw {
  width: 44px; height: 24px;
  border-radius: 9999px;
  background: var(--glass-2);
  border: 1px solid var(--glass-border);
  position: relative;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}
.toggle-sw::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--text-muted);
  transition: transform 0.25s var(--ease-spring), background 0.2s;
}
.toggle-sw.on {
  background: rgba(0,212,255,0.18);
  border-color: rgba(0,212,255,0.4);
}
.toggle-sw.on::after {
  transform: translateX(20px);
  background: var(--neon-blue);
  box-shadow: 0 0 8px rgba(0,212,255,0.6);
}

/* ═══════════════════════════════════════════════════════════
   24. NEON GLOW UTILITY CLASSES
   ═══════════════════════════════════════════════════════════ */
.glow-blue   { box-shadow: var(--glow-blue); }
.glow-violet { box-shadow: var(--glow-violet); }
.glow-cyan   { box-shadow: var(--glow-cyan); }
.glow-pink   { box-shadow: var(--glow-pink); }

.text-neon-blue   { color: var(--neon-blue)   !important; }
.text-neon-violet { color: var(--neon-violet) !important; }
.text-neon-cyan   { color: var(--neon-cyan)   !important; }
.text-neon-pink   { color: var(--neon-pink)   !important; }
.text-neon-green  { color: var(--neon-green)  !important; }

/* Gradient text shorthand */
.text-aurora { background: var(--grad-aurora); background-size:300% 300%; -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; animation: fu-gradient-shift 6s ease infinite; }
.text-cyber  { background: var(--grad-cyber);  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

/* ═══════════════════════════════════════════════════════════
   25. SKELETON LOADERS
   ═══════════════════════════════════════════════════════════ */
.skeleton {
  background: linear-gradient(90deg, var(--glass-1) 0%, var(--glass-2) 50%, var(--glass-1) 100%);
  background-size: 200% 100%;
  animation: fu-shimmer 1.5s ease-in-out infinite;
  border-radius: 8px;
}

/* ═══════════════════════════════════════════════════════════
   26. CHIP / TAG
   ═══════════════════════════════════════════════════════════ */
.chip,
.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.7rem;
  border-radius: 9999px;
  font-size: 0.7rem;
  font-weight: 600;
  background: var(--glass-2);
  border: 1px solid var(--glass-border);
  color: var(--text-secondary);
  transition: all 0.2s;
}
.chip:hover, .tag:hover { border-color: var(--glass-border-accent); color: var(--neon-cyan); }

/* ═══════════════════════════════════════════════════════════
   27. LANDING PAGE — NAVBAR OVERRIDE (index.ejs specific)
   ═══════════════════════════════════════════════════════════ */
.navbar {
  background: rgba(8,11,20,0.78) !important;
  backdrop-filter: blur(28px) saturate(200%);
  border-bottom: 1px solid var(--glass-border) !important;
  position: sticky; top: 0; z-index: 1030;
}

/* ═══════════════════════════════════════════════════════════
   28. ABTN (ARK action buttons)
   ═══════════════════════════════════════════════════════════ */
.abtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35rem 0.65rem;
  border-radius: 8px;
  font-size: 0.8rem;
  border: 1px solid var(--glass-border);
  background: var(--glass-1);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
}
.abtn:hover { background: var(--glass-2); color: var(--text-primary); border-color: var(--glass-border-accent); }
.abtn.dng { border-color: rgba(248,113,113,0.25); color: #f87171; }
.abtn.dng:hover { background: rgba(248,113,113,0.1); box-shadow: 0 0 12px rgba(248,113,113,0.3); }

/* ═══════════════════════════════════════════════════════════
   29. CARD HEADER (ch)
   ═══════════════════════════════════════════════════════════ */
.ch {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--glass-border);
  display: flex; align-items: center; gap: 0.5rem;
  background: rgba(255,255,255,0.02);
}
.ch h3 { font-size: 0.9rem; font-weight: 700; color: var(--text-primary); margin: 0; }

/* ═══════════════════════════════════════════════════════════
   30. RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  section { padding: 2.5rem 0; }
  .service-card { padding: 1.25rem; }
  .service-card:hover { transform: translateY(-4px) scale(1.01) !important; }
  .card, .dashboard-card { border-radius: 12px !important; }
  .btn-lg { padding: 0.75rem 1.5rem !important; }
  table { font-size: 0.8rem; }
  th, td { padding: 0.625rem 0.75rem; }
  /* Stack the 2-col feature + footer grids */
  [style*="grid-template-columns:1fr 1fr"][style*="gap:4rem"] { grid-template-columns: 1fr !important; gap: 2.5rem !important; }
  [style*="grid-template-columns:2fr 1fr 1fr 1fr"] { grid-template-columns: 1fr 1fr !important; gap: 1.5rem !important; }
}

@media (max-width: 480px) {
  .section-title, section h2 { font-size: 1.6rem; }
  .service-card { border-radius: 16px !important; }
}

/* ═══════════════════════════════════════════════════════════
   31. REDUCED MOTION
   ═══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.15ms !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   32. MISC HELPERS
   ═══════════════════════════════════════════════════════════ */
.glass-card {
  background: var(--glass-1);
  backdrop-filter: blur(20px) saturate(150%);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
  box-shadow: var(--depth-md);
}

.neon-border {
  border: 1px solid var(--glass-border-accent) !important;
  box-shadow: 0 0 0 1px rgba(0,212,255,0.08), var(--glow-blue);
}

.cyber-bg {
  background:
    linear-gradient(rgba(0,212,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,212,255,0.03) 1px, transparent 1px),
    var(--space-700);
  background-size: 40px 40px;
}

/* Action button groups */
.btn-group { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; }

/* Number/stat highlight */
.num, .big-num {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.slbl { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 0.25rem; }

/* Tiny "online" dot */
.online-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--neon-green);
  box-shadow: 0 0 6px var(--neon-green);
  display: inline-block;
  animation: fu-glow-pulse 2s ease-in-out infinite;
}
.offline-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #475569;
  display: inline-block;
}

/* Divider with label */
.divider-label {
  display: flex; align-items: center; gap: 0.75rem;
  color: var(--text-muted); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.08em;
}
.divider-label::before, .divider-label::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, var(--glass-border));
}
.divider-label::after { background: linear-gradient(270deg, transparent, var(--glass-border)); }

/* ═══════════════════════════════════════════════════════════
   33. GLOBAL TAILWIND DARK MODE OVERRIDES
   When html has class="dark", force all Tailwind bg-gray-*,
   text-gray-* classes to match the deep-space palette.
   ═══════════════════════════════════════════════════════════ */

/* ── Backgrounds ───────────────────────────────────────────── */
.dark .bg-white         { background-color: rgba(13,17,23,0.98)    !important; }
.dark .bg-white\/80     { background-color: rgba(8,11,20,0.85)     !important; }
.dark .bg-gray-50       { background-color: #0d1117               !important; }
.dark .bg-gray-100      { background-color: rgba(255,255,255,.05)  !important; }
.dark .bg-gray-200      { background-color: rgba(255,255,255,.07)  !important; }
.dark .bg-gray-700      { background-color: rgba(255,255,255,.07)  !important; }
.dark .bg-gray-800      { background-color: rgba(8,11,20,.9)       !important; }
.dark .bg-gray-900      { background-color: #060810               !important; }
.dark .bg-gray-900\/80  { background-color: rgba(6,8,16,.8)        !important; }
.dark .bg-gray-900\/95  { background-color: rgba(6,8,16,.95)       !important; }

/* ── Text ──────────────────────────────────────────────────── */
.dark .text-gray-800    { color: #f1f5f9  !important; }
.dark .text-gray-700    { color: #e2e8f0  !important; }
.dark .text-gray-600    { color: #94a3b8  !important; }
.dark .text-gray-500    { color: #64748b  !important; }
.dark .text-gray-400    { color: #64748b  !important; }
.dark .text-gray-300    { color: #94a3b8  !important; }

/* ── Borders ───────────────────────────────────────────────── */
.dark .border-gray-100  { border-color: rgba(255,255,255,.06) !important; }
.dark .border-gray-200  { border-color: rgba(255,255,255,.07) !important; }
.dark .border-gray-700  { border-color: rgba(255,255,255,.08) !important; }
.dark .border-gray-800  { border-color: rgba(255,255,255,.06) !important; }
.dark hr                { border-color: rgba(255,255,255,.06) !important; }

/* ── Hover states ──────────────────────────────────────────── */
.dark .hover\:bg-gray-50:hover  { background-color: rgba(0,212,255,.06) !important; }
.dark .hover\:bg-gray-200:hover { background-color: rgba(255,255,255,.08) !important; }
.dark .hover\:bg-gray-700:hover { background-color: rgba(0,212,255,.08) !important; color: #00d4ff !important; }
.dark .hover\:bg-red-50:hover   { background-color: rgba(248,113,113,.08) !important; }
.dark .hover\:bg-red-900\/20:hover { background-color: rgba(248,113,113,.1) !important; }

/* ── Navbars & fixed headers ───────────────────────────────── */
nav.fixed,
header.fixed nav,
.dark nav.fixed,
.dark nav[class*="bg-white"],
.dark nav[class*="bg-gray"] {
  background: rgba(8,11,20,0.88) !important;
  border-bottom: 1px solid rgba(0,212,255,.08) !important;
  backdrop-filter: blur(28px) saturate(200%) !important;
}

/* ── Dropdown menus ────────────────────────────────────────── */
.dark [class*="dropdown-content"] {
  background: rgba(8,11,20,0.97) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 12px !important;
}
.dark [class*="dropdown-content"] a,
.dark [class*="dropdown-content"] button {
  color: #94a3b8 !important;
}
.dark [class*="dropdown-content"] a:hover {
  background: rgba(0,212,255,.07) !important;
  color: #00d4ff !important;
}

/* ── Mobile side menu ──────────────────────────────────────── */
.dark #sideMenuContent,
.dark [id*="mobileMenu"] > div:last-child,
.dark [id*="sideMenu"] > div:last-child {
  background: rgba(6,8,16,0.99) !important;
  border-color: rgba(255,255,255,.07) !important;
}

/* ── Footer ────────────────────────────────────────────────── */
.dark footer,
footer.bg-gray-900,
.dark footer.bg-gray-900 {
  background-color: #060810 !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
}
.dark footer .border-gray-800 { border-color: rgba(255,255,255,.06) !important; }

/* ── Modals ────────────────────────────────────────────────── */
.dark [class*="modal-content"],
.dark [class*="modal_content"] {
  background: rgba(8,11,20,.98) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}

/* ═══════════════════════════════════════════════════════════
   34. ARK DASHBOARD — accent colour alignment
   ═══════════════════════════════════════════════════════════ */
/* Replace orange #ff6b35 accent with neon blue */
.period-tab.active { background: var(--neon-blue) !important; box-shadow: 0 0 16px rgba(0,212,255,.35) !important; }
.search-input:focus { border-color: var(--neon-blue) !important; box-shadow: 0 0 0 3px rgba(0,212,255,.12) !important; }

/* ── Stat cards accent ─────────────────────────────────────── */
.stat-card { border-color: rgba(0,212,255,.15) !important; }
.stat-card:hover { border-color: rgba(0,212,255,.4) !important; box-shadow: 0 10px 40px rgba(0,212,255,.15) !important; }

/* ── Chart cards accent bars ───────────────────────────────── */
.chart-card.orange::before { background: linear-gradient(90deg,#00d4ff,#8b5cf6) !important; }

/* ═══════════════════════════════════════════════════════════
   35. ARK SERVERS PAGE — hero & filter enhancements
   ═══════════════════════════════════════════════════════════ */
/* Futuristic filter tabs */
.filter-btn {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: #64748b !important;
  transition: all .25s !important;
}
.filter-btn:hover {
  background: rgba(0,212,255,.07) !important;
  border-color: rgba(0,212,255,.25) !important;
  color: #00d4ff !important;
}
.filter-btn.active {
  background: linear-gradient(135deg,rgba(0,212,255,.15),rgba(139,92,246,.15)) !important;
  border-color: rgba(0,212,255,.4) !important;
  color: #00d4ff !important;
  box-shadow: 0 0 20px rgba(0,212,255,.2) !important;
}

/* CTA buttons in ark-servers */
.dark a[href*="discord.gg"] {
  box-shadow: 0 0 20px rgba(88,101,242,.3);
  transition: box-shadow .3s, transform .2s !important;
}
.dark a[href*="discord.gg"]:hover { box-shadow: 0 0 30px rgba(88,101,242,.5) !important; }

/* ═══════════════════════════════════════════════════════════
   36. SERVER MODS PAGE — quick actions
   ═══════════════════════════════════════════════════════════ */
/* Quick action buttons */
.dark button[onclick*="copy"],
.dark button[onclick*="download"],
.dark button[onclick*="subscribe"] {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 10px !important;
  color: #94a3b8 !important;
  transition: all .2s !important;
}
.dark button[onclick*="copy"]:hover,
.dark button[onclick*="download"]:hover,
.dark button[onclick*="subscribe"]:hover {
  background: rgba(0,212,255,.08) !important;
  border-color: rgba(0,212,255,.25) !important;
  color: #00d4ff !important;
}

/* Mod image placeholder bg */
.dark .dark\:bg-gray-800 { background-color: rgba(8,11,20,.9) !important; }
