﻿/* ═══════════════════════════════════════════════════════════════════
   Indraprastha Jump Rope Association — Main Stylesheet
   Sports / Athletic Theme  |  Bootstrap 5 companion
═══════════════════════════════════════════════════════════════════ */
:root {
  --primary:        #1a3fa5;
  --primary-light:  #2563eb;
  --primary-dark:   #0f2878;
  --secondary:      #ea580c;
  --secondary-light:#fb923c;
  --accent:         #dc2626;
  --gold:           #f59e0b;
  --dark:           #0f172a;
  --dark-mid:       #1e293b;
  --light-bg:       #f1f5f9;
  --surface:        #ffffff;
  --text:           #1e293b;
  --text-muted:     #64748b;
  --border:         #e2e8f0;
  --font:           'Poppins', sans-serif;
  --font-display:   'Oswald', sans-serif;
  --transition:     .25s ease;
  --transition-slow:.45s cubic-bezier(.4,0,.2,1);
  --shadow-sm:      0 2px 8px rgba(0,0,0,.08);
  --shadow-md:      0 6px 24px rgba(0,0,0,.12);
  --shadow-lg:      0 12px 40px rgba(0,0,0,.16);
  --shadow-xl:      0 24px 64px rgba(0,0,0,.22);
  --shadow-glow:    0 0 32px rgba(26,63,165,.35);
  --radius-sm:      .5rem;
  --radius-md:      .875rem;
  --radius-lg:      1.25rem;
  --radius-xl:      2rem;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;margin:0;padding:0}
