/* ═══════════════════════════════════════════════════════════
   Osmanoğlu Derneği – Modern Ana Stil
   ═══════════════════════════════════════════════════════════ */

:root {
    --primary:       #1a6b3c;
    --primary-dark:  #0f4726;
    --primary-light: #25a05a;
    --primary-glow:  rgba(26,107,60,.35);
    --gold:          #c9a02a;
    --gold-light:    #e8be45;
    --gold-glow:     rgba(201,160,42,.4);
    --accent:        #e53935;
    --dark:          #0e1117;
    --dark-2:        #1c1c2e;
    --gray:          #6b7280;
    --light:         #f0f7f3;
    --white:         #ffffff;
    --shadow:        0 4px 24px rgba(0,0,0,.10);
    --shadow-lg:     0 16px 48px rgba(0,0,0,.16);
    --shadow-card:   0 2px 12px rgba(0,0,0,.07);
    --radius:        16px;
    --radius-sm:     10px;
    --transition:    all .35s cubic-bezier(.4,0,.2,1);
    --glass-bg:      rgba(255,255,255,.10);
    --glass-border:  rgba(255,255,255,.18);
}

/* ── Reset & Base ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family:'Nunito',sans-serif; color:#374151; line-height:1.75; overflow-x:hidden; background:#fff; }
h1,h2,h3,h4,h5,h6 { font-family:'Poppins',sans-serif; font-weight:700; }
a { text-decoration:none; transition:var(--transition); }
img { max-width:100%; }

/* ── Gradient Text ─────────────────────────────────────── */
.gradient-text {
    background: linear-gradient(135deg, var(--primary-light) 0%, var(--gold) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* ── Utility ───────────────────────────────────────────── */
.section-title {
    font-size: clamp(1.6rem,3vw,2.4rem);
    font-weight: 800;
    color: var(--dark-2);
    line-height: 1.2;
}
.section-title span { color: var(--primary); }
.section-subtitle { color: var(--gray); font-size:1.05rem; max-width:580px; margin:0 auto; }

.divider {
    width:56px; height:4px;
    background: linear-gradient(90deg,var(--primary),var(--gold));
    border-radius:2px; margin:14px 0 22px;
}
.divider.center { margin-left:auto; margin-right:auto; }

/* ── Buttons ───────────────────────────────────────────── */
.btn-primary-custom {
    background: linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#fff; border:none;
    border-radius:50px; padding:13px 34px;
    font-weight:700; font-family:'Poppins',sans-serif; font-size:.93rem;
    transition:var(--transition);
    display:inline-flex; align-items:center; gap:8px;
    box-shadow:0 4px 16px var(--primary-glow);
}
.btn-primary-custom:hover {
    color:#fff; transform:translateY(-3px);
    box-shadow:0 10px 28px var(--primary-glow);
}

.btn-gold {
    background: linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--dark-2); border:none;
    border-radius:50px; padding:13px 34px;
    font-weight:700; font-family:'Poppins',sans-serif; font-size:.93rem;
    transition:var(--transition);
    display:inline-flex; align-items:center; gap:8px;
    box-shadow:0 4px 16px var(--gold-glow);
}
.btn-gold:hover {
    color:var(--dark-2); transform:translateY(-3px);
    box-shadow:0 10px 28px var(--gold-glow);
}

.btn-outline-white {
    border:2px solid rgba(255,255,255,.65);
    color:#fff; border-radius:50px; padding:12px 32px;
    font-weight:600; font-family:'Poppins',sans-serif; font-size:.93rem;
    transition:var(--transition);
    display:inline-flex; align-items:center; gap:8px;
    backdrop-filter:blur(4px);
}
.btn-outline-white:hover {
    background:rgba(255,255,255,.18); color:#fff;
    border-color:#fff; transform:translateY(-3px);
}

/* ── Floating Donate Button ────────────────────────────── */
.float-donate {
    position:fixed; bottom:28px; right:28px; z-index:9998;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--dark-2);
    border:none; border-radius:50px;
    padding:13px 20px;
    font-weight:800; font-family:'Poppins',sans-serif; font-size:.88rem;
    box-shadow:0 8px 28px var(--gold-glow);
    cursor:pointer; transition:var(--transition);
    display:flex; align-items:center; gap:8px;
    text-decoration:none;
}
.float-donate:hover { transform:translateY(-5px) scale(1.04); box-shadow:0 16px 40px var(--gold-glow); color:var(--dark-2); }
.float-donate i { font-size:1.1rem; }
.float-donate .float-text { display:none; }
@media(min-width:640px){ .float-donate .float-text { display:inline; } }

