/* ============================================================
   QUR'AN WORLD VIEW — COMPONENTS CSS
   components.css · v1.0 · Phase 2
   ============================================================
   Page-specific and shared component styles.
   All design tokens come from design.css — never hardcode
   colours, fonts, or spacing values here.
   ============================================================ */


/* ============================================================
   NAVBAR
   ============================================================ */

.qwv-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  height: var(--navbar-height);
  /* Transition for scroll state */
  transition: background var(--transition-slow), box-shadow var(--transition-slow);
}

/* Transparent by default; fills on scroll */
.navbar-bg {
  position: absolute;
  inset: 0;
  background: transparent;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  transition: background var(--transition-slow),
              backdrop-filter var(--transition-slow),
              box-shadow var(--transition-slow);
}

.qwv-navbar.scrolled .navbar-bg {
  background: rgba(10, 12, 16, 0.88);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  box-shadow: 0 1px 0 var(--border);
}

[data-theme="light"] .qwv-navbar.scrolled .navbar-bg {
  background: rgba(246, 241, 232, 0.90);
}

.navbar-inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

/* Logo — natural width only, never stretches */
.navbar-logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}

.navbar-logo-img {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.navbar-logo-text {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.06em;
  line-height: 1.2;
  white-space: nowrap;
}

@media (min-width: 480px) {
  .navbar-logo-text {
    font-size: var(--text-base);
  }
}

/* Desktop nav links — absolutely centred in the navbar.
   This is the only reliable way to keep links in the true
   centre regardless of logo width or controls width. */
.navbar-links {
  display: none;
  align-items: center;
  gap: 0;
  list-style: none;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}

@media (min-width: 1024px) {
  .navbar-links { display: flex; }
}

.navbar-link {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: var(--space-2) var(--space-2);
  border-radius: var(--r-sm);
  text-decoration: none;
  transition: color var(--transition-fast), background var(--transition-fast);
  white-space: nowrap;
}

/* Hide lower-priority links until there's enough room.
   About and Contact are reachable from the footer — they
   drop off the desktop nav at narrower desktop widths. */
.navbar-link-secondary {
  display: none;
}

@media (min-width: 1200px) {
  .navbar-link-secondary { display: block; }
}

.navbar-link:hover {
  color: var(--off-white);
  background: rgba(255, 255, 255, 0.05);
}

.navbar-link.active {
  color: var(--gold);
}

[data-theme="light"] .navbar-link:hover {
  background: rgba(0, 0, 0, 0.04);
}

/* Right controls — natural width, pinned to the right.
   z-index:2 ensures it renders above the absolutely-positioned links
   if they ever overflow (they shouldn't, but safety first). */
.navbar-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}

/* Hide lang toggle and auth CTA on smallest screens */
@media (max-width: 639px) {
  .navbar-controls .lang-toggle { display: none; }
  .navbar-controls .btn          { display: none; }
}

@media (max-width: 1023px) {
  .navbar-controls .btn { display: none; }
}

/* Hamburger */
.navbar-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: transparent;
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
  padding: 0;
  flex-shrink: 0;
}

.navbar-hamburger:hover {
  border-color: var(--border-gold);
  background: rgba(255, 255, 255, 0.04);
}

@media (min-width: 1024px) {
  .navbar-hamburger { display: none; }
}

.hamburger-bar {
  display: block;
  width: 18px;
  height: 1.5px;
  background: var(--text);
  border-radius: var(--r-full);
  transition: transform var(--transition-base), opacity var(--transition-fast);
}

.navbar-hamburger[aria-expanded="true"] .hamburger-bar:nth-child(1) {
  transform: translateY(6.5px) rotate(45deg);
}
.navbar-hamburger[aria-expanded="true"] .hamburger-bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.navbar-hamburger[aria-expanded="true"] .hamburger-bar:nth-child(3) {
  transform: translateY(-6.5px) rotate(-45deg);
}

/* ── Mobile overlay ── */
.navbar-mobile-overlay {
  position: fixed;
  inset: 0;
  background: var(--bg);
  z-index: var(--z-overlay);
  display: flex;
  flex-direction: column;
  opacity: 0;
  pointer-events: none;
  transform: translateX(100%);
  transition: opacity var(--transition-base),
              transform var(--transition-base);
}

.navbar-mobile-overlay.open {
  opacity: 1;
  pointer-events: all;
  transform: translateX(0);
}

.mobile-overlay-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: var(--space-6) var(--space-5);
  overflow-y: auto;
}

.mobile-close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  align-self: flex-end;
  margin-bottom: var(--space-8);
  transition: border-color var(--transition-fast), color var(--transition-fast);
}

.mobile-close-btn:hover {
  border-color: var(--border-gold);
  color: var(--gold);
}

.mobile-nav-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}

.mobile-nav-link {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  text-decoration: none;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border);
  display: block;
  transition: color var(--transition-fast);
}

.mobile-nav-link:hover,
.mobile-nav-link.active {
  color: var(--gold);
}

.mobile-lang-toggle {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}

.mobile-lang-btn {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-2) var(--space-5);
  cursor: pointer;
  transition: all var(--transition-fast);
  min-height: 40px;
}

.mobile-lang-btn.active {
  background: var(--gold);
  border-color: var(--gold);
  color: #0A0C10;
}

.mobile-auth {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: auto;
}


/* ============================================================
   FOOTER
   ============================================================ */

.qwv-footer {
  background: var(--bg);
  border-top: 1px solid var(--border);
  padding-top: var(--space-16);
  padding-bottom: var(--space-10);
}

.qwv-footer .divider-gold {
  margin-bottom: var(--space-12);
  margin-top: 0;
}

.footer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  margin-bottom: var(--space-12);
}

@media (min-width: 640px) {
  .footer-inner {
    grid-template-columns: 1fr 1fr;
  }
}

@media (min-width: 1024px) {
  .footer-inner {
    grid-template-columns: 2fr 1fr 1fr;
    gap: var(--space-16);
  }
}

/* Brand */
.footer-logo-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  margin-bottom: var(--space-4);
}

.footer-logo-img {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

.footer-logo-wordmark {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--gold);
  letter-spacing: 0.06em;
}

.footer-tagline {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: var(--space-6);
  max-width: 34ch;
}

.footer-social {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer-social-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-social-link:hover {
  color: var(--gold);
}

/* Nav columns */
.footer-nav-heading {
  margin-bottom: var(--space-5);
}

.footer-nav-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer-nav-link {
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
  line-height: 1.4;
}

.footer-nav-link:hover {
  color: var(--gold);
}

/* Bottom bar */
.footer-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  padding-top: var(--space-8);
  border-top: 1px solid var(--border);
  text-align: center;
}

@media (min-width: 640px) {
  .footer-bottom {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }
}

.footer-supplication {
  font-family: var(--font-arabic);
  font-size: var(--arabic-sm);
  color: var(--gold-dim);
  direction: rtl;
  line-height: 1.8;
}

.footer-legal {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-muted);
}

@media (min-width: 640px) {
  .footer-legal {
    align-items: flex-end;
  }
}

.footer-license {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.footer-copyright {
  color: var(--text-muted);
  opacity: 0.6;
}


/* ============================================================
   PAGE LOADER
   ============================================================ */

#page-loader {
  position: fixed;
  inset: 0;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--space-6);
  z-index: var(--z-top);
  transition: opacity var(--transition-slow);
}

#page-loader.fade-out {
  opacity: 0;
  pointer-events: none;
}

.loader-logo {
  width: 56px;
  height: 56px;
  object-fit: contain;
  animation: float 3s ease-in-out infinite;
}

.loader-spinner {
  width: 28px;
  height: 28px;
  border: 2px solid var(--border);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}


/* ============================================================
   HERO SLIDESHOW (placeholder — full styles in home page)
   ============================================================ */

.hero-slideshow {
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 560px;
  overflow: hidden;
  background: var(--bg);
}

.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-5);
  text-align: center;
  opacity: 0;
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}

.hero-slide.active {
  opacity: 1;
  pointer-events: all;
}

.hero-slide-dots {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--space-2);
  z-index: 2;
}

.hero-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--r-full);
  background: rgba(255, 255, 255, 0.25);
  border: none;
  cursor: pointer;
  transition: background var(--transition-base), transform var(--transition-base);
  padding: 0;
}

.hero-dot.active {
  background: var(--gold);
  transform: scale(1.4);
}


/* ============================================================
   AYAH OF THE DAY
   ============================================================ */

.ayah-section {
  text-align: center;
  padding-block: var(--space-20);
}

.ayah-card {
  max-width: 700px;
  margin-inline: auto;
  padding: var(--space-10) var(--space-8);
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-xl);
  position: relative;
  overflow: hidden;
}

.ayah-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--crimson), var(--gold));
}

.ayah-arabic {
  margin-bottom: var(--space-6);
}

.ayah-translation {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--text);
  line-height: 1.7;
  margin-bottom: var(--space-4);
}

.ayah-reference {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-6);
}

.ayah-social-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--gold);
  text-decoration: none;
  border: 1px solid var(--border-gold);
  border-radius: var(--r-full);
  padding: var(--space-2) var(--space-4);
  transition: background var(--transition-fast), color var(--transition-fast);
}

.ayah-social-link:hover {
  background: rgba(201, 168, 76, 0.08);
  color: var(--gold-bright);
}


/* ============================================================
   JOURNEY OVERVIEW SECTION
   ============================================================ */

.journey-stages-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  max-width: 600px;
  margin-inline: auto;
}

@media (min-width: 640px) {
  .journey-stages-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    max-width: 100%;
  }
}

@media (min-width: 1024px) {
  .journey-stages-grid {
    grid-template-columns: repeat(5, 1fr);
    max-width: 100%;
  }
}

.journey-stage-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6) var(--space-5);
  text-align: center;
  transition: border-color var(--transition-base), transform var(--transition-base);
  position: relative;
  overflow: hidden;
}

.journey-stage-card:hover {
  border-color: var(--border-gold);
  transform: translateY(-3px);
}

.journey-stage-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--crimson), var(--gold));
  transform: scaleX(0);
  transition: transform var(--transition-base);
  transform-origin: left;
}

.journey-stage-card:hover::after {
  transform: scaleX(1);
}

.stage-card-number {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--text-muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: var(--space-3);
}

.stage-card-arabic {
  font-family: var(--font-arabic);
  font-size: var(--arabic-lg);
  color: var(--gold);
  direction: rtl;
  line-height: 1.6;
  margin-bottom: var(--space-2);
}

.stage-card-name {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.06em;
  margin-bottom: var(--space-3);
}

.stage-card-role {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.5;
}

.journey-gate-rule {
  text-align: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--text-muted);
  margin-top: var(--space-8);
  margin-bottom: var(--space-8);
}


/* ============================================================
   TESTIMONIALS
   ============================================================ */

.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .testimonials-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .testimonials-grid { grid-template-columns: repeat(3, 1fr); }
}

.testimonial-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: border-color var(--transition-base);
}

.testimonial-card:hover {
  border-color: var(--border-gold);
}

.testimonial-quote-mark {
  font-family: var(--font-serif);
  font-size: 2.5rem;
  color: var(--gold-dim);
  line-height: 1.2;
  align-self: flex-start;
}

.testimonial-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-md);
  color: var(--text);
  line-height: 1.7;
  flex: 1;
}

.testimonial-author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}

.testimonial-author-name {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.04em;
}

.testimonial-author-stage {
  font-size: var(--text-xs);
  color: var(--gold);
}


/* ============================================================
   BLOG CARDS
   ============================================================ */

.blog-cards-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .blog-cards-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .blog-cards-grid { grid-template-columns: repeat(3, 1fr); }
}

.blog-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: border-color var(--transition-base), transform var(--transition-base);
  display: flex;
  flex-direction: column;
}

.blog-card:hover {
  border-color: var(--border-gold);
  transform: translateY(-2px);
}

