/*
Theme Name: Bhakti - आपकी भक्ति यात्रा का केंद्र
Theme URI: https://bhakti.theyogic.in
Author: The Yogic
Description: एक सुंदर हिंदी भक्ति थीम
Version: 1.1.0
License: GNU General Public License v2 or later
Text Domain: bhakti
*/

/* ===== DESIGN TOKENS ===== */
:root {
  --saffron:       #FF6B00;
  --saffron-light: #FF9A3C;
  --gold:          #D4A017;
  --gold-light:    #F0C040;
  --crimson:       #8B0000;
  --crimson-light: #C0392B;
  --ivory:         #FDF6E3;
  --ivory-dark:    #F5E6C8;
  --midnight:      #1A0A2E;
  --midnight-mid:  #2D1654;
  --text-dark:     #2C1810;
  --text-mid:      #5C3317;
  --text-light:    #8B6347;
  --border-gold:   1px solid rgba(212,160,23,0.4);
  --shadow-warm:   0 4px 24px rgba(139,0,0,0.10);
  --shadow-gold:   0 8px 40px rgba(212,160,23,0.18);
  --radius-card:   16px;
  --radius-pill:   40px;
  --transition:    0.3s cubic-bezier(0.4,0,0.2,1);
}

/* ===== RESET ===== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Noto Sans Devanagari', 'Noto Serif Devanagari', Georgia, serif;
  background: var(--ivory);
  color: var(--text-dark);
  line-height: 1.7;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ===== TYPOGRAPHY ===== */
h1,h2,h3,h4 { font-family: 'Noto Serif Devanagari', Georgia, serif; line-height: 1.3; color: var(--midnight); }
.section-title { font-size: clamp(1.6rem,3.5vw,2.4rem); color: var(--crimson); text-align: center; margin-bottom: 0.4rem; }
.section-subtitle { text-align: center; color: var(--text-light); font-size: 1rem; margin-bottom: 2.8rem; }

.om-divider { display: flex; align-items: center; justify-content: center; gap: 1rem; margin: 0.6rem auto 2.8rem; }
.om-divider::before, .om-divider::after { content: ''; flex: 1; max-width: 120px; height: 1px; background: linear-gradient(90deg, transparent, var(--gold)); }
.om-divider::after { background: linear-gradient(90deg, var(--gold), transparent); }
.om-divider span { font-size: 1.8rem; color: var(--gold); animation: omPulse 3s ease-in-out infinite; }
@keyframes omPulse {
  0%,100% { filter: drop-shadow(0 0 8px rgba(212,160,23,0.4)); transform: scale(1); }
  50%      { filter: drop-shadow(0 0 18px rgba(212,160,23,0.9)); transform: scale(1.08); }
}

/* ===== LAYOUT ===== */
.container { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; }
section { padding: 5rem 0; }

/* ===== BUTTONS ===== */
.btn-primary {
  background: linear-gradient(135deg,var(--saffron),var(--crimson));
  color: white; padding: 0.8rem 2rem; border-radius: var(--radius-pill);
  font-weight: 600; font-size: 1rem; transition: var(--transition);
  box-shadow: 0 4px 16px rgba(255,107,0,0.3);
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(255,107,0,0.45); }
.btn-secondary {
  background: transparent; color: var(--crimson);
  padding: 0.8rem 2rem; border-radius: var(--radius-pill);
  font-weight: 600; font-size: 1rem; border: 2px solid var(--crimson);
  transition: var(--transition); display: inline-flex; align-items: center; gap: 0.5rem;
}
.btn-secondary:hover { background: var(--crimson); color: white; transform: translateY(-2px); }

