/* =========================================================
   Homepage v2 — Bhakti Bhawna
   Photography-forward, temple-devotional, content-dense
   ========================================================= */

/* ====================== HERO ====================== */
.bb-hero {
    position: relative;
    min-height: 560px;
    overflow: hidden;
    background: var(--bb-maroon);
}

.bb-hero__slides {
    position: absolute; inset: 0;
}

.bb-hero__slide {
    position: absolute; inset: 0;
    opacity: 0;
    transition: opacity 900ms var(--bb-ease);
    background-position: center;
    background-size: cover;
}
.bb-hero__slide.is-active { opacity: 1; }

.bb-hero__slide::after {
    content: "";
    position: absolute; inset: 0;
    background:
        linear-gradient(180deg, rgba(46, 29, 31, 0.25) 0%, rgba(46, 29, 31, 0.15) 45%, rgba(46, 29, 31, 0.85) 100%),
        linear-gradient(90deg, rgba(122, 26, 53, 0.35) 0%, rgba(122, 26, 53, 0) 55%);
}

.bb-hero__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 560px;
    padding-block: var(--bb-sp-5) var(--bb-sp-5);
    color: #fff;
}

.bb-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.9rem;
    background: rgba(212, 160, 23, 0.20);
    border: 1px solid rgba(245, 211, 90, 0.5);
    color: var(--bb-gold-bright);
    font-size: var(--bb-fs-xs);
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    border-radius: var(--bb-r-pill);
    align-self: flex-start;
    backdrop-filter: blur(6px);
}

.bb-hero__title {
    font-size: var(--bb-fs-4xl);
    line-height: 1.05;
    margin: var(--bb-sp-2) 0 var(--bb-sp-2);
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.4);
    color: #fff;
    max-width: 18ch;
}
.bb-hero__title .bb-devanagari {
    display: block;
    color: var(--bb-gold-bright);
    font-weight: 400;
    font-size: 0.75em;
    margin-bottom: 0.25em;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.5);
}

.bb-hero__lede {
    font-size: var(--bb-fs-lg);
    color: rgba(255, 255, 255, 0.95);
    max-width: 52ch;
    margin-bottom: var(--bb-sp-3);
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.4);
}

.bb-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--bb-sp-2);
}

.bb-hero__dots {
    display: flex;
    gap: 0.5rem;
    margin-top: var(--bb-sp-4);
}
.bb-hero__dot {
    width: 10px; height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.4);
    border: none;
    padding: 0;
    cursor: pointer;
    transition: all var(--bb-dur) var(--bb-ease);
}
.bb-hero__dot.is-active {
    background: var(--bb-gold);
    width: 28px;
    border-radius: 5px;
}

@media (min-width: 768px) {
    .bb-hero {
        min-height: 640px;
    }
    .bb-hero__inner {
        min-height: 640px;
        padding-block: var(--bb-sp-6);
    }
}

/* ====================== QUICK TOOLS STRIP ====================== */
.bb-quick-tools {
    background: linear-gradient(180deg, var(--bb-cream) 0%, var(--bb-cream-warm) 100%);
    border-bottom: 1px solid var(--bb-line);
    padding-block: var(--bb-sp-3);
}
.bb-quick-tools__grid {
    display: grid;
    gap: 0.75rem;
    grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px)  { .bb-quick-tools__grid { grid-template-columns: repeat(4, 1fr); } }

.bb-quick-tool {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.9rem 1rem;
    background: #fff;
    border: 1px solid var(--bb-line);
    border-radius: var(--bb-r);
    color: var(--bb-charcoal);
    transition: all var(--bb-dur) var(--bb-ease);
    position: relative;
    overflow: hidden;
}
.bb-quick-tool:hover {
    transform: translateY(-2px);
    box-shadow: var(--bb-shadow);
    border-color: var(--bb-gold);
    color: var(--bb-maroon);
}
.bb-quick-tool__icon {
    width: 44px; height: 44px;
    display: flex; align-items: center; justify-content: center;
    font-size: 24px;
    background: linear-gradient(135deg, var(--bb-saffron-soft), var(--bb-gold-soft));
    color: var(--bb-maroon);
    border-radius: 50%;
    flex-shrink: 0;
}
.bb-quick-tool__label {
    display: flex; flex-direction: column;
    line-height: 1.2;
}
.bb-quick-tool__title {
    font-weight: 600;
    font-size: var(--bb-fs-base);
}
.bb-quick-tool__sub {
    font-size: var(--bb-fs-xs);
    color: var(--bb-muted);
    margin-top: 0.15rem;
}

