/* ============================================================
   ZamZam — SOLO LEVELING OVERRIDES (Phase 2 — full ПОЛНЫЙ ФАРШ)
   Targets every existing UI element on top of solo-system.css.
   - Prayer hero → ACTIVE MISSION window
   - Prayer rows → hex stat tiles
   - Bottom nav → command dock
   - Header → command bar
   - Hijri date → terminal readout
   - Ramadan banner → boss-raid card
   - Sections / cards / inputs polished
   ============================================================ */

/* ---------- HEADER as command bar ---------- */
header {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 14px !important;
  margin-bottom: 6px !important;
  position: relative;
  background: linear-gradient(180deg, rgba(0,20,40,0.55), transparent);
}
header::after {
  content: '';
  position: absolute;
  left: 14px; right: 14px; bottom: 4px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--sys-cyan-dim), transparent);
}
.header-logo {
  max-height: 30px !important;
  filter: drop-shadow(0 0 10px var(--sys-cyan-glow))
          drop-shadow(0 0 20px rgba(0, 246, 255, 0.3))
          hue-rotate(170deg) saturate(1.6) !important;
  opacity: 0.95;
  transition: filter 0.3s;
}
.header-logo:hover {
  filter: drop-shadow(0 0 14px var(--sys-cyan))
          drop-shadow(0 0 24px var(--sys-cyan-glow))
          hue-rotate(170deg) saturate(1.6) !important;
}

.header-actions {
  display: flex !important;
  align-items: center;
  gap: 6px !important;
}

/* Location chip — terminal pill */
.location-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(0, 246, 255, 0.06) !important;
  border: 1px solid var(--sys-cyan-dim) !important;
  border-radius: 0 !important;
  padding: 5px 10px !important;
  font-family: 'Orbitron', monospace !important;
  font-size: 10px !important;
  font-weight: 600;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 4px var(--sys-cyan-glow);
  transition: all 0.15s;
  /* Parallelogram cut */
  clip-path: polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
}
.location-chip:hover {
  background: rgba(0, 246, 255, 0.18) !important;
  box-shadow: 0 0 12px var(--sys-cyan-glow);
}
.location-chip-icon {
  font-size: 12px;
  filter: drop-shadow(0 0 4px var(--sys-cyan-glow));
}

/* ============================================================
   Sync dot — FULL-FRAME state indicator (very visible)
   States: synced(green) / pending(yellow) / syncing(cyan)
           / offline(orange) / error(red)
   ============================================================ */
.sync-dot {
  display: inline-flex !important;
  align-items: center;
  gap: 7px;
  border-radius: 0 !important;
  padding: 6px 12px !important;
  font-family: 'Orbitron', monospace !important;
  font-size: 10px !important;
  font-weight: 800;
  letter-spacing: 0.20em !important;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.12s, filter 0.12s;
  clip-path: polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
  border: 2px solid transparent !important;
  white-space: nowrap;
}
.sync-dot:hover { transform: translateY(-1px); filter: brightness(1.15); }
.sync-dot:active { transform: scale(0.96); }
.sync-dot-led {
  display: inline-block;
  width: 9px; height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}
.sync-dot-text { font-weight: 800; }

/* === SYNCED — bright green === */
.sync-dot.dot-synced {
  background: rgba(0, 255, 163, 0.18) !important;
  border-color: var(--sys-success) !important;
  color: var(--sys-success) !important;
  text-shadow: 0 0 6px rgba(0, 255, 163, 0.7);
  box-shadow: 0 0 14px rgba(0, 255, 163, 0.45);
}
.sync-dot.dot-synced .sync-dot-led {
  background: var(--sys-success);
  box-shadow: 0 0 6px var(--sys-success), 0 0 12px rgba(0, 255, 163, 0.7);
  animation: led-breathe 2.4s ease-in-out infinite;
}
.sync-dot.dot-synced .sync-dot-text { color: var(--sys-success); }

