/* ═══════════════════════════════════════════════════
   NudeBot Web — Dark Minimal Theme
   ═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --bg:          #0e0e11;
  --bg-2:        #16161a;
  --bg-3:        #1c1c22;
  --bg-4:        #242430;
  --border:      rgba(255,255,255,.07);
  --border-hover:rgba(255,255,255,.14);

  --accent:      #7c6af7;
  --accent-dim:  rgba(124,106,247,.18);
  --accent-glow: rgba(124,106,247,.35);

  --text:        #e8e8f0;
  --text-2:      #9494a8;
  --text-3:      #5a5a6e;

  --success:     #34d399;
  --danger:      #f87171;
  --warning:     #fbbf24;
  --info:        #60a5fa;

  --radius:      12px;
  --radius-sm:   8px;
  --radius-lg:   18px;

  --shadow:      0 4px 24px rgba(0,0,0,.45);
  --shadow-lg:   0 8px 48px rgba(0,0,0,.6);

  --transition:  all .2s cubic-bezier(.4,0,.2,1);
}

/* ── Reset & Base ─────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', 'Segoe UI', sans-serif;
  background-color: var(--bg);
  color: var(--text);
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  -webkit-font-smoothing: antialiased;
}

/* ── Scrollbar ────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg-2); }
::-webkit-scrollbar-thumb { background: var(--bg-4); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--accent); }

/* ── Typography ───────────────────────────────────── */
h1,h2,h3,h4,h5,h6 { font-weight: 600; letter-spacing: -.02em; color: var(--text); }
p { color: var(--text-2); }
a { color: var(--accent); text-decoration: none; transition: var(--transition); }
a:hover { color: #a89bf9; }
small { color: var(--text-3); }

/* ── Navbar ───────────────────────────────────────── */
.navbar {
  background: rgba(14,14,17,.85) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  padding: 14px 0;
  box-shadow: none;
}
.navbar-brand {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--text) !important;
}
.navbar-brand i { color: var(--accent); margin-right: 6px; }
.nav-link {
  color: var(--text-2) !important;
  font-size: .9rem;
  font-weight: 500;
  padding: 6px 14px !important;
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.nav-link:hover { color: var(--text) !important; background: var(--bg-3); }
.nav-link strong { color: var(--accent); }
.navbar-toggler { border: 1px solid var(--border); }

.navbar-toggler-icon { filter: invert(0); }

/* ── Main ─────────────────────────────────────────── */
main { flex: 1; padding: 2.5rem 0; }

/* ── Cards ────────────────────────────────────────── */
.card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  animation: fadeUp .3s ease both;
  transition: var(--transition);
}
.card:hover {
  border-color: var(--border-hover);
  box-shadow: var(--shadow-lg);
}
.card-body { color: var(--text); }
.card-footer {
  background: var(--bg-3) !important;
  border-top: 1px solid var(--border) !important;
  border-radius: 0 0 var(--radius) var(--radius) !important;
}
.card-title { color: var(--text); font-weight: 600; }

/* ── Buttons ──────────────────────────────────────── */
.btn {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: .875rem;
  border-radius: var(--radius-sm);
  border: none;
  padding: 8px 20px;
  transition: var(--transition);
  letter-spacing: .01em;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 0 0 0 var(--accent-glow);
}
.btn-primary:hover {
  background: #9183f9;
  box-shadow: 0 4px 20px var(--accent-glow);
  color: #fff;
}

