:root{--bg:#f6f8fb;--surface:#fff;--surface-muted:#f0f4fa;--text:#0f172a;--text-muted:#475569;--border:#dbe4f0;--primary:#0f4c81;--primary-hover:#0d416f;--radius-md:12px;--radius-lg:20px;--shadow-sm:0 6px 20px #0f4c8114;--max-content:1120px}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{color:var(--text);background:linear-gradient(180deg, #f8fbff 0%, var(--bg) 40%);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin:0}#root{min-height:100vh}.container{width:min(var(--max-content), calc(100% - 2rem));margin-inline:auto}.app-shell{flex-direction:column;min-height:100vh;display:flex}.page-main{flex:1;padding-block:1.75rem 2.75rem}.page-main-home{padding-block:0}.site-header{z-index:20;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);background:#f8fbfff0;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;gap:1rem;min-height:102px;display:flex}.brand{flex-shrink:0;align-items:center;display:inline-flex}.header-logo-left{object-fit:contain;width:auto;height:76px}.header-logo-right{object-fit:contain;flex-shrink:0;width:auto;height:82px}.top-nav{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.city-link{color:var(--text-muted);border-radius:999px;padding:.45rem .75rem;font-weight:600}.city-link:hover{background:var(--surface-muted);color:var(--text)}.is-disabled{opacity:.5;pointer-events:none}.site-footer{border-top:1px solid var(--border);background:var(--surface)}.footer-inner{color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;gap:.5rem;padding:1rem 0;font-size:.92rem;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.4rem}.stack-lg{gap:1.2rem;display:grid}.home-with-background{border-radius:0;width:100vw;min-height:calc(100vh - 102px);margin-inline:calc(50% - 50vw);position:relative;overflow:hidden}.home-background{background-position:50%;background-repeat:no-repeat;background-size:cover;transition:background-image .7s ease-in-out;position:absolute;inset:0}.home-background-overlay{background:linear-gradient(#02081738 0%,#0208176b 58%,#02081780 100%);position:absolute;inset:0}.home-background.fallback{background:linear-gradient(180deg, #f8fbff 0%, var(--bg) 70%)}.home-content{z-index:1;width:min(var(--max-content), calc(100% - 2rem));margin-inline:auto;padding:1.2rem 0;position:relative}.home-page .home-content.stack-lg{gap:0;margin-block:0;padding-block:0}.home-with-background .card{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffe6}.eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:.3rem;font-size:.78rem}h1{font-size:clamp(1.6rem,2.5vw,2.35rem);line-height:1.2}h2{margin-bottom:.3rem;font-size:clamp(1.2rem,2vw,1.6rem)}h3{font-size:1.1rem;line-height:1.3}.lead{color:var(--text-muted);margin-top:.5rem}.hero-section{padding:clamp(1.35rem,2vw,2rem)}.hero-centered{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.85rem;min-height:calc(100vh - 170px);display:flex}.hero-center-logo{object-fit:contain;width:min(260px,70vw);height:auto}.hero-title{color:#fff;text-shadow:0 3px 18px #00000073;font-size:clamp(2rem,5.8vw,4rem);font-weight:500;line-height:1.15}.hero-arabic{color:#fff;text-shadow:0 3px 18px #0006;font-size:clamp(2rem,6.2vw,4.25rem);font-weight:700;line-height:1.05}.hero-subtitle{color:#fffffff2;text-shadow:0 2px 14px #00000073;font-size:clamp(1rem,2.3vw,1.15rem);font-weight:500}.hero-actions{flex-wrap:wrap;justify-content:center;gap:.65rem;margin-top:.4rem;display:flex}.hero-centered .btn-primary{background:#12775f;min-width:190px;min-height:3rem;font-size:1.05rem}.hero-centered .btn-primary:hover{background:#0f6651}.hero-store-links{flex-wrap:wrap;justify-content:center;align-items:center;gap:.95rem;margin-top:.4rem;display:flex}.store-link{border-radius:14px;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.store-badge{object-fit:contain;filter:drop-shadow(0 2px 10px #00000038);border-radius:14px;width:auto;height:54px}.social-badge{object-fit:cover;filter:drop-shadow(0 2px 10px #0000003d);border-radius:14px;width:58px;height:58px}.btn{border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;min-height:2.6rem;padding:.45rem .9rem;font-size:.95rem;font-weight:600;transition:all .12s ease-in-out;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-secondary:hover{background:var(--surface-muted)}.city-grid,.mosque-grid{gap:1rem;display:grid}.city-grid{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.city-card{gap:.55rem;display:grid}.city-meta{color:var(--text-muted);font-size:.86rem;font-weight:600}.search-filter{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.9rem;display:grid}.search-field{gap:.35rem;display:grid}.search-field label{color:var(--text-muted);font-size:.88rem;font-weight:600}.search-field input,.search-field select{border:1px solid var(--border);width:100%;min-height:2.6rem;color:var(--text);background:#fff;border-radius:10px;padding:.55rem .65rem;font-size:.95rem}.mosque-grid{grid-template-columns:repeat(3,minmax(0,1fr))}@media (width<=1024px){.mosque-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.mosque-card{padding:0;overflow:hidden}.mosque-card-link{color:inherit;display:block}.mosque-open-btn{background:#106851}.mosque-open-btn:hover{background:#0d5b46}.mosque-card img{aspect-ratio:16/10;object-fit:cover;width:100%;display:block}.mosque-card-content{gap:.5rem;padding:1rem;display:grid}.mosque-meta,.mosque-address,.mosque-arabic{color:var(--text-muted)}.listener-head .mosque-arabic{margin-top:.35rem}.listener-title{font-size:clamp(1.25rem,3.2vw,1.9rem);line-height:1.25}.listener-panel{gap:.9rem;display:grid}.listener-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:.8rem;display:flex}.iframe-wrap{border:1px solid var(--border);background:#fff;border-radius:14px;width:100%;position:relative;overflow:visible}.iframe-wrap iframe{border:0;width:100%;min-height:72vh;display:block}.iframe-wrap.is-muted{opacity:.65}.muted-badge{color:#fff;background:#020817d9;border-radius:999px;padding:.2rem .5rem;font-size:.75rem;position:absolute;top:.8rem;right:.8rem}.listener-note{color:var(--text-muted);font-size:.92rem}.apps-section{gap:.75rem;display:grid}.app-links,.city-switch-links{flex-wrap:wrap;gap:.6rem;display:flex}.empty-state{gap:.8rem;display:grid}.listener-mini-head{border-bottom:1px solid var(--border);align-items:center;gap:.65rem;margin-bottom:.25rem;padding-bottom:.65rem;display:flex}.listener-nav-back{min-width:44px;min-height:44px;color:var(--primary);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;margin:-.35rem 0 -.35rem -.35rem;padding:.35rem;font-size:.95rem;font-weight:600;display:inline-flex}.listener-nav-back--icon-only .listener-nav-back-icon{font-size:1.35rem;line-height:1}.listener-nav-back:hover{background:var(--surface-muted);color:var(--primary-hover)}.listener-nav-back-icon{font-size:1.15rem;line-height:1}.listener-mini-text{flex:1;gap:.1rem;min-width:0;display:grid}.listener-mini-head p{color:var(--text-muted);margin:0;font-size:.78rem}.listener-mini-head h1{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:clamp(1rem,2.2vw,1.25rem);line-height:1.2;display:-webkit-box;overflow:hidden}.listener-mini-actions{flex-shrink:0;align-items:center;gap:.35rem;display:flex}.listener-nav-home-icon{min-width:44px;min-height:44px;color:var(--text-muted);border:1px solid var(--border);background:var(--surface);border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.listener-nav-home-icon:hover{color:var(--primary);border-color:var(--text-muted)}.listener-mini-instagram-link{align-items:center;display:inline-flex}.listener-mini-instagram{object-fit:cover;border-radius:10px;width:auto;height:100%;min-height:42px;max-height:48px}.city-mosques-eyebrow-row{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.city-mosques-eyebrow-row .eyebrow{margin:0}.city-mosques-back{flex-shrink:0;margin:-.35rem 0}.city-page-head{gap:.7rem;display:grid}@media (width<=760px){.header-inner{gap:.6rem;min-height:88px}.top-nav{justify-content:center}.city-link{padding:.35rem .55rem;font-size:.84rem}.header-logo-left{height:56px}.header-logo-right{height:60px}.page-main{padding-block:1rem 1.8rem}.page-main-home{padding-block:0}.home-with-background{min-height:calc(100vh - 88px)}.home-content{width:min(var(--max-content), calc(100% - 1.4rem));padding:.8rem 0}.home-page .home-content.stack-lg{gap:0;margin-block:0;padding-block:0}.hero-centered{gap:.65rem;min-height:calc(100vh - 150px)}.hero-centered .btn-primary{min-width:170px;min-height:2.8rem;font-size:1rem}.listener-title{font-size:1.2rem}.store-badge{height:36px}.social-badge{border-radius:10px;width:38px;height:38px}.hero-store-links{gap:.55rem}.card{border-radius:var(--radius-md);padding:1rem}.footer-inner{flex-direction:column;gap:.25rem}.iframe-wrap iframe{min-height:65vh}.mosque-grid{grid-template-columns:1fr}}.home-gps-mosques{width:100%;padding-bottom:1.5rem}.home-with-background .home-gps-all .home-gps-heading{color:#fff;text-shadow:0 2px 12px #00000059}.home-gps-heading{margin:0 0 .75rem;font-size:1.15rem}.home-gps-all-title{margin-top:1.25rem}.home-gps-loading{text-align:center;color:#ffffffeb;text-shadow:0 1px 8px #00000059;margin:0 0 1rem;font-size:.95rem}.home-gps-notice{border-left:4px solid var(--primary);color:var(--text);margin:0 0 1rem;font-size:.95rem}.home-gps-nearest-body{flex-direction:column;align-items:stretch;gap:1rem;display:flex}@media (width>=480px){.home-gps-nearest-body{flex-direction:row;justify-content:space-between;align-items:center}}.home-gps-nearest-name{color:var(--text);margin:0 0 .25rem;font-size:1.1rem}.home-gps-nearest-meta{color:var(--text-muted);margin:0;font-size:.9rem}.home-gps-distance{color:var(--primary);margin:.35rem 0 0;font-size:.95rem;font-weight:600}.home-gps-open-btn{text-align:center;flex-shrink:0;justify-content:center}.home-gps-empty{color:#ffffffe6;text-shadow:0 1px 8px #00000059;margin:0}.home-gps-debug{z-index:40;color:#e2e8f0;pointer-events:none;background:#0f172aeb;border-radius:6px;max-width:min(100%,260px);padding:.5rem .65rem;font-family:ui-monospace,monospace;font-size:.7rem;line-height:1.45;position:fixed;bottom:.5rem;right:.5rem}.home-gps-debug strong{color:#fff;margin-bottom:.25rem;display:block}.mosque-card-nearest{outline:2px solid var(--primary);outline-offset:2px}.mosque-distance-badge{color:var(--primary);margin:0;font-size:.85rem;font-weight:600}.mosque-detect-overlay{z-index:30;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);pointer-events:none;background:#f8fbffb8;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.mosque-detect-card{pointer-events:auto;text-align:center;max-width:320px;padding:1.5rem 1.75rem;box-shadow:0 12px 40px #0f172a1f}.mosque-detect-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:2.25rem;height:2.25rem;margin:0 auto 1rem;animation:.75s linear infinite mosque-detect-spin}@keyframes mosque-detect-spin{to{transform:rotate(360deg)}}.mosque-detect-title{color:var(--text);margin:0;font-size:1.05rem;font-weight:600}.mosque-detect-fallback{z-index:18;text-align:center;border:1px solid var(--border);width:min(420px,100% - 2rem);padding:1.1rem 1.25rem;position:fixed;bottom:1.25rem;left:50%;transform:translate(-50%);box-shadow:0 10px 36px #0f172a24}.mosque-detect-fallback-title{margin:0 0 .35rem;font-size:1rem;font-weight:600}.mosque-detect-fallback-hint{color:var(--text-muted);margin:0 0 .85rem;font-size:.9rem}.mosque-detect-fallback-btn{justify-content:center;width:100%}.mosque-detect-debug{z-index:40;color:#e2e8f0;pointer-events:none;background:#0f172ae6;border-radius:6px;max-width:min(100%,280px);padding:.5rem .65rem;font-family:ui-monospace,monospace;font-size:.7rem;line-height:1.45;position:fixed;bottom:.5rem;left:.5rem}.mosque-detect-debug strong{color:#fff;margin-bottom:.25rem;display:block}
