/* ════════════════════════════════════════════════════════════
   TILAWAH — "Ink & Lamplight"
   A monochrome dark theme. Pure-black room, white light as the
   only accent, and a luminous paper mushaf lit like lamplight.
   ════════════════════════════════════════════════════════════ */
:root{
  --bg0:#060606;
  --bg1:#0b0b0c;
  --bg2:#101012;
  --ink:#f4f3f0;
  --muted:#9b9b98;
  --dim:#626260;
  --faint:#3a3a39;
  --line:rgba(255,255,255,.11);
  --line-soft:rgba(255,255,255,.055);
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.07);
  --white:#ffffff;
  --silver-hi:#ffffff;
  --silver:#d7d7d4;
  --silver-lo:#8c8c8a;
  /* the luminous reading page */
  --paper:#f3f1ec;
  --paper-2:#e9e6dd;
  --paper-ink:#15130d;
  --paper-ink-mid:#403b30;
  --paper-faded:#b3ad9e;
  --danger:#e9e9e9;
  --r-lg:20px;
  --r-md:15px;
  --quran-size:2.35rem;
  --font-ui:'Outfit',system-ui,sans-serif;
  --font-display:'Fraunces',Georgia,serif;
  --font-q:'Amiri Quran','Noto Naskh Arabic',serif;
  --font-ar:'Noto Naskh Arabic',serif;
  --ease:cubic-bezier(.22,.8,.26,.99);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-ui);
  background:var(--bg0);
  color:var(--ink);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:rgba(255,255,255,.9);color:#000}
:focus-visible{outline:2px solid rgba(255,255,255,.6);outline-offset:3px;border-radius:8px}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:99px;border:3px solid var(--bg0)}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.28)}
main{max-width:1000px;margin:0 auto;padding:28px 22px 200px;position:relative;z-index:1}
button{font-family:inherit;cursor:pointer;color:inherit}
[hidden]{display:none!important}

