@font-face{font-family:DM Sans;font-style:normal;font-weight:100 1000;font-display:swap;src:url(../media/c3cb240f9c892514-s.d8e4bce2.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:DM Sans;font-style:normal;font-weight:100 1000;font-display:swap;src:url(../media/5c285b27cdda1fe8-s.p.a62025f2.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:DM Sans Fallback;src:local(Arial);ascent-override:94.9%;descent-override:29.66%;line-gap-override:0.0%;size-adjust:104.53%}.dm_sans_b792f8f7-module__HCtePq__className{font-family:DM Sans,DM Sans Fallback;font-style:normal}.dm_sans_b792f8f7-module__HCtePq__variable{--font-body:"DM Sans","DM Sans Fallback"}
@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1e219c03c996efbd-s.ba7d7329.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b35b0dbffda7f2c4-s.0c27b1b4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Fraunces;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/03bda585a99c6450-s.p.ad37b9d9.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Fraunces Fallback;src:local(Times New Roman);ascent-override:84.71%;descent-override:22.09%;line-gap-override:0.0%;size-adjust:115.45%}.fraunces_33b78945-module__7w08Gq__className{font-family:Fraunces,Fraunces Fallback;font-style:normal}.fraunces_33b78945-module__7w08Gq__variable{--font-heading:"Fraunces","Fraunces Fallback"}
:root{--bg:#ece9fb;--shell:#faf9ff;--card:#fff;--text:#1f1b34;--muted:#6f6a8d;--line:#e5e1f5;--primary:#5b46e7;--primary-2:#4633ca;--ok:#1d8a5a;--warn:#996b18;--bad:#b03c3c;--heat-cell-size:3rem}*{box-sizing:border-box}html,body{min-height:100%;margin:0;padding:0}body{font-family:var(--font-body),sans-serif;color:var(--text);background:radial-gradient(circle at 20% 10%,#fff 0%,var(--bg)55%)}.page{max-width:1180px;margin:0 auto;padding:1.15rem}.appShell{background:linear-gradient(160deg,#fcfbff 0%,var(--shell)100%);border:1px solid var(--line);border-radius:28px;padding:.95rem}.appBar{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);background:#faf9ffeb;border-radius:16px;grid-template-columns:auto 1fr auto;align-items:center;gap:.6rem;padding:.5rem;display:grid;position:sticky;top:.55rem}.brand{font-family:var(--font-heading),serif;border:1px solid var(--line);background:#fff;border-radius:999px;padding:.42rem .8rem;font-size:1.05rem}.tabs{flex-wrap:wrap;justify-content:center;gap:.36rem;display:flex}.tab{color:var(--muted);background:0 0;border:1px solid #0000;border-radius:999px;padding:.45rem .8rem;font-size:.84rem}.tab.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}.appMeta{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:999px;padding:.4rem .75rem;font-size:.8rem}.headRow{justify-content:space-between;align-items:flex-end;gap:.8rem;margin-top:.9rem;display:flex}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:#6b5fd6;margin:0;font-size:.73rem;font-weight:700}h1,h2{font-family:var(--font-heading),serif;margin:0}h1{margin-top:.2rem;font-size:clamp(1.35rem,3.8vw,2rem)}h2{margin-bottom:.62rem;font-size:1.03rem}button,label,input,select,textarea{font:inherit}button{background:linear-gradient(140deg,var(--primary),var(--primary-2));color:#fff;border:none;border-radius:999px;padding:.6rem 1rem;font-weight:600}button:disabled{opacity:.65}.dateSlider{align-items:center;gap:.45rem;margin-top:.85rem;display:flex}.sliderBtn{place-items:center;width:34px;min-width:34px;height:34px;padding:0;display:grid}.dateCards{grid-auto-columns:minmax(95px,1fr);grid-auto-flow:column;gap:.42rem;width:100%;padding:.1rem;display:grid;overflow-x:auto}.dateCard{border:1px solid var(--line);color:var(--text);text-align:left;background:#fff;border-radius:12px;min-height:66px;padding:.42rem .55rem;display:grid}.dateCard span{color:var(--muted);font-size:.74rem}.dateCard small{color:#6b5fd6;min-height:.8rem;font-size:.68rem}.dateCard.active{background:#f0edff;border-color:#cfc7ff}.contentGrid{grid-template-columns:1.3fr 1fr;gap:.8rem;margin-top:.9rem;display:grid}.singlePane{margin-top:.9rem}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:1rem}.summaryCard{grid-column:1/-1}.metrics{grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem;display:grid}.metrics div{border:1px solid var(--line);border-radius:12px;padding:.58rem}.metrics span{color:var(--muted);font-size:.76rem;display:block}.metrics strong{font-size:1.08rem}.prayerList{gap:.46rem;display:grid}.prayerRow{border:1px solid var(--line);border-radius:12px;justify-content:space-between;align-items:center;gap:.5rem;padding:.52rem;display:flex}.prayerRow p{color:var(--muted);margin:.15rem 0 0;font-size:.82rem}.inline{align-items:center;gap:.4rem;margin-top:.6rem;display:flex}label{gap:.38rem;margin-top:.58rem;display:grid}.splitFields{grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;display:grid}input,select,textarea{border:1px solid var(--line);color:var(--text);background:#fff;border-radius:11px;padding:.55rem .62rem}.muted{color:var(--muted);margin:.4rem 0}.progressTrack{background:#ece9fa;border-radius:999px;height:10px;margin-top:.6rem;overflow:hidden}.progressTrack span{background:linear-gradient(120deg,#f1ce5b,var(--primary));height:100%;display:block}.progressTrack.tiny{height:7px;margin-top:.45rem}.notice{border-radius:12px;margin:.65rem 0;padding:.54rem .65rem;font-size:.86rem}.notice.warning{color:var(--warn);background:#fff5dc;border:1px solid #f2dfaa}.notice.success{color:var(--ok);background:#e8f8ef;border:1px solid #c3e8d4}.rowBetween{justify-content:space-between;align-items:center;gap:.6rem;display:flex}.goalRow{border:1px solid var(--line);border-radius:12px;margin-top:.6rem;padding:.58rem}.goalTitle{align-items:center;gap:.4rem;margin:0;font-weight:600;display:flex}.goalInputRow{align-items:center;gap:.35rem;margin-top:.45rem;display:flex}.goalInputRow input{width:84px}.milestoneGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;display:grid}.milestoneItem{border:1px solid var(--line);background:#fdfcff;border-radius:12px;padding:.55rem}.milestoneItem span{color:var(--muted);font-size:.82rem;display:block}.milestoneItem strong{font-size:.9rem}.pageCounterWrap{background:linear-gradient(145deg,#f4f1ff 0%,#ebe5ff 100%);border:1px solid #cfc7ff;border-radius:14px;grid-template-columns:44px 1fr 44px;align-items:center;gap:.42rem;margin-top:.42rem;padding:.44rem;display:grid}.counterBtn{border-radius:12px;place-items:center;width:44px;min-width:44px;height:44px;padding:0;font-size:1.2rem;font-weight:700;display:grid}.pageCounterValue{color:#3f32a7;text-align:center;background:#fff;border:1px solid #d8d1ff;border-radius:12px;padding:.65rem .4rem;font-size:1.7rem;font-weight:800;line-height:1}.reportsLayout{grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem;margin-top:.9rem;display:grid}.reportWide{grid-column:1/-1}.heatTopLabels{width:max-content;color:var(--muted);grid-template-columns:repeat(12,minmax(0,1fr));gap:.22rem;margin-top:.3rem;margin-left:56px;font-size:.64rem;display:grid}.heatTopLabels span{text-align:center;white-space:nowrap}.heatmapControls{align-items:center;gap:.34rem;display:flex}.heatViewToggle{border:1px solid var(--line);background:#fff;border-radius:8px;display:inline-flex;overflow:hidden}.heatViewToggle button{height:30px;color:var(--muted);background:0 0;border:0;padding:0 .54rem;font-size:.76rem}.heatViewToggle button.active{color:#087a5b;background:#eef8f4;font-weight:700}.heatmapControls select{border:1px solid var(--line);height:30px;color:var(--text);background:#fff;border-radius:8px;padding:.2rem .44rem;font-size:.78rem}.heatNavBtn{border:1px solid var(--line);width:30px;height:30px;color:var(--text);background:#fff;border-radius:8px;place-items:center;font-size:.92rem;display:grid}.heatNavBtn:hover{background:#f6f8ff}.heatmapSubhead{margin:.3rem 0 .12rem;font-size:.76rem}.heatmapWrap{grid-template-rows:auto auto;grid-template-columns:48px 1fr;align-items:start;gap:.44rem;margin-top:.25rem;display:grid;overflow-x:auto}.heatmapWrap.monthly{overflow-x:auto}.heatSideScale{grid-row:2;align-self:start;align-items:stretch;gap:.22rem;display:grid}.heatSideScale span{color:var(--muted);text-align:right;align-self:center;font-size:.62rem;line-height:1}.heatHoverTop{color:var(--muted);grid-column:2;margin-bottom:.16rem;font-size:.78rem}.heatmapGrid{grid-column:2;grid-template-rows:repeat(7,10px);grid-template-columns:repeat(12,10px);grid-auto-flow:row;gap:.22rem;width:max-content;display:grid}.heatTopLabels.monthly,.heatmapGrid.monthly{min-width:0}.heatmapGrid.monthly{grid-template-columns:repeat(7,var(--heat-cell-size))}.heatCell{border:1px solid #5b46e714;border-radius:2px;width:100%;height:100%}.heatCell.i0{background:#f1effb}.heatCell.i1{background:#ddd6ff}.heatCell.i2{background:#b8a9ff}.heatCell.i3{background:#8e77fb}.heatCell.i4{background:#5b46e7}.heatCell.placeholder{pointer-events:none;background:#f1effb;border-color:#5b46e714}.heatLegend{color:var(--muted);align-items:center;gap:.32rem;margin-top:.55rem;font-size:.78rem;display:flex}.heatLegend .heatCell{aspect-ratio:1;width:11px}.scoreChartWrap{border:1px solid var(--line);background:linear-gradient(#f9fdfb 0%,#fff 100%);border-radius:12px;margin-top:.5rem;padding:.6rem}.scoreChartFrame{grid-template-columns:28px 1fr;align-items:stretch;gap:.38rem;display:grid}.scoreAxisLabels{height:150px;color:var(--muted);text-align:right;flex-direction:column;justify-content:space-between;padding:2px 0;font-size:.7rem;line-height:1;display:flex}.scoreChart{width:100%;height:150px;display:block}.chartPlot{position:relative}.scoreChart .axis{stroke:#d6e7dc;stroke-width:.5px}.scoreChart .gridLine{stroke:#e8f2eb;stroke-width:.6px;stroke-dasharray:1.4 1.4}.scoreChart .scoreArea{fill:#0080601f}.scoreChart .scoreLine{fill:none;stroke:#4aa78f;stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round}.scoreChart .hoverGuide{stroke:#b8d1c5;stroke-width:.7px;stroke-dasharray:2 2}.scoreChart .hoverDot{fill:#fff;stroke-width:1.4px}.scoreChart .hoverDot.score{stroke:#008060}.quranChart .quranArea{fill:#3b82f624}.quranChart .quranLine{fill:none;stroke:#6ea2ff;stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round}.scoreChart .hoverDot.quran{stroke:#2563eb}.chartTooltip{pointer-events:none;border:1px solid var(--line);z-index:2;white-space:nowrap;background:#fff;border-radius:10px;gap:.08rem;padding:.28rem .46rem;display:grid;position:absolute;transform:translate(-50%,-118%);box-shadow:0 10px 20px #23195424}.chartTooltip strong{font-size:.8rem;line-height:1}.chartTooltip span{color:var(--muted);font-size:.72rem;line-height:1}.chartMeta{color:var(--muted);justify-content:space-between;margin-top:.42rem;font-size:.78rem;display:flex}.qualityGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.46rem;display:grid}.qualityCard{border:1px solid;border-radius:10px;padding:.5rem}.qualityCard p{margin:.14rem 0 0;font-size:.8rem}.qualityCard.green{color:var(--ok);background:#e8f7ef;border-color:#bfe3ce}.qualityCard.yellow{color:var(--warn);background:#fff6df;border-color:#efd89e}.qualityCard.red{color:var(--bad);background:#ffe9e9;border-color:#ebb5b5}.qualityCard.none{color:var(--muted);background:#f2f1f7;border-color:#ddd8ec}.statusBar{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:12px;margin-top:.85rem;padding:.58rem .72rem;font-size:.9rem}.bottomAppBar{display:none}.loading{min-height:100vh;color:var(--muted);place-items:center;display:grid}.skeletonCard{position:relative;overflow:hidden}.skeletonCard:after{content:"";background:linear-gradient(90deg,#0000 0%,#ffffffa6 50%,#0000 100%);animation:1.2s ease-in-out infinite skeletonShimmer;position:absolute;inset:0;transform:translate(-100%)}.skeletonLine,.skeletonBlock{background:#eceff5;border-radius:8px}.skeletonLine{height:12px}.skeletonBlock{width:100%}.skeletonStack{gap:.55rem;margin-top:.9rem;display:grid}.skeletonMetricGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;margin-top:.9rem;display:grid}.skeletonGrid{align-content:start;min-height:calc(100vh - 250px)}.skeletonGrid .card{min-height:220px}.singlePane.skeletonGrid{display:grid}.w100{width:100%}.w96{width:96%}.w94{width:94%}.w92{width:92%}.w90{width:90%}.w86{width:86%}.w80{width:80%}.w70{width:70%}.w56{width:56%}.w52{width:52%}.w48{width:48%}.w46{width:46%}.w44{width:44%}.w42{width:42%}.w40{width:40%}.h70{height:70px}.h80{height:80px}.h120{height:120px}.h180{height:180px}.h210{height:210px}@keyframes skeletonShimmer{to{transform:translate(100%)}}@media (max-width:940px){:root{--heat-cell-size:3rem}.appBar{grid-template-columns:1fr auto;align-items:center}.tabs{display:none}.headRow{flex-direction:column;align-items:flex-start}.contentGrid,.reportsLayout,.qualityGrid,.milestoneGrid,.metrics,.splitFields{grid-template-columns:1fr}.heatmapGrid{grid-template-rows:repeat(7,9px);grid-template-columns:repeat(12,9px)}.heatTopLabels{margin-left:0}.heatTopLabels.yearly{grid-template-columns:repeat(6,9px)}.heatTopLabels.yearly span:nth-child(n+7){display:none}.heatmapWrap{grid-template-columns:1fr}.heatmapControls{flex-wrap:wrap;justify-content:flex-end;width:100%}.skeletonGrid{min-height:calc(100vh - 220px)}.skeletonGrid .card{min-height:170px}.page{padding-bottom:5.8rem}.bottomAppBar{border:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:30;background:#fffffff0;border-radius:14px;grid-template-columns:repeat(4,minmax(0,1fr));gap:.34rem;width:min(96vw,560px);padding:.38rem;display:grid;position:fixed;bottom:.9rem;left:50%;transform:translate(-50%);box-shadow:0 14px 30px #251c5629}.bottomTab{color:var(--muted);background:0 0;border:1px solid #0000;border-radius:10px;padding:.5rem .3rem;font-size:.76rem;font-weight:700}.bottomTab.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-color:#0000}.heatSideScale{display:none}.heatHoverTop,.heatmapGrid{grid-column:1}.prayerRow{flex-direction:column;align-items:flex-start}.prayerRow select{width:100%}}
