/* ═══════════════════════════════════════════════════
   BASE.CSS — Variables, Reset, Typography, Layout
   Edit this file to change the overall theme/colours
   ═══════════════════════════════════════════════════ */

/* ── Colour Palette ── */
:root {
  --s:   #FF6B1A;          /* saffron (primary) */
  --ds:  #E8420A;          /* dark saffron */
  --g:   #D4A017;          /* gold */
  --bri: #F5C842;          /* bright gold */
  --dk:  #0D0804;          /* darkest bg */
  --dm:  #1A0A00;          /* dark bg */
  --wm:  #120906;          /* warm dark bg */
  --tl:  #FFF8EE;          /* light text */
  --tm:  #C8A882;          /* muted text */
  --go:  rgba(255,107,26,.4);
  --ggo: rgba(212,160,23,.3);
}

/* ── Reset ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--dk);
  color: var(--tl);
  font-family: 'Lato', sans-serif;
  overflow-x: hidden;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--dk); }
::-webkit-scrollbar-thumb { background:var(--s); border-radius:3px; }

/* ── Canvas overlay ── */
#cv { position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.3; }

/* ── Section wrapper ── */
section { position:relative; z-index:1; padding:5.5rem 2rem; }

/* ── Section heading block ── */
.sh { text-align:center; margin-bottom:3.5rem; }
.st {
  font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.28em;
  text-transform:uppercase; color:var(--s); display:block; margin-bottom:.9rem;
}
.stt {
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(1.7rem,3.5vw,2.8rem);
  font-weight:700; color:var(--g); margin-bottom:.9rem; line-height:1.2;
}
.sd {
  display:flex; align-items:center; justify-content:center;
  gap:1rem; margin-bottom:.9rem;
}
.sd span { color:var(--s); }
.sd::before, .sd::after {
  content:''; width:55px; height:1px;
  background:linear-gradient(90deg,transparent,var(--g));
}
.sd::after { background:linear-gradient(90deg,var(--g),transparent); }
.sdesc {
  font-size:.95rem; color:var(--tm);
  max-width:580px; margin:0 auto; line-height:1.8;
}

/* ── Buttons ── */
.bp {
  font-family:'Cinzel',serif; font-size:.82rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  padding:.95rem 2.4rem;
  background:linear-gradient(135deg,var(--s),var(--ds));
  color:#fff; text-decoration:none; border:none; border-radius:5px;
  cursor:pointer; position:relative; overflow:hidden;
  box-shadow:0 4px 18px rgba(255,107,26,.4);
  transition:all .3s; display:inline-block;
}
.bp:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(255,107,26,.6); }
.bo {
  font-family:'Cinzel',serif; font-size:.82rem; font-weight:700;
  letter-spacing:.14em; text-transform:uppercase;
  padding:.95rem 2.4rem; background:transparent; color:var(--g);
  text-decoration:none; border:1px solid var(--g); border-radius:5px;
  cursor:pointer; transition:all .3s; display:inline-block;
}
.bo:hover {
  background:rgba(212,160,23,.1); border-color:var(--bri);
  color:var(--bri); box-shadow:0 0 18px rgba(212,160,23,.18);
}

