/* SalatiPal — state-of-the-art offline download manager overlay.
   Self-contained; namespaced under .spom-* so it never collides with the app. */
.spom-backdrop{position:fixed;inset:0;z-index:2147483600;background:rgba(15,23,42,.45);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;transition:opacity .28s ease;
  display:flex;align-items:flex-end;justify-content:center;}
.spom-backdrop.spom-show{opacity:1;}

.spom{--bg:#f5f7fb;--card:#ffffff;--card2:#f0f3f9;--text:#0f172a;--sub:#64748b;--line:#e2e8f0;
  --accent:#2563eb;--accent2:#06b6d4;--green:#10b981;--danger:#ef4444;--ring-track:#e2e8f0;
  position:relative;width:100%;max-width:560px;height:92dvh;max-height:92dvh;background:var(--bg);
  border-radius:26px 26px 0 0;display:flex;flex-direction:column;overflow:hidden;color:var(--text);
  box-shadow:0 -8px 40px rgba(2,6,23,.35);transform:translateY(100%);
  transition:transform .42s cubic-bezier(.22,1,.36,1);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,system-ui,sans-serif;
  padding-bottom:env(safe-area-inset-bottom);}
.spom-backdrop.spom-show .spom{transform:translateY(0);}
.spom[data-theme="dark"]{--bg:#0b1220;--card:#151c2c;--card2:#1c2638;--text:#f1f5f9;--sub:#94a3b8;
  --line:#27324a;--ring-track:#27324a;--accent:#3b82f6;}

/* grabber + header */
.spom-grab{width:38px;height:5px;border-radius:3px;background:var(--line);margin:9px auto 2px;flex:none;}
.spom-head{display:flex;align-items:center;gap:10px;padding:6px 16px 12px;flex:none;}
.spom-title{font-size:20px;font-weight:800;letter-spacing:-.02em;flex:1;}
.spom-x{width:34px;height:34px;border-radius:50%;border:none;background:var(--card2);color:var(--sub);
  font-size:17px;cursor:pointer;display:grid;place-items:center;transition:transform .15s,background .15s;}
.spom-x:active{transform:scale(.9);}

/* storage meter */
.spom-storage{margin:0 16px 12px;background:var(--card);border:1px solid var(--line);border-radius:16px;
  padding:12px 14px;flex:none;}
.spom-storage-top{display:flex;justify-content:space-between;align-items:baseline;font-size:12.5px;color:var(--sub);}
.spom-storage-top b{color:var(--text);font-size:13.5px;font-weight:700;}
.spom-bar{height:7px;border-radius:4px;background:var(--ring-track);margin-top:8px;overflow:hidden;}
.spom-bar>i{display:block;height:100%;border-radius:4px;width:0;
  background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .5s ease;}

/* segmented tabs */
.spom-tabs{display:flex;gap:4px;margin:0 16px 10px;background:var(--card2);border-radius:14px;padding:4px;flex:none;}
.spom-tab{flex:1;border:none;background:transparent;color:var(--sub);font-size:14px;font-weight:700;
  padding:9px 0;border-radius:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;
  transition:color .2s;}
.spom-tab.spom-active{background:var(--card);color:var(--text);box-shadow:0 1px 4px rgba(2,6,23,.12);}
.spom-tab svg{width:16px;height:16px;}

/* scroll area */
.spom-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px 90px;}
.spom-section-h{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--sub);
  margin:14px 4px 8px;}