/* ===== HEADER ===== */
.site-header {
  background: linear-gradient(135deg,var(--midnight) 0%,var(--midnight-mid) 50%,#3D1A6E 100%);
  position: sticky; top: 0; z-index: 1000;
  box-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 0.9rem 1.5rem; max-width: 1200px; margin: 0 auto; }
.site-branding { display: flex; align-items: center; gap: 0.9rem; }
.site-logo-circle {
  width: 48px; height: 48px;
  background: radial-gradient(circle,var(--gold-light),var(--saffron));
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; box-shadow: 0 0 16px rgba(212,160,23,0.6); flex-shrink: 0;
  animation: logoPulse 4s ease-in-out infinite;
}
@keyframes logoPulse {
  0%,100% { box-shadow: 0 0 16px rgba(212,160,23,0.5); }
  50%      { box-shadow: 0 0 28px rgba(212,160,23,0.9), 0 0 50px rgba(255,107,0,0.3); }
}
.site-name    { font-size: 1.7rem; font-weight: 700; color: var(--gold-light); font-family: 'Noto Serif Devanagari',serif; }
.site-tagline { font-size: 0.7rem; color: rgba(240,192,64,0.7); letter-spacing: 0.05em; }

.primary-nav ul { display: flex; gap: 0.2rem; align-items: center; }
.primary-nav a { color: rgba(253,246,227,0.85); font-size: 0.9rem; padding: 0.5rem 0.9rem; border-radius: var(--radius-pill); transition: var(--transition); white-space: nowrap; }
.primary-nav a:hover, .primary-nav .current-menu-item > a { background: rgba(212,160,23,0.2); color: var(--gold-light); }
.nav-highlight a { background: linear-gradient(135deg,var(--saffron),var(--gold)); color: white !important; font-weight: 600; }
.nav-highlight a:hover { box-shadow: 0 4px 16px rgba(255,107,0,0.4); transform: translateY(-1px); }
.menu-toggle { display: none; background: none; border: 1px solid rgba(212,160,23,0.4); color: var(--gold-light); padding: 0.5rem 0.8rem; border-radius: 8px; cursor: pointer; font-size: 1.2rem; }

/* ===== HERO ===== */
.hero {
  background: radial-gradient(ellipse at 20% 50%, rgba(139,0,0,0.12) 0%,transparent 60%),
              radial-gradient(ellipse at 80% 20%, rgba(212,160,23,0.1) 0%,transparent 50%),
              linear-gradient(160deg,#FDF6E3 0%,#F5E6C8 40%,#FDE8C8 70%,#FDF6E3 100%);
  padding: 5rem 0 4rem; overflow: hidden; position: relative;
}
.hero::before { content:'ॐ'; position:absolute; font-size:28rem; color:rgba(212,160,23,0.05); top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; font-family:'Noto Serif Devanagari',serif; line-height:1; }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; position: relative; z-index: 1; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; background: linear-gradient(135deg,var(--saffron),var(--gold)); color: white; font-size: 0.8rem; font-weight: 600; padding: 0.3rem 1rem; border-radius: var(--radius-pill); margin-bottom: 1.2rem; }
.hero-title { font-size: clamp(2rem,4.5vw,3.5rem); color: var(--midnight); margin-bottom: 1rem; line-height: 1.2; }
.hero-title .accent { color: var(--saffron); }
.hero-desc { color: var(--text-mid); font-size: 1.05rem; margin-bottom: 2rem; line-height: 1.8; }
.hero-ctas { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-visual { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.hero-deity-card { background: white; border-radius: var(--radius-card); padding: 1.5rem 1rem; text-align: center; box-shadow: var(--shadow-warm); border: var(--border-gold); transition: var(--transition); cursor: pointer; }
.hero-deity-card:hover { transform: translateY(-4px) scale(1.02); box-shadow: var(--shadow-gold); border-color: var(--gold); }
.hero-deity-card:first-child { grid-column: 1/-1; display: flex; align-items: center; gap: 1rem; text-align: left; padding: 1rem 1.5rem; }
.deity-mini-name { font-size: 0.95rem; font-weight: 600; color: var(--midnight); margin-top: 0.5rem; }
.deity-mini-count { font-size: 0.78rem; color: var(--text-light); }

/* ===== STATS BAR ===== */
.stats-bar { background: linear-gradient(135deg,var(--midnight),var(--midnight-mid)); padding: 2rem 0; }
.stats-inner { display: flex; justify-content: space-around; flex-wrap: wrap; gap: 1.5rem; }
.stat-item { text-align: center; color: white; }
.stat-number { font-size: 2rem; font-weight: 700; background: linear-gradient(135deg,var(--gold-light),var(--saffron-light)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; display: block; }
.stat-label { font-size: 0.85rem; color: rgba(253,246,227,0.65); }

/* ===== DEITY CARDS ===== */
.deities-section { background: var(--ivory); padding: 5rem 0; }
.deities-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(180px,1fr)); gap: 1.8rem; }
.deity-card { position: relative; text-align: center; cursor: pointer; transition: var(--transition); }
.deity-card:hover { transform: translateY(-6px); }
.deity-card-inner { background: white; border-radius: var(--radius-card); padding: 1.5rem 1rem 1.2rem; box-shadow: var(--shadow-warm); border: 2px solid transparent; transition: var(--transition); position: relative; overflow: hidden; }
.deity-card:hover .deity-card-inner { border-color: var(--gold); box-shadow: var(--shadow-gold); }
.deity-mandala-ring { width: 130px; height: 130px; border-radius: 50%; margin: 0 auto 1rem; position: relative; display: flex; align-items: center; justify-content: center; }
.deity-mandala-ring::before { content:''; position:absolute; inset:-4px; border-radius:50%; background:conic-gradient(var(--saffron) 0deg,var(--gold) 60deg,var(--crimson) 120deg,var(--saffron) 180deg,var(--gold) 240deg,var(--crimson) 300deg,var(--saffron) 360deg); opacity:0.2; transition:var(--transition); }
.deity-card:hover .deity-mandala-ring::before { opacity:0.7; animation: mandalaRotate 4s linear infinite; }
@keyframes mandalaRotate { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
.deity-image-circle { width:120px; height:120px; border-radius:50%; overflow:hidden; background:var(--ivory-dark); display:flex; align-items:center; justify-content:center; position:relative; z-index:1; border:3px solid white; }
.deity-image-circle img { width:100%; height:100%; object-fit:cover; transition:var(--transition); }
.deity-card:hover .deity-image-circle img { transform:scale(1.05); }
.deity-card-name { font-size:1.05rem; font-weight:700; color:var(--midnight); margin-bottom:0.25rem; }
.deity-card-count { font-size:0.78rem; color:var(--text-light); margin-bottom:0.8rem; }
.deity-card-arrow { display:inline-flex; align-items:center; gap:0.3rem; font-size:0.8rem; font-weight:600; color:var(--saffron); transition:var(--transition); }
.deity-card:hover .deity-card-arrow { color:var(--crimson); gap:0.5rem; }

/* ===== FEATURED SECTION ===== */
.featured-section { background: linear-gradient(160deg,var(--midnight) 0%,var(--midnight-mid) 100%); padding: 5rem 0; position: relative; overflow: hidden; }
.featured-section .section-title { color: var(--gold-light); }
.featured-section .section-subtitle { color: rgba(253,246,227,0.6); }
.featured-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 1.5rem; }
.featured-card { background: rgba(255,255,255,0.06); border: 1px solid rgba(212,160,23,0.2); border-radius: var(--radius-card); padding: 1.8rem; transition: var(--transition); cursor: pointer; position: relative; overflow: hidden; }
.featured-card::before { content:''; position:absolute; top:0;left:0;right:0; height:3px; background:linear-gradient(90deg,var(--saffron),var(--gold)); transform:scaleX(0); transform-origin:left; transition:var(--transition); }
.featured-card:hover { background: rgba(255,255,255,0.1); border-color: rgba(212,160,23,0.5); transform: translateY(-3px); }
.featured-card:hover::before { transform: scaleX(1); }
.featured-card-large { padding: 2.5rem; }
.card-type-label { font-size:0.7rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--saffron-light); margin-bottom:0.6rem; display:block; }
.featured-card h3 { font-size:1.3rem; color:white; margin-bottom:0.6rem; }
.featured-card-large h3 { font-size:1.8rem; }
.featured-card p { font-size:0.88rem; color:rgba(253,246,227,0.6); line-height:1.7; margin-bottom:1.2rem; }
.card-link { font-size:0.85rem; font-weight:600; color:var(--gold-light); display:inline-flex; align-items:center; gap:0.3rem; transition:var(--transition); }
.card-link:hover { gap:0.6rem; color:var(--saffron-light); }

/* ===== FESTIVALS ===== */
.festivals-section { background: var(--ivory-dark); padding: 5rem 0; }
.festivals-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(200px,1fr)); gap: 1.5rem; }
.festival-card { background:white; border-radius:var(--radius-card); overflow:hidden; box-shadow:var(--shadow-warm); border:2px solid transparent; transition:var(--transition); cursor:pointer; text-align:center; }
.festival-card:hover { transform:translateY(-5px); border-color:var(--saffron); box-shadow:0 12px 40px rgba(255,107,0,0.2); }
.festival-img-wrap { width:120px; height:120px; border-radius:50%; overflow:hidden; margin:1.5rem auto 1rem; border:3px solid var(--ivory-dark); transition:var(--transition); display:flex; align-items:center; justify-content:center; background:var(--ivory); }
.festival-card:hover .festival-img-wrap { border-color:var(--saffron); }
.festival-name { font-size:1rem; font-weight:700; color:var(--midnight); padding:0 1rem 0.3rem; }
.festival-date { font-size:0.78rem; color:var(--saffron); font-weight:600; padding-bottom:1.2rem; }

