/* ==========================================================================
   A-NET ONLINE — full re-skin of webv4
   Auto-loaded by root/index.xjs when this file exists.
   Loaded LAST, after bootstrap.min.css, offcanvas.css, style.css, checkbox.css.
   Targets BS3 markup directly so unmodified stock pages also re-skin.
   ========================================================================== */

:root {
  --anet-bg-0: #08090f;
  --anet-bg-1: #0c0e18;
  --anet-bg-2: #11142a;
  --anet-card-1: #1a1d2e;
  --anet-card-2: #1f2147;
  --anet-card-3: #2a2d6e;
  --anet-line: rgba(0, 255, 234, 0.14);
  --anet-line-strong: rgba(0, 255, 234, 0.32);
  --anet-text: #e7ecf3;
  --anet-text-dim: #9aa3c4;
  --anet-text-muted: #6f7895;
  --anet-cyan: #00ffea;
  --anet-green: #39ff14;
  --anet-purple: #b56cff;
  --anet-pink: #ff4fa3;
  --anet-yellow: #ffd166;
  --anet-shadow-glow: 0 0 24px rgba(0, 255, 234, 0.18), 0 6px 30px rgba(0, 0, 0, 0.55);
  --anet-radius: 14px;
  --anet-radius-sm: 9px;
  --anet-font-display: 'Inter', 'Segoe UI', Roboto, system-ui, -apple-system, sans-serif;
  --anet-font-mono: 'JetBrains Mono', 'Fira Code', 'Source Code Pro', Menlo, Consolas, monospace;
}

/* ----- Global reset / base ----- */
html, body {
  background: radial-gradient(1200px 700px at 12% -10%, rgba(0, 255, 234, 0.06), transparent 60%),
              radial-gradient(900px 600px at 90% 0%, rgba(181, 108, 255, 0.06), transparent 60%),
              linear-gradient(180deg, #06070d 0%, #0a0c1a 40%, #0a0c1a 100%) !important;
  background-attachment: fixed !important;
  color: var(--anet-text);
  font-family: var(--anet-font-display);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Override any per-page background-image hack from old home page */
body { background-image: none !important; background-size: cover !important; }

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

/* Scrollbar */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: rgba(255, 255, 255, 0.02); }
*::-webkit-scrollbar-thumb { background: rgba(0, 255, 234, 0.18); border-radius: 8px; }
*::-webkit-scrollbar-thumb:hover { background: rgba(0, 255, 234, 0.34); }

/* Headings */
h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6 {
  color: #f4f7ff;
  font-family: var(--anet-font-display);
  letter-spacing: -0.01em;
}
h1, .h1 { font-weight: 800; letter-spacing: -0.02em; }
h2, .h2 { font-weight: 700; }
h3, .h3 { font-weight: 700; }

/* Links */
a { color: var(--anet-cyan); transition: color .18s ease, text-shadow .18s ease; }
a:hover, a:focus { color: #baffff; text-shadow: 0 0 10px rgba(0, 255, 234, 0.5); text-decoration: none; }

hr { border-color: var(--anet-line); }

/* ==========================================================================
   TOP STRIP (mods/components/header.xjs branded social row)
   The strip is fixed at top:0 and the navbar is offset down by its height
   so they stack cleanly. Hidden on very narrow screens to save vertical space.
   ========================================================================== */
.anet-topstrip {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1042;
  background: linear-gradient(90deg, rgba(8,9,15,.94) 0%, rgba(17,20,42,.94) 100%);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--anet-line);
  padding: 6px 14px;
  height: 34px;
  box-sizing: border-box;
}
.anet-topstrip-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
  align-items: center;
  justify-content: flex-end;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.anet-topstrip-link {
  color: var(--anet-text-dim);
  text-decoration: none;
  padding: 2px 6px;
  border-radius: 6px;
  transition: color .15s ease, background .15s ease;
}
.anet-topstrip-link:hover { color: var(--anet-cyan); background: rgba(0,255,234,.06); text-shadow: none; }

/* ==========================================================================
   NAVBAR (override BS3 navbar-default look)
   ========================================================================== */
.navbar.anet-navbar,
.navbar-default {
  background: linear-gradient(90deg, rgba(10,12,26,.92) 0%, rgba(20,23,55,.92) 100%) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 0 !important;
  border-bottom: 1px solid var(--anet-line) !important;
  border-radius: 0 !important;
  margin-bottom: 0 !important;
  min-height: 60px !important;
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.55);
}
/* offset fixed navbar by topstrip height */
.navbar-default.navbar-fixed-top,
.navbar.anet-navbar.navbar-fixed-top { top: 34px !important; }

