/* ============================================================
   RAMADAN THEME - Eagle Sky Academy
   Easily removable after Ramadan - just remove this CSS file
   and the ramadan-banner.html include
   ============================================================ */

/* ── Color Variables ── */
:root {
  --ramadan-navy: #1a1a4e;
  --ramadan-navy-light: #2d1b69;
  --ramadan-gold: #d4a843;
  --ramadan-gold-light: #f0d68a;
  --ramadan-gold-glow: rgba(212, 168, 67, 0.4);
  --ramadan-warm-white: #fff8e7;
  --ramadan-deep-purple: #1e0f3d;
  --ramadan-star: #ffe8a3;
}

/* ============================================================
   0. TOP DECORATION STRIP (Hanging stars & crescents image)
   ============================================================ */

.ramadan-decoration-strip {
  width: 100%;
  height: 120px;
  background-repeat: repeat-x;
  background-size: auto 100%;
  background-position: center top;
  position: relative;
  z-index: 10;
  pointer-events: none;
}

/* Inside dashboard (after navbar, matching navbar width) */
.ramadan-decoration-content {
  height: 62px;
  background-repeat: repeat-x;
  background-size: auto 70px;
  background-position: center top;
  margin-top: 17px;
  margin-bottom: -30px;
  position: relative;
  z-index: 5;
  pointer-events: none;
}

/* On login page - full width, positioned at top */
.ramadan-decoration-login {
  width: 100%;
  height: 58px;
  background-repeat: repeat-x;
  background-size: auto 100%;
  background-position: center top;
  position: absolute;
  top: -26px;
  left: 0;
  z-index: 5;
  pointer-events: none;
  display: block;
}

/* Responsive sizes */
@media (max-width: 768px) {
  .ramadan-decoration-strip {
    height: 70px;
  }
  .ramadan-decoration-content {
    height: 53px;
    margin-top: 17px;
    margin-bottom: -28px;
  }
}


/* ============================================================
   1. LOGIN PAGE STYLES
   ============================================================ */

/* Night sky background for login */
.ramadan-login-bg {
  background: linear-gradient(170deg, #0a0a2e 0%, var(--ramadan-navy) 40%, var(--ramadan-navy-light) 70%, #1a0a3e 100%) !important;
  min-height: 100vh;
  position: relative;
  overflow: hidden;
}

/* Stars layer 1 - slow drift */
.ramadan-login-bg::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 200%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(2px 2px at 20px 30px, var(--ramadan-star), transparent),
    radial-gradient(2px 2px at 40px 70px, rgba(255,255,255,0.8), transparent),
    radial-gradient(1px 1px at 90px 40px, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 130px 80px, rgba(255,255,255,0.6), transparent),
    radial-gradient(2px 2px at 160px 30px, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 200px 60px, rgba(255,255,255,0.7), transparent),
    radial-gradient(2px 2px at 250px 20px, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 300px 90px, rgba(255,255,255,0.5), transparent),
    radial-gradient(2px 2px at 350px 50px, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 400px 30px, rgba(255,255,255,0.8), transparent),
    radial-gradient(1px 1px at 450px 75px, var(--ramadan-star), transparent),
    radial-gradient(2px 2px at 500px 45px, rgba(255,255,255,0.6), transparent),
    radial-gradient(1px 1px at 550px 85px, var(--ramadan-star), transparent),
    radial-gradient(2px 2px at 600px 25px, rgba(255,255,255,0.9), transparent),
    radial-gradient(1px 1px at 650px 65px, var(--ramadan-star), transparent),
    radial-gradient(2px 2px at 700px 40px, rgba(255,255,255,0.7), transparent);
  background-repeat: repeat;
  background-size: 700px 100px;
  animation: ramadan-stars-drift 60s linear infinite, ramadan-twinkle 4s ease-in-out infinite alternate;
}

