/* ===================================================================
   Premium Dark Theme — Quantivo / Stardust-inspired
   Bootstrap 5 overrides + glassmorphism + glow effects
   =================================================================== */

/* ── Custom Properties ─────────────────────────────────────────── */
:root {
  --bg:             hsl(220 15% 5%);
  --bg-card:        hsl(220 15% 8%);
  --bg-card-hover:  hsl(220 15% 10%);
  --bg-secondary:   hsl(220 15% 15%);
  --bg-muted:       hsl(220 10% 25%);

  --text:           hsl(0 0% 98%);
  --text-secondary: hsl(0 0% 80%);
  --text-muted:     hsl(0 0% 65%);

  --primary:        hsl(180 80% 50%);
  --primary-dim:    hsl(180 80% 35%);
  --accent:         hsl(260 60% 55%);
  --accent-dim:     hsl(260 60% 40%);
  --success:        hsl(145 60% 45%);
  --warning:        hsl(40 90% 55%);
  --danger:         hsl(0 72% 50%);
  --info:           hsl(200 80% 55%);

  --border:         hsl(220 10% 18%);
  --border-glass:   rgba(255,255,255,0.08);
  --border-hover:   hsl(180 80% 50% / 0.3);

  --radius:         0.75rem;
  --radius-lg:      1rem;

  --shadow-card:    0 4px 24px rgba(0,0,0,0.3);
  --shadow-glow:    0 0 30px hsl(180 80% 50% / 0.12);
  --shadow-glow-strong: 0 0 50px hsl(180 80% 50% / 0.2);

  --glass-bg:       hsl(220 15% 8% / 0.6);
  --glass-blur:     20px;

  --font-sans:      'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --font-display:   'Space Grotesk', var(--font-sans);
  --font-mono:      'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Courier New', monospace;
}

/* ── Base ──────────────────────────────────────────────────────── */
* { border-color: var(--border); }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% -20%, hsl(180 80% 50% / 0.04), transparent),
    radial-gradient(ellipse 60% 40% at 100% 100%, hsl(260 60% 50% / 0.03), transparent);
}

/* ── Scrollbar ─────────────────────────────────────────────────── */
::-webkit-scrollbar        { width: 6px; height: 6px; }
::-webkit-scrollbar-track  { background: var(--bg); }
::-webkit-scrollbar-thumb  { background: var(--bg-muted); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-muted); }

/* ── Links ─────────────────────────────────────────────────────── */
a { color: var(--primary); text-decoration: none; transition: color 0.2s; }
a:hover { color: hsl(180 80% 65%); }

hr { border-color: var(--border); opacity: 0.4; }

code {
  color: var(--primary);
  background: hsl(180 80% 50% / 0.08);
  padding: 0.1em 0.4em;
  border-radius: 4px;
  font-size: 0.85em;
}

/* ── Navbar ─────────────────────────────────────────────────────── */
.navbar {
  background: var(--glass-bg) !important;
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-bottom: 1px solid var(--border-glass);
  padding: 0.7rem 1.5rem;
}

.navbar-brand {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.2rem;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.navbar .btn-outline-light {
  border: 1px solid var(--border);
  color: var(--text-muted);
  background: transparent;
  border-radius: var(--radius);
  font-weight: 500;
  font-size: 0.82rem;
  padding: 0.4rem 1rem;
  transition: all 0.25s ease;
}
.navbar .btn-outline-light:hover,
.navbar .btn-outline-light:focus {
  background: var(--bg-secondary);
  color: var(--text);
  border-color: var(--border-hover);
  box-shadow: var(--shadow-glow);
}

/* ── Cards ──────────────────────────────────────────────────────── */
.card {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  color: var(--text);
  transition: border-color 0.3s, box-shadow 0.3s;
  animation: fade-in 0.4s ease-out;
}
.card:hover {
  border-color: hsl(180 80% 50% / 0.12);
}

.card-header {
  background: transparent;
  border-bottom: 1px solid var(--border-glass);
  padding: 1rem 1.25rem;
}
.card-header h5 {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--text);
  margin: 0;
}
.card-body { padding: 1.25rem; }

