/* ==========================================================================
   ATHKAR SECTION — "The Breathing Garden" (Redesigned)
   Full-bleed, edge-to-edge scrollable page. Cards stretch full screen width
   on mobile. Utilizes 100% of viewport with safe-area-inset for notch devices.
   ========================================================================== */


/* --------------------------------------------------------------------------
   1. SECTION — Full viewport, zero side gaps
   -------------------------------------------------------------------------- */

#section-athkar.active {
  display: flex;
  flex-direction: column;
  position: relative;
  min-block-size: 100dvh;
  width: 100%;
  background: var(--bg-deep);
  padding-inline: 0; /* override any global section padding */
}


/* --------------------------------------------------------------------------
   2. HEADER — Full-width sticky, edge-to-edge
   -------------------------------------------------------------------------- */

.athkar-header {
  position: sticky;
  inset-block-start: 0;
  z-index: var(--z-sticky);
  width: 100%;
  padding-block-start: calc(env(safe-area-inset-top, 0px) + var(--space-3));
  padding-block-end: var(--space-2);
  padding-inline: calc(env(safe-area-inset-right, 0px) + 12px) calc(env(safe-area-inset-left, 0px) + 12px);
  background: oklch(from var(--bg-deep) l c h / 0.92);
  -webkit-backdrop-filter: saturate(160%) blur(20px);
  backdrop-filter: saturate(160%) blur(20px);
  border-block-end: 1px solid var(--border);
  flex-shrink: 0;
}

.athkar-header h2 {
  font-family: var(--font-display);
  font-size: var(--text-ar-lg);
  color: var(--fg-primary);
  line-height: var(--leading-ar-heading);
  margin-block-end: var(--space-2);
  text-align: center;
}

/* Sub-nav — scrollable pill tabs, full width */
.athkar-sub-nav {
  display: flex;
  gap: var(--space-1-5);
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-block: var(--space-1);
  justify-content: flex-start;
  flex-wrap: nowrap;
  /* Allow scroll to extend into safe areas */
  margin-inline: -12px;
  padding-inline: 12px;
  width: calc(100% + 24px);
}

.athkar-sub-nav::-webkit-scrollbar {
  display: none;
}

.athkar-sub-nav-btn {
  flex-shrink: 0;
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--text-ar-xs);
  font-weight: var(--weight-medium);
  color: var(--fg-muted);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  transition: all var(--dur-normal) var(--ease-out);
  white-space: nowrap;
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  touch-action: manipulation;
}

.athkar-sub-nav-btn:hover {
  color: var(--fg-secondary);
  background: var(--bg-elevated);
  border-color: var(--border-strong);
}

.athkar-sub-nav-btn:active {
  transform: scale(0.96);
}

.athkar-sub-nav-btn.active {
  background: var(--accent-amber);
  color: var(--accent-amber-on);
  border-color: var(--accent-amber);
  box-shadow: var(--glow-amber-sm);
  font-weight: var(--weight-semibold);
}


/* --------------------------------------------------------------------------
   3. PROGRESS BAR — Full-width, zero side gaps
   -------------------------------------------------------------------------- */

.athkar-progress-wrap {
  position: sticky;
  inset-block-start: 0;
  z-index: calc(var(--z-sticky) - 1);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding-block: var(--space-2);
  padding-inline: calc(env(safe-area-inset-right, 0px) + 12px) calc(env(safe-area-inset-left, 0px) + 12px);
  background: oklch(from var(--bg-deep) l c h / 0.88);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  flex-shrink: 0;
}

.athkar-progress-bar {
  flex: 1;
  block-size: 3px;
  border-radius: var(--radius-full);
  background: var(--border);
  overflow: hidden;
  position: relative;
}

.athkar-progress-bar.all-done {
  box-shadow: 0 0 8px oklch(75% 0.18 70 / 0.4);
}

.athkar-progress-fill {
  block-size: 100%;
  border-radius: var(--radius-full);
  background: var(--accent-amber);
  transition: width var(--dur-moderate) var(--ease-out);
  box-shadow: 0 0 6px oklch(75% 0.18 70 / 0.3);
}

.athkar-progress-text {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  font-weight: var(--weight-semibold);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  min-inline-size: 3em;
  text-align: end;
}


/* --------------------------------------------------------------------------
   4. ATHKAR LIST — Edge-to-edge, no side padding
   -------------------------------------------------------------------------- */

