/*============================================================
# Ashvani Singh BJP - Premium Stylesheet
# Built with custom theme, textures, advanced animations
============================================================*/
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,300&family=Satisfy&family=Playfair+Display:wght@400;500;600;700;800&family=Montserrat:wght@400;600;700;800&display=swap');

/*------------------------------------------------------------
# Root & General
------------------------------------------------------------*/
:root{
    --saffron:#f8971d;
    --saffron-dark:#ed502e;
    --bjp-orange:#ff5a00;
    --bjp-red:#e70f47;
    --bjp-green:#009961;
    --bjp-blue:#16327A;
    --bjp-cyan:#14B3E4;
    --bjp-yellow:#ff9600;
    --brown-dark:#8c3400;
    --brown-darker:#5a1f00;
    --cream:#fff5e2;
    --navy:#0b2341;
    --text:#3a3a3a;
    --shadow-lg: 0 18px 50px -10px rgba(140,52,0,.35);
    --shadow-md: 0 10px 30px -8px rgba(237,80,46,.25);
    --shadow-sm: 0 4px 15px rgba(0,0,0,.08);
    --grad-saffron: linear-gradient(135deg, #ff9600 0%, #ed502e 50%, #b91c1c 100%);
    --grad-india: linear-gradient(135deg, #ff5a00 0%, #ffffff 50%, #009961 100%);
}

*{box-sizing:border-box;}
html, body {
    margin: 0;
    padding: 0;
    scroll-behavior: smooth;
    overflow-x: clip;  /* preserves sticky on mobile (unlike overflow-x: hidden) */
    max-width: 100%;
    width: 100%;
}

body {
    font-family: "Poppins", sans-serif;
    color: var(--text);
    background-color: #fffaf2;
    /* Repeating subtle paisley/mandala texture in saffron */
    background-image:
        radial-gradient(circle at 20% 10%, rgba(248,151,29,.06) 0%, transparent 25%),
        radial-gradient(circle at 80% 60%, rgba(237,80,46,.05) 0%, transparent 30%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><g fill='none' stroke='%23ed502e' stroke-opacity='0.06' stroke-width='1'><circle cx='90' cy='90' r='60'/><circle cx='90' cy='90' r='40'/><circle cx='90' cy='90' r='20'/><path d='M90 30 L96 80 L146 90 L96 100 L90 150 L84 100 L34 90 L84 80 Z' fill='%23f8971d' fill-opacity='0.04' stroke='none'/></g></svg>");
    background-attachment: fixed;
    background-size: auto, auto, 180px 180px;
}

a {color:var(--saffron-dark); text-decoration:none; transition:all .3s ease;}
a:hover {color:var(--bjp-orange);}

h1,h2,h3,h4,h5,h6 {font-family:"Poppins",sans-serif;}
img{max-width:100%; height:auto; display:block;}

/* Safety against horizontal overflow on mobile */
section, header, footer, .marquee-wrpaeer { max-width: 100%;}
.container { padding-left: 15px; padding-right: 15px;}
@media (max-width: 991px) {
    body { background-attachment: scroll;}
    .header.inner-header { background-attachment: scroll;}
}
@media (max-width: 575px) {
    .container { padding-left: 14px; padding-right: 14px;}
}

/* Selection */
::selection { background: var(--saffron-dark); color:#fff;}

/*------------------------------------------------------------
# Reusable animations
------------------------------------------------------------*/
@keyframes spinFwd{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes bloom{0%,100%{transform:scale(.45);opacity:.4}50%{transform:scale(1);opacity:1}}
@keyframes pulse-ring{0%{transform:scale(.85);opacity:.7}100%{transform:scale(1.45);opacity:0}}
@keyframes float-y{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-28px)}to{opacity:1;transform:none}}
@keyframes fadeInScale{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
@keyframes glowSaffron{0%,100%{box-shadow:0 0 0 0 rgba(248,151,29,.45)}50%{box-shadow:0 0 0 14px rgba(248,151,29,0)}}
@keyframes gradMove{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}
@keyframes scroll-left{from{transform:translateX(100vw)}to{transform:translateX(-100%)}}
@keyframes typeBlink{50%{opacity:0}}
@keyframes underlineSlide{from{width:0}to{width:100%}}

/*------------------------------------------------------------
# Premium Preloader (Portrait reveal with rotating rings)
------------------------------------------------------------*/
#preloader {
    position: fixed; inset: 0; z-index: 9999;
    background:
        radial-gradient(ellipse at top left, rgba(248,151,29,.4) 0%, transparent 50%),
        radial-gradient(ellipse at bottom right, rgba(237,80,46,.3) 0%, transparent 50%),
        radial-gradient(ellipse at center, #fff8ec 0%, #ffe7c2 70%, #ffd394 100%);
    display:flex; flex-direction:column;
    align-items:center; justify-content:center;
    transition: opacity .7s ease, visibility .7s ease;
    overflow: hidden;
}
/* Floating particles backdrop */
#preloader::before {
    content:""; position:absolute; inset:0;
    background:
        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='%23ed502e' fill-opacity='0.08'><circle cx='30' cy='40' r='2'/><circle cx='160' cy='60' r='1.5'/><circle cx='80' cy='120' r='2.5'/><circle cx='170' cy='170' r='1.5'/><circle cx='40' cy='180' r='2'/><circle cx='120' cy='30' r='1.5'/></g></svg>"),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300' viewBox='0 0 300 300'><g fill='none' stroke='%23ed502e' stroke-opacity='0.05' stroke-width='1'><circle cx='150' cy='150' r='100'/><circle cx='150' cy='150' r='130'/></g></svg>");
    background-size: 200px 200px, 300px 300px;
    pointer-events:none;
    animation: gradMove 20s ease infinite;
}
/* Vignette */
#preloader::after {
    content:""; position:absolute; inset:0;
    background: radial-gradient(circle, transparent 30%, rgba(140,52,0,.12) 100%);
    pointer-events:none;
}
#preloader.fade-out { opacity:0; visibility:hidden;}
#preloader .pre-wrap {
    position:relative; text-align:center; z-index:2;
    animation: fadeInScale .8s ease both;
}

/* Portrait with rotating rings */
#preloader .pre-lotus {
    width: 200px; height: 200px; margin: 0 auto 22px;
    position: relative;
    display: flex; align-items: flex-end; justify-content: center;
}
/* Inner pulsing halo */
#preloader .pre-lotus::before{
    content:""; position:absolute; left:50%; top:55%;
    transform: translate(-50%, -50%);
    width: 200px; height: 200px;
    border-radius:50%;
    background: radial-gradient(circle, rgba(248,151,29,.55) 0%, rgba(237,80,46,.2) 40%, transparent 70%);
    animation: pulse-ring 2.4s ease-out infinite;
    z-index: 0;
}
/* Soft ground shadow */
#preloader .pre-lotus::after{
    content:""; position:absolute; left:50%; bottom:-4px;
    transform: translateX(-50%);
    width: 140px; height: 14px;
    border-radius: 50%;
    background: radial-gradient(ellipse, rgba(140,52,0,.4) 0%, transparent 70%);
    z-index: 0;
    animation: float-y 3s ease-in-out infinite reverse;
}
#preloader .pre-lotus img{
    width:100%; height:100%; object-fit:contain;
    object-position: center bottom;
    position:relative; z-index:3;
    filter: drop-shadow(0 12px 28px rgba(237,80,46,.45));
    animation: float-y 3s ease-in-out infinite;
}

/* Rotating SVG ring container around portrait */
#preloader .pre-ring {
    position: absolute; left: 50%; top: 50%;
    transform: translate(-50%, -50%);
    width: 230px; height: 230px;
    pointer-events: none;
    z-index: 1;
}
#preloader .pre-ring svg {
    width: 100%; height: 100%;
    animation: spinFwd 14s linear infinite;
}
#preloader .pre-ring .dotted-ring {
    fill: none; stroke: var(--saffron-dark);
    stroke-width: 2; stroke-dasharray: 6 10;
    opacity: .55;
}
#preloader .pre-ring .progress-arc {
    fill: none; stroke: var(--saffron);
    stroke-width: 4; stroke-linecap: round;
    transform-origin: center;
    animation: arcDash 1.6s ease-in-out infinite;
}
@keyframes arcDash {
    0% { stroke-dasharray: 0 360; stroke-dashoffset: 0;}
    50% { stroke-dasharray: 180 360; stroke-dashoffset: -90;}
    100% { stroke-dasharray: 0 360; stroke-dashoffset: -360;}
}

/* Tricolor underline below name */
#preloader h3{
    font-family:'Playfair Display', serif;
    color: var(--brown-dark);
    font-size: 32px; margin: 8px 0 4px; font-weight: 800;
    letter-spacing: .5px;
    position: relative; display: inline-block;
}
#preloader h3 small{
    display:block; font-family:'Satisfy',cursive;
    color:var(--saffron-dark); font-size:18px; font-weight:400; margin-bottom:2px;
    animation: fadeDown .6s ease both;
}
#preloader h3::after {
    content: ""; display: block;
    width: 70%; height: 3px; margin: 6px auto 0;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron) 33%, #fff 33%, #fff 66%, var(--bjp-green) 66%);
    border-radius: 3px;
    animation: underlineSlide .8s ease both;
}
#preloader .pre-party {
    font-family:'Montserrat'; font-size:10px;
    letter-spacing:3.5px; color:var(--brown-dark);
    margin: 8px 0 16px; font-weight:800;
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
#preloader .pre-party::before,
#preloader .pre-party::after {
    content: ""; width: 24px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--brown-dark));
}
#preloader .pre-party::after {
    background: linear-gradient(90deg, var(--brown-dark), transparent);
}

/* Circular dot progress */
#preloader .pre-loader-bar{
    width: 240px; height: 4px; margin: 14px auto 10px;
    background: rgba(140,52,0,.15); border-radius: 4px; overflow: hidden;
    position: relative;
}
#preloader .pre-loader-bar::after{
    content:""; position:absolute; inset:0;
    background: linear-gradient(90deg, transparent, var(--saffron-dark), var(--bjp-orange), transparent);
    background-size: 50% 100%;
    background-repeat: no-repeat;
    animation: shimmer 1.6s linear infinite;
}

/* Tagline */
#preloader .pre-tag{
    font-size:11px; color:var(--brown-dark);
    letter-spacing:3px; text-transform:uppercase;
    font-weight: 600;
    display: inline-block; padding: 6px 18px;
    background: rgba(255,255,255,.4); backdrop-filter: blur(4px);
    border-radius: 30px;
    border: 1px solid rgba(237,80,46,.2);
}

@media (max-width: 575px) {
    #preloader { padding: 20px;}
    #preloader .pre-wrap {
        max-width: 100%;
        text-align: center;
        margin: 0 auto;
        position: relative;
        left: auto; right: auto;
    }
    #preloader .pre-lotus {
        width: 130px; height: 130px;
        margin: 0 auto 16px;
    }
    #preloader .pre-lotus::before {
        width: 130px; height: 130px;
    }
    #preloader .pre-ring {
        width: 160px; height: 160px;
    }
    #preloader h3 { font-size: 22px;}
    #preloader h3 small { font-size: 15px;}
    #preloader .pre-party { font-size: 9px; letter-spacing: 2.5px;}
    #preloader .pre-loader-bar { width: 200px;}
    #preloader .pre-tag { font-size: 10px; padding: 5px 14px;}
}

/*------------------------------------------------------------
# Back to top
------------------------------------------------------------*/
.back-to-top {
    position: fixed; right: 18px; bottom: 18px; z-index: 996;
    background: var(--grad-saffron);
    width: 46px; height: 46px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    visibility: hidden; opacity: 0;
    transition: all .4s ease;
    box-shadow: 0 8px 22px rgba(237,80,46,.5);
}
.back-to-top i { font-size: 24px; color: #fff; line-height: 1;}
.back-to-top:hover { background: var(--brown-dark); transform: translateY(-4px) rotate(-8deg);}
.back-to-top.active { visibility: visible; opacity: 1;}

/*------------------------------------------------------------
# Marquee top bar
------------------------------------------------------------*/
.marquee-wrpaeer {
    background: linear-gradient(90deg, #5a1f00 0%, #8c3400 50%, #5a1f00 100%);
    background-size: 200% 100%;
    animation: gradMove 12s ease infinite;
    border-bottom: 1px solid rgba(255,255,255,.1);
    position: relative; z-index: 100;
    overflow: hidden;
}
.marquee-wrpaeer > .container {
    overflow: hidden;
    max-width: 100%;
}
.marquee { height: 40px; overflow: hidden; position: relative; color: #fff; flex: 1;}
/* Pre-header social icons strip on the right of the marquee bar */
.marquee-wrpaeer .container {
    display: flex;
    align-items: center;
    gap: 14px;
}
.preheader-socials {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0;
}
.preheader-socials a {
    color: rgba(255,255,255,.85);
    font-size: 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px; height: 28px;
    border-radius: 50%;
    transition: background .25s ease, color .25s ease, transform .25s ease;
    text-decoration: none;
}
.preheader-socials a:hover {
    background: rgba(255,255,255,.15);
    color: #fff;
    transform: translateY(-1px);
}
@media (max-width: 575px) {
    .preheader-socials { gap: 6px; }
    .preheader-socials a { width: 24px; height: 24px; font-size: 13px; }
    .marquee-wrpaeer .container { gap: 8px; }
}
/* Seamless infinite scroll — duplicate text, translate -50% */
.marquee-track {
    display: flex;
    width: max-content;
    animation: marquee-scroll 35s linear infinite;
    will-change: transform;
}
.marquee-track p {
    flex-shrink: 0;
    margin: 0;
    padding-right: 60px;
    line-height: 40px;
    white-space: nowrap;
    font-size: 12.5px;
    font-family: 'Poppins', sans-serif;
    text-shadow: 0 1px 2px rgba(0,0,0,.3);
    color: #fff;
}
.marquee-track p i { color: var(--saffron); margin: 0 6px;}
@keyframes marquee-scroll {
    from { transform: translateX(0);}
    to   { transform: translateX(-50%);}
}
.marquee:hover .marquee-track { animation-play-state: paused;}

/*------------------------------------------------------------
# Header & Navigation
------------------------------------------------------------*/
#header {
    background: linear-gradient(to bottom, #fff8e8 0%, #fff5e2 100%);
    transition: all .4s ease;
    z-index: 1000;
    border-bottom: 4px solid;
    border-image: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dark) 50%, var(--bjp-red) 100%) 1;
    position: sticky;
    top: 0;
    width: 100%;
    will-change: transform;
}

/* On mobile/tablet — header sticks, marquee scrolls naturally */
@media (max-width: 991px) {
    .marquee-wrpaeer {
        position: relative;
        z-index: 100;
    }
    #header {
        position: sticky;
        top: 0;
        width: 100%;
    }
}
#header.header-scrolled {
    box-shadow: 0 6px 24px rgba(140,52,0,.18);
    background: rgba(255,248,232,.98);
    backdrop-filter: blur(8px);
}
#header .container {
    position: relative;
    padding: 8px 60px;
    max-width: 1480px;
}
@media (max-width: 1399px) {
    #header .container { padding: 8px 44px; }
}
@media (max-width: 1199px) {
    #header .container { padding: 8px 28px; }
}
@media (max-width: 575px) {
    #header .container { padding: 6px 16px; }
}

/* ============================================================
   OFFICIAL PARTY LOGO (v9) — BJP Lotus emblem + bold wordmark
   No photo · big visible lotus · saffron blob accent
============================================================ */
#header .logo {
    padding: 8px 0; margin: 0; flex-shrink: 0;
    position: relative;
}
#header .logo a {
    display: flex; align-items: center;
    gap: 14px;
    text-decoration: none;
    position: relative;
    padding: 0;
    background: transparent;
    transition: all .35s ease;
}
#header .logo a::before,
#header .logo a::after { display: none;}
#header .logo a:hover { transform: translateY(-2px);}

/* PHOTO FRAME — premium circular portrait of Ashvani Singh */
#header .logo .lotus-mark {
    width: 82px; height: 82px;
    background: transparent;
    padding: 0;
    transition: all .5s cubic-bezier(.2,.8,.2,1);
    flex-shrink: 0;
    position: relative;
    clip-path: none !important;
    transform: none !important;
    display: flex; align-items: center; justify-content: center;
    overflow: visible;
    border-radius: 50%;
    box-shadow: none !important;
}

/* Saffron gradient outer ring with conic motion */
#header .logo .lotus-mark::before {
    content: "";
    position: absolute;
    inset: -3px;
    background: conic-gradient(
        from 0deg,
        var(--saffron) 0%,
        var(--saffron-dark) 25%,
        var(--bjp-red) 50%,
        var(--saffron-dark) 75%,
        var(--saffron) 100%
    );
    border-radius: 50%;
    z-index: 0;
    transition: all .5s ease;
}

/* White spacer ring between gradient and photo */
#header .logo .lotus-mark::after {
    content: "";
    position: absolute;
    inset: 0;
    background: #fff;
    border-radius: 50%;
    z-index: 1;
    transition: all .5s ease;
}

/* The photo */
#header .logo .lotus-mark img {
    width: calc(100% - 6px); height: calc(100% - 6px);
    object-fit: cover;
    object-position: center 18%;
    position: relative;
    z-index: 2;
    transition: transform .5s ease;
    border-radius: 50% !important;
    box-shadow: 0 4px 12px rgba(237,80,46,.3);
    background: linear-gradient(135deg, #fff8ec 0%, #ffe0a8 100%) !important;
    filter: none;
    clip-path: none !important;
    padding: 0;
}

#header .logo a:hover .lotus-mark::before {
    inset: -5px;
    filter: brightness(1.1);
}
#header .logo a:hover .lotus-mark img {
    transform: scale(1.06);
    box-shadow: 0 6px 18px rgba(237,80,46,.5);
}

/* BJP LOTUS VERIFIED BADGE — real favicon (fav2.png) shown in full colour */
#header .logo .lotus-mark .verified-badge {
    display: flex !important;
    align-items: center;
    justify-content: center;
    position: absolute;
    right: -4px; bottom: -4px;
    width: 30px; height: 30px;
    background: #fff;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 3px 8px rgba(237,80,46,.45);
    z-index: 5;
    overflow: hidden;
    padding: 2px;
}
#header .logo .lotus-mark .verified-badge img {
    display: block !important;
    width: 100%; height: 100%;
    object-fit: contain;
    object-position: center;
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    filter: none;
}
#header .logo .lotus-mark .verified-badge::before { display: none;}

/* Hide old elements */
#header .logo .logo-text .pre-tag-mini { display: none;}
#header .logo .logo-text em { display: none;}

/* TEXT BLOCK */
#header .logo .logo-text {
    display: flex; flex-direction: column; justify-content: center;
    line-height: 1;
    position: relative;
}
#header .logo .logo-text::before { display: none;}