/* Stars layer 2 - slower drift (depth effect) */
.ramadan-login-bg::after {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 200%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(1.5px 1.5px at 50px 50px, rgba(255,232,163,0.6), transparent),
    radial-gradient(1px 1px at 150px 120px, rgba(255,255,255,0.4), transparent),
    radial-gradient(2px 2px at 280px 30px, rgba(255,232,163,0.5), transparent),
    radial-gradient(1px 1px at 380px 100px, rgba(255,255,255,0.3), transparent),
    radial-gradient(1.5px 1.5px at 520px 60px, rgba(255,232,163,0.4), transparent),
    radial-gradient(1px 1px at 620px 110px, rgba(255,255,255,0.5), transparent),
    radial-gradient(2px 2px at 100px 140px, rgba(255,232,163,0.3), transparent),
    radial-gradient(1px 1px at 450px 20px, rgba(255,255,255,0.4), transparent);
  background-repeat: repeat;
  background-size: 800px 150px;
  animation: ramadan-stars-drift 90s linear infinite, ramadan-twinkle 6s ease-in-out infinite alternate-reverse;
}

@keyframes ramadan-twinkle {
  0% { opacity: 0.5; }
  50% { opacity: 1; }
  100% { opacity: 0.7; }
}

@keyframes ramadan-stars-drift {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* Crescent moon */
.ramadan-crescent {
  position: absolute;
  top: 72px;
  right: 141px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  box-shadow:
    inset -20px -2px 0 0 var(--ramadan-gold),
    0 0 40px var(--ramadan-gold-glow),
    0 0 80px rgba(212, 168, 67, 0.2);
  z-index: 1;
  animation: ramadan-moon-glow 3s ease-in-out infinite alternate;
}

@keyframes ramadan-moon-glow {
  0% { box-shadow: inset -20px -2px 0 0 var(--ramadan-gold), 0 0 40px var(--ramadan-gold-glow), 0 0 80px rgba(212, 168, 67, 0.2); }
  100% { box-shadow: inset -20px -2px 0 0 var(--ramadan-gold-light), 0 0 60px var(--ramadan-gold-glow), 0 0 120px rgba(212, 168, 67, 0.3); }
}

/* Login card styling */
.ramadan-login-bg .card {
  background: rgba(255, 255, 255, 0.95) !important;
  border: 1px solid var(--ramadan-gold) !important;
  border-radius: 16px !important;
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.3), 0 0 20px var(--ramadan-gold-glow) !important;
  position: relative;
  z-index: 5;
  overflow: visible;
}

/* Islamic arch decoration on top of card */
.ramadan-login-bg .card::before {
  content: '';
  position: absolute;
  top: -2px;
  left: 10%;
  right: 10%;
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--ramadan-gold), var(--ramadan-gold-light), var(--ramadan-gold), transparent);
  border-radius: 4px;
}

/* Islamic geometric pattern border at bottom */
.ramadan-login-bg .card::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 10%;
  right: 10%;
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--ramadan-gold), var(--ramadan-gold-light), var(--ramadan-gold), transparent);
  border-radius: 4px;
}

