:root{
  /* Default Emerald Theme */
  --bg:#071510;--surf:#0c1f16;--card:#0f2a1d;--card2:#152f22;
  --bord:rgba(201,168,76,0.18);--bord2:rgba(201,168,76,0.35);
  --gold:#c9a84c;--gold2:#e8d68a;--gold3:rgba(201,168,76,0.1);--gold4:rgba(201,168,76,0.05);
  --gem:#1d7a4a;--gem2:#2fbd72;
  --txt:#f0e8d5;--txt2:#b8a888;--txt3:#6a5e44;
  --red:#c0392b;--rs:10px;--r:14px;
  --ar-fs: 21px; /* Arabic Font Size Variable */
}

body.theme-midnight{
  --bg:#0a0f1d;--surf:#0f172a;--card:#1e293b;--card2:#334155;
  --bord:rgba(148,163,184,0.2);--bord2:rgba(148,163,184,0.4);
  --gold:#38bdf8;--gold2:#7dd3fc;--gold3:rgba(56,189,248,0.1);--gold4:rgba(56,189,248,0.05);
  --gem:#0284c7;--gem2:#0ea5e9;
  --txt:#f1f5f9;--txt2:#94a3b8;--txt3:#64748b;
}

body.theme-purple{
  --bg:#1a101f;--surf:#2a1a33;--card:#3b2347;--card2:#4c2e5c;
  --bord:rgba(192,132,252,0.2);--bord2:rgba(192,132,252,0.4);
  --gold:#c084fc;--gold2:#d8b4fe;--gold3:rgba(192,132,252,0.1);--gold4:rgba(192,132,252,0.05);
  --gem:#9333ea;--gem2:#a855f7;
  --txt:#f5f3ff;--txt2:#a78bfa;--txt3:#7c3aed;
}

body.theme-sunset{
  --bg:#1d0f0a;--surf:#2d1811;--card:#3d2118;--card2:#4d2a1f;
  --bord:rgba(251,146,60,0.2);--bord2:rgba(251,146,60,0.4);
  --gold:#fb923c;--gold2:#fdba74;--gold3:rgba(251,146,60,0.1);--gold4:rgba(251,146,60,0.05);
  --gem:#ea580c;--gem2:#f97316;
  --txt:#fff7ed;--txt2:#fdba74;--txt3:#f97316;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overflow:hidden;}
body{
  background:var(--bg);color:var(--txt);
  font-family:'Nunito',sans-serif;
  display:flex;flex-direction:column;
  max-width:480px;margin:0 auto;
  position:relative;
}
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(201,168,76,0.035) 59px,rgba(201,168,76,0.035) 60px),
    repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(201,168,76,0.035) 59px,rgba(201,168,76,0.035) 60px),
    repeating-linear-gradient(45deg,transparent,transparent 29px,rgba(201,168,76,0.015) 29px,rgba(201,168,76,0.015) 30px),
    repeating-linear-gradient(-45deg,transparent,transparent 29px,rgba(201,168,76,0.015) 29px,rgba(201,168,76,0.015) 30px);
}

/* ══ HEADER ══ */
.hdr{
  position:relative;z-index:10;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px 10px;
  background:linear-gradient(180deg,var(--surf) 0%,transparent 100%);
  border-bottom:1px solid var(--bord);flex-shrink:0;
}
.hdr-logo{font-family:'Cinzel',serif;font-size:17px;font-weight:600;color:var(--gold);letter-spacing:1px;}
.hdr-sub{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:2px;}
.hdr-btn{
  width:36px;height:36px;border-radius:50%;
  border:1px solid var(--bord);background:var(--card);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--gold);font-size:16px;transition:background .2s;
}
.hdr-btn:hover{background:var(--card2);}

/* ══ CONTENT ══ */
#app-content{flex:1;overflow-y:auto;overflow-x:hidden;position:relative;z-index:1;}

/* ══ PAGES ══ */
.page{display:none;}
.page.active{display:block;}

/* ══ COUNTER PAGE ══ */
#page-counter{padding:18px 18px 10px;display:flex;flex-direction:column;align-items:center;gap:16px;}
#page-counter.active{display:flex;}

.dhikr-sel{
  width:100%;background:var(--card);border:1px solid var(--bord);
  border-radius:var(--r);padding:13px 15px;
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:background .2s, border-color .2s;
}
.dhikr-sel:hover{background:var(--card2);border-color:var(--bord2);}
.ds-arabic{font-family:'Amiri',serif;font-size:var(--ar-fs);color:var(--gold);direction:rtl;line-height:1.3;}
.ds-name{font-size:12px;color:var(--txt2);margin-top:2px;}
.ds-arr{color:var(--txt3);font-size:16px;margin-left:10px;flex-shrink:0;}

