/*
  LawBlog UI Theme (Bootstrap 5)
  - Modern, clean, law‑style palette
  - Uses CSS variables so you can retheme in one place
*/

:root {
  /* Core palette */
  --lb-bg: #0b1220;          /* deep navy */
  --lb-surface: #0f1a2e;     /* slightly lighter */
  --lb-card: #111f38;
  --lb-text: #eaf0ff;
  --lb-muted: rgba(234, 240, 255, 0.72);

  --lb-primary: #6ea8fe;     /* calm blue */
  --lb-primary-2: #8a5cf6;   /* violet accent */
  --lb-accent: #2dd4bf;      /* teal accent */

  --lb-border: rgba(255, 255, 255, 0.10);
  --lb-shadow: 0 10px 30px rgba(0, 0, 0, 0.30);
  --lb-radius: 18px;
}

body {
  background:
    radial-gradient(1200px 800px at 20% 10%, rgba(110, 168, 254, 0.20), transparent 55%),
    radial-gradient(900px 700px at 80% 0%, rgba(138, 92, 246, 0.16), transparent 60%),
    var(--lb-bg);
  color: var(--lb-text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Links */
a { text-decoration: none; }
a, .link-primary { color: var(--lb-primary); }
a:hover, .link-primary:hover { color: #a9c7ff; }

/* Navbar + Footer (override Bootstrap dark) */
.navbar.bg-dark,
footer.bg-dark {
  background:
    linear-gradient(90deg, rgba(110, 168, 254, 0.20), rgba(45, 212, 191, 0.10), rgba(138, 92, 246, 0.18)),
    rgba(15, 26, 46, 0.92) !important;
  border-bottom: 1px solid var(--lb-border);
  backdrop-filter: blur(10px);
}

.navbar .navbar-brand {
  font-weight: 800;
  letter-spacing: 0.4px;
}

.navbar .nav-link {
  color: rgba(234, 240, 255, 0.85) !important;
}
.navbar .nav-link:hover {
  color: var(--lb-text) !important;
}

/* Containers spacing */
.container { max-width: 1180px; }

/* Cards */
.card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.04), transparent 40%),
    var(--lb-card);
  border: 1px solid var(--lb-border);
  border-radius: var(--lb-radius);
  overflow: hidden;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--lb-shadow);
  border-color: rgba(110, 168, 254, 0.28);
}

.card-title a { color: var(--lb-text); }
.card-title a:hover { color: #cfe1ff; }

.text-muted { color: var(--lb-muted) !important; }

.object-fit-cover { object-fit: cover; }

/* Buttons */
.btn-primary {
  background: linear-gradient(90deg, var(--lb-primary), var(--lb-primary-2));
  border: 0;
}
.btn-primary:hover { filter: brightness(1.05); }

.btn-outline-light {
  border-color: rgba(234, 240, 255, 0.40) !important;
  color: rgba(234, 240, 255, 0.92) !important;
}
.btn-outline-light:hover {
  background: rgba(234, 240, 255, 0.10) !important;
}

.btn-outline-info {
  border-color: rgba(45, 212, 191, 0.60) !important;
  color: rgba(45, 212, 191, 0.95) !important;
}
.btn-outline-info:hover {
  background: rgba(45, 212, 191, 0.12) !important;
}

/* Forms */
.form-control {
  background-color: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid var(--lb-border) !important;
  color: var(--lb-text) !important;
  border-radius: 14px;
}
.form-control::placeholder { color: rgba(234, 240, 255, 0.55) !important; }
.form-control:focus {
  box-shadow: 0 0 0 0.20rem rgba(110, 168, 254, 0.20) !important;
  border-color: rgba(110, 168, 254, 0.45) !important;
}

.dropdown-menu {
  background: rgba(15, 26, 46, 0.98);
  border: 1px solid var(--lb-border);
  border-radius: 14px;
}
.dropdown-item { color: rgba(234, 240, 255, 0.92); }
.dropdown-item:hover {
  background: rgba(110, 168, 254, 0.12);
  color: var(--lb-text);
}

/* Hero */
.lb-hero {
  border: 1px solid var(--lb-border);
  border-radius: calc(var(--lb-radius) + 6px);
  background:
    linear-gradient(135deg, rgba(110, 168, 254, 0.22), rgba(45, 212, 191, 0.10), rgba(138, 92, 246, 0.22)),
    rgba(17, 31, 56, 0.65);
  box-shadow: var(--lb-shadow);
  padding: 28px;
}

.lb-hero .badge {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(0, 0, 0, 0.18);
}

/* Sidebar widgets */
.sidebar-widget .card { margin-bottom: 1rem; }

/* Lists */
ul.list-unstyled li + li { margin-top: 0.35rem; }

/* Small details */
.lb-meta {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}
.lb-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(110, 168, 254, 0.12);
  border: 1px solid rgba(110, 168, 254, 0.22);
  color: rgba(234, 240, 255, 0.92);
  font-size: 0.82rem;
}

/* Footer */
footer { border-top: 1px solid var(--lb-border); }

/* Borders on dark background */
.border-bottom { border-bottom-color: var(--lb-border) !important; }
.border-top { border-top-color: var(--lb-border) !important; }

/* Alerts: slightly darker so they blend with the theme */
.alert {
  background-color: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--lb-border);
  color: rgba(234, 240, 255, 0.92);
}
