/* =============================================
   NGO Website - GLOBAL THEME (single source)
   Sirf is file ko edit karein — poori website update ho jayegi.
   ============================================= */

:root {
    /* Brand */
    --clr-primary:      #1565c0;
    --clr-secondary:    #fb8c00;
    --clr-accent:       #42a5f5;

    /* Backgrounds */
    --clr-bg:           #f0f4ff;
    --clr-surface:      #ffffff;
    --clr-footer-bg:    #0d47a1;
    --clr-footer-text:  #ffffff;

    /* Typography */
    --clr-h1:           #0d2b5a;
    --clr-h2:           #1565c0;
    --clr-h3:           #1976d2;
    --clr-h4:           #37474f;
    --clr-h5:           #546e7a;
    --clr-h6:           #78909c;
    --clr-para:         #37474f;
    --clr-subheading:   #607d8b;

    /* Links */
    --clr-link:         #1565c0;
    --clr-link-hover:   #fb8c00;
    --clr-link-visited: #6a1b9a;

    /* Buttons */
    --clr-btn-bg:           #1565c0;
    --clr-btn-text:         #ffffff;
    --clr-btn-hover-bg:     #fb8c00;
    --clr-btn-hover-text:   #ffffff;
    --clr-btn-border:       #1565c0;

    /* Navigation & Tabs */
    --clr-nav-bg:           #ffffff;
    --clr-nav-text:         #37474f;
    --clr-nav-hover:        #1565c0;
    --clr-nav-active:       #1565c0;
    --clr-tab-bg:           #e3f2fd;
    --clr-tab-text:         #546e7a;
    --clr-tab-active-bg:    #1565c0;
    --clr-tab-active-text:  #ffffff;

    /* Derived / system */
    --clr-topbar-bg:        #0d47a1;
    --clr-border:           #e3e9f5;
    --radius:               14px;
    --shadow-sm:            0 2px 10px rgba(13, 43, 90, .06);
    --shadow-md:            0 10px 30px rgba(13, 43, 90, .10);
    --font-heading:         'Josefin Sans', 'Poppins', system-ui, sans-serif;
    --font-body:            'Inter', system-ui, -apple-system, 'Segoe UI', sans-serif;
    --container:            1200px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font-body);
    color: var(--clr-para);
    background: var(--clr-bg);
    line-height: 1.65;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 { font-family: var(--font-heading); font-weight: 700; line-height: 1.2; margin: 0 0 .5em; }
h1 { color: var(--clr-h1); }
h2 { color: var(--clr-h2); }
h3 { color: var(--clr-h3); }
h4 { color: var(--clr-h4); }
h5 { color: var(--clr-h5); }
h6 { color: var(--clr-h6); }
p { margin: 0 0 1rem; color: var(--clr-para); }

a { color: var(--clr-link); text-decoration: none; transition: color .2s ease; }
a:hover { color: var(--clr-link-hover); }

img { max-width: 100%; height: auto; display: block; }

.container-x { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 16px; }
.container-x--fluid { max-width: 100%; padding: 0 40px; }
@media (max-width: 992px) { .container-x--fluid { padding: 0 16px; } }