/* Ring + Button */
.c-wrap{position:relative;width:230px;height:230px;flex-shrink:0;}
.c-svg{position:absolute;inset:0;width:100%;height:100%;}
.ring-bg{fill:none;stroke:rgba(201,168,76,0.07);stroke-width:9;}
.ring-fill{
  fill:none;stroke:var(--gold);stroke-width:9;stroke-linecap:round;
  stroke-dasharray:659.73;stroke-dashoffset:659.73;
  transform-box:fill-box;transform-origin:center;transform:rotate(-90deg);
  transition:stroke-dashoffset .4s cubic-bezier(.34,1.56,.64,1),stroke .3s;
}
.ring-done{stroke:var(--gem2);}
.c-btn{
  position:absolute;inset:22px;border-radius:50%;
  background:var(--card);border:1px solid var(--bord);
  cursor:pointer;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2px;
  transition:transform .1s, background .2s;user-select:none;
}
.c-btn:active{transform:scale(.93);background:var(--card2);}
.c-btn:hover{border-color:var(--bord2);}
.c-num{font-family:'Cinzel',serif;font-size:50px;font-weight:600;color:var(--gold);line-height:1;}
.c-of{font-size:12px;color:var(--txt3);}
.c-hint{font-size:9px;color:var(--txt3);text-transform:uppercase;letter-spacing:1.5px;margin-top:3px;}

/* Laps row */
.laps-row{display:flex;gap:10px;}
.lbadge{background:var(--card);border:1px solid var(--bord);border-radius:20px;padding:5px 14px;font-size:12px;color:var(--txt2);}
.lbadge b{color:var(--gold);}