/* TOP MINI-LABEL */
#header .logo .logo-text h2 {
    margin: 0;
    font-family: 'Poppins', sans-serif;
    font-size: 19px;
    font-weight: 800;
    letter-spacing: -.4px;
    line-height: 1;
    color: var(--navy);
    text-transform: none;
    position: relative;
    display: block;
    padding-bottom: 5px;
}
#header .logo .logo-text h2 span {
    background: none;
    -webkit-background-clip: unset;
    background-clip: unset;
    color: var(--saffron-dark);
    margin-left: 4px;
    font-style: normal;
    font-weight: 800;
}
#header .logo .logo-text h2 span::after { display: none;}

/* TRICOLOR FLAG STRIP under name */
#header .logo .logo-text h2::after {
    content: "";
    display: block;
    width: 100%;
    height: 4px;
    margin-top: 4px;
    background:
        linear-gradient(90deg,
            var(--saffron) 0%, var(--saffron) 33.33%,
            #ffffff 33.33%, #ffffff 66.66%,
            var(--bjp-green) 66.66%, var(--bjp-green) 100%);
    border-radius: 2px;
    border: 1px solid rgba(0,0,0,.05);
    box-shadow: 0 2px 6px rgba(0,0,0,.1);
}

/* SUBTITLE — clean party label */
#header .logo .logo-text small {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 8px;
    font-weight: 800;
    color: var(--brown-dark);
    letter-spacing: 2.4px;
    text-transform: uppercase;
    margin-top: 4px;
    padding: 0;
    background: none;
    border: 0;
    border-radius: 0;
    backdrop-filter: none;
    width: auto;
}
#header .logo .logo-text small::before,
#header .logo .logo-text small::after { display: none;}
#header .logo .logo-text small i { display: none;}

.navbar { padding: 0;}
.navbar ul {
    margin: 0; padding: 0; display: flex; list-style: none; align-items: center;
}
.navbar li { position: relative;}

/* JOIN US button using real image - fixed clipping by moving overflow */
.navbar li.join {
    width: 78px; margin-left: 18px;
    padding: 8px 0 !important;  /* extra space so float doesn't clip */
}
.navbar li.join a {
    padding: 0 !important; margin: 0 !important;
    background: none !important;
    display: block; line-height: 0;
    position: relative;
    transition: transform .35s ease;
    overflow: visible;
}
.navbar li.join a::before{ display:none;}
.navbar li.join a::after{ display:none !important;}
.navbar li.join a img {
    width: 100%; display: block;
    filter: drop-shadow(0 8px 18px rgba(237,80,46,.45));
    animation: floatJoin 3.5s ease-in-out infinite;
    transform-origin: center;
}
.navbar li.join a:hover { transform: scale(1.1) rotate(-4deg);}
.navbar li.join a:hover img { animation-play-state: paused;}
@keyframes floatJoin {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-6px) scale(1.02); }
}

.navbar a, .navbar a:focus {
    display: flex; align-items: center; justify-content: space-between;
    padding: 32px 12px;
    font-size: 11px; font-family: 'Montserrat', sans-serif;
    font-weight: 700; color: var(--navy);
    white-space: nowrap; transition: color .3s, background .3s, transform .3s;
    text-transform: uppercase; letter-spacing: .6px;
    position: relative;
}
.navbar li.home { padding: 0;}
.navbar li.home a {
    padding: 26px 14px;
    border-right: 1px solid rgba(248,151,29,.3);
}
.navbar li.home a i { margin-left: 0;}
.navbar a i { font-size: 10px; line-height: 0; margin-left: 6px; transition: transform .3s;}
.navbar li:hover > a i { transform: rotate(180deg);}

/* Top accent line on hover */
.navbar > ul > li:not(.home):not(.join) > a::before{
    content:""; position:absolute; top:0; left:50%;
    width:0; height:3px;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    transition: width .35s ease, left .35s ease;
    border-radius: 0 0 3px 3px;
}
.navbar > ul > li:not(.home):not(.join) > a:hover::before,
.navbar > ul > li:not(.home):not(.join):hover > a::before,
.navbar > ul > li:not(.home):not(.join) > a.active::before{
    width: 60%; left: 20%;
}
/* Subtle bottom underline (keep) */
.navbar > ul > li:not(.home):not(.join) > a::after{
    content:""; position:absolute; left:50%; bottom:18px;
    height:2px; width:0; background: var(--saffron-dark);
    transition: width .3s ease, left .3s ease; border-radius: 3px;
}
.navbar > ul > li:not(.home):not(.join) > a:hover::after,
.navbar > ul > li:not(.home):not(.join):hover > a::after,
.navbar > ul > li:not(.home):not(.join) > a.active::after{
    width: 40%; left: 30%;
}
.navbar a:hover, .navbar li:hover > a, .navbar .active {
    color: var(--saffron-dark);
}

/* Dropdowns */
.navbar .dropdown ul {
    display: block; position: absolute; left: 0;
    top: calc(100% + 30px); margin: 0; padding: 8px 0;
    z-index: 99; opacity: 0; visibility: hidden;
    background: #fff;
    box-shadow: 0 18px 40px rgba(140,52,0,.22);
    border-radius: 10px;
    transition: .3s; min-width: 230px;
    border-top: 3px solid var(--saffron);
    transform: translateY(10px);
}
.navbar .dropdown ul li { min-width: 200px;}
.navbar .dropdown ul a {
    padding: 11px 20px; text-transform: none; font-size: 12.5px;
    font-weight: 500; color: var(--navy); position: relative;
}
.navbar .dropdown ul a::after{display:none;}
.navbar .dropdown ul a:hover,
.navbar .dropdown ul li:hover > a {
    color: #fff; background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    padding-left: 28px;
}
.navbar .dropdown:hover > ul {
    opacity: 1; top: 100%; visibility: visible; transform: translateY(0);
}

/* Mobile nav toggle — premium saffron button */
.mobile-nav-toggle {
    color: #fff;
    font-size: 22px;
    cursor: pointer;
    display: none;
    line-height: 1;
    transition: all .3s ease;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    border: 0;
    width: 44px; height: 44px;
    border-radius: 12px;
    align-items: center; justify-content: center;
    box-shadow: 0 6px 14px rgba(237,80,46,.4);
    flex-shrink: 0;
    z-index: 1000;
    position: relative;
}
.mobile-nav-toggle:hover { transform: translateY(-2px); box-shadow: 0 8px 18px rgba(237,80,46,.55);}
.mobile-nav-toggle.bi-x {
    background: rgba(255,255,255,.25);
    color: #fff;
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.4);
    position: fixed;
    top: 22px; right: 22px;
    z-index: 10001;
    width: 40px; height: 40px;
    border-radius: 50%;
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
}
@media (max-width: 991px) {
    .mobile-nav-toggle { display: inline-flex; }
    .navbar ul { display: none;}
    /* Make sure header layout works */
    #header .container { padding: 8px 12px;}
}

/* Premium Mobile Sidebar Drawer — overlays entire viewport */
.navbar-mobile {
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    width: 100vw;
    height: 100vh;
    height: 100dvh; /* dynamic viewport — better for mobile browsers */
    background: rgba(11,35,65,.7);
    backdrop-filter: blur(10px);
    z-index: 9999;
    overflow: hidden;
    isolation: isolate;
}
@keyframes drawerOverlayFade {
    from { opacity: 0;}
    to { opacity: 1;}
}

#navbar.navbar-mobile > ul {
    display: block;
    position: absolute;
    top: 0; right: 0; bottom: 0;
    width: 86%;
    max-width: 340px;
    padding: 130px 0 30px 0;  /* leave space for the saffron header */
    margin: 0;
    background:
        linear-gradient(180deg, #fff5e2 0%, #ffeac2 25%, #ffffff 60%, #ffffff 100%);
    overflow-y: auto;
    overflow-x: hidden;
    border-radius: 20px 0 0 20px;
    box-shadow: -16px 0 40px rgba(0,0,0,.4);
    animation: drawerSlideIn .4s cubic-bezier(.2,.8,.2,1) both;
    list-style: none;
    -webkit-overflow-scrolling: touch;
}
@keyframes drawerSlideIn {
    from { transform: translateX(100%);}
    to { transform: translateX(0);}
}

/* Fixed saffron header strip at top of drawer */
.navbar-mobile ul::before {
    content: "Ashvani Singh\A BJYM · BALLIA";
    white-space: pre;
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 110px;
    padding: 24px 70px 18px 24px;
    background:
        linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 60%, var(--brown-dark) 100%);
    border-radius: 20px 0 0 0;
    color: #fff;
    font-family: 'Playfair Display', serif;
    font-size: 19px;
    font-weight: 800;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
    line-height: 1.3;
    letter-spacing: 0;
    border-bottom: 3px solid;
    border-image: linear-gradient(90deg,
        var(--saffron) 0%, var(--saffron) 33%,
        #ffffff 33%, #ffffff 66%,
        var(--bjp-green) 66%, var(--bjp-green) 100%) 1;
    z-index: 5;
    box-sizing: border-box;
    pointer-events: none;
}
.navbar-mobile ul::after { display: none !important;}

.navbar-mobile li {
    margin: 0 12px;
    border-radius: 12px;
    overflow: hidden;
    transition: background .2s ease;
}
.navbar-mobile li:hover { background: rgba(248,151,29,.1);}
/* Style the Home item like other menu items — clean icon + text */
.navbar-mobile li.home {
    border-right: 0;
    padding: 0;
}
.navbar-mobile li.home a {
    padding: 14px 18px !important;
    border-right: 0 !important;
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: flex-start;
}
.navbar-mobile li.home a i {
    font-size: 18px !important;
    margin: 0 !important;
    color: var(--saffron-dark) !important;
    line-height: 1;
}
.navbar-mobile li.home a::after {
    content: "Home";
    font-family: 'Poppins', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: var(--navy);
    margin: 0;
}
.navbar-mobile li.home a:hover::after,
.navbar-mobile li.home:hover > a::after { color: #fff;}
.navbar-mobile li.home a:hover i,
.navbar-mobile li.home:hover > a i { color: #fff !important;}

.navbar-mobile a, .navbar-mobile a:focus {
    padding: 14px 18px;
    font-size: 14px;
    font-weight: 600;
    color: var(--navy);
    margin: 0;
    border-radius: 12px;
    text-transform: none;
    letter-spacing: 0;
    font-family: 'Poppins', sans-serif;
    display: flex; align-items: center;
    border-bottom: 1px solid rgba(248,151,29,.12);
    background: none;
    transition: all .25s ease;
}
.navbar-mobile a i { color: var(--saffron-dark);}
.navbar-mobile a:hover, .navbar-mobile .active, .navbar-mobile li:hover > a {
    color: #fff;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    padding-left: 24px;
}
.navbar-mobile a:hover i, .navbar-mobile li:hover > a i { color: #fff;}

/* Submenus — hidden by default, shown when .dropdown-active added */
.navbar-mobile .dropdown ul {
    position: static !important;
    display: none !important;
    margin: 8px 0 6px 0 !important;
    padding: 6px 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
    box-shadow: none !important;
    background: rgba(248,151,29,.08) !important;
    border-radius: 10px !important;
    border: 1px solid rgba(248,151,29,.18) !important;
    width: auto !important;
    border-top: 1px solid rgba(248,151,29,.18) !important;
    animation: none !important;
    max-width: none !important;
    min-width: 0 !important;
    overflow: hidden;
    transform: none !important;
    top: auto !important; right: auto !important; bottom: auto !important; left: auto !important;
}
.navbar-mobile .dropdown ul::before,
.navbar-mobile .dropdown ul::after { display: none !important;}
.navbar-mobile .dropdown ul li {
    margin: 0 !important;
    border-radius: 0 !important;
    padding: 0 !important;
    background: transparent !important;
}
.navbar-mobile .dropdown ul li:hover { background: rgba(248,151,29,.12) !important;}
.navbar-mobile .dropdown ul a {
    padding: 10px 18px 10px 28px !important;
    font-size: 13px !important;
    color: var(--brown-dark) !important;
    border-bottom: 1px solid rgba(0,0,0,.05) !important;
    background: transparent !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
}
.navbar-mobile .dropdown ul li:last-child a { border-bottom: 0 !important;}
.navbar-mobile .dropdown ul a:hover { background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dark) 100%) !important; color: #fff !important; padding-left: 32px !important;}
/* Show submenu when active */
.navbar-mobile .dropdown > ul.dropdown-active { display: block !important;}
/* Chevron rotation when open */
.navbar-mobile .dropdown > a > i.bi-chevron-down { transition: transform .3s ease;}
.navbar-mobile .dropdown > a + ul.dropdown-active ~ a > i.bi-chevron-down,
.navbar-mobile .dropdown:has(> ul.dropdown-active) > a > i.bi-chevron-down { transform: rotate(180deg);}

/* JOIN button in mobile drawer */
.navbar-mobile li.join {
    width: auto;
    margin: 16px 16px 24px;
    padding: 0 !important;
}
.navbar-mobile li.join a {
    animation: none;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    color: #fff;
    text-align: center;
    border-radius: 12px;
    padding: 14px !important;
    justify-content: center;
    box-shadow: 0 8px 20px rgba(237,80,46,.4);
    border-bottom: 0;
}
.navbar-mobile li.join a::before {
    content: "Join BJYM Ballia";
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: .5px;
}
.navbar-mobile li.join a img { display: none;}

/*------------------------------------------------------------
# Hero / Carousel
------------------------------------------------------------*/
#hero {
    width: 100%; max-width: 100vw; height: 560px;
    overflow: hidden; position: relative;
}
#hero.abtbann { height: 360px;}
#hero .carousel, #hero .carousel-inner, #hero .carousel-item { position: absolute; inset: 0;}
#hero .carousel-item {
    background-size: cover; background-position: center; background-repeat: no-repeat;
}
#hero .carousel-item::before {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(11,35,65,.55) 0%, rgba(140,52,0,.25) 50%, rgba(237,80,46,.45) 100%);
}
#hero .carousel-item::after{
    content:""; position:absolute; inset:0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><path d='M0 0 L40 0 L40 40 L0 40 Z' fill='none' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='1'/></svg>");
    background-size: 40px 40px;
}
#hero .carousel-container {
    display: flex; align-items: center; position: absolute;
    inset: 90px 50px 60px 50px; z-index: 2;
}
#hero h2 {
    color: #fff; margin: 0; font-weight: 700;
    font-family: 'Playfair Display', serif; font-size: 44px;
    line-height: 1.18; text-shadow: 2px 4px 14px rgba(0,0,0,.55);
    max-width: 680px;
    animation: fadeUp .9s ease both;
}
#hero h2 span{ display:inline-block; background: linear-gradient(90deg, var(--saffron) 0%, #fff 50%, var(--bjp-green) 100%); -webkit-background-clip:text; background-clip:text; color:transparent;}
#hero .carousel-container.rtlHdng { justify-content:flex-end;}
#hero .carousel-container.rtlHdng h2 { text-align: right;}
#hero .carousel-container.lftHdng h2 { text-align: left;}
#hero .hero-tagline{
    display:inline-block; background: rgba(248,151,29,.85); color:#fff;
    font-family:'Satisfy',cursive; font-size:18px; padding:4px 18px;
    border-radius:30px; margin-bottom:14px; backdrop-filter:blur(4px);
    border:1px solid rgba(255,255,255,.4);
    animation: fadeDown .8s ease both;
}

#hero .carousel-control-prev, #hero .carousel-control-next { z-index: 3; width: 5%;}
#hero .carousel-control-next-icon, #hero .carousel-control-prev-icon {
    background: rgba(255,255,255,.18); border: 2px solid rgba(255,255,255,.6);
    border-radius: 50%; transition: .3s; color: #fff;
    width: 52px; height: 52px; display: flex;
    align-items: center; justify-content: center; font-size: 22px;
    backdrop-filter: blur(6px);
}
#hero .carousel-control-next-icon:hover, #hero .carousel-control-prev-icon:hover {
    background: var(--saffron-dark); border-color: var(--saffron-dark); transform: scale(1.08);
}

#hero .carousel-inner .carousel-item { transition-property: opacity; opacity: 0;}
#hero .carousel-inner .active { opacity: 1; transition: .5s;}
#hero .carousel-indicators { display: none;}