.blog-card-body {
  padding: var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.blog-card-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.blog-card-excerpt {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  flex: 1;
}

.blog-card-meta {
  font-size: var(--text-xs);
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  margin-top: auto;
}

.blog-card-read-more {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: var(--space-4);
}

.blog-card-read-more:hover {
  color: var(--gold-bright);
}


/* ============================================================
   LOGIN PAGE
   ============================================================ */

.login-page {
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-5);
  background: var(--bg);
}

.login-card {
  width: 100%;
  max-width: 420px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-10) var(--space-8);
  position: relative;
  overflow: hidden;
}

.login-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--crimson), var(--gold));
}

.login-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}

.login-logo img {
  width: 52px;
  height: 52px;
  object-fit: contain;
  animation: float 4s ease-in-out infinite;
}

.login-error {
  background: var(--error-dim);
  border: 1px solid rgba(192, 57, 43, 0.30);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--error);
  margin-bottom: var(--space-5);
  text-align: center;
}

.login-success {
  background: var(--success-dim);
  border: 1px solid rgba(76, 175, 122, 0.30);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--success);
  margin-bottom: var(--space-5);
  text-align: center;
}


/* ============================================================
   SECTION HEADINGS — shared across pages
   ============================================================ */

.section-heading {
  text-align: center;
  margin-bottom: var(--space-12);
}

.section-heading h2 {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-3);
}

@media (min-width: 768px) {
  .section-heading h2 { font-size: var(--text-3xl); }
}

.section-heading p {
  color: var(--text-muted);
  max-width: 52ch;
  margin-inline: auto;
  font-size: var(--text-md);
  line-height: 1.6;
}


/* ============================================================
   DASHBOARD — base layout
   ============================================================ */

.dashboard-page {
  min-height: 100svh;
  background: var(--bg);
  padding: var(--space-6) var(--space-5);
}

@media (min-width: 768px) {
  .dashboard-page {
    padding: var(--space-10) var(--space-8);
    max-width: var(--container-lg);
    margin-inline: auto;
  }
}

.dashboard-header {
  margin-bottom: var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .dashboard-header {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}

.dashboard-greeting {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--off-white);
}

@media (min-width: 768px) {
  .dashboard-greeting { font-size: var(--text-2xl); }
}

.dashboard-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

/* ── Journey Map ── */
.journey-map {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-bottom: var(--space-12);
}

@media (min-width: 640px) {
  .journey-map {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: var(--space-3);
  }
}

.stage-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5) var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color var(--transition-base);
  position: relative;
  overflow: hidden;
}

.stage-card-active {
  border-color: var(--border-gold);
  background: linear-gradient(160deg,
    var(--bg-card) 60%,
    rgba(201, 168, 76, 0.05) 100%);
}

.stage-card-active::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold-dim), var(--gold));
}

.stage-card-complete {
  border-color: rgba(76, 175, 122, 0.25);
}

.stage-card-locked {
  opacity: 0.6;
}

.stage-card-silhouette {
  opacity: 0.22;
  pointer-events: none;
  filter: blur(1px);
}

/* ── Reflection Space ── */
.reflection-space {
  margin-top: var(--space-12);
  padding-top: var(--space-10);
  border-top: 1px solid var(--border);
}

.reflection-textarea {
  min-height: 140px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.7;
  resize: vertical;
  width: 100%;
  transition: border-color var(--transition-fast);
}

.reflection-textarea:focus {
  border-color: var(--gold);
  outline: none;
  box-shadow: 0 0 0 3px rgba(201, 168, 76, 0.10);
}

.reflection-prompt {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-md);
  color: var(--text-muted);
  margin-bottom: var(--space-5);
  line-height: 1.6;
}

/* ── Founder Insights ── */
.founder-insights {
  margin-top: var(--space-10);
  padding: var(--space-6);
  background: linear-gradient(135deg,
    rgba(201, 168, 76, 0.06) 0%,
    rgba(120, 15, 0, 0.06) 100%);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
}


/* ============================================================
   END OF components.css
   ============================================================ */


/* ============================================================
   HOME PAGE
   ============================================================ */

.home-page {
  /* Page wrapper — no padding-top here, hero is full-bleed */
}

.home-section {
  padding-block: var(--space-20);
}

.home-section-alt {
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* ── HERO ────────────────────────────────────────────────── */

.home-hero-wrap {
  position: relative;
}

.hero-slideshow {
  position: relative;
  width: 100%;
  height: 100svh;
  min-height: 580px;
  max-height: 900px;
  overflow: hidden;
  background: var(--bg);
  outline: none;
}

.hero-particles {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

/* Radial glow behind text */
.hero-glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 70% 60% at 50% 55%,
    rgba(120, 15, 0, 0.13) 0%,
    rgba(201, 168, 76, 0.05) 45%,
    transparent 72%
  );
  pointer-events: none;
}

/* Slides */
.hero-slides-container {
  position: absolute;
  inset: 0;
}

.hero-slide {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-6);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

.hero-slide.active {
  opacity: 1;
  pointer-events: all;
}

.hero-slide-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
  text-align: center;
  max-width: 800px;
  width: 100%;
}

/* Problem slide text */
.hero-problem-line1 {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 5vw, 3.4rem);
  font-weight: 400;
  color: var(--off-white);
  letter-spacing: 0.02em;
  line-height: 1.2;
}

.hero-problem-line2 {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(1.2rem, 3.5vw, 2.2rem);
  color: var(--gold);
  letter-spacing: 0.01em;
  line-height: 1.4;
}

[data-theme="light"] .hero-problem-line1 { color: var(--off-white); }
[data-theme="light"] .hero-problem-line2 { color: var(--gold); }

/* Solution slide */
.hero-brand-eyebrow {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-dim);
}

.hero-solution-heading {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 4.5vw, 3rem);
  font-weight: 500;
  color: var(--off-white);
  letter-spacing: 0.02em;
  line-height: 1.25;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

[data-theme="light"] .hero-problem-line1,
[data-theme="light"] .hero-solution-heading { color: var(--off-white); }

.hero-solution-line {
  display: block;
}

.hero-solution-line:last-child {
  color: var(--gold);
}

.hero-cta {
  margin-top: var(--space-4);
}

/* Entry animations for slide text */
@keyframes hero-fade-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero-anim {
  animation: hero-fade-up 0.7s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.hero-anim-delay  { animation-delay: 0.18s; }
.hero-anim-delay2 { animation-delay: 0.38s; }

/* Dot indicators */
.hero-slide-dots {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: var(--space-2);
  z-index: 2;
}

.hero-dot {
  width: 7px;
  height: 7px;
  border-radius: var(--r-full);
  background: rgba(255, 255, 255, 0.22);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background var(--transition-base), transform var(--transition-base);
  -webkit-tap-highlight-color: transparent;
}

.hero-dot:hover  { background: rgba(255, 255, 255, 0.45); }
.hero-dot.active { background: var(--gold); transform: scale(1.5); }

/* Keyboard hint */
.hero-keyboard-hint {
  position: absolute;
  bottom: var(--space-8);
  right: var(--space-6);
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.18);
  display: none;
}

@media (hover: hover) {
  .hero-keyboard-hint { display: block; }
}

/* ── ABOUT SECTION ───────────────────────────────────────── */

.home-about {
  position: relative;
  overflow: hidden;
}

.about-bg-glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(
    ellipse 80% 50% at 50% 100%,
    rgba(120, 15, 0, 0.08) 0%,
    transparent 70%
  );
  pointer-events: none;
}

/* ── PRINCIPLES GRID ─────────────────────────────────────── */

.principles-wrap {
  margin-top: var(--space-4);
}

.principles-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
}

@media (min-width: 640px) {
  .principles-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .principles-grid { grid-template-columns: repeat(4, 1fr); }
}

.principle-card {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-5);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  transition: border-color var(--transition-base);
}

.principle-card:hover {
  border-color: var(--border-gold);
}

.principle-number {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--gold-dim);
  letter-spacing: 0.1em;
  flex-shrink: 0;
  margin-top: 2px;
  min-width: 18px;
}

.principle-text {
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.65;
}

/* ── BLOG EMPTY STATE ────────────────────────────────────── */

.blog-empty-state {
  text-align: center;
  padding: var(--space-12);
  color: var(--text-muted);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lg);
}



/* ============================================================
   LOGIN PAGE
   ============================================================ */

.login-page {
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6) var(--space-5);
  background: var(--bg);
  position: relative;
  overflow: hidden;
}

/* Ambient background glow */
.login-bg-glow {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 30% 20%,  rgba(120, 15, 0, 0.10) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 75% 80%,  rgba(201, 168, 76, 0.07) 0%, transparent 55%);
  pointer-events: none;
}

/* Card */
.login-card {
  width: 100%;
  max-width: 440px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-10) var(--space-8);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}

/* Gold accent line at top */
.login-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--crimson), var(--gold), var(--crimson));
}

/* Logo */
.login-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}

.login-logo img {
  width: 64px;
  height: 64px;
  object-fit: contain;
}

.login-brand-name {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: 0.10em;
  color: var(--gold);
  text-transform: uppercase;
}

/* Heading block */
.login-heading {
  text-align: center;
  margin-bottom: var(--space-8);
}

.login-heading h1 {
  margin-bottom: var(--space-2);
}

.login-subheading {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.5;
}

/* Form */
.login-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.login-form .form-group {
  margin-bottom: var(--space-2);
}

/* Password field wrapper */
.password-field {
  position: relative;
}

.password-field input {
  padding-right: 48px;
}

.password-toggle {
  position: absolute;
  right: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-1);
  border-radius: var(--r-sm);
  transition: color var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.password-toggle:hover {
  color: var(--gold);
}

/* Submit button */
.login-form .btn-primary {
  margin-top: var(--space-4);
}

/* Forgot / back link */
.login-forgot-link {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: var(--text-sm);
  cursor: pointer;
  text-align: center;
  padding: var(--space-3);
  border-radius: var(--r-md);
  transition: color var(--transition-fast);
  margin-top: var(--space-2);
  font-family: var(--font-body);
}

.login-forgot-link:hover {
  color: var(--gold);
}

/* Button loading spinner */
.btn-spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}

/* Error & success messages */
.login-error,
.login-success {
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  text-align: center;
  margin-bottom: var(--space-4);
  line-height: 1.5;
}

.login-error {
  background: var(--error-dim);
  border: 1px solid rgba(192, 57, 43, 0.30);
  color: var(--error);
}

.login-success {
  background: var(--success-dim);
  border: 1px solid rgba(76, 175, 122, 0.30);
  color: var(--success);
}

/* Language toggle at bottom of card */
.login-lang-toggle {
  display: flex;
  justify-content: center;
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border);
}

/* RTL support for Urdu */
[dir="rtl"] .login-card {
  text-align: right;
}

[dir="rtl"] .login-heading,
[dir="rtl"] .login-subheading,
[dir="rtl"] .login-forgot-link {
  text-align: center;
}

[dir="rtl"] .form-label {
  text-align: right;
}

[dir="rtl"] .password-toggle {
  right: auto;
  left: var(--space-3);
}

[dir="rtl"] .password-field input {
  padding-right: var(--space-4);
  padding-left: 48px;
}



/* ============================================================
   DASHBOARD
   ============================================================ */

.dash-page {
  min-height: 100svh;
  background: var(--bg);
  display: flex;
  flex-direction: column;
}

/* ── TOP BAR ─────────────────────────────────────────────── */

.dash-topbar {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: rgba(10, 12, 16, 0.90);
  backdrop-filter: blur(16px) saturate(1.4);
  -webkit-backdrop-filter: blur(16px) saturate(1.4);
  border-bottom: 1px solid var(--border);
}

[data-theme="light"] .dash-topbar {
  background: rgba(246, 241, 232, 0.92);
}

.dash-topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: 0 var(--space-5);
  height: var(--navbar-height);
  max-width: var(--container-xl);
  margin-inline: auto;
  width: 100%;
}

/* Logo */
.dash-logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  flex-shrink: 0;
}

.dash-logo img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.dash-logo-text {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.06em;
  white-space: nowrap;
  display: none;
}

@media (min-width: 480px) {
  .dash-logo-text { display: block; }
}