/* Targets */
.tgt-section{width:100%;}
.tgt-lbl{font-size:10px;color:var(--txt3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:9px;text-align:center;}
.tgt-row{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;}
.tgt-btn{
  padding:6px 13px;border-radius:20px;border:1px solid var(--bord);
  background:var(--card);color:var(--txt2);font-size:13px;
  font-family:'Nunito',sans-serif;cursor:pointer;transition:all .2s;
}
.tgt-btn:hover{border-color:var(--gold);color:var(--gold);}
.tgt-btn.on{background:var(--gold);border-color:var(--gold);color:var(--bg);font-weight:700;}
.tgt-custom{
  width:74px;padding:6px 10px;border-radius:20px;border:1px solid var(--bord);
  background:var(--card);color:var(--gold);font-family:'Nunito',sans-serif;
  font-size:13px;text-align:center;outline:none;
}
.tgt-custom:focus{border-color:var(--gold);}
.tgt-custom::placeholder{color:var(--txt3);}

/* Next-up banner */
.next-up{
  width:100%;background:var(--card);border:1px dashed var(--bord2);
  border-radius:var(--r);padding:10px 14px;
  display:flex;align-items:center;gap:10px;
  animation:fadeIn .4s ease;
}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.nu-lbl{font-size:10px;color:var(--gold);text-transform:uppercase;letter-spacing:1.2px;white-space:nowrap;flex-shrink:0;}
.nu-ar{font-family:'Amiri',serif;font-size:16px;color:var(--txt2);direction:rtl;flex:1;text-align:right;}
.nu-tr{font-size:11px;color:var(--txt3);white-space:nowrap;flex-shrink:0;}

/* Meaning */
.dhikr-meaning{
  width:100%;background:var(--card);border:1px solid var(--bord);
  border-radius:var(--r);padding:11px 14px;text-align:center;
}
.dm-text{font-style:italic;color:var(--txt2);font-size:13px;line-height:1.5;}

/* Actions */
.act-row{width:100%;display:flex;gap:9px;padding-bottom:8px;}
.act-btn{
  flex:1;padding:11px;border-radius:var(--r);border:1px solid var(--bord);
  background:var(--card);color:var(--txt2);font-size:13px;
  font-family:'Nunito',sans-serif;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;justify-content:center;gap:5px;
}
.act-btn:hover{background:var(--card2);color:var(--txt);}
.act-btn.red{border-color:rgba(192,57,43,.3);color:#c0392b;}
.act-btn.red:hover{background:rgba(192,57,43,.12);}

/* ══ ADHKAR PAGE ══ */
#page-adhkar{padding:16px;}
.pg-title{font-family:'Cinzel',serif;font-size:15px;color:var(--gold2);margin-bottom:14px;letter-spacing:.5px;}
.srch{
  width:100%;background:var(--card);border:1px solid var(--bord);
  border-radius:var(--r);padding:10px 14px;color:var(--txt);
  font-family:'Nunito',sans-serif;font-size:14px;margin-bottom:12px;outline:none;
}
.srch::placeholder{color:var(--txt3);}
.srch:focus{border-color:var(--gold);}
.cat-strip{display:flex;gap:5px;overflow-x:auto;margin-bottom:12px;padding-bottom:3px;scrollbar-width:none;}
.cat-strip::-webkit-scrollbar{display:none;}
.cpill{
  padding:4px 12px;border-radius:20px;border:1px solid var(--bord);
  background:var(--card);color:var(--txt3);font-size:11px;cursor:pointer;
  white-space:nowrap;transition:all .2s;flex-shrink:0;
}
.cpill.on{background:var(--gold);border-color:var(--gold);color:var(--bg);font-weight:700;}
.dg{display:flex;flex-direction:column;gap:8px;padding-bottom:16px;}
.dc{
  background:var(--card);border:1px solid var(--bord);border-radius:var(--r);
  padding:12px 14px;cursor:pointer;transition:all .2s;
  display:flex;align-items:center;gap:11px;
}
.dc:hover{background:var(--card2);border-color:var(--bord2);}
.dc.cur{border-color:var(--gold);background:var(--gold4);}
.dc-n{
  width:30px;height:30px;border-radius:50%;
  background:var(--bord);display:flex;align-items:center;
  justify-content:center;font-size:11px;color:var(--txt3);flex-shrink:0;
}
.dc.cur .dc-n{background:var(--gold);color:var(--bg);}
.dc-info{flex:1;min-width:0;}
.dc-ar{font-family:'Amiri',serif;font-size:var(--ar-fs);color:var(--gold);direction:rtl;line-height:1.4;}
.dc-tr{font-size:11px;color:var(--txt2);margin-top:1px;}
.dc-me{font-size:10px;color:var(--txt3);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.dc-tgt{font-family:'Cinzel',serif;font-size:15px;color:var(--gold);font-weight:600;text-align:right;flex-shrink:0;}
.dc-tl{font-size:9px;color:var(--txt3);text-transform:uppercase;letter-spacing:.8px;display:block;}

/* ══ SETTINGS PAGE ══ */
#page-settings{padding:16px;}
.ss-sec{margin-bottom:22px;}
.ss-title{font-size:10px;color:var(--gold);text-transform:uppercase;letter-spacing:2px;margin-bottom:9px;padding:0 3px;}
.ss-card{background:var(--card);border:1px solid var(--bord);border-radius:var(--r);overflow:hidden;}
.ss-row{display:flex;align-items:center;padding:13px 15px;border-bottom:1px solid var(--bord);gap:11px;}
.ss-row:last-child{border-bottom:none;}
.ss-ico{font-size:17px;width:24px;text-align:center;}
.ss-inf{flex:1;}
.ss-lbl{font-size:13px;color:var(--txt);}
.ss-desc{font-size:10px;color:var(--txt3);margin-top:1px;}
.toggle{position:relative;width:44px;height:24px;cursor:pointer;flex-shrink:0;}
.toggle input{opacity:0;width:0;height:0;}
.ttrack{position:absolute;inset:0;background:var(--txt3);border-radius:24px;transition:.3s;}
.toggle input:checked+.ttrack{background:var(--gold);}
.tthumb{position:absolute;left:3px;top:3px;width:18px;height:18px;background:white;border-radius:50%;transition:.3s;pointer-events:none;}
.toggle input:checked~.tthumb{left:23px;}
.ss-sel{
  background:var(--card2);border:1px solid var(--bord);border-radius:var(--rs);
  padding:5px 9px;color:var(--txt);font-family:'Nunito',sans-serif;font-size:13px;outline:none;cursor:pointer;
}
.ss-range{
  flex: 1; accent-color: var(--gold); cursor: pointer; height: 6px;
  background: var(--card2); border-radius: 5px; outline: none;
}
.dbtn{
  width:100%;padding:12px;background:rgba(192,57,43,.1);
  border:1px solid rgba(192,57,43,.3);border-radius:var(--r);
  color:var(--red);font-family:'Nunito',sans-serif;font-size:13px;
  font-weight:700;cursor:pointer;transition:all .2s;
}
.dbtn:hover{background:rgba(192,57,43,.2);}
.ss-stat{font-family:'Cinzel',serif;font-size:18px;color:var(--gold);}

/* ══ ADMIN PAGE ══ */
#page-admin{padding:16px;}
.adm-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.btn-add{
  padding:8px 16px;background:var(--gold);border:none;border-radius:20px;
  color:var(--bg);font-family:'Nunito',sans-serif;font-size:13px;
  font-weight:700;cursor:pointer;transition:opacity .2s;
}
.btn-add:hover{opacity:.85;}
.adm-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:14px;}
.adm-stat{
  background:var(--card);border:1px solid var(--bord);border-radius:var(--r);
  padding:11px;text-align:center;
}
.adm-stat-n{font-family:'Cinzel',serif;font-size:21px;color:var(--gold);}
.adm-stat-l{font-size:9px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;}
.adm-list{display:flex;flex-direction:column;gap:7px;padding-bottom:20px;}
.ai{
  background:var(--card);border:1px solid var(--bord);border-radius:var(--r);
  padding:11px 13px;display:flex;align-items:center;gap:11px;
}
.ai-info{flex:1;min-width:0;}
.ai-ar{font-family:'Amiri',serif;font-size:15px;color:var(--gold);direction:rtl;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ai-nm{font-size:11px;color:var(--txt2);}
.ai-cat{
  font-size:9px;background:var(--gold3);color:var(--gold);
  border-radius:10px;padding:2px 7px;display:inline-block;margin-top:3px;
}
.ai-acts{display:flex;gap:5px;flex-shrink:0;}
.ib{
  width:30px;height:30px;border-radius:var(--rs);border:1px solid var(--bord);
  background:transparent;color:var(--txt2);font-size:13px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.ib:hover{background:var(--card2);color:var(--txt);}
.ib.ed:hover{border-color:var(--gold);color:var(--gold);}
.ib.dl:hover{border-color:rgba(192,57,43,.4);color:var(--red);}

/* ══ MODAL ══ */
.overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:100;
  display:none;align-items:flex-end;justify-content:center;
}
.overlay.on{display:flex;}
.modal{
  background:var(--surf);border:1px solid var(--bord);
  border-radius:var(--r) var(--r) 0 0;padding:22px 18px;
  width:100%;max-width:480px;max-height:88vh;overflow-y:auto;
  animation:su .3s ease;
}
@keyframes su{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-ttl{
  font-family:'Cinzel',serif;font-size:15px;color:var(--gold);
  margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;
}
.modal-x{
  width:27px;height:27px;border-radius:50%;border:1px solid var(--bord);
  background:var(--card);color:var(--txt2);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.fg{margin-bottom:12px;}
.fl{font-size:11px;color:var(--txt3);text-transform:uppercase;letter-spacing:1px;margin-bottom:5px;display:block;}
.fi{
  width:100%;background:var(--card);border:1px solid var(--bord);
  border-radius:var(--rs);padding:9px 11px;color:var(--txt);
  font-family:'Nunito',sans-serif;font-size:13px;outline:none;
}
.fi:focus{border-color:var(--gold);}
.fi[dir="rtl"]{font-family:'Amiri',serif;font-size:17px;text-align:right;}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.modal-acts{display:flex;gap:9px;margin-top:18px;}
.btn-can{
  flex:1;padding:11px;background:transparent;border:1px solid var(--bord);
  border-radius:var(--r);color:var(--txt2);font-family:'Nunito',sans-serif;font-size:13px;cursor:pointer;
}
.btn-sv{
  flex:2;padding:11px;background:var(--gold);border:none;
  border-radius:var(--r);color:var(--bg);font-family:'Nunito',sans-serif;
  font-size:13px;font-weight:700;cursor:pointer;
}

/* ══ DHIKR DRAWER ══ */
.dd{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.65);display:none;align-items:flex-end;}
.dd.on{display:flex;}
.dd-inner{
  background:var(--surf);border-radius:var(--r) var(--r) 0 0;
  width:100%;max-width:480px;margin:0 auto;
  max-height:72vh;overflow-y:auto;padding:15px;
  animation:su .3s ease;
}
.dd-ttl{font-family:'Cinzel',serif;font-size:13px;color:var(--gold);text-align:center;margin-bottom:12px;letter-spacing:1px;}

/* ══ BOTTOM NAV ══ */
.bnav{
  position:relative;z-index:10;display:flex;
  background:var(--surf);border-top:1px solid var(--bord);
  padding:7px 0 max(7px,env(safe-area-inset-bottom));flex-shrink:0;
}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 3px;cursor:pointer;transition:all .2s;color:var(--txt3);user-select:none;}
.ni.on{color:var(--gold);}
.ni-ico{font-size:19px;line-height:1;}
.ni-lbl{font-size:9px;text-transform:uppercase;letter-spacing:.5px;}

/* ══ TOAST ══ */
.toast{
  position:fixed;bottom:78px;left:50%;
  transform:translateX(-50%) translateY(16px);
  background:var(--card2);border:1px solid var(--bord);
  border-radius:20px;padding:9px 18px;font-size:12px;
  color:var(--txt);z-index:200;opacity:0;transition:all .3s;white-space:nowrap;
}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0);}

/* ══ COMPLETE PULSE ══ */
@keyframes cpulse{0%{transform:scale(1)}50%{transform:scale(1.07)}100%{transform:scale(1)}}
.c-btn.done{animation:cpulse .5s ease;}

/* Page header spacing */
#page-settings .pg-title,#page-admin .pg-title{margin-bottom:16px;}
