/*
  RamadanDaily.com — responsive, animated Ramadan day experience
  Author: generated project
*/

:root{
  --bg0:#040610;
  --bg1:#070a18;
  --bg2:#0b1027;
  --glass:rgba(255,255,255,.06);
  --glass2:rgba(255,255,255,.09);
  --border:rgba(255,255,255,.14);
  --border2:rgba(255,255,255,.22);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.74);
  --muted2:rgba(255,255,255,.62);
  --shadow: 0 20px 60px rgba(0,0,0,.45);

  /* Persian accent */
  --persia-green:#0b8f4a;
  --persia-white:#f4f4f4;
  --persia-red:#d7263d;

  /* Ramadan gold */
  --gold:#d7b45a;
  --gold2:#f3d78a;

  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 16px;
  --radius-sm: 12px;

  --maxw: 1160px;

  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-top: env(safe-area-inset-top, 0px);

  --focus: 0 0 0 3px rgba(215,180,90,.35);
}

*{box-sizing:border-box}
html,body{height:100%}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color:var(--text);
  background:
    radial-gradient(900px 600px at 80% 20%, rgba(215,180,90,.12), transparent 55%),
    radial-gradient(900px 600px at 20% 80%, rgba(11,143,74,.10), transparent 60%),
    radial-gradient(700px 500px at 40% 10%, rgba(215,180,90,.08), transparent 65%),
    linear-gradient(180deg, var(--bg0), var(--bg2) 55%, #050816);
  min-height:100vh;
  overflow-x:hidden;
}

/* Persian pattern overlay */
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:url('/assets/img/pattern.svg');
  background-size:420px 420px;
  opacity:.22;
  mix-blend-mode:screen;
  filter: blur(.2px);
  z-index:-1;
}

/* Star field */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:
    radial-gradient(1px 1px at 12% 28%, rgba(255,255,255,.8) 50%, transparent 55%),
    radial-gradient(1px 1px at 58% 18%, rgba(255,255,255,.5) 50%, transparent 55%),
    radial-gradient(1px 1px at 78% 68%, rgba(255,255,255,.55) 50%, transparent 55%),
    radial-gradient(1px 1px at 34% 78%, rgba(255,255,255,.6) 50%, transparent 55%),
    radial-gradient(1px 1px at 92% 40%, rgba(255,255,255,.6) 50%, transparent 55%),
    radial-gradient(1px 1px at 15% 65%, rgba(255,255,255,.55) 50%, transparent 55%),
    radial-gradient(1px 1px at 48% 52%, rgba(255,255,255,.55) 50%, transparent 55%);
  opacity:.45;
  z-index:-2;
}

a{color:inherit; text-decoration:none}
a:hover{text-decoration:underline}

.container{
  width:min(var(--maxw), calc(100% - 32px));
  margin:0 auto;
}

.topbar-wrap{
  position:sticky;
  top:0;
  z-index:20;
  padding-top: var(--safe-top);
  backdrop-filter: blur(12px);
  background: linear-gradient(180deg, rgba(4,6,16,.86), rgba(4,6,16,.55));
  border-bottom:1px solid rgba(255,255,255,.08);
}

.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 220px;
}

.brand .mark{
  width:38px; height:38px;
  border-radius: 12px;
  background: radial-gradient(circle at 30% 30%, rgba(243,215,138,.95), rgba(215,180,90,.25) 55%, rgba(11,143,74,.12) 80%),
              linear-gradient(180deg, rgba(215,180,90,.22), rgba(215,180,90,.06));
  border:1px solid rgba(255,255,255,.20);
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  position:relative;
  overflow:hidden;
}
.brand .mark::after{
  content:"";
  position:absolute;
  inset:-40% -40%;
  background: conic-gradient(from 210deg, transparent, rgba(215,180,90,.35), transparent 55%);
  animation: spin 7.5s linear infinite;
  opacity:.75;
}

@keyframes spin{to{transform: rotate(360deg)}}

.brand .name{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}
.brand .name strong{font-size:14px; letter-spacing:.6px}
.brand .name span{font-size:12px; color:var(--muted2)}

.flag-accent{
  height:3px;
  width:100%;
  background: linear-gradient(90deg, var(--persia-green), var(--persia-white), var(--persia-red));
  opacity:.85;
}

.actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color:var(--text);
  cursor:pointer;
  user-select:none;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}

.btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.22);
}

.btn:active{transform: translateY(0px) scale(.99)}

.btn:focus-visible{outline:none; box-shadow: var(--focus)}

.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  color: var(--muted);
  font-size:12px;
}

main{
  padding: 18px 0 120px;
}

.grid{
  display:grid;
  gap:16px;
}

/* Desktop layout */
@media (min-width: 980px){
  .grid{
    grid-template-columns: 360px 1fr 320px;
    align-items:start;
  }
}

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.035));
  border:1px solid rgba(255,255,255,.12);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}

.card::before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(650px 300px at 40% 0%, rgba(243,215,138,.12), transparent 55%),
              radial-gradient(700px 320px at 0% 75%, rgba(11,143,74,.11), transparent 60%);
  opacity:.9;
  pointer-events:none;
}