@media (max-width:991px){ #hero{height:400px;} #hero h2{font-size:30px;} }
@media (max-width:575px){ #hero{height:280px;} #hero h2{font-size:20px;} #hero .carousel-container{inset:50px 18px 30px 18px;} #hero .hero-tagline{font-size:14px;} }

/*------------------------------------------------------------
# Sections General
------------------------------------------------------------*/
section { padding: 100px 0; position:relative;}
section + section { padding-top: 100px;}
.inner-content { padding: 90px 0 100px;}

.section-title { padding-bottom: 22px;}
.section-title h2 {
    font-size: 28px; font-weight: 500; padding: 0;
    line-height: 28px; margin: 0 0 6px 0; letter-spacing: 2px;
    color: #fff; font-family: 'Satisfy', cursive;
}
.section-title h2::after {
    content: ""; width: 80px; height: 1px; display: inline-block;
    background: #fff; margin: 4px 10px; vertical-align: middle;
}
.section-title p {
    margin: 0; font-size: 34px; font-weight: 600;
    font-family: 'Playfair Display', serif; color: #fff;
}

/*------------------------------------------------------------
# Icon Boxes (Home 4 cards)
------------------------------------------------------------*/
.icon-boxes { padding: 0; position: relative; z-index: 100; margin-top: -1px;}
.icon-boxes-wrap.r-r .row { margin: 0;}
.icon-boxes .icon-box {
    padding: 0; position: relative; overflow: hidden;
    box-shadow: 0 18px 35px rgba(11,35,65,.32);
    transition: all .4s cubic-bezier(.2,.8,.2,1);
    text-align: center; min-height: 100%; color: #fff;
}
.icon-boxes .icon-box::before{
    content:""; position:absolute; inset:0; pointer-events:none;
    background: linear-gradient(180deg, rgba(255,255,255,.15) 0%, transparent 30%);
}
.icon-boxes .icon-box:hover{ transform: translateY(-10px); box-shadow: 0 25px 50px rgba(11,35,65,.4);}
.icon-boxes-wrap.r-r .icon-box.colorbx01 { border-radius: 41px 0 0 0;}
.icon-boxes-wrap.r-r .icon-box.colorbx04 { border-radius: 0 0 41px 0;}
.colorbx01 { background: linear-gradient(135deg, #ff2563, #b91c4d);}
.colorbx02 { background: linear-gradient(135deg, #00d6a3, #008f6c);}
.colorbx03 { background: linear-gradient(135deg, #1f4ba8, #0f2854);}
.colorbx04 { background: linear-gradient(135deg, #29c6f5, #0a83b8);}
.colorbx05 { background: linear-gradient(135deg, #ffae3a, #d97300);}

.icon-boxes .icon-box .icon { margin: 0; width: 100%; transition: all .4s; position: relative;}
.icon-boxes .icon-box .icon span {
    width: 100%; display: flex; min-height: 130px;
    align-items: center; justify-content: center; padding: 22px;
    position: relative; z-index: 2;
}
.icon-boxes .icon-box .icon span img {
    max-width: 78px; max-height: 78px; transition: transform .5s ease;
    filter: drop-shadow(0 4px 10px rgba(0,0,0,.4));
}
.icon-boxes .icon-box:hover .icon span img { transform: scale(1.15) rotate(-8deg);}

/* Small image strip at top of icon-box */
.icon-boxes .icon-box .ib-strip {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2px;
    height: 70px;
    overflow: hidden;
}
.icon-boxes .icon-box .ib-strip .ib-img {
    background-size: cover; background-position: center;
    opacity: .8; transition: opacity .4s, transform .4s;
    position: relative;
}
.icon-boxes .icon-box .ib-strip .ib-img::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,.4) 100%);
}
.icon-boxes .icon-box:hover .ib-strip .ib-img { opacity: 1;}
.icon-boxes .icon-box:hover .ib-strip .ib-img:nth-child(1) { transform: scale(1.08);}
.icon-boxes .icon-box:hover .ib-strip .ib-img:nth-child(2) { transform: scale(1.05);}
.icon-boxes .icon-box:hover .ib-strip .ib-img:nth-child(3) { transform: scale(1.08);}
.iconbox-cont { padding: 0 22px 28px;}
.icon-boxes .title {
    font-weight: 700; margin-bottom: 12px; font-size: 18px; color: #fff;
}
.icon-boxes .description {
    font-size: 13.5px; line-height: 21px; margin-bottom: 0; color: rgba(255,255,255,.92);
}
.icon-boxes .linkRM {
    display: inline-block; font-size: 13px; margin-top: 18px;
    color: #fff; padding: 7px 22px; border: 2px solid rgba(255,255,255,.75);
    border-radius: 30px; transition: all .3s; font-weight: 600;
    position: relative; overflow: hidden;
}
.icon-boxes .linkRM::before{
    content:""; position:absolute; inset:0;
    background: #fff; transform: scaleX(0); transform-origin: left;
    transition: transform .35s ease; z-index: -1;
}
.icon-boxes .linkRM:hover{ color: var(--navy); border-color:#fff;}
.icon-boxes .linkRM:hover::before{ transform: scaleX(1);}

/* Inner secondary icon boxes (about page mini grid) */
#icon-boxes01.icon-boxes .icon-box {
    box-shadow: 0 12px 28px rgba(0,0,0,.12); border-radius: 20px; overflow: hidden;
}
#icon-boxes01.icon-boxes .icon-box.colorbx01 { padding: 30px 22px;}
#icon-boxes01.icon-boxes .icon-box.colorbx03 { padding: 30px 22px;}
#icon-boxes01.icon-boxes .icon-box.colorbx04 { padding: 30px 22px;}
#icon-boxes01.icon-boxes .icon-box.vdbox { background: transparent; padding: 0;}
#icon-boxes01.icon-boxes .icon-box .icon span {width: 60%; min-height: 100px; margin: 0 auto;}
#icon-boxes01.icon-boxes { margin-top: -140px; padding-bottom: 0; position:relative; z-index: 12;}
#icon-boxes01 .icon-boxes-wrap.portfolio {
    margin-bottom: 22px; display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 22px;
}
.vdbox { position: relative; border-radius: 20px; overflow: hidden;
    box-shadow: 0 12px 28px rgba(0,0,0,.18);}
.vdbox img { width: 100%; height: 100%; object-fit: cover; min-height: 230px; transition: transform .6s;}
.vdbox:hover img { transform: scale(1.06);}
.vdbox .portfolio-info {
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(11,35,65,.35) 0%, rgba(237,80,46,.45) 100%);
    display: flex; align-items: center; justify-content: center;
    transition: all .3s;
}
.vdbox:hover .portfolio-info{ background: linear-gradient(135deg, rgba(11,35,65,.55) 0%, rgba(237,80,46,.65) 100%);}
.vdbox .portfolio-info a {
    width: 68px; height: 68px; border-radius: 50%;
    background: rgba(255,255,255,.95);
    display: flex; align-items: center; justify-content: center;
    color: var(--saffron-dark); font-size: 30px;
    transition: .3s; position: relative;
}
.vdbox .portfolio-info a::before{
    content:""; position:absolute; inset:-8px;
    border:2px solid rgba(255,255,255,.5); border-radius:50%;
    animation: pulse-ring 2s ease-out infinite;
}
.vdbox .portfolio-info a:hover { background: var(--saffron-dark); color: #fff; transform: scale(1.08);}

@media (max-width: 768px) { #icon-boxes01 .icon-boxes-wrap.portfolio { grid-template-columns: 1fr;}}

/*------------------------------------------------------------
# Section titles (Campaign)
------------------------------------------------------------*/
.section-title-cmpgn { padding-bottom: 6px; position: relative; z-index: 1;}
.section-title-cmpgn h2 {
    font-size: 28px; font-weight: 700; margin-bottom: 12px;
    padding-bottom: 14px; position: relative;
    color: var(--navy); font-family:'Playfair Display',serif;
}
.section-title-cmpgn h2::after {
    content: ""; position: absolute; display: block;
    width: 60px; height: 3px; background: var(--bjp-green); bottom: 0; left: 0;
    border-radius: 3px;
}
.section-title-cmpgn.campaignHome { text-align: center; padding: 30px 0 10px;}
.section-title-cmpgn.campaignHome h2 { font-size: 36px;}
.section-title-cmpgn.campaignHome h2::after { background: var(--saffron-dark); left: 50%; transform: translateX(-50%); width:100px;}
.section-title-cmpgn p { margin-bottom: 6px; color: #555; font-size: 14.5px; line-height: 24px;}

/*------------------------------------------------------------
# Testimonials / Campaign slider
------------------------------------------------------------*/
.testimonials {
    padding: 60px 0 70px;
    background: linear-gradient(135deg, #ed502e 0%, #e70f47 50%, #8c3400 100%);
    background-size: 200% 200%;
    animation: gradMove 14s ease infinite;
    position: relative; color: #fff; margin-top: 30px;
    overflow: hidden;
}
.testimonials::before{
    content:""; position:absolute; inset:0;
    background-image:
        radial-gradient(circle at 12% 20%, rgba(255,255,255,.08) 0%, transparent 30%),
        radial-gradient(circle at 88% 80%, rgba(255,255,255,.08) 0%, transparent 30%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><circle cx='60' cy='60' r='40' fill='none' stroke='%23ffffff' stroke-opacity='0.05'/><circle cx='60' cy='60' r='25' fill='none' stroke='%23ffffff' stroke-opacity='0.05'/></svg>");
}
.testimonials > .container{ position:relative; z-index:1;}
.testimonials .section-title-cmpgn h2 { color: #fff; padding-bottom: 6px;}
.testimonials .section-title-cmpgn h2::after { background: #fff;}
.testimonials .section-title-cmpgn p { color: rgba(255,255,255,.95); line-height: 24px;}
.testimonials .hero-img { position:relative;}
.testimonials .hero-img img {
    border: 6px solid rgba(255,255,255,.4); width: 100%;
    border-radius: 16px; box-shadow: 0 18px 40px rgba(0,0,0,.3);
    transition: transform .5s ease;
}
.testimonials .hero-img:hover img{ transform: scale(1.02);}
.testimonials-slider { overflow: hidden; padding-bottom: 36px;}
.testimonials .swiper-pagination { position: relative; margin-top: 22px; text-align: center;}
.testimonials .swiper-pagination .swiper-pagination-bullet {
    width: 12px; height: 12px; background: rgba(255,255,255,.5); opacity: 1; margin: 0 5px;
    transition: all .3s;
}
.testimonials .swiper-pagination .swiper-pagination-bullet-active {
    background: #fff; width: 36px; border-radius: 6px;
}

/* ============================================================
   CAMPAIGN HIGHLIGHTS  v2  — editorial white card
============================================================ */

/* Heading area */
.section-title-cmpgn.campaignHome { padding: 60px 0 24px;}
.section-title-cmpgn.campaignHome .ch-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    background: linear-gradient(135deg, #fff7ee 0%, #ffe0c2 100%);
    color: var(--brown-dark);
    font-size: 11px; font-weight: 800;
    letter-spacing: 2.4px; text-transform: uppercase;
    padding: 8px 22px;
    border: 1px solid rgba(217, 91, 0, .3);
    border-radius: 30px;
    margin-bottom: 16px;
    box-shadow: 0 4px 14px rgba(237, 80, 46, .15);
}
.section-title-cmpgn.campaignHome .ch-eyebrow i { color: var(--saffron-dark); font-size: 13px;}
.section-title-cmpgn.campaignHome h2 {
    background: linear-gradient(135deg, var(--brown-dark) 0%, var(--bjp-red) 70%, var(--saffron-dark) 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
    padding-bottom: 18px;
}
.section-title-cmpgn.campaignHome .ch-sub {
    color: #666; font-size: 15px; line-height: 1.6;
    max-width: 640px; margin: 14px auto 0;
}

/* Section background — softer, deeper saffron with depth */
.testimonials {
    padding: 70px 0 60px;
    background:
        radial-gradient(circle at 18% 25%, rgba(255, 153, 51, .35) 0%, transparent 45%),
        radial-gradient(circle at 82% 75%, rgba(231, 15, 71, .35) 0%, transparent 50%),
        linear-gradient(135deg, #5a1f00 0%, #8c3400 45%, #b94117 100%);
    animation: gradMove 18s ease infinite;
    background-size: 200% 200%, 200% 200%, 240% 240%;
}
.testimonials::before {
    background-image:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><circle cx='60' cy='60' r='40' fill='none' stroke='%23ffffff' stroke-opacity='0.05'/><circle cx='60' cy='60' r='25' fill='none' stroke='%23ffffff' stroke-opacity='0.05'/></svg>"),
        radial-gradient(circle at 50% 0%, rgba(255, 255, 255, .08), transparent 60%);
}

/* Slide card — white editorial card */
.testimonials .ch-slide {
    position: relative;
    background: linear-gradient(180deg, #ffffff 0%, #fffaf2 100%);
    border-radius: 26px;
    padding: 38px 42px 34px 42px;
    box-shadow:
        0 30px 60px rgba(0, 0, 0, .35),
        0 0 0 1px rgba(255, 153, 51, .25);
    overflow: hidden;
    isolation: isolate;
}
/* Top tricolour strip */
.testimonials .ch-slide::before {
    content: ""; position: absolute;
    top: 0; left: 0; right: 0; height: 6px;
    background: linear-gradient(90deg,
        var(--saffron) 0%, var(--saffron) 33.33%,
        #ffffff 33.33%, #ffffff 66.66%,
        var(--bjp-green) 66.66%, var(--bjp-green) 100%);
    z-index: 3;
}
/* Soft saffron blob in bottom-right */
.testimonials .ch-slide::after {
    content: ""; position: absolute;
    right: -120px; bottom: -120px;
    width: 380px; height: 380px;
    background: radial-gradient(circle, rgba(255, 153, 51, .18) 0%, rgba(237, 80, 46, .08) 45%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

/* Huge background numeral */
.testimonials .ch-num {
    position: absolute;
    top: 30px; right: 32px;
    font-family: 'Playfair Display', serif;
    font-size: 220px; font-weight: 900;
    line-height: 1;
    background: linear-gradient(180deg, rgba(255, 153, 51, .25) 0%, rgba(237, 80, 46, .1) 100%);
    -webkit-background-clip: text; background-clip: text;
    -webkit-text-fill-color: transparent; color: transparent;
    letter-spacing: -8px;
    pointer-events: none;
    z-index: 1;
    user-select: none;
}

/* Grid — image left, text right */
.testimonials .ch-grid {
    display: grid;
    grid-template-columns: 0.95fr 1.3fr;
    gap: 44px;
    align-items: center;
    position: relative;
    z-index: 2;
}

/* Image column with offset deco backdrop */
.testimonials .ch-img-col { position: relative;}
.testimonials .ch-img-deco {
    position: absolute;
    left: -14px; bottom: -14px;
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--bjp-red) 100%);
    border-radius: 22px;
    z-index: 0;
    box-shadow: 0 16px 36px rgba(237, 80, 46, .35);
}
.testimonials .ch-img-frame {
    position: relative;
    z-index: 2;
    border-radius: 22px;
    overflow: hidden;
    box-shadow: 0 18px 36px rgba(0, 0, 0, .35);
    transition: transform .55s cubic-bezier(.2, .9, .3, 1.2);
}
.testimonials .ch-slide:hover .ch-img-frame { transform: translate(6px, -6px);}
.testimonials .ch-img-frame img {
    display: block;
    width: 100%; height: 340px;
    object-fit: cover;
    border: 0;
    box-shadow: none;
    border-radius: 22px;
    margin: 0;
    transition: transform .9s ease;
}
.testimonials .ch-slide:hover .ch-img-frame img { transform: scale(1.06);}
.testimonials .ch-img-frame::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(160deg, transparent 55%, rgba(0, 0, 0, .35) 100%);
    border-radius: 22px;
    pointer-events: none;
}
.testimonials .ch-year-stamp {
    position: absolute;
    left: 16px; bottom: 16px;
    z-index: 3;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--bjp-red) 100%);
    color: #fff;
    padding: 10px 16px;
    border-radius: 14px;
    border: 2px solid rgba(255, 255, 255, .55);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .35);
    font-family: 'Playfair Display', serif;
    font-size: 18px; font-weight: 800;
    line-height: 1;
    text-align: center;
}
.testimonials .ch-year-stamp small {
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 8.5px; font-weight: 800;
    letter-spacing: 2px; text-transform: uppercase;
    opacity: .9;
    margin-bottom: 4px;
}

/* Text column */
.testimonials .ch-text-col { color: var(--navy); position: relative;}
.testimonials .ch-meta {
    display: flex; flex-wrap: wrap; gap: 8px;
    margin-bottom: 16px;
}
.testimonials .ch-cat {
    display: inline-flex; align-items: center; gap: 7px;
    background: linear-gradient(135deg, #fff7ee 0%, #ffe0c2 100%);
    color: var(--brown-dark);
    font-size: 10.5px; font-weight: 800;
    letter-spacing: 1.3px; text-transform: uppercase;
    padding: 7px 14px;
    border: 1px solid rgba(217, 91, 0, .25);
    border-radius: 30px;
}
.testimonials .ch-cat i { color: var(--saffron-dark); font-size: 12px;}
.testimonials .ch-flag {
    display: inline-flex; align-items: center;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--bjp-red) 100%);
    color: #fff;
    font-size: 10.5px; font-weight: 800;
    letter-spacing: 1.3px; text-transform: uppercase;
    padding: 7px 14px;
    border-radius: 30px;
    box-shadow: 0 6px 16px rgba(217, 91, 0, .35);
}

.testimonials .ch-text-col h2 {
    font-family: 'Playfair Display', serif;
    font-size: 42px; font-weight: 800;
    color: var(--navy);
    line-height: 1.08;
    margin: 0 0 6px 0;
    padding-bottom: 14px;
    position: relative;
    letter-spacing: -.5px;
}
.testimonials .ch-text-col h2::after {
    content: ""; position: absolute;
    left: 0; bottom: 0; height: 5px; width: 80px;
    border-radius: 3px;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--bjp-red) 50%, var(--bjp-green) 100%);
}
.testimonials .ch-quote-mark {
    color: var(--saffron-dark);
    font-size: 38px;
    line-height: 1;
    opacity: .35;
    margin: 6px 0 -10px 0;
}
.testimonials .ch-text-col p {
    color: #444;
    font-size: 15px; line-height: 1.75;
    margin: 14px 0 0 0;
}
.testimonials .ch-text-col p strong { color: var(--bjp-red);}
.testimonials .ch-text-col em { color: var(--saffron-dark); font-style: italic;}

/* Stat row — icon + number + label */
.testimonials .ch-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 24px;
    padding-top: 22px;
    border-top: 1px dashed rgba(217, 91, 0, .35);
}
.testimonials .ch-stat {
    display: flex; align-items: center; gap: 12px;
    background: linear-gradient(135deg, #fff7ee 0%, #fff 100%);
    border: 1px solid rgba(217, 91, 0, .15);
    border-radius: 14px;
    padding: 12px 14px;
    transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.testimonials .ch-stat:hover {
    transform: translateY(-4px);
    box-shadow: 0 10px 22px rgba(237, 80, 46, .2);
    border-color: rgba(217, 91, 0, .35);
}
.testimonials .ch-stat-icon {
    width: 42px; height: 42px;
    flex: 0 0 42px;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    color: #fff;
    border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 18px;
    box-shadow: 0 6px 14px rgba(217, 91, 0, .4);
}
.testimonials .ch-stat strong {
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 22px; font-weight: 800;
    color: var(--navy);
    line-height: 1.1;
    margin-bottom: 2px;
}
.testimonials .ch-stat em {
    display: block;
    font-style: normal;
    font-size: 10px; font-weight: 700;
    letter-spacing: .9px; text-transform: uppercase;
    color: var(--brown-dark);
    line-height: 1.3;
}

/* Navigation row */
.testimonials .ch-nav-row {
    display: flex; align-items: center; justify-content: center;
    gap: 20px;
    margin-top: 32px;
    position: relative; z-index: 2;
}
.testimonials .ch-arrow {
    width: 50px; height: 50px;
    border-radius: 50%;
    background: #fff;
    border: 0;
    color: var(--bjp-red);
    font-size: 19px;
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    transition: all .3s cubic-bezier(.2, .9, .3, 1.2);
    box-shadow: 0 8px 20px rgba(0, 0, 0, .3);
}
.testimonials .ch-arrow:hover {
    background: linear-gradient(135deg, var(--saffron) 0%, var(--bjp-red) 100%);
    color: #fff;
    transform: scale(1.1);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .4);
}
.testimonials .ch-nav-row .swiper-pagination { position: static; margin: 0; width: auto;}

/* Responsive */
@media (max-width: 991px) {
    .testimonials .ch-slide { padding: 28px 24px 26px 24px; border-radius: 22px;}
    .testimonials .ch-num { font-size: 140px; top: 18px; right: 18px;}
    .testimonials .ch-grid { grid-template-columns: 1fr; gap: 26px;}
    .testimonials .ch-img-frame img { height: 260px;}
    .testimonials .ch-text-col h2 { font-size: 30px;}
    .testimonials .ch-stats { gap: 10px;}
    .testimonials .ch-stat { padding: 10px 12px; gap: 10px;}
    .testimonials .ch-stat-icon { width: 36px; height: 36px; flex-basis: 36px; font-size: 15px;}
    .testimonials .ch-stat strong { font-size: 18px;}
}
@media (max-width: 575px) {
    .testimonials { padding: 50px 0 50px;}
    .testimonials .ch-slide { padding: 22px 18px 22px 18px; border-radius: 18px;}
    .testimonials .ch-num { font-size: 90px; top: 12px; right: 14px;}
    .testimonials .ch-img-frame img { height: 200px;}
    .testimonials .ch-img-deco { left: -8px; bottom: -8px;}
    .testimonials .ch-text-col h2 { font-size: 24px;}
    .testimonials .ch-quote-mark { font-size: 28px;}
    .testimonials .ch-text-col p { font-size: 13.5px;}
    .testimonials .ch-stats { grid-template-columns: 1fr; gap: 8px; padding-top: 16px; margin-top: 18px;}
    .testimonials .ch-arrow { width: 42px; height: 42px; font-size: 16px;}
    .testimonials .ch-year-stamp { font-size: 14px; padding: 7px 12px;}
}

/*------------------------------------------------------------
# About / Portfolio wrapper
------------------------------------------------------------*/
section.portfolio {
    position: relative; background-color: transparent;
    z-index: 9; padding-top: 0; padding-bottom: 70px;
}
section.portfolio.home { padding: 0 0 80px;}

.portfolio .bg01 {
    background:
        linear-gradient(120deg, rgba(255,245,226,.94) 0%, rgba(248,151,29,.18) 100%),
        url('../images/about-bg.jpg');
    background-size: cover; background-position: center;
    position: relative; z-index: 1;
    padding: 90px 0 240px;
}
.portfolio .bg01::after{
    content:""; position:absolute; inset:0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><g fill='%23ed502e' fill-opacity='0.04'><circle cx='100' cy='100' r='80'/><circle cx='100' cy='100' r='60'/><circle cx='100' cy='100' r='40'/></g></svg>");
    background-size: 200px 200px; opacity: .8; pointer-events: none;
}
.portfolio .bg01 > .container{position:relative; z-index:2;}
.portfolio .bg01 .contact-wrap {
    font-size: 14.5px; padding: 0 30px 0 0;
    text-align: justify; color: #2b2b2b;
}
.portfolio .bg01 .contact-wrap p { line-height: 25px; margin-bottom: 14px;}
.portfolio .bg01 .section-title h2 { color: var(--bjp-orange);}
.portfolio .bg01 .section-title h2::after { background: var(--bjp-orange);}
.portfolio .bg01 .section-title p { color: var(--navy); font-family: 'Playfair Display', serif;}

/* About hero photo (right side on home) */
.about-hero-img{
    position:relative; height:100%; min-height:340px;
}
.about-hero-img .photo{
    width:100%; height:100%; min-height:340px;
    background-size:cover; background-position:center;
    border-radius: 24px 60px 24px 60px;
    box-shadow: 0 20px 50px rgba(140,52,0,.35);
    border: 8px solid #fff;
    transform: rotate(-1deg);
    transition: transform .5s;
}
.about-hero-img:hover .photo{transform: rotate(0);}
.about-hero-img::before{
    content:""; position:absolute;
    width: 80%; height: 80%; top: 20px; left: 20px;
    border: 4px solid var(--saffron); border-radius: 24px 60px 24px 60px;
    z-index: -1;
}

/*------------------------------------------------------------
# Buttons
------------------------------------------------------------*/
.btn-learn-more {
    font-family: "Poppins", sans-serif; font-weight: 600;
    font-size: 14px; letter-spacing: 1px;
    display: inline-block; padding: 13px 34px; border-radius: 30px;
    transition: all .35s ease; line-height: 1; color: #fff;
    margin-top: 10px; background: var(--grad-saffron); background-size: 200% 200%;
    border: 0; text-decoration: none;
    box-shadow: 0 10px 22px rgba(237,80,46,.35);
    position: relative; overflow: hidden;
}
.btn-learn-more::before{
    content:""; position:absolute; top:0; left:-100%;
    width:100%; height:100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
    transition: left .6s;
}
.btn-learn-more:hover {
    transform: translateY(-3px); color:#fff;
    box-shadow: 0 14px 28px rgba(237,80,46,.5);
    background-position: 100% 100%;
}
.btn-learn-more:hover::before{ left:100%;}
.portfolio .btn-more { padding: 35px 0 0; text-align: center;}
.portfolio.pressNote .btn-more .btn-learn-more {
    background: #fff; color: var(--brown-dark);
    box-shadow: 0 10px 22px rgba(0,0,0,.25);
}
.portfolio.pressNote .btn-more .btn-learn-more:hover { background: var(--navy); color:#fff;}

/*------------------------------------------------------------
# PressNote section
------------------------------------------------------------*/
.portfolio.pressNote.section-bg {
    background: linear-gradient(135deg, #8c3400 0%, #b94117 50%, #ed502e 100%);
    background-size: 200% 200%; animation: gradMove 16s ease infinite;
    color: #fff; padding: 80px 0;
    position: relative; overflow: hidden;
}
.portfolio.pressNote.section-bg::before{
    content:""; position:absolute; inset:0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><path d='M0 40 L80 40 M40 0 L40 80' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='1'/></svg>");
    background-size: 80px 80px;
}
.portfolio.pressNote > .container { position:relative; z-index:1;}
.portfolio.pressNote .section-title h2 { color: #fff;}
.portfolio.pressNote .section-title h2::after { background: #fff;}
.portfolio.pressNote .section-title p { color: #fff;}
.portfolio.pressNote .section-title { text-align: center;}
.portfolio.pressNote .portfolio-item { margin-bottom: 20px;}
.portfolio.pressNote .portfolio-item .bxshdw {
    aspect-ratio: 3/4; display: flex; align-items: center; justify-content: center;
    background: #fff; color: var(--navy); font-weight: 600;
    font-size: 14px; text-align: center; padding: 26px;
    box-shadow: 5px 5px 18px rgba(0,0,0,.3);
    transition: all .4s ease;
    position: relative; overflow: hidden;
}
.portfolio.pressNote .portfolio-item .bxshdw::before{
    content:""; position:absolute; top:0; left:0; right:0; height:6px;
    background: var(--grad-saffron);
}
.portfolio.pressNote .portfolio-item .bxshdw:hover{
    transform: translateY(-8px) scale(1.02);
    box-shadow: 5px 15px 30px rgba(0,0,0,.45);
}
.opt01 { border-radius: 41px 0;}
.opt02 { border-radius: 0 41px;}

/* ----- Enhanced Press Note cards ----- */
.portfolio.pressNote .press-note-card {
    background: linear-gradient(180deg, #ffffff 0%, #fff7ee 100%);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 10px 26px rgba(0, 0, 0, .35), 0 0 0 1px rgba(255, 255, 255, .04);
    display: flex; flex-direction: column;
    transition: transform .45s cubic-bezier(.2, .9, .3, 1.2), box-shadow .45s ease;
    position: relative;
    height: 100%;
    isolation: isolate;
}
.portfolio.pressNote .press-note-card::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0; height: 5px;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--bjp-orange) 50%, var(--bjp-red) 100%);
    z-index: 4;
}
.portfolio.pressNote .press-note-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 26px 50px rgba(0, 0, 0, .55), 0 0 0 1px rgba(255, 153, 51, .25);
}

.portfolio.pressNote .pn-image {
    height: 170px;
    background-size: cover; background-position: center;
    position: relative;
    overflow: hidden;
}
.portfolio.pressNote .pn-image::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 35%, rgba(0, 0, 0, .65) 100%);
}
.portfolio.pressNote .press-note-card:hover .pn-image { background-size: 110% auto; }
.portfolio.pressNote .pn-image, .portfolio.pressNote .pn-image::after { transition: all .6s ease; }

.portfolio.pressNote .pn-source {
    position: absolute; left: 12px; top: 12px; z-index: 3;
    background: rgba(255, 255, 255, .96);
    color: var(--brown-dark);
    font-size: 10px; font-weight: 800;
    letter-spacing: .8px; text-transform: uppercase;
    padding: 5px 11px;
    border-radius: 30px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .25);
}
.portfolio.pressNote .pn-cat {
    position: absolute; right: 12px; bottom: 12px; z-index: 3;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    color: #fff;
    font-size: 10px; font-weight: 700;
    letter-spacing: .6px;
    padding: 5px 10px;
    border-radius: 30px;
    display: inline-flex; align-items: center; gap: 5px;
    box-shadow: 0 4px 12px rgba(217, 91, 0, .45);
}
.portfolio.pressNote .pn-cat i { font-size: 11px;}

.portfolio.pressNote .pn-body {
    padding: 16px 18px 18px 18px;
    display: flex; flex-direction: column; gap: 8px;
    flex: 1;
}
.portfolio.pressNote .pn-date {
    font-size: 11px; font-weight: 700;
    color: var(--saffron-dark);
    letter-spacing: .6px; text-transform: uppercase;
    display: inline-flex; align-items: center; gap: 6px;
}
.portfolio.pressNote .pn-date i { font-size: 12px;}
.portfolio.pressNote .press-note-card h4 {
    color: var(--navy);
    font-family: 'Playfair Display', serif;
    font-size: 16px; font-weight: 700;
    line-height: 1.3;
    margin: 0;
}
.portfolio.pressNote .press-note-card p {
    color: #444;
    font-size: 13px; line-height: 1.55;
    margin: 0;
}
.portfolio.pressNote .pn-link {
    margin-top: auto;
    align-self: flex-start;
    color: var(--saffron-dark);
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .6px;
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 0;
    position: relative;
}
.portfolio.pressNote .pn-link::after {
    content: ""; position: absolute;
    left: 0; bottom: 2px; height: 2px; width: 100%;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--bjp-red) 100%);
    transform: scaleX(0); transform-origin: left;
    transition: transform .35s ease;
}
.portfolio.pressNote .pn-link:hover::after { transform: scaleX(1);}
.portfolio.pressNote .pn-link i { transition: transform .25s ease;}
.portfolio.pressNote .pn-link:hover i { transform: translateX(4px);}

@media (max-width: 575px) {
    .portfolio.pressNote .pn-image { height: 150px;}
    .portfolio.pressNote .press-note-card h4 { font-size: 15px;}
    .portfolio.pressNote .press-note-card p { font-size: 12.5px;}
}

/*------------------------------------------------------------
# Contact Section
------------------------------------------------------------*/
.contact { padding: 80px 0;}
.contact .info-box {
    color: var(--navy); text-align: center;
    box-shadow: 0 12px 30px rgba(0,0,0,.1);
    padding: 26px 16px 30px; background: #fff;
    border-radius: 12px; height: 100%;
    transition: transform .35s ease, box-shadow .35s;
    border-top: 4px solid var(--saffron-dark);
}
.contact .info-box:hover{transform: translateY(-6px); box-shadow: 0 18px 40px rgba(0,0,0,.18);}
.contact .info-box i {
    font-size: 32px; color: var(--saffron-dark);
    border-radius: 50%; padding: 12px;
    border: 2px dashed #fbdad2;
    display: inline-flex; align-items: center; justify-content: center;
    width: 60px; height: 60px;
    transition: transform .4s ease;
}
.contact .info-box:hover i { transform: rotate(15deg) scale(1.05);}
.contact .info-box h3 {
    font-size: 18px; color: #777; font-weight: 600; margin: 14px 0 8px;
}
.contact .info-box p {
    padding: 0; line-height: 22px; font-size: 13.5px; margin-bottom: 0;
}
.contact .info-box p a { color: inherit; text-decoration: none; transition: color .2s ease; }
.contact .info-box p a:hover { color: var(--saffron-dark); text-decoration: underline; }
.contact .php-email-form {
    box-shadow: 0 12px 30px rgba(0,0,0,.1);
    padding: 44px 36px; background: #fff;
    border-radius: 12px; height: 100%;
    position: relative; overflow: hidden;
}
.contact .php-email-form::before{
    content:""; position:absolute; top:0; left:0; right:0; height:6px;
    background: var(--grad-saffron);
}
.contact .php-email-form .form-control {
    border-radius: 8px; box-shadow: none; font-size: 14.5px;
    padding: 12px 16px; border: 1px solid #e3e3e3; width: 100%;
    transition: border-color .3s, box-shadow .3s;
}
.contact .php-email-form .form-control:focus {
    border-color: var(--saffron-dark); outline: none;
    box-shadow: 0 0 0 3px rgba(237,80,46,.15);
}
.contact .php-email-form button[type=submit] {
    background: var(--grad-saffron); background-size:200% 200%;
    border: 0; padding: 13px 38px; border-radius: 30px;
    color: #fff; transition: all .4s; font-weight: 600;
    letter-spacing: .5px; cursor: pointer;
    box-shadow: 0 10px 22px rgba(237,80,46,.35);
}
.contact .php-email-form button[type=submit]:hover {
    transform: translateY(-3px); background-position: 100% 100%;
    box-shadow: 0 14px 28px rgba(237,80,46,.5);
}
.contact .section-title h2 { color: var(--saffron-dark);}
.contact .section-title h2::after { background: var(--saffron-dark);}
.contact .section-title p { color: var(--navy); font-family:'Playfair Display',serif;}

/*------------------------------------------------------------
# Footer
------------------------------------------------------------*/
#footer {
    background: linear-gradient(180deg, #8c3400 0%, #5a1f00 100%);
    padding: 0 0 30px; color: #fff; font-size: 14px;
    position: relative; overflow: hidden;
}
#footer::before{
    content:""; position:absolute; inset:0; pointer-events:none;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='100' height='100'><g fill='%23ffffff' fill-opacity='0.03'><circle cx='50' cy='50' r='30'/></g></svg>");
}
#footer.inner-footer { margin-top: 50px;}
#footer .footer-top { padding: 65px 0 22px; position:relative; z-index:1;}
#footer .footer-top .footer-info {
    min-height: 380px; margin-bottom: 15px;
    background: #4a1900;
    border-top: 4px solid var(--saffron-dark);
    border-radius: 8px;
    text-align: center; padding: 30px 22px;
    box-shadow: 0 10px 25px rgba(0,0,0,.25);
    transition: transform .3s;
}
#footer .footer-top .footer-info:hover{ transform: translateY(-4px);}
#footer .footer-top .footer-info h3 {
    font-size: 22px; margin: 0 0 16px; padding-bottom:10px;
    line-height: 1; font-weight: 600; position:relative;
    display:inline-block;
}
#footer .footer-top .footer-info h3::after{
    content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
    width: 40px; height: 2px; background: var(--saffron);
}

/* ============================================================
   Premium Social Cards — unified Facebook / Instagram / X
============================================================ */
.sm-mock {
    --sm-grad: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    --sm-accent: var(--saffron-dark);
    --sm-btn-grad: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    margin-bottom: 15px;
}
.sm-mock .sm-card {
    display: block;
    background: #fff;
    color: #1c1e21;
    border-radius: 18px;
    padding: 0 22px 22px;
    text-align: center;
    box-shadow: 0 14px 38px rgba(0,0,0,.28), 0 0 0 1px rgba(255,255,255,.06);
    position: relative;
    overflow: hidden;
    text-decoration: none;
    transition: transform .4s cubic-bezier(.2,.8,.2,1), box-shadow .4s ease;
}
.sm-mock .sm-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 28px 55px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.12);
    color: #1c1e21;
}
.sm-mock .sm-cover {
    position: relative;
    height: 90px;
    margin: 0 -22px;
    background: var(--sm-grad);
}
.sm-mock .sm-cover::after {
    content: ""; position: absolute; inset: 0;
    background: repeating-linear-gradient(45deg, rgba(255,255,255,.07) 0 2px, transparent 2px 12px);
    pointer-events: none;
}
.sm-mock .sm-platform {
    position: absolute;
    top: 12px; right: 14px;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,.92);
    color: var(--sm-accent);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 18px;
    box-shadow: 0 6px 14px rgba(0,0,0,.18);
    z-index: 2;
}
.sm-mock .sm-avatar {
    width: 78px; height: 78px;
    border-radius: 50%;
    border: 4px solid #fff;
    background: var(--sm-grad);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Playfair Display', serif;
    font-weight: 800;
    font-size: 26px;
    margin: -42px auto 10px;
    box-shadow: 0 8px 18px rgba(0,0,0,.22);
    position: relative;
    z-index: 2;
}
.sm-mock .sm-name {
    font-family: 'Playfair Display', serif;
    font-size: 18px;
    font-weight: 800;
    color: #1c1e21;
    line-height: 1.2;
}
.sm-mock .sm-handle {
    font-family: 'Montserrat';
    font-size: 11.5px;
    font-weight: 700;
    color: var(--sm-accent);
    letter-spacing: 1px;
    margin-top: 4px;
}
.sm-mock .sm-meta {
    font-size: 12px;
    color: #65676b;
    margin: 6px 0 14px;
}
.sm-mock .sm-stats {
    display: flex;
    justify-content: center;
    gap: 18px;
    padding: 12px 0;
    margin-bottom: 14px;
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee;
}
.sm-mock .sm-stats > div {
    flex: 0 0 auto;
    text-align: center;
}
.sm-mock .sm-stats strong {
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 18px;
    color: var(--sm-accent);
    line-height: 1;
}
.sm-mock .sm-stats span {
    font-family: 'Montserrat';
    font-size: 9.5px;
    font-weight: 700;
    color: #999;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    margin-top: 4px;
    display: block;
}
/* 3-stat row (Instagram) — tighter spacing */
.sm-mock .sm-stats.sm-stats-3 { gap: 12px; }
.sm-mock .sm-stats.sm-stats-3 strong { font-size: 16px; }
.sm-mock .sm-stats.sm-stats-3 span { font-size: 8.5px; letter-spacing: 1.1px; }
.sm-mock .sm-flag {
    font-size: 14px;
    vertical-align: middle;
    margin-left: 2px;
}
.sm-mock .sm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 11px 16px;
    border-radius: 30px;
    background: var(--sm-btn-grad);
    color: #fff;
    font-family: 'Montserrat';
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    box-shadow: 0 8px 18px rgba(0,0,0,.18);
    transition: gap .25s, transform .25s, box-shadow .25s;
}
.sm-mock .sm-card:hover .sm-btn {
    gap: 12px;
    box-shadow: 0 12px 26px rgba(0,0,0,.28);
}
.sm-mock .sm-btn i { font-size: 14px; line-height: 1; }

