/* ===========================================================================
   पितृ प्रसाद ग्रहण — memorial invitation for the late Mrs. Bhim Kumari Bhujel
   Static page. No frameworks, no data collection. Decorative animations are
   CSS-driven; a few petals are seeded by a tiny inline script.
   =========================================================================== */

:root {
  --sky-1: #dff0fb;
  --sky-2: #bfe0f4;
  --sky-3: #a8d3ee;
  --ink: #2a3a4a;
  --ink-soft: #51657a;
  --gold: #e0a52e;
  --gold-deep: #b8791a;
  --saffron: #f08a24;
  --marigold: #f6a623;
  --maroon: #8a2b2b;
  --rose: #c1456b;
  --card: rgba(255, 255, 255, 0.86);
  --card-border: rgba(184, 121, 26, 0.45);
  --shadow: 0 18px 50px rgba(43, 74, 105, 0.22);
  --font-dev: "Noto Serif Devanagari", "Tiro Devanagari Sanskrit", serif;
  --font-en: "EB Garamond", Georgia, "Times New Roman", serif;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  min-height: 100vh;
  color: var(--ink);
  font-family: var(--font-en);
  background:
    radial-gradient(1200px 600px at 50% -10%, #ffffff 0%, rgba(255, 255, 255, 0) 60%),
    radial-gradient(900px 500px at 12% 8%, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0) 55%),
    radial-gradient(900px 500px at 88% 14%, rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0) 55%),
    linear-gradient(180deg, var(--sky-1) 0%, var(--sky-2) 45%, var(--sky-3) 100%);
  background-attachment: fixed;
  overflow-x: hidden;
}

/* --- ambient layers (petals + doves) sit behind content ------------------ */
.sky {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  pointer-events: none;
  z-index: 5;
  overflow: hidden;
}

.petal {
  position: absolute;
  top: -8vh;
  width: 14px;
  height: 9px;
  background: radial-gradient(circle at 30% 30%, #ffd27a, var(--marigold) 70%, var(--gold-deep));
  border-radius: 80% 10% 80% 10%;
  opacity: 0.85;
  will-change: transform;
  animation: petal-fall linear infinite;
}

@keyframes petal-fall {
  0%   { transform: translate3d(0, -10vh, 0) rotate(0deg); opacity: 0; }
  10%  { opacity: 0.9; }
  50%  { transform: translate3d(28px, 50vh, 0) rotate(180deg); }
  90%  { opacity: 0.9; }
  100% { transform: translate3d(-22px, 110vh, 0) rotate(360deg); opacity: 0; }
}

.dove {
  position: absolute;
  width: 64px;
  height: auto;
  opacity: 0.75;
  filter: drop-shadow(0 3px 6px rgba(43, 74, 105, 0.18));
  animation: dove-glide linear infinite;
}
.dove .wing { transform-origin: 50% 60%; animation: flap 1.6s ease-in-out infinite; }

@keyframes dove-glide {
  0%   { transform: translate3d(-15vw, 0, 0); }
  100% { transform: translate3d(115vw, -6vh, 0); }
}
@keyframes flap {
  0%, 100% { transform: rotate(-8deg); }
  50%      { transform: rotate(12deg); }
}

/* --- card ----------------------------------------------------------------- */
.wrap {
  position: relative;
  z-index: 1;
  max-width: 680px;
  margin: 0 auto;
  padding: 28px 16px 56px;
}

.card {
  position: relative;
  background: var(--card);
  backdrop-filter: blur(2px);
  border: 3px solid var(--gold-deep);
  border-radius: 22px;
  box-shadow: var(--shadow), inset 0 0 0 1px rgba(255, 255, 255, 0.6);
  padding: 0 26px 36px;
  overflow: hidden;
}

/* bold double inner keyline */
.card::before {
  content: "";
  position: absolute;
  inset: 7px;
  border: 2px solid var(--gold);
  border-radius: 17px;
  pointer-events: none;
  z-index: 3;
}
.card::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1.5px solid rgba(192, 69, 107, 0.5);
  border-radius: 13px;
  pointer-events: none;
  z-index: 3;
}