.athkar-list {
  display: flex;
  flex-direction: column;
  gap: 0; /* cards touch — separated by borders, not gaps */
  width: 100%;
  padding: 0;
  padding-block-end: 0; /* cat-nav handles safe-area bottom */
  flex: 1;
}


/* --------------------------------------------------------------------------
   5. ATHKAR ITEM — Full-bleed flat cards, tappable, no border-radius
   -------------------------------------------------------------------------- */

.athkar-item {
  position: relative;
  width: 100%;
  border-radius: 0;
  background: var(--bg-surface);
  border: none;
  border-block-end: 1px solid var(--border);
  padding-block: var(--space-3);
  padding-inline: calc(env(safe-area-inset-right, 0px) + 12px) calc(env(safe-area-inset-left, 0px) + 12px);
  overflow: hidden;
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition:
    border-color var(--dur-normal) var(--ease-out),
    opacity var(--dur-moderate) var(--ease-out),
    background var(--dur-fast) var(--ease-out);
  animation: athkar-fade-in var(--dur-moderate) var(--ease-out) both;
}

.athkar-item:active:not(.completed) {
  background: var(--accent-amber-subtle);
}

/* Staggered entrance */
.athkar-item:nth-child(1)  { animation-delay:  0ms; }
.athkar-item:nth-child(2)  { animation-delay:  30ms; }
.athkar-item:nth-child(3)  { animation-delay:  60ms; }
.athkar-item:nth-child(4)  { animation-delay:  90ms; }
.athkar-item:nth-child(5)  { animation-delay: 120ms; }
.athkar-item:nth-child(6)  { animation-delay: 150ms; }
.athkar-item:nth-child(7)  { animation-delay: 180ms; }
.athkar-item:nth-child(8)  { animation-delay: 210ms; }
.athkar-item:nth-child(9)  { animation-delay: 240ms; }
.athkar-item:nth-child(10) { animation-delay: 270ms; }
.athkar-item:nth-child(n+11) { animation-delay: 300ms; }

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

/* Completed state */
.athkar-item.completed {
  opacity: 0.45;
}

/* Gold inline-start accent on completed */
.athkar-item.completed::before {
  content: "";
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
  inline-size: 3px;
  background: var(--accent-amber);
  opacity: 0.5;
}


/* --------------------------------------------------------------------------
   6. ITEM LAYOUT — Text + Badge
   -------------------------------------------------------------------------- */

.athkar-item-text {
  font-family: var(--font-quran);
  font-size: clamp(1.05rem, 0.85rem + 0.9vw, 1.5rem);
  line-height: var(--leading-ar-quran);
  color: var(--fg-primary);
  margin-block-end: var(--space-2);
  word-break: break-word;
}

.athkar-item-source {
  font-family: var(--font-body);
  font-size: var(--text-ar-xs);
  color: var(--fg-muted);
  margin-block-end: var(--space-1);
}

.athkar-item-benefit {
  font-family: var(--font-body);
  font-size: var(--text-ar-xs);
  color: var(--fg-secondary);
  background: var(--accent-amber-subtle);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  margin-block-start: var(--space-2);
  line-height: var(--leading-ar-body);
  border-inline-start: 2px solid oklch(75% 0.18 70 / 0.3);
}


/* --------------------------------------------------------------------------
   7. COUNTER BADGE — Single floating pill, bottom-inline-start of card
   -------------------------------------------------------------------------- */

.athkar-badge {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  margin-block-start: var(--space-2);
  padding: 3px 12px;
  border-radius: var(--radius-full);
  background: var(--accent-amber);
  color: var(--accent-amber-on);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  font-variant-numeric: tabular-nums;
  line-height: 1.4;
  transition: all var(--dur-fast) var(--ease-out);
}

.athkar-badge.single {
  background: var(--accent-amber-subtle);
  color: var(--accent-amber);
  font-size: var(--text-xs);
}

.athkar-badge.done {
  background: oklch(60% 0.18 145);
  color: white;
  padding: 3px 8px;
}

.athkar-badge-sep {
  opacity: 0.6;
  font-size: 0.7em;
}

.athkar-badge-total {
  opacity: 0.7;
  font-size: 0.85em;
}