/* Desktop nav */
.dash-nav {
  display: none;
  align-items: center;
  gap: var(--space-1);
}

@media (min-width: 768px) {
  .dash-nav { display: flex; }
}

.dash-nav-link {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--r-sm);
  text-decoration: none;
  transition: color var(--transition-fast), background var(--transition-fast);
  white-space: nowrap;
}

.dash-nav-link:hover {
  color: var(--off-white);
  background: rgba(255,255,255,0.05);
}

/* Controls */
.dash-topbar-controls {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Avatar button */
.dash-user-menu { position: relative; }

.dash-avatar-btn {
  background: none;
  border: 1px solid var(--border-gold);
  border-radius: var(--r-full);
  cursor: pointer;
  padding: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.dash-avatar-btn:hover {
  border-color: var(--gold);
  box-shadow: var(--shadow-gold);
}

.dash-avatar {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.05em;
}

/* Dropdown */
.dash-dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  min-width: 200px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  pointer-events: none;
  transform: translateY(-6px) scale(0.97);
  transition: opacity var(--transition-base),
              transform var(--transition-base);
  z-index: var(--z-dropdown);
}

.dash-dropdown.open {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0) scale(1);
}

.dash-dropdown-name {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.04em;
}

.dash-dropdown-email {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-1);
  word-break: break-all;
}

.dash-dropdown-item {
  width: 100%;
  text-align: left;
  font-size: var(--text-sm);
  color: var(--text-muted);
  padding: var(--space-2) 0;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  transition: color var(--transition-fast);
}

.dash-dropdown-item:hover { color: var(--error); }

/* Hamburger */
.dash-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}

@media (min-width: 768px) { .dash-hamburger { display: none; } }

.dash-hamburger span {
  display: block;
  width: 16px;
  height: 1.5px;
  background: var(--text);
  border-radius: var(--r-full);
}

/* Mobile drawer */
.dash-mobile-drawer {
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.dash-mobile-drawer.open {
  max-height: 400px;
}

.dash-mobile-link {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--text-muted);
  text-decoration: none;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border);
  letter-spacing: 0.04em;
  transition: color var(--transition-fast);
}

.dash-mobile-link:hover { color: var(--gold); }

.dash-mobile-lang {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4) 0;
}

/* ── MAIN CONTENT ────────────────────────────────────────── */

.dash-main {
  flex: 1;
  padding-block: var(--space-8);
}

.dash-content {
  max-width: var(--container-lg);
  margin-inline: auto;
  padding-inline: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

@media (min-width: 768px) {
  .dash-content { padding-inline: var(--space-8); }
}

/* ── DASHBOARD HEADER ────────────────────────────────────── */

.dash-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--border);
}

@media (min-width: 640px) {
  .dash-header {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}

.dash-greeting {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: clamp(var(--text-xl), 3vw, var(--text-2xl));
  color: var(--off-white);
  line-height: 1.3;
}

.dash-greeting-sub {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-top: var(--space-2);
}

.dash-stats {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}

.dash-gems-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: rgba(201,168,76,0.06);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-full);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-sm);
  color: var(--gold);
  font-weight: 500;
}

/* ── SECTION WRAPPER ─────────────────────────────────────── */

.dash-section {}

.dash-section-header {
  margin-bottom: var(--space-8);
}

.dash-section-title {
  font-size: var(--text-xl);
  margin-top: var(--space-2);
}

@media (min-width: 768px) {
  .dash-section-title { font-size: var(--text-2xl); }
}

/* ── JOURNEY MAP ─────────────────────────────────────────── */

.journey-map-scroll-wrap {
  position: relative;
}

/* Mobile: horizontal scroll */
.journey-map-track {
  display: flex;
  gap: var(--space-4);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: var(--space-4);
}

.journey-map-track::-webkit-scrollbar { display: none; }

/* Desktop: grid */
@media (min-width: 768px) {
  .journey-map-track {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    overflow-x: visible;
  }
}

/* Scroll dots (mobile only) */
.journey-scroll-dots {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
}

@media (min-width: 768px) {
  .journey-scroll-dots { display: none; }
}

.journey-scroll-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--r-full);
  background: var(--border);
  transition: background var(--transition-base), transform var(--transition-base);
}

.journey-scroll-dot.active {
  background: var(--gold);
  transform: scale(1.4);
}

/* ── STAGE CARD ──────────────────────────────────────────── */

.stage-card-dash {
  flex: 0 0 260px; /* mobile: fixed width for scroll */
  scroll-snap-align: center;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-6) var(--space-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
  text-align: center;
  transition: border-color var(--transition-base),
              transform var(--transition-base),
              box-shadow var(--transition-base);
  position: relative;
  overflow: hidden;
}

@media (min-width: 768px) {
  .stage-card-dash {
    flex: unset;
  }
}

/* Active card */
.stage-card-active {
  border-color: var(--border-gold);
  background: linear-gradient(160deg, var(--bg-card) 50%, rgba(201,168,76,0.06) 100%);
  box-shadow: var(--shadow-gold);
}

.stage-card-active::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--gold-dim), var(--gold));
}

/* Complete card */
.stage-card-complete {
  border-color: rgba(76,175,122,0.25);
}

.stage-card-complete::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--success);
}

/* Next (locked but visible) */
.stage-card-next {
  opacity: 0.7;
}

/* Far (silhouette) */
.stage-card-far {
  opacity: 0.28;
  filter: grayscale(0.5);
  pointer-events: none;
}

/* Stage number */
.sc-top {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  position: relative;
}

.sc-number-wrap { position: relative; }

.sc-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
}

.sc-number-active {
  background: linear-gradient(135deg, var(--gold-dim), var(--gold));
  color: #0A0C10;
}

.sc-number-complete {
  background: var(--success);
  color: #0A0C10;
}

.sc-number-locked {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  color: var(--text-muted);
}

.sc-lock {
  position: absolute;
  right: 0;
  color: var(--text-muted);
}

.sc-pending-dot {
  position: absolute;
  right: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold);
  animation: pulse-gold 2s ease-in-out infinite;
}

/* Arabic */
.sc-arabic { width: 100%; }
.sc-arabic-dim { opacity: 0.4; }

/* Body */
.sc-name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.04em;
}

.sc-name-active { color: var(--gold); }

.sc-role {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.5;
  margin-top: var(--space-1);
}

/* Status */
.sc-status { width: 100%; }

.sc-progress-bar {
  height: 3px;
  background: var(--bg-surface);
  border-radius: var(--r-full);
  overflow: hidden;
  margin-bottom: var(--space-2);
}

.sc-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--gold-dim), var(--gold));
  border-radius: var(--r-full);
  transition: width 1s cubic-bezier(0.16,1,0.3,1);
}

.sc-progress-text,
.sc-pending-text,
.sc-locked-text,
.sc-far-text {
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-align: center;
}

.sc-complete-text {
  font-size: var(--text-xs);
  color: var(--success);
  font-weight: 500;
  text-align: center;
}

.sc-pending-text { color: var(--gold); }

/* CTA */
.sc-cta { width: 100%; margin-top: auto; }

/* ── REFLECTION SPACE ────────────────────────────────────── */

.dash-reflection-section {
  padding-top: var(--space-8);
  border-top: 1px solid var(--border);
}

.reflection-wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 768px) {
  .reflection-wrap {
    grid-template-columns: 3fr 2fr;
    align-items: start;
  }
}

.reflection-editor {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.reflection-prompt-text {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--gold);
  line-height: 1.6;
  margin-bottom: var(--space-2);
}

/* Publish toggle */
.reflection-publish-toggle {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

@media (min-width: 480px) {
  .reflection-publish-toggle { flex-direction: row; gap: var(--space-6); }
}

.reflection-pub-option {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  cursor: pointer;
  font-size: var(--text-sm);
  color: var(--text);
  user-select: none;
}

/* Hide native radio — replace with custom gold indicator */
.reflection-pub-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Custom radio circle */
.reflection-pub-option::before {
  content: '';
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--border-gold);
  background: transparent;
  transition: border-color var(--transition-fast), background var(--transition-fast);
  display: inline-block;
}

/* Selected state — gold fill with white dot */
.reflection-pub-option:has(input:checked)::before {
  border-color: var(--gold);
  background: var(--gold);
  box-shadow: inset 0 0 0 4px var(--bg-card);
}

/* Hover */
.reflection-pub-option:hover::before {
  border-color: var(--gold);
}

/* Selected label brightens */
.reflection-pub-option:has(input:checked) {
  color: var(--off-white);
}

/* Recent reflections */
.reflection-recent {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5);
}

.reflection-recent-card {
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--border);
}

.reflection-recent-card:last-child { border-bottom: none; }

.reflection-recent-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

.reflection-recent-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.reflection-recent-excerpt {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.6;
}

/* ── FOUNDER INSIGHTS ────────────────────────────────────── */

.founder-insights-section {
  padding-top: var(--space-8);
  border-top: 1px solid var(--border);
}

.founder-insights-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.founder-insight-card {
  background: linear-gradient(135deg, rgba(201,168,76,0.06) 0%, rgba(120,15,0,0.06) 100%);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
}

.founder-insight-accent {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--gold), var(--crimson));
  border-radius: var(--r-full);
}

.founder-insight-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.03em;
  margin-bottom: var(--space-3);
  padding-left: var(--space-4);
}

.founder-insight-body {
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.7;
  padding-left: var(--space-4);
}

.founder-insight-date {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-4);
  padding-left: var(--space-4);
}



/* ============================================================
   ADMIN PANEL
   ============================================================ */

.admin-page {
  display: flex;
  min-height: 100svh;
  background: var(--bg);
}

/* ── SIDEBAR ─────────────────────────────────────────────── */

.admin-sidebar {
  width: 240px;
  flex-shrink: 0;
  background: var(--bg-card);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: var(--z-overlay);
  transform: translateX(-100%);
  transition: transform var(--transition-base);
  overflow-y: auto;
}

@media (min-width: 1024px) {
  .admin-sidebar {
    position: sticky;
    top: 0;
    height: 100svh;
    transform: translateX(0);
  }
}

.admin-sidebar.open { transform: translateX(0); }

.admin-sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--scrim);
  z-index: calc(var(--z-overlay) - 1);
}

.admin-sidebar-overlay.open { display: block; }

@media (min-width: 1024px) {
  .admin-sidebar-overlay { display: none !important; }
}

.admin-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-4);
  border-bottom: 1px solid var(--border);
  gap: var(--space-3);
}

.admin-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  flex: 1;
  min-width: 0;
}

.admin-logo img {
  width: 28px;
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;
}

.admin-logo-title {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--gold);
  letter-spacing: 0.08em;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.admin-sidebar-close {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: var(--space-1);
  font-size: var(--text-base);
  flex-shrink: 0;
}

@media (min-width: 1024px) { .admin-sidebar-close { display: none; } }

/* Nav */
.admin-nav {
  flex: 1;
  padding: var(--space-4) var(--space-2);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.admin-nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-3);
  border-radius: var(--r-md);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  text-align: left;
  width: 100%;
  transition: background var(--transition-fast), color var(--transition-fast);
  position: relative;
}

.admin-nav-item:hover {
  background: rgba(255,255,255,0.04);
  color: var(--off-white);
}

.admin-nav-item.active {
  background: rgba(201,168,76,0.10);
  color: var(--gold);
}

.admin-nav-icon {
  font-size: var(--text-base);
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}

.admin-nav-label { flex: 1; }

.admin-nav-badge {
  background: var(--crimson);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  border-radius: var(--r-full);
  padding: 2px 6px;
  min-width: 18px;
  text-align: center;
}

/* Sidebar footer */
.admin-sidebar-footer {
  padding: var(--space-4);
  border-top: 1px solid var(--border);
}

.admin-user-name {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--off-white);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-1);
}

.admin-user-email {
  font-size: var(--text-xs);
  color: var(--text-muted);
  word-break: break-all;
  margin-bottom: var(--space-3);
}

.admin-logout-btn {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-size: var(--text-sm);
  cursor: pointer;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--r-md);
  width: 100%;
  font-family: var(--font-body);
  transition: all var(--transition-fast);
}

