/* ============================================
   BADGES-GALLERY.CSS – Badges, Gallery, Social, Links, Join, Footer
   ============================================ */

/* ── JCI FOUNDATION BADGES ── */
.badges-section{background:linear-gradient(135deg,var(--dark),#051a4a);padding:64px 40px;width:100%}
.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:20px;width:100%}
.badge-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,215,0,.18);
  border-radius:var(--radius);padding:26px 16px;text-align:center;
  position:relative;overflow:hidden;
  transition:all .4s cubic-bezier(.175,.885,.32,1.275);cursor:pointer;
}
.badge-card::after{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.08),transparent);transform:skewX(-15deg);transition:.6s}
.badge-card:hover{background:rgba(255,215,0,.1);transform:translateY(-8px) scale(1.04);border-color:var(--gold);box-shadow:0 16px 40px rgba(255,215,0,.18)}
.badge-card:hover::after{left:150%}
.badge-icon{font-size:44px;margin-bottom:12px;filter:drop-shadow(0 4px 8px rgba(255,215,0,.3));transition:.4s}
.badge-card:hover .badge-icon{transform:scale(1.15) rotate(5deg)}
.badge-name{color:var(--gold);font-weight:700;font-size:13px;margin-bottom:4px}
.badge-desc{color:rgba(255,255,255,.6);font-size:11px;line-height:1.5}

/* ── GALLERY ── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;width:100%}
.gal-item{border-radius:var(--radius);overflow:hidden;cursor:pointer;background:linear-gradient(135deg,var(--blue),#1a5276);height:210px;display:flex;align-items:center;justify-content:center;font-size:48px;transition:all .4s cubic-bezier(.175,.885,.32,1.275);position:relative}
.gal-item:hover{transform:translateY(-6px) scale(1.03);box-shadow:0 16px 40px rgba(0,56,147,.3)}
.gal-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,56,147,.7),rgba(255,215,0,.2));opacity:0;transition:.3s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.gal-item:hover .gal-overlay{opacity:1}
.gal-overlay span{color:#fff;font-size:13px;font-weight:600}

/* ── SOCIAL ACTIVITIES ── */
.social-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;width:100%}
.social-card{background:#fff;box-shadow:var(--shadow)}
.social-card:hover{box-shadow:var(--shadow-hover)}
.social-img{height:160px;background:linear-gradient(135deg,var(--blue),#1a5276);display:flex;align-items:center;justify-content:center;font-size:52px;position:relative;overflow:hidden}
.social-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,215,0,.1),transparent)}
.social-body{padding:20px}
.social-title{font-weight:700;font-size:15px;color:var(--blue);margin-bottom:6px}
.social-desc{color:var(--gray);font-size:13px;line-height:1.65}
.social-impact{margin-top:12px;display:flex;gap:20px}
.impact-num{font-size:20px;font-weight:800;color:var(--blue)}
.impact-lbl{font-size:11px;color:var(--gray)}

/* ── ZONE & LO LINKS ── */
.links-section{background:var(--light);padding:64px 40px;width:100%}
.links-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;width:100%}
.links-box{background:#fff;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);transition:.3s}
.links-box:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}
.links-box-title{font-size:17px;font-weight:800;color:var(--blue);margin-bottom:16px;padding-bottom:12px;border-bottom:3px solid var(--gold);display:flex;align-items:center;gap:8px}
.link-item{display:flex;align-items:center;justify-content:space-between;padding:10px;border-radius:8px;transition:.2s;margin-bottom:2px}
.link-item:hover{background:var(--light)}
.link-name{font-size:14px;font-weight:600;color:#444;transition:.2s}
.link-item:hover .link-name{color:var(--blue)}
.link-arrow{color:var(--gold);font-size:18px;font-weight:700}

/* ── JOIN CTA ── */
.join-section{background:linear-gradient(135deg,var(--dark),#003893);padding:72px 40px;text-align:center;width:100%;position:relative;overflow:hidden}
.join-section::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23FFD700' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E")}
.join-title{font-size:36px;font-weight:900;color:#fff;margin-bottom:14px;position:relative;z-index:1}
.join-title span{color:var(--gold)}
.join-sub{color:rgba(255,255,255,.78);font-size:16px;margin-bottom:32px;max-width:560px;margin-left:auto;margin-right:auto;position:relative;z-index:1}
.join-btns{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--blue);padding:14px 34px;border-radius:8px;font-weight:800;font-size:15px;transition:all .25s;display:inline-block;box-shadow:0 6px 20px rgba(255,215,0,.3)}
.btn-gold:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 12px 30px rgba(255,215,0,.45)}
.btn-outline{border:2px solid var(--gold);color:var(--gold);padding:12px 32px;border-radius:8px;font-weight:700;font-size:15px;transition:all .25s;display:inline-block}
.btn-outline:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--blue);transform:translateY(-3px)}

/* ── FOOTER ── */
footer{background:var(--dark);padding:50px 40px 20px;color:rgba(255,255,255,.72);width:100%}
.footer-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px}
.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-logo-icon{width:44px;height:44px;background:linear-gradient(135deg,var(--gold),var(--gold2));border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--blue);font-size:14px;flex-shrink:0}
.footer-logo-text{color:#fff;font-weight:700;font-size:15px}
.footer-logo-text span{color:var(--gold);font-size:11px;display:block}
.footer-desc{font-size:13px;line-height:1.75;margin-bottom:16px}
.footer-social{display:flex;gap:10px}
.soc-btn{width:36px;height:36px;border-radius:8px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:14px;transition:.25s;color:#fff;border:1px solid rgba(255,255,255,.08)}
.soc-btn:hover{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--blue);transform:translateY(-2px)}
.footer-heading{color:#fff;font-weight:700;font-size:13px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,215,0,.2)}
.footer-links{list-style:none}
.footer-links li{margin-bottom:8px}
.footer-links a{font-size:13px;transition:.2s;color:rgba(255,255,255,.6)}
.footer-links a:hover{color:var(--gold)}
.footer-contact p{font-size:13px;margin-bottom:8px;display:flex;align-items:flex-start;gap:8px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:18px;text-align:center;font-size:12px}
.footer-bottom span{color:var(--gold)}

/* ── RESPONSIVE ── */
@media(max-width:860px){
  .badges-section,.links-section,.join-section,footer{padding-left:20px;padding-right:20px}
  .links-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr}
  .join-title{font-size:24px}
}