/* --------------------------------------------------------------------------
   8. DESKTOP — Centered column with max-width
   -------------------------------------------------------------------------- */

@media (min-width: 768px) {
  #section-athkar.active {
    width: 100%;
  }

  .athkar-item {
    padding-block: var(--space-4);
    padding-inline: calc(env(safe-area-inset-right, 0px) + 16px) calc(env(safe-area-inset-left, 0px) + 16px);
  }

  .athkar-item-text {
    font-size: clamp(1.2rem, 1rem + 0.6vw, 1.6rem);
  }
}


/* --------------------------------------------------------------------------
   9. SMALL MOBILE — Tighter spacing
   -------------------------------------------------------------------------- */

@media (max-width: 400px) {
  .athkar-sub-nav-btn {
    padding: 5px var(--space-2);
    font-size: 0.68rem;
  }

  .athkar-item {
    padding-block: var(--space-2);
    padding-inline: 8px;
  }

  .athkar-item-text {
    font-size: clamp(0.95rem, 0.8rem + 0.7vw, 1.15rem);
  }

  .athkar-badge {
    font-size: var(--text-xs);
    padding: 2px 10px;
  }
}


/* --------------------------------------------------------------------------
   10. REDUCED MOTION
   -------------------------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  .athkar-item {
    animation: none;
  }

  .athkar-badge {
    transition: none;
  }
}


/* --------------------------------------------------------------------------
   11. LIGHT THEME — Adjusted glass backgrounds
   -------------------------------------------------------------------------- */

[data-theme="light"] .athkar-header,
:root:not([data-theme]) .athkar-header {
  background: oklch(from var(--bg-deep) l c h / 0.96);
}

[data-theme="light"] .athkar-progress-wrap,
:root:not([data-theme]) .athkar-progress-wrap {
  background: oklch(from var(--bg-deep) l c h / 0.94);
}

[data-theme="light"] .athkar-item,
:root:not([data-theme]) .athkar-item {
  border-block-end-color: oklch(0% 0 0 / 0.06);
}


/* --------------------------------------------------------------------------
   12. PICKER GRID — Category selection landing page
   -------------------------------------------------------------------------- */

.athkar-picker {
  width: 100%;
  padding: 0;
  padding-block-end: calc(env(safe-area-inset-bottom, 0px) + 80px);
}

.athkar-picker-header {
  padding: calc(env(safe-area-inset-top, 0px) + var(--space-4)) var(--space-4) var(--space-2);
  text-align: center;
}

.athkar-picker-header h2 {
  font-family: var(--font-display);
  font-size: var(--text-ar-lg);
  color: var(--fg-primary);
  line-height: var(--leading-ar-heading);
}

/* Group */
.athkar-group {
  margin-block-end: var(--space-3);
}

.athkar-group-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-body);
  font-size: var(--text-ar-sm);
  font-weight: var(--weight-semibold);
  color: var(--accent-amber);
}

.athkar-group-label svg {
  flex-shrink: 0;
  opacity: 0.7;
}

/* Card grid — 2 columns */
.athkar-group-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-2);
  padding-inline: var(--space-3);
}

/* Category card */
.athkar-cat-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-3) var(--space-2);
  border-radius: var(--radius-md);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: all var(--dur-normal) var(--ease-out);
  -webkit-user-select: none;
  user-select: none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  overflow: hidden;
  text-align: center;
  animation: athkar-fade-in var(--dur-moderate) var(--ease-out) both;
}

.athkar-cat-card:active {
  transform: scale(0.96);
}

.athkar-cat-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 36px;
  block-size: 36px;
  border-radius: var(--radius-full);
  background: var(--accent-amber-subtle);
  color: var(--accent-amber);
}

.athkar-cat-card-name {
  font-family: var(--font-body);
  font-size: var(--text-ar-sm);
  font-weight: var(--weight-semibold);
  color: var(--fg-primary);
  line-height: 1.3;
}

.athkar-cat-card-count {
  font-family: var(--font-mono);
  font-size: var(--text-2xs);
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}

/* Mini progress bar on card */
.athkar-cat-card-progress {
  width: 80%;
  block-size: 2px;
  border-radius: var(--radius-full);
  background: var(--border);
  overflow: hidden;
  margin-block-start: var(--space-1);
}

.athkar-cat-card-fill {
  block-size: 100%;
  border-radius: var(--radius-full);
  background: var(--accent-amber);
  transition: width var(--dur-moderate) var(--ease-out);
}