/* === PENDING — bright yellow/amber === */
.sync-dot.dot-pending {
  background: rgba(255, 200, 0, 0.20) !important;
  border-color: #ffc800 !important;
  color: #ffc800 !important;
  text-shadow: 0 0 6px rgba(255, 200, 0, 0.7);
  box-shadow: 0 0 16px rgba(255, 200, 0, 0.5);
  animation: dot-pulse-amber 1.4s ease-in-out infinite;
}
.sync-dot.dot-pending .sync-dot-led {
  background: #ffc800;
  box-shadow: 0 0 8px #ffc800, 0 0 14px rgba(255, 200, 0, 0.8);
  animation: led-breathe 1.4s ease-in-out infinite;
}
.sync-dot.dot-pending .sync-dot-text { color: #ffc800; }

/* === SYNCING — bright cyan with motion === */
.sync-dot.dot-syncing {
  background: rgba(0, 246, 255, 0.22) !important;
  border-color: var(--sys-cyan) !important;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 8px var(--sys-cyan);
  box-shadow: 0 0 18px var(--sys-cyan-glow);
  animation: dot-pulse-cyan 0.9s ease-in-out infinite;
}
.sync-dot.dot-syncing .sync-dot-led {
  background: var(--sys-cyan);
  box-shadow: 0 0 8px var(--sys-cyan), 0 0 18px var(--sys-cyan-glow);
  animation: led-spin 0.9s linear infinite;
}
.sync-dot.dot-syncing .sync-dot-text { color: #fff; text-shadow: 0 0 8px var(--sys-cyan); }

/* === OFFLINE — orange/dim === */
.sync-dot.dot-offline {
  background: rgba(255, 120, 30, 0.20) !important;
  border-color: #ff7a1e !important;
  color: #ff7a1e !important;
  text-shadow: 0 0 6px rgba(255, 120, 30, 0.7);
  box-shadow: 0 0 12px rgba(255, 120, 30, 0.4);
}
.sync-dot.dot-offline .sync-dot-led {
  background: #ff7a1e;
  box-shadow: 0 0 6px #ff7a1e, 0 0 12px rgba(255, 120, 30, 0.7);
  animation: led-breathe 3s ease-in-out infinite;
}
.sync-dot.dot-offline .sync-dot-text { color: #ff7a1e; }

/* === ERROR — RED, hard pulse — impossible to miss === */
.sync-dot.dot-error {
  background: rgba(255, 51, 102, 0.26) !important;
  border-color: var(--sys-danger) !important;
  color: #fff !important;
  text-shadow: 0 0 8px var(--sys-danger), 0 0 16px rgba(255, 51, 102, 0.6);
  box-shadow: 0 0 18px rgba(255, 51, 102, 0.7);
  animation: dot-pulse-red 0.7s ease-in-out infinite;
}
.sync-dot.dot-error .sync-dot-led {
  background: var(--sys-danger);
  box-shadow: 0 0 8px var(--sys-danger), 0 0 18px rgba(255, 51, 102, 0.9);
  animation: led-flash 0.5s steps(2) infinite;
}
.sync-dot.dot-error .sync-dot-text { color: #fff; }

@keyframes led-breathe {
  0%, 100% { opacity: 1;   transform: scale(1); }
  50%      { opacity: 0.55; transform: scale(0.85); }
}
@keyframes led-spin {
  0%   { box-shadow: 0 0 8px var(--sys-cyan), inset -3px 0 0 rgba(0, 0, 0, 0.4); }
  50%  { box-shadow: 0 0 16px var(--sys-cyan), inset 3px 0 0 rgba(0, 0, 0, 0.4); }
  100% { box-shadow: 0 0 8px var(--sys-cyan), inset -3px 0 0 rgba(0, 0, 0, 0.4); }
}
@keyframes led-flash {
  50% { opacity: 0.2; }
}
@keyframes dot-pulse-cyan {
  0%, 100% { box-shadow: 0 0 12px var(--sys-cyan-glow); }
  50%      { box-shadow: 0 0 26px var(--sys-cyan), 0 0 36px rgba(0, 246, 255, 0.5); }
}
@keyframes dot-pulse-amber {
  0%, 100% { box-shadow: 0 0 12px rgba(255, 200, 0, 0.4); }
  50%      { box-shadow: 0 0 22px rgba(255, 200, 0, 0.8); }
}
@keyframes dot-pulse-red {
  0%, 100% { box-shadow: 0 0 14px rgba(255, 51, 102, 0.5); }
  50%      { box-shadow: 0 0 28px var(--sys-danger), 0 0 44px rgba(255, 51, 102, 0.7); }
}

/* Icon buttons (theme, settings, qibla) — hex */
.icon-btn {
  width: 34px !important;
  height: 34px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  font-size: 16px !important;
  background: rgba(0, 246, 255, 0.05) !important;
  border: 1px solid var(--sys-cyan-dim) !important;
  border-radius: 0 !important;
  color: var(--sys-cyan) !important;
  text-decoration: none !important;
  transition: all 0.18s !important;
  /* Hex */
  clip-path: polygon(
    6px 0, calc(100% - 6px) 0,
    100% 6px, 100% calc(100% - 6px),
    calc(100% - 6px) 100%, 6px 100%,
    0 calc(100% - 6px), 0 6px
  );
}
.icon-btn:hover {
  background: var(--sys-cyan) !important;
  color: #000 !important;
  box-shadow: 0 0 14px var(--sys-cyan-glow);
  transform: translateY(-1px);
}

/* ---------- HIJRI DATE as terminal readout ---------- */
.hijri-date {
  font-family: 'Orbitron', monospace !important;
  font-size: 10px !important;
  font-weight: 600;
  letter-spacing: 0.22em !important;
  text-transform: uppercase;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 4px var(--sys-cyan-glow);
  text-align: center;
  padding: 6px 0 !important;
  opacity: 0.85;
}
.hijri-date::before { content: '◆ HIJRI · '; opacity: 0.7; }
.hijri-date::after  { content: ' ◆';        opacity: 0.7; }

/* ---------- ISLAMIC EVENT BADGE ---------- */
.islamic-event-badge {
  background: linear-gradient(90deg, rgba(255, 215, 0, 0.18), rgba(255, 215, 0, 0.06)) !important;
  border: 1px solid #ffd700 !important;
  color: #fff !important;
  font-family: 'Orbitron', monospace !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  text-shadow: 0 0 6px rgba(255, 215, 0, 0.6);
  box-shadow: 0 0 14px rgba(255, 215, 0, 0.4);
  padding: 8px 14px !important;
  margin: 8px 0 !important;
  text-align: center;
  border-radius: 0 !important;
  /* Asymmetric */
  clip-path: polygon(
    0 0, calc(100% - 10px) 0, 100% 10px,
    100% 100%, 10px 100%, 0 calc(100% - 10px)
  );
}
.islamic-event-badge::before { content: '★ EVENT · '; opacity: 0.85; }

/* ---------- RAMADAN BANNER as Boss Raid ---------- */
.ramadan-banner {
  background:
    linear-gradient(135deg, rgba(123, 45, 255, 0.18), rgba(0, 8, 20, 0.95)) !important;
  border: 1px solid var(--sys-purple) !important;
  border-radius: 0 !important;
  box-shadow:
    0 0 24px var(--sys-purple-glow),
    inset 0 0 20px rgba(123, 45, 255, 0.08) !important;
  padding: 14px 16px !important;
  margin: 10px 0 !important;
  position: relative;
  /* Asymmetric — top-right + bottom-left cut */
  clip-path: polygon(
    0 0, calc(100% - 14px) 0, 100% 14px,
    100% 100%, 14px 100%, 0 calc(100% - 14px)
  );
}
.ramadan-banner::before {
  content: '[ EVENT · RAMADAN ]';
  display: block;
  font-family: 'Orbitron', monospace;
  font-size: 9.5px;
  letter-spacing: 0.28em;
  color: var(--sys-purple);
  text-shadow: 0 0 6px var(--sys-purple-glow);
  font-weight: 800;
  margin-bottom: 6px;
}
.ramadan-header {
  font-family: 'Orbitron', sans-serif !important;
  font-weight: 800 !important;
  font-size: 17px !important;
  color: #fff !important;
  text-shadow: 0 0 10px var(--sys-purple-glow);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.ramadan-times {
  font-family: 'Orbitron', monospace !important;
  font-size: 12px !important;
  color: var(--sys-cyan) !important;
  margin-top: 4px;
  letter-spacing: 0.1em;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 4px var(--sys-cyan-glow);
}
.ramadan-countdown {
  font-family: 'Orbitron', sans-serif !important;
  font-size: 22px !important;
  font-weight: 900 !important;
  color: #fff !important;
  text-shadow: 0 0 14px var(--sys-cyan-glow);
  margin-top: 6px;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
}
.ramadan-progress {
  height: 4px !important;
  background: rgba(123, 45, 255, 0.12) !important;
  border: 1px solid var(--sys-purple) !important;
  margin-top: 8px;
  border-radius: 0 !important;
  overflow: hidden;
}
.ramadan-progress-fill {
  height: 100% !important;
  background: linear-gradient(90deg, var(--sys-purple), var(--sys-cyan)) !important;
  box-shadow: 0 0 8px var(--sys-purple-glow);
  transition: width 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.ramadan-day-text {
  font-family: 'Orbitron', monospace !important;
  font-size: 10px !important;
  color: var(--sys-purple) !important;
  margin-top: 6px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* ---------- DATE HEADER (when navigating dates) ---------- */
.prayer-date-header {
  font-family: 'Orbitron', monospace !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.22em !important;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 6px var(--sys-cyan-glow);
  text-transform: uppercase !important;
  text-align: center;
  padding: 10px 0 8px !important;
  opacity: 0.9;
}
.prayer-date-header:not(:empty)::before { content: '◆ DATE · '; opacity: 0.7; }
.prayer-date-header:not(:empty)::after  { content: ' ◆'; opacity: 0.7; }

/* ============================================================
   PRAYER HERO CARD — ACTIVE MISSION window
   ============================================================ */
.prayer-hero-card {
  position: relative;
  margin: 12px 0 16px !important;
  padding: 22px 18px 20px !important;
  background:
    radial-gradient(ellipse at top, rgba(0, 246, 255, 0.10), transparent 60%),
    linear-gradient(180deg, rgba(0,20,40,0.92), rgba(0,8,20,0.85)) !important;
  border: 1px solid var(--sys-cyan-dim) !important;
  border-radius: 0 !important;
  box-shadow:
    0 0 28px rgba(0,246,255,0.18),
    inset 0 0 30px rgba(0,246,255,0.04),
    inset 0 1px 0 rgba(0,246,255,0.20) !important;
  /* Top-right + bottom-left cut */
  clip-path: polygon(
    0 0, calc(100% - 16px) 0, 100% 16px,
    100% 100%, 16px 100%, 0 calc(100% - 16px)
  ) !important;
  overflow: hidden;
  text-align: center !important;
  font-family: 'Orbitron', sans-serif;
}
/* Scanline texture */
.prayer-hero-card::before {
  content: '';
  position: absolute; inset: 0;
  background:
    repeating-linear-gradient(
      0deg,
      transparent 0,
      transparent 3px,
      rgba(0,246,255,0.02) 3px,
      rgba(0,246,255,0.02) 4px
    );
  pointer-events: none;
  z-index: 0;
}
/* Top accent */
.prayer-hero-card > * { position: relative; z-index: 1; }

.prayer-hero-label {
  font-family: 'Orbitron', monospace !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.32em !important;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 6px var(--sys-cyan-glow);
  text-transform: uppercase !important;
  display: block;
  margin-bottom: 12px !important;
  opacity: 0.95;
}
.prayer-hero-label::before { content: '◆ '; opacity: 0.7; }
.prayer-hero-label::after  { content: ' ◆'; opacity: 0.7; }

.prayer-hero-name {
  font-family: 'Orbitron', sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(28px, 9vw, 44px) !important;
  color: #fff !important;
  text-shadow:
    0 0 14px var(--sys-cyan),
    0 0 28px var(--sys-cyan-glow),
    0 0 56px rgba(0,246,255,0.3) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  line-height: 1.05 !important;
  margin: 0 !important;
}

.prayer-hero-time {
  font-family: 'Orbitron', monospace !important;
  font-weight: 800 !important;
  font-size: clamp(20px, 6vw, 28px) !important;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 10px var(--sys-cyan-glow);
  letter-spacing: 0.08em !important;
  font-variant-numeric: tabular-nums !important;
  margin-top: 8px !important;
}

/* ============================================================
   Countdown badge — color-coded by time remaining
   GREEN  : >3h    (calm)
   YELLOW : 1h-3h  (heads up)
   RED    : <1h    (red fills from right as time runs out)
   00:00  : full red
   On reset (next prayer) → back to GREEN automatically
   ============================================================ */
.prayer-hero-countdown {
  --cd-fill: 0%;
  position: relative;
  font-family: 'Orbitron', monospace !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  margin-top: 12px !important;
  padding: 7px 16px !important;
  display: inline-block !important;
  border: 2px solid transparent !important;
  background: rgba(0, 8, 20, 0.6) !important;
  font-variant-numeric: tabular-nums !important;
  clip-path: polygon(8px 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
  overflow: hidden;
  z-index: 1;
  transition: border-color 0.4s, color 0.4s, text-shadow 0.4s, box-shadow 0.4s;
}
/* Red progress bar that fills from right → left as <1h ticks down */
.prayer-hero-countdown::before {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  right: 0;
  width: var(--cd-fill, 0%);
  background: linear-gradient(90deg, rgba(255, 51, 102, 0.45), rgba(255, 51, 102, 0.85));
  box-shadow: 0 0 16px rgba(255, 51, 102, 0.6);
  z-index: -1;
  transition: width 1s linear;
}

/* GREEN — plenty of time (>3h) */
.prayer-hero-countdown.cd-green {
  background: rgba(0, 255, 163, 0.10) !important;
  border-color: var(--sys-success) !important;
  color: var(--sys-success) !important;
  text-shadow: 0 0 8px rgba(0, 255, 163, 0.7);
  box-shadow: 0 0 14px rgba(0, 255, 163, 0.45);
  animation: cd-green-breath 3s ease-in-out infinite;
}
@keyframes cd-green-breath {
  0%, 100% { box-shadow: 0 0 10px rgba(0, 255, 163, 0.35); }
  50%      { box-shadow: 0 0 22px rgba(0, 255, 163, 0.65); }
}

/* YELLOW — getting close (1h-3h) */
.prayer-hero-countdown.cd-yellow {
  background: rgba(255, 200, 0, 0.12) !important;
  border-color: #ffc800 !important;
  color: #ffc800 !important;
  text-shadow: 0 0 8px rgba(255, 200, 0, 0.7);
  box-shadow: 0 0 16px rgba(255, 200, 0, 0.5);
  animation: cd-yellow-pulse 1.8s ease-in-out infinite;
}
@keyframes cd-yellow-pulse {
  0%, 100% { box-shadow: 0 0 12px rgba(255, 200, 0, 0.4); }
  50%      { box-shadow: 0 0 24px rgba(255, 200, 0, 0.8); }
}

/* RED — <1h, red bar chases yellow filling from right→left.
   Border + text turn red as fill grows. */
.prayer-hero-countdown.cd-red {
  background: rgba(255, 200, 0, 0.10) !important;
  border-color: var(--sys-danger) !important;
  color: #fff !important;
  text-shadow: 0 0 8px var(--sys-danger), 0 0 16px rgba(255, 51, 102, 0.6);
  box-shadow: 0 0 18px rgba(255, 51, 102, 0.6);
  animation: cd-red-pulse 1s ease-in-out infinite;
}
@keyframes cd-red-pulse {
  0%, 100% { box-shadow: 0 0 14px rgba(255, 51, 102, 0.5); }
  50%      { box-shadow: 0 0 28px var(--sys-danger), 0 0 44px rgba(255, 51, 102, 0.7); }
}

/* Hero nav arrows — make hex */
.hero-nav-arrow {
  background: rgba(0, 246, 255, 0.06) !important;
  border: 1px solid var(--sys-cyan-dim) !important;
  color: var(--sys-cyan) !important;
  border-radius: 0 !important;
  font-family: 'Orbitron', sans-serif;
  font-weight: 800;
  text-shadow: 0 0 4px var(--sys-cyan-glow);
  transition: all 0.18s !important;
  clip-path: polygon(
    6px 0, calc(100% - 6px) 0,
    100% 6px, 100% calc(100% - 6px),
    calc(100% - 6px) 100%, 6px 100%,
    0 calc(100% - 6px), 0 6px
  );
}
.hero-nav-arrow:hover {
  background: var(--sys-cyan) !important;
  color: #000 !important;
  box-shadow: 0 0 12px var(--sys-cyan-glow);
}

/* ============================================================
   PRAYER TIME ROWS — SL stat tiles
   ============================================================ */
#prayerTimesList { padding: 4px 0; }

.prayer-time-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  margin: 8px 12px !important;
  background: rgba(0, 8, 20, 0.55) !important;
  border: 1px solid rgba(0, 246, 255, 0.12) !important;
  border-radius: 0 !important;
  position: relative;
  transition: all 0.2s cubic-bezier(0.2, 0.8, 0.2, 1) !important;
  /* Asymmetric — top-right + bottom-left cut */
  clip-path: polygon(
    0 0, calc(100% - 10px) 0, 100% 10px,
    100% 100%, 10px 100%, 0 calc(100% - 10px)
  );
}
.prayer-time-row.clickable { cursor: pointer; }
.prayer-time-row:hover {
  background: rgba(0, 246, 255, 0.06) !important;
  border-color: var(--sys-cyan-dim) !important;
  transform: translateX(2px);
}

/* Left: hex icon + name */
.prayer-time-left {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.prayer-time-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px !important;
  background: rgba(0, 246, 255, 0.08) !important;
  border: 1px solid var(--sys-cyan-dim) !important;
  filter: drop-shadow(0 0 4px var(--sys-cyan-glow));
  /* Hex */
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  flex-shrink: 0;
}
.prayer-time-label {
  font-family: 'Orbitron', sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--sys-text) !important;
  text-shadow: 0 0 4px rgba(0,246,255,0.2);
}

/* Right: state btn + done-at + time */
.prayer-time-right {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.prayer-time-value {
  font-family: 'Orbitron', monospace !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 6px var(--sys-cyan-glow);
  letter-spacing: 0.04em !important;
  font-variant-numeric: tabular-nums !important;
  white-space: nowrap;
}
.prayer-done-at {
  font-family: 'Orbitron', monospace;
  font-size: 9px;
  letter-spacing: 0.16em;
  color: var(--sys-success) !important;
  text-shadow: 0 0 4px rgba(0,255,163,0.5);
  text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  opacity: 0.95;
}
.prayer-done-at:not(:empty)::before { content: '◆ '; opacity: 0.7; }

/* === State buttons (the cycle ✓/❌/⬜) === */
button#pstate-Fajr, button#pstate-Dhuhr, button#pstate-Asr,
button#pstate-Maghrib, button#pstate-Isha, button#pstate-Witr,
button#pstate-Tahajjud, .prayer-time-row .state-btn,
button[id^="pstate-"] {
  width: 32px !important;
  height: 32px !important;
  border-radius: 0 !important;
  background: rgba(0, 246, 255, 0.05) !important;
  border: 1px solid var(--sys-cyan-dim) !important;
  color: var(--sys-cyan) !important;
  font-family: 'Orbitron', sans-serif !important;
  font-weight: 800 !important;
  font-size: 14px !important;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: all 0.15s !important;
  /* Hex */
  clip-path: polygon(
    6px 0, calc(100% - 6px) 0,
    100% 6px, 100% calc(100% - 6px),
    calc(100% - 6px) 100%, 6px 100%,
    0 calc(100% - 6px), 0 6px
  );
}
button[id^="pstate-"]:active { transform: scale(0.92); }

/* === Row state colors === */
/* Next / current — bright cyan with pulse */
.prayer-time-row.prayer-next {
  background: linear-gradient(90deg, rgba(0,246,255,0.10), rgba(0,8,20,0.7)) !important;
  border-color: var(--sys-cyan) !important;
  box-shadow:
    0 0 18px var(--sys-cyan-glow),
    inset 0 0 14px rgba(0,246,255,0.06) !important;
  animation: row-next-pulse 2s ease-in-out infinite;
}
@keyframes row-next-pulse {
  0%, 100% { box-shadow: 0 0 14px rgba(0,246,255,0.3), inset 0 0 12px rgba(0,246,255,0.04); }
  50%      { box-shadow: 0 0 24px var(--sys-cyan-glow), inset 0 0 18px rgba(0,246,255,0.08); }
}
.prayer-time-row.prayer-next .prayer-time-icon {
  background: var(--sys-cyan) !important;
  border-color: #fff !important;
  box-shadow: 0 0 12px var(--sys-cyan-glow);
  filter: drop-shadow(0 0 8px var(--sys-cyan-glow));
}
.prayer-time-row.prayer-next .prayer-time-label,
.prayer-time-row.prayer-next .prayer-time-value {
  color: #fff !important;
  text-shadow: 0 0 8px var(--sys-cyan-glow);
}
.prayer-time-row.prayer-next::before {
  content: 'NOW';
  position: absolute;
  top: -1px; left: 14px;
  font-family: 'Orbitron', monospace;
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 0.18em;
  color: #000;
  background: var(--sys-cyan);
  padding: 2px 6px 2px 4px;
  text-shadow: none;
  box-shadow: 0 0 8px var(--sys-cyan-glow);
  z-index: 2;
}

/* Passed but not done — dim */
.prayer-time-row.prayer-passed:not(.prayer-next):not(.prayer-info) {
  opacity: 0.55;
}

/* Info-only rows (Sunrise, Ishraq) — purple subdued */
.prayer-time-row.prayer-info {
  background: rgba(123, 45, 255, 0.04) !important;
  border-color: rgba(123, 45, 255, 0.15) !important;
}
.prayer-time-row.prayer-info .prayer-time-icon {
  background: rgba(123, 45, 255, 0.10) !important;
  border-color: rgba(123, 45, 255, 0.3) !important;
  filter: drop-shadow(0 0 4px var(--sys-purple-glow));
}
.prayer-time-row.prayer-info .prayer-time-label {
  color: #b89aff !important;
  text-shadow: 0 0 4px var(--sys-purple-glow);
}
.prayer-time-row.prayer-info .prayer-time-value {
  color: #b89aff !important;
  text-shadow: 0 0 4px var(--sys-purple-glow);
}

/* When a prayer state button is "done" (true), highlight whole row */
.prayer-time-row:has(button[id^="pstate-"].state-done),
.prayer-time-row:has(button.state-done) {
  background: linear-gradient(90deg, rgba(0,255,163,0.06), rgba(0,8,20,0.7)) !important;
  border-color: rgba(0,255,163,0.35) !important;
}
.prayer-time-row:has(button.state-done) .prayer-time-icon {
  background: rgba(0,255,163,0.18) !important;
  border-color: var(--sys-success) !important;
  filter: drop-shadow(0 0 6px rgba(0,255,163,0.6));
}

/* state-done style on the button itself */
button[id^="pstate-"].state-done,
.prayer-time-row .state-done {
  background: var(--sys-success) !important;
  color: #000 !important;
  border-color: var(--sys-success) !important;
  box-shadow: 0 0 14px rgba(0,255,163,0.6),
              inset 0 0 6px rgba(255,255,255,0.3) !important;
  text-shadow: none !important;
}
button[id^="pstate-"].state-missed,
.prayer-time-row .state-missed {
  background: rgba(255,51,102,0.10) !important;
  color: var(--sys-danger) !important;
  border-color: var(--sys-danger) !important;
  box-shadow: 0 0 10px rgba(255,51,102,0.5) !important;
}

/* ============================================================
   BOTTOM NAV — command dock
   ============================================================ */
.bottom-nav {
  background: linear-gradient(0deg, rgba(0,8,20,0.97), rgba(0,20,40,0.94)) !important;
  /* Lighter blur — 22px caused repaint pressure on every hover/scroll */
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  contain: layout paint !important;
  border: none !important;
  border-top: 1px solid var(--sys-cyan-dim) !important;
  border-radius: 0 !important;
  box-shadow:
    0 -4px 24px rgba(0,246,255,0.20),
    inset 0 1px 0 rgba(0,246,255,0.20) !important;
  display: flex !important;
  justify-content: space-around;
  padding: 8px 4px 10px !important;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 40;
}
.nav-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: center;
  gap: 3px;
  padding: 6px 10px !important;
  text-decoration: none !important;
  color: var(--sys-text-muted) !important;
  font-family: 'Orbitron', monospace !important;
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  position: relative;
  transition: all 0.18s !important;
  border-radius: 0 !important;
  min-width: 56px;
}
.nav-icon {
  font-size: 18px !important;
  line-height: 1;
  filter: grayscale(0.6) opacity(0.7);
  transition: filter 0.18s, transform 0.18s;
}
.nav-item:hover .nav-icon {
  filter: grayscale(0) opacity(1);
  transform: translateY(-1px);
}
.nav-item:hover { color: var(--sys-cyan) !important; }

.nav-item.active {
  color: var(--sys-cyan) !important;
  text-shadow: 0 0 8px var(--sys-cyan-glow) !important;
}
.nav-item.active .nav-icon {
  filter: drop-shadow(0 0 6px var(--sys-cyan-glow)) opacity(1);
  transform: translateY(-2px);
}
/* Active marker — top hex bar */
.nav-item.active::before {
  content: '';
  position: absolute;
  top: -10px; left: 50%;
  transform: translateX(-50%);
  width: 32px; height: 3px;
  background: var(--sys-cyan);
  box-shadow: 0 0 10px var(--sys-cyan-glow);
  clip-path: polygon(4px 0, calc(100% - 4px) 0, 100% 100%, 0 100%);
  animation: nav-active-glow 1.8s ease-in-out infinite;
}
@keyframes nav-active-glow {
  0%, 100% { opacity: 0.7; box-shadow: 0 0 6px rgba(0,246,255,0.4); }
  50%      { opacity: 1;   box-shadow: 0 0 14px var(--sys-cyan-glow); }
}

/* ============================================================
   COUNTDOWN OVERLAY (when tapping a prayer time)
   ============================================================ */
#countdownOverlay,
.countdown-overlay {
  background: radial-gradient(circle at center, rgba(0,246,255,0.18), rgba(0,0,0,0.95)) !important;
  backdrop-filter: blur(8px) !important;
}
#countdownOverlay .overlay-prayer-name,
#overlayPrayerName {
  font-family: 'Orbitron', sans-serif !important;
  font-weight: 900 !important;
  font-size: clamp(28px, 8vw, 42px) !important;
  color: #fff !important;
  text-shadow: 0 0 18px var(--sys-cyan), 0 0 36px var(--sys-cyan-glow) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}
#countdownOverlay .overlay-prayer-time,
#overlayPrayerTime {
  font-family: 'Orbitron', monospace !important;
  font-weight: 800 !important;
  font-size: 20px !important;
  color: var(--sys-cyan) !important;
  letter-spacing: 0.1em !important;
  text-shadow: 0 0 8px var(--sys-cyan-glow);
  font-variant-numeric: tabular-nums !important;
}
#countdownOverlay .countdown-display,
#countdownText {
  font-family: 'Orbitron', monospace !important;
  font-weight: 900 !important;
  font-size: clamp(40px, 12vw, 64px) !important;
  color: #fff !important;
  text-shadow:
    0 0 20px var(--sys-cyan),
    0 0 40px var(--sys-cyan-glow) !important;
  letter-spacing: 0.04em !important;
  font-variant-numeric: tabular-nums !important;
  margin-top: 16px !important;
}

/* ============================================================
   QAZA / HABITS / FASTING / SALAWAT / ISTIGHFAR (today.html)
   Polish toggles + counters
   ============================================================ */

/* Section header inside cards (when there's a label inline) */
.section-row, .row-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-top: 1px solid rgba(0,246,255,0.06);
}

/* Generic "+N" / number control buttons */
button.text-btn,
button.istighfar-btn {
  letter-spacing: 0.16em !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  padding: 8px 14px !important;
  clip-path: polygon(6px 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
}

/* Big counter values (Salawat / Istighfar) — extra glow */
.istighfar-total,
.salawat-total,
.counter-total {
  text-align: center;
  padding: 18px 0 !important;
}
.istighfar-total span,
.salawat-total span,
.counter-total span {
  font-size: 40px !important;
  text-shadow:
    0 0 16px var(--sys-cyan),
    0 0 36px var(--sys-cyan-glow) !important;
  display: inline-block;
  animation: counter-breathe 4s ease-in-out infinite;
}
@keyframes counter-breathe {
  0%, 100% { text-shadow: 0 0 14px var(--sys-cyan), 0 0 28px var(--sys-cyan-glow); }
  50%      { text-shadow: 0 0 20px var(--sys-cyan), 0 0 44px var(--sys-cyan-glow); }
}

/* ============================================================
   STATS PAGE — heatmap polish (override styles.css)
   ============================================================ */
.heatmap-cell {
  border-radius: 0 !important;
}
.heatmap-cell.lvl-1 { background: rgba(0, 246, 255, 0.18) !important; box-shadow: 0 0 4px rgba(0,246,255,0.18); }
.heatmap-cell.lvl-2 { background: rgba(0, 246, 255, 0.40) !important; box-shadow: 0 0 6px rgba(0,246,255,0.30); }
.heatmap-cell.lvl-3 { background: rgba(0, 246, 255, 0.65) !important; box-shadow: 0 0 8px rgba(0,246,255,0.45); }
.heatmap-cell.lvl-4 { background: var(--sys-cyan) !important;          box-shadow: 0 0 10px var(--sys-cyan-glow); }

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 380px) {
  .prayer-hero-card { padding: 18px 14px 16px !important; }
  .prayer-time-row { padding: 10px 12px !important; margin: 6px 8px !important; }
  .prayer-time-icon { width: 30px; height: 30px; font-size: 15px !important; }
  .prayer-time-label { font-size: 12px !important; letter-spacing: 0.1em !important; }
  .prayer-time-value { font-size: 13px !important; }
  .nav-item { font-size: 8px !important; min-width: 48px; padding: 5px 6px !important; }
  .nav-icon { font-size: 16px !important; }
  .location-chip { font-size: 9px !important; padding: 4px 8px !important; }
  .sync-dot { font-size: 8px !important; padding: 4px 8px !important; }
  .icon-btn { width: 30px !important; height: 30px !important; font-size: 14px !important; }
}

/* Add bottom padding so content doesn't sit under fixed nav */
body { padding-bottom: 80px !important; }

/* Container max-width on phones */
@media (max-width: 600px) {
  .container {
    max-width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}