/* Login button gold */
.ramadan-login-bg .btn-primary {
  background: linear-gradient(135deg, var(--ramadan-gold) 0%, #b8912e 100%) !important;
  border-color: var(--ramadan-gold) !important;
  color: #fff !important;
  font-weight: 600;
  box-shadow: 0 4px 15px rgba(212, 168, 67, 0.3);
  transition: all 0.3s ease;
}

.ramadan-login-bg .btn-primary:hover {
  background: linear-gradient(135deg, var(--ramadan-gold-light) 0%, var(--ramadan-gold) 100%) !important;
  box-shadow: 0 6px 20px rgba(212, 168, 67, 0.5);
  transform: translateY(-1px);
}

/* Login navbar */
.ramadan-login-bg .layout-navbar {
  background: transparent !important;
  top: 24px;
}

.ramadan-login-bg .landing-hero {
  background: transparent !important;
}

/* Login footer */
.ramadan-login-bg .landing-footer {
  background: rgba(10, 10, 46, 0.8) !important;
}

/* Ramadan Kareem text above login form */
.ramadan-greeting-login {
  text-align: center;
  margin-bottom: 16px;
  padding: 12px 0;
}

.ramadan-greeting-login h4 {
  font-family: 'Cairo', sans-serif;
  color: var(--ramadan-gold);
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0;
  text-shadow: 0 0 10px var(--ramadan-gold-glow);
}

/* Ramadan Kareem SVG in login card */
.ramadan-kareem-svg {
  max-width: 220px;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* Lantern decorations for login */
.ramadan-lanterns-login {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  overflow: hidden;
}

.ramadan-lantern-svg {
  position: absolute;
  top: -5px;
  animation: ramadan-lantern-swing 4s ease-in-out infinite;
  transform-origin: top center;
  z-index: 2;
  filter: drop-shadow(0 8px 25px rgba(212, 168, 67, 0.5));
}

.ramadan-lantern-svg svg {
  display: block;
}

.ramadan-lantern-svg:nth-child(1) { left: 3%; width: 50px; animation-delay: 0s; animation-duration: 4.5s; }
.ramadan-lantern-svg:nth-child(2) { left: 46%; width: 38px; animation-delay: 0.7s; animation-duration: 3.8s; }
.ramadan-lantern-svg:nth-child(3) { right: 33%; width: 42px; animation-delay: 1.2s; animation-duration: 4.2s; }
.ramadan-lantern-svg:nth-child(4) { right: 2%; width: 48px; animation-delay: 0.4s; animation-duration: 3.5s; }

@keyframes ramadan-lantern-swing {
  0%, 100% { transform: rotate(-4deg); }
  50% { transform: rotate(4deg); }
}

/* Lantern glow pulse on login page */
.ramadan-lantern-svg .lantern-glow {
  animation: ramadan-svg-glow 2.5s ease-in-out infinite alternate;
}

@keyframes ramadan-svg-glow {
  0% { opacity: 0.4; }
  100% { opacity: 0.8; }
}

/* Login lanterns responsive */
@media (max-width: 768px) {
  .ramadan-lantern-svg:nth-child(1) { width: 30px; }
  .ramadan-lantern-svg:nth-child(2) { width: 22px; }
  .ramadan-lantern-svg:nth-child(3) { width: 24px; }
  .ramadan-lantern-svg:nth-child(4) { width: 28px; }
}

@media (max-width: 480px) {
  .ramadan-lantern-svg:nth-child(1) { width: 22px; }
  .ramadan-lantern-svg:nth-child(2) { width: 16px; }
  .ramadan-lantern-svg:nth-child(3) { width: 18px; }
  .ramadan-lantern-svg:nth-child(4) { width: 20px; }
}

/* ============================================================
   2. RAMADAN NAVBAR HERO (Below navbar - looks like part of it)
   ============================================================ */

/* Hidden - kept for reference, navbar now has the ramadan design */
.ramadan-navbar-hero {
  display: none;
  background: linear-gradient(135deg, var(--ramadan-navy) 0%, var(--ramadan-navy-light) 50%, var(--ramadan-deep-purple) 100%);
  padding: 18px 24px;
  position: relative;
  overflow: hidden;
  margin: -1px -1.5rem 0;
  border-radius: 0 0 12px 12px;
  animation: ramadan-hero-fadein 0.8s ease-out;
}

@keyframes ramadan-hero-fadein {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Stars overlay */
.ramadan-navbar-hero-stars {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(1px 1px at 5% 20%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 15% 70%, rgba(255,255,255,0.6), transparent),
    radial-gradient(1.5px 1.5px at 25% 40%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 35% 15%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1px 1px at 45% 65%, var(--ramadan-star), transparent),
    radial-gradient(1.5px 1.5px at 55% 30%, rgba(255,255,255,0.7), transparent),
    radial-gradient(1px 1px at 65% 80%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 75% 20%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1.5px 1.5px at 85% 55%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 95% 35%, rgba(255,255,255,0.6), transparent);
  animation: ramadan-twinkle 3s ease-in-out infinite alternate;
}

/* Content layout */
.ramadan-navbar-hero-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 2;
  min-height: 60px;
}

/* Left side: Text */
.ramadan-navbar-hero-text {
  flex: 0 0 auto;
}

.ramadan-navbar-hero-text h3 {
  font-family: 'Cairo', sans-serif;
  color: var(--ramadan-gold-light);
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 4px 0;
  text-shadow: 0 2px 10px rgba(212, 168, 67, 0.3);
}

.ramadan-navbar-hero-text p {
  font-family: 'Cairo', sans-serif;
  color: rgba(255, 248, 231, 0.8);
  font-size: 0.85rem;
  margin: 0;
  line-height: 1.4;
}

/* Center: Lantern + Moon + Lantern */
.ramadan-navbar-hero-center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

/* Hero moon */
.ramadan-hero-moon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  box-shadow: inset -15px -2px 0 0 var(--ramadan-gold-light);
  animation: ramadan-moon-glow 3s ease-in-out infinite alternate;
}

/* Hero lantern */
.ramadan-hero-lantern {
  display: inline-flex;
  align-items: flex-start;
  width: 34px;
  filter: drop-shadow(0 4px 12px rgba(212, 168, 67, 0.5));
  animation: ramadan-hero-lantern-sway 3s ease-in-out infinite;
  transform-origin: top center;
}

.ramadan-hero-lantern:nth-child(1) { animation-delay: 0s; }
.ramadan-hero-lantern:nth-child(3) { animation-delay: 0.6s; }

.ramadan-hero-lantern svg {
  width: 100%;
  height: auto;
}

.ramadan-hero-lantern .lantern-glow {
  animation: ramadan-svg-glow 2s ease-in-out infinite alternate;
}

@keyframes ramadan-hero-lantern-sway {
  0%, 100% { transform: rotate(-3deg); }
  50% { transform: rotate(3deg); }
}

/* Gold accent line at bottom */
.ramadan-navbar-hero-accent {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--ramadan-gold) 20%, var(--ramadan-gold-light) 50%, var(--ramadan-gold) 80%, transparent 100%);
}

