/* ═══════════════════════════════════════════════════════════════════
   Prayers.lk — style.css
   Single source of truth for all design tokens.
   Sky.js updates --sky-* custom properties on :root every second,
   and all components derive their colours from those tokens.
   No attribute selectors. No !important. No contrast system.
   ═══════════════════════════════════════════════════════════════════ */

/* ── Design tokens ──────────────────────────────────────────────── */
:root {
  /* Brand */
  --gold:       #c9a84c;
  --gold-lt:    #e8c97a;
  --gold-pale:  #f5e9c8;
  --gold-dim:   rgba(201,168,76,.18);

  /* Night-sky base (overridden live by sky.js) */
  --deep:       #080d1c;
  --navy:       #0c1428;
  --navy-mid:   #152040;
  --navy-lt:    #1c2d58;

  /* Semantic */
  --white:      #f8f5ee;
  --cream:      #faf6ef;
  --muted:      rgba(248,245,238,.58);
  --border:     rgba(201,168,76,.18);
  --green:      #86e87a;
  --purple:     #8b5cf6;
  --purple-lt:  #c4b5fd;
  --orange:     #f97316;
  --orange-lt:  #fdba74;

  /* Layout */
  --r:          16px;
  --header-h:   72px;
  --nav-h:      64px;

  /* ── Sky-driven tokens (sky.js writes these on :root) ──
     These are the ONLY things sky.js changes.
     All components read from these — no other sky-specific CSS needed. */
  --sky-text:        rgba(248,245,238,1);     /* primary text */
  --sky-muted:       rgba(248,245,238,.58);   /* secondary text */
  --sky-card:        rgba(10,16,36,.80);      /* card background */
  --sky-card-border: rgba(201,168,76,.20);    /* card border */
  --sky-blur:        14px;                    /* card blur */
  --sky-header:      rgba(8,13,28,.52);       /* header bg */
  --sky-footer:      rgba(8,13,28,.45);       /* footer bg */
  --sky-input:       rgba(8,13,28,.68);       /* input/select bg */
  --sky-overlay:     rgba(4,8,18,.0);
  --sky-text-shadow: none;         /* tint overlay on canvas */
}

/* ── Global reset ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--deep);
  color: var(--sky-text);
  overflow-x: hidden;
  min-height: 100vh;
}

/* ── Sky canvas overlay (subtle tint layer above canvas) ────────── */
#skyOverlay {
  position: fixed; inset: 0; z-index: 1;
  pointer-events: none;
  background: var(--sky-overlay);
  transition: background 4s ease;
}
.sky-pattern {
  position: fixed; inset: 0; z-index: 2; pointer-events: none;
  opacity: .018;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M40 0L80 40L40 80L0 40Z' fill='none' stroke='%23c9a84c' stroke-width='1'/%3E%3Ccircle cx='40' cy='40' r='20' fill='none' stroke='%23c9a84c' stroke-width='.5'/%3E%3C/svg%3E");
}

/* ── Typography ─────────────────────────────────────────────────── */
h1, h2, h3 { color: var(--sky-text); }
p, span, li { color: var(--sky-text); }
.muted, [class*="-muted"], .logo-sub,
.dist-label, .card-t12, .t12, .date-day,
.banner-cd-sub, .bn-eyebrow, .banner-next-label,
.hero-hijri, .hijri-sub, .footer-tagline,
.footer-acju, .ig-unit, .qsub, .mc-addr,
.badge-sub, .ai-date, .ann-body {
  color: var(--sky-muted);
}
a { color: var(--gold); }
a:hover { color: var(--gold-lt); }

/* ── Header ─────────────────────────────────────────────────────── */
.site-header {
  position: relative; z-index: 10;
  display: flex; align-items: center; justify-content: space-between;
  height: var(--header-h); padding: 0 40px;
  border-bottom: 1px solid var(--sky-card-border);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  background: var(--sky-header);
  transition: background 3s ease, border-color 3s ease;
}
.logo { display:flex; align-items:center; gap:13px; text-decoration:none; flex-shrink:0; }
.logo-icon {
  width:44px; height:44px;
  background: linear-gradient(135deg, var(--gold), var(--gold-lt));
  border-radius:11px; display:grid; place-items:center; font-size:21px;
  box-shadow: 0 4px 18px rgba(201,168,76,.38); flex-shrink:0;
}
.logo-name { font-family:'Cormorant Garamond',serif; font-size:1.55rem; font-weight:500; color:var(--sky-text); }
.logo-name span { color:var(--gold); }
.logo-sub { font-size:.65rem; color:var(--sky-muted); letter-spacing:2px; text-transform:uppercase; margin-top:1px; }
.site-nav { display:flex; gap:6px; align-items:center; }
.site-nav a {
  color: var(--sky-muted); text-decoration:none;
  padding:8px 15px; border-radius:8px;
  font-size:.875rem; transition: all .2s; white-space:nowrap;
}
.site-nav a:hover, .site-nav a.active {
  color: var(--sky-text);
  background: rgba(201,168,76,.14);
}
.btn-gps {
  background: linear-gradient(135deg, var(--gold), #a0813a);
  color: var(--deep); font-weight:500;
  border-radius:9px; padding:8px 16px;
  box-shadow: 0 3px 14px rgba(201,168,76,.28);
  border:none; cursor:pointer;
  font-family:'DM Sans',sans-serif; font-size:.875rem;
  transition: all .25s;
}
.btn-gps:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(201,168,76,.42); }

/* ── Cards — the core surface ────────────────────────────────────── */
.card-surface,
.pc, .icard, .info-card, .tbl-wrap, .form-card,
.prayer-banner, .qibla-outer, .ig-card,
.masjid-card, .masjid-hero, .ann-card,
.map-card, .live-section, .dist-sel-wrap,
.nearest-strip, .success-card, .mode-card,
.pt-card, .side-col > div {
  background: var(--sky-card);
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  border-color: var(--sky-card-border);
  transition: background 3s ease, border-color 3s ease,
              backdrop-filter 3s ease;
}