.admin-logout-btn:hover {
  border-color: var(--error);
  color: var(--error);
}

/* ── MAIN AREA ───────────────────────────────────────────── */

.admin-main-wrap {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

@media (min-width: 1024px) {
  .admin-main-wrap { margin-left: 0; }
}

/* Top bar (mobile) */
.admin-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--space-5);
  height: var(--navbar-height);
  border-bottom: 1px solid var(--border);
  background: var(--bg-card);
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
}

@media (min-width: 1024px) { .admin-topbar { display: none; } }

.admin-topbar-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.06em;
}

.admin-hamburger {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  cursor: pointer;
  padding: 0;
}

.admin-hamburger span {
  display: block;
  width: 16px;
  height: 1.5px;
  background: var(--text);
  border-radius: var(--r-full);
}

.admin-topbar-home {
  color: var(--text-muted);
  text-decoration: none;
  display: flex;
  align-items: center;
  padding: var(--space-2);
  transition: color var(--transition-fast);
}

.admin-topbar-home:hover { color: var(--gold); }

.admin-main {
  flex: 1;
  padding: var(--space-6);
  overflow-y: auto;
}

@media (min-width: 768px) { .admin-main { padding: var(--space-8); } }

/* ── MODULE WRAPPER ──────────────────────────────────────── */

.admin-module {
  max-width: 1100px;
}

.admin-module-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-8);
  gap: var(--space-4);
  flex-wrap: wrap;
}

.admin-module-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  letter-spacing: 0.03em;
}

.admin-module-sub {
  color: var(--text-muted);
  font-size: var(--text-sm);
  margin-top: var(--space-1);
}

/* ── OVERVIEW STATS ──────────────────────────────────────── */

.admin-stats-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

@media (min-width: 640px) {
  .admin-stats-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 1024px) {
  .admin-stats-grid { grid-template-columns: repeat(6, 1fr); }
}

.admin-stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5) var(--space-4);
  text-align: center;
  transition: border-color var(--transition-fast);
}

.admin-stat-card:hover { border-color: var(--border-gold); }
.admin-stat-gold    { border-color: var(--border-gold); }
.admin-stat-crimson { border-color: var(--border-crimson); }

.admin-stat-icon {
  font-size: var(--text-xl);
  display: block;
  margin-bottom: var(--space-2);
}

.admin-stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  font-weight: 600;
  letter-spacing: 0.02em;
}

.admin-stat-label {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-1);
  line-height: 1.4;
}

/* ── TABLE ───────────────────────────────────────────────── */

.admin-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.admin-table thead tr {
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
}

.admin-table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}

.admin-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: middle;
}

.admin-table tr:last-child td { border-bottom: none; }

.admin-table tr:hover td { background: rgba(255,255,255,0.02); }

.admin-table-title {
  font-weight: 500;
  color: var(--off-white);
  max-width: 300px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── QUEUE CARDS ─────────────────────────────────────────── */

.admin-queue {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.admin-queue-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5) var(--space-6);
  transition: border-color var(--transition-fast);
}

.admin-queue-card:hover { border-color: var(--border-gold); }

.admin-queue-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}

.admin-queue-name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.02em;
}

.admin-queue-meta {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-1);
}

.admin-queue-excerpt {
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}

.admin-queue-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.admin-queue-status {
  font-size: var(--text-xs);
  color: var(--gold);
  margin-top: var(--space-3);
}

/* ── DETAIL PANEL ────────────────────────────────────────── */

.admin-detail-panel {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-8);
}

.admin-detail-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin: var(--space-6) 0;
  flex-wrap: wrap;
}

.admin-detail-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  letter-spacing: 0.02em;
}

.admin-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

@media (min-width: 640px) {
  .admin-detail-grid { grid-template-columns: repeat(3, 1fr); }
}

.admin-detail-item {
  background: var(--bg-surface);
  border-radius: var(--r-md);
  padding: var(--space-4);
}

.admin-detail-label {
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-1);
  font-family: var(--font-display);
}

/* Gate grid */
.admin-gate-grid {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-3);
}

.admin-gate-item {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
  text-align: center;
}

.admin-gate-app {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-2);
}

/* ── BLOG EDITOR ─────────────────────────────────────────── */

.admin-blog-editor { max-width: 860px; }

.admin-editor-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.admin-editor-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.admin-save-status {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.admin-lang-tabs {
  display: flex;
  gap: 2px;
  margin-bottom: var(--space-2);
}

.admin-lang-tab {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--r-sm);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  cursor: pointer;
  color: var(--text-muted);
  transition: all var(--transition-fast);
}

.admin-lang-tab.active {
  background: var(--gold);
  border-color: var(--gold);
  color: #0A0C10;
}

.admin-title-input {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: 0.02em;
}

.admin-cover-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.admin-cover-preview {
  width: 120px;
  height: 72px;
  object-fit: cover;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
}

.admin-cover-placeholder {
  width: 120px;
  height: 72px;
  background: var(--bg-surface);
  border: 1px dashed var(--border);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-align: center;
  padding: var(--space-2);
}

/* Quill overrides */
.ql-toolbar.ql-snow {
  background: var(--bg-surface);
  border: 1px solid var(--border) !important;
  border-bottom: none !important;
  border-radius: var(--r-md) var(--r-md) 0 0;
}

.ql-container.ql-snow {
  background: var(--bg-card);
  border: 1px solid var(--border) !important;
  border-radius: 0 0 var(--r-md) var(--r-md);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text);
}

.ql-editor { min-height: 320px; line-height: 1.7; }
.ql-editor p { margin-bottom: 0.8em; }
.ql-editor .ql-blank::before { color: var(--text-muted); font-style: italic; }

[data-theme="light"] .ql-toolbar.ql-snow { background: var(--bg-surface); }
[data-theme="light"] .ql-container.ql-snow { background: var(--bg-card); }
[data-theme="light"] .ql-stroke { stroke: var(--text) !important; }
[data-theme="light"] .ql-fill   { fill:   var(--text) !important; }
[data-theme="light"] .ql-picker-label { color: var(--text) !important; }

/* ── AYAH EDITOR ─────────────────────────────────────────── */

.admin-ayah-wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}

@media (min-width: 900px) {
  .admin-ayah-wrap { grid-template-columns: 3fr 2fr; }
}

.admin-ayah-form { display: flex; flex-direction: column; gap: var(--space-1); }

.admin-ayah-preview {
  position: sticky;
  top: var(--space-6);
  align-self: start;
}

/* ── FILTERS ─────────────────────────────────────────────── */

.admin-filters {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
}

.admin-search-input {
  max-width: 320px;
}

.admin-select {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-4);
  cursor: pointer;
  min-height: 40px;
}

/* ── TAB BAR ─────────────────────────────────────────────── */

.admin-tab-bar {
  display: flex;
  gap: 2px;
  margin-bottom: var(--space-6);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 3px;
  width: fit-content;
}

.admin-tab {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--r-sm);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  transition: all var(--transition-fast);
  min-height: 32px;
}

.admin-tab.active {
  background: var(--gold);
  color: #0A0C10;
}

/* ── FIELDS ──────────────────────────────────────────────── */

.admin-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.admin-field-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

@media (min-width: 640px) {
  .admin-field-row { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
}

/* ── ALERTS ──────────────────────────────────────────────── */

.admin-overview-alerts { margin-top: var(--space-6); }

.admin-alert {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--r-lg);
  font-size: var(--text-sm);
  flex-wrap: wrap;
}

.admin-alert-gold {
  background: rgba(201,168,76,0.08);
  border: 1px solid var(--border-gold);
  color: var(--gold);
}

/* ── MISC ────────────────────────────────────────────────── */

.admin-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-16);
}

.admin-empty {
  text-align: center;
  padding: var(--space-12);
  color: var(--text-muted);
  font-size: var(--text-base);
}

.admin-error {
  padding: var(--space-4);
  background: var(--error-dim);
  border: 1px solid rgba(192,57,43,0.3);
  border-radius: var(--r-md);
  color: var(--error);
  font-size: var(--text-sm);
}

.admin-access-denied {
  text-align: center;
  padding: var(--space-16);
}

.admin-status-msg {
  font-size: var(--text-xs);
  color: var(--gold);
  min-height: 1.2em;
}

.admin-response-answers {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin-top: var(--space-6);
}

.admin-response-item {
  padding: var(--space-4);
  background: var(--bg-surface);
  border-radius: var(--r-md);
  border-left: 2px solid var(--border-gold);
}

.admin-response-q {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: var(--space-2);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--font-display);
}

.admin-response-a {
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.6;
}

.admin-sabiqun-create { }

.admin-insight-form {
  max-width: 600px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-8);
}



/* ============================================================
   APPLY PAGE
   ============================================================ */

.apply-page {
  min-height: 100svh;
  background: var(--bg);
  position: relative;
  overflow-x: hidden;
}

.apply-bg {
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 20% 20%, rgba(120,15,0,0.10) 0%, transparent 60%),
    radial-gradient(ellipse 50% 35% at 80% 80%, rgba(201,168,76,0.07) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

.apply-wrap {
  position: relative;
  z-index: 1;
  max-width: 720px;
  margin-inline: auto;
  padding: var(--space-8) var(--space-5) var(--space-16);
}

@media (min-width: 768px) {
  .apply-wrap { padding-inline: var(--space-8); }
}

.apply-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-12);
}

.apply-logo-link img {
  width: 40px;
  height: 40px;
  object-fit: contain;
}

.apply-intro {
  margin-bottom: var(--space-12);
}

.apply-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.02em;
  margin: var(--space-3) 0 var(--space-4);
}

.apply-subtitle {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--text-muted);
  line-height: 1.6;
  max-width: 52ch;
}

/* Form */
.apply-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
}

/* Question block */
.apply-question {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--space-7) var(--space-6);
  transition: border-color var(--transition-base);
}

.apply-question:focus-within {
  border-color: var(--border-gold);
}

.apply-q-num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: var(--space-3);
}

.apply-q-text {
  font-family: var(--font-serif);
  font-size: var(--text-xl);
  color: var(--off-white);
  line-height: 1.4;
  margin-bottom: var(--space-6);
}

@media (min-width: 768px) {
  .apply-q-text { font-size: var(--text-2xl); }
}

/* MCQ options */
.apply-options {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.apply-option {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  cursor: pointer;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  transition: border-color var(--transition-fast),
              background var(--transition-fast);
}

.apply-option:hover {
  border-color: var(--border-gold);
  background: rgba(201,168,76,0.04);
}

.apply-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

/* Custom radio circle */
.apply-option-box {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  min-width: 22px;
  border-radius: 50%;
  border: 2px solid var(--text-muted);
  margin-top: 1px;
  transition: border-color 0.2s ease, background 0.2s ease;
  position: relative;
}

/* Checkmark — hidden by default */
.apply-option-box::after {
  content: '';
  display: block;
  width: 7px;
  height: 12px;
  border: 2.5px solid var(--bg);
  border-top: none;
  border-left: none;
  transform: rotate(45deg) translate(-1px, -1px);
  opacity: 0;
  transition: opacity 0.15s ease;
}

/* Selected state */
.apply-option:has(input:checked) {
  border-color: var(--gold);
  background: rgba(201,168,76,0.07);
}

.apply-option:has(input:checked) .apply-option-box {
  background: var(--gold);
  border-color: var(--gold);
}

.apply-option:has(input:checked) .apply-option-box::after {
  opacity: 1;
}

.apply-option-label {
  font-size: var(--text-base);
  color: var(--text);
  line-height: 1.5;
}

/* Textarea */
.apply-question textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 140px;
  resize: vertical;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text);
  line-height: 1.7;
  transition: border-color var(--transition-fast);
}

.apply-question textarea:focus {
  border-color: var(--gold);
  outline: none;
  box-shadow: 0 0 0 3px rgba(201,168,76,0.10);
}

.apply-char-hint {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-2);
  transition: color var(--transition-fast);
}