.navbar.anet-navbar .navbar-brand,
.navbar-default .navbar-brand {
  color: #fff !important;
  font-weight: 800;
  letter-spacing: 0.02em;
  font-size: 18px;
  height: auto;
  padding: 18px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.navbar.anet-navbar .navbar-brand:hover,
.navbar-default .navbar-brand:hover {
  color: var(--anet-cyan) !important;
  text-shadow: 0 0 12px rgba(0,255,234,.55);
}

/* Brand mark — pixel-A SVG. Auto-glow via drop-shadow filter on hover. */
.anet-brand-mark {
  width: 32px; height: 32px;
  display: inline-block;
  filter: drop-shadow(0 0 6px rgba(0, 255, 234, 0.45));
  transition: filter .2s ease, transform .2s ease;
}
.navbar-brand:hover .anet-brand-mark {
  filter: drop-shadow(0 0 12px rgba(0, 255, 234, 0.85));
  transform: scale(1.05);
}

.navbar-default .navbar-nav > li > a {
  color: var(--anet-text-dim) !important;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.02em;
  padding: 22px 14px !important;
  position: relative;
  transition: color .15s ease;
}
/* Hover/focus/open — must override BS3 .navbar-default { color:#555; bg:#e7e7e7 }
   for the right-side items (Dark / Register / Login) so they don't go
   white-on-near-white. Every selector permutation, including .navbar-right
   nested forms. */
.navbar-default .navbar-nav > li > a,
.navbar-default .navbar-nav > li > a:link,
.navbar-default .navbar-nav > li > a:visited {
  color: var(--anet-text-dim) !important;
  background: transparent !important;
}
.navbar-default .navbar-nav > li > a:hover,
.navbar-default .navbar-nav > li > a:focus,
.navbar-default .navbar-nav > li > a:active,
.navbar-default .navbar-nav > li.active > a,
.navbar-default .navbar-nav > li.active > a:hover,
.navbar-default .navbar-nav > li.active > a:focus,
.navbar-default .navbar-nav > li.open > a,
.navbar-default .navbar-nav > li.open > a:hover,
.navbar-default .navbar-nav > li.open > a:focus,
.navbar-default .navbar-nav.navbar-right > li > a:hover,
.navbar-default .navbar-nav.navbar-right > li > a:focus,
.navbar-default .navbar-nav.navbar-right > li.open > a,
.navbar-default .navbar-nav.navbar-right > li.open > a:hover,
.navbar-default .navbar-nav.navbar-right > li.open > a:focus {
  color: var(--anet-cyan) !important;
  background: rgba(0, 255, 234, 0.08) !important;
  text-shadow: 0 0 10px rgba(0, 255, 234, 0.4);
}

.navbar-default .navbar-nav > li > a::after {
  content: "";
  position: absolute;
  left: 14px; right: 14px; bottom: 14px;
  height: 2px;
  background: linear-gradient(90deg, var(--anet-cyan), var(--anet-purple));
  border-radius: 2px;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}
.navbar-default .navbar-nav > li > a:hover::after,
.navbar-default .navbar-nav > .active > a::after,
.navbar-default .navbar-nav > .open > a::after { transform: scaleX(1); }

/* Dark-mode toggle label inside the navbar — keep readable on hover too */
.navbar .dark-switch label,
.navbar .dark-switch .checkbox label {
  color: var(--anet-text-dim) !important;
}
.navbar .dark-switch:hover label,
.navbar .dark-switch label:hover {
  color: var(--anet-cyan) !important;
}

/* checkbox.css ships the toggle pill with `background: rgb(255,255,255)` and
   the moving knob also white. Reskin to brand colors so nothing in the navbar
   ever shows a hard white block. */
.checkbox.checbox-switch label span,
.checkbox-inline.checbox-switch span {
  background-color: rgba(255, 255, 255, 0.06) !important;
  border-color: var(--anet-line-strong) !important;
  box-shadow: rgba(0, 255, 234, 0.0) 0 0 0 0 inset !important;
}
.checkbox.checbox-switch label span:before,
.checkbox-inline.checbox-switch span:before {
  background: linear-gradient(135deg, var(--anet-cyan), #00b4ff) !important;
  box-shadow: 0 0 8px rgba(0, 255, 234, 0.55) !important;
}
.checkbox.checbox-switch label > input:checked + span,
.checkbox-inline.checbox-switch > input:checked + span {
  background-color: rgba(0, 255, 234, 0.16) !important;
  border-color: var(--anet-cyan) !important;
  box-shadow: rgba(0, 255, 234, 0.18) 0 0 0 8px inset !important;
}

/* Defensive: any element inside the navbar that BS3 / external CSS sets to a
   hard white background gets neutralized. Targets only `background-color` so
   our intentional translucent cyan hovers still work. */
.navbar-default *[style*="background:#fff"],
.navbar-default *[style*="background-color:#fff"],
.navbar-default *[style*="background: #fff"],
.navbar-default *[style*="background-color: #fff"] {
  background-color: transparent !important;
}
.navbar-default a,
.navbar-default a:link,
.navbar-default a:visited {
  background-color: transparent !important;
}

/* Dropdown menus */
.dropdown-menu,
.anet-dropdown {
  background: linear-gradient(180deg, #14172a 0%, #0e1020 100%) !important;
  border: 1px solid var(--anet-line) !important;
  border-radius: var(--anet-radius-sm) !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.6), 0 0 0 1px var(--anet-line);
  padding: 6px !important;
  min-width: 200px;
}
.dropdown-menu > li > a,
.dropdown-menu .dropdown-item {
  color: var(--anet-text) !important;
  border-radius: 6px;
  padding: 8px 12px !important;
  font-weight: 500;
}
.dropdown-menu > li > a:hover,
.dropdown-menu > li > a:focus,
.dropdown-menu .dropdown-item:hover {
  background: rgba(0, 255, 234, 0.08) !important;
  color: var(--anet-cyan) !important;
}

/* User chip in navbar */
.anet-user { display: flex !important; align-items: center; gap: 8px; }
.anet-user-avatar {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--anet-cyan), var(--anet-purple));
  color: #06070d;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  box-shadow: 0 0 12px rgba(0, 255, 234, 0.35);
}

/* Login form in dropdown */
.anet-login-form input.form-control,
.anet-input {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid var(--anet-line) !important;
  color: var(--anet-text) !important;
  border-radius: 8px !important;
  margin-bottom: 8px !important;
}
.anet-login-form input.form-control:focus,
.anet-input:focus {
  outline: none;
  border-color: var(--anet-cyan) !important;
  box-shadow: 0 0 0 3px rgba(0, 255, 234, 0.16) !important;
}

/* Badge */
.badge.scanned, .anet-badge {
  background: linear-gradient(135deg, var(--anet-cyan), var(--anet-purple)) !important;
  color: #06070d !important;
  font-weight: 800;
  border-radius: 999px;
  padding: 2px 7px;
  font-size: 11px;
}

/* Toggle button (mobile hamburger) */
.navbar-default .navbar-toggle {
  border: 1px solid var(--anet-line) !important;
  background: rgba(0, 255, 234, 0.06) !important;
}
.navbar-default .navbar-toggle .icon-bar { background: var(--anet-cyan) !important; }

/* Dark switch in navbar */
.dark-switch label { color: var(--anet-text-dim); }

/* Push body content below fixed top-strip (34px) + fixed navbar (60px) */
body { padding-top: 94px; }

/* ==========================================================================
   BUTTONS (override BS3 + add .anet-btn variants)
   ========================================================================== */