/* ── Inputs & Selects ───────────────────────────────────────────── */
input, select, textarea {
  background: var(--sky-input);
  border: 1px solid var(--sky-card-border);
  color: var(--sky-text);
  padding: 9px 13px; border-radius: 9px;
  font-family: 'DM Sans', sans-serif; font-size: .88rem;
  transition: border-color .2s, background 3s ease;
  width: 100%;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.14);
}
select option { background: var(--navy-mid); }
select.dist-sel {
  appearance: none;
  padding: 10px 38px 10px 16px;
  min-width: 195px;
}

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn-primary {
  background: linear-gradient(135deg, var(--gold), #a0813a);
  color: var(--deep); border: none;
  padding: 10px 22px; border-radius: 9px;
  font-family:'DM Sans',sans-serif; font-size:.88rem; font-weight:500;
  cursor: pointer; transition: all .2s;
}
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(201,168,76,.3); }
.btn-outline {
  background: transparent;
  border: 1px solid var(--sky-card-border);
  color: var(--sky-muted);
  padding: 10px 22px; border-radius: 9px;
  font-family:'DM Sans',sans-serif; font-size:.88rem;
  cursor: pointer; transition: all .2s;
}
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }

/* ── Tables ──────────────────────────────────────────────────────── */
table { width:100%; border-collapse:collapse; }
thead tr {
  background: linear-gradient(90deg, rgba(201,168,76,.12), rgba(201,168,76,.04));
  border-bottom: 1px solid var(--sky-card-border);
}
thead th {
  padding:13px 10px; text-align:center;
  font-family:'Cormorant Garamond',serif;
  font-size:.78rem; font-weight:500; color:var(--gold);
  letter-spacing:1.2px; text-transform:uppercase; white-space:nowrap;
}
thead th:first-child { text-align:left; padding-left:16px; }
tbody tr { border-bottom:1px solid rgba(201,168,76,.06); transition:background .15s; }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background: rgba(201,168,76,.05); }

/* ── Footer ──────────────────────────────────────────────────────── */
.site-footer {
  position: relative; z-index: 5;
  border-top: 1px solid var(--sky-card-border);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  background: var(--sky-footer);
  padding: 28px 40px;
  transition: background 3s ease;
}
.footer-top {
  display:flex; align-items:center; justify-content:space-between;
  gap:20px; margin-bottom:14px; padding-bottom:14px;
  border-bottom:1px solid rgba(201,168,76,.1);
}
.footer-brand { font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-weight:500; color:var(--sky-text); }
.footer-brand span { color:var(--gold); }
.footer-acju { font-size:.75rem; color:var(--sky-muted); text-align:right; line-height:1.6; }
.footer-acju a, .footer-contact a { color:var(--gold); text-decoration:none; }
.footer-acju a:hover, .footer-contact a:hover { text-decoration:underline; }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; gap:20px; }
.footer-tagline { font-size:.73rem; color:var(--sky-muted); line-height:1.5; }
.footer-contact { display:flex; gap:18px; flex-shrink:0; }
.footer-contact a { display:flex; align-items:center; gap:5px; font-size:.73rem; color:var(--sky-muted); white-space:nowrap; transition:color .2s; }
.footer-contact a:hover { color:var(--gold); }

/* ── Mobile bottom nav — Liquid Glass ───────────────────────────── */
.bottom-nav { display: none; }

@media (max-width: 768px) {
  body { padding-bottom: calc(var(--nav-h) + 12px); }
  .site-header { padding: 0 18px; }
  .site-nav a:not(.btn-gps) { display: none; }

  .bottom-nav {
    display: flex;
    position: fixed;
    bottom: calc(12px + env(safe-area-inset-bottom));
    left: 50%; transform: translateX(-50%);
    z-index: 200;
    width: auto;
    background: rgba(10,16,36,.52);
    border: 1px solid rgba(255,255,255,.13);
    border-radius: 100px;
    padding: 6px 8px; gap: 4px;
    backdrop-filter: blur(40px) saturate(200%) brightness(1.15);
    -webkit-backdrop-filter: blur(40px) saturate(200%) brightness(1.15);
    box-shadow:
      0 8px 32px rgba(0,0,0,.4),
      0 2px 8px rgba(0,0,0,.3),
      inset 0 1px 0 rgba(255,255,255,.15),
      inset 0 -1px 0 rgba(0,0,0,.2);
    transition: background 3s ease;
  }
  .bottom-nav a {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 2px; padding: 8px 20px;
    text-decoration: none;
    color: rgba(248,245,238,.52);
    border-radius: 80px;
    transition: all .25s cubic-bezier(.34,1.56,.64,1);
    -webkit-tap-highlight-color: transparent;
    min-width: 72px;
  }
  .bottom-nav a:active { transform: scale(.92); }
  .bottom-nav a.active {
    color: var(--sky-text);
    background: rgba(255,255,255,.13);
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.22),
      inset 0 -1px 0 rgba(0,0,0,.15),
      0 2px 12px rgba(201,168,76,.18),
      0 0 0 1px rgba(201,168,76,.15);
  }
  .bottom-nav a.active .bn-icon {
    filter: drop-shadow(0 0 6px rgba(201,168,76,.65)) drop-shadow(0 0 2px rgba(201,168,76,.4));
  }
  .bottom-nav a.active .bn-label { color: var(--gold-lt); }
  .bn-icon { font-size:1.4rem; line-height:1; transition: transform .25s cubic-bezier(.34,1.56,.64,1), filter .25s ease; }
  .bottom-nav a:active .bn-icon { transform: scale(.88); }
  .bn-label { font-size:.5rem; letter-spacing:.6px; text-transform:uppercase; white-space:nowrap; font-weight:500; }
}