/* ---- Brand variants ---- */
.sm-mock.sm-fb {
    --sm-grad: linear-gradient(135deg, #4267B2 0%, #1877f2 100%);
    --sm-accent: #1877f2;
    --sm-btn-grad: linear-gradient(135deg, #1877f2 0%, #0a4ec0 100%);
}
.sm-mock.sm-ig {
    --sm-grad: linear-gradient(135deg, #feda75 0%, #fa7e1e 25%, #d62976 55%, #962fbf 80%, #4f5bd5 100%);
    --sm-accent: #d62976;
    --sm-btn-grad: linear-gradient(135deg, #fa7e1e 0%, #d62976 50%, #962fbf 100%);
}
.sm-mock.sm-x {
    --sm-grad: linear-gradient(135deg, #2a2a2a 0%, #000000 100%);
    --sm-accent: #000000;
    --sm-btn-grad: linear-gradient(135deg, #1a1a1a 0%, #000000 100%);
}
.sm-mock.sm-x .sm-platform { color: #000; }

#footer .social-links { text-align: center; padding-top: 20px; position:relative; z-index:1;}
#footer .social-links a {
    font-size: 20px; display: inline-flex; color: #fff;
    line-height: 1; margin: 5px; border-radius: 50%;
    align-items: center; justify-content: center;
    width: 42px; height: 42px; transition: all .35s ease;
    background: rgba(0,0,0,.4); border: 1px solid rgba(255,255,255,.15);
}
#footer .social-links a:hover {
    color: #fff; background: var(--grad-saffron);
    transform: translateY(-4px) rotate(-6deg);
    box-shadow: 0 10px 22px rgba(237,80,46,.5);
}
#footer .copyright {
    border-top: 1px solid rgba(255,255,255,.12);
    text-align: center; padding-top: 22px; margin-top: 20px;
    font-size: 13px; position:relative; z-index:1;
}
#footer .copyright a { color: var(--saffron);}
#footer .copyright strong { color: var(--saffron);}

/*------------------------------------------------------------
# Inner Page Header (Banner)
------------------------------------------------------------*/
.header.inner-header {
    position: relative; padding: 110px 0 130px;
    text-align: center; color: #fff; overflow: hidden;
    background:
        linear-gradient(135deg, rgba(248,151,29,.85) 0%, rgba(237,80,46,.92) 50%, rgba(140,52,0,.92) 100%),
        url('../images/lib-rally-flags.jpg');
    background-size: cover; background-position: center;
    background-attachment: fixed;
}
.header.inner-header::before{
    content:""; position:absolute; inset:0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40'><path d='M0 20 L40 20 M20 0 L20 40' stroke='%23ffffff' stroke-opacity='0.07' stroke-width='1'/></svg>");
    background-size: 40px 40px;
}
.header.inner-header::after{
    content:""; position:absolute; left:0; right:0; bottom:-1px; height:60px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'><path d='M0 60 L0 30 Q 300 0 600 30 T 1200 30 L 1200 60 Z' fill='%23fffaf2'/></svg>") no-repeat;
    background-size: 100% 100%;
}
.header.inner-header .pgtitle { position: relative; z-index: 2; animation: fadeUp .9s ease both;}
.header.inner-header h1 {
    font-family: 'Playfair Display', serif; font-weight: 800;
    font-size: 50px; margin: 0 0 12px; color: #fff;
    text-shadow: 2px 4px 12px rgba(0,0,0,.4);
    letter-spacing: .5px;
}
.header.inner-header .breadcrumb-mini {
    display:inline-block; background: rgba(255,255,255,.18); backdrop-filter: blur(6px);
    color: #fff; padding: 6px 18px; border-radius:30px;
    font-size:12px; letter-spacing: 1.5px; text-transform:uppercase;
    margin-bottom: 14px; border:1px solid rgba(255,255,255,.4);
}
.header.inner-header p {
    font-size: 17px; color: rgba(255,255,255,.95);
    margin: 0 auto; max-width: 660px; line-height: 1.5;
}

/*------------------------------------------------------------
# Inner page content cards
------------------------------------------------------------*/
.inner-card {
    background: #fff; border-radius: 14px; overflow: hidden;
    box-shadow: 0 12px 35px rgba(140,52,0,.12); margin-bottom: 38px;
    transition: transform .4s, box-shadow .4s;
    position: relative;
}
.inner-card::before{
    content:""; position:absolute; top:0; left:0; bottom:0; width:5px;
    background: var(--grad-saffron); z-index:1;
}
.inner-card:hover{ transform: translateY(-4px); box-shadow: 0 18px 45px rgba(140,52,0,.2);}
.inner-card .row { align-items: stretch;}
.inner-card .img-side {
    background: linear-gradient(135deg, var(--saffron), var(--bjp-orange));
    min-height: 280px; background-size: cover; background-position: center;
    position: relative; overflow: hidden;
}
.inner-card .img-side::after{
    content:""; position:absolute; inset:0;
    background: linear-gradient(135deg, rgba(237,80,46,.25) 0%, transparent 60%);
}
.inner-card .text-side { padding: 32px 36px;}
.inner-card h3 {
    font-size: 24px; color: var(--saffron-dark); font-weight: 700; margin-bottom: 12px;
    font-family: 'Playfair Display', serif;
}
.inner-card h3 small {
    display: block; font-family: 'Satisfy', cursive;
    font-size: 16px; color: var(--bjp-orange);
    font-weight: 400; margin-bottom: 6px;
}
.inner-card p { font-size: 15px; line-height: 26px; color: #444; margin-bottom: 12px;}
.inner-card ul { padding-left: 20px; font-size: 14.5px; line-height: 28px;}
.inner-card ul li::marker { color: var(--saffron-dark);}

.inner-heading { text-align: center; padding: 30px 0 24px;}
.inner-heading h2 {
    color: var(--saffron-dark); font-size: 32px; font-weight: 700;
    margin: 0; font-family: 'Playfair Display', serif;
    position: relative; display:inline-block; padding-bottom:12px;
}
.inner-heading h2::after{
    content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
    width: 80px; height: 3px; background: var(--saffron); border-radius:3px;
}
.inner-heading h2 small {
    display: block; font-family: 'Satisfy', cursive;
    font-size: 18px; color: var(--bjp-orange);
    font-weight: 400; margin-bottom: 8px;
}

/* Page-level intro paragraph */
.page-intro {
    background: linear-gradient(135deg, #fffaf2 0%, #fff5e2 100%);
    padding: 32px 36px; border-radius: 14px;
    box-shadow: 0 8px 22px rgba(140,52,0,.1);
    margin-bottom: 36px; font-size: 15px; line-height: 27px;
    border-left: 5px solid var(--saffron-dark);
    position: relative; overflow: hidden;
}
.page-intro::before{
    content:""; position:absolute; right:-40px; top:-40px;
    width:160px; height:160px; opacity:.07;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 10 C 40 30 30 50 20 60 C 30 70 40 75 50 78 C 60 75 70 70 80 60 C 70 50 60 30 50 10 Z' fill='%23ed502e'/></svg>") no-repeat center;
    background-size:contain;
}

/*------------------------------------------------------------
# Constituency list
------------------------------------------------------------*/
.constituency-list ul {
    list-style: none; padding: 0; margin: 0 0 30px;
    background: #fff; border-radius: 12px; overflow: hidden;
    box-shadow: 0 10px 30px rgba(140,52,0,.1);
}
.constituency-list li {
    padding: 16px 24px; border-bottom: 1px solid #f5e1bb;
    font-size: 14.5px; color: #333;
    display: flex; align-items: flex-start; gap: 12px;
    transition: all .25s ease;
}
.constituency-list li:hover{
    background: linear-gradient(90deg, #fff5e2 0%, transparent 100%);
    padding-left: 32px;
}
.constituency-list li:last-child { border-bottom: 0;}
.constituency-list li::before {
    content: "\F285"; font-family: 'bootstrap-icons';
    color: var(--saffron-dark); font-weight: bold; flex-shrink: 0;
    font-size: 18px; line-height: 1.2;
}

/*------------------------------------------------------------
# Premium Multi-Image Campaign Cards
# 4-image collage header + content body
------------------------------------------------------------*/
.campaign-card {
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 14px 35px rgba(140,52,0,.12);
    height: 100%;
    transition: all .5s cubic-bezier(.2,.8,.2,1);
    position: relative;
    display: flex; flex-direction: column;
}
.campaign-card::before {
    content: ""; position: absolute; inset: 0;
    border-radius: 20px;
    padding: 2px;
    background: linear-gradient(135deg, transparent 0%, var(--saffron) 50%, transparent 100%);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude;
    opacity: 0; transition: opacity .4s;
    pointer-events: none; z-index: 4;
}
.campaign-card:hover {
    transform: translateY(-12px);
    box-shadow: 0 28px 55px rgba(140,52,0,.22);
}
.campaign-card:hover::before { opacity: 1;}

/* Multi-image collage header */
.campaign-card .cc-collage {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 100px 100px;
    gap: 4px;
    height: 204px;
    overflow: hidden;
    position: relative;
    background: var(--saffron);
}
.campaign-card .cc-collage .cc-img-tile {
    overflow: hidden;
    position: relative;
    background-size: cover;
    background-position: center;
    transition: transform .6s ease;
}
.campaign-card .cc-collage .cc-img-tile::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(248,151,29,.15) 0%, rgba(237,80,46,.1) 100%);
    transition: opacity .4s;
    opacity: 0;
}
.campaign-card:hover .cc-collage .cc-img-tile::after { opacity: 1;}
.campaign-card .cc-collage .cc-img-tile:hover { transform: scale(1.08); z-index: 2;}

/* First tile spans full height — large hero image */
.campaign-card .cc-collage .cc-img-tile:first-child {
    grid-row: 1 / 3;
}

/* Floating campaign badge over the collage */
.campaign-card .cc-collage .cc-badge {
    position: absolute;
    top: 12px; left: 12px;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(8px);
    color: var(--saffron-dark);
    padding: 5px 14px;
    font-family: 'Montserrat'; font-size: 9.5px;
    font-weight: 800; letter-spacing: 1.5px;
    text-transform: uppercase;
    border-radius: 20px;
    z-index: 3;
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
    border: 1px solid rgba(248,151,29,.3);
}
.campaign-card .cc-collage .cc-overlay-icon {
    position: absolute;
    bottom: 12px; right: 12px;
    width: 44px; height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 20px;
    box-shadow: 0 6px 16px rgba(237,80,46,.45);
    z-index: 3;
    transition: transform .4s ease;
}
.campaign-card:hover .cc-collage .cc-overlay-icon { transform: rotate(360deg) scale(1.12);}

/* Body section */
.campaign-card .cc-body {
    padding: 22px 24px 26px;
    flex: 1;
    display: flex; flex-direction: column;
}
.campaign-card .cc-body .cc-date {
    font-family: 'Montserrat'; font-size: 10px;
    color: var(--saffron-dark); font-weight: 700;
    letter-spacing: 2px; text-transform: uppercase;
    margin-bottom: 6px;
    display: flex; align-items: center; gap: 6px;
}
.campaign-card .cc-body .cc-date::before {
    content: ""; width: 18px; height: 2px;
    background: var(--saffron-dark);
}
.campaign-card h4 {
    font-size: 19px; color: var(--navy);
    font-weight: 800;
    margin: 0 0 10px;
    font-family: 'Playfair Display', serif;
    line-height: 1.25;
}
.campaign-card p {
    font-size: 13.5px; line-height: 22px;
    color: #555; margin: 0 0 16px;
    flex: 1;
}
.campaign-card .cc-footer {
    display: flex; align-items: center; justify-content: space-between;
    padding-top: 14px;
    border-top: 1px solid #f1e8d8;
}
.campaign-card .cc-link {
    color: var(--saffron-dark); font-weight: 700;
    font-size: 12.5px; letter-spacing: .5px;
    display: inline-flex; align-items: center; gap: 6px;
    transition: gap .25s;
}
.campaign-card .cc-link:hover { gap: 10px; color: var(--brown-dark);}
.campaign-card .cc-meta {
    color: #999; font-size: 11px;
    display: inline-flex; align-items: center; gap: 4px;
}

/*------------------------------------------------------------
# Premium Press / Media Cards (multi-image)
------------------------------------------------------------*/
.press-card {
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(140,52,0,.1);
    margin-bottom: 26px;
    transition: all .45s cubic-bezier(.2,.8,.2,1);
    position: relative;
    display: flex; flex-direction: column;
}
.press-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 22px 45px rgba(140,52,0,.2);
}
/* Mini gallery strip at top */
.press-card .pc-gallery {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: 80px 80px;
    gap: 3px;
    background: var(--saffron);
    height: 160px;
    position: relative;
}
.press-card .pc-gallery .pc-tile {
    background-size: cover; background-position: center;
    overflow: hidden; position: relative;
    transition: transform .5s;
}
.press-card .pc-gallery .pc-tile:first-child {
    grid-row: 1 / 3;
}
.press-card .pc-gallery .pc-tile::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, transparent, rgba(237,80,46,.15));
    opacity: 0; transition: opacity .3s;
}
.press-card:hover .pc-gallery .pc-tile::after { opacity: 1;}
.press-card:hover .pc-gallery .pc-tile:first-child { transform: scale(1.05);}
/* Newspaper / source badge */
.press-card .pc-source {
    position: absolute;
    top: 12px; right: 12px;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(8px);
    color: var(--brown-dark);
    padding: 4px 12px;
    font-family: 'Playfair Display', serif; font-size: 11px;
    font-weight: 700;
    border-radius: 4px;
    z-index: 2;
    box-shadow: 0 4px 10px rgba(0,0,0,.15);
    border-left: 3px solid var(--saffron-dark);
}
.press-card .pc-head {
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    color: #fff; padding: 10px 22px;
    font-weight: 700; font-size: 12px;
    letter-spacing: 1.5px; text-transform: uppercase;
    display: flex; align-items: center; justify-content: space-between;
}
.press-card .pc-head i { font-size: 14px;}
.press-card .pc-body {
    color: #333; font-size: 14px; line-height: 23px;
    padding: 18px 22px;
    flex: 1;
}
.press-card .pc-meta {
    color: #999; font-size: 11.5px;
    border-top: 1px solid #f1e8d8;
    padding: 12px 22px;
    display: flex; align-items: center; justify-content: space-between;
}
.press-card .pc-meta i { color: var(--saffron-dark); margin-right: 4px;}

/*------------------------------------------------------------
# Leader profile blocks
------------------------------------------------------------*/
.leader-block {
    background: #fff; border-radius: 16px; padding: 36px;
    box-shadow: 0 12px 32px rgba(140,52,0,.12); margin-bottom: 38px;
    transition: transform .4s, box-shadow .4s;
    position: relative; overflow: hidden;
}
.leader-block::before{
    content:""; position:absolute; right:-50px; top:-50px;
    width:200px; height:200px; opacity:.06;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><path d='M50 10 L60 40 L90 50 L60 60 L50 90 L40 60 L10 50 L40 40 Z' fill='%23ed502e'/></svg>") no-repeat;
    background-size: contain;
}
.leader-block:hover{transform: translateY(-4px); box-shadow: 0 18px 40px rgba(140,52,0,.18);}
.leader-block .row { align-items: center;}
.leader-photo {
    width: 100%; aspect-ratio: 4/5;
    background: linear-gradient(135deg, var(--saffron), var(--brown-dark));
    border-radius: 14px; background-size: cover; background-position: center;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-weight: 600; font-size: 14px;
    text-align: center; padding: 10px;
    box-shadow: 0 12px 30px rgba(140,52,0,.25);
    border: 6px solid #fff;
    position:relative;
}
.leader-block h3 {
    font-size: 26px; color: var(--saffron-dark); font-weight: 700; margin: 0 0 6px;
    font-family: 'Playfair Display', serif;
}
.leader-block h4 {
    font-family: 'Satisfy', cursive; color: var(--bjp-orange);
    font-size: 18px; margin: 0 0 14px; font-weight: 400;
}
.leader-block p { font-size: 14.5px; line-height: 25px; color: #444;}

/*------------------------------------------------------------
# Section Collage Card — multi-image collage + text side
# (matches Tarun Chugh reference design)
------------------------------------------------------------*/
.section-collage {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    align-items: center;
    margin-bottom: 80px;
    position: relative;
}
.section-collage.reverse { direction: rtl;}
.section-collage.reverse > * { direction: ltr;}

/* The image collage container */
.section-collage .sc-images {
    position: relative;
    padding: 20px;
}
.section-collage .sc-images::before {
    content: ""; position: absolute;
    inset: 0;
    background: linear-gradient(135deg, #fff5e2 0%, #ffeac2 100%);
    border-radius: 8px 60px 8px 60px;
    box-shadow: 0 18px 40px rgba(140,52,0,.12);
    z-index: 0;
}
.section-collage.reverse .sc-images::before {
    border-radius: 60px 8px 60px 8px;
}
/* 4 to 6 images in a creative asymmetric grid */
.section-collage .sc-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(4, 70px);
    gap: 5px;
    position: relative;
    z-index: 1;
}
.section-collage .sc-grid .sc-tile {
    border-radius: 4px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,.15);
    background-size: cover;
    background-position: center 22%;
    transition: transform .4s ease, box-shadow .4s ease, z-index 0s .15s;
    position: relative;
}
.section-collage .sc-grid .sc-tile:hover {
    transform: scale(1.08); z-index: 5;
    box-shadow: 0 12px 25px rgba(0,0,0,.3);
    transition-delay: 0s;
}
/* Asymmetric positions for visual interest */
.section-collage .sc-grid .sc-tile:nth-child(1) { grid-column: 1 / 4; grid-row: 1 / 3;}
.section-collage .sc-grid .sc-tile:nth-child(2) { grid-column: 4 / 7; grid-row: 1 / 3;}
.section-collage .sc-grid .sc-tile:nth-child(3) { grid-column: 1 / 3; grid-row: 3 / 5;}
.section-collage .sc-grid .sc-tile:nth-child(4) { grid-column: 3 / 5; grid-row: 3 / 5;}
.section-collage .sc-grid .sc-tile:nth-child(5) { grid-column: 5 / 7; grid-row: 3 / 5;}
.section-collage .sc-grid .sc-tile:nth-child(6) { grid-column: 1 / 7; grid-row: 5 / 6;}

/* Text side */
.section-collage .sc-text {
    padding: 0 20px;
    position: relative;
}
.section-collage .sc-text .sc-tag {
    display: inline-block;
    font-family: 'Satisfy', cursive;
    font-size: 22px;
    color: var(--saffron-dark);
    margin-bottom: 4px;
    line-height: 1;
}
.section-collage .sc-text h3 {
    font-family: 'Playfair Display', serif;
    font-size: 36px;
    font-weight: 800;
    color: var(--navy);
    margin: 0 0 20px;
    line-height: 1.15;
    position: relative;
    padding-bottom: 16px;
}
.section-collage .sc-text h3::after {
    content: ""; position: absolute;
    left: 0; bottom: 0;
    width: 60px; height: 3px;
    background: linear-gradient(90deg, var(--saffron), var(--saffron-dark));
    border-radius: 3px;
}
.section-collage .sc-text p {
    font-size: 15px;
    line-height: 28px;
    color: #555;
    margin-bottom: 14px;
}
.section-collage .sc-text ul {
    padding: 0; margin: 16px 0 0; list-style: none;
}
.section-collage .sc-text ul li {
    padding: 6px 0 6px 28px;
    position: relative;
    font-size: 14px;
    color: #444;
    line-height: 22px;
}
.section-collage .sc-text ul li::before {
    content: "\F26B"; font-family: 'bootstrap-icons';
    position: absolute; left: 0; top: 6px;
    color: var(--saffron-dark);
    font-size: 16px;
}
.section-collage .sc-text .sc-stat {
    display: inline-flex; align-items: center; gap: 18px;
    margin-top: 22px; padding: 14px 22px;
    background: #fff;
    border-radius: 14px;
    box-shadow: 0 8px 22px rgba(140,52,0,.1);
    border-left: 4px solid var(--saffron-dark);
}
.section-collage .sc-text .sc-stat strong {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    color: var(--saffron-dark);
    font-weight: 800;
    display: block;
    line-height: 1;
}
.section-collage .sc-text .sc-stat span {
    font-size: 11px;
    color: #888;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    display: block;
    margin-top: 2px;
}

@media (max-width: 991px) {
    .section-collage {
        grid-template-columns: 1fr;
        gap: 36px;
        margin-bottom: 60px;
    }
    .section-collage.reverse > .sc-images { order: -1;}
    .section-collage .sc-text h3 { font-size: 28px;}
    .section-collage .sc-grid { grid-template-rows: repeat(4, 60px);}
}
@media (max-width: 575px) {
    .section-collage .sc-grid { grid-template-rows: repeat(4, 50px);}
    .section-collage .sc-text h3 { font-size: 24px;}
}

/*------------------------------------------------------------
# State Image Grid (bento layout for state sections - legacy)
------------------------------------------------------------*/
.state-section {
    position: relative;
    padding: 30px 0 50px;
}
.state-section + .state-section { border-top: 1px dashed rgba(237,80,46,.2);}
.state-header {
    display:flex; align-items:center; gap: 18px;
    margin-bottom: 28px;
}
.state-header .state-flag {
    width: 60px; height: 60px; border-radius: 50%;
    display:flex; align-items:center; justify-content:center;
    background: var(--grad-saffron); color:#fff;
    font-size: 28px; box-shadow: 0 10px 22px rgba(237,80,46,.35);
    flex-shrink: 0;
}
.state-header .state-info { flex: 1;}
.state-header .state-info h3 {
    margin: 0; font-family: 'Playfair Display', serif;
    font-size: 30px; color: var(--saffron-dark); font-weight: 800;
    line-height: 1.15;
}
.state-header .state-info small {
    display:block; font-family: 'Satisfy', cursive;
    font-size: 16px; color: var(--bjp-orange); margin-bottom: 4px;
}
.state-header .state-info p {
    margin: 4px 0 0; font-size: 13px; color: #777;
    text-transform: uppercase; letter-spacing: 1.5px;
}

/* Bento grid: 4 columns × 2 rows */
.state-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: 180px 180px;
    gap: 14px;
    margin-bottom: 22px;
}
.state-grid .sg-item {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    background: linear-gradient(135deg, var(--saffron), var(--brown-dark));
    box-shadow: 0 10px 28px rgba(140,52,0,.15);
    transition: transform .4s, box-shadow .4s, filter .4s;
}
.state-grid .sg-item img {
    width: 100%; height: 100%; object-fit: cover;
    display: block; transition: transform .6s ease;
}
.state-grid .sg-item .sg-cap {
    position: absolute; left: 0; right: 0; bottom: 0;
    background: linear-gradient(0deg, rgba(0,0,0,.75) 0%, transparent 100%);
    color: #fff; padding: 22px 16px 12px;
    font-size: 13px; font-weight: 600;
    transform: translateY(15px); opacity: 0;
    transition: transform .35s, opacity .35s;
}
.state-grid .sg-item:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: 0 18px 38px rgba(140,52,0,.3);
    z-index: 2;
}
.state-grid .sg-item:hover img { transform: scale(1.1);}
.state-grid .sg-item:hover .sg-cap { transform: translateY(0); opacity: 1;}
.state-grid .sg-item::after{
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(248,151,29,0) 0%, rgba(237,80,46,.2) 100%);
    opacity: 0; transition: opacity .3s;
    pointer-events: none;
}
.state-grid .sg-item:hover::after{ opacity: 1;}