/* Navbar hero responsive */
@media (max-width: 768px) {
  .ramadan-navbar-hero {
    padding: 14px 16px;
  }
  .ramadan-navbar-hero-content {
    flex-direction: column;
    text-align: center;
    gap: 12px;
    min-height: auto;
  }
  .ramadan-navbar-hero-text h3 {
    font-size: 1.2rem;
  }
  .ramadan-navbar-hero-text p {
    font-size: 0.8rem;
  }
  .ramadan-navbar-hero-center {
    position: relative;
    left: auto;
    top: auto;
    transform: none;
  }
  .ramadan-hero-moon {
    width: 36px;
    height: 36px;
    box-shadow: inset -10px -2px 0 0 var(--ramadan-gold-light);
  }
  .ramadan-hero-lantern {
    width: 26px;
  }
}

/* ============================================================
   3. SIDEBAR RAMADAN STYLES
   ============================================================ */

/* Sidebar night sky theme */
.layout-menu.bg-menu-theme.ramadan-sidebar {
  background: linear-gradient(180deg, var(--ramadan-navy) 0%, var(--ramadan-deep-purple) 100%) !important;
}

/* Sidebar stars */
.layout-menu.bg-menu-theme.ramadan-sidebar::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(1px 1px at 20px 60px, rgba(255,232,163,0.7), transparent),
    radial-gradient(1px 1px at 80px 120px, rgba(255,255,255,0.5), transparent),
    radial-gradient(1.5px 1.5px at 50px 200px, rgba(255,232,163,0.6), transparent),
    radial-gradient(1px 1px at 150px 80px, rgba(255,255,255,0.4), transparent),
    radial-gradient(1px 1px at 120px 300px, rgba(255,232,163,0.5), transparent),
    radial-gradient(1.5px 1.5px at 40px 400px, rgba(255,255,255,0.6), transparent),
    radial-gradient(1px 1px at 180px 250px, rgba(255,232,163,0.4), transparent),
    radial-gradient(1px 1px at 100px 500px, rgba(255,255,255,0.5), transparent),
    radial-gradient(1.5px 1.5px at 60px 600px, rgba(255,232,163,0.6), transparent),
    radial-gradient(1px 1px at 200px 450px, rgba(255,255,255,0.4), transparent);
  animation: ramadan-twinkle 5s ease-in-out infinite alternate;
}