/* ── Animations ──────────────────────────────────────────────────── */
@keyframes fadeUp {
  from { transform: translateY(28px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
@keyframes slideDown {
  from { transform: translateY(-28px); opacity: 0; }
  to   { transform: translateY(0);     opacity: 1; }
}
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .5; transform: scale(.8); }
}
.animate-up { animation: fadeUp .8s ease both; }

/* ── Loading overlay ─────────────────────────────────────────────── */
.loading-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: var(--deep);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 18px;
  animation: loadOut .45s 1.1s forwards;
}
@keyframes loadOut { to { opacity: 0; visibility: hidden; } }
.loading-overlay .load-crescent { font-size: 3.8rem; animation: spinC 1.6s linear infinite; }
@keyframes spinC { to { transform: rotate(360deg); } }
.loading-overlay .load-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem; color: var(--gold); letter-spacing: 3px;
}

/* ── Alerts ──────────────────────────────────────────────────────── */
.alert { padding:12px 16px; border-radius:9px; margin-bottom:16px; font-size:.85rem; border:1px solid; }
.alert-success { background:rgba(46,204,113,.1); border-color:rgba(46,204,113,.3); color:#2ecc71; }
.alert-error   { background:rgba(231,76,60,.1);  border-color:rgba(231,76,60,.3);  color:#e74c3c; }

/* ── Badges ──────────────────────────────────────────────────────── */
.badge { padding:2px 8px; border-radius:6px; font-size:.68rem; font-weight:500; }
.badge-gold   { background:rgba(201,168,76,.2);  color:var(--gold); }
.badge-green  { background:rgba(134,232,122,.18); color:var(--green); }

/* ── Mobile misc ─────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .site-footer { padding: 22px 18px; }
  .footer-top  { flex-direction:column; align-items:flex-start; gap:6px; }
  .footer-acju { text-align:left; }
  .footer-bottom { flex-direction:column; align-items:flex-start; gap:10px; }
  .footer-contact { flex-wrap:wrap; gap:12px; }
}

/* ════════════════════════════════════════════════════════════
   PRAYER CARDS — homepage (.pc grid)
   Glass surface — no inner row backgrounds, no banding
   ════════════════════════════════════════════════════════════ */
.prayer-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
  margin-bottom: 44px;
}
@media(max-width:680px){ .prayer-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:420px){ .prayer-grid { grid-template-columns: 1fr; } }

.pc {
  background: var(--sky-card);
  border: 1px solid var(--sky-card-border);
  border-radius: var(--r);
  padding: 22px 18px 18px;
  text-align: center;
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  transition: background 3s ease, border-color 3s ease,
              transform .32s cubic-bezier(.34,1.56,.64,1),
              box-shadow .32s ease;
  position: relative;
  overflow: hidden;
  animation: fadeUp .6s ease both;
}
/* Bottom accent line — hidden by default */
.pc::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  transform: scaleX(0);
  transition: transform .3s;
}
.pc:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 42px rgba(0,0,0,.3);
  border-color: rgba(201,168,76,.35);
}
.pc:hover::before { transform: scaleX(1); }

/* Active state — gold tint, no extra bg layers */
.pc.active {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px rgba(201,168,76,.15),
              0 8px 30px rgba(201,168,76,.15),
              inset 0 1px 0 rgba(201,168,76,.2);
}
.pc.active::before { transform: scaleX(1); }

/* Jumuah card */
.pc.jumuah-card { border-color: rgba(134,232,122,.25); }
.pc.jumuah-card::before { background: linear-gradient(90deg,transparent,var(--green),transparent); }
.pc.jumuah-card.active, .pc.jumuah-card.iqamah-active {
  border-color: var(--green);
  box-shadow: 0 0 0 1px rgba(134,232,122,.12),
              0 8px 30px rgba(134,232,122,.12);
}

/* Sunrise — dimmed */
.pc.sunrise-card { opacity: .6; }

/* Iqamah active — purple */
.pc.iqamah-active {
  border-color: var(--purple);
  box-shadow: 0 0 0 1px rgba(139,92,246,.15),
              0 8px 30px rgba(139,92,246,.18);
}
.pc.iqamah-active::before { background: linear-gradient(90deg,transparent,var(--purple),transparent); transform: scaleX(1); }

/* Active indicator dot */
.active-dot {
  position: absolute; top: 11px; right: 11px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold); box-shadow: 0 0 8px var(--gold);
  animation: pulse 2s infinite;
}
.jumuah-card .active-dot  { background: var(--green);  box-shadow: 0 0 8px var(--green); }
.iqamah-active .active-dot{ background: var(--purple); box-shadow: 0 0 8px var(--purple); }

/* Card content — clean, no inner backgrounds */
.card-icon {
  font-size: 1.75rem;
  margin-bottom: 10px;
  display: block;
  filter: drop-shadow(0 2px 8px rgba(201,168,76,.2));
}
.card-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem; font-weight: 500;
  color: var(--sky-muted);
  letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 8px;
}
.pc.active       .card-name { color: var(--gold); }
.jumuah-card     .card-name { color: rgba(134,232,122,.8); }
.iqamah-active   .card-name { color: var(--purple-lt); }

.card-t24 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.2rem; font-weight: 300;
  color: var(--sky-text);
  letter-spacing: 1px; line-height: 1;
  margin-bottom: 2px;
}
.card-t12 {
  font-size: .72rem;
  color: var(--sky-muted);
  letter-spacing: .4px;
  margin-bottom: 10px;
}

/* Iqamah row — NO background, just a subtle top border */
.iqamah-row {
  display: flex; align-items: center; justify-content: center; gap: 5px;
  border-top: 1px solid rgba(201,168,76,.12);
  padding-top: 9px; margin-top: 4px;
}
.jumuah-card   .iqamah-row { border-top-color: rgba(134,232,122,.15); }
.iqamah-active .iqamah-row { border-top-color: rgba(139,92,246,.22); }
.sunrise-card  .iqamah-row { display: none; }

.iq-lbl { font-size:.58rem; color:var(--sky-muted); letter-spacing:1px; text-transform:uppercase; }
.iq-t   { font-family:'Cormorant Garamond',serif; font-size:.92rem; font-weight:500; color:var(--gold-lt); }
.iq-off { font-size:.58rem; color:var(--sky-muted); }
.jumuah-card   .iq-t { color: var(--green); }
.iqamah-active .iq-t { color: var(--purple-lt); }

