*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;background:0 0;border:none}ul,ol{list-style:none}img{max-width:100%;display:block}input,textarea,select{font:inherit}:root{--bg-primary:#0f0f14;--bg-secondary:#1a1a24;--bg-tertiary:#252533;--bg-elevated:#2a2a3c;--glass:#ffffff0d;--glass-hover:#ffffff14;--glass-border:#ffffff14;--glass-border-hover:#ffffff24;--text-primary:#f0f0f5;--text-secondary:#8888a0;--text-tertiary:#55556a;--text-inverse:#0f0f14;--accent-blue:#4f8cff;--accent-green:#34d399;--accent-red:#ff6b6b;--accent-orange:#ffaa4f;--accent-purple:#a78bfa;--accent-pink:#f472b6;--accent-cyan:#22d3ee;--accent-yellow:#fbbf24;--gradient-blue:linear-gradient(135deg, #4f8cff, #6366f1);--gradient-green:linear-gradient(135deg, #34d399, #10b981);--gradient-gold:linear-gradient(135deg, #f59e0b, #ef4444);--gradient-purple:linear-gradient(135deg, #a78bfa, #8b5cf6);--gradient-pink:linear-gradient(135deg, #f472b6, #ec4899);--gradient-cyan:linear-gradient(135deg, #22d3ee, #06b6d4);--gradient-subtle:linear-gradient(135deg, #4f8cff26, #6366f114);--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--space-3xl:32px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-glow-blue:0 0 20px #4f8cff33;--shadow-glow-green:0 0 20px #34d39933;--shadow-glow-purple:0 0 20px #a78bfa33;--bottom-nav-height:72px;--header-height:56px;--safe-area-bottom:env(safe-area-inset-bottom,0px)}#root{width:100%;max-width:100vw;min-height:100dvh}.glass{background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg)}.glass-card{background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all .25s cubic-bezier(.4,0,.2,1)}.glass-card:active{background:var(--glass-hover);border-color:var(--glass-border-hover);transform:scale(.98)}.glass-solid{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.page{padding:var(--space-lg);padding-bottom:calc(var(--bottom-nav-height) + var(--safe-area-bottom) + var(--space-xl));min-height:100dvh;animation:.35s ease-out fadeIn}.page-header{padding:var(--space-xl) 0 var(--space-lg)}.page-title{color:var(--text-primary);letter-spacing:-.5px;font-size:28px;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:var(--space-xs);font-size:14px}.stat-grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.stat-card{background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-sm);flex-direction:column;transition:all .25s cubic-bezier(.4,0,.2,1);animation:.4s ease-out backwards slideUp;display:flex;position:relative;overflow:hidden}.stat-card:before{content:"";opacity:0;height:2px;transition:opacity .25s;position:absolute;top:0;left:0;right:0}.stat-card:active{transform:scale(.97)}.stat-card .stat-emoji{border-radius:var(--radius-md);background:var(--glass);justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;display:flex}.stat-card .stat-value{color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700;line-height:1.1}.stat-card .stat-label{color:var(--text-secondary);font-size:12px;font-weight:500}.stat-card .stat-trend{border-radius:var(--radius-full);align-items:center;gap:2px;padding:2px 6px;font-size:11px;font-weight:600;display:inline-flex}.stat-trend.up{color:var(--accent-green);background:#34d3991f}.stat-trend.down{color:var(--accent-red);background:#ff6b6b1f}.stat-card:first-child{animation-delay:50ms}.stat-card:nth-child(2){animation-delay:.1s}.stat-card:nth-child(3){animation-delay:.15s}.stat-card:nth-child(4){animation-delay:.2s}.stat-card:nth-child(5){animation-delay:.25s}.stat-card:nth-child(6){animation-delay:.3s}.stat-card:nth-child(7){animation-delay:.35s}.stat-card:nth-child(8){animation-delay:.4s}.chart-card{background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-xl);margin-bottom:var(--space-lg);animation:.5s ease-out backwards fadeIn}.chart-card .chart-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:16px;font-weight:600}.chart-card .chart-subtitle{color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:12px}.chart-card .chart-container{width:100%;height:200px}.bottom-nav{height:calc(var(--bottom-nav-height) + var(--safe-area-bottom));padding-bottom:var(--safe-area-bottom);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--glass-border);z-index:1000;background:#0f0f14d9;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-md);flex-direction:column;align-items:center;gap:3px;min-width:44px;transition:all .2s;display:flex;position:relative}.nav-item .nav-icon{font-size:20px;line-height:1;transition:transform .2s}.nav-item .nav-label{color:var(--text-tertiary);white-space:nowrap;font-size:9px;font-weight:500;transition:color .2s}.nav-item.active .nav-icon{transform:scale(1.15)}.nav-item.active .nav-label{color:var(--accent-blue);font-weight:600}.nav-item.active:after{content:"";background:var(--gradient-blue);border-radius:0 0 var(--radius-full) var(--radius-full);width:20px;height:3px;position:absolute;top:-1px;left:50%;transform:translate(-50%)}.prayer-grid{border-collapse:separate;border-spacing:4px;width:100%}.prayer-grid th{color:var(--text-tertiary);padding:var(--space-sm);text-align:center;font-size:11px;font-weight:500}.prayer-grid td{text-align:center;padding:var(--space-sm);border-radius:var(--radius-sm);min-width:32px;height:32px;font-size:14px}.prayer-grid .prayer-name{color:var(--text-secondary);text-align:left;white-space:nowrap;padding-right:var(--space-md);font-size:11px;font-weight:500}.prayer-cell{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;transition:transform .15s;display:inline-flex}.prayer-cell:active{transform:scale(.9)}.prayer-cell.jamaah{background:#34d39933;border:1px solid #34d3994d}.prayer-cell.prayed{background:#4f8cff33;border:1px solid #4f8cff4d}.prayer-cell.missed{background:#ff6b6b26;border:1px solid #ff6b6b40}.prayer-cell.future{background:var(--glass);border:1px solid var(--glass-border)}.prayer-today-row{justify-content:space-between;gap:var(--space-sm);padding:var(--space-md) 0;display:flex}.prayer-circle{align-items:center;gap:var(--space-xs);flex-direction:column;display:flex}.prayer-circle-dot{border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;transition:all .2s;display:flex}.prayer-circle-dot.jamaah{background:var(--gradient-green);box-shadow:var(--shadow-glow-green)}.prayer-circle-dot.prayed{background:var(--gradient-blue);box-shadow:var(--shadow-glow-blue)}.prayer-circle-dot.missed{border:2px solid var(--accent-red);background:#ff6b6b40}.prayer-circle-dot.upcoming{background:var(--glass);border:2px dashed var(--glass-border-hover)}.prayer-circle-label{color:var(--text-secondary);font-size:10px;font-weight:500}.heatmap{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.heatmap-cell{aspect-ratio:1;border-radius:3px;min-width:12px;transition:transform .15s}.heatmap-cell:active{transform:scale(1.5)}.heatmap-cell.level-0{background:var(--glass)}.heatmap-cell.level-1{background:#34d39933}.heatmap-cell.level-2{background:#34d39966}.heatmap-cell.level-3{background:#34d39999}.heatmap-cell.level-4{background:#34d399d9}.progress-bar{background:var(--glass);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:var(--gradient-blue);height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.progress-bar-fill.green{background:var(--gradient-green)}.progress-bar-fill.purple{background:var(--gradient-purple)}.progress-bar-fill.gold{background:var(--gradient-gold)}.progress-ring{justify-content:center;align-items:center;display:inline-flex;position:relative}.progress-ring svg{transform:rotate(-90deg)}.progress-ring-track{fill:none;stroke:var(--glass-border);stroke-width:6px}.progress-ring-fill{fill:none;stroke:url(#gradientBlue);stroke-width:6px;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1)}.progress-ring-text{color:var(--text-primary);font-size:18px;font-weight:700;position:absolute}.period-tabs{gap:var(--space-xs);background:var(--glass);border-radius:var(--radius-full);margin-bottom:var(--space-xl);padding:3px;display:flex}.period-tab{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-full);color:var(--text-secondary);text-align:center;flex:1;font-size:13px;font-weight:500;transition:all .25s}.period-tab.active{background:var(--gradient-blue);color:#fff;font-weight:600}.list-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:var(--space-sm);transition:all .2s;animation:.4s ease-out backwards slideUp;display:flex}.list-item:active{background:var(--glass-hover);transform:scale(.98)}.list-item-icon{border-radius:var(--radius-md);background:var(--glass);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.list-item-content{flex:1;min-width:0}.list-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.list-item-subtitle{color:var(--text-secondary);margin-top:1px;font-size:12px}.list-item-right{text-align:right;flex-shrink:0}.list-item-amount{font-size:15px;font-weight:600}.list-item-amount.expense{color:var(--accent-red)}.list-item-amount.income{color:var(--accent-green)}.list-item-time{color:var(--text-tertiary);margin-top:1px;font-size:11px}.badge{border-radius:var(--radius-full);align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge.low{color:var(--accent-green);background:#34d39926}.badge.medium{color:var(--accent-orange);background:#ffaa4f26}.badge.high{color:var(--accent-red);background:#ff6b6b26}.badge.recurring{color:var(--accent-purple);background:#a78bfa26}.priority-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.priority-dot.high{background:var(--accent-red);box-shadow:0 0 8px #ff6b6b66}.priority-dot.medium{background:var(--accent-orange);box-shadow:0 0 8px #ffaa4f66}.priority-dot.low{background:var(--accent-green);box-shadow:0 0 8px #34d39966}.section-header{color:var(--text-primary);margin:var(--space-2xl) 0 var(--space-md);align-items:center;gap:var(--space-sm);font-size:18px;font-weight:600;display:flex}.section-header:first-child{margin-top:0}.task-column-header{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-md);align-items:center;gap:var(--space-sm);font-size:13px;font-weight:600;display:flex}.task-column-count{background:var(--glass);width:20px;height:20px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:11px;display:inline-flex}.task-card{background:var(--glass);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-sm);transition:all .2s;animation:.3s ease-out backwards slideUp}.task-card:active{transform:scale(.98)}.task-card .task-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:14px;font-weight:500}.task-card .task-meta{align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:12px;display:flex}.task-card.done{opacity:.6}.task-card.done .task-title{color:var(--text-secondary);text-decoration:line-through}.balance-card{background:var(--gradient-blue);border-radius:var(--radius-xl);padding:var(--space-2xl);margin-bottom:var(--space-xl);animation:.5s ease-out fadeIn;position:relative;overflow:hidden}.balance-card:after{content:"";background:#ffffff14;border-radius:50%;width:200px;height:200px;position:absolute;top:-50%;right:-30%}.balance-card .balance-label{color:#ffffffb3;margin-bottom:var(--space-sm);font-size:13px;font-weight:500}.balance-card .balance-value{color:#fff;letter-spacing:-1px;font-size:36px;font-weight:700;line-height:1.1}.balance-card .balance-row{gap:var(--space-xl);margin-top:var(--space-lg);display:flex}.balance-card .balance-sub-label{color:#ffffff80;font-size:11px}.balance-card .balance-sub-value{color:#fff;margin-top:2px;font-size:16px;font-weight:600}.greeting{padding:var(--space-xl) 0 var(--space-md)}.greeting-text{color:var(--text-primary);letter-spacing:-.3px;font-size:22px;font-weight:700}.greeting-date{color:var(--text-secondary);margin-top:var(--space-xs);font-size:13px}.skeleton{background:linear-gradient(90deg, var(--glass) 25%, var(--glass-hover) 50%, var(--glass) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.skeleton-text{height:14px;margin-bottom:var(--space-sm)}.skeleton-title{width:60%;height:24px;margin-bottom:var(--space-md)}.skeleton-card{height:100px;margin-bottom:var(--space-md)}.skeleton-circle{border-radius:50%}.streak-badge{align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);color:var(--accent-orange);background:#ffaa4f1f;border:1px solid #ffaa4f33;font-size:13px;font-weight:600;display:inline-flex}.quick-actions{gap:var(--space-sm);padding-bottom:var(--space-sm);-webkit-overflow-scrolling:touch;scrollbar-width:none;display:flex;overflow-x:auto}.quick-actions::-webkit-scrollbar{display:none}.quick-action-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-full);color:var(--text-primary);white-space:nowrap;font-size:13px;font-weight:500;transition:all .2s;display:flex}.quick-action-btn:active{background:var(--glass-hover);transform:scale(.95)}.empty-state{padding:var(--space-3xl);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-emoji{margin-bottom:var(--space-lg);font-size:48px}.empty-state-text{color:var(--text-secondary);font-size:15px;font-weight:500}.countdown{color:var(--accent-orange);font-size:13px;font-weight:500}.reminder-past{opacity:.45}.goal-progress-value{margin-top:var(--space-sm);font-size:13px;font-weight:600}.goal-progress-value.green{color:var(--accent-green)}.goal-progress-value.yellow{color:var(--accent-orange)}.goal-progress-value.red{color:var(--accent-red)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--glass-border)}.recharts-text{fill:var(--text-secondary);font-size:11px}.recharts-tooltip-wrapper{outline:none}::-webkit-scrollbar{width:0;height:0}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}
