@import url("assets/css/nageshwar-brand.css");

/*-----------------------------------------------------------------------
Template Name      : Prachite - Temple Church And Mosque Website HTML Template
Author             : pus_infotech
Author Portfolio   : https://themeforest.net/user/pus_infotech 
Version            : 1.0.0 
-----------------------------------------------------------------------
CSS TABLE OF CONTENTS
-----------------------------------------------------------------------
- base 
    - variables
    - mixin
    - reset
    - typography
    - forms

- components 
    - accordion
    - breadcrumb
    - buttons
    - offcanvus
    - widget

- theme
    - animations
    - common
    - preloader 
    - spacing
    - theme-class
 
- layout
    -header
        - header
        - meanmenu
    - footer 
        - footer
    - section 
        - about 
        - authentication
        - blog
        - breadcrumb
        - campaigns
        - cart
        - checkout
        - comingsoon
        - contact
        - counter
        - courses
        - cta
        - donate
        - event
        - faq
        - gallery
        - hero
        - how-it-work
        - instagram
        - marquee
        - micon
        - mission
        - page
        - partners
        - prayer
        - pricing
        - product
        - progress
        - services
        - shop
        - team
        - testimonials
        - upcomming-event
        - video
        - why
        - wishlist
        
Main Style file-> assets/css/main.css
-----------------------------------------------------------------------*/

.page-wrapper.nageshwar-site {
    display: block;
}

/* Frontend navbar polish */
.header.header-1 {
    left: 0;
    position: sticky;
    right: 0;
    top: 0;
    transition: padding-top .22s ease, box-shadow .25s ease;
    z-index: 1000;
}

.header.header-1 .header-lower {
    background: #fff;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    transition: margin .22s ease, background .25s ease, border-color .25s ease, border-radius .22s ease, box-shadow .25s ease, backdrop-filter .25s ease;
}

.header.header-1 .header-content {
    transition: none;
}

.page-wrapper.nageshwar-site .header.header-1 .header-lower.sticky {
    animation: none !important;
    left: auto !important;
    position: static !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    width: auto !important;
    z-index: auto;
}

.header.header-1 .header-top {
    max-height: 58px;
    overflow: hidden;
    opacity: 1;
    transition: max-height .22s ease, opacity .18s ease, padding .22s ease;
}

.header.header-1.is-scrolled {
    padding-top: 10px;
    pointer-events: none;
}

.header.header-1.is-scrolled .header-top {
    max-height: 0;
    opacity: 0;
    padding-bottom: 0;
    padding-top: 0;
}

.header.header-1.is-scrolled .header-lower {
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px);
    background: rgba(24, 32, 44, .78);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 14px;
    box-shadow: 0 16px 42px rgba(15, 23, 42, .20);
    margin: 0 clamp(12px, 4vw, 54px);
    pointer-events: auto;
}

.header.header-1 .main-menu .nav-link {
    border-radius: 0;
    position: relative;
    transition: color .2s ease;
}

.header.header-1 .main-menu .nav-link:hover,
.header.header-1 .main-menu .nav-link.active,
.header.header-1 .main-menu .nav-item:hover > .nav-link {
    background: transparent !important;
    color: var(--primary-color) !important;
    transform: none;
}

.header.header-1 .submenu {
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .22);
    overflow: hidden;
}

.header.header-1.is-scrolled .header-content {
    min-height: 74px;
}

.page-wrapper.nageshwar-site .header.header-1 .header-lower.sticky .header-content .logo-box .logo {
    height: auto !important;
    min-height: 108px;
    max-height: none;
    padding: 12px 14px;
    top: -49px;
    width: min(300px, 34vw);
}

.page-wrapper.nageshwar-site .header.header-1 .header-lower.sticky .header-content .logo-box .logo figure img[src*="nageshwar-logo"] {
    max-height: none;
}

.page-wrapper.nageshwar-site .header.header-1.is-scrolled .header-lower.sticky .header-content .logo-box .logo {
    top: -49px;
}

.header.header-1.is-scrolled .main-menu .nav-link:hover,
.header.header-1.is-scrolled .main-menu .nav-link.active,
.header.header-1.is-scrolled .main-menu .nav-item:hover > .nav-link {
    background: transparent !important;
    color: var(--primary-color) !important;
}

.header.header-1.is-scrolled .nj-site-name,
.header.header-1.is-scrolled .main-menu .nav-link {
    color: #fff;
}

.header.header-1 .main-menu .nav-link::before,
.header.header-1 .main-menu .nav-link::after {
    display: none !important;
}

.nj-mobile-menu-drawer a.active,
.nj-mobile-menu-drawer a:hover {
    color: var(--primary-color) !important;
}

.nj-mobile-menu-drawer button {
    background: transparent;
    border: 0;
    color: inherit;
    font: inherit;
    min-height: 44px;
    padding: 0;
    text-align: left;
    width: 100%;
}

.nj-mobile-menu-drawer form {
    background: #fff;
    border: 1px solid rgba(196, 92, 38, .12);
    border-radius: 8px;
    display: flex;
    margin: 0;
    padding: 10px 12px;
}