/* Personal fields */
.apply-personal-fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 480px) {
  .apply-personal-fields { grid-template-columns: 1fr 1fr; }
}

.apply-personal-fields .form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  min-width: 0; /* prevents grid blowout */
}

.apply-personal-fields input {
  width: 100%;
  box-sizing: border-box;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--off-white);
  transition: border-color var(--transition-fast);
  outline: none;
}

.apply-personal-fields input::placeholder {
  color: var(--text-muted);
}

.apply-personal-fields input:focus {
  border-color: var(--gold-dim);
}

/* Submit */
.apply-submit {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-4);
}

.apply-note {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
  font-style: italic;
}

/* Success */
.apply-success {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 60vh;
  padding: var(--space-8);
}

.apply-success-inner {
  text-align: center;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.apply-success-inner h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--gold);
  letter-spacing: 0.04em;
}

.apply-success-inner p {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--text);
  line-height: 1.6;
}

/* ── ADMIN CREDENTIALS CARD ── */

.admin-credentials-box {
  margin-top: var(--space-5);
}

.admin-creds-card {
  background: rgba(76,175,122,0.06);
  border: 1px solid rgba(76,175,122,0.30);
  border-radius: var(--r-lg);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.admin-creds-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--success);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-2);
}

.admin-creds-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-2) 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

.admin-creds-label {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--text-muted);
  width: 80px;
  flex-shrink: 0;
}

.admin-creds-value {
  font-size: var(--text-sm);
  color: var(--off-white);
  word-break: break-all;
}

.admin-creds-password {
  font-family: monospace;
  font-size: var(--text-base);
  color: var(--gold);
  letter-spacing: 0.08em;
  background: rgba(201,168,76,0.08);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--r-sm);
}

.admin-creds-note {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.5;
  font-style: italic;
}


/* ═══════════════════════════════════════════════════════════════
   WELCOME SCREEN — arrival moment on first login
   ═══════════════════════════════════════════════════════════════ */

.welcome-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-8) var(--space-5);
  position: relative;
  overflow: hidden;
  background: var(--bg);
}

/* Atmospheric background orbs */
.welcome-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.welcome-bg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.18;
}

.welcome-bg-orb--1 {
  width: 400px;
  height: 400px;
  background: var(--crimson);
  top: -100px;
  right: -80px;
  animation: welcome-orb-drift 12s ease-in-out infinite alternate;
}

.welcome-bg-orb--2 {
  width: 300px;
  height: 300px;
  background: var(--gold);
  bottom: -60px;
  left: -60px;
  animation: welcome-orb-drift 15s ease-in-out infinite alternate-reverse;
}

@keyframes welcome-orb-drift {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(20px, -20px) scale(1.08); }
}

/* Content */
.welcome-content {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 560px;
  width: 100%;
}

.welcome-logo-wrap {
  margin-bottom: var(--space-6);
}

.welcome-logo {
  width: 72px;
  height: 72px;
}

/* "Marhaba, [Name]" */
.welcome-greeting {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 3rem);
  font-weight: 500;
  color: var(--off-white);
  margin: 0 0 var(--space-3);
  line-height: 1.2;
  letter-spacing: 0.02em;
}

.welcome-name {
  color: var(--gold);
}

.welcome-subtitle {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text-muted);
  margin: 0 0 var(--space-8);
  line-height: 1.7;
}

/* Ayah block — the Al-Ankabut 29:69 callback */
.welcome-ayah-block {
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: var(--space-6) var(--space-6);
  margin: 0 0 var(--space-8);
  text-align: right;
}

.welcome-ayah-arabic {
  font-family: var(--font-arabic);
  font-size: clamp(1.3rem, 4vw, 1.7rem);
  color: var(--gold);
  line-height: 2;
  direction: rtl;
  margin: 0 0 var(--space-2);
}

.welcome-ayah-ref {
  font-size: var(--text-xs);
  color: var(--gold-dim);
  letter-spacing: 0.05em;
  margin: 0 0 var(--space-3);
  text-align: right;
}

.welcome-ayah-trans {
  font-family: var(--font-serif);
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.7;
  font-style: italic;
  text-align: right;
  direction: ltr;
  margin: 0;
}

/* CTA */
.welcome-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

.welcome-cta-arrow {
  transition: transform 0.2s ease;
}

.welcome-cta:hover .welcome-cta-arrow {
  transform: translateX(4px);
}

/* ═══════════════════════════════════════════════════════════════
   ORIENTATION MODAL — 4-step walkthrough, cannot be skipped
   ═══════════════════════════════════════════════════════════════ */

.orient-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(10, 12, 16, 0.92);
  backdrop-filter: blur(12px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-5);
  animation: orient-overlay-in 0.3s ease forwards;
}

.orient-overlay.hidden {
  display: none;
}

@keyframes orient-overlay-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.orient-modal {
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  width: 100%;
  max-width: 600px;
  max-height: 90vh;
  overflow-y: auto;
  padding: var(--space-8) var(--space-7);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

/* Progress dots */
.orient-dots {
  display: flex;
  justify-content: center;
  gap: var(--space-2);
}

.orient-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
  transition: background 0.3s ease, transform 0.3s ease;
}

.orient-dot--active {
  background: var(--gold);
  transform: scale(1.3);
}

/* Step container */
.orient-body {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.orient-body.orient-step-visible {
  opacity: 1;
  transform: translateY(0);
}

.orient-step {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.orient-heading {
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 4vw, 1.7rem);
  font-weight: 500;
  color: var(--off-white);
  margin: 0;
  letter-spacing: 0.02em;
}

.orient-body-text,
.orient-body p,
.orient-step p.orient-body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--text);
  line-height: 1.8;
  margin: 0;
}

/* Step 1 — Stage cards row */
.orient-stages-row {
  display: flex;
  gap: var(--space-2);
  overflow-x: auto;
  padding-bottom: var(--space-1);
  scrollbar-width: none;
}

.orient-stages-row::-webkit-scrollbar { display: none; }

.orient-stage-card {
  flex: 0 0 auto;
  width: 110px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-3);
  text-align: center;
  animation: orient-card-in 0.3s ease both;
  transition: border-color 0.2s;
}

.orient-stage-card--active {
  border-color: var(--border-gold);
  background: rgba(201,168,76,0.06);
}

@keyframes orient-card-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.orient-stage-num {
  font-size: 10px;
  color: var(--text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 var(--space-1);
}

.orient-stage-arabic {
  font-family: var(--font-arabic);
  font-size: 1.2rem;
  color: var(--gold);
  direction: rtl;
  margin: 0 0 var(--space-1);
  line-height: 1.6;
}

.orient-stage-arabic--lg {
  font-size: 2.5rem;
  display: block;
  text-align: center;
  margin-bottom: var(--space-2);
}

.orient-stage-name {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--off-white);
  margin: 0 0 var(--space-1);
  letter-spacing: 0.04em;
}

.orient-stage-role {
  font-size: 10px;
  color: var(--text-muted);
  line-height: 1.4;
  margin: 0;
}

/* Step 2 — Stage spotlight */
.orient-stage-spotlight {
  background: var(--bg-surface);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-md);
  padding: var(--space-6);
  text-align: center;
}

.orient-stage-spotlight-role {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0;
  font-style: italic;
}

/* Step 3 — Gem callout */
.orient-gem-callout {
  background: rgba(201,168,76,0.08);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-md);
  padding: var(--space-5);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.orient-gem-icon {
  color: var(--gold);
  font-size: 1.2rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.orient-gem-text {
  font-family: var(--font-serif);
  font-size: var(--text-base);
  color: var(--gold);
  font-style: italic;
  line-height: 1.6;
  margin: 0;
}

/* Step 4 — Gate callout */
.orient-gate-callout {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-5);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}

.orient-gate-icon {
  font-size: 1.4rem;
  flex-shrink: 0;
}

.orient-gate-text {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.03em;
  line-height: 1.5;
  margin: 0;
}

/* Final CTA button — slightly more prominent */
.orient-final-btn {
  width: 100%;
  justify-content: center;
  background: var(--crimson);
  border-color: var(--crimson);
  padding: var(--space-4) var(--space-6);
  font-size: var(--text-base);
  letter-spacing: 0.03em;
}

.orient-final-btn:hover {
  background: #8f1200;
  border-color: #8f1200;
}

/* Next button — standard width */
.orient-next-btn {
  align-self: flex-start;
}

/* Mobile */
@media (max-width: 480px) {
  .orient-modal {
    padding: var(--space-6) var(--space-5);
    max-height: 95vh;
  }

  .welcome-ayah-block {
    padding: var(--space-5) var(--space-4);
  }
}


/* ============================================================
   BLOG PAGE — full list view
   ============================================================ */

.blog-page {
  min-height: calc(100vh - var(--navbar-height));
}

.blog-page-hero {
  padding: var(--space-16) var(--space-6) var(--space-12);
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.blog-page-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-4);
}

.blog-page-subtitle {
  color: var(--text-muted);
  font-size: var(--text-base);
  line-height: 1.6;
}

.blog-list-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .blog-list-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .blog-list-grid { grid-template-columns: repeat(3, 1fr); }
}

.blog-list-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  transition: border-color var(--transition-base), transform var(--transition-base);
}

.blog-list-card:hover {
  border-color: var(--border-gold);
  transform: translateY(-3px);
}

.blog-list-card-cover {
  width: 100%;
  height: 180px;
  background-size: cover;
  background-position: center;
  background-color: var(--bg-surface);
}

.blog-list-card-cover-placeholder {
  background: linear-gradient(135deg, var(--bg-surface) 0%, var(--crimson-dim) 100%);
  position: relative;
  overflow: hidden;
}

.blog-list-card-cover-placeholder::after {
  content: '✦';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: var(--text-2xl);
  color: var(--gold-dim);
  opacity: 0.4;
}

.blog-list-card-body {
  padding: var(--space-5) var(--space-6) var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.blog-list-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.blog-tag {
  font-size: 0.7rem;
  font-family: var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--gold);
  background: rgba(201,168,76,0.08);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-full);
  padding: 2px 10px;
}

.blog-list-card-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.02em;
  line-height: 1.4;
}

.blog-list-card-excerpt {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.65;
  flex: 1;
}

.blog-list-card-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-muted);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  margin-top: auto;
}

.blog-meta-dot {
  opacity: 0.4;
}

.blog-list-read-more {
  margin-left: auto;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.06em;
  color: var(--gold);
}

.blog-loading {
  display: flex;
  justify-content: center;
  padding: var(--space-16) 0;
}

.loading-spinner {
  width: 32px;
  height: 32px;
  border: 2px solid var(--border);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

.blog-empty-state {
  text-align: center;
  padding: var(--space-20) var(--space-6);
}

.blog-empty-icon {
  font-size: var(--text-3xl);
  color: var(--gold-dim);
  margin-bottom: var(--space-6);
  opacity: 0.5;
}

.blog-empty-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-4);
}

.blog-empty-body {
  color: var(--text-muted);
  max-width: 380px;
  margin: 0 auto;
}

/* ============================================================
   BLOG POST — individual post view
   ============================================================ */

.blog-post-page {
  min-height: calc(100vh - var(--navbar-height));
}

.blog-post-cover {
  width: 100%;
  height: clamp(200px, 35vw, 420px);
  background-size: cover;
  background-position: center;
  background-color: var(--bg-surface);
}

.blog-post-container {
  max-width: 740px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.blog-post-back {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-6) 0 var(--space-4);
  transition: color var(--transition-fast);
}

.blog-post-back:hover {
  color: var(--gold);
}

.blog-post-header {
  margin-bottom: var(--space-10);
}

.blog-post-tags {
  margin-bottom: var(--space-4);
}

.blog-post-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-xl), 4vw, var(--text-3xl));
  color: var(--off-white);
  letter-spacing: 0.03em;
  line-height: 1.3;
  margin-bottom: var(--space-4);
}

.blog-post-meta {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-muted);
}

/* Body — inherits Quill output styles */
.blog-post-body {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--text);
  padding: 0; /* override ql-editor padding */
}