/* Sidebar menu items styling */
.ramadan-sidebar .menu-inner > .menu-item > .menu-link {
  position: relative;
  z-index: 1;
}

.ramadan-sidebar .menu-inner .menu-item .menu-link {
  color: rgba(255, 248, 231, 0.85) !important;
}

.ramadan-sidebar .menu-inner .menu-item .menu-link:hover {
  color: var(--ramadan-gold-light) !important;
  background: rgba(212, 168, 67, 0.1) !important;
}

.ramadan-sidebar .menu-inner .menu-item.active > .menu-link,
.ramadan-sidebar .menu-inner .menu-item.open > .menu-link {
  background: rgba(212, 168, 67, 0.15) !important;
  color: var(--ramadan-gold-light) !important;
}

/* Sidebar icons gold */
.ramadan-sidebar .menu-icon {
  color: var(--ramadan-gold) !important;
}

/* Sidebar header/divider */
.ramadan-sidebar .menu-header {
  color: var(--ramadan-gold) !important;
}

/* Sidebar app brand */
.ramadan-sidebar .app-brand {
  position: relative;
  z-index: 1;
}

/* Sidebar scrollbar */
.ramadan-sidebar .menu-inner {
  position: relative;
  z-index: 1;
}

/* Menu toggle icon */
.ramadan-sidebar .layout-menu-toggle i,
.ramadan-sidebar .menu-toggle-icon {
  color: var(--ramadan-gold) !important;
}

/* Sub menu items */
.ramadan-sidebar .menu-sub .menu-link {
  color: rgba(255, 248, 231, 0.7) !important;
}

.ramadan-sidebar .menu-sub .menu-link:hover {
  color: var(--ramadan-gold-light) !important;
}

/* Menu inner shadow */
.ramadan-sidebar .menu-inner-shadow {
  background: linear-gradient(var(--ramadan-navy) 41%, rgba(26, 26, 78, 0.11) 95%, rgba(26, 26, 78, 0)) !important;
}

/* ============================================================
   4. NAVBAR RAMADAN STYLES
   ============================================================ */

.layout-navbar.ramadan-navbar {
  background: linear-gradient(135deg, var(--ramadan-navy) 0%, var(--ramadan-navy-light) 50%, var(--ramadan-deep-purple) 100%) !important;
  border-bottom: none !important;
  border-radius: 0.375rem !important;
  position: relative;
  overflow: visible;
  padding-bottom: 0 !important;
}

/* Stars on navbar */
.layout-navbar.ramadan-navbar::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background-image:
    radial-gradient(1px 1px at 5% 30%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 15% 70%, rgba(255,255,255,0.5), transparent),
    radial-gradient(1.5px 1.5px at 28% 20%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 40% 80%, rgba(255,255,255,0.4), transparent),
    radial-gradient(1px 1px at 55% 25%, var(--ramadan-star), transparent),
    radial-gradient(1.5px 1.5px at 68% 65%, rgba(255,255,255,0.6), transparent),
    radial-gradient(1px 1px at 80% 40%, var(--ramadan-star), transparent),
    radial-gradient(1px 1px at 92% 75%, rgba(255,255,255,0.5), transparent);
  animation: ramadan-twinkle 4s ease-in-out infinite alternate;
}

/* Gold accent line at bottom */
.layout-navbar.ramadan-navbar::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--ramadan-gold) 20%, var(--ramadan-gold-light) 50%, var(--ramadan-gold) 80%, transparent 100%);
  z-index: 5;
}

