/**
 * Nabawi — nuansa modern Islami untuk Taqmir (struktur FlexStart)
 * Palet: hijau zamrud, emas kuning, krem lembut; Latin: Sora; Arab: Amiri / Scheherazade
 */
.nabawi-theme {
  --nb-emerald-950: #052e28;
  --nb-emerald-900: #0a3d35;
  --nb-emerald-800: #0d4a3e;
  --nb-emerald-700: #145a4a;
  --nb-gold-500: #c9a227;
  --nb-gold-400: #d4af37;
  --nb-cream-50: #fbf8f1;
  --nb-cream-100: #f4ede0;
  --nb-ink: #1a1f1e;
  --font-heading: "Sora", "Segoe UI", system-ui, sans-serif;
  --font-ui: "Sora", "Segoe UI", system-ui, sans-serif;
  --font-arabic: "Amiri", "Scheherazade New", serif;
}

.nabawi-theme body {
  font-family: var(--font-ui);
  color: var(--nb-ink);
  background-color: var(--nb-cream-50);
  font-size: 1rem;
  -webkit-font-smoothing: antialiased;
}

.nabawi-theme h1,
.nabawi-theme h2,
.nabawi-theme h3,
.nabawi-theme h4,
.nabawi-theme .h1,
.nabawi-theme .h2,
.nabawi-theme .section-title h2,
.nabawi-theme .section-header h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--nb-emerald-900);
}

/* Header & footer: logo teks putih, ukuran sedikit lebih besar dari menu (menu 16px → logo 19px) */
.nabawi-theme .header .logo span,
.nabawi-theme .footer .footer-top .footer-info .logo span {
  color: #fff !important;
  font-size: 19px !important;
}

/* Header: permadani gelap lembut */
.nabawi-theme .header {
  background: linear-gradient(180deg, rgba(5, 46, 40, 0.97) 0%, rgba(10, 61, 53, 0.95) 100%) !important;
  box-shadow: 0 4px 24px rgba(5, 46, 40, 0.25);
  border-bottom: 1px solid rgba(201, 162, 39, 0.25);
}

.nabawi-theme .header .navbar a,
.nabawi-theme .header .navbar ul li a {
  color: rgba(255, 255, 255, 0.92) !important;
}

.nabawi-theme .header .navbar ul li a:hover {
  color: var(--nb-gold-400) !important;
}

.nabawi-theme .mobile-nav-toggle {
  color: var(--nb-cream-50) !important;
}

/* Primary CTAs & links merujuk ke palet masjid */
.nabawi-theme .btn-get-started,
.nabawi-theme .about .btn-read-more {
  background: linear-gradient(135deg, var(--nb-gold-500) 0%, var(--nb-gold-400) 100%) !important;
  color: var(--nb-emerald-950) !important;
  border: none !important;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(201, 162, 39, 0.35);
}

.nabawi-theme .btn-get-started:hover,
.nabawi-theme .about .btn-read-more:hover {
  filter: brightness(1.08);
  transform: translateY(-2px);
}

.nabawi-theme a {
  color: var(--nb-emerald-800);
}

.nabawi-theme a:hover {
  color: var(--nb-gold-500);
}

.nabawi-theme .text-primary {
  color: var(--nb-emerald-800) !important;
}

.nabawi-theme .bg-primary,
.nabawi-theme .btn-primary {
  background-color: var(--nb-emerald-800) !important;
  border-color: var(--nb-emerald-700) !important;
}

.nabawi-theme .btn-outline-primary {
  color: var(--nb-emerald-800) !important;
  border-color: var(--nb-emerald-700) !important;
}

.nabawi-theme .btn-outline-primary:hover {
  background-color: var(--nb-emerald-800) !important;
  color: #fff !important;
}

/* Kartu & section */
.nabawi-theme .about .content,
.nabawi-theme .features .feature-box,
.nabawi-theme .counts .count-box {
  border-radius: 12px;
}