/* ── Stat mini-cards (dashboard) ───────────────────────────────── */
.card.text-center.p-2 {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border-glass);
  border-radius: var(--radius);
  transition: all 0.3s ease;
}
.card.text-center.p-2:hover {
  border-color: var(--border-hover);
  box-shadow: var(--shadow-glow);
  transform: translateY(-2px);
}
.card.text-center.p-2 small {
  color: var(--text-muted);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 500;
}
.card.text-center.p-2 strong {
  color: var(--primary);
  font-family: var(--font-display);
  font-size: 1.5rem;
  font-weight: 700;
  display: block;
  margin-top: 0.15rem;
}

/* ── Tables ─────────────────────────────────────────────────────── */
.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--text);
  --bs-table-border-color: var(--border);
  --bs-table-hover-bg: hsl(220 15% 12% / 0.5);
  --bs-table-hover-color: var(--text);
  color: var(--text);
}
.table thead th {
  background: hsl(220 15% 10% / 0.8);
  color: var(--text-muted);
  font-weight: 600;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border);
  padding: 0.7rem 0.9rem;
  position: sticky;
  top: 0;
  z-index: 1;
}
.table tbody td {
  padding: 0.7rem 0.9rem;
  border-bottom: 1px solid hsl(220 10% 18% / 0.4);
  vertical-align: middle;
  color: var(--text-secondary);
  font-size: 0.88rem;
}
.table-hover tbody tr:hover td {
  background: hsl(220 15% 12% / 0.5);
  color: var(--text);
}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn {
  border-radius: var(--radius);
  font-weight: 500;
  font-size: 0.875rem;
  transition: all 0.25s ease;
}

.btn-primary {
  background: linear-gradient(135deg, var(--primary), hsl(200 80% 50%));
  border: none;
  color: hsl(220 15% 5%);
  font-weight: 600;
  box-shadow: 0 2px 12px hsl(180 80% 50% / 0.25);
}
.btn-primary:hover, .btn-primary:focus {
  background: linear-gradient(135deg, hsl(180 80% 55%), hsl(200 80% 55%));
  color: hsl(220 15% 5%);
  box-shadow: var(--shadow-glow-strong);
  transform: translateY(-1px);
}
.btn-primary:disabled {
  background: var(--bg-muted);
  color: var(--text-muted);
  box-shadow: none;
  transform: none;
}

.btn-danger {
  background: linear-gradient(135deg, var(--danger), hsl(0 72% 40%));
  border: none;
  color: var(--text);
}
.btn-danger:hover {
  background: linear-gradient(135deg, hsl(0 72% 55%), hsl(0 72% 45%));
  color: var(--text);
  box-shadow: 0 0 20px hsl(0 72% 50% / 0.3);
  transform: translateY(-1px);
}

.btn-success {
  background: linear-gradient(135deg, var(--success), hsl(145 60% 35%));
  border: none;
  color: var(--text);
}
.btn-success:hover {
  background: linear-gradient(135deg, hsl(145 60% 50%), hsl(145 60% 40%));
  color: var(--text);
  box-shadow: 0 0 20px hsl(145 60% 45% / 0.3);
}

/* Outline buttons */
.btn-outline-primary {
  border: 1px solid hsl(180 80% 50% / 0.4);
  color: var(--primary);
  background: transparent;
}
.btn-outline-primary:hover {
  background: hsl(180 80% 50% / 0.1);
  border-color: var(--primary);
  color: var(--primary);
  box-shadow: var(--shadow-glow);
}

.btn-outline-secondary {
  border: 1px solid var(--border);
  color: var(--text-muted);
  background: transparent;
}
.btn-outline-secondary:hover {
  background: var(--bg-secondary);
  color: var(--text);
  border-color: var(--text-muted);
}

.btn-outline-success {
  border: 1px solid hsl(145 60% 45% / 0.4);
  color: var(--success);
  background: transparent;
}
.btn-outline-success:hover {
  background: hsl(145 60% 45% / 0.1);
  border-color: var(--success);
  color: var(--success);
}

.btn-outline-danger {
  border: 1px solid hsl(0 72% 50% / 0.4);
  color: var(--danger);
  background: transparent;
}
.btn-outline-danger:hover {
  background: hsl(0 72% 50% / 0.1);
  border-color: var(--danger);
  color: var(--danger);
}