/* ── Navbar ────────────────────────────────────────────── */
#mainNav {
    padding:20px 0;
    transition:var(--transition);
    background:transparent;
}
#mainNav.scrolled {
    background:rgba(10,38,20,.92);
    backdrop-filter:blur(18px) saturate(1.4);
    -webkit-backdrop-filter:blur(18px) saturate(1.4);
    padding:12px 0;
    box-shadow:0 4px 32px rgba(0,0,0,.25);
    border-bottom:1px solid rgba(255,255,255,.06);
}
#mainNav.solid { background:var(--primary-dark); padding:14px 0; }

.navbar-brand {
    display:flex; align-items:center; gap:10px;
    color:#fff !important; font-weight:800; font-size:1.1rem; font-family:'Poppins',sans-serif;
}
.nav-logo {
    height:42px; width:auto; object-fit:contain;
    filter: brightness(0) invert(1);
}

.footer-logo {
    height:70px; width:auto; object-fit:contain;
    filter: brightness(0) invert(1);
}

.nav-link {
    color:rgba(255,255,255,.88) !important;
    font-weight:600; font-family:'Poppins',sans-serif; font-size:.88rem;
    padding:8px 16px !important; border-radius:8px; letter-spacing:.2px;
    position:relative;
}
.nav-link::after {
    content:''; position:absolute; bottom:4px; left:50%; transform:translateX(-50%);
    width:0; height:2px; background:var(--gold-light); border-radius:1px;
    transition:width .3s ease;
}
.nav-link:hover::after, .nav-link.active::after { width:60%; }
.nav-link:hover, .nav-link.active { color:#fff !important; }

.btn-donate-nav { padding:10px 22px !important; font-size:.86rem !important; }
.navbar-toggler { border:2px solid rgba(255,255,255,.55); border-radius:8px; }
.navbar-toggler-icon { background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255%2c255%2c255%2c0.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e"); }

/* ── Hero Slider ───────────────────────────────────────── */
.hero-swiper { height:100vh; min-height:620px; }

.hero-slide {
    position:relative;
    display:flex; align-items:center; height:100%;
    background:linear-gradient(135deg,var(--primary-dark),var(--dark));
}
.hero-slide-bg {
    position:absolute; inset:0;
    background-size:cover; background-position:center;
    transition:transform 8s ease;
}
.swiper-slide-active .hero-slide-bg { transform:scale(1.10); }

/* Çok katmanlı modern overlay */
.hero-overlay {
    position:absolute; inset:0;
    background:
        linear-gradient(to right, rgba(10,38,20,.92) 0%, rgba(10,38,20,.65) 60%, rgba(10,38,20,.3) 100%),
        linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 50%);
}

/* Dekoratif ışık efekti */
.hero-overlay::after {
    content:'';
    position:absolute; inset:0;
    background:radial-gradient(ellipse 60% 70% at 20% 50%, rgba(26,107,60,.22) 0%, transparent 70%);
}

.hero-content { position:relative; z-index:3; color:#fff; padding:0 20px; }

/* Hero animasyonları */
.hero-badge,
.hero-title,
.hero-subtitle,
.hero-buttons { opacity:0; transform:translateY(36px); }

.swiper-slide-active .hero-badge    { animation:heroReveal .65s .15s cubic-bezier(.22,1,.36,1) forwards; }
.swiper-slide-active .hero-title    { animation:heroReveal .65s .32s cubic-bezier(.22,1,.36,1) forwards; }
.swiper-slide-active .hero-subtitle { animation:heroReveal .65s .48s cubic-bezier(.22,1,.36,1) forwards; }
.swiper-slide-active .hero-buttons  { animation:heroReveal .65s .62s cubic-bezier(.22,1,.36,1) forwards; }

@keyframes heroReveal {
    to { opacity:1; transform:translateY(0); }
}

.hero-badge {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(201,160,42,.18);
    border:1px solid rgba(201,160,42,.45);
    color:var(--gold-light);
    padding:6px 18px; border-radius:50px;
    font-size:.8rem; font-weight:700; letter-spacing:.8px; text-transform:uppercase;
    margin-bottom:20px;
    backdrop-filter:blur(8px);
}
.hero-badge .badge-dot {
    width:6px; height:6px; border-radius:50%;
    background:var(--gold-light);
    animation:pulseDot 2s infinite;
}
@keyframes pulseDot {
    0%,100% { opacity:1; transform:scale(1); }
    50%      { opacity:.4; transform:scale(.6); }
}

.hero-title {
    font-size:clamp(2.2rem,5.5vw,4.2rem);
    font-weight:900; line-height:1.12;
    margin-bottom:22px;
    text-shadow:0 4px 24px rgba(0,0,0,.4);
    letter-spacing:-.5px;
}
.hero-title .highlight {
    background:linear-gradient(135deg,var(--gold-light),#fff 60%,var(--gold-light));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.hero-subtitle {
    font-size:clamp(.97rem,2vw,1.2rem);
    color:rgba(255,255,255,.82);
    margin-bottom:40px;
    max-width:560px; line-height:1.7;
}
.hero-buttons { display:flex; flex-wrap:wrap; gap:14px; }

/* Slider pagination & arrows */
.hero-swiper .swiper-pagination { bottom:36px; }
.hero-swiper .swiper-pagination-bullet {
    background:rgba(255,255,255,.4); width:10px; height:10px;
    transition:var(--transition);
}
.hero-swiper .swiper-pagination-bullet-active {
    background:var(--gold-light); width:28px; border-radius:5px;
}
.hero-swiper .swiper-button-next,
.hero-swiper .swiper-button-prev {
    color:#fff; width:48px; height:48px;
    background:rgba(255,255,255,.12);
    backdrop-filter:blur(8px);
    border-radius:50%; border:1px solid rgba(255,255,255,.18);
    transition:var(--transition);
}
.hero-swiper .swiper-button-next:hover,
.hero-swiper .swiper-button-prev:hover { background:rgba(255,255,255,.25); }
.hero-swiper .swiper-button-next::after,
.hero-swiper .swiper-button-prev::after { font-size:1rem; font-weight:900; }

/* Scroll indicator */
.scroll-indicator {
    position:absolute; bottom:28px; right:28px; z-index:4;
    display:flex; flex-direction:column; align-items:center; gap:6px;
    color:rgba(255,255,255,.55); font-size:.72rem; font-weight:600;
    letter-spacing:.8px; text-transform:uppercase;
}
.scroll-indicator .scroll-line {
    width:1.5px; height:36px;
    background:linear-gradient(to bottom,rgba(255,255,255,.6),transparent);
    animation:scrollDrop 1.8s ease-in-out infinite;
}
@keyframes scrollDrop {
    0%   { transform:scaleY(0); transform-origin:top; }
    50%  { transform:scaleY(1); transform-origin:top; }
    51%  { transform:scaleY(1); transform-origin:bottom; }
    100% { transform:scaleY(0); transform-origin:bottom; }
}

/* ── Stats Section ─────────────────────────────────────── */
.stats-section {
    background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);
    padding:72px 0;
    position:relative; overflow:hidden;
}
/* Dekoratif arka plan deseni */
.stats-section::before {
    content:'';
    position:absolute; inset:0;
    background-image:radial-gradient(circle at 20% 50%, rgba(255,255,255,.04) 1px, transparent 1px),
                      radial-gradient(circle at 80% 50%, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size:40px 40px;
}
/* Alt wave şekli */
.stats-section::after {
    content:'';
    position:absolute; bottom:-2px; left:0; width:100%;
    height:50px;
    background:inherit;
    clip-path:ellipse(55% 100% at 50% 100%);
    background:#fff;
    z-index:1;
}

.stat-card {
    text-align:center; padding:22px 16px;
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
    border-radius:var(--radius);
    backdrop-filter:blur(10px);
    transition:var(--transition);
}
.stat-card:hover {
    background:rgba(255,255,255,.14);
    transform:translateY(-6px);
    box-shadow:0 12px 32px rgba(0,0,0,.2);
}
.stat-icon {
    width:56px; height:56px;
    background:rgba(255,255,255,.12);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:1.5rem; color:var(--gold-light);
    margin:0 auto 14px;
    border:1px solid rgba(255,255,255,.15);
}
.stat-number {
    font-family:'Poppins',sans-serif;
    font-size:clamp(2rem,4vw,3rem);
    font-weight:900; color:#fff; line-height:1;
    display:block;
    text-shadow:0 0 30px rgba(255,255,255,.2);
}
.stat-plus { color:var(--gold-light); }
.stat-label { color:rgba(255,255,255,.68); font-size:.85rem; font-weight:600; margin-top:8px; letter-spacing:.3px; }

/* ── Section Common ────────────────────────────────────── */
.section-pad    { padding:96px 0; }
.section-pad-sm { padding:64px 0; }
.bg-light-green { background:var(--light) !important; }

/* Section label badge */
.section-badge {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(26,107,60,.1);
    border:1px solid rgba(26,107,60,.22);
    color:var(--primary);
    padding:6px 18px; border-radius:50px;
    font-size:.78rem; font-weight:700;
    letter-spacing:.8px; text-transform:uppercase;
    margin-bottom:18px;
}

/* ── Donation Cards ────────────────────────────────────── */
.donation-card {
    border:none; border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-card);
    transition:var(--transition);
    background:#fff;
    height:100%;
    border:1px solid rgba(0,0,0,.04);
}
.donation-card:hover {
    transform:translateY(-12px);
    box-shadow:0 24px 56px rgba(26,107,60,.18);
    border-color:transparent;
}

.donation-card-img {
    position:relative; height:220px; overflow:hidden;
}
.donation-card-img img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.donation-card:hover .donation-card-img img { transform:scale(1.1); }

/* Görsel üstü gradient */
.donation-card-img::after {
    content:'';
    position:absolute; inset:0;
    background:linear-gradient(to top, rgba(0,0,0,.4) 0%, transparent 60%);
    opacity:0; transition:var(--transition);
}
.donation-card:hover .donation-card-img::after { opacity:1; }

.donation-card-img-placeholder {
    width:100%; height:100%;
    display:flex; align-items:center; justify-content:center;
    font-size:3.2rem; color:rgba(255,255,255,.9);
}

/* Featured badge */
.donation-featured-badge {
    position:absolute; top:14px; left:14px; z-index:2;
    background:var(--gold); color:var(--dark-2);
    font-size:.68rem; font-weight:800; padding:4px 12px;
    border-radius:50px; letter-spacing:.6px; text-transform:uppercase;
    box-shadow:0 3px 10px rgba(0,0,0,.2);
}

.donation-card-body { padding:24px; }
.donation-cat-name { font-size:1.05rem; font-weight:800; color:var(--dark-2); margin-bottom:8px; }
.donation-cat-desc { color:var(--gray); font-size:.87rem; margin-bottom:18px; line-height:1.6; }

.progress-wrap   { margin-bottom:16px; }
.progress-info   { display:flex; justify-content:space-between; font-size:.8rem; margin-bottom:7px; }
.progress-info .raised { color:var(--primary); font-weight:800; }
.progress-info .target { color:var(--gray); }
.progress {
    height:9px; border-radius:50px;
    background:rgba(26,107,60,.1);
    overflow:hidden;
}
.progress-bar {
    background:linear-gradient(90deg,var(--primary),var(--primary-light));
    border-radius:50px;
    transition:width 1.8s cubic-bezier(.4,0,.2,1);
    position:relative;
}
/* Parlayan uç efekti */
.progress-bar::after {
    content:'';
    position:absolute; right:0; top:50%;
    transform:translate(50%,-50%);
    width:14px; height:14px; border-radius:50%;
    background:var(--primary-light);
    box-shadow:0 0 8px var(--primary-glow);
    opacity:0; transition:opacity .5s .5s;
}
.progress-bar[style*="width"]:not([style*="width: 0"])::after { opacity:1; }

.btn-donate-card {
    background:linear-gradient(135deg,var(--primary),var(--primary-light));
    color:#fff; border:none;
    border-radius:50px; padding:10px 22px;
    font-size:.87rem; font-weight:700; width:100%;
    transition:var(--transition);
    display:flex; align-items:center; justify-content:center; gap:7px;
    box-shadow:0 4px 12px var(--primary-glow);
}
.btn-donate-card:hover {
    color:#fff; box-shadow:0 8px 24px var(--primary-glow);
    transform:translateY(-2px);
}

/* Card gradyan arka planlar */
.cat-grad-1{background:linear-gradient(135deg,#1a6b3c,#25a05a)}
.cat-grad-2{background:linear-gradient(135deg,#1565c0,#1e88e5)}
.cat-grad-3{background:linear-gradient(135deg,#6a1b9a,#ab47bc)}
.cat-grad-4{background:linear-gradient(135deg,#bf360c,#ef6c00)}
.cat-grad-5{background:linear-gradient(135deg,#00695c,#26a69a)}

/* ── Activity Cards ────────────────────────────────────── */
.activity-card {
    border:none; border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-card);
    transition:var(--transition);
    background:#fff; height:100%;
    border:1px solid rgba(0,0,0,.04);
}
.activity-card:hover {
    transform:translateY(-10px);
    box-shadow:0 20px 48px rgba(0,0,0,.14);
    border-color:transparent;
}
.activity-card-img { position:relative; height:210px; overflow:hidden; }
.activity-card-img img {
    width:100%; height:100%; object-fit:cover;
    transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.activity-card:hover .activity-card-img img { transform:scale(1.1); }

/* İmge overlay */
.activity-card-img::before {
    content:'';
    position:absolute; inset:0; z-index:1;
    background:linear-gradient(to top, rgba(0,0,0,.45) 0%, transparent 60%);
}
.activity-cat-badge {
    position:absolute; top:14px; left:14px; z-index:2;
    background:var(--primary);
    color:#fff; font-size:.7rem; font-weight:700;
    padding:4px 12px; border-radius:50px;
    box-shadow:0 3px 10px rgba(0,0,0,.2);
}
.activity-card-body { padding:22px; }
.activity-date {
    color:var(--gray); font-size:.8rem; margin-bottom:9px;
    display:flex; align-items:center; gap:5px;
}
.activity-title {
    font-size:.98rem; font-weight:800; color:var(--dark-2);
    margin-bottom:9px; line-height:1.4;
}
.activity-excerpt { color:var(--gray); font-size:.86rem; margin-bottom:15px; }
.activity-link {
    color:var(--primary); font-size:.86rem; font-weight:700;
    display:inline-flex; align-items:center; gap:5px;
}
.activity-link i { transition:transform .3s; }
.activity-link:hover { color:var(--primary-dark); }
.activity-link:hover i { transform:translateX(4px); }

/* ── About Section ─────────────────────────────────────── */
.about-img-wrap { position:relative; }
.about-img-main {
    border-radius:var(--radius);
    box-shadow:var(--shadow-lg);
    width:100%; height:460px; object-fit:cover;
}
/* Dekoratif border frame */
.about-img-frame {
    position:absolute; top:-16px; left:-16px; right:16px; bottom:16px;
    border:3px solid rgba(26,107,60,.2);
    border-radius:var(--radius);
    z-index:-1;
}
.about-badge-card {
    position:absolute; bottom:-24px; right:-24px;
    background:linear-gradient(135deg,var(--gold),var(--gold-light));
    color:var(--dark-2); border-radius:var(--radius);
    padding:22px 28px; box-shadow:var(--shadow-lg); text-align:center;
}
.about-badge-num  { font-size:2.6rem; font-weight:900; font-family:'Poppins',sans-serif; line-height:1; }
.about-badge-text { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.5px; }

.feature-item { display:flex; gap:16px; margin-bottom:20px; }
.feature-icon {
    flex-shrink:0; width:48px; height:48px;
    background:rgba(26,107,60,.1);
    color:var(--primary); border-radius:var(--radius-sm);
    display:flex; align-items:center; justify-content:center;
    font-size:1.25rem; transition:var(--transition);
}
.feature-item:hover .feature-icon { background:var(--primary); color:#fff; transform:scale(1.1); }
.feature-text h6 { font-size:.95rem; font-weight:700; color:var(--dark-2); margin-bottom:2px; }
.feature-text p  { font-size:.85rem; color:var(--gray); margin:0; }

/* ── CTA Section ───────────────────────────────────────── */
.cta-section {
    background:linear-gradient(135deg,var(--dark) 0%,var(--primary-dark) 50%,var(--dark) 100%);
    padding:110px 0;
    position:relative; overflow:hidden; text-align:center;
}
.cta-section::before {
    content:'';
    position:absolute; inset:0;
    background:radial-gradient(ellipse 80% 60% at 50% 50%, rgba(26,107,60,.28) 0%, transparent 70%);
}
/* Dekoratif çizgiler */
.cta-section::after {
    content:'';
    position:absolute; inset:0;
    background-image:linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
                      linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size:60px 60px;
}
.cta-section > .container { position:relative; z-index:2; }
.cta-section h2 { color:#fff; font-size:clamp(1.8rem,4vw,3rem); font-weight:900; }
.cta-section h2 span { color:var(--gold-light); }
.cta-section p  { color:rgba(255,255,255,.72); font-size:1.1rem; }

/* Pulse ring animation */
@keyframes pulseRing {
    0%   { transform:scale(1); opacity:.8; }
    100% { transform:scale(1.35); opacity:0; }
}
.pulse-wrap { position:relative; display:inline-flex; }
.pulse-wrap::before, .pulse-wrap::after {
    content:''; position:absolute; inset:0;
    border-radius:50px;
    background:var(--gold);
    animation:pulseRing 2.4s cubic-bezier(.4,0,.6,1) infinite;
}
.pulse-wrap::after { animation-delay:.8s; }

/* ── Footer ────────────────────────────────────────────── */
.site-footer { background:var(--dark); color:rgba(255,255,255,.75); }
.footer-top  { padding:72px 0 44px; }
.footer-brand {
    display:flex; align-items:center; gap:12px;
    color:#fff; font-family:'Poppins',sans-serif; font-size:1.05rem; font-weight:800;
}
.footer-desc { font-size:.87rem; color:rgba(255,255,255,.55); line-height:1.75; }

.social-links { display:flex; gap:10px; }
.social-links a {
    width:40px; height:40px;
    background:rgba(255,255,255,.07);
    border:1px solid rgba(255,255,255,.1);
    color:rgba(255,255,255,.7);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:.95rem; transition:var(--transition);
}
.social-links a:hover { background:var(--primary); color:#fff; border-color:var(--primary); transform:translateY(-3px); }

.footer-heading {
    color:#fff; font-family:'Poppins',sans-serif;
    font-size:.88rem; font-weight:700; margin-bottom:20px;
    position:relative; padding-bottom:10px;
}
.footer-heading::after {
    content:''; position:absolute; bottom:0; left:0;
    width:28px; height:2px;
    background:linear-gradient(90deg,var(--primary),var(--gold));
    border-radius:1px;
}

.footer-links   { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:10px; }
.footer-links a {
    color:rgba(255,255,255,.55); font-size:.87rem;
    transition:var(--transition);
    display:inline-flex; align-items:center; gap:6px;
}
.footer-links a::before { content:'›'; color:var(--gold); opacity:0; transition:var(--transition); }
.footer-links a:hover { color:var(--gold-light); padding-left:8px; }
.footer-links a:hover::before { opacity:1; }

.footer-contact { list-style:none; padding:0; margin:0; }
.footer-contact li {
    display:flex; align-items:flex-start; gap:12px;
    margin-bottom:14px; font-size:.87rem; color:rgba(255,255,255,.6);
}
.footer-contact i  { color:var(--gold-light); margin-top:3px; flex-shrink:0; }
.footer-contact a  { color:rgba(255,255,255,.6); }
.footer-contact a:hover { color:var(--gold-light); }

.footer-bottom {
    border-top:1px solid rgba(255,255,255,.07);
    padding:22px 0; font-size:.82rem; color:rgba(255,255,255,.35);
}
.footer-admin-link { color:rgba(255,255,255,.25); font-size:.76rem; }
.footer-admin-link:hover { color:var(--gold-light); }

/* ── Inner Pages Hero ──────────────────────────────────── */
.page-hero {
    background:linear-gradient(135deg,var(--primary-dark),var(--primary));
    padding:136px 0 72px; text-align:center; color:#fff;
    position:relative; overflow:hidden;
}
.page-hero::before {
    content:'';
    position:absolute; inset:0;
    background:radial-gradient(ellipse 60% 80% at 30% 50%, rgba(255,255,255,.05) 0%, transparent 60%);
}
.page-hero h1 { font-size:clamp(1.8rem,4vw,2.9rem); position:relative; z-index:1; }
.breadcrumb-item, .breadcrumb-item a { color:rgba(255,255,255,.65); font-size:.87rem; }
.breadcrumb-item.active { color:var(--gold-light); }
.breadcrumb-item + .breadcrumb-item::before { color:rgba(255,255,255,.35); }

/* ── Forms ─────────────────────────────────────────────── */
.contact-card {
    background:#fff; border-radius:var(--radius);
    box-shadow:var(--shadow); padding:38px;
    border:1px solid rgba(0,0,0,.04);
}
.form-control, .form-select {
    border:2px solid #e5e7eb; border-radius:var(--radius-sm);
    padding:12px 16px; font-family:'Nunito',sans-serif;
    transition:var(--transition); font-size:.93rem;
    background:#fafafa;
}
.form-control:focus, .form-select:focus {
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(26,107,60,.1);
    background:#fff;
}
.form-label { font-weight:700; font-size:.85rem; color:var(--dark-2); margin-bottom:6px; }

.contact-info-card {
    background:linear-gradient(135deg,var(--primary-dark),var(--primary));
    color:#fff; border-radius:var(--radius);
    padding:36px; height:100%;
    position:relative; overflow:hidden;
}
.contact-info-card::before {
    content:'';
    position:absolute; top:-40%; right:-20%;
    width:240px; height:240px;
    background:rgba(255,255,255,.05);
    border-radius:50%;
}
.contact-info-item { display:flex; gap:16px; margin-bottom:28px; }
.contact-info-icon {
    flex-shrink:0; width:50px; height:50px;
    background:rgba(255,255,255,.12);
    border-radius:var(--radius-sm);
    display:flex; align-items:center; justify-content:center;
    font-size:1.25rem;
    border:1px solid rgba(255,255,255,.15);
}

/* ── Donation Page ─────────────────────────────────────── */
.donation-form-section { background:var(--light); }
.donation-amount-btns  { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:16px; }
.amount-btn {
    border:2px solid var(--primary); color:var(--primary);
    background:transparent; border-radius:50px;
    padding:9px 24px; font-weight:700; font-size:.9rem;
    cursor:pointer; transition:var(--transition);
    font-family:'Poppins',sans-serif;
}
.amount-btn:hover, .amount-btn.active { background:var(--primary); color:#fff; box-shadow:0 4px 14px var(--primary-glow); }

/* ── Activity Detail ───────────────────────────────────── */
.activity-detail-img {
    width:100%; max-height:500px;
    object-fit:cover; border-radius:var(--radius);
    box-shadow:var(--shadow-lg);
}
.activity-content { line-height:1.9; font-size:1rem; }
.activity-content h2,
.activity-content h3 { color:var(--dark-2); margin-top:32px; font-size:1.3rem; }

/* ── Alerts ────────────────────────────────────────────── */
.alert-success-custom {
    background:#d1fae5; color:#065f46;
    border:1px solid #a7f3d0; border-radius:var(--radius-sm); padding:14px 18px;
}
.alert-danger-custom {
    background:#fee2e2; color:#991b1b;
    border:1px solid #fca5a5; border-radius:var(--radius-sm); padding:14px 18px;
}
.flash-msg { animation:slideDown .4s ease; }
@keyframes slideDown {
    from { opacity:0; transform:translateY(-12px); }
    to   { opacity:1; transform:translateY(0); }
}

/* ── Responsive ────────────────────────────────────────── */
@media(max-width:991px){
    .navbar-collapse {
        background:rgba(10,38,20,.97);
        backdrop-filter:blur(12px);
        border-radius:var(--radius); padding:16px;
        margin-top:12px; border:1px solid rgba(255,255,255,.08);
    }
    .hero-content    { text-align:center; }
    .hero-subtitle   { margin:0 auto 36px; }
    .hero-buttons    { justify-content:center; }
    .about-badge-card{ position:static; display:inline-block; margin:24px auto 0; }
    .about-img-wrap  { margin-bottom:60px; }
    .about-img-frame { display:none; }
    .scroll-indicator{ display:none; }
}
@media(max-width:576px){
    .section-pad { padding:64px 0; }
    .stats-section  { padding:52px 0; }
    .hero-swiper    { height:100svh; }
    .contact-card   { padding:24px; }
    .cta-section    { padding:80px 0; }
}

/* ── Scrollbar ─────────────────────────────────────────── */
::-webkit-scrollbar       { width:5px; }
::-webkit-scrollbar-track { background:#f1f1f1; }
::-webkit-scrollbar-thumb { background:var(--primary); border-radius:3px; }

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