/* ───────────── ambient darkroom ───────────── */
.bg{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg::before{ /* fine grain */
  content:"";position:absolute;inset:0;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
}
.bg::after{ /* vignette */
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 0%,transparent 40%,rgba(0,0,0,.55) 100%);
}
.aurora{position:absolute;border-radius:50%;filter:blur(80px);opacity:1}
.a1{ /* lamp from above */
  width:760px;height:520px;top:-280px;left:50%;transform:translateX(-50%);
  background:radial-gradient(closest-side,rgba(255,255,255,.10),transparent 70%);
  animation:breathe 14s ease-in-out infinite;
}
.a2{ /* concentric voice ripples, faint */
  width:900px;height:900px;top:-360px;left:50%;margin-left:-450px;filter:none;opacity:.5;
  background:
    repeating-radial-gradient(circle at 50% 0,transparent 0 58px,rgba(255,255,255,.035) 58px 59px);
  -webkit-mask-image:radial-gradient(60% 60% at 50% 0,#000 25%,transparent 70%);
  mask-image:radial-gradient(60% 60% at 50% 0,#000 25%,transparent 70%);
}
.a3{
  width:520px;height:420px;bottom:-240px;right:4%;
  background:radial-gradient(closest-side,rgba(255,255,255,.05),transparent 70%);
  animation:breathe 20s ease-in-out infinite alternate;
}
@keyframes breathe{0%,100%{opacity:.7}50%{opacity:1}}

/* ───────────── icons & text utilities ───────────── */
.ic{width:1.05em;height:1.05em;flex:none;display:inline-block;vertical-align:-.16em}
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.34em;text-transform:uppercase;color:var(--muted)}
.grad-gold{ /* repurposed: brushed silver */
  background:linear-gradient(100deg,#fff 8%,var(--silver) 42%,var(--silver-lo) 70%,#fff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;
}
.shimmer{animation:shimmer 3.4s linear infinite}
@keyframes shimmer{from{background-position:0 0}to{background-position:-200% 0}}

/* ───────────── glass recipe (dark) ───────────── */
.panel,.card,.picker-box,.summary-box,.surah-chip,.seg,.tool-btn,
.listen-chip,.resume-note,.sess,.trust-chip,.feat,.hero-continue button,.ghost-btn,.data-btn,.ayah-jump{
  border:1px solid var(--line);
  background:linear-gradient(168deg,var(--surface),rgba(255,255,255,.01));
}
.panel,.card{box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 24px 56px -34px rgba(0,0,0,.9)}

/* ───────────── BSI back link ───────────── */
.bsi-back{
  display:flex;align-items:center;gap:5px;color:var(--muted);text-decoration:none;
  font-size:.72rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  opacity:.55;transition:opacity .2s;white-space:nowrap;flex:none;
}
.bsi-back:hover{opacity:1}

/* ───────────── top bar ───────────── */
.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:18px;padding:13px 26px;
  background:linear-gradient(180deg,rgba(6,6,6,.94),rgba(6,6,6,.7));
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line-soft);
}
.brand{display:flex;align-items:center;gap:11px;font-weight:700;font-size:1.12rem;letter-spacing:.01em;cursor:pointer;user-select:none}
.brand-mark{
  display:grid;place-items:center;width:38px;height:38px;border-radius:11px;color:#0a0a0a;
  background:linear-gradient(150deg,#fff,#d2d2cf);
  box-shadow:0 4px 16px -4px rgba(255,255,255,.4),inset 0 1px 1px rgba(255,255,255,.9);
}
.brand-mark .ic{width:17px;height:17px}
.brand-ar{font-family:var(--font-ar);font-weight:600;color:var(--silver);font-size:.95rem;margin-inline-start:8px;opacity:.85}
.tabs{display:flex;gap:4px;margin-inline-start:auto;padding:4px;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--line-soft)}
.tab{
  display:flex;align-items:center;gap:8px;border:1px solid transparent;background:transparent;color:var(--muted);
  font-weight:600;font-size:.9rem;padding:8px 18px;border-radius:999px;transition:all .25s var(--ease);
}
.tab .ic{width:.95em;height:.95em}
.tab:hover{color:var(--ink)}
.tab.active{color:#fff;background:rgba(255,255,255,.1);border-color:var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.1)}
.donate-btn{
  display:flex;align-items:center;gap:8px;text-decoration:none;font-weight:700;font-size:.9rem;color:#0a0a0a;
  padding:10px 20px;border-radius:999px;
  background:linear-gradient(150deg,#fff,#dcdcd9);
  box-shadow:0 6px 22px -8px rgba(255,255,255,.45),inset 0 1px 1px rgba(255,255,255,.9);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.donate-btn:hover{transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(255,255,255,.6)}
.donate-btn:active{transform:translateY(0) scale(.98)}
.donate-btn .ic{width:.95em;height:.95em;animation:beat 1.9s infinite}
@keyframes beat{0%,100%{transform:scale(1)}10%{transform:scale(1.22)}20%{transform:scale(1)}}

/* ───────────── hero ───────────── */
.hero{position:relative;text-align:center;padding:78px 16px 26px}
.hero-bismillah{
  font-family:var(--font-q);font-size:2.1rem;margin:26px 0 30px;
  background:linear-gradient(100deg,#fff,var(--silver) 60%,var(--silver-lo));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 26px rgba(255,255,255,.18));
}
.hero h1{
  font-family:var(--font-display);font-weight:540;font-size:clamp(2.4rem,5.6vw,4.1rem);
  line-height:1.06;letter-spacing:-.022em;margin-bottom:22px;color:#fbfbfa;
}
.hero h1 em{font-style:italic;font-weight:600}
.hero-sub{color:var(--muted);max-width:580px;margin:0 auto 36px;font-size:1.06rem;line-height:1.7}
.hero-sub strong{color:var(--ink);font-weight:600}
.hero-cta-row{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.cta{
  position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:10px;
  border:0;font-weight:700;font-size:1.02rem;color:#0a0a0a;text-decoration:none;
  padding:16px 32px;border-radius:999px;
  background:linear-gradient(150deg,#fff,#dadad7);
  box-shadow:0 14px 38px -12px rgba(255,255,255,.4),inset 0 1px 1px rgba(255,255,255,.9);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.cta:hover{transform:translateY(-2px);box-shadow:0 20px 48px -12px rgba(255,255,255,.55)}
.cta:active{transform:translateY(0) scale(.98)}
.cta::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 32%,rgba(255,255,255,.6) 50%,transparent 68%);
  transform:translateX(-130%);
}
.cta:hover::after{animation:shine .9s var(--ease)}
@keyframes shine{to{transform:translateX(130%)}}
.ghost-cta{
  color:var(--ink);background:transparent;border:1px solid var(--line);
  box-shadow:none;
}
.ghost-cta:hover{background:var(--surface);box-shadow:0 12px 30px -18px rgba(0,0,0,.9)}
.ghost-cta::after{display:none}
.ghost-cta .ic{color:#fff}
.hero-continue{margin-top:18px;display:flex;justify-content:center}
.hero-continue button{
  display:inline-flex;align-items:center;gap:9px;color:var(--ink);
  padding:12px 24px;border-radius:999px;font-weight:600;font-size:.94rem;transition:.25s var(--ease);
}
.hero-continue button:hover{transform:translateY(-2px);background:var(--surface-2)}

/* jump-to-ayah search */
.ayah-jump{
  display:flex;align-items:center;gap:10px;max-width:540px;margin:0 auto;
  padding:7px 7px 7px 18px;border-radius:999px;position:relative;
  box-shadow:0 20px 50px -28px rgba(0,0,0,.9);transition:border-color .25s,box-shadow .25s;
}
.ayah-jump:focus-within{border-color:rgba(255,255,255,.35);box-shadow:0 0 0 3px rgba(255,255,255,.08)}
.jump-ic{width:17px;height:17px;color:var(--dim);flex:none}
.ayah-input{flex:1;min-width:0;border:0;background:transparent;color:var(--ink);font-family:inherit;font-size:1rem;outline:0;padding:8px 0}
.ayah-input::placeholder{color:var(--dim)}
.ayah-input::-webkit-search-cancel-button{-webkit-appearance:none}
.jump-go{
  flex:none;border:0;color:#0a0a0a;font-weight:700;font-size:.92rem;padding:12px 24px;border-radius:999px;
  background:linear-gradient(150deg,#fff,#dadad7);
  box-shadow:0 8px 22px -10px rgba(255,255,255,.45),inset 0 1px 1px rgba(255,255,255,.9);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease);
}
.jump-go:hover{transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(255,255,255,.6)}
.jump-go:active{transform:scale(.96)}
.jump-hint{color:var(--dim);font-size:.82rem;margin:13px auto 0;max-width:480px;line-height:1.5}
.jump-hint b{color:var(--muted);font-weight:600;font-variant-numeric:tabular-nums}

.trust-row{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:34px;flex-wrap:wrap}
.trust-chip{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:8px 16px;border-radius:999px}
.trust-dot{width:4px;height:4px;border-radius:50%;background:var(--silver);opacity:.6}
.ornament{display:flex;align-items:center;gap:18px;max-width:420px;margin:44px auto 0;color:var(--silver)}
.ornament .ic{width:13px;height:13px;filter:drop-shadow(0 0 8px rgba(255,255,255,.45))}
.ornament span{flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28))}
.ornament span:last-child{background:linear-gradient(90deg,rgba(255,255,255,.28),transparent)}
.hero-feats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;max-width:880px;margin:40px auto 0}
.feat{border-radius:var(--r-lg);padding:24px 18px 22px;display:flex;flex-direction:column;gap:7px;align-items:center;transition:transform .3s var(--ease),border-color .3s}
.feat:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2)}
.feat-ic{
  display:grid;place-items:center;width:46px;height:46px;border-radius:14px;margin-bottom:8px;font-size:1.15rem;color:#fff;
  background:rgba(255,255,255,.05);border:1px solid var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.feat-ic.em,.feat-ic.gold{color:#fff}
.feat b{font-size:.98rem;color:var(--ink)}
.feat small{color:var(--muted);line-height:1.5;font-size:.82rem}

/* hero entrance */
.r1,.r2,.r3,.r4,.r5,.r6,.r7{animation:rise .8s var(--ease) both}
.r2{animation-delay:.08s}.r3{animation-delay:.16s}.r4{animation-delay:.24s}
.r5{animation-delay:.32s}.r6{animation-delay:.42s}.r7{animation-delay:.52s}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.view{animation:fadeUp .5s var(--ease) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ───────────── landing / FAQ / footer ───────────── */
.seo-block{max-width:780px;margin:56px auto 0;text-align:center}
.seo-block .ornament{margin-bottom:40px}
.seo-title{font-family:var(--font-display);font-weight:540;font-size:clamp(1.4rem,2.8vw,1.95rem);letter-spacing:-.01em;line-height:1.25;margin-bottom:18px;color:#fbfbfa}
.seo-copy{color:var(--muted);font-size:.98rem;line-height:1.75;margin-bottom:44px}
.seo-copy strong{color:var(--ink);font-weight:600}
.faq{text-align:start}
.faq-title{font-family:var(--font-display);font-weight:540;font-size:1.3rem;letter-spacing:-.01em;text-align:center;margin-bottom:18px;color:#fbfbfa}
.faq details{border-bottom:1px solid var(--line-soft);padding:0 4px}
.faq details[open]{background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}
.faq summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 0;font-weight:600;font-size:.97rem;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:#fff;font-weight:400;font-size:1.4rem;line-height:1;flex:none;transition:transform .3s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);line-height:1.7;padding:0 0 19px;font-size:.92rem}
.site-footer{margin-top:52px;padding-top:30px;border-top:1px solid var(--line-soft);display:flex;flex-direction:column;gap:9px;align-items:center}
.footer-brand{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.86rem;font-weight:600}
.footer-brand .ic{width:11px;height:11px;color:var(--silver)}
.footer-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;color:var(--dim);font-size:.8rem}
.footer-links a{color:var(--ink);text-decoration:none;font-weight:600;border-bottom:1px solid rgba(255,255,255,.25)}
.footer-links a:hover{border-color:#fff}
.footer-copy{color:var(--dim);font-size:.74rem}

/* ───────────── reader toolbar ───────────── */
.reader-bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.surah-chip{display:flex;align-items:center;gap:13px;border-radius:var(--r-md);padding:9px 17px;transition:transform .25s var(--ease),border-color .25s}
.surah-chip:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.22)}
.chip-num{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;color:#0a0a0a;font-weight:800;font-size:.92rem;background:linear-gradient(150deg,#fff,#cfcfcc)}
.chip-names{display:flex;flex-direction:column;align-items:flex-start;line-height:1.18}
.chip-names b{font-family:var(--font-ar);font-size:1.14rem;color:var(--ink)}
.chip-names small{color:var(--muted);font-size:.76rem;letter-spacing:.04em}
.chip-caret{color:var(--dim);margin-inline-start:6px;font-size:.8rem}
.bar-tools{display:flex;gap:8px;margin-inline-start:auto;flex-wrap:wrap}
.seg{display:flex;border-radius:13px;padding:3px;gap:2px}
.seg-btn{display:flex;align-items:center;gap:7px;border:1px solid transparent;background:transparent;color:var(--muted);font-weight:600;font-size:.84rem;padding:8px 14px;border-radius:10px;transition:all .25s var(--ease)}
.seg-btn .ic{width:.92em;height:.92em}
.seg-btn:hover{color:var(--ink)}
.seg-btn.active{color:#fff;background:rgba(255,255,255,.1);border-color:var(--line)}
.tool-btn{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;color:var(--muted);font-size:.92rem;font-weight:700;transition:all .25s var(--ease)}
.tool-btn:hover{color:var(--ink);transform:translateY(-1px);border-color:rgba(255,255,255,.22)}
.tool-btn.on{color:#0a0a0a;background:#fff;border-color:#fff;box-shadow:0 0 18px -4px rgba(255,255,255,.5)}
.resume-note{color:var(--silver);padding:11px 18px;border-radius:var(--r-md);font-size:.88rem;margin-bottom:16px;border-color:var(--line)}

/* ───────────── mushaf — white Quran text on premium black ───────────── */
.mushaf{
  position:relative;border-radius:18px;
  padding:48px 40px;line-height:2.55;
  font-family:var(--font-q);font-size:var(--quran-size);
  text-align:justify;text-align-last:right;
  color:#f6f6f4;
  background:
    radial-gradient(78% 38% at 50% 0,rgba(255,255,255,.055),transparent 70%),
    radial-gradient(135% 95% at 50% 0%,#161618,#0c0c0d 55%,#070708 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.05),
    0 0 90px -34px rgba(255,255,255,.12),
    0 40px 90px -40px rgba(0,0,0,.95);
  transition:box-shadow .6s var(--ease);
}
.mushaf::before{ /* hairline frame */
  content:"";position:absolute;inset:14px;border-radius:12px;pointer-events:none;
  border:1px solid rgba(255,255,255,.10);
  box-shadow:inset 0 0 50px rgba(0,0,0,.5);
}
.ayah{display:inline}
.w{
  display:inline-block;padding:0 .14em;border-radius:8px;color:#6c6c6a;
  transition:color .3s,background .3s,box-shadow .3s,text-shadow .3s,filter .35s;cursor:default;
}
.mushaf.tap-mode .w.current{cursor:pointer}
.w.read{color:#f6f6f4}
.w.skipped{color:#9c9c9a}
.w.current{ /* lit by white lamplight */
  color:#fff;font-weight:inherit;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.03));
  box-shadow:0 0 0 1px rgba(255,255,255,.3),0 0 38px -6px rgba(255,255,255,.4);
  text-shadow:0 0 26px rgba(255,255,255,.8);
}
.mushaf.memorize .w:not(.read):not(.skipped):not(.current){filter:blur(7px);opacity:.5}
.marker{
  display:inline-grid;place-items:center;font-family:var(--font-ar);
  color:#fff;font-size:.44em;font-weight:600;
  width:2.3em;height:2.3em;margin:0 .2em;vertical-align:middle;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg fill='none' stroke='%23ffffff'%3E%3Ccircle cx='24' cy='24' r='14.5' stroke-opacity='.7' stroke-width='1.1'/%3E%3Crect x='14.6' y='14.6' width='18.8' height='18.8' rx='1' stroke-opacity='.3'/%3E%3Crect x='14.6' y='14.6' width='18.8' height='18.8' rx='1' transform='rotate(45 24 24)' stroke-opacity='.3'/%3E%3C/g%3E%3C/svg%3E");
  background-size:contain;background-repeat:no-repeat;background-position:center;
  filter:drop-shadow(0 0 8px rgba(255,255,255,.2));
}
.w.flash{animation:wflash 1.2s var(--ease)}
@keyframes wflash{
  0%,100%{box-shadow:0 0 0 1px rgba(255,255,255,.3),0 0 38px -6px rgba(255,255,255,.4)}
  35%{box-shadow:0 0 0 2px rgba(255,255,255,.65),0 0 48px -4px rgba(255,255,255,.65)}
}
.float-h{
  position:fixed;z-index:80;pointer-events:none;font-weight:800;font-size:1.02rem;letter-spacing:.02em;
  color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.75),0 0 18px rgba(255,255,255,.45);
  animation:floatUp 1.1s ease-out forwards;
}
@keyframes floatUp{0%{opacity:0;transform:translateY(8px) scale(.85)}18%{opacity:1;transform:translateY(0) scale(1)}100%{opacity:0;transform:translateY(-48px) scale(1)}}

/* ───────────── floating dock ───────────── */
.control-bar{
  position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:40;
  width:min(920px,calc(100vw - 28px));
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;
  padding:14px 26px;border-radius:26px;border:1px solid var(--line);
  background:linear-gradient(168deg,rgba(18,18,20,.9),rgba(8,8,9,.94));
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 30px 70px -20px rgba(0,0,0,.95);
}
.cb-stats{display:flex;gap:26px}
.cb-stats.is-hidden{visibility:hidden}
.cb-stat{display:flex;flex-direction:column;line-height:1.12;gap:2px}
.cb-val{font-weight:800;font-size:1.4rem;font-variant-numeric:tabular-nums;letter-spacing:-.01em;color:#fff;transition:transform .16s var(--ease)}
.cb-val.pop{transform:scale(1.16)}
.cb-stat.gold .cb-val{
  background:linear-gradient(110deg,#fff,var(--silver) 55%,var(--silver-lo));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cb-label{display:flex;align-items:center;gap:5px;color:var(--dim);font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.cb-label .ic{width:9px;height:9px;color:var(--silver)}
.cb-center{display:flex;align-items:center;gap:18px;justify-content:center}
.mic-btn{
  position:relative;width:84px;height:84px;border-radius:50%;border:1px solid rgba(255,255,255,.22);color:#fff;
  background:radial-gradient(120% 100% at 32% 20%,rgba(255,255,255,.16),transparent 50%),#131315;
  box-shadow:0 16px 40px -12px rgba(0,0,0,.9),inset 0 1px 1px rgba(255,255,255,.12);
  display:grid;place-items:center;transition:transform .2s var(--ease),background .3s,box-shadow .3s,color .3s,border-color .3s;
}
.mic-btn:hover{transform:scale(1.05)}
.mic-btn:active{transform:scale(.95)}
.mic-icon{display:grid;place-items:center}
.mic-icon .ic{width:30px;height:30px}
.ic-pause{display:none}
.mic-btn.listening{ /* inverts to solid white light */
  background:#fff;color:#0a0a0a;border-color:#fff;
  box-shadow:0 0 50px -6px rgba(255,255,255,.6),inset 0 1px 2px rgba(255,255,255,.9);
}
.mic-btn.listening .ic-mic{display:none}
.mic-btn.listening .ic-pause{display:block}
.mic-rings{position:absolute;inset:-7px;border-radius:50%;pointer-events:none}
.mic-btn.listening .mic-rings::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(transparent 0 78%,rgba(255,255,255,.95) 92%,transparent 100%);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 2px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 3px),#000 calc(100% - 2px));
  animation:orbit 1.4s linear infinite;
}
.mic-btn.listening .mic-rings::after{
  content:"";position:absolute;inset:0;border-radius:50%;border:2px solid rgba(255,255,255,.55);
  animation:pulse 2s var(--ease) infinite;
}
@keyframes orbit{to{transform:rotate(360deg)}}
@keyframes pulse{0%{transform:scale(1);opacity:.85}100%{transform:scale(1.65);opacity:0}}
.back-btn,.end-btn{
  display:flex;align-items:center;justify-content:center;gap:8px;
  border:1px solid var(--line);background:rgba(255,255,255,.04);border-radius:15px;font-weight:700;color:var(--muted);
  transition:all .25s var(--ease);
}
.back-btn{width:48px;height:48px;font-size:1rem}
.back-btn:hover{color:#fff;background:var(--surface-2);transform:translateY(-1px)}
.end-btn{padding:14px 19px;font-size:.88rem;color:var(--ink);border-color:var(--line)}
.end-btn .ic{width:.85em;height:.85em}
.end-btn:hover{background:var(--surface-2);transform:translateY(-1px)}
.cb-status{display:flex;align-items:center;gap:12px;justify-content:flex-end}
.dock-donate{
  display:grid;place-items:center;width:46px;height:46px;border-radius:14px;flex:none;color:#fff;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.3);
  transition:transform .25s var(--ease),background .25s,color .25s;
}
.dock-donate .ic{width:18px;height:18px;animation:beat 1.9s infinite}
.dock-donate:hover{transform:translateY(-2px);background:#fff;color:#0a0a0a}
.dock-donate:active{transform:scale(.95)}
.listen-chip{display:flex;align-items:center;gap:11px;color:var(--muted);font-size:.83rem;border-radius:999px;padding:10px 17px;max-width:290px;transition:color .3s,border-color .3s}
.listen-chip.live{color:#fff;border-color:rgba(255,255,255,.35);box-shadow:0 0 24px -8px rgba(255,255,255,.35)}
.eq{display:none;align-items:flex-end;gap:2.5px;height:15px}
.listen-chip.live .eq{display:flex}
.eq i{width:3px;background:linear-gradient(180deg,#fff,#888);border-radius:2px;animation:eq 1.1s infinite ease-in-out}
.eq i:nth-child(1){animation-delay:0s}.eq i:nth-child(2){animation-delay:.22s}
.eq i:nth-child(3){animation-delay:.44s}.eq i:nth-child(4){animation-delay:.66s}
@keyframes eq{0%,100%{height:5px}50%{height:15px}}

/* ───────────── dashboard ───────────── */
.dash-head{margin:10px 0 26px}
.dash-title{font-family:var(--font-display);font-weight:540;font-size:clamp(1.7rem,3.4vw,2.3rem);letter-spacing:-.015em;margin-top:8px;color:#fbfbfa}
.dash-ar{font-family:var(--font-ar);color:var(--silver);font-size:1.25rem;margin-inline-start:10px;font-weight:600}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-bottom:18px}
.card{border-radius:var(--r-lg);padding:24px 22px;transition:transform .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.2)}
.hero-card{
  background:linear-gradient(168deg,rgba(255,255,255,.09),rgba(255,255,255,.015));
  border-color:rgba(255,255,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.1),0 24px 56px -32px rgba(0,0,0,.9),0 0 50px -22px rgba(255,255,255,.18);
}
.card-ic{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;margin-bottom:14px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:#fff}
.card-ic.gold,.card-ic.em,.card-ic.flame{color:#fff}
.card-val{font-size:2.1rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1.08;letter-spacing:-.02em;color:#fff}
.hero-card .card-val{font-size:2.5rem}
.card-label{color:var(--muted);font-size:.8rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-top:7px}
.card-sub{color:var(--dim);font-size:.78rem;margin-top:9px}
.panel{border-radius:var(--r-lg);padding:26px;margin-bottom:18px}
.panel-head{display:flex;align-items:baseline;gap:13px;margin-bottom:20px}
.panel-head h3{font-family:var(--font-display);font-weight:540;font-size:1.18rem;letter-spacing:-.01em;color:#fbfbfa}
.panel-sub{color:var(--dim);font-size:.8rem}
.chart{display:flex;align-items:flex-end;gap:10px;height:158px}
.chart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:9px;height:100%;justify-content:flex-end}
.chart .bar{width:100%;max-width:56px;border-radius:8px 8px 4px 4px;min-height:4px;background:linear-gradient(180deg,#fff,rgba(255,255,255,.18));box-shadow:0 0 22px -6px rgba(255,255,255,.3),inset 0 1px 0 rgba(255,255,255,.4);transition:height .7s var(--ease),filter .25s}
.chart .bar:hover{filter:brightness(1.15)}
.chart .bar.zero{background:rgba(255,255,255,.06);box-shadow:none}
.chart .lbl{color:var(--dim);font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.chart .col:last-child .lbl{color:#fff}
.chart .num{color:var(--muted);font-size:.72rem;font-variant-numeric:tabular-nums}
.progress-track{height:13px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden;margin-bottom:20px;box-shadow:inset 0 1px 3px rgba(0,0,0,.5)}
.progress-fill{height:100%;width:0%;border-radius:99px;background:linear-gradient(90deg,#777,#fff);box-shadow:0 0 22px rgba(255,255,255,.4);transition:width .9s var(--ease)}
.surah-progress{display:flex;flex-direction:column;gap:12px}
.sp-row{display:flex;align-items:center;gap:14px;font-size:.9rem}
.sp-name{min-width:160px;display:flex;gap:9px;align-items:baseline}
.sp-name b{font-family:var(--font-ar);font-size:1.02rem;color:var(--ink)}
.sp-name small{color:var(--dim);font-size:.76rem}
.sp-track{flex:1;height:7px;border-radius:99px;background:rgba(255,255,255,.06);overflow:hidden}
.sp-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,#888,#e6e6e6)}
.sp-fill.done{background:linear-gradient(90deg,#d0d0cd,#fff)}
.sp-pct{color:var(--muted);font-size:.77rem;min-width:52px;text-align:right;font-variant-numeric:tabular-nums}
.sessions{display:flex;flex-direction:column;gap:9px}
.sess{display:flex;align-items:center;gap:15px;padding:14px 17px;border-radius:15px;font-size:.9rem;transition:transform .25s var(--ease)}
.sess:hover{transform:translateX(3px)}
.sess-ic{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;flex:none;color:#fff;background:rgba(255,255,255,.05);border:1px solid var(--line)}
.sess-ic .ic{width:16px;height:16px}
.sess-main{display:flex;flex-direction:column;line-height:1.3}
.sess-main b{font-size:.94rem;color:var(--ink)}
.sess-main small{color:var(--dim);font-size:.75rem}
.sess-stats{margin-inline-start:auto;display:flex;gap:18px;color:var(--muted);font-size:.82rem;font-variant-numeric:tabular-nums;align-items:center}
.sess-stats .gold{font-weight:700;color:#fff}
.empty{color:var(--dim);font-size:.92rem;text-align:center;padding:16px}
.data-copy{color:var(--muted);font-size:.92rem;line-height:1.7;margin-bottom:20px;max-width:660px}
.data-badge{display:inline-flex;align-items:center;gap:6px;margin-inline-end:8px;color:#fff;font-weight:600;font-size:.8rem;padding:4px 11px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.25);vertical-align:middle}
.data-badge .ic{width:12px;height:12px}
.data-actions{display:flex;gap:10px;flex-wrap:wrap}
.data-btn{display:inline-flex;align-items:center;gap:9px;border-radius:13px;padding:11px 18px;font-weight:600;font-size:.9rem;color:var(--ink);transition:transform .2s var(--ease),border-color .2s,background .2s}
.data-btn .ic{width:1.02em;height:1.02em;color:#fff}
.data-btn:hover{transform:translateY(-2px);border-color:rgba(255,255,255,.28);background:var(--surface-2)}
.data-btn:active{transform:scale(.98)}
.data-btn.danger{color:var(--muted)}
.data-btn.danger .ic{color:var(--muted)}
.data-btn.danger:hover{color:#fff;border-color:rgba(255,255,255,.4)}
.donate-panel{display:flex;align-items:center;gap:26px;flex-wrap:wrap;background:linear-gradient(168deg,rgba(255,255,255,.07),rgba(255,255,255,.015));border-color:rgba(255,255,255,.2)}
.donate-copy h3{font-family:var(--font-display);font-weight:540;font-size:1.25rem;margin-bottom:9px;letter-spacing:-.01em;color:#fbfbfa}
.donate-copy p{color:var(--muted);font-size:.93rem;line-height:1.6;max-width:520px}
.donate-panel .cta{margin-inline-start:auto;white-space:nowrap}

/* ───────────── overlays ───────────── */
.overlay{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:20px;background:rgba(2,2,2,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);animation:fadeIn .22s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.picker-box{width:min(580px,100%);max-height:84vh;display:flex;flex-direction:column;border-radius:24px;padding:24px;background:linear-gradient(168deg,#131315,#0a0a0b);box-shadow:0 40px 100px -20px rgba(0,0,0,.9);animation:popIn .32s var(--ease)}
.picker-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.picker-head h3{font-family:var(--font-display);font-weight:540;font-size:1.25rem;letter-spacing:-.01em;color:#fbfbfa}
.x-btn{display:grid;place-items:center;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);width:36px;height:36px;border-radius:11px;transition:all .2s}
.x-btn .ic{width:13px;height:13px}
.x-btn:hover{color:#fff;background:var(--surface-2)}
.search-wrap{position:relative;margin-bottom:14px}
.search-wrap .ic{position:absolute;left:17px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--dim);pointer-events:none}
.picker-search{width:100%;padding:14px 18px 14px 44px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--ink);font-family:inherit;font-size:.95rem;outline:0;transition:border-color .25s,box-shadow .25s}
.picker-search::placeholder{color:var(--dim)}
.picker-search:focus{border-color:rgba(255,255,255,.4);box-shadow:0 0 0 3px rgba(255,255,255,.08)}
.picker-list{overflow-y:auto;display:flex;flex-direction:column;gap:5px;scrollbar-width:thin;padding-right:4px}
.s-row{display:flex;align-items:center;gap:15px;padding:12px 14px;border-radius:14px;border:1px solid transparent;background:transparent;color:var(--ink);text-align:start;width:100%;transition:all .18s var(--ease)}
.s-row:hover{background:rgba(255,255,255,.05);border-color:var(--line);transform:translateX(3px)}
.s-num{display:grid;place-items:center;min-width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--muted);font-weight:700;font-size:.84rem}
.s-row:hover .s-num{color:#fff;border-color:rgba(255,255,255,.3)}
.s-names{display:flex;flex-direction:column;line-height:1.25}
.s-names b{font-family:var(--font-ar);font-size:1.16rem;color:var(--ink)}
.s-names small{color:var(--dim);font-size:.76rem}
.s-meta{margin-inline-start:auto;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.s-meta small{color:var(--dim);font-size:.72rem;letter-spacing:.03em}
.s-pct{color:#fff;font-size:.74rem;font-weight:700}
.s-pct.done{color:var(--silver)}
.summary-box{position:relative;width:min(460px,100%);text-align:center;overflow:hidden;border-radius:26px;padding:42px 32px 34px;background:linear-gradient(168deg,#15151700,#0a0a0b),radial-gradient(120% 80% at 50% 0,#1a1a1c,#0a0a0b 70%);border:1px solid rgba(255,255,255,.18);box-shadow:0 40px 110px -20px rgba(0,0,0,.9),0 0 80px -34px rgba(255,255,255,.2);animation:popIn .35s var(--ease)}
@keyframes popIn{from{transform:scale(.88) translateY(12px);opacity:0}to{transform:none;opacity:1}}
.summary-glow{position:absolute;top:-90px;left:50%;transform:translateX(-50%);width:340px;height:230px;border-radius:50%;pointer-events:none;background:radial-gradient(closest-side,rgba(255,255,255,.16),transparent)}
.sum-rosette{
  position:relative;display:grid;place-items:center;width:58px;height:58px;margin:0 auto 14px;color:#fff;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cg fill='none' stroke='%23ffffff'%3E%3Ccircle cx='24' cy='24' r='15' stroke-opacity='.85' stroke-width='1.1'/%3E%3Crect x='14.4' y='14.4' width='19.2' height='19.2' rx='1' stroke-opacity='.45'/%3E%3Crect x='14.4' y='14.4' width='19.2' height='19.2' rx='1' transform='rotate(45 24 24)' stroke-opacity='.45'/%3E%3C/g%3E%3C/svg%3E");
  background-size:contain;background-repeat:no-repeat;background-position:center;
  filter:drop-shadow(0 0 16px rgba(255,255,255,.35));
}
.sum-rosette .ic{width:16px;height:16px}
.summary-ma{font-family:var(--font-q);font-size:1.45rem;color:var(--silver);margin-bottom:8px}
.summary-box h3{font-family:var(--font-display);font-weight:540;font-size:1.35rem;letter-spacing:-.01em;margin-bottom:20px;color:#fbfbfa}
.sum-hasanat{display:flex;flex-direction:column;margin-bottom:24px;gap:3px}
.sum-hasanat span{font-size:3.4rem;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1.05}
.sum-hasanat small{color:var(--muted);font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}
.sum-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:22px}
.sum-grid div{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:14px;padding:13px 6px;display:flex;flex-direction:column;gap:3px}
.sum-grid b{font-size:1.08rem;font-variant-numeric:tabular-nums;color:#fff}
.sum-grid small{color:var(--dim);font-size:.68rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.sum-dua{color:var(--muted);font-size:.9rem;margin-bottom:26px;line-height:1.55}
.sum-actions{display:flex;flex-direction:column;gap:10px}
.sum-actions .cta{justify-content:center}
.ghost-btn{display:flex;align-items:center;justify-content:center;gap:9px;color:var(--ink);padding:13px;border-radius:999px;font-weight:600;font-size:.94rem;text-decoration:none;transition:all .25s var(--ease)}
.ghost-btn:hover{transform:translateY(-1px);background:var(--surface-2)}
.gold-link{color:#fff}
.gold-link .ic{width:.9em;height:.9em}
.toast{position:fixed;bottom:128px;left:50%;transform:translateX(-50%);z-index:200;border:1px solid var(--line);background:linear-gradient(168deg,#1a1a1c,#0c0c0d);color:var(--ink);padding:14px 24px;border-radius:15px;font-size:.92rem;max-width:90vw;text-align:center;box-shadow:0 18px 50px -10px rgba(0,0,0,.9);animation:toastIn .3s var(--ease)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}
.toast.err{border-color:rgba(255,255,255,.3);color:#fff}

/* ───────────── premium polish ───────────── */
/* the lamp you carry — a soft spotlight follows the pointer through the dark */
.spotlight{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(520px 520px at var(--mx,50%) var(--my,15%),rgba(255,255,255,.06),transparent 62%);
}
/* slow-drifting dust motes for depth */
.motes{position:absolute;inset:0;overflow:hidden}
.motes i{position:absolute;bottom:-12px;width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.55);filter:blur(.4px);opacity:0;animation:mote 18s linear infinite}
.motes i:nth-child(1){left:10%;animation-delay:0s;animation-duration:19s}
.motes i:nth-child(2){left:27%;animation-delay:5s;animation-duration:23s}
.motes i:nth-child(3){left:44%;animation-delay:9s;animation-duration:16s}
.motes i:nth-child(4){left:61%;animation-delay:3s;animation-duration:21s}
.motes i:nth-child(5){left:78%;animation-delay:12s;animation-duration:25s}
.motes i:nth-child(6){left:91%;animation-delay:7s;animation-duration:18s}
@keyframes mote{0%{transform:translateY(0) scale(.6);opacity:0}12%{opacity:.5}86%{opacity:.32}100%{transform:translateY(-100vh) scale(1);opacity:0}}

/* typographic refinement */
body{text-rendering:optimizeLegibility;font-feature-settings:"kern" 1,"liga" 1}
h1,.hero h1,.seo-title,.dash-title,.faq-title,.panel-head h3,.summary-box h3,.picker-head h3,.donate-copy h3{text-wrap:balance}
.hero-sub,.seo-copy,.data-copy,.donate-copy p,.faq details p,.jump-hint{text-wrap:pretty}
.cb-val,.card-val,.sum-hasanat span,.sum-grid b,.sp-pct,.chart .num,#hud-time{font-feature-settings:"tnum" 1,"lnum" 1}

/* logo glint — a periodic specular sweep */
.brand-mark{position:relative;overflow:hidden}
.brand-mark::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.75) 50%,transparent 58%);
  transform:translateX(-140%);animation:brandSheen 7s ease-in-out infinite;
}
@keyframes brandSheen{0%,72%{transform:translateX(-140%)}88%,100%{transform:translateX(140%)}}

/* while you recite, the page & dock breathe with light */
body.is-listening .mushaf{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 0 130px -30px rgba(255,255,255,.24),
    0 40px 90px -40px rgba(0,0,0,.95);
}
body.is-listening .control-bar{
  box-shadow:inset 0 1px 0 rgba(255,255,255,.09),0 30px 70px -20px rgba(0,0,0,.95),0 0 64px -26px rgba(255,255,255,.28);
}

/* graceful scroll-reveal for the landing sections */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* dashboard — staggered entrance, replayed on every open */
#view-dash.enter .cards .card{animation:revealUp .5s var(--ease) both}
#view-dash.enter .cards .card:nth-child(2){animation-delay:.05s}
#view-dash.enter .cards .card:nth-child(3){animation-delay:.1s}
#view-dash.enter .cards .card:nth-child(4){animation-delay:.15s}
#view-dash.enter .panel{animation:revealUp .55s var(--ease) both;animation-delay:.16s}
@keyframes revealUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  .motes,.spotlight,.brand-mark::after{display:none}
}

/* ───────────── tools view ───────────── */
.tab-home{padding:9px 12px}
.tool-nav{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px;background:rgba(255,255,255,.03);border:1px solid var(--line-soft);border-radius:16px;padding:5px}
.tool-tab{display:flex;align-items:center;gap:8px;border:1px solid transparent;background:transparent;color:var(--muted);font-weight:600;font-size:.9rem;padding:11px 18px;border-radius:12px;transition:all .2s var(--ease);flex:1;justify-content:center}
.tool-tab .ic{width:1em;height:1em}
.tool-tab:hover{color:var(--ink)}
.tool-tab.active{color:#fff;background:rgba(255,255,255,.08);border-color:var(--line);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.tool-pane{animation:fadeUp .4s var(--ease) both}
.tool-note{color:var(--dim);font-size:.82rem;line-height:1.6;margin-top:4px;padding:0 4px}
.cfg{display:flex;flex-direction:column;gap:7px}
.cfg label{color:var(--muted);font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}

/* prayer times */
.prayer-loc{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:16px}
.loc-label{color:var(--dim);font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.loc-value{font-family:var(--font-display);font-size:1.35rem;font-weight:540;margin-top:3px}
.loc-hijri{color:var(--silver);font-size:.85rem;margin-top:4px}
.loc-actions{display:flex;gap:9px;flex-wrap:wrap}
.prayer-city-form{display:flex;gap:10px;margin-bottom:16px}
.prayer-city-form .search-wrap{flex:1;margin-bottom:0}
.prayer-config{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.prayer-next{display:flex;align-items:center;justify-content:space-between;gap:16px;background:linear-gradient(168deg,rgba(255,255,255,.08),rgba(255,255,255,.015));border-color:rgba(255,255,255,.2)}
.pn-label{color:var(--dim);font-size:.74rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.pn-name{font-family:var(--font-display);font-size:1.7rem;font-weight:560;margin-top:4px}
.pn-count{font-size:2rem;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;letter-spacing:-.01em}
.prayer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:11px;margin-bottom:8px}
.pr-cell{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-radius:15px;border:1px solid var(--line);background:var(--surface);transition:border-color .25s,transform .25s}
.pr-cell:hover{transform:translateY(-2px)}
.pr-cell.now{border-color:rgba(255,255,255,.4);background:linear-gradient(168deg,rgba(255,255,255,.1),rgba(255,255,255,.02));box-shadow:0 0 40px -18px rgba(255,255,255,.4)}
.pr-cell.passed{opacity:.5}
.pr-name{display:flex;flex-direction:column;gap:2px}
.pr-name b{font-size:1rem;font-weight:600}
.pr-name small{color:var(--dim);font-size:.72rem}
.pr-time{font-size:1.25rem;font-weight:700;font-variant-numeric:tabular-nums;color:#fff}
.pr-cell.sunrise .pr-time{color:var(--silver)}

/* qibla compass */
.qibla-panel{display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center}
.compass{position:relative;width:240px;height:240px;flex:none}
.compass-face{position:absolute;inset:0;border-radius:50%;border:1px solid var(--line);background:radial-gradient(circle at 50% 40%,#161618,#0a0a0b);box-shadow:inset 0 0 50px rgba(0,0,0,.6),0 20px 50px -24px rgba(0,0,0,.9)}
.compass-ticks{position:absolute;inset:10px;border-radius:50%;background:
  repeating-conic-gradient(from 0deg, rgba(255,255,255,.18) 0 1deg, transparent 1deg 30deg);
  -webkit-mask:radial-gradient(farthest-side,transparent calc(100% - 12px),#000 calc(100% - 11px));
  mask:radial-gradient(farthest-side,transparent calc(100% - 12px),#000 calc(100% - 11px))}
.cm{position:absolute;color:var(--muted);font-weight:700;font-size:.85rem;left:50%;top:50%;transform:translate(-50%,-50%)}
.cm-n{top:16px;color:#fff}.cm-s{top:auto;bottom:16px;transform:translate(-50%,0)}
.cm-e{left:auto;right:16px;top:50%;transform:translate(0,-50%)}.cm-w{left:16px;top:50%;transform:translate(0,-50%)}
.compass-needle{position:absolute;inset:0;display:grid;place-items:center;transition:transform .35s var(--ease)}
.needle-line{position:absolute;top:24px;left:50%;width:2px;height:calc(50% - 24px);transform:translateX(-50%);transform-origin:bottom;background:linear-gradient(180deg,#fff,rgba(255,255,255,.1))}
.needle-kaaba{position:absolute;top:6px;left:50%;transform:translateX(-50%);display:grid;place-items:center;width:38px;height:38px;border-radius:11px;color:#0a0a0a;background:linear-gradient(150deg,#fff,#cfcfcc);box-shadow:0 6px 18px -6px rgba(255,255,255,.5)}
.needle-kaaba .ic{width:20px;height:20px}
.qibla-info{text-align:center;min-width:200px}
.qi-deg{font-size:3.2rem;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;letter-spacing:-.02em;line-height:1}
.qi-label{color:var(--muted);font-size:.86rem;margin-top:6px}
.qi-dist{color:var(--silver);font-size:.95rem;margin-top:10px;font-weight:600}
.qibla-actions{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin:16px 0}

/* zakat */
.zakat-top{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.zakat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.zk{display:flex;flex-direction:column;gap:7px}
.zk label{color:var(--muted);font-size:.82rem;font-weight:500}
.zk input{padding:12px 14px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--ink);font-family:inherit;font-size:1rem;outline:0;font-variant-numeric:tabular-nums;transition:border-color .2s}
.zk input:focus{border-color:rgba(255,255,255,.35)}
.zakat-result{display:flex;flex-direction:column;gap:2px}
.zr-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 2px;font-size:.96rem;border-bottom:1px solid var(--line-soft)}
.zr-row span:first-child{color:var(--muted)}
.zr-row b{font-variant-numeric:tabular-nums;font-weight:600}
.zr-row.total b{color:#fff}
.zr-verdict{margin-top:16px;padding:16px 18px;border-radius:15px;font-weight:600;text-align:center;line-height:1.5}
.zr-verdict.due{background:linear-gradient(168deg,rgba(255,255,255,.1),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.3);color:#fff}
.zr-verdict.notdue{background:var(--surface);border:1px solid var(--line);color:var(--muted)}
.zr-payable{font-size:2.4rem;font-weight:800;font-variant-numeric:tabular-nums;color:#fff;display:block;margin-top:6px;letter-spacing:-.01em}

/* dhikr */
.dhikr-panel{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}
.dhikr-chips{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.dhikr-chip{border:1px solid var(--line);background:var(--surface);color:var(--muted);font-weight:600;font-size:.82rem;padding:8px 14px;border-radius:999px;transition:all .2s var(--ease)}
.dhikr-chip:hover{color:var(--ink)}
.dhikr-chip.active{color:#0a0a0a;background:linear-gradient(150deg,#fff,#d2d2cf);border-color:#fff}
.dhikr-chip.ar{font-family:var(--font-ar);font-size:1.05rem;font-weight:600;padding:7px 16px}
.dhikr-ar{font-family:var(--font-q);font-size:2.3rem;color:#fff;line-height:1.6;margin-top:6px}
.dhikr-translit{color:var(--silver);font-size:1.02rem;font-weight:600;letter-spacing:.01em}
.dhikr-mean{color:var(--muted);font-size:.92rem;margin-top:-6px}
.dhikr-count{position:relative;width:200px;height:200px;border-radius:50%;border:1px solid rgba(255,255,255,.22);color:#fff;margin:8px 0;display:grid;place-items:center;cursor:pointer;
  background:radial-gradient(120% 100% at 32% 22%,rgba(255,255,255,.14),transparent 50%),#121214;
  box-shadow:0 18px 50px -14px rgba(0,0,0,.9),inset 0 1px 2px rgba(255,255,255,.12);transition:transform .12s var(--ease),box-shadow .3s}
.dhikr-count:active{transform:scale(.96)}
.dhikr-count.pulse{box-shadow:0 0 60px -6px rgba(255,255,255,.55),inset 0 1px 2px rgba(255,255,255,.2)}
.dc-ring{position:absolute;inset:0;border-radius:50%;pointer-events:none}
.dc-num{font-size:4rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-.02em}
.dc-target{color:var(--muted);font-size:.95rem;font-variant-numeric:tabular-nums;margin-top:4px}
.dhikr-actions{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;justify-content:center}
.dhikr-totals{display:flex;gap:14px;margin-top:6px}
.dhikr-totals div{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 22px;display:flex;flex-direction:column;gap:2px}
.dhikr-totals b{font-size:1.4rem;font-weight:800;font-variant-numeric:tabular-nums;color:#fff}
.dhikr-totals small{color:var(--dim);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}

/* ───────────── language switcher ───────────── */
.lang{position:relative}
.lang-btn{display:flex;align-items:center;gap:7px;border:1px solid var(--line-soft);background:rgba(255,255,255,.04);color:var(--muted);font-weight:600;font-size:.85rem;padding:8px 12px;border-radius:999px;transition:all .2s var(--ease)}
.lang-btn:hover{color:var(--ink)}
.lang-btn>.ic{width:1em;height:1em}
.lang-caret{width:.78em!important;height:.78em!important;opacity:.6}
.lang-menu{position:absolute;top:calc(100% + 8px);inset-inline-end:0;z-index:60;min-width:200px;padding:6px;border-radius:15px;border:1px solid var(--line);background:linear-gradient(168deg,#161618,#0b0b0c);box-shadow:0 24px 60px -16px rgba(0,0,0,.9);animation:popIn .2s var(--ease)}
.lang-opt{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;border:0;background:transparent;color:var(--ink);font-weight:500;font-size:.92rem;padding:10px 12px;border-radius:10px;text-align:start;transition:background .15s}
.lang-opt:hover{background:rgba(255,255,255,.06)}
.lang-opt.on{color:#fff;font-weight:600}
.lang-opt .ic{width:14px;height:14px;color:#fff}

/* ───────────── tafsir overlay ───────────── */
.tafseer-box{width:min(640px,100%);max-height:88vh;display:flex;flex-direction:column;border-radius:24px;padding:24px;background:linear-gradient(168deg,#141416,#0a0a0b);border:1px solid var(--line);box-shadow:0 40px 100px -20px rgba(0,0,0,.9);animation:popIn .32s var(--ease)}
.tafseer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}
.tafseer-title{display:flex;gap:13px;align-items:flex-start}
.t-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:13px;flex:none;color:#fff;background:rgba(255,255,255,.05);border:1px solid var(--line)}
.tafseer-title h3{font-family:var(--font-display);font-weight:540;font-size:1.3rem;letter-spacing:-.01em}
.tafseer-ref{color:var(--muted);font-size:.83rem;margin-top:3px}
.tafseer-edition{display:flex;align-items:center;gap:11px;margin-bottom:14px;flex-wrap:wrap}
.tafseer-edition label{color:var(--dim);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.tafseer-select{flex:1;min-width:180px;padding:11px 13px;border-radius:11px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--ink);font-family:inherit;font-size:.88rem;outline:0}
.tafseer-select:focus{border-color:rgba(255,255,255,.35)}
.tafseer-ayah{font-family:var(--font-q);font-size:1.75rem;line-height:2.1;color:#fff;text-align:right;padding:18px 20px;margin-bottom:16px;border-radius:15px;background:radial-gradient(120% 80% at 50% 0,rgba(255,255,255,.05),transparent 70%),#0e0e10;border:1px solid var(--line)}
.tafseer-body{overflow-y:auto;color:#dadad8;line-height:1.85;font-size:.97rem;scrollbar-width:thin;padding-inline-end:4px}
.tafseer-body p{margin-bottom:12px}
.tafseer-body h2,.tafseer-body h3,.tafseer-body b,.tafseer-body strong{color:#fff}
.tafseer-body h2,.tafseer-body h3{font-size:1.06rem;margin:14px 0 8px}
.tafseer-loading{color:var(--muted);text-align:center;padding:28px}
.tafseer-source{color:var(--dim);font-size:.77rem;margin-top:16px;padding-top:14px;border-top:1px solid var(--line-soft)}

/* ───────────── RTL refinements ───────────── */
html[dir="rtl"] .search-wrap>.ic{left:auto;right:17px}
html[dir="rtl"] .picker-search{padding:14px 44px 14px 18px}
html[dir="rtl"] .cta::after{background:linear-gradient(250deg,transparent 32%,rgba(255,255,255,.6) 50%,transparent 68%)}
html[dir="rtl"] .marker{transform:scaleX(1)}

/* clickable ayah markers */
.marker{cursor:pointer;transition:filter .2s,transform .2s}
.marker:hover{filter:drop-shadow(0 0 10px rgba(255,255,255,.4));transform:scale(1.08)}

/* ───────────── ad units (blended) ───────────── */
.ad-slot{
  max-width:980px;margin:34px auto 0;text-align:center;
  padding:14px 0 2px;border-radius:var(--r-lg);
}
.ad-slot.subtle{margin:26px auto 6px}
.ad-label{
  display:block;color:var(--dim);font-size:.6rem;font-weight:600;
  letter-spacing:.26em;text-transform:uppercase;margin-bottom:9px;opacity:.6;
}
.ad-slot ins.adsbygoogle{display:block;background:transparent;border-radius:14px;overflow:hidden;min-height:0}

/* ───────────── responsive ───────────── */
@media (max-width:780px){
  main{padding:18px 13px 230px}
  .topbar{padding:10px 14px;gap:10px}
  .brand-text{display:none}
  .tab span{display:none}
  .tab{padding:9px 14px}
  .donate-btn{padding:9px 15px;font-size:.84rem}
  .donate-btn span{display:none}
  .donate-btn .ic{width:1.05em;height:1.05em}
  .hero{padding-top:46px}
  .hero-bismillah{font-size:1.7rem}
  .mushaf{padding:32px 20px;font-size:calc(var(--quran-size)*.8)}
  .mushaf::before{inset:9px}
  .control-bar{grid-template-columns:1fr;gap:13px;padding:14px 18px;border-radius:24px;bottom:12px}
  .cb-stats{justify-content:center;gap:22px}
  .cb-status{justify-content:center}
  .bar-tools{margin-inline-start:0}
  .donate-panel .cta{margin-inline-start:0}
  .sum-grid{grid-template-columns:repeat(2,1fr)}
  .sp-name{min-width:120px}
  .sess-stats{gap:10px;font-size:.76rem}
  .ayah-jump{padding:6px 6px 6px 15px}
  .jump-go{padding:11px 18px}
  .dock-donate{width:42px;height:42px}
  .cb-status{justify-content:center}
  .topbar{gap:8px}
  .lang-btn{padding:8px 10px;gap:5px}
  .lang-caret{display:none}
  .tafseer-box{padding:18px;border-radius:20px}
  .tafseer-ayah{font-size:1.45rem;padding:14px 16px}
  .prayer-config,.zakat-top{grid-template-columns:1fr}
  .tafseer-select{min-width:0}
  .tool-tab{padding:10px 12px;font-size:.82rem}
  .tool-tab span{display:none}
  .prayer-next{flex-wrap:wrap}
  .qibla-panel{gap:18px}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}
