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

.salf-page {
  max-width: 600px;
  margin: 0 auto;
  padding: var(--spacing-lg);
}

.salf-header {
  text-align: center;
  margin-bottom: var(--spacing-xl);
  padding-bottom: var(--spacing-lg);
  border-bottom: 1px solid color-mix(in srgb, var(--color-quran) 20%, transparent);
}

.salf-header__title {
  font-family: var(--font-arabic);
  font-size: 2rem;
  color: var(--color-quran);
  margin: 0 0 var(--spacing-xs);
  font-weight: 700;
}

.salf-header__sub {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  margin: 0;
  letter-spacing: 0.5px;
}

/* ── Section Headers ── */

.salf-section {
  margin-bottom: var(--spacing-xl);
}

.salf-section__title {
  font-size: 0.6rem;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 500;
  margin: 0 0 var(--spacing-md);
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid var(--color-border);
}

/* ── Cards Container ── */

.salf-cards {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}

/* ── Card Base ── */

.salf-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--spacing-xl) var(--spacing-lg);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  text-decoration: none;
  transition: all var(--transition-fast);
}

/* ── Card Colors ── */

.salf-card--quran {
  border: 1px solid color-mix(in srgb, var(--color-quran) 30%, transparent);
}

.salf-card--quran:hover {
  border-color: var(--color-quran);
  box-shadow: 0 4px 20px color-mix(in srgb, var(--color-quran) 20%, transparent);
}

.salf-card--quran .salf-card__arabic { color: var(--color-quran); }

.salf-card--hadith {
  border: 1px solid color-mix(in srgb, var(--color-hadith) 30%, transparent);
}

.salf-card--hadith:hover {
  border-color: var(--color-hadith);
  box-shadow: 0 4px 20px color-mix(in srgb, var(--color-hadith) 20%, transparent);
}

.salf-card--hadith .salf-card__arabic { color: var(--color-hadith); }

.salf-card--asma {
  border: 1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);
}

.salf-card--asma:hover {
  border-color: var(--color-primary);
  box-shadow: 0 4px 20px color-mix(in srgb, var(--color-primary) 20%, transparent);
}

.salf-card--asma .salf-card__arabic { color: var(--color-primary); }

.salf-card--duas {
  border: 1px solid color-mix(in srgb, var(--color-learn) 30%, transparent);
}

.salf-card--duas:hover {
  border-color: var(--color-learn);
  box-shadow: 0 4px 20px color-mix(in srgb, var(--color-learn) 20%, transparent);
}

.salf-card--duas .salf-card__arabic { color: var(--color-learn); }

.salf-card__arabic {
  font-family: var(--font-arabic);
  font-size: 1.4rem;
  color: var(--color-quran);
  font-weight: 600;
  margin-bottom: var(--spacing-xs);
}

.salf-card__title {
  font-size: var(--font-size-base);
  color: var(--color-text);
  font-weight: 600;
  margin-bottom: var(--spacing-xs);
}

.salf-card__desc {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

/* === ASMA UL HUSNA — PREMIUM MINIMAL LUXURY === */

.asma-page {
  max-width: 600px;
  margin: 0 auto;
  padding: var(--spacing-md);
  display: flex;
  flex-direction: column;
}

/* ── Top bar ── */
.asma-top {
  margin-bottom: var(--spacing-md);
}

.asma-top__back {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.asma-top__back:hover {
  color: var(--color-quran);
}

/* ── Search Input ── */
.salf-fzf-input {
  width: 100%;
  margin-bottom: var(--spacing-md);
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid color-mix(in srgb, var(--color-quran) 20%, transparent);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-quran) 4%, var(--color-surface));
  color: var(--color-text);
  font-size: var(--font-size-sm);
  outline: none;
  transition: all var(--transition-fast);
  text-align: center;
}

.salf-fzf-input::placeholder {
  color: var(--color-text-muted);
  text-align: center;
}

.salf-fzf-input:focus {
  border-color: var(--color-quran);
  box-shadow: 0 0 12px color-mix(in srgb, var(--color-quran) 15%, transparent);
}

.asma-no-results {
  text-align: center;
  padding: var(--spacing-xl);
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
}

/* ── Wrapper ── */
.asma-wrapper {
  flex: 1;
  position: relative;
}

/* ── Scroll container ── */
.asma-scroll {
  height: calc(100vh - 260px);
  overflow-y: auto;
  scroll-snap-type: y mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.asma-scroll::-webkit-scrollbar {
  display: none;
}

/* ── Card ── */
.asma-card {
  position: relative;
  min-height: calc(100vh - 260px);
  display: flex;
  align-items: center;
  justify-content: center;
  scroll-snap-align: start;
  padding: var(--spacing-lg) var(--spacing-lg) calc(var(--spacing-xl) + 48px);
  border-radius: var(--radius-xl);
}

.asma-card__bg {
  position: absolute;
  inset: 0;
  border-radius: var(--radius-xl);
  background: radial-gradient(ellipse at 50% 30%, color-mix(in srgb, var(--color-quran) 5%, transparent) 0%, transparent 70%);
  pointer-events: none;
}

.asma-card:nth-child(odd) .asma-card__bg {
  background: radial-gradient(ellipse at 50% 30%, color-mix(in srgb, var(--color-quran) 3%, transparent) 0%, transparent 70%);
}

.asma-card__content {
  position: relative;
  text-align: center;
  max-width: 480px;
}

.asma-card__number {
  display: block;
  font-size: 0.65rem;
  color: color-mix(in srgb, var(--color-quran) 40%, transparent);
  letter-spacing: 3px;
  margin-bottom: var(--spacing-lg);
  font-weight: 400;
}

.asma-card__arabic {
  font-family: var(--font-arabic);
  font-size: clamp(3rem, 10vw, 5rem);
  color: var(--color-quran);
  font-weight: 700;
  margin: 0 0 var(--spacing-sm);
  line-height: 1.3;
  text-shadow: 0 0 40px color-mix(in srgb, var(--color-quran) 15%, transparent);
  letter-spacing: 2px;
}

.asma-card__trans {
  font-size: clamp(1rem, 2.5vw, 1.25rem);
  color: var(--color-text);
  font-weight: 400;
  margin: 0 0 var(--spacing-md);
  letter-spacing: 0.5px;
}

.asma-card__meaning {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  line-height: 1.7;
  margin: 0 auto;
  max-width: 400px;
}

/* ── Actions ── */
.asma-actions {
  position: absolute;
  bottom: var(--spacing-lg);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 2;
}

.asma-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
  padding: 0;
  line-height: 1;
}