/* marigold garland across the top of the card */
.garland {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 2px;
  margin: 0 -26px 6px;
  padding-top: 4px;
  line-height: 0;
  overflow: hidden;
}
.garland .bud { flex: 0 0 auto; }
.garland .bud svg { display: block; }

/* mirror of the top garland, hanging from the bottom edge of the card */
.garland-bottom {
  margin: 24px -26px -28px;
  padding-top: 0;
  padding-bottom: 4px;
  transform: scaleY(-1);
}

/* --- header --------------------------------------------------------------- */
.eyebrow {
  text-align: center;
  font-family: var(--font-dev);
  color: var(--maroon);
  letter-spacing: 0.04em;
  margin: 6px 0 0;
}
.eyebrow .big { font-size: 1.15rem; font-weight: 700; }
.eyebrow .small { display: block; font-size: 0.8rem; color: var(--ink-soft); margin-top: 2px; }

.blessing {
  text-align: center;
  font-family: var(--font-dev);
  color: var(--gold-deep);
  font-weight: 700;
  font-size: 1.05rem;
  margin: 14px 0 2px;
}
.sub-blessing {
  text-align: center;
  font-family: var(--font-dev);
  color: var(--maroon);
  font-weight: 700;
  font-size: 1.3rem;
  margin: 2px 0 4px;
}

.divider {
  display: flex;
  justify-content: center;
  margin: 10px 0;
}

/* --- portrait ------------------------------------------------------------- */
.portrait-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin: 22px 0 28px;
}
.portrait {
  position: relative;
  width: 190px;
  height: 190px;
  flex: 0 0 auto;
}
.portrait .ring {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(100% + 52px);
  height: calc(100% + 52px);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: slow-spin 22s linear infinite;
}
.portrait img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--gold);
  box-shadow:
    0 0 0 4px #fff,
    0 0 0 7px var(--gold-deep),
    0 8px 22px rgba(43, 74, 105, 0.32);
}
@keyframes slow-spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to   { transform: translate(-50%, -50%) rotate(360deg); }
}

.name {
  text-align: center;
  font-family: var(--font-dev);
  color: var(--ink);
  font-weight: 700;
  font-size: 1.45rem;
  margin: 12px 0 2px;
}
.name .en { display: block; font-family: var(--font-en); font-size: 0.95rem; color: var(--ink-soft); font-weight: 400; letter-spacing: 0.06em; margin-top: 2px; }

/* --- title with flanking diyas ------------------------------------------- */
.title-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 14px 0 6px;
}
.title {
  font-family: var(--font-dev);
  font-weight: 700;
  font-size: clamp(1.7rem, 6vw, 2.4rem);
  color: var(--maroon);
  text-align: center;
  margin: 0;
  text-shadow: 0 1px 0 #fff;
}

/* diya lamp + glowing flame */
.diya { width: 78px; height: 78px; flex: 0 0 auto; }
.flame {
  transform-origin: 50% 100%;
  animation: flicker 1.6s ease-in-out infinite alternate;
}
.flame-glow {
  fill: #ffd36b;
  opacity: 0.6;
  transform-origin: 50% 70%;
  animation: glow-pulse 1.8s ease-in-out infinite alternate;
}
@keyframes flicker {
  0%   { transform: scale(1) rotate(-2deg); opacity: 0.92; }
  40%  { transform: scale(1.06) rotate(1.5deg); opacity: 1; }
  70%  { transform: scale(0.97) rotate(-1deg); opacity: 0.95; }
  100% { transform: scale(1.05) rotate(2deg); opacity: 1; }
}
@keyframes glow-pulse {
  0%   { opacity: 0.45; transform: scale(0.9); }
  100% { opacity: 0.8; transform: scale(1.25); }
}

/* --- text blocks ---------------------------------------------------------- */
.body-np {
  font-family: var(--font-dev);
  color: var(--ink);
  font-size: 1.02rem;
  line-height: 1.95;
  text-align: center;
  margin: 6px auto 10px;
  max-width: 38rem;
}
.body-en {
  font-size: 0.96rem;
  line-height: 1.7;
  color: var(--ink-soft);
  text-align: center;
  margin: 0 auto;
  max-width: 36rem;
  font-style: italic;
}