.card > *{
  position:relative;
}

.card-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:16px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.card-header h2{
  margin:0;
  font-size:14px;
  letter-spacing:.5px;
  text-transform:uppercase;
  color:var(--muted);
}

.card-body{
  padding: 16px 18px 18px;
}

.moon-hero{
  padding: 16px 18px 18px;
}

.moon-canvas{
  width:100%;
  aspect-ratio: 1 / 1;
  max-height: 330px;
  border-radius: 22px;
  background: radial-gradient(circle at 30% 30%, rgba(243,215,138,.09), rgba(255,255,255,.02) 55%, rgba(0,0,0,.25) 85%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow: 0 25px 70px rgba(0,0,0,.45);
  display:block;
}

.moon-meta{
  margin-top: 14px;
  display:grid;
  gap:10px;
}

.kpis{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

.kpi{
  flex:1;
  min-width: 120px;
  padding:12px;
  border-radius: var(--radius-md);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}

.kpi .label{font-size:11px; color:var(--muted2); text-transform:uppercase; letter-spacing:.6px}
.kpi .value{margin-top:6px; font-size:15px; font-weight:650}

.moon-strip{
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(11,143,74,.9), rgba(244,244,244,.7), rgba(215,38,61,.9));
  opacity:.65;
  overflow:hidden;
}

.moon-strip .fill{
  height:100%;
  width: 50%;
  background: linear-gradient(90deg, rgba(215,180,90,.9), rgba(243,215,138,.35));
  border-radius:999px;
  filter: blur(.0px);
  box-shadow: 0 0 18px rgba(243,215,138,.55);
}

.dua-ar{
  font-family: ui-serif, "Geeza Pro", "Noto Naskh Arabic", "Amiri", serif;
  font-size: 28px;
  line-height:1.65;
  letter-spacing:.2px;
  margin: 10px 0 0;
  text-align:right;
}

.dua-translit{
  margin-top:12px;
  color:var(--muted);
  line-height:1.55;
  font-size: 14px;
}

.dua-translation{
  margin-top: 12px;
  color: rgba(255,255,255,.88);
  font-size: 15px;
  line-height:1.65;
}

.meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top: 14px;
}

.tabs{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top: 10px;
}

.tab{
  padding:8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  cursor:pointer;
  color: var(--muted);
  font-size:12px;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}

.tab:hover{transform: translateY(-1px); border-color: rgba(255,255,255,.22)}
.tab[aria-selected="true"]{
  background: rgba(215,180,90,.18);
  border-color: rgba(243,215,138,.55);
  color: rgba(255,255,255,.92);
}

.small-note{
  margin-top:12px;
  color: var(--muted2);
  font-size: 12px;
  line-height:1.5;
}

.list{
  display:grid;
  gap:10px;
}

.check{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:10px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}

.check input{margin-top: 3px; width:18px; height:18px}
.check label{cursor:pointer; line-height:1.45; color: rgba(255,255,255,.88)}
.check .hint{display:block; color: var(--muted2); font-size: 12px; margin-top:4px}

.event{
  padding:12px;
  border-radius: var(--radius-md);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.event .title{font-weight:650}
.event .when{margin-top:4px; color:var(--muted2); font-size:12px}

/* Timeline */
.timeline{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:30;
  padding: 10px 0 calc(10px + var(--safe-bottom));
  background: linear-gradient(180deg, rgba(5,8,22,0), rgba(5,8,22,.78) 30%, rgba(5,8,22,.92));
  backdrop-filter: blur(12px);
  border-top:1px solid rgba(255,255,255,.10);
}

.timeline-inner{
  width:min(var(--maxw), calc(100% - 24px));
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:10px;
}

.timeline .navbtn{
  width:44px; height:44px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  cursor:pointer;
  color:rgba(255,255,255,.92);
  display:flex;
  align-items:center;
  justify-content:center;
  transition: transform .15s ease, background .15s ease;
}
.timeline .navbtn:hover{transform: translateY(-1px); background: rgba(255,255,255,.06)}
.timeline .navbtn:active{transform: translateY(0px) scale(.99)}
.timeline .navbtn:focus-visible{outline:none; box-shadow: var(--focus)}

.range-wrap{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.range-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:12px;
  color: var(--muted2);
}

.range-top strong{color: rgba(255,255,255,.90); font-weight:650}

input[type="range"]{
  -webkit-appearance:none;
  appearance:none;
  width:100%;
  height: 34px;
  background: transparent;
}

input[type="range"]:focus{outline:none}

input[type="range"]::-webkit-slider-runnable-track{
  height: 10px;
  border-radius: 999px;
  background:
    linear-gradient(90deg,
      rgba(11,143,74,.75),
      rgba(244,244,244,.45) 45%,
      rgba(215,38,61,.75)
    );
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);
}

input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;
  appearance:none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255,255,255,.96), rgba(243,215,138,.55) 40%, rgba(215,180,90,.22) 70%);
  border: 1px solid rgba(255,255,255,.35);
  box-shadow: 0 10px 24px rgba(0,0,0,.35), 0 0 22px rgba(243,215,138,.35);
  margin-top: -10px;
}