/* ── Form inputs (shared across contact, booking, donation) ── */
.fi2 {
  background:rgba(26,10,0,.55); border:1px solid rgba(212,160,23,.2);
  border-radius:8px; padding:.8rem 1rem; color:var(--tl);
  font-size:.9rem; font-family:'Lato',sans-serif;
  transition:border-color .3s; outline:none; width:100%;
}
.fi2:focus { border-color:var(--s); box-shadow:0 0 12px rgba(255,107,26,.1); }
.fi2 option { background:#1A0A00; }
.fl {
  font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.18em;
  color:var(--tm); text-transform:uppercase; display:block; margin-bottom:.35rem;
}
.fg2 { display:flex; flex-direction:column; gap:1rem; margin-top:1.2rem; text-align:left; }
.fr2 { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

/* ── Toast ── */
.toast {
  position:fixed; bottom:5rem; left:50%;
  transform:translateX(-50%) translateY(20px);
  background:linear-gradient(135deg,var(--dm),var(--wm));
  border:1px solid var(--g); border-radius:10px;
  padding:.9rem 1.8rem; font-family:'Cinzel',serif;
  font-size:.82rem; color:var(--g); z-index:4000;
  opacity:0; transition:all .4s; white-space:nowrap;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ── Back to top ── */
.btt {
  position:fixed; bottom:2rem; right:2rem;
  width:48px; height:48px;
  background:linear-gradient(135deg,var(--s),var(--ds));
  border-radius:50%; display:flex; align-items:center;
  justify-content:center; text-decoration:none; font-size:1.2rem;
  box-shadow:0 4px 18px rgba(255,107,26,.5); z-index:999;
  opacity:0; pointer-events:none; transition:all .3s;
}
.btt.vis { opacity:1; pointer-events:all; }
.btt:hover { transform:translateY(-3px); box-shadow:0 8px 28px rgba(255,107,26,.7); }

/* ── Floating diya ── */
.fldiya {
  position:fixed; bottom:2rem; left:2rem; z-index:999;
  cursor:pointer; animation:df 3s ease-in-out infinite;
  font-size:1.9rem; filter:drop-shadow(0 0 9px rgba(255,107,26,.8));
}
@keyframes df { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)} }

/* ── Keyframes ── */
@keyframes op {
  0%,100%{text-shadow:0 0 10px var(--s),0 0 28px rgba(255,107,26,.5)}
  50%{text-shadow:0 0 22px var(--bri),0 0 50px var(--g)}
}
@keyframes fsu { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:translateY(0)} }
@keyframes fi  { from{opacity:0} to{opacity:1} }
@keyframes rs  { from{transform:rotate(0)} to{transform:rotate(360deg)} }
@keyframes rm  {
  from{transform:translate(-50%,-50%) rotate(0)}
  to{transform:translate(-50%,-50%) rotate(360deg)}
}
@keyframes lp {
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.8)}
}
@keyframes sb {
  0%,100%{opacity:1;transform:scaleY(1)}
  50%{opacity:.35;transform:scaleY(.55)}
}
@keyframes tick { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── Reveal animation ──
   Content is always visible (opacity:1).
   JS adds .animate first (makes it hidden),
   then adds .vis when scrolled into view.
   If JS fails: content stays visible. ── */
.rv { opacity:1; transform:none; }
.rv.animate {
  opacity:0; transform:translateY(36px);
  transition:opacity .8s ease, transform .8s ease;
}
.rv.animate.vis { opacity:1; transform:translateY(0); }
.rv.animate.d1 { transition-delay:.1s; }
.rv.animate.d2 { transition-delay:.2s; }
.rv.animate.d3 { transition-delay:.3s; }
.rv.animate.d4 { transition-delay:.4s; }

/* ── Mobile menu ── */
.mmenu {
  position:fixed; top:68px; left:0; right:0;
  background:rgba(13,8,4,.98); backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(212,160,23,.18);
  padding:1.8rem; z-index:999;
  transform:translateY(-110%); opacity:0; transition:all .4s;
}
.mmenu.open { transform:translateY(0); opacity:1; }
.mmenu ul { list-style:none; }
.mmenu ul li { border-bottom:1px solid rgba(212,160,23,.09); }
.mmenu ul li a {
  display:block; padding:.9rem 0;
  font-family:'Cinzel',serif; color:var(--tm); text-decoration:none;
  letter-spacing:.14em; text-transform:uppercase; font-size:.82rem;
  transition:color .3s;
}
.mmenu ul li a:hover { color:var(--s); }

/* ── Responsive ── */
@media(max-width:900px) {
  .ag  { grid-template-columns:1fr; gap:2.8rem; }
  .avis { display:none; }
  .cg  { grid-template-columns:1fr; gap:2.8rem; }
  .fogg { grid-template-columns:1fr 1fr; gap:1.8rem; }
  .gg  { grid-template-columns:repeat(2,1fr); grid-template-rows:auto; }
  .gi:first-child { grid-row:auto; grid-column:auto; }
}
@media(max-width:640px) {
  .nl  { display:none; }
  .hbg { display:flex; }
  .fogg { grid-template-columns:1fr; }
  .frw  { grid-template-columns:1fr; }
  .dbox { padding:1.8rem; }
  .gg   { grid-template-columns:1fr; }
  .fr2  { grid-template-columns:1fr; }
  .pbox { padding:1.8rem; }
}

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