/* ================================================================
   DEITY PAGES — shared styles
   Each page overrides --dp-primary / --dp-glow / --dp-bg via
   a class on <body>  e.g.  body.dp-rama
   ================================================================ */

/* ── COLOUR THEMES ── */
body.dp-rama         { --dp-primary:#C9A84C; --dp-glow:rgba(201,168,76,0.7);   --dp-glow2:rgba(255,200,80,0.35);  --dp-bg:#0C0600; --dp-accent:#6B9FD4; }
body.dp-hanuman      { --dp-primary:#FF7A1A; --dp-glow:rgba(255,122,26,0.75);  --dp-glow2:rgba(255,170,60,0.35);  --dp-bg:#0D0400; --dp-accent:#FFB347; }
body.dp-shiva        { --dp-primary:#7AADFF; --dp-glow:rgba(122,173,255,0.7);  --dp-glow2:rgba(160,200,255,0.3);  --dp-bg:#040810; --dp-accent:#C0C8D8; }
body.dp-ganesha      { --dp-primary:#50D28C; --dp-glow:rgba(80,210,140,0.7);   --dp-glow2:rgba(120,230,160,0.3);  --dp-bg:#040E08; --dp-accent:#FFB830; }
body.dp-lakshmi      { --dp-primary:#D4AAFF; --dp-glow:rgba(180,120,255,0.75); --dp-glow2:rgba(200,150,255,0.3);  --dp-bg:#07030F; --dp-accent:#FFD700; }
body.dp-radha        { --dp-primary:#5EC4FF; --dp-glow:rgba(60,180,255,0.75);  --dp-glow2:rgba(100,200,255,0.3);  --dp-bg:#020810; --dp-accent:#FFB8E0; }
body.dp-durga        { --dp-primary:#FF6B6B; --dp-glow:rgba(255,80,80,0.75);   --dp-glow2:rgba(255,120,80,0.3);   --dp-bg:#0E0202; --dp-accent:#FFD700; }
body.dp-kartikeya    { --dp-primary:#FF9840; --dp-glow:rgba(255,152,64,0.75);  --dp-glow2:rgba(255,180,80,0.3);   --dp-bg:#0A0400; --dp-accent:#FFDD88; }
body.dp-sarasvati    { --dp-primary:#A8DCFF; --dp-glow:rgba(140,210,255,0.7);  --dp-glow2:rgba(200,235,255,0.25); --dp-bg:#020810; --dp-accent:#FFFFFF; }
body.dp-gayatri      { --dp-primary:#FFD84C; --dp-glow:rgba(255,220,76,0.75);  --dp-glow2:rgba(255,240,120,0.3);  --dp-bg:#080600; --dp-accent:#FFFFFF; }
body.dp-surya        { --dp-primary:#FF9030; --dp-glow:rgba(255,144,48,0.8);   --dp-glow2:rgba(255,180,60,0.35);  --dp-bg:#0A0300; --dp-accent:#FFE066; }

/* ── RESET ON DEITY PAGES ── */
body.dp-rama, body.dp-hanuman, body.dp-shiva, body.dp-ganesha,
body.dp-lakshmi, body.dp-radha, body.dp-durga, body.dp-kartikeya,
body.dp-sarasvati, body.dp-gayatri, body.dp-surya {
  background: var(--dp-bg);
  color: #f5e6c8;
}

/* Deity icon glyph on pages without PNG silhouette */
.dp-figure-icon {
  flex: 0 0 auto;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 260px;
  height: 320px;
}
.dp-figure-icon::before {
  content: '';
  position: absolute;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--dp-glow), transparent 65%);
  filter: blur(50px);
  z-index: 0;
}
.dp-figure-glyph {
  font-size: 9rem;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 0 40px var(--dp-glow)) drop-shadow(0 0 80px var(--dp-glow2));
  animation: pulse-glow 3s ease-in-out infinite;
  line-height: 1;
}

/* ── HERO ── */
.dp-hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  padding: 120px 5% 80px;
}

/* Radial glow background */
.dp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 60%, var(--dp-glow2), transparent 70%),
    radial-gradient(ellipse 40% 40% at 50% 55%, var(--dp-glow) , transparent 50%);
  pointer-events: none;
}

/* Temple arch shapes */
.dp-arch {
  position: absolute;
  bottom: 0;
  width: 280px;
  height: 420px;
  border-top-left-radius: 140px;
  border-top-right-radius: 140px;
  border: 2px solid rgba(255,255,255,0.06);
  background: linear-gradient(to top, rgba(255,255,255,0.03), transparent);
  pointer-events: none;
}
.dp-arch-l { left: -60px; }
.dp-arch-r { right: -60px; }
.dp-arch-c {
  width: 380px;
  height: 520px;
  border-top-left-radius: 190px;
  border-top-right-radius: 190px;
  left: 50%;
  transform: translateX(-50%);
  border-color: rgba(255,255,255,0.05);
}

/* Inner hero layout */
.dp-hero-inner {
  display: flex;
  align-items: center;
  gap: 60px;
  max-width: 1100px;
  width: 100%;
  position: relative;
  z-index: 2;
}

/* Figure */
.dp-figure {
  flex: 0 0 auto;
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.dp-figure::before {
  content: '';
  position: absolute;
  width: 300px; height: 300px;
  border-radius: 50%;
  bottom: -20px; left: 50%;
  transform: translateX(-50%);
  background: radial-gradient(circle, var(--dp-glow), transparent 65%);
  filter: blur(50px);
  z-index: 0;
}
.dp-figure img {
  height: 360px;
  width: auto;
  position: relative;
  z-index: 1;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 0 40px var(--dp-glow));
}

/* Hero text */
.dp-hero-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.dp-dev-name {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  color: var(--dp-primary);
  opacity: 0.85;
  letter-spacing: 2px;
}
.dp-hero-text h1 {
  font-family: 'Cinzel Decorative', serif;
  font-size: clamp(2.4rem, 6vw, 5rem);
  color: #fff;
  line-height: 1.1;
  text-shadow: 0 0 60px var(--dp-glow);
}
.dp-mantra {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: clamp(1.1rem, 2.5vw, 1.6rem);
  color: var(--dp-primary);
  letter-spacing: 3px;
  border-left: 3px solid var(--dp-primary);
  padding-left: 16px;
}
.dp-tagline {
  font-family: 'Cormorant Garamond', serif;
  font-size: clamp(1rem, 2vw, 1.3rem);
  color: rgba(245,230,200,0.7);
  font-style: italic;
  max-width: 480px;
}
.dp-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
}
.dp-badge {
  padding: 6px 18px;
  border: 1px solid var(--dp-primary);
  border-radius: 50px;
  font-size: 0.82rem;
  color: var(--dp-primary);
  letter-spacing: 1px;
  background: rgba(255,255,255,0.03);
}

/* Scroll hint */
.dp-scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(245,230,200,0.4);
  font-size: 0.8rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  animation: bounce 2s ease-in-out infinite;
  z-index: 2;
}
.dp-scroll::after {
  content: '';
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--dp-primary), transparent);
}

/* ── CONTENT SECTIONS ── */
.dp-section {
  padding: 90px 5%;
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
}
.dp-section-full {
  padding: 90px 5%;
  position: relative;
}
.dp-section-dark {
  background: rgba(0,0,0,0.4);
  border-top: 1px solid rgba(255,255,255,0.05);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

/* Section header */
.dp-section-header {
  text-align: center;
  margin-bottom: 60px;
}
.dp-section-tag {
  font-family: 'Cormorant Garamond', serif;
  font-size: 0.78rem;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--dp-primary);
  opacity: 0.8;
  display: block;
  margin-bottom: 10px;
}
.dp-section-header h2 {
  font-family: 'Cinzel Decorative', serif;
  font-size: clamp(1.8rem, 4vw, 3rem);
  color: #fff;
  text-shadow: 0 0 40px var(--dp-glow2);
}
.dp-ornament {
  width: 80px;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--dp-primary), transparent);
  margin: 16px auto 0;
}