/* Navbar icons color - make them visible on dark bg */
.layout-navbar.ramadan-navbar .navbar-nav .nav-link,
.layout-navbar.ramadan-navbar .navbar-nav .nav-link i {
  color: var(--ramadan-gold-light) !important;
  position: relative;
  z-index: 2;
}

.layout-navbar.ramadan-navbar .navbar-nav .nav-link:hover,
.layout-navbar.ramadan-navbar .navbar-nav .nav-link:hover i {
  color: var(--ramadan-gold) !important;
}

/* Menu toggle icon on dark bg */
.layout-navbar.ramadan-navbar .layout-menu-toggle i {
  color: var(--ramadan-gold-light) !important;
}

/* Navbar dropdown menus keep normal style */
.layout-navbar.ramadan-navbar .dropdown-menu {
  background: #fff;
}

.layout-navbar.ramadan-navbar .dropdown-menu .dropdown-item {
  color: #566a7f;
}

/* User avatar border - circular */
.layout-navbar.ramadan-navbar .avatar {
  border: 2px solid var(--ramadan-gold) !important;
  border-radius: 50% !important;
  overflow: hidden;
}

.layout-navbar.ramadan-navbar .avatar img {
  border-radius: 50% !important;
}

/* Hide notification bell - not needed */
.layout-navbar.ramadan-navbar .dropdown-notifications {
  display: none !important;
}

/* Navbar-nav-right z-index */
.layout-navbar.ramadan-navbar .navbar-nav-right {
  position: relative;
  z-index: 2;
}

/* ── Ramadan content inside navbar ── */
.ramadan-navbar-row {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 0 15px;
  z-index: 2;
}

/* Left: Text */
.ramadan-navbar-text {
  position: absolute;
  left: 24px;
  z-index: 2;
}

.ramadan-navbar-text h3 {
  font-family: 'Cairo', sans-serif;
  color: var(--ramadan-gold-light);
  font-size: 1.4rem;
  font-weight: 700;
  margin: 0 0 3px 0;
  text-shadow: 0 2px 10px rgba(212, 168, 67, 0.3);
}

.ramadan-navbar-text p {
  font-family: 'Cairo', sans-serif;
  color: rgba(255, 248, 231, 0.75);
  font-size: 0.82rem;
  margin: 0;
  line-height: 1.3;
}

/* Center: Lantern + Moon + Lantern */
.ramadan-navbar-center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

/* Navbar moon */
.ramadan-nav-moon {
  width: 45px;
  height: 45px;
  border-radius: 50%;
  box-shadow: inset -14px -2px 0 0 var(--ramadan-gold-light);
  animation: ramadan-moon-glow 3s ease-in-out infinite alternate;
}

/* Navbar lanterns */
.ramadan-nav-lantern {
  display: inline-flex;
  align-items: flex-start;
  width: 30px;
  filter: drop-shadow(0 3px 10px rgba(212, 168, 67, 0.5));
  animation: ramadan-nav-lantern-sway 3s ease-in-out infinite;
  transform-origin: top center;
}

.ramadan-nav-lantern:nth-child(1) { animation-delay: 0s; }
.ramadan-nav-lantern:nth-child(3) { animation-delay: 0.6s; }

.ramadan-nav-lantern svg {
  width: 100%;
  height: auto;
}

.ramadan-nav-lantern .lantern-glow {
  animation: ramadan-svg-glow 2s ease-in-out infinite alternate;
}

@keyframes ramadan-nav-lantern-sway {
  0%, 100% { transform: rotate(-3deg); }
  50% { transform: rotate(3deg); }
}

/* Navbar ramadan responsive */
@media (max-width: 1199px) {
  .ramadan-navbar-text {
    left: 70px;
  }
  [dir="rtl"] .ramadan-navbar-text {
    right: 60px;
  }
  .ramadan-navbar-text h3 {
    font-size: 1.1rem;
  }
  .ramadan-navbar-text p {
    font-size: 0.7rem;
  }
  .ramadan-navbar-center {
    display: none !important;
  }
  .ramadan-navbar-row {
    padding: 8px 0 10px;
  }
}