input[type="range"]::-moz-range-track{
  height: 10px;
  border-radius: 999px;
  background:
    linear-gradient(90deg,
      rgba(11,143,74,.75),
      rgba(244,244,244,.45) 45%,
      rgba(215,38,61,.75)
    );
  border: 1px solid rgba(255,255,255,.16);
}
input[type="range"]::-moz-range-thumb{
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(255,255,255,.96), rgba(243,215,138,.55) 40%, rgba(215,180,90,.22) 70%);
  border: 1px solid rgba(255,255,255,.35);
  box-shadow: 0 10px 24px rgba(0,0,0,.35), 0 0 22px rgba(243,215,138,.35);
}

.fade{
  animation: fade .28s ease;
}
@keyframes fade{
  from{opacity:0; transform: translateY(6px)}
  to{opacity:1; transform: translateY(0)}
}

/* Dialog (Settings) */

dialog{
  border:none;
  padding:0;
  border-radius: 22px;
  width:min(720px, calc(100% - 26px));
  background: rgba(10,14,32,.92);
  color: var(--text);
  box-shadow: 0 40px 120px rgba(0,0,0,.65);
}

dialog::backdrop{
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(5px);
}

.dialog-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

.dialog-header h3{margin:0; font-size:15px; letter-spacing:.4px}

.dialog-body{
  padding: 16px 18px 18px;
}

.form{
  display:grid;
  gap:14px;
}

.field{
  display:grid;
  gap:8px;
}

.field label{
  font-size:12px;
  color: var(--muted);
  letter-spacing:.4px;
  text-transform:uppercase;
}

select, input[type="date"], input[type="text"]{
  width:100%;
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  color: var(--text);
}

select:focus-visible, input[type="date"]:focus-visible, input[type="text"]:focus-visible{
  outline:none;
  box-shadow: var(--focus);
}

.dialog-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  padding: 14px 18px 18px;
  border-top:1px solid rgba(255,255,255,.10);
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius: 999px;
  background: rgba(215,180,90,.14);
  border:1px solid rgba(243,215,138,.32);
  color: rgba(255,255,255,.92);
  font-size:12px;
}

.footer{
  padding: 22px 0 120px;
  color: var(--muted2);
  font-size: 12px;
}

.footer a{color: rgba(255,255,255,.86)}

/* RTL support */

[dir="rtl"] .dua-ar{text-align:right}
[dir="rtl"] .brand{flex-direction:row-reverse}
[dir="rtl"] .topbar{flex-direction:row-reverse}
[dir="rtl"] .actions{flex-direction:row-reverse}
[dir="rtl"] .card-header{flex-direction:row-reverse}
[dir="rtl"] .meta-row{flex-direction:row-reverse}

 float{
  0%,100%{transform: translateY(0px)}
  50%{transform: translateY(-6px)}
}

.moon-canvas{
  animation: float 7.2s ease-in-out infinite;
  will-change: transform;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .brand .mark::after{animation:none}
  .fade{animation:none}
  .btn, .tab, .timeline .navbtn{transition:none}
}

/* Bold theme accent */
.theme-bold .flag-accent{opacity: 1}
body.theme-bold::after{opacity:.30}
.theme-bold .card{border-color: rgba(255,255,255,.16)}

/* Toast */
#toast{
  position: fixed;
  left: 50%;
  bottom: calc(86px + var(--safe-bottom));
  transform: translateX(-50%) translateY(12px);
  background: rgba(10,14,32,.92);
  border: 1px solid rgba(255,255,255,.16);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  border-radius: 999px;
  font-size: 13px;
  opacity: 0;
  pointer-events:none;
  transition: opacity .18s ease, transform .18s ease;
  box-shadow: 0 18px 50px rgba(0,0,0,.55);
  z-index: 50;
}
#toast.show{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* Calendar page */
.calendar-header{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  padding: 18px 0 10px;
}
.calendar-header h1{
  margin:0;
  font-size: 22px;
  letter-spacing:.2px;
}
.calendar-header p{
  margin:6px 0 0;
  color: var(--muted2);
  font-size: 13px;
}

.calendar-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
}

@media (min-width: 640px){
  .calendar-grid{grid-template-columns: repeat(3, minmax(0,1fr));}
}
@media (min-width: 980px){
  .calendar-grid{grid-template-columns: repeat(5, minmax(0,1fr));}
}

.day-tile{
  display:flex;
  gap: 12px;
  align-items:center;
  padding: 12px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
}

.day-tile:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.04);
}

.day-tile:focus-visible{outline:none; box-shadow: var(--focus)}

.day-tile .mini-moon{
  width: 48px;
  height: 48px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
}

.day-tile .meta{
  display:flex;
  flex-direction:column;
  gap: 3px;
}

.day-tile .meta strong{font-size: 14px}
.day-tile .meta span{font-size: 12px; color: var(--muted2)}

.day-tile.current{
  border-color: rgba(243,215,138,.55);
  background: rgba(215,180,90,.10);
}