/* ── TWO COLUMN ── */
.dp-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.dp-two-col.flip { direction: rtl; }
.dp-two-col.flip > * { direction: ltr; }

/* ── STORY TEXT ── */
.dp-story p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  line-height: 1.9;
  color: rgba(245,230,200,0.85);
  margin-bottom: 20px;
}
.dp-story p:first-child::first-letter {
  font-size: 3.5rem;
  float: left;
  line-height: 0.8;
  margin: 8px 12px 0 0;
  color: var(--dp-primary);
  font-family: 'Cinzel Decorative', serif;
}

/* ── QUOTE BOX ── */
.dp-quote {
  border-left: 4px solid var(--dp-primary);
  padding: 20px 28px;
  background: rgba(255,255,255,0.04);
  border-radius: 0 12px 12px 0;
  margin: 30px 0;
}
.dp-quote p {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: 1.2rem;
  color: var(--dp-primary);
  margin-bottom: 8px;
}
.dp-quote span {
  font-size: 0.9rem;
  color: rgba(245,230,200,0.5);
  font-style: italic;
}

/* ── ATTRIBUTES GRID ── */
.dp-attrs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 20px;
}
.dp-attr-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  padding: 24px 20px;
  text-align: center;
  transition: border-color 0.3s, transform 0.3s;
}
.dp-attr-card:hover {
  border-color: var(--dp-primary);
  transform: translateY(-4px);
}
.dp-attr-icon {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--dp-primary);
  opacity: 0.9;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 1px solid var(--dp-primary);
  background: rgba(255,255,255,0.04);
  letter-spacing: 0;
  line-height: 1;
  margin-left: auto;
  margin-right: auto;
  box-shadow: 0 0 16px var(--dp-glow2);
  transition: box-shadow 0.3s, background 0.3s;
}
.dp-attr-card:hover .dp-attr-icon {
  background: rgba(255,255,255,0.08);
  box-shadow: 0 0 24px var(--dp-glow);
}
.dp-attr-card h4 {
  font-family: 'Cinzel Decorative', serif;
  font-size: 0.78rem;
  color: var(--dp-primary);
  letter-spacing: 1px;
  margin-bottom: 6px;
}
.dp-attr-card p {
  font-size: 0.88rem;
  color: rgba(245,230,200,0.6);
  line-height: 1.5;
}