.btn-outline-info {
  border: 1px solid hsl(200 80% 55% / 0.4);
  color: var(--info);
  background: transparent;
}
.btn-outline-info:hover {
  background: hsl(200 80% 55% / 0.1);
  border-color: var(--info);
  color: var(--info);
}

.btn-outline-warning {
  border: 1px solid hsl(40 90% 55% / 0.4);
  color: var(--warning);
  background: transparent;
}
.btn-outline-warning:hover {
  background: hsl(40 90% 55% / 0.1);
  border-color: var(--warning);
  color: var(--warning);
}

/* ── Forms ──────────────────────────────────────────────────────── */
.form-control, .form-select {
  background: hsl(220 15% 10% / 0.8);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius);
  padding: 0.55rem 0.85rem;
  font-size: 0.9rem;
  transition: all 0.25s ease;
}
.form-control:focus, .form-select:focus {
  background: hsl(220 15% 12%);
  border-color: var(--primary);
  color: var(--text);
  box-shadow: 0 0 0 3px hsl(180 80% 50% / 0.12);
  outline: none;
}
.form-control::placeholder { color: var(--text-muted); opacity: 0.6; }
.form-select option { background: var(--bg-card); color: var(--text); }

.form-label {
  color: var(--text-secondary);
  font-weight: 500;
  font-size: 0.85rem;
  margin-bottom: 0.35rem;
}

.form-check-input {
  background-color: var(--bg-muted);
  border: 1px solid var(--border);
}
.form-check-input:checked {
  background-color: var(--primary);
  border-color: var(--primary);
}
.form-check-input:focus {
  box-shadow: 0 0 0 3px hsl(180 80% 50% / 0.12);
  border-color: var(--primary);
}
.form-check-label { color: var(--text-secondary); }

textarea.form-control {
  font-family: var(--font-mono);
  font-size: 0.82rem;
}

.input-group .btn { border-color: var(--border); }

/* ── Text utilities ────────────────────────────────────────────── */
.text-muted { color: var(--text-muted) !important; }
.text-danger { color: var(--danger) !important; }
.text-success { color: var(--success) !important; }
.text-warning { color: var(--warning) !important; }

/* ── Badges ─────────────────────────────────────────────────────── */
.badge {
  font-weight: 500;
  padding: 0.35em 0.75em;
  border-radius: 999px;
  font-size: 0.72rem;
  letter-spacing: 0.02em;
}

.badge.bg-primary { background: linear-gradient(135deg, var(--primary), hsl(200 80% 50%)) !important; color: hsl(220 15% 5%) !important; }
.badge.bg-secondary { background: var(--bg-muted) !important; color: var(--text-muted) !important; }
.badge.bg-success { background: hsl(145 60% 45% / 0.15) !important; color: var(--success) !important; border: 1px solid hsl(145 60% 45% / 0.3); }
.badge.bg-warning { background: hsl(40 90% 55% / 0.15) !important; color: var(--warning) !important; border: 1px solid hsl(40 90% 55% / 0.3); }
.badge.bg-danger  { background: hsl(0 72% 50% / 0.15) !important; color: var(--danger) !important; border: 1px solid hsl(0 72% 50% / 0.3); }
.badge.bg-info    { background: hsl(200 80% 55% / 0.15) !important; color: var(--info) !important; border: 1px solid hsl(200 80% 55% / 0.3); }

/* Session status */
.badge-pending   { background: hsl(40 90% 55% / 0.12); color: var(--warning); border: 1px solid hsl(40 90% 55% / 0.25); }
.badge-running   { background: hsl(180 80% 50% / 0.12); color: var(--primary); border: 1px solid hsl(180 80% 50% / 0.25); animation: glow-pulse 3s ease-in-out infinite; }
.badge-completed { background: hsl(145 60% 45% / 0.12); color: var(--success); border: 1px solid hsl(145 60% 45% / 0.25); }
.badge-stopped   { background: hsl(220 10% 40% / 0.15); color: var(--text-muted); border: 1px solid hsl(220 10% 40% / 0.25); }
.badge-failed    { background: hsl(0 72% 50% / 0.12); color: var(--danger); border: 1px solid hsl(0 72% 50% / 0.25); }