.nj-nav-user-name {
    color: var(--black-color);
    font-size: 14px;
    font-weight: 800;
    max-width: 150px;
    overflow: hidden;
    text-decoration: none;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.nj-nav-user-name:hover,
.nj-nav-user-name.active {
    color: var(--primary-color);
}

.header.header-1.is-scrolled .nj-nav-user-name {
    color: #fff;
}

.header.header-1.is-scrolled .nj-nav-user-name:hover,
.header.header-1.is-scrolled .nj-nav-user-name.active {
    color: var(--primary-color);
}

/* Footer glass effect only */
.nj-glass-footer {
    -webkit-backdrop-filter: blur(18px);
    backdrop-filter: blur(18px);
    background:
        linear-gradient(135deg, rgba(24, 32, 44, .86), rgba(35, 18, 10, .88)),
        var(--footer-color) !important;
    isolation: isolate;
    overflow: hidden;
}

.nj-glass-footer::before {
    background:
        radial-gradient(circle at 18% 12%, rgba(255, 77, 0, .18), transparent 32%),
        radial-gradient(circle at 88% 8%, rgba(255, 255, 255, .12), transparent 28%),
        linear-gradient(180deg, rgba(255, 255, 255, .08), rgba(255, 255, 255, .02));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: -1;
}

.nj-glass-footer::after {
    background-color: rgba(0, 0, 0, .42) !important;
    opacity: 1 !important;
}

.nj-glass-footer .footer-bottom {
    -webkit-backdrop-filter: blur(14px);
    backdrop-filter: blur(14px);
    background-color: rgba(255, 255, 255, .08) !important;
    border-top: 1px solid rgba(255, 255, 255, .12);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.nj-glass-footer .footer-copyright {
    background-color: rgba(0, 0, 0, .42);
}

.nj-glass-footer .footer-copyright .footer-copyright-wrap {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
}

.nj-glass-footer .footer-copyright .copyright-text {
    margin-top: 0 !important;
}

.nj-glass-footer .footer-widget-title,
.nj-glass-footer .nj-site-name--footer,
.nj-glass-footer .footer-contact-item a,
.nj-glass-footer .footer-contact-item p {
    color: var(--white-color) !important;
}

.nj-glass-footer .footer-widget-about p,
.nj-glass-footer .nj-footer-about-content,
.nj-glass-footer .nj-footer-about-content p,
.nj-glass-footer .widget-link .link li a,
.nj-glass-footer .footer-contact-item span,
.nj-glass-footer .copyright-text p {
    color: rgba(255, 255, 255, .78) !important;
}

.nj-glass-footer .nj-footer-about-content pre {
    background: transparent !important;
    border: 0;
    color: rgba(255, 255, 255, .78) !important;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
    overflow: visible;
    padding: 0;
    white-space: normal;
}

.nj-glass-footer .footer-widget-title::after {
    background-color: var(--primary-color) !important;
}

.nj-glass-footer .widget-link .link li a i {
    color: var(--primary-color) !important;
}

.nj-glass-footer .widget-link .link li a:hover {
    color: var(--primary-color) !important;
}

.nj-glass-footer .footer-social-icon .social-icon a {
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    background-color: rgba(255, 255, 255, .12) !important;
    border: 1px solid rgba(255, 255, 255, .16);
    color: var(--white-color) !important;
}

.nj-glass-footer .footer-social-icon .social-icon a:hover {
    background-color: var(--primary-color) !important;
    color: var(--white-color) !important;
}

.gallery-section .photo-gallery,
.gallery-section .photo-gallery-image,
.gallery-section .photo-gallery-image figure {
    height: 100%;
}

.gallery-section .nj-photo-gallery-grid {
    --nj-gallery-gap: 24px;
    margin-left: calc(var(--nj-gallery-gap) / -2);
    margin-right: calc(var(--nj-gallery-gap) / -2);
    row-gap: var(--nj-gallery-gap);
}

.gallery-section .nj-photo-gallery-grid > [class*="col-"] {
    margin-bottom: 0;
    padding-left: calc(var(--nj-gallery-gap) / 2);
    padding-right: calc(var(--nj-gallery-gap) / 2);
}

.gallery-section .photo-gallery {
    aspect-ratio: 4 / 3;
    margin-bottom: 0;
    overflow: hidden;
}

.gallery-section .photo-gallery-image figure {
    margin: 0;
    position: relative;
}

.gallery-section .photo-gallery-image figure img {
    display: block;
    height: 100% !important;
    object-fit: cover;
    object-position: center;
    width: 100% !important;
}

@media (max-width: 767px) {
    .gallery-section .nj-photo-gallery-grid {
        --nj-gallery-gap: 18px;
    }
}

.nj-about-db-content pre {
    background: transparent !important;
    border: 0;
    color: inherit;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0 0 18px;
    overflow: visible;
    padding: 0;
    white-space: normal;
}

.nj-about-db-content p {
    overflow-wrap: anywhere;
}

.nj-profile-menu {
    position: relative;
}

.nj-language-switcher {
    flex: 0 0 auto;
    position: relative;
}

.nj-language-toggle {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(139, 61, 20, .22);
    border-radius: 999px;
    color: var(--black-color);
    display: inline-flex;
    font-size: 13px;
    font-weight: 800;
    gap: 7px;
    height: 44px;
    justify-content: center;
    line-height: 1;
    min-width: 54px;
    padding: 0 12px;
}

.nj-language-toggle i {
    color: var(--primary-color);
    font-size: 14px;
}

.nj-language-toggle:hover,
.nj-language-toggle[aria-expanded="true"] {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
}

.nj-language-toggle:hover i,
.nj-language-toggle[aria-expanded="true"] i {
    color: #fff;
}

.nj-language-dropdown {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .16);
    min-width: 150px;
    padding: 8px;
    position: absolute;
    right: 0;
    top: calc(100% + 12px);
    z-index: 1200;
}

.nj-language-dropdown[hidden] {
    display: none;
}

.nj-language-dropdown a {
    align-items: center;
    border-radius: 6px;
    color: var(--black-color);
    display: flex;
    font-size: 14px;
    font-weight: 800;
    padding: 10px 12px;
    text-decoration: none;
}

.nj-language-dropdown a.active,
.nj-language-dropdown a:hover {
    background: rgba(255, 77, 0, .1);
    color: var(--primary-color);
}

.nj-profile-menu-toggle {
    align-items: center;
    background: var(--primary-color);
    border: 0;
    border-radius: 50%;
    color: #fff;
    display: inline-flex;
    font-size: 15px;
    font-weight: 800;
    height: 44px;
    justify-content: center;
    line-height: 1;
    width: 44px;
}

.nj-profile-menu-toggle.active,
.nj-profile-menu-toggle:hover {
    background: var(--black-color);
}

.nj-profile-menu-dropdown {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .16);
    min-width: 180px;
    padding: 8px;
    position: absolute;
    right: 0;
    top: calc(100% + 12px);
    z-index: 1200;
}