.asma-action-btn svg {
  width: 13px;
  height: 13px;
  display: block;
}

.asma-action-btn:hover {
  color: var(--color-quran);
  border-color: var(--color-quran);
}

.asma-capturing .asma-actions,
.asma-capturing .asma-card__bg {
  display: none !important;
}

.asma-capturing,
.asma-capturing * {
  -webkit-user-select: none !important;
  user-select: none !important;
  transition: none !important;
  animation: none !important;
}

/* === DUAS STYLES === */

.dua-page {
  max-width: 600px;
  margin: 0 auto;
  padding: var(--spacing-md);
  display: flex;
  flex-direction: column;
}

/* ── Page heading ── */
.dua-page__heading {
  font-size: var(--font-size-base);
  color: var(--color-text-muted);
  font-weight: 400;
  text-align: center;
  margin: var(--spacing-lg) 0 0;
}

/* ── Category squircle grid ── */
.dua-cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
}

.dua-cat-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: var(--spacing-md) var(--spacing-sm);
  border-radius: var(--radius-lg);
  border: 1px solid color-mix(in srgb, var(--color-quran) 15%, transparent);
  background: var(--color-surface);
  cursor: pointer;
  transition: all var(--transition-fast);
  min-height: 80px;
}

.dua-cat-card:hover {
  border-color: color-mix(in srgb, var(--color-quran) 40%, transparent);
  box-shadow: 0 4px 16px color-mix(in srgb, var(--color-quran) 8%, transparent);
  transform: translateY(-1px);
}

.dua-cat-card.active {
  border-color: var(--color-quran);
  background: color-mix(in srgb, var(--color-quran) 8%, var(--color-surface));
  box-shadow: 0 0 20px color-mix(in srgb, var(--color-quran) 12%, transparent);
}

.dua-cat-card__title {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text);
  letter-spacing: 0.3px;
}

.dua-cat-card.active .dua-cat-card__title {
  color: var(--color-quran);
}

.dua-cat-card__count {
  font-size: 0.55rem;
  color: var(--color-text-muted);
  letter-spacing: 0.5px;
}

.dua-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
  padding-bottom: var(--spacing-xl);
}

.dua-card {
  position: relative;
  background: var(--color-surface);
  border: 1px solid color-mix(in srgb, var(--color-quran) 15%, transparent);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  transition: all var(--transition-fast);
  text-align: center;
}

.dua-card:hover {
  border-color: color-mix(in srgb, var(--color-quran) 35%, transparent);
  box-shadow: 0 4px 16px color-mix(in srgb, var(--color-quran) 8%, transparent);
}

.dua-card__purpose {
  display: block;
  font-size: 0.6rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: var(--spacing-md);
  font-weight: 500;
}

.dua-card__arabic {
  font-family: var(--font-arabic);
  font-size: clamp(1.3rem, 4vw, 2rem);
  color: var(--color-quran);
  font-weight: 600;
  margin: 0 0 var(--spacing-sm);
  line-height: 1.6;
  direction: rtl;
}

.dua-card__trans {
  font-size: var(--font-size-sm);
  color: var(--color-text);
  font-weight: 400;
  margin: 0 0 var(--spacing-sm);
  line-height: 1.6;
  font-style: italic;
}

.dua-card__meaning {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  line-height: 1.7;
  margin: 0 0 var(--spacing-md);
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.dua-card__source {
  display: inline-block;
  font-size: 0.6rem;
  letter-spacing: 0.5px;
  color: var(--grade-sahih);
  border: 1px solid color-mix(in srgb, var(--grade-sahih) 25%, transparent);
  border-radius: var(--radius-full);
  padding: 2px 10px;
  font-weight: 500;
  text-decoration: none;
  transition: all var(--transition-fast);
}

.dua-card__source:hover {
  background: color-mix(in srgb, var(--grade-sahih) 10%, transparent);
  border-color: var(--grade-sahih);
}

.dua-actions {
  display: flex;
  justify-content: center;
  margin-top: var(--spacing-md);
  gap: 6px;
}

.dua-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-muted);
  cursor: pointer;
  padding: 0;
  line-height: 1;
  transition: all var(--transition-fast);
}

.dua-link-btn svg {
  width: 13px;
  height: 13px;
  display: block;
}

.dua-link-btn:hover {
  color: var(--color-quran);
  border-color: var(--color-quran);
}

/* ── Responsive ── */
@media (max-width: 500px) {
  .salf-page, .asma-page, .dua-page {
    padding: var(--spacing-md);
  }
  .asma-card {
    padding: var(--spacing-md);
  }
  .asma-card__arabic {
    font-size: clamp(2.2rem, 12vw, 3.5rem);
  }
  .asma-index {
    right: var(--spacing-xs);
  }
}