.btn-success {
  background: var(--success);
  color: #0a2018;
}
.btn-success:hover { background: #4ee8ab; color: #0a2018; }

.btn-danger  { background: var(--danger);  color: #fff; }
.btn-warning { background: var(--warning); color: #1a0f00; }

.btn-outline-primary {
  background: transparent;
  border: 1px solid var(--accent);
  color: var(--accent);
}
.btn-outline-primary:hover { background: var(--accent-dim); color: var(--accent); border-color: var(--accent); }

.btn-outline-secondary {
  background: transparent;
  border: 1px solid var(--border-hover);
  color: var(--text-2);
}
.btn-outline-secondary:hover { background: var(--bg-3); color: var(--text); border-color: var(--border-hover); }

.btn-outline-light {
  border: 1px solid var(--border-hover);
  color: var(--text-2);
  background: transparent;
}
.btn-outline-light:hover { background: var(--bg-3); color: var(--text); }

.btn-lg { padding: 12px 28px; font-size: 1rem; border-radius: var(--radius); }
.btn-sm { padding: 5px 14px; font-size: .8rem; }

/* ── Forms ────────────────────────────────────────── */
.form-control, .form-select, .input-group-text {
  background: var(--bg-3);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: .9rem;
  transition: var(--transition);
}
.form-control::placeholder { color: var(--text-3); }
.form-control:focus, .form-select:focus {
  background: var(--bg-3);
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-dim);
  color: var(--text);
  outline: none;
}
.form-control.is-invalid { border-color: var(--danger); }
.form-control.is-invalid:focus { box-shadow: 0 0 0 3px rgba(248,113,113,.2); }
.invalid-feedback, .text-danger { color: var(--danger) !important; font-size: .82rem; }
.form-label { color: var(--text-2); font-size: .85rem; font-weight: 500; margin-bottom: 6px; }
.form-text  { color: var(--text-3); }
.input-group-text {
  border-right: none;
  color: var(--text-3);
}
.input-group .form-control { border-left: none; }

/* ── Alerts ───────────────────────────────────────── */
.alert {
  border-radius: var(--radius);
  border: 1px solid;
  font-size: .9rem;
  padding: 12px 16px;
}
.alert-info    { background: rgba(96,165,250,.1); border-color: rgba(96,165,250,.25); color: var(--info); }
.alert-success { background: rgba(52,211,153,.1); border-color: rgba(52,211,153,.25); color: var(--success); }
.alert-warning { background: rgba(251,191,36,.1);  border-color: rgba(251,191,36,.25);  color: var(--warning); }
.alert-danger  { background: rgba(248,113,113,.1); border-color: rgba(248,113,113,.25); color: var(--danger); }
.alert .btn-close { filter: invert(1) opacity(.5); }

/* ── Badges ───────────────────────────────────────── */
.badge {
  font-size: .72rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 99px;
  letter-spacing: .03em;
}
.bg-success { background: rgba(52,211,153,.15)  !important; color: var(--success) !important; border: 1px solid rgba(52,211,153,.3); }
.bg-danger  { background: rgba(248,113,113,.15) !important; color: var(--danger)  !important; border: 1px solid rgba(248,113,113,.3); }
.bg-warning { background: rgba(251,191,36,.15)  !important; color: var(--warning) !important; border: 1px solid rgba(251,191,36,.3); }
.bg-info    { background: rgba(96,165,250,.15)  !important; color: var(--info)    !important; border: 1px solid rgba(96,165,250,.3); }
.bg-primary { background: var(--accent-dim)     !important; color: var(--accent)  !important; border: 1px solid rgba(124,106,247,.3); }
.bg-secondary{ background: rgba(148,148,168,.12)!important; color: var(--text-2)  !important; border: 1px solid var(--border); }

/* ── Progress ─────────────────────────────────────── */
.progress {
  background: var(--bg-4);
  border-radius: 99px;
}
.progress-bar {
  background: var(--accent);
  border-radius: 99px;
  transition: width .4s ease;
}
.progress-bar-animated { animation: progressPulse 1.5s ease infinite; }
@keyframes progressPulse {
  0%,100% { opacity: 1; }
  50%      { opacity: .7; }
}

/* ── Tables ───────────────────────────────────────── */
.table {
  color: var(--text);
  border-color: var(--border);
  margin-bottom: 0;
}
.table-hover tbody tr:hover > * { background: var(--bg-3); color: var(--text); }
.table thead th {
  background: var(--bg-3);
  color: var(--text-2);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  padding: 14px 16px;
}
.table tbody td {
  border-color: var(--border);
  padding: 13px 16px;
  vertical-align: middle;
  font-size: .9rem;
}
.table-light { --bs-table-bg: var(--bg-3); }

/* ── Pagination ───────────────────────────────────── */
.page-link {
  background: var(--bg-2);
  border: 1px solid var(--border);
  color: var(--text-2);
  border-radius: var(--radius-sm) !important;
  margin: 0 3px;
  font-size: .875rem;
  padding: 6px 14px;
  transition: var(--transition);
}
.page-link:hover  { background: var(--bg-3); color: var(--text); border-color: var(--border-hover); }
.page-item.active .page-link { background: var(--accent); border-color: var(--accent); color: #fff; }
.page-item.disabled .page-link { background: var(--bg-2); color: var(--text-3); }

/* ── HR ───────────────────────────────────────────── */
hr { border-color: var(--border); opacity: 1; }

/* ── Footer ───────────────────────────────────────── */
footer {
  background: var(--bg-2) !important;
  border-top: 1px solid var(--border);
  color: var(--text-3) !important;
  font-size: .85rem;
  padding: 24px 0;
}
footer p { color: var(--text-3); margin: 0; }

/* ── Spinner ──────────────────────────────────────── */
.spinner-border { border-color: var(--accent); border-right-color: transparent; }
.spinner-border.text-primary { border-color: var(--accent); border-right-color: transparent; }

/* ── Animations ───────────────────────────────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── Responsive ───────────────────────────────────── */
@media (max-width: 768px) {
  .navbar-brand { font-size: 1.1rem; }
  main { padding: 1.5rem 0; }
  .btn-lg { padding: 10px 20px; }
}
