/* =========================================================
   DigiPus - app.css (Login-style theme, Bootstrap-friendly)
   Font: Poppins
   ========================================================= */

/* ---------- Theme tokens ---------- */
:root {
  --dp-bg: #f6f8fb;
  --dp-surface: #ffffff;
  --dp-text: #0f172a;
  --dp-muted: #64748b;
  --dp-border: rgba(15, 23, 42, 0.1);

  /* Login-style: biru-violet dominan */
  --dp-primary: #2563eb; /* blue */
  --dp-accent: #7c3aed; /* violet */
  --dp-primary-2: #22c55e; /* green accent */
  --dp-warn: #f59e0b; /* amber */
  --dp-rose: #f43f5e; /* rose */

  --dp-shadow: 0 16px 40px rgba(2, 6, 23, 0.1);
  --dp-shadow-soft: 0 10px 25px rgba(2, 6, 23, 0.08);
  --dp-radius: 20px;
}

/* ---------- Base ---------- */
html,
body {
  height: 100%;
}

body {
  font-family: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, Arial,
    sans-serif;
  background: radial-gradient(
      900px 450px at 15% 10%,
      rgba(37, 99, 235, 0.16),
      transparent 60%
    ),
    radial-gradient(
      900px 450px at 85% 20%,
      rgba(124, 58, 237, 0.14),
      transparent 60%
    ),
    radial-gradient(
      900px 450px at 50% 95%,
      rgba(34, 197, 94, 0.1),
      transparent 60%
    ),
    radial-gradient(
      800px 420px at 95% 95%,
      rgba(244, 63, 94, 0.07),
      transparent 55%
    ),
    var(--dp-bg);
  color: var(--dp-text);
}

/* Better typography feel */
h1,
h2,
h3,
h4,
h5,
h6 {
  letter-spacing: -0.02em;
  font-weight: 700;
}

.text-muted {
  color: var(--dp-muted) !important;
}

small,
.small {
  color: rgba(15, 23, 42, 0.62);
}

/* ---------- Navbar polish ---------- */
.navbar {
  backdrop-filter: saturate(140%) blur(10px);
}

.navbar.bg-white {
  background: rgba(255, 255, 255, 0.88) !important;
  border-bottom: 1px solid var(--dp-border) !important;
}

.navbar .navbar-brand {
  letter-spacing: -0.02em;
}

.navbar .nav-link {
  border-radius: 12px;
  padding: 0.55rem 0.85rem;
  font-weight: 500;
}

.navbar .nav-link:hover {
  background: rgba(37, 99, 235, 0.1);
}

.navbar .nav-link.active {
  background: linear-gradient(
    135deg,
    rgba(37, 99, 235, 0.16),
    rgba(124, 58, 237, 0.12)
  );
  color: #0b1220 !important;
}

/* ---------- Containers / sections ---------- */
main.container {
  min-height: calc(100vh - 220px);
}

/* ---------- Cards (global) ---------- */
.card {
  border-color: var(--dp-border) !important;
  border-radius: var(--dp-radius) !important;
  background: var(--dp-surface);
}

.card.shadow-sm {
  box-shadow: var(--dp-shadow-soft);
}

a .card {
  transition: transform 0.18s ease, box-shadow 0.18s ease,
    border-color 0.18s ease;
}

.card:hover {
  transform: translateY(-2px);
  box-shadow: var(--dp-shadow);
  border-color: rgba(37, 99, 235, 0.22) !important;
}

/* ---------- “Hero” background helpers ---------- */
.bg-body-tertiary {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.92),
    rgba(255, 255, 255, 0.75)
  ) !important;
}

.rounded-4 {
  border-radius: var(--dp-radius) !important;
}

/* ---------- Buttons (Login-style across app) ---------- */
.btn {
  border-radius: 14px;
  font-weight: 600;
  transition: transform 0.14s ease, filter 0.14s ease, box-shadow 0.14s ease;
}

/* Make Bootstrap primary match login gradient */
.btn-primary,
.btn-dp-primary {
  background: linear-gradient(
    135deg,
    var(--dp-primary),
    var(--dp-accent)
  ) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: var(--dp-shadow-soft);
}

.btn-primary:hover,
.btn-dp-primary:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
  color: #fff !important;
}

