:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#b45309;--accent-light:#fef3c7;--accent-hover:#92400e;--border-color:#e2e8f0;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--glass-bg:#fffc;--glass-border:#f1f5f9cc;--font-sans:"Cairo", "Inter", system-ui, -apple-system, sans-serif;--font-serif:"Amiri", Georgia, serif;--card-radius:16px;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1)}.dark{--bg-primary:#090a10;--bg-secondary:#121420;--bg-tertiary:#1b1e32;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#f59e0b;--accent-light:#f59e0b26;--accent-hover:#fbbf24;--border-color:#ffffff14;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #0000004d, 0 2px 4px -1px #0003;--shadow-lg:0 20px 25px -5px #0006, 0 10px 10px -5px #0000004d;--glass-bg:#121420b3;--glass-border:#ffffff0d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);transition:var(--transition-smooth);min-height:100vh;line-height:1.5;position:relative;overflow-x:hidden}body:before{content:"";opacity:.03;z-index:-1;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 80 80'%3E%3Cpath d='M40 0l40 40-40 40L0 40z' fill='none' stroke='%2523000' stroke-width='1'/%3E%3Ccircle cx='40' cy='40' r='15' fill='none' stroke='%2523000' stroke-width='1'/%3E%3Ccircle cx='40' cy='40' r='25' fill='none' stroke='%2523000' stroke-width='1'/%3E%3Cpath d='M0 0h80v80H0z' fill='none' stroke='%2523000' stroke-width='0.5'/%3E%3C/svg%3E");background-repeat:repeat;width:100vw;height:100vh;position:fixed;top:0;left:0}.dark:before{opacity:.06;filter:invert()}#root{flex-direction:column;gap:24px;width:100%;max-width:1200px;min-height:100vh;margin:0 auto;padding:24px 16px;display:flex}header{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);z-index:1000;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:relative}.brand-section{align-items:center;gap:16px;display:flex}.brand-icon-wrapper{background:var(--accent-light);color:var(--accent);width:48px;height:48px;box-shadow:var(--shadow-sm);border-radius:12px;justify-content:center;align-items:center;font-size:24px;display:flex}.title-area h1{font-size:22px;font-weight:700;line-height:1.2}.title-area .arabic-text{font-family:var(--font-serif);color:var(--accent);margin-top:4px;font-size:26px}.header-controls{align-items:center;gap:12px;display:flex}button.btn-icon{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;width:42px;height:42px;transition:var(--transition-smooth);border-radius:10px;justify-content:center;align-items:center;font-size:18px;display:flex}button.btn-icon:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.city-selector-container{z-index:1010;width:100%;max-width:450px;position:relative}.search-input-wrapper{align-items:center;display:flex;position:relative}.search-input{border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);font-family:var(--font-sans);transition:var(--transition-smooth);border-radius:10px;padding:12px 16px 12px 42px;font-size:15px}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.search-icon{color:var(--text-muted);font-size:16px;position:absolute;left:14px}.current-loc-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);border-radius:6px;padding:6px 10px;font-size:12px;font-weight:600;position:absolute;right:8px}.current-loc-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.suggestions-dropdown{background:var(--bg-secondary);border:1px solid var(--border-color);width:100%;box-shadow:var(--shadow-lg);z-index:1020;border-radius:10px;max-height:250px;margin-top:6px;position:absolute;top:100%;left:0;overflow:hidden auto}.suggestion-item{cursor:pointer;transition:var(--transition-smooth);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:var(--bg-tertiary);color:var(--accent)}.suggestion-name{font-weight:500}.suggestion-dept{color:var(--text-muted);font-size:12px}.bottom-widgets-row{flex-direction:row;gap:24px;width:100%;margin-top:12px;display:flex}.bottom-widgets-row>div,.bottom-widgets-row>aside{flex:1 1 0;min-width:0}@media (width<=960px){.bottom-widgets-row{flex-flow:wrap;justify-content:center;gap:16px;display:flex}.bottom-widgets-row>div,.bottom-widgets-row>aside{flex:calc(50% - 16px);min-width:280px}}.hero-mosque-display{background:linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-md);transition:var(--transition-smooth);grid-template-columns:1fr 2.2fr 1fr;align-items:center;padding:32px;display:grid;position:relative;overflow:hidden}.dark .hero-mosque-display{background:linear-gradient(135deg,#121422 0%,#090a10 100%);border-color:#ffffff0d}.hero-mosque-display:after{content:"";background:var(--accent-light);filter:blur(90px);pointer-events:none;z-index:0;border-radius:50%;width:250px;height:250px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.mosque-left-slot,.mosque-right-slot,.mosque-center-clock{z-index:1;position:relative}.mosque-left-slot{text-align:left;flex-direction:column;align-items:flex-start;display:flex}.mosque-right-slot{text-align:right;flex-direction:column;align-items:flex-end;display:flex}.mosque-center-clock{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.slot-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-size:13px;font-weight:700}.slot-time{color:var(--text-primary);margin-top:4px;font-size:36px;font-weight:850}.slot-countdown{color:var(--accent);margin-top:2px;font-size:15px;font-weight:700}.running-clock{font-variant-numeric:tabular-nums;color:var(--text-primary);letter-spacing:-2px;margin-bottom:8px;font-size:72px;font-weight:800;line-height:1}.running-date-fr{color:var(--text-secondary);font-size:20px;font-weight:700}.running-date-hijri{font-family:var(--font-serif);color:var(--accent);margin-top:4px;font-size:19px;font-weight:700}.location-badge-mosque{color:var(--text-muted);background:var(--bg-tertiary);border-radius:20px;margin-top:10px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.mosque-progress-bar-container{background:var(--border-color);width:100%;height:6px;position:absolute;bottom:0;left:0;overflow:hidden}.progress-bar{background:var(--accent);height:100%;transition:width 1s linear}.prayer-list{flex-direction:row;justify-content:space-between;gap:16px;width:100%;margin-top:24px;display:flex}.prayer-card{background:var(--bg-secondary);border:1px solid var(--border-color);text-align:center;box-shadow:var(--shadow-sm);transition:var(--transition-smooth);border-radius:14px;flex-direction:column;flex:1 1 0;align-items:center;padding:24px 12px;display:flex;position:relative}.prayer-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent);transform:translateY(-4px)}.prayer-card.active{background-color:#10b98114;border-color:#10b981;box-shadow:0 0 20px #10b98126}.dark .prayer-card.active{background-color:#10b98126;border-color:#10b981;box-shadow:0 0 24px #10b98140}.prayer-card.active .prayer-arabic,.prayer-card.active .prayer-icon{color:#10b981}.prayer-icon{color:var(--text-muted);transition:var(--transition-smooth);margin-bottom:8px;font-size:24px}.prayer-card.active .prayer-icon,.prayer-card:hover .prayer-icon{color:var(--accent);transform:scale(1.1)}.prayer-name{margin-bottom:2px;font-size:16px;font-weight:700}.prayer-arabic{font-family:var(--font-serif);color:var(--text-muted);margin-bottom:6px;font-size:18px}.prayer-card.active .prayer-arabic{color:var(--accent)}.prayer-time{font-variant-numeric:tabular-nums;font-size:22px;font-weight:800}.sidebar-panel{flex-direction:column;gap:24px;display:flex}.widget-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);box-shadow:var(--shadow-sm);transition:var(--transition-smooth);flex-direction:column;min-height:250px;padding:24px;display:flex}.widget-title{border-bottom:1px solid var(--border-color);align-items:center;gap:8px;margin-bottom:16px;padding-bottom:10px;font-size:16px;font-weight:700;display:flex}.widget-icon{color:var(--accent)}.compass-wrapper{flex-direction:column;align-items:center;gap:16px;display:flex}.compass-container{background:var(--bg-tertiary);border:4px solid var(--border-color);border-radius:50%;justify-content:center;align-items:center;width:180px;height:180px;display:flex;position:relative;box-shadow:inset 0 2px 4px #0000001a}.compass-rose{border-radius:50%;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute}.compass-direction{color:var(--text-muted);font-size:12px;font-weight:800;position:absolute}.compass-direction.north{top:8px}.compass-direction.south{bottom:8px}.compass-direction.east{right:8px}.compass-direction.west{left:8px}.qibla-needle{transform-origin:50%;width:8px;height:140px;transition:transform .5s ease-out;position:relative}.qibla-needle:before{content:"";border-bottom:40px solid #ef4444;border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0;position:absolute;top:0;left:50%;transform:translate(-50%)}.qibla-needle:after{content:"";border-left:8px solid #0000;border-right:8px solid #0000;border-top:40px solid var(--text-muted);width:0;height:0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.compass-center{background:var(--accent);border:3px solid var(--bg-secondary);z-index:10;border-radius:50%;width:16px;height:16px;position:absolute}.qibla-angle-info{text-align:center;font-size:14px;font-weight:600}.qibla-degree{color:var(--accent);font-weight:700}.calendar-trigger-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);width:100%;font-family:var(--font-sans);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px;font-weight:600;display:flex}.calendar-trigger-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0006;justify-content:center;align-items:center;width:100vw;height:100vh;padding:16px;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--card-radius);width:100%;max-width:800px;max-height:85vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{font-size:18px;font-weight:700}.modal-close-btn{cursor:pointer;color:var(--text-secondary);transition:var(--transition-smooth);background:0 0;border:none;font-size:24px}.modal-close-btn:hover{color:var(--accent)}.modal-body{padding:20px 24px;overflow-x:auto}.calendar-table{border-collapse:collapse;width:100%;font-size:14px}.calendar-table th{background:var(--bg-tertiary);color:var(--text-secondary);text-align:center;border-bottom:2px solid var(--border-color);padding:10px 12px;font-weight:600}.calendar-table td{border-bottom:1px solid var(--border-color);text-align:center;padding:10px 12px}.calendar-table tr.current-day td{background:var(--accent-light);font-weight:700}.dark .calendar-table tr.current-day td{background:#f59e0b26}.loading-container,.error-container{background:var(--bg-secondary);border-radius:var(--card-radius);border:1px solid var(--border-color);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:300px;padding:32px;display:flex}.spinner{border:4px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-container h3{color:#ef4444;font-size:18px}.error-container button{background:var(--accent);color:#fff;cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:8px;padding:10px 20px;font-weight:600}.error-container button:hover{background:var(--accent-hover)}.modal-tabs{border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);gap:8px;padding:0 24px;display:flex}.modal-tab{cursor:pointer;color:var(--text-secondary);transition:var(--transition-smooth);font-size:14px;font-weight:600;font-family:var(--font-sans);background:0 0;border:none;padding:12px 20px}.modal-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-tab:hover{color:var(--accent-hover)}.calendar-controls-bar{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;padding:12px 16px;display:flex}.calendar-control-group{flex-direction:column;gap:6px;display:flex}.calendar-control-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:11px;font-weight:700}.calendar-select,.calendar-date-input{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-family:var(--font-sans);transition:var(--transition-smooth);border-radius:6px;padding:8px 12px;font-size:14px}.calendar-select:focus,.calendar-date-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light);outline:none}.daily-info-header{background:linear-gradient(135deg, var(--bg-secondary) 0%, var(--bg-tertiary) 100%);border:1px solid var(--border-color);border-radius:var(--card-radius);text-align:center;margin-bottom:20px;padding:20px}.dark .daily-info-header{background:linear-gradient(135deg,#121422 0%,#090a10 100%)}.daily-timings-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-top:16px;display:grid}@media (width<=480px){.daily-timings-grid{grid-template-columns:1fr 1fr}}.daily-timing-card{background:var(--bg-secondary);border:1px solid var(--border-color);text-align:center;transition:var(--transition-smooth);box-shadow:var(--shadow-sm);border-radius:10px;padding:16px 12px}.daily-timing-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.daily-timing-name{color:var(--text-primary);margin-bottom:2px;font-size:14px;font-weight:700}.daily-timing-arabic{font-family:var(--font-serif);color:var(--text-muted);margin-bottom:6px;font-size:15px}.daily-timing-val{color:var(--accent);font-size:20px;font-weight:800}footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);margin-top:auto;padding:24px 0;font-size:13px}footer a{color:var(--accent);font-weight:600;text-decoration:none}footer a:hover{text-decoration:underline}@media (width<=768px){#root{gap:16px;padding:16px 12px}header{flex-direction:column;align-items:stretch;gap:14px;padding:16px}.brand-section{justify-content:center}.title-area h1{text-align:center;font-size:18px}.title-area .arabic-text{text-align:center;margin-top:2px;font-size:20px}.header-controls{justify-content:space-between;align-items:center;gap:8px;width:100%;display:flex}.city-selector-container{flex:1;min-width:0;max-width:none}.search-input{padding:10px 12px 10px 36px;font-size:14px}.search-icon{left:10px}.current-loc-btn{padding:4px 8px;font-size:11px}button.btn-icon{border-radius:8px;width:38px;height:38px;font-size:16px}.hero-mosque-display{grid-template-columns:1fr 1fr;gap:20px;padding:24px 16px}.mosque-center-clock{order:-1;grid-column:span 2}.running-clock{margin-bottom:4px;font-size:46px}.running-date-fr,.running-date-hijri{font-size:16px}.mosque-left-slot{text-align:center;border-right:1px solid var(--border-color);align-items:center;padding-right:8px}.mosque-right-slot{text-align:center;align-items:center;padding-left:8px}.slot-label{font-size:11px}.slot-time{font-size:26px}.slot-countdown{font-size:13px}.prayer-list{flex-direction:column;gap:8px;margin-top:8px}.prayer-card{text-align:left;border-radius:12px;flex-direction:row;justify-content:space-between;align-items:center;width:100%;padding:14px 20px}.prayer-card:hover{transform:none}.prayer-icon{align-items:center;margin-bottom:0;margin-right:12px;font-size:20px;display:flex}.prayer-name{flex:1;font-size:15px}.prayer-arabic{text-align:right;margin-bottom:0;margin-right:16px;font-size:16px}.prayer-time{font-size:18px;font-weight:700}}.pdf-export-btn{background:var(--accent);color:#fff;border:1px solid var(--accent);font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border-radius:8px;align-items:center;gap:8px;margin-left:auto;padding:8px 16px;font-size:14px;display:flex}.pdf-export-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-1px)}@media (width<=600px){.pdf-export-btn{justify-content:center;width:100%;margin-left:0}}@media print{#root>:not(.modal-overlay){display:none!important}body{color:#000!important;background:#fff!important}.modal-overlay{-webkit-backdrop-filter:none!important;background:0 0!important;width:100%!important;height:auto!important;padding:0!important;display:block!important;position:absolute!important;top:0!important;left:0!important}.modal-content{box-shadow:none!important;background:#fff!important;border:none!important;width:100%!important;max-height:none!important;padding:0!important;overflow:visible!important}.modal-tabs,.calendar-controls-bar,.modal-close-btn{display:none!important}.modal-header{border-bottom:2px solid #333!important;margin-bottom:20px!important;padding:10px 0!important}.modal-title{text-align:center;width:100%;color:#000!important;font-size:24px!important}.modal-body{padding:0!important}.calendar-table{border-collapse:collapse!important;width:100%!important;margin-top:10px!important}.calendar-table th{-webkit-print-color-adjust:exact;print-color-adjust:exact;color:#000!important;background-color:#f1f5f9!important;border-bottom:2px solid #cbd5e1!important;font-weight:700!important}.calendar-table td{color:#000!important;border-bottom:1px solid #e2e8f0!important;padding:8px 10px!important}.calendar-table tr.current-day td{-webkit-print-color-adjust:exact;print-color-adjust:exact;background-color:#fef3c7!important;font-weight:700!important}.daily-info-header{-webkit-print-color-adjust:exact;print-color-adjust:exact;color:#000!important;background:#f8fafc!important;border:1px solid #cbd5e1!important;border-radius:8px!important;margin-bottom:24px!important;padding:16px!important}.daily-timings-grid{grid-template-columns:repeat(3,1fr)!important;gap:16px!important;display:grid!important}.daily-timing-card{page-break-inside:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact;box-shadow:none!important;color:#000!important;background:#fff!important;border:1px solid #cbd5e1!important;border-radius:8px!important}.daily-timing-name{color:#475569!important;font-size:14px!important}.daily-timing-arabic{color:#94a3b8!important;font-size:15px!important}.daily-timing-val{color:#b45309!important;font-size:22px!important;font-weight:800!important}}