.nj-profile-menu-dropdown[hidden] {
    display: none;
}

.nj-profile-menu-dropdown a,
.nj-profile-menu-dropdown button {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 6px;
    color: var(--black-color);
    display: flex;
    font-size: 14px;
    font-weight: 800;
    gap: 10px;
    padding: 10px 12px;
    text-align: left;
    width: 100%;
}

.nj-profile-menu-dropdown a:hover,
.nj-profile-menu-dropdown button:hover {
    background: rgba(255, 77, 0, .1);
    color: var(--primary-color);
}

.nj-profile-menu-dropdown form {
    margin: 0;
}

.nj-password-field {
    position: relative;
}

.nj-auth-form .nj-password-field .form-control {
    padding-right: 52px;
}

.nj-password-toggle {
    align-items: center;
    background: transparent;
    border: 0;
    border-radius: 10px;
    color: rgba(26, 21, 16, .58);
    display: inline-flex;
    height: 40px;
    justify-content: center;
    position: absolute;
    right: 7px;
    top: 7px;
    width: 40px;
}

.nj-password-toggle:hover,
.nj-password-toggle:focus {
    background: rgba(255, 77, 0, .1);
    color: var(--primary-color);
    outline: none;
}

.header.header-1.is-scrolled .nj-auth-nav .nj-nav-auth-btn,
.header.header-1.is-scrolled .nj-mobile-menu-toggle {
    box-shadow: 0 8px 18px rgba(0, 0, 0, .14);
}

@media (max-width: 1199.98px) {
    .header.header-1.is-scrolled {
        padding-top: 8px;
    }

    .header.header-1.is-scrolled .header-lower {
        margin: 0 10px;
    }

    .page-wrapper.nageshwar-site .header.header-1 .header-lower.sticky .header-content .logo-box .logo,
    .page-wrapper.nageshwar-site .header.header-1.is-scrolled .header-lower.sticky .header-content .logo-box .logo {
        min-height: 88px;
        top: -10px;
        width: min(260px, 52vw);
    }
}

@media (max-width: 575.98px) {
    .nj-language-toggle {
        border-radius: 50%;
        height: 36px;
        min-width: 36px;
        padding: 0;
        width: 36px;
    }

    .nj-language-toggle i {
        display: none;
    }
}

@media (min-width: 1200px) {
    .page-wrapper.nageshwar-site .header.header-1 .header-lower .container-fluid {
        padding-left: 16px;
        padding-right: 16px;
    }

    .page-wrapper.nageshwar-site .header.header-1 .header-lower .header-content {
        align-items: center;
        display: grid !important;
        gap: 20px;
        grid-template-columns: minmax(360px, 430px) minmax(0, 1fr) auto;
        min-height: 72px;
        padding: 0;
    }

    .page-wrapper.nageshwar-site .header.header-1 .header-left,
    .page-wrapper.nageshwar-site .header.header-1 .header-navigation,
    .page-wrapper.nageshwar-site .header.header-1 .header-right {
        min-width: 0;
    }

    .page-wrapper.nageshwar-site .header.header-1 .header-navigation {
        justify-content: center !important;
        margin-left: 0 !important;
    }

    .page-wrapper.nageshwar-site .header.header-1 .main-menu {
        width: 100%;
    }

    .page-wrapper.nageshwar-site .header.header-1 .main-menu nav > ul {
        align-items: center;
        display: flex;
        gap: clamp(12px, 1vw, 20px);
        justify-content: center;
        margin: 0;
        white-space: nowrap;
    }

    .page-wrapper.nageshwar-site .header.header-1 .main-menu nav > ul > li {
        margin: 0 !important;
    }

    .page-wrapper.nageshwar-site .header.header-1 .main-menu nav > ul > li > a {
        align-items: center;
        display: inline-flex;
        font-size: 14px;
        font-weight: 800;
        gap: 5px;
        line-height: 1;
        min-height: 44px;
        padding: 0;
    }

    .page-wrapper.nageshwar-site .header.header-1 .header-right {
        align-items: center;
        display: inline-flex !important;
        gap: 10px !important;
        justify-content: flex-end;
        margin-left: 0 !important;
        white-space: nowrap;
    }

    .page-wrapper.nageshwar-site .header.header-1 .logo-box .logo .nj-site-name {
        display: block;
        font-size: 20px;
        line-height: 1.15;
        max-width: 100%;
        overflow: visible;
        overflow-wrap: anywhere;
        padding: 0;
        text-align: left;
        text-overflow: clip;
        white-space: normal;
    }

    .page-wrapper.nageshwar-site .header.header-1 .nj-language-toggle,
    .page-wrapper.nageshwar-site .header.header-1 .nj-nav-auth-btn,
    .page-wrapper.nageshwar-site .header.header-1 .nj-profile-menu-toggle {
        box-shadow: 0 8px 18px rgba(0, 0, 0, .12);
    }
}