.blog-post-body h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  margin: var(--space-8) 0 var(--space-4);
  letter-spacing: 0.03em;
}

.blog-post-body h3 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--off-white);
  margin: var(--space-6) 0 var(--space-3);
}

.blog-post-body p {
  margin-bottom: var(--space-5);
}

.blog-post-body blockquote {
  border-left: 3px solid var(--gold);
  padding: var(--space-3) var(--space-6);
  margin: var(--space-6) 0;
  font-family: var(--font-serif);
  font-size: var(--text-md);
  color: var(--off-white);
  background: rgba(201,168,76,0.04);
  border-radius: 0 var(--r-md) var(--r-md) 0;
}

.blog-post-body .arabic-inline {
  font-family: var(--font-arabic);
  font-size: 1.25em;
  direction: rtl;
  color: var(--gold);
}

.blog-post-body img {
  max-width: 100%;
  border-radius: var(--r-md);
  margin: var(--space-6) 0;
}

.blog-post-body ul,
.blog-post-body ol {
  padding-left: var(--space-6);
  margin-bottom: var(--space-5);
}

.blog-post-body li {
  margin-bottom: var(--space-2);
}

.blog-post-footer {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-12);
  padding-top: var(--space-8);
  border-top: 1px solid var(--border);
  padding-bottom: var(--space-16);
}

/* Skeleton */
.blog-skeleton-line {
  background: var(--bg-surface);
  border-radius: var(--r-sm);
  animation: skeleton-pulse 1.4s ease-in-out infinite;
}

@keyframes skeleton-pulse {
  0%, 100% { opacity: 0.6; }
  50%       { opacity: 1; }
}

/* ============================================================
   JOURNEY PAGE
   ============================================================ */

.journey-page {
  min-height: calc(100vh - var(--navbar-height));
}

.journey-hero {
  padding: var(--space-16) var(--space-6) var(--space-10);
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}

.journey-hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-5);
}

.journey-hero-sub {
  color: var(--text-muted);
  font-size: var(--text-md);
  margin-bottom: var(--space-8);
}

.journey-gate-rule-trans {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  color: var(--text);
  font-style: italic;
  margin: var(--space-4) 0 var(--space-2);
}

.journey-gate-rule-ref {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.journey-gate-banner {
  background: linear-gradient(135deg, var(--crimson-dim) 0%, transparent 100%);
  border-top: 1px solid var(--border-crimson);
  border-bottom: 1px solid var(--border-crimson);
}

.journey-gate-statement {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--gold);
  letter-spacing: 0.04em;
  text-align: center;
  margin-bottom: var(--space-3);
}

.journey-gate-sub {
  text-align: center;
  color: var(--text-muted);
  font-size: var(--text-sm);
}

.journey-stages-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.journey-stage-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  padding: var(--space-8) 0;
  border-top: 1px solid var(--border);
}

@media (min-width: 768px) {
  .journey-stage-block {
    grid-template-columns: 180px 1fr;
    align-items: start;
  }
  .journey-stage-block-alt {
    grid-template-columns: 1fr 180px;
  }
  .journey-stage-block-alt .journey-stage-arabic-col {
    order: 2;
  }
  .journey-stage-block-alt .journey-stage-content-col {
    order: 1;
  }
}

.journey-stage-arabic-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}

.journey-arabic-display {
  font-size: clamp(2.5rem, 8vw, 4rem) !important;
  color: var(--gold) !important;
}

.journey-stage-num {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  color: var(--border);
  letter-spacing: -0.02em;
  line-height: 1;
}

.journey-stage-name {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-2) 0 var(--space-2);
}

.journey-stage-role {
  font-size: var(--text-sm);
  color: var(--gold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-display);
  margin-bottom: var(--space-4);
}

.journey-stage-desc {
  color: var(--text);
  line-height: 1.75;
  margin-bottom: var(--space-6);
}

.journey-stage-principles {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.journey-stage-principle {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.5;
}

.journey-principle-dot {
  color: var(--gold-dim);
  flex-shrink: 0;
  margin-top: 2px;
  font-size: 0.65rem;
}

.journey-cta-section {
  background: linear-gradient(180deg, transparent 0%, var(--bg-card) 100%);
  border-top: 1px solid var(--border);
}

.journey-cta-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-4);
}

.journey-cta-sub {
  color: var(--text-muted);
  margin-bottom: var(--space-8);
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */

.about-page {
  min-height: calc(100vh - var(--navbar-height));
}

.about-hero {
  padding: var(--space-16) var(--space-6) var(--space-10);
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.about-hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-5);
}

.about-hero-mantra {
  font-family: var(--font-serif);
  font-size: var(--text-lg);
  color: var(--gold);
  font-style: italic;
  line-height: 1.5;
}

.about-mission-container {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  max-width: 900px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .about-mission-container {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

.about-section-heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-6);
}

.about-body {
  color: var(--text);
  line-height: 1.8;
  margin-bottom: var(--space-5);
}

.about-ayah-block {
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: var(--space-8);
  text-align: center;
}

.about-ayah-trans {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--text);
  margin: var(--space-5) 0 var(--space-2);
  font-size: var(--text-md);
}

.about-ayah-ref {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.about-principles-section {
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.about-principles-header {
  text-align: center;
  margin-bottom: var(--space-10);
}

.about-principles-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 540px) {
  .about-principles-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 900px) {
  .about-principles-grid { grid-template-columns: repeat(4, 1fr); }
}

.about-principle-card {
  padding: var(--space-6);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  transition: border-color var(--transition-base);
}

.about-principle-card:hover {
  border-color: var(--border-gold);
}

.about-principle-num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--gold-dim);
  letter-spacing: -0.02em;
  margin-bottom: var(--space-4);
  opacity: 0.6;
}

.about-principle-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-3);
  line-height: 1.4;
}

.about-principle-body {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.6;
}

.about-scholars-container {
  max-width: 720px;
  margin: 0 auto;
}

.about-scholar-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.about-scholar-item {
  padding: var(--space-5) var(--space-6);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  border-radius: 0 var(--r-md) var(--r-md) 0;
}

.about-scholar-name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.03em;
  margin-bottom: var(--space-2);
}

.about-scholar-note {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

.about-social-links {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  margin: var(--space-6) 0;
  flex-wrap: wrap;
}

.about-license {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-6);
}

.about-cta-section {
  border-top: 1px solid var(--border);
}

.about-cta-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-4);
}

/* ============================================================
   APPS PAGE
   ============================================================ */

.apps-page {
  min-height: calc(100vh - var(--navbar-height));
}

.apps-hero {
  padding: var(--space-16) var(--space-6) var(--space-10);
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.apps-hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-4);
}

.apps-hero-sub {
  color: var(--text-muted);
  font-size: var(--text-base);
}

.apps-gate-banner {
  background: linear-gradient(135deg, var(--crimson-dim) 0%, transparent 100%);
  border-top: 1px solid var(--border-crimson);
  border-bottom: 1px solid var(--border-crimson);
}

.apps-gate-statement {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--gold);
  letter-spacing: 0.04em;
  text-align: center;
  margin-bottom: var(--space-2);
}

.apps-gate-sub {
  text-align: center;
  color: var(--text-muted);
  font-size: var(--text-sm);
}

.apps-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .apps-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .apps-grid { grid-template-columns: repeat(3, 1fr); }
}

.apps-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  transition: border-color var(--transition-base), transform var(--transition-base);
  overflow: hidden;
}

.apps-card:hover {
  border-color: var(--border-gold);
  transform: translateY(-3px);
}

.apps-card-planned {
  opacity: 0.6;
}

.apps-card-planned:hover {
  transform: none;
  border-color: var(--border);
}

/* ── Icon area ── */
.apps-card-icon-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--bg-surface);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.apps-card-icon {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s cubic-bezier(0.16,1,0.3,1);
}

.apps-card:hover .apps-card-icon {
  transform: scale(1.04);
}

.apps-status-badge {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  font-family: var(--font-display);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: var(--r-full);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.apps-status-live {
  color: #4ade80;
  background: rgba(10,12,16,0.65);
  border: 1px solid rgba(74,222,128,0.35);
}

.apps-status-building {
  color: var(--gold);
  background: rgba(10,12,16,0.65);
  border: 1px solid var(--border-gold);
}

.apps-status-planned {
  color: var(--text-muted);
  background: rgba(10,12,16,0.65);
  border: 1px solid var(--border);
}

[data-theme="light"] .apps-status-live,
[data-theme="light"] .apps-status-building,
[data-theme="light"] .apps-status-planned {
  background: rgba(246,241,232,0.80);
}

/* ── Card body ── */
.apps-card-body {
  padding: var(--space-5) var(--space-6) var(--space-4);
  flex: 1;
}

.apps-card-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}

.apps-card-stage-num {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-family: var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.apps-card-arabic-inline {
  font-family: var(--font-arabic);
  font-size: var(--text-xl);
  color: var(--gold);
  line-height: 1;
}

.apps-card-name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-2);
}

.apps-card-role {
  font-size: var(--text-xs);
  color: var(--gold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-family: var(--font-display);
  margin-bottom: var(--space-3);
}

.apps-card-desc {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.65;
}

/* ── Card footer ── */
.apps-card-footer {
  padding: var(--space-4) var(--space-6);
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.apps-coming-soon {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-style: italic;
}

.apps-students-only {
  font-size: var(--text-xs);
  color: var(--gold-dim);
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  margin-left: auto;
}

.apps-cta-sub {
  color: var(--text-muted);
  margin-bottom: var(--space-8);
}

/* ============================================================
   CONTACT PAGE
   ============================================================ */

.contact-page {
  min-height: calc(100vh - var(--navbar-height));
}

.contact-hero {
  padding: var(--space-16) var(--space-6) var(--space-10);
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}

.contact-hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-4);
}

.contact-hero-sub {
  color: var(--text-muted);
}

/* Main layout — stacked on mobile, side-by-side on desktop */
.contact-layout {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
  max-width: 640px;
  margin: 0 auto;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* Name + email side by side on wider screens */
.contact-field-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 540px) {
  .contact-field-row { grid-template-columns: 1fr 1fr; }
}

.contact-field-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.contact-input,
.contact-textarea {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-5) var(--space-6);
  color: var(--off-white);
  font-family: var(--font-body);
  font-size: var(--text-base);
  width: 100%;
  transition: border-color var(--transition-fast);
  outline: none;
  box-sizing: border-box;
}

.contact-input:focus,
.contact-textarea:focus {
  border-color: var(--gold-dim);
}

.contact-textarea {
  resize: vertical;
  min-height: 160px;
  line-height: 1.6;
}

.contact-form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.contact-status {
  font-size: var(--text-sm);
  flex: 1;
}

.contact-status-error { color: #f87171; }
.contact-status-info  { color: var(--gold); }

.contact-success {
  text-align: center;
  padding: var(--space-12) var(--space-6);
}

.contact-success-icon {
  font-size: var(--text-3xl);
  color: var(--gold);
  margin-bottom: var(--space-4);
}

.contact-success-msg {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--off-white);
  letter-spacing: 0.03em;
}

/* Side panel */
.contact-alt {
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: var(--space-8);
}

.contact-alt-label {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-5);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.contact-social-links {
  display: flex;
  flex-direction: column;
  flex-wrap: nowrap;
  gap: var(--space-3);
}

.contact-social-link {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--off-white);
  text-decoration: none;
  font-size: var(--text-sm);
  transition: border-color var(--transition-fast), color var(--transition-fast);
}

.contact-social-icon {
  display: flex;
  align-items: center;
  color: var(--gold);
  flex-shrink: 0;
}

.contact-social-handle {
  flex: 1;
  font-family: var(--font-body);
}

.contact-social-link:hover {
  border-color: var(--border-gold);
  color: var(--gold);
}

.contact-social-platform {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-family: var(--font-display);
  letter-spacing: 0.06em;
  margin-left: auto;
}

/* ============================================================
   TESTIMONIALS PAGE — full view
   ============================================================ */

.testimonials-page {
  min-height: calc(100vh - var(--navbar-height));
}