/* ── Card animation delays ── */
.pc:nth-child(1){animation-delay:.44s}
.pc:nth-child(2){animation-delay:.49s}
.pc:nth-child(3){animation-delay:.54s}
.pc:nth-child(4){animation-delay:.59s}
.pc:nth-child(5){animation-delay:.64s}
.pc:nth-child(6){animation-delay:.69s}

/* ════════════════════════════════════════════════════════════
   PRAYER BANNER — countdown + progress bar
   ════════════════════════════════════════════════════════════ */
.prayer-banner {
  border-radius: var(--r);
  padding: 0;
  margin-bottom: 36px;
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  animation: fadeUp .8s .28s ease both;
  position: relative; overflow: hidden;
  background: var(--sky-card);
  border: 1px solid var(--sky-card-border);
  transition: background 3s ease, border-color 3s ease;
}
.prayer-banner.jumuah-bg  { border-color: rgba(134,232,122,.28); }
.prayer-banner.iqamah-mode{ border-color: rgba(139,92,246,.38); }
.prayer-banner::before {
  content: ''; position: absolute;
  top: -40%; left: -10%; width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(201,168,76,.06), transparent 70%);
  border-radius: 50%; pointer-events: none;
}
.banner-inner {
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 22px 30px 18px; gap: 20px;
}
.banner-eyebrow {
  font-size: .65rem; color: var(--gold);
  letter-spacing: 2.5px; text-transform: uppercase; margin-bottom: 4px;
}
.iqamah-mode .banner-eyebrow { color: var(--purple-lt); }
.jumuah-bg   .banner-eyebrow { color: var(--green); }
.banner-prayer-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem; font-weight: 500;
  color: var(--sky-text); line-height: 1;
}
.banner-sub { font-size: .78rem; color: var(--sky-muted); margin-top: 5px; }
.banner-right { text-align: right; flex-shrink: 0; }
.banner-next-label {
  font-size: .65rem; color: var(--sky-muted);
  letter-spacing: 2px; text-transform: uppercase; margin-bottom: 4px;
}
.banner-next-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: .95rem; color: var(--sky-text); margin-bottom: 5px;
}
#countdown {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.6rem; font-weight: 300;
  color: var(--gold-lt); letter-spacing: 2px;
  font-variant-numeric: tabular-nums; line-height: 1;
}
#countdown .u { font-size: .82rem; color: var(--sky-muted); margin: 0 1px; }
.iqamah-mode #countdown { color: var(--purple-lt); }
.jumuah-bg   #countdown { color: var(--green); }
.banner-cd-sub {
  font-size: .6rem; color: var(--sky-muted);
  letter-spacing: 1.5px; text-transform: uppercase; margin-top: 4px;
}
/* Progress bar */
.banner-progress-track {
  height: 3px;
  background: rgba(255,255,255,.05);
  position: relative;
}
.banner-progress-fill {
  position: absolute; top: 0; bottom: 0;
  right: 0; left: auto; width: 100%;
  background: linear-gradient(270deg, rgba(201,168,76,.3) 0%, var(--gold) 60%, var(--gold-lt) 100%);
  transition: width 1s linear;
}
.iqamah-mode .banner-progress-fill { background: linear-gradient(270deg, rgba(139,92,246,.3) 0%, var(--purple) 60%, var(--purple-lt) 100%); }
.jumuah-bg   .banner-progress-fill { background: linear-gradient(270deg, rgba(134,232,122,.3) 0%, var(--green) 60%, rgba(134,232,122,.6) 100%); }

/* ── Info cards (Qibla + Timetable row) ── */
.info-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 18px; margin-bottom: 44px;
  animation: fadeUp .8s .5s ease both;
}
@media(max-width:620px){ .info-row { grid-template-columns: 1fr; } }
.icard {
  background: var(--sky-card);
  border: 1px solid var(--sky-card-border);
  border-radius: var(--r); padding: 26px;
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  transition: background 3s ease, border-color 3s ease;
}
.icard h3 {
  font-family: 'Cormorant Garamond', serif;
  font-size: .9rem; color: var(--gold);
  letter-spacing: 2px; text-transform: uppercase; margin-bottom: 16px;
}

/* ── Nearest masjid card ── */
.nearest-masjid-card {
  display: flex; align-items: center;
  justify-content: space-between; gap: 20px;
  background: var(--sky-card);
  border: 1px solid rgba(249,115,22,.28);
  border-radius: var(--r);
  padding: 22px 26px; margin-bottom: 44px;
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  animation: fadeUp .8s .55s ease both;
  text-decoration: none; transition: all .25s;
  position: relative; overflow: hidden;
}
.nearest-masjid-card::before {
  content: ''; position: absolute;
  top: -40%; right: -5%; width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(249,115,22,.06), transparent 70%);
  border-radius: 50%;
}
.nearest-masjid-card:hover {
  border-color: rgba(249,115,22,.48);
  transform: translateY(-2px);
  box-shadow: 0 10px 32px rgba(0,0,0,.25);
}
.nm-left   { display:flex; align-items:center; gap:16px; }
.nm-icon   { font-size:2rem; flex-shrink:0; filter:drop-shadow(0 2px 8px rgba(249,115,22,.35)); }
.nm-label  { font-size:.68rem; color:rgba(253,186,116,.7); letter-spacing:2px; text-transform:uppercase; margin-bottom:4px; }
.nm-title  { font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-weight:500; color:var(--sky-text); line-height:1; }
.nm-sub    { font-size:.78rem; color:var(--sky-muted); margin-top:5px; }
.nm-sub strong { color:rgba(253,186,116,.9); }
.nm-arrow  { font-size:1.5rem; color:rgba(253,186,116,.55); flex-shrink:0; transition:transform .2s; }
.nearest-masjid-card:hover .nm-arrow { transform:translateX(4px); }