/* Bento layout positions: 1 large + 1 wide + 3 small + 1 tall */
.state-grid .sg-item:nth-child(1) { grid-column: span 2; grid-row: span 2;}
.state-grid .sg-item:nth-child(2) { grid-column: span 2; grid-row: span 1;}
.state-grid .sg-item:nth-child(3) { grid-column: span 1; grid-row: span 1;}
.state-grid .sg-item:nth-child(4) { grid-column: span 1; grid-row: span 1;}

/* Variant: reversed bento */
.state-grid.rev .sg-item:nth-child(1) { grid-column: span 1; grid-row: span 1;}
.state-grid.rev .sg-item:nth-child(2) { grid-column: span 1; grid-row: span 1;}
.state-grid.rev .sg-item:nth-child(3) { grid-column: span 2; grid-row: span 1;}
.state-grid.rev .sg-item:nth-child(4) { grid-column: span 2; grid-row: span 2;}

.state-description {
    background: #fff;
    padding: 26px 30px;
    border-radius: 14px;
    box-shadow: 0 8px 22px rgba(140,52,0,.08);
    border-left: 5px solid var(--saffron-dark);
    font-size: 14.5px; line-height: 26px; color: #444;
    margin-bottom: 10px;
}
.state-description p { margin: 0 0 10px;}
.state-description p:last-child { margin: 0;}