.nabawi-theme section:not(#hero) {
  background-color: transparent;
}

.nabawi-theme #about,
.nabawi-theme .about {
  background: linear-gradient(180deg, var(--nb-cream-50) 0%, #fff 50%, var(--nb-cream-100) 100%);
}

/* Footer selaras */
.nabawi-theme #footer.footer {
  background: linear-gradient(180deg, var(--nb-emerald-950) 0%, var(--nb-emerald-900) 40%, #071f1c 100%);
  color: rgba(255, 255, 255, 0.88);
}

.nabawi-theme #footer .footer-top,
.nabawi-theme #footer .footer-top-wrap {
  background: transparent;
}

.nabawi-theme #footer h4,
.nabawi-theme #footer .footer-links a {
  color: rgba(255, 255, 255, 0.95);
}

.nabawi-theme #footer .footer-links a:hover {
  color: var(--nb-gold-400);
}

.nabawi-theme #footer .copyright,
.nabawi-theme #footer .credits {
  color: rgba(255, 255, 255, 0.75);
}

/* Ikon media sosial di footer — putih (bukan biru default FlexStart) */
.nabawi-theme #footer .footer-top .social-links a,
.nabawi-theme #footer .social-links a,
.nabawi-theme #footer .social-links .btn {
  color: rgba(255, 255, 255, 0.92) !important;
  background: transparent !important;
  border-color: rgba(255, 255, 255, 0.35) !important;
  box-shadow: none !important;
}

.nabawi-theme #footer .footer-top .social-links a i,
.nabawi-theme #footer .social-links a i,
.nabawi-theme #footer .social-links .btn i {
  color: inherit !important;
}

.nabawi-theme #footer .footer-top .social-links a:hover,
.nabawi-theme #footer .social-links a:hover,
.nabawi-theme #footer .social-links .btn:hover {
  color: var(--nb-gold-400, #e8c547) !important;
  border-color: var(--nb-gold-400, #e8c547) !important;
}

.nabawi-theme .back-to-top {
  background: var(--nb-gold-500) !important;
  color: var(--nb-emerald-950) !important;
}

/* Kutipan / ayat — huruf Arab tetap terbaca */
.nabawi-theme .hero h2,
.nabawi-theme blockquote {
  font-family: var(--font-ui);
}

.nabawi-theme .ayat,
.nabawi-theme [lang="ar"],
.nabawi-theme .arabic {
  font-family: var(--font-arabic);
  font-size: 1.15em;
  line-height: 1.9;
}

/* Aksen ornamen tipis di pinggir hero (hanya dekoratif) */
.nabawi-theme #hero.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.12;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cg fill='none' stroke='%23c9a227' stroke-width='0.5'%3E%3Cpath d='M40 0v80M0 40h80M20 20l40 40M60 20L20 60'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 80px 80px;
}

@media (prefers-reduced-motion: reduce) {
  .nabawi-theme #hero {
    animation: none !important;
  }
}

/* ══════════════════════════════════════════════
   FIX 1 — Dropdown menu text contrast
   nabawi-islamic.css forces all .navbar a to white,
   which makes dropdown text invisible on white bg.
══════════════════════════════════════════════ */
.nabawi-theme .header .navbar .dropdown ul,
.nabawi-theme .header .navbar ul .dropdown ul {
  background: #fff !important;
}
.nabawi-theme .header .navbar .dropdown ul a,
.nabawi-theme .header .navbar .dropdown ul li a {
  color: #012970 !important;
  font-weight: 600;
}
.nabawi-theme .header .navbar .dropdown ul a:hover,
.nabawi-theme .header .navbar .dropdown ul li:hover > a,
.nabawi-theme .header .navbar .dropdown ul .active > a {
  color: var(--nb-emerald-700) !important;
}