/* --- details panel -------------------------------------------------------- */
.section-label {
  font-family: var(--font-dev);
  font-weight: 700;
  color: var(--gold-deep);
  text-align: center;
  font-size: 1.1rem;
  margin: 22px 0 8px;
}
.details {
  background: linear-gradient(180deg, rgba(255, 249, 235, 0.9), rgba(255, 255, 255, 0.7));
  border: 1px solid rgba(224, 165, 46, 0.4);
  border-radius: 16px;
  padding: 16px 18px;
  max-width: 30rem;
  margin: 0 auto;
}
.detail {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 8px 2px;
  border-bottom: 1px dashed rgba(184, 121, 26, 0.25);
}
.detail:last-child { border-bottom: none; }
.detail .ico { font-size: 1.15rem; line-height: 1.6; flex: 0 0 auto; }
.detail .np { font-family: var(--font-dev); font-weight: 700; color: var(--ink); }
.detail .en { display: block; font-size: 0.85rem; color: var(--ink-soft); font-weight: 400; font-style: italic; }
.detail a { color: var(--maroon); text-decoration: none; border-bottom: 1px dotted var(--gold); }
.detail a:hover { color: var(--rose); }

/* --- map ------------------------------------------------------------------ */
.map {
  margin: 16px auto 0;
  max-width: 30rem;
}
.map iframe {
  width: 100%;
  height: 230px;
  border: 0;
  border-radius: 14px;
  box-shadow: 0 8px 22px rgba(43, 74, 105, 0.18);
}
.map-link {
  display: inline-block;
  margin-top: 8px;
  font-size: 0.9rem;
  color: var(--maroon);
  text-decoration: none;
  border-bottom: 1px dotted var(--gold);
}

/* --- family --------------------------------------------------------------- */
.family {
  text-align: center;
  margin: 22px auto 0;
  max-width: 32rem;
}
.family ul { list-style: none; padding: 0; margin: 6px 0 0; }
.family li {
  font-family: var(--font-dev);
  color: var(--ink);
  padding: 4px 0;
  font-size: 1.0rem;
}
.family li .en { display: block; font-family: var(--font-en); font-size: 0.82rem; color: var(--ink-soft); font-style: italic; }

/* --- contact -------------------------------------------------------------- */
.contact {
  text-align: center;
  margin: 22px auto 0;
}
.contact .phones {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 8px;
}
.contact a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(180deg, #fff7e8, #ffeccd);
  border: 1px solid rgba(224, 165, 46, 0.55);
  color: var(--maroon);
  text-decoration: none;
  padding: 10px 16px;
  border-radius: 999px;
  font-weight: 700;
  box-shadow: 0 4px 12px rgba(184, 121, 26, 0.18);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.contact a:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(184, 121, 26, 0.28); }

/* --- footer --------------------------------------------------------------- */
.shanti {
  text-align: center;
  font-family: var(--font-dev);
  color: var(--gold-deep);
  font-weight: 700;
  letter-spacing: 0.12em;
  margin-top: 28px;
  font-size: 1.05rem;
}
.footnote {
  text-align: center;
  color: var(--ink-soft);
  font-size: 0.78rem;
  margin-top: 10px;
}

/* --- responsive ----------------------------------------------------------- */
@media (max-width: 480px) {
  .card { padding: 0 16px 28px; }
  .garland { margin: 0 -16px 6px; }
  .garland-bottom { margin: 24px -16px -20px; }
  .portrait { width: 158px; height: 158px; }
  .diya { width: 60px; height: 60px; }
  .body-np { font-size: 0.98rem; }
}

/* respect reduced-motion preferences */
@media (prefers-reduced-motion: reduce) {
  .petal, .dove, .dove .wing, .portrait .ring, .flame, .flame-glow { animation: none !important; }
  .petal, .dove { display: none; }
}