/* ====================== FEATURED AARTIS ====================== */
.bb-featured {
    background: var(--bb-ivory);
}
.bb-featured__grid {
    display: grid;
    gap: var(--bb-sp-3);
    grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .bb-featured__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .bb-featured__grid { grid-template-columns: repeat(4, 1fr); } }

.bb-featured-card {
    display: flex; flex-direction: column;
    background: #fff;
    border-radius: var(--bb-r);
    overflow: hidden;
    border: 1px solid var(--bb-line);
    text-decoration: none;
    color: var(--bb-charcoal);
    transition: all var(--bb-dur) var(--bb-ease);
    position: relative;
}
.bb-featured-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--bb-shadow-lg);
    border-color: var(--bb-gold);
}
.bb-featured-card__img {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--bb-cream-warm);
    position: relative;
}
.bb-featured-card__img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 600ms var(--bb-ease);
}
.bb-featured-card:hover .bb-featured-card__img img { transform: scale(1.08); }
.bb-featured-card__img::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(46, 29, 31, 0.45) 100%);
}
.bb-featured-card__body {
    padding: var(--bb-sp-2) var(--bb-sp-3) var(--bb-sp-3);
    text-align: center;
}
.bb-featured-card__title {
    font-family: var(--bb-font-display);
    font-size: var(--bb-fs-lg);
    color: var(--bb-maroon);
    margin: 0 0 0.25rem;
    font-weight: 700;
}
.bb-featured-card__sub {
    font-family: var(--bb-font-devanagari);
    color: var(--bb-saffron-dark);
    font-size: var(--bb-fs-sm);
}

/* Gold corner ornaments on cards */
.bb-featured-card::before,
.bb-featured-card::after {
    content: "";
    position: absolute;
    width: 22px; height: 22px;
    border: 2px solid var(--bb-gold);
    z-index: 3;
    pointer-events: none;
    transition: opacity var(--bb-dur) var(--bb-ease);
    opacity: 0.65;
}
.bb-featured-card::before { top: 10px; left: 10px; border-right: none; border-bottom: none; border-top-left-radius: 4px; }
.bb-featured-card::after  { bottom: 10px; right: 10px; border-left: none; border-top: none; border-bottom-right-radius: 4px; }
.bb-featured-card:hover::before,
.bb-featured-card:hover::after { opacity: 1; }

/* ====================== PANCHANG CARD (ORNATE) ====================== */
.bb-panchang-wrap {
    padding-block: var(--bb-sp-5);
    background:
        radial-gradient(circle at 20% 20%, rgba(212, 160, 23, 0.08), transparent 50%),
        radial-gradient(circle at 80% 70%, rgba(232, 118, 41, 0.06), transparent 50%),
        var(--bb-cream);
}

.bb-panchang-card {
    max-width: 1000px; margin-inline: auto;
    position: relative;
    background:
        linear-gradient(135deg, rgba(122, 26, 53, 0.96), rgba(90, 16, 38, 0.97)),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><g fill='none' stroke='%23f5d35a' stroke-width='0.8' stroke-opacity='0.25'><circle cx='100' cy='100' r='90'/><circle cx='100' cy='100' r='70'/><circle cx='100' cy='100' r='50'/><circle cx='100' cy='100' r='30'/><path d='M100 10 L100 190 M10 100 L190 100 M30 30 L170 170 M170 30 L30 170'/><path d='M100 10 L115 60 L100 45 L85 60 Z M100 190 L115 140 L100 155 L85 140 Z M10 100 L60 115 L45 100 L60 85 Z M190 100 L140 115 L155 100 L140 85 Z'/></g></svg>");
    background-size: cover, 200px 200px;
    color: #fff;
    padding: var(--bb-sp-4);
    border-radius: var(--bb-r-lg);
    border: 1px solid rgba(212, 160, 23, 0.35);
    box-shadow: var(--bb-shadow-lg), inset 0 0 0 8px rgba(212, 160, 23, 0.08);
    display: grid;
    gap: var(--bb-sp-3);
    overflow: hidden;
}
@media (min-width: 768px) {
    .bb-panchang-card {
        grid-template-columns: 1fr 1fr;
        align-items: center;
        padding: var(--bb-sp-5) var(--bb-sp-5);
        gap: var(--bb-sp-4);
    }
}
/* Gold corners on the panchang card */
.bb-panchang-card::before,
.bb-panchang-card::after {
    content: "";
    position: absolute;
    width: 40px; height: 40px;
    border: 2px solid var(--bb-gold);
    pointer-events: none;
}
.bb-panchang-card::before { top: 12px; left: 12px; border-right: none; border-bottom: none; }
.bb-panchang-card::after  { bottom: 12px; right: 12px; border-left: none; border-top: none; }