body{font-family:var(--font);background:var(--light-bg);color:var(--text);line-height:1.65;margin:0;padding:0}
a{color:var(--primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--primary-light)}
img{max-width:100%}
/* Bootstrap overrides */
.text-primary{color:var(--primary)!important}
.bg-primary{background-color:var(--primary)!important}
.btn-primary{background-color:var(--primary);border-color:var(--primary);font-weight:600}
.btn-primary:hover,.btn-primary:focus{background-color:var(--primary-light);border-color:var(--primary-light)}
.border-primary{border-color:var(--primary)!important}
.text-secondary{color:var(--secondary)!important}
.btn-warning{background-color:var(--gold);border-color:var(--gold);color:var(--dark);font-weight:700}
.btn-warning:hover{background-color:#d97706;border-color:#d97706;color:var(--dark)}
.btn-outline-primary{color:var(--primary);border-color:var(--primary);font-weight:600}
.btn-outline-primary:hover{background-color:var(--primary);border-color:var(--primary)}
/* ── Navbar ─────────────────────────────────────────────────────── */
.navbar.sports-nav{
  background:rgba(254,249,199,.94)!important;
  box-shadow:0 2px 28px rgba(120,53,15,.10);
  padding:.5rem 0;
  backdrop-filter:blur(22px) saturate(1.6);
  -webkit-backdrop-filter:blur(22px) saturate(1.6);
  border-bottom:1px solid rgba(180,83,9,.13);
  transition:background .35s,box-shadow .35s;
  margin-top:0!important;
}
.navbar.sports-nav::after{
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,#d97706 30%,#f59e0b 60%,transparent);
  opacity:.7;
  pointer-events:none;
}
.navbar.sports-nav.scrolled{
  background:rgba(255,252,235,.98)!important;
  box-shadow:0 4px 36px rgba(120,53,15,.14);
}
.navbar.sports-nav .navbar-brand{font-family:var(--font-display);font-size:1.15rem;letter-spacing:.02em;color:#44350a!important;font-weight:600}
/* Logo wrap + spinning halo */
.nav-logo-wrap{
  position:relative;width:64px;height:64px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.nav-logo-wrap::before{
  content:'';
  position:absolute;inset:-3px;
  border-radius:50%;
  background:conic-gradient(#d97706 0%,#fde68a 25%,#b45309 50%,#fbbf24 75%,#d97706 100%);
  animation:logoSpin 8s linear infinite;
  opacity:.8;
}
.nav-logo-wrap::after{
  content:'';
  position:absolute;inset:2px;
  border-radius:50%;
  background:#fff;
}
@keyframes logoSpin{to{transform:rotate(360deg)}}
/* Logo ring */
.nav-logo-ring{
  width:56px;height:56px;border-radius:50%;flex-shrink:0;
  background:#fff;
  display:flex;align-items:center;justify-content:center;
  position:relative;z-index:1;overflow:hidden;
}
.nav-logo-ring::before{content:none}
.nav-logo-ring img{
  width:52px;height:52px;object-fit:contain;object-position:center;
  display:block;position:relative;z-index:1;
}
.navbar-brand:hover .nav-logo-wrap::before{animation-duration:2.5s;opacity:1}
/* Brand name */
.nav-brand-name{font-family:'Oswald',sans-serif;font-size:1.08rem;font-weight:800;letter-spacing:.04em;line-height:1;color:#44350a}
.nav-brand-i{color:#b45309}
.nav-brand-a{color:#d97706}
.nav-brand-sub{font-size:.58rem;letter-spacing:.07em;text-transform:uppercase;color:#92400e;margin-top:2px;font-weight:500;opacity:.75}
.navbar.sports-nav .nav-link{
  color:#44350a!important;
  font-weight:500;
  font-size:.87rem;
  position:relative;
  padding:.5rem .75rem!important;
  letter-spacing:.02em;
  transition:color .2s;
}
.navbar.sports-nav .nav-link::after{
  content:'';
  position:absolute;
  bottom:2px;left:50%;right:50%;
  height:2px;
  background:linear-gradient(90deg,#b45309,#d97706);
  border-radius:2px;
  transition:left .25s,right .25s;
}
.navbar.sports-nav .nav-link:hover,
.navbar.sports-nav .nav-link.active{color:#b45309!important}
.navbar.sports-nav .nav-link:hover::after,
.navbar.sports-nav .nav-link.active::after{left:.75rem;right:.75rem}
/* hide underline on dropdown toggles */
.navbar.sports-nav .nav-link.dropdown-toggle::after{display:none!important}
.navbar.sports-nav .dropdown-toggle.nav-link::before{content:none}

/* Dropdown menu — cream glassy card */
.navbar.sports-nav .dropdown-menu{
  border:1px solid rgba(180,83,9,.13);
  background:rgba(255,252,235,.98);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  box-shadow:0 16px 48px rgba(120,53,15,.16),0 2px 12px rgba(180,83,9,.08);
  border-radius:1rem;
  margin-top:.6rem!important;
  padding:.6rem .4rem;
  min-width:220px;
  animation:dropFadeIn .2s ease;
}
@keyframes dropFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Dropdown items */
.navbar.sports-nav .dropdown-item{
  color:#44350a;
  font-size:.83rem;
  font-weight:500;
  border-radius:.6rem;
  padding:.52rem .9rem;
  margin:.05rem 0;
  transition:background .18s,color .18s,padding-left .18s;
}
.navbar.sports-nav .dropdown-item:hover,
.navbar.sports-nav .dropdown-item:focus{
  background:rgba(217,119,6,.1);
  color:#92400e;
  padding-left:1.2rem;
}
.navbar.sports-nav .dropdown-item i{opacity:.7;transition:opacity .18s}
.navbar.sports-nav .dropdown-item:hover i{opacity:1}

/* Dropdown headers */
.navbar.sports-nav .dropdown-header{
  color:#b45309;
  font-size:.67rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:.55rem .9rem .25rem;
}
/* Dividers */
.navbar.sports-nav .dropdown-divider{border-color:rgba(180,83,9,.12);margin:.3rem .6rem}

/* ── Mega-menu (Explore dropdown) ── */
.nav-megamenu{
  min-width:680px;
  max-width:min(760px, calc(100vw - 1rem));
  padding:.8rem .6rem!important;
  display:none;
  flex-direction:row;
  flex-wrap:nowrap;
  gap:0;
}
.nav-megamenu.show{display:flex!important;animation:dropFadeIn .2s ease}
@media(min-width:992px){
  .nav-megamenu{
    right:0!important;
    left:auto!important;
    transform:none!important;
  }
}
.nav-mega-col{
  flex:1;
  min-width:0;
  list-style:none;
  padding:0 .4rem;
  margin:0;
}
.nav-mega-col + .nav-mega-col{
  border-left:1px solid rgba(180,83,9,.12);
}
.nav-mega-head{
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:#b45309;
  padding:.3rem .9rem .45rem;
  display:flex;align-items:center;gap:.3rem;
  white-space:nowrap;
}
.nav-megamenu .dropdown-item{display:flex;align-items:center;white-space:nowrap}
@media(max-width:991.9px){
  .nav-megamenu{
    min-width:0!important;
    width:100%;
    flex-direction:column;
  }
  .nav-mega-col + .nav-mega-col{
    border-left:none;
    border-top:1px solid rgba(180,83,9,.12);
    padding-top:.5rem;
    margin-top:.3rem;
  }
}

.navbar-brand img{height:38px}
/* Hero */
.sports-hero{min-height:92vh;position:relative;display:flex;align-items:center;overflow:hidden;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 45%,#1e40af 75%,#1e3a8a 100%)}
.sports-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 75% 40%,rgba(234,88,12,.2) 0%,transparent 60%),radial-gradient(ellipse 50% 80% at 10% 80%,rgba(255,255,255,.04) 0%,transparent 60%)}
.sports-hero::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:120px;background:var(--light-bg);clip-path:polygon(0 55%,100% 0%,100% 100%,0 100%)}
.hero-badge-pill{display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);color:#fff;padding:.35rem 1.1rem;border-radius:50px;font-size:.8rem;font-weight:600;letter-spacing:.05em;backdrop-filter:blur(6px);text-transform:uppercase}
.hero-badge-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--secondary-light);flex-shrink:0;display:inline-block}
.sports-hero h1{font-family:'Oswald',sans-serif;font-size:clamp(2.2rem,5.5vw,4rem);font-weight:700;line-height:1.08;text-transform:uppercase;letter-spacing:.02em}
.sports-hero h1 .highlight-text{color:var(--secondary-light)}
.sports-hero .hero-sub-text{font-size:clamp(.9rem,2vw,1.1rem);color:rgba(255,255,255,.75);max-width:540px;line-height:1.7}
.hero-stat-pill{display:inline-flex;flex-direction:column;align-items:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-md);padding:.8rem 1.2rem;backdrop-filter:blur(8px);min-width:90px}
.hero-stat-pill .num{font-family:'Oswald',sans-serif;font-size:1.7rem;font-weight:700;color:#fff;line-height:1}
.hero-stat-pill .lbl{font-size:.7rem;color:rgba(255,255,255,.7);text-transform:uppercase;letter-spacing:.07em;margin-top:2px}
/* Hero visual panel */
.hero-visual-panel{position:relative;width:320px;height:320px;flex-shrink:0}
.hero-logo-ring{position:absolute;inset:30px;border-radius:50%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px)}
.hero-main-logo{width:150px;height:150px;object-fit:contain;filter:drop-shadow(0 6px 24px rgba(255,255,255,.25))}
/* Orbit rings — purely decorative, static */
.hero-orbit-ring{position:absolute;border-radius:50%;pointer-events:none}
.hero-orbit-1{inset:-10px;border:2px dashed rgba(251,146,60,.55);animation:orbitCW 18s linear infinite;box-shadow:0 0 12px rgba(251,146,60,.15)}
.hero-orbit-2{inset:-40px;border:1.5px dashed rgba(96,165,250,.45);animation:orbitCCW 28s linear infinite;box-shadow:0 0 18px rgba(96,165,250,.1)}
/* Orbit arm: zero-size div pinned to panel centre, rotates around it */
.orbit-arm{position:absolute;top:50%;left:50%;width:0;height:0;transform-origin:0 0}
/* Badge base — sits at tip of arm */
.hero-float-badge{
  position:absolute;border-radius:50%;
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2px;
  font-size:.5rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;line-height:1.1;text-align:center;
  padding:6px;
  border:1.5px solid rgba(255,255,255,.38);
  backdrop-filter:blur(6px);
}
.hero-float-badge i{font-size:1rem;line-height:1;display:block}
.hero-float-badge span{display:block;margin-top:1px}
/* National — middle ring (R=170), CW 16s */
.orbit-arm-national{animation:orbitCW 16s linear infinite;animation-delay:-2s}
.orbit-arm-national .hero-float-badge{
  top:-206px;left:-33px;width:66px;height:66px;
  background:linear-gradient(135deg,#f59e0b,#ea580c);
  color:#fff;
  box-shadow:0 0 0 3px rgba(245,158,11,.25),0 6px 24px rgba(245,158,11,.6);
  animation:counterCW 16s linear infinite;animation-delay:-2s;
}
/* Team — middle ring (R=170), CW 22s */
.orbit-arm-team{animation:orbitCW 22s linear infinite;animation-delay:-13.7s}
.orbit-arm-team .hero-float-badge{
  top:-200px;left:-30px;width:60px;height:60px;
  background:linear-gradient(135deg,#ef4444,#9f1239);
  color:#fff;
  box-shadow:0 0 0 3px rgba(239,68,68,.25),0 6px 22px rgba(239,68,68,.55);
  animation:counterCW 22s linear infinite;animation-delay:-13.7s;
}
/* Intl — inner ring (R=120), CCW 14s */
.orbit-arm-intl{animation:orbitCCW 14s linear infinite;animation-delay:-7.8s}
.orbit-arm-intl .hero-float-badge{
  top:-150px;left:-30px;width:60px;height:60px;
  background:linear-gradient(135deg,#3b82f6,#1e40af);
  color:#fff;
  box-shadow:0 0 0 3px rgba(59,130,246,.25),0 6px 22px rgba(59,130,246,.55);
  animation:counterCCW 14s linear infinite;animation-delay:-7.8s;
}
/* Support — orange ring (R=170), CW 11s */
.orbit-arm-support{animation:orbitCW 11s linear infinite;animation-delay:-4s}
.orbit-arm-support .hero-float-badge{
  top:-200px;left:-30px;width:60px;height:60px;
  background:linear-gradient(135deg,#eab308,#d97706);
  color:#fff;
  box-shadow:0 0 0 3px rgba(234,179,8,.28),0 6px 22px rgba(234,179,8,.6);
  animation:counterCW 11s linear infinite;animation-delay:-4s;
}
/* Medal — outermost ring (R=200), CCW 19s */
.orbit-arm-medal{animation:orbitCCW 19s linear infinite;animation-delay:-5s}
.orbit-arm-medal .hero-float-badge{
  top:-230px;left:-30px;width:60px;height:60px;
  background:linear-gradient(135deg,#10b981,#065f46);
  color:#fff;
  box-shadow:0 0 0 3px rgba(16,185,129,.25),0 6px 22px rgba(16,185,129,.55);
  animation:counterCCW 19s linear infinite;animation-delay:-5s;
}
/* India — outermost ring (R=200), CW 26s */
.orbit-arm-india{animation:orbitCW 26s linear infinite;animation-delay:-15s}
.orbit-arm-india .hero-float-badge{
  top:-230px;left:-30px;width:60px;height:60px;
  background:linear-gradient(135deg,#f97316,#b91c1c);
  color:#fff;
  box-shadow:0 0 0 3px rgba(249,115,22,.25),0 6px 22px rgba(249,115,22,.55);
  animation:counterCW 26s linear infinite;animation-delay:-15s;
}
@keyframes orbitCW {to{transform:rotate(360deg)}}
@keyframes orbitCCW{to{transform:rotate(-360deg)}}
@keyframes counterCW {to{transform:rotate(-360deg)}}
@keyframes counterCCW{to{transform:rotate(360deg)}}
/* Stats strip */
.stats-strip{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:1.5rem 2rem;margin-top:-50px;position:relative;z-index:10}
.stat-box{text-align:center;padding:.5rem 0}
.stat-box .stat-num{font-family:'Oswald',sans-serif;font-size:2.3rem;font-weight:700;line-height:1;color:var(--primary)}
.stat-box .stat-lbl{font-size:.76rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-top:2px}
.stat-box .stat-num.orange{color:var(--secondary)}
.stat-box .stat-num.gold{color:var(--gold)}
.stat-box .stat-num.red{color:var(--accent)}
/* Section headings */
.section-tag{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--secondary);font-weight:700;display:inline-flex;align-items:center;gap:.4rem}
.section-tag::before,.section-tag::after{content:'';width:24px;height:2px;background:var(--secondary);border-radius:2px}
.section-title{font-family:'Oswald',sans-serif;font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:700;letter-spacing:.01em;text-transform:uppercase}
.section-divider{width:56px;height:4px;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:3px;display:block;margin:.8rem 0}
/* Cards */
.card{border-radius:var(--radius-md)!important}
.program-card{border:none!important;border-radius:var(--radius-lg)!important;transition:transform var(--transition),box-shadow var(--transition);overflow:hidden;background:#fff}
.program-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)!important}
.program-card .card-icon-wrap{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0;margin:0 auto 1rem}
.program-card .card-accent-line{height:4px;width:40px;border-radius:2px;background:linear-gradient(90deg,var(--primary),var(--secondary));margin-bottom:.8rem}
/* Event cards */
.event-card{border:none!important;border-radius:var(--radius-lg)!important;overflow:hidden;background:#fff;transition:transform var(--transition),box-shadow var(--transition)}
.event-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)!important}
.event-card .date-accent{background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;padding:1rem .8rem;text-align:center;min-width:68px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.event-card .date-accent .day{font-family:'Oswald',sans-serif;font-size:2rem;font-weight:700;line-height:1}
.event-card .date-accent .month{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;opacity:.85}
.event-card .date-accent .year{font-size:.66rem;opacity:.7}
.event-card-img-top{height:180px;object-fit:cover}
.event-date-badge{background:var(--primary);color:#fff;border-radius:.4rem;padding:.25rem .6rem;font-size:.75rem;font-weight:600}
/* Campaign cards */
.campaign-card{border:none!important;border-radius:var(--radius-lg)!important;overflow:hidden;background:#fff;transition:transform var(--transition),box-shadow var(--transition)}
.campaign-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)!important}
.campaign-card .campaign-img{height:200px;object-fit:cover;width:100%}
.donate-btn{background:linear-gradient(135deg,var(--secondary),#f97316);border:none;color:#fff;font-weight:700;width:100%;padding:.65rem;border-radius:8px;transition:opacity var(--transition)}
.donate-btn:hover{opacity:.88;color:#fff}
/* Page header */
.page-header{
  background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 50%,#e0f2fe 100%);
  padding:70px 0 60px;position:relative;overflow:hidden;
  color:#0f172a;
}
.page-header::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 70% 60%,rgba(37,99,235,.07) 0%,transparent 65%);
}
.page-header::after{content:'';position:absolute;bottom:-1px;left:0;right:0;height:40px;background:var(--light-bg);clip-path:ellipse(52% 100% at 50% 100%)}
.page-header .stripe{position:absolute;right:-80px;top:-80px;width:360px;height:360px;border-radius:50%;background:rgba(37,99,235,.04)}
.page-header .stripe2{position:absolute;left:-60px;bottom:-120px;width:300px;height:300px;border-radius:50%;background:rgba(37,99,235,.03)}
/* Hover lift */
.hover-lift{transition:transform var(--transition),box-shadow var(--transition)}
.hover-lift:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)!important}
/* Icon circle */
.icon-circle{width:52px;height:52px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
/* Testimonials */
.testimonial-card{border-radius:var(--radius-lg);background:#fff;transition:transform var(--transition),box-shadow var(--transition);border:1px solid var(--border)!important}
.testimonial-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)!important}
.testimonial-card .stars{color:var(--gold)}
/* Team page */
.team-avatar-lg{width:110px;height:110px;border-radius:50%;background-size:cover;background-position:center top;border:3px solid var(--border);margin:0 auto 12px}
.team-avatar{width:76px;height:76px;border-radius:50%;background-size:cover;background-position:center top;border:2px solid var(--border);margin:0 auto 10px}
.team-social a{color:var(--text-muted);transition:color var(--transition)}
.team-social a:hover{color:var(--primary)}
/* Homepage team card */
.team-card{border:none!important;border-radius:var(--radius-lg)!important;overflow:hidden;background:#fff;transition:transform var(--transition),box-shadow var(--transition);text-align:center}
.team-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)!important}
.team-card .tc-photo{width:88px;height:88px;border-radius:50%;object-fit:cover;border:3px solid var(--border)}
.team-card .tc-initials{width:88px;height:88px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:2.2rem;font-weight:700;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:3px solid rgba(26,63,165,.15)}
/* Gallery */
.gallery-item{overflow:hidden;border-radius:var(--radius-md);cursor:pointer}
.gallery-img{width:100%;height:220px;object-fit:cover;transition:transform .4s ease;display:block}
.gallery-item:hover .gallery-img{transform:scale(1.07)}
.gallery-overlay{position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .35s;display:flex;align-items:center;justify-content:center;gap:10px}
.gallery-item:hover .gallery-overlay{background:rgba(0,0,0,.45)}
.gallery-overlay .gallery-icon{color:#fff;font-size:1.6rem;opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.gallery-item:hover .gallery-icon{opacity:1;transform:translateY(0)}
/* Blog */
.blog-card-img{height:210px;object-fit:cover;transition:transform .4s ease}
.blog-card:hover .blog-card-img{transform:scale(1.04)}
.blog-card{transition:box-shadow var(--transition);border-radius:var(--radius-lg)!important;overflow:hidden}
.blog-card:hover{box-shadow:var(--shadow-lg)!important}
/* FAQ */
.faq-section .accordion-button:not(.collapsed){background:#eff6ff;color:var(--primary)}
.faq-section .accordion-button:focus{box-shadow:0 0 0 .2rem rgba(26,63,165,.2)}
/* Partners */
.partner-logo{width:64px;height:64px;object-fit:contain;border-radius:10px}
/* Progress */
.progress{border-radius:100px}
.progress-bar.sports-bar{background:linear-gradient(90deg,var(--primary),var(--secondary))}
/* CTA */
.sports-cta-banner{background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 50%,#e0f2fe 100%);position:relative;overflow:hidden;color:#0f172a}
.sports-cta-banner::before{content:'';position:absolute;right:-100px;top:-100px;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.05)}
/* Text effects */
.text-gradient-sport{background:linear-gradient(135deg,var(--primary-light),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-gradient-gold{background:linear-gradient(135deg,#f59e0b,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
/* Event filter tabs */
.event-filter-tab .nav-link{color:var(--text-muted);font-weight:600;border-radius:50px!important;padding:.45rem 1.2rem}
.event-filter-tab .nav-link.active{background:var(--primary);color:#fff!important}
/* Background pattern */
.section-bg-dots{background-image:radial-gradient(circle,rgba(26,63,165,.06) 1px,transparent 1px);background-size:24px 24px}
/* Admin layout */
.admin-layout{min-height:100vh}
/* Forms */
.form-control:focus,.form-select:focus{border-color:var(--primary-light);box-shadow:0 0 0 .2rem rgba(37,99,235,.18)}
/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--light-bg)}
::-webkit-scrollbar-thumb{background:var(--primary);border-radius:3px}
/* Achievement badge */
.achievement-badge{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;font-size:.78rem;font-weight:700;padding:.3rem .8rem;border-radius:50px}
/* Responsive */
@media(max-width:768px){
  .sports-hero{min-height:75vh}
  .sports-hero h1{font-size:2rem}
  .stats-strip{margin-top:0;border-radius:var(--radius-md)}
}

/* ═══════════════════════════════════════════════════════════════
   ENHANCED STYLES v3 — Scroll Reveal, Animations, Modern UI
═══════════════════════════════════════════════════════════════ */

/* ── Scroll Reveal ────────────────────────────────────────── */
[data-reveal]{
  opacity:0;
  transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1);
}
[data-reveal="up"]   {transform:translateY(50px)}
[data-reveal="down"] {transform:translateY(-50px)}
[data-reveal="left"] {transform:translateX(-60px)}
[data-reveal="right"]{transform:translateX(60px)}
[data-reveal="scale"]{transform:scale(.88)}
[data-reveal="fade"] {transform:none}
[data-reveal].revealed{opacity:1;transform:none!important}
.stagger-1{transition-delay:.06s}.stagger-2{transition-delay:.13s}
.stagger-3{transition-delay:.20s}.stagger-4{transition-delay:.27s}
.stagger-5{transition-delay:.34s}.stagger-6{transition-delay:.41s}

/* ── Enhanced Buttons ─────────────────────────────────────── */
.btn-primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-light))!important;
  border-color:var(--primary)!important;
}
.btn-primary:hover,.btn-primary:focus{
  background:linear-gradient(135deg,var(--primary-light),var(--primary-dark))!important;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(26,63,165,.4)!important;
}
.btn-warning{
  background:linear-gradient(135deg,var(--gold),#f97316)!important;
  color:#fff!important;
}
.btn-warning:hover{
  background:linear-gradient(135deg,#f97316,var(--gold))!important;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(245,158,11,.45)!important;
}
.btn,.btn-outline-primary,.btn-outline-secondary,.btn-outline-light{
  transition:all .2s ease!important;
}
.btn:active{transform:translateY(0)!important;box-shadow:none!important}

/* Button ripple */
.btn .ripple{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.35);
  transform:scale(0);
  animation:rippleAnim .55s linear;
  pointer-events:none;width:100px;height:100px;
  margin-top:-50px;margin-left:-50px;
}
@keyframes rippleAnim{to{transform:scale(4);opacity:0}}

/* ── Navbar enhancements ─────────────────────────────────── */
.navbar.sports-nav .nav-link{
  position:relative;
  padding:.5rem .8rem!important;
}
.navbar.sports-nav .nav-link::after{
  content:'';position:absolute;
  bottom:2px;left:.8rem;right:.8rem;height:2px;
  background:var(--secondary-light);
  transform:scaleX(0);transform-origin:center;
  transition:transform .25s ease;
  border-radius:2px;
}
.navbar.sports-nav .nav-link:hover::after,
.navbar.sports-nav .nav-link.active::after{transform:scaleX(1)}
.navbar.sports-nav .dropdown-menu{
  border-top:3px solid var(--secondary)!important;
  animation:dropIn .2s ease;
}
@keyframes dropIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* ── Hero enhancements ───────────────────────────────────── */
.hero-badge-pill{animation:badgePulse 3s ease-in-out infinite}
@keyframes badgePulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.12)}
  50%{box-shadow:0 0 0 8px rgba(255,255,255,0)}
}
.hero-badge-pill .dot{animation:dotBlink 1.4s ease-in-out infinite}
@keyframes dotBlink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}
.sports-hero h1 .highlight-text{
  text-shadow:0 0 40px rgba(251,146,60,.4);
}
.hero-main-logo{animation:logoFloat 4s ease-in-out infinite}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.hero-stat-pill{transition:transform .25s,background .25s}
.hero-stat-pill:hover{transform:translateY(-4px);background:rgba(255,255,255,.2)!important}

/* ── Stats strip gradient border ─────────────────────────── */
.stats-strip{
  border-top:3px solid transparent!important;
  background-image:
    linear-gradient(#fff,#fff),
    linear-gradient(90deg,var(--primary),var(--secondary))!important;
  background-origin:border-box!important;
  background-clip:padding-box,border-box!important;
}

/* ── Section divider shimmer ─────────────────────────────── */
.section-divider{position:relative;overflow:hidden}
.section-divider::after{
  content:'';position:absolute;
  top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.7),transparent);
  animation:shimmerLine 2.5s ease-in-out infinite;
}
@keyframes shimmerLine{to{left:200%}}

/* ── Cards general hover ─────────────────────────────────── */
.hover-lift{transition:transform var(--transition-slow),box-shadow var(--transition-slow)!important}
.hover-lift:hover{transform:translateY(-7px)!important;box-shadow:var(--shadow-xl)!important}

.card{transition:box-shadow .3s ease}
.event-card,.campaign-card,.blog-card,.team-card,.program-card,.testimonial-card{
  transition:transform .38s cubic-bezier(.16,1,.3,1),box-shadow .38s ease!important;
}
.event-card:hover,.campaign-card:hover,.blog-card:hover,.team-card:hover,.program-card:hover{
  transform:translateY(-8px) scale(1.01)!important;
  box-shadow:var(--shadow-xl)!important;
}

/* ── Event card accent line ──────────────────────────────── */
.event-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--secondary));
  transform:scaleX(0);transition:transform .3s;border-radius:0 0 var(--radius-lg) var(--radius-lg);
}
.event-card:hover::after,.campaign-card:hover::after{transform:scaleX(1)}
.event-card,.campaign-card{position:relative}

/* ── Team card top accent ────────────────────────────────── */
.team-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--secondary));
  transform:scaleX(0);transition:transform .3s;
}
.team-card:hover::before{transform:scaleX(1)}
.team-card{position:relative}