.testimonials-hero {
  padding: var(--space-16) var(--space-6) var(--space-10);
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.testimonials-hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-4);
}

.testimonials-hero-sub {
  color: var(--text-muted);
}

.testimonials-full-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .testimonials-full-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .testimonials-full-grid { grid-template-columns: repeat(3, 1fr); }
}

.testimonial-card-full {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-8) var(--space-7);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: border-color var(--transition-base);
}

.testimonial-card-full:hover {
  border-color: var(--border-gold);
}

.testimonial-quote-mark {
  font-family: var(--font-serif);
  font-size: 3.5rem;
  color: var(--gold);
  line-height: 0.6;
  opacity: 0.35;
  user-select: none;
}

.testimonial-full-quote {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  color: var(--off-white);
  line-height: 1.7;
  font-style: italic;
  flex: 1;
  margin: 0;
}

.testimonial-full-meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
}

.testimonial-cta-sub {
  color: var(--text-muted);
  margin-bottom: var(--space-6);
}

/* reveal animation lives in design.css (.reveal + .visible) */

/* ============================================================
   REFLECTION SPACE — QURANIC ANCHOR FIELDS
   ============================================================ */

.req {
  color: var(--gold);
  margin-left: 2px;
}

.ref-anchor-row {
  display: grid;
  grid-template-columns: 1fr 100px;
  gap: var(--space-4);
  align-items: end;
}

.ref-surah-group select,
.ref-ayah-group input {
  width: 100%;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
  color: var(--off-white);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  outline: none;
  box-sizing: border-box;
  transition: border-color var(--transition-fast);
}

.ref-surah-group select:focus,
.ref-ayah-group input:focus {
  border-color: var(--gold-dim);
}

.ref-surah-group select:disabled,
.ref-ayah-group input:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* Ayah preview box */
.ref-ayah-preview {
  background: var(--bg-surface);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-md);
  padding: var(--space-5) var(--space-6);
  margin-bottom: var(--space-2);
}

#ref-ayah-arabic {
  font-family: var(--font-arabic);
  font-size: var(--text-xl);
  color: var(--off-white);
  direction: rtl;
  text-align: right;
  line-height: 2;
  margin-bottom: var(--space-3);
}

#ref-ayah-trans {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--text);
  font-size: var(--text-sm);
  line-height: 1.65;
  margin-bottom: var(--space-2);
}

#ref-ayah-ref {
  font-size: var(--text-xs);
  color: var(--gold);
  font-family: var(--font-display);
  letter-spacing: 0.05em;
}

/* Theme tags grid */
.ref-tags-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.ref-tag-btn {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
  color: var(--text-muted);
  cursor: pointer;
  transition: border-color var(--transition-fast), color var(--transition-fast),
              background var(--transition-fast);
}

.ref-tag-btn:hover {
  border-color: var(--border-gold);
  color: var(--gold);
}

.ref-tag-btn.selected {
  background: rgba(201,168,76,0.12);
  border-color: var(--gold);
  color: var(--gold);
}

/* ============================================================
   QWV LIBRARY PAGE
   ============================================================ */

.lib-page {
  min-height: calc(100vh - var(--navbar-height));
}

/* Hero */
.lib-hero {
  padding: var(--space-16) var(--space-6) var(--space-10);
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
}

.lib-hero-title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 5vw, var(--text-4xl));
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: var(--space-3) 0 var(--space-4);
}

.lib-hero-sub {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--text-muted);
  font-size: var(--text-lg);
  margin-bottom: var(--space-6);
}

.lib-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.lib-stat {
  font-size: var(--text-sm);
  color: var(--gold);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
}

.lib-stat-dot {
  color: var(--text-muted);
}

/* View tabs */
.lib-view-bar {
  border-bottom: 1px solid var(--border);
  background: var(--bg-card);
  position: sticky;
  top: var(--navbar-height);
  z-index: 10;
}

.lib-view-tabs {
  display: flex;
  gap: 0;
  overflow-x: auto;
}

.lib-view-tab {
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  letter-spacing: 0.05em;
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}

.lib-view-tab:hover { color: var(--off-white); }
.lib-view-tab.active {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

/* Surah list */
.lib-surah-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.lib-surah-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-5) var(--space-6);
  cursor: pointer;
  transition: border-color var(--transition-base), transform var(--transition-base);
}

.lib-surah-card:hover {
  border-color: var(--border-gold);
  transform: translateX(4px);
}

.lib-surah-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.lib-surah-card-info {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.lib-surah-num {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--gold);
  min-width: 28px;
  letter-spacing: 0.04em;
}

.lib-surah-name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.03em;
}

.lib-surah-arabic {
  font-family: var(--font-arabic);
  font-size: var(--text-base);
  color: var(--gold-dim);
  direction: rtl;
}

.lib-surah-card-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--space-2);
}

.lib-gem-count {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
}

.lib-ayah-pills {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  justify-content: flex-end;
}

.lib-ayah-pill {
  font-size: 10px;
  padding: 2px 6px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  color: var(--text-muted);
  font-family: var(--font-display);
}

.lib-ayah-more {
  color: var(--gold-dim);
  border-color: var(--border-gold);
}

/* Surah detail */
.lib-back-btn {
  background: none;
  border: none;
  color: var(--gold);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: var(--space-2) 0;
  margin-bottom: var(--space-6);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  transition: color var(--transition-fast);
}

.lib-back-btn:hover { color: var(--off-white); }

.lib-surah-detail-header {
  margin-bottom: var(--space-8);
}

.lib-surah-detail-name {
  display: flex;
  align-items: center;
  gap: var(--space-5);
  margin-bottom: var(--space-5);
}

.lib-detail-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--off-white);
  letter-spacing: 0.03em;
}

.lib-detail-arabic {
  font-family: var(--font-arabic);
  font-size: var(--text-xl);
  color: var(--gold);
  direction: rtl;
  margin-top: var(--space-1);
}

/* Ayah display (in surah detail) */
.lib-ayah-display {
  background: var(--bg-surface);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-md);
  padding: var(--space-6);
  margin-bottom: var(--space-6);
}

.lib-display-arabic {
  font-family: var(--font-arabic);
  font-size: var(--text-2xl);
  color: var(--off-white);
  direction: rtl;
  text-align: right;
  line-height: 2;
  margin-bottom: var(--space-3);
}

.lib-display-trans {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--text);
  font-size: var(--text-sm);
  line-height: 1.7;
}

/* Ayah sections */
.lib-ayah-section {
  margin-bottom: var(--space-8);
}

.lib-ayah-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-3) var(--space-5);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-bottom: var(--space-4);
  cursor: pointer;
  transition: border-color var(--transition-fast);
}

.lib-ayah-btn:hover,
.lib-ayah-btn.active-ayah {
  border-color: var(--border-gold);
}

.lib-ayah-label {
  cursor: default;
}

.lib-ayah-label-text {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--gold);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.lib-ayah-gem-count {
  font-size: var(--text-xs);
  color: var(--text-muted);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  padding: 2px 8px;
}

/* Gems grid */
.lib-gems-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .lib-gems-grid { grid-template-columns: 1fr 1fr; }
}

.lib-gems-masonry {
  columns: 1;
  gap: var(--space-4);
}

@media (min-width: 640px) {
  .lib-gems-masonry { columns: 2; }
}

@media (min-width: 1024px) {
  .lib-gems-masonry { columns: 3; }
}

/* Gem card */
.lib-gem-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  break-inside: avoid;
  margin-bottom: var(--space-4);
  transition: border-color var(--transition-base);
}

.lib-gem-card:hover {
  border-color: var(--border-gold);
}

.lib-gem-anchor {
  font-size: var(--text-xs);
  color: var(--gold);
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  margin-bottom: var(--space-3);
}

.lib-gem-title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  color: var(--off-white);
  letter-spacing: 0.03em;
  margin-bottom: var(--space-3);
}

.lib-gem-text {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--text);
  font-size: var(--text-sm);
  line-height: 1.75;
  margin-bottom: var(--space-4);
}

.lib-gem-footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}

.lib-gem-meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.lib-gem-author {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
}

.lib-gem-stage {
  font-size: 10px;
  color: var(--gold-dim);
  font-family: var(--font-display);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.lib-gem-tags {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.lib-gem-tag {
  font-size: 10px;
  padding: 2px 7px;
  background: rgba(201,168,76,0.08);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-full);
  color: var(--gold-dim);
  font-family: var(--font-display);
  letter-spacing: 0.04em;
}

/* Theme view */
.lib-theme-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-8);
}

.lib-theme-btn {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-full);
  padding: var(--space-2) var(--space-5);
  font-size: var(--text-xs);
  font-family: var(--font-display);
  letter-spacing: 0.05em;
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.lib-theme-btn:hover,
.lib-theme-btn.active {
  background: rgba(201,168,76,0.10);
  border-color: var(--gold);
  color: var(--gold);
}

/* Stage view */
.lib-stage-filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.lib-stage-btn {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-5);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.lib-stage-btn:hover,
.lib-stage-btn.active {
  background: rgba(201,168,76,0.10);
  border-color: var(--gold);
  color: var(--gold);
}

.lib-stage-hint {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-6);
}

/* Empty state */
.lib-empty {
  text-align: center;
  padding: var(--space-20) var(--space-6);
}

.lib-empty-icon {
  font-size: var(--text-2xl);
  color: var(--gold-dim);
  margin-bottom: var(--space-4);
}

.lib-empty-text {
  color: var(--text-muted);
  font-family: var(--font-serif);
  font-style: italic;
}


/* ============================================================
   GATE APPROVALS — Phase 3 (Iqra Integration)
   ============================================================ */

/* Subtitle under Gate Approvals heading */
.admin-module-sub {
  color: var(--text-muted);
  font-size: var(--text-sm);
  font-style: italic;
  margin-top: var(--space-1);
}

/* Gate review card — extends admin-queue-card */
.gate-review-card {
  border-left: 3px solid var(--border-gold);
}

/* Iqra data block inside gate card */
.gate-iqra-card {
  background: rgba(201,168,76,0.04);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-md);
  padding: var(--space-4);
  margin: var(--space-4) 0;
}

.gate-iqra-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--off-white);
  margin-bottom: var(--space-3);
  letter-spacing: 0.03em;
}

/* 2×2 grid of signal items */
.gate-signals-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}

@media (max-width: 480px) {
  .gate-signals-grid {
    grid-template-columns: 1fr;
  }
}

.gate-signal-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
}

/* Coloured dot — readiness indicator */
.gate-signal {
  font-size: 10px;
  margin-top: 3px;
  flex-shrink: 0;
}

.gate-signal-ok   { color: #4ade80; } /* green  — signal present */
.gate-signal-warn { color: #fbbf24; } /* amber  — signal missing */

.gate-signal-label {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-bottom: 2px;
}

.gate-signal-value {
  font-size: var(--text-sm);
  color: var(--off-white);
  font-weight: 500;
}

.gate-last-read {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-3);
}

.gate-no-iqra {
  font-size: var(--text-xs);
  color: var(--text-muted);
  font-style: italic;
  margin-top: var(--space-3);
}

/* Published reflections preview section */
.gate-reflections-preview {
  margin: var(--space-2) 0 var(--space-1);
}

.gate-no-reflections {
  font-size: var(--text-sm);
  color: var(--text-muted);
  font-style: italic;
  padding: var(--space-2) 0;
}

/* Individual reflection item in gate preview */
.gate-ref-list {
  margin-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.gate-ref-item {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-3) var(--space-4);
}

.gate-ref-ayah {
  font-size: var(--text-xs);
  color: var(--gold);
  font-weight: 500;
  letter-spacing: 0.04em;
}

.gate-ref-text {
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.6;
  margin-top: var(--space-1);
  font-family: var(--font-serif);
}

/* ============================================================
   REFLECTIONS QUEUE — source_app badges
   ============================================================ */

.badge-source-iqra {
  background: rgba(120,15,0,0.18);
  color: #f87171;
  border: 1px solid rgba(120,15,0,0.35);
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 99px;
  letter-spacing: 0.04em;
}

.badge-source-dashboard {
  background: rgba(201,168,76,0.10);
  color: var(--gold);
  border: 1px solid var(--border-gold);
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 99px;
  letter-spacing: 0.04em;
}

/* Miftah source badge */
.badge-source-miftah {
  background: rgba(99,102,241,0.15);
  color: #a5b4fc;
  border: 1px solid rgba(99,102,241,0.35);
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 99px;
  letter-spacing: 0.04em;
}

/* Lens badge — Miftah only */
.badge-lens {
  background: rgba(168,85,247,0.12);
  color: #d8b4fe;
  border: 1px solid rgba(168,85,247,0.30);
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 99px;
  letter-spacing: 0.03em;
  font-style: italic;
}


/* ============================================================
   LIBRARY — PLACEHOLDER (below gem threshold)
   ============================================================ */

.lib-placeholder-wrap {
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-16) var(--space-6);
  gap: var(--space-10);
}