.btn,
.anet-btn {
  border-radius: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.01em;
  padding: 10px 18px !important;
  border: 1px solid var(--anet-line) !important;
  background: rgba(255, 255, 255, 0.04) !important;
  color: var(--anet-text) !important;
  transition: transform .12s ease, box-shadow .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn:hover, .btn:focus, .anet-btn:hover, .anet-btn:focus {
  background: rgba(0, 255, 234, 0.08) !important;
  color: var(--anet-cyan) !important;
  border-color: var(--anet-line-strong) !important;
  box-shadow: 0 6px 20px rgba(0, 255, 234, 0.15);
  transform: translateY(-1px);
}

.btn-primary,
.anet-btn-primary {
  background: linear-gradient(135deg, var(--anet-cyan) 0%, #00b4ff 100%) !important;
  color: #06070d !important;
  border: 0 !important;
  box-shadow: 0 8px 24px rgba(0, 255, 234, 0.28), inset 0 -2px 0 rgba(0,0,0,.18);
}
.btn-primary:hover, .anet-btn-primary:hover,
.btn-primary:focus, .anet-btn-primary:focus {
  background: linear-gradient(135deg, #5cffe8 0%, #4cc8ff 100%) !important;
  color: #06070d !important;
  box-shadow: 0 12px 36px rgba(0, 255, 234, 0.42);
}

.btn-default { background: rgba(255, 255, 255, 0.04) !important; }

.anet-btn-ghost {
  background: transparent !important;
  border: 1px solid var(--anet-line-strong) !important;
  color: var(--anet-text) !important;
}
.anet-btn-ghost:hover { background: rgba(0, 255, 234, 0.08) !important; color: var(--anet-cyan) !important; }

/* ==========================================================================
   HERO (home page)
   ========================================================================== */
.anet-hero {
  position: relative;
  border-radius: var(--anet-radius);
  overflow: hidden;
  padding: clamp(36px, 7vw, 84px) clamp(20px, 4vw, 56px);
  margin: 6px 0 28px;
  border: 1px solid var(--anet-line);
  background:
    radial-gradient(800px 320px at 80% 0%, rgba(181,108,255,0.18), transparent 60%),
    radial-gradient(640px 320px at 0% 100%, rgba(0,255,234,0.16), transparent 60%),
    linear-gradient(160deg, #0d1124 0%, #14183a 60%, #1a1f55 100%);
  box-shadow: var(--anet-shadow-glow);
}
.anet-hero-bg, .anet-hero-grid {
  position: absolute; inset: 0; pointer-events: none;
}
.anet-hero-grid {
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: radial-gradient(60% 70% at 50% 30%, #000 0%, transparent 100%);
  -webkit-mask-image: radial-gradient(60% 70% at 50% 30%, #000 0%, transparent 100%);
  opacity: .6;
}
.anet-hero-content { position: relative; z-index: 1; max-width: 880px; }
.anet-hero-eyebrow {
  display: inline-block;
  font-family: var(--anet-font-mono);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--anet-cyan);
  text-shadow: 0 0 12px rgba(0,255,234,0.5);
  padding: 4px 10px;
  border: 1px solid var(--anet-line-strong);
  border-radius: 999px;
  margin-bottom: 18px;
}
.anet-hero-title {
  font-size: clamp(32px, 5vw, 56px);
  line-height: 1.05;
  margin: 0 0 16px;
  color: #fff;
}
.anet-hero-accent {
  background: linear-gradient(90deg, var(--anet-cyan), #4cc8ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.anet-hero-accent2 {
  background: linear-gradient(90deg, var(--anet-purple), var(--anet-pink));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.anet-hero-tagline { font-size: clamp(15px, 1.6vw, 18px); color: var(--anet-text-dim); margin: 0 0 24px; max-width: 60ch; }
.anet-hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 24px; }
.anet-hero-meta { display: flex; flex-wrap: wrap; gap: 14px 22px; font-family: var(--anet-font-mono); font-size: 13px; color: var(--anet-text-muted); }
.anet-hero-stat strong { color: var(--anet-green); margin-right: 6px; }

/* ==========================================================================
   FEATURE GRID (home)
   ========================================================================== */
.anet-feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  margin: 0 0 28px;
}
.anet-feature {
  display: block;
  text-decoration: none;
  padding: 22px 20px;
  border-radius: var(--anet-radius);
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%);
  border: 1px solid var(--anet-line);
  color: var(--anet-text);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
  position: relative;
  overflow: hidden;
}
.anet-feature::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(420px 220px at 0% 0%, rgba(0,255,234,0.10), transparent 60%);
  opacity: 0; transition: opacity .25s ease;
}
.anet-feature:hover {
  transform: translateY(-4px);
  border-color: var(--anet-line-strong);
  box-shadow: 0 14px 38px rgba(0, 0, 0, 0.55), 0 0 0 1px var(--anet-line-strong);
  text-shadow: none;
}
.anet-feature:hover::before { opacity: 1; }
.anet-feature h3 { margin: 0 0 6px; font-size: 18px; color: #fff; }
.anet-feature p { margin: 0; color: var(--anet-text-dim); font-size: 14px; }
.anet-feature-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(0,255,234,0.18), rgba(181,108,255,0.18));
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  margin-bottom: 14px;
  border: 1px solid var(--anet-line);
}

/* ==========================================================================
   SECTIONS (home modules)
   ========================================================================== */
.anet-section {
  margin: 0 0 28px;
  padding: 22px;
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%);
  border: 1px solid var(--anet-line);
  border-radius: var(--anet-radius);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.45);
}
.anet-section-head { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 14px; flex-wrap: wrap; }
.anet-section-head h2 { margin: 0; font-size: 22px; }
.anet-section-sub { color: var(--anet-text-muted); font-size: 13px; font-family: var(--anet-font-mono); }

/* Live pulse indicator */
.anet-live-pulse {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--anet-pink); margin-left: 6px; vertical-align: middle;
  box-shadow: 0 0 8px var(--anet-pink);
  animation: anet-pulse-soft 1.6s ease-in-out infinite;
}
@keyframes anet-pulse-soft { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: .5; transform: scale(1.3); } }