/* ── Gallery enhanced ────────────────────────────────────── */
.gallery-item:hover .gallery-img{transform:scale(1.1)}
.gallery-item:hover .gallery-overlay{background:rgba(15,40,120,.55)!important}
.gallery-overlay .gallery-icon{transform:translateY(12px) scale(.8)!important}
.gallery-item:hover .gallery-icon{transform:translateY(0) scale(1)!important}

/* ── Blog card bottom bar ────────────────────────────────── */
.blog-card{position:relative}
.blog-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--secondary));
  transform:scaleX(0);transition:transform .3s;
}
.blog-card:hover::after{transform:scaleX(1)}

/* ── Testimonial quote decoration ───────────────────────── */
.testimonial-card{position:relative;overflow:hidden}
.testimonial-card::before{
  content:'\201C';
  position:absolute;top:-10px;right:16px;
  font-size:6rem;font-family:Georgia,serif;
  color:var(--primary);opacity:.06;line-height:1;
  pointer-events:none;
}

/* ── Progress bar shimmer ────────────────────────────────── */
.progress-bar.sports-bar{position:relative;overflow:hidden}
.progress-bar.sports-bar::after{
  content:'';position:absolute;
  top:0;left:-60%;width:50%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  animation:progressShimmer 2.2s ease-in-out infinite;
}
@keyframes progressShimmer{to{left:130%}}