@media (min-width: 1200px) and (max-width: 1399.98px) {
    .page-wrapper.nageshwar-site .header.header-1 .header-lower .header-content {
        gap: 14px;
        grid-template-columns: minmax(320px, 380px) minmax(0, 1fr) auto;
        min-height: 68px;
    }

    .page-wrapper.nageshwar-site .header.header-1 .logo-box .logo .nj-site-name {
        font-size: 18px;
        line-height: 1.12;
    }

    .page-wrapper.nageshwar-site .header.header-1 .main-menu nav > ul {
        gap: 10px;
    }

    .page-wrapper.nageshwar-site .header.header-1 .main-menu nav > ul > li > a {
        font-size: 13px;
        min-height: 40px;
    }

    .page-wrapper.nageshwar-site .header.header-1 .header-right {
        gap: 8px !important;
    }

    .page-wrapper.nageshwar-site .header.header-1 .nj-language-toggle {
        height: 42px;
        min-width: 58px;
        padding-inline: 10px;
    }

    .page-wrapper.nageshwar-site .header.header-1 .nj-nav-auth-btn {
        min-height: 42px;
        padding: 10px 14px;
    }
}

.nj-youtube-ratio {
    border: 1px solid rgba(15, 23, 42, .08);
    min-height: 260px;
}