/* Radio iframe */
.anet-radio-frame {
  border-radius: 10px;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--anet-line);
}
.anet-radio-frame iframe { width: 100%; height: 700px; border: 0; display: block; }
.anet-radio-fallback { display: none; margin-top: 12px; text-align: center; }
.anet-radio-fallback audio { width: 100%; max-width: 880px; border-radius: 8px; }

/* ==========================================================================
   TERMINAL FRAME (around fTelnet)
   ========================================================================== */
.anet-terminal-frame {
  border-radius: 10px;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--anet-line);
  box-shadow: inset 0 0 60px rgba(0, 255, 234, 0.04);
}
.anet-terminal-chrome {
  display: flex; align-items: center; gap: 8px;
  background: linear-gradient(180deg, #1a1d2e, #11142a);
  padding: 8px 12px;
  border-bottom: 1px solid var(--anet-line);
  font-family: var(--anet-font-mono);
  font-size: 12px;
  color: var(--anet-text-dim);
}
.anet-term-dot { width: 11px; height: 11px; border-radius: 50%; box-shadow: inset 0 0 4px rgba(0,0,0,.5); }
.anet-term-dot-r { background: #ff5f56; }
.anet-term-dot-y { background: #ffbd2e; }
.anet-term-dot-g { background: #27c93f; }
.anet-term-title { margin-left: 8px; }
.anet-connect-btnrow { display: flex; justify-content: center; margin: 18px 0 4px; }
.fTelnetContainer { background: #000 !important; }

/* ==========================================================================
   QUICKLINKS (home)
   ========================================================================== */
.anet-ql-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.anet-ql-card {
  display: block;
  padding: 16px 18px;
  border-radius: var(--anet-radius-sm);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--anet-line);
  text-decoration: none;
  color: var(--anet-text);
  position: relative;
  transition: border-color .18s ease, transform .12s ease, background .18s ease;
}
.anet-ql-card:hover { transform: translateY(-2px); border-color: var(--anet-line-strong); background: rgba(0,255,234,0.05); text-shadow: none; }
.anet-ql-tag {
  display: inline-block;
  font-family: var(--anet-font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--anet-green);
  margin-bottom: 6px;
  text-transform: uppercase;
}
.anet-ql-title { font-size: 15px; font-weight: 600; color: #fff; }
.anet-ql-arrow { position: absolute; right: 16px; top: 50%; transform: translateY(-50%); color: var(--anet-cyan); font-size: 18px; opacity: .8; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.anet-footer {
  margin-top: 40px;
  padding: 28px 22px 18px;
  background: linear-gradient(180deg, rgba(10,12,26,.6), rgba(8,9,15,.95));
  border-top: 1px solid var(--anet-line);
  border-radius: var(--anet-radius);
}
.anet-footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 1.4fr 1fr 1.2fr;
  gap: 18px;
  align-items: center;
}
.anet-footer-brand { display: flex; align-items: center; gap: 10px; }
.anet-footer-mark {
  width: 36px; height: 36px;
  display: inline-block;
  filter: drop-shadow(0 0 8px rgba(0, 255, 234, 0.5));
}
.anet-footer-name { font-weight: 800; letter-spacing: .02em; font-size: 16px; color: #fff; }
.anet-footer-links, .anet-footer-social {
  display: flex; flex-wrap: wrap; gap: 6px 14px; font-size: 13px;
}
.anet-footer-links a, .anet-footer-social a { color: var(--anet-text-dim); text-decoration: none; }
.anet-footer-links a:hover, .anet-footer-social a:hover { color: var(--anet-cyan); }
.anet-footer-meta { font-family: var(--anet-font-mono); font-size: 12px; color: var(--anet-text-muted); display: flex; flex-direction: column; gap: 4px; text-align: right; }

@media (max-width: 880px) {
  .anet-footer-inner { grid-template-columns: 1fr 1fr; }
  .anet-footer-meta { text-align: left; }
}
@media (max-width: 520px) {
  .anet-footer-inner { grid-template-columns: 1fr; }
}

/* Hide the bare `<p>&copy; ...</p>` fallback if it slipped in */
footer > p:only-child { color: var(--anet-text-muted); font-size: 12px; text-align: center; }

/* ==========================================================================
   GENERIC PAGE WIDGETS  (forum / files / mail / games inherit these)
   ========================================================================== */

/* Container background already handled via body bg */
.container, .container-fluid { color: var(--anet-text); }

/* Page title (breadcrumb area) */
.breadcrumb {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid var(--anet-line);
  border-radius: var(--anet-radius-sm) !important;
  padding: 10px 14px !important;
  margin-bottom: 16px !important;
  color: var(--anet-text-dim);
}
.breadcrumb a { color: var(--anet-cyan); }
.breadcrumb > .active { color: #fff !important; }

/* Panels (BS3) */
.panel {
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%) !important;
  border: 1px solid var(--anet-line) !important;
  border-radius: var(--anet-radius) !important;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.45);
  color: var(--anet-text);
}
.panel-default > .panel-heading,
.panel-heading {
  background: rgba(0,255,234,0.06) !important;
  border-bottom: 1px solid var(--anet-line) !important;
  color: #fff !important;
  border-radius: var(--anet-radius) var(--anet-radius) 0 0 !important;
}
.panel-body { background: transparent !important; color: var(--anet-text); }
.panel-footer { background: rgba(0,0,0,0.25) !important; border-top: 1px solid var(--anet-line) !important; color: var(--anet-text-dim) !important; }

/* List groups (forum lists, mail) */
.list-group { border-radius: var(--anet-radius) !important; overflow: hidden; }
.list-group-item {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid var(--anet-line) !important;
  color: var(--anet-text) !important;
  padding: 12px 14px !important;
  transition: background .15s ease, border-color .15s ease;
}
.list-group-item + .list-group-item { border-top-width: 0 !important; }
a.list-group-item { color: var(--anet-text) !important; }
a.list-group-item:hover, a.list-group-item:focus, li.list-group-item.mail:hover {
  background: rgba(0, 255, 234, 0.06) !important;
  color: var(--anet-cyan) !important;
  border-color: var(--anet-line-strong) !important;
  text-shadow: none;
}
a.list-group-item.scanned, .scanned { color: var(--anet-cyan) !important; }
a.unread { background: rgba(0, 255, 234, 0.08) !important; }
a.read { background: rgba(255, 255, 255, 0.02) !important; color: var(--anet-text-muted) !important; }

/* Tables */
.table { color: var(--anet-text); }
.table > thead > tr > th { color: var(--anet-cyan); border-bottom-color: var(--anet-line) !important; }
.table > tbody > tr > td, .table > tbody > tr > th { border-color: var(--anet-line) !important; }
.table-striped > tbody > tr:nth-child(odd) > td,
.table-striped > tbody > tr:nth-child(odd) > th,
.striped:nth-of-type(even) { background: rgba(255, 255, 255, 0.025) !important; }
.table-hover > tbody > tr:hover { background: rgba(0, 255, 234, 0.05) !important; }

/* Forms */
.form-control, input[type="text"], input[type="password"], input[type="email"], input[type="number"], input[type="search"], select, textarea {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid var(--anet-line) !important;
  color: var(--anet-text) !important;
  border-radius: 8px !important;
  box-shadow: none !important;
}
.form-control:focus, textarea:focus, input:focus, select:focus {
  border-color: var(--anet-cyan) !important;
  box-shadow: 0 0 0 3px rgba(0, 255, 234, 0.16) !important;
  outline: none !important;
}
label { color: var(--anet-text-dim); }

/* Modals */
.modal-content {
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%) !important;
  border: 1px solid var(--anet-line) !important;
  border-radius: var(--anet-radius) !important;
  color: var(--anet-text) !important;
  box-shadow: 0 24px 64px rgba(0,0,0,.6);
}
.modal-header { border-bottom-color: var(--anet-line) !important; }
.modal-footer { border-top-color: var(--anet-line) !important; }

/* ==========================================================================
   SIDEBAR — collapsible glass panels (anet-enhance.js wraps each widget)
   Hard-overrides BS3 list-group whiteness for every nested element.
   ========================================================================== */
#sidebar, .anet-sidebar { padding-top: 8px; }
#sidebar h4 { color: var(--anet-cyan); }

/* Each widget gets wrapped in .anet-sb-panel by anet-enhance.js */
.anet-sb-panel {
  background: linear-gradient(160deg, rgba(26,29,46,0.85) 0%, rgba(31,33,71,0.85) 100%);
  border: 1px solid var(--anet-line);
  border-radius: var(--anet-radius);
  margin-bottom: 14px;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255,255,255,0.04);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: border-color .2s ease, box-shadow .2s ease;
}
.anet-sb-panel:hover { border-color: var(--anet-line-strong); box-shadow: 0 10px 34px rgba(0, 0, 0, 0.55), 0 0 0 1px var(--anet-line-strong); }

.anet-sb-panel-head {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 12px 14px;
  background: linear-gradient(90deg, rgba(0,255,234,0.08) 0%, rgba(181,108,255,0.06) 100%);
  border: 0;
  border-bottom: 1px solid var(--anet-line);
  color: #fff;
  cursor: pointer;
  font-family: var(--anet-font-display);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-align: left;
  transition: background .2s ease;
}
.anet-sb-panel-head:hover { background: linear-gradient(90deg, rgba(0,255,234,0.14) 0%, rgba(181,108,255,0.10) 100%); }
.anet-sb-panel-title { color: var(--anet-cyan); text-shadow: 0 0 10px rgba(0,255,234,0.35); }
.anet-sb-panel-chev {
  color: var(--anet-cyan);
  font-size: 12px;
  transition: transform .25s ease;
}
.anet-sb-panel.is-collapsed .anet-sb-panel-chev { transform: rotate(-90deg); }

.anet-sb-panel-body {
  padding: 14px;
  background: rgba(8, 9, 15, 0.3);
  max-height: 4000px;
  transition: max-height .3s ease, padding .3s ease, opacity .25s ease;
  overflow: hidden;
}
.anet-sb-panel.is-collapsed .anet-sb-panel-body { max-height: 0; padding-top: 0; padding-bottom: 0; opacity: 0; }

/* Force-kill any white BS3 backgrounds anywhere inside the sidebar */
#sidebar h4,
#sidebar h5,
#sidebar h6 {
  color: var(--anet-cyan) !important;
  background: transparent !important;
  text-shadow: 0 0 10px rgba(0,255,234,0.25);
}
#sidebar table,
#sidebar .table,
#sidebar .table tbody,
#sidebar .table thead,
#sidebar .table tr,
#sidebar .table td,
#sidebar .table th,
#sidebar .list-group,
#sidebar .list-group-item,
#sidebar .panel,
#sidebar .panel-body,
#sidebar div[style*="background"] {
  background: transparent !important;
  background-image: none !important;
  border-color: rgba(0,255,234,0.10) !important;
  color: var(--anet-text) !important;
}
#sidebar .table-striped > tbody > tr:nth-child(odd) > td,
#sidebar .table-striped > tbody > tr:nth-child(odd) > th {
  background: rgba(255,255,255,0.025) !important;
}
#sidebar .table > tbody > tr > td,
#sidebar .table > tbody > tr > th {
  border-color: rgba(0,255,234,0.10) !important;
  padding: 6px 8px !important;
  font-size: 13px;
}
#sidebar .table > thead > tr > th {
  color: var(--anet-cyan) !important;
  border-bottom-color: var(--anet-line-strong) !important;
}
#sidebar .list-group-item {
  background: rgba(255,255,255,0.025) !important;
  border-color: rgba(0,255,234,0.08) !important;
  border-radius: 8px !important;
  margin-bottom: 6px !important;
  padding: 10px 12px !important;
}
#sidebar .list-group-item:hover {
  background: rgba(0,255,234,0.08) !important;
  border-color: var(--anet-line-strong) !important;
  color: #fff !important;
}

