
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --green:#0B6E4F;--green2:#1D9E75;--green3:#E6F4EE;
  --red:#C0392B;--amber:#D4881A;
  --ink:#111;--ink2:#3A3A3A;--ink3:#6B6B6B;--ink4:#9E9E9E;
  --bg:#FAFAF7;--white:#FFFFFF;--rule:#E5E5E0;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.65;overflow-x:hidden}
#progress{position:fixed;top:0;left:0;height:3px;background:var(--green2);z-index:9999;width:0%;transition:width .1s linear}

/* NAV */
nav{position:sticky;top:0;z-index:100;background:rgba(250,250,247,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--rule);padding:0 5vw}
.nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:52px}
.nav-logo{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--green);letter-spacing:-.3px}
.nav-links{display:flex;gap:28px;list-style:none}
.nav-links a{font-size:12px;font-weight:500;color:var(--ink3);text-decoration:none;letter-spacing:.5px;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--green2)}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding:56px 5vw 64px;position:relative;overflow:hidden;background:#06271A}
.hero-skyline{position:absolute;bottom:0;left:0;right:0;z-index:1;pointer-events:none}
.hero-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(to bottom,rgba(4,20,13,.15) 0%,rgba(4,20,13,.45) 50%,rgba(4,20,13,.82) 100%)}
.hero-content{position:relative;z-index:3;max-width:1100px;margin:0 auto;width:100%}
.hero h1{font-family:var(--serif);font-size:clamp(36px,5vw,68px);font-weight:900;line-height:1.08;color:#fff;max-width:820px;margin-bottom:24px;letter-spacing:-.5px}
.hero h1 em{font-style:italic;color:#5DCAA5}
.hero-deck{font-size:clamp(14px,1.5vw,17px);color:rgba(255,255,255,.68);max-width:620px;line-height:1.78;margin-bottom:44px;font-weight:300}
.hero-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);border-radius:12px;overflow:hidden;max-width:820px}
.kpi{background:rgba(255,255,255,.06);padding:22px 18px;text-align:center;transition:background .2s}
.kpi:hover{background:rgba(255,255,255,.12)}
.kpi-n{font-family:var(--serif);font-size:40px;font-weight:900;color:#fff;line-height:1;margin-bottom:6px}
.kpi-n sup{font-size:18px;vertical-align:super}
.kpi-l{font-size:11px;color:rgba(255,255,255,.55);line-height:1.4;font-weight:400}
.hero-source{margin-top:28px;font-size:10px;color:rgba(255,255,255,.3);font-style:italic}
.hero-scroll{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;font-size:10px;color:rgba(255,255,255,.3);letter-spacing:1px;text-transform:uppercase;z-index:3}
.scroll-line{width:1px;height:44px;background:rgba(255,255,255,.2);animation:scrollpulse 2s infinite}
@keyframes scrollpulse{0%,100%{opacity:.2;transform:scaleY(.4);transform-origin:top}50%{opacity:.8;transform:scaleY(1);transform-origin:top}}

/* BUILDING CHART */
#building-chart-wrap{overflow-x:auto}
@keyframes buildingsRise{from{opacity:0;transform:translateY(26px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}

/* SECTIONS */
section{padding:80px 5vw;max-width:1100px;margin:0 auto}
body{counter-reset:chapter}
.section-numbered{counter-increment:chapter;position:relative}
.section-numbered .section-title::before{content:counter(chapter,decimal-leading-zero);display:block;font-family:var(--serif);font-size:13px;font-weight:700;letter-spacing:5px;color:var(--green2);margin-bottom:10px}
.section-numbered::after{content:counter(chapter,decimal-leading-zero);position:absolute;top:-6px;right:5vw;font-family:var(--serif);font-size:140px;font-weight:900;color:rgba(11,110,79,.045);line-height:1;pointer-events:none;z-index:0;user-select:none}
@media(max-width:800px){.section-numbered::after{display:none}}
.section-label{font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--green2);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.section-label::after{content:'';flex:1;height:1px;background:var(--rule)}
h2.section-title{font-family:var(--serif);font-size:clamp(28px,3.5vw,42px);font-weight:700;line-height:1.2;color:var(--ink);margin-bottom:20px}
.section-intro{font-size:16px;color:var(--ink2);max-width:680px;line-height:1.8;margin-bottom:48px;font-weight:300}

/* CHARTS */
.chart-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:24px}
.chart-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:24px;transition:transform .25s ease,box-shadow .25s ease}
.chart-card:hover{transform:translateY(-5px);box-shadow:0 14px 32px rgba(17,17,17,.08)}
.chart-card-title{font-size:14px;font-weight:500;color:var(--ink2);margin-bottom:18px;line-height:1.4}
.chart-wrap{position:relative;width:100%}

/* TABLE */
.rank-table-wrap{background:var(--white);border:1px solid var(--rule);border-radius:12px;overflow:hidden;transition:box-shadow .25s ease}
.rank-table-wrap:hover{box-shadow:0 14px 32px rgba(17,17,17,.08)}
.rank-table{width:100%;border-collapse:collapse;font-size:13px}
.rank-table thead tr{background:#F7F7F4}
.rank-table th{padding:11px 16px;font-size:10.5px;font-weight:600;color:var(--ink3);letter-spacing:.8px;text-transform:uppercase;border-bottom:1px solid var(--rule);white-space:nowrap;cursor:pointer}
.rank-table td{padding:10px 16px;border-bottom:1px solid #F0F0ED;color:var(--ink2);white-space:nowrap}
.rank-table tr:last-child td{border-bottom:none}
.rank-table tr:hover td{background:#fafaf7}
.rank-num{font-family:var(--serif);font-weight:700;color:var(--ink);font-size:15px}
.pill{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px}
.pill-green{background:#E6F4EE;color:#0B6E4F}
.pill-amber{background:#FEF3E2;color:#92540A}
.pill-red{background:#FDECEB;color:#9B2219}

/* INSIGHTS */
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.ins-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:24px;position:relative;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}
.ins-card:hover{transform:translateY(-5px);box-shadow:0 14px 32px rgba(17,17,17,.08)}
.ins-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--green2)}
.ins-card.warn::before{background:var(--amber)}
.ins-card.danger::before{background:var(--red)}
.ins-num{font-family:var(--serif);font-size:36px;font-weight:900;color:var(--green);line-height:1;margin-bottom:8px}
.ins-card.warn .ins-num{color:var(--amber)}
.ins-card.danger .ins-num{color:var(--red)}
.ins-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.ins-body{font-size:12px;color:var(--ink3);line-height:1.6}

/* HDBANK SPOTLIGHT */
.hd-wrap{border-radius:16px;overflow:hidden;border:1.5px solid var(--green2);margin-top:40px;transition:transform .25s ease,box-shadow .25s ease}
.hd-wrap:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(11,110,79,.12)}
.hd-header{background:var(--green);padding:24px 32px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.hd-body{display:grid;grid-template-columns:1fr 380px}
.hd-text{padding:28px 32px}
.hd-stats-mini{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:var(--rule);border-radius:8px;overflow:hidden;margin-bottom:20px}
.hd-stat-cell{background:#fff;padding:16px;text-align:center}
.hd-stat-cell+.hd-stat-cell{border-left:1px solid var(--rule)}
.hd-photo{position:relative;overflow:hidden;min-height:280px}
.hd-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block}

/* BUILDING CHART */
.building-chart{display:flex;align-items:flex-end;gap:16px;padding:32px 24px 0;background:#fff;border:1px solid var(--rule);border-radius:12px;overflow-x:auto;min-height:300px}
.bld-group{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}
.bld-country{font-size:10px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:.5px;text-align:center}
.bld-banks{display:flex;align-items:flex-end;gap:6px}
.bld-tower{display:flex;flex-direction:column;align-items:center;cursor:default;transition:transform .2s}
.bld-tower:hover{transform:translateY(-4px)}
.bld-body{border-radius:3px 3px 0 0;position:relative;min-width:28px;transition:height .8s cubic-bezier(.4,0,.2,1)}
.bld-name{font-size:8.5px;font-weight:600;color:var(--ink3);margin-top:4px;text-align:center;max-width:44px;line-height:1.2;writing-mode:horizontal-tb}
.bld-assets{font-size:9px;font-weight:700;color:var(--ink4);position:absolute;top:-18px;left:50%;transform:translateX(-50%);white-space:nowrap}

/* MAP */
.map-container{position:relative}
#map-svg{width:100%;height:auto}
#country-card{display:none;position:absolute;z-index:50;pointer-events:none;min-width:220px;background:#fff;border:1px solid #E5E5E0;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.12);overflow:hidden}

/* BANK DETAIL OVERLAY (building chart) */
.bank-detail-wrap{position:relative;min-height:420px}
#building-chart-wrap{display:flex;justify-content:center}
#bank-card{display:none;position:absolute;inset:0;z-index:60;background:#fff;border-radius:10px;box-shadow:0 10px 36px rgba(0,0,0,.16);overflow:hidden;flex-direction:row}
#bank-card.show{display:flex}
#bank-card .bc-photo{flex:0 0 38%;min-width:200px;position:relative;overflow:hidden;background:#eee}
#bank-card .bc-photo img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}
#bank-card .bc-body{flex:1;padding:28px 32px;display:flex;flex-direction:column;justify-content:center;overflow-y:auto}
#bank-card .bc-name{font-family:var(--serif);font-size:26px;font-weight:900;color:#111;margin-bottom:14px}
#bank-card .bc-stats{display:flex;gap:28px;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid #F0F0ED}
#bank-card .bc-stat-n{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--green)}
#bank-card .bc-stat-l{font-size:10.5px;color:#9E9E9E;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}
#bank-card .bc-info{font-size:14.5px;color:#3A3A3A;line-height:1.85;font-weight:300}
#bank-card .bc-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;border:none;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2}
#bank-card .bc-close:hover{background:rgba(0,0,0,.75)}
@media(max-width:800px){
  #bank-card{flex-direction:column;overflow-y:auto}
  #bank-card .bc-photo{flex:0 0 160px;min-width:0}
}

/* DIVIDER */
.divider{border:none;border-top:1px solid var(--rule);margin:0;position:relative;height:1px;overflow:visible}
.divider::after{content:'';position:absolute;top:-4.5px;left:50%;transform:translateX(-50%);width:9px;height:9px;border-radius:50%;background:var(--green2);box-shadow:0 0 0 5px var(--bg)}

/* LEADERBOARD */
.leaderboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:8px}
.lb-card{background:var(--white);border:1px solid var(--rule);border-radius:12px;padding:26px 28px;transition:transform .25s ease,box-shadow .25s ease}
.lb-card:hover{transform:translateY(-5px);box-shadow:0 14px 32px rgba(17,17,17,.08)}
.lb-card-title{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--ink)}
.lb-card-sub{font-size:10.5px;color:var(--ink4);margin-bottom:14px;text-transform:uppercase;letter-spacing:.6px;margin-top:2px}
.lb-list{list-style:none;display:flex;flex-direction:column}
.lb-item{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid #F3F3F0}
.lb-item:last-child{border-bottom:none}
.lb-rank{font-family:var(--serif);font-size:13px;font-weight:700;color:var(--ink4);width:18px;flex-shrink:0}
.lb-item.lb-vn .lb-rank{color:var(--red)}
.lb-name{flex:1;font-size:13.5px;color:var(--ink2);font-weight:500;display:flex;align-items:center}
.lb-item.lb-vn .lb-name{color:var(--red);font-weight:700}
.lb-flag{margin-right:8px;width:18px;height:13px;object-fit:cover;border-radius:2px;box-shadow:0 0 0 1px rgba(0,0,0,.08);vertical-align:middle;flex-shrink:0}
.lb-value{font-family:var(--serif);font-size:13.5px;font-weight:700;color:var(--ink)}
.lb-item.lb-vn .lb-value{color:var(--red)}
@media(max-width:800px){.leaderboard-grid{grid-template-columns:1fr}}

/* CALLOUT */
.callout{position:relative;padding:22px 26px 22px 30px;border-radius:10px;background:#FEF6EC;border-left:4px solid var(--amber);transition:transform .25s ease,box-shadow .25s ease}
.callout:hover{transform:translateY(-3px);box-shadow:0 12px 26px rgba(212,136,26,.14)}
.callout p{font-size:15.5px;line-height:1.85;color:var(--ink2);font-weight:400;margin:0}
.callout-label{font-size:10.5px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--amber);margin-bottom:8px;display:block}

/* FILTER BUTTONS */
.filter-btn{padding:6px 14px;font-size:12px;font-weight:500;border:1px solid var(--rule);border-radius:20px;background:var(--white);color:var(--ink3);cursor:pointer;transition:all .2s;font-family:var(--sans)}
.filter-btn:hover{border-color:var(--green2);color:var(--green2)}
.filter-btn.active{background:var(--green);border-color:var(--green);color:#fff}

/* FOOTER */
footer{background:var(--ink);color:rgba(255,255,255,.5);padding:40px 5vw;font-size:12px;line-height:1.8;margin-top:0}
footer strong{color:rgba(255,255,255,.8)}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.in{opacity:1;transform:none}

@media(max-width:800px){
  .hero-kpis{grid-template-columns:repeat(2,1fr)}
  .chart-grid-2{grid-template-columns:1fr}
  .insights-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .hd-body{grid-template-columns:1fr}
  .hd-photo{min-height:200px}
}


/* ===== combined styles ===== */


.bb-marquee-outer{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;overflow:hidden;padding:70px 0 56px}
.bb-marquee-track{display:flex;align-items:flex-end;width:max-content;animation:bbScroll 38s linear infinite}
.bb-marquee-track:hover{animation-play-state:paused}
@keyframes bbScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.bb-item{position:relative;display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.bb-tag{position:relative;margin-bottom:18px;background:#fff;color:var(--ink);border-radius:10px;padding:8px 16px;text-align:center;border:2px solid var(--green2);box-shadow:0 10px 20px rgba(11,110,79,.16), 0 3px 8px rgba(0,0,0,.08);white-space:nowrap;animation:bbFloat 3.2s ease-in-out infinite;will-change:transform}
.bb-tag:after{content:'';position:absolute;left:50%;bottom:-8px;transform:translateX(-50%) rotate(45deg);width:12px;height:12px;background:#fff;border-right:2px solid var(--green2);border-bottom:2px solid var(--green2);border-radius:0 0 3px 0}
.bb-tag-num{font-family:var(--serif);font-size:18px;font-weight:800;line-height:1.1;color:var(--green)}
.bb-tag-unit{display:block;font-size:9.5px;font-weight:600;color:var(--ink3);letter-spacing:.3px;margin-top:2px}
@keyframes bbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.bb-bubble{position:relative;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 32% 28%, #ffffff 0%, #f3f3f0 38%, #e2e2dd 100%);
  box-shadow:0 14px 26px rgba(17,17,17,.18), 0 3px 8px rgba(17,17,17,.12), inset 0 -8px 14px rgba(0,0,0,.08), inset 0 6px 10px rgba(255,255,255,.9);
  border:1px solid rgba(0,0,0,.06);
}
.bb-bubble .bb-shine{position:absolute;top:8%;left:18%;width:42%;height:28%;border-radius:50%;background:linear-gradient(135deg,rgba(255,255,255,.85),rgba(255,255,255,0));pointer-events:none}
.bb-bubble img{position:relative;z-index:1;object-fit:contain;pointer-events:none;filter:drop-shadow(0 1px 1px rgba(0,0,0,.15))}
.closing-band{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;background:linear-gradient(135deg,#06271A 0%,#0B3D29 100%);padding:80px 5vw;margin-top:16px;overflow:hidden}
.closing-band::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 18% 25%,rgba(93,202,165,.18),transparent 55%),radial-gradient(circle at 85% 75%,rgba(255,255,255,.07),transparent 50%);pointer-events:none}
.closing-band::after{content:'\201C';position:absolute;top:-38px;left:50%;transform:translateX(-50%);font-family:var(--serif);font-size:200px;font-weight:900;color:rgba(255,255,255,.045);line-height:1;pointer-events:none;user-select:none}
.closing-band-inner{position:relative;z-index:1;max-width:760px;margin:0 auto;text-align:center}
.closing-band-inner p{font-family:var(--serif);font-style:italic;font-weight:600;font-size:clamp(20px,2.4vw,28px);line-height:1.75;color:#fff;letter-spacing:-.1px;margin:0;text-wrap:balance}