.btn-dark {
  background: linear-gradient(135deg, #111827, #0f172a);
  border: none;
  box-shadow: 0 12px 24px rgba(2, 6, 23, 0.14);
}

.btn-dark:hover {
  filter: brightness(1.06);
  transform: translateY(-1px);
}

.btn-outline-dark {
  border-color: rgba(15, 23, 42, 0.25);
}

.btn-light.border {
  border-color: var(--dp-border) !important;
}

.btn:focus {
  box-shadow: 0 0 0 0.25rem rgba(37, 99, 235, 0.18) !important;
}

/* Optional: soft secondary action */
.btn-dp-soft {
  background: rgba(37, 99, 235, 0.1);
  border: 1px solid rgba(37, 99, 235, 0.2);
  color: #0b1220;
}

.btn-dp-soft:hover {
  background: rgba(37, 99, 235, 0.14);
  transform: translateY(-1px);
}

/* ---------- Inputs ---------- */
.form-control,
.form-select {
  border-radius: 14px;
  border-color: var(--dp-border);
}

.form-control:focus,
.form-select:focus {
  border-color: rgba(37, 99, 235, 0.55);
  box-shadow: 0 0 0 0.25rem rgba(37, 99, 235, 0.18);
}

.input-group-text {
  border-radius: 14px;
  border-color: var(--dp-border);
  background: rgba(255, 255, 255, 0.92);
  color: rgba(15, 23, 42, 0.78);
}

/* ---------- Badges (lebih “alive”) ---------- */
.badge {
  border-radius: 999px;
  font-weight: 600;
}

.badge.text-bg-success {
  background: linear-gradient(
    135deg,
    rgba(34, 197, 94, 0.98),
    rgba(16, 185, 129, 0.95)
  ) !important;
}

.badge.text-bg-secondary {
  background: linear-gradient(
    135deg,
    rgba(100, 116, 139, 0.95),
    rgba(71, 85, 105, 0.95)
  ) !important;
}

.badge.text-bg-light {
  color: var(--dp-text) !important;
  background: rgba(255, 255, 255, 0.78) !important;
  border: 1px solid var(--dp-border);
}

/* Utility pill like "Secure Area" */
.dp-pill {
  border-radius: 999px;
  padding: 0.42rem 0.85rem;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid var(--dp-border);
  color: var(--dp-text);
}

/* ---------- List group (lebih modern) ---------- */
.list-group {
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-soft);
}

.list-group-item {
  border-color: var(--dp-border);
}

.list-group-item-action {
  transition: background 0.16s ease, transform 0.16s ease;
}

.list-group-item-action:hover {
  background: linear-gradient(
    90deg,
    rgba(37, 99, 235, 0.08),
    rgba(124, 58, 237, 0.06)
  );
  transform: translateX(2px);
}

/* ---------- Pagination ---------- */
.pagination .page-link {
  border-radius: 12px !important;
  border-color: var(--dp-border);
  color: var(--dp-text);
  font-weight: 600;
}

.pagination .page-item.active .page-link {
  background: linear-gradient(
    135deg,
    rgba(37, 99, 235, 0.98),
    rgba(124, 58, 237, 0.9)
  );
  border: none;
}

.pagination .page-link:focus {
  box-shadow: 0 0 0 0.25rem rgba(37, 99, 235, 0.18);
}

/* ---------- Alerts ---------- */
.alert {
  border-radius: var(--dp-radius);
  border-color: var(--dp-border);
}

/* ---------- Footer ---------- */
footer {
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.7),
    rgba(255, 255, 255, 0.88)
  );
  border-top: 1px solid var(--dp-border);
}

footer .text-muted {
  color: rgba(15, 23, 42, 0.6) !important;
}

/* ---------- Utility: subtle separators ---------- */
hr {
  border-color: rgba(15, 23, 42, 0.1);
}

/* ---------- Motion reduce ---------- */
@media (prefers-reduced-motion: reduce) {
  * {
    transition: none !important;
    transform: none !important;
  }
}

/* =========================================================
   DigiPus Auth (Login/Admin) - make whole app match login vibe
   ========================================================= */

.dp-auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px 16px;
}

.dp-auth-card {
  width: 100%;
  max-width: 980px;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  overflow: hidden;
  background: var(--dp-surface);
  box-shadow: var(--dp-shadow);
}

.dp-brand-panel {
  position: relative;
  height: 100%;
  color: #fff;
  background: radial-gradient(
      900px 520px at 10% 0%,
      rgba(37, 99, 235, 0.28),
      transparent 55%
    ),
    radial-gradient(
      820px 460px at 90% 10%,
      rgba(124, 58, 237, 0.22),
      transparent 60%
    ),
    radial-gradient(
      740px 420px at 70% 100%,
      rgba(34, 197, 94, 0.16),
      transparent 60%
    ),
    radial-gradient(
      700px 420px at 95% 95%,
      rgba(244, 63, 94, 0.12),
      transparent 60%
    ),
    linear-gradient(135deg, rgba(37, 99, 235, 0.95), rgba(124, 58, 237, 0.9));
}