/* Sidebar imagery */
#sidebar img {
  border-radius: 10px;
  max-width: 100%;
  height: auto;
}

/* Tighten heading spacing inside legacy widgets */
#sidebar .anet-sb-panel-body > h4:first-child,
#sidebar .anet-sb-panel-body > h5:first-child {
  margin-top: 0;
}

/* Old inline-style widgets shipped from sidebar/*.xjs use linear-gradient
   backgrounds directly. Override their inline-style backgrounds via attribute
   selector tricks — works for the gradient strings the user has hardcoded. */
#sidebar [style*="linear-gradient"] {
  background: rgba(255,255,255,0.02) !important;
  border-radius: var(--anet-radius-sm) !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Sidebar list-group host: kill the BS3 list border so the panels stand alone */
#sidebar ul.list-group {
  background: transparent !important;
  border: 0 !important;
  margin-bottom: 0;
}
#sidebar li.list-group-item.sidebar {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 0 14px !important;
}
#sidebar li.list-group-item.sidebar:empty { display: none !important; }

/* MRC stats widget (mods/sidebar/004-mrcstats.xjs) */
.anet-mrc-grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.anet-mrc-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--anet-line);
  border-radius: 8px;
  font-family: var(--anet-font-mono);
  font-size: 13px;
}
.anet-mrc-label { color: var(--anet-text-dim); letter-spacing: 0.04em; text-transform: uppercase; font-size: 11px; }
.anet-mrc-value {
  color: var(--anet-green);
  font-weight: 800;
  font-size: 16px;
  text-shadow: 0 0 8px rgba(57,255,20,0.4);
}
.anet-mrc-foot {
  margin-top: 6px;
  font-family: var(--anet-font-mono);
  font-size: 11px;
  color: var(--anet-text-muted);
  text-align: right;
}

