/* =====================================================================
   JEWELS Africa - Premium Theme (Black | White | Gold)
   ===================================================================== */

:root {
    --ja-black: #0a0a0a;
    --ja-black-soft: #141414;
    --ja-charcoal: #1f1f1f;
    --ja-graphite: #2b2b2b;
    --ja-ink: #111111;
    --ja-white: #ffffff;
    --ja-cream: #faf7f1;
    --ja-light: #f7f5ef;
    --ja-gold: #c9a227;
    --ja-gold-bright: #e6b835;
    --ja-gold-deep: #a07d10;
    --ja-gold-soft: #f5e9c3;
    --ja-muted: #6c757d;
    --ja-border: rgba(201, 162, 39, 0.25);
    --ja-shadow-sm: 0 6px 18px rgba(10, 10, 10, 0.06);
    --ja-shadow-md: 0 18px 40px rgba(10, 10, 10, 0.10);
    --ja-shadow-lg: 0 32px 60px rgba(10, 10, 10, 0.16);
    --ja-gold-gradient: linear-gradient(135deg, #f3d27a 0%, #c9a227 50%, #8a6a0a 100%);
    --ja-dark-gradient: linear-gradient(135deg, #0a0a0a 0%, #1f1f1f 100%);
    --ja-font-display: "Playfair Display", "Georgia", serif;
    --ja-font-body: "Poppins", "Segoe UI", system-ui, -apple-system, sans-serif;
    --ja-radius: 14px;
    --ja-radius-lg: 22px;
}

/* ---------- Base ---------- */
html { font-size: 15px; scroll-behavior: smooth; }
@media (min-width: 992px) { html { font-size: 16px; } }
body {
    font-family: var(--ja-font-body);
    color: #222;
    background: var(--ja-white);
    line-height: 1.7;
    overflow-x: hidden;
}
h1, h2, h3, h4, h5, .display-1, .display-2, .display-3, .display-4 {
    font-family: var(--ja-font-display);
    color: var(--ja-black);
    font-weight: 700;
    letter-spacing: -0.02em;
}
p { color: #4a4a4a; }
a { color: var(--ja-gold-deep); text-decoration: none; transition: all .25s ease; }
a:hover { color: var(--ja-gold); }
.text-gold { color: var(--ja-gold) !important; }
.bg-gold { background: var(--ja-gold-gradient) !important; color: #fff; }
.bg-black-soft { background: var(--ja-black-soft); color: #fff; }
.text-muted-light { color: rgba(255,255,255,0.7); }

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

/* ---------- Utility / Sections ---------- */
.section-padding { padding: 6rem 0; }
@media (max-width: 767px) { .section-padding { padding: 4rem 0; } }
.section-padding-sm { padding: 3.5rem 0; }
.bg-soft { background: var(--ja-cream); }
.bg-dark-jewel { background: var(--ja-dark-gradient); color: #fff; }
.bg-dark-jewel h1, .bg-dark-jewel h2, .bg-dark-jewel h3, .bg-dark-jewel h4, .bg-dark-jewel h5 { color: #fff; }

.section-eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    text-transform: uppercase; letter-spacing: .35em;
    font-size: .72rem; font-weight: 600;
    color: var(--ja-gold-deep);
    margin-bottom: 1rem;
}
.section-eyebrow::before, .section-eyebrow::after {
    content: ""; width: 32px; height: 1px; background: var(--ja-gold);
}
.section-title { font-size: clamp(1.85rem, 3vw, 2.8rem); margin-bottom: 1.25rem; }
.section-lead { font-size: 1.05rem; color: #555; max-width: 720px; margin: 0 auto 2.5rem; }

.divider-gold {
    width: 90px; height: 3px; border: 0;
    background: var(--ja-gold-gradient); border-radius: 99px;
    margin: 0 0 1.5rem 0;
}
.text-center .divider-gold { margin-left: auto; margin-right: auto; }

/* ---------- Buttons ---------- */
.btn { font-family: var(--ja-font-body); font-weight: 600; letter-spacing: .02em; border-radius: 99px; padding: .7rem 1.6rem; transition: all .3s ease; position: relative; }
.btn i { vertical-align: -2px; margin-right: .4rem; }
.btn-gold {
    background: var(--ja-gold-gradient);
    color: #1a1a1a; border: 0;
    box-shadow: 0 12px 26px rgba(201, 162, 39, 0.35);
}
.btn-gold:hover { transform: translateY(-2px); color: #0a0a0a; box-shadow: 0 16px 32px rgba(201, 162, 39, 0.5); }
.btn-outline-gold {
    background: transparent;
    color: var(--ja-gold);
    border: 1.5px solid var(--ja-gold);
}
.btn-outline-gold:hover { background: var(--ja-gold-gradient); color: #1a1a1a; border-color: transparent; }
.btn-dark-jewel { background: var(--ja-black); color: #fff; border: 0; }
.btn-dark-jewel:hover { background: #000; color: var(--ja-gold-bright); }
.btn-light-jewel { background: #fff; color: var(--ja-black); border: 1.5px solid rgba(0,0,0,0.08); }
.btn-light-jewel:hover { color: var(--ja-gold-deep); border-color: var(--ja-gold); }

/* ---------- Top Utility Bar ---------- */
.top-utility-bar {
    background: var(--ja-black);
    color: #d8d8d8;
    font-size: .82rem;
    padding: .55rem 0;
    border-bottom: 1px solid rgba(201,162,39,0.18);
}
.top-utility-bar .container-xxl {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    max-width: 1480px;
}
.top-utility-bar i { color: var(--ja-gold-bright); margin-right: .35rem; }
.top-utility-bar .utility-right a {
    color: #d8d8d8; margin-left: .8rem; font-size: 1rem;
}
.top-utility-bar .utility-right a:hover { color: var(--ja-gold-bright); }
.top-utility-bar .utility-donate {
    background: var(--ja-gold-gradient); color: #1a1a1a;
    padding: .3rem .9rem; border-radius: 99px; font-weight: 600; font-size: .8rem;
}
.top-utility-bar .utility-donate:hover { color: #0a0a0a; }

/* ---------- Navbar ---------- */
.ja-navbar {
    background: rgba(255,255,255,0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    padding: 1.1rem 0;
    transition: all .3s ease;
    position: sticky; top: 0; z-index: 1030;
    border-bottom: 1px solid rgba(0,0,0,0.05);
}
.ja-navbar .container-xxl {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    max-width: 1480px;
}
.ja-navbar.scrolled {
    padding: .55rem 0;
    box-shadow: var(--ja-shadow-sm);
}
.ja-navbar .navbar-brand {
    display: flex; align-items: center; gap: .65rem;
    font-family: var(--ja-font-display);
    flex-shrink: 0;
    margin-right: 1rem;
}
.brand-logo {
    width: 52px; height: 52px; border-radius: 14px; object-fit: cover;
    border: 2px solid var(--ja-gold);
    box-shadow: 0 8px 20px rgba(201,162,39,0.35);
    background: #fff;
}
.footer-logo-img {
    width: 48px; height: 48px; border-radius: 12px; object-fit: cover;
    border: 2px solid var(--ja-gold);
    box-shadow: 0 8px 20px rgba(201,162,39,0.3);
    background: #fff; margin-right: .55rem;
}
.brand-mark {
    display: inline-flex; align-items: center; justify-content: center;
    width: 46px; height: 46px; border-radius: 50%;
    background: var(--ja-gold-gradient); color: #0a0a0a;
    font-weight: 800; font-size: 1.45rem; font-family: var(--ja-font-display);
    box-shadow: 0 8px 20px rgba(201,162,39,0.4);
}
.brand-dot { color: #0a0a0a; }
.brand-text { display: flex; flex-direction: column; line-height: 1.05; }
.brand-title { font-weight: 700; color: var(--ja-black); font-size: 1.25rem; letter-spacing: .02em; }
.brand-sub { font-family: var(--ja-font-body); font-size: .68rem; letter-spacing: .25em; text-transform: uppercase; color: var(--ja-gold-deep); }

.ja-navbar .navbar-nav { gap: .15rem; }
.ja-navbar .navbar-nav .nav-item { position: relative; }
.ja-navbar .navbar-nav .nav-link {
    color: #1a1a1a; font-weight: 600; padding: .55rem .85rem;
    position: relative; font-size: .85rem; letter-spacing: .01em;
    border-radius: 99px; z-index: 1;
    display: inline-flex; align-items: center;
    white-space: nowrap;
    transition: color .3s cubic-bezier(.16,1,.3,1), transform .3s cubic-bezier(.16,1,.3,1);
}
.ja-navbar .navbar-nav .nav-link::before {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(201,162,39,0.14) 0%, rgba(230,184,53,0.22) 100%);
    border-radius: inherit;
    opacity: 0; transform: scale(.85);
    transition: opacity .35s cubic-bezier(.16,1,.3,1), transform .35s cubic-bezier(.16,1,.3,1);
    z-index: -1; pointer-events: none;
}

/* Animated underline ONLY for non-dropdown links (dropdown links use ::after for the chevron) */
.ja-navbar .navbar-nav .nav-link:not(.dropdown-toggle)::after {
    content: ""; position: absolute; left: 50%; bottom: .15rem;
    width: 0; height: 2px; border-radius: 99px;
    background: var(--ja-gold-gradient);
    transition: width .35s cubic-bezier(.16,1,.3,1);
    transform: translateX(-50%);
}
.ja-navbar .navbar-nav .nav-link:hover {
    color: var(--ja-gold-deep); transform: translateY(-1px);
}
.ja-navbar .navbar-nav .nav-link:hover::before,
.ja-navbar .navbar-nav .nav-link.active::before,
.ja-navbar .navbar-nav .show > .nav-link::before { opacity: 1; transform: scale(1); }
.ja-navbar .navbar-nav .nav-link:not(.dropdown-toggle):hover::after,
.ja-navbar .navbar-nav .nav-link:not(.dropdown-toggle).active::after { width: 24px; }
.ja-navbar .navbar-nav .nav-link.active,
.ja-navbar .navbar-nav .show > .nav-link {
    color: var(--ja-gold-deep);
    background: linear-gradient(135deg, rgba(10,10,10,0.04) 0%, rgba(201,162,39,0.08) 100%);
    box-shadow: inset 0 0 0 1px rgba(201,162,39,0.25);
}

/* Custom chevron for dropdown toggles (replaces Bootstrap's triangle) */
.ja-navbar .nav-link.dropdown-toggle { padding-right: 2rem; }
.ja-navbar .nav-link.dropdown-toggle::after {
    content: ""; position: absolute;
    right: .85rem; top: 50%;
    width: .42rem; height: .42rem;
    border: 0;
    border-right: 1.6px solid var(--ja-gold-deep);
    border-bottom: 1.6px solid var(--ja-gold-deep);
    transform: translateY(-65%) rotate(45deg);
    margin: 0; vertical-align: 0;
    transition: transform .3s cubic-bezier(.16,1,.3,1), border-color .25s ease;
}
.ja-navbar .nav-link.dropdown-toggle:hover::after { border-color: var(--ja-gold); }
.ja-navbar .nav-item.show > .nav-link.dropdown-toggle::after {
    transform: translateY(-30%) rotate(225deg);
    border-color: var(--ja-gold);
}

/* Premium Donate CTA in navbar */
.ja-navbar .btn-gold {
    padding: .6rem 1.3rem; font-size: .85rem; letter-spacing: .04em;
    text-transform: uppercase; font-weight: 700;
    box-shadow: 0 10px 22px rgba(201,162,39,0.4);
    position: relative; overflow: hidden;
}
.ja-navbar .btn-gold::before {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.45) 50%, transparent 100%);
    transform: translateX(-120%); transition: transform .7s ease;
}
.ja-navbar .btn-gold:hover::before { transform: translateX(120%); }
.ja-navbar .btn-gold i { transition: transform .35s cubic-bezier(.16,1,.3,1); }
.ja-navbar .btn-gold:hover i { transform: scale(1.15) rotate(-8deg); }

.ja-dropdown {
    border: 0; border-radius: 16px;
    box-shadow: 0 24px 60px rgba(10,10,10,0.15);
    padding: .55rem; min-width: 240px;
    border-top: 3px solid var(--ja-gold);
    background: rgba(255,255,255,0.98);
    backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
    margin-top: .65rem !important;
    animation: ja-dd-in .25s cubic-bezier(.16,1,.3,1) both;
}
@keyframes ja-dd-in {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: none; }
}
.ja-dropdown .dropdown-item {
    padding: .6rem .85rem; border-radius: 10px;
    color: #1a1a1a; font-weight: 500; font-size: .9rem;
    display: flex; align-items: center; gap: .65rem;
    position: relative; transition: all .25s ease;
}
.ja-dropdown .dropdown-item i {
    color: var(--ja-gold-deep); font-size: 1.05rem;
    transition: transform .3s cubic-bezier(.16,1,.3,1);
}
.ja-dropdown .dropdown-item:hover {
    background: linear-gradient(135deg, var(--ja-cream) 0%, rgba(201,162,39,0.1) 100%);
    color: var(--ja-gold-deep); transform: translateX(3px);
}
.ja-dropdown .dropdown-item:hover i { transform: scale(1.2) rotate(-8deg); color: var(--ja-gold); }

.navbar-toggler {
    border: 1.5px solid var(--ja-gold); color: var(--ja-gold-deep);
    padding: .4rem .6rem; border-radius: 12px;
    transition: all .3s ease;
}
.navbar-toggler:hover { background: var(--ja-gold-gradient); color: #1a1a1a; border-color: transparent; }
.navbar-toggler:focus { box-shadow: 0 0 0 .25rem rgba(201,162,39,0.25); }
.navbar-toggler i { font-size: 1.4rem; }

@media (max-width: 1199.98px) {
    .ja-navbar .navbar-nav { padding-top: 1rem; max-height: 75vh; overflow-y: auto; gap: .1rem; }
    .ja-navbar .navbar-nav .nav-link { padding: .65rem .9rem; border-radius: 12px; }
    .ja-navbar .navbar-nav .nav-link:not(.dropdown-toggle)::after { left: 1rem; bottom: .35rem; transform: none; }
    .ja-navbar .navbar-nav .nav-link:not(.dropdown-toggle):hover::after,
    .ja-navbar .navbar-nav .nav-link:not(.dropdown-toggle).active::after { width: 18px; }
    .ja-navbar .nav-link.dropdown-toggle { padding-right: 2rem; }
    .ja-navbar .ja-dropdown { box-shadow: none; border-top: 0; padding-left: 1rem; background: transparent; animation: none; }
}

/* Tight desktop range: hide brand tagline + tighten nav so all items fit */
@media (min-width: 1200px) and (max-width: 1499.98px) {
    .ja-navbar .brand-sub { display: none; }
    .ja-navbar .brand-title { font-size: 1.1rem; }
    .ja-navbar .brand-logo { width: 44px; height: 44px; border-radius: 12px; }
    .ja-navbar .navbar-nav .nav-link { padding: .5rem .65rem; font-size: .8rem; letter-spacing: 0; }
    .ja-navbar .nav-link.dropdown-toggle { padding-right: 1.6rem; }
    .ja-navbar .nav-link.dropdown-toggle::after { right: .6rem; }
    .ja-navbar .btn-gold { padding: .55rem 1.05rem; font-size: .78rem; }
    .ja-navbar .navbar-brand { margin-right: .5rem; }
    .ja-navbar .container-xxl { padding-left: 1rem; padding-right: 1rem; }
}

/* ---------- Hero ---------- */
.hero {
    position: relative; min-height: 92vh;
    display: flex; align-items: center;
    color: #fff; overflow: hidden;
    background: linear-gradient(120deg, rgba(10,10,10,0.82) 0%, rgba(20,20,20,0.55) 60%, rgba(201,162,39,0.35) 100%),
                url('https://images.unsplash.com/photo-1532629345422-7515f3d16bb6?auto=format&fit=crop&w=2000&q=80') center/cover no-repeat;
}
.hero::before {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(ellipse at top right, rgba(201,162,39,0.35), transparent 55%);
    pointer-events: none;
}
.hero .container { position: relative; z-index: 2; }
.hero-eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    text-transform: uppercase; letter-spacing: .35em;
    font-size: .8rem; color: var(--ja-gold-bright); font-weight: 600;
    background: rgba(255,255,255,0.06); border: 1px solid rgba(201,162,39,0.5);
    padding: .45rem 1.1rem; border-radius: 99px;
    backdrop-filter: blur(6px);
}
.hero-title {
    font-size: clamp(2.2rem, 5vw, 4.5rem); color: #fff;
    line-height: 1.05; font-weight: 800;
    margin: 1.4rem 0 1.2rem;
}
.hero-title .accent { background: var(--ja-gold-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero-sub { font-size: 1.15rem; max-width: 640px; color: rgba(255,255,255,0.85); margin-bottom: 2rem; }
.hero-actions .btn { padding: .9rem 1.8rem; }

.hero-stats {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem; margin-top: 3rem;
    border-top: 1px solid rgba(255,255,255,0.18); padding-top: 2rem;
}
.hero-stats .stat-num { font-family: var(--ja-font-display); font-size: 2rem; color: var(--ja-gold-bright); font-weight: 800; }
.hero-stats .stat-label { font-size: .85rem; color: rgba(255,255,255,0.75); text-transform: uppercase; letter-spacing: .15em; }

/* Scroll cue */
.hero-cue {
    position: absolute; bottom: 1.5rem; left: 50%; transform: translateX(-50%);
    color: rgba(255,255,255,0.7); font-size: .8rem; text-transform: uppercase; letter-spacing: .35em;
    z-index: 2; animation: floatY 2.5s ease-in-out infinite;
}
@keyframes floatY { 0%,100% { transform: translate(-50%, 0); } 50% { transform: translate(-50%, -8px); } }

/* ---------- Page banner ---------- */
.page-banner {
    position: relative; padding: 8rem 0 5rem; color: #fff;
    background: linear-gradient(120deg, rgba(10,10,10,0.85) 0%, rgba(20,20,20,0.7) 60%, rgba(201,162,39,0.25) 100%),
                url('https://images.unsplash.com/photo-1604881991720-f91add269bed?auto=format&fit=crop&w=2000&q=80') center/cover no-repeat;
}
.page-banner h1 { color: #fff; font-size: clamp(2rem, 4vw, 3.2rem); }
.page-banner .breadcrumb {
    background: transparent; padding: 0; margin-bottom: .6rem;
    color: rgba(255,255,255,0.8); font-size: .85rem; text-transform: uppercase; letter-spacing: .25em;
}
.page-banner .breadcrumb a { color: var(--ja-gold-bright); }
.page-banner .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.5); content: "/"; }

/* ---------- Cards ---------- */
.ja-card {
    background: #fff; border-radius: var(--ja-radius-lg);
    box-shadow: var(--ja-shadow-sm); border: 1px solid rgba(0,0,0,0.04);
    overflow: hidden; height: 100%;
    transition: transform .4s ease, box-shadow .4s ease, border-color .3s ease;
}
.ja-card:hover { transform: translateY(-8px); box-shadow: var(--ja-shadow-md); border-color: var(--ja-border); }
.ja-card .card-img-wrap { position: relative; overflow: hidden; aspect-ratio: 4 / 3; }
.ja-card .card-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.ja-card:hover .card-img-wrap img { transform: scale(1.08); }
.ja-card .card-body { padding: 1.5rem 1.6rem 1.7rem; }
.ja-card .card-cat {
    color: var(--ja-gold-deep); font-size: .72rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .25em;
}
.ja-card h4, .ja-card h5 { margin-top: .4rem; }
.ja-card .read-more {
    display: inline-flex; align-items: center; gap: .35rem;
    margin-top: .8rem; font-weight: 600; color: var(--ja-black);
}
.ja-card .read-more i { transition: transform .3s ease; }
.ja-card .read-more:hover i { transform: translateX(4px); color: var(--ja-gold); }

/* Icon Card (programmes / values) */
.icon-card {
    background: #fff; border-radius: var(--ja-radius-lg);
    padding: 2rem 1.7rem; height: 100%;
    border: 1px solid rgba(0,0,0,0.05);
    transition: all .4s ease;
    position: relative; overflow: hidden;
}
.icon-card::before {
    content: ""; position: absolute; top: -50%; right: -50%;
    width: 200%; height: 200%;
    background: radial-gradient(circle, rgba(201,162,39,0.08) 0%, transparent 60%);
    opacity: 0; transition: opacity .5s ease;
}
.icon-card:hover { transform: translateY(-6px); border-color: var(--ja-border); box-shadow: var(--ja-shadow-md); }
.icon-card:hover::before { opacity: 1; }
.icon-card .icon-wrap {
    width: 64px; height: 64px; border-radius: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--ja-gold-gradient); color: #1a1a1a;
    font-size: 1.7rem; margin-bottom: 1.25rem;
    box-shadow: 0 10px 22px rgba(201,162,39,0.35);
    position: relative; z-index: 1;
}
.icon-card h5 { font-size: 1.2rem; position: relative; z-index: 1; }
.icon-card p { font-size: .95rem; color: #555; position: relative; z-index: 1; }

.icon-card.dark {
    background: var(--ja-dark-gradient); color: #fff;
    border-color: rgba(255,255,255,0.06);
}
.icon-card.dark h5 { color: #fff; }
.icon-card.dark p { color: rgba(255,255,255,0.75); }
.icon-card.dark .icon-wrap { background: rgba(201,162,39,0.15); color: var(--ja-gold-bright); box-shadow: none; }

/* ---------- Stats ---------- */
.stat-tile {
    text-align: center; padding: 2rem 1rem;
    border-right: 1px dashed rgba(255,255,255,0.18);
}
.stat-tile:last-child { border-right: 0; }
@media (max-width: 767px) { .stat-tile { border-right: 0; border-bottom: 1px dashed rgba(255,255,255,0.18); } }
.stat-tile .num {
    font-family: var(--ja-font-display); font-weight: 800;
    font-size: clamp(2.2rem, 5vw, 3.3rem); color: var(--ja-gold-bright); line-height: 1;
}
.stat-tile .num-suffix { font-size: 1.6rem; }
.stat-tile .label { color: rgba(255,255,255,0.75); text-transform: uppercase; letter-spacing: .2em; font-size: .8rem; margin-top: .55rem; }

/* ---------- Testimonial ---------- */
.testimonial-card {
    background: #fff; border-radius: var(--ja-radius-lg);
    padding: 2.3rem 2rem; position: relative;
    box-shadow: var(--ja-shadow-sm); height: 100%;
    border: 1px solid rgba(0,0,0,0.04);
    transition: all .35s ease;
}
.testimonial-card:hover { transform: translateY(-6px); box-shadow: var(--ja-shadow-md); }
.testimonial-card .quote-mark {
    font-family: var(--ja-font-display); font-size: 4rem; line-height: 1;
    color: var(--ja-gold); position: absolute; top: 1rem; right: 1.4rem; opacity: .25;
}
.testimonial-card p { font-style: italic; color: #444; }
.testimonial-card .author { display: flex; align-items: center; gap: .9rem; margin-top: 1.2rem; }
.testimonial-card .author img { width: 56px; height: 56px; border-radius: 50%; object-fit: cover; border: 2px solid var(--ja-gold); }
.testimonial-card .author .name { font-weight: 600; color: var(--ja-black); }
.testimonial-card .author .role { font-size: .8rem; color: var(--ja-muted); }

/* ---------- Partners ---------- */
.partners-strip {
    background: var(--ja-cream); padding: 3rem 0;
}
.partners-strip img {
    max-height: 50px; opacity: .55; filter: grayscale(1);
    transition: all .35s ease;
}
.partners-strip a:hover img { opacity: 1; filter: grayscale(0); }

/* ---------- Team ---------- */
.team-card {
    background: #fff; border-radius: var(--ja-radius-lg);
    overflow: hidden; box-shadow: var(--ja-shadow-sm);
    transition: all .4s ease; height: 100%;
    border: 1px solid rgba(0,0,0,0.04);
}
.team-card:hover { transform: translateY(-8px); box-shadow: var(--ja-shadow-md); border-color: var(--ja-border); }
.team-card .photo { aspect-ratio: 1/1; overflow: hidden; position: relative; }
.team-card .photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; filter: grayscale(0.1); }
.team-card:hover .photo img { transform: scale(1.06); filter: grayscale(0); }
.team-card .photo::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 55%, rgba(10,10,10,0.65) 100%);
}
.team-card .socials {
    position: absolute; bottom: .9rem; left: 50%; transform: translateX(-50%);
    display: flex; gap: .55rem; opacity: 0; transition: all .4s ease; z-index: 2;
}
.team-card:hover .socials { opacity: 1; bottom: 1.2rem; }
.team-card .socials a {
    width: 36px; height: 36px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.9); color: var(--ja-black);
}
.team-card .socials a:hover { background: var(--ja-gold); color: #fff; }
.team-card .info { padding: 1.4rem 1.4rem 1.6rem; text-align: center; }
.team-card .info .name { font-family: var(--ja-font-display); font-size: 1.2rem; font-weight: 700; }
.team-card .info .role { color: var(--ja-gold-deep); font-size: .82rem; text-transform: uppercase; letter-spacing: .2em; font-weight: 600; }

/* ---------- Gallery ---------- */
.gallery-filters { display: flex; flex-wrap: wrap; justify-content: center; gap: .6rem; margin-bottom: 2.5rem; }
.gallery-filters .filter-btn {
    background: #fff; border: 1px solid rgba(0,0,0,0.08);
    padding: .5rem 1.2rem; border-radius: 99px;
    font-weight: 500; font-size: .85rem; cursor: pointer;
    transition: all .25s ease;
}
.gallery-filters .filter-btn:hover, .gallery-filters .filter-btn.active {
    background: var(--ja-gold-gradient); color: #1a1a1a; border-color: transparent;
}
.gallery-item {
    position: relative; border-radius: var(--ja-radius-lg);
    overflow: hidden; aspect-ratio: 4/3; box-shadow: var(--ja-shadow-sm);
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s ease; }
.gallery-item:hover img { transform: scale(1.1); }
.gallery-item .overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(10,10,10,0.85) 100%);
    color: #fff; display: flex; flex-direction: column; justify-content: flex-end;
    padding: 1.2rem; opacity: 0; transition: opacity .35s ease;
}
.gallery-item:hover .overlay { opacity: 1; }
.gallery-item .overlay .cat { color: var(--ja-gold-bright); font-size: .7rem; text-transform: uppercase; letter-spacing: .25em; }
.gallery-item .overlay h6 { color: #fff; margin: .3rem 0 0; }
.gallery-item .play-btn {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 70px; height: 70px; border-radius: 50%;
    background: rgba(255,255,255,0.92); color: var(--ja-black);
    display: flex; align-items: center; justify-content: center; font-size: 1.6rem;
    z-index: 2; box-shadow: 0 10px 24px rgba(0,0,0,0.25);
}

/* ---------- Forms ---------- */
.form-card {
    background: #fff; border-radius: var(--ja-radius-lg);
    padding: 2.5rem; box-shadow: var(--ja-shadow-md);
    border: 1px solid rgba(0,0,0,0.04);
}
.form-control, .form-select {
    border-radius: 12px; border: 1px solid rgba(0,0,0,0.1);
    padding: .85rem 1rem; font-size: .95rem;
}
.form-control:focus, .form-select:focus {
    border-color: var(--ja-gold); box-shadow: 0 0 0 .25rem rgba(201,162,39,0.18);
}
.form-label { font-weight: 500; color: #333; font-size: .9rem; }
.form-floating > label { color: #888; }

/* ---------- Donation tile ---------- */
.donate-preset-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .55rem; }
@media (max-width: 575px) { .donate-preset-grid { grid-template-columns: repeat(2, 1fr); } }
.donate-preset {
    background: #fff; border: 1.5px solid rgba(0,0,0,0.08);
    padding: .8rem .4rem; border-radius: 12px; cursor: pointer; text-align: center;
    font-weight: 600; transition: all .25s ease;
}
.donate-preset:hover, .donate-preset.active {
    background: var(--ja-gold-gradient); color: #1a1a1a; border-color: transparent;
    box-shadow: 0 10px 22px rgba(201,162,39,0.3);
}

/* ---------- Newsletter band ---------- */
.newsletter-band {
    background: var(--ja-dark-gradient); color: #fff; padding: 3.5rem 0;
    position: relative; overflow: hidden;
}
.newsletter-band::before {
    content: ""; position: absolute; right: -100px; top: -100px;
    width: 360px; height: 360px;
    background: radial-gradient(circle, rgba(201,162,39,0.25), transparent 70%);
    border-radius: 50%;
}
.newsletter-band h3 { color: #fff; font-family: var(--ja-font-display); font-weight: 700; }
.newsletter-band h3 i { color: var(--ja-gold-bright); }
.newsletter-form .form-control {
    border: 0; padding: 1rem 1.1rem; border-radius: 99px 0 0 99px;
}
.newsletter-form .btn { border-radius: 0 99px 99px 0; padding: 1rem 1.4rem; }

/* ---------- Footer ---------- */
.site-footer {
    background: #060606; color: #c8c8c8; padding: 4.5rem 0 1.5rem;
    border-top: 4px solid var(--ja-gold);
}
.site-footer h6.footer-heading {
    color: #fff; text-transform: uppercase; letter-spacing: .22em;
    font-size: .82rem; font-weight: 600; margin-bottom: 1.2rem;
    position: relative; padding-bottom: .55rem;
}
.site-footer h6.footer-heading::after {
    content: ""; position: absolute; bottom: 0; left: 0; width: 32px; height: 2px;
    background: var(--ja-gold-gradient);
}
.footer-links { list-style: none; padding: 0; margin: 0; }
.footer-links li { margin-bottom: .55rem; }
.footer-links a {
    color: #c8c8c8; font-size: .92rem; transition: all .25s ease;
    display: inline-flex; align-items: center; gap: .35rem;
}
.footer-links a::before { content: "›"; color: var(--ja-gold); font-weight: 700; }
.footer-links a:hover { color: var(--ja-gold-bright); transform: translateX(3px); }
.footer-brand { display: inline-flex; align-items: center; gap: .6rem; }
.footer-brand .brand-title { color: #fff; font-size: 1.3rem; }
.footer-socials { display: flex; gap: .55rem; margin-top: 1rem; }
.footer-socials a {
    width: 38px; height: 38px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.06); color: #ccc;
}
.footer-socials a:hover { background: var(--ja-gold-gradient); color: #1a1a1a; transform: translateY(-3px); }
.footer-divider { border-color: rgba(255,255,255,0.08); margin: 2.5rem 0 1.2rem; }
.site-footer a { color: #c8c8c8; }
.site-footer a:hover { color: var(--ja-gold-bright); }

/* ---------- WhatsApp FAB ---------- */
.whatsapp-fab {
    position: fixed; bottom: 24px; right: 24px;
    width: 60px; height: 60px; border-radius: 50%;
    background: #25d366; color: #fff; font-size: 2rem;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 12px 30px rgba(37,211,102,0.5);
    z-index: 1050; transition: all .3s ease;
}
.whatsapp-fab:hover { color: #fff; transform: scale(1.07); box-shadow: 0 16px 36px rgba(37,211,102,0.65); }
.whatsapp-fab .whatsapp-pulse {
    position: absolute; inset: 0; border-radius: 50%;
    box-shadow: 0 0 0 0 rgba(37,211,102,0.6);
    animation: waPulse 2s infinite;
    z-index: -1;
}
.whatsapp-fab .whatsapp-tooltip {
    position: absolute; right: 72px; top: 50%; transform: translateY(-50%);
    background: #0a0a0a; color: #fff; padding: .45rem .9rem; border-radius: 99px;
    font-size: .78rem; white-space: nowrap; opacity: 0; pointer-events: none;
    transition: all .3s ease;
}
.whatsapp-fab:hover .whatsapp-tooltip { opacity: 1; right: 76px; }
@keyframes waPulse {
    0% { box-shadow: 0 0 0 0 rgba(37,211,102,0.55); }
    70% { box-shadow: 0 0 0 22px rgba(37,211,102,0); }
    100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); }
}

/* ---------- Back to top ---------- */
.back-to-top {
    position: fixed; bottom: 92px; right: 30px;
    width: 44px; height: 44px; border-radius: 50%;
    background: var(--ja-black); color: var(--ja-gold-bright);
    border: 1px solid var(--ja-gold); display: flex; align-items: center; justify-content: center;
    opacity: 0; transform: translateY(20px); pointer-events: none;
    transition: all .3s ease; z-index: 1040;
}
.back-to-top.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.back-to-top:hover { background: var(--ja-gold); color: #1a1a1a; }

/* ---------- Reports / Documents ---------- */
.report-item {
    background: #fff; border: 1px solid rgba(0,0,0,0.06);
    border-radius: var(--ja-radius); padding: 1.25rem;
    display: flex; gap: 1rem; align-items: center;
    transition: all .3s ease;
}
.report-item:hover { border-color: var(--ja-gold); transform: translateY(-3px); box-shadow: var(--ja-shadow-sm); }
.report-item .report-icon {
    width: 56px; height: 56px; border-radius: 12px;
    background: var(--ja-cream); color: var(--ja-gold-deep);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.6rem; flex-shrink: 0;
}
.report-item h6 { margin: 0; }
.report-item .meta { font-size: .8rem; color: var(--ja-muted); }
.report-item .download-link { margin-left: auto; color: var(--ja-gold-deep); font-weight: 600; }

/* ---------- Timeline ---------- */
.ja-timeline { position: relative; padding-left: 2.4rem; }
.ja-timeline::before {
    content: ""; position: absolute; left: 11px; top: 0; bottom: 0;
    width: 2px; background: var(--ja-gold);
    opacity: .35;
}
.ja-timeline .tl-item { position: relative; padding-bottom: 2rem; }
.ja-timeline .tl-item::before {
    content: ""; position: absolute; left: -2.4rem; top: 4px;
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--ja-gold-gradient); border: 4px solid #fff;
    box-shadow: 0 0 0 3px rgba(201,162,39,0.25);
}
.ja-timeline .tl-date { color: var(--ja-gold-deep); font-weight: 600; font-size: .85rem; text-transform: uppercase; letter-spacing: .2em; }
.ja-timeline .tl-title { font-family: var(--ja-font-display); font-size: 1.2rem; margin-top: .25rem; }

/* ---------- Feature image cluster ---------- */
.image-cluster { position: relative; }
.image-cluster .img-main {
    width: 100%; border-radius: var(--ja-radius-lg);
    box-shadow: var(--ja-shadow-lg); object-fit: cover; aspect-ratio: 4/5;
}
.image-cluster .img-mini {
    position: absolute; bottom: -40px; right: -20px;
    width: 55%; border-radius: var(--ja-radius);
    border: 6px solid #fff; box-shadow: var(--ja-shadow-md); object-fit: cover; aspect-ratio: 4/3;
}
.image-cluster .img-badge {
    position: absolute; top: 20px; left: -20px;
    background: var(--ja-gold-gradient); color: #1a1a1a;
    padding: .9rem 1.1rem; border-radius: var(--ja-radius);
    box-shadow: var(--ja-shadow-md); font-weight: 700;
    display: flex; flex-direction: column; align-items: center; line-height: 1.1;
}
.image-cluster .img-badge .big { font-size: 1.7rem; font-family: var(--ja-font-display); }
.image-cluster .img-badge .small { font-size: .68rem; text-transform: uppercase; letter-spacing: .22em; }

/* ---------- Accordion (FAQ etc.) ---------- */
.accordion-button {
    font-weight: 600; color: #1a1a1a; padding: 1.1rem 1.3rem;
    border-radius: var(--ja-radius) !important;
}
.accordion-button:not(.collapsed) { background: var(--ja-cream); color: var(--ja-gold-deep); }
.accordion-button:focus { box-shadow: 0 0 0 .25rem rgba(201,162,39,0.18); border-color: var(--ja-border); }
.accordion-item { border: 1px solid rgba(0,0,0,0.06); border-radius: var(--ja-radius) !important; margin-bottom: .8rem; overflow: hidden; }

/* ---------- Alerts ---------- */
.alert-gold {
    background: var(--ja-gold-soft); color: #5a4a0d;
    border: 1px solid var(--ja-gold);
    border-radius: var(--ja-radius);
}

/* ---------- Animations ---------- */
@keyframes fadeUp { from { opacity: 0; transform: translateY(30px); } to { opacity: 1; transform: translateY(0); } }
@keyframes shimmer { 0% { background-position: -800px 0; } 100% { background-position: 800px 0; } }
.shimmer-text {
    background: linear-gradient(90deg, var(--ja-gold-deep) 0%, var(--ja-gold-bright) 50%, var(--ja-gold-deep) 100%);
    background-size: 800px 100%;
    -webkit-background-clip: text; background-clip: text; color: transparent;
    animation: shimmer 4s linear infinite;
}

/* ---------- Misc ---------- */
.list-check { list-style: none; padding-left: 0; }
.list-check li { position: relative; padding-left: 1.8rem; margin-bottom: .6rem; }
.list-check li::before {
    content: "\2713"; position: absolute; left: 0; top: 0;
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--ja-gold-gradient); color: #1a1a1a;
    display: flex; align-items: center; justify-content: center;
    font-size: .75rem; font-weight: 700;
}

.tag-pill {
    display: inline-block; padding: .25rem .8rem; border-radius: 99px;
    font-size: .72rem; font-weight: 600; letter-spacing: .15em; text-transform: uppercase;
    background: var(--ja-gold-soft); color: var(--ja-gold-deep);
}

.page-main { min-height: 50vh; }

/* ---------- Animated Contact Form ---------- */
.contact-form-card {
    position: relative;
    overflow: hidden;
    background: linear-gradient(180deg, #ffffff 0%, #fffdf6 100%);
    border: 1px solid rgba(201,162,39,0.18);
    box-shadow: 0 24px 60px rgba(10,10,10,0.08);
    animation: cardLift .8s ease both;
}
.contact-form-card::before {
    content: ""; position: absolute; top: -120px; right: -120px;
    width: 280px; height: 280px; border-radius: 50%;
    background: radial-gradient(circle, rgba(201,162,39,0.18) 0%, transparent 65%);
    z-index: 0; animation: blobFloat 9s ease-in-out infinite;
}
.contact-form-card::after {
    content: ""; position: absolute; bottom: -100px; left: -80px;
    width: 240px; height: 240px; border-radius: 50%;
    background: radial-gradient(circle, rgba(10,10,10,0.06) 0%, transparent 65%);
    z-index: 0; animation: blobFloat 11s ease-in-out infinite reverse;
}
.contact-form-card > * { position: relative; z-index: 1; }

.form-head-row {
    display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem;
}
.form-head-icon {
    width: 58px; height: 58px; border-radius: 16px;
    display: inline-flex; align-items: center; justify-content: center;
    background: var(--ja-gold-gradient); color: #1a1a1a;
    font-size: 1.7rem; box-shadow: 0 12px 28px rgba(201,162,39,0.4);
    animation: floaty 4s ease-in-out infinite;
}

.ja-contact-form .floating-field {
    position: relative;
}
.ja-contact-form .floating-field .field-icon {
    position: absolute; left: 1rem; top: 38px; z-index: 2;
    color: var(--ja-gold-deep); font-size: 1.15rem;
    transition: all .3s cubic-bezier(.16,1,.3,1);
    pointer-events: none;
}
.ja-contact-form .floating-field-textarea .field-icon { top: 42px; }
.ja-contact-form .floating-field .form-control { padding-left: 2.8rem; transition: all .3s ease; }
.ja-contact-form .floating-field .form-control:focus { transform: translateY(-2px); box-shadow: 0 12px 24px rgba(201,162,39,0.18), 0 0 0 .25rem rgba(201,162,39,0.18); }
.ja-contact-form .floating-field:focus-within .field-icon { color: var(--ja-gold); transform: scale(1.15) rotate(-6deg); }
.ja-contact-form .floating-field:focus-within .form-label { color: var(--ja-gold-deep); transform: translateX(2px); }
.ja-contact-form .form-label { transition: all .2s ease; display: inline-block; }

.form-trust-row { padding: .8rem 1rem; background: rgba(201,162,39,0.06); border-radius: 12px; border: 1px dashed rgba(201,162,39,0.3); }
.form-trust-row > div { display: flex; align-items: center; gap: .35rem; }

.btn-send {
    position: relative; overflow: hidden;
    padding: 1rem 1.4rem !important;
    font-weight: 700; letter-spacing: .02em;
    transition: all .35s ease;
}
.btn-send .btn-icon-wrap {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(10,10,10,0.85); color: var(--ja-gold);
    margin-right: .55rem;
    transition: transform .4s ease;
}
.btn-send:hover { transform: translateY(-3px); box-shadow: 0 18px 36px rgba(201,162,39,0.45); }
.btn-send:hover .btn-icon-wrap { transform: rotate(-25deg) scale(1.1); }
.btn-send::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
    transform: translateX(-100%); transition: transform .6s ease;
}
.btn-send:hover::after { transform: translateX(100%); }

.success-pop { animation: popIn .55s cubic-bezier(.16,1,.3,1) both; }

@keyframes cardLift { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes blobFloat { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(10px,18px) scale(1.07); } }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-6px); } }
@keyframes popIn { 0% { opacity: 0; transform: scale(.85); } 60% { transform: scale(1.04); } 100% { opacity: 1; transform: scale(1); } }

/* ---------- Footer Credit ---------- */
.footer-credit {
    padding-top: 1.1rem;
    margin-top: .5rem;
    border-top: 1px solid rgba(255,255,255,0.06);
    color: rgba(255,255,255,0.55);
    letter-spacing: .03em;
}
.footer-credit .credit-link {
    color: var(--ja-gold);
    font-weight: 600;
    text-decoration: none;
    background-image: linear-gradient(90deg, var(--ja-gold), var(--ja-gold-deep));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: filter .25s ease, transform .25s ease;
    display: inline-block;
}
.footer-credit .credit-link:hover { filter: brightness(1.15); transform: translateY(-1px); }
.pulse-heart { display: inline-block; animation: pulseHeart 1.6s ease-in-out infinite; }
@keyframes pulseHeart {
    0%, 100% { transform: scale(1); }
    25% { transform: scale(1.18); }
    50% { transform: scale(1); }
    75% { transform: scale(1.12); }
}

/* ---------- Hero Carousel ---------- */
.hero-carousel-section { position: relative; }
.hero-carousel, .hero-carousel .carousel-inner, .hero-carousel .carousel-item { height: 100vh; min-height: 640px; }
@media (max-width: 768px) {
    .hero-carousel, .hero-carousel .carousel-inner, .hero-carousel .carousel-item { height: 88vh; min-height: 560px; }
}
.hero-slide {
    width: 100%; height: 100%;
    background-size: cover; background-position: center;
    display: flex; align-items: center; position: relative;
    overflow: hidden;
}
.hero-slide::before {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(ellipse at top right, rgba(201,162,39,0.28), transparent 55%);
    pointer-events: none;
}
.hero-slide-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 45%, rgba(10,10,10,0.55) 100%);
    pointer-events: none;
}
.hero-slide-content { position: relative; z-index: 3; color: #fff; padding-bottom: 6rem; }
.min-h-hero { min-height: calc(100vh - 6rem); }
@media (max-width: 768px) { .min-h-hero { min-height: calc(88vh - 6rem); } }

.hero-carousel .hero-eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    text-transform: uppercase; letter-spacing: .35em;
    font-size: .78rem; color: var(--ja-gold-bright); font-weight: 700;
    background: rgba(255,255,255,0.08); border: 1px solid rgba(201,162,39,0.6);
    padding: .5rem 1.2rem; border-radius: 99px;
    backdrop-filter: blur(8px);
}
.hero-carousel .hero-title { font-size: clamp(2.2rem, 5.5vw, 5rem); color: #fff; line-height: 1.05; font-weight: 800; margin: 1.4rem 0 1.2rem; }
.hero-carousel .hero-title .accent { background: var(--ja-gold-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; display: inline-block; }
.hero-carousel .hero-sub { font-size: 1.1rem; max-width: 700px; color: rgba(255,255,255,0.9); margin-bottom: 2rem; line-height: 1.7; }

.btn-outline-light-gold {
    background: transparent; color: #fff;
    border: 1.5px solid rgba(255,255,255,0.7);
    padding: .9rem 1.8rem;
}
.btn-outline-light-gold:hover { background: var(--ja-gold-gradient); color: #1a1a1a; border-color: transparent; box-shadow: 0 16px 32px rgba(201, 162, 39, 0.5); }

/* Indicators */
.hero-indicators { bottom: 9.5rem; margin-bottom: 0; gap: .55rem; }
.hero-indicators [data-bs-target] {
    width: 32px; height: 4px; border-radius: 99px;
    background: rgba(255,255,255,0.4); border: 0; opacity: 1;
    transition: all .35s ease;
}
.hero-indicators .active { background: var(--ja-gold-gradient); width: 56px; }

/* Nav arrows */
.hero-carousel .hero-nav {
    width: 56px; height: 56px;
    border-radius: 50%; opacity: 0.85;
    background: rgba(10,10,10,0.55); border: 1px solid rgba(255,255,255,0.18);
    backdrop-filter: blur(8px);
    display: inline-flex; align-items: center; justify-content: center;
    top: 50%; transform: translateY(-50%); margin: 0 1.25rem;
    transition: all .3s ease;
}
.hero-carousel .hero-nav:hover { background: var(--ja-gold-gradient); color: #1a1a1a; opacity: 1; transform: translateY(-50%) scale(1.08); }
.hero-carousel .hero-nav i { font-size: 1.6rem; color: inherit; }
.hero-carousel .carousel-control-prev-icon, .hero-carousel .carousel-control-next-icon { display: none; }
@media (max-width: 575px) { .hero-carousel .hero-nav { display: none; } }

/* Stats band */
.hero-stats-band {
    position: absolute; bottom: 0; left: 0; right: 0; z-index: 4;
    background: linear-gradient(180deg, rgba(10,10,10,0) 0%, rgba(10,10,10,0.85) 100%);
    padding: 2.5rem 0 1.6rem; color: #fff;
}
.hero-stat {
    display: flex; align-items: center; gap: 1rem;
    background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px; padding: 1rem 1.1rem;
    backdrop-filter: blur(8px); transition: all .3s ease;
}
.hero-stat:hover { background: rgba(201,162,39,0.12); border-color: rgba(201,162,39,0.5); transform: translateY(-3px); }
.hero-stat i { font-size: 1.85rem; color: var(--ja-gold-bright); }
.hero-stat .stat-num { font-family: var(--ja-font-display); font-size: 1.7rem; font-weight: 800; color: #fff; line-height: 1; }
.hero-stat .stat-label { font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; color: rgba(255,255,255,0.7); }

/* Slide entrance animations */
.carousel-item.active .animate-in { animation: heroFadeUp .9s cubic-bezier(.16,1,.3,1) both; }
@keyframes heroFadeUp {
    from { opacity: 0; transform: translateY(28px); }
    to { opacity: 1; transform: translateY(0); }
}
.carousel-item { transition: transform 1.2s ease-in-out, opacity .8s ease-in-out !important; }

/* ====================================================
   PREMIUM DONATION PAGE
   ==================================================== */
.donate-hero {
    position: relative;
    padding: 5rem 0 4rem;
    color: #fff;
    background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 55%, #2a1f08 100%);
    overflow: hidden;
}
.donate-hero::before {
    content: ""; position: absolute; inset: 0;
    background: radial-gradient(circle at top right, rgba(201,162,39,0.35) 0%, transparent 55%),
                radial-gradient(circle at bottom left, rgba(201,162,39,0.18) 0%, transparent 50%);
    pointer-events: none;
}
.donate-hero .container { position: relative; z-index: 2; }
.donate-hero .breadcrumb { background: transparent; padding: 0; margin-bottom: 1.5rem; }
.donate-hero .breadcrumb-item, .donate-hero .breadcrumb-item a { color: rgba(255,255,255,0.7); font-size: .82rem; letter-spacing: .12em; text-transform: uppercase; }
.donate-hero .breadcrumb-item.active { color: var(--ja-gold-bright); }
.donate-hero .breadcrumb-item + .breadcrumb-item::before { color: rgba(255,255,255,0.4); content: "›"; }

.donate-eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    text-transform: uppercase; letter-spacing: .3em; font-size: .78rem;
    color: var(--ja-gold-bright); font-weight: 700;
    background: rgba(255,255,255,0.06); border: 1px solid rgba(201,162,39,0.5);
    padding: .5rem 1.1rem; border-radius: 99px;
    margin-bottom: 1.25rem;
}
.donate-title { font-size: clamp(2.4rem, 5vw, 4.2rem); font-weight: 800; color: #fff; margin: 0 0 1rem; line-height: 1.05; }
.donate-title .accent { background: var(--ja-gold-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.donate-sub { font-size: 1.1rem; color: rgba(255,255,255,0.85); max-width: 640px; margin: 0; }

.donate-trust-pill {
    display: flex; align-items: center; gap: 1rem;
    background: rgba(255,255,255,0.05); border: 1px solid rgba(201,162,39,0.35);
    padding: 1rem 1.2rem; border-radius: 18px; backdrop-filter: blur(10px);
    color: #fff;
}
.donate-trust-pill i { font-size: 2.4rem; color: var(--ja-gold-bright); }
.donate-trust-pill strong { display: block; font-weight: 700; }
.donate-trust-pill small { display: block; color: rgba(255,255,255,0.7); font-size: .78rem; }

.donate-section { background: linear-gradient(180deg, #fafaf6 0%, #ffffff 100%); }

/* Success banner */
.donate-success-banner {
    display: flex; align-items: center; gap: 1.25rem;
    background: linear-gradient(135deg, rgba(46,160,67,0.08) 0%, rgba(201,162,39,0.08) 100%);
    border: 1px solid rgba(46,160,67,0.3);
    border-left: 6px solid #2ea043;
    border-radius: 18px;
    padding: 1.4rem 1.6rem;
}
.donate-success-banner .success-icon {
    width: 56px; height: 56px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: #2ea043; color: #fff; font-size: 1.8rem;
    box-shadow: 0 12px 24px rgba(46,160,67,0.35);
    flex-shrink: 0;
}

/* Sticky impact summary card */
.impact-summary-card {
    background: #fff; border-radius: 20px;
    padding: 1.8rem; box-shadow: 0 24px 60px rgba(10,10,10,0.08);
    border: 1px solid rgba(0,0,0,0.04);
    position: sticky; top: 110px;
}
.impact-summary-head {
    display: flex; align-items: center; gap: 1rem;
    padding-bottom: 1.25rem; border-bottom: 1px dashed rgba(201,162,39,0.3);
    margin-bottom: 1.25rem;
}
.impact-summary-head i {
    width: 52px; height: 52px; border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    background: var(--ja-gold-gradient); color: #1a1a1a; font-size: 1.6rem;
    box-shadow: 0 12px 24px rgba(201,162,39,0.35);
}
.impact-summary-head small { font-size: .72rem; text-transform: uppercase; letter-spacing: .2em; color: var(--ja-gold-deep); font-weight: 700; }

.impact-list { list-style: none; padding: 0; margin: 0 0 1.5rem; }
.impact-list li {
    display: flex; flex-direction: column; gap: .15rem;
    padding: .75rem 0; border-bottom: 1px solid rgba(0,0,0,0.05);
    transition: transform .2s ease;
}
.impact-list li:hover { transform: translateX(4px); }
.impact-list li:last-child { border-bottom: 0; }
.impact-amount { font-family: var(--ja-font-display); font-weight: 800; color: var(--ja-black); font-size: 1.05rem; }
.impact-line { display: inline-flex; align-items: center; gap: .4rem; font-size: .85rem; color: #555; }
.impact-line i { color: var(--ja-gold); }

.impact-payment {
    background: rgba(201,162,39,0.06);
    border: 1px dashed rgba(201,162,39,0.35);
    border-radius: 14px; padding: 1rem 1.1rem;
}
.impact-payment-head { font-weight: 700; color: var(--ja-black); margin-bottom: .6rem; display: flex; align-items: center; gap: .45rem; }
.impact-payment-head i { color: var(--ja-gold); }
.impact-payment-row { display: flex; justify-content: space-between; font-size: .82rem; padding: .25rem 0; }
.impact-payment-row span { color: #777; }
.impact-payment-row strong { color: var(--ja-black); }

.impact-trust { display: flex; justify-content: space-around; margin-top: 1.25rem; padding-top: 1.25rem; border-top: 1px solid rgba(0,0,0,0.05); font-size: .8rem; color: #555; }
.impact-trust div { display: flex; align-items: center; gap: .35rem; }

/* Donation form card */
.donation-form-card {
    background: #fff; border-radius: 24px;
    padding: 2.5rem; box-shadow: 0 32px 80px rgba(10,10,10,0.08);
    border: 1px solid rgba(201,162,39,0.18);
    position: relative; overflow: hidden;
}
.donation-form-card::before {
    content: ""; position: absolute; top: -120px; right: -120px;
    width: 320px; height: 320px; border-radius: 50%;
    background: radial-gradient(circle, rgba(201,162,39,0.18) 0%, transparent 65%);
    pointer-events: none;
}
.donation-form-card > * { position: relative; z-index: 1; }
.donation-form-head { display: flex; align-items: center; gap: 1.25rem; margin-bottom: 1.5rem; }
.donation-form-icon {
    width: 64px; height: 64px; border-radius: 18px;
    display: flex; align-items: center; justify-content: center;
    background: var(--ja-gold-gradient); color: #1a1a1a; font-size: 1.85rem;
    box-shadow: 0 14px 30px rgba(201,162,39,0.4);
}

/* Steps indicator */
.donate-steps {
    display: flex; list-style: none; padding: 0; margin: 0 0 2rem;
    gap: .75rem; position: relative;
}
.donate-steps li {
    flex: 1; display: flex; flex-direction: column; align-items: center; gap: .35rem;
    position: relative; color: #999;
}
.donate-steps li::after {
    content: ""; position: absolute; top: 14px; left: calc(50% + 18px); right: calc(-50% + 18px);
    height: 2px; background: rgba(0,0,0,0.08); z-index: 0;
}
.donate-steps li:last-child::after { display: none; }
.donate-steps li.done::after, .donate-steps li.active::after { background: var(--ja-gold-gradient); }
.donate-steps li .step-dot {
    width: 30px; height: 30px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    background: #f1efe7; color: #999; font-weight: 700; font-size: .85rem;
    border: 2px solid #f1efe7; position: relative; z-index: 1;
    transition: all .3s ease;
}
.donate-steps li.active .step-dot {
    background: var(--ja-gold-gradient); color: #1a1a1a; border-color: var(--ja-gold);
    transform: scale(1.15); box-shadow: 0 8px 18px rgba(201,162,39,0.35);
}
.donate-steps li.done .step-dot {
    background: #1a1a1a; color: var(--ja-gold-bright); border-color: #1a1a1a;
}
.donate-steps li small { font-weight: 600; font-size: .78rem; letter-spacing: .05em; }
.donate-steps li.active small { color: var(--ja-gold-deep); }
.donate-steps li.done small { color: #1a1a1a; }

/* Form steps */
.donate-step { display: none; border: 0; padding: 0; margin: 0; animation: donateStepIn .45s cubic-bezier(.16,1,.3,1) both; }
.donate-step.active { display: block; }
@keyframes donateStepIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.donate-step-title {
    font-family: var(--ja-font-display); font-weight: 700;
    font-size: 1.2rem; margin-bottom: 1.4rem;
    display: flex; align-items: center; gap: .55rem; color: var(--ja-black);
}

/* Frequency toggle */
.donate-freq-toggle {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: .5rem;
    background: #faf7ee; border-radius: 14px; padding: .4rem;
    border: 1px solid rgba(201,162,39,0.2);
}
.donate-freq-toggle input { display: none; }
.donate-freq-toggle label {
    text-align: center; padding: .75rem .5rem;
    border-radius: 10px; cursor: pointer; font-weight: 600; font-size: .9rem;
    color: #777; display: flex; align-items: center; justify-content: center; gap: .35rem;
    transition: all .25s ease; margin: 0;
}
.donate-freq-toggle label:hover { color: var(--ja-gold-deep); }
.donate-freq-toggle input:checked + label {
    background: #fff; color: var(--ja-black);
    box-shadow: 0 6px 14px rgba(10,10,10,0.08);
    border: 1px solid rgba(201,162,39,0.4);
}

/* Premium preset grid */
.donate-preset-grid-premium {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem;
}
@media (max-width: 575px) { .donate-preset-grid-premium { grid-template-columns: repeat(2, 1fr); } }
.donate-preset-premium {
    position: relative;
    background: #fff; border: 1.5px solid rgba(0,0,0,0.08);
    padding: 1.1rem .8rem; border-radius: 16px; cursor: pointer; text-align: center;
    display: flex; flex-direction: column; gap: .2rem;
    transition: all .25s cubic-bezier(.16,1,.3,1);
}
.donate-preset-premium:hover { transform: translateY(-3px); border-color: var(--ja-gold); box-shadow: 0 14px 28px rgba(201,162,39,0.18); }
.donate-preset-premium.active {
    background: var(--ja-gold-gradient); color: #1a1a1a; border-color: transparent;
    box-shadow: 0 16px 32px rgba(201,162,39,0.4);
    transform: translateY(-3px);
}
.donate-preset-premium .preset-amount { font-family: var(--ja-font-display); font-weight: 800; font-size: 1.15rem; }
.donate-preset-premium .preset-label { font-size: .75rem; opacity: .8; text-transform: uppercase; letter-spacing: .08em; }
.donate-preset-premium .preset-flag {
    position: absolute; top: -10px; right: -10px;
    background: #1a1a1a; color: var(--ja-gold-bright);
    font-size: .65rem; padding: .2rem .55rem; border-radius: 99px;
    display: inline-flex; align-items: center; gap: .2rem;
    box-shadow: 0 6px 14px rgba(0,0,0,0.25);
}

/* Amount input with currency */
.donate-amount-group {
    display: flex; align-items: stretch;
    border: 1px solid rgba(0,0,0,0.1); border-radius: 12px; overflow: hidden;
    transition: all .25s ease;
}
.donate-amount-group:focus-within { border-color: var(--ja-gold); box-shadow: 0 0 0 .25rem rgba(201,162,39,0.18); }
.donate-currency-pill {
    background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%); color: var(--ja-gold-bright);
    padding: 0 1.1rem; display: flex; align-items: center;
    font-weight: 700; font-family: var(--ja-font-display); letter-spacing: .05em;
}
.donate-amount-input { border: 0 !important; box-shadow: none !important; font-weight: 700; font-size: 1.15rem; }

/* Designation tile grid */
.designation-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; }
@media (max-width: 767px) { .designation-grid { grid-template-columns: repeat(2, 1fr); } }
.designation-grid input { display: none; }
.designation-grid label {
    display: flex; flex-direction: column; align-items: center; text-align: center;
    gap: .45rem; padding: 1rem .75rem;
    background: #fff; border: 1.5px solid rgba(0,0,0,0.08); border-radius: 14px;
    cursor: pointer; font-weight: 600; font-size: .85rem; color: #444;
    transition: all .25s ease; margin: 0; min-height: 100px; justify-content: center;
}
.designation-grid label i { font-size: 1.5rem; color: var(--ja-gold); transition: transform .3s ease; }
.designation-grid label:hover { border-color: var(--ja-gold); transform: translateY(-2px); }
.designation-grid label:hover i { transform: scale(1.15); }
.designation-grid input:checked + label {
    background: linear-gradient(135deg, #fff8e3 0%, #fff 100%);
    border-color: var(--ja-gold); color: var(--ja-black);
    box-shadow: 0 10px 24px rgba(201,162,39,0.2);
}
.designation-grid input:checked + label i { color: var(--ja-gold-deep); }

/* Payment method grid */
.payment-method-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .75rem; }
@media (max-width: 767px) { .payment-method-grid { grid-template-columns: 1fr; } }
.payment-method-grid input { display: none; }
.payment-method-grid label {
    display: flex; flex-direction: column; align-items: flex-start; gap: .35rem;
    padding: 1.1rem 1.2rem;
    background: #fff; border: 1.5px solid rgba(0,0,0,0.08); border-radius: 14px;
    cursor: pointer; transition: all .25s ease; margin: 0; position: relative;
}
.payment-method-grid label i { font-size: 1.8rem; color: var(--ja-gold); }
.payment-method-grid label span { font-weight: 700; color: var(--ja-black); }
.payment-method-grid label small { color: #777; font-size: .75rem; }
.payment-method-grid label:hover { border-color: var(--ja-gold); transform: translateY(-2px); }
.payment-method-grid input:checked + label {
    border-color: var(--ja-gold);
    background: linear-gradient(135deg, #fff8e3 0%, #fff 100%);
    box-shadow: 0 12px 26px rgba(201,162,39,0.22);
}
.payment-method-grid input:checked + label::after {
    content: "✓"; position: absolute; top: .8rem; right: 1rem;
    width: 24px; height: 24px; border-radius: 50%;
    background: var(--ja-gold-gradient); color: #1a1a1a;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800; font-size: .85rem;
}

/* Summary panel */
.donate-summary {
    background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);
    color: #fff; border-radius: 18px; padding: 1.5rem;
    margin-top: 1.5rem; box-shadow: 0 18px 40px rgba(10,10,10,0.2);
    border: 1px solid rgba(201,162,39,0.3);
}
.donate-summary-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: .55rem 0; border-bottom: 1px dashed rgba(255,255,255,0.1);
    font-size: .92rem;
}
.donate-summary-row:last-child { border-bottom: 0; }
.donate-summary-row span { color: rgba(255,255,255,0.7); display: flex; align-items: center; gap: .4rem; }
.donate-summary-row span i { color: var(--ja-gold-bright); }
.donate-summary-row strong { color: #fff; font-weight: 700; }

/* Step actions */
.donate-step-actions {
    display: flex; justify-content: space-between; gap: 1rem;
    margin-top: 2rem; padding-top: 1.5rem;
    border-top: 1px solid rgba(0,0,0,0.06);
}
.donate-step-actions .btn { padding: .85rem 1.6rem; }
.donate-step-actions .btn-step-next, .donate-step-actions .btn-donate-submit { margin-left: auto; }

/* Submit button enhancement */
.btn-donate-submit {
    position: relative; overflow: hidden;
    padding: 1rem 1.8rem !important; font-weight: 700;
}
.btn-donate-submit .btn-icon-wrap {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(10,10,10,0.85); color: var(--ja-gold);
    margin-right: .6rem; transition: transform .4s ease;
}
.btn-donate-submit:hover .btn-icon-wrap { transform: scale(1.15) rotate(-12deg); }
.btn-donate-submit::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
    transform: translateX(-100%); transition: transform .6s ease;
}
.btn-donate-submit:hover::after { transform: translateX(100%); }

/* Smaller donate hero on mobile */
@media (max-width: 767px) {
    .donate-hero { padding: 3rem 0 2.5rem; }
    .donation-form-card { padding: 1.5rem; }
    .impact-summary-card { position: relative; top: 0; }
    .donate-steps li small { font-size: .68rem; }
}

/* ====================================================
   LUXE CONTACT FORM
   ==================================================== */
.luxe-contact {
    position: relative;
    background: linear-gradient(180deg, #ffffff 0%, #fffdf6 100%);
    border-radius: 28px;
    padding: 2.5rem 2.5rem 2.25rem;
    box-shadow: 0 32px 70px rgba(10,10,10,0.10), 0 0 0 1px rgba(201,162,39,0.18) inset;
    overflow: hidden;
    isolation: isolate;
    animation: luxeRise .8s cubic-bezier(.16,1,.3,1) both;
}
@keyframes luxeRise {
    0% { opacity: 0; transform: translateY(28px) scale(.98); }
    100% { opacity: 1; transform: none; }
}
.luxe-glow {
    position: absolute; inset: -2px;
    border-radius: inherit; padding: 2px;
    background: conic-gradient(from 0deg,
        rgba(201,162,39,0.0) 0deg,
        rgba(201,162,39,0.55) 90deg,
        rgba(201,162,39,0.0) 180deg,
        rgba(201,162,39,0.55) 270deg,
        rgba(201,162,39,0.0) 360deg);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude;
    animation: luxeGlowSpin 14s linear infinite;
    opacity: .9; z-index: -1; pointer-events: none;
}
@keyframes luxeGlowSpin { to { transform: rotate(360deg); } }
.luxe-orb { position: absolute; border-radius: 50%; filter: blur(40px); z-index: -1; pointer-events: none; }
.luxe-orb-a { width: 280px; height: 280px; top: -110px; right: -110px;
    background: radial-gradient(circle, rgba(201,162,39,0.45) 0%, transparent 70%);
    animation: luxeFloat 11s ease-in-out infinite;
}
.luxe-orb-b { width: 220px; height: 220px; bottom: -90px; left: -80px;
    background: radial-gradient(circle, rgba(10,10,10,0.18) 0%, transparent 70%);
    animation: luxeFloat 14s ease-in-out infinite reverse;
}
@keyframes luxeFloat { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(14px,22px) scale(1.08); } }

/* Head */
.luxe-head {
    display: grid; grid-template-columns: auto 1fr auto; align-items: center;
    gap: 1.1rem; margin-bottom: 1.75rem;
}
@media (max-width: 575px) {
    .luxe-contact { padding: 1.75rem 1.25rem; }
    .luxe-head { grid-template-columns: auto 1fr; }
    .luxe-live { grid-column: 1 / -1; justify-self: start; }
}
.luxe-head-icon {
    position: relative; width: 64px; height: 64px;
    border-radius: 18px;
    background: linear-gradient(135deg, #c9a227 0%, #e6c14b 100%);
    color: #1a1a1a; display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.85rem; box-shadow: 0 14px 30px rgba(201,162,39,0.4);
    animation: luxeIconBob 4.5s ease-in-out infinite;
}
@keyframes luxeIconBob { 0%,100% { transform: translateY(0) rotate(-2deg); } 50% { transform: translateY(-6px) rotate(2deg); } }
.luxe-icon-ring {
    position: absolute; inset: -10px; border-radius: 22px;
    border: 1.5px dashed rgba(201,162,39,0.55);
    animation: luxeRingSpin 16s linear infinite;
}
@keyframes luxeRingSpin { to { transform: rotate(360deg); } }
.luxe-eyebrow {
    display: inline-flex; align-items: center; gap: .4rem;
    text-transform: uppercase; letter-spacing: .22em; font-size: .72rem;
    color: var(--ja-gold-deep); font-weight: 700;
    background: rgba(201,162,39,0.1); border: 1px solid rgba(201,162,39,0.3);
    padding: .25rem .65rem; border-radius: 99px;
}
.luxe-title { font-family: var(--ja-font-display); font-weight: 800; margin: .55rem 0 .3rem; font-size: 1.85rem; color: var(--ja-black); }
.luxe-title .accent { background: var(--ja-gold-gradient); -webkit-background-clip: text; background-clip: text; color: transparent; }
.luxe-sub { font-size: .9rem; color: #666; margin: 0; }
.luxe-sub i { color: var(--ja-gold-deep); }
.luxe-live {
    display: inline-flex; align-items: center; gap: .45rem;
    background: rgba(46,160,67,0.08); color: #1a7f37;
    padding: .3rem .7rem; border-radius: 99px; font-weight: 600; font-size: .75rem;
    border: 1px solid rgba(46,160,67,0.25);
}
.live-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #2ea043; box-shadow: 0 0 0 0 rgba(46,160,67,0.55);
    animation: livePulse 1.6s ease-out infinite;
}
@keyframes livePulse {
    0% { box-shadow: 0 0 0 0 rgba(46,160,67,0.55); }
    70% { box-shadow: 0 0 0 10px rgba(46,160,67,0); }
    100% { box-shadow: 0 0 0 0 rgba(46,160,67,0); }
}

/* Success burst */
.luxe-success {
    display: flex; align-items: center; gap: 1.1rem;
    background: linear-gradient(135deg, rgba(46,160,67,0.10) 0%, rgba(201,162,39,0.12) 100%);
    border: 1px solid rgba(46,160,67,0.3);
    border-left: 5px solid #2ea043;
    border-radius: 18px; padding: 1.1rem 1.25rem; margin-bottom: 1.5rem;
    animation: luxeSuccessIn .7s cubic-bezier(.16,1,.3,1) both;
}
@keyframes luxeSuccessIn { 0% { opacity: 0; transform: scale(.9); } 60% { transform: scale(1.02); } 100% { opacity: 1; transform: none; } }
.luxe-success-burst {
    position: relative; width: 52px; height: 52px; flex-shrink: 0;
    border-radius: 50%; background: #2ea043; color: #fff;
    display: flex; align-items: center; justify-content: center; font-size: 1.8rem;
    box-shadow: 0 12px 24px rgba(46,160,67,0.35);
}
.luxe-success-burst .confetti {
    position: absolute; width: 6px; height: 6px; border-radius: 1px;
    background: var(--ja-gold); opacity: 0;
    animation: confettiBurst 1.4s ease-out .15s forwards;
}
.luxe-success-burst .c1 { background: #c9a227; --x: -42px; --y: -36px; --r: -45deg; }
.luxe-success-burst .c2 { background: #2ea043; --x: 40px; --y: -34px; --r: 30deg; }
.luxe-success-burst .c3 { background: #e6c14b; --x: -50px; --y: 10px; --r: 65deg; }
.luxe-success-burst .c4 { background: #c9a227; --x: 50px; --y: 8px; --r: -65deg; }
.luxe-success-burst .c5 { background: #2ea043; --x: -22px; --y: 44px; --r: 12deg; }
.luxe-success-burst .c6 { background: #e6c14b; --x: 28px; --y: 42px; --r: -25deg; }
@keyframes confettiBurst {
    0% { opacity: 0; transform: translate(0,0) rotate(0); }
    20% { opacity: 1; }
    100% { opacity: 0; transform: translate(var(--x), var(--y)) rotate(var(--r)); }
}

/* Segmented inquiry control */
.luxe-segment {
    background: linear-gradient(180deg, #fafaf6 0%, #ffffff 100%);
    border: 1px dashed rgba(201,162,39,0.35);
    padding: .9rem 1rem 1rem; border-radius: 16px;
}
.luxe-segment-label {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .8rem; color: #555; font-weight: 600; margin-bottom: .6rem;
}
.luxe-segment-label i { color: var(--ja-gold-deep); }
.luxe-segment-group {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: .5rem;
}
@media (max-width: 575px) { .luxe-segment-group { grid-template-columns: repeat(2, 1fr); } }
.luxe-segment-group input { display: none; }
.luxe-segment-group label {
    display: flex; align-items: center; justify-content: center; gap: .4rem;
    padding: .65rem .4rem; border-radius: 12px; cursor: pointer;
    background: #fff; border: 1.5px solid rgba(0,0,0,0.06);
    font-weight: 600; font-size: .82rem; color: #555;
    transition: all .25s cubic-bezier(.16,1,.3,1); margin: 0;
}
.luxe-segment-group label i { color: var(--ja-gold-deep); font-size: 1rem; transition: transform .3s ease; }
.luxe-segment-group label:hover { transform: translateY(-2px); border-color: var(--ja-gold); color: var(--ja-black); }
.luxe-segment-group label:hover i { transform: scale(1.18); }
.luxe-segment-group input:checked + label {
    background: linear-gradient(135deg, #1a1a1a 0%, #2a2a2a 100%);
    color: #fff; border-color: transparent;
    box-shadow: 0 12px 24px rgba(10,10,10,0.25);
}
.luxe-segment-group input:checked + label i { color: var(--ja-gold-bright); }

/* Fields */
.luxe-form .luxe-field { position: relative; padding-top: .4rem; }
.luxe-input {
    width: 100%; padding: 1.6rem 1rem .65rem 2.6rem;
    background: #ffffff; border: 1.5px solid rgba(0,0,0,0.08);
    border-radius: 14px; font-size: .95rem; color: #1a1a1a;
    transition: all .3s cubic-bezier(.16,1,.3,1);
    box-shadow: 0 1px 0 rgba(0,0,0,0.02);
}
.luxe-textarea { padding-top: 2rem; resize: vertical; min-height: 140px; }
.luxe-input::placeholder { color: transparent; }
.luxe-input:focus { outline: 0; border-color: var(--ja-gold); background: #fffdf6; box-shadow: 0 12px 28px rgba(201,162,39,0.18); transform: translateY(-1px); }
.luxe-label {
    position: absolute; left: 2.6rem; top: 1.25rem; pointer-events: none;
    font-size: .95rem; color: #888; font-weight: 500;
    display: inline-flex; align-items: center; gap: .4rem;
    transition: all .25s cubic-bezier(.16,1,.3,1);
    background: transparent; padding: 0 .25rem;
}
.luxe-label i { color: var(--ja-gold-deep); font-size: 1.05rem; transition: transform .3s ease; }
.luxe-input:focus + .luxe-label,
.luxe-input:not(:placeholder-shown) + .luxe-label {
    top: -.45rem; left: 1rem; font-size: .72rem; color: var(--ja-gold-deep); font-weight: 700;
    background: #ffffff; letter-spacing: .04em; text-transform: uppercase;
}
.luxe-input:focus + .luxe-label i { transform: scale(1.18) rotate(-6deg); color: var(--ja-gold); }

/* Underline bar */
.luxe-bar {
    position: absolute; left: 1rem; right: 1rem; bottom: -1px; height: 2px;
    background: var(--ja-gold-gradient); border-radius: 99px;
    transform: scaleX(0); transform-origin: left center;
    transition: transform .35s cubic-bezier(.16,1,.3,1); opacity: 0;
}
.luxe-input:focus ~ .luxe-bar { transform: scaleX(1); opacity: 1; }

/* Error */
.luxe-error { display: block; margin-top: .35rem; font-size: .78rem; color: #c1303f; font-weight: 500; }

/* Textarea footer */
.luxe-field-area .luxe-area-foot {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: .35rem; padding: 0 .25rem; gap: .5rem;
}
.luxe-counter { font-variant-numeric: tabular-nums; color: #999; }
.luxe-counter.warn { color: #c1303f; font-weight: 700; }

/* Trust */
.luxe-trust {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: .6rem;
    margin: 1.5rem 0 1.25rem;
}
@media (max-width: 575px) { .luxe-trust { grid-template-columns: repeat(2, 1fr); } }
.luxe-trust > div {
    display: flex; align-items: center; gap: .4rem;
    padding: .55rem .7rem; background: rgba(201,162,39,0.06);
    border: 1px solid rgba(201,162,39,0.2); border-radius: 10px;
    font-size: .78rem; color: #555; font-weight: 600;
    transition: all .25s ease;
}
.luxe-trust > div:hover { background: rgba(201,162,39,0.14); transform: translateY(-2px); }
.luxe-trust > div i { color: var(--ja-gold-deep); font-size: 1rem; }

/* Submit button */
.luxe-submit {
    position: relative; width: 100%;
    border: 0; border-radius: 16px; padding: 1.1rem 1.5rem;
    background: #0a0a0a; color: #fff;
    font-weight: 700; letter-spacing: .03em; font-size: 1rem;
    overflow: hidden; cursor: pointer;
    transition: transform .25s ease, box-shadow .25s ease;
    box-shadow: 0 16px 36px rgba(10,10,10,0.35);
}
.luxe-submit-bg {
    position: absolute; inset: 0;
    background: linear-gradient(120deg, #c9a227 0%, #e6c14b 50%, #c9a227 100%);
    background-size: 220% 100%;
    background-position: 100% 0;
    transition: background-position .8s ease, opacity .3s ease;
    opacity: 0;
}
.luxe-submit:hover { transform: translateY(-3px); box-shadow: 0 22px 44px rgba(201,162,39,0.45); color: #1a1a1a; }
.luxe-submit:hover .luxe-submit-bg { opacity: 1; background-position: 0 0; }
.luxe-submit-content {
    position: relative; z-index: 1;
    display: inline-flex; align-items: center; gap: .65rem;
    transition: transform .3s ease, opacity .3s ease;
}
.luxe-plane {
    display: inline-flex; align-items: center; justify-content: center;
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(255,255,255,0.12); color: var(--ja-gold-bright);
    transition: transform .45s cubic-bezier(.16,1,.3,1), background .3s ease, color .3s ease;
}
.luxe-submit:hover .luxe-plane { background: rgba(10,10,10,0.85); color: var(--ja-gold-bright); transform: translateX(4px) rotate(-18deg) scale(1.08); }
.luxe-submit-arrow { transition: transform .35s ease; }
.luxe-submit:hover .luxe-submit-arrow { transform: translateX(6px); }
.luxe-submit::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.45), transparent);
    transform: translateX(-100%); transition: transform .8s ease; z-index: 1;
}
.luxe-submit:hover::after { transform: translateX(100%); }
.luxe-submit-spinner {
    position: absolute; inset: 0; display: none;
    align-items: center; justify-content: center; z-index: 2;
    color: #1a1a1a;
}
.luxe-submit-spinner i { font-size: 1.4rem; animation: luxeSpin 1s linear infinite; }
@keyframes luxeSpin { to { transform: rotate(360deg); } }
.luxe-submit.is-sending .luxe-submit-content { opacity: 0; transform: translateY(4px); }
.luxe-submit.is-sending .luxe-submit-spinner { display: flex; }
.luxe-submit.is-sending .luxe-submit-bg { opacity: 1; background-position: 0 0; }
.luxe-submit.is-sending { color: transparent; cursor: progress; }

/* ====================================================
   LUXE CONTACT SIDE PANEL
   ==================================================== */
.luxe-side { display: flex; flex-direction: column; gap: 1.25rem; }
.luxe-side-card {
    background: #fff; border-radius: 22px;
    box-shadow: 0 24px 60px rgba(10,10,10,0.08);
    border: 1px solid rgba(0,0,0,0.04);
    overflow: hidden; position: relative;
    transition: transform .3s ease, box-shadow .3s ease;
}
.luxe-side-card:hover { transform: translateY(-3px); box-shadow: 0 28px 70px rgba(10,10,10,0.12); }
.luxe-side-head {
    display: flex; align-items: center; gap: .85rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid rgba(0,0,0,0.04);
}
.luxe-side-head > i {
    width: 42px; height: 42px; border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #fff8e3 0%, #ffeaa7 100%);
    color: var(--ja-gold-deep); font-size: 1.25rem; flex-shrink: 0;
}
.luxe-side-head strong { display: block; color: var(--ja-black); font-weight: 700; font-size: .95rem; }
.luxe-side-head small { color: #777; font-size: .78rem; }
.luxe-side-link {
    margin-left: auto; width: 36px; height: 36px; border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    background: rgba(201,162,39,0.1); color: var(--ja-gold-deep);
    transition: all .25s ease; text-decoration: none;
}
.luxe-side-link:hover { background: var(--ja-gold-gradient); color: #1a1a1a; transform: rotate(-8deg); }
.luxe-map-frame { height: 280px; }
.luxe-map-frame iframe { display: block; filter: saturate(.9) contrast(1.05); }

.luxe-whatsapp-card {
    background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);
    color: #fff; padding: 1.5rem 1.5rem 1.6rem; text-align: center;
    border: 1px solid rgba(46,160,67,0.3);
}
.luxe-whatsapp-card h6 { color: #fff; font-weight: 700; }
.luxe-whatsapp-card p { color: rgba(255,255,255,0.7); }
.luxe-wa-glow {
    position: absolute; top: -80px; right: -80px;
    width: 220px; height: 220px; border-radius: 50%;
    background: radial-gradient(circle, rgba(37,211,102,0.45) 0%, transparent 65%);
    filter: blur(20px); animation: luxeFloat 9s ease-in-out infinite;
}
.luxe-wa-icon {
    width: 64px; height: 64px; border-radius: 50%;
    background: linear-gradient(135deg, #25d366 0%, #1da851 100%); color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 2rem; margin: 0 auto .85rem;
    box-shadow: 0 14px 30px rgba(37,211,102,0.45);
    animation: luxeWaPulse 2.4s ease-in-out infinite;
    position: relative; z-index: 1;
}
@keyframes luxeWaPulse {
    0%,100% { transform: scale(1); box-shadow: 0 14px 30px rgba(37,211,102,0.45); }
    50% { transform: scale(1.06); box-shadow: 0 18px 38px rgba(37,211,102,0.6); }
}
.luxe-wa-btn {
    position: relative; z-index: 1;
    display: inline-flex; align-items: center; justify-content: center; gap: .45rem;
    width: 100%; padding: .9rem 1.25rem; border-radius: 12px;
    background: linear-gradient(135deg, #25d366 0%, #1da851 100%);
    color: #fff; font-weight: 700; text-decoration: none;
    box-shadow: 0 14px 30px rgba(37,211,102,0.35);
    transition: all .3s ease;
}
.luxe-wa-btn:hover { transform: translateY(-3px); color: #fff; box-shadow: 0 20px 40px rgba(37,211,102,0.55); }

.luxe-hours-list { list-style: none; padding: 1rem 1.25rem 1.25rem; margin: 0; }
.luxe-hours-list li {
    display: flex; justify-content: space-between; align-items: center;
    padding: .55rem 0; border-bottom: 1px dashed rgba(0,0,0,0.06);
    font-size: .9rem;
}
.luxe-hours-list li:last-child { border-bottom: 0; }
.luxe-hours-list span { color: #777; }
.luxe-hours-list strong { color: var(--ja-black); }

@media (max-width: 991px) {
    .luxe-side { margin-top: 1.5rem; }
}

/* ====================================================
   PROFILE CARD (clickable) + PROFILE MODAL
   For Team & Advisory Board members
   ==================================================== */
.profile-card {
    cursor: pointer;
    outline: 0;
    transition: transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s cubic-bezier(.16,1,.3,1);
}
.profile-card:focus-visible {
    box-shadow: 0 0 0 3px rgba(201,162,39,0.45), var(--ja-shadow-md);
    transform: translateY(-6px);
}

/* "View Profile" overlay hint */
.profile-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 35%, rgba(10,10,10,0.78) 100%);
    display: flex; align-items: flex-end; justify-content: center;
    padding-bottom: 4.5rem;
    opacity: 0;
    transition: opacity .4s cubic-bezier(.16,1,.3,1);
    pointer-events: none;
    z-index: 2;
}
.profile-card:hover .profile-overlay,
.profile-card:focus-visible .profile-overlay { opacity: 1; }
.view-profile-badge {
    display: inline-flex; align-items: center; gap: .45rem;
    padding: .55rem 1.1rem;
    background: rgba(255,255,255,0.95);
    color: #1a1a1a; font-weight: 700;
    font-size: .8rem; letter-spacing: .04em; text-transform: uppercase;
    border-radius: 99px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.35);
    transform: translateY(12px);
    transition: transform .45s cubic-bezier(.16,1,.3,1);
}
.profile-card:hover .view-profile-badge,
.profile-card:focus-visible .view-profile-badge { transform: translateY(0); }
.view-profile-badge i { color: var(--ja-gold-deep); font-size: 1.05rem; }

/* Socials sit above the overlay on hover */
.team-card .socials { z-index: 3; }

/* ====================================================
   PROFILE MODAL
   ==================================================== */
.profile-modal .modal-dialog {
    margin: 1.75rem auto;
}
.profile-modal-content {
    border: 0;
    border-radius: 24px;
    overflow: hidden;
    background: #ffffff;
    box-shadow: 0 50px 100px rgba(10,10,10,0.35), 0 0 0 1px rgba(201,162,39,0.18) inset;
    position: relative;
}
.profile-modal.fade .modal-dialog {
    transform: scale(.92) translateY(20px);
    transition: transform .45s cubic-bezier(.16,1,.3,1), opacity .35s ease;
}
.profile-modal.show .modal-dialog {
    transform: none;
}

/* Close button */
.btn-close-luxe {
    position: absolute; top: 1rem; right: 1rem; z-index: 5;
    width: 40px; height: 40px; border-radius: 50%;
    border: 0;
    background: rgba(255,255,255,0.9);
    color: #1a1a1a;
    backdrop-filter: blur(10px);
    box-shadow: 0 8px 20px rgba(0,0,0,0.2);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.3rem;
    cursor: pointer;
    transition: all .3s cubic-bezier(.16,1,.3,1);
}
.btn-close-luxe:hover {
    background: #1a1a1a; color: var(--ja-gold-bright);
    transform: rotate(90deg) scale(1.08);
    box-shadow: 0 12px 28px rgba(0,0,0,0.35);
}

/* Two-column grid */
.profile-modal-grid {
    display: grid;
    grid-template-columns: 0.85fr 1.15fr;
    min-height: 480px;
}
@media (max-width: 767px) {
    .profile-modal-grid { grid-template-columns: 1fr; }
}

/* Photo side */
.profile-modal-photo {
    position: relative;
    background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%);
    overflow: hidden;
    min-height: 320px;
}
.profile-modal-photo img {
    width: 100%; height: 100%; object-fit: cover; object-position: center top;
    display: block;
    filter: grayscale(0.05);
    animation: profilePhotoIn .9s cubic-bezier(.16,1,.3,1) both;
}
@keyframes profilePhotoIn {
    from { opacity: 0; transform: scale(1.08); }
    to   { opacity: 1; transform: none; }
}
.profile-photo-overlay {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: 1.25rem;
    background: linear-gradient(180deg, transparent 0%, rgba(10,10,10,0.85) 100%);
}
.profile-badge {
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .4rem .85rem;
    background: rgba(255,255,255,0.96);
    color: var(--ja-gold-deep);
    border-radius: 99px;
    font-size: .72rem; font-weight: 800;
    letter-spacing: .15em; text-transform: uppercase;
    box-shadow: 0 8px 20px rgba(0,0,0,0.25);
}
.profile-badge i { color: var(--ja-gold); font-size: .95rem; }
.profile-badge-advisor {
    background: linear-gradient(135deg, #c9a227 0%, #e6c14b 100%);
    color: #1a1a1a;
}
.profile-badge-advisor i { color: #1a1a1a; }

/* Decorative gold corner on the photo */
.profile-modal-photo::before {
    content: ""; position: absolute; top: 0; left: 0;
    width: 90px; height: 90px;
    background: linear-gradient(135deg, var(--ja-gold) 0%, transparent 60%);
    opacity: .45; z-index: 1; pointer-events: none;
}

/* Body side */
.profile-modal-body {
    padding: 2.25rem 2.25rem 2rem;
    display: flex; flex-direction: column;
    animation: profileBodyIn .6s .15s cubic-bezier(.16,1,.3,1) both;
    overflow-y: auto;
}
@keyframes profileBodyIn {
    from { opacity: 0; transform: translateX(20px); }
    to   { opacity: 1; transform: none; }
}
@media (max-width: 767px) {
    .profile-modal-body { padding: 1.5rem 1.5rem 1.75rem; }
    .profile-modal-photo { min-height: 280px; max-height: 320px; }
}

.profile-eyebrow {
    display: inline-flex; align-items: center; gap: .4rem;
    align-self: flex-start;
    padding: .3rem .75rem;
    background: rgba(201,162,39,0.12);
    color: var(--ja-gold-deep);
    border: 1px solid rgba(201,162,39,0.3);
    border-radius: 99px;
    font-size: .68rem; font-weight: 700;
    letter-spacing: .22em; text-transform: uppercase;
    margin-bottom: .85rem;
}
.profile-eyebrow i { font-size: .85rem; color: var(--ja-gold); }
.profile-eyebrow-advisor {
    background: linear-gradient(135deg, rgba(201,162,39,0.18) 0%, rgba(230,184,53,0.25) 100%);
    border-color: rgba(201,162,39,0.45);
}

.profile-name {
    font-family: var(--ja-font-display);
    font-weight: 800;
    font-size: 1.75rem;
    color: var(--ja-black);
    margin: 0 0 .35rem;
    line-height: 1.15;
}
.profile-role {
    color: var(--ja-gold-deep);
    font-weight: 700;
    font-size: .78rem;
    text-transform: uppercase;
    letter-spacing: .2em;
}

.profile-divider {
    width: 50px; height: 3px;
    background: var(--ja-gold-gradient);
    border-radius: 99px;
    margin: 1.1rem 0 1rem;
}

.profile-bio {
    color: #555;
    line-height: 1.7;
    font-size: .94rem;
    margin-bottom: 1.5rem;
}

/* Meta grid (expertise / location / years) */
.profile-meta-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .75rem;
    margin-bottom: 1.75rem;
}
.profile-meta-wide { grid-column: 1 / -1; }
.profile-meta-item {
    display: flex; align-items: flex-start; gap: .7rem;
    padding: .85rem 1rem;
    background: linear-gradient(180deg, #fffdf6 0%, #ffffff 100%);
    border: 1px solid rgba(201,162,39,0.18);
    border-radius: 12px;
    transition: all .3s cubic-bezier(.16,1,.3,1);
}
.profile-meta-item:hover {
    border-color: var(--ja-gold);
    transform: translateY(-2px);
    box-shadow: 0 10px 22px rgba(201,162,39,0.18);
}
.profile-meta-item > i {
    width: 36px; height: 36px; flex-shrink: 0;
    border-radius: 10px;
    background: linear-gradient(135deg, #c9a227 0%, #e6c14b 100%);
    color: #1a1a1a;
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.1rem;
    box-shadow: 0 6px 14px rgba(201,162,39,0.35);
}
.profile-meta-item small {
    display: block;
    font-size: .68rem; font-weight: 700;
    color: #999;
    text-transform: uppercase;
    letter-spacing: .15em;
    margin-bottom: .15rem;
}
.profile-meta-item strong {
    display: block;
    font-size: .88rem;
    color: var(--ja-black);
    line-height: 1.35;
    font-weight: 600;
}

/* Action buttons */
.profile-actions {
    display: flex; align-items: center; flex-wrap: wrap; gap: .7rem;
    margin-top: auto;
    padding-top: .25rem;
}
.profile-actions .btn { padding: .65rem 1.2rem; font-size: .85rem; }
.profile-icon-btn {
    width: 42px; height: 42px; border-radius: 12px;
    display: inline-flex; align-items: center; justify-content: center;
    background: #1a1a1a; color: #fff;
    text-decoration: none; font-size: 1.05rem;
    transition: all .3s cubic-bezier(.16,1,.3,1);
}
.profile-icon-btn:hover {
    background: var(--ja-gold-gradient);
    color: #1a1a1a;
    transform: translateY(-2px) rotate(-6deg);
    box-shadow: 0 12px 24px rgba(201,162,39,0.4);
}

/* Modal backdrop tweak */
.modal-backdrop.show { opacity: .65; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