.bb-panchang-card__date {
    color: var(--bb-gold-bright);
    font-size: var(--bb-fs-xs);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    font-weight: 700;
    margin-bottom: 0.5rem;
}
.bb-panchang-card h2 { color: #fff; margin-bottom: var(--bb-sp-2); }
.bb-panchang-card h2 .bb-devanagari {
    display: block;
    font-size: 0.58em;
    color: var(--bb-gold-bright);
    margin-bottom: 0.25em;
    font-weight: 400;
}
.bb-panchang-card p {
    color: rgba(255, 255, 255, 0.92);
    margin-bottom: var(--bb-sp-3);
}
.bb-panchang-card__facts {
    display: grid;
    gap: 0.9rem;
    grid-template-columns: repeat(2, 1fr);
    padding: var(--bb-sp-3);
    background: rgba(255, 255, 255, 0.07);
    border-radius: var(--bb-r);
    border: 1px solid rgba(212, 160, 23, 0.3);
}
.bb-panchang-card__fact { margin: 0; }
.bb-panchang-card__fact dt {
    font-size: var(--bb-fs-xs);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--bb-gold-bright);
    margin-bottom: 0.3rem;
    font-weight: 600;
}
.bb-panchang-card__fact dd {
    margin: 0;
    font-family: var(--bb-font-display);
    font-size: var(--bb-fs-lg);
    font-weight: 700;
    color: #fff;
}

/* ====================== CATEGORY TILES (PHOTO BG) ====================== */
.bb-categories {
    background: var(--bb-ivory);
}
.bb-categories__grid {
    display: grid;
    gap: var(--bb-sp-2);
    grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px)  { .bb-categories__grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1024px) { .bb-categories__grid { grid-template-columns: repeat(6, 1fr); } }

.bb-cat-tile {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    padding: var(--bb-sp-3) var(--bb-sp-2);
    text-align: center;
    border-radius: var(--bb-r);
    color: #fff;
    min-height: 160px;
    background-color: var(--bb-maroon);
    background-size: cover;
    background-position: center;
    overflow: hidden;
    transition: transform var(--bb-dur) var(--bb-ease), box-shadow var(--bb-dur) var(--bb-ease);
    text-decoration: none;
    isolation: isolate;
}
.bb-cat-tile::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(46, 29, 31, 0.15) 0%, rgba(46, 29, 31, 0.85) 100%);
    z-index: 1;
}
.bb-cat-tile:hover {
    transform: translateY(-3px);
    box-shadow: var(--bb-shadow-lg);
}
.bb-cat-tile:hover::before {
    background: linear-gradient(180deg, rgba(122, 26, 53, 0.3) 0%, rgba(122, 26, 53, 0.9) 100%);
}

.bb-cat-tile__inner {
    position: relative; z-index: 2;
    display: flex; flex-direction: column; align-items: center; gap: 0.35rem;
}

.bb-cat-tile__name {
    font-family: var(--bb-font-display);
    font-size: var(--bb-fs-xl);
    font-weight: 700;
    color: #fff;
}
.bb-cat-tile__name-hi {
    font-family: var(--bb-font-devanagari);
    font-size: var(--bb-fs-sm);
    color: var(--bb-gold-bright);
}

/* ====================== LATEST POSTS ====================== */
.bb-posts__grid {
    display: grid;
    gap: var(--bb-sp-3);
    grid-template-columns: 1fr;
}
@media (min-width: 640px)  { .bb-posts__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .bb-posts__grid { grid-template-columns: repeat(3, 1fr); } }

.bb-post-card {
    background: #fff;
    border: 1px solid var(--bb-line);
    border-radius: var(--bb-r);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: all var(--bb-dur) var(--bb-ease);
    text-decoration: none;
    color: inherit;
}
.bb-post-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--bb-shadow-lg);
    border-color: var(--bb-gold);
}
.bb-post-card__img {
    aspect-ratio: 16 / 10;
    background: var(--bb-cream-warm);
    overflow: hidden;
    position: relative;
}
.bb-post-card__img img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 500ms var(--bb-ease);
}
.bb-post-card:hover .bb-post-card__img img { transform: scale(1.05); }