/* ── CTA banner orbs ─────────────────────────────────────── */
.sports-cta-banner{position:relative;overflow:hidden}
.sports-cta-banner::after{
  content:'';position:absolute;left:-60px;bottom:-80px;
  width:300px;height:300px;border-radius:50%;
  background:rgba(234,88,12,.07);
  animation:ctaOrb 12s ease-in-out infinite reverse;
}
@keyframes ctaOrb{0%,100%{transform:scale(1)}50%{transform:scale(1.35)}}

/* ── Page header animation ───────────────────────────────── */
.page-header .stripe,
.page-header .stripe2{animation:stripePulse 8s ease-in-out infinite}
.page-header .stripe2{animation-duration:12s;animation-direction:reverse}
@keyframes stripePulse{0%,100%{transform:scale(1);opacity:.04}50%{transform:scale(1.15);opacity:.09}}

/* ── Form enhancements ───────────────────────────────────── */
.form-control,.form-select{
  border:1.5px solid var(--border)!important;
  border-radius:var(--radius-md)!important;
  padding:.58rem .85rem!important;
  transition:border-color .2s,box-shadow .2s,transform .15s!important;
}
.form-control:focus,.form-select:focus{
  border-color:var(--primary-light)!important;
  box-shadow:0 0 0 3px rgba(37,99,235,.14),0 2px 8px rgba(26,63,165,.09)!important;
  transform:translateY(-1px);
}
.form-control:not(:placeholder-shown):not(:focus){
  border-color:rgba(26,63,165,.25)!important;
}
.form-label{font-size:.86rem;font-weight:600;color:var(--dark-mid)!important;margin-bottom:.35rem!important}
.input-group-text{background:var(--light-bg)!important;border:1.5px solid var(--border)!important;font-weight:600}