.lib-placeholder-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.lib-placeholder-heading {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 5vw, 3rem);
  color: var(--off-white);
  letter-spacing: 0.04em;
  margin: 0;
}

.lib-placeholder-sub {
  font-family: var(--font-serif);
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  color: var(--text-muted);
  font-style: italic;
  max-width: 500px;
  line-height: 1.7;
  margin: 0;
}

.lib-placeholder-ayah {
  background: rgba(201,168,76,0.06);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: var(--space-6) var(--space-8);
  max-width: 560px;
}

.lib-placeholder-ayah-text {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  color: var(--text);
  font-style: italic;
  line-height: 1.8;
  margin: 0 0 var(--space-2);
}

.lib-placeholder-ayah-ref {
  font-size: var(--text-xs);
  color: var(--gold);
  letter-spacing: 0.06em;
  margin: 0;
}

.lib-placeholder-count {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
}

.lib-placeholder-gem-icon {
  font-size: 1.5rem;
  color: var(--gold);
  opacity: 0.7;
}

.lib-placeholder-count-text {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0;
}

.lib-placeholder-cta {
  margin-top: var(--space-2);
}

/* ============================================================
   DASHBOARD — Mobile Admin link
   ============================================================ */

.dash-mobile-admin {
  color: var(--crimson) !important;
  font-weight: 500;
}


/* ============================================================
   BLOG / REFLECTIONS — Branded placeholder card cover
   ============================================================ */

.blog-list-card-cover-placeholder {
  background: linear-gradient(145deg, #0d0f14 0%, #1a0a08 60%, #0d0f14 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  position: relative;
  overflow: hidden;
}

/* Subtle radial glow */
.blog-list-card-cover-placeholder::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 60%, rgba(201,168,76,0.08) 0%, transparent 70%);
  pointer-events: none;
}

.blog-placeholder-logo {
  width: 36px;
  height: 36px;
  object-fit: contain;
  opacity: 0.75;
  position: relative;
  z-index: 1;
}

.blog-placeholder-name {
  font-family: var(--font-display);
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-dim);
  position: relative;
  z-index: 1;
}

.blog-placeholder-gem {
  font-size: 1rem;
  position: relative;
  z-index: 1;
  line-height: 1;
}

/* ============================================================
   ADMIN — Pexels Image Search
   ============================================================ */

.pexels-search-bar {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  margin-bottom: var(--space-2);
}

.pexels-results {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--space-3);
  margin-top: var(--space-2);
  max-height: 320px;
  overflow-y: auto;
}

.pexels-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}

@media (max-width: 600px) {
  .pexels-grid { grid-template-columns: repeat(2, 1fr); }
}

.pexels-thumb {
  all: unset;
  cursor: pointer;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 2px solid transparent;
  transition: border-color var(--transition-fast), transform var(--transition-fast);
  display: block;
  aspect-ratio: 16/9;
}

.pexels-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.pexels-thumb:hover {
  border-color: var(--gold-dim);
  transform: scale(1.02);
}

.pexels-thumb.selected {
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(201,168,76,0.3);
}

.pexels-empty {
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
  padding: var(--space-4) 0;
  font-style: italic;
}

.admin-field-hint {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--space-2);
}

.admin-input {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--off-white);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  outline: none;
  transition: border-color var(--transition-fast);
}

.admin-input:focus {
  border-color: var(--gold-dim);
}


/* ============================================================
   BLOG / REFLECTIONS — Language filter bar
   ============================================================ */

.blog-lang-filter {
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-8);
  background: var(--bg);
  position: sticky;
  top: var(--navbar-height);
  z-index: 10;
}

.blog-lang-tabs {
  display: flex;
  gap: var(--space-1);
  padding: var(--space-3) 0;
}

.blog-lang-tab {
  all: unset;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--r-sm);
  border: 1px solid transparent;
  transition: color var(--transition-fast), border-color var(--transition-fast),
              background var(--transition-fast);
  white-space: nowrap;
}

.blog-lang-tab:hover {
  color: var(--off-white);
  background: rgba(255,255,255,0.04);
}

.blog-lang-tab.active {
  color: var(--gold);
  border-color: var(--border-gold);
  background: rgba(201,168,76,0.06);
}

.blog-lang-empty {
  text-align: center;
  padding: var(--space-16) 0;
  color: var(--text-muted);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-lg);
}

/* ============================================================
   ADMIN — Pexels full-screen modal
   ============================================================ */

.pexels-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
}

.pexels-modal {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  width: 100%;
  max-width: 760px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.pexels-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.pexels-modal-title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  letter-spacing: 0.06em;
  color: var(--off-white);
  margin: 0;
}

.pexels-modal-close {
  all: unset;
  cursor: pointer;
  color: var(--text-muted);
  font-size: var(--text-lg);
  line-height: 1;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--r-sm);
  transition: color var(--transition-fast);
}
.pexels-modal-close:hover { color: var(--off-white); }

.pexels-modal-search {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.pexels-modal-results {
  overflow-y: auto;
  padding: var(--space-4) var(--space-5);
  flex: 1;
}

.pexels-grid-modal {
  grid-template-columns: repeat(3, 1fr);
}

@media (max-width: 540px) {
  .pexels-grid-modal { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   ADMIN — Blog editor Library toggle
   ============================================================ */

.admin-library-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--gold);
  cursor: pointer;
  white-space: nowrap;
}

.admin-library-toggle input[type="checkbox"] {
  accent-color: var(--gold);
  width: 14px;
  height: 14px;
  cursor: pointer;
}

.admin-library-toggle input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ============================================================
   YOUTUBE / COMMUNITY SECTION (Home — Section 5)
   ============================================================ */

/* 16:9 responsive iframe wrapper */
.yt-embed-wrap {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border);
}

.yt-embed-wrap iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}

/* Featured (large) video */
.yt-featured {
  margin-bottom: var(--space-8);
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

/* Curated grid — 1 col mobile, 3 cols desktop */
.yt-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-8);
}

@media (min-width: 600px) {
  .yt-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 900px) {
  .yt-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Smaller embed for grid items */
.yt-embed-wrap-sm {
  border-radius: var(--r-sm);
}

/* Channel link CTA row */
.yt-channel-link {
  text-align: center;
  margin-top: var(--space-8);
}

/* Empty state when no videos configured yet */
.yt-empty {
  text-align: center;
  padding: var(--space-12) var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}

.yt-empty-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  color: var(--gold);
}

.yt-empty-text {
  color: var(--text-muted);
  font-size: var(--text-sm);
  margin: 0;
}

/* Section subheading */
.section-subhead {
  color: var(--text-muted);
  font-size: var(--text-sm);
  margin: var(--space-3) auto 0;
  max-width: 560px;
  text-align: center;
  line-height: 1.7;
}

/* ── Admin: YouTube module ── */
.yt-admin-field {
  margin-bottom: var(--space-6);
}

.yt-admin-field label {
  display: block;
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-2);
  letter-spacing: 0.03em;
}

.yt-admin-field input {
  width: 100%;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: var(--space-3) var(--space-4);
  color: var(--off-white);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  box-sizing: border-box;
}

.yt-admin-field input:focus {
  outline: none;
  border-color: var(--gold-dim);
}

.yt-admin-preview {
  margin-top: var(--space-3);
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--bg);
  border: 1px solid var(--border);
  aspect-ratio: 16/9;
  max-width: 400px;
}

.yt-admin-preview iframe {
  width: 100%;
  height: 100%;
  border: none;
}

.yt-admin-hint {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: var(--space-2);
}

.yt-curated-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.yt-curated-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.yt-curated-item input {
  flex: 1;
}

.yt-curated-remove {
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--text-muted);
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  font-size: 13px;
  white-space: nowrap;
}

.yt-curated-remove:hover {
  border-color: var(--crimson);
  color: #e07070;
}

/* ============================================================
   MAHFOOZ BRANCH CARD (Dashboard — optional Hifz path)
   ============================================================ */

.mhz-branch-card {
  background: var(--bg-card);
  border: 1px solid var(--border-gold);
  border-radius: var(--r-lg);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s;
}

/* Subtle ruby-toned shimmer on the left edge — nods to the gem logo */
.mhz-branch-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, #780F00, #C9A84C, #780F00);
  border-radius: var(--r-lg) 0 0 var(--r-lg);
}

.mhz-locked {
  border-color: var(--border);
  opacity: 0.75;
}

.mhz-locked::before {
  background: var(--border);
}

.mhz-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.mhz-header-text {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.mhz-sub {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin: 0;
  font-style: italic;
}

.mhz-gem-icon {
  font-size: 1.5rem;
  line-height: 1;
  opacity: 0.85;
}

.mhz-identity {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}

.mhz-role {
  color: var(--text-muted);
  font-size: var(--text-sm);
  margin: 0;
}

/* Stats row */
.mhz-stats {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

.mhz-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.mhz-stat-wide {
  flex-basis: 100%;
}

.mhz-stat-num {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--gold);
  font-family: var(--font-display);
  line-height: 1;
}

.mhz-stat-label {
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.mhz-pathway-badge {
  display: inline-block;
  font-size: var(--text-xs);
  color: var(--gold);
  border: 1px solid var(--border-gold);
  border-radius: 20px;
  padding: 2px var(--space-3);
  margin-bottom: var(--space-4);
}

.mhz-start-nudge,
.mhz-pending-text,
.mhz-locked-text {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin: 0 0 var(--space-4);
  font-style: italic;
}

.mhz-cta {
  margin-top: var(--space-2);
}

.mhz-lock-icon {
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  font-size: 1.1rem;
  opacity: 0.4;
}

/* ============================================================
   APPS PAGE — GO FURTHER / ADD-ONS SECTION
   ============================================================ */

.apps-addons-section {
  background: var(--bg-card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.apps-addons-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-top: var(--space-8);
}

@media (min-width: 640px) {
  .apps-addons-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
  .apps-addons-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Addon card — echoes apps-card but with ruby accent */
.apps-addon-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-top: 3px solid var(--addon-ruby, #8B0000);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.apps-addon-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(139,0,0,0.15);
  border-color: var(--addon-ruby, #8B0000);
}

.addon-card-icon-wrap {
  position: relative;
  padding: var(--space-6) var(--space-6) var(--space-4);
  display: flex;
  justify-content: center;
}

.addon-card-body {
  padding: 0 var(--space-6) var(--space-4);
  flex: 1;
}

.addon-branch-label {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--addon-ruby, #8B0000);
  font-family: var(--font-display);
}

.addon-open-btn {
  border-color: var(--addon-ruby, #8B0000);
  color: var(--addon-ruby, #8B0000);
}

.addon-open-btn:hover {
  background: var(--addon-ruby, #8B0000);
  color: var(--off-white);
}

/* Ruby colour for ArabicText when colour='ruby' */
.arabic-ruby {
  color: #C0392B;
}

/* ── Also update Mahfooz dashboard card ruby vars ── */
.mhz-branch-card::before {
  background: linear-gradient(180deg, #8B0000, #C0392B, #8B0000);
}

.mhz-pathway-badge {
  color: #C0392B;
  border-color: rgba(192, 57, 43, 0.3);
}