.dp-brand-panel::after {
  content: "";
  position: absolute;
  inset: auto -40px -60px -40px;
  height: 160px;
  background: linear-gradient(
    90deg,
    rgba(37, 99, 235, 0.22),
    rgba(124, 58, 237, 0.18),
    rgba(34, 197, 94, 0.16),
    rgba(244, 63, 94, 0.12)
  );
  filter: blur(24px);
  opacity: 0.85;
  pointer-events: none;
}

.dp-brand-inner {
  position: relative;
  z-index: 1;
  padding: 34px 28px;
}

.dp-brand-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(6px);
}

.dp-brand-avatar {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.22);
  box-shadow: var(--dp-shadow-soft);
}

.dp-feature {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.dp-feature i {
  font-size: 18px;
  margin-top: 1px;
  opacity: 0.95;
}

.dp-feature .t {
  font-weight: 600;
}

.dp-feature .d {
  font-size: 13px;
  opacity: 0.92;
}

.dp-form-panel {
  padding: 34px 28px;
  background: var(--dp-surface);
}

@media (max-width: 767.98px) {
  .dp-brand-panel {
    display: none;
  }
  .dp-form-panel {
    padding: 28px 20px;
  }
}

/* =========================================================
   DigiPus Home Enhancements (target: .dp-home)
   ========================================================= */

.dp-home .dp-hero {
  background: radial-gradient(
      900px 450px at 10% 0%,
      rgba(37, 99, 235, 0.18),
      transparent 55%
    ),
    radial-gradient(
      800px 420px at 90% 10%,
      rgba(124, 58, 237, 0.16),
      transparent 55%
    ),
    radial-gradient(
      700px 360px at 70% 100%,
      rgba(34, 197, 94, 0.12),
      transparent 60%
    ),
    radial-gradient(
      650px 340px at 95% 95%,
      rgba(244, 63, 94, 0.08),
      transparent 60%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.92),
      rgba(255, 255, 255, 0.75)
    );
  border-color: rgba(15, 23, 42, 0.1) !important;
  box-shadow: 0 16px 34px rgba(2, 6, 23, 0.1);
  position: relative;
}

.dp-home .dp-hero::after {
  content: "";
  position: absolute;
  inset: auto -40px -60px -40px;
  height: 150px;
  background: linear-gradient(
    90deg,
    rgba(37, 99, 235, 0.22),
    rgba(124, 58, 237, 0.18),
    rgba(34, 197, 94, 0.16),
    rgba(244, 63, 94, 0.12)
  );
  filter: blur(24px);
  opacity: 0.85;
  pointer-events: none;
}

.dp-home .dp-hero .form-control-lg {
  border-radius: 16px;
  border-color: rgba(15, 23, 42, 0.14);
  box-shadow: 0 10px 22px rgba(2, 6, 23, 0.05);
}

.dp-home .dp-hero .btn.btn-dark.btn-lg,
.dp-home .dp-hero .btn.btn-primary.btn-lg,
.dp-home .dp-hero .btn.btn-dp-primary.btn-lg {
  border-radius: 16px;
  box-shadow: 0 16px 28px rgba(2, 6, 23, 0.14);
}

.dp-home .dp-book-card {
  border-color: rgba(15, 23, 42, 0.1) !important;
  overflow: hidden;
  position: relative;
}

.dp-home .dp-book-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(37, 99, 235, 0.1),
    transparent 45%,
    rgba(124, 58, 237, 0.08)
  );
  opacity: 0;
  transition: opacity 0.18s ease;
  pointer-events: none;
}

.dp-home a:hover .dp-book-card {
  transform: translateY(-3px);
  box-shadow: 0 20px 38px rgba(2, 6, 23, 0.12);
  border-color: rgba(124, 58, 237, 0.24) !important;
}

.dp-home a:hover .dp-book-card::before {
  opacity: 1;
}

.dp-home .dp-info-card {
  background: radial-gradient(
      900px 300px at 0% 0%,
      rgba(34, 197, 94, 0.14),
      transparent 55%
    ),
    radial-gradient(
      800px 280px at 100% 20%,
      rgba(37, 99, 235, 0.12),
      transparent 55%
    ),
    radial-gradient(
      700px 300px at 95% 95%,
      rgba(124, 58, 237, 0.1),
      transparent 60%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.93),
      rgba(255, 255, 255, 0.78)
    );
  border-color: rgba(15, 23, 42, 0.1) !important;
}

.dp-home .dp-info-card .bg-body-tertiary {
  background: rgba(255, 255, 255, 0.78) !important;
  border-color: rgba(15, 23, 42, 0.1) !important;
  box-shadow: 0 12px 20px rgba(2, 6, 23, 0.06);
}

@media (max-width: 576px) {
  .dp-home .dp-hero {
    box-shadow: 0 12px 26px rgba(2, 6, 23, 0.1);
  }
}
