:root{--primary-green: #059669;--primary-dark: #047857;--primary-light: #10b981;--accent-gold: #f59e0b;--accent-blue: #3b82f6;--bg-light: #f9fafb;--bg-dark: #111827;--text-dark: #1f2937;--text-light: #6b7280;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1);--transition-fast: .15s ease-in-out;--transition-normal: .3s ease-in-out;--transition-slow: .5s ease-in-out}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-light);color:var(--text-dark);line-height:1.6}.hijri-text{font-family:Amiri,Inter,serif;font-weight:700}.bg-primary{background:linear-gradient(135deg,var(--primary-green) 0%,var(--primary-dark) 100%)!important}.btn-primary{background:linear-gradient(135deg,var(--primary-green),var(--primary-dark));border:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-dark),var(--primary-green));transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-primary:active{transform:translateY(0)}.text-primary{color:var(--primary-green)!important}.card{border-radius:12px;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-title{font-weight:600;color:var(--text-dark)}.navbar{box-shadow:var(--shadow-md)}.navbar-brand{font-size:1.25rem;transition:transform var(--transition-fast)}.navbar-brand:hover{transform:scale(1.05)}.navbar-dark .navbar-toggler{color:#fff!important;border-color:#fff!important;opacity:1!important}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")!important;opacity:1!important}.nav-link{font-weight:500;transition:color var(--transition-fast);position:relative;padding:.5rem 1rem;display:inline-flex;align-items:center;gap:.5rem}.nav-link:hover,.nav-link.active{color:var(--accent-gold)!important}.nav-link.active:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background-color:var(--accent-gold)}.hero-date-card{background:linear-gradient(135deg,#fff,#f0f9ff);border-radius:16px;animation:fadeInUp .6s ease-out}.hero-date-card h2{color:var(--text-dark);font-size:1.75rem}.hero-date-card h3{font-size:1.5rem}@media(min-width:768px){.hero-date-card h2{font-size:2.25rem}.hero-date-card h3{font-size:2rem}}.gradient-card{background:linear-gradient(135deg,#ecfdf5,#d1fae5,#a7f3d0);border-radius:16px;animation:fadeInUp .8s ease-out}.gradient-card .card-title{font-size:1.5rem}.prayer-time-card{background-color:#f8fafc;border:2px solid transparent;transition:all var(--transition-normal);cursor:pointer}.prayer-time-card:hover{background-color:#e0f2fe;border-color:var(--accent-blue);transform:scale(1.05)}.prayer-time-card.active-prayer{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:var(--accent-blue);box-shadow:0 0 20px rgba(59,130,246,.3);animation:pulse 2s infinite}.prayer-time-card h5{color:var(--text-dark);font-size:1.25rem}.stat-card{background:#fff;border-radius:12px;transition:all var(--transition-normal);animation:fadeInUp 1s ease-out}.stat-card:hover{transform:translateY(-8px);box-shadow:0 20px 25px -5px rgba(0,0,0,.1)}.stat-icon{font-size:3rem;opacity:.2;position:absolute;top:10px;right:10px}.stat-card .card-body{position:relative;padding:2rem 1rem}.stat-card h3{font-size:2rem;color:var(--text-dark)}.progress{border-radius:10px;overflow:hidden;background-color:#e5e7eb}.progress-bar{border-radius:10px;transition:width var(--transition-slow)}.alert{border-radius:12px;border:none;font-weight:500;animation:fadeIn .5s ease-out}.alert-success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.alert-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.alert-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.modal-content{border-radius:16px;border:none;box-shadow:var(--shadow-lg)}.modal-header.bg-primary{border-radius:16px 16px 0 0}.btn{border-radius:8px;padding:.5rem 1.5rem;font-weight:600;transition:all var(--transition-fast)}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-lg{padding:.75rem 2rem;font-size:1.125rem}.form-control,.form-select{border-radius:8px;border:2px solid #e5e7eb;padding:.75rem 1rem;transition:border-color var(--transition-fast)}.form-control:focus,.form-select:focus{border-color:var(--primary-green);box-shadow:0 0 0 3px rgba(5,150,105,.1)}footer{border-top:1px solid #e5e7eb}footer a{color:var(--primary-green);font-weight:600}footer a:hover{color:var(--primary-dark)}#loadingIndicator{animation:fadeIn .3s ease-out}.spinner-border{width:3rem;height:3rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;box-shadow:0 0 20px rgba(59,130,246,.3)}50%{opacity:.9;box-shadow:0 0 30px rgba(59,130,246,.5)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@media(max-width:768px){.navbar-brand{font-size:1rem}.hero-date-card h2{font-size:1.5rem}.hero-date-card h3{font-size:1.25rem}.stat-card h3{font-size:1.5rem}.stat-icon{font-size:2rem}.gradient-card .card-title{font-size:1.25rem}}.text-muted{color:var(--text-light)!important}.shadow-sm{box-shadow:var(--shadow-sm)!important}.shadow{box-shadow:var(--shadow-md)!important}.shadow-lg{box-shadow:var(--shadow-lg)!important}.rounded{border-radius:12px!important}.rounded-lg{border-radius:16px!important}html{scroll-behavior:smooth}::selection{background-color:var(--primary-light);color:#fff}*:focus{outline:2px solid var(--primary-green);outline-offset:2px}*:focus:not(:focus-visible){outline:none}.current-time-display{font-family:Inter,sans-serif}.current-time-display .alert{background:linear-gradient(135deg,#e0f2fe,#dbeafe);border:1px solid #0ea5e9;box-shadow:0 2px 4px rgba(14,165,233,.1)}.current-time-display #currentTime{font-size:1.5rem;letter-spacing:.05em;color:#0369a1;font-variant-numeric:tabular-nums}@media(max-width:576px){.current-time-display #currentTime{font-size:1.25rem}}.calendar-container{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.calendar-table{width:100%;border-collapse:collapse}.calendar-table th{background-color:#f3f4f6;padding:.75rem;text-align:center;font-weight:600;color:#6b7280;border-radius:8px 8px 0 0}.calendar-table td{padding:1rem;text-align:center;border:1px solid #e5e7eb;cursor:pointer;transition:all .3s ease;position:relative}.calendar-table td:hover{background-color:#f9fafb;transform:scale(1.05)}.calendar-date{font-weight:600;font-size:1.125rem}.calendar-date.today{color:#3b82f6;border:2px solid #3b82f6;border-radius:50%;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;margin:0 auto}.calendar-date.ayyamul-bidh{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46;border-radius:50%;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;margin:0 auto;font-weight:700}.calendar-date.marked:after{content:"✓";position:absolute;top:5px;right:5px;background-color:#10b981;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.calendar-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:24px;height:24px;border-radius:50%;display:inline-block}.legend-color.ayyamul-bidh{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.legend-color.today{border:2px solid #3b82f6}.legend-color.marked{background-color:#10b981;position:relative}.legend-color.marked:after{content:"✓";color:#fff;font-size:.75rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tracker-list{list-style:none;padding:0}.tracker-item{display:flex;align-items:center;padding:1rem;margin-bottom:.75rem;background-color:#f9fafb;border-radius:12px;border:2px solid transparent;transition:all .3s ease}.tracker-item:hover{background-color:#f3f4f6;border-color:#d1d5db}.tracker-item.completed{background:linear-gradient(135deg,#d1fae5,#ecfdf5);border-color:#10b981}.tracker-checkbox{width:24px;height:24px;margin-right:1rem;cursor:pointer;accent-color:#10b981}.tracker-checkbox:checked{transform:scale(1.1)}.tracker-label{flex:1;font-weight:500;color:#1f2937}.tracker-badge{background-color:#10b981;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.progress-circle{position:relative;width:150px;height:150px;margin:0 auto}.progress-circle svg{transform:rotate(-90deg)}.progress-circle-bg{fill:none;stroke:#e5e7eb;stroke-width:10}.progress-circle-fill{fill:none;stroke:#10b981;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1s ease}.progress-circle-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-circle-percentage{font-size:2rem;font-weight:700;color:#1f2937}.progress-circle-label{font-size:.875rem;color:#6b7280}.islamic-pattern{background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23059669' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.toast-container{position:fixed;top:80px;right:20px;z-index:1050}.custom-toast{background:#fff;border-radius:12px;box-shadow:0 10px 15px -3px rgba(0,0,0,.1);padding:1rem 1.5rem;margin-bottom:1rem;min-width:300px;animation:slideInRight .3s ease-out}.toast-success{border-left:4px solid #10b981}.toast-error{border-left:4px solid #ef4444}.toast-info{border-left:4px solid #3b82f6}.toast-warning{border-left:4px solid #f59e0b}.custom-badge{display:inline-block;padding:.35rem .65rem;font-size:.875rem;font-weight:600;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.badge-complete{background-color:#d1fae5;color:#065f46}.badge-partial{background-color:#fef3c7;color:#92400e}.badge-none{background-color:#f3f4f6;color:#6b7280}.accordion-item{border:none;margin-bottom:.75rem;border-radius:12px!important;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.1)}.accordion-button{background-color:#fff;border:none;font-weight:600;padding:1rem 1.5rem}.accordion-button:not(.collapsed){background:linear-gradient(135deg,#ecfdf5,#d1fae5);color:#065f46;box-shadow:none}.accordion-button:focus{box-shadow:none;border-color:transparent}.accordion-body{padding:1.5rem}.chart-container{padding:1.5rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.chart-bar{display:flex;align-items:center;margin-bottom:1rem}.chart-label{width:100px;font-size:.875rem;font-weight:500;color:#6b7280}.chart-bar-bg{flex:1;height:30px;background-color:#f3f4f6;border-radius:8px;overflow:hidden;position:relative}.chart-bar-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:8px;transition:width 1s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem;color:#fff;font-size:.75rem;font-weight:600}.prayer-detail-card{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 1px 3px rgba(0,0,0,.1);border-left:4px solid #10b981;transition:all .3s ease}.prayer-detail-card:hover{transform:translate(4px);box-shadow:0 4px 6px -1px rgba(0,0,0,.1)}.prayer-detail-card.active{background:linear-gradient(135deg,#dbeafe,#eff6ff);border-left-color:#3b82f6;animation:pulse 2s infinite}.prayer-name{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:.25rem}.prayer-time-large{font-size:2rem;font-weight:700;color:#059669}.prayer-countdown{font-size:.875rem;color:#6b7280;font-weight:500}.info-card{background:linear-gradient(135deg,#fff,#f9fafb);border-radius:12px;padding:1.5rem;border:2px solid #e5e7eb;margin-bottom:1.5rem}.info-card-title{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.info-card-content{color:#4b5563;line-height:1.8}.arabic-text{font-family:Amiri,serif;font-size:1.5rem;line-height:2;text-align:right;direction:rtl;color:#059669;margin:1rem 0}.transliteration{font-style:italic;color:#6b7280;margin:.5rem 0}.translation{color:#4b5563;padding:1rem;background-color:#f9fafb;border-radius:8px;border-left:4px solid #10b981}.empty-state{text-align:center;padding:3rem 1.5rem;color:#6b7280}.empty-state-icon{font-size:4rem;opacity:.3;margin-bottom:1rem}.empty-state-title{font-size:1.5rem;font-weight:600;color:#4b5563;margin-bottom:.5rem}.empty-state-message{font-size:1rem;margin-bottom:1.5rem}@media(max-width:768px){.calendar-table td{padding:.5rem}.calendar-date{font-size:1rem}.prayer-detail-card{padding:1rem}.prayer-time-large{font-size:1.5rem}.chart-label{width:80px;font-size:.75rem}.progress-circle{width:120px;height:120px}.progress-circle-percentage{font-size:1.5rem}}.date-card-with-bg{position:relative;overflow:hidden;min-height:180px}.date-card-bg{position:absolute;top:0;left:0;width:100%;height:100%;background-image:url(/jadwal-puasa-ayyamulbidh/assets/hero_image_mosque-DW9CvcEY.jpg);background-size:cover;background-position:center 65%;background-repeat:no-repeat;z-index:0}.date-card-bg:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom,rgba(255,255,255,.75),rgba(255,255,255,.7),rgba(255,255,255,.65))}.date-card-content{position:relative;z-index:2;padding:1.5rem!important}.date-card-content h2{text-shadow:0 1px 3px rgba(255,255,255,.8)}.date-card-content h3{text-shadow:0 1px 2px rgba(255,255,255,.7)}.date-card-content h5{text-shadow:0 1px 2px rgba(255,255,255,.6)}@media(max-width:576px){.date-card-with-bg{min-height:150px}.date-card-bg{background-position:center center}.date-card-bg:before{background:linear-gradient(to bottom,rgba(255,255,255,.75),rgba(255,255,255,.65))}}
