/* ============================================================
   JOAF v8.0 — Energetic & Dynamic Design System
   ============================================================ */
@import url('https://fonts.maateen.me/bensen-handwriting/font.css');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+Bengali:wght@400;600;700;800;900&display=swap');
:root{
  --brand:#90161f;--brand2:#b91c1c;--brand-glow:rgba(144,22,31,.4);
  --accent:#075e55;--accent2:#15803d;--accent-glow:rgba(7,94,85,.4);
  --gold:#c9a227;--gold2:#f59e0b;--gold-glow:rgba(201,162,39,.45);
  --dark:#0d0d1a;--dark2:#16213e;--dark3:#0a1628;
  --light:#f8f9fa;--text:#1a202c;--muted:#6b7280;
  --shadow:0 4px 24px rgba(0,0,0,.10);
  --shadow-lg:0 16px 48px rgba(0,0,0,.18);
  --shadow-xl:0 32px 80px rgba(0,0,0,.25);
  --radius:16px;--radius-sm:10px;
  --tr:.3s cubic-bezier(.4,0,.2,1);
  --tr-spring:.55s cubic-bezier(.34,1.56,.64,1);
  --tr-bounce:.6s cubic-bezier(.68,-.55,.265,1.55);
  --font:'BenSen Handwriting','Noto Sans Bengali','Siyam Rupali',Arial,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;}
a,button{touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
html{scroll-behavior:smooth;}
img{max-width:100%;height:auto;}
body{font-family:var(--font);color:var(--text);}.wrapper{overflow-x:hidden;}
@media(pointer:fine){body{cursor:none;}}

@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulse-ring{0%{box-shadow:0 0 0 0 var(--brand-glow)}70%{box-shadow:0 0 0 16px rgba(144,22,31,0)}100%{box-shadow:0 0 0 0 rgba(144,22,31,0)}}
@keyframes bounce-y{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(10px)}}
@keyframes shine-text{0%{background-position:0% center}100%{background-position:250% center}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes spin-slow{to{transform:rotate(360deg)}}
@keyframes gradient-shift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes pl-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
@keyframes pl-bar{0%{transform:translateX(-100%)}100%{transform:translateX(200%)}}
@keyframes fade-up{0%{opacity:0;transform:translateY(30px)}100%{opacity:1;transform:translateY(0)}}
@keyframes ticker-scroll{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}
@keyframes hero-float-1{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-22px) rotate(4deg)}}
@keyframes hero-float-2{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
@keyframes glow-pulse{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}
@keyframes particle-drift{0%{transform:translateY(0);opacity:.9}100%{transform:translateY(-90px) translateX(20px);opacity:0}}

/* PRELOADER */
#joaf-preloader{position:fixed;inset:0;z-index:999999;background:var(--dark);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .7s ease,visibility .7s ease;}
#joaf-preloader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.preloader-logo{width:90px;animation:pl-pulse 1.4s ease-in-out infinite;}
.preloader-text{color:rgba(255,255,255,.6);margin-top:16px;font-size:13px;letter-spacing:3px;text-transform:uppercase;}
.preloader-bar{width:220px;height:2px;background:rgba(255,255,255,.1);border-radius:2px;margin-top:20px;overflow:hidden;}
.preloader-bar::after{content:'';display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--gold),var(--accent));background-size:300% 100%;animation:gradient-shift 1.8s ease infinite,pl-bar 1.6s ease infinite;}

/* SCROLL REVEAL */
.joaf-reveal{opacity:0;transform:translateY(40px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1);}
.joaf-reveal.visible{opacity:1;transform:translateY(0);}
.joaf-reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.joaf-reveal-left.visible{opacity:1;transform:translateX(0);}
.joaf-reveal-right{opacity:0;transform:translateX(50px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
.joaf-reveal-right.visible{opacity:1;transform:translateX(0);}
.joaf-reveal-scale{opacity:0;transform:scale(.85) translateY(20px);transition:opacity .65s cubic-bezier(.34,1.56,.64,1),transform .65s cubic-bezier(.34,1.56,.64,1);}
.joaf-reveal-scale.visible{opacity:1;transform:scale(1) translateY(0);}
.joaf-reveal-flip{opacity:0;transform:perspective(600px) rotateX(18deg) translateY(30px);transition:opacity .68s cubic-bezier(.16,1,.3,1),transform .68s cubic-bezier(.16,1,.3,1);}
.joaf-reveal-flip.visible{opacity:1;transform:perspective(600px) rotateX(0) translateY(0);}
.joaf-reveal-zoom{opacity:0;transform:scale(.92);filter:blur(6px);transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1),filter .85s ease;}
.joaf-reveal-zoom.visible{opacity:1;transform:scale(1);filter:blur(0);}
.joaf-reveal-top{opacity:0;transform:translateY(-40px);transition:opacity .75s cubic-bezier(.16,1,.3,1),transform .75s cubic-bezier(.16,1,.3,1);}
.joaf-reveal-top.visible{opacity:1;transform:translateY(0);}

.delay-1{transition-delay:.07s!important;}.delay-2{transition-delay:.14s!important;}
.delay-3{transition-delay:.21s!important;}.delay-4{transition-delay:.28s!important;}
.delay-5{transition-delay:.36s!important;}.delay-6{transition-delay:.44s!important;}
.section-heading::after{transform:scaleX(0);transform-origin:left;transition:transform .65s cubic-bezier(.16,1,.3,1) .28s;}
.section-heading.visible::after{transform:scaleX(1);}
.pulse-btn{animation:pulse-ring 2.2s ease infinite;}
.float-anim{animation:float 3.5s ease-in-out infinite;}

/* HEADER */
.joaf-header{position:sticky;top:0;z-index:2000;background:rgba(255,255,255,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:2px solid transparent;box-shadow:0 2px 20px rgba(0,0,0,.08);transition:all .35s ease;;overflow:visible;}
.joaf-header.scrolled{background:rgba(255,255,255,.99);border-bottom-color:var(--brand);box-shadow:0 4px 32px rgba(0,0,0,.13);}
.joaf-header-top{background:linear-gradient(135deg,var(--dark),var(--dark2));padding:5px 0;}
.joaf-header-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;}
.joaf-header-meta span{color:rgba(255,255,255,.8);font-size:12px;display:flex;align-items:center;gap:5px;}
.joaf-header-main{padding:0;overflow:visible;}
.joaf-header-row{display:flex;align-items:center;justify-content:space-between;min-height:54px;gap:8px;flex-wrap:nowrap;}
.joaf-header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.joaf-logo img{max-width:95px;height:auto;display:block;padding:4px 0;}
.joaf-logo:hover img{transform:scale(1.06);}

/* DESKTOP NAV */
.joaf-desktop-nav{display:flex;align-items:center;}
.joaf-desktop-nav>ul{display:flex;list-style:none;margin:0;padding:0;gap:0;align-items:center;}
.joaf-desktop-nav>ul>li{position:relative;}
.joaf-desktop-nav>ul>li>a{display:flex;align-items:center;gap:4px;font-size:12.5px;font-weight:700;padding:6px 7px;white-space:nowrap;color:var(--text);text-decoration:none;position:relative;transition:color .25s;}
.joaf-desktop-nav>ul>li>a::after{content:'';position:absolute;bottom:0;left:7px;right:7px;height:2.5px;background:linear-gradient(90deg,var(--brand),var(--gold));border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.joaf-desktop-nav>ul>li>a:hover{color:var(--brand);}
.joaf-desktop-nav>ul>li>a:hover::after,.joaf-desktop-nav>ul>li.active>a::after{transform:scaleX(1);}
.joaf-desktop-nav>ul>li.active>a{color:var(--brand);}
.joaf-desktop-nav>ul>li.nav-cta>a{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff!important;border-radius:50px;padding:7px 16px!important;box-shadow:0 3px 12px var(--brand-glow);transition:all .3s!important;}
.joaf-desktop-nav>ul>li.nav-cta>a:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--brand-glow);}
.joaf-desktop-nav>ul>li.nav-cta>a::after{display:none!important;}
/* Legacy compat */
#main-menu{display:flex;align-items:center;}
#main-menu ul{display:flex;list-style:none;margin:0;padding:0;gap:0;align-items:center;}
#main-menu ul li>a{display:block;font-size:12.5px;font-weight:700;padding:6px 7px;white-space:nowrap;color:var(--text);text-decoration:none;position:relative;transition:color .25s;}
#main-menu ul li>a::after{content:'';position:absolute;bottom:0;left:7px;right:7px;height:2.5px;background:linear-gradient(90deg,var(--brand),var(--gold));border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
#main-menu ul li>a:hover{color:var(--brand);}
#main-menu ul li>a:hover::after,#main-menu ul li.active>a::after{transform:scaleX(1);}
#main-menu ul li.active>a{color:var(--brand);}