/* Suggested card — amber highlight */
.athkar-cat-card.suggested {
  border-color: var(--accent-amber);
  box-shadow: var(--glow-amber-sm);
}

.athkar-cat-card.suggested::after {
  content: 'مُقترح';
  position: absolute;
  inset-block-start: 4px;
  inset-inline-end: 4px;
  padding: 1px 6px;
  border-radius: var(--radius-full);
  background: var(--accent-amber);
  color: var(--accent-amber-on);
  font-family: var(--font-body);
  font-size: 0.55rem;
  font-weight: var(--weight-bold);
  line-height: 1.5;
}

/* Done card — green check */
.athkar-cat-card.done {
  opacity: 0.6;
}

.athkar-cat-card.done .athkar-cat-card-icon {
  background: oklch(60% 0.18 145 / 0.15);
  color: oklch(60% 0.18 145);
}

.athkar-cat-card-check {
  position: absolute;
  inset-block-start: 4px;
  inset-inline-end: 4px;
  color: oklch(60% 0.18 145);
}


/* --------------------------------------------------------------------------
   13. READER HEADER — Back button + title
   -------------------------------------------------------------------------- */

.athkar-reader-top {
  position: sticky;
  inset-block-start: 0;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  margin-block-end: var(--space-1);
  background: var(--bg-glass-heavy);
  -webkit-backdrop-filter: saturate(var(--saturate-glass)) blur(var(--blur-glass));
  backdrop-filter: saturate(var(--saturate-glass)) blur(var(--blur-glass));
  border-block-end: 1px solid var(--border-glass);
}

.athkar-back-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 36px;
  block-size: 36px;
  border-radius: var(--radius-full);
  background: var(--bg-elevated, var(--bg-surface));
  border: 1px solid var(--border);
  color: var(--fg-primary);
  cursor: pointer;
  flex-shrink: 0;
  transition: all var(--dur-fast) var(--ease-out);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.athkar-back-btn:active {
  transform: scale(0.9);
}

.athkar-reader-top h2 {
  flex: 1;
  font-family: var(--font-display);
  font-size: var(--text-ar-md);
  color: var(--fg-primary);
  line-height: var(--leading-ar-heading);
  text-align: center;
  margin: 0;
}

.athkar-reader-spacer {
  inline-size: 36px;
  flex-shrink: 0;
}

.athkar-reader-intro {
  font-family: var(--font-body);
  font-size: var(--text-ar-xs);
  color: var(--fg-muted);
  text-align: center;
  margin: 0;
  padding-block-end: var(--space-1);
}


/* --------------------------------------------------------------------------
   14. LIGHT THEME — Picker overrides
   -------------------------------------------------------------------------- */

[data-theme="light"] .athkar-cat-card,
:root:not([data-theme]) .athkar-cat-card {
  background: oklch(100% 0 0);
  border-color: oklch(0% 0 0 / 0.08);
}

[data-theme="light"] .athkar-back-btn,
:root:not([data-theme]) .athkar-back-btn {
  background: oklch(96% 0.01 80);
  border-color: oklch(0% 0 0 / 0.1);
}

[data-theme="light"] .athkar-picker-header h2,
:root:not([data-theme]) .athkar-picker-header h2 {
  color: oklch(15% 0.02 55);
}


/* --------------------------------------------------------------------------
   15. SMALL MOBILE — Picker adjustments
   -------------------------------------------------------------------------- */

@media (max-width: 400px) {
  .athkar-group-grid {
    gap: var(--space-1-5);
    padding-inline: var(--space-2);
  }

  .athkar-cat-card {
    padding: var(--space-2) var(--space-1-5);
  }

  .athkar-cat-card-icon {
    inline-size: 30px;
    block-size: 30px;
  }

  .athkar-cat-card-name {
    font-size: var(--text-ar-xs);
  }
}


/* --------------------------------------------------------------------------
   16. DESKTOP — Picker max-width
   -------------------------------------------------------------------------- */

@media (min-width: 768px) {
  .athkar-picker {
    max-inline-size: 800px;
    margin-inline: auto;
    padding-inline: var(--space-6);
  }

  .athkar-group-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1024px) {
  .athkar-picker {
    max-inline-size: 960px;
  }

  .athkar-group-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