/* ===== MANTRA BANNER ===== */
.mantra-banner { background: linear-gradient(135deg,var(--saffron) 0%,var(--crimson) 100%); padding: 3rem 0; text-align: center; }
.mantra-text { font-size: clamp(1.4rem,3vw,2.2rem); color: white; font-family: 'Noto Serif Devanagari',serif; font-weight: 700; text-shadow: 0 2px 8px rgba(0,0,0,0.2); }
.mantra-translation { font-size: 0.95rem; color: rgba(255,255,255,0.8); margin-top: 0.5rem; font-style: italic; }

/* ===== LATEST POSTS ===== */
.latest-section { padding: 5rem 0; }
.posts-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(300px,1fr)); gap: 1.8rem; }
.post-card { background:white; border-radius:var(--radius-card); box-shadow:var(--shadow-warm); border:var(--border-gold); overflow:hidden; transition:var(--transition); cursor:pointer; }
.post-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-gold); border-color:var(--gold); }
.post-card-header { background:linear-gradient(135deg,var(--midnight),var(--midnight-mid)); padding:1.5rem; display:flex; align-items:center; gap:1rem; }
.post-deity-badge { width:50px; height:50px; border-radius:50%; background:radial-gradient(circle,var(--gold-light),var(--saffron)); display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; }
.post-meta-top h4 { color:white; font-size:0.95rem; margin-bottom:0.2rem; }
.post-category { font-size:0.72rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--saffron-light); }
.post-card-body { padding: 1.4rem; }
.post-card-body h3 { font-size:1.05rem; color:var(--midnight); margin-bottom:0.6rem; line-height:1.4; }
.post-card-body p { font-size:0.85rem; color:var(--text-light); line-height:1.7; margin-bottom:1rem; }
.post-read-link { font-size:0.82rem; font-weight:700; color:var(--saffron); display:inline-flex; align-items:center; gap:0.3rem; transition:var(--transition); }
.post-card:hover .post-read-link { gap:0.6rem; }