/* HAMBURGER */
.joaf-hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:var(--brand);border:none;border-radius:10px;cursor:pointer;gap:5px;padding:10px;flex-shrink:0;transition:all .25s;box-shadow:0 2px 10px var(--brand-glow);}
.joaf-hamburger:hover{background:var(--brand2);transform:scale(1.06);}
.joaf-hamburger:active{transform:scale(.93);}
.joaf-hamburger-bar{width:22px;height:2.5px;background:#fff;border-radius:2px;transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .22s ease,width .25s ease;transform-origin:center;}
.joaf-hamburger--open .joaf-hamburger-bar:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.joaf-hamburger--open .joaf-hamburger-bar:nth-child(2){opacity:0;width:0;}
.joaf-hamburger--open .joaf-hamburger-bar:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* MOBILE NAV */
.joaf-mobile-nav{position:fixed;inset:0;z-index:99999;pointer-events:none;}
.joaf-mnav-backdrop{position:absolute;inset:0;background:rgba(5,5,15,.78);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;transition:opacity .35s ease;}
.joaf-mnav-panel{position:absolute;top:0;right:0;bottom:0;width:min(320px,85vw);background:linear-gradient(160deg,#0d0d1a 0%,#1a0810 50%,#071a16 100%);transform:translateX(100%);transition:transform .38s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:-10px 0 50px rgba(0,0,0,.65);}
.joaf-mnav--open{pointer-events:auto;}
.joaf-mnav--open .joaf-mnav-backdrop{opacity:1;}
.joaf-mnav--open .joaf-mnav-panel{transform:translateX(0);}
.joaf-mnav-head{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;}
.joaf-mnav-brand{display:flex;align-items:center;gap:12px;}
.joaf-mnav-logo{width:40px;height:40px;object-fit:contain;filter:brightness(10);border-radius:8px;background:rgba(255,255,255,.07);padding:4px;}
.joaf-mnav-name{color:#fff;font-weight:900;font-size:15px;line-height:1;}
.joaf-mnav-tagline{color:rgba(255,255,255,.4);font-size:10px;margin-top:3px;letter-spacing:.5px;}
.joaf-mnav-close{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;}
.joaf-mnav-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg);}
.joaf-mnav-nav{padding:12px 0;flex:1;}
.joaf-mnav-nav ul{list-style:none;margin:0;padding:0 16px;}
.mnav-item{margin-bottom:4px;}
.mnav-link{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-radius:12px;color:rgba(255,255,255,.88);text-decoration:none;font-size:15px;font-weight:700;transition:background .2s,color .2s,transform .15s;border:1px solid rgba(255,255,255,0);}
.mnav-link:active{transform:scale(.97);}
.mnav-link:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1);color:#fff;}
.mnav-link--active{background:linear-gradient(135deg,rgba(144,22,31,.35),rgba(7,94,85,.3));color:var(--gold)!important;border-color:rgba(201,162,39,.22)!important;}
.mnav-label{flex:1;}
.mnav-arrow{font-size:18px;opacity:.35;transition:opacity .2s,transform .2s;}
.mnav-link:hover .mnav-arrow{opacity:.8;transform:translateX(3px);}
.joaf-mnav-footer{padding:16px 20px 28px;border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex-shrink:0;}
.joaf-mnav-social{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.8);font-size:18px;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all .2s;}
.joaf-mnav-social:hover{background:rgba(255,255,255,.2);color:#fff;transform:scale(1.1);}
.joaf-mnav-cta{margin-left:auto;background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;font-weight:800;font-size:13px;padding:9px 18px;border-radius:50px;text-decoration:none;transition:all .25s;white-space:nowrap;}
.joaf-mnav-cta:hover{transform:scale(1.05);color:#fff;}

/* TICKER */
.announcement-ticker{background:linear-gradient(90deg,var(--brand) 0%,#5a0b10 40%,var(--accent) 100%);color:#fff;padding:9px 0;overflow:hidden;position:relative;z-index:5;}
.ticker-label{position:absolute;left:0;top:0;bottom:0;background:rgba(0,0,0,.42);padding:0 14px;display:flex;align-items:center;font-weight:800;font-size:12px;white-space:nowrap;z-index:2;min-width:82px;letter-spacing:.5px;}
.ticker-track{display:flex;white-space:nowrap;padding-left:96px;will-change:transform;transform:translateZ(0);}
.ticker-track:hover{cursor:pointer;}
.ticker-item{white-space:nowrap;padding:0 32px;font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:4px;}
.ticker-item a{color:#fff;text-decoration:none;transition:opacity .2s;}
.ticker-item a:hover{opacity:.85;text-decoration:underline;}
.ticker-sep{opacity:.3;padding:0 6px;font-size:9px;}

/* HERO */
.cinematic-hero{position:relative;width:100%;background:var(--dark);}
.ch-video-wrap{position:relative;width:100%;padding-top:56.25%;overflow:hidden;}
.ch-video-wrap video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center center;display:block;}
.ch-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,13,26,.62) 0%,rgba(13,13,26,.05) 30%,rgba(13,13,26,.05) 60%,rgba(13,13,26,.92) 100%);z-index:1;pointer-events:none;}
.ch-content{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;text-align:center;color:#fff;padding:0 20px 36px;}
@media(min-width:768px){
  .cinematic-hero{height:100vh;min-height:560px;overflow:hidden;}
  .ch-video-wrap{position:absolute;inset:0;padding-top:0;overflow:visible;}
  .ch-video-wrap video{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;}
  .ch-content{position:absolute;inset:0;justify-content:center;padding:0 8% 80px;align-items:flex-start;text-align:left;background:none;}
}

/* Hero decorative ring - desktop only */
.ch-deco-ring{display:none;}
@media(min-width:768px){
  .ch-deco-ring{
    display:block;position:absolute;z-index:1;pointer-events:none;
    right:6%;top:50%;transform:translateY(-50%);
    width:min(480px,40vw);height:min(480px,40vw);
    border-radius:50%;
    border:1px solid rgba(255,255,255,.07);
    animation:spin-slow 28s linear infinite;
  }
  .ch-deco-ring::before{content:'';position:absolute;inset:35px;border-radius:50%;border:1px solid rgba(201,162,39,.14);animation:spin-slow 18s linear infinite reverse;}
  .ch-deco-ring::after{content:'';position:absolute;inset:75px;border-radius:50%;border:1px solid rgba(144,22,31,.18);}
  .ch-deco-dot1{position:absolute;z-index:1;width:7px;height:7px;border-radius:50%;background:var(--gold);right:23%;top:22%;animation:hero-float-1 4.5s ease-in-out infinite;box-shadow:0 0 18px var(--gold-glow);pointer-events:none;}
  .ch-deco-dot2{position:absolute;z-index:1;width:5px;height:5px;border-radius:50%;background:var(--brand2);right:18%;bottom:30%;animation:hero-float-2 5.5s ease-in-out infinite;box-shadow:0 0 14px var(--brand-glow);pointer-events:none;}
  .ch-deco-dot3{position:absolute;z-index:1;width:9px;height:9px;border-radius:50%;background:var(--accent);right:36%;top:38%;animation:hero-float-1 6s ease-in-out infinite .6s;box-shadow:0 0 20px var(--accent-glow);pointer-events:none;}
}

.ch-tag{background:rgba(144,22,31,.88);backdrop-filter:blur(10px);color:#fff;font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;padding:6px 16px;border-radius:50px;margin-bottom:16px;border:1px solid rgba(255,255,255,.18);display:inline-flex;align-items:center;gap:6px;opacity:1;visibility:visible;}
.ch-tag-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:glow-pulse 1.5s ease infinite;}

#hero-title,.ch-content h1{font-size:clamp(1.7rem,6vw,3.8rem);font-weight:900;line-height:1.12;margin-bottom:16px;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.5);}

.ch-content p{font-size:clamp(.88rem,2.2vw,1.05rem);opacity:.9;max-width:560px;margin-bottom:28px;line-height:1.75;text-shadow:0 2px 14px rgba(0,0,0,.55);}
@media(min-width:768px){.ch-content p{margin-bottom:32px;}}

.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
@media(min-width:768px){.hero-cta{justify-content:flex-start;}}
@media(max-width:767px){.hero-cta{justify-content:center;}}
.hero-cta a{padding:13px 28px;border-radius:50px;font-weight:700;font-size:14.5px;text-decoration:none;transition:all .38s var(--tr-spring);display:inline-flex;align-items:center;gap:8px;}
.cta-primary{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;box-shadow:0 6px 24px var(--brand-glow);}
.cta-primary:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 14px 38px var(--brand-glow);color:#fff;}
.cta-outline{border:2px solid rgba(255,255,255,.65);color:#fff;backdrop-filter:blur(6px);background:rgba(255,255,255,.07);}
.cta-outline:hover{background:rgba(255,255,255,.18);transform:translateY(-4px);color:#fff;border-color:rgba(255,255,255,.9);}

.hero-badges{display:flex;gap:8px;flex-wrap:wrap;}
@media(min-width:768px){.hero-badges{justify-content:flex-start;}}
@media(max-width:767px){.hero-badges{justify-content:center;}}
.hero-badge{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);padding:5px 13px;border-radius:50px;font-size:12px;font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:5px;transition:all .25s;}
.hero-badge:hover{background:rgba(255,255,255,.2);transform:scale(1.06);}

.scroll-hint{position:absolute;bottom:px;left:50%;transform:translateX(-50%);z-index:3;animation:bounce-y 2s ease infinite;cursor:pointer;}
.scroll-hint i{color:rgba(255,255,255,.55);font-size:28px;}

/* MUTE BUTTON */
.mute-toggle{position:absolute!important;bottom:20px!important;left:18px!important;z-index:100!important;width:48px!important;height:48px!important;border-radius:50%!important;background:rgba(0,0,0,.55)!important;backdrop-filter:blur(12px)!important;-webkit-backdrop-filter:blur(12px)!important;border:2px solid rgba(255,255,255,.35)!important;color:#fff!important;font-size:20px!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;transition:all .25s!important;-webkit-tap-highlight-color:transparent!important;pointer-events:auto!important;visibility:visible!important;opacity:1!important;line-height:1!important;padding:0!important;}
.mute-toggle:hover{background:rgba(0,0,0,.82)!important;transform:scale(1.12)!important;border-color:rgba(255,255,255,.6)!important;}
.mute-toggle:active{transform:scale(.9)!important;}

/* STATS BAR */
.stats-bar{background:linear-gradient(135deg,var(--brand) 0%,#5a0b10 50%,var(--accent) 100%);background-size:200% 200%;animation:gradient-shift 8s ease infinite;padding:0px 0;color:#fff;position:relative;overflow:hidden;}
.stats-bar::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:shimmer 3s ease infinite;background-size:200% 100%;pointer-events:none;z-index:0;}
.stat-item{text-align:center;position:relative;transition:transform .35s var(--tr-spring);z-index:1;}
.stat-item:hover{transform:translateY(-4px);}
.stat-item+.stat-item::before{content:'';position:absolute;left:0;top:15%;bottom:15%;width:1px;background:rgba(255,255,255,.18);}
.stat-number{font-size:2.4rem;font-weight:900;line-height:1;letter-spacing:-1px;}
.stat-label{font-size:12.5px;opacity:.8;margin-top:5px;letter-spacing:.3px;}

/* SECTION HEADINGS */
.section-heading{text-align:center;margin-bottom:52px;position:relative;}
.section-heading h2{color:var(--brand);font-size:clamp(1.6rem,4vw,2.3rem);font-weight:900;display:inline-block;}
.section-heading p{color:var(--muted);font-size:15px;max-width:580px;margin:10px auto 0;line-height:1.7;}
.section-heading::after{content:'';display:block;width:56px;height:3px;background:linear-gradient(90deg,var(--brand),var(--gold));margin:14px auto 0;border-radius:2px;}

/* MEMBER CARDS - 3D */
.member-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .5s var(--tr-spring),box-shadow .5s ease;position:relative;cursor:pointer;transform-style:preserve-3d;will-change:transform;}
.member-card:hover{transform:translateY(-14px) scale(1.025) rotateY(-2deg);box-shadow:0 30px 70px rgba(144,22,31,.25),0 0 0 1.5px rgba(144,22,31,.12);}
.member-card-img-wrap{position:relative;overflow:hidden;height:280px;}
.member-card-img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;transition:transform .7s cubic-bezier(.25,0,.25,1),filter .45s ease;filter:brightness(1.05) saturate(1.08);}
.member-card:hover .member-card-img{transform:scale(1.1);filter:brightness(1.12) saturate(1.15);}
.member-card-img-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 38%,rgba(13,13,26,.15) 65%,rgba(13,13,26,.7) 100%);opacity:.75;transition:opacity .45s;}
.member-card:hover .member-card-img-wrap::after{opacity:1;}
.member-role-badge{position:absolute;top:12px;left:12px;z-index:2;background:rgba(144,22,31,.88);backdrop-filter:blur(6px);color:#fff;font-size:10px;font-weight:800;padding:4px 11px;border-radius:50px;letter-spacing:.4px;border:1px solid rgba(255,255,255,.2);transition:background .3s,transform .3s;}
.member-card:hover .member-role-badge{background:rgba(7,94,85,.92);transform:scale(1.06);}
.member-num-badge{position:absolute;top:12px;right:12px;z-index:2;width:29px;height:29px;border-radius:50%;background:rgba(201,162,39,.92);backdrop-filter:blur(6px);color:#fff;font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25);}
.member-card-body{padding:18px 16px 16px;background:linear-gradient(160deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);color:#fff;text-align:center;position:relative;overflow:hidden;}
.member-card-body::before{content:'';position:absolute;top:-30px;left:50%;transform:translateX(-50%);width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,39,.15),transparent 70%);}
.member-card-body h4{font-size:.95rem;font-weight:800;margin-bottom:4px;color:#fff;position:relative;}
.member-card-body .role-text{font-size:11px;color:rgba(201,162,39,.92);font-weight:700;margin-bottom:12px;letter-spacing:.3px;}
.member-card-body .actions{display:flex;gap:7px;justify-content:center;flex-wrap:wrap;}
.btn-fb{background:rgba(59,89,152,.85);color:#fff;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;text-decoration:none;transition:all .25s;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(255,255,255,.1);}
.btn-fb:hover{background:#3b5998;color:#fff;transform:scale(1.07);}
.btn-bio{background:rgba(201,162,39,.85);color:#fff;padding:5px 12px;border-radius:20px;font-size:11px;font-weight:700;text-decoration:none;transition:all .25s;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(255,255,255,.1);}
.btn-bio:hover{background:var(--gold);color:#fff;transform:scale(1.07);}
.member-card::after{content:'';position:absolute;top:0;left:-100%;width:55%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transform:skewX(-18deg);transition:left .65s ease;pointer-events:none;z-index:4;}
.member-card:hover::after{left:160%;}

/* PERSON CARDS */
.person-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:all var(--tr);height:100%;}
.person-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);}
.person-card .card-img-wrap{height:240px;overflow:hidden;position:relative;}
.person-card .card-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s ease;filter:brightness(1.04);}
.person-card:hover .card-img-wrap img{transform:scale(1.07);}
.person-card .card-info{padding:16px;}
.person-card .card-info h3{font-size:15px;font-weight:700;margin-bottom:4px;color:var(--brand);}
.person-card .card-info p{font-size:13px;color:var(--muted);margin:0;}
.card-socials{padding:0 16px 14px;display:flex;gap:8px;}
.card-socials a{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;text-decoration:none;transition:all .2s;}
.card-socials .fb{background:#e8edf8;color:#3b5998;}.card-socials .fb:hover{background:#3b5998;color:#fff;}
.card-socials .info,.card-socials .info-btn{background:#e8f8f5;color:var(--accent);}
.card-socials .info:hover,.card-socials .info-btn:hover{background:var(--accent);color:#fff;}

/* PRESS CARDS */
.press-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:all var(--tr);display:flex;flex-direction:column;height:100%;position:relative;}
.press-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);}
.press-card-img-wrap{overflow:hidden;height:200px;position:relative;flex-shrink:0;}
.press-card-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.press-card:hover .press-card-img-wrap img{transform:scale(1.06);}
.press-date-top{position:absolute;top:10px;left:10px;background:var(--brand);color:#fff;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.press-date-bottom{position:absolute;bottom:10px;right:10px;background:var(--accent);color:#fff;padding:3px 10px;border-radius:20px;font-size:11px;}
.press-card-body{padding:16px;flex:1;display:flex;flex-direction:column;}
.press-card-body h4{font-size:.95rem;font-weight:700;margin-bottom:8px;color:var(--brand);}
.press-card-body p{font-size:13px;color:var(--muted);flex:1;line-height:1.7;}
.press-read-more{display:inline-flex;align-items:center;gap:6px;margin-top:12px;color:var(--brand);font-weight:700;font-size:13px;text-decoration:none;transition:gap .22s;}
.press-read-more:hover{gap:10px;}
.share-row{display:flex;gap:7px;margin-top:10px;flex-wrap:wrap;}
.share-row a{padding:4px 10px;border-radius:20px;font-size:11px;color:#fff;text-decoration:none;transition:all .2s;}
.share-row a:hover{opacity:.85;color:#fff;transform:scale(1.06);}
.s-fb{background:#3b5998;}.s-wa{background:#25d366;}.s-tw{background:#1da1f2;}

/* COMMUNITY */
.comm-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:all var(--tr);position:relative;}
.comm-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.comm-cover{height:80px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;color:#fff;letter-spacing:.5px;text-align:center;padding:0 8px;}
.comm-cover.cat-main{background:linear-gradient(135deg,#90161f,#b91c1c);}
.comm-cover.cat-regional{background:linear-gradient(135deg,#075e55,#15803d);}
.comm-cover.cat-intl{background:linear-gradient(135deg,#1a1a2e,#2563eb);}
.comm-cover.cat-special{background:linear-gradient(135deg,#7c3aed,#a855f7);}
.comm-cover.cat-expand{background:linear-gradient(135deg,#c9a227,#f59e0b);}
.comm-ribbon{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.3);color:#fff;font-size:10px;padding:2px 8px;border-radius:20px;font-weight:700;}
.comm-body{padding:14px;}
.comm-body h3{font-size:14px;font-weight:700;margin-bottom:5px;color:var(--text);}
.comm-body p{font-size:12px;color:var(--muted);margin-bottom:10px;}
.comm-join-btn{display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;padding:7px 14px;border-radius:20px;font-size:12px;font-weight:700;text-decoration:none;transition:all var(--tr);}
.comm-join-btn:hover{transform:scale(1.06);color:#fff;box-shadow:0 4px 14px rgba(37,211,102,.4);}
.comm-join-btn.no-link{background:linear-gradient(135deg,#6b7280,#9ca3af);pointer-events:none;opacity:.75;border:2px dashed rgba(255,255,255,.4);}
.comm-map{height:80px;width:100%;z-index:1;}

/* ABOUT/VISION/MOVEMENT */
.about-highlight{background:linear-gradient(135deg,#fff8f8,#f0fffe);border-left:5px solid var(--brand);border-radius:0 var(--radius) var(--radius) 0;padding:22px 26px;margin-bottom:18px;transition:all var(--tr);}
.about-highlight:hover{transform:translateX(6px);border-left-color:var(--accent);box-shadow:var(--shadow);}
.vision-box{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;height:100%;position:relative;overflow:hidden;transition:all var(--tr);}
.vision-box:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);}
.vision-box::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;}
.vision-box.vision::before{background:linear-gradient(90deg,var(--brand),var(--gold));}
.vision-box.mission::before{background:linear-gradient(90deg,var(--accent),var(--accent2));}
.movement-card{background:#fff;border-radius:var(--radius);padding:28px 24px;height:100%;box-shadow:var(--shadow);transition:all var(--tr);border-top:4px solid var(--brand);position:relative;overflow:hidden;}
.movement-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-top-color:var(--accent);}
.movement-icon{font-size:2.4rem;margin-bottom:14px;line-height:1;display:block;}
.movement-card h4{font-size:1rem;font-weight:800;color:var(--brand);margin-bottom:10px;}
.movement-card p{font-size:14px;color:var(--muted);line-height:1.7;margin:0;}
.movement-card-cta{background:linear-gradient(135deg,var(--dark),var(--dark2));border-top-color:var(--gold);color:#fff;}
.movement-card-cta h4{color:var(--gold);}
.movement-card-cta p{color:rgba(255,255,255,.75);}
.movement-join-btn{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:9px 20px;background:linear-gradient(90deg,var(--brand),var(--gold));color:#fff;border-radius:30px;font-size:13px;font-weight:700;text-decoration:none;transition:all var(--tr);}
.movement-join-btn:hover{transform:translateX(5px);color:#fff;box-shadow:0 6px 18px var(--gold-glow);}

/* QA BUTTONS */
.qa-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 18px;border-radius:var(--radius);font-weight:700;font-size:15px;text-decoration:none;color:#fff;transition:all .38s var(--tr-spring);border:none;width:100%;cursor:pointer;font-family:var(--font);position:relative;overflow:hidden;}
.qa-btn:hover{transform:translateY(-5px) scale(1.01);box-shadow:var(--shadow-xl);color:#fff;}
.qa-btn i{font-size:20px;transition:transform .38s var(--tr-bounce);}
.qa-btn:hover i{transform:scale(1.22) rotate(-5deg);}
.qa-btn.financial{background:linear-gradient(135deg,var(--brand),var(--brand2));}
.qa-btn.join,.qa-btn.join-btn-qa{background:linear-gradient(135deg,var(--accent),var(--accent2));}
.qa-btn.policy{background:linear-gradient(135deg,var(--dark),var(--dark2));}

/* GALLERY FILTER */
.gallery-filter{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:36px;}
.gallery-filter button{padding:9px 20px;border-radius:50px;border:2px solid #e5e7eb;background:#fff;font-family:var(--font);font-size:12.5px;font-weight:700;cursor:pointer;transition:all .28s;color:#374151;}
.gallery-filter button:hover{border-color:var(--brand);color:var(--brand);transform:scale(1.04);}
.gallery-filter button.active{background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border-color:transparent;box-shadow:0 4px 16px var(--brand-glow);transform:scale(1.05);}

/* FORMS */
.joaf-form-wrap{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:36px;position:relative;overflow:hidden;}
.joaf-form-wrap::before{content:'';position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--brand),var(--gold),var(--accent));}
.joaf-form-wrap .form-group{margin-bottom:18px;}
.joaf-form-wrap label{display:block;font-weight:700;font-size:14px;margin-bottom:6px;color:var(--text);}
.joaf-form-wrap label .req{color:var(--brand);}
.joaf-form-wrap input,.joaf-form-wrap select,.joaf-form-wrap textarea{width:100%;padding:12px 15px;border:2px solid #e5e7eb;border-radius:10px;font-size:15px;font-family:var(--font);transition:.3s;background:#fdfdfd;}
.joaf-form-wrap input:focus,.joaf-form-wrap select:focus,.joaf-form-wrap textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(144,22,31,.1);background:#fff;}
.joaf-submit-btn{background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;border:none;width:100%;padding:15px;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;transition:.3s;font-family:var(--font);margin-top:6px;}
.joaf-submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2);}
.joaf-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none;}
.form-success{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#166534;padding:16px 20px;border-radius:12px;margin-top:16px;font-weight:600;display:none;border-left:4px solid #16a34a;text-align:center;}
.form-error{background:#fee2e2;color:#991b1b;padding:14px 18px;border-radius:10px;margin-top:12px;display:none;border-left:4px solid #dc2626;}
.form-section-head{background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;padding:10px 16px;border-radius:10px;font-weight:700;font-size:14px;margin-bottom:16px;margin-top:8px;display:flex;align-items:center;gap:8px;}

/* POLLS */
.poll-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;margin-bottom:20px;position:relative;overflow:hidden;}
.poll-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--brand),var(--gold),var(--accent));}
.poll-q{font-weight:800;font-size:15px;margin-bottom:14px;color:var(--text);}
.poll-opt-btn{width:100%;text-align:left;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;padding:10px 14px;margin-bottom:8px;cursor:pointer;font-family:var(--font);font-size:14px;font-weight:600;transition:all .2s;position:relative;overflow:hidden;}
.poll-opt-btn:hover{border-color:var(--brand);background:#fff8f8;}
.poll-opt-btn.voted-this{background:linear-gradient(135deg,var(--brand),var(--accent));color:#fff;border-color:transparent;}
.poll-opt-btn:disabled{cursor:default;}
.poll-opt-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(144,22,31,.1);transition:width .7s ease;pointer-events:none;border-radius:8px;}
.poll-opt-pct{float:right;font-weight:700;font-size:12px;position:relative;z-index:1;}

/* FOOTER */
.footer-area{background:var(--dark);color:rgba(255,255,255,.82);padding:55px 0 0;}
.footer-area h4{color:#fff;font-size:1.05rem;margin-bottom:16px;font-weight:700;}
.footer-area ul{list-style:none;padding:0;}
.footer-area ul li{margin-bottom:7px;}
.footer-area ul li a{color:rgba(255,255,255,.72);text-decoration:none;font-size:14px;transition:.2s;}
.footer-area ul li a:hover{color:#fff;padding-left:4px;}
.footer-area p{color:rgba(255,255,255,.72);font-size:14px;line-height:1.7;}
.footer-area a{color:rgba(255,255,255,.72);text-decoration:none;transition:.2s;}
.footer-area a:hover{color:#fff;}
.footer-bottom{background:rgba(0,0,0,.35);padding:16px 0;margin-top:40px;text-align:center;}
.footer-bottom p{font-size:13px;margin:0;color:rgba(255,255,255,.55);}
.footer-bottom a{color:var(--gold);margin:0 6px;}
.footer-bottom a:hover{color:#fff;}

/* UTILS */
.section{padding:68px 0;}
.section-sm{padding:32px 0;}
.bg-subtle{background:linear-gradient(180deg,#f8f9fa,#f0f4f8);}
.gradient-text{background:linear-gradient(135deg,var(--brand),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.tag-chip{display:inline-block;background:var(--brand);color:#fff;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;}
.hero-area{margin-top:0!important;}

/* DESKTOP ENHANCEMENTS */
@media(min-width:768px){
  .section-heading{text-align:left;}
  .section-heading::after{margin:14px 0 0;}
  .movement-cards-wrap{grid-template-columns:repeat(3,1fr);}
  .quick-actions{padding:28px 0;}
}

/* MOBILE */
@media(max-width:767px){
  .joaf-header-meta span{font-size:11px;}
  .joaf-logo img{max-width:72px!important;}
  .ticker-label{min-width:60px;font-size:11px;padding:0 10px;}
  /* ticker speed set by JS */
  .ticker-item{padding:0 18px;font-size:12px;}
  .ch-content{padding:0 16px 28px;}
  .hero-cta{gap:8px;}
  .hero-cta a{padding:11px 20px;font-size:13px;}
  .hero-badge{font-size:10.5px;}
  .mute-toggle{bottom:54px!important;left:1px!important;width:42px!important;height:42px!important;font-size:18px!important;}
  .stat-number{font-size:1.75rem;}
  .section-heading{margin-bottom:30px;text-align:center;}
  .section-heading h2{font-size:1.45rem;}
  .section-heading::after{margin:14px auto 0;}
  .section{padding:38px 0;}
  .member-card-img-wrap{height:220px;}
  .press-card-img-wrap{height:165px;}
  .joaf-form-wrap{padding:22px 14px;}
  .footer-area{padding:36px 0 0;}
  .footer-area .col-md-4{margin-bottom:24px;}
  .gallery-filter{gap:6px;}
  .gallery-filter button{padding:6px 13px;font-size:11.5px;}
  .comm-grid{grid-template-columns:1fr!important;}
  .movement-cards-wrap{grid-template-columns:1fr;}
  #contact-area .col-lg-5{flex:0 0 100%;max-width:100%;}
}

@media(max-width:480px){
  #hero-title,.ch-content h1{font-size:1.55rem;}
  .section-heading h2{font-size:1.28rem;}
  .hero-cta{flex-direction:column;align-items:center;}
  .hero-cta a{width:100%;max-width:260px;justify-content:center;}
  /* ticker speed set by JS */
  .section{padding:28px 0;}
  .container{padding-left:16px;padding-right:16px;}
}
@media(max-width:360px){
  #hero-title,.ch-content h1{font-size:1.3rem;}
  .section-heading h2{font-size:1.15rem;}
}

/* Mobile header right — ch-tag + hero title */
.joaf-mobile-right{
  display:flex;flex-direction:column;justify-content:center;
  align-items:flex-end;text-align:right;
  flex:1;min-width:0;padding:0 4px 0 6px;overflow:hidden;
}
.joaf-mobile-chtag{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(144,22,31,.9);color:#fff;
  font-size:clamp(9px,2.8vw,13px);font-weight:800;letter-spacing:.2px;
  text-transform:uppercase;padding:2px 8px;
  border-radius:50px;margin-bottom:3px;
  border:1px solid rgba(255,255,255,.2);
  max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.joaf-mobile-chtag-dot{
  width:5px;height:5px;border-radius:50%;
  background:#fff;flex-shrink:0;
  animation:glow-pulse 1.5s ease infinite;
}
.joaf-mobile-herotitle{
  font-size:clamp(7px,2.2vw,9px);font-weight:900;color:var(--brand);
  line-height:1.25;max-width:100%;
}
.joaf-mobile-herop{
  font-size:clamp(6px,1.8vw,8px);color:var(--muted);
  font-weight:600;line-height:1.3;margin-top:1px;max-width:100%;
}
@media(min-width:768px){.joaf-mobile-right{display:none!important;}}
/* Mobile hero — tag+title+p in header, only buttons+badges on video */

/* Mobile: ch-tag + h1 + p hidden in hero (shown in header right side) */
@media(max-width:767px){
  .ch-tag{display:none!important;}
  #hero-title,.ch-content h1{display:none!important;}
  .ch-content>p{display:none!important;}
  .ch-content{padding:0 14px 14px!important;}
  .hero-cta{flex-direction:column!important;align-items:center!important;gap:8px!important;margin-bottom:8px!important;}
  .hero-cta a{padding:9px 28px!important;font-size:13px!important;width:auto!important;justify-content:center;}
  .hero-badges{gap:5px!important;justify-content:center!important;}
  .hero-badge{font-size:10px!important;padding:4px 8px!important;}

}

/* ============================================================
   v9.0 — FLOATING HAM + HEADER CTA PILLS + CENTER PILL-TAG
   ============================================================ */

/* ── 1. CENTER block: pill-tag + tagline (replaces hamburger) ── */
.joaf-mob-center {
  flex: 1;
  min-width: 0;
  padding: 0 8px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* The red pill tag */
.joaf-mob-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--brand);
  color: #fff;
  font-size: clamp(9px, 2.6vw, 12px);
  font-weight: 800;
  letter-spacing: .3px;
  padding: 3px 10px;
  border-radius: 50px;
  border: 1px solid rgba(255,255,255,.25);
  margin-bottom: 3px;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  width: fit-content;
}
.joaf-mob-pill-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #fff;
  flex-shrink: 0;
  animation: glow-pulse 1.5s ease infinite;
}

/* The two-line tagline text */
.joaf-mob-tagline {
  font-size: clamp(8px, 2vw, 10.5px);
  color: var(--muted);
  font-weight: 600;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Hide on desktop */
@media (min-width: 768px) {
  .joaf-mob-center { display: none !important; }
}

/* ── 2. RIGHT side: desktop nav stays, mobile gets CTA pills ── */
.joaf-header-right {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

/* Mobile CTA pills container */
.joaf-mob-cta {
  display: flex !important;
  flex-direction: column;
  gap: 4px;
  align-items: stretch;
}

/* Pill button base */
.joaf-cta-pill {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: 50px;
  font-size: clamp(9px, 2.3vw, 11px);
  font-weight: 800;
  text-decoration: none;
  white-space: nowrap;
  transition: all .3s var(--tr-spring);
  -webkit-tap-highlight-color: transparent;
  line-height: 1;
  width: 100%;
}
.joaf-cta-pill i { font-size: 14px; }
.joaf-cta-pill span { display: inline; }

/* Green — সদস্য হোন */
.joaf-cta-join {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff !important;
  box-shadow: 0 3px 10px var(--accent-glow);
}
.joaf-cta-join:hover, .joaf-cta-join:active {
  transform: scale(1.06);
  color: #fff !important;
  box-shadow: 0 5px 16px var(--accent-glow);
}

/* Outline — সম্পর্কে */
.joaf-cta-about {
  background: transparent;
  color: var(--brand) !important;
  border: 1.5px solid rgba(144,22,31,.35);
}
.joaf-cta-about:hover, .joaf-cta-about:active {
  background: var(--brand);
  color: #fff !important;
  border-color: var(--brand);
}

/* Hide mobile CTA on desktop */
@media (min-width: 768px) {
  .joaf-mob-cta { display: none !important; }
}

/* ── 3. FLOATING HAMBURGER — fixed bottom-left ─────────────── */
.joaf-fab-ham {
  position: fixed;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  width: 54px;
  height: 54px;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 0;
  box-shadow:
    0 6px 20px var(--brand-glow),
    0 2px 8px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.18);
  -webkit-tap-highlight-color: transparent;
  transition: transform .3s var(--tr-spring), box-shadow .3s ease;
  /* Subtle pulse to attract attention */
  animation: fab-ham-pulse 3s ease infinite;
}

@keyframes fab-ham-pulse {
  0%, 100% {
    box-shadow: 0 6px 20px var(--brand-glow), 0 2px 8px rgba(0,0,0,.3);
  }
  50% {
    box-shadow: 0 6px 24px var(--brand-glow), 0 0 0 8px rgba(144,22,31,.1), 0 2px 8px rgba(0,0,0,.3);
  }
}

.joaf-fab-ham:active {
  transform: translateX(-50%) scale(.88);
  transition: transform .1s;
  animation: none;
}

/* The three bars */
.joaf-fab-bar {
  display: block;
  width: 22px;
  height: 2.5px;
  background: #fff;
  border-radius: 2px;
  transform-origin: center;
  transition:
    transform .35s cubic-bezier(.34,1.56,.64,1),
    opacity .22s ease,
    width .25s ease;
}

/* Open (X) state */
.joaf-fab--open .joaf-fab-bar:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
.joaf-fab--open .joaf-fab-bar:nth-child(2) {
  opacity: 0;
  width: 0;
}
.joaf-fab--open .joaf-fab-bar:nth-child(3) {
  transform: translateY(-7.5px) rotate(-45deg);
}

/* Hide on desktop */
@media (min-width: 768px) {
  .joaf-fab-ham { display: none !important; }
}

/* ── 4. Mobile hero: tag+title+text hidden (shown in header) ─ */
@media (max-width: 767px) {
  .ch-tag { display: none !important; }
  #hero-title, .ch-content h1 { display: none !important; }
  .ch-content > p { display: none !important; }
  .ch-content {
    padding: 0 14px 20px !important;
    justify-content: flex-end !important;
  }
  .hero-cta {
    flex-direction: column !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
  }
  .hero-cta a {
    padding: 11px 32px !important;
    font-size: 13.5px !important;
    min-width: 175px;
    justify-content: center;
  }
  .hero-badges {
    gap: 5px !important;
    justify-content: center !important;
  }
  .hero-badge { font-size: 10px !important; padding: 4px 9px !important; }
}

/* ── 5. Header row on mobile — clean 3-column layout ─────── */
@media (max-width: 767px) {
  .joaf-header-row {
    gap: 4px;
    min-height: 58px;
    flex-wrap: nowrap;
    align-items: center;
  }
  .joaf-logo img { max-width: 50px !important; padding: 2px 0; }
  .joaf-header-top { padding: 4px 0; }
  .joaf-header-meta span { font-size: 10px; gap: 3px; }
}

/* ── 6. Scroll-to-top: stay above floating ham ────────────── */
@media (max-width: 767px) {
  /* scroll-top is inline-styled at bottom:76px, that's fine */
  /* WhatsApp float not shown on mobile */
}

/* ── 7. Mobile nav panel slides from LEFT (near ham button) ── */
.joaf-mnav-panel {
  left: 0 !important;
  right: auto !important;
  transform: translateX(-105%) !important;
  border-radius: 0 20px 20px 0 !important;
}
.joaf-mnav--open .joaf-mnav-panel {
  transform: translateX(0) !important;
}

@media(max-width:767px){.hero-cta{display:none!important;}}

/* Logo pulse */
.joaf-logo img {
  animation: logo-pulse 2.5s ease-in-out infinite !important;
}
@keyframes logo-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}
/* Global Blood FAB */
#joaf-blood-fab {
  position: fixed !important;
  bottom: 140px !important;
  left: 16px !important;
  background: linear-gradient(135deg,#075e55,#0a7a6e) !important;
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 12px 18px;
  font-size: 13px;
  font-weight: 800;
  font-family: inherit;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(7,94,85,.4);
  z-index: 9990 !important;
  display: none;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
  text-decoration: none;
}

/* ── Desktop Dropdown Nav ─────────────────────────────────── */
.joaf-desktop-nav ul li.has-dropdown{position:relative;}
.joaf-desktop-nav ul li.has-dropdown>a{display:flex;align-items:center;gap:4px;}
.nav-caret{font-size:10px;transition:transform .25s;}
.has-dropdown:hover .nav-caret{transform:rotate(180deg);}
.nav-dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(6px);
  background:#fff;border-radius:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.15);
  padding:8px;min-width:180px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .22s ease,transform .22s ease;
  z-index:9999;
}
.has-dropdown:hover .nav-dropdown{
  opacity:1;visibility:visible;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.nav-dropdown li{list-style:none;}
.nav-dropdown li a{
  display:block;padding:9px 14px;font-size:13px;font-weight:700;
  color:#1a1a2e;text-decoration:none;border-radius:8px;
  transition:background .15s;white-space:nowrap;
}
.nav-dropdown li a:hover{background:#f5f5f5;color:var(--brand);}

/* ── Mobile submenu indent ────────────────────────────────── */
.mnav-link--sub{padding-left:28px!important;font-size:13px!important;opacity:.85;}
.mnav-link--sub .mnav-label::before{content:"└ ";color:var(--brand);font-size:11px;}

/* ══ JOAF Maze Navigation ═══════════════════════════════════ */
.joaf-maze-wrap{max-width:480px;margin:0 auto;padding:0 4px;}

/* breadcrumb */
.joaf-bc{display:flex;align-items:center;gap:6px;margin-bottom:14px;min-height:0px;flex-wrap:wrap;}
.jbc-back{background:#f3f4f6;border:1.5px solid #e5e7eb;border-radius:50px;padding:6px 14px;font-size:12px;font-weight:700;color:var(--color-text-primary);cursor:pointer;font-family:inherit;transition:.15s;}
.jbc-back:hover{background:var(--color-border-tertiary);}
.jbc-home{background:#f3f4f6;border:1.5px solid #e5e7eb;border-radius:50%;width:30px;height:30px;font-size:13px;cursor:pointer;font-family:inherit;}
.jbc-sep{font-size:11px;color:var(--color-text-tertiary);}
.jbc-item{border:none;border-radius:50px;padding:5px 12px;font-size:11px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit;}
.jbc-cur{opacity:.75;cursor:default;}

/* screen + layers */
.joaf-screen{position:relative;overflow:hidden;}
.jlayer{display:none;}
.jlayer.active{display:block;animation:jSlideIn .32s cubic-bezier(.34,1.1,.64,1) both;}
.jlayer.jback{animation:jSlideBack .28s cubic-bezier(.4,0,.2,1) both;}
@keyframes jSlideIn{from{opacity:0;transform:translateX(44px) scale(.95);}to{opacity:1;transform:none;}}
@keyframes jSlideBack{from{opacity:0;transform:translateX(-44px) scale(.95);}to{opacity:1;transform:none;}}

/* grids */
.jgrid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.jgrid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}

/* main tile */
.jtile{border-radius:18px;padding:18px 12px 14px;cursor:pointer;position:relative;min-height:90px;transition:transform .16s,box-shadow .16s;}
.jtile:active{transform:scale(.94);}
.jtile-icon{font-size:28px;display:block;margin-bottom:5px;}
.jtile-name{font-size:13px;font-weight:800;color:#fff;line-height:1.2;}
.jtile-sub{font-size:10px;color:rgba(255,255,255,.6);margin-top:2px;}
.jtile-arr{position:absolute;bottom:9px;right:10px;width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.22);display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;}

/* section header */
.jsec-head{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;color:#fff;margin-bottom:12px;}
.jsec-head span:first-child{font-size:22px;}
.jsec-name{font-size:15px;font-weight:900;}
.jsec-sub{font-size:11px;opacity:.7;margin-top:1px;}

/* sub tile */
.jstile{background:#fff;border:1.5px solid #e5e7eb;border-radius:14px;padding:13px 6px 10px;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;text-decoration:none;transition:transform .16s,border-color .16s;animation:jPopIn .3s cubic-bezier(.34,1.4,.64,1) both;}
.jstile:nth-child(1){animation-delay:.03s}.jstile:nth-child(2){animation-delay:.07s}.jstile:nth-child(3){animation-delay:.11s}.jstile:nth-child(4){animation-delay:.15s}.jstile:nth-child(5){animation-delay:.19s}.jstile:nth-child(6){animation-delay:.23s}
.jstile:active{transform:scale(.91);}
.jsi{font-size:24px;margin-bottom:4px;}
.jsn{font-size:10.5px;font-weight:700;color:#1a1a2e;line-height:1.3;}
.jsa{font-size:9px;color:var(--color-text-tertiary);margin-top:2px;}
@keyframes jPopIn{from{opacity:0;transform:scale(.6) translateY(10px);}to{opacity:1;transform:none;}}

/* colors */
.jc-red{background:linear-gradient(135deg,#7f1d1d,#dc2626);}
.jc-blue{background:linear-gradient(135deg,#1e3a5f,#2563eb);}
.jc-green{background:linear-gradient(135deg,#14532d,#16a34a);}
.jc-purple{background:linear-gradient(135deg,#3b0764,#9333ea);}
.jc-teal{background:linear-gradient(135deg,#134e4a,#0d9488);}
.jc-amber{background:linear-gradient(135deg,#78350f,#d97706);}
.jbr-red{border-color:#dc2626!important;}.jbr-red:hover{background:rgba(220,38,38,.07)!important;}
.jbr-blue{border-color:#2563eb!important;}.jbr-blue:hover{background:rgba(37,99,235,.07)!important;}
.jbr-green{border-color:#16a34a!important;}.jbr-green:hover{background:rgba(22,163,74,.07)!important;}
.jbr-purple{border-color:#9333ea!important;}.jbr-purple:hover{background:rgba(147,51,234,.07)!important;}
.jbr-teal{border-color:#0d9488!important;}.jbr-teal:hover{background:rgba(13,148,136,.07)!important;}
.jbr-amber{border-color:#d97706!important;}.jbr-amber:hover{background:rgba(217,119,6,.07)!important;}

/* Dropdown — hover on desktop, click on touch */
.has-dropdown{position:relative;}
.has-dropdown>.nav-dropdown{pointer-events:none;}
.has-dropdown:hover>.nav-dropdown,
.has-dropdown.open>.nav-dropdown{
  opacity:1!important;visibility:visible!important;
  pointer-events:auto!important;
  transform:translateX(-50%) translateY(0)!important;
}
/* Maze section background */
.joaf-maze-section{background:#ffffff!important;padding:20px 0;color:#1a202c!important;position:relative;z-index:10;}

/* ── Bootstrap display utility fallback (for pages without Bootstrap) ──
   Ensures header mobile/desktop layout works on ALL pages.
   Safe on pages that DO have Bootstrap — same values, no conflict. */
.d-none  { display: none  !important; }
.d-flex  { display: flex  !important; }
.d-block { display: block !important; }
@media (min-width: 768px) {
  .d-md-none  { display: none  !important; }
  .d-md-flex  { display: flex  !important; }
  .d-md-block { display: block !important; }
}
/* Mobile dropdown toggle */
.mnav-has-sub > .mnav-link .mnav-arrow{transition:transform .25s ease,opacity .2s;}
.mnav-sub-list{list-style:none;margin:0;padding:0;max-height:0;overflow:hidden;transition:max-height .3s ease;}
.mnav-has-sub.mnav-open > .mnav-link .mnav-arrow{transform:rotate(90deg);opacity:.9;}
.mnav-has-sub.mnav-open > .mnav-sub-list{max-height:500px;}