/* ── Hero ── */
main { position:relative; z-index:5; max-width:1180px; margin:0 auto; padding:0 22px 40px; }
.hero { text-align:center; padding:52px 0 36px; animation:fadeUp .8s .1s ease both; }
.hero-date  { font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--gold); letter-spacing:3px; text-transform:uppercase; margin-bottom:6px; }
.hero-hijri { font-family:'Noto Naskh Arabic',serif; font-size:1.25rem; color:var(--sky-muted); margin-bottom:18px; direction:rtl; }
.hero-title { font-family:'Cormorant Garamond',serif; font-size:clamp(2rem,5vw,3.6rem); font-weight:300; line-height:1.15; color:var(--sky-text); }
.hero-title em { font-style:italic; color:var(--gold-lt); }
.jumuah-badge-hero { display:inline-flex; align-items:center; gap:9px; background:linear-gradient(135deg,rgba(134,232,122,.1),rgba(134,232,122,.04)); border:1px solid rgba(134,232,122,.3); border-radius:30px; padding:7px 20px; color:var(--green); letter-spacing:1.5px; text-transform:uppercase; margin-top:16px; font-family:'Cormorant Garamond',serif; font-size:1rem; }

/* ── Location hierarchy ── */
.loc-stack    { display:inline-flex; flex-direction:column; align-items:center; gap:0; margin-bottom:20px; animation:fadeUp .8s .12s ease both; }
.loc-district { font-size:.7rem; color:var(--sky-muted); letter-spacing:2.5px; text-transform:uppercase; margin-bottom:2px; }
.loc-city     { font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:var(--sky-muted); margin-bottom:6px; }
.loc-connector { display:flex; align-items:center; gap:6px; font-size:.65rem; color:rgba(201,168,76,.45); letter-spacing:1px; text-transform:uppercase; margin-bottom:4px; }
.loc-connector::before, .loc-connector::after { content:''; flex:1; height:1px; width:28px; background:rgba(201,168,76,.15); }
.loc-masjid { display:inline-flex; align-items:center; gap:8px; padding:7px 16px; background:rgba(249,115,22,.08); border:1px solid rgba(249,115,22,.22); border-radius:20px; text-decoration:none; transition:all .22s; }
.loc-masjid:hover { background:rgba(249,115,22,.15); border-color:rgba(249,115,22,.45); transform:translateY(-1px); }
.lm-icon  { font-size:1rem; }
.lm-name  { font-family:'Cormorant Garamond',serif; font-size:1rem; color:rgba(253,186,116,.9); }
.lm-arrow { font-size:.75rem; color:rgba(249,115,22,.5); margin-left:2px; }
.lm-dist  { font-size:.68rem; color:rgba(253,186,116,.65); background:rgba(249,115,22,.12); border-radius:8px; padding:1px 6px; }
.loc-masjid-placeholder { display:inline-flex; align-items:center; gap:7px; padding:6px 14px; border:1px dashed rgba(201,168,76,.18); border-radius:20px; font-size:.75rem; color:var(--sky-muted); text-decoration:none; transition:all .2s; }
.loc-masjid-placeholder:hover { border-color:rgba(201,168,76,.38); color:var(--gold); }

/* ── District bar ── */
.dist-bar    { display:flex; align-items:center; justify-content:center; gap:14px; margin:28px 0 44px; animation:fadeUp .8s .22s ease both; flex-wrap:wrap; }
.dist-label  { font-size:.75rem; color:var(--sky-muted); letter-spacing:1.5px; text-transform:uppercase; }
.sel-wrap    { position:relative; }
.sel-wrap::after { content:'▾'; position:absolute; right:13px; top:50%; transform:translateY(-50%); color:var(--gold); pointer-events:none; font-size:.78rem; }
select.dist-sel {
  appearance:none; background:var(--sky-card);
  border:1px solid var(--sky-card-border); color:var(--sky-text);
  padding:10px 38px 10px 16px; border-radius:11px;
  font-family:'DM Sans',sans-serif; font-size:.92rem; cursor:pointer;
  backdrop-filter:blur(var(--sky-blur)); min-width:195px;
  transition:border-color .2s, background 3s ease;
}
select.dist-sel:focus { outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,.12); }
select.dist-sel option { background:#152040; }
.gps-bar-btn {
  display:flex; align-items:center; gap:7px;
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  color:var(--sky-muted); padding:10px 16px; border-radius:11px;
  font-family:'DM Sans',sans-serif; font-size:.85rem; cursor:pointer;
  transition:all .25s; backdrop-filter:blur(var(--sky-blur));
}
.gps-bar-btn:hover { border-color:var(--gold); color:var(--gold); }

/* ── Mobile ── */
@media(max-width:768px) {
  main  { padding: 0 14px 20px; }
  .hero { padding: 38px 0 18px; }
  .dist-bar { gap:8px; margin:20px 0 28px; justify-content:center; }
  .dist-label { display:none; }
  .sel-wrap   { flex:1; max-width:320px; }
  select.dist-sel { min-width:0; width:100%; }
  .gps-bar-btn { padding:10px 14px; flex-shrink:0; }
  .gps-bar-btn .gps-text { display:none; }
  .banner-inner { flex-direction:row-reverse; padding:18px 18px 14px; gap:14px; }
  .banner-right { text-align:left; }
  #countdown    { font-size:2rem; }
  .banner-next-name { font-size:.85rem; }
  .banner-progress-fill {
    left:0; right:auto;
    background: linear-gradient(90deg, rgba(201,168,76,.3) 0%, var(--gold) 60%, var(--gold-lt) 100%);
  }
  .iqamah-mode .banner-progress-fill { background: linear-gradient(90deg, rgba(139,92,246,.3) 0%, var(--purple) 60%, var(--purple-lt) 100%); }
  .jumuah-bg   .banner-progress-fill { background: linear-gradient(90deg, rgba(134,232,122,.3) 0%, var(--green) 60%, rgba(134,232,122,.6) 100%); }
  .nearest-masjid-card { padding:16px 18px; }
  .nm-title { font-size:1.2rem; }
}

/* ════════════════════════════════════════════════════════════
   MASJID PAGES
   ════════════════════════════════════════════════════════════ */

/* ── Page header shared ── */
.page-header {
  display:flex; align-items:flex-end; justify-content:space-between;
  flex-wrap:wrap; gap:16px; margin-bottom:28px;
  animation:fadeUp .6s ease both;
}
.ph-left .sub {
  font-size:.72rem; color:var(--gold);
  letter-spacing:2.5px; text-transform:uppercase; margin-bottom:5px;
}
.ph-left h1 {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.6rem,4vw,2.6rem); font-weight:300; color:var(--sky-text);
}
.ph-left h1 em { font-style:italic; color:var(--gold-lt); }
.ph-actions { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }

/* ── Action buttons (outline + primary) ── */
.btn-locate {
  display:flex; align-items:center; gap:7px;
  padding:9px 16px; border-radius:9px;
  border:1px solid var(--sky-card-border);
  background:rgba(201,168,76,.08); color:var(--gold);
  font-family:'DM Sans',sans-serif; font-size:.85rem;
  cursor:pointer; transition:all .2s; text-decoration:none;
}
.btn-locate:hover { background:rgba(201,168,76,.16); border-color:var(--gold); }
.btn-register {
  display:flex; align-items:center; gap:7px;
  padding:9px 18px; border-radius:9px; border:none;
  background:linear-gradient(135deg, var(--gold), #a0813a);
  color:var(--deep); font-family:'DM Sans',sans-serif;
  font-size:.85rem; font-weight:500;
  cursor:pointer; text-decoration:none; transition:all .2s;
}
.btn-register:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(201,168,76,.3); }

/* ── Filter bar ── */
.filter-bar {
  display:flex; gap:10px; align-items:center;
  flex-wrap:wrap; margin-bottom:24px;
  animation:fadeUp .6s .08s ease both;
}
.filter-bar select {
  appearance:none;
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  color:var(--sky-text); padding:9px 13px; border-radius:9px;
  font-family:'DM Sans',sans-serif; font-size:.85rem;
  cursor:pointer; min-width:160px;
  backdrop-filter:blur(var(--sky-blur));
  transition:background 3s ease;
}
.filter-bar select:focus { outline:none; border-color:var(--gold); }
.filter-bar select option { background:var(--navy-mid); }

/* ── Nearest strip ── */
.nearest-strip {
  background:var(--sky-card); border:1px solid rgba(201,168,76,.22);
  border-radius:14px; padding:16px 20px; margin-bottom:24px;
  display:none; gap:14px; flex-wrap:wrap;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  animation:fadeUp .5s ease both;
  transition:background 3s ease;
}
.nearest-strip.show { display:flex; align-items:center; }
.ns-icon { font-size:1.5rem; flex-shrink:0; }
.ns-text { font-size:.85rem; color:var(--sky-text); line-height:1.6; }
.ns-text strong { color:var(--gold); }

/* ── Masjid grid ── */
.masjid-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:16px;
}
@media(max-width:900px) { .masjid-grid { grid-template-columns:1fr; } }