/* ===== MAIN CONTENT + SIDEBAR LAYOUT ===== */
.content-sidebar-wrap {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 3rem;
  align-items: start;
}
.main-content-area { min-width: 0; } /* prevent grid blowout */

/* ===== ARTICLE CONTENT ===== */
.article-wrap { background:white; border-radius:var(--radius-card); box-shadow:var(--shadow-warm); border:var(--border-gold); overflow:hidden; }
.article-header { background:linear-gradient(135deg,var(--midnight),var(--midnight-mid)); padding:2.5rem; text-align:center; }
.article-header h1 { color:var(--gold-light); font-size:clamp(1.4rem,3vw,2.2rem); margin-bottom:0.8rem; }
.article-header .meta { color:rgba(253,246,227,0.5); font-size:0.82rem; }
.article-accent-bar { height:3px; background:linear-gradient(90deg,var(--saffron),var(--gold),var(--crimson)); }
.article-body { padding: 2.5rem; font-size: 1.05rem; line-height: 2; color: var(--text-dark); }
.article-body h2 { color:var(--crimson); font-size:1.3rem; margin:1.5rem 0 0.8rem; text-align:center; }
.article-body h3 { color:var(--midnight); font-size:1.1rem; margin:1.2rem 0 0.6rem; text-align:center; }
.article-body h4 { color:var(--midnight-mid); font-size:1rem; margin:1rem 0 0.5rem; text-align:center; }
.article-body p { margin-bottom:1rem; }
.article-body strong { color:var(--crimson); }
.article-body blockquote, .article-body .doha {
  text-align:center; background:linear-gradient(135deg,rgba(255,107,0,0.05),rgba(212,160,23,0.05));
  border:1px solid rgba(212,160,23,0.25); border-radius:12px; padding:1.5rem; margin:1.5rem 0;
  font-size:1.05rem; color:var(--text-mid); font-style:italic;
}
.article-body em { font-style:italic; color:var(--text-mid); }