@media (max-width: 576px) {
  .ramadan-navbar-text h3 {
    font-size: 0.9rem;
  }
  .ramadan-navbar-text p {
    font-size: 0.6rem;
  }
  .ramadan-nav-moon {
    width: 24px;
    height: 24px;
    box-shadow: inset -10px -2px 0 0 var(--ramadan-gold-light);
  }
  .ramadan-nav-lantern {
    width: 18px;
  }
  .ramadan-navbar-center {
    gap: 6px;
  }
  .ramadan-navbar-row {
    padding: 6px 0 8px;
  }
  [dir="rtl"] .ramadan-navbar-text {
    right: 60px;
  }
}

/* ============================================================
   5. ISLAMIC GEOMETRIC PATTERN (Top Border)
   ============================================================ */

.ramadan-top-pattern {
  height: 4px;
  background: linear-gradient(90deg,
    transparent,
    var(--ramadan-gold) 10%,
    var(--ramadan-gold-light) 20%,
    var(--ramadan-gold) 30%,
    transparent 40%,
    var(--ramadan-gold) 50%,
    var(--ramadan-gold-light) 60%,
    var(--ramadan-gold) 70%,
    transparent 80%,
    var(--ramadan-gold) 90%,
    transparent
  );
  position: sticky;
  top: 0;
  z-index: 9999;
}

/* ============================================================
   6. CARDS & UI ELEMENTS
   ============================================================ */

/* Dashboard cards subtle gold */
.ramadan-cards .card {
  border: 1px solid rgba(212, 168, 67, 0.12);
  transition: border-color 0.3s ease;
}

.ramadan-cards .card:hover {
  border-color: rgba(212, 168, 67, 0.3);
}

/* ============================================================
   7. FOOTER RAMADAN STYLES
   ============================================================ */

.ramadan-footer-text {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ramadan-gold);
  font-family: 'Cairo', sans-serif;
  font-size: 0.8rem;
  opacity: 0.8;
}

.ramadan-footer-text .ramadan-footer-moon {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  box-shadow: inset -5px -1px 0 0 var(--ramadan-gold);
}

/* ============================================================
   8. DARK MODE ADJUSTMENTS
   ============================================================ */

.dark-style .ramadan-banner {
  border-color: rgba(212, 168, 67, 0.4);
}

.dark-style .ramadan-login-bg .card {
  background: rgba(40, 40, 80, 0.95) !important;
}

.dark-style .ramadan-login-bg .card .form-label,
.dark-style .ramadan-login-bg .card .form-check-label {
  color: rgba(255, 248, 231, 0.85);
}

.dark-style .ramadan-login-bg .card .form-control {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(212, 168, 67, 0.3);
  color: var(--ramadan-warm-white);
}

/* ============================================================
   9. RTL ADJUSTMENTS
   ============================================================ */

[dir="rtl"] .ramadan-crescent {
  right: auto;
  left: 80px;
}

[dir="rtl"] .ramadan-lantern-svg:nth-child(1) { left: auto; right: 3%; }
[dir="rtl"] .ramadan-lantern-svg:nth-child(2) { left: auto; right: 18%; }
[dir="rtl"] .ramadan-lantern-svg:nth-child(3) { right: auto; left: 18%; }
[dir="rtl"] .ramadan-lantern-svg:nth-child(4) { right: auto; left: 3%; }

/* RTL: Navbar text position flip */
[dir="rtl"] .ramadan-navbar-text {
  left: auto;
  right: 60px;
}

/* ============================================================
   10. PRINT - HIDE RAMADAN DECORATIONS
   ============================================================ */

@media print {
  .ramadan-navbar-hero,
  .ramadan-crescent,
  .ramadan-lanterns-login,
  .ramadan-top-pattern,
  .ramadan-footer-text,
  .ramadan-decoration-content,
  .ramadan-decoration-login {
    display: none !important;
  }
}