/* ── Masjid card ── */
.masjid-card {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:16px;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  overflow:hidden;
  transition:background 3s ease, border-color .3s, transform .3s cubic-bezier(.34,1.56,.64,1);
  animation:fadeUp .6s ease both;
}
.masjid-card:hover {
  transform:translateY(-3px);
  border-color:rgba(201,168,76,.38);
  box-shadow:0 12px 36px rgba(0,0,0,.35);
}
.masjid-card.nearest {
  border-color:var(--gold);
  box-shadow:0 0 0 1px rgba(201,168,76,.22), 0 8px 24px rgba(201,168,76,.12);
}
.mc-head { padding:20px 20px 16px; border-bottom:1px solid var(--sky-card-border); }
.mc-head-row { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; margin-bottom:8px; }
.mc-name { font-family:'Cormorant Garamond',serif; font-size:1.25rem; font-weight:500; color:var(--sky-text); line-height:1.2; }
.mc-arabic { font-family:'Noto Naskh Arabic',serif; font-size:1rem; color:var(--sky-muted); direction:rtl; }
.mc-badges { display:flex; gap:6px; flex-shrink:0; flex-wrap:wrap; }
.badge-nearest { background:rgba(201,168,76,.18); color:var(--gold); }
.badge-acju { background:rgba(20,184,166,.14); color:#5eead4; border:1px solid rgba(20,184,166,.2); }
.badge-custom { background:rgba(139,92,246,.14); color:var(--purple-lt); border:1px solid rgba(139,92,246,.2); }
.mc-addr { font-size:.78rem; color:var(--sky-muted); line-height:1.5; }
.mc-dist { font-size:.72rem; color:var(--gold-lt); margin-top:4px; }
.mc-body { padding:16px 20px; }
.mc-ann {
  background:rgba(201,168,76,.05); border:1px solid rgba(201,168,76,.1);
  border-radius:9px; padding:10px 12px; margin-bottom:12px;
}
.mc-ann .ann-title { font-size:.78rem; color:var(--gold-lt); font-weight:500; margin-bottom:3px; }
.mc-ann .ann-body { font-size:.75rem; color:var(--sky-muted); line-height:1.5; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ── Masjid card action buttons ── */
.mc-actions { display:flex; gap:8px; flex-wrap:wrap; }
.mc-btn {
  display:flex; align-items:center; gap:5px;
  padding:7px 13px; border-radius:8px;
  font-family:'DM Sans',sans-serif; font-size:.75rem; font-weight:500;
  text-decoration:none; cursor:pointer; transition:all .2s;
  border:1px solid var(--sky-card-border);
  background:transparent; color:var(--sky-muted);
}
.mc-btn:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,.06); }
.mc-btn.nav {
  background:linear-gradient(135deg, var(--gold), #a0813a);
  color:var(--deep); border-color:transparent;
}
.mc-btn.nav:hover { transform:translateY(-1px); box-shadow:0 4px 14px rgba(201,168,76,.3); }

/* ── Empty state ── */
.empty { text-align:center; padding:70px 20px; color:var(--sky-muted); }
.empty .ei { font-size:3.5rem; margin-bottom:14px; }
.empty p { font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:var(--sky-text); }
.empty small { font-size:.82rem; margin-top:6px; display:block; }
.empty a { color:var(--gold); }

/* ── Masjid view page ── */
.back-link {
  display:inline-flex; align-items:center; gap:7px;
  font-size:.8rem; color:var(--sky-muted);
  text-decoration:none; margin-bottom:24px; transition:color .2s;
}
.back-link:hover { color:var(--gold); }
.masjid-hero {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:18px; padding:28px;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  margin-bottom:20px; animation:fadeUp .6s ease both;
  position:relative; overflow:hidden;
  transition:background 3s ease;
}
.masjid-hero::before {
  content:''; position:absolute; top:-30%; right:-10%;
  width:200px; height:200px;
  background:radial-gradient(circle,rgba(201,168,76,.06),transparent 70%);
  border-radius:50%;
}
.mh-top { display:flex; align-items:flex-start; justify-content:space-between; gap:16px; margin-bottom:18px; flex-wrap:wrap; }
.mh-name { font-family:'Cormorant Garamond',serif; font-size:clamp(1.6rem,4vw,2.4rem); font-weight:400; color:var(--sky-text); line-height:1.15; }
.mh-arabic { font-family:'Noto Naskh Arabic',serif; font-size:1.2rem; color:var(--sky-muted); direction:rtl; margin-top:4px; }
.mh-meta { display:flex; flex-wrap:wrap; gap:12px; font-size:.8rem; color:var(--sky-muted); margin-top:10px; }
.mh-meta a { color:var(--gold); text-decoration:none; }
.mh-meta a:hover { text-decoration:underline; }
.mh-badges { display:flex; gap:8px; flex-shrink:0; flex-wrap:wrap; }
.badge-jumuah { background:rgba(134,232,122,.14); color:var(--green); border:1px solid rgba(134,232,122,.2); }

/* content grid */
.content-grid { display:grid; grid-template-columns:1fr 360px; gap:18px; align-items:start; }
@media(max-width:780px) { .content-grid { grid-template-columns:1fr; } }

/* prayer times card */
.pt-card {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:16px; overflow:hidden;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  animation:fadeUp .6s .08s ease both;
  transition:background 3s ease;
}
.pt-card-head { padding:16px 20px; border-bottom:1px solid var(--sky-card-border); display:flex; align-items:center; justify-content:space-between; }
.pt-card-head h3 { font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--gold); letter-spacing:2px; text-transform:uppercase; }
.pt-card-head .hijri { font-size:.72rem; color:var(--sky-muted); }
table.pt-table { width:100%; border-collapse:collapse; }
.pt-table tr { border-bottom:1px solid rgba(201,168,76,.06); transition:background .15s; }
.pt-table tr:last-child { border-bottom:none; }
.pt-table tr:hover { background:rgba(201,168,76,.04); }
.pt-table tr.active-row { background:linear-gradient(90deg,rgba(201,168,76,.1),rgba(201,168,76,.03)); border-left:3px solid var(--gold); }
.pt-table tr.jumuah-row { background:rgba(134,232,122,.04); }
.pt-table td { padding:12px 16px; font-size:.88rem; color:var(--sky-text); }
.pt-table td:first-child { display:flex; align-items:center; gap:9px; font-weight:500; }
.pt-table td.adhan { text-align:right; font-family:'Cormorant Garamond',serif; font-size:1.1rem; }
.pt-table td.iqamah { text-align:right; font-size:.8rem; color:var(--sky-muted); }
.pt-table td.iqamah .iq-val { color:var(--gold-lt); font-family:'Cormorant Garamond',serif; font-size:.95rem; }
.sunrise-row td { opacity:.5; }