/* Blockquote (forum messages) */
blockquote {
  background: rgba(0, 255, 234, 0.04);
  border-left: 4px solid var(--anet-line-strong) !important;
  color: var(--anet-text-dim);
  border-radius: 8px;
  padding: 10px 14px !important;
}
div.message {
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--anet-line);
  border-radius: var(--anet-radius-sm);
  padding: 14px;
  margin: 12px 0;
}

/* Pagination */
.pagination > li > a, .pagination > li > span {
  background: rgba(255, 255, 255, 0.03) !important;
  border-color: var(--anet-line) !important;
  color: var(--anet-text) !important;
}
.pagination > .active > a, .pagination > .active > span,
.pagination > .active > a:hover, .pagination > .active > span:hover {
  background: var(--anet-cyan) !important;
  color: #06070d !important;
  border-color: var(--anet-cyan) !important;
}
.pagination > li > a:hover { background: rgba(0,255,234,0.08) !important; color: var(--anet-cyan) !important; }

/* Alerts */
.alert {
  border-radius: var(--anet-radius-sm) !important;
  border: 1px solid var(--anet-line) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  color: var(--anet-text);
}
.alert-info    { border-left: 4px solid var(--anet-cyan) !important; }
.alert-success { border-left: 4px solid var(--anet-green) !important; }
.alert-warning { border-left: 4px solid var(--anet-yellow) !important; }
.alert-danger  { border-left: 4px solid var(--anet-pink) !important; }

/* Glyphicons (BS3) — keep visible */
.glyphicon { color: inherit; }

/* Pre/code */
pre, code, kbd, samp {
  font-family: var(--anet-font-mono);
  background: rgba(0, 0, 0, 0.4) !important;
  border: 1px solid var(--anet-line);
  border-radius: 6px;
  color: var(--anet-cyan);
}
pre.ansi { background: #000 !important; }

/* ==========================================================================
   DARK MODE — already-dark theme; prevent BS3 .dark from re-applying weirdly
   ========================================================================== */
.dark { background-color: transparent !important; color: var(--anet-text) !important; }
.dark .navbar { background-color: transparent !important; }
.dark .navbar-brand { color: #fff !important; }
.dark .dropdown-menu { background-color: #14172a !important; }
.dark .list-group-item { background-color: rgba(255,255,255,0.03) !important; color: var(--anet-text) !important; border-color: var(--anet-line) !important; }
.dark .breadcrumb { background-color: rgba(255,255,255,0.03) !important; }
.dark .modal-content { background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%) !important; color: var(--anet-text) !important; }
.dark a.btn, .dark .btn { background-color: rgba(255,255,255,0.04) !important; color: var(--anet-text) !important; }
.dark .btn-primary { background: linear-gradient(135deg, var(--anet-cyan), #00b4ff) !important; color: #06070d !important; }
.dark input, .dark select, .dark textarea { background: rgba(255,255,255,0.03) !important; color: var(--anet-text) !important; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 991px) {
  body { padding-top: 94px; }
  .navbar-default .navbar-nav > li > a { padding: 12px 14px !important; }
  .navbar-default .navbar-nav > li > a::after { display: none; }
  .navbar-collapse {
    background: rgba(10,12,26,0.95);
    border-top: 1px solid var(--anet-line);
  }
}

@media (max-width: 480px) {
  /* hide topstrip on tiny screens to save vertical space */
  .anet-topstrip { display: none; }
  .navbar-default.navbar-fixed-top,
  .navbar.anet-navbar.navbar-fixed-top { top: 0 !important; }
  body { padding-top: 60px; }
}

/* ==========================================================================
   COMPACT HERO (used on subpages like the gallery)
   ========================================================================== */
.anet-hero-compact { padding: 28px 22px; margin-bottom: 18px; }

/* ==========================================================================
   GAME GALLERY  (mods/pages/008-gameservers.xjs)
   ========================================================================== */
.anet-gallery-toolbar {
  position: sticky;
  top: 94px;
  z-index: 10;
  margin: 0 -4px 18px;
  padding: 12px 14px;
  background: linear-gradient(180deg, rgba(8,9,15,0.92) 0%, rgba(10,12,26,0.92) 100%);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--anet-line);
  border-radius: var(--anet-radius);
  box-shadow: 0 12px 30px rgba(0,0,0,0.45);
}
.anet-gallery-search { margin-bottom: 10px; }
.anet-gallery-search input.anet-input {
  width: 100%;
  padding: 12px 14px !important;
  font-size: 14px !important;
}
.anet-gallery-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.anet-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--anet-line);
  color: var(--anet-text-dim);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .15s ease;
}
.anet-chip:hover { background: rgba(0,255,234,0.08); color: var(--anet-cyan); border-color: var(--anet-line-strong); }
.anet-chip.is-active {
  background: linear-gradient(135deg, var(--anet-cyan), #00b4ff);
  color: #06070d;
  border-color: transparent;
  box-shadow: 0 4px 16px rgba(0,255,234,0.34);
}
.anet-chip-count {
  background: rgba(0,0,0,0.25);
  color: inherit;
  padding: 1px 7px;
  border-radius: 999px;
  font-size: 11px;
  font-family: var(--anet-font-mono);
}
.anet-chip.is-active .anet-chip-count { background: rgba(0,0,0,0.35); }
.anet-chip-icon { font-size: 14px; }

.anet-gal-section { margin: 0 0 30px; }
.anet-gal-section-head {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--anet-line);
  flex-wrap: wrap;
}
.anet-gal-cat-icon { font-size: 22px; }
.anet-gal-section-head h2 { margin: 0; font-size: 20px; color: #fff; }
.anet-gal-cat-count {
  background: rgba(0,255,234,0.1);
  color: var(--anet-cyan);
  border: 1px solid var(--anet-line-strong);
  padding: 2px 10px;
  border-radius: 999px;
  font-family: var(--anet-font-mono);
  font-size: 12px;
}
.anet-gal-cat-desc { color: var(--anet-text-muted); font-size: 13px; flex: 1; }

.anet-gal-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}

.anet-gal-card {
  display: block;
  border-radius: var(--anet-radius);
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%);
  border: 1px solid var(--anet-line);
  overflow: hidden;
  text-decoration: none;
  color: var(--anet-text);
  position: relative;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.anet-gal-card:hover {
  transform: translateY(-3px);
  border-color: var(--anet-line-strong);
  box-shadow: 0 14px 38px rgba(0,0,0,0.6), 0 0 0 1px var(--anet-line-strong);
  text-shadow: none;
}
.anet-gal-thumb {
  position: relative;
  background: #000;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.anet-gal-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform .35s ease;
}
.anet-gal-card:hover .anet-gal-thumb img { transform: scale(1.04); }
.anet-gal-thumb-shine {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.65) 100%);
  pointer-events: none;
}
.anet-gal-meta {
  padding: 12px 14px;
  border-top: 1px solid var(--anet-line);
}
.anet-gal-cat-tag {
  font-family: var(--anet-font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--anet-green);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.anet-gal-title {
  font-weight: 600;
  font-size: 14px;
  color: #fff;
  line-height: 1.3;
}

.anet-gallery-empty {
  text-align: center;
  padding: 60px 20px;
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%);
  border: 1px solid var(--anet-line);
  border-radius: var(--anet-radius);
}
.anet-gallery-empty h3 { margin: 12px 0 6px; }
.anet-gallery-empty p { color: var(--anet-text-muted); }