.bb-post-card__body {
    padding: var(--bb-sp-2) var(--bb-sp-3) var(--bb-sp-3);
    display: flex; flex-direction: column; gap: 0.5rem;
    flex: 1;
}
.bb-post-card__cat {
    font-size: var(--bb-fs-xs);
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--bb-sindoori);
}
.bb-post-card__title {
    font-family: var(--bb-font-display);
    font-size: var(--bb-fs-lg);
    line-height: 1.3;
    color: var(--bb-charcoal);
    margin: 0;
    font-weight: 700;
}
.bb-post-card:hover .bb-post-card__title { color: var(--bb-maroon); }
.bb-post-card__meta {
    margin-top: auto;
    font-size: var(--bb-fs-xs);
    color: var(--bb-muted);
    display: flex; align-items: center; gap: 0.4rem;
}

/* ====================== TRUST STRIP ====================== */
.bb-trust {
    background: linear-gradient(135deg, var(--bb-maroon) 0%, var(--bb-sindoori-dark) 100%);
    color: #fff;
    padding-block: var(--bb-sp-5);
    position: relative;
    overflow: hidden;
}
.bb-trust::before {
    content: "";
    position: absolute; inset: 0;
    background:
        radial-gradient(circle at 10% 50%, rgba(212, 160, 23, 0.15), transparent 40%),
        radial-gradient(circle at 90% 50%, rgba(212, 160, 23, 0.12), transparent 40%);
    pointer-events: none;
}
.bb-trust__inner { position: relative; }
.bb-trust__heading {
    text-align: center;
    margin-bottom: var(--bb-sp-4);
}
.bb-trust__heading h2 {
    color: var(--bb-gold-bright);
    font-size: var(--bb-fs-xl);
    margin: 0;
}
.bb-trust__grid {
    display: grid;
    gap: var(--bb-sp-3);
    grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 640px) { .bb-trust__grid { grid-template-columns: repeat(4, 1fr); } }

.bb-trust__item {
    text-align: center;
}
.bb-trust__num {
    font-family: var(--bb-font-display);
    font-size: clamp(1.75rem, 3vw, 2.75rem);
    color: var(--bb-gold-bright);
    font-weight: 700;
    line-height: 1;
}
.bb-trust__label {
    display: block;
    font-size: var(--bb-fs-sm);
    color: rgba(255, 255, 255, 0.85);
    margin-top: 0.4rem;
    letter-spacing: 0.03em;
}

/* ====================== SHLOKA / QUOTE ====================== */
.bb-shloka {
    background: var(--bb-ivory);
    position: relative;
    text-align: center;
}
.bb-shloka__inner {
    max-width: 820px; margin-inline: auto;
}
.bb-shloka__om {
    font-size: 4rem;
    line-height: 1;
    background: linear-gradient(135deg, var(--bb-saffron), var(--bb-gold));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    margin-bottom: var(--bb-sp-2);
}
.bb-shloka__verse {
    font-family: var(--bb-font-devanagari);
    font-size: clamp(1.35rem, 2vw, 2rem);
    color: var(--bb-maroon);
    line-height: 1.6;
    margin: var(--bb-sp-2) 0 var(--bb-sp-2);
    font-style: normal;
}
.bb-shloka__translation {
    font-size: var(--bb-fs-lg);
    color: var(--bb-charcoal-soft);
    max-width: 58ch;
    margin-inline: auto;
    line-height: 1.8;
    font-style: italic;
}

/* ====================== CTA BAND ====================== */
.bb-cta-band {
    background:
        linear-gradient(135deg, var(--bb-saffron) 0%, var(--bb-sindoori) 55%, var(--bb-maroon) 100%);
    color: #fff;
    text-align: center;
    padding-block: clamp(3rem, 6vw, 5rem);
    position: relative;
    overflow: hidden;
}
.bb-cta-band::before {
    content: "";
    position: absolute; inset: 0;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><g fill='none' stroke='%23ffffff' stroke-opacity='0.06' stroke-width='1'><circle cx='60' cy='60' r='55'/><circle cx='60' cy='60' r='40'/><circle cx='60' cy='60' r='25'/><path d='M60 5 L65 55 L60 50 L55 55 Z M60 115 L65 65 L60 70 L55 65 Z M5 60 L55 65 L50 60 L55 55 Z M115 60 L65 65 L70 60 L65 55 Z'/></g></svg>");
    background-size: 120px 120px;
    pointer-events: none;
}
.bb-cta-band__inner { position: relative; }
.bb-cta-band h2 { color: #fff; margin-bottom: var(--bb-sp-1); }
.bb-cta-band p {
    color: rgba(255, 255, 255, 0.92);
    max-width: 55ch; margin-inline: auto;
    font-size: var(--bb-fs-lg);
}
.bb-cta-band .bb-btn { margin-top: var(--bb-sp-2); }