/* side column */
.side-col { display:flex; flex-direction:column; gap:16px; }
.map-card {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:16px; overflow:hidden;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  animation:fadeUp .6s .12s ease both;
  transition:background 3s ease;
}
.map-card-head { padding:14px 18px; border-bottom:1px solid var(--sky-card-border); font-family:'Cormorant Garamond',serif; font-size:.95rem; color:var(--gold); letter-spacing:1.5px; text-transform:uppercase; }
.map-placeholder { height:180px; background:rgba(8,13,28,.5); display:flex; align-items:center; justify-content:center; flex-direction:column; gap:8px; color:var(--sky-muted); font-size:.82rem; }
.map-actions { padding:14px 16px; display:flex; gap:8px; flex-wrap:wrap; }
.map-btn { display:flex; align-items:center; gap:6px; padding:9px 14px; border-radius:9px; font-family:'DM Sans',sans-serif; font-size:.8rem; font-weight:500; text-decoration:none; cursor:pointer; transition:all .2s; border:none; }
.map-btn.primary { background:linear-gradient(135deg,var(--gold),#a0813a); color:var(--deep); }
.map-btn.primary:hover { transform:translateY(-1px); box-shadow:0 5px 16px rgba(201,168,76,.3); }
.map-btn.secondary { background:var(--sky-card); border:1px solid var(--sky-card-border); color:var(--sky-text); }
.map-btn.secondary:hover { border-color:var(--gold); color:var(--gold); }
.info-card {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:16px; padding:18px;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  animation:fadeUp .6s .16s ease both;
  transition:background 3s ease;
}
.info-card h3 { font-family:'Cormorant Garamond',serif; font-size:.95rem; color:var(--gold); letter-spacing:2px; text-transform:uppercase; margin-bottom:12px; }
.info-row-item { display:flex; align-items:center; gap:10px; padding:7px 0; border-bottom:1px solid rgba(201,168,76,.07); font-size:.82rem; color:var(--sky-muted); }
.info-row-item:last-child { border-bottom:none; }
.info-row-item .ik { flex-shrink:0; font-size:1rem; }
.info-row-item .iv { color:var(--sky-text); }
.info-row-item a { color:var(--gold); text-decoration:none; }
.ann-card {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:16px; overflow:hidden;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  animation:fadeUp .6s .2s ease both;
  transition:background 3s ease;
}
.ann-card-head { padding:14px 18px; border-bottom:1px solid var(--sky-card-border); font-family:'Cormorant Garamond',serif; font-size:.95rem; color:var(--gold); letter-spacing:1.5px; text-transform:uppercase; }
.ann-item { padding:14px 18px; border-bottom:1px solid rgba(201,168,76,.06); }
.ann-item:last-child { border-bottom:none; }
.ann-item .ai-title { font-size:.88rem; color:var(--sky-text); font-weight:500; margin-bottom:4px; }
.ann-item .ai-body { font-size:.8rem; color:var(--sky-muted); line-height:1.6; }
.ann-item .ai-date { font-size:.68rem; color:rgba(201,168,76,.45); margin-top:6px; }
.no-ann { padding:24px 18px; text-align:center; font-size:.82rem; color:var(--sky-muted); }

/* ── Register form ── */
.form-card {
  background:var(--sky-card); border:1px solid var(--sky-card-border);
  border-radius:16px; padding:32px;
  backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter:blur(var(--sky-blur)) saturate(180%);
  margin-bottom:20px; animation:fadeUp .6s .15s ease both;
  transition:background 3s ease;
}
.form-card h2 { font-family:'Cormorant Garamond',serif; font-size:1.15rem; font-weight:400; color:var(--gold); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid var(--sky-card-border); }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-grid.cols1 { grid-template-columns:1fr; }
.form-grid.cols3 { grid-template-columns:1fr 1fr 1fr; }
.fg { display:flex; flex-direction:column; gap:5px; margin-bottom:4px; }
.fg.full { grid-column:1/-1; }
.fg label { font-size:.7rem; color:var(--gold); letter-spacing:1px; text-transform:uppercase; }
.fg label .opt { color:var(--sky-muted); font-weight:300; letter-spacing:0; }
.mode-cards { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:4px; }
.mode-card { border:1px solid var(--sky-card-border); border-radius:11px; padding:16px; cursor:pointer; transition:all .2s; position:relative; background:transparent; }
.mode-card:hover { border-color:rgba(201,168,76,.38); }
.mode-card input[type=radio] { position:absolute; opacity:0; width:0; height:0; }
.mode-card.selected { border-color:var(--gold); background:rgba(201,168,76,.08); }
.mode-card .mc-title { font-family:'Cormorant Garamond',serif; font-size:1rem; color:var(--sky-text); margin-bottom:4px; }
.mode-card .mc-desc { font-size:.75rem; color:var(--sky-muted); line-height:1.5; }
.map-hint { font-size:.75rem; color:var(--sky-muted); margin-top:6px; line-height:1.5; }
.map-hint a { color:var(--gold); }
.btn-submit { width:100%; padding:14px; border-radius:11px; border:none; background:linear-gradient(135deg,var(--gold),#a0813a); color:var(--deep); font-family:'DM Sans',sans-serif; font-size:.95rem; font-weight:600; cursor:pointer; transition:all .2s; margin-top:8px; letter-spacing:.5px; }
.btn-submit:hover { transform:translateY(-1px); box-shadow:0 8px 24px rgba(201,168,76,.35); }
.success-card { text-align:center; background:var(--sky-card); border:1px solid rgba(46,204,113,.22); border-radius:16px; padding:50px 32px; backdrop-filter:blur(var(--sky-blur)) saturate(180%); }
.success-card .s-icon { font-size:3.5rem; margin-bottom:16px; }
.success-card h2 { font-family:'Cormorant Garamond',serif; font-size:1.9rem; font-weight:300; color:var(--sky-text); margin-bottom:10px; }
.success-card p { color:var(--sky-muted); font-size:.88rem; line-height:1.7; }

/* ── Mobile masjid ── */
@media(max-width:480px) {
  .form-grid { grid-template-columns:1fr; }
  .form-grid.cols3 { grid-template-columns:1fr 1fr; }
  .mode-cards { grid-template-columns:1fr; }
  .mh-top { flex-direction:column; }
  .ph-actions { width:100%; }
  .btn-register, .btn-locate { flex:1; justify-content:center; text-align:center; }
}

/* ════════════════════════════════════════════════════════════
   SKY TEXT SHADOWS
   Applied to any text that sits directly on the sky canvas
   (outside a card). sky.js drives --sky-text-shadow strength.
   ════════════════════════════════════════════════════════════ */

/* Elements that float directly on sky — need shadow */
.hero-date,
.hero-hijri,
.hero-title,
.hero-title em,
.loc-district,
.loc-city,
.loc-connector,
.lm-name,
.page-sub,
.arabic-title,
.page-title,
.page-title em,
.ph-left .sub,
.ph-left h1,
.ph-left h1 em {
  text-shadow: var(--sky-text-shadow);
}

/* Filter bar, month nav, and controls — give them card backing */
.filter-bar {
  background: var(--sky-card);
  border: 1px solid var(--sky-card-border);
  border-radius: 12px;
  padding: 12px 16px;
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  transition: background 3s ease;
}
.month-nav {
  background: var(--sky-card);
  border: 1px solid var(--sky-card-border);
  border-radius: 12px;
  padding: 10px 16px;
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  transition: background 3s ease;
  display: flex; justify-content: space-between;
  align-items: center; gap: 10px;
  margin-bottom: 16px;
}

/* Count text sitting on sky (e.g. "7 masjids listed", "30 days · Ampara") */
.mnav-info,
.filter-bar > span {
  text-shadow: var(--sky-text-shadow);
}

/* Qibla selector row */
.dist-sel-row {
  background: var(--sky-card);
  border: 1px solid var(--sky-card-border);
  backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  -webkit-backdrop-filter: blur(var(--sky-blur)) saturate(180%);
  transition: background 3s ease;
}