@media (max-width: 991px){
    .state-grid { grid-template-columns: repeat(2, 1fr); grid-template-rows: auto;}
    .state-grid .sg-item,
    .state-grid.rev .sg-item { grid-column: span 1 !important; grid-row: span 1 !important;}
    .state-grid .sg-item:nth-child(1) { grid-column: span 2 !important;}
}
@media (max-width: 575px){
    .state-grid { grid-template-columns: 1fr;}
    .state-grid .sg-item,
    .state-grid .sg-item:nth-child(1),
    .state-grid.rev .sg-item { grid-column: span 1 !important;}
}

/*------------------------------------------------------------
# Leader Hub Cards (my-leaders.html grid)
------------------------------------------------------------*/
.leader-hub-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px;
}
.leader-card-hub {
    position: relative;
    background: #fff; border-radius: 18px; overflow: hidden;
    box-shadow: 0 14px 36px rgba(140,52,0,.12);
    transition: transform .45s cubic-bezier(.2,.8,.2,1), box-shadow .45s;
    text-decoration: none;
    color: inherit;
    display: block;
}
.leader-card-hub::before{
    content:""; position:absolute; top:0; left:0; right:0; height:5px;
    background: var(--grad-saffron);
    transform: scaleX(0); transform-origin: left;
    transition: transform .4s ease;
    z-index: 3;
}
.leader-card-hub:hover { transform: translateY(-12px); box-shadow: 0 26px 50px rgba(140,52,0,.25);}
.leader-card-hub:hover::before { transform: scaleX(1);}
.leader-card-hub .lch-photo {
    height: 320px;
    background-size: cover; background-position: center top;
    position: relative;
    background-color: var(--saffron);
}
.leader-card-hub .lch-photo::after{
    content:""; position:absolute; inset:0;
    background: linear-gradient(0deg, rgba(255,255,255,.95) 0%, transparent 50%);
}
.leader-card-hub .lch-badge {
    position: absolute; top: 16px; left: 16px;
    background: rgba(255,255,255,.95); color: var(--saffron-dark);
    padding: 5px 14px; border-radius: 30px;
    font-size: 11px; font-weight: 700; letter-spacing: 1.5px;
    text-transform: uppercase; backdrop-filter: blur(4px);
    z-index: 2;
}
.leader-card-hub .lch-body {
    padding: 0 26px 26px;
    margin-top: -50px; position: relative; z-index: 2;
}
.leader-card-hub .lch-body small {
    font-family: 'Satisfy', cursive;
    color: var(--bjp-orange); font-size: 16px;
    display:block; margin-bottom: 2px;
}
.leader-card-hub h3 {
    font-family: 'Playfair Display', serif;
    font-size: 22px; color: var(--saffron-dark);
    font-weight: 800; margin: 0 0 10px;
}
.leader-card-hub p {
    font-size: 14px; line-height: 22px; color: #555;
    margin: 0 0 16px;
}
.leader-card-hub .lch-link {
    display: inline-flex; align-items: center; gap: 6px;
    color: var(--saffron-dark); font-weight: 600; font-size: 13px;
    letter-spacing: .5px;
    transition: gap .25s, color .25s;
}
.leader-card-hub:hover .lch-link { gap: 12px; color: var(--brown-dark);}

@media (max-width: 991px){ .leader-hub-grid { grid-template-columns: repeat(2, 1fr);}}
@media (max-width: 575px){ .leader-hub-grid { grid-template-columns: 1fr;}}

/*------------------------------------------------------------
# Achievements List (leader detail pages)
------------------------------------------------------------*/
.achievements-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px;
    margin-bottom: 36px;
}
.achievement-card {
    background: #fff; padding: 24px 26px;
    border-radius: 14px; box-shadow: 0 10px 24px rgba(140,52,0,.08);
    border-left: 4px solid var(--saffron-dark);
    transition: transform .35s, box-shadow .35s;
    position: relative;
}
.achievement-card:hover{ transform: translateY(-4px); box-shadow: 0 16px 32px rgba(140,52,0,.15);}
.achievement-card .ach-icon {
    width: 48px; height: 48px; border-radius: 14px;
    background: var(--grad-saffron);
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size: 22px; margin-bottom: 12px;
    box-shadow: 0 6px 14px rgba(237,80,46,.3);
}
.achievement-card h4 {
    font-family: 'Playfair Display', serif;
    font-size: 17px; color: var(--navy);
    font-weight: 700; margin: 0 0 8px;
}
.achievement-card p {
    font-size: 13.5px; line-height: 22px; color: #555; margin: 0;
}

.quote-block {
    background: linear-gradient(135deg, var(--brown-dark) 0%, var(--saffron-dark) 100%);
    color: #fff; padding: 40px 50px;
    border-radius: 18px; margin: 30px 0;
    position: relative; overflow: hidden;
    box-shadow: 0 18px 40px rgba(140,52,0,.3);
}
.quote-block::before{
    content: "\201C"; position: absolute; top: -30px; left: 16px;
    font-family: 'Playfair Display', serif; font-size: 160px;
    color: rgba(255,255,255,.18); line-height: 1;
}
.quote-block p {
    font-family: 'Playfair Display', serif;
    font-size: 20px; line-height: 1.6; font-style: italic;
    margin: 0 0 14px; position: relative; z-index: 2;
}
.quote-block .qb-author {
    display: block; font-family: 'Satisfy', cursive;
    font-size: 18px; opacity: .95; position: relative; z-index: 2;
}

@media (max-width:991px){ .achievements-grid { grid-template-columns: 1fr;}}

/*------------------------------------------------------------
# Leader detail hero
------------------------------------------------------------*/
.leader-hero {
    background: linear-gradient(135deg, rgba(248,151,29,.92) 0%, rgba(140,52,0,.95) 100%);
    padding: 80px 0; color: #fff; position: relative; overflow: hidden;
    margin-top: 0;
}
.leader-hero::before{
    content:""; position:absolute; inset:0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><circle cx='40' cy='40' r='30' fill='none' stroke='%23ffffff' stroke-opacity='0.08'/></svg>");
}
.leader-hero > .container { position: relative; z-index: 2;}
.leader-hero .lh-photo {
    width: 100%; aspect-ratio: 1/1.2;
    background: #fff; border-radius: 20px;
    background-size: cover; background-position: center top;
    box-shadow: 0 24px 50px rgba(0,0,0,.3);
    border: 6px solid #fff;
}
.leader-hero h1 {
    font-family: 'Playfair Display', serif;
    font-size: 46px; font-weight: 800; margin: 0 0 12px;
    text-shadow: 0 4px 12px rgba(0,0,0,.3);
}
.leader-hero h1 small {
    display: block; font-family: 'Satisfy', cursive;
    font-size: 22px; font-weight: 400; opacity: .9; margin-bottom: 4px;
}
.leader-hero .lh-role {
    display: inline-block; background: rgba(255,255,255,.2);
    backdrop-filter: blur(4px); border: 1px solid rgba(255,255,255,.4);
    padding: 6px 18px; border-radius: 30px;
    font-size: 12px; letter-spacing: 1.5px; text-transform: uppercase;
    margin-bottom: 18px;
}
.leader-hero p {
    font-size: 16px; line-height: 1.7;
    color: rgba(255,255,255,.95); margin-bottom: 20px;
}
.leader-hero .lh-stats {
    display: flex; gap: 28px; margin-top: 28px; flex-wrap: wrap;
}
.leader-hero .lh-stats .stat {
    background: rgba(255,255,255,.12); backdrop-filter: blur(6px);
    border: 1px solid rgba(255,255,255,.25);
    border-radius: 12px; padding: 14px 22px;
    min-width: 140px;
}
.leader-hero .lh-stats .stat strong {
    display:block; font-family: 'Playfair Display', serif;
    font-size: 28px; font-weight: 800;
}
.leader-hero .lh-stats .stat span {
    font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
    opacity: .85;
}

@media (max-width: 991px){
    .leader-hero { padding: 60px 0;}
    .leader-hero h1 { font-size: 32px;}
    .leader-hero .lh-photo { margin-bottom: 28px; max-width: 320px;}
}

/*------------------------------------------------------------
# Mobile logo
------------------------------------------------------------*/
@media (max-width: 991px) {
    /* Make room for hamburger button */
    #header .logo a { gap: 10px;}
    #header .logo .lotus-mark { width: 62px; height: 62px;}
    #header .logo .logo-text h2 { font-size: 14px; padding-bottom: 4px;}
    #header .logo .logo-text small { font-size: 7px; letter-spacing: 1.5px; margin-top: 3px;}
    #header .logo .lotus-mark .verified-badge { width: 22px; height: 22px; right: -3px; bottom: -3px;}
}
@media (max-width: 480px) {
    #header .logo a { gap: 8px;}
    #header .logo .lotus-mark { width: 54px; height: 54px;}
    #header .logo .logo-text h2 { font-size: 13px;}
    #header .logo .logo-text small { display: none;}
    #header .logo .lotus-mark .verified-badge { width: 20px; height: 20px;}
}

/*------------------------------------------------------------
# Premium Join BJP Modal Form
------------------------------------------------------------*/
.join-modal-overlay {
    position: fixed; inset: 0;
    background: rgba(11, 35, 65, .72);
    backdrop-filter: blur(8px);
    z-index: 9990;
    opacity: 0; visibility: hidden;
    transition: opacity .35s ease, visibility .35s ease;
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
    overflow-y: auto;
}
.join-modal-overlay.show {
    opacity: 1; visibility: visible;
}
.join-modal {
    background: #fff;
    border-radius: 20px;
    width: 100%;
    max-width: 620px;
    overflow: hidden;
    box-shadow:
        0 30px 80px rgba(0,0,0,.4),
        0 0 0 1px rgba(248,151,29,.2);
    transform: translateY(40px) scale(.96);
    transition: transform .45s cubic-bezier(.2,.8,.2,1);
    position: relative;
}
.join-modal-overlay.show .join-modal {
    transform: translateY(0) scale(1);
}

/* Hero header with saffron gradient — compact */
.join-modal .jm-header {
    background:
        linear-gradient(135deg, rgba(248,151,29,.95) 0%, rgba(237,80,46,.95) 60%, rgba(140,52,0,.95) 100%),
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='80' height='80'><circle cx='40' cy='40' r='30' fill='none' stroke='%23ffffff' stroke-opacity='0.08' stroke-width='1'/></svg>");
    color: #fff;
    padding: 22px 28px 48px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.join-modal .jm-header::after {
    content: ""; position: absolute;
    left: 0; right: 0; bottom: -1px; height: 36px;
    background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 60' preserveAspectRatio='none'><path d='M0 60 L0 30 Q 300 0 600 30 T 1200 30 L 1200 60 Z' fill='%23ffffff'/></svg>") no-repeat;
    background-size: 100% 100%;
}
.join-modal .jm-close {
    position: absolute;
    top: 16px; right: 16px;
    width: 36px; height: 36px;
    background: rgba(255,255,255,.18);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px;
    transition: all .3s ease;
    z-index: 5;
}
.join-modal .jm-close:hover {
    background: rgba(255,255,255,.3);
    transform: rotate(90deg);
}
.join-modal .jm-lotus {
    width: 64px; height: 64px;
    margin: 0 auto 12px;
    background: #fff;
    border-radius: 50%;
    padding: 6px;
    border: 3px solid rgba(255,255,255,.6);
    box-shadow: 0 6px 18px rgba(0,0,0,.25);
    animation: float-y 3s ease-in-out infinite;
}
.join-modal .jm-lotus img {
    width: 100%; height: 100%;
    object-fit: contain;
    filter: none;
}
.join-modal .jm-header h2 {
    font-family: 'Playfair Display', serif;
    font-size: 24px; font-weight: 800;
    margin: 0 0 4px;
    text-shadow: 0 3px 10px rgba(0,0,0,.3);
    line-height: 1.15;
}
.join-modal .jm-header p {
    font-size: 12.5px; opacity: .95;
    margin: 0;
    max-width: 420px;
    margin-inline: auto;
    line-height: 1.4;
}
.join-modal .jm-tag {
    display: inline-block;
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.4);
    backdrop-filter: blur(4px);
    padding: 3px 12px;
    border-radius: 30px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 10px;
}

/* Form body — compact */
.join-modal .jm-body {
    padding: 0 28px 18px;
}
.join-modal .jm-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-top: 0;
}
.join-modal .jm-field { position: relative;}
.join-modal .jm-field.full { grid-column: 1 / -1;}
.join-modal .jm-field label {
    display: block;
    font-family: 'Poppins', sans-serif;
    font-size: 10px;
    font-weight: 700;
    color: var(--brown-dark);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 4px;
}
.join-modal .jm-field label .req-star {
    color: #df1529;
    margin-left: 2px;
}
.join-modal .jm-field label i {
    color: var(--saffron-dark);
    margin-right: 3px;
    font-size: 12px;
}
.join-modal .jm-field input,
.join-modal .jm-field select,
.join-modal .jm-field textarea {
    width: 100%;
    padding: 9px 12px;
    border: 1.5px solid #eee5cf;
    border-radius: 8px;
    font-size: 13.5px;
    font-family: 'Poppins', sans-serif;
    color: var(--navy);
    background: #fffaf2;
    transition: all .3s ease;
    outline: none;
}
.join-modal .jm-field input:focus,
.join-modal .jm-field select:focus,
.join-modal .jm-field textarea:focus {
    border-color: var(--saffron-dark);
    background: #fff;
    box-shadow: 0 0 0 4px rgba(237,80,46,.12);
}
.join-modal .jm-field textarea {
    resize: vertical;
    min-height: 50px;
}
.join-modal .jm-checks {
    margin-top: 10px;
    background: #fffaf2;
    padding: 10px 12px;
    border-radius: 8px;
    border: 1px solid #f1e1c1;
}
.join-modal .jm-check {
    display: flex; align-items: flex-start; gap: 8px;
    font-size: 11.5px; color: #444; line-height: 1.4;
    cursor: pointer;
}
.join-modal .jm-check + .jm-check { margin-top: 6px;}
.join-modal .jm-check input {
    width: 14px; height: 14px; flex-shrink: 0;
    accent-color: var(--saffron-dark);
    margin-top: 2px;
}