/* ===== IN-POST PAGINATION (<!--nextpage-->) ===== */
.wp-link-pages {
  margin: 2rem 0 0;
  padding: 1.5rem;
  background: var(--ivory-dark);
  border-radius: 12px;
  border: var(--border-gold);
  text-align: center;
}
.wp-link-pages .wp-link-pages-label {
  display: block;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 0.8rem;
}
.wp-link-pages span,
.wp-link-pages a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: 50%;
  font-size: 0.95rem;
  font-weight: 600;
  margin: 0.2rem;
  transition: var(--transition);
}
.wp-link-pages a {
  background: white;
  color: var(--saffron);
  border: 2px solid rgba(255,107,0,0.3);
}
.wp-link-pages a:hover {
  background: var(--saffron);
  color: white;
  border-color: var(--saffron);
  transform: scale(1.1);
}
/* Current page indicator */
.wp-link-pages > span:not(.wp-link-pages-label) {
  background: linear-gradient(135deg,var(--saffron),var(--crimson));
  color: white;
  border: 2px solid transparent;
}

/* Article nav prev/next */
.article-nav { border-top:1px solid var(--ivory-dark); padding:1.5rem 2.5rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.article-nav a { font-size:0.88rem; color:var(--saffron); font-weight:600; transition:var(--transition); display:inline-flex; align-items:center; gap:0.3rem; }
.article-nav a:hover { color:var(--crimson); }

/* Post list row */
.deity-posts-list { display:grid; gap:1rem; }
.deity-post-row { background:white; border-radius:12px; padding:1.2rem 1.5rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; box-shadow:var(--shadow-warm); border:var(--border-gold); transition:var(--transition); cursor:pointer; }
.deity-post-row:hover { border-color:var(--saffron); transform:translateX(4px); box-shadow:var(--shadow-gold); }
.deity-post-row h4 { font-size:1.05rem; color:var(--midnight); margin-bottom:0.2rem; }
.deity-post-row span { font-size:0.8rem; color:var(--text-light); }
.deity-post-row-arrow { color:var(--saffron); font-size:1.2rem; flex-shrink:0; }

/* ===== BREADCRUMB ===== */
.breadcrumb { background:var(--midnight-mid); padding:0.8rem 0; }
.breadcrumb-inner { display:flex; gap:0.5rem; align-items:center; font-size:0.82rem; color:rgba(253,246,227,0.5); flex-wrap:wrap; }
.breadcrumb-inner a { color:rgba(212,160,23,0.8); transition:var(--transition); }
.breadcrumb-inner a:hover { color:var(--gold-light); }
.breadcrumb-inner .current { color:var(--gold-light); }

/* ===== SIDEBAR ===== */
.sidebar-area { display:flex; flex-direction:column; gap:1.5rem; }
.sidebar-widget { background:white; border-radius:var(--radius-card); box-shadow:var(--shadow-warm); border:var(--border-gold); overflow:hidden; }
.sidebar-widget-head { padding:1rem 1.5rem; }
.sidebar-widget-head h3 { font-size:0.95rem; color:white; }
.sidebar-widget-body { padding:1rem; }
.sidebar-link { display:flex; align-items:center; gap:0.6rem; padding:0.55rem 0; border-bottom:1px solid var(--ivory-dark); color:var(--text-dark); font-size:0.88rem; transition:color 0.2s; }
.sidebar-link:last-child { border-bottom:none; }
.sidebar-link:hover { color:var(--saffron); }
.sidebar-link-arrow { margin-left:auto; color:var(--saffron); font-size:0.75rem; }

/* Search form */
.search-form-bhakti { display:flex; }
.search-form-bhakti input { flex:1; padding:0.65rem 1rem; border:2px solid rgba(212,160,23,0.3); border-right:none; border-radius:8px 0 0 8px; font-size:0.9rem; font-family:inherit; outline:none; background:var(--ivory); color:var(--text-dark); }
.search-form-bhakti input:focus { border-color:var(--saffron); }
.search-form-bhakti button { padding:0.65rem 1.1rem; background:linear-gradient(135deg,var(--saffron),var(--crimson)); border:none; border-radius:0 8px 8px 0; color:white; cursor:pointer; font-size:1rem; }

/* ===== PAGINATION (archive pages) ===== */
.posts-pagination { margin-top:2.5rem; text-align:center; }
.posts-pagination .nav-links { display:flex; justify-content:center; gap:0.4rem; flex-wrap:wrap; }
.posts-pagination .page-numbers {
  display:inline-flex; align-items:center; justify-content:center;
  min-width:40px; height:40px; padding:0 0.6rem;
  border-radius:50%; font-size:0.95rem; font-weight:600;
  border:2px solid rgba(255,107,0,0.3);
  background:white; color:var(--saffron);
  transition:var(--transition);
}
.posts-pagination .page-numbers:hover { background:var(--saffron); color:white; border-color:var(--saffron); }
.posts-pagination .page-numbers.current { background:linear-gradient(135deg,var(--saffron),var(--crimson)); color:white; border-color:transparent; }
.posts-pagination .page-numbers.dots { border:none; background:none; }

/* ===== FOOTER ===== */
.site-footer { background: linear-gradient(180deg,var(--midnight) 0%,#0D0520 100%); padding: 4rem 0 2rem; color: rgba(253,246,227,0.7); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.footer-brand .site-name { color:var(--gold-light); margin-bottom:0.6rem; font-size:1.4rem; }
.footer-brand p { font-size:0.88rem; line-height:1.7; color:rgba(253,246,227,0.55); margin-bottom:1.2rem; }
.footer-heading { font-size:0.85rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--gold); margin-bottom:1rem; }
.footer-links li { margin-bottom:0.5rem; }
.footer-links a { font-size:0.88rem; color:rgba(253,246,227,0.55); transition:var(--transition); }
.footer-links a:hover { color:var(--saffron-light); }
.footer-bottom { border-top:1px solid rgba(212,160,23,0.1); padding-top:1.5rem; display:flex; align-items:center; justify-content:space-between; font-size:0.82rem; color:rgba(253,246,227,0.35); flex-wrap:wrap; gap:1rem; }
.footer-om { font-size:1.5rem; color:var(--gold); opacity:0.6; }

/* ===== DEITY PAGE HERO ===== */
.deity-page-hero { background:linear-gradient(160deg,var(--midnight) 0%,var(--midnight-mid) 100%); padding:4rem 0; }
.deity-page-inner { display:flex; align-items:center; gap:3rem; }
.deity-page-image { width:200px; height:200px; border-radius:50%; overflow:hidden; border:4px solid var(--gold); box-shadow:0 0 40px rgba(212,160,23,0.4); flex-shrink:0; }
.deity-page-image img { width:100%; height:100%; object-fit:cover; }
.deity-page-info h1 { font-size:clamp(2rem,4vw,3rem); color:var(--gold-light); margin-bottom:0.8rem; }
.deity-page-info p { color:rgba(253,246,227,0.7); font-size:1.05rem; line-height:1.8; }

/* ===== ACCESSIBILITY ===== */
:focus-visible { outline:3px solid var(--gold); outline-offset:2px; }

/* ================================================================
   RESPONSIVE — ALL BREAKPOINTS
   ================================================================ */

/* Tablet */
@media (max-width: 1024px) {
  .featured-grid { grid-template-columns: 1fr 1fr; }
  .featured-card-large { grid-column: 1/-1; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .content-sidebar-wrap { grid-template-columns: 1fr 260px; gap: 2rem; }
}

/* ── MOBILE — the main fix ── */
@media (max-width: 768px) {

  /* Header */
  .primary-nav { display: none; }
  .primary-nav.open {
    display: flex; flex-direction: column;
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--midnight); padding: 1rem;
    z-index: 999; box-shadow: 0 8px 24px rgba(0,0,0,0.4);
  }
  .primary-nav.open ul { flex-direction: column; width: 100%; }
  .primary-nav.open a { display: block; width: 100%; padding: 0.8rem 1rem; }
  .menu-toggle { display: block; }

  /* Hero */
  .hero-inner { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .hero { padding: 3rem 0; }
  .hero-ctas { flex-direction: column; }
  .btn-primary, .btn-secondary { text-align: center; justify-content: center; }

  /* Grid adjustments */
  .deities-grid { grid-template-columns: repeat(auto-fill,minmax(140px,1fr)); gap: 1rem; }
  .festivals-grid { grid-template-columns: repeat(auto-fill,minmax(150px,1fr)); }
  .featured-grid { grid-template-columns: 1fr; }
  .posts-grid { grid-template-columns: 1fr; }
  section { padding: 3rem 0; }

  /* ── CRITICAL: Sidebar stacks BELOW content on mobile ── */
  .content-sidebar-wrap {
    grid-template-columns: 1fr;   /* single column */
    gap: 2rem;
  }
  /* Sidebar naturally appears after main content in source order */
  /* Article body — fix visibility on mobile */
  .article-body {
    padding: 1.5rem;
    font-size: 1rem;
    /* Ensure text is always visible */
    color: var(--text-dark);
    overflow-x: hidden;
    word-break: break-word;
  }
  .article-header { padding: 1.8rem 1.2rem; }
  .article-nav { padding: 1rem 1.5rem; }

  /* Deity page */
  .deity-page-inner { flex-direction: column; text-align: center; }
  .deity-page-image { width: 140px; height: 140px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; text-align: center; }

  /* Stats */
  .stats-inner { flex-direction: column; gap: 1rem; }

  /* In-post pagination on mobile — make buttons bigger */
  .wp-link-pages span,
  .wp-link-pages a { width: 44px; height: 44px; font-size: 1rem; }
}

/* Small phones */
@media (max-width: 480px) {
  .container { padding: 0 1rem; }
  .header-inner { padding: 0.8rem 1rem; }
  .site-name { font-size: 1.3rem; }
  .deities-grid { grid-template-columns: repeat(3,1fr); gap: 0.8rem; }
  .deity-mandala-ring { width: 90px; height: 90px; }
  .deity-image-circle { width: 80px; height: 80px; }
  .deity-card-inner { padding: 1rem 0.5rem 0.8rem; }
  .deity-card-name { font-size: 0.82rem; }
  .deity-card-count { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}

.bhakti-shlok h4.wp-block-heading {
    font-family: "Mukta", serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    line-height: 1.8 !important;
    text-align: center !important;
}

.bhakti-shlok p {
    font-family: "Mukta", serif !important;
    font-size: 0.8rem !important;
    line-height: 1.8 !important;
    text-align: center !important;
    font-weight: 100 !important;
	margin-bottom: 30px;
}
