@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #d4a84333}50%{box-shadow:0 0 40px #d4a84366}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes tick{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(170deg,#0a1628,#0d2137 40%,#0e4d5c);color:#e0e8f0;min-height:100vh;line-height:1.6;overflow-x:hidden;position:relative}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 600px 400px at 20% 10%,rgba(26,107,60,.15) 0%,transparent 70%),radial-gradient(ellipse 500px 300px at 80% 80%,rgba(212,168,67,.08) 0%,transparent 70%);pointer-events:none;z-index:0}.stars-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.stars-bg .star{position:absolute;width:3px;height:3px;background:#fff9;border-radius:50%;animation:float 4s ease-in-out infinite}.stars-bg .star:nth-child(1){top:97%;left:28%;animation-delay:3656ms;animation-duration:7s;width:2px;height:3px;opacity:.4}.stars-bg .star:nth-child(2){top:45%;left:86%;animation-delay:3466ms;animation-duration:4s;width:4px;height:3px;opacity:.87}.stars-bg .star:nth-child(3){top:60%;left:27%;animation-delay:2955ms;animation-duration:4s;width:4px;height:3px;opacity:.64}.stars-bg .star:nth-child(4){top:2%;left:41%;animation-delay:3711ms;animation-duration:7s;width:2px;height:2px;opacity:.63}.stars-bg .star:nth-child(5){top:32%;left:60%;animation-delay:371ms;animation-duration:7s;width:4px;height:2px;opacity:.75}.stars-bg .star:nth-child(6){top:85%;left:55%;animation-delay:216ms;animation-duration:7s;width:4px;height:4px;opacity:.99}.stars-bg .star:nth-child(7){top:30%;left:52%;animation-delay:1.23s;animation-duration:6s;width:4px;height:3px;opacity:.36}.stars-bg .star:nth-child(8){top:92%;left:83%;animation-delay:2436ms;animation-duration:6s;width:3px;height:2px;opacity:.68}.stars-bg .star:nth-child(9){top:20%;left:100%;animation-delay:2.33s;animation-duration:6s;width:3px;height:3px;opacity:.7}.stars-bg .star:nth-child(10){top:78%;left:12%;animation-delay:76ms;animation-duration:4s;width:2px;height:2px;opacity:.32}.stars-bg .star:nth-child(11){top:62%;left:88%;animation-delay:1476ms;animation-duration:5s;width:4px;height:2px;opacity:.51}.stars-bg .star:nth-child(12){top:85%;left:66%;animation-delay:3691ms;animation-duration:6s;width:4px;height:4px;opacity:.49}.stars-bg .star:nth-child(13){top:78%;left:88%;animation-delay:1753ms;animation-duration:5s;width:3px;height:2px;opacity:.8}.stars-bg .star:nth-child(14){top:61%;left:27%;animation-delay:3365ms;animation-duration:5s;width:3px;height:4px;opacity:.35}.stars-bg .star:nth-child(15){top:25%;left:59%;animation-delay:3205ms;animation-duration:7s;width:4px;height:3px;opacity:.42}.stars-bg .star:nth-child(16){top:99%;left:60%;animation-delay:3529ms;animation-duration:5s;width:4px;height:4px;opacity:.46}.stars-bg .star:nth-child(17){top:45%;left:19%;animation-delay:.21s;animation-duration:7s;width:3px;height:2px;opacity:.56}.stars-bg .star:nth-child(18){top:52%;left:25%;animation-delay:2565ms;animation-duration:7s;width:3px;height:4px;opacity:.85}.stars-bg .star:nth-child(19){top:65%;left:97%;animation-delay:3173ms;animation-duration:6s;width:3px;height:2px;opacity:.93}.stars-bg .star:nth-child(20){top:11%;left:49%;animation-delay:1907ms;animation-duration:4s;width:4px;height:4px;opacity:.73}.stars-bg .star:nth-child(21){top:14%;left:3%;animation-delay:2062ms;animation-duration:7s;width:4px;height:2px;opacity:.7}.stars-bg .star:nth-child(22){top:33%;left:34%;animation-delay:1092ms;animation-duration:4s;width:2px;height:2px;opacity:.67}.stars-bg .star:nth-child(23){top:87%;left:25%;animation-delay:.91s;animation-duration:7s;width:4px;height:4px;opacity:.55}.stars-bg .star:nth-child(24){top:88%;left:76%;animation-delay:2611ms;animation-duration:7s;width:2px;height:3px;opacity:.94}.stars-bg .star:nth-child(25){top:97%;left:79%;animation-delay:766ms;animation-duration:5s;width:3px;height:4px;opacity:.63}.app-container{position:relative;z-index:1;max-width:480px;margin:0 auto;padding:0 16px 100px}.header{text-align:center;padding:40px 0 20px;position:relative}.header .mosque-silhouette{width:100%;max-width:320px;margin:0 auto;height:80px;position:relative}.header .mosque-silhouette svg{width:100%;height:100%;fill:#d4a84326}.header .bismillah{font-family:Amiri,Traditional Arabic,serif;font-size:1.5rem;color:#d4a843;margin-bottom:8px;direction:rtl}.header h1{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.5px;line-height:1.2}.header h1 .year{display:block;font-size:1rem;font-weight:600;letter-spacing:4px;color:#2d9e5a;margin-bottom:4px}.header .city-selector-wrapper{display:inline-flex;align-items:center;gap:6px;margin-top:10px}.header .city-selector-wrapper .pin-icon{font-size:1rem}.header .city-selector-wrapper .city-selector{appearance:none;-webkit-appearance:none;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#e0e8f0;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:1rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;padding:8px 32px 8px 14px;cursor:pointer;transition:border-color .2s ease,background .2s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238a9bb5' viewBox='0 0 16 16'%3E%3Cpath d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.header .city-selector-wrapper .city-selector:focus{outline:none;border-color:#d4a843;background-color:#ffffff1f}.header .city-selector-wrapper .city-selector option{background:#0a1628;color:#e0e8f0}.header .ahmadiyya-badge{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 16px;background:#1a6b3c40;border:1px solid rgba(26,107,60,.4);border-radius:20px;font-size:.75rem;color:#2d9e5a;letter-spacing:.5px}.today-card{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;padding:24px;margin:20px 0;animation:fade-in-up .6s ease-out}.today-card .today-date{font-size:.9rem;color:#8a9bb5;margin-bottom:4px}.today-card .today-day-number{font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:16px}.today-card .times-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.today-card .time-box{background:#ffffff14;border-radius:16px;padding:16px;text-align:center;border:1px solid rgba(255,255,255,.06);transition:transform .3s ease,box-shadow .3s ease}.today-card .time-box:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.today-card .time-box .time-label{font-size:.75rem;text-transform:uppercase;letter-spacing:1.5px;color:#8a9bb5;margin-bottom:8px}.today-card .time-box .time-value{font-size:1.8rem;font-weight:700;font-variant-numeric:tabular-nums}.today-card .time-box.sahar .time-value{color:#7ec8e3}.today-card .time-box.iftar .time-value{color:#d4a843}.today-card .time-box .time-icon{font-size:1.2rem;margin-bottom:4px}.today-card .section-label{text-align:center;margin-top:12px;padding:6px 0;font-size:.8rem;color:#2d9e5a;font-style:italic}.countdown-section{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;padding:28px 24px;margin:20px 0;text-align:center;animation:fade-in-up .6s ease-out .1s both}.countdown-section.active{animation:pulse-glow 3s ease-in-out infinite}.countdown-section .countdown-label{font-size:.9rem;text-transform:uppercase;letter-spacing:2px;color:#8a9bb5;margin-bottom:16px}.countdown-section .countdown-timer{font-size:3.2rem;font-weight:800;font-variant-numeric:tabular-nums;color:#2d9e5a;line-height:1;animation:tick 1s ease-in-out infinite}.countdown-section .countdown-timer.phase-sahar{color:#7ec8e3}.countdown-section .countdown-units{display:flex;justify-content:center;gap:32px;margin-top:8px}.countdown-section .countdown-units span{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:#8a9bb5}.countdown-section .countdown-status{font-size:1.2rem;margin-top:8px;color:#d4a843}.countdown-section .countdown-message{font-size:1.4rem;font-weight:600;color:#d4a843;padding:16px 0}.quran-card{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;padding:24px;margin:20px 0;text-align:center;border-left:3px solid #1a6b3c;animation:fade-in-up .6s ease-out .2s both}.quran-card .quran-arabic{font-family:Amiri,Traditional Arabic,serif;font-size:1.35rem;color:#f0d078;line-height:2;direction:rtl;margin-bottom:12px}.quran-card .quran-german{font-size:.85rem;color:#8a9bb5;font-style:italic;line-height:1.6}.dua-card{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;padding:24px;margin:20px 0;text-align:center;position:relative;overflow:hidden;animation:fade-in-up .6s ease-out .3s both}.dua-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#1a6b3c,#d4a843,#1a6b3c)}.dua-card .dua-title{font-size:1.1rem;font-weight:600;color:#d4a843;margin-bottom:16px;text-decoration:underline;text-underline-offset:4px;text-decoration-color:#d4a8434d}.dua-card .dua-arabic{font-family:Amiri,Traditional Arabic,serif;font-size:1.6rem;color:#f0d078;line-height:2.2;direction:rtl;margin-bottom:12px}.dua-card .dua-urdu{font-family:Amiri,Traditional Arabic,serif;font-size:1.1rem;color:#e0e8f0;line-height:2;direction:rtl;margin-bottom:12px}.dua-card .dua-german{font-size:.9rem;color:#8a9bb5;font-style:italic;line-height:1.6;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.timetable-section{margin:30px 0;animation:fade-in-up .6s ease-out .4s both}.timetable-section .timetable-header{text-align:center;margin-bottom:20px}.timetable-section .timetable-header h2{font-size:1.5rem;font-weight:700;color:#fff}.timetable-section .timetable-header .timetable-subtitle{color:#8a9bb5;font-size:.85rem;letter-spacing:2px;text-transform:uppercase;margin-top:4px}.timetable-section .section-badges{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.timetable-section .section-badges .section-badge{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-radius:8px;font-size:.8rem}.timetable-section .section-badges .section-badge .section-urdu{font-family:Amiri,Traditional Arabic,serif;direction:rtl;font-size:.95rem}.timetable-section .section-badges .section-badge .section-label{flex:1;text-align:center;font-weight:500}.timetable-section .section-badges .section-badge .section-days{font-weight:600;font-size:.75rem;opacity:.8}.timetable-section .section-badges .section-badge.section-0{background:#1a6b3c33;border:1px solid rgba(26,107,60,.35);color:#6ddc8e}.timetable-section .section-badges .section-badge.section-1{background:#d4a84326;border:1px solid rgba(212,168,67,.3);color:#f0d078}.timetable-section .section-badges .section-badge.section-2{background:#7ec8e326;border:1px solid rgba(126,200,227,.3);color:#a8dcef}.timetable-section .table-wrapper{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;overflow:hidden;padding:0}.timetable-section .ramadan-table{width:100%;border-collapse:collapse;font-size:.85rem}.timetable-section .ramadan-table thead{background:#1a6b3c4d}.timetable-section .ramadan-table thead th{padding:12px 8px;text-align:center;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:1px;color:#f0d078;border-bottom:2px solid rgba(26,107,60,.5)}.timetable-section .ramadan-table tbody tr{border-bottom:1px solid rgba(255,255,255,.04);transition:background .2s ease}.timetable-section .ramadan-table tbody tr:hover{background:#ffffff08}.timetable-section .ramadan-table tbody tr td{padding:10px 8px;text-align:center}.timetable-section .ramadan-table tbody tr .day-num{font-weight:700;color:#8a9bb5}.timetable-section .ramadan-table tbody tr .time-sahar{color:#7ec8e3;font-weight:600;font-variant-numeric:tabular-nums}.timetable-section .ramadan-table tbody tr .time-iftar{color:#d4a843;font-weight:600;font-variant-numeric:tabular-nums}.timetable-section .ramadan-table tbody .today-row{background:#1a6b3c40!important;border-left:3px solid #2d9e5a;position:relative}.timetable-section .ramadan-table tbody .today-row td{font-weight:600;color:#fff}.timetable-section .ramadan-table tbody .today-row .day-num{color:#d4a843}.timetable-section .ramadan-table tbody .section-divider td{padding:8px;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.timetable-section .ramadan-table tbody .section-divider.section-divider-0 td{background:#1a6b3c26;color:#6ddc8e}.timetable-section .ramadan-table tbody .section-divider.section-divider-1 td{background:#d4a8431a;color:#f0d078}.timetable-section .ramadan-table tbody .section-divider.section-divider-2 td{background:#7ec8e31a;color:#a8dcef}.timetable-section .eid-notice{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;margin-top:16px;font-size:1rem;color:#d4a843;border:1px solid rgba(212,168,67,.3)}.timetable-section .eid-notice .eid-icon{font-size:1.4rem}.timetable-section .shawwal-section{margin-top:24px;text-align:center}.timetable-section .shawwal-section h3{font-family:Amiri,Traditional Arabic,serif;font-size:1.3rem;color:#d4a843;direction:rtl;margin-bottom:4px}.timetable-section .shawwal-section .shawwal-subtitle{font-size:.85rem;color:#8a9bb5;margin-bottom:16px;font-style:italic}.timetable-section .shawwal-section .shawwal-table thead{background:#d4a84326}.timetable-section .shawwal-section .shawwal-table thead th{border-bottom-color:#d4a8434d}.footer-section{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;padding:20px 24px;margin:20px 0;text-align:center;animation:fade-in-up .6s ease-out .5s both}.footer-section .footer-org{font-size:.8rem;color:#2d9e5a;font-weight:600;margin-bottom:12px;letter-spacing:.5px}.footer-section .footer-info{display:grid;grid-template-columns:1fr 1fr;gap:10px}.footer-section .footer-info .info-item{padding:8px;background:#ffffff14;border-radius:8px;font-size:.75rem;color:#8a9bb5}.footer-section .footer-info .info-item strong{display:block;color:#e0e8f0;font-size:.85rem;margin-bottom:2px}.footer-section .footer-bottom{margin-top:16px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08);font-size:.7rem;color:#8a9bb5}.nav-dots{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px;padding:8px 16px;background:#0a1628e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;border:1px solid rgba(255,255,255,.1);z-index:100}.nav-dots .nav-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#8a9bb5;font-size:1rem;cursor:pointer;transition:all .3s ease}.nav-dots .nav-dot:hover,.nav-dots .nav-dot.active{color:#d4a843;background:#d4a84326}@media(min-width:600px){.app-container{max-width:520px;padding:0 24px 80px}.header h1{font-size:2.4rem}.countdown-section .countdown-timer{font-size:4rem}}@media(max-width:360px){.header h1{font-size:1.6rem}.countdown-section .countdown-timer{font-size:2.4rem}.today-card .time-box .time-value{font-size:1.4rem}.ramadan-table{font-size:.8rem}}.install-banner{background:#0d2137d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 8px 32px #0000004d;position:fixed;bottom:70px;left:16px;right:16px;max-width:448px;margin:0 auto;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:200;border:1px solid rgba(26,107,60,.4);animation:fade-in-up .4s ease-out}.install-banner.hidden{display:none}.install-banner .install-text{font-size:.85rem;color:#e0e8f0}.install-banner .install-text strong{color:#d4a843}.install-banner .install-btn{padding:8px 18px;background:linear-gradient(135deg,#1a6b3c,#0d4a25);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .2s ease}.install-banner .install-btn:hover{transform:scale(1.05)}.install-banner .install-dismiss{background:none;border:none;color:#8a9bb5;cursor:pointer;font-size:1.2rem;padding:4px}.install-banner .install-dismiss:hover{color:#e0e8f0}.install-banner.ios-install-banner,.install-banner.android-fallback-banner{flex-wrap:wrap}.install-banner.ios-install-banner .install-text,.install-banner.android-fallback-banner .install-text{flex:1;display:inline-flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:.82rem;line-height:1.5}.install-banner.ios-install-banner .ios-share-icon,.install-banner.android-fallback-banner .ios-share-icon{display:inline-block;vertical-align:middle;color:#d4a843;margin:0 2px}.azan-toggle{position:relative}.azan-toggle.azan-active{color:#d4a843!important;background:#d4a84333!important}.azan-toggle.azan-active:after{content:"";position:absolute;bottom:4px;left:50%;transform:translate(-50%);width:6px;height:6px;border-radius:50%;background:#d4a843}