/* ══════════════════════════════════════════════
   FIX 3 — Mobile nav: teks gelap di atas panel putih
   Saat .navbar-mobile aktif, background panel putih
   tapi teks diwarisi warna putih → tidak terlihat.
══════════════════════════════════════════════ */
.nabawi-theme .header .navbar.navbar-mobile,
.nabawi-theme .navbar-mobile {
  background: #fff !important;
  box-shadow: -4px 0 20px rgba(5, 46, 40, 0.18) !important;
}

.nabawi-theme .header .navbar.navbar-mobile ul,
.nabawi-theme .navbar-mobile ul,
.nabawi-theme .navbar-mobile > ul {
  background: #fff !important;
}

/* Override putih !important yang diwarisi dari .header .navbar a */
.nabawi-theme .header .navbar.navbar-mobile a,
.nabawi-theme .header .navbar.navbar-mobile ul li a,
.nabawi-theme .header .navbar.navbar-mobile a:focus {
  color: #0a3d35 !important;
}

.nabawi-theme .header .navbar.navbar-mobile a:hover,
.nabawi-theme .header .navbar.navbar-mobile ul li a:hover,
.nabawi-theme .header .navbar.navbar-mobile li:hover > a {
  color: #c9a227 !important;
}

.nabawi-theme .header .navbar.navbar-mobile .dropdown ul,
.nabawi-theme .header .navbar.navbar-mobile .dropdown > ul {
  background: #f4ede0 !important;
}

.nabawi-theme .header .navbar.navbar-mobile .dropdown ul a,
.nabawi-theme .header .navbar.navbar-mobile .dropdown ul li a {
  color: #0a3d35 !important;
}

/* Close button (bi-x) dan hamburger saat panel terbuka */
.nabawi-theme .header .navbar.navbar-mobile .mobile-nav-toggle,
.nabawi-theme .header .navbar.navbar-mobile .bi-x {
  color: #0a3d35 !important;
}

/* ══════════════════════════════════════════════
   FIX 2 — Custom Nabawi hero section (.nb-hero)
   All .nb-* classes were missing — headings
   inherited dark #0a3d35 on dark background.
══════════════════════════════════════════════ */
.nabawi-theme .nb-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  background-attachment: fixed;
}

/* Dark overlay so text stays readable over mosque photos */
.nabawi-theme .nb-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    rgba(5, 46, 40, 0.82) 0%,
    rgba(10, 61, 53, 0.75) 50%,
    rgba(5, 46, 40, 0.70) 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* Geometric ornament circles */
.nabawi-theme .nb-geo {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
}
.nabawi-theme .nb-geo-1 {
  width: 420px; height: 420px;
  top: -120px; right: -120px;
  border: 1.5px solid rgba(201, 162, 39, 0.18);
}
.nabawi-theme .nb-geo-2 {
  width: 280px; height: 280px;
  top: -40px; right: -40px;
  border: 1px solid rgba(201, 162, 39, 0.12);
}
.nabawi-theme .nb-geo-3 {
  width: 600px; height: 600px;
  bottom: -220px; left: -180px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

/* Inner container sits above overlay */
.nabawi-theme .nb-hero-inner {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 120px 0 80px;
}

/* Bismillah */
.nabawi-theme .nb-bismillah {
  font-family: var(--font-arabic);
  font-size: clamp(1.4rem, 3vw, 2rem);
  color: var(--nb-gold-400);
  letter-spacing: 0.04em;
  margin-bottom: 20px;
  text-shadow: 0 2px 8px rgba(5, 46, 40, 0.6);
}

/* Mosque name heading */
.nabawi-theme .nb-hero-title {
  font-family: var(--font-heading) !important;
  font-size: clamp(2rem, 5vw, 3.4rem) !important;
  font-weight: 700 !important;
  color: #fbf8f1 !important;
  text-shadow: 0 3px 16px rgba(5, 46, 40, 0.55) !important;
  margin-bottom: 16px;
  line-height: 1.2;
}

/* Tagline */
.nabawi-theme .nb-hero-tagline {
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: rgba(251, 248, 241, 0.92) !important;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.35);
  max-width: 640px;
  margin: 0 auto 28px;
  line-height: 1.7;
}

