:root{
  --bg:#0b1220;
  --card:#121b2f;
  --line:#223055;
  --text:#e8eefc;
  --muted:rgba(232,238,252,.78);
  --accent:#4f7cff;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;background:var(--bg);color:var(--text);padding:24px}
.card{max-width:560px;margin:0 auto;background:var(--card);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.header h1{margin:0 0 8px}
.muted{color:var(--muted)}
.small{font-size:12px}
.actions{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
button{flex:1;min-width:160px;padding:14px 12px;border:0;border-radius:12px;background:var(--accent);color:#fff;font-weight:800;font-size:15px}
button.secondary{background:#1a2645;border:1px solid var(--line)}
button:disabled{opacity:.6}
.status{margin-top:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:#0b1220;font-size:13px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.box{border:1px solid var(--line);border-radius:14px;background:#0b1220;padding:12px}
.label{font-size:12px;color:var(--muted)}
.big{font-size:28px;font-weight:900;margin:8px 0 2px;line-height:1.1}
.compassWrap{margin-top:14px;display:flex;flex-direction:column;align-items:center;gap:10px}
.compass{width:260px;height:260px;border-radius:50%;border:1px solid var(--line);background:radial-gradient(circle at 30% 30%, #142048, #0b1220 65%);position:relative;overflow:hidden}
.dial{position:absolute;inset:18px;border-radius:50%;border:1px dashed rgba(232,238,252,.22)}
.north{position:absolute;top:10px;left:50%;transform:translateX(-50%);font-weight:900;opacity:.9}
.centerDot{position:absolute;width:10px;height:10px;background:#fff;border-radius:50%;left:50%;top:50%;transform:translate(-50%,-50%);opacity:.9}
.needle{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(0deg);transform-origin:50% 50%}
.needleBody{position:absolute;width:6px;height:92px;background:rgba(255,255,255,.9);left:-3px;top:-92px;border-radius:6px}
.needleHead{position:absolute;width:0;height:0;border-left:14px solid transparent;border-right:14px solid transparent;border-bottom:20px solid rgba(255,255,255,.95);left:-14px;top:-112px}
.hint{text-align:center;max-width:320px}
.align{padding:8px 10px;border-radius:999px;border:1px solid rgba(232,238,252,.25);background:#0b1220;font-size:12px}
.meta{margin-top:12px;display:flex;flex-wrap:wrap;gap:10px}
.pill{padding:10px 12px;border-radius:999px;background:#0b1220;border:1px solid var(--line);font-size:12px}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.55);padding:18px}
.modal.show{display:flex}
.modalCard{width:min(520px,100%);background:#121b2f;border:1px solid #223055;border-radius:16px;padding:14px;box-shadow:0 20px 60px rgba(0,0,0,.45)}
.modalHead{display:flex;align-items:center;justify-content:space-between;gap:10px}
.modalHead h2{margin:0;font-size:18px}
.modalClose{min-width:auto;width:44px;flex:0 0 auto}
.modalList{margin:12px 0 0;padding-left:18px;line-height:1.5}
.modalActions{margin-top:12px;display:flex;gap:10px}
.mapWrap{margin-top:14px;border:1px solid var(--line);border-radius:14px;background:#0b1220;padding:12px}
.mapHeader{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.map{width:100%;height:320px;border-radius:12px;overflow:hidden;border:1px solid rgba(232,238,252,.18)}


/* Prayer times */
.prayerWrap{
  margin-top:14px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#0b1220;
  padding:12px;
}
.prayerHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.prayerHead button{
  min-width:auto;
  flex:0 0 auto;
  padding:12px 12px;
}
.nextBox{
  margin-top:10px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(232,238,252,.18);
  background:rgba(255,255,255,.03);
}
.nextName{font-size:18px;font-weight:900;margin-top:2px}
.nextLeft{font-size:14px;font-weight:800;margin-top:2px}
.prayerList{
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.prayerRow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(232,238,252,.12);
  background:rgba(255,255,255,.02);
}
.prayerRow.active{
  border-color:rgba(79,124,255,.7);
  background:rgba(79,124,255,.08);
}
.prayerName{font-weight:900}
.prayerTime{font-variant-numeric:tabular-nums; font-weight:800}


/* Alarm toggles */
.prayerControls{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.toggle{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(232,238,252,.14);
  background:rgba(255,255,255,.02);
  font-size:12px;
  color:var(--muted);
}
.toggle input{accent-color: var(--accent)}

/* Prayer head layout tweaks */
.prayerHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.prayerLeft{flex:1; min-width:220px}
.prayerRight{flex:0 0 auto}
.prayerControls{margin-top:10px; justify-content:flex-start}
.prayerControls button{min-width:auto}
@media (max-width:520px){
  .prayerHead{flex-direction:column; align-items:stretch}
  .prayerRight button{width:100%}
}


.dialGroup{position:absolute;inset:0;transform-origin:50% 50%}