/* Footer with submit */
.join-modal .jm-footer {
    padding: 12px 28px 18px;
    background: linear-gradient(180deg, #fffaf2 0%, #fff5e2 100%);
    border-top: 1px solid #f1e1c1;
    display: flex; align-items: center; justify-content: space-between;
    gap: 14px;
    flex-wrap: wrap;
}
.join-modal .jm-note {
    font-size: 10.5px;
    color: var(--brown-dark);
    flex: 1;
    line-height: 1.4;
    margin: 0;
}
.join-modal .jm-note i { color: var(--saffron-dark); margin-right: 3px;}
.join-modal .jm-submit {
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    color: #fff;
    border: 0;
    padding: 10px 24px;
    border-radius: 26px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 13px;
    letter-spacing: .5px;
    cursor: pointer;
    box-shadow: 0 6px 18px rgba(237,80,46,.4);
    transition: all .35s ease;
    display: inline-flex; align-items: center; gap: 6px;
    white-space: nowrap;
    position: relative;
    overflow: hidden;
}
.join-modal .jm-submit::before {
    content: ""; position: absolute; inset: 0; left: -100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.4), transparent);
    transition: left .6s;
}
.join-modal .jm-submit:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 28px rgba(237,80,46,.55);
}
.join-modal .jm-submit:hover::before { left: 100%;}

/* Success state */
.join-modal.success .jm-body,
.join-modal.success .jm-footer { display: none;}
.join-modal .jm-success {
    display: none;
    padding: 50px 40px;
    text-align: center;
}
.join-modal.success .jm-success { display: block; animation: fadeInScale .5s ease both;}
.join-modal .jm-success-icon {
    width: 80px; height: 80px;
    margin: 0 auto 20px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--bjp-green) 0%, #007a3d 100%);
    display: flex; align-items: center; justify-content: center;
    color: #fff;
    font-size: 38px;
    box-shadow: 0 12px 28px rgba(0,153,97,.4);
    animation: glowSaffron 2s ease infinite;
}
.join-modal .jm-success h3 {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    color: var(--saffron-dark);
    margin: 0 0 10px;
    font-weight: 800;
}
.join-modal .jm-success p {
    font-size: 15px;
    color: #555;
    line-height: 1.6;
    max-width: 400px;
    margin: 0 auto;
}

@media (max-width: 575px) {
    .join-modal { border-radius: 18px;}
    .join-modal .jm-header { padding: 30px 22px 60px;}
    .join-modal .jm-header h2 { font-size: 22px;}
    .join-modal .jm-body { padding: 0 22px 22px;}
    .join-modal .jm-grid { grid-template-columns: 1fr; gap: 14px;}
    .join-modal .jm-footer { padding: 18px 22px 22px;}
    .join-modal .jm-submit { width: 100%; justify-content: center;}
}

/*------------------------------------------------------------
# Utilities
------------------------------------------------------------*/
.container { max-width: 1200px;}
.bg-cream { background: var(--cream);}
.bg-texture-light{ background:
    linear-gradient(135deg, #fffaf2 0%, #fff5e2 100%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60'><circle cx='30' cy='30' r='1' fill='%23ed502e' fill-opacity='0.15'/></svg>");
}

/*------------------------------------------------------------
# Comprehensive Responsive — All devices
------------------------------------------------------------*/

/* TABLETS & SMALL LAPTOPS */
@media (max-width: 991px) {
    .icon-boxes-wrap.r-r .icon-box.colorbx01,
    .icon-boxes-wrap.r-r .icon-box.colorbx04 { border-radius: 0;}
    .portfolio .bg01 { padding: 60px 0 100px;}
    #icon-boxes01.icon-boxes { margin-top: -60px;}
    #icon-boxes01 .icon-boxes-wrap.portfolio { grid-template-columns: 1fr 1fr;}
    .testimonials .hero-img img { margin-bottom: 20px;}
    .leader-photo { aspect-ratio: 1/1; margin-bottom: 18px;}
    .header.inner-header { padding: 70px 0 90px;}
    .header.inner-header h1 { font-size: 34px;}
    .about-hero-img { display: none;}
    section { padding: 70px 0;}
    .inner-content { padding: 60px 0 70px;}
    #hero h2 { font-size: 28px; max-width: 100%;}
    #hero .carousel-container { inset: 70px 30px 40px 30px;}
    .icon-boxes .icon-box .icon span { min-height: 140px;}
    .icon-boxes .icon-box .ib-strip { height: 60px;}
    .testimonials { padding: 50px 0 60px;}
    .testimonials .section-title-cmpgn h2 { font-size: 22px;}
    /* About hero section */
    .portfolio .bg01 .contact-wrap { padding: 0;}
    /* PressNote stack better */
    .portfolio.pressNote .portfolio-item .bxshdw { font-size: 13px; padding: 18px;}
}

/* TABLETS */
@media (max-width: 767px) {
    section { padding: 55px 0;}
    .inner-content { padding: 50px 0 60px;}
    .header.inner-header { padding: 55px 0 80px;}
    .header.inner-header h1 { font-size: 28px;}
    .header.inner-header p { font-size: 14px;}
    .header.inner-header .breadcrumb-mini { font-size: 10px; padding: 5px 14px;}
    /* Cards full-width */
    .icon-boxes .icon-box { min-height: auto !important;}
    /* Hero — tablet */
    #hero { height: 440px;}
    #hero h2 { font-size: 26px; line-height: 1.25;}
    #hero .hero-tagline { font-size: 13px; padding: 4px 16px; margin-bottom: 14px;}
    #hero .carousel-container {
        inset: 0;
        text-align: center;
        align-items: center;
        justify-content: center;
        padding: 50px 28px;
    }
    #hero .carousel-container.rtlHdng h2,
    #hero .carousel-container.lftHdng h2 { text-align: center;}
    #hero .carousel-control-next-icon,
    #hero .carousel-control-prev-icon { width: 40px; height: 40px; font-size: 18px;}
    /* Campaign cards full-width */
    .campaign-card .cc-collage { height: 170px; grid-template-rows: 83px 83px;}
    .campaign-card h4 { font-size: 16px;}
    /* Press cards full-width */
    .press-card .pc-gallery { height: 140px;}
    /* State headers */
    .state-header .state-flag { width: 50px; height: 50px; font-size: 22px;}
    .state-header .state-info h3 { font-size: 22px;}
    .state-header .state-info p { font-size: 11px;}
    /* Collage sections */
    .section-collage { margin-bottom: 50px;}
    .section-collage .sc-text h3 { font-size: 24px;}
    .section-collage .sc-text { padding: 0 10px;}
    /* Leader hero */
    .leader-hero { padding: 50px 0;}
    .leader-hero h1 { font-size: 28px;}
    .leader-hero h1 small { font-size: 18px;}
    .leader-hero .lh-photo { max-width: 280px;}
    .leader-hero .lh-stats .stat { min-width: 110px; padding: 10px 16px;}
    .leader-hero .lh-stats .stat strong { font-size: 22px;}
    /* Footer mocks */
    #footer .footer-top .footer-info { min-height: auto; padding: 22px 18px;}
    #footer .footer-top { padding: 45px 0 18px;}
    /* Quote block */
    .quote-block { padding: 30px 26px;}
    .quote-block p { font-size: 16px;}
    .quote-block::before { font-size: 110px; top: -20px;}
    /* Achievement cards */
    .achievements-grid { gap: 16px;}
    .achievement-card { padding: 20px 22px;}
    /* Page intro */
    .page-intro { padding: 22px 22px;}
    /* Section titles */
    .section-title-cmpgn.campaignHome h2 { font-size: 26px;}
    .section-title h2 { font-size: 22px;}
    .section-title p { font-size: 24px;}
    /* Contact info boxes */
    .contact .info-box { padding: 20px 14px 22px;}
    .contact .php-email-form { padding: 30px 22px;}
    /* Inner heading */
    .inner-heading h2 { font-size: 24px;}
    .inner-heading h2 small { font-size: 14px;}
    /* Reduce general spacing in cards */
    .inner-card .text-side { padding: 22px;}
    .inner-card h3 { font-size: 20px;}
    .inner-card p { font-size: 14px; line-height: 24px;}
    /* Marquee */
    .marquee-track p { font-size: 11px; padding-right: 40px;}
    .marquee { height: 36px;}
    .marquee-track p { line-height: 36px;}
    /* Constituency list */
    .constituency-list li { padding: 12px 16px; font-size: 13.5px;}
    .constituency-list li:hover { padding-left: 22px;}
}

/* PHONES */
@media (max-width: 575px) {
    /* Hero — bigger, centered */
    #hero { height: 420px;}
    #hero h2 { font-size: 22px; line-height: 1.25; max-width: 100%;}
    #hero .hero-tagline { font-size: 11px; padding: 4px 14px; margin-bottom: 14px;}
    #hero .carousel-container {
        inset: 0;
        text-align: center;
        align-items: center;
        justify-content: center;
        padding: 40px 22px;
    }
    #hero .carousel-container.rtlHdng h2,
    #hero .carousel-container.lftHdng h2 { text-align: center;}
    #hero .carousel-control-next-icon,
    #hero .carousel-control-prev-icon { width: 36px; height: 36px; font-size: 16px;}
    /* Headers */
    .header.inner-header { padding: 45px 0 70px;}
    .header.inner-header h1 { font-size: 24px;}
    .header.inner-header p { font-size: 13px;}
    /* Section title */
    .section-title h2 { font-size: 20px; letter-spacing: 1.5px;}
    .section-title p { font-size: 22px;}
    .section-title-cmpgn h2 { font-size: 22px;}
    .section-title-cmpgn.campaignHome h2 { font-size: 24px;}
    /* Sections */
    section { padding: 45px 0;}
    .inner-content { padding: 40px 0 50px;}
    .icon-boxes .icon-box { min-height: auto !important;}
    .icon-boxes .icon-box .icon span { min-height: 110px; padding: 18px;}
    .icon-boxes .icon-box .icon span img { max-width: 60px; max-height: 60px;}
    .iconbox-cont { padding: 0 16px 22px;}
    .icon-boxes .title { font-size: 16px;}
    .icon-boxes .description { font-size: 13px; line-height: 19px;}
    #icon-boxes01 .icon-boxes-wrap.portfolio { grid-template-columns: 1fr; gap: 16px;}
    .portfolio .bg01 { padding: 40px 0 50px;}
    /* Campaign cards */
    .campaign-card { border-radius: 14px;}
    .campaign-card .cc-collage { height: 150px; grid-template-rows: 73px 73px;}
    .campaign-card .cc-body { padding: 18px 18px 22px;}
    .campaign-card h4 { font-size: 15px;}
    .campaign-card p { font-size: 13px;}
    .campaign-card .cc-link { font-size: 12px;}
    .campaign-card .cc-meta { font-size: 10px;}
    .campaign-card .cc-collage .cc-badge { font-size: 8px; padding: 4px 11px;}
    .campaign-card .cc-collage .cc-overlay-icon { width: 38px; height: 38px; font-size: 18px;}
    /* Press cards */
    .press-card { border-radius: 14px;}
    .press-card .pc-gallery { height: 120px;}
    .press-card .pc-source { font-size: 10px; padding: 3px 10px;}
    .press-card .pc-head { padding: 9px 18px; font-size: 11px;}
    .press-card .pc-body { padding: 14px 18px; font-size: 13px;}
    .press-card .pc-meta { padding: 10px 18px; font-size: 11px;}
    /* State collage */
    .section-collage .sc-images { padding: 12px;}
    .section-collage .sc-grid { grid-template-rows: repeat(4, 44px);}
    .section-collage .sc-text h3 { font-size: 22px;}
    .section-collage .sc-text p { font-size: 13.5px; line-height: 22px;}
    .section-collage .sc-text .sc-stat { gap: 14px; padding: 12px 16px;}
    .section-collage .sc-text .sc-stat strong { font-size: 22px;}
    /* Leader cards */
    .leader-card-hub .lch-photo { height: 250px;}
    .leader-card-hub h3 { font-size: 19px;}
    /* Leader hero */
    .leader-hero { padding: 40px 0;}
    .leader-hero h1 { font-size: 22px;}
    .leader-hero h1 small { font-size: 16px;}
    .leader-hero .lh-photo { max-width: 230px;}
    .leader-hero p { font-size: 14px; line-height: 1.55;}
    .leader-hero .lh-stats { gap: 12px;}
    .leader-hero .lh-stats .stat { min-width: 100px; padding: 9px 14px;}
    .leader-hero .lh-stats .stat strong { font-size: 19px;}
    .leader-hero .lh-stats .stat span { font-size: 9.5px; letter-spacing: 1px;}
    /* Quote */
    .quote-block { padding: 26px 22px; border-radius: 14px;}
    .quote-block p { font-size: 14.5px; line-height: 1.6;}
    .quote-block .qb-author { font-size: 16px;}
    /* Footer */
    #footer { font-size: 13px;}
    #footer .footer-top { padding: 40px 0 16px;}
    #footer .footer-top .footer-info { min-height: auto; padding: 22px 16px;}
    #footer .footer-top .footer-info h3 { font-size: 19px;}
    .sm-mock .sm-card { padding: 0 18px 18px; border-radius: 16px; }
    .sm-mock .sm-cover { height: 80px; margin: 0 -18px; }
    .sm-mock .sm-avatar { width: 70px; height: 70px; font-size: 22px; margin-top: -38px;}
    .sm-mock .sm-name { font-size: 16px; }
    .sm-mock .sm-stats strong { font-size: 16px; }
    #footer .copyright { font-size: 12px; padding-top: 18px;}
    /* Marquee */
    .marquee-track p { font-size: 10.5px; padding-right: 36px;}
    /* Contact form */
    .contact .info-box { padding: 18px 14px 20px;}
    .contact .info-box h3 { font-size: 16px;}
    .contact .info-box p { font-size: 12.5px;}
    .contact .php-email-form { padding: 26px 18px;}
    .contact .php-email-form .form-control { font-size: 13.5px; padding: 10px 13px;}
    .contact .php-email-form button[type=submit] { width: 100%; padding: 12px;}
    /* Page intro */
    .page-intro { padding: 20px 18px; font-size: 13.5px; line-height: 22px;}
    /* Inner card */
    .inner-card { border-radius: 12px; margin-bottom: 24px;}
    .inner-card .text-side { padding: 20px 18px;}
    .inner-card h3 { font-size: 18px;}
    .inner-card p { font-size: 13.5px; line-height: 22px;}
    .inner-card ul { font-size: 13px; line-height: 24px;}
    .inner-card .img-side { min-height: 200px;}
    /* Achievement cards */
    .achievement-card { padding: 18px 20px;}
    .achievement-card h4 { font-size: 16px;}
    .achievement-card p { font-size: 13px;}
    .achievement-card .ach-icon { width: 42px; height: 42px; font-size: 18px;}
    /* Constituency list */
    .constituency-list ul { border-radius: 10px;}
    .constituency-list li { padding: 12px 14px; font-size: 13px;}
    .constituency-list li::before { font-size: 15px;}
    /* Inner heading */
    .inner-heading h2 { font-size: 21px; padding-bottom: 10px;}
    .inner-heading h2 small { font-size: 13px;}
    /* State header */
    .state-header { gap: 12px; margin-bottom: 20px;}
    .state-header .state-flag { width: 44px; height: 44px; font-size: 19px;}
    .state-header .state-info h3 { font-size: 18px;}
    .state-header .state-info small { font-size: 13px;}
    .state-header .state-info p { font-size: 10px;}
    /* Back to top */
    .back-to-top { width: 40px; height: 40px; right: 12px; bottom: 12px;}
    .back-to-top i { font-size: 20px;}
    /* About-hero on home */
    .about-hero-img { display: none;}
    .portfolio .bg01 .contact-wrap p { font-size: 13.5px; line-height: 22px;}
    /* Modal full screen feel */
    .join-modal-overlay { padding: 0;}
    .join-modal { border-radius: 0; max-height: 100vh; min-height: 100vh;}
    .join-modal .jm-header { padding: 18px 18px 38px;}
    .join-modal .jm-header h2 { font-size: 20px;}
    .join-modal .jm-header p { font-size: 12px;}
    .join-modal .jm-tag { font-size: 8px; padding: 2px 10px; letter-spacing: 1.5px;}
    .join-modal .jm-lotus { width: 52px; height: 52px; margin-bottom: 8px;}
    .join-modal .jm-body { padding: 0 18px 14px;}
    .join-modal .jm-grid { grid-template-columns: 1fr; gap: 10px;}
    .join-modal .jm-field input,
    .join-modal .jm-field select { font-size: 13px; padding: 9px 11px;}
    .join-modal .jm-field label { font-size: 9.5px;}
    .join-modal .jm-footer { padding: 10px 18px 16px; gap: 10px;}
    .join-modal .jm-note { font-size: 10px;}
    .join-modal .jm-submit { width: 100%; justify-content: center; padding: 11px 20px; font-size: 13px;}
}

/*------------------------------------------------------------
# Mobile Horizontal Card Slider
# Add class "mobile-slider" to .row or .grid wrapper
------------------------------------------------------------*/
@media (max-width: 767px) {
    .mobile-slider-wrap {
        margin-left: -12px;
        margin-right: -12px;
        max-width: calc(100% + 24px);
        overflow: hidden;
        position: relative;
    }
    .mobile-slider {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        padding: 0 12px 20px 12px;
        margin: 0;
        scrollbar-width: thin;
        scrollbar-color: var(--saffron) transparent;
        gap: 14px;
        max-width: 100%;
    }
    .mobile-slider::-webkit-scrollbar { height: 6px;}
    .mobile-slider::-webkit-scrollbar-track { background: rgba(248,151,29,.1); border-radius: 10px;}
    .mobile-slider::-webkit-scrollbar-thumb {
        background: linear-gradient(90deg, var(--saffron), var(--saffron-dark));
        border-radius: 10px;
    }
    .mobile-slider > [class*="col-"] {
        flex: 0 0 85%;
        max-width: 85%;
        scroll-snap-align: start;
    }
    /* Override grid display for non-row sliders */
    .achievements-grid.mobile-slider {
        grid-template-columns: none !important;
    }
    .leader-hub-grid.mobile-slider {
        grid-template-columns: none !important;
    }
    .achievements-grid.mobile-slider > * {
        flex: 0 0 82%;
        max-width: 82%;
        scroll-snap-align: start;
    }
    .leader-hub-grid.mobile-slider > * {
        flex: 0 0 82%;
        max-width: 82%;
        scroll-snap-align: start;
    }
    /* Hint scroll for first-time users */
    .mobile-slider-wrap {
        position: relative;
    }
    .mobile-slider-wrap::after {
        content: "← swipe →";
        display: block;
        text-align: center;
        font-size: 11px;
        color: var(--saffron-dark);
        font-weight: 600;
        letter-spacing: 2px;
        text-transform: uppercase;
        margin-top: 4px;
        opacity: .65;
    }
}

/* TINY PHONES */
@media (max-width: 360px) {
    #hero { height: 240px;}
    #hero h2 { font-size: 15px; line-height: 1.25;}
    .section-title p { font-size: 19px;}
    .header.inner-header h1 { font-size: 21px;}
    .leader-hero h1 { font-size: 20px;}
    .section-collage .sc-grid { grid-template-rows: repeat(4, 38px);}
}

/* TOUCH DEVICE TWEAKS — bigger tap targets */
@media (hover: none) and (pointer: coarse) {
    .navbar a { padding: 16px 14px;}
    .btn-learn-more { padding: 14px 30px;}
    .icon-boxes .linkRM { padding: 9px 20px;}
    .campaign-card .cc-link { padding: 6px 0;}
    .back-to-top { width: 48px; height: 48px;}
}