.nabawi-theme .nb-hero-loc {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.95em;
  color: var(--nb-gold-400);
  margin-top: 8px;
}

/* CTA buttons */
.nabawi-theme .nb-hero-ctas {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 32px;
}

.nabawi-theme .nb-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 30px;
  border-radius: 50px;
  background: linear-gradient(135deg, var(--nb-gold-500) 0%, var(--nb-gold-400) 100%);
  color: var(--nb-emerald-950) !important;
  font-weight: 700;
  font-size: 1rem;
  border: none;
  box-shadow: 0 4px 16px rgba(201, 162, 39, 0.40);
  transition: all 0.3s ease;
  text-decoration: none;
}
.nabawi-theme .nb-btn-primary:hover {
  filter: brightness(1.08);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(201, 162, 39, 0.50);
  color: var(--nb-emerald-950) !important;
}

.nabawi-theme .nb-btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: 50px;
  background: rgba(251, 248, 241, 0.10);
  backdrop-filter: blur(8px);
  color: #fbf8f1 !important;
  font-weight: 600;
  font-size: 1rem;
  border: 1.5px solid rgba(251, 248, 241, 0.45);
  transition: all 0.3s ease;
  text-decoration: none;
}
.nabawi-theme .nb-btn-outline:hover {
  background: rgba(251, 248, 241, 0.20);
  border-color: rgba(251, 248, 241, 0.70);
  transform: translateY(-2px);
}

/* Quranic verse strip */
.nabawi-theme .nb-verse-strip {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  background: rgba(201, 162, 39, 0.12);
  border: 1px solid rgba(201, 162, 39, 0.30);
  backdrop-filter: blur(6px);
  border-radius: 50px;
  padding: 10px 24px;
  font-size: 0.9rem;
  color: rgba(251, 248, 241, 0.90);
  max-width: 640px;
  margin: 0 auto;
}
.nabawi-theme .nb-verse-arabic {
  font-family: var(--font-arabic);
  font-size: 1.15em;
  color: var(--nb-gold-400);
  line-height: 1.6;
}
.nabawi-theme .nb-verse-sep {
  color: rgba(201, 162, 39, 0.50);
}
.nabawi-theme .nb-verse-trans {
  font-style: italic;
  color: rgba(251, 248, 241, 0.80);
}

/* Stats strip at bottom of hero */
.nabawi-theme .nb-hero-stats {
  position: relative;
  z-index: 2;
  background: rgba(5, 46, 40, 0.55);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(201, 162, 39, 0.20);
  padding: 20px 0;
}
.nabawi-theme .nb-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  color: rgba(251, 248, 241, 0.90);
  padding: 12px;
  border-right: 1px solid rgba(201, 162, 39, 0.15);
}
.nabawi-theme .nb-stat:last-child {
  border-right: none;
}
.nabawi-theme .nb-stat i {
  font-size: 1.5rem;
  color: var(--nb-gold-400);
  margin-bottom: 4px;
}
.nabawi-theme .nb-stat strong {
  font-size: 1.4rem;
  font-weight: 700;
  color: #fbf8f1;
}
.nabawi-theme .nb-stat span {
  font-size: 0.8rem;
  color: rgba(251, 248, 241, 0.65);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Mosque hero photo: ensure overlay covers it */
.nabawi-theme .nb-hero.mosque-hero-has-photo {
  background-size: cover !important;
  background-position: center !important;
}

@media (max-width: 768px) {
  .nabawi-theme .nb-hero-inner {
    padding: 100px 0 60px;
  }
  .nabawi-theme .nb-hero-title {
    font-size: clamp(1.6rem, 7vw, 2.4rem) !important;
  }
  .nabawi-theme .nb-verse-strip {
    flex-direction: column;
    gap: 6px;
    border-radius: 16px;
    text-align: center;
  }
}