/* ── MANTRA SECTION ── */
.dp-mantras {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.dp-mantra-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-left: 4px solid var(--dp-primary);
  border-radius: 0 16px 16px 0;
  padding: 28px 32px;
  position: relative;
  overflow: hidden;
}
.dp-mantra-card::before {
  content: 'ॐ';
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 4rem;
  color: var(--dp-primary);
  opacity: 0.06;
  font-family: 'Noto Serif Devanagari', serif;
}
.dp-mantra-card h4 {
  font-size: 0.75rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--dp-primary);
  margin-bottom: 10px;
}
.dp-mantra-card .dp-mantra-text {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: 1.5rem;
  color: #fff;
  margin-bottom: 8px;
}
.dp-mantra-card .dp-mantra-trans {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  color: rgba(245,230,200,0.55);
  font-size: 1rem;
}
.dp-mantra-card .dp-mantra-meaning {
  font-size: 0.9rem;
  color: rgba(245,230,200,0.5);
  margin-top: 8px;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 10px;
}

/* ── TIMELINE / STORY STEPS ── */
.dp-timeline {
  position: relative;
  padding-left: 40px;
}
.dp-timeline::before {
  content: '';
  position: absolute;
  left: 12px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: linear-gradient(to bottom, var(--dp-primary), transparent);
}
.dp-tl-item {
  position: relative;
  margin-bottom: 36px;
}
.dp-tl-item::before {
  content: '';
  position: absolute;
  left: -34px;
  top: 6px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--dp-primary);
  box-shadow: 0 0 12px var(--dp-glow);
}
.dp-tl-item h4 {
  font-family: 'Cinzel Decorative', serif;
  font-size: 0.95rem;
  color: var(--dp-primary);
  margin-bottom: 6px;
}
.dp-tl-item p {
  color: rgba(245,230,200,0.72);
  line-height: 1.7;
  font-size: 1rem;
}

/* ── VISIT SECTION ── */
.dp-visit {
  text-align: center;
  padding: 80px 5%;
  background: radial-gradient(ellipse 60% 50% at 50% 50%, var(--dp-glow2), transparent 70%);
}
.dp-visit h2 {
  font-family: 'Cinzel Decorative', serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  color: #fff;
  margin-bottom: 16px;
}
.dp-visit p {
  color: rgba(245,230,200,0.7);
  max-width: 560px;
  margin: 0 auto 32px;
  line-height: 1.8;
}
.dp-visit-btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.dp-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 36px;
  background: linear-gradient(135deg, var(--dp-primary), var(--dp-accent));
  color: #1a0a00;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  font-weight: 700;
  border-radius: 50px;
  text-decoration: none;
  letter-spacing: 0.5px;
  transition: transform 0.3s, box-shadow 0.3s;
}
.dp-btn-primary:hover { transform: translateY(-3px); box-shadow: 0 8px 30px var(--dp-glow); }
.dp-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 36px;
  border: 1px solid var(--dp-primary);
  color: var(--dp-primary);
  font-family: 'Cormorant Garamond', serif;
  font-size: 1rem;
  border-radius: 50px;
  text-decoration: none;
  transition: background 0.3s, transform 0.3s;
}
.dp-btn-ghost:hover { background: rgba(255,255,255,0.06); transform: translateY(-3px); }

/* ── DEITY NAV (prev/next) ── */
.dp-deity-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 40px 5%;
  border-top: 1px solid rgba(255,255,255,0.07);
  max-width: 1100px;
  margin: 0 auto;
}
.dp-deity-nav-link {
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-decoration: none;
  transition: opacity 0.3s;
}
.dp-deity-nav-link:hover { opacity: 0.7; }
.dp-deity-nav-link span:first-child {
  font-size: 0.75rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(245,230,200,0.4);
}
.dp-deity-nav-link span:last-child {
  font-family: 'Cinzel Decorative', serif;
  font-size: 1rem;
  color: var(--dp-primary);
}

/* ── DECORATIVE DIVIDER ── */
.dp-divider {
  display: flex;
  align-items: center;
  gap: 20px;
  margin: 0 auto 60px;
  max-width: 600px;
}
.dp-divider::before, .dp-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--dp-primary), transparent);
}
.dp-divider-icon {
  font-family: 'Noto Serif Devanagari', serif;
  font-size: 1.4rem;
  color: var(--dp-primary);
  opacity: 0.7;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .dp-hero-inner { flex-direction: column; text-align: center; gap: 40px; }
  .dp-figure img { height: 240px; }
  .dp-figure::before { width: 200px; height: 200px; }
  .dp-two-col { grid-template-columns: 1fr; gap: 40px; }
  .dp-two-col.flip { direction: ltr; }
  .dp-hero-badges { justify-content: center; }
  .dp-mantra { border-left: none; border-top: 3px solid var(--dp-primary); padding: 12px 0 0; }
  .dp-deity-nav { flex-direction: column; gap: 24px; text-align: center; }
}