/* ==========================================================================
   LIGHTBOX (game gallery)
   ========================================================================== */
html.anet-lb-open, html.anet-lb-open body { overflow: hidden; }

/* Override our display:flex when the [hidden] attribute is set so that
   lb.hidden = true actually hides the lightbox. Browsers treat [hidden]
   as display:none by default but our .anet-lightbox display:flex wins
   without this explicit rule. */
.anet-lightbox[hidden] { display: none !important; }

.anet-lightbox {
  position: fixed; inset: 0;
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.anet-lightbox-backdrop {
  position: absolute; inset: 0;
  background: radial-gradient(800px 500px at 50% 50%, rgba(0,255,234,0.10), rgba(0,0,0,0.85) 60%, rgba(0,0,0,0.95));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.anet-lightbox-frame {
  position: relative;
  z-index: 1;
  max-width: min(1100px, 96vw);
  max-height: 92vh;
  width: 100%;
  display: flex;
  flex-direction: column;
  background: linear-gradient(160deg, var(--anet-card-1) 0%, var(--anet-card-2) 100%);
  border: 1px solid var(--anet-line-strong);
  border-radius: var(--anet-radius);
  box-shadow: 0 30px 80px rgba(0,0,0,0.7), 0 0 0 1px var(--anet-line);
  overflow: hidden;
  animation: anet-lb-in .22s ease-out both;
}
@keyframes anet-lb-in {
  from { opacity: 0; transform: translateY(8px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.anet-lightbox-chrome {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: linear-gradient(180deg, #1a1d2e, #11142a);
  border-bottom: 1px solid var(--anet-line);
  font-family: var(--anet-font-mono);
  font-size: 13px;
  color: var(--anet-text-dim);
}
.anet-lightbox-chrome .anet-term-dot[data-anet-lb-close] { cursor: pointer; }
.anet-lightbox-title {
  flex: 1;
  margin-left: 6px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #fff;
}
.anet-lightbox-x {
  background: transparent;
  border: 0;
  color: var(--anet-text-dim);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  padding: 0 6px;
}
.anet-lightbox-x:hover { color: var(--anet-cyan); }

.anet-lightbox-body {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;
  overflow: auto;
  min-height: 200px;
}
.anet-lightbox-body img {
  max-width: 100%;
  max-height: calc(92vh - 110px);
  display: block;
  background: #000;
}
.anet-lb-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.5);
  border: 1px solid var(--anet-line);
  color: #fff;
  width: 44px; height: 44px;
  border-radius: 50%;
  font-size: 24px;
  cursor: pointer;
  z-index: 1;
  transition: background .15s ease, border-color .15s ease, transform .12s ease;
  display: flex; align-items: center; justify-content: center;
}
.anet-lb-nav:hover { background: rgba(0,255,234,0.14); border-color: var(--anet-line-strong); color: var(--anet-cyan); transform: translateY(-50%) scale(1.06); }
.anet-lb-prev { left: 12px; }
.anet-lb-next { right: 12px; }

.anet-lightbox-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  border-top: 1px solid var(--anet-line);
  background: rgba(0,0,0,0.25);
}
.anet-lightbox-counter { font-family: var(--anet-font-mono); font-size: 12px; color: var(--anet-text-muted); }

@media (max-width: 640px) {
  .anet-gallery-toolbar { top: 60px; }
  .anet-gal-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .anet-gal-thumb { aspect-ratio: 4 / 3; }
  .anet-gal-meta { padding: 10px; }
  .anet-gal-title { font-size: 13px; }
  .anet-lb-nav { width: 38px; height: 38px; font-size: 20px; }
}
@media (max-width: 420px) {
  .anet-gal-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .anet-hero { padding: 28px 18px; }
  .anet-section { padding: 16px; }
  .anet-feature-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .anet-feature { padding: 14px; }
  .anet-feature h3 { font-size: 16px; }
  .anet-radio-frame iframe { height: 520px; }
}
@media (max-width: 420px) {
  .anet-feature-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   FINAL NAVBAR HOVER OVERRIDE — placed last so source-order wins any tie.
   The Log-in link kept getting a white block because BS3's
     .navbar-default .navbar-nav > .open > a { background-color: #d5d5d5 }
   plus its descendant rules layer on the dropdown-toggle. This block is
   broad: any link/button/dropdown-toggle/list-item inside the navbar in
   any state gets cyan-on-glass (or transparent for non-interactive states).
   ========================================================================== */
.navbar-default,
.navbar-default ul,
.navbar-default li,
.navbar-default .nav-item,
.navbar-default .navbar-nav,
.navbar-default .navbar-collapse,
.navbar-default .open,
.navbar-default .open > a,
.navbar-default .nav-link,
.navbar-default .dropdown-toggle,
.navbar-default a,
.navbar-default a:link,
.navbar-default a:visited {
  background-color: transparent !important;
}

.navbar-default a:hover,
.navbar-default a:focus,
.navbar-default a:active,
.navbar-default .nav-link:hover,
.navbar-default .nav-link:focus,
.navbar-default .nav-link:active,
.navbar-default .dropdown-toggle:hover,
.navbar-default .dropdown-toggle:focus,
.navbar-default .dropdown-toggle:active,
.navbar-default li:hover > a,
.navbar-default li.open > a,
.navbar-default li.open > a:hover,
.navbar-default li.open > a:focus,
.navbar-default li.active > a,
.navbar-default li.active > a:hover,
.navbar-default li.active > a:focus,
.navbar-default .navbar-nav > .open > a,
.navbar-default .navbar-nav > .open > a:hover,
.navbar-default .navbar-nav > .open > a:focus,
.navbar-default .navbar-nav > .active > a,
.navbar-default .navbar-nav > .active > a:hover,
.navbar-default .navbar-nav > .active > a:focus {
  background: rgba(0, 255, 234, 0.10) !important;
  background-color: rgba(0, 255, 234, 0.10) !important;
  color: var(--anet-cyan) !important;
  text-shadow: 0 0 8px rgba(0, 255, 234, 0.4);
}

/* Dropdown menu itself — make the entire menu (including dim padding zones)
   immune to BS3's `background-color: #fff` default. */
.navbar-default .dropdown-menu,
.navbar-default .dropdown-menu.anet-dropdown,
#login-form.dropdown-menu {
  background: linear-gradient(180deg, #14172a 0%, #0e1020 100%) !important;
  background-color: #14172a !important;
  border: 1px solid var(--anet-line) !important;
}

/* The Login dropdown-toggle specifically (anet-login-toggle class) */
.navbar-default a.anet-login-toggle,
.navbar-default a.anet-login-toggle:hover,
.navbar-default a.anet-login-toggle:focus,
.navbar-default a.anet-login-toggle:active,
.navbar-default .open > a.anet-login-toggle {
  background: transparent !important;
  background-color: transparent !important;
}
.navbar-default a.anet-login-toggle:hover,
.navbar-default a.anet-login-toggle:focus,
.navbar-default .open > a.anet-login-toggle {
  background: rgba(0, 255, 234, 0.10) !important;
  background-color: rgba(0, 255, 234, 0.10) !important;
  color: var(--anet-cyan) !important;
}

/* ==========================================================================
   GENERIC .nav HOVER OVERRIDE — BS3 also has a non-navbar-scoped rule:
     .nav > li > a:focus, .nav > li > a:hover { background-color: #eee }
   That's the actual source of the "white" highlight on Login (it's #eee,
   light gray, but reads as white on most monitors). Override it for any
   .nav inside any .navbar.
   ========================================================================== */
.navbar .nav > li > a,
.navbar .nav > li > a:link,
.navbar .nav > li > a:visited {
  background-color: transparent !important;
}
.navbar .nav > li > a:hover,
.navbar .nav > li > a:focus,
.navbar .nav > li > a:active,
.navbar .nav > li.open > a,
.navbar .nav > li.open > a:hover,
.navbar .nav > li.open > a:focus,
.navbar .nav > li.active > a,
.navbar .nav > li.active > a:hover,
.navbar .nav > li.active > a:focus,
.anet-navbar .nav > li > a:hover,
.anet-navbar .nav > li > a:focus,
.anet-navbar .nav > li.open > a,
.anet-navbar .nav > li.active > a {
  background: rgba(0, 255, 234, 0.10) !important;
  background-color: rgba(0, 255, 234, 0.10) !important;
  color: var(--anet-cyan) !important;
  text-shadow: 0 0 8px rgba(0, 255, 234, 0.4);
}

/* Anet-navbar variant — target the Log-in toggle by its unique class chain.
   These selectors don't depend on .navbar-default at all. */
.anet-navbar a.anet-login-toggle,
.anet-navbar a.anet-nav-link {
  background-color: transparent !important;
}
.anet-navbar a.anet-login-toggle:hover,
.anet-navbar a.anet-login-toggle:focus,
.anet-navbar a.anet-login-toggle:active,
.anet-navbar a.anet-nav-link:hover,
.anet-navbar a.anet-nav-link:focus,
.anet-navbar a.anet-nav-link:active,
.anet-navbar li.open > a.anet-login-toggle,
.anet-navbar li.open > a.anet-nav-link {
  background: rgba(0, 255, 234, 0.10) !important;
  background-color: rgba(0, 255, 234, 0.10) !important;
  color: var(--anet-cyan) !important;
}