/* reciter chips */
.spom-chips{display:flex;gap:8px;overflow-x:auto;padding:2px 0 6px;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.spom-chips::-webkit-scrollbar{display:none;}
.spom-chip{flex:none;border:1px solid var(--line);background:var(--card);color:var(--text);font-size:13px;
  font-weight:600;padding:8px 14px;border-radius:999px;cursor:pointer;white-space:nowrap;transition:.15s;}
.spom-chip.spom-on{background:var(--accent);border-color:var(--accent);color:#fff;}
.spom-chip.spom-empty{opacity:.5;}
.spom-chip .spom-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-left:6px;vertical-align:middle;}

/* hero "download all" card */
.spom-hero{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-radius:18px;
  padding:15px 16px;margin:4px 0 6px;display:flex;align-items:center;gap:14px;}
.spom-hero-txt{flex:1;min-width:0;}
.spom-hero-txt h4{font-size:15px;font-weight:800;margin:0 0 3px;}
.spom-hero-txt p{font-size:12px;opacity:.9;margin:0;}
.spom-hero-btn{flex:none;background:rgba(255,255,255,.22);border:none;color:#fff;font-weight:700;font-size:13px;
  padding:10px 16px;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:.15s;}
.spom-hero-btn:active{transform:scale(.95);}

/* item cards */
.spom-item{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:11px 13px;margin-bottom:8px;content-visibility:auto;contain-intrinsic-size:64px;}
.spom-num{flex:none;width:34px;height:34px;border-radius:10px;background:var(--card2);color:var(--sub);
  font-size:13px;font-weight:700;display:grid;place-items:center;}
.spom-meta{flex:1;min-width:0;}
.spom-meta h5{font-size:14.5px;font-weight:700;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.spom-meta span{font-size:12px;color:var(--sub);display:block;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.spom-ar{font-size:15px;font-weight:600;opacity:.85;direction:rtl;}

/* per-item action: button / ring / done / delete */
.spom-act{flex:none;width:38px;height:38px;display:grid;place-items:center;}
.spom-dl{width:38px;height:38px;border-radius:11px;border:none;background:var(--accent);color:#fff;cursor:pointer;
  display:grid;place-items:center;transition:.15s;}
.spom-dl:active{transform:scale(.9);}
.spom-dl[disabled]{opacity:.4;cursor:default;}
.spom-done{width:38px;height:38px;border-radius:11px;background:rgba(16,185,129,.14);color:var(--green);
  display:grid;place-items:center;cursor:pointer;}
.spom-ring{transform:rotate(-90deg);}
.spom-ring circle{fill:none;stroke-width:3.5;}
.spom-ring .trk{stroke:var(--ring-track);}
.spom-ring .ind{stroke:var(--accent);stroke-linecap:round;transition:stroke-dashoffset .25s;}
.spom-pct{position:absolute;font-size:10px;font-weight:700;color:var(--accent);}
.spom-ringwrap{position:relative;display:grid;place-items:center;width:38px;height:38px;}

.spom-statebadge{font-size:11px;font-weight:700;padding:3px 8px;border-radius:7px;}
.spom-statebadge.q{background:var(--card2);color:var(--sub);}
.spom-statebadge.e{background:rgba(239,68,68,.14);color:var(--danger);}

/* progress label under download-all */
.spom-prog{height:6px;border-radius:3px;background:var(--ring-track);margin:8px 0 2px;overflow:hidden;}
.spom-prog>i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));width:0;transition:width .3s;}

/* sticky bottom action bar (pause/resume all) */
.spom-foot{position:absolute;left:0;right:0;bottom:0;padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(to top,var(--bg) 60%,transparent);display:flex;gap:10px;transform:translateY(120%);
  transition:transform .3s ease;}
.spom-foot.spom-show{transform:translateY(0);}
.spom-foot button{flex:1;border:none;border-radius:13px;padding:13px;font-size:14px;font-weight:700;cursor:pointer;}
.spom-foot .spom-pause{background:var(--card2);color:var(--text);}
.spom-foot .spom-cancel{background:rgba(239,68,68,.12);color:var(--danger);}

.spom-empty-state{text-align:center;color:var(--sub);font-size:13px;padding:30px 20px;}
.spom-toast{position:absolute;left:50%;bottom:90px;transform:translateX(-50%) translateY(20px);
  background:var(--text);color:var(--bg);font-size:12.5px;font-weight:600;padding:9px 16px;border-radius:11px;
  opacity:0;transition:.25s;pointer-events:none;white-space:nowrap;}
.spom-toast.spom-show{opacity:1;transform:translateX(-50%) translateY(0);}
@media (min-width:600px){.spom{height:86vh;margin-bottom:0;border-radius:22px;}.spom-backdrop{align-items:center;}}

/* ---- downloaded-recitation mini player ---- */
.spom-player{position:absolute;left:0;right:0;bottom:0;transform:translateY(120%);transition:transform .3s ease;
  background:var(--card);border-top:1px solid var(--line);padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  box-shadow:0 -4px 20px rgba(2,6,23,.18);z-index:5;}
.spom-player.spom-show{transform:translateY(0);}
.spom.has-player .spom-foot.spom-show{bottom:104px;}
.spom.has-player .spom-scroll{padding-bottom:130px;}
.spom-pl-top{display:flex;align-items:center;gap:10px;}
.spom-pl-play{width:42px;height:42px;border-radius:50%;border:none;flex:none;cursor:pointer;display:grid;place-items:center;
  color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));}
.spom-pl-btn{width:34px;height:34px;border:none;background:transparent;color:var(--text);cursor:pointer;display:grid;place-items:center;opacity:.8;}
.spom-pl-btn:active,.spom-pl-play:active{transform:scale(.92);}
.spom-pl-meta{flex:1;min-width:0;}
.spom-pl-meta b{display:block;font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.spom-pl-meta span{display:block;font-size:12px;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.spom-pl-x{width:30px;height:30px;border-radius:50%;border:none;background:var(--card2);color:var(--sub);font-size:14px;cursor:pointer;flex:none;}
.spom-pl-seekrow{display:flex;align-items:center;gap:8px;margin-top:8px;}
.spom-pl-seekrow span{font-size:11px;color:var(--sub);font-variant-numeric:tabular-nums;min-width:34px;text-align:center;}
.spom-seek{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:var(--ring-track);border-radius:3px;outline:none;}
.spom-seek::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;background:var(--accent);cursor:pointer;}
.spom-seek::-moz-range-thumb{width:15px;height:15px;border:none;border-radius:50%;background:var(--accent);cursor:pointer;}