/* Proxy status */
.badge-proxy-active   { background: hsl(145 60% 45% / 0.12); color: var(--success); border: 1px solid hsl(145 60% 45% / 0.25); }
.badge-proxy-inactive { background: hsl(220 10% 40% / 0.15); color: var(--text-muted); border: 1px solid hsl(220 10% 40% / 0.25); }
.badge-proxy-failed   { background: hsl(0 72% 50% / 0.12); color: var(--danger); border: 1px solid hsl(0 72% 50% / 0.25); }

/* ── Progress bars ──────────────────────────────────────────────── */
.progress {
  background: hsl(220 15% 12%);
  border-radius: 999px;
  border: 1px solid var(--border-glass);
  overflow: hidden;
}
.progress-bar {
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 600;
}
.progress-bar.bg-primary {
  background: linear-gradient(90deg, var(--primary), hsl(200 80% 55%)) !important;
  color: hsl(220 15% 5%) !important;
}
.progress-bar.bg-warning {
  background: linear-gradient(90deg, var(--warning), hsl(30 90% 50%)) !important;
  color: hsl(220 15% 5%) !important;
}

/* ── Alert ──────────────────────────────────────────────────────── */
.alert-danger {
  background: hsl(0 72% 50% / 0.1);
  border: 1px solid hsl(0 72% 50% / 0.3);
  color: var(--text);
  border-radius: var(--radius);
}

/* ── Log box ────────────────────────────────────────────────────── */
.log-box {
  background: hsl(220 15% 4%);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.75rem;
  max-height: 250px;
  overflow-y: auto;
  font-family: var(--font-mono);
  font-size: 0.76rem;
  line-height: 1.65;
}
.log-entry { padding: 0.1rem 0; color: var(--text-muted); white-space: pre-wrap; word-break: break-all; }
.log-entry.info    { color: var(--info); }
.log-entry.success { color: var(--success); }
.log-entry.error   { color: var(--danger); }

/* ── Map ────────────────────────────────────────────────────────── */
#map {
  height: 500px;
  width: 100%;
  min-height: 400px;
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
}

/* Leaflet popups — dark theme */
.leaflet-popup-content-wrapper {
  background: var(--bg-card);
  color: var(--text);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius);
  box-shadow: var(--shadow-card);
}
.leaflet-popup-tip { background: var(--bg-card); }
.leaflet-popup-content { font-family: var(--font-sans); font-size: 0.85rem; }

/* Leaflet draw toolbar */
.leaflet-draw-toolbar a { background-color: var(--bg-card); }
.leaflet-draw-actions a {
  background: var(--bg-secondary);
  color: var(--text);
  border: 1px solid var(--border);
}
.leaflet-bar a {
  background-color: var(--bg-card);
  color: var(--text);
  border-bottom-color: var(--border);
}
.leaflet-bar a:hover { background-color: var(--bg-secondary); }

/* ── Pagination ─────────────────────────────────────────────────── */
.page-item .page-link {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-muted);
  border-radius: var(--radius);
  margin: 0 2px;
  transition: all 0.25s ease;
}
.page-item .page-link:hover {
  background: var(--bg-secondary);
  border-color: var(--border-hover);
  color: var(--primary);
}
.page-item.active .page-link {
  background: linear-gradient(135deg, var(--primary), hsl(200 80% 50%));
  border-color: transparent;
  color: hsl(220 15% 5%);
  font-weight: 600;
}
.page-item.disabled .page-link {
  background: transparent;
  border-color: var(--border);
  color: var(--bg-muted);
}

/* ── Results container ──────────────────────────────────────────── */
.results-container {
  max-height: 65vh;
  overflow-y: auto;
  border-radius: var(--radius);
}

/* ── Container spacing ──────────────────────────────────────────── */
.container-fluid { padding-left: 1.5rem; padding-right: 1.5rem; }

/* ── Animations ─────────────────────────────────────────────────── */
@keyframes fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes glow-pulse {
  0%, 100% { box-shadow: 0 0 8px hsl(180 80% 50% / 0.2); }
  50%      { box-shadow: 0 0 20px hsl(180 80% 50% / 0.4); }
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.animate-fade-in  { animation: fade-in 0.4s ease-out; }
.animate-glow     { animation: glow-pulse 3s ease-in-out infinite; }

/* ── Gradient text utility ──────────────────────────────────────── */
.gradient-text {
  background: linear-gradient(135deg, var(--primary) 0%, hsl(180 90% 70%) 50%, var(--accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