.nj-youtube-ratio iframe,
.nj-youtube-preview img {
    border: 0;
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.nj-youtube-preview {
    display: block;
}

.nj-youtube-preview::after {
    background: linear-gradient(180deg, rgba(15, 23, 42, .08), rgba(15, 23, 42, .42));
    content: "";
    inset: 0;
    position: absolute;
}

.nj-youtube-play {
    align-items: center;
    background: #ff0033;
    border-radius: 999px;
    color: #fff;
    display: flex;
    font-size: 42px;
    height: 92px;
    justify-content: center;
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 92px;
    z-index: 2;
}

.nj-live-empty {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    padding: 48px 24px;
}

.nj-live-empty i {
    color: #ff0033;
    font-size: 54px;
    margin-bottom: 18px;
}

.nj-timing-panel {
    background: linear-gradient(135deg, #151515 0%, #232323 55%, #111 100%);
    border: 1px solid rgba(255, 77, 0, .24);
    border-radius: 8px;
    box-shadow: 0 24px 70px rgba(15, 23, 42, .20);
    overflow: hidden;
    position: relative;
}

.nj-timing-panel::before {
    background: linear-gradient(90deg, var(--primary-color), #16c7ff, var(--primary-color));
    content: "";
    height: 3px;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}

.nj-timing-panel-head {
    align-items: center;
    border-bottom: 1px solid rgba(255, 255, 255, .1);
    color: #fff;
    display: flex;
    justify-content: space-between;
    padding: 22px 24px;
}

.nj-timing-panel-head span {
    align-items: center;
    display: inline-flex;
    font-weight: 800;
    gap: 10px;
}

.nj-timing-panel-head i {
    color: var(--primary-color);
}

.nj-timing-panel-head strong {
    background: rgba(22, 199, 255, .12);
    border: 1px solid rgba(22, 199, 255, .28);
    border-radius: 999px;
    color: #8be7ff;
    font-size: 13px;
    padding: 8px 12px;
}

.nj-timing-table {
    display: grid;
    padding: 18px;
    row-gap: 12px;
}

.nj-timing-row {
    align-items: center;
    background: rgba(255, 255, 255, .065);
    border: 1px solid rgba(255, 255, 255, .1);
    border-radius: 8px;
    color: #fff;
    display: grid;
    gap: 14px;
    grid-template-columns: 1.4fr .8fr .8fr;
    padding: 16px 18px;
}

.nj-timing-row-head {
    background: rgba(255, 255, 255, .03);
    color: rgba(255, 255, 255, .7);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.nj-timing-name {
    align-items: center;
    display: flex;
    gap: 12px;
}

.nj-timing-name strong {
    display: block;
    font-size: 18px;
    line-height: 1.2;
}

.nj-timing-name small {
    color: rgba(255, 255, 255, .62);
    display: block;
    margin-top: 4px;
}

.nj-timing-icon {
    align-items: center;
    background: rgba(255, 77, 0, .14);
    border: 1px solid rgba(255, 77, 0, .28);
    border-radius: 8px;
    color: var(--primary-color);
    display: inline-flex;
    flex: 0 0 auto;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.nj-timing-value {
    color: #fff;
    font-family: var(--heading-font);
    font-size: 22px;
    font-weight: 800;
}

.nj-timing-note {
    align-items: center;
    background: rgba(255, 255, 255, .05);
    border-top: 1px solid rgba(255, 255, 255, .1);
    color: rgba(255, 255, 255, .72);
    display: flex;
    gap: 10px;
    justify-content: space-between;
    padding: 16px 24px;
}

.nj-timing-note-text {
    align-items: center;
    display: flex;
    gap: 10px;
}

.nj-timing-note-text i {
    color: #8be7ff;
}

.nj-timing-call-button {
    align-items: center;
    background: var(--primary-color);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 999px;
    box-shadow: 0 10px 24px rgba(255, 77, 0, .22);
    color: #fff;
    display: inline-flex;
    flex: 0 0 auto;
    font-size: 14px;
    font-weight: 800;
    gap: 8px;
    line-height: 1;
    padding: 11px 16px;
}

.nj-timing-call-button i {
    color: #fff;
    font-size: 13px;
}

.nj-timing-call-button:hover {
    background: #16c7ff;
    color: #111;
}

.nj-timing-call-button:hover i {
    color: #111;
}

@media (max-width: 767.98px) {
    .nj-timing-panel-head,
    .nj-timing-note {
        align-items: flex-start;
        flex-direction: column;
    }

    .nj-timing-row,
    .nj-timing-row-head {
        grid-template-columns: 1fr;
    }

    .nj-timing-row-head {
        display: none;
    }

    .nj-timing-call-button {
        justify-content: center;
        width: 100%;
    }
}

.nj-pooja-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    display: flex;
    height: 100%;
    min-height: 100%;
    padding: 20px 22px;
    transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.nj-pooja-card:hover {
    border-color: rgba(255, 77, 0, .28);
    box-shadow: 0 22px 58px rgba(15, 23, 42, .12);
    transform: translateY(-2px);
}

.nj-pooja-card-body {
    display: flex;
    flex-direction: column;
    min-height: 214px;
    width: 100%;
}

.nj-pooja-card h3 {
    font-size: 22px;
    line-height: 1.25;
    margin-bottom: 10px;
}

.nj-pooja-description {
    color: var(--text-color);
    display: -webkit-box;
    font-size: 16px;
    line-height: 1.55;
    margin-bottom: 8px;
    min-height: 4.65em;
    overflow: hidden;
    position: relative;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.nj-pooja-description p {
    margin-bottom: 10px;
}

.nj-pooja-read-more {
    align-self: flex-start;
    background: transparent;
    border: 0;
    color: var(--primary-color);
    font-weight: 800;
    margin: 0 0 12px;
    padding: 0;
}

.nj-pooja-read-more:hover {
    text-decoration: underline;
}

.nj-pooja-price {
    color: var(--primary-color);
    font-family: var(--heading-font);
    font-size: 26px;
    font-weight: 800;
    margin-top: auto;
}

.nj-pooja-book-btn {
    align-self: flex-start;
    margin-top: 16px;
}

.nj-pooja-popup[hidden] {
    display: none;
}

.nj-pooja-popup {
    align-items: center;
    display: flex;
    inset: 0;
    justify-content: center;
    padding: 22px;
    position: fixed;
    z-index: 10000010;
}

.nj-pooja-popup-backdrop {
    background: rgba(15, 23, 42, .72);
    inset: 0;
    position: absolute;
}

.nj-pooja-popup-dialog {
    background: #fff;
    border: 1px solid rgba(255, 77, 0, .14);
    border-radius: 10px;
    box-shadow: 0 30px 90px rgba(15, 23, 42, .30);
    max-height: min(720px, calc(100vh - 44px));
    max-width: 760px;
    overflow: hidden;
    position: relative;
    width: min(100%, 760px);
    z-index: 1;
}

.nj-pooja-popup-header {
    align-items: flex-start;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    display: flex;
    gap: 20px;
    justify-content: space-between;
    padding: 26px 30px 22px;
    position: relative;
}

.nj-pooja-popup-header::before {
    background: var(--primary-color);
    content: "";
    height: 4px;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}

.nj-pooja-popup-header .sub-title {
    color: var(--primary-color);
    display: block;
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.nj-pooja-popup-header h3 {
    font-size: 30px;
    line-height: 1.22;
    margin-bottom: 0;
}

.nj-pooja-popup-close {
    align-items: center;
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 50%;
    color: var(--black-color);
    display: inline-flex;
    flex: 0 0 auto;
    height: 40px;
    justify-content: center;
    width: 40px;
}

.nj-pooja-popup-close:hover {
    color: var(--primary-color);
}

.nj-pooja-popup-body {
    max-height: calc(min(720px, 100vh - 44px) - 194px);
    overflow-y: auto;
    padding: 24px 30px 30px;
}

.nj-pooja-popup-price {
    align-items: center;
    background: linear-gradient(135deg, #fff6f0 0%, #fff 100%);
    border: 1px solid rgba(255, 77, 0, .18);
    border-radius: 8px;
    display: flex;
    justify-content: space-between;
    margin-bottom: 22px;
    padding: 16px 18px;
}

.nj-pooja-popup-price span {
    color: var(--text-color);
    font-weight: 800;
}

.nj-pooja-popup-price strong {
    color: var(--primary-color);
    font-family: var(--heading-font);
    font-size: 28px;
    line-height: 1;
}

.nj-pooja-popup-details {
    color: #333;
    line-height: 1.8;
}

.nj-pooja-popup-details p,
.nj-pooja-popup-details ul,
.nj-pooja-popup-details ol {
    margin-bottom: 14px;
}

.nj-pooja-popup-details > *:last-child {
    margin-bottom: 0;
}

.nj-pooja-popup-footer {
    background: #fbfbfc;
    border-top: 1px solid rgba(15, 23, 42, .08);
    display: flex;
    justify-content: flex-end;
    padding: 18px 30px;
}

body.nj-pooja-popup-open {
    overflow: hidden;
}

body.nj-pooja-popup-open .mouse-cursor {
    display: none !important;
}

@media (max-width: 575.98px) {
    .nj-pooja-popup {
        padding: 12px;
    }

    .nj-pooja-popup-header,
    .nj-pooja-popup-body,
    .nj-pooja-popup-footer {
        padding-left: 20px;
        padding-right: 20px;
    }

    .nj-pooja-popup-footer .theme-button {
        width: 100%;
    }

    .nj-pooja-popup-price {
        align-items: flex-start;
        flex-direction: column;
        gap: 10px;
    }
}

.nj-video-gallery-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    margin-bottom: 30px;
    overflow: hidden;
}

.nj-video-gallery-card video {
    aspect-ratio: 16 / 9;
    background: #111827;
    display: block;
    height: auto;
    object-fit: cover;
    width: 100%;
}

.nj-about-db-content {
    color: var(--text-color);
    line-height: 1.8;
}

.nj-about-db-content p,
.nj-about-db-content ul,
.nj-about-db-content ol {
    margin-bottom: 16px;
}

.nj-about-db-content ul,
.nj-about-db-content ol {
    padding-left: 22px;
}

.nj-about-db-content h1,
.nj-about-db-content h2,
.nj-about-db-content h3,
.nj-about-db-content h4,
.nj-about-db-content h5,
.nj-about-db-content h6 {
    color: var(--black-color);
    margin-bottom: 14px;
}

.nj-honeypot {
    height: 0;
    left: -9999px;
    overflow: hidden;
    position: absolute;
    width: 0;
}

.nj-contact-alert {
    border-radius: 8px;
    margin-bottom: 24px;
}

.contact-form .error {
    color: #dc3545;
    font-size: 13px;
    font-weight: 600;
    margin-top: 6px;
}

.contact-form .error-border {
    border-color: #dc3545 !important;
}

.nj-donation-section {
    background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.nj-donation-info {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    padding: 34px;
}

.nj-donation-info h2 {
    margin-bottom: 16px;
}

.nj-donation-purpose-list {
    display: grid;
    gap: 14px;
    margin-top: 28px;
}

.nj-donation-purpose {
    align-items: center;
    background: #fbfdff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    display: flex;
    gap: 14px;
    padding: 16px;
}

.nj-donation-purpose i {
    align-items: center;
    background: rgba(255, 77, 0, .12);
    border-radius: 8px;
    color: var(--primary-color);
    display: inline-flex;
    flex: 0 0 auto;
    height: 42px;
    justify-content: center;
    width: 42px;
}

.nj-donation-purpose strong,
.nj-donation-purpose span {
    display: block;
}

.nj-donation-purpose strong {
    color: var(--black-color);
    font-family: var(--heading-font);
    font-size: 18px;
    line-height: 1.2;
}

.nj-donation-purpose span {
    color: var(--text-color);
    font-size: 14px;
    margin-top: 3px;
}

.nj-donation-form {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    padding: 34px;
}

.nj-donation-form .error {
    color: #dc3545;
    font-size: 13px;
    font-weight: 600;
    margin-top: 6px;
}

.nj-donation-form .error-border {
    border-color: #dc3545 !important;
}

.nj-donation-amounts .donation-amount {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .12);
    border-radius: 999px;
    color: var(--black-color);
    cursor: pointer;
    display: inline-flex;
    font-weight: 800;
    margin-bottom: 10px;
    margin-right: 8px;
    padding: 10px 18px;
    transition: background .2s ease, border-color .2s ease, color .2s ease;
}

.nj-donation-amounts .donation-amount.active,
.nj-donation-amounts .donation-amount:hover {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
}

.nj-donation-status-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    padding: 46px 34px;
}

.nj-donation-status-icon {
    align-items: center;
    background: rgba(255, 77, 0, .12);
    border-radius: 50%;
    color: var(--primary-color);
    display: inline-flex;
    font-size: 30px;
    height: 72px;
    justify-content: center;
    margin-bottom: 18px;
    width: 72px;
}

.nj-donation-status-details {
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    margin: 28px 0;
    overflow: hidden;
}

.nj-donation-status-details div {
    padding: 18px;
}

.nj-donation-status-details div + div {
    border-left: 1px solid rgba(15, 23, 42, .08);
}

.nj-donation-status-details span,
.nj-donation-status-details strong {
    display: block;
}

.nj-donation-status-details span {
    color: var(--text-color);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.nj-donation-status-details strong {
    color: var(--black-color);
    font-family: var(--heading-font);
    font-size: 22px;
    line-height: 1.2;
    margin-top: 6px;
}

.nj-status-invoice {
    border: 1px solid rgba(15, 23, 42, .1);
    border-radius: 8px;
    margin: 28px 0;
    overflow: hidden;
    text-align: left;
}

.nj-status-invoice-head {
    align-items: center;
    background: #fff8ef;
    border-bottom: 1px solid rgba(196, 92, 38, .18);
    display: flex;
    gap: 16px;
    justify-content: space-between;
    padding: 18px 20px;
}

.nj-status-invoice-head span {
    color: var(--text-color);
    display: block;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.nj-status-invoice-head strong {
    color: var(--black-color);
    display: block;
    font-family: var(--heading-font);
    font-size: 22px;
    line-height: 1.2;
    margin-top: 4px;
}

.nj-status-paid-badge {
    background: #dcfce7;
    border: 1px solid #86efac;
    border-radius: 999px;
    color: #166534 !important;
    display: inline-flex !important;
    flex: 0 0 auto;
    padding: 7px 12px;
}

.nj-status-invoice-table {
    border-color: rgba(15, 23, 42, .08);
    min-width: 720px;
}

.nj-status-invoice-table th,
.nj-status-invoice-table td {
    border-color: rgba(15, 23, 42, .08) !important;
    padding: 13px 16px !important;
    vertical-align: middle;
}

.nj-status-invoice-table th {
    background: #f8fafc;
    color: var(--text-color);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
    white-space: nowrap;
}

.nj-status-invoice-table td {
    color: var(--black-color);
    font-weight: 700;
    overflow-wrap: anywhere;
}

.nj-status-total-row th,
.nj-status-total-row td {
    background: #2a130d !important;
    color: #fff !important;
    font-size: 16px;
}

.nj-status-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}

.nj-status-actions .theme-button {
    margin: 0;
}

/* Download Invoice button — keep the download arrow upright.
   The theme rule .theme-button.style-1 i applies transform: rotate(-45deg)
   which is intended for the right-arrow icon. Applied to fa-download it
   makes the icon look tilted/broken, so we neutralise it here. */
.nj-status-download-action i,
.nj-status-actions .theme-button.style-1 .fa-download {
    -webkit-transform: rotate(0deg) !important;
    -moz-transform: rotate(0deg) !important;
    -ms-transform: rotate(0deg) !important;
    -o-transform: rotate(0deg) !important;
    transform: rotate(0deg) !important;
}

.nj-status-download-action:hover i,
.nj-status-actions .theme-button.style-1:hover .fa-download {
    -webkit-transform: rotate(0deg) translateY(2px) !important;
    -moz-transform: rotate(0deg) translateY(2px) !important;
    -ms-transform: rotate(0deg) translateY(2px) !important;
    -o-transform: rotate(0deg) translateY(2px) !important;
    transform: rotate(0deg) translateY(2px) !important;
}

.nj-status-secondary-action {
    background: #fff !important;
    border: 1px solid rgba(196, 92, 38, .28) !important;
    color: var(--primary-color) !important;
}

.nj-status-secondary-action span,
.nj-status-secondary-action span::before,
.nj-status-secondary-action i {
    color: inherit !important;
}

.nj-status-secondary-action:hover {
    background: #fff7f1 !important;
    border-color: rgba(196, 92, 38, .42) !important;
    color: var(--primary-color) !important;
}

.nj-status-secondary-action:hover span::before {
    color: var(--primary-color) !important;
}

@media (max-width: 575.98px) {
    .nj-donation-info,
    .nj-donation-form,
    .nj-donation-status-card {
        padding: 24px;
    }

    .nj-donation-status-details {
        grid-template-columns: 1fr;
    }

    .nj-donation-status-details div + div {
        border-left: 0;
        border-top: 1px solid rgba(15, 23, 42, .08);
    }

    .nj-status-invoice-head {
        align-items: flex-start;
        flex-direction: column;
    }
}

.nj-auth-section {
    background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.nj-auth-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
    padding: 36px;
}

.nj-auth-form {
    margin-top: 26px;
}

.nj-auth-form .error {
    color: #dc3545;
    font-size: 13px;
    font-weight: 600;
    margin-top: 6px;
}

.nj-auth-form .error-border {
    border-color: #dc3545 !important;
}

.nj-password-checklist {
    display: grid;
    gap: 8px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-top: 12px;
}

.nj-password-checklist span {
    align-items: center;
    color: #64748b;
    display: inline-flex;
    font-size: 13px;
    font-weight: 700;
    gap: 7px;
    line-height: 1.35;
}

.nj-password-checklist span::before {
    align-items: center;
    background: #f1f5f9;
    border: 1px solid #cbd5e1;
    border-radius: 50%;
    color: transparent;
    content: "\2713";
    display: inline-flex;
    flex: 0 0 18px;
    font-size: 11px;
    height: 18px;
    justify-content: center;
    line-height: 1;
    width: 18px;
}

.nj-password-checklist span.is-valid {
    color: #15803d;
}

.nj-password-checklist span.is-valid::before {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff;
}

.nj-password-checklist span.is-invalid {
    color: #b42318;
}

.nj-password-checklist span.is-invalid::before {
    background: #fff1f2;
    border-color: #fb7185;
    color: transparent;
}

.nj-auth-check {
    align-items: center;
    color: var(--text-color);
    display: inline-flex;
    gap: 8px;
    margin-bottom: 22px;
}

.nj-auth-check input {
    accent-color: var(--primary-color);
}

.nj-auth-forgot {
    margin: -6px 0 22px;
    text-align: right;
}

.nj-auth-forgot a {
    color: var(--primary-color);
    font-size: 14px;
    font-weight: 800;
}

.nj-auth-switch {
    color: var(--text-color);
    margin-top: 22px;
    text-align: center;
}

.nj-auth-switch a {
    color: var(--primary-color);
    font-weight: 800;
}

@media (max-width: 575.98px) {
    .nj-auth-card {
        padding: 24px;
    }

    .nj-password-checklist {
        grid-template-columns: 1fr;
    }
}

.nj-profile-section {
    background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.nj-profile-card,
.nj-profile-history-card,
.nj-profile-summary-card {
    background: #fff;
    border: 1px solid rgba(15, 23, 42, .08);
    border-radius: 8px;
    box-shadow: 0 18px 48px rgba(15, 23, 42, .08);
}

.nj-profile-card {
    padding: 34px;
    text-align: center;
}

.nj-profile-avatar {
    align-items: center;
    background: rgba(255, 77, 0, .12);
    border: 1px solid rgba(255, 77, 0, .18);
    border-radius: 50%;
    color: var(--primary-color);
    display: inline-flex;
    font-family: var(--heading-font);
    font-size: 42px;
    font-weight: 800;
    height: 96px;
    justify-content: center;
    margin-bottom: 20px;
    width: 96px;
}

.nj-profile-card h2 {
    font-size: 30px;
    line-height: 1.2;
    margin-bottom: 8px;
}

.nj-profile-card p {
    color: var(--text-color);
    margin-bottom: 0;
    overflow-wrap: anywhere;
}

.nj-profile-detail-list {
    border-top: 1px solid rgba(15, 23, 42, .08);
    display: grid;
    gap: 14px;
    margin-top: 24px;
    padding-top: 24px;
    text-align: left;
}

.nj-profile-detail-list span,
.nj-profile-summary-card span {
    color: var(--text-color);
    display: block;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
}

.nj-profile-detail-list strong {
    color: var(--black-color);
    display: block;
    margin-top: 4px;
    overflow-wrap: anywhere;
}

.nj-profile-summary-grid {
    display: grid;
    gap: 16px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-bottom: 30px;
}

.nj-profile-summary-card {
    padding: 20px;
}

.nj-profile-summary-card strong {
    color: var(--black-color);
    display: block;
    font-family: var(--heading-font);
    font-size: 24px;
    line-height: 1.15;
    margin-top: 8px;
}

.nj-profile-history-card {
    overflow: hidden;
}

.nj-profile-form-wrap {
    padding: 24px;
}

.nj-profile-form .error {
    color: #dc3545;
    font-size: 13px;
    font-weight: 600;
    margin-top: 6px;
}

.nj-profile-form .error-border {
    border-color: #dc3545 !important;
}

.nj-profile-history-head {
    align-items: center;
    border-bottom: 1px solid rgba(15, 23, 42, .08);
    display: flex;
    gap: 18px;
    justify-content: space-between;
    padding: 24px;
}

.nj-profile-history-head h3 {
    font-size: 26px;
    line-height: 1.2;
    margin-bottom: 0;
}

.nj-profile-small-link {
    color: var(--primary-color);
    font-weight: 800;
    white-space: nowrap;
}

.nj-profile-table {
    color: var(--text-color);
}

.nj-profile-table th {
    background: #f8fafc;
    color: var(--black-color);
    font-size: 13px;
    text-transform: uppercase;
}

.nj-profile-table td,
.nj-profile-table th {
    border-color: rgba(15, 23, 42, .08);
    padding: 14px 16px;
    vertical-align: middle;
}

.nj-profile-status {
    border-radius: 999px;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    padding: 6px 10px;
}

.nj-profile-status.is-paid {
    background: rgba(25, 135, 84, .12);
    color: #198754;
}

.nj-profile-status.is-progress {
    background: rgba(13, 110, 253, .12);
    color: #0d6efd;
}

.nj-profile-status.is-failed {
    background: rgba(220, 53, 69, .12);
    color: #dc3545;
}

.nj-profile-status.is-pending {
    background: rgba(255, 193, 7, .18);
    color: #8a6500;
}

.nj-invoice-download-btn {
    align-items: center;
    background: var(--primary-color);
    border-radius: 6px;
    color: #fff;
    display: inline-flex;
    font-size: 12px;
    font-weight: 800;
    gap: 6px;
    line-height: 1;
    padding: 9px 11px;
    text-decoration: none;
    white-space: nowrap;
}

.nj-invoice-download-btn:hover {
    background: var(--black-color);
    color: #fff;
}

.nj-profile-empty {
    color: var(--text-color);
    padding: 24px;
}

@media (max-width: 1199.98px) {
    .nj-profile-summary-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 575.98px) {
    .nj-profile-card {
        padding: 24px;
    }

    .nj-profile-summary-grid {
        grid-template-columns: 1fr;
    }

    .nj-profile-history-head {
        align-items: flex-start;
        flex-direction: column;
    }
}