/* =========================================================
   MEDIA LIGHTBOX (images, embedded videos, inline articles)
   ========================================================= */
.media-lightbox-overlay {
    position: fixed;
    inset: 0;
    background: rgba(8, 10, 24, 0.92);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    z-index: 10000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 30px 20px;
    overflow-y: auto;
    animation: lbFadeIn .25s ease both;
}
.media-lightbox-overlay.show { display: flex; }
@keyframes lbFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes lbPop { from { transform: translateY(20px) scale(.96); opacity: 0; } to { transform: translateY(0) scale(1); opacity: 1; } }

.media-lightbox {
    position: relative;
    max-width: 1000px;
    width: 100%;
    background: linear-gradient(155deg, #fff 0%, #fff7ee 100%);
    border-radius: 20px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .55), 0 0 0 1px rgba(255, 255, 255, .08);
    overflow: hidden;
    animation: lbPop .35s cubic-bezier(.2, .9, .3, 1.2) both;
    border: 1px solid rgba(255, 153, 51, .35);
}
.media-lightbox.is-image,
.media-lightbox.is-video {
    background: transparent;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .55);
    border: none;
}
.media-lightbox.is-article {
    max-width: 760px;
}

.ml-close {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, #FF9933, #d95b00);
    color: #fff;
    border: 2px solid #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    cursor: pointer;
    z-index: 5;
    box-shadow: 0 6px 18px rgba(0, 0, 0, .35);
    transition: transform .2s, box-shadow .2s;
}
.ml-close:hover { transform: rotate(90deg) scale(1.06); box-shadow: 0 10px 26px rgba(217, 91, 0, .55); }

/* IMAGE viewer */
.ml-image-stage {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: transparent;
}
.ml-image-stage img {
    max-width: 100%;
    max-height: 86vh;
    width: auto;
    height: auto;
    display: block;
    border-radius: 14px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .5);
}

/* VIDEO viewer */
.ml-video-stage {
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0, 0, 0, .5);
}
.ml-video-stage iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

/* ARTICLE / PODCAST viewer */
.ml-article {
    padding: 0;
    max-height: 90vh;
    overflow-y: auto;
}
.ml-article-cover {
    height: 240px;
    background-size: cover;
    background-position: center;
    position: relative;
}
.ml-article-cover::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 35%, rgba(0, 0, 0, .75) 100%);
}
.ml-article-source {
    position: absolute;
    left: 22px;
    bottom: 18px;
    z-index: 2;
    background: linear-gradient(135deg, #FF9933, #d95b00);
    color: #fff;
    padding: 6px 14px;
    border-radius: 30px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .5px;
    text-transform: uppercase;
    box-shadow: 0 4px 14px rgba(217, 91, 0, .55);
}
.ml-article-body {
    padding: 28px 34px 34px 34px;
}
.ml-article-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: #888;
    text-transform: uppercase;
    letter-spacing: .8px;
    font-weight: 600;
    margin-bottom: 10px;
}
.ml-article-meta i { color: var(--saffron-dark); }
.ml-article h3 {
    font-family: 'Playfair Display', serif;
    font-size: 28px;
    line-height: 1.25;
    color: #1a1a1a;
    margin: 0 0 14px 0;
}
.ml-article-lede {
    font-size: 16px;
    color: #444;
    font-style: italic;
    border-left: 4px solid var(--saffron);
    padding: 4px 0 4px 14px;
    margin-bottom: 18px;
}
.ml-article p {
    color: #333;
    font-size: 15px;
    line-height: 1.75;
    margin-bottom: 14px;
}
.ml-article .ml-pull {
    background: #fff7ee;
    border: 1px dashed #f4b56a;
    padding: 16px 18px;
    border-radius: 12px;
    color: #6a3500;
    font-weight: 600;
    margin: 16px 0;
}

/* Audio / podcast variant */
.ml-audio-card {
    display: flex;
    gap: 16px;
    align-items: center;
    background: linear-gradient(135deg, #fff 0%, #fff1de 100%);
    border: 1px solid #f4b56a;
    padding: 16px;
    border-radius: 14px;
    margin: 18px 0;
}
.ml-audio-card .ml-audio-icon {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, #FF9933, #d95b00);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 26px;
    flex: 0 0 56px;
    box-shadow: 0 6px 18px rgba(217, 91, 0, .45);
}
.ml-audio-card .ml-audio-bar {
    height: 6px;
    background: #ffe2c0;
    border-radius: 4px;
    overflow: hidden;
    margin-top: 6px;
}
.ml-audio-card .ml-audio-bar span {
    display: block;
    height: 100%;
    width: 42%;
    background: linear-gradient(90deg, #FF9933, #d95b00);
    border-radius: 4px;
}

/* Cursor for clickable media */
[data-lightbox-image],
[data-lightbox-video],
[data-lightbox-article],
.vdbox img { cursor: zoom-in; }
[data-lightbox-video], .vdbox .portfolio-info a[data-lightbox-video] { cursor: pointer; }

/* Mobile tweaks */
@media (max-width: 575px) {
    .media-lightbox-overlay { padding: 14px; }
    .media-lightbox { border-radius: 16px; }
    .ml-close { width: 38px; height: 38px; font-size: 17px; top: 10px; right: 10px; }
    .ml-article-cover { height: 160px; }
    .ml-article-body { padding: 20px 18px 24px 18px; }
    .ml-article h3 { font-size: 21px; }
    .ml-article-lede, .ml-article p { font-size: 14px; }
    .ml-image-stage img { max-height: 70vh; }
}

/*------------------------------------------------------------
# Campaign Detail Modal — Premium Split Layout
------------------------------------------------------------*/
.camp-modal-overlay {
    position: fixed; inset: 0;
    background: radial-gradient(ellipse at center, rgba(90,31,0,.78) 0%, rgba(11,35,65,.88) 100%);
    backdrop-filter: blur(10px);
    z-index: 1080;
    display: flex; align-items: center; justify-content: center;
    padding: 28px;
    opacity: 0; visibility: hidden;
    transition: opacity .35s ease, visibility .35s ease;
}
.camp-modal-overlay.open { opacity: 1; visibility: visible; }

.camp-modal {
    background: #fff;
    width: 100%;
    max-width: 1080px;
    max-height: 90vh;
    border-radius: 24px;
    overflow: hidden;
    box-shadow:
        0 0 0 1px rgba(248,151,29,.35),
        0 40px 100px rgba(0,0,0,.55),
        0 0 80px rgba(248,151,29,.18);
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    position: relative;
    transform: translateY(30px) scale(.96);
    transition: transform .45s cubic-bezier(.2,.8,.2,1);
}
.camp-modal-overlay.open .camp-modal { transform: translateY(0) scale(1); }

/* Decorative top accent strip */
.camp-modal::before {
    content: "";
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, #ff5a00 0%, #f8971d 35%, #ffffff 50%, #009961 70%, #16327A 100%);
    z-index: 6;
}

/* Close button — glassy gold */
.camp-modal-close {
    position: absolute;
    top: 18px; right: 18px;
    width: 42px; height: 42px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.55);
    background: rgba(255,255,255,.92);
    color: var(--brown-dark);
    font-size: 17px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    z-index: 10;
    box-shadow: 0 8px 24px rgba(0,0,0,.32);
    transition: transform .3s, background .3s, color .3s, border-color .3s;
}
.camp-modal-close:hover {
    background: linear-gradient(135deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    color: #fff;
    border-color: rgba(255,255,255,.85);
    transform: rotate(90deg) scale(1.05);
}

/* ------------ Media (left) ------------ */
.camp-modal-media {
    position: relative;
    background:
        radial-gradient(circle at 30% 30%, rgba(255,255,255,.18) 0%, transparent 55%),
        linear-gradient(135deg, #ff9933 0%, #ed502e 55%, #b91c1c 100%);
    padding: 28px 24px 84px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
/* Subtle texture overlay */
.camp-modal-media::after {
    content: "";
    position: absolute; inset: 0;
    background:
        repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 14px);
    pointer-events: none;
}
.cm-main-img {
    position: relative;
    width: 100%;
    height: 430px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    background-color: transparent;
    border-radius: 14px;
    filter: drop-shadow(0 18px 30px rgba(0,0,0,.35));
    transition: background-image .35s ease;
    z-index: 2;
}

.cm-badge {
    position: absolute;
    top: 20px; left: 20px;
    background: linear-gradient(135deg, #ffffff 0%, #fff5e2 100%);
    color: var(--brown-dark);
    padding: 7px 16px;
    font-family: 'Montserrat'; font-size: 10.5px;
    font-weight: 800; letter-spacing: 1.8px;
    text-transform: uppercase;
    border-radius: 30px;
    box-shadow: 0 6px 18px rgba(0,0,0,.28);
    border: 1px solid rgba(255,255,255,.6);
    z-index: 4;
}
.cm-badge i { color: var(--saffron-dark); margin-right: 4px; }

.cm-thumbs {
    position: absolute;
    bottom: 18px; left: 50%;
    transform: translateX(-50%);
    display: flex; gap: 10px;
    flex-wrap: wrap;
    justify-content: center;
    max-width: calc(100% - 36px);
    padding: 8px 10px;
    background: rgba(0,0,0,.32);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 16px;
    z-index: 4;
}
.cm-thumb {
    width: 64px; height: 44px;
    border-radius: 9px;
    border: 2px solid transparent;
    background-size: cover;
    background-position: center;
    cursor: pointer;
    padding: 0;
    transition: transform .3s, border-color .3s, box-shadow .3s, opacity .3s;
    opacity: .7;
}
.cm-thumb:hover { opacity: 1; transform: translateY(-3px); }
.cm-thumb.active {
    border-color: #fff;
    opacity: 1;
    box-shadow: 0 6px 18px rgba(255,255,255,.5);
}

/* ------------ Body (right) — centered & premium ------------ */
.camp-modal-body {
    position: relative;
    padding: 54px 44px 48px;
    overflow-y: auto;
    background:
        radial-gradient(circle at top, #fff7e9 0%, #ffffff 60%),
        linear-gradient(180deg, #ffffff 0%, #fffaf2 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}
/* Logo watermark — large, faded, centered behind content */
.camp-modal-body::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url('../images/logo.jpeg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: 85% auto;
    opacity: .09;
    filter: grayscale(15%) contrast(.95) drop-shadow(0 8px 18px rgba(140,52,0,.25));
    pointer-events: none;
    z-index: 1;
}
/* Top ornament — small lotus glyph */
.camp-modal-body::after {
    content: "\F315";
    font-family: "bootstrap-icons";
    position: absolute;
    top: 18px; left: 50%;
    transform: translateX(-50%);
    font-size: 22px;
    color: var(--saffron);
    opacity: .55;
    line-height: 1;
    pointer-events: none;
    z-index: 2;
}
.camp-modal-body .cm-date {
    font-family: 'Montserrat'; font-size: 10.5px;
    color: var(--saffron-dark); font-weight: 800;
    letter-spacing: 2.6px; text-transform: uppercase;
    margin: 0 0 18px;
    display: inline-flex; align-items: center; gap: 12px;
    position: relative;
    z-index: 2;
}
.camp-modal-body .cm-date::before,
.camp-modal-body .cm-date::after {
    content: ""; width: 28px; height: 2px;
    background: linear-gradient(90deg, transparent 0%, var(--saffron-dark) 100%);
    border-radius: 2px;
}
.camp-modal-body .cm-date::after {
    background: linear-gradient(90deg, var(--saffron-dark) 0%, transparent 100%);
}
.camp-modal-body h3 {
    font-family: 'Playfair Display', serif;
    font-size: 30px;
    font-weight: 800;
    color: var(--navy);
    margin: 0 0 20px;
    line-height: 1.22;
    position: relative;
    z-index: 2;
    max-width: 32ch;
}
.camp-modal-body h3::after {
    content: "";
    display: block;
    width: 72px; height: 3px;
    margin: 16px auto 0;
    background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dark) 100%);
    border-radius: 3px;
}
.camp-modal-body p {
    font-size: 15.5px;
    line-height: 1.85;
    color: #4a4a4a;
    margin: 0 0 14px;
    position: relative;
    z-index: 2;
    max-width: 44ch;
}
.camp-modal-body p:last-child { margin-bottom: 0; }
.camp-modal-body .cm-gallery-sub {
    display: inline-block;
    font-family: 'Montserrat'; font-size: 11px; font-weight: 700;
    letter-spacing: 2px; text-transform: uppercase;
    color: var(--saffron-dark);
    margin-top: 4px;
}

/* ---- Slider nav arrows + counter (hidden unless slider mode) ---- */
.cm-nav {
    display: none;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 52px; height: 52px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.55);
    background: rgba(0,0,0,.45);
    backdrop-filter: blur(8px);
    color: #fff;
    font-size: 22px;
    line-height: 1;
    padding: 0;
    cursor: pointer;
    z-index: 6;
    box-shadow: 0 8px 22px rgba(0,0,0,.4);
    transition: background .25s, transform .25s, color .25s, border-color .25s;
}
.cm-nav:hover {
    background: #fff;
    color: var(--saffron-dark);
    border-color: #fff;
    transform: translateY(-50%) scale(1.06);
}
.cm-nav.cm-prev { left: 18px; }
.cm-nav.cm-next { right: 18px; }
.cm-counter {
    display: none;
    position: absolute;
    bottom: 22px; left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(8px);
    color: #fff;
    padding: 6px 16px;
    font-family: 'Montserrat'; font-size: 12px; font-weight: 700;
    letter-spacing: 1.5px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,.25);
    z-index: 6;
}

/* ---- Image-only variant: gallery lightbox (no text panel) ---- */
.camp-modal.cm-image-only {
    grid-template-columns: 1fr;
    max-width: 1100px;
}
.camp-modal.cm-image-only .camp-modal-body { display: none; }
.camp-modal.cm-image-only .camp-modal-media {
    padding: 28px;
    background:
        radial-gradient(circle at 30% 30%, rgba(255,255,255,.15) 0%, transparent 55%),
        linear-gradient(135deg, #ff9933 0%, #ed502e 55%, #b91c1c 100%);
}
.camp-modal.cm-image-only .cm-main-img {
    height: min(80vh, 720px);
    border-radius: 14px;
}
.camp-modal.cm-image-only .cm-thumbs { display: none; }
.camp-modal.cm-image-only .cm-badge   { display: none; }

@media (max-width: 575px) {
    .camp-modal.cm-image-only .camp-modal-media { padding: 18px 14px; }
    .camp-modal.cm-image-only .cm-main-img { height: 70vh; }
    .cm-nav { width: 42px; height: 42px; font-size: 18px; }
    .cm-nav.cm-prev { left: 8px; }
    .cm-nav.cm-next { right: 8px; }
    .cm-counter { bottom: 14px; font-size: 11px; padding: 5px 12px; }
}

/* ---- Rich (section-collage) variant: long-form, left-aligned body ---- */
/* Stack image + thumbs at the top of the media column so the thumb strip sits
   right under the main image instead of being absolutely pinned to the bottom
   of a tall stretched container. */
.camp-modal.cm-rich .camp-modal-media {
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    padding: 32px 24px 32px;
    gap: 18px;
}
.camp-modal.cm-rich .cm-main-img {
    flex-shrink: 0;
    width: 100%;
    max-width: 100%;
}
.camp-modal.cm-rich .cm-thumbs {
    position: relative;
    bottom: auto; left: auto;
    transform: none;
    margin: 0;
}

.camp-modal.cm-rich .camp-modal-body {
    align-items: stretch;
    text-align: left;
    padding: 54px 42px 44px;
}
.camp-modal.cm-rich .camp-modal-body .cm-date,
.camp-modal.cm-rich .camp-modal-body h3 { align-self: flex-start; }
.camp-modal.cm-rich .camp-modal-body h3::after {
    margin-left: 0; margin-right: 0;
}
.camp-modal.cm-rich .camp-modal-body p,
.camp-modal.cm-rich .camp-modal-body ul,
.camp-modal.cm-rich .camp-modal-body ol {
    max-width: 56ch;
    text-align: left;
}
.camp-modal.cm-rich .camp-modal-body ul,
.camp-modal.cm-rich .camp-modal-body ol {
    position: relative;
    z-index: 2;
    padding-left: 22px;
    margin: 0 0 16px;
    color: #4a4a4a;
    font-size: 14.5px;
    line-height: 1.75;
}
.camp-modal.cm-rich .camp-modal-body li { margin-bottom: 6px; }
.camp-modal.cm-rich .camp-modal-body li::marker { color: var(--saffron-dark); }
.camp-modal.cm-rich .camp-modal-body strong { color: var(--brown-dark); font-weight: 700; }
.camp-modal.cm-rich .camp-modal-body em { color: var(--saffron-dark); font-style: italic; }
.camp-modal.cm-rich .camp-modal-body .sc-stat {
    display: flex; flex-wrap: wrap; gap: 14px;
    margin-top: 8px;
    position: relative; z-index: 2;
}
.camp-modal.cm-rich .camp-modal-body .sc-stat > div {
    background: linear-gradient(135deg, #fff7e9 0%, #fff 100%);
    border: 1px solid rgba(248,151,29,.35);
    border-radius: 12px;
    padding: 12px 16px;
    min-width: 110px;
    box-shadow: 0 4px 14px rgba(140,52,0,.08);
}
.camp-modal.cm-rich .camp-modal-body .sc-stat strong {
    display: block;
    font-family: 'Playfair Display', serif;
    font-size: 22px;
    color: var(--saffron-dark);
    line-height: 1.1;
}
.camp-modal.cm-rich .camp-modal-body .sc-stat span {
    display: block;
    font-family: 'Montserrat';
    font-size: 10px; font-weight: 700;
    letter-spacing: 1.4px; text-transform: uppercase;
    color: #888;
    margin-top: 4px;
}

/* ------------ Tablet & below: stack ------------ */
@media (max-width: 991px) {
    .camp-modal {
        grid-template-columns: 1fr;
        max-width: 720px;
        max-height: 94vh;
    }
    .camp-modal-media { padding: 22px 18px 78px; }
    .cm-main-img { height: 320px; }
    .camp-modal-body { padding: 32px 28px 36px; }
    .camp-modal-body h3 { font-size: 24px; }
}

@media (max-width: 575px) {
    .camp-modal-overlay { padding: 14px; }
    .camp-modal { border-radius: 18px; }
    .camp-modal-media { padding: 18px 14px 70px; }
    .cm-main-img { height: 240px; }
    .cm-badge { font-size: 9px; padding: 5px 12px; top: 14px; left: 14px; }
    .cm-thumb { width: 52px; height: 36px; }
    .camp-modal-body { padding: 26px 22px 28px; }
    .camp-modal-body h3 { font-size: 20px; }
    .camp-modal-body p { font-size: 14px; line-height: 1.7; }
    .camp-modal-close { width: 36px; height: 36px; font-size: 15px; top: 12px; right: 12px; }
}