/* ── Payment Panel ───────────────────────────────────────── */
.payment-panel{
  background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 50%,#eff6ff 100%)!important;
  border:2px solid #bae6fd!important;
  border-radius:var(--radius-lg)!important;
  box-shadow:0 4px 24px rgba(2,132,199,.12)!important;
  position:relative;overflow:hidden;
}
.payment-info-box{
  background:#fff!important;
  border:1.5px solid #bae6fd!important;
  border-radius:var(--radius-md)!important;
  transition:box-shadow .2s,transform .2s;
}
.payment-info-box:hover{box-shadow:0 6px 20px rgba(2,132,199,.18)!important;transform:translateY(-2px)}
.upi-id-display{
  font-size:1.05rem;font-weight:700;letter-spacing:.02em;color:#0c4a6e;
  background:linear-gradient(135deg,#e0f2fe,#f0f9ff);
  border:1.5px dashed #7dd3fc;
  border-radius:var(--radius-md);
  padding:.5rem 1rem;
  display:inline-block;
}

/* ── Receipt cards ───────────────────────────────────────── */
#receiptCard,#regReceiptCard,.receipt-card{
  border-radius:var(--radius-xl)!important;
  box-shadow:0 12px 48px rgba(26,63,165,.15),0 0 0 1px rgba(26,63,165,.06)!important;
  animation:receiptIn .6s cubic-bezier(.16,1,.3,1) both;
}
@keyframes receiptIn{
  from{opacity:0;transform:translateY(32px) scale(.95)}
  to{opacity:1;transform:none}
}
.receipt-check-icon{
  width:72px;height:72px;border-radius:50%;
  background:rgba(255,255,255,.2);
  border:2px solid rgba(255,255,255,.4);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;
  animation:checkPop .5s .3s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes checkPop{from{transform:scale(0) rotate(-180deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}

/* ── Download Screenshot Button ──────────────────────────── */
.btn-screenshot{
  background:linear-gradient(135deg,#7c3aed,#a855f7)!important;
  border:none!important;color:#fff!important;font-weight:600;
  border-radius:50px!important;
  position:relative;overflow:hidden;
  transition:all .2s!important;
}
.btn-screenshot:hover{
  transform:translateY(-2px)!important;
  box-shadow:0 6px 20px rgba(124,58,237,.4)!important;
  color:#fff!important;
}

/* ── QR Code placeholder ──────────────────────────────────── */
.qr-code-box{
  width:110px;height:110px;margin:0 auto;
  background:linear-gradient(135deg,#f0f9ff,#e0f2fe);
  border:2px dashed #7dd3fc;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  cursor:pointer;transition:all .25s;
}
.qr-code-box:hover{border-color:#0284c7;transform:scale(1.06);box-shadow:0 4px 16px rgba(2,132,199,.2)}
.qr-code-box i{font-size:2.8rem;color:#0284c7}
.qr-code-box span{font-size:.6rem;color:#0369a1;margin-top:3px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}

/* ── Scroll to Top ───────────────────────────────────────── */
#scrollTopBtn{
  position:fixed;bottom:24px;left:24px;z-index:999;
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  color:#fff;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(26,63,165,.4);
  opacity:0;transform:translateY(20px);
  transition:all .3s ease;font-size:1.1rem;
}
#scrollTopBtn.visible{opacity:1;transform:translateY(0)}
#scrollTopBtn:hover{transform:translateY(-4px)!important;box-shadow:0 8px 24px rgba(26,63,165,.5)}

/* ── Confetti canvas ─────────────────────────────────────── */
#confettiCanvas{position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:0;transition:opacity .5s}
#confettiCanvas.active{opacity:1}

/* ── Page header breadcrumb ──────────────────────────────── */
.breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.45)!important}
.breadcrumb-item a{color:rgba(255,255,255,.7);transition:color .2s}
.breadcrumb-item a:hover{color:#fff}
.breadcrumb-item.active{color:#fff}

/* ── FAQ enhanced ────────────────────────────────────────── */
.faq-section .accordion-item{
  border-radius:var(--radius-md)!important;
  margin-bottom:.5rem;overflow:hidden;
  border:1px solid var(--border)!important;
  transition:box-shadow .25s;
}
.faq-section .accordion-item:hover{box-shadow:var(--shadow-sm)}
.faq-section .accordion-button{font-weight:600;letter-spacing:.01em}

/* ── Text gradient utilities ─────────────────────────────── */
.text-gradient-sport{background:linear-gradient(135deg,var(--primary-light),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-gradient-gold{background:linear-gradient(135deg,#f59e0b,var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.text-gradient-fire{background:linear-gradient(135deg,#dc2626,#f97316,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── Step badges ─────────────────────────────────────────── */
.step-badge-active{background:linear-gradient(135deg,#0284c7,#0369a1)!important;color:#fff!important}
.step-badge-inactive{background:#e2e8f0!important;color:#64748b!important}

/* ── Achievement badge pulse ──────────────────────────────── */
.achievement-badge{animation:achievePulse 3s ease-in-out infinite}
@keyframes achievePulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.3)}50%{box-shadow:0 0 12px 4px rgba(245,158,11,.1)}}

/* ── Toast notification ──────────────────────────────────── */
.toast-msg{
  position:fixed;top:76px;right:20px;z-index:9999;
  background:#fff;border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);padding:1rem 1.25rem;
  border-left:4px solid var(--primary);
  min-width:260px;max-width:340px;
  animation:toastIn .4s cubic-bezier(.16,1,.3,1) both;
  display:flex;align-items:flex-start;gap:.65rem;
}
.toast-msg.success-toast{border-left-color:#059669}
.toast-msg.error-toast{border-left-color:var(--accent)}
.toast-msg.warning-toast{border-left-color:var(--gold)}
@keyframes toastIn{from{opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(60px)}}

/* ── Donation page specific ──────────────────────────────── */
.preset-amt{
  transition:all .2s!important;
  position:relative;overflow:hidden;
}
.preset-amt.active,.preset-amt:hover{
  background:var(--primary)!important;
  border-color:var(--primary)!important;
  color:#fff!important;
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(26,63,165,.35)!important;
}
.donation-amount-display{
  font-family:'Oswald',sans-serif;
  font-size:3rem;font-weight:700;
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}

/* ── Membership fee display ──────────────────────────────── */
#mbrFeeDisplay{
  font-family:'Oswald',sans-serif;
  font-size:1.5rem;font-weight:700;
  color:var(--primary);
  transition:all .3s ease;
}

/* ── Section BG patterns ──────────────────────────────────── */
.section-bg-grid{
  background-image:
    linear-gradient(rgba(26,63,165,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,63,165,.04) 1px,transparent 1px);
  background-size:32px 32px;
}

/* ── Responsive additional ───────────────────────────────── */
@media(max-width:991px){
  .stats-strip{padding:1rem}
}
@media(max-width:576px){
  .hero-stat-pill{min-width:72px;padding:.6rem .8rem}
  .hero-stat-pill .num{font-size:1.35rem}
  .page-header{padding:50px 0 40px}
  .section-title{font-size:1.3rem}
}
@media print{
  .navbar,.sports-hero,footer,.no-print,#scrollTopBtn,
  .fab-donate,.btn-screenshot,.preset-amt{display:none!important}
  body{background:#fff!important}
  #receiptCard,#regReceiptCard{max-width:600px!important;margin:0 auto!important;box-shadow:none!important}
}

/* ═══════════════════════════════════════════════════════════════
   ADVANCED MODERN UI v4 — Team, Cards, Glass, Motion, Sections
═══════════════════════════════════════════════════════════════ */

/* ── Glass morphism utility ───────────────────────────────── */
.glass{
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.22);
}
.glass-dark{
  background:rgba(10,20,60,.45);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.12);
}

/* ── Gradient text utility ────────────────────────────────── */
.text-gradient{
  background:linear-gradient(135deg,var(--primary-light),var(--secondary));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── Pill badge utility ───────────────────────────────────── */
.chip{
  display:inline-flex;align-items:center;gap:.35rem;
  background:var(--light-bg);color:var(--text-muted);
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;
  padding:.25rem .75rem;border-radius:50px;
  border:1px solid var(--border);
}
.chip.primary{background:#eff6ff;color:var(--primary);border-color:rgba(26,63,165,.18)}
.chip.orange{background:#fff7ed;color:var(--secondary);border-color:rgba(234,88,12,.18)}
.chip.gold{background:#fffbeb;color:#92400e;border-color:rgba(245,158,11,.25)}
.chip.green{background:#f0fdf4;color:#166534;border-color:rgba(22,163,74,.18)}

/* ── Number counter ───────────────────────────────────────── */
.counter-num{
  font-family:'Oswald',sans-serif;font-weight:700;line-height:1;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

/* ── Zigzag / wave divider ────────────────────────────────── */
.wave-divider{position:absolute;bottom:-1px;left:0;right:0;line-height:0}
.wave-divider svg{display:block;width:100%}

/* ════════════════════════════════════════════════════════════
   TEAM PAGE — Premium 3-D Flip Leader Cards + Grid Team
════════════════════════════════════════════════════════════ */

/* === Leader Flip Card === */
.flip-card{
  perspective:1100px;
  height:360px;
}
.flip-card-inner{
  position:relative;width:100%;height:100%;
  transition:transform .65s cubic-bezier(.4,0,.2,1);
  transform-style:preserve-3d;
}
.flip-card:hover .flip-card-inner{
  transform:rotateY(180deg);
}
.flip-card-front,.flip-card-back{
  position:absolute;inset:0;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  border-radius:var(--radius-lg);
  overflow:hidden;
}
/* Front */
.flip-card-front{
  background:#fff;
  box-shadow:0 4px 20px rgba(26,63,165,.09);
  display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  border:1px solid var(--border);
}
.flip-card-front .fc-photo-wrap{
  width:100%;height:160px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--primary-dark),var(--primary));
}
.flip-card-front .fc-photo-wrap img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
}
.flip-card-front .fc-initials{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-size:3.5rem;font-weight:700;color:rgba(255,255,255,.4);
}
.flip-card-front .fc-avatar-ring{
  position:absolute;bottom:-28px;left:50%;transform:translateX(-50%);
  width:72px;height:72px;border-radius:50%;
  border:4px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,.18);
  overflow:hidden;background:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-size:1.6rem;font-weight:700;
}
.flip-card-front .fc-avatar-ring img{width:100%;height:100%;object-fit:cover}
.flip-card-front .fc-body{
  padding:2rem 1.2rem 1.2rem;text-align:center;width:100%;margin-top:20px;
}
.flip-card-front .fc-name{
  font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:700;
  color:var(--dark);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem;
}
.flip-card-front .fc-role{
  font-size:.78rem;font-weight:600;color:var(--secondary);text-transform:uppercase;
  letter-spacing:.08em;margin-bottom:.8rem;
}
.flip-card-front .fc-dept-chip{
  display:inline-flex;align-items:center;
  background:var(--light-bg);color:var(--text-muted);
  font-size:.7rem;font-weight:600;padding:.2rem .7rem;border-radius:50px;
  border:1px solid var(--border);
}
.flip-card-front .fc-hint{
  position:absolute;bottom:12px;right:12px;
  font-size:.65rem;color:var(--text-muted);
  display:flex;align-items:center;gap:.25rem;
  opacity:.7;
}

/* Back */
.flip-card-back{
  background:linear-gradient(145deg,var(--primary-dark) 0%,var(--primary) 65%,#1e40af 100%);
  transform:rotateY(180deg);
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  padding:1.8rem 1.5rem;text-align:center;color:#fff;
}
.flip-card-back .fb-icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(255,255,255,.13);border:2px solid rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1rem;
}
.flip-card-back .fb-name{
  font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem;
}
.flip-card-back .fb-role{
  font-size:.75rem;color:rgba(255,255,255,.7);
  text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;
}
.flip-card-back .fb-bio{
  font-size:.8rem;line-height:1.7;color:rgba(255,255,255,.85);
  margin-bottom:1.2rem;max-height:100px;overflow:hidden;
}
.flip-card-back .fb-social{
  display:flex;gap:.5rem;justify-content:center;
}
.flip-card-back .fb-social a{
  width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:.9rem;transition:all .2s;
}
.flip-card-back .fb-social a:hover{
  background:var(--secondary);border-color:var(--secondary);transform:translateY(-2px);
}

/* === Core Team Grid Cards === */
.team-grid-card{
  background:#fff;
  border-radius:var(--radius-md);
  border:1px solid var(--border);
  padding:1.4rem 1rem;
  text-align:center;
  transition:all .28s ease;
  position:relative;
  overflow:hidden;
}
.team-grid-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--secondary));
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;
}
.team-grid-card:hover::before{transform:scaleX(1)}
.team-grid-card:hover{
  box-shadow:var(--shadow-md);
  transform:translateY(-4px);
  border-color:transparent;
}
.team-grid-card .tgc-avatar{
  width:68px;height:68px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-size:1.5rem;font-weight:700;color:#fff;
  margin:0 auto .8rem;
  border:3px solid #fff;
  box-shadow:0 4px 14px rgba(0,0,0,.15);
}
.team-grid-card .tgc-name{
  font-size:.9rem;font-weight:700;color:var(--dark);margin-bottom:.3rem;
}
.team-grid-card .tgc-dept{
  font-size:.72rem;color:var(--text-muted);text-transform:uppercase;
  letter-spacing:.06em;
}
.team-grid-card img.tgc-photo{
  width:68px;height:68px;border-radius:50%;object-fit:cover;
  border:3px solid #fff;box-shadow:0 4px 14px rgba(0,0,0,.15);
  display:block;margin:0 auto .8rem;
}

/* === Dept filter tabs === */
.dept-filter{
  display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;
}
.dept-filter .df-btn{
  padding:.35rem 1rem;border-radius:50px;border:1.5px solid var(--border);
  background:#fff;color:var(--text-muted);font-size:.78rem;font-weight:600;
  cursor:pointer;transition:all .2s;
}
.dept-filter .df-btn:hover,
.dept-filter .df-btn.active{
  background:var(--primary);color:#fff;border-color:var(--primary);
}

/* === Team stats strip === */
.team-stats-bar{
  display:grid;grid-template-columns:repeat(4,1fr);
  background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
.team-stats-bar .tsb-item{
  padding:1.5rem 1rem;text-align:center;
  border-right:1px solid var(--border);
  position:relative;
}
.team-stats-bar .tsb-item:last-child{border-right:none}
.team-stats-bar .tsb-num{
  font-family:'Oswald',sans-serif;font-size:2rem;font-weight:700;
  line-height:1;margin-bottom:.2rem;
}
.team-stats-bar .tsb-lbl{
  font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);
}

/* === CTA section enhancements === */
.cta-sport{
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,#1e40af 100%);
  position:relative;overflow:hidden;
}
.cta-sport::before{
  content:'';position:absolute;
  right:-120px;top:-120px;
  width:400px;height:400px;border-radius:50%;
  background:rgba(255,255,255,.04);
}
.cta-sport::after{
  content:'';position:absolute;
  left:-80px;bottom:-80px;
  width:280px;height:280px;border-radius:50%;
  background:rgba(234,88,12,.1);
}

/* ════════════════════════════════════════════════════════════
   ABOUT PAGE enhancements
════════════════════════════════════════════════════════════ */
.timeline{position:relative;padding-left:2rem}
.timeline::before{
  content:'';position:absolute;left:.75rem;top:0;bottom:0;
  width:2px;background:linear-gradient(180deg,var(--primary),var(--secondary),var(--primary));
}
.timeline-item{position:relative;padding-bottom:2rem}
.timeline-item:last-child{padding-bottom:0}
.timeline-dot{
  position:absolute;left:-2rem;top:.2rem;
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  border:3px solid #fff;box-shadow:0 0 0 3px rgba(26,63,165,.2);
}
.timeline-content{background:#fff;border-radius:var(--radius-md);padding:1rem 1.2rem;box-shadow:var(--shadow-sm);border:1px solid var(--border)}
.timeline-year{font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:700;color:var(--primary);margin-bottom:.2rem}
.timeline-title{font-weight:700;font-size:.9rem;color:var(--dark);margin-bottom:.25rem}
.timeline-desc{font-size:.8rem;color:var(--text-muted);line-height:1.6}

/* ════════════════════════════════════════════════════════════
   EVENTS / GALLERY / CONTACT improvements
════════════════════════════════════════════════════════════ */
/* Event card v2 */
.event-card-v2{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);
  transition:all .28s ease;
  display:flex;flex-direction:column;
}
.event-card-v2:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg);
  border-color:transparent;
}
.event-card-v2 .ecv2-img{
  height:190px;object-fit:cover;width:100%;
  transition:transform .4s ease;
}
.event-card-v2:hover .ecv2-img{transform:scale(1.05)}
.event-card-v2 .ecv2-body{padding:1.2rem;flex:1;display:flex;flex-direction:column}
.event-card-v2 .ecv2-date-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  background:var(--light-bg);color:var(--primary);
  font-size:.72rem;font-weight:700;padding:.2rem .65rem;
  border-radius:50px;border:1px solid rgba(26,63,165,.15);
  margin-bottom:.7rem;
}
.event-card-v2 .ecv2-title{
  font-weight:700;font-size:1rem;color:var(--dark);margin-bottom:.5rem;line-height:1.4;
}
.event-card-v2 .ecv2-meta{
  display:flex;flex-direction:column;gap:.3rem;font-size:.78rem;color:var(--text-muted);margin-bottom:.9rem;
}
.event-card-v2 .ecv2-meta i{color:var(--primary);width:14px;flex-shrink:0}
.event-card-v2 .ecv2-footer{margin-top:auto;padding-top:.8rem;border-top:1px solid var(--border)}

/* Gallery v2 */
.gallery-item-v2{
  position:relative;overflow:hidden;border-radius:var(--radius-md);
  cursor:pointer;background:#000;height:220px;
}
.gallery-item-v2 img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform .4s ease,opacity .3s;
  display:block;
}
.gallery-item-v2:hover img{transform:scale(1.08);opacity:.7}
.gallery-item-v2 .giv2-overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;
  opacity:0;transition:opacity .3s;
  color:#fff;
}
.gallery-item-v2:hover .giv2-overlay{opacity:1}
.gallery-item-v2 .giv2-icon{font-size:1.8rem;transform:scale(.7);transition:transform .3s .05s}
.gallery-item-v2:hover .giv2-icon{transform:scale(1)}
.gallery-item-v2 .giv2-title{font-size:.78rem;font-weight:600;text-align:center;padding:0 .8rem;transform:translateY(6px);transition:transform .3s .08s}
.gallery-item-v2:hover .giv2-title{transform:translateY(0)}

/* Contact card */
.contact-info-card{
  background:#fff;border-radius:var(--radius-md);padding:1rem 1.2rem;
  border:1px solid var(--border);
  transition:all .25s ease;
  display:flex;align-items:center;gap:1rem;
}
.contact-info-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.contact-info-card .cic-icon{
  width:48px;height:48px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}

/* ════════════════════════════════════════════════════════════
   PAGE-LEVEL HERO v2 (shared improved page-header)
════════════════════════════════════════════════════════════ */
.page-hero{
  background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 50%,#1e40af 100%);
  padding:80px 0 72px;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 70% at 80% 50%,rgba(234,88,12,.18) 0%,transparent 65%);
}
.page-hero::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;height:56px;
  background:var(--light-bg);
  clip-path:ellipse(52% 100% at 50% 100%);
}
.page-hero-particles{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.phero-circle{
  position:absolute;border-radius:50%;
  background:rgba(255,255,255,.04);
  animation:floatUp 8s ease-in-out infinite;
}
@keyframes floatUp{
  0%,100%{transform:translateY(0) scale(1)}
  50%   {transform:translateY(-20px) scale(1.04)}
}

/* ════════════════════════════════════════════════════════════
   INTERACTIVE FEATURE TABS (Awards / About)
════════════════════════════════════════════════════════════ */
.feature-tab-nav{
  display:flex;flex-direction:column;gap:.5rem;
}
.feature-tab-nav .ftn-item{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:1rem 1.2rem;background:#fff;cursor:pointer;
  transition:all .22s ease;display:flex;align-items:center;gap:.8rem;
}
.feature-tab-nav .ftn-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}
.feature-tab-nav .ftn-item.active{
  background:linear-gradient(135deg,var(--primary),var(--primary-light));
  border-color:var(--primary);color:#fff;
  box-shadow:0 6px 20px rgba(26,63,165,.3);
}
.feature-tab-nav .ftn-item .ftn-icon{
  width:40px;height:40px;border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem;
  background:var(--light-bg);color:var(--primary);transition:all .22s;
}
.feature-tab-nav .ftn-item.active .ftn-icon{background:rgba(255,255,255,.18);color:#fff}
.feature-tab-nav .ftn-item .ftn-title{font-weight:700;font-size:.9rem;line-height:1}
.feature-tab-nav .ftn-item .ftn-sub{font-size:.75rem;opacity:.7;margin-top:.2rem}
.feature-tab-nav .ftn-item.active .ftn-sub{opacity:.8;color:rgba(255,255,255,.8)}

/* RESPONSIVE add-ons */
@media(max-width:991px){
  .flip-card{height:auto;perspective:none}
  .flip-card-inner{transform:none!important;display:flex;flex-direction:column}
  .flip-card-back{position:relative;transform:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);inset:auto}
  .flip-card-front{position:relative;border-radius:var(--radius-lg) var(--radius-lg) 0 0;inset:auto}
  .team-stats-bar{grid-template-columns:repeat(2,1fr)}
  .team-stats-bar .tsb-item:nth-child(2){border-right:none}
  .team-stats-bar .tsb-item:nth-child(3){border-top:1px solid var(--border)}
}
@media(max-width:576px){
  .flip-card-back .fb-bio{font-size:.75rem}
  .team-stats-bar{grid-template-columns:repeat(2,1fr)}
  .dept-filter .df-btn{font-size:.7rem;padding:.28rem .8rem}
}

/* ════════════════════════════════════════════════════════════
   EXTRA POLISH v5 — Section accents, gallery filter standalone
════════════════════════════════════════════════════════════ */

/* Standalone df-btn (works without .dept-filter wrapper) */
a.df-btn,button.df-btn,.df-btn{
  display:inline-flex;align-items:center;gap:.35rem;
  padding:.38rem 1.1rem;border-radius:50px;
  border:1.5px solid var(--border);
  background:#fff;color:var(--text-muted);
  font-size:.8rem;font-weight:600;letter-spacing:.02em;
  cursor:pointer;transition:all .2s;text-decoration:none;
}
a.df-btn:hover,button.df-btn:hover,.df-btn:hover,
a.df-btn.active,button.df-btn.active,.df-btn.active{
  background:var(--primary);color:#fff;border-color:var(--primary);
  box-shadow:0 4px 14px rgba(26,63,165,.3);
  transform:translateY(-2px);
}

/* About page VM&V enhanced */
.vmv-card{
  border-radius:var(--radius-lg)!important;
  border:1px solid var(--border)!important;
  transition:all .28s ease;
  overflow:hidden;
  position:relative;
}
.vmv-card .vmv-top-line{
  height:4px;width:100%;
  position:absolute;top:0;left:0;right:0;
}
.vmv-card:hover{box-shadow:var(--shadow-lg)!important;transform:translateY(-5px)}

/* Gallery hero stat */
.gal-stat{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(8px);
  border-radius:var(--radius-md);
  padding:.8rem 1.4rem;text-align:center;
}

/* Section gradient bg for alternating variety */
.section-gradient-light{
  background:linear-gradient(160deg,#f8faff 0%,#fff 60%,#fff7ed 100%);
}

/* Team grid card on about page hover badge reveal */
.team-role-tip{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(180deg,transparent,rgba(26,63,165,.85));
  color:#fff;text-align:center;padding:1rem .5rem .5rem;
  transform:translateY(100%);transition:transform .28s ease;
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
}
.team-grid-card:hover .team-role-tip{transform:translateY(0)}
.team-grid-card{overflow:hidden}

/* Page hero responsive */
@media(max-width:768px){
  .page-hero{padding:60px 0 50px}
}
@media(max-width:576px){
  .page-hero{padding:48px 0 40px}
  .gallery-item-v2{height:180px}
}

/* ════════════════════════════════════════════════════════════════
   VISUAL OVERHAUL v6 — DRAMATIC VISIBLE IMPROVEMENTS (OVERRIDE)
════════════════════════════════════════════════════════════════ */

/* PAGE-HERO & PAGE-HEADER: light blue gradient — all pages */
.page-hero,
.page-header{
  background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 50%,#e0f2fe 100%)!important;
  padding:90px 0 78px!important;
  position:relative!important;overflow:hidden!important;
  color:#0f172a!important;
}
.page-hero::before,
.page-header::before{
  content:''!important;position:absolute!important;inset:0!important;
  pointer-events:none!important;
  background:
    radial-gradient(ellipse 55% 100% at 88% 50%,rgba(37,99,235,.08) 0%,transparent 58%),
    radial-gradient(ellipse 35% 60% at 10% 80%,rgba(234,88,12,.05) 0%,transparent 55%),
    repeating-linear-gradient(
      -45deg,
      transparent 0px,transparent 18px,
      rgba(37,99,235,.022) 18px,rgba(37,99,235,.022) 19px
    )!important;
}
.page-hero::after,
.page-header::after{
  content:''!important;position:absolute!important;
  bottom:-2px!important;left:0!important;right:0!important;height:64px!important;
  background:#f1f5f9!important;
  clip-path:ellipse(55% 100% at 50% 100%)!important;
}
/* Override ALL white text within light hero sections */
.page-hero h1,.page-hero h2,.page-hero h3,
.page-header h1,.page-header h2,.page-header h3,
.page-hero.text-white,.page-hero .text-white,
.page-header.text-white,.page-header .text-white,
.page-hero .section-title,.page-header .section-title{color:#0f172a!important}
.page-hero p,.page-header p{color:#4b5563!important}
.page-header .stripe,.page-header .stripe2,
.page-hero .stripe,.page-hero .stripe2{
  background:rgba(37,99,235,.05)!important;
  border:1px solid rgba(37,99,235,.07)!important;
}
.phero-circle{
  background:rgba(37,99,235,.06)!important;
  border:1px solid rgba(37,99,235,.08)!important;
}

/* Badge pill — light bg context */
.hero-badge-pill{
  background:rgba(37,99,235,.1)!important;
  border:1px solid rgba(37,99,235,.22)!important;
  display:inline-flex!important;align-items:center!important;gap:.5rem!important;
  padding:.48rem 1.2rem!important;border-radius:50px!important;
  font-size:.75rem!important;font-weight:700!important;
  letter-spacing:.09em!important;text-transform:uppercase!important;
  color:#1e40af!important;backdrop-filter:blur(4px)!important;
  margin-bottom:.8rem!important;
}

/* ── GALLERY CARDS ─────────────────────────────────────────── */
.gallery-item-v2{
  height:260px!important;
  border-radius:14px!important;
  box-shadow:0 6px 24px rgba(0,0,0,.18)!important;
  transition:transform .32s cubic-bezier(.16,1,.3,1),box-shadow .32s!important;
  overflow:hidden!important;position:relative!important;
}
.gallery-item-v2:hover{
  transform:translateY(-8px) scale(1.02)!important;
  box-shadow:0 20px 60px rgba(0,0,0,.28)!important;
}
.gallery-item-v2 img{
  width:100%!important;height:100%!important;
  object-fit:cover!important;display:block!important;
  transition:transform .5s ease,opacity .4s!important;
}
.gallery-item-v2:hover img{
  transform:scale(1.13)!important;opacity:.6!important;
}
.gallery-item-v2::after{
  content:''!important;position:absolute!important;
  bottom:0!important;left:0!important;right:0!important;height:55%!important;
  background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 100%)!important;
  z-index:1!important;pointer-events:none!important;
}
.gallery-item-v2 .giv2-overlay{
  position:absolute!important;inset:0!important;z-index:3!important;
  display:flex!important;flex-direction:column!important;
  align-items:center!important;justify-content:center!important;gap:.5rem!important;
  background:rgba(10,26,92,.76)!important;
  opacity:0!important;transition:opacity .3s!important;
}
.gallery-item-v2:hover .giv2-overlay{opacity:1!important}
.gallery-item-v2 .giv2-icon{
  font-size:2.4rem!important;color:#fff!important;
  transform:scale(.55) translateY(-14px)!important;
  transition:transform .3s .05s!important;
}
.gallery-item-v2:hover .giv2-icon{transform:scale(1) translateY(0)!important}
.gallery-item-v2 .giv2-title{
  font-size:.88rem!important;font-weight:700!important;
  color:#fff!important;text-align:center!important;padding:0 1rem!important;
  transform:translateY(12px)!important;transition:transform .3s .1s!important;
}
.gallery-item-v2:hover .giv2-title{transform:translateY(0)!important}

/* Gallery caption below card */
.ga-caption{
  padding:.6rem .8rem .4rem;
}
.ga-caption-title{
  font-weight:700;font-size:.85rem;color:#1e293b;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.ga-caption-cat{
  font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
}

/* ── VMV CARDS ─────────────────────────────────────────────── */
.vmv-card-vision{
  background:linear-gradient(160deg,#dbeafe 0%,#eff6ff 100%)!important;
  border:none!important;
  border-left:5px solid #1a3fa5!important;
  box-shadow:0 4px 24px rgba(26,63,165,.1)!important;
}
.vmv-card-mission{
  background:linear-gradient(160deg,#ffedd5 0%,#fff7ed 100%)!important;
  border:none!important;
  border-left:5px solid #ea580c!important;
  box-shadow:0 4px 24px rgba(234,88,12,.1)!important;
}
.vmv-card-values{
  background:linear-gradient(160deg,#dcfce7 0%,#f0fdf4 100%)!important;
  border:none!important;
  border-left:5px solid #059669!important;
  box-shadow:0 4px 24px rgba(5,150,105,.1)!important;
}
.vmv-card{transition:all .3s ease!important}
.vmv-card:hover{transform:translateY(-8px)!important;box-shadow:var(--shadow-xl)!important}

/* ── TIMELINE ──────────────────────────────────────────────── */
.timeline{padding-left:2.5rem!important}
.timeline::before{
  left:0.85rem!important;width:3px!important;
  background:linear-gradient(180deg,#1a3fa5 0%,#ea580c 50%,#059669 100%)!important;
  border-radius:3px!important;
}
.timeline-item{padding-bottom:2.2rem!important}
.timeline-dot{
  left:-1.75rem!important;
  width:22px!important;height:22px!important;
  background:linear-gradient(135deg,#1a3fa5,#ea580c)!important;
  border:4px solid #fff!important;
  box-shadow:0 0 0 4px rgba(26,63,165,.2),0 4px 12px rgba(26,63,165,.35)!important;
}
.timeline-content{
  background:#fff!important;
  border-radius:12px!important;
  padding:1.2rem 1.4rem!important;
  box-shadow:0 4px 20px rgba(0,0,0,.1)!important;
  border:1px solid #e2e8f0!important;
  border-left:4px solid var(--primary)!important;
  transition:transform .25s,box-shadow .25s!important;
}
.timeline-content:hover{
  transform:translateX(8px)!important;
  box-shadow:0 8px 32px rgba(26,63,165,.18)!important;
}
.timeline-year{
  font-family:'Oswald',sans-serif!important;
  font-size:1.6rem!important;font-weight:700!important;line-height:1!important;
  background:linear-gradient(135deg,var(--primary),var(--secondary))!important;
  -webkit-background-clip:text!important;-webkit-text-fill-color:transparent!important;
  background-clip:text!important;margin-bottom:.3rem!important;
}
.timeline-title{
  font-size:.95rem!important;font-weight:700!important;
  color:#0f172a!important;margin-bottom:.3rem!important;
}
.timeline-desc{font-size:.82rem!important;color:#64748b!important;line-height:1.7!important}

/* ── CONTACT INFO CARDS ────────────────────────────────────── */
.contact-info-card{
  display:flex!important;align-items:center!important;gap:1rem!important;
  padding:1rem 1.25rem!important;
  border-radius:12px!important;
  border:none!important;
  box-shadow:0 2px 12px rgba(0,0,0,.07)!important;
  transition:all .28s ease!important;
}
.contact-info-card:hover{
  transform:translateX(8px)!important;
  box-shadow:0 6px 28px rgba(0,0,0,.14)!important;
}
.cic-addr{background:linear-gradient(135deg,#dbeafe,#eff6ff)!important;border-left:4px solid #1a3fa5!important}
.cic-phone{background:linear-gradient(135deg,#dcfce7,#f0fdf4)!important;border-left:4px solid #059669!important}
.cic-email{background:linear-gradient(135deg,#fef3c7,#fffbeb)!important;border-left:4px solid #d97706!important}
.cic-hours{background:linear-gradient(135deg,#ede9fe,#f5f3ff)!important;border-left:4px solid #7c3aed!important}

/* ── OBJECTIVES CARDS ─────────────────────────────────────── */
.card.border-0.shadow-sm.h-100.p-4.hover-lift[style*="border-radius:16px"]{
  border-left:4px solid var(--primary)!important;
  background:linear-gradient(145deg,#f8faff,#fff)!important;
}

/* ── TEAM GRID CARD ───────────────────────────────────────── */
.team-grid-card{
  box-shadow:0 2px 14px rgba(0,0,0,.07)!important;
  border:none!important;
  background:linear-gradient(160deg,#f8faff,#fff)!important;
  transition:all .28s ease!important;
}
.team-grid-card:hover{
  box-shadow:0 12px 40px rgba(26,63,165,.18)!important;
  background:#fff!important;
}
.team-grid-card .tgc-avatar{
  width:78px!important;height:78px!important;
  font-size:1.9rem!important;margin-bottom:1rem!important;
}
.team-grid-card img.tgc-photo{
  width:78px!important;height:78px!important;margin-bottom:1rem!important;
}

/* ── SECTION BACKGROUND CLASSES ──────────────────────────── */
.sec-blue-tint{background:linear-gradient(180deg,#eef3ff 0%,#f8faff 100%)!important}
.sec-orange-tint{background:linear-gradient(180deg,#fff7ed 0%,#fffdf9 100%)!important}
.sec-dot-bg{background-color:#fff;background-image:radial-gradient(circle,rgba(26,63,165,.07) 1px,transparent 1px)!important;background-size:22px 22px!important}

/* ── EVENTS PAGE — Filter strip + Stats strip overhaul ─────── */

/* Filter bar background */
div[style*="background:#fff;border-bottom:1px solid #e2e8f0;position:sticky"]{
  background:linear-gradient(90deg,#f8faff 0%,#fff 50%,#fff7ed 100%)!important;
  border-bottom:2px solid rgba(26,63,165,.12)!important;
  box-shadow:0 2px 12px rgba(26,63,165,.06)!important;
}

/* Filter buttons in events */
.event-filter-bar a.btn-primary,
.event-filter-bar a.btn.btn-primary{
  background:linear-gradient(135deg,#0f2878,#1a3fa5)!important;
  border:none!important;
  box-shadow:0 4px 14px rgba(26,63,165,.35)!important;
  color:#fff!important;
}
.event-filter-bar a.btn-outline-secondary{
  background:#fff!important;border:1.5px solid #e2e8f0!important;color:#64748b!important;
}
.event-filter-bar a.btn-outline-secondary:hover{
  background:#eff6ff!important;border-color:#1a3fa5!important;color:#1a3fa5!important;
}

/* Stats strip — give it a dramatic gradient + shadow */
.stats-strip{
  background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 55%,#e0f2fe 100%)!important;
  border-radius:16px!important;
  box-shadow:0 6px 28px rgba(26,63,165,.12)!important;
  padding:2rem 2.5rem!important;
  margin-top:0!important;
  border:1px solid rgba(26,63,165,.1)!important;
}
.stats-strip .stat-box .stat-num{
  color:#1a3fa5!important;
  font-size:2.6rem!important;
  text-shadow:none!important;
}
.stats-strip .stat-box .stat-num.orange{color:#ea580c!important}
.stats-strip .stat-box .stat-num.gold{color:#b45309!important}
.stats-strip .stat-box .stat-num.red{color:#dc2626!important}
.stats-strip .stat-box .stat-num.green{color:#16a34a!important}
.stats-strip .stat-box .stat-label,
.stats-strip .stat-box .stat-lbl{
  color:#475569!important;
  font-size:.72rem!important;
  text-transform:uppercase!important;
  letter-spacing:.09em!important;
  font-weight:600!important;
}
.stats-strip .col-6,.stats-strip .col-md-3{
  border-right:1px solid rgba(26,63,165,.1);
}
.stats-strip .col-6:last-child,.stats-strip .col-md-3:last-child{
  border-right:none;
}

/* EVENT CARDS — more dramatic date accent + card style */
.event-card{
  box-shadow:0 4px 20px rgba(0,0,0,.09)!important;
  border:none!important;
  background:#fff!important;
}
.event-card .date-accent{
  background:linear-gradient(180deg,#ea580c 0%,#c2410c 100%)!important;
  min-width:75px!important;
  padding:1.2rem .8rem!important;
}
.event-card .date-accent .day{
  font-size:2.4rem!important;
  text-shadow:0 2px 8px rgba(0,0,0,.2)!important;
}
.event-card:hover{
  transform:translateY(-10px) scale(1.015)!important;
  box-shadow:0 20px 56px rgba(0,0,0,.16)!important;
}
/* Completed events section heading */
section.py-3.pb-5 .section-title{
  font-size:1.6rem!important;
  background:linear-gradient(135deg,#1a3fa5,#ea580c);
  -webkit-background-clip:text!important;
  -webkit-text-fill-color:transparent!important;
  background-clip:text!important;
}

/* ── FORM INPUT improvements ───────────────────────────────── */
.form-control,.form-select{
  background:#fafbff!important;
}
.form-control:focus,.form-select:focus{
  background:#fff!important;
}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:768px){
  .page-hero,.page-header{padding:65px 0 58px!important}
  .gallery-item-v2{height:200px!important}
  .stats-strip{padding:1.4rem 1rem!important}
}
@media(max-width:576px){
  .page-hero,.page-header{padding:52px 0 46px!important}
  .gallery-item-v2{height:175px!important}
  .timeline{padding-left:2rem!important}
  .stats-strip .stat-box .stat-num{font-size:1.9rem!important}
}

/* ═══════════════════════════════════════════════════════════
   TASK 7 — GLOBAL LIGHT-MODE OVERRIDES (inner pages)
   ═══════════════════════════════════════════════════════════ */

/* ── Tab & filter bars across all pages ─────────────────── */
.ev-tabbar,.gallery-tabs,.filter-bar,.sort-bar{
  background:#f8faff!important;
  border:1px solid rgba(26,63,165,.1)!important;
  border-radius:14px!important;
}
.ev-tab-btn,.filter-btn,.gallery-tab-btn{
  color:#475569!important;
  background:transparent!important;
  border-radius:10px!important;
}
.ev-tab-btn.active,.filter-btn.active,.gallery-tab-btn.active{
  background:linear-gradient(135deg,#1a3fa5,#2563eb)!important;
  color:#fff!important;
  box-shadow:0 4px 14px rgba(26,63,165,.28)!important;
}

/* ── Generic inner section backgrounds ───────────────────── */
.section-light{
  background:linear-gradient(135deg,#f8faff 0%,#eff6ff 50%,#f0f9ff 100%)!important;
}
.section-alt{
  background:linear-gradient(135deg,#f1f5f9 0%,#e0e7ff 100%)!important;
}

/* ── CTA / promo banners on inner pages — softer ─────────── */
.inner-cta-section{
  background:linear-gradient(135deg,#1a3fa5 0%,#2563eb 55%,#0284c7 100%)!important;
}

/* ── Card improvements across all pages ─────────────────── */
.card{
  box-shadow:0 2px 16px rgba(0,0,0,.06)!important;
  border:1px solid rgba(0,0,0,.06)!important;
}
.card:hover{
  box-shadow:0 8px 32px rgba(26,63,165,.14)!important;
  transform:translateY(-3px);
}
.card.no-hover:hover{
  transform:none!important;
  box-shadow:0 2px 16px rgba(0,0,0,.06)!important;
}

/* ── Section heading / title consistency ─────────────────── */
.section-title{
  color:#0f172a!important;
}
.section-subtitle{
  color:#475569!important;
}

/* ── Badge refinements for light pages ───────────────────── */
.badge.bg-primary{background:#1a3fa5!important}
.badge.bg-secondary{background:#64748b!important}
.badge.bg-success{background:#16a34a!important}
.badge.bg-danger{background:#dc2626!important}
.badge.bg-warning{background:#d97706!important;color:#fff!important}
.badge.bg-info{background:#0284c7!important}

/* ── Timeline (about/history pages) ─────────────────────── */
.timeline-item::before{
  background:linear-gradient(180deg,#1a3fa5,#2563eb)!important;
}

/* ── Breadcrumb ──────────────────────────────────────────── */
.breadcrumb-item a{color:#1a3fa5!important}
.breadcrumb-item.active{color:#64748b!important}

/* ── Pagination ──────────────────────────────────────────── */
.page-item .page-link{color:#1a3fa5!important;border-color:#e2e8f0!important}
.page-item.active .page-link{
  background:linear-gradient(135deg,#1a3fa5,#2563eb)!important;
  border-color:transparent!important;
  color:#fff!important;
}

/* ── Table improvements ───────────────────────────────────── */
.table thead th{
  background:linear-gradient(135deg,#1a3fa5,#2563eb)!important;
  color:#fff!important;
  font-weight:600!important;
  letter-spacing:.03em!important;
}
.table tbody tr:hover{background:rgba(26,63,165,.04)!important}

/* ── Form control focus glow ─────────────────────────────── */
.form-control:focus,.form-select:focus{
  border-color:rgba(26,63,165,.45)!important;
  box-shadow:0 0 0 .25rem rgba(26,63,165,.12)!important;
}

/* ── Alert boxes softer ───────────────────────────────────── */
.alert-info{background:#eff6ff!important;border-color:#bfdbfe!important;color:#1e40af!important}
.alert-success{background:#f0fdf4!important;border-color:#bbf7d0!important;color:#166534!important}
.alert-warning{background:#fffbeb!important;border-color:#fde68a!important;color:#92400e!important}
.alert-danger{background:#fef2f2!important;border-color:#fecaca!important;color:#991b1b!important}

/* ── Responsive padding ──────────────────────────────────── */
@media(max-width:768px){
  .stats-strip{padding:1.2rem .8rem!important}
  .stats-strip .stat-box .stat-num{font-size:1.8rem!important}
}