/* ---------- Buttons ---------- */
.btn-thm {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
    background: var(--clr-btn-bg); color: var(--clr-btn-text);
    border: 2px solid var(--clr-btn-border);
    padding: .7rem 1.6rem; border-radius: 50px; font-weight: 600; font-size: .95rem;
    cursor: pointer; transition: all .25s ease; text-align: center;
}
.btn-thm:hover { background: var(--clr-btn-hover-bg); border-color: var(--clr-btn-hover-bg); color: var(--clr-btn-hover-text); transform: translateY(-2px); }
.btn-thm--outline { background: transparent; color: var(--clr-primary); }
.btn-thm--outline:hover { background: var(--clr-primary); color: #fff; }
.btn-thm--secondary { background: var(--clr-secondary); border-color: var(--clr-secondary); }
.btn-thm--secondary:hover { background: var(--clr-primary); border-color: var(--clr-primary); }
.btn-thm--sm { padding: .45rem 1.1rem; font-size: .85rem; }
.btn-thm--light { background: #fff; color: var(--clr-primary); border-color: #fff; }
.btn-thm--block { width: 100%; }

/* ---------- Section helpers ---------- */
.section { padding: 70px 0; }
.section--tight { padding: 45px 0; }
.section--alt { background: var(--clr-surface); }
.section--soft { background: linear-gradient(180deg, #eaf1ff 0%, var(--clr-bg) 100%); }

.section-head { max-width: 680px; margin: 0 auto 42px; text-align: center; }
.section-head--left { margin-left: 0; text-align: left; }
.section-head .eyebrow {
    display: inline-block; color: var(--clr-secondary); font-weight: 700;
    text-transform: uppercase; letter-spacing: 2px; font-size: .8rem; margin-bottom: .5rem;
    position: relative;
}
.section-head h2 { font-size: 2.1rem; }
.section-head .sub { color: var(--clr-subheading); margin-top: .35rem; }
.title-bar { width: 64px; height: 4px; border-radius: 4px; background: var(--clr-secondary); margin: 14px auto 0; }
.section-head--left .title-bar { margin-left: 0; }

/* ---------- Cards ---------- */
.card-thm {
    background: var(--clr-surface); border: 1px solid var(--clr-border);
    border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm);
    transition: transform .25s ease, box-shadow .25s ease; height: 100%;
}
.card-thm:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.card-thm__img { aspect-ratio: 16 / 10; overflow: hidden; background: #dfe7f5; }
.card-thm__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.card-thm:hover .card-thm__img img { transform: scale(1.06); }
.card-thm__body { padding: 20px; }
.card-thm__tag { display: inline-block; font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--clr-secondary); margin-bottom: .4rem; }
.card-thm__title { font-size: 1.15rem; color: var(--clr-h3); margin-bottom: .4rem; }
.card-thm__title a { color: inherit; }
.card-thm__title a:hover { color: var(--clr-primary); }
.card-thm__meta { font-size: .82rem; color: var(--clr-h6); display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: .6rem; }
.card-thm__text { color: var(--clr-subheading); font-size: .92rem; }

/* ---------- Grid ---------- */
.grid { display: grid; gap: 24px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 992px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } }

/* =====================================================
   TOP BAR
   ===================================================== */
.topbar { background: var(--clr-topbar-bg); color: #fff; font-size: .85rem; }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 12px; min-height: 42px; flex-wrap: wrap; }
.topbar__left { display: flex; align-items: center; gap: 18px; }
.topbar__left a { color: #dbe7ff; display: inline-flex; align-items: center; gap: 6px; }
.topbar__left a:hover { color: #fff; }
.topbar__right { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.topbar__btn {
    display: inline-flex; align-items: center; gap: 6px; color: #eaf1ff;
    padding: 6px 12px; border-radius: 6px; font-weight: 600; font-size: .8rem;
    transition: background .2s ease, color .2s ease;
}
.topbar__btn:hover { background: rgba(255,255,255,.14); color: #fff; }
.topbar__btn--accent { background: var(--clr-secondary); color: #fff; }
.topbar__btn--accent:hover { background: #fff; color: var(--clr-secondary); }
@media (max-width: 992px) { .topbar { display: none; } }

/* =====================================================
   HEADER / NAVBAR
   ===================================================== */
.site-header {
    position: sticky; top: 0; z-index: 1000;
    background: var(--clr-nav-bg);
    box-shadow: 0 1px 0 rgba(13,43,90,.06);
    transition: box-shadow .25s ease;
}
.site-header.is-stuck { box-shadow: 0 8px 28px rgba(13,43,90,.12); }

.navbar__bar {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; min-height: 72px;
}

/* Brand: circular logo from General Settings */
.navbar__logo {
    display: flex; align-items: center; gap: 12px;
    flex-shrink: 0; min-width: 0;
    font-family: var(--font-heading); font-weight: 700;
    color: var(--clr-primary); text-decoration: none;
}
.navbar__logo--icon-only { margin-right: 4px; }
.navbar__logo-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; line-height: 1.15; }
.navbar__logo-name { font-size: 1.15rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.navbar__logo-tag {
    font-family: var(--font-body); font-size: .68rem; font-weight: 500;
    color: var(--clr-subheading); letter-spacing: .02em;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.logo-circle {
    flex-shrink: 0; border-radius: 50%; overflow: hidden;
    display: grid; place-items: center;
    background: #fff;
    border: 2px solid rgba(13,43,90,.08);
    box-shadow: 0 4px 14px rgba(13,43,90,.12);
}
.logo-circle--md { width: 50px; height: 50px; }
.logo-circle--sm { width: 42px; height: 42px; }
.logo-circle img { width: 100%; height: 100%; object-fit: cover; display: block; }
.logo-circle__fallback {
    width: 100%; height: 100%;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent));
    color: #fff; font-family: var(--font-heading); font-weight: 700;
    font-size: 1.2rem; line-height: 1; text-transform: uppercase;
}
.logo-circle--sm .logo-circle__fallback { font-size: 1rem; }

.navbar__logo--footer { margin-bottom: 14px; color: #fff; }
.navbar__logo--footer .navbar__logo-name { color: #fff; }
.navbar__logo--footer .navbar__logo-tag { color: rgba(255,255,255,.72); }
.navbar__logo--footer .logo-circle { border-color: rgba(255,255,255,.22); box-shadow: 0 4px 16px rgba(0,0,0,.22); }

/* Main navigation — single row with logo + CTA */
.navbar__nav {
    flex: 1 1 auto; min-width: 0;
    display: flex; align-items: center; justify-content: center;
}
.menu {
    display: flex; align-items: stretch; justify-content: center;
    flex-wrap: nowrap; gap: 0;
    list-style: none; margin: 0; padding: 0;
    max-width: 100%; overflow: visible;
}
.menu__item { position: relative; flex: 0 0 auto; }
.menu__link {
    display: inline-flex; align-items: center; justify-content: center; gap: 5px;
    padding: 0 11px; min-height: 72px;
    font-weight: 600; font-size: .82rem; letter-spacing: .01em;
    color: var(--clr-nav-text); text-decoration: none;
    transition: color .2s ease, background .2s ease;
    white-space: nowrap; position: relative;
}
.menu__link::after {
    content: ""; position: absolute; left: 12px; right: 12px; bottom: 0;
    height: 3px; border-radius: 3px 3px 0 0;
    background: var(--clr-secondary);
    transform: scaleX(0); transition: transform .22s ease;
}
.menu__icon { font-size: .78rem; opacity: .75; }
.menu__chev { font-size: .58rem; opacity: .55; margin-left: 1px; transition: transform .2s ease; }
.menu__item.has-children:hover .menu__chev { transform: rotate(180deg); }
.menu__link:hover,
.menu__item.is-active > .menu__link {
    color: var(--clr-nav-hover);
    background: rgba(13,43,90,.04);
}
.menu__item.is-active > .menu__link::after,
.menu__link:hover::after { transform: scaleX(1); }
.menu__item.is-active > .menu__link { font-weight: 700; }

.menu .submenu {
    position: absolute; top: calc(100% - 4px); left: 50%;
    transform: translateX(-50%) translateY(6px);
    min-width: 230px; background: #fff;
    border-radius: 12px; box-shadow: 0 14px 36px rgba(13,43,90,.14);
    list-style: none; margin: 0; padding: 6px 0;
    opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
    z-index: 1001; border: 1px solid rgba(13,43,90,.07);
}
.menu .submenu li + li {
    border-top: 1px dotted rgba(13,43,90,.18);
}
.menu__item.has-children:hover > .submenu {
    opacity: 1; visibility: visible; pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}
.submenu__link {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; border-radius: 0;
    color: var(--clr-nav-text); font-size: .86rem; font-weight: 500;
    transition: background .18s ease, color .18s ease, padding-left .18s ease;
}
.submenu__link i { font-size: .72rem; opacity: .45; transition: opacity .18s ease; }
.submenu__link:hover {
    background: var(--clr-tab-bg); color: var(--clr-nav-hover);
    padding-left: 16px;
}
.submenu__link:hover i { opacity: .85; color: var(--clr-secondary); }

.navbar__cta { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.nav-link-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 0 14px; min-height: 40px; border-radius: 10px;
    font-size: .86rem; font-weight: 600; color: var(--clr-nav-text);
    border: 1px solid rgba(13,43,90,.1); background: #fff;
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}
.nav-link-btn:hover { background: var(--clr-tab-bg); color: var(--clr-primary); border-color: rgba(13,43,90,.16); }
.nav-link-btn.is-active { color: var(--clr-primary); background: var(--clr-tab-bg); border-color: rgba(13,43,90,.14); }
.navbar__donate { white-space: nowrap; }
.navbar__toggle {
    display: none; background: var(--clr-primary); color: #fff; border: none;
    width: 44px; height: 44px; border-radius: 12px; font-size: 1.15rem; cursor: pointer;
    box-shadow: 0 4px 14px rgba(13,43,90,.18);
}

/* Header cart icon + count badge */
.nav-cart {
    position: relative; display: inline-flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; border-radius: 10px;
    color: var(--clr-primary); font-size: 1.1rem;
    border: 1px solid rgba(13,43,90,.1); background: #fff;
    transition: background .2s ease, border-color .2s ease;
}
.nav-cart:hover { background: var(--clr-tab-bg, #eef2ff); border-color: rgba(13,43,90,.16); }
.nav-cart__badge {
    position: absolute; top: 0; right: 0; min-width: 17px; height: 17px; padding: 0 4px;
    border-radius: 999px; background: var(--clr-secondary, #e53935); color: #fff;
    font-size: .64rem; font-weight: 700; line-height: 17px; text-align: center;
    border: 2px solid var(--clr-nav-bg, #fff);
}

@media (max-width: 1280px) {
    .menu__link { padding: 0 8px; font-size: .78rem; min-height: 68px; }
    .nav-link-btn span { display: none; }
    .nav-link-btn { width: 40px; padding: 0; justify-content: center; }
}

@media (max-width: 1100px) {
    .menu__link { padding: 0 6px; font-size: .74rem; }
    .menu__chev { display: none; }
}

@media (max-width: 992px) {
    .navbar__nav { display: none; }
    .navbar__cta .btn-thm,
    .navbar__cta .nav-link-btn { display: none; }
    .navbar__toggle { display: inline-flex; align-items: center; justify-content: center; }
    .navbar__bar { min-height: 64px; gap: 12px; }
    .logo-circle--md { width: 46px; height: 46px; }
}

/* ---------- Mobile drawer ---------- */
.drawer { position: fixed; inset: 0; z-index: 1100; visibility: hidden; }
.drawer.open { visibility: visible; }
.drawer__overlay { position: absolute; inset: 0; background: rgba(8,22,48,.55); opacity: 0; transition: opacity .25s ease; }
.drawer.open .drawer__overlay { opacity: 1; }
.drawer__panel {
    position: absolute; top: 0; left: 0; height: 100%; width: 86%; max-width: 340px; background: #fff;
    transform: translateX(-100%); transition: transform .3s ease; overflow-y: auto; padding: 18px;
}
.drawer.open .drawer__panel { transform: translateX(0); }
.drawer__head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid var(--clr-border); margin-bottom: 10px; }
.drawer__close { background: none; border: none; font-size: 1.5rem; color: var(--clr-h4); cursor: pointer; }
.drawer__menu, .drawer__menu ul { list-style: none; margin: 0; padding: 0; }
.drawer__menu > li { border-bottom: 1px solid rgba(13,43,90,.06); }
.drawer__menu > li:last-child { border-bottom: none; }
.drawer__menu a {
    display: block; padding: 12px 10px; color: var(--clr-nav-text);
    font-weight: 600; border-radius: 10px; transition: background .18s ease, color .18s ease;
}
.drawer__menu a:hover { background: var(--clr-tab-bg); color: var(--clr-primary); }
.drawer__menu .sub { display: none; padding: 0 0 8px 12px; }
.drawer__menu .sub.open { display: block; }
.drawer__menu .sub li + li { border-top: 1px dotted rgba(13,43,90,.16); }
.drawer__menu .sub a { font-weight: 500; font-size: .9rem; color: var(--clr-subheading); padding: 9px 10px; }
.drawer__toggle-sub {
    display: flex; align-items: center; justify-content: space-between;
    cursor: pointer; padding-right: 4px;
}
.drawer__toggle-sub a { flex: 1; }
.drawer__toggle-sub i { font-size: .75rem; color: var(--clr-subheading); transition: transform .2s ease; padding: 12px 8px; }
.drawer__toggle-sub.open i { transform: rotate(180deg); }

/* =====================================================
   PAGE BANNER / BREADCRUMB
   ===================================================== */
.page-banner {
    position: relative; padding: 86px 0 78px; overflow: hidden; color: #fff;
    background: linear-gradient(120deg, var(--clr-footer-bg) 0%, var(--clr-primary) 58%, var(--clr-secondary) 135%);
}
.page-banner::before {
    content: ""; position: absolute; inset: 0; z-index: 1; opacity: .5;
    background-image: radial-gradient(rgba(255,255,255,.10) 1.5px, transparent 1.5px);
    background-size: 22px 22px;
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 30%, #000 70%, transparent);
            mask-image: linear-gradient(90deg, transparent, #000 30%, #000 70%, transparent);
}
.page-banner::after { content: ""; position: absolute; right: -70px; top: -80px; width: 280px; height: 280px; border-radius: 50%; background: rgba(255,255,255,.08); z-index: 1; }
.page-banner__inner { position: relative; z-index: 2; text-align: center; }
.page-banner__inner::before { content: ""; position: absolute; left: -90px; bottom: -120px; width: 220px; height: 220px; border-radius: 50%; background: rgba(255,255,255,.06); z-index: -1; }
.page-banner h1 { color: #fff; font-size: 2.6rem; line-height: 1.15; letter-spacing: -.5px; margin: 0 0 16px; text-shadow: 0 2px 12px rgba(0,0,0,.18); }

.breadcrumb-x {
    display: inline-flex; flex-wrap: wrap; gap: 6px; align-items: center; justify-content: center;
    font-size: .88rem; font-weight: 600; color: rgba(255,255,255,.85);
    background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.18);
    padding: 8px 16px; border-radius: 50px; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.breadcrumb-x a { display: inline-flex; align-items: center; gap: 6px; color: rgba(255,255,255,.85); padding: 2px 8px; border-radius: 50px; transition: all .2s ease; }
.breadcrumb-x a:hover { color: #fff; background: rgba(255,255,255,.18); }
.breadcrumb-x a .fa-home { font-size: .85rem; }
.breadcrumb-x .sep { display: inline-flex; align-items: center; opacity: .55; font-size: .75rem; }
.breadcrumb-x .current { color: #fff; background: var(--clr-secondary); padding: 3px 12px; border-radius: 50px; box-shadow: 0 4px 12px rgba(0,0,0,.15); }
@media (max-width: 576px) { .page-banner h1 { font-size: 2rem; } .page-banner { padding: 64px 0 58px; } }

/* =====================================================
   HERO SLIDER
   ===================================================== */
.hero { position: relative; }
.hero .swiper-slide { position: relative; min-height: 560px; display: flex; align-items: center; }
.hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
.hero__overlay { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(10,29,60,.86) 0%, rgba(10,29,60,.55) 60%, rgba(10,29,60,.25) 100%); }
.hero__content { position: relative; z-index: 3; max-width: 640px; color: #fff; padding: 40px 0; }
.hero__content .eyebrow { color: var(--clr-secondary); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; }
.hero__content h1 { color: #fff; font-size: 3rem; margin: 10px 0 14px; }
.hero__content p { color: #e7eefc; font-size: 1.1rem; margin-bottom: 24px; }
.hero__btns { display: flex; flex-wrap: wrap; gap: 12px; }
.hero .swiper-button-next, .hero .swiper-button-prev { color: #fff; }
.hero .swiper-pagination-bullet { background: #fff; opacity: .6; }
.hero .swiper-pagination-bullet-active { background: var(--clr-secondary); opacity: 1; width: 26px; border-radius: 6px; }
@media (max-width: 768px) { .hero__content h1 { font-size: 2rem; } .hero .swiper-slide { min-height: 440px; } }

/* =============================================
   DYNAMIC HERO (admin banners: image/video + badge + 2 buttons)
   ============================================= */
.dhero { position: relative; background: #0a1b3d; overflow: hidden; }
.dhero .swiper-slide { position: relative; min-height: min(88vh, 760px); display: flex; align-items: center; overflow: hidden; }
.dhero__media { position: absolute; inset: 0; z-index: 0; }
.dhero__img { position: absolute; inset: 0; background-size: cover; background-position: center; animation: dheroZoom 14s ease-out both; }
.dhero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
@keyframes dheroZoom { from { transform: scale(1.08); } to { transform: scale(1); } }
.dhero__overlay { position: absolute; inset: 0; z-index: 1;
    background:
        radial-gradient(120% 120% at 82% 28%, rgba(10,27,61,.30) 0%, rgba(10,27,61,.72) 55%, rgba(8,20,46,.96) 100%),
        linear-gradient(90deg, rgba(8,20,46,.92) 0%, rgba(8,20,46,.55) 55%, rgba(8,20,46,.18) 100%); }
.dhero__content { position: relative; z-index: 2; max-width: 640px; color: #fff; padding: 60px 0; }

.dhero__badge { display: inline-flex; align-items: center; gap: 10px; padding: 8px 18px; border: 1px solid rgba(255,255,255,.18); background: rgba(255,255,255,.06); border-radius: 999px; font-size: .72rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: #dbe4f5; }
.dhero__dot { width: 8px; height: 8px; border-radius: 999px; background: var(--clr-secondary); box-shadow: 0 0 0 4px rgba(251,140,0,.25); }

.dhero__title { color: #fff; font-size: clamp(2.4rem, 5.2vw, 4.4rem); line-height: 1.03; font-weight: 800; margin: 22px 0 0; letter-spacing: -.5px; }
.dhero__accent { display: block; color: var(--clr-secondary); }
.dhero__sub { color: #cdd8ef; font-size: 1.15rem; font-weight: 600; margin: 14px 0 0; }
.dhero__desc { color: #aab8d6; font-size: 1.05rem; line-height: 1.7; margin: 18px 0 0; max-width: 540px; }

.dhero__btns { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.dhero__btn { display: inline-flex; align-items: center; gap: 14px; padding: 14px 16px 14px 26px; border-radius: 999px; font-weight: 700; font-size: 1rem; text-decoration: none; transition: transform .25s ease, box-shadow .25s ease, background .25s ease; }
.dhero__btn--primary { background: var(--clr-secondary); color: #0a1b3d; box-shadow: 0 14px 30px rgba(251,140,0,.35); }
.dhero__btn--primary i { display: grid; place-items: center; width: 30px; height: 30px; border-radius: 999px; background: #0a1b3d; color: #fff; font-size: .8rem; transition: transform .25s ease; }
.dhero__btn--primary:hover { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(251,140,0,.45); }
.dhero__btn--primary:hover i { transform: translateX(3px); }
.dhero__btn--ghost { background: rgba(255,255,255,.08); color: #fff; border: 1px solid rgba(255,255,255,.25); padding: 14px 28px; }
.dhero__btn--ghost:hover { background: rgba(255,255,255,.16); transform: translateY(-2px); }

.dhero__scroll { position: absolute; left: 50%; bottom: 24px; transform: translateX(-50%); z-index: 4; display: flex; flex-direction: column; align-items: center; gap: 8px; color: #9fb0d4; font-size: .7rem; font-weight: 700; letter-spacing: .3em; }
.dhero__scroll-dot { width: 6px; height: 6px; border-radius: 999px; background: var(--clr-secondary); animation: dheroScroll 1.6s ease-in-out infinite; }
@keyframes dheroScroll { 0%,100% { transform: translateY(0); opacity: 1; } 50% { transform: translateY(6px); opacity: .4; } }

.dhero__nav { position: absolute; right: 28px; bottom: 24px; z-index: 5; display: flex; gap: 10px; }
.dhero .dhero__arrow { position: static; width: 44px; height: 44px; margin: 0; border-radius: 999px; border: 1px solid rgba(255,255,255,.3); background: rgba(255,255,255,.06); color: #fff; display: grid; place-items: center; cursor: pointer; transition: background .2s ease, transform .2s ease, color .2s ease; }
.dhero .dhero__arrow:hover { background: var(--clr-secondary); color: #0a1b3d; border-color: transparent; }
.dhero .dhero__arrow::after { content: none; }
.dhero .swiper-pagination { bottom: auto; top: 50%; left: auto; right: 18px; width: auto; transform: translateY(-50%); display: flex; flex-direction: column; gap: 8px; }
.dhero .swiper-pagination-bullet { background: #fff; opacity: .45; margin: 0 !important; }
.dhero .swiper-pagination-bullet-active { background: var(--clr-secondary); opacity: 1; height: 22px; border-radius: 6px; }

.dhero .swiper-slide-active .dhero__badge,
.dhero .swiper-slide-active .dhero__title,
.dhero .swiper-slide-active .dhero__sub,
.dhero .swiper-slide-active .dhero__desc,
.dhero .swiper-slide-active .dhero__btns { animation: dheroUp .8s cubic-bezier(.2,.7,.2,1) both; }
.dhero .swiper-slide-active .dhero__title { animation-delay: .08s; }
.dhero .swiper-slide-active .dhero__sub { animation-delay: .18s; }
.dhero .swiper-slide-active .dhero__desc { animation-delay: .26s; }
.dhero .swiper-slide-active .dhero__btns { animation-delay: .36s; }
@keyframes dheroUp { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }

@media (max-width: 768px) {
    .dhero .swiper-slide { min-height: 560px; }
    .dhero__content { padding: 48px 0; }
    .dhero__desc { font-size: .98rem; }
    .dhero__nav { right: 14px; bottom: 16px; }
    .dhero__scroll { display: none; }
}

/* =====================================================
   COUNTERS
   ===================================================== */
.counters { background: linear-gradient(120deg, var(--clr-primary), var(--clr-footer-bg)); color: #fff; }
.counters__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 12px 20px;
}
.counter { text-align: center; padding: 14px; }
.counter__icon { font-size: 2.2rem; color: var(--clr-secondary); margin-bottom: 8px; }
.counter__num { font-size: 2.6rem; font-weight: 800; font-family: var(--font-heading); line-height: 1; }
.counter__label { margin-top: 6px; color: #d8e4ff; font-size: .95rem; }

/* =====================================================
   HOME — Counter bar (below FAQ)
   ===================================================== */
.home-counter-bar {
    padding-top: 8px;
    padding-bottom: 52px;
}
.home-counter-bar__panel {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    padding: 30px 12px;
    border-radius: 16px;
    background: linear-gradient(135deg, #3f7f79 0%, #356b66 100%);
    color: #fff;
    box-shadow: 0 14px 36px rgba(13,43,90,.16);
}
.home-counter-bar__item {
    position: relative;
    text-align: center;
    padding: 10px 18px;
}
.home-counter-bar__item:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 12%;
    right: 0;
    bottom: 12%;
    width: 1px;
    background: rgba(255,255,255,.22);
}
.home-counter-bar__icon {
    width: 58px;
    height: 58px;
    margin: 0 auto 14px;
    border-radius: 50%;
    background: rgba(186, 214, 214, .55);
    display: grid;
    place-items: center;
    font-size: 1.45rem;
    color: var(--clr-secondary);
}
.home-counter-bar__num {
    font-size: clamp(1.75rem, 3vw, 2.25rem);
    font-weight: 800;
    line-height: 1;
    font-family: var(--font-heading);
}
.home-counter-bar__label {
    margin-top: 8px;
    font-size: .88rem;
    font-weight: 700;
    line-height: 1.35;
    color: rgba(255,255,255,.95);
}

@media (max-width: 992px) {
    .home-counter-bar__panel { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px 0; }
    .home-counter-bar__item:nth-child(2)::after { display: none; }
    .home-counter-bar__item:nth-child(odd):not(:last-child)::after { display: block; }
}
@media (max-width: 560px) {
    .home-counter-bar__panel { grid-template-columns: 1fr; padding: 24px 16px; }
    .home-counter-bar__item::after { display: none !important; }
    .home-counter-bar__item + .home-counter-bar__item {
        border-top: 1px solid rgba(255,255,255,.18);
        padding-top: 18px;
        margin-top: 8px;
    }
}

/* =====================================================
   HOME — Projects & Our Impact tabs + carousel
   ===================================================== */
.impact-showcase { overflow: hidden; }
.impact-showcase__head { display: flex; justify-content: center; margin-bottom: 28px; }
.impact-tabs {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 6px; border-radius: 999px;
    background: #fff; box-shadow: 0 8px 28px rgba(13,43,90,.1);
    border: 1px solid rgba(13,43,90,.06);
}
.impact-tabs__btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 12px 22px; border: 0; border-radius: 999px;
    background: transparent; color: var(--clr-nav-text);
    font-weight: 600; font-size: .92rem; cursor: pointer;
    transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}
.impact-tabs__btn i { font-size: .95rem; opacity: .75; }
.impact-tabs__btn.is-active {
    background: var(--clr-primary); color: #fff;
    box-shadow: 0 6px 18px rgba(13,43,90,.18);
}
.impact-tabs__btn.is-active i { opacity: 1; color: #fff; }

.impact-panels { position: relative; min-height: 280px; }
.impact-panel { display: none; animation: impactFade .28s ease; }
.impact-panel.is-active { display: block; }
@keyframes impactFade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

.impact-swiper { overflow: visible; padding: 4px 2px 8px; }
.impact-swiper .swiper-slide { height: auto; }

.impact-card {
    position: relative; display: block; overflow: hidden;
    border-radius: 16px; aspect-ratio: 4 / 3.1;
    box-shadow: 0 10px 30px rgba(13,43,90,.12);
    text-decoration: none; color: #fff;
    transition: transform .25s ease, box-shadow .25s ease;
}
.impact-card:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(13,43,90,.18); }
.impact-card img {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; display: block;
    transition: transform .35s ease;
}
.impact-card:hover img { transform: scale(1.04); }
.impact-card__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(8,22,48,.05) 35%, rgba(8,22,48,.82) 100%);
    pointer-events: none;
}
.impact-card__date {
    position: absolute; top: 14px; right: 14px; z-index: 2;
    padding: 6px 12px; border-radius: 999px;
    background: #16a34a; color: #fff;
    font-size: .72rem; font-weight: 700; letter-spacing: .02em;
    box-shadow: 0 4px 12px rgba(22,163,74,.35);
}
.impact-card__foot {
    position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
    padding: 18px 16px 16px;
}
.impact-card__meta {
    display: flex; flex-wrap: wrap; align-items: center; gap: 8px 14px;
    margin-bottom: 6px; font-size: .78rem; font-weight: 500; color: rgba(255,255,255,.9);
}
.impact-card__meta span { display: inline-flex; align-items: center; gap: 5px; }
.impact-card__meta i { font-size: .72rem; opacity: .92; }
.impact-card__title {
    margin: 0;
    font-size: 1.05rem; font-weight: 700; line-height: 1.35;
    color: #fff; font-family: var(--font-heading);
}

.impact-showcase__foot {
    display: flex; align-items: center; justify-content: space-between;
    gap: 16px; margin-top: 22px; flex-wrap: wrap;
}
.impact-showcase__links { min-height: 24px; }
.impact-showcase__more {
    display: none; align-items: center; gap: 8px;
    font-size: .88rem; font-weight: 600; color: var(--clr-primary);
    text-decoration: none;
}
.impact-showcase__more.is-visible { display: inline-flex; }
.impact-showcase__more:hover { color: var(--clr-secondary); }

.impact-nav { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.impact-nav__btn {
    width: 44px; height: 44px; border-radius: 999px;
    border: 1px solid rgba(13,43,90,.18); background: #fff;
    color: var(--clr-heading); font-size: .95rem; cursor: pointer;
    display: grid; place-items: center;
    transition: background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}
.impact-nav__btn:hover {
    background: var(--clr-primary); border-color: var(--clr-primary);
    color: #fff; transform: translateY(-1px);
}
.impact-nav__btn.swiper-button-disabled { opacity: .35; cursor: not-allowed; pointer-events: none; }

.media-showcase .impact-swiper .swiper-slide { height: auto; }
.media-showcase .card-thm {
    height: 100%;
    display: flex;
    flex-direction: column;
}
.media-showcase .card-thm__body {
    flex: 1;
    display: flex;
    flex-direction: column;
}
.media-showcase .card-thm__text { flex: 1; }

.highlight-card--award { text-align: center; }
.highlight-card__img--portrait { aspect-ratio: 3 / 4; }

/* Home — photo & video gallery tabs */
.gallery-showcase .section-head { margin-bottom: 28px; }
.gallery-showcase .impact-panel { padding-top: 4px; }
.gallery-showcase .media-filter { margin-bottom: 28px; }
.gallery-showcase .gallery-grid--home { grid-template-columns: repeat(4, 1fr); }
.gallery-showcase .gallery-video-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.gallery-showcase .gallery-video-card { display: block; height: 100%; }
.gallery-showcase__foot { justify-content: center; }
.gallery-showcase__foot .impact-nav { display: none; }
.gallery-showcase__empty {
    text-align: center;
    color: var(--clr-subheading);
    padding: 28px 16px;
}
.gallery-showcase__empty a { color: var(--clr-secondary); font-weight: 600; }
.gallery-item--link .gallery-item__go {
    position: absolute; inset: 0; display: grid; place-items: center;
    color: #fff; font-size: 1.1rem;
    background: rgba(13,43,90,.35); opacity: 0; transition: opacity .25s ease;
}
.gallery-item--link:hover .gallery-item__go { opacity: 1; }
.gallery-video-card--link { text-decoration: none; color: inherit; }
@media (max-width: 992px) {
    .gallery-showcase .gallery-grid--home { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .gallery-showcase .gallery-grid--home,
    .gallery-showcase .gallery-video-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .impact-tabs__btn { padding: 10px 16px; font-size: .84rem; }
    .impact-card { aspect-ratio: 16 / 12; }
    .impact-card__foot { padding: 14px 12px 12px; }
    .impact-card__title { font-size: .95rem; }
}

/* =====================================================
   HOME — Internship courses carousel
   ===================================================== */
.course-showcase {
    background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
    padding-bottom: 52px;
}
.course-showcase__head { margin-bottom: 32px; }
.course-showcase__eyebrow {
    display: inline-block; margin-bottom: 10px; padding: 6px 16px;
    border-radius: 999px; background: rgba(59,130,246,.12); color: #1d4ed8;
    font-size: .78rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
}
.course-showcase__head h2 { font-size: clamp(1.65rem, 3vw, 2.15rem); margin: 0; }

.course-showcase__slider { position: relative; padding-bottom: 36px; }
.course-showcase__card {
    height: 100%; display: flex; flex-direction: column;
    background: #fff; border-radius: 18px;
    border: 1px solid rgba(13,43,90,.07);
    box-shadow: 0 10px 28px rgba(13,43,90,.08);
    overflow: hidden;
}
.course-showcase__media {
    position: relative; aspect-ratio: 16 / 10; overflow: hidden;
}
.course-showcase__media img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform .45s ease;
}
.course-showcase__card:hover .course-showcase__media img { transform: scale(1.04); }
.course-showcase__price {
    position: absolute; left: 14px; bottom: 14px; z-index: 2;
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 12px; border-radius: 999px;
    font-size: .82rem; font-weight: 700; color: #fff;
    box-shadow: 0 4px 12px rgba(0,0,0,.18);
}
.course-showcase__price--free { background: #16a34a; }
.course-showcase__price--paid { background: #1e293b; }

.course-showcase__body {
    display: flex; flex-direction: column; flex: 1;
    padding: 18px 18px 20px;
}
.course-showcase__title {
    margin: 0 0 8px; font-size: 1.15rem; font-weight: 700;
    color: var(--clr-heading); font-family: var(--font-heading);
}
.course-showcase__text {
    margin: 0 0 16px; flex: 1;
    font-size: .88rem; line-height: 1.55; color: var(--clr-muted);
}
.course-showcase__actions {
    display: flex; gap: 10px; margin-top: auto;
}
.course-showcase__actions .btn-thm { flex: 1; justify-content: center; text-align: center; }

.course-showcase__pagination {
    position: absolute; left: 0; right: 0; bottom: 0 !important;
    display: flex; justify-content: flex-end; gap: 6px;
    padding-right: 4px;
}
.course-showcase__pagination .swiper-pagination-bullet {
    width: 10px; height: 10px; margin: 0 !important;
    background: rgba(13,43,90,.22); opacity: 1;
}
.course-showcase__pagination .swiper-pagination-bullet-active {
    background: var(--clr-primary);
}

.course-showcase__foot {
    display: flex; justify-content: center; margin-top: 28px;
}
.course-showcase__foot .btn-thm { min-width: 220px; padding: .72rem 1.6rem; }

@media (max-width: 768px) {
    .course-showcase__actions { flex-direction: column; }
    .course-showcase__pagination { justify-content: center; padding-right: 0; }
}

/* =====================================================
   HOME — Trusted partners
   ===================================================== */
.trusted-partners {
    background: #f1f5f9;
    padding-top: 44px;
    padding-bottom: 52px;
}
.trusted-partners .section-head { margin-bottom: 32px; }
.trusted-partners .section-head h2 {
    font-size: clamp(1.35rem, 2.5vw, 1.65rem);
    color: var(--clr-primary);
    margin-bottom: 0;
}
.trusted-partners__marquee { margin-top: 4px; }
.trusted-partners__card {
    display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
    flex: 0 0 200px; width: 200px;
    min-height: 118px; padding: 22px 18px;
    background: #fff; border-radius: 16px;
    border: 1px solid rgba(13,43,90,.06);
    box-shadow: 0 8px 22px rgba(13,43,90,.07);
    text-decoration: none;
    transition: transform .25s ease, box-shadow .25s ease;
}
.trusted-partners__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 28px rgba(13,43,90,.12);
}
.trusted-partners__card img {
    max-width: 100%; max-height: 72px; width: auto; height: auto;
    object-fit: contain;
}
.trusted-partners__initials {
    width: 56px; height: 56px; border-radius: 50%;
    display: grid; place-items: center;
    background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent));
    color: #fff; font-weight: 800; font-size: 1.1rem; letter-spacing: .5px;
    text-transform: uppercase;
}
.trusted-partners__name {
    display: block;
    max-width: 100%;
    font-size: .78rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--clr-primary);
    text-align: center;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

@media (max-width: 768px) {
    .trusted-partners__card { flex-basis: 170px; width: 170px; min-height: 100px; padding: 18px 14px; }
}

/* =====================================================
   HOME — Auto scroll (marquee + swipers)
   ===================================================== */
.auto-marquee {
    overflow: hidden; width: 100%;
    mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.auto-marquee__track {
    display: flex; align-items: stretch; gap: 18px;
    width: max-content;
    animation: autoMarqueeScroll var(--marquee-duration, 32s) linear infinite;
    will-change: transform;
}
.auto-marquee:hover .auto-marquee__track { animation-play-state: paused; }

@keyframes autoMarqueeScroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

.home-auto-swiper { overflow: hidden; padding: 4px 2px 8px; }
.home-auto-swiper .swiper-slide { height: auto; }
.home-auto-swiper .icon-box,
.home-auto-swiper .card-thm,
.home-auto-swiper .team-card,
.home-auto-swiper .tcard { height: 100%; }

@media (prefers-reduced-motion: reduce) {
    .auto-marquee__track { animation: none; flex-wrap: wrap; width: 100%; justify-content: center; }
    .auto-marquee { mask-image: none; -webkit-mask-image: none; overflow: visible; }
}

/* =====================================================
   ABOUT / FEATURE bits
   ===================================================== */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; }
@media (max-width: 900px) { .about-grid { grid-template-columns: 1fr; } }
.about-img { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); }
.about-img img { width: 100%; }
.feature-list { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 12px; }
.feature-list li { display: flex; gap: 12px; align-items: flex-start; }
.feature-list i { color: var(--clr-primary); margin-top: 4px; font-size: 1.05rem; }

/* ---------- Vision/Mission head (icon + title side by side) ---------- */
.vm-head { display: flex; align-items: center; gap: 16px; }
.vm-head__icon { width: 60px; height: 60px; flex: 0 0 60px; border-radius: 16px; display: grid; place-items: center; font-size: 1.5rem; color: #fff; background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent)); }
.vm-head__title { margin: 0; }
@media (max-width: 600px) { .about-img.vm-img-right { order: 0 !important; } }

/* ---------- Icon box ---------- */
.icon-box { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 28px 22px; text-align: center; box-shadow: var(--shadow-sm); transition: all .25s ease; height: 100%; }
.icon-box:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: var(--clr-accent); }
.icon-box__icon { width: 70px; height: 70px; border-radius: 18px; display: grid; place-items: center; margin: 0 auto 16px; font-size: 1.8rem; color: #fff; background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent)); }
.icon-box:hover .icon-box__icon { background: linear-gradient(135deg, var(--clr-secondary), #ffb74d); }
.icon-box h3 { font-size: 1.15rem; }

/* ---------- Team ---------- */
.team-card { background: #fff; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); text-align: center; transition: all .25s ease; }
.team-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.team-card__img { aspect-ratio: 1 / 1; overflow: hidden; background: #dfe7f5; }
.team-card__img img { width: 100%; height: 100%; object-fit: cover; }
.team-card__body { padding: 18px; }
.team-card__body h3 { font-size: 1.1rem; margin-bottom: 2px; }
.team-card__role { color: var(--clr-secondary); font-weight: 600; font-size: .88rem; }
.team-card__social { display: flex; justify-content: center; gap: 8px; margin-top: 12px; }
.team-card__social a { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; background: var(--clr-tab-bg); color: var(--clr-primary); }
.team-card__social a:hover { background: var(--clr-primary); color: #fff; }

/* ---------- Team (circular animated photo) ---------- */
.tm-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; }
@media (max-width: 992px) { .tm-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .tm-grid { grid-template-columns: 1fr; } }
.tm-card { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 26px 18px; text-align: center; box-shadow: var(--shadow-sm); transition: transform .3s ease, box-shadow .3s ease; }
.tm-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.tm-avatar { position: relative; width: 168px; height: 168px; margin: 0 auto 18px; }
.tm-avatar::before {
    content: ""; position: absolute; inset: 0; border-radius: 50%;
    background: conic-gradient(from 0deg, var(--clr-primary), var(--clr-secondary), var(--clr-accent), var(--clr-primary));
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 6px));
            mask: radial-gradient(farthest-side, transparent calc(100% - 6px), #000 calc(100% - 6px));
    animation: tm-spin 6s linear infinite;
}
.tm-avatar img { position: absolute; inset: 10px; width: calc(100% - 20px); height: calc(100% - 20px); border-radius: 50%; object-fit: cover; box-shadow: var(--shadow-sm); transition: transform .45s ease; }
.tm-card:hover .tm-avatar img { transform: scale(1.07); }
.tm-card:hover .tm-avatar::before { animation-duration: 2.5s; }
@keyframes tm-spin { to { transform: rotate(360deg); } }
.tm-card h3 { font-size: 1.12rem; margin-bottom: 2px; }
.tm-card h3 a { color: var(--clr-h3); }
.tm-card h3 a:hover { color: var(--clr-primary); }
.tm-role { color: var(--clr-secondary); font-weight: 600; font-size: .88rem; }
.tm-social { display: flex; justify-content: center; gap: 8px; margin-top: 14px; }
.tm-social a { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; background: var(--clr-tab-bg); color: var(--clr-primary); transition: all .25s ease; }
.tm-social a:hover { background: var(--clr-primary); color: #fff; transform: translateY(-3px); }
.tm-hidden { display: none !important; }

/* Team member detail — profile layout */
.td-section { padding-top: 48px; padding-bottom: 64px; }
.td-wrap { max-width: 820px; margin: 0 auto; }
.td-back {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 22px;
    font-size: .92rem;
    font-weight: 600;
    color: var(--clr-h5);
    text-decoration: none;
    transition: color .2s ease;
}
.td-back:hover { color: var(--clr-primary); }
.td-card {
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}
.td-profile {
    display: flex;
    align-items: flex-start;
    gap: 28px;
    padding: 32px 36px;
    background: linear-gradient(135deg, #f8fafc 0%, #fff 55%);
    border-bottom: 1px solid var(--clr-border);
}
.td-avatar {
    position: relative;
    flex: 0 0 132px;
    width: 132px;
    height: 132px;
}
.td-avatar::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: conic-gradient(from 0deg, var(--clr-primary), var(--clr-secondary), var(--clr-accent), var(--clr-primary));
    -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 5px));
            mask: radial-gradient(farthest-side, transparent calc(100% - 5px), #000 calc(100% - 5px));
}
.td-avatar img {
    position: absolute;
    inset: 8px;
    width: calc(100% - 16px);
    height: calc(100% - 16px);
    border-radius: 50%;
    object-fit: cover;
    box-shadow: var(--shadow-sm);
    background: #e2e8f0;
}
.td-profile__meta { flex: 1; min-width: 0; padding-top: 4px; }
.td-profile__badge {
    display: inline-block;
    margin-bottom: 10px;
    padding: 4px 12px;
    border-radius: 999px;
    background: rgba(14, 165, 233, .1);
    color: var(--clr-primary);
    font-size: .75rem;
    font-weight: 700;
    letter-spacing: .02em;
    text-transform: uppercase;
}
.td-profile__name {
    margin: 0 0 6px;
    font-size: clamp(1.45rem, 3vw, 1.85rem);
    line-height: 1.2;
    color: var(--clr-h2);
}
.td-profile__role {
    margin: 0 0 10px;
    font-size: 1rem;
    font-weight: 600;
    color: var(--clr-secondary);
}
.td-profile__tagline {
    margin: 0 0 16px;
    font-size: .95rem;
    line-height: 1.65;
    color: var(--clr-h5);
    max-width: 52ch;
}
.td-profile__social {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.td-profile__social a {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #fff;
    border: 1px solid var(--clr-border);
    color: var(--clr-primary);
    transition: all .22s ease;
}
.td-profile__social a:hover {
    background: var(--clr-primary);
    border-color: var(--clr-primary);
    color: #fff;
    transform: translateY(-2px);
}
.td-body { padding: 32px 36px 36px; }
.td-body__title {
    margin: 0 0 16px;
    font-size: 1.25rem;
    color: var(--clr-h3);
}
.td-prose {
    font-size: .98rem;
    line-height: 1.85;
    color: var(--clr-h5);
}
.td-prose p + p { margin-top: 14px; }
@media (max-width: 640px) {
    .td-profile {
        flex-direction: column;
        align-items: center;
        text-align: center;
        padding: 28px 22px;
    }
    .td-avatar { flex: 0 0 auto; }
    .td-profile__tagline { max-width: none; }
    .td-profile__social { justify-content: center; }
    .td-body { padding: 26px 22px 30px; }
}

/* ---------- Progress / campaign ---------- */
.progress-x { height: 10px; border-radius: 8px; background: #e3e9f5; overflow: hidden; }
.progress-x__bar { height: 100%; border-radius: 8px; background: linear-gradient(90deg, var(--clr-secondary), #ffb74d); }
.campaign-stats { display: flex; justify-content: space-between; font-size: .85rem; color: var(--clr-h5); margin-top: 8px; }

/* =====================================================
   ACCORDION (FAQ)
   ===================================================== */
.accordion-x { max-width: 820px; margin: 0 auto; display: grid; gap: 12px; }
.acc-item { background: #fff; border: 1px solid var(--clr-border); border-radius: 12px; overflow: hidden; }
.acc-head { width: 100%; text-align: left; background: none; border: none; padding: 16px 20px; font-weight: 600; color: var(--clr-h3); display: flex; justify-content: space-between; align-items: center; gap: 12px; cursor: pointer; font-size: 1rem; }
.acc-head i { color: var(--clr-secondary); transition: transform .25s ease; }
.acc-item.open .acc-head i { transform: rotate(45deg); }
.acc-body { display: none; padding: 0 20px 18px; color: var(--clr-subheading); }
.acc-item.open .acc-body { display: block; }

/* =====================================================
   HOME — FAQ accordion
   ===================================================== */
.home-faq { padding-bottom: 52px; }
.home-faq__eyebrow {
    display: block; margin-bottom: 8px;
    font-size: .72rem; font-weight: 700; letter-spacing: .14em;
    text-transform: uppercase; color: var(--clr-primary);
}
.home-faq .section-head { margin-bottom: 28px; }
.home-faq__list {
    max-width: 720px; margin: 0 auto;
    display: grid; gap: 14px;
}
.home-faq__item {
    background: #fff;
    border: 1px solid rgba(13,43,90,.11);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 14px rgba(13,43,90,.04);
}
.home-faq__head {
    width: 100%; display: flex; align-items: center; gap: 14px;
    padding: 16px 18px; background: #fff; border: none;
    cursor: pointer; text-align: left;
}
.home-faq__qmark {
    flex: 0 0 38px; width: 38px; height: 38px; border-radius: 10px;
    background: var(--clr-primary); color: #fff;
    display: grid; place-items: center; font-size: .92rem;
}
.home-faq__question {
    flex: 1; font-weight: 700; color: var(--clr-primary);
    font-size: .96rem; line-height: 1.45; font-family: var(--font-heading);
}
.home-faq__toggle {
    flex: 0 0 34px; width: 34px; height: 34px; border-radius: 50%;
    background: rgba(13,43,90,.08); color: var(--clr-primary);
    display: grid; place-items: center; font-size: .72rem;
    transition: transform .25s ease, background .25s ease, color .25s ease;
}
.home-faq__item.open .home-faq__toggle {
    background: var(--clr-primary); color: #fff;
    transform: rotate(180deg);
}
.home-faq__body {
    display: none;
    padding: 4px 18px 18px 70px;
    background: #faf6f1;
    color: var(--clr-subheading);
    line-height: 1.65; font-size: .92rem;
}
.home-faq__item.open .home-faq__body { display: block; }
.home-faq__body p:last-child { margin-bottom: 0; }

.home-faq__foot {
    display: flex; justify-content: center; margin-top: 28px;
}
.home-faq__foot .btn-thm {
    min-width: 220px; padding: .72rem 1.5rem;
    text-transform: uppercase; letter-spacing: .04em;
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}

@media (max-width: 600px) {
    .home-faq__head { padding: 14px 14px; gap: 10px; }
    .home-faq__qmark { flex-basis: 34px; width: 34px; height: 34px; font-size: .82rem; }
    .home-faq__question { font-size: .88rem; }
    .home-faq__body { padding: 4px 14px 16px 14px; }
}

/* FAQ categories + filter */
.faq-filter { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; max-width: 820px; margin: 0 auto 38px; }
.faq-pill {
    border: 1px solid var(--clr-border); background: #fff; color: var(--clr-nav-text);
    padding: 8px 18px; border-radius: 50px; font-weight: 600; font-size: .9rem; cursor: pointer;
    transition: all .2s ease;
}
.faq-pill:hover { border-color: var(--clr-secondary); color: var(--clr-secondary); }
.faq-pill.is-active { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }
.faq-group { max-width: 820px; margin: 0 auto 34px; }
.faq-group__title { font-size: 1.3rem; margin-bottom: 14px; color: var(--clr-h3); display: flex; align-items: center; gap: 10px; }
.faq-group__title::before { content: ""; width: 6px; height: 22px; border-radius: 4px; background: var(--clr-secondary); }

/* =====================================================
   FORMS — moved to public/web/css/public-forms.css
   (single global stylesheet for all public forms)
   ===================================================== */

/* ---------- Section tabs / filters ---------- */
.pill-tabs { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 30px; }
.pill-tabs a { background: var(--clr-tab-bg); color: var(--clr-tab-text); padding: 8px 18px; border-radius: 50px; font-weight: 600; font-size: .88rem; }
.pill-tabs a.active, .pill-tabs a:hover { background: var(--clr-tab-active-bg); color: var(--clr-tab-active-text); }

/* ---------- Info list (contact/branches) ---------- */
.info-row { display: flex; gap: 14px; align-items: flex-start; margin-bottom: 18px; }
.info-row__icon { width: 46px; height: 46px; flex: 0 0 46px; border-radius: 12px; background: var(--clr-tab-bg); color: var(--clr-primary); display: grid; place-items: center; font-size: 1.1rem; }
.info-row__text h4 { margin: 0 0 2px; font-size: 1rem; color: var(--clr-h3); }
.info-row__text p { margin: 0; color: var(--clr-subheading); font-size: .92rem; }

/* ---------- Partner / logo strip ---------- */
.logo-strip { display: flex; flex-wrap: wrap; gap: 30px; align-items: center; justify-content: center; }
.logo-strip img { max-height: 64px; filter: grayscale(1); opacity: .65; transition: all .25s ease; }
.logo-strip img:hover { filter: none; opacity: 1; }

/* ---------- Testimonial ---------- */
.tcard { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 26px; box-shadow: var(--shadow-sm); height: 100%; }
.tcard__quote { color: var(--clr-secondary); font-size: 1.8rem; }
.tcard__text { color: var(--clr-h4); font-style: italic; }
.tcard__person { display: flex; align-items: center; gap: 12px; margin-top: 16px; border-top: 1px solid var(--clr-border); padding-top: 14px; }
.tcard__person img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; }
.tcard__person strong { color: var(--clr-h3); display: block; }
.tcard__person span { font-size: .82rem; color: var(--clr-h6); }

/* ---------- Detail page sidebar ---------- */
.detail-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 36px; align-items: start; }
/* Prevent grid/flex children (e.g. the campaign swiper) from blowing out the column width. */
.detail-grid > * { min-width: 0; }
@media (max-width: 900px) { .detail-grid { grid-template-columns: 1fr; } }
.sidebar-box { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow-sm); margin-bottom: 24px; }
.sidebar-box h3 { font-size: 1.15rem; border-bottom: 2px solid var(--clr-tab-bg); padding-bottom: 10px; margin-bottom: 14px; }
.recent-item { display: flex; gap: 12px; margin-bottom: 14px; }
.recent-item img { width: 64px; height: 64px; border-radius: 10px; object-fit: cover; flex: 0 0 64px; }
.recent-item h4 { font-size: .92rem; margin: 0 0 2px; }
.recent-item span { font-size: .78rem; color: var(--clr-h6); }

/* ---------- Gallery ---------- */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 700px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }
.gallery-item { display: block; border-radius: 12px; overflow: hidden; aspect-ratio: 4/3; background: #dfe7f5; position: relative; cursor: pointer; }
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.gallery-item:hover img { transform: scale(1.08); }
.gallery-item__zoom {
    position: absolute; inset: 0; display: grid; place-items: center; color: #fff; font-size: 1.3rem;
    background: rgba(13,43,90,.35); opacity: 0; transition: opacity .25s ease;
}
.gallery-item:hover .gallery-item__zoom { opacity: 1; }
.gallery-item__caption {
    position: absolute; left: 0; right: 0; bottom: 0; padding: 26px 14px 12px; color: #fff; font-weight: 600; font-size: .9rem;
    background: linear-gradient(transparent, rgba(13,43,90,.85)); transform: translateY(101%); transition: transform .25s ease;
}
.gallery-item:hover .gallery-item__caption { transform: translateY(0); }

/* Press release detail gallery */
.pr-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.pr-gallery__item { position: relative; display: block; border-radius: 12px; overflow: hidden; aspect-ratio: 4/3; background: #dfe7f5; cursor: pointer; }
.pr-gallery__item img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.pr-gallery__item:hover img { transform: scale(1.08); }
.pr-gallery__zoom {
    position: absolute; inset: 0; display: grid; place-items: center; color: #fff; font-size: 1.2rem;
    background: rgba(13,43,90,.35); opacity: 0; transition: opacity .25s ease;
}
.pr-gallery__item:hover .pr-gallery__zoom { opacity: 1; }
@media (max-width: 640px) { .pr-gallery { grid-template-columns: repeat(2, 1fr); } }

/* Media (gallery/video) category filter pills */
.media-filter { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; max-width: 920px; margin: 0 auto 38px; }
.media-pill {
    border: 1px solid var(--clr-border); background: #fff; color: var(--clr-nav-text);
    padding: 8px 18px; border-radius: 50px; font-weight: 600; font-size: .9rem; cursor: pointer; transition: all .2s ease;
}
.media-pill:hover { border-color: var(--clr-secondary); color: var(--clr-secondary); }
.media-pill.is-active { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }

/* Video thumbnails */
.video-thumb { position: relative; }
.video-thumb__placeholder { position: absolute; inset: 0; display: grid; place-items: center; font-size: 2.4rem; color: #fff; background: linear-gradient(135deg, var(--clr-primary), var(--clr-secondary)); }
.video-thumb__play {
    position: absolute; inset: 0; margin: auto; width: 60px; height: 60px; border-radius: 50%;
    display: grid; place-items: center; font-size: 1.25rem; color: var(--clr-primary);
    background: rgba(255,255,255,.92); box-shadow: 0 6px 20px rgba(0,0,0,.25); transition: transform .25s ease, background .25s ease;
}
.card-thm:hover .video-thumb__play { transform: scale(1.1); background: #fff; }

/* Lightbox */
.lightbox { position: fixed; inset: 0; z-index: 1200; display: none; align-items: center; justify-content: center; padding: 24px; background: rgba(8,18,40,.9); }
.lightbox.open { display: flex; }
.lightbox__content { position: relative; max-width: 960px; width: 100%; max-height: 86vh; display: flex; align-items: center; justify-content: center; }
.lightbox--video .lightbox__content { max-width: min(1000px, 96vw); width: 100%; }
.lightbox--video .lightbox__stage { width: 100%; }
.lightbox__content img { max-width: 100%; max-height: 86vh; border-radius: 10px; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.lightbox__frame { position: relative; width: 100%; aspect-ratio: 16/9; }
.lightbox__frame iframe, .lightbox__frame video { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; border-radius: 10px; background: #000; }
.lightbox__close {
    position: absolute; top: -14px; right: -14px; width: 42px; height: 42px; border-radius: 50%; border: none; cursor: pointer;
    background: #fff; color: var(--clr-primary); font-size: 1.1rem; box-shadow: 0 6px 18px rgba(0,0,0,.3); z-index: 2;
}
.lightbox__close:hover { background: var(--clr-secondary); color: #fff; }
.lightbox__nav {
    position: absolute; top: 50%; transform: translateY(-50%); width: 44px; height: 44px; border-radius: 50%; border: none;
    cursor: pointer; background: rgba(255,255,255,.92); color: var(--clr-primary); font-size: 1rem;
    box-shadow: 0 6px 18px rgba(0,0,0,.3); z-index: 2; transition: background .2s ease, color .2s ease;
}
.lightbox__nav:hover { background: var(--clr-secondary); color: #fff; }
.lightbox__nav--prev { left: -56px; }
.lightbox__nav--next { right: -56px; }
.lightbox__meta {
    position: absolute; left: 0; right: 0; bottom: -42px; display: flex; align-items: center; justify-content: space-between;
    gap: 12px; margin: 0; color: #fff; font-size: .9rem;
}
.lightbox__caption { opacity: .92; }
.lightbox__counter { font-weight: 600; white-space: nowrap; }
@media (max-width: 768px) {
    .lightbox__nav--prev { left: 8px; }
    .lightbox__nav--next { right: 8px; }
    .lightbox__meta { bottom: 12px; padding: 0 56px; }
}
@media (max-width: 576px) { .lightbox__close { top: 8px; right: 8px; } }

/* ---- Awards page ---- */
.award-card { text-align: center; overflow: hidden; }
.award-card__img { aspect-ratio: 3/4; position: relative; }
.award-card__photo {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    cursor: zoom-in;
    overflow: hidden;
}
.award-card__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .35s ease;
}
.award-card__photo:hover img { transform: scale(1.05); }
.award-card__zoom {
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(13, 43, 90, .78);
    color: #fff;
    font-size: .85rem;
    opacity: 0;
    transform: translateY(6px);
    transition: opacity .2s ease, transform .2s ease;
}
.award-card__photo:hover .award-card__zoom,
.award-card__photo:focus-visible .award-card__zoom {
    opacity: 1;
    transform: translateY(0);
}
.award-card__body { padding-top: 14px; }
.award-card__title { font-size: 1rem; margin-bottom: 6px; }
.award-card__text { font-size: .85rem; color: var(--clr-subheading); line-height: 1.55; }
.award-card__read-more {
    margin-top: 10px;
    border: none;
    background: none;
    padding: 0;
    color: var(--clr-primary);
    font-size: .84rem;
    font-weight: 700;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.award-card__read-more:hover { color: var(--clr-secondary); }

.award-read-modal {
    position: fixed;
    inset: 0;
    z-index: 1250;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 20px;
    background: rgba(8, 18, 40, .88);
}
.award-read-modal.open { display: flex; }
.award-read-modal__dialog {
    position: relative;
    width: min(560px, 100%);
    max-height: 86vh;
    overflow: auto;
    background: #fff;
    border-radius: 16px;
    box-shadow: var(--shadow-md);
}
.award-read-modal__close {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 2;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 50%;
    background: rgba(255,255,255,.95);
    color: var(--clr-h3);
    cursor: pointer;
    box-shadow: var(--shadow-sm);
}
.award-read-modal__close:hover { background: var(--clr-primary); color: #fff; }
.award-read-modal__media img {
    display: block;
    width: 100%;
    max-height: 280px;
    object-fit: cover;
    border-radius: 16px 16px 0 0;
}
.award-read-modal__body { padding: 22px 24px 24px; }
.award-read-modal__body h3 {
    margin: 8px 0 12px;
    font-size: 1.2rem;
    color: var(--clr-h1);
}
.award-read-modal__text {
    font-size: .92rem;
    line-height: 1.7;
    color: var(--clr-h4);
    white-space: pre-wrap;
}

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer {
    position: relative;
    background: linear-gradient(160deg, #0a3578 0%, var(--clr-footer-bg) 45%, #08306e 100%);
    color: var(--clr-footer-text);
    overflow: hidden;
}
.site-footer a { color: #cdddff; }
.site-footer a:hover { color: var(--clr-secondary); }

/* animated glow blobs in the background */
.site-footer::before,
.site-footer::after {
    content: ""; position: absolute; border-radius: 50%; filter: blur(10px); pointer-events: none; z-index: 0;
}
.site-footer::before { width: 320px; height: 320px; top: -120px; right: -80px; background: radial-gradient(circle, rgba(66,165,245,.28), transparent 70%); animation: ftFloat 9s ease-in-out infinite; }
.site-footer::after { width: 300px; height: 300px; bottom: -120px; left: -70px; background: radial-gradient(circle, rgba(251,140,0,.22), transparent 70%); animation: ftFloat 11s ease-in-out infinite reverse; }
@keyframes ftFloat { 0%,100% { transform: translate(0,0); } 50% { transform: translate(24px,-24px); } }

/* animated top accent line */
.site-footer__line { height: 4px; background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary), var(--clr-accent), var(--clr-secondary), var(--clr-primary)); background-size: 200% 100%; animation: ftSlide 6s linear infinite; position: relative; z-index: 2; }
@keyframes ftSlide { to { background-position: 200% 0; } }

/* newsletter strip */
.footer-news { position: relative; z-index: 2; border-bottom: 1px solid rgba(255,255,255,.12); }
.footer-news__inner { display: flex; align-items: center; justify-content: space-between; gap: 22px; flex-wrap: wrap; padding: 26px 0; }
.footer-news h3 { color: #fff; margin: 0 0 2px; font-size: 1.3rem; }
.footer-news p { color: #bcd0f5; margin: 0; }
.footer-news form { display: flex; gap: 10px; flex: 1; min-width: 280px; max-width: 460px; }
.footer-news input { flex: 1; padding: 12px 16px; border-radius: 50px; border: 1px solid rgba(255,255,255,.2); background: rgba(255,255,255,.08); color: #fff; }
.footer-news input::placeholder { color: #b7c8ea; }
.footer-news input:focus { outline: none; border-color: var(--clr-secondary); background: rgba(255,255,255,.14); }
.footer-news__msg { margin: 8px 0 0; font-size: .88rem; color: #aef0c4; }
.footer-news__msg--err { color: #ffcdd2; }

/* Global confirmation toasts (form submissions) */
.toast-stack { position: fixed; top: 22px; right: 22px; z-index: 9999; display: flex; flex-direction: column; gap: 12px; max-width: min(380px, calc(100vw - 32px)); pointer-events: none; }
.toast-pop {
    position: relative; display: flex; align-items: flex-start; gap: 12px;
    padding: 14px 40px 14px 16px; border-radius: 14px; background: #fff; color: var(--clr-h4, #1f2d3d);
    box-shadow: 0 16px 40px rgba(13, 43, 90, .22); border-left: 5px solid var(--clr-primary, #1565c0);
    overflow: hidden; pointer-events: auto; transform: translateX(120%); opacity: 0;
    animation: toastIn .55s cubic-bezier(.21, 1.02, .73, 1) forwards;
}
.toast-pop--success { border-left-color: #1faa59; }
.toast-pop--error { border-left-color: #e23d3d; }
.toast-pop.is-hiding { animation: toastOut .4s ease forwards; }
.toast-pop__icon { flex-shrink: 0; font-size: 1.35rem; line-height: 1.4; }
.toast-pop--success .toast-pop__icon { color: #1faa59; }
.toast-pop--error .toast-pop__icon { color: #e23d3d; }
.toast-pop__msg { margin: 0; font-size: .92rem; font-weight: 600; line-height: 1.45; }
.toast-pop__close {
    position: absolute; top: 8px; right: 10px; border: 0; background: transparent;
    font-size: 1.25rem; line-height: 1; color: #9aa7b6; cursor: pointer; transition: color .2s;
}
.toast-pop__close:hover { color: #485563; }
.toast-pop__bar { position: absolute; left: 0; bottom: 0; height: 3px; width: 100%; transform-origin: left; background: currentColor; opacity: .35; animation: toastBar 5s linear forwards; }
.toast-pop--success .toast-pop__bar { color: #1faa59; }
.toast-pop--error .toast-pop__bar { color: #e23d3d; }
@keyframes toastIn { 0% { transform: translateX(120%); opacity: 0; } 60% { transform: translateX(-6px); opacity: 1; } 100% { transform: translateX(0); opacity: 1; } }
@keyframes toastOut { to { transform: translateX(120%); opacity: 0; } }
@keyframes toastBar { from { transform: scaleX(1); } to { transform: scaleX(0); } }
@media (max-width: 575px) {
    .toast-stack { top: 12px; right: 12px; left: 12px; max-width: none; }
    .toast-pop { transform: translateY(-130%); animation: toastInTop .5s cubic-bezier(.21,1.02,.73,1) forwards; }
    .toast-pop.is-hiding { animation: toastOutTop .35s ease forwards; }
}
@keyframes toastInTop { 0% { transform: translateY(-130%); opacity: 0; } 100% { transform: translateY(0); opacity: 1; } }
@keyframes toastOutTop { to { transform: translateY(-130%); opacity: 0; } }

/* Google Translate widget (topbar) */
.topbar__translate { display: inline-flex; align-items: center; gap: 6px; }
.topbar__translate > i { font-size: .9rem; opacity: .85; }
.topbar__translate .goog-te-gadget { font-size: 0 !important; color: transparent !important; }
.topbar__translate .goog-te-gadget .goog-te-combo {
    margin: 0 !important; padding: 2px 6px; font-size: .8rem; line-height: 1.2;
    border: 1px solid rgba(255,255,255,.35); border-radius: 6px;
    background: rgba(255,255,255,.12); color: #fff; cursor: pointer; max-width: 150px;
}
.topbar__translate .goog-te-combo option { color: #1a1a1a; }
/* Hide Google's injected top banner & keep body from shifting */
.goog-te-banner-frame.skiptranslate, .goog-te-gadget-icon { display: none !important; }
body { top: 0 !important; }
#goog-gt-tt, .goog-te-balloon-frame { display: none !important; }
.goog-text-highlight { background: none !important; box-shadow: none !important; }

.footer-top { position: relative; z-index: 2; padding: 56px 0 30px; }
.footer-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.4fr; gap: 32px; }
@media (max-width: 992px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-col h3 { color: #fff; font-size: 1.1rem; margin-bottom: 8px; }
.footer-col .fbar { width: 46px; height: 3px; background: var(--clr-secondary); margin-bottom: 16px; position: relative; overflow: hidden; border-radius: 3px; }
.footer-col .fbar::after { content: ""; position: absolute; top: 0; left: -50%; width: 50%; height: 100%; background: rgba(255,255,255,.7); animation: ftBar 2.6s ease-in-out infinite; }
@keyframes ftBar { 0% { left: -50%; } 60%,100% { left: 110%; } }
.footer-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.footer-col ul a { display: inline-flex; align-items: center; gap: 8px; transition: all .25s ease; }
.footer-col ul:not(.footer-contact) a::before { content: "\f105"; font-family: "Font Awesome 6 Free"; font-weight: 900; font-size: .75rem; color: var(--clr-secondary); transition: transform .25s ease; }
.footer-col ul:not(.footer-contact) a:hover { transform: translateX(6px); }
.footer-col ul:not(.footer-contact) a:hover::before { transform: translateX(3px); }
.footer-about p { color: #c6d6f5; }
.footer-contact li { display: flex; gap: 10px; color: #c6d6f5; margin-bottom: 12px; }
.footer-contact a { display: inline; gap: 0; }
.footer-contact a:hover { transform: none; }
.footer-contact a::before { content: none !important; display: none !important; }
.footer-contact i { color: var(--clr-secondary); margin-top: 4px; }
.footer-social { display: flex; gap: 10px; margin-top: 16px; }
.footer-social a { width: 40px; height: 40px; border-radius: 12px; background: rgba(255,255,255,.1); display: grid; place-items: center; color: #fff; transition: transform .3s ease, background .3s ease, box-shadow .3s ease; }
.footer-social a:hover { background: var(--clr-secondary); color: #fff; transform: translateY(-5px) rotate(-6deg); box-shadow: 0 10px 20px rgba(251,140,0,.4); }
.footer-donate { margin-top: 16px; display: inline-flex; }
.footer-contact-sep { color: #c6d6f5; }
.footer-bottom { position: relative; z-index: 2; border-top: 1px solid rgba(255,255,255,.14); padding: 16px 0; text-align: center; font-size: .85rem; color: #bcd0f5; }
.footer-bottom__inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 8px 18px; }
.footer-policy { display: flex; flex-wrap: wrap; align-items: center; gap: 6px 16px; list-style: none; margin: 0; padding: 0; }
.footer-policy li { position: relative; }
.footer-policy li + li::before { content: ""; position: absolute; left: -9px; top: 50%; transform: translateY(-50%); width: 1px; height: 12px; background: rgba(255,255,255,.25); }
.footer-policy a { color: #bcd0f5; transition: color .2s ease; }
.footer-policy a:hover { color: #fff; }
@media (max-width: 640px) { .footer-bottom__inner { flex-direction: column; justify-content: center; } }

/* back to top */
.back-top { position: fixed; right: 22px; bottom: 22px; width: 48px; height: 48px; border-radius: 50%; border: none; background: var(--clr-secondary); color: #fff; font-size: 1.1rem; cursor: pointer; box-shadow: var(--shadow-md); opacity: 0; visibility: hidden; transform: translateY(16px); transition: all .3s ease; z-index: 1090; }
.back-top.show { opacity: 1; visibility: visible; transform: translateY(0); }
.back-top:hover { background: var(--clr-primary); transform: translateY(-3px); }

/* =====================================================
   CONTACT PAGE (hrcofindia-style)
   ===================================================== */
.contact-cards { padding: 60px 0 10px; }
.contact-card {
    border-radius: 16px; padding: 24px; height: 100%;
    display: flex; flex-direction: row; align-items: center; gap: 20px;
    transition: all .3s ease; border: 2px solid; box-shadow: var(--shadow-sm);
}
.contact-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.contact-card__icon { width: 56px; height: 56px; min-width: 56px; border-radius: 12px; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 22px; flex-shrink: 0; }
.contact-card__body { flex: 1; min-width: 0; }
.contact-card__value { font-size: 15px; line-height: 1.5; word-break: break-word; }
.contact-card__value a { color: inherit; display: block; margin-bottom: 4px; }
.contact-card__value a:hover { text-decoration: underline; }
.contact-card__value p { margin: 0; }
/* Phone (primary blue) */
.contact-card--phone { background: linear-gradient(135deg, #e7f0fc 0%, #cfe2fa 100%); border-color: var(--clr-primary); }
.contact-card--phone .contact-card__icon { background: linear-gradient(135deg, var(--clr-primary), var(--clr-footer-bg)); }
.contact-card--phone .contact-card__value { color: var(--clr-h1); }
/* Email (secondary orange) */
.contact-card--email { background: linear-gradient(135deg, #fff4e6 0%, #ffe2c2 100%); border-color: var(--clr-secondary); }
.contact-card--email .contact-card__icon { background: linear-gradient(135deg, var(--clr-secondary), #ef6c00); }
.contact-card--email .contact-card__value, .contact-card--email .contact-card__value a { color: #8a4b00; }
/* Address (accent light blue) */
.contact-card--address { background: linear-gradient(135deg, #eaf4ff 0%, #d6ebff 100%); border-color: var(--clr-accent); }
.contact-card--address .contact-card__icon { background: linear-gradient(135deg, var(--clr-accent), var(--clr-primary)); }
.contact-card--address .contact-card__value, .contact-card--address .contact-card__value p { color: var(--clr-h1); }

/* Follow us */
.contact-social-section { padding: 30px 0 50px; text-align: center; }
.contact-social-title { font-size: 1.5rem; color: var(--clr-h1); margin-bottom: 1.5rem; position: relative; padding-bottom: 1rem; }
.contact-social-title::after { content: ''; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 80px; height: 3px; background: var(--clr-secondary); border-radius: 2px; }
.contact-social-icons { display: flex; justify-content: center; align-items: center; gap: 1rem; flex-wrap: wrap; }
.contact-social-icon { width: 50px; height: 50px; border-radius: 12px; background: var(--clr-tab-bg); color: var(--clr-primary); display: inline-flex; align-items: center; justify-content: center; font-size: 20px; transition: all .3s ease; border: 2px solid transparent; }
.contact-social-icon:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); color: #fff; background: var(--clr-primary); border-color: var(--clr-primary); }
.contact-social-icon.facebook:hover { background: #1877f2; border-color: #1877f2; }
.contact-social-icon.twitter:hover { background: #111; border-color: #111; }
.contact-social-icon.instagram:hover { background: linear-gradient(135deg, #e4405f, #c13584 50%, #833ab4); border-color: #e4405f; }
.contact-social-icon.linkedin:hover { background: #0077b5; border-color: #0077b5; }
.contact-social-icon.youtube:hover { background: #ff0000; border-color: #ff0000; }

/* Map + Form */
.contact-map-form { padding: 0 0 70px; }
.contact-map-card, .contact-form-card { border-radius: 16px; border: 2px solid var(--clr-border); background: #fff; box-shadow: var(--shadow-sm); overflow: hidden; transition: all .3s ease; height: 100%; }
.contact-map-card:hover, .contact-form-card:hover { box-shadow: var(--shadow-md); }
.contact-map-card { min-height: 500px; display: flex; flex-direction: column; }
.contact-map-frame { position: relative; flex: 1; min-height: 500px; }
.contact-map-frame iframe { display: block; width: 100%; height: 100%; min-height: 500px; border: 0; }
.contact-map-open { margin: 0; padding: 10px 14px; border-top: 1px solid var(--clr-border); background: var(--clr-tab-bg, #f8fafc); text-align: center; font-size: .88rem; }
.contact-map-open a { color: var(--clr-primary); font-weight: 600; text-decoration: none; }
.contact-map-open a:hover { text-decoration: underline; }
.contact-form-card { padding: 28px; }
.contact-form-title { font-size: 1.25rem; color: var(--clr-h1); margin-bottom: 1.5rem; padding-bottom: .75rem; border-bottom: 2px solid var(--clr-primary); display: flex; align-items: center; gap: 10px; }
.contact-form-title i { color: var(--clr-primary); }
.contact-grid-5050 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }

/* ---- Donor receipt verification ---- */
.donor-verify { padding: 0 0 70px; }
.donor-verify__box { max-width: 640px; margin: 0 auto; }
.donor-verify__card {
    background: #fff;
    border: 2px solid var(--clr-border);
    border-radius: 16px;
    box-shadow: var(--shadow-sm);
    padding: 28px;
}
.donor-verify__head { display: flex; gap: 16px; align-items: flex-start; margin-bottom: 22px; }
.donor-verify__icon {
    width: 52px; height: 52px; flex: 0 0 auto; border-radius: 14px;
    display: grid; place-items: center; font-size: 1.35rem;
    background: var(--clr-primary); color: #fff;
}
.donor-verify__head h2 { margin: 0 0 6px; font-size: 1.25rem; color: var(--clr-h1); }
.donor-verify__head p { margin: 0; font-size: .9rem; color: var(--clr-subheading); line-height: 1.5; }
.donor-verify__result { margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--clr-border); }
.donor-verify__result--ok { }
.donor-verify__badge {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 14px; border-radius: 999px;
    background: #dcfce7; color: #166534; font-weight: 700; font-size: .85rem;
}
.donor-verify__lead { margin: 14px 0 18px; color: var(--clr-subheading); font-size: .92rem; }
.donor-verify__details {
    display: grid; grid-template-columns: 1fr 1fr; gap: 14px 20px; margin: 0;
}
.donor-verify__details > div { min-width: 0; }
.donor-verify__details dt { margin: 0 0 4px; font-size: .78rem; color: var(--clr-subheading); font-weight: 600; text-transform: uppercase; letter-spacing: .02em; }
.donor-verify__details dd { margin: 0; font-size: .95rem; color: var(--clr-h3); font-weight: 600; word-break: break-word; }
.donor-verify__details code { font-family: ui-monospace, monospace; font-size: .88rem; background: var(--clr-tab-bg); padding: 2px 8px; border-radius: 6px; }
.donor-verify__amount { font-size: 1.35rem !important; color: var(--clr-primary) !important; }
.donor-verify__status {
    display: inline-block; padding: 3px 10px; border-radius: 999px;
    background: #dcfce7; color: #166534; font-size: .82rem;
}
.donor-verify__items { margin-top: 20px; padding-top: 16px; border-top: 1px dashed var(--clr-border); }
.donor-verify__items h3 { margin: 0 0 10px; font-size: .95rem; color: var(--clr-h3); }
.donor-verify__items ul { list-style: none; margin: 0; padding: 0; }
.donor-verify__items li {
    display: flex; justify-content: space-between; gap: 12px;
    padding: 8px 0; border-bottom: 1px solid var(--clr-border); font-size: .88rem;
}
.donor-verify__items li:last-child { border-bottom: 0; }
.donor-verify__items small { color: var(--clr-subheading); }
.donor-verify__result--fail { text-align: center; padding-bottom: 8px; }
.donor-verify__fail-icon {
    display: inline-flex; width: 72px; height: 72px; border-radius: 50%;
    align-items: center; justify-content: center; font-size: 2rem;
    background: #fee2e2; color: #dc2626; margin-bottom: 12px;
}
.donor-verify__result--fail h3 { margin: 0 0 8px; color: var(--clr-h2); }
.donor-verify__result--fail p { margin: 0; color: var(--clr-subheading); font-size: .9rem; line-height: 1.55; }
.donor-verify__note {
    margin: 18px 0 0; padding: 14px 16px; border-radius: 12px;
    background: var(--clr-tab-bg); color: var(--clr-subheading); font-size: .84rem; line-height: 1.55;
}
.donor-verify__note a { color: var(--clr-primary); font-weight: 600; text-decoration: none; }
.donor-verify__note a:hover { text-decoration: underline; }
@media (max-width: 575px) {
    .donor-verify__details { grid-template-columns: 1fr; }
    .donor-verify__card { padding: 20px; }
}
@media (max-width: 900px) { .contact-grid-5050 { grid-template-columns: 1fr; } }

/* ---------- Utilities ---------- */
.text-center { text-align: center; }
.mt-1 { margin-top: .5rem; } .mt-2 { margin-top: 1rem; } .mt-3 { margin-top: 1.5rem; } .mt-4 { margin-top: 2rem; }
.mb-0 { margin-bottom: 0; } .mb-2 { margin-bottom: 1rem; } .mb-3 { margin-bottom: 1.5rem; }
.lead { font-size: 1.1rem; color: var(--clr-subheading); }
.badge-x { display: inline-block; background: var(--clr-tab-bg); color: var(--clr-primary); padding: 3px 12px; border-radius: 50px; font-size: .78rem; font-weight: 600; }
.alert-x { background: #e8f5e9; border: 1px solid #a5d6a7; color: #2e7d32; padding: 12px 16px; border-radius: 10px; margin-bottom: 18px; }
.wow-fade { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
.wow-fade.in { opacity: 1; transform: none; }

/* =====================================================
   CAREER PAGE — alerts, empty state, apply modal/form
   ===================================================== */
.alert-x--success { background: #e8f5e9; border-color: #a5d6a7; color: #2e7d32; }
.alert-x--error { background: #fdecea; border: 1px solid #f5b7b1; color: #c0392b; }

.empty-x { text-align: center; padding: 56px 20px; background: var(--clr-surface); border: 1px dashed var(--clr-border); border-radius: var(--radius); }
.empty-x i { font-size: 2.4rem; color: var(--clr-accent); margin-bottom: 12px; }
.empty-x h3 { color: var(--clr-h2); margin-bottom: 6px; }
.empty-x p { color: var(--clr-subheading); margin: 0; }

/* apply modal */
.apply-modal { position: fixed; inset: 0; z-index: 1200; display: none; }
.apply-modal.show { display: block; }
.apply-modal__overlay { position: absolute; inset: 0; background: rgba(13,43,90,.55); backdrop-filter: blur(2px); animation: amFade .3s ease; }
.apply-modal__dialog { position: relative; z-index: 2; width: min(720px, 94vw); max-height: 92vh; display: flex; flex-direction: column; margin: 4vh auto; background: var(--clr-surface); border-radius: var(--radius); box-shadow: var(--shadow-md); overflow: hidden; animation: amPop .35s cubic-bezier(.2,.8,.2,1); }
.apply-modal__dialog .apply-form { display: flex; flex-direction: column; min-height: 0; max-height: 92vh; }
@keyframes amFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes amPop { from { opacity: 0; transform: translateY(26px) scale(.97); } to { opacity: 1; transform: none; } }

/* header (separate) */
.apply-modal__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; padding: 20px 24px; background: linear-gradient(120deg, var(--clr-primary), var(--clr-h1)); color: #fff; flex: 0 0 auto; }
.apply-modal__title { color: #fff; margin: 0 0 4px; font-size: 1.2rem; }
.apply-modal__title i { color: var(--clr-secondary); }
.apply-modal__sub { color: rgba(255,255,255,.85); margin: 0; font-size: .9rem; }
.apply-modal__sub strong { color: var(--clr-secondary); }
.apply-modal__close { flex: 0 0 auto; width: 36px; height: 36px; border: none; border-radius: 50%; background: rgba(255,255,255,.18); color: #fff; cursor: pointer; transition: all .25s ease; }
.apply-modal__close:hover { background: var(--clr-secondary); color: #fff; transform: rotate(90deg); }

/* body (scrollable) */
.apply-modal__body { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 22px 24px; }

/* footer (separate, buttons) */
.apply-modal__footer { flex: 0 0 auto; display: flex; justify-content: flex-end; gap: 10px; padding: 16px 24px; border-top: 1px solid var(--clr-border); background: var(--clr-bg); }

.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 18px; }
@media (max-width: 560px) { .form-grid-2 { grid-template-columns: 1fr; } }
.field-x { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.field-x--full { grid-column: 1 / -1; }
.field-x label { font-size: .85rem; font-weight: 600; color: var(--clr-h4); }
.field-x label span { color: #e53935; }
.field-x input, .field-x textarea, .field-x select { width: 100%; max-width: 100%; height: 44px; padding: 10px 14px; border: 1px solid var(--clr-border); border-radius: 10px; font: inherit; color: var(--clr-para); background: #fff; transition: border-color .2s ease, box-shadow .2s ease; }
.field-x textarea { height: auto; min-height: 80px; resize: vertical; }
.field-x input:focus, .field-x textarea:focus, .field-x select:focus { outline: none; border-color: var(--clr-primary); box-shadow: 0 0 0 3px rgba(21,101,192,.12); }
.field-x .hint { font-size: .75rem; color: var(--clr-h6); }
.field-x .err { font-size: .78rem; color: #c0392b; }
.apply-form__actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }

/* modern file upload (resume) */
.filedrop { position: relative; display: flex; align-items: center; gap: 14px; width: 100%; padding: 16px; border: 2px dashed var(--clr-border); border-radius: 12px; background: var(--clr-bg); cursor: pointer; transition: border-color .25s ease, background .25s ease, transform .15s ease; }
.filedrop:hover { border-color: var(--clr-primary); background: #eef4ff; }
.filedrop input[type="file"] { position: absolute; width: 1px; height: 1px; opacity: 0; overflow: hidden; clip: rect(0 0 0 0); }
.filedrop__icon { flex: 0 0 auto; width: 46px; height: 46px; display: grid; place-items: center; border-radius: 50%; background: var(--clr-tab-bg); color: var(--clr-primary); font-size: 1.2rem; transition: all .25s ease; }
.filedrop:hover .filedrop__icon { background: var(--clr-primary); color: #fff; }
.filedrop__text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.filedrop__title { font-weight: 600; color: var(--clr-h4); font-size: .9rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.filedrop__hint { font-size: .76rem; color: var(--clr-h6); }
.filedrop.has-file { border-style: solid; border-color: #2e7d32; background: #e8f5e9; }
.filedrop.has-file .filedrop__icon { background: #2e7d32; color: #fff; }
.filedrop.has-file .filedrop__title { color: #2e7d32; }

.btn-thm--ghost { background: transparent; color: var(--clr-primary); border-color: var(--clr-border); }
.btn-thm--ghost:hover { background: var(--clr-bg); border-color: var(--clr-primary); color: var(--clr-primary); }

/* built-in captcha widget */
.captcha-field { margin-top: 14px; }
.captcha-field__label { display: block; font-size: .85rem; font-weight: 600; color: var(--clr-h4); margin-bottom: 6px; }
.captcha-field__label span { color: #e53935; }
.captcha-field__row { display: flex; align-items: stretch; gap: 10px; }
.captcha-field__q { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: var(--clr-tab-bg); color: var(--clr-primary); font-weight: 700; font-size: 1.05rem; letter-spacing: 1px; border-radius: 10px; user-select: none; white-space: nowrap; }
.captcha-field__q i { color: var(--clr-secondary); }
.captcha-field__input { width: 110px; padding: 10px 12px; border: 1px solid var(--clr-border); border-radius: 10px; font: inherit; color: var(--clr-para); background: #fff; transition: border-color .2s ease, box-shadow .2s ease; }
.captcha-field__input:focus { outline: none; border-color: var(--clr-primary); box-shadow: 0 0 0 3px rgba(21,101,192,.12); }
.captcha-field__err { display: block; margin-top: 6px; font-size: .78rem; color: #c0392b; }

/* live client-side validation feedback */
.field-live-err { display: block; margin-top: 5px; font-size: .78rem; color: #c0392b; }
.input-invalid { border-color: #e53935 !important; box-shadow: 0 0 0 3px rgba(229,57,53,.12) !important; }

/* =====================================================
   BLOG — filter pills, pagination, video embed, categories
   ===================================================== */
.filter-pills { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 28px; }
.filter-pill { display: inline-block; padding: 8px 18px; border-radius: 50px; background: var(--clr-surface); border: 1px solid var(--clr-border); color: var(--clr-h4); font-size: .9rem; font-weight: 600; transition: all .25s ease; }
.filter-pill:hover { border-color: var(--clr-primary); color: var(--clr-primary); transform: translateY(-2px); }
.filter-pill.is-active { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }

.pagination-x { display: flex; justify-content: center; }
.pagination-x nav > div:last-child { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.pagination-x a, .pagination-x span { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 12px; border-radius: 10px; border: 1px solid var(--clr-border); background: var(--clr-surface); color: var(--clr-h4); font-size: .9rem; font-weight: 600; transition: all .2s ease; }
.pagination-x a:hover { border-color: var(--clr-primary); color: var(--clr-primary); }
.pagination-x [aria-current] span { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }
.pagination-x .hidden { display: none; }

.video-embed { position: relative; width: 100%; padding-top: 56.25%; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.cat-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 4px; }
.cat-list a { display: flex; align-items: center; gap: 8px; padding: 9px 12px; border-radius: 8px; color: var(--clr-h4); transition: all .2s ease; }
.cat-list a i { color: var(--clr-secondary); transition: transform .2s ease; }
.cat-list a:hover { background: var(--clr-bg); color: var(--clr-primary); }
.cat-list a:hover i { transform: translateX(3px); }

/* =====================================================
   LEGAL & REGISTRATION cards
   ===================================================== */
.legal-card { position: relative; background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 28px 24px; text-align: center; box-shadow: var(--shadow-sm); overflow: hidden; transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.legal-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary)); transform: scaleX(0); transform-origin: left; transition: transform .35s ease; }
.legal-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: transparent; }
.legal-card:hover::before { transform: scaleX(1); }
.legal-card__icon { width: 70px; height: 70px; margin: 0 auto 16px; display: grid; place-items: center; border-radius: 50%; background: var(--clr-tab-bg); color: var(--clr-primary); font-size: 1.6rem; transition: all .35s ease; }
.legal-card:hover .legal-card__icon { background: var(--clr-primary); color: #fff; transform: rotateY(180deg); }
.legal-card__title { color: var(--clr-h2); font-size: 1.05rem; margin-bottom: 10px; }
.legal-card__value { display: inline-block; padding: 6px 16px; border-radius: 50px; background: var(--clr-bg); color: var(--clr-h4); font-weight: 700; letter-spacing: .5px; word-break: break-word; }

/* =====================================================
   PARTNER cards
   ===================================================== */
.partner-card { background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 22px 18px; text-align: center; box-shadow: var(--shadow-sm); transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease; }
.partner-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); border-color: var(--clr-accent); }
.partner-card__logo { height: 90px; display: grid; place-items: center; margin-bottom: 12px; }
.partner-card__logo img { max-height: 90px; max-width: 100%; object-fit: contain; filter: grayscale(1); opacity: .85; transition: filter .3s ease, opacity .3s ease, transform .3s ease; }
.partner-card:hover .partner-card__logo img { filter: grayscale(0); opacity: 1; transform: scale(1.05); }
.partner-card__initials { width: 72px; height: 72px; display: grid; place-items: center; border-radius: 50%; background: linear-gradient(135deg, var(--clr-primary), var(--clr-accent)); color: #fff; font-weight: 800; font-size: 1.4rem; letter-spacing: 1px; text-transform: uppercase; }
.partner-card__name { font-weight: 700; color: var(--clr-h3); font-size: .95rem; line-height: 1.35; }
.partner-card__type { margin-top: 4px; font-size: .78rem; color: var(--clr-h6); }

/* =====================================================
   VIDEO testimonial cards
   ===================================================== */
.vtcard { background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); transition: transform .3s ease, box-shadow .3s ease; }
.vtcard:hover { transform: translateY(-6px); box-shadow: var(--shadow-md); }
.vtcard__media { position: relative; aspect-ratio: 16/10; cursor: pointer; overflow: hidden; background: #0d2b5a; }
.vtcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease, filter .3s ease; }
.vtcard__media:hover img { transform: scale(1.06); filter: brightness(.85); }
.vtcard__play { position: absolute; inset: 0; margin: auto; width: 64px; height: 64px; border: none; border-radius: 50%; background: var(--clr-secondary); color: #fff; font-size: 1.3rem; cursor: pointer; display: grid; place-items: center; box-shadow: 0 8px 24px rgba(251,140,0,.45); transition: transform .25s ease, background .25s ease; animation: vtPulse 2s infinite; }
.vtcard__media:hover .vtcard__play { transform: scale(1.12); background: var(--clr-primary); }
@keyframes vtPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(251,140,0,.5); } 50% { box-shadow: 0 0 0 14px rgba(251,140,0,0); } }
.vtcard__body { padding: 16px 18px; }
.vtcard__body strong { display: block; color: var(--clr-h3); }
.vtcard__body span { font-size: .82rem; color: var(--clr-h6); }
.vtcard__iframe { position: relative; aspect-ratio: 16/10; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-md); }
.vtcard__iframe iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* =====================================================
   TABS (testimonials)
   ===================================================== */
.tab-nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-bottom: 32px; }
.tab-btn { display: inline-flex; align-items: center; gap: 8px; padding: 10px 22px; border-radius: 50px; border: 1px solid var(--clr-border); background: var(--clr-surface); color: var(--clr-h4); font-weight: 600; font-size: .95rem; cursor: pointer; transition: all .25s ease; }
.tab-btn i { color: var(--clr-secondary); }
.tab-btn:hover { border-color: var(--clr-primary); color: var(--clr-primary); transform: translateY(-2px); }
.tab-btn.is-active { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }
.tab-btn.is-active i { color: #fff; }
.tab-panel { display: none; animation: tabFade .4s ease; }
.tab-panel.is-active { display: block; }
@keyframes tabFade { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }

/* Google reviews */
.google-embed { background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 12px; box-shadow: var(--shadow-sm); overflow: hidden; }
.google-embed iframe { width: 100%; border: 0; min-height: 420px; }
.google-cta { max-width: 560px; margin: 0 auto; text-align: center; background: var(--clr-surface); border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 44px 28px; box-shadow: var(--shadow-sm); }
.google-cta__icon { width: 76px; height: 76px; margin: 0 auto 18px; display: grid; place-items: center; border-radius: 50%; background: var(--clr-tab-bg); font-size: 2rem; background: conic-gradient(#4285F4 0 25%, #EA4335 0 50%, #FBBC05 0 75%, #34A853 0 100%); }
.google-cta__icon i { width: 56px; height: 56px; display: grid; place-items: center; border-radius: 50%; background: #fff; color: #4285F4; font-size: 1.5rem; }
.google-cta h3 { color: var(--clr-h2); margin-bottom: 8px; }
.google-cta p { color: var(--clr-subheading); margin-bottom: 20px; }

/* career listing card actions */
.career-card__actions { display: flex; flex-wrap: wrap; gap: 10px; }

/* career detail */
.detail-sec-title { color: var(--clr-h2); font-size: 1.15rem; margin: 22px 0 10px; padding-bottom: 8px; border-bottom: 2px solid var(--clr-tab-bg); }
.rich-text { color: var(--clr-para); line-height: 1.8; }
.rich-text p { margin: 0 0 12px; }
.rich-text ul, .rich-text ol { margin: 0 0 14px; padding-left: 22px; }
.rich-text ul { list-style: disc; }
.rich-text ol { list-style: decimal; }
.rich-text li { margin-bottom: 6px; }
.rich-text strong, .rich-text b { color: var(--clr-h4); font-weight: 700; }
.rich-text a { color: var(--clr-link); text-decoration: underline; }
.rich-text a:hover { color: var(--clr-link-hover); }
.rich-text h1, .rich-text h2, .rich-text h3, .rich-text h4 { color: var(--clr-h3); margin: 16px 0 8px; }
.rich-text img { max-width: 100%; height: auto; border-radius: 8px; }
.side-card { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow-sm); margin-bottom: 24px; }
.side-card__title { font-size: 1.1rem; color: var(--clr-h2); border-bottom: 2px solid var(--clr-tab-bg); padding-bottom: 10px; margin-bottom: 14px; }
.side-list { list-style: none; margin: 0; padding: 0; }
.side-list li { display: grid; grid-template-columns: 22px 1fr auto; align-items: center; gap: 10px; padding: 12px 0; border-bottom: 2px dotted var(--clr-border); }
.side-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.side-list li:first-child { padding-top: 0; }
.side-list li i { color: var(--clr-secondary); }
.side-list li span { color: var(--clr-subheading); font-size: .9rem; }
.side-list li strong { color: var(--clr-h4); font-size: .9rem; text-align: right; }
.side-jobs { list-style: none; margin: 0; padding: 0; display: grid; gap: 6px; }
.side-jobs li a { display: flex; align-items: flex-start; gap: 12px; padding: 10px 12px; border-radius: 10px; transition: background .2s ease, transform .2s ease; }
.side-jobs li a:hover { background: var(--clr-bg); transform: translateX(4px); }
.side-jobs__icon { flex: 0 0 auto; width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; background: var(--clr-tab-bg); color: var(--clr-secondary); font-size: .85rem; transition: all .25s ease; }
.side-jobs li a:hover .side-jobs__icon { background: var(--clr-secondary); color: #fff; transform: rotate(-15deg); }
.side-jobs__text { min-width: 0; }
.side-jobs__name { display: block; font-weight: 600; color: var(--clr-h3); }
.side-jobs li a:hover .side-jobs__name { color: var(--clr-link-hover); }
.side-jobs__meta { display: block; font-size: .78rem; color: var(--clr-h6); }

/* =============================================
   CAMPAIGN DETAIL (advanced)
   ============================================= */
.campaign-slider { position: relative; max-width: 100%; min-width: 0; }
.campaign-swiper { width: 100%; max-width: 100%; border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.campaign-swiper .swiper-slide { width: 100%; }
.campaign-swiper .swiper-slide img { width: 100%; height: 440px; object-fit: cover; display: block; }
.campaign-thumbs { width: 100%; max-width: 100%; }
.campaign-swiper .swiper-button-prev, .campaign-swiper .swiper-button-next { color: #fff; background: rgba(0,0,0,.35); width: 40px; height: 40px; border-radius: 50%; }
.campaign-swiper .swiper-button-prev::after, .campaign-swiper .swiper-button-next::after { font-size: 1rem; font-weight: 700; }
.campaign-swiper .swiper-pagination-bullet-active { background: var(--clr-secondary); }
.campaign-thumbs .swiper-slide { opacity: .55; cursor: pointer; border-radius: 8px; overflow: hidden; transition: opacity .2s ease; }
.campaign-thumbs .swiper-slide img { width: 100%; height: 70px; object-fit: cover; display: block; }
.campaign-thumbs .swiper-slide-thumb-active { opacity: 1; outline: 2px solid var(--clr-secondary); }

.campaign-urgent-badge { display: inline-flex; align-items: center; gap: 6px; background: linear-gradient(135deg, #e53935, #b71c1c); color: #fff; font-weight: 700; font-size: .72rem; padding: 5px 12px; border-radius: 30px; letter-spacing: .3px; box-shadow: 0 4px 12px rgba(229,57,53,.4); }
.campaign-card-badge, .card-thm__img .campaign-urgent-badge { position: absolute; top: 12px; left: 12px; z-index: 3; }
.campaign-urgent-badge--lg { position: absolute; top: 16px; left: 16px; z-index: 5; font-size: .8rem; padding: 7px 16px; animation: urgentPulse 1.8s ease-in-out infinite; }
@keyframes urgentPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.06); } }

.campaign-meta-row { display: flex; flex-wrap: wrap; gap: 18px; }
.campaign-meta-row span { display: inline-flex; align-items: center; gap: 6px; color: var(--clr-subheading); font-size: .9rem; font-weight: 600; }
.campaign-meta-row i { color: var(--clr-secondary); }

.campaign-tabs__nav { display: flex; flex-wrap: wrap; gap: 6px; border-bottom: 2px solid var(--clr-border); margin-bottom: 18px; }
.campaign-tab { appearance: none; border: 0; background: transparent; padding: 12px 18px; font-weight: 700; font-size: .95rem; color: var(--clr-tab-text); cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; transition: color .2s ease, border-color .2s ease; display: inline-flex; align-items: center; gap: 8px; }
.campaign-tab:hover { color: var(--clr-primary); }
.campaign-tab.active { color: var(--clr-tab-active-bg); border-bottom-color: var(--clr-tab-active-bg); }
.campaign-tab__count { background: var(--clr-tab-bg); color: var(--clr-tab-text); font-size: .72rem; padding: 1px 8px; border-radius: 20px; }
.campaign-tab.active .campaign-tab__count { background: var(--clr-tab-active-bg); color: var(--clr-tab-active-text); }
.campaign-pane { display: none; animation: fadeInUp .35s ease; }
.campaign-pane.active { display: block; }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.rich-content p { margin: 0 0 1em; }
.rich-content img { max-width: 100%; height: auto; border-radius: 10px; margin: 8px 0; }
.rich-content h2 { font-size: 1.5rem; font-weight: 700; margin: 1em 0 .5em; line-height: 1.3; }
.rich-content h3 { font-size: 1.25rem; font-weight: 700; margin: 1em 0 .5em; line-height: 1.3; }
.rich-content h4 { font-size: 1.1rem; font-weight: 700; margin: 1em 0 .5em; }
.rich-content ul { list-style: disc; padding-left: 1.5em; margin: 0 0 1em; }
.rich-content ol { list-style: decimal; padding-left: 1.5em; margin: 0 0 1em; }
.rich-content li { margin: 0 0 .35em; }
.rich-content a { color: var(--clr-primary); text-decoration: underline; }
.rich-content b, .rich-content strong { font-weight: 700; }
.rich-content blockquote { border-left: 3px solid var(--clr-border); padding-left: 14px; color: #64748b; margin: 0 0 1em; font-style: italic; }

.organiser-card { border: 1px solid var(--clr-border); border-radius: var(--radius); padding: 18px; background: var(--clr-bg); }
.organiser-card__head { display: flex; gap: 14px; align-items: center; }
.organiser-card__head img, .organiser-card__avatar { width: 58px; height: 58px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; }
.organiser-card__avatar { display: grid; place-items: center; background: var(--clr-tab-bg); color: var(--clr-primary); font-size: 1.4rem; }
.organiser-card__label { font-size: .72rem; text-transform: uppercase; letter-spacing: .5px; color: var(--clr-h6); }
.organiser-card h4 { margin: 2px 0; color: var(--clr-h3); }
.organiser-card__contact { display: flex; flex-wrap: wrap; gap: 14px; }
.organiser-card__contact a { font-size: .85rem; color: var(--clr-link); display: inline-flex; align-items: center; gap: 5px; }

.campaign-update { display: flex; gap: 14px; padding-bottom: 18px; position: relative; }
.campaign-update:not(:last-child)::before { content: ''; position: absolute; left: 6px; top: 18px; bottom: 0; width: 2px; background: var(--clr-border); }
.campaign-update__dot { width: 14px; height: 14px; border-radius: 50%; background: var(--clr-secondary); flex: 0 0 auto; margin-top: 4px; box-shadow: 0 0 0 4px var(--clr-tab-bg); z-index: 1; }
.campaign-update__date { font-size: .78rem; color: var(--clr-h6); font-weight: 600; }
.campaign-update__body h4 { margin: 2px 0 6px; color: var(--clr-h3); }

.campaign-doc { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border: 1px solid var(--clr-border); border-radius: 12px; margin-bottom: 10px; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; }
.campaign-doc:hover { transform: translateX(4px); box-shadow: var(--shadow-sm); border-color: var(--clr-secondary); }
.campaign-doc__icon { width: 40px; height: 40px; border-radius: 10px; display: grid; place-items: center; background: var(--clr-tab-bg); color: var(--clr-secondary); font-size: 1.1rem; flex: 0 0 auto; }
.campaign-doc__title { flex: 1; font-weight: 600; color: var(--clr-h4); }
.campaign-doc__dl { color: var(--clr-primary); }

.campaign-kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; text-align: center; }
.campaign-kpis > div { background: var(--clr-bg); border: 1px solid var(--clr-border); border-radius: 12px; padding: 12px 6px; transition: transform .2s ease, box-shadow .2s ease; }
.campaign-kpis > div:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.campaign-kpis > div > i { color: var(--clr-primary); font-size: .9rem; margin-bottom: 4px; display: block; }
.campaign-kpis strong { display: block; font-size: 1.2rem; font-weight: 800; color: var(--clr-h2); line-height: 1; }
.campaign-kpis span { font-size: .72rem; color: var(--clr-h6); }

/* ---- Donation sidebar card ---- */
.campaign-aside { position: sticky; top: 90px; }
.donate-box { position: relative; overflow: hidden; padding-top: 26px; }
.donate-box::before { content: ''; position: absolute; inset: 0 0 auto 0; height: 5px; background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary)); }
.donate-box__raised strong { display: block; font-size: 1.9rem; font-weight: 800; color: var(--clr-primary); line-height: 1.1; }
.donate-box__raised span { font-size: .85rem; color: var(--clr-h6); }
.progress-x--lg { height: 14px; margin-top: 12px; box-shadow: inset 0 1px 2px rgba(0,0,0,.06); }
.progress-x--lg .progress-x__bar { position: relative; background: linear-gradient(90deg, var(--clr-secondary), #ffb74d); transition: width .8s cubic-bezier(.22,.61,.36,1); }
.campaign-stats span { display: inline-flex; align-items: center; gap: 5px; font-weight: 600; }
.campaign-stats span i { color: #ff7043; }
.donate-box__urgency { display: flex; align-items: center; gap: 7px; font-size: .78rem; font-weight: 600; color: #c62828; background: #fdecea; border: 1px solid #f8c9c4; border-radius: 10px; padding: 8px 12px; }
.donate-box__choose { font-size: .82rem; font-weight: 700; color: var(--clr-h4); margin: 0 0 8px; }
.donate-box__cta { font-size: 1.02rem; font-weight: 700; padding: 14px; box-shadow: 0 8px 20px rgba(245,124,0,.32); animation: donatePulse 2.4s ease-in-out infinite; }
.donate-box__cta:hover { transform: translateY(-2px); }
@keyframes donatePulse { 0%,100% { box-shadow: 0 8px 20px rgba(245,124,0,.32); } 50% { box-shadow: 0 8px 28px rgba(245,124,0,.5); } }
.donate-box__trust { display: flex; justify-content: center; gap: 18px; margin-top: 12px; }
.donate-box__trust span { display: inline-flex; align-items: center; gap: 6px; font-size: .76rem; font-weight: 600; color: var(--clr-h5); }
.donate-box__trust i { color: #2e7d32; }

/* ============================================================
   Dynamic form (Builder module public form)
   ============================================================ */
.fb-section { padding: 48px 0 64px; }
.fb-card { max-width: 760px; margin: 0 auto; background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 32px; }
.fb-card__desc { color: var(--clr-h5); margin: 0 0 20px; }
.fb-form { display: flex; flex-wrap: wrap; gap: 16px; }
.fb-field { display: flex; flex-direction: column; }
.fb-field--full { width: 100%; }
.fb-field--half { width: calc(50% - 8px); }
@media (max-width: 600px) { .fb-field--half { width: 100%; } }
.fb-label { font-size: .9rem; font-weight: 600; color: var(--clr-h4); margin-bottom: 6px; }
.fb-req { color: #e53935; margin-left: 2px; }
.fb-help { font-size: .78rem; color: var(--clr-h6); margin-top: 4px; }
.fb-error { font-size: .78rem; color: #b71c1c; margin-top: 4px; }
.fb-heading { font-size: 1.25rem; color: var(--clr-h3); margin: 8px 0 0; padding-bottom: 8px; border-bottom: 2px solid var(--clr-tab-bg); }
.fb-paragraph { color: var(--clr-h5); margin: 0; }
.fb-choices { display: flex; flex-wrap: wrap; gap: 10px 18px; padding-top: 4px; }
.fb-choice { display: inline-flex; align-items: center; gap: 7px; font-size: .9rem; color: var(--clr-h4); cursor: pointer; }
.fb-choice input { width: 16px; height: 16px; accent-color: var(--clr-secondary); }

/* ---- Donor list (donors tab) ---- */
.donor-list { list-style: none; margin: 0; padding: 0; }
.donor-list__item { display: flex; align-items: center; gap: 12px; padding: 12px 2px; border-bottom: 1px dashed var(--clr-border); }
.donor-list__item:last-child { border-bottom: 0; }
.donor-list__avatar { width: 40px; height: 40px; border-radius: 50%; flex: 0 0 auto; display: grid; place-items: center; background: var(--clr-tab-bg); color: var(--clr-primary); font-size: .95rem; }
.donor-list__info { flex: 1 1 auto; min-width: 0; }
.donor-list__info h4 { margin: 0; font-size: .95rem; color: var(--clr-h3); }
.donor-list__info small { font-size: .76rem; color: var(--clr-h6); }
.donor-list__amt { color: var(--clr-primary); font-weight: 800; white-space: nowrap; }

/* ---- Organiser sidebar card ---- */
.organiser-box__head { display: flex; gap: 14px; align-items: center; }
.organiser-box__head img, .organiser-box__avatar { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; }
.organiser-box__avatar { display: grid; place-items: center; background: var(--clr-tab-bg); color: var(--clr-primary); font-size: 1.3rem; }
.organiser-box__head h4 { margin: 0; font-size: 1.02rem; color: var(--clr-h3); display: flex; align-items: center; gap: 6px; }
.organiser-box__verified { color: #1da1f2; font-size: .85rem; }
.organiser-box__tag { font-size: .74rem; color: #2e7d32; font-weight: 600; }
.organiser-box__about { margin: 14px 0 0; font-size: .86rem; color: var(--clr-h5); line-height: 1.6; }
.organiser-box__contact { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--clr-border); }
.organiser-box__contact a { display: inline-flex; align-items: center; gap: 8px; font-size: .85rem; color: var(--clr-h4); transition: color .2s ease; }
.organiser-box__contact a:hover { color: var(--clr-primary); }
.organiser-box__contact a i { width: 28px; height: 28px; border-radius: 50%; background: var(--clr-tab-bg); color: var(--clr-primary); display: inline-grid; place-items: center; font-size: .8rem; }

.campaign-countdown { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; text-align: center; }
.campaign-countdown > div { background: var(--clr-primary); color: #fff; border-radius: 12px; padding: 10px 4px; }
.campaign-countdown span { display: block; font-size: 1.3rem; font-weight: 800; line-height: 1; }
.campaign-countdown small { font-size: .65rem; opacity: .85; text-transform: uppercase; letter-spacing: .5px; }

.campaign-share { border-top: 1px solid var(--clr-border); padding-top: 16px; }
.campaign-share__label { display: block; font-size: .82rem; color: var(--clr-h6); margin-bottom: 8px; font-weight: 600; }
.campaign-share__links { display: flex; gap: 8px; }
.campaign-share .sh { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; color: #fff; border: 0; cursor: pointer; font-size: .95rem; transition: transform .2s ease, opacity .2s ease; text-decoration: none; }
.campaign-share .sh:hover { transform: translateY(-3px); }
.sh--fb { background: #1877f2; } .sh--tw { background: #111; } .sh--wa { background: #25d366; } .sh--ml { background: var(--clr-h5); } .sh--cp { background: var(--clr-primary); }
.campaign-share .sh.copied { background: #2e7d32; }

.mini-campaign { display: flex; gap: 12px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--clr-border); }
.mini-campaign:last-child { border-bottom: 0; }
.mini-campaign img { width: 64px; height: 48px; border-radius: 8px; object-fit: cover; flex: 0 0 auto; }
.mini-campaign h4 { margin: 0 0 6px; font-size: .9rem; color: var(--clr-h4); }
.mini-campaign small { color: var(--clr-h6); font-size: .75rem; }
.progress-x--sm { height: 6px; }

@media (max-width: 768px) {
    .campaign-swiper .swiper-slide img { height: 280px; }
}

/* ============================================================
   Donation modal
   ============================================================ */
.dm-overlay {
    position: fixed; inset: 0; z-index: 1200;
    display: flex; align-items: flex-start; justify-content: center;
    padding: 24px 16px; overflow-y: auto;
    background: rgba(10, 22, 48, .62);
    backdrop-filter: blur(4px);
    opacity: 0; transition: opacity .25s ease;
}
.dm-overlay[hidden] { display: none; }
.dm-overlay.is-open { opacity: 1; }

.dm {
    position: relative; width: 100%; max-width: 480px;
    margin: auto;
    background: #fff; border-radius: 20px;
    box-shadow: 0 24px 70px rgba(8, 22, 51, .35);
    overflow: hidden;
    transform: translateY(18px) scale(.98); opacity: 0;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), opacity .3s ease;
}
.dm-overlay.is-open .dm { transform: translateY(0) scale(1); opacity: 1; }

.dm__close {
    position: absolute; top: 12px; right: 12px; z-index: 3;
    width: 34px; height: 34px; border: 0; cursor: pointer;
    border-radius: 50%; background: rgba(255,255,255,.18); color: #fff;
    font-size: 15px; display: flex; align-items: center; justify-content: center;
    transition: background .2s;
}
.dm__close:hover { background: rgba(255,255,255,.35); }

.dm__hero {
    background: linear-gradient(135deg, var(--clr-primary, #1565c0), var(--clr-accent, #42a5f5));
    color: #fff; text-align: center; padding: 30px 24px 24px;
}
.dm__hero-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 58px; height: 58px; border-radius: 50%;
    background: rgba(255,255,255,.16); font-size: 24px; margin-bottom: 10px;
    animation: dmPulse 2.4s ease-in-out infinite;
}
@keyframes dmPulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.08); } }
.dm__title { margin: 0; font-size: 1.25rem; font-weight: 700; }
.dm__hero .dm__title { color: #fff; }
.dm__sub { margin: 6px 0 0; font-size: .9rem; opacity: .92; }
.dm__hero .dm__sub { color: rgba(255,255,255,.92); }

.dm__body { padding: 22px 24px 26px; }

.dm-freq {
    display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
    background: #eef3fb; border-radius: 12px; padding: 5px; margin-bottom: 18px;
}
.dm-freq__btn {
    position: relative; overflow: visible;
    border: 0; background: transparent; cursor: pointer;
    padding: 10px; border-radius: 9px; font-weight: 600; font-size: .9rem;
    color: #5c6b85; transition: all .2s; display: flex; align-items: center; justify-content: center; gap: 6px;
}
.dm-freq__btn.is-active { background: #fff; color: var(--clr-primary, #1565c0); box-shadow: 0 3px 10px rgba(13,43,90,.12); }

/* Heart icons in the frequency tabs */
.dm-freq__heart { color: #c2cad8; transition: color .2s, transform .2s; }
.dm-freq__btn.is-active .dm-freq__heart { color: #e11d48; }
.dm-freq__btn[data-dm-freq="monthly"].is-active .dm-freq__heart {
    animation: dmHeartBeat 1s ease-in-out infinite;
}
@keyframes dmHeartBeat {
    0%, 100% { transform: translateY(0) scale(1); }
    30% { transform: translateY(-3px) scale(1.18); }
    60% { transform: translateY(0) scale(1); }
}

/* Rising hearts burst when Monthly is chosen */
.dm-heart-fly {
    position: absolute; bottom: 10px;
    color: #e11d48; font-size: 13px; pointer-events: none; opacity: 0;
    animation: dmHeartFly 1s ease-out forwards;
}
@keyframes dmHeartFly {
    0% { transform: translateY(0) scale(.5); opacity: 0; }
    20% { opacity: 1; }
    100% { transform: translateY(-48px) scale(1.15); opacity: 0; }
}

.dm-label { display: block; font-size: .82rem; font-weight: 600; color: #455066; margin: 0 0 8px; }
.dm-req { color: #e11d48; }
.dm-muted { color: #9aa6bb; font-weight: 400; }

.dm-amounts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 12px; }
.dm-chip {
    border: 1.5px solid #dbe3f0; background: #fff; cursor: pointer;
    padding: 11px 4px; border-radius: 10px; font-weight: 700; font-size: .88rem; color: #37474f;
    transition: all .18s;
}
.dm-chip:hover { border-color: var(--clr-primary, #1565c0); }
.dm-chip.is-active { background: var(--clr-primary, #1565c0); border-color: var(--clr-primary, #1565c0); color: #fff; }

.dm-amount-input { position: relative; display: flex; align-items: center; margin-bottom: 18px; }
.dm-amount-input__sign { position: absolute; left: 14px; font-weight: 700; color: #455066; }
.dm-amount-input__field {
    width: 100%; padding: 12px 14px 12px 32px; border: 1.5px solid #dbe3f0; border-radius: 10px;
    font-size: 1rem; font-weight: 600; outline: none; transition: border-color .2s;
}
.dm-amount-input__field:focus { border-color: var(--clr-primary, #1565c0); }
.dm-amount-input__freq { position: absolute; right: 14px; color: #9aa6bb; font-size: .85rem; }

.dm-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
.dm-field { display: flex; flex-direction: column; }
.dm-field--full { grid-column: 1 / -1; }
.dm-field .dm-label { margin-bottom: 6px; }
.dm-input {
    width: 100%; padding: 10px 12px; border: 1.5px solid #dbe3f0; border-radius: 10px;
    font-size: .92rem; outline: none; transition: border-color .2s; font-family: inherit;
}
.dm-input:focus { border-color: var(--clr-primary, #1565c0); }
textarea.dm-input { resize: vertical; }

/* Field-level validation */
.dm-input--error,
select.dm-input--error,
.dm-amount-input__field.dm-input--error {
    border-color: #e11d48 !important;
    background: #fff5f6;
}
.dm-field-err {
    margin: 5px 0 0; font-size: .76rem; color: #e11d48; line-height: 1.3;
}
.dm-hint { display: block; margin-top: 5px; font-size: .74rem; color: #9aa6bb; }
.dm-input--pan { text-transform: uppercase; letter-spacing: 1px; font-weight: 600; }
.dm-amount-input { flex-wrap: wrap; }
.dm-amount-input .dm-field-err { flex-basis: 100%; }

.dm-check { display: flex; align-items: flex-start; gap: 9px; font-size: .85rem; color: #5c6b85; cursor: pointer; margin: 4px 0 16px; }
.dm-check input { margin-top: 2px; }

.dm-error {
    background: #fdecec; color: #b91c1c; border: 1px solid #f5c2c2;
    border-radius: 9px; padding: 9px 12px; font-size: .85rem; margin: 0 0 14px;
}

.dm-proceed {
    width: 100%; border: 0; cursor: pointer;
    background: var(--clr-secondary, #fb8c00); color: #fff;
    padding: 14px; border-radius: 11px; font-size: 1rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center; gap: 8px;
    transition: filter .2s, transform .1s; box-shadow: 0 8px 20px rgba(251,140,0,.28);
}
.dm-proceed:hover { filter: brightness(1.05); }
.dm-proceed:active { transform: translateY(1px); }
.dm-proceed:disabled { opacity: .75; cursor: not-allowed; }

.dm-secure { text-align: center; font-size: .78rem; color: #9aa6bb; margin: 12px 0 0; }
.dm-secure i { color: #16a34a; }

/* Centered states */
.dm__center { padding: 40px 28px 34px; text-align: center; }
.dm__center .dm__title { color: #16324f; }
.dm__center .dm-proceed { margin-top: 22px; }

.dm-spinner {
    display: inline-block; width: 44px; height: 44px;
    border: 4px solid #e3eaf5; border-top-color: var(--clr-primary, #1565c0);
    border-radius: 50%; animation: dmSpin .8s linear infinite;
}
.dm-spinner--sm { width: 16px; height: 16px; border-width: 2px; border-top-color: #fff; vertical-align: middle; }
@keyframes dmSpin { to { transform: rotate(360deg); } }

.dm-success-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 72px; height: 72px; border-radius: 50%;
    background: #dcfce7; color: #16a34a; font-size: 32px;
    animation: dmPop .4s cubic-bezier(.2,1.4,.4,1);
}
@keyframes dmPop { 0% { transform: scale(0); } 100% { transform: scale(1); } }
.dm-receipt { margin: 14px auto 0; font-size: .85rem; color: #5c6b85; background: #f4f7fc; border-radius: 9px; padding: 8px 14px; display: inline-block; }
.dm-receipt strong { font-family: monospace; color: #16324f; }
.dm-mail-note { font-size: .82rem; color: #5c6b85; margin: 14px 0 0; }
.dm-mail-note i { color: #16a34a; }

.dm-plead-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 72px; height: 72px; border-radius: 50%;
    background: #fff1e6; color: var(--clr-secondary, #fb8c00); font-size: 32px;
    animation: dmPulse 2s ease-in-out infinite;
}
.dm-cancel-link {
    display: block; width: 100%; margin-top: 10px; border: 0; background: transparent;
    color: #9aa6bb; cursor: pointer; font-size: .85rem; text-decoration: underline;
}
.dm-cancel-link:hover { color: #5c6b85; }

@media (max-width: 540px) {
    .dm-amounts { grid-template-columns: repeat(2, 1fr); }
    .dm-grid { grid-template-columns: 1fr; }
    .dm__body { padding: 20px 18px 22px; }
}

/* ============================================================
   Membership form (public)
   ============================================================ */
.mem-section { padding: 40px 0 64px; }

/* 404 page */
.err404-section { min-height: 50vh; display: flex; align-items: center; }
.err404 {
    max-width: 560px;
    margin: 0 auto;
    text-align: center;
    padding: 48px 28px;
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: 20px;
    box-shadow: var(--shadow-md, 0 18px 50px rgba(15, 23, 42, .08));
}
.err404__code {
    font-size: clamp(4.5rem, 14vw, 7rem);
    font-weight: 800;
    line-height: 1;
    color: color-mix(in srgb, var(--clr-primary) 18%, #fff);
    letter-spacing: -.04em;
}
.err404__title {
    margin: 8px 0 12px;
    font-size: clamp(1.35rem, 3vw, 1.75rem);
    font-weight: 700;
    color: var(--clr-h3);
}
.err404__text {
    margin: 0 0 24px;
    color: var(--clr-h6);
    font-size: 1rem;
    line-height: 1.6;
}
.err404__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}
.mem-grid { display: grid; grid-template-columns: 1fr 320px; gap: 24px; align-items: start; }
.mem-main { min-width: 0; }
.mem-card { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 28px; }
.mem-card--narrow { max-width: 760px; margin: 0 auto; }
.mem-card + .mem-card { margin-top: 20px; }
.mem-card__head { border-bottom: 1px solid var(--clr-border); padding-bottom: 16px; margin-bottom: 20px; }
.mem-card__head h2 { font-size: 1.4rem; font-weight: 700; color: var(--clr-heading); margin: 0 0 6px; }
.mem-card__head h2 i { color: var(--clr-primary); margin-right: 6px; }
.mem-card__head p { color: var(--clr-muted); margin: 0; font-size: .94rem; }

.mem-legend { display: flex; align-items: center; gap: 10px; font-size: 1.02rem; font-weight: 700; color: var(--clr-heading); margin: 26px 0 14px; }
.mem-legend:first-of-type { margin-top: 0; }
.mem-legend span { display: grid; place-items: center; width: 26px; height: 26px; border-radius: 50%; background: var(--clr-primary); color: #fff; font-size: .82rem; }
.mem-legend small { font-weight: 400; color: var(--clr-muted); font-size: .8rem; }

.mem-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 16px; }
.mem-row:has(.mem-field:nth-child(3)) { grid-template-columns: repeat(3, 1fr); }
.mem-field { display: flex; flex-direction: column; min-width: 0; }
.mem-field--full { grid-column: 1 / -1; }
.mem-field label { font-size: .85rem; font-weight: 600; color: var(--clr-heading); margin-bottom: 6px; }
.mem-field label i { color: #e11d48; font-style: normal; }
.mem-field input, .mem-field select, .mem-field textarea {
    width: 100%; padding: 11px 13px; border: 1px solid var(--clr-border); border-radius: 10px;
    font-size: .92rem; background: #fff; color: var(--clr-text); transition: border-color .15s, box-shadow .15s;
}
.mem-field input:focus, .mem-field select:focus, .mem-field textarea:focus {
    outline: none; border-color: var(--clr-primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--clr-primary) 18%, transparent);
}
.mem-field small { color: var(--clr-muted); font-size: .78rem; margin-top: 5px; }
.mem-field--error input, .mem-field--error select, .mem-field--error textarea { border-color: #e11d48; }
.mem-field-err { color: #e11d48 !important; font-size: .78rem; margin-top: 5px; }

.mem-pin-status { display: block; font-size: .78rem; margin-top: 5px; color: var(--clr-muted); }
.mem-pin-status.is-loading { color: var(--clr-muted); }
.mem-pin-status.is-ok { color: #16a34a; font-weight: 600; }
.mem-pin-status.is-error { color: #e11d48; }

.mem-note { display: flex; align-items: flex-start; gap: 9px; font-size: .85rem; color: var(--clr-muted); background: var(--clr-tab-bg, #f8fafc); border: 1px solid var(--clr-border); border-radius: 12px; padding: 13px 15px; margin: 6px 0 4px; }
.mem-note i { color: var(--clr-primary); margin-top: 2px; }


/* Membership fee popup */
.memfee[hidden] { display: none; }
.memfee { position: fixed; inset: 0; z-index: 1200; display: flex; align-items: center; justify-content: center; padding: 18px; }
.memfee__backdrop { position: absolute; inset: 0; background: rgba(15, 23, 42, .55); backdrop-filter: blur(2px); }
.memfee__box { position: relative; width: 100%; max-width: 1024px; max-height: 88vh; background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 30px 80px rgba(0, 0, 0, .3); display: flex; flex-direction: column; animation: memfeeIn .2s ease; }
@keyframes memfeeIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.memfee__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; background: var(--clr-primary); color: #fff; padding: 16px 22px; }
.memfee__head h3 { margin: 0; font-size: 1.15rem; display: flex; align-items: center; gap: 9px; }
.memfee__hint { margin: 4px 0 0; font-size: .82rem; opacity: .88; font-weight: 400; }
.memfee__close { background: rgba(255, 255, 255, .15); border: 0; color: #fff; width: 34px; height: 34px; border-radius: 50%; cursor: pointer; font-size: 1rem; }
.memfee__close:hover { background: rgba(255, 255, 255, .28); }
.memfee__scroll { overflow: auto; }
.memfee__table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.memfee__table th, .memfee__table td { padding: 13px 16px; text-align: center; border-bottom: 1px solid #eef1f4; white-space: nowrap; }
.memfee__table thead th { background: #f8fafc; color: #4b5563; font-weight: 700; position: sticky; top: 0; }
.memfee__table th:first-child, .memfee__table td:first-child { text-align: left; }
.memfee__post { font-weight: 600; color: #1f2937; }
.memfee__table tbody tr:hover { background: #f8fafc; }
.memfee__cell--pick { cursor: pointer; transition: background .15s, color .15s; }
.memfee__cell--pick:hover,
.memfee__cell--pick:focus { background: #e0f2fe !important; color: var(--clr-primary); font-weight: 700; outline: none; box-shadow: inset 0 0 0 2px var(--clr-primary); }

.mem-coupon { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin: 22px 0; padding: 16px; background: var(--clr-tab-bg, #f8fafc); border-radius: 12px; }
.mem-coupon input { flex: 1; min-width: 160px; padding: 10px 13px; border: 1px dashed var(--clr-border); border-radius: 10px; text-transform: uppercase; }
.mem-coupon-ok { color: #16a34a; font-size: .82rem; }
.mem-coupon-err { color: #e11d48; font-size: .82rem; }

.mem-terms { display: flex; align-items: flex-start; gap: 9px; font-size: .88rem; color: var(--clr-text); margin: 6px 0 20px; }
.mem-terms input { margin-top: 3px; }
.mem-terms a { color: var(--clr-primary); }

.mem-submit { font-size: 1rem; padding: 14px; }
.mem-old-link { text-align: center; margin: 16px 0 0; font-size: .88rem; color: var(--clr-muted); }
.mem-old-link a { color: var(--clr-primary); font-weight: 600; }

.mem-alert { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-radius: 10px; font-size: .9rem; margin-bottom: 18px; }
.mem-alert--error { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; }

.mem-terms-box h3 { font-size: 1.1rem; font-weight: 700; margin: 0 0 12px; color: var(--clr-heading); }
.mem-terms-box h3 i { color: var(--clr-primary); margin-right: 6px; }
.mem-terms-text { font-size: .88rem; color: var(--clr-text); line-height: 1.7; max-height: 280px; overflow-y: auto; }

/* Sidebar summary */
.mem-aside { position: sticky; top: 90px; }
.mem-summary { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 22px; overflow: hidden; position: relative; }
.mem-summary::before { content: ''; position: absolute; inset: 0 0 auto 0; height: 4px; background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary)); }
.mem-summary h3 { font-size: 1.05rem; font-weight: 700; color: var(--clr-heading); margin: 6px 0 16px; }
.mem-summary__row { display: flex; justify-content: space-between; align-items: center; font-size: .9rem; padding: 9px 0; border-bottom: 1px dashed var(--clr-border); }
.mem-summary__row span { color: var(--clr-muted); }
.mem-summary__row strong { color: var(--clr-heading); font-weight: 600; }
.mem-summary__row--discount strong { color: #16a34a; }
.mem-summary__total { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; padding-top: 14px; border-top: 2px solid var(--clr-border); }
.mem-summary__total span { font-weight: 600; color: var(--clr-heading); }
.mem-summary__total strong { font-size: 1.4rem; font-weight: 800; color: var(--clr-primary); }
.mem-perks { list-style: none; margin: 18px 0 0; padding: 16px 0 0; border-top: 1px dashed var(--clr-border); }
.mem-perks li { display: flex; align-items: center; gap: 9px; font-size: .85rem; color: var(--clr-text); padding: 6px 0; }
.mem-perks li i { color: var(--clr-primary); width: 18px; text-align: center; }

/* Processing overlay */
.mem-overlay { position: fixed; inset: 0; z-index: 9999; background: rgba(15, 23, 42, .6); backdrop-filter: blur(3px); display: grid; place-items: center; }
.mem-overlay__box { background: #fff; border-radius: 16px; padding: 32px 40px; text-align: center; box-shadow: 0 20px 60px rgba(0,0,0,.25); }
.mem-overlay__box p { margin: 16px 0 0; font-weight: 600; color: var(--clr-heading); }
.mem-spinner { width: 44px; height: 44px; margin: 0 auto; border: 4px solid var(--clr-border); border-top-color: var(--clr-primary); border-radius: 50%; animation: mem-spin .8s linear infinite; }
@keyframes mem-spin { to { transform: rotate(360deg); } }

/* Thank-you */
.mem-thanks { max-width: 620px; margin: 0 auto; text-align: center; background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 48px 32px; }
.mem-thanks__icon { font-size: 4rem; color: #16a34a; margin-bottom: 16px; }
.mem-thanks h2 { font-size: 1.6rem; font-weight: 700; color: var(--clr-heading); margin: 0 0 12px; }
.mem-thanks p { color: var(--clr-muted); margin: 0 auto 24px; max-width: 480px; line-height: 1.7; }
.mem-thanks__actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Pay-by-link page */
.mem-pay { max-width: 480px; margin: 0 auto; }
.mem-pay__card { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 32px; }
.mem-pay__head { text-align: center; margin-bottom: 20px; }
.mem-pay__badge { display: inline-flex; align-items: center; gap: 6px; font-size: .8rem; font-weight: 600; color: var(--clr-primary); background: color-mix(in srgb, var(--clr-primary) 12%, #fff); padding: 5px 12px; border-radius: 999px; }
.mem-pay__head h2 { font-size: 1.45rem; font-weight: 700; color: var(--clr-heading); margin: 14px 0 6px; }
.mem-pay__head p { color: var(--clr-muted); margin: 0; line-height: 1.6; }
.mem-pay__rows { list-style: none; margin: 0 0 22px; padding: 0; border: 1px solid var(--clr-border); border-radius: 12px; overflow: hidden; }
.mem-pay__rows li { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--clr-border); }
.mem-pay__rows li:last-child { border-bottom: 0; }
.mem-pay__rows li span { color: var(--clr-muted); font-size: .9rem; }
.mem-pay__rows li strong { color: var(--clr-heading); }
.mem-pay__total { background: color-mix(in srgb, var(--clr-primary) 7%, #fff); }
.mem-pay__total strong { color: var(--clr-primary); font-size: 1.2rem; }
.mem-pay__secure { text-align: center; color: var(--clr-muted); font-size: .82rem; margin: 12px 0 0; }

@media (max-width: 900px) {
    .mem-grid { grid-template-columns: 1fr; }
    .mem-aside { position: static; }
}
@media (max-width: 600px) {
    .mem-row, .mem-row:has(.mem-field:nth-child(3)) { grid-template-columns: 1fr; }
    .mem-card { padding: 20px; }
}

/* ============================================================
   Member panel
   ============================================================ */
.mp-section { padding: 36px 0 64px; }
.mp-grid { display: grid; grid-template-columns: 260px 1fr; gap: 24px; align-items: start; }

/* Standalone member/volunteer panel shell (no public site header/footer) */
.mp-shell { background: var(--clr-tab-bg, #f1f5f9); min-height: 100vh; }
.mp-shell .mp-section { padding: 20px 0 28px; min-height: 100vh; }
.mp-shell .mp-nav { top: 16px; }
.mp-nav__brand { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-bottom: 1px solid var(--clr-border); background: #fff; }
.mp-nav__brand-logo { height: 32px; width: auto; max-width: 120px; object-fit: contain; }
.mp-nav__brand-text { font-size: .88rem; font-weight: 700; color: var(--clr-heading); line-height: 1.2; }
.mp-nav__dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: #ef4444; margin-left: 4px; }
.mp-topbar__left { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.mp-topbar__badge { font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--clr-primary); }
.mp-panel-footer { margin-top: 8px; padding-top: 16px; border-top: 1px solid var(--clr-border); text-align: center; font-size: .78rem; color: var(--clr-muted); }

.mp-nav { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; position: sticky; top: 90px; }
.mp-nav__user { display: flex; align-items: center; gap: 12px; padding: 18px; background: linear-gradient(135deg, var(--clr-primary), var(--clr-secondary)); color: #fff; }
.mp-nav__user img, .mp-nav__avatar { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.mp-nav__avatar { display: grid; place-items: center; background: rgba(255,255,255,.2); font-size: 1.2rem; }
.mp-nav__user strong { display: block; font-size: .95rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mp-nav__user small { opacity: .85; font-size: .78rem; }
.mp-nav__links { display: flex; flex-direction: column; padding: 8px; }
.mp-nav__links a { display: flex; align-items: center; gap: 11px; padding: 11px 14px; border-radius: 10px; color: var(--clr-text); font-size: .9rem; font-weight: 500; transition: background .15s, color .15s; }
.mp-nav__links a i { width: 18px; text-align: center; color: var(--clr-muted); }
.mp-nav__links a:hover { background: var(--clr-tab-bg, #f1f5f9); }
.mp-nav__links a.active { background: color-mix(in srgb, var(--clr-primary) 12%, transparent); color: var(--clr-primary); }
.mp-nav__links a.active i { color: var(--clr-primary); }
.mp-logout { margin-top: 4px; border-top: 1px dashed var(--clr-border); padding-top: 4px; }
.mp-logout button { display: flex; align-items: center; gap: 11px; width: 100%; padding: 11px 14px; border: 0; background: none; color: #dc2626; font-size: .9rem; font-weight: 500; cursor: pointer; border-radius: 10px; }
.mp-logout button:hover { background: #fef2f2; }

.mp-main { min-width: 0; display: flex; flex-direction: column; gap: 18px; }
.mp-topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.mp-topbar__title { font-size: 1.15rem; font-weight: 700; color: var(--clr-heading); }
.mp-card { background: #fff; border: 1px solid var(--clr-border); border-radius: var(--radius); box-shadow: var(--shadow-sm); padding: 24px; }
.mp-card__title { font-size: 1.1rem; font-weight: 700; color: var(--clr-heading); margin: 0 0 16px; }
.mp-card__title i { color: var(--clr-primary); margin-right: 6px; }
.mp-muted { color: var(--clr-muted); font-size: .9rem; margin: 0 0 16px; }

.mp-hero { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; flex-wrap: wrap; }
.mp-hero h2 { font-size: 1.4rem; font-weight: 700; color: var(--clr-heading); margin: 8px 0 4px; }
.mp-hero p { color: var(--clr-muted); margin: 0; }
.mp-hero__id { text-align: right; }
.mp-hero__id small { display: block; color: var(--clr-muted); font-size: .76rem; }
.mp-hero__id strong { font-family: monospace; font-size: 1.15rem; color: var(--clr-primary); }

.mp-status { display: inline-block; padding: 3px 12px; border-radius: 999px; font-size: .75rem; font-weight: 700; }
.mp-status--active { background: #ecfdf5; color: #047857; }
.mp-status--expired, .mp-status--kyc-rejected { background: #fef2f2; color: #b91c1c; }
.mp-status--kyc-pending, .mp-status--pending-payment { background: #fffbeb; color: #b45309; }

.mp-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.mp-stat { display: flex; align-items: center; gap: 12px; background: #fff; border: 1px solid var(--clr-border); border-radius: 12px; padding: 16px; box-shadow: var(--shadow-sm); }
.mp-stat i { font-size: 1.4rem; color: var(--clr-primary); }
.mp-stat small { display: block; color: var(--clr-muted); font-size: .76rem; }
.mp-stat strong { color: var(--clr-heading); font-size: .98rem; }

.mp-actions { display: flex; flex-wrap: wrap; gap: 10px; }

.mp-kyc-current { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.mp-kyc-thumb { border: 1px dashed var(--clr-border); border-radius: 12px; padding: 12px; text-align: center; }
.mp-kyc-thumb span { display: block; font-size: .78rem; font-weight: 600; color: var(--clr-muted); margin-bottom: 8px; }
.mp-kyc-thumb img { width: 100%; height: 110px; object-fit: cover; border-radius: 8px; }
.mp-kyc-thumb em { color: var(--clr-muted); font-size: .82rem; }

.mp-docs { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.mp-doc { display: flex; flex-direction: column; gap: 4px; padding: 20px; border: 1px solid var(--clr-border); border-radius: 14px; text-align: center; transition: transform .15s, box-shadow .15s, border-color .15s; }
.mp-doc:hover { transform: translateY(-3px); box-shadow: var(--shadow-md, 0 10px 30px rgba(0,0,0,.08)); border-color: var(--clr-primary); }
.mp-doc i { font-size: 2.2rem; color: var(--clr-primary); margin-bottom: 6px; }
.mp-doc strong { color: var(--clr-heading); }
.mp-doc span { font-size: .8rem; color: var(--clr-muted); }

.mp-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.mp-table th { text-align: left; padding: 10px 12px; background: var(--clr-tab-bg, #f8fafc); color: var(--clr-muted); font-size: .76rem; text-transform: uppercase; }
.mp-table td { padding: 10px 12px; border-top: 1px solid var(--clr-border); color: var(--clr-text); }
.mp-pill { padding: 2px 10px; border-radius: 999px; font-size: .74rem; font-weight: 600; }
.mp-pill--completed { background: #ecfdf5; color: #047857; }
.mp-pill--pending { background: #fffbeb; color: #b45309; }

@media (max-width: 900px) {
    .mp-grid { grid-template-columns: 1fr; }
    .mp-nav { position: static; }
    .mp-nav__links { flex-direction: row; flex-wrap: wrap; }
    .mp-nav__links a { flex: 1 1 auto; }
}
@media (max-width: 600px) {
    .mp-stats, .mp-kyc-current, .mp-docs { grid-template-columns: 1fr; }
}

/* ---- Intern panel: status, progress, study list, viewers ---- */
.mp-status--approved { background: #ecfdf5; color: #047857; }
.mp-status--under-review { background: #fffbeb; color: #b45309; }
.mp-status--rejected { background: #fef2f2; color: #b91c1c; }

.mp-progress { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.mp-progress__bar { flex: 1 1 200px; height: 12px; background: #eef2f7; border-radius: 999px; overflow: hidden; }
.mp-progress__bar span { display: block; height: 100%; background: linear-gradient(90deg, #0ea5e9, #6366f1); border-radius: 999px; transition: width .4s ease; }
.mp-progress__meta strong { font-size: 1.2rem; color: var(--clr-heading); }
.mp-progress__meta small { display: block; color: var(--clr-muted); font-size: .78rem; }

.study-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.study-item { display: flex; align-items: center; gap: 12px; padding: 14px; border: 1px solid var(--clr-border); border-radius: 12px; background: #fff; }
.study-item.is-done { border-color: #a7f3d0; background: #f0fdf4; }
.study-item.is-locked { opacity: .65; }
.study-item__no { flex: 0 0 32px; width: 32px; height: 32px; border-radius: 50%; background: #eef2f7; color: var(--clr-muted); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .85rem; }
.study-item.is-done .study-item__no { background: #16a34a; color: #fff; }
.study-item__icon { color: var(--clr-primary); font-size: 1.2rem; flex: 0 0 auto; }
.study-item__body { flex: 1 1 auto; min-width: 0; }
.study-item__body strong { display: block; color: var(--clr-heading); }
.study-item__body small { color: var(--clr-muted); font-size: .78rem; }
.study-item__action { flex: 0 0 auto; }
.study-item__locked { font-size: .78rem; color: var(--clr-muted); }

.study-view__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 10px; }
.study-back { color: var(--clr-muted); font-size: .85rem; }

.pdf-viewer { border: 1px solid var(--clr-border); border-radius: 12px; overflow: hidden; background: #f1f5f9; margin-top: 12px; }
.pdf-viewer__bar { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px; background: #0f172a; color: #fff; }
.pdf-viewer__hint { font-size: .78rem; opacity: .85; }
.pdf-zoom { background: rgba(255,255,255,.15); color: #fff; border: 0; width: 30px; height: 30px; border-radius: 8px; cursor: pointer; }
.pdf-zoom:hover { background: rgba(255,255,255,.3); }
.pdf-viewer__pages { max-height: 75vh; overflow-y: auto; padding: 16px; text-align: center; }
.pdf-viewer__pages .pdf-page { max-width: 100%; height: auto; box-shadow: 0 4px 14px rgba(0,0,0,.12); margin: 0 auto 16px; display: block; background: #fff; }
.pdf-viewer__loading { color: var(--clr-muted); padding: 30px; }

.video-thumb { display: flex; align-items: center; gap: 14px; width: 100%; margin-top: 12px; padding: 28px; border: 1px dashed var(--clr-border); border-radius: 14px; background: #fff; cursor: pointer; font-weight: 600; color: var(--clr-heading); }
.video-thumb:hover { border-color: var(--clr-primary); }
.video-thumb__play { width: 54px; height: 54px; border-radius: 50%; background: linear-gradient(135deg, #0ea5e9, #6366f1); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; }

.video-modal { position: fixed; inset: 0; z-index: 1200; display: flex; align-items: center; justify-content: center; padding: 20px; }
.video-modal[hidden] { display: none; }
.video-modal__backdrop { position: absolute; inset: 0; background: rgba(15,23,42,.8); }
.video-modal__box { position: relative; width: 100%; max-width: 900px; }
.video-modal__close { position: absolute; top: -42px; right: 0; background: rgba(255,255,255,.15); color: #fff; border: 0; width: 36px; height: 36px; border-radius: 50%; cursor: pointer; font-size: 1.1rem; }
.video-modal__frame { position: relative; padding-bottom: 56.25%; height: 0; background: #000; border-radius: 12px; overflow: hidden; }
.video-modal__frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

@media (max-width: 600px) {
    .study-item { flex-wrap: wrap; }
    .study-item__body { flex: 1 1 60%; }
    .pdf-viewer__pages { max-height: 65vh; padding: 8px; }
    .video-thumb { flex-direction: column; text-align: center; padding: 20px; }
}

/* ============ Donation page ============ */
.dn-grid { display: grid; grid-template-columns: 1fr 360px; gap: 26px; align-items: start; }
.dn-main { display: flex; flex-direction: column; gap: 22px; }
.dn-side { display: flex; flex-direction: column; gap: 22px; position: sticky; top: 90px; }

.dn-card { background: #fff; border: 1px solid var(--clr-border); border-radius: 16px; padding: 22px; box-shadow: var(--shadow-sm); }
.dn-card__head h3 { font-size: 1.2rem; color: var(--clr-heading); margin: 0 0 4px; }
.dn-card__head p { color: var(--clr-muted); font-size: .88rem; margin: 0 0 16px; }

.dn-causes { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
.dn-cause { display: flex; flex-direction: column; border: 1px solid var(--clr-border); border-radius: 14px; overflow: hidden; transition: border-color .15s, box-shadow .15s, transform .15s; background: #fff; }
.dn-cause.is-active { border-color: var(--clr-secondary); box-shadow: 0 8px 24px rgba(251,140,0,.14); }
.dn-cause__media { height: 120px; background: #eef2f7; position: relative; }
.dn-cause__media img { width: 100%; height: 100%; object-fit: cover; }
.dn-cause__ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: 2rem; color: var(--clr-primary); }
.dn-cause__body { padding: 12px 14px 14px; display: flex; flex-direction: column; gap: 4px; flex: 1; }
.dn-cause__tag { align-self: flex-start; font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--clr-primary); background: var(--clr-tab-bg, #e3f2fd); padding: 2px 8px; border-radius: 999px; }
.dn-cause__body h4 { font-size: .98rem; color: var(--clr-heading); margin: 2px 0; }
.dn-cause__body p { font-size: .8rem; color: var(--clr-muted); margin: 0; flex: 1; }
.dn-cause__price { font-weight: 700; color: var(--clr-secondary); margin-top: 6px; }
.dn-cause__price small { color: var(--clr-muted); font-weight: 500; font-size: .72rem; }
.dn-cause__foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: 8px; }
.dn-cause__line { font-size: .9rem; color: var(--clr-heading); }

.dn-stepper { display: inline-flex; align-items: center; border: 1px solid var(--clr-border); border-radius: 999px; overflow: hidden; }
.dn-stepper button { width: 30px; height: 30px; border: 0; background: #f1f5f9; color: var(--clr-heading); cursor: pointer; font-size: .8rem; }
.dn-stepper button:hover { background: var(--clr-secondary); color: #fff; }
.dn-stepper input { width: 38px; text-align: center; border: 0; font-weight: 700; color: var(--clr-heading); background: #fff; }

.dn-total { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-top: 18px; padding: 16px 18px; border-radius: 14px; background: linear-gradient(135deg, var(--clr-tab-bg, #e3f2fd), #fff); border: 1px dashed var(--clr-primary); }
.dn-total small { display: block; color: var(--clr-muted); font-size: .76rem; }
.dn-total strong { font-size: 1.5rem; color: var(--clr-heading); }

.dn-form { display: flex; flex-direction: column; gap: 14px; }
.dn-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.dn-field { display: flex; flex-direction: column; gap: 5px; }
.dn-field label { font-size: .82rem; font-weight: 600; color: var(--clr-heading); }
.dn-field label span { color: #dc2626; }
.dn-field label em { color: var(--clr-muted); font-weight: 400; font-style: normal; font-size: .76rem; }
.dn-field input { width: 100%; padding: 11px 13px; border: 1px solid var(--clr-border); border-radius: 10px; font-size: .9rem; background: #fff; transition: border-color .15s, box-shadow .15s; }
.dn-field input:focus { outline: 0; border-color: var(--clr-primary); box-shadow: 0 0 0 3px rgba(21,101,192,.12); }

.dn-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.dn-chip { padding: 8px 14px; border: 1px solid var(--clr-border); border-radius: 999px; background: #fff; cursor: pointer; font-weight: 600; font-size: .85rem; color: var(--clr-heading); transition: all .15s; }
.dn-chip:hover { border-color: var(--clr-secondary); color: var(--clr-secondary); }
.dn-chip.is-active { background: var(--clr-secondary); border-color: var(--clr-secondary); color: #fff; }
.dn-amount { display: flex; align-items: center; border: 1px solid var(--clr-border); border-radius: 10px; overflow: hidden; }
.dn-amount span { padding: 0 13px; font-weight: 700; color: var(--clr-muted); background: #f8fafc; align-self: stretch; display: flex; align-items: center; }
.dn-amount input { border: 0; padding: 12px 13px; font-size: 1.1rem; font-weight: 700; width: 100%; }
.dn-amount input:focus { outline: 0; }

.dn-error { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; padding: 10px 14px; border-radius: 10px; font-size: .85rem; margin: 0; }
.dn-secure { text-align: center; color: var(--clr-muted); font-size: .8rem; margin: 4px 0 0; }
.dn-spin { display: inline-block; width: 15px; height: 15px; border: 2px solid rgba(255,255,255,.5); border-top-color: #fff; border-radius: 50%; animation: dn-spin .7s linear infinite; vertical-align: -2px; }
@keyframes dn-spin { to { transform: rotate(360deg); } }

.dn-why ul { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.dn-why li { display: flex; gap: 10px; align-items: flex-start; font-size: .88rem; color: var(--clr-text); }
.dn-why li i { color: #16a34a; margin-top: 3px; }
.dn-why h3, .dn-bank h3, .dn-claim h3 { font-size: 1.05rem; color: var(--clr-heading); margin: 0 0 6px; }

.dn-bank__list { list-style: none; margin: 12px 0 0; padding: 0; }
.dn-bank__list li { display: flex; justify-content: space-between; gap: 10px; padding: 8px 0; border-bottom: 1px dashed var(--clr-border); font-size: .86rem; }
.dn-bank__list li:last-child { border-bottom: 0; }
.dn-bank__list span { color: var(--clr-muted); }
.dn-bank__list strong { color: var(--clr-heading); text-align: right; word-break: break-word; }
.dn-qr { text-align: center; margin: 6px 0 6px; }
.dn-qr img { width: 168px; height: 168px; border: 1px solid var(--clr-border); border-radius: 12px; padding: 8px; background: #fff; }
.dn-qr small { display: block; color: var(--clr-muted); font-size: .76rem; margin-top: 6px; }

.dn-claim p { color: var(--clr-muted); font-size: .86rem; margin: 0 0 14px; }

.dn-success-overlay { position: fixed; inset: 0; z-index: 1300; display: flex; align-items: center; justify-content: center; padding: 20px; background: rgba(15,23,42,.6); }
.dn-success-overlay[hidden] { display: none; }
.dn-success-box { background: #fff; border-radius: 18px; padding: 36px 30px; max-width: 420px; width: 100%; text-align: center; box-shadow: 0 24px 60px rgba(0,0,0,.25); }
.dn-success-icon { width: 70px; height: 70px; border-radius: 50%; background: #16a34a; color: #fff; display: inline-flex; align-items: center; justify-content: center; font-size: 1.8rem; margin-bottom: 14px; }
.dn-success-box h3 { color: var(--clr-heading); margin: 0 0 8px; }
.dn-success-box p { color: var(--clr-muted); margin: 0 0 14px; }
.dn-receipt { background: #f0fdf4; border: 1px solid #bbf7d0; color: #166534; border-radius: 10px; padding: 10px; font-size: .85rem; margin-bottom: 16px; }

@media (max-width: 992px) {
    .dn-grid { grid-template-columns: 1fr; }
    .dn-side { position: static; }
}
@media (max-width: 600px) {
    .dn-causes { grid-template-columns: 1fr; }
    .dn-form__row { grid-template-columns: 1fr; }
    .dn-cause__media { height: 140px; }
}

/* ============================================================
   Members Directory (Card / List / Map)
   ============================================================ */
.section.md { --md-teal: var(--clr-primary); --md-teal2: var(--clr-footer-bg); }

.md-filters {
    display: grid;
    grid-template-columns: 1.6fr repeat(4, 1fr) auto;
    gap: 16px;
    align-items: end;
    background: var(--clr-surface);
    border: 1px solid #eef2f7;
    border-radius: 16px;
    padding: 18px 20px;
    box-shadow: 0 10px 30px rgba(13, 43, 90, .06);
    margin-bottom: 26px;
}
.md-filters--4 { grid-template-columns: 1.6fr repeat(3, 1fr) auto; }
.md-filter label {
    display: block;
    font-size: .8rem;
    color: #64748b;
    margin-bottom: 6px;
}
.md-filter select,
.md-search input {
    width: 100%;
    height: 44px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    padding: 0 14px;
    background: #fff;
    font-size: .92rem;
    color: #334155;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
}
.md-filter select:focus,
.md-search input:focus {
    border-color: var(--md-teal);
    box-shadow: 0 0 0 3px rgba(43, 168, 142, .15);
}
.md-search { position: relative; }
.md-search i {
    position: absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--md-teal);
    pointer-events: none;
}
.md-reset {
    height: 44px;
    width: 48px;
    border: none;
    border-radius: 10px;
    background: #334155;
    color: #fff;
    cursor: pointer;
    transition: background .15s;
}
.md-reset:hover { background: #1e293b; }

.md-panel {
    background: var(--clr-surface);
    border: 1px solid #eef2f7;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(13, 43, 90, .06);
    overflow: hidden;
}
.md-tabs {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-bottom: 1px solid #eef2f7;
}
.md-tab {
    border: none;
    background: transparent;
    padding: 18px 12px;
    font-weight: 600;
    font-size: .95rem;
    color: #64748b;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.md-tab i { margin-right: 6px; }
.md-tab.is-active {
    background: linear-gradient(135deg, var(--md-teal), var(--md-teal2));
    color: #fff;
}
.md-body { padding: 26px; position: relative; min-height: 220px; }

.md-loading { display: flex; justify-content: center; padding: 40px 0; }
.md-spinner {
    width: 34px; height: 34px;
    border: 3px solid #d7e6f5;
    border-top-color: var(--md-teal);
    border-radius: 50%;
    animation: md-spin .8s linear infinite;
}
@keyframes md-spin { to { transform: rotate(360deg); } }
.md-empty { text-align: center; color: #94a3b8; padding: 40px 0; }

/* Cards */
.md-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 22px;
}
.md-card {
    border: 1px solid #eef2f7;
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    transition: transform .15s, box-shadow .15s;
}
.md-card:hover { transform: translateY(-3px); box-shadow: 0 16px 36px rgba(13, 43, 90, .12); }
.md-card__top {
    background: linear-gradient(135deg, var(--clr-bg), #e6f0ff);
    padding: 26px 0 18px;
    display: flex;
    justify-content: center;
}
.md-card__photo {
    position: relative;
    width: 104px; height: 104px;
}
.md-card__photo-inner {
    display: block;
    width: 100%; height: 100%;
    border-radius: 50%;
    overflow: hidden;
    border: 4px solid #fff;
    box-shadow: 0 6px 16px rgba(13, 43, 90, .15);
    background: #cbd5e1;
}
.md-card__photo img { width: 100%; height: 100%; object-fit: cover; }
.md-initials {
    display: flex; align-items: center; justify-content: center;
    width: 100%; height: 100%;
    font-weight: 700; font-size: 1.6rem; color: #fff;
    background: linear-gradient(135deg, var(--md-teal), var(--md-teal2));
}
.md-verified {
    position: absolute;
    right: 4px; bottom: 4px;
    z-index: 3;
    color: #2563eb;
    background: #fff;
    border-radius: 50%;
    width: 24px; height: 24px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    box-shadow: 0 1px 4px rgba(0, 0, 0, .2);
}
.md-verified.sm { width: 16px; height: 16px; right: -2px; bottom: -2px; font-size: .72rem; }
.md-card__rows { padding: 6px 18px 18px; }
.md-row {
    display: grid;
    grid-template-columns: 96px 1fr;
    gap: 8px;
    padding: 9px 0;
    border-bottom: 1px solid #f1f5f9;
    font-size: .9rem;
}
.md-row:last-child { border-bottom: none; }
.md-row__k { color: #94a3b8; text-transform: uppercase; font-size: .7rem; letter-spacing: .04em; font-weight: 600; align-self: center; }
.md-row__v { color: #334155; }
.md-id { color: var(--md-teal2); font-weight: 700; }

/* List */
.md-table-wrap { overflow-x: auto; border: 1px solid #eef2f7; border-radius: 14px; }
.md-table { width: 100%; border-collapse: separate; border-spacing: 0; min-width: 640px; }
.md-table thead th {
    background: #f1f5f9;
    color: #475569;
    text-align: left;
    padding: 14px 18px;
    font-size: .78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    cursor: pointer;
    white-space: nowrap;
    position: relative;
    user-select: none;
    border-bottom: 2px solid #e2e8f0;
    transition: background .15s;
}
.md-table thead th:hover { background: #e8eef6; }
.md-table thead th:first-child { border-top-left-radius: 14px; }
.md-table thead th:last-child { border-top-right-radius: 14px; }
.md-table thead th i { opacity: .5; margin-left: 6px; color: var(--clr-primary); }
.md-table thead th.asc i:before { content: "\f0de"; opacity: 1; }
.md-table thead th.desc i:before { content: "\f0dd"; opacity: 1; }
.md-table .md-th-no { width: 56px; text-align: center; cursor: default; }
.md-table tbody td { padding: 14px 18px; border-bottom: 1px solid #eef2f7; vertical-align: middle; font-size: .9rem; color: #334155; }
.md-table tbody tr:last-child td { border-bottom: none; }
.md-table tbody tr:nth-child(even) { background: #f8fbff; }
.md-table tbody tr:hover { background: #eef5ff; }
.md-table small { color: #94a3b8; }

/* Pagination */
.md-pager { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-top: 22px; }
.md-pager:empty { margin: 0; }
.md-page-btn {
    min-width: 38px;
    height: 38px;
    padding: 0 10px;
    border: 1px solid #e2e8f0;
    background: #fff;
    border-radius: 9px;
    color: #475569;
    font-weight: 600;
    font-size: .88rem;
    cursor: pointer;
    transition: all .15s;
}
.md-page-btn:hover:not(:disabled):not(.is-active) { border-color: var(--clr-primary); color: var(--clr-primary); }
.md-page-btn.is-active { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }
.md-page-btn:disabled { opacity: .4; cursor: not-allowed; }
.md-page-dots { padding: 0 4px; color: #94a3b8; }
.md-page-info { margin-left: auto; color: #94a3b8; font-size: .82rem; }
.md-cell-user { display: flex; align-items: center; gap: 12px; }
.md-cell-photo { position: relative; width: 42px; height: 42px; flex: 0 0 auto; }
.md-cell-photo-inner { display: block; width: 100%; height: 100%; border-radius: 50%; overflow: hidden; background: #cbd5e1; }
.md-cell-photo img { width: 100%; height: 100%; object-fit: cover; }
.md-cell-photo .md-initials { font-size: .85rem; }

/* Map */
.md-map-toggle { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 14px; font-size: .9rem; color: #334155; cursor: pointer; }
.md-map { height: 540px; width: 100%; border-radius: 12px; overflow: hidden; border: 1px solid #eef2f7; background: #eef4fb; }
.md-pin-tip { padding: 0; border: none; background: transparent; box-shadow: none; }
.md-pin-tip:before { display: none !important; }
.md-pin-tip .leaflet-tooltip-content, .md-pin-tip.leaflet-tooltip { background: transparent; }
.md-tip {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fff;
    border-radius: 12px;
    padding: 8px 12px 8px 8px;
    box-shadow: 0 6px 20px rgba(13, 43, 90, .28);
    border: 1px solid #eef2f7;
}
.md-tip__img {
    width: 42px; height: 42px;
    flex: 0 0 auto;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid var(--clr-primary);
    background: #cbd5e1;
    display: block;
}
.md-tip__img img { width: 100%; height: 100%; object-fit: cover; }
.md-tip__img .md-initials { font-size: .85rem; }
.md-tip__txt { display: flex; flex-direction: column; line-height: 1.25; }
.md-tip__txt b { color: #0d2b5a; font-size: .9rem; }
.md-tip__txt small { color: var(--clr-primary); font-size: .76rem; }
/* Animated dotted member markers */
.leaflet-marker-icon.md-dot { overflow: visible; background: transparent; border: none; }
.md-dot__core,
.md-dot__pulse {
    position: absolute;
    top: 50%; left: 50%;
    border-radius: 50%;
    transform: translate(-50%, -50%);
}
.md-dot__core {
    width: 12px; height: 12px;
    background: var(--clr-primary);
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(13, 43, 90, .45);
    z-index: 2;
    transition: transform .15s;
}
.md-dot__pulse {
    width: 12px; height: 12px;
    background: var(--clr-primary);
    opacity: .55;
    z-index: 1;
    animation: mdPulse 1.8s ease-out infinite;
}
@keyframes mdPulse {
    0% { transform: translate(-50%, -50%) scale(1); opacity: .55; }
    70% { transform: translate(-50%, -50%) scale(3.4); opacity: 0; }
    100% { transform: translate(-50%, -50%) scale(3.4); opacity: 0; }
}
.leaflet-marker-icon.md-dot:hover .md-dot__core { transform: translate(-50%, -50%) scale(1.35); }

/* Marker clusters (for thousands of members) */
.md-cluster-wrap { background: transparent; border: none; }
.md-cluster {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    background: var(--clr-primary);
    color: #fff;
    font-weight: 700;
    font-size: .85rem;
    border: 3px solid rgba(255, 255, 255, .85);
    box-shadow: 0 2px 10px rgba(13, 43, 90, .35);
}
.md-legend {
    background: #fff;
    padding: 10px 12px;
    border-radius: 8px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, .15);
    font-size: .8rem;
    line-height: 1.7;
    color: #334155;
}
.md-legend strong { display: block; margin-bottom: 4px; }
.md-legend span { display: flex; align-items: center; gap: 8px; }
.md-legend i { width: 16px; height: 16px; border-radius: 3px; display: inline-block; }

@media (max-width: 992px) {
    .md-filters, .md-filters--4 { grid-template-columns: 1fr 1fr; }
    .md-filter--search { grid-column: 1 / -1; }
    .md-reset { width: 100%; }
}
@media (max-width: 560px) {
    .md-filters, .md-filters--4 { grid-template-columns: 1fr; }
    .md-tab { font-size: .82rem; padding: 14px 6px; }
    .md-tab i { display: block; margin: 0 0 4px; }
    .md-body { padding: 16px; }
    .md-map { height: 420px; }
}

/* =====================================================
   SHOP / STOREFRONT
   ===================================================== */
.shop-trust {
    background: linear-gradient(90deg, var(--clr-primary), #1976d2);
    color: #fff;
    padding: 14px 0;
}
.shop-trust__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
}
.shop-trust__list li {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: .88rem;
    font-weight: 600;
    opacity: .95;
}
.shop-trust__list i { font-size: 1.05rem; opacity: .9; }

.shop-section { padding-top: 36px; }

.shop-cat-chips {
    display: none;
    gap: 8px;
    overflow-x: auto;
    padding-bottom: 4px;
    margin-bottom: 18px;
    scrollbar-width: none;
}
.shop-cat-chips::-webkit-scrollbar { display: none; }
.shop-cat-chip {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: 999px;
    border: 1px solid var(--clr-border);
    background: #fff;
    color: var(--clr-h4);
    font-size: .84rem;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: border-color .15s, background .15s, color .15s;
}
.shop-cat-chip em {
    font-style: normal;
    font-size: .74rem;
    color: var(--clr-h6);
    background: var(--clr-tab-bg);
    padding: 1px 7px;
    border-radius: 999px;
}
.shop-cat-chip:hover,
.shop-cat-chip.is-active {
    border-color: var(--clr-primary);
    background: var(--clr-tab-bg);
    color: var(--clr-primary);
}
.shop-cat-chip.is-active em { background: rgba(21, 101, 192, .15); color: var(--clr-primary); }

.shop-grid { display: grid; grid-template-columns: 280px minmax(0, 1fr); gap: 28px; align-items: start; }
.shop-sidebar { position: sticky; top: 90px; display: grid; gap: 16px; }
.shop-main { min-width: 0; }

.shop-panel {
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: 14px;
    padding: 18px;
    box-shadow: var(--shadow-sm);
}
.shop-panel--accent {
    background: linear-gradient(145deg, var(--clr-primary), #1976d2);
    border-color: transparent;
    color: #fff;
}
.shop-panel__title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .95rem;
    font-weight: 700;
    color: var(--clr-h3);
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--clr-border);
}
.shop-panel__title i { color: var(--clr-primary); font-size: .9rem; }
.shop-panel--accent .shop-panel__title { color: #fff; border-bottom-color: rgba(255,255,255,.2); }
.shop-panel--accent .shop-panel__title i { color: #fff; }

.shop-search { display: flex; gap: 8px; }
.shop-search__input {
    flex: 1;
    min-width: 0;
    border: 1px solid var(--clr-border);
    border-radius: 10px;
    padding: 10px 12px;
    font-size: .9rem;
    background: var(--clr-bg);
    transition: border-color .15s, box-shadow .15s;
}
.shop-search__input:focus {
    outline: none;
    border-color: var(--clr-primary);
    box-shadow: 0 0 0 3px rgba(21, 101, 192, .12);
}
.shop-search__btn {
    flex: 0 0 auto;
    width: 42px;
    border: none;
    border-radius: 10px;
    background: var(--clr-primary);
    color: #fff;
    cursor: pointer;
    transition: background .15s;
}
.shop-search__btn:hover { background: var(--clr-secondary); }
.shop-search--mobile { display: none; margin-bottom: 14px; }

.shop-cat-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.shop-cat-list a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    font-size: .9rem;
    color: var(--clr-h4);
    text-decoration: none;
    transition: background .15s ease, color .15s ease;
}
.shop-cat-list a:hover { background: var(--clr-tab-bg); color: var(--clr-primary); }
.shop-cat-list a.is-active { background: var(--clr-tab-bg); color: var(--clr-primary); font-weight: 700; }
.shop-cat-list__count {
    font-size: .74rem;
    font-weight: 700;
    color: var(--clr-h6);
    background: var(--clr-bg);
    padding: 2px 8px;
    border-radius: 999px;
}
.shop-cat-list a.is-active .shop-cat-list__count { background: rgba(21, 101, 192, .12); color: var(--clr-primary); }

.shop-track-card { text-align: center; }
.shop-track-card > i { font-size: 1.8rem; color: #fff; opacity: .95; margin-bottom: 8px; }
.shop-track-card h3 { font-size: 1.05rem; color: #fff; margin: 0 0 6px; border: 0; padding: 0; }
.shop-track-card p { font-size: .84rem; color: #fff; margin: 0 0 14px; line-height: 1.5; }

.shop-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 22px;
    padding: 14px 16px;
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: 12px;
    box-shadow: var(--shadow-sm);
}
.shop-toolbar__count { font-size: .92rem; color: var(--clr-h5); }
.shop-toolbar__count strong { color: var(--clr-h3); }
.shop-toolbar__filter { color: var(--clr-h6); }
.shop-toolbar__right { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.shop-sort { display: flex; align-items: center; gap: 8px; }
.shop-sort__label { font-size: .82rem; color: var(--clr-h6); white-space: nowrap; }
.shop-sort__select {
    border: 1px solid var(--clr-border);
    border-radius: 9px;
    padding: 8px 30px 8px 10px;
    font-size: .86rem;
    color: var(--clr-h4);
    background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23546e7a' d='M6 8L1 3h10z'/%3E%3C/svg%3E") no-repeat right 10px center;
    appearance: none;
    cursor: pointer;
}
.shop-sort__select:focus { outline: none; border-color: var(--clr-primary); }

.shop-products {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 22px;
}

.shop-card {
    background: #fff;
    border: 1px solid var(--clr-border);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    display: flex;
    flex-direction: column;
}
.shop-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
    border-color: rgba(21, 101, 192, .25);
}
.shop-card.is-sold-out { opacity: .88; }
.shop-card.is-sold-out .shop-card__img-link img { filter: grayscale(.35); }

.shop-card__media {
    position: relative;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: linear-gradient(145deg, #e8eef8, #dfe7f5);
}
.shop-card__img-link { display: block; width: 100%; height: 100%; }
.shop-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s ease;
}
.shop-card:hover .shop-card__media img { transform: scale(1.06); }

.shop-card__badges {
    position: absolute;
    top: 10px;
    left: 10px;
    right: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    z-index: 2;
    pointer-events: none;
}
.shop-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 700;
    text-transform: capitalize;
    line-height: 1.2;
}
.shop-badge--sale { background: #e53935; color: #fff; }
.shop-badge--label { background: var(--clr-secondary); color: #fff; }
.shop-badge--featured { background: #fff; color: var(--clr-primary); box-shadow: 0 2px 8px rgba(0,0,0,.12); }
.shop-badge--stock { background: #37474f; color: #fff; margin-left: auto; }
.shop-badge--digital { background: #7b1fa2; color: #fff; }

.shop-download-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; }
.shop-download-list li {
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    padding: 12px 14px; border: 1px solid var(--clr-border); border-radius: 10px; background: var(--clr-tab-bg);
}
.shop-digital-downloads h3 { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }

.shop-card__actions {
    position: absolute;
    inset: auto 0 0 0;
    display: flex;
    gap: 8px;
    padding: 12px;
    background: linear-gradient(to top, rgba(13, 43, 90, .72), transparent);
    transform: translateY(100%);
    opacity: 0;
    transition: transform .25s ease, opacity .25s ease;
    z-index: 3;
}
.shop-card:hover .shop-card__actions { transform: translateY(0); opacity: 1; }
.shop-card__action {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 12px;
    border: none;
    border-radius: 10px;
    font-size: .82rem;
    font-weight: 700;
    text-decoration: none;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.shop-card__action--view { background: #fff; color: var(--clr-h3); }
.shop-card__action--view:hover { background: var(--clr-tab-bg); color: var(--clr-primary); }
.shop-card__action--cart { background: var(--clr-primary); color: #fff; width: 100%; }
.shop-card__action--cart:hover { background: var(--clr-secondary); }
.shop-card__actions form { flex: 1; display: flex; }

.shop-card__body {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 6px;
}
.shop-card__cat {
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--clr-secondary);
}
.shop-card__title {
    font-size: 1rem;
    line-height: 1.35;
    margin: 0;
    color: var(--clr-h3);
}
.shop-card__title a { color: inherit; text-decoration: none; }
.shop-card__title a:hover { color: var(--clr-primary); }
.shop-card__desc {
    margin: 0;
    font-size: .82rem;
    color: var(--clr-h6);
    line-height: 1.45;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.shop-card__footer {
    margin-top: auto;
    padding-top: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.shop-card__price { display: flex; align-items: baseline; flex-wrap: wrap; gap: 6px; }
.shop-card__price-now { font-size: 1.12rem; font-weight: 800; color: var(--clr-primary); }
.shop-card__price-was { font-size: .82rem; color: var(--clr-h6); text-decoration: line-through; }
.shop-card__quick-add { margin: 0; }
.shop-card__quick-btn {
    width: 38px;
    height: 38px;
    border: 1px solid var(--clr-border);
    border-radius: 10px;
    background: #fff;
    color: var(--clr-primary);
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s, transform .15s;
}
.shop-card__quick-btn:hover {
    background: var(--clr-primary);
    border-color: var(--clr-primary);
    color: #fff;
    transform: scale(1.05);
}

.shop-pagination { margin-top: 28px; display: flex; justify-content: center; }

.shop-empty {
    text-align: center;
    padding: 56px 24px;
    background: #fff;
    border: 1px dashed var(--clr-border);
    border-radius: 16px;
}
.shop-empty__icon {
    width: 72px;
    height: 72px;
    margin: 0 auto 16px;
    border-radius: 50%;
    background: var(--clr-tab-bg);
    color: var(--clr-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
}
.shop-empty h3 { margin: 0 0 8px; color: var(--clr-h3); }
.shop-empty p { margin: 0 0 20px; color: var(--clr-h6); font-size: .92rem; }

/* Cart quantity stepper */
.cart-qty {
    display: inline-flex;
    align-items: center;
    gap: 0;
    border: 1px solid var(--clr-border);
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
}
.cart-qty__btn {
    width: 34px;
    height: 34px;
    border: none;
    background: var(--clr-tab-bg);
    color: var(--clr-h3);
    font-size: 1.1rem;
    line-height: 1;
    cursor: pointer;
    transition: background .15s, color .15s;
}
.cart-qty__btn:hover:not(:disabled) { background: var(--clr-primary); color: #fff; }
.cart-qty__btn:disabled { opacity: .45; cursor: not-allowed; }
.cart-qty__val {
    min-width: 36px;
    padding: 0 6px;
    text-align: center;
    font-size: .92rem;
    font-weight: 700;
    color: var(--clr-h3);
    border-left: 1px solid var(--clr-border);
    border-right: 1px solid var(--clr-border);
    line-height: 34px;
}
.cart-line__qty-form { flex: 0 0 auto; }

@media (max-width: 900px) {
    .shop-trust__list { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
    .shop-trust__list li { justify-content: flex-start; font-size: .82rem; }
    .shop-grid { grid-template-columns: 1fr; }
    .shop-sidebar { position: static; display: none; }
    .shop-search--mobile { display: flex; }
    .shop-cat-chips { display: flex; }
    .shop-toolbar { padding: 12px; }
}
@media (max-width: 560px) {
    .shop-products { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
    .shop-card__body { padding: 10px 12px 12px; }
    .shop-card__title { font-size: .88rem; }
    .shop-card__desc { display: none; }
    .shop-card__price-now { font-size: .98rem; }
    .shop-card__actions { display: none; }
    .shop-toolbar__right { width: 100%; justify-content: space-between; }
    .shop-sort { flex: 1; }
    .shop-sort__select { flex: 1; min-width: 0; }
}

/* Order tracking */
.track-steps { display: flex; align-items: flex-start; justify-content: space-between; margin: 20px 0 4px; position: relative; }
.track-steps::before { content: ""; position: absolute; top: 15px; left: 8%; right: 8%; height: 3px; background: var(--clr-border); z-index: 0; }
.track-step { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; flex: 1; text-align: center; }
.track-step__dot { width: 32px; height: 32px; border-radius: 50%; background: #fff; border: 2px solid var(--clr-border); color: var(--clr-h6); display: flex; align-items: center; justify-content: center; font-size: .82rem; font-weight: 700; }
.track-step__label { font-size: .78rem; color: var(--clr-h6); }
.track-step.is-done .track-step__dot { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }
.track-step.is-done .track-step__label { color: var(--clr-h4); font-weight: 600; }
.track-timeline { margin-top: 18px; border-top: 1px dashed var(--clr-border); padding-top: 14px; }
.track-timeline ul { list-style: none; margin: 0; padding: 0 0 0 18px; border-left: 2px solid var(--clr-tab-bg); }
.track-timeline li { position: relative; padding: 0 0 14px; }
.track-timeline li:last-child { padding-bottom: 0; }
.track-timeline li::before { content: ""; position: absolute; left: -25px; top: 4px; width: 10px; height: 10px; border-radius: 50%; background: var(--clr-primary); }
.track-timeline__badge { display: inline-block; font-size: .8rem; font-weight: 700; color: var(--clr-h3); }
.track-timeline p { margin: 4px 0 2px; font-size: .88rem; color: var(--clr-h5); }
.track-timeline small { font-size: .76rem; color: var(--clr-h6); }

/* =====================================================
   FUNDRAISER
   ===================================================== */
.fundraise-cta { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; background: linear-gradient(120deg, var(--clr-primary), var(--clr-secondary)); color: #fff; border-radius: var(--radius); padding: 22px 26px; margin-bottom: 30px; }
.fundraise-cta h3 { color: #fff; margin: 0 0 4px; font-size: 1.25rem; }
.fundraise-cta p { margin: 0; opacity: .92; font-size: .92rem; }
.fr-stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; }
.fr-stat { background: #fff; border: 1px solid var(--clr-border); border-radius: 12px; padding: 16px 18px; box-shadow: var(--shadow-sm); }
.fr-stat__label { font-size: .78rem; color: var(--clr-h6); text-transform: uppercase; letter-spacing: .03em; }
.fr-stat__value { font-size: 1.5rem; font-weight: 800; color: var(--clr-primary); margin-top: 4px; }
.fr-badge { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: .74rem; font-weight: 700; text-transform: capitalize; }
.fr-badge--approved { background: #e8f5e9; color: #2e7d32; }
.fr-badge--pending { background: #fff8e1; color: #f57f17; }
.fr-badge--rejected { background: #fdecea; color: #c0392b; }
.fr-badge--draft { background: #eceff1; color: #546e7a; }
.fr-stars { color: #fbc02d; font-size: 1.1rem; letter-spacing: 2px; }
.fr-stars .off { color: #d7d7d7; }
.table-x { border-collapse: collapse; font-size: .9rem; }
.table-x th { padding: 9px 12px; border-bottom: 2px solid var(--clr-border); color: var(--clr-h6); font-weight: 700; font-size: .78rem; text-transform: uppercase; letter-spacing: .03em; white-space: nowrap; }
.table-x td { padding: 10px 12px; border-bottom: 1px solid var(--clr-border); color: var(--clr-h4); }
.table-x tbody tr:last-child td { border-bottom: 0; }

/* =====================================================
   HOME — FUNDAMENTAL RIGHTS CARDS
   ===================================================== */
.fundamental-rights-home .section-head__lead {
    max-width: 640px;
    margin: 12px auto 0;
    color: var(--clr-h5);
    font-size: .95rem;
    line-height: 1.6;
}

.fr-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

@media (min-width: 768px) {
    .fr-cards { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
}

@media (min-width: 1200px) {
    .fr-cards { grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 18px; }
}

.fr-card {
    --fr-color: #2563eb;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    min-height: 168px;
    padding: 22px 14px 18px;
    border-radius: 14px;
    border: 2px dashed color-mix(in srgb, var(--fr-color) 55%, #fff);
    background: color-mix(in srgb, var(--fr-color) 8%, #fff);
    box-shadow: 0 8px 24px rgba(15, 23, 42, .06);
    text-decoration: none;
    text-align: center;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}

.fr-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(15, 23, 42, .12);
    border-color: var(--fr-color);
    background: color-mix(in srgb, var(--fr-color) 12%, #fff);
}

.fr-card__icon {
    width: 58px;
    height: 58px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.35rem;
    background: radial-gradient(circle at 30% 25%, color-mix(in srgb, var(--fr-color) 85%, #fff), var(--fr-color));
    box-shadow: 0 8px 18px color-mix(in srgb, var(--fr-color) 35%, transparent);
}

.fr-card__title {
    font-family: var(--font-heading, 'Josefin Sans', sans-serif);
    font-size: .72rem;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: .02em;
    color: var(--fr-color);
}

@media (min-width: 768px) {
    .fr-card { min-height: 180px; padding: 24px 16px 20px; }
    .fr-card__icon { width: 64px; height: 64px; font-size: 1.45rem; }
    .fr-card__title { font-size: .78rem; }
}
