/* ============================================================
   PALET WARNA (mengikuti logo IEEF)
   ============================================================ */
:root{
  --bg:#FFFFFF;
  --card:#F7FBFD;
  --card2:#F5F8FA;
  --navy:#003C62;
  --navy2:#004371;
  --blue:#0069A8;
  --turq:#74C3B9;
  --dturq:#008D80;
  --lblue:#EAF6FB;
  --grey:#333333;
  --border:#DCE7EC;
  --shadow:0 4px 18px rgba(0,60,98,.07);
  --shadow-sm:0 2px 8px rgba(0,60,98,.05);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Times New Roman", Times, serif;
  background:var(--bg);
  color:var(--grey);
  line-height:1.55;
  font-size:16px;
}
em{font-style:italic;color:var(--blue)}
/* Istilah italic di dalam card berbackground gelap: tetap italic, warna terang agar kontras */
.msg em,.helix em,.fnode em{color:#F4FAFC}
/* Judul italic pada Quality Growth Framework (card putih): navy, tegas, terbaca */
.qg h4 em{color:var(--navy);font-style:italic}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}

/* ============================================================
   HEADER / HERO
   ============================================================ */
header{
  background:var(--bg);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:50;
  box-shadow:var(--shadow-sm);
}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:20px}
.brand{display:flex;align-items:center;gap:16px}
.brand img{height:46px;width:auto;display:block}
.brand .div{height:38px;width:1px;background:var(--border)}
.brand .ttl{font-size:.82rem;color:var(--navy);font-weight:bold;letter-spacing:.3px;line-height:1.3}
.brand .ttl small{display:block;font-weight:normal;color:#5a7180;font-size:.72rem}
nav.menu{display:flex;gap:4px;flex-wrap:wrap}
nav.menu a{
  font-size:.78rem;color:var(--navy);text-decoration:none;padding:6px 10px;
  border-radius:6px;transition:.15s;white-space:nowrap;
}
nav.menu a:hover{background:var(--lblue);color:var(--blue)}

.hero{
  position:relative;overflow:hidden;background:var(--bg);
  border-bottom:1px solid var(--border);padding:54px 0 60px;
}
.hero .wave{position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:920px}
.badge{
  display:inline-block;background:var(--lblue);color:var(--navy);
  font-size:.74rem;font-weight:bold;padding:6px 14px;border-radius:20px;
  border:1px solid var(--border);letter-spacing:.4px;margin-bottom:18px;
}
.hero h1{
  font-size:2.55rem;line-height:1.15;color:var(--navy);font-weight:bold;
  margin-bottom:14px;letter-spacing:-.5px;
}
.hero .sub{font-size:1.12rem;color:#3d5663;max-width:780px;line-height:1.5}
.hero .pills{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}
.pill{
  display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);
  border-radius:10px;padding:8px 14px;font-size:.82rem;box-shadow:var(--shadow-sm);
}
.pill b{color:var(--dturq)}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}

/* ============================================================
   SECTION GENERIK
   ============================================================ */
section.block{padding:46px 0;border-bottom:1px solid var(--border)}
.sec-head{margin-bottom:26px;max-width:880px}
.sec-tag{
  font-size:.72rem;font-weight:bold;color:var(--dturq);letter-spacing:1.5px;
  text-transform:uppercase;margin-bottom:8px;display:flex;align-items:center;gap:8px;
}
.sec-tag .num{
  background:var(--navy);color:#fff;width:24px;height:24px;border-radius:6px;
  display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;
}
.sec-head h2{font-size:1.72rem;color:var(--navy);font-weight:bold;line-height:1.2;margin-bottom:8px}
.sec-head p{font-size:1rem;color:#54707d}

/* GRID UTIL */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g5{grid-template-columns:repeat(5,1fr)}
.g6{grid-template-columns:repeat(6,1fr)}

/* CARD */
.card{
  background:var(--card);border:1px solid var(--border);border-radius:14px;
  padding:22px;box-shadow:var(--shadow-sm);transition:.18s;
}
.card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.card h3{font-size:1.04rem;color:var(--navy);font-weight:bold;margin-bottom:8px}
.card p{font-size:.92rem;color:#465c67}
.card ul{list-style:none;margin-top:8px}
.card ul li{font-size:.9rem;color:#465c67;padding-left:18px;position:relative;margin-bottom:5px}
.card ul li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--turq)}

/* KPI */
.kpi{
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px 20px;
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
}
.kpi .ic{font-size:1.3rem;margin-bottom:8px;display:block;color:var(--blue)}
.kpi .val{font-size:2.15rem;font-weight:bold;color:var(--navy);line-height:1;letter-spacing:-1px}
.kpi .lab{font-size:.86rem;color:#465c67;margin-top:8px;font-weight:bold}
.kpi .src{font-size:.7rem;color:#56707c;margin-top:6px}
.kpi.alt .val{color:var(--dturq)}

/* CONTEXT 2 COL */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:26px;align-items:start}
.map-jabar{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;box-shadow:var(--shadow-sm)}
.corridor{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-radius:9px;margin-bottom:8px;border:1px solid var(--border)}
.corridor:last-child{margin-bottom:0}
.corridor b{font-size:.92rem;color:var(--navy)}
.corridor span{font-size:.78rem;color:#5a7180}
.lvl{font-size:.7rem;font-weight:bold;padding:3px 9px;border-radius:12px;white-space:nowrap}
.lvl.t{background:#003C62;color:#fff}
.lvl.s{background:var(--turq);color:#04403a}
.lvl.r{background:var(--lblue);color:var(--navy)}

/* HEXAGON / QUALITY GROWTH */
.qg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.qg{
  background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;
  box-shadow:var(--shadow-sm);transition:.18s;
}
.qg:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--turq)}
.qg .hx{
  width:54px;height:54px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--blue),var(--dturq));color:#fff;font-size:1.3rem;font-weight:bold;
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
}
.qg h4{font-size:1rem;color:var(--navy);margin-bottom:5px;font-weight:bold}
.qg p{font-size:.82rem;color:#3d5663;line-height:1.4}
.qg[style*="navy"] p{color:#cfe3ee}

/* CHART BOX */
.chartbox{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:var(--shadow-sm)}
.chartbox h3{font-size:1.04rem;color:var(--navy);font-weight:bold;margin-bottom:4px}
.chartbox .csub{font-size:.82rem;color:#56707c;margin-bottom:14px}
.chartbox .src{font-size:.7rem;color:#56707c;margin-top:12px;border-top:1px dashed var(--border);padding-top:8px}
.canvas-h{position:relative;height:280px}

/* SECTOR MATRIX (2-axis diagram) */
.matrix-wrap{display:grid;grid-template-columns:1.55fr 1fr;gap:20px;align-items:stretch}
.matrix-plot{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--shadow-sm)}
.matrix-plot svg{width:100%;height:auto;display:block}
.matrix-legend{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow-sm)}
.matrix-legend h4{font-size:.96rem;color:var(--navy);font-weight:bold;margin-bottom:12px}
.mleg{display:flex;align-items:flex-start;gap:11px;margin-bottom:11px}
.mleg .badge-n{flex:none;width:26px;height:26px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:bold}
.mleg .txt b{font-size:.86rem;color:var(--navy);display:block;line-height:1.2}
.mleg .txt span{font-size:.76rem;color:#54707d;line-height:1.25}
.mleg.hi{background:var(--lblue);border-radius:9px;padding:9px 11px;margin-top:14px}
.mleg.hi .txt b{color:var(--navy)}
.mleg.hi .txt span{color:#3d5663}

/* ABG-C ECOSYSTEM */
.abgc{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.helix{border-radius:14px;padding:20px;color:#fff;box-shadow:var(--shadow-sm)}
.helix .badge2{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.18);font-size:1.2rem;font-weight:bold;margin-bottom:12px}
.helix h4{font-size:1.08rem;font-weight:bold;margin-bottom:10px}
.helix ul{list-style:none}
.helix ul li{font-size:.85rem;padding-left:16px;position:relative;margin-bottom:5px;opacity:.95}
.helix ul li::before{content:"›";position:absolute;left:0;font-weight:bold}

/* BRIDGE / PATHWAY */
.bridge{display:flex;align-items:center;gap:0;flex-wrap:wrap;justify-content:center}
.bnode{background:#fff;border:2px solid var(--turq);border-radius:11px;padding:12px 16px;text-align:center;font-size:.84rem;font-weight:bold;color:var(--navy);min-width:118px;box-shadow:var(--shadow-sm)}
.barrow{color:var(--blue);font-size:1.4rem;padding:0 6px}
.flowwrap{overflow-x:auto;padding-bottom:8px}
.flow{display:flex;align-items:center;gap:0;min-width:max-content;padding:6px 2px}
.fnode{background:linear-gradient(135deg,var(--blue),var(--dturq));color:#fff;border-radius:11px;padding:13px 15px;text-align:center;font-size:.8rem;font-weight:bold;min-width:120px;box-shadow:var(--shadow-sm)}
.farrow{color:var(--turq);font-size:1.5rem;padding:0 7px;flex-shrink:0}

/* FUNNEL / BOTTLENECK */
.funnel{display:flex;flex-direction:column;gap:9px;align-items:center}
.frow{display:flex;align-items:center;gap:14px;width:100%}
.fbar{color:#fff;border-radius:9px;padding:13px 18px;font-weight:bold;font-size:.92rem;text-align:center;box-shadow:var(--shadow-sm)}
.fnote{font-size:.84rem;color:#54707d;flex:1}

/* 5 PILLARS — icon-based flow infographic */
.pillars-flow{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;position:relative}
.pillar{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px 18px;box-shadow:var(--shadow-sm);text-align:center;position:relative;transition:.18s}
.pillar:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--turq)}
.pillar .picon{width:58px;height:58px;margin:0 auto 14px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;box-shadow:var(--shadow-sm)}
.pillar .pn{position:absolute;top:12px;right:14px;font-size:1.5rem;font-weight:bold;color:var(--border)}
.pillar h4{font-size:.98rem;color:var(--navy);font-weight:bold;margin-bottom:8px;line-height:1.25}
.pillar p{font-size:.84rem;color:#465c67;line-height:1.4}
.pillar .arrow{position:absolute;top:46px;right:-19px;font-size:1.4rem;color:var(--turq);z-index:2}
.pillar:last-child .arrow{display:none}

/* TABLE */
table.matrix-t{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm)}
table.matrix-t th{background:var(--navy);color:#fff;font-size:.84rem;padding:12px 14px;text-align:left;font-weight:bold}
table.matrix-t td{padding:12px 14px;font-size:.86rem;border-bottom:1px solid var(--border);vertical-align:top;color:#465c67}
table.matrix-t tr:last-child td{border-bottom:none}
table.matrix-t tr:nth-child(even){background:var(--card2)}
table.matrix-t .ac{font-weight:bold;color:var(--navy);white-space:nowrap}
table.matrix-t .ind{color:var(--dturq);font-weight:bold;font-size:.8rem}

/* POLICY LEVELS */
.plevel{background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:var(--shadow-sm)}
.plevel .htag{display:inline-block;font-size:.72rem;font-weight:bold;padding:5px 12px;border-radius:14px;margin-bottom:14px;letter-spacing:.5px}
.plevel.l1 .htag{background:var(--lblue);color:var(--navy)}
.plevel.l2 .htag{background:var(--turq);color:#04403a}
.plevel.l3 .htag{background:var(--navy);color:#fff}
.plevel h4{font-size:1.06rem;color:var(--navy);font-weight:bold;margin-bottom:12px}
.plevel ul{list-style:none}
.plevel ul li{font-size:.88rem;color:#465c67;padding-left:20px;position:relative;margin-bottom:9px;line-height:1.4}
.plevel ul li::before{content:"✓";position:absolute;left:0;color:var(--dturq);font-weight:bold}

/* ROADMAP */
.roadmap{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rstep{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;box-shadow:var(--shadow-sm);position:relative}
.rstep .yr{font-size:1.5rem;font-weight:bold;color:var(--dturq);line-height:1;margin-bottom:6px}
.rstep .ph{font-size:.74rem;font-weight:bold;color:var(--navy);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}
.rstep ul{list-style:none}
.rstep ul li{font-size:.82rem;color:#54707d;padding-left:16px;position:relative;margin-bottom:6px;line-height:1.35}
.rstep ul li::before{content:"›";position:absolute;left:0;color:var(--turq);font-weight:bold}

/* THREE MESSAGES */
.msg{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff;border-radius:14px;padding:24px;box-shadow:var(--shadow)}
.msg .mn{width:38px;height:38px;border-radius:50%;background:var(--turq);color:var(--navy);display:flex;align-items:center;justify-content:center;font-weight:bold;font-size:1.15rem;margin-bottom:14px}
.msg h4{font-size:1.1rem;font-weight:bold;margin-bottom:8px}
.msg p{font-size:.9rem;opacity:.92;line-height:1.45}

/* FOOTER */
footer{background:var(--navy);color:#cfe3ee;padding:40px 0 30px}
footer .fwrap{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
footer img{height:40px;filter:brightness(0) invert(1);opacity:.9}
footer .note{font-size:.82rem;max-width:620px;line-height:1.5;opacity:.85}
footer .yr{font-size:1.4rem;font-weight:bold;color:#fff}

/* RESPONSIVE */
@media(max-width:1100px){
  .g6,.g5{grid-template-columns:repeat(3,1fr)}
  .g4,.qg-grid,.abgc,.roadmap{grid-template-columns:repeat(2,1fr)}
  .matrix-wrap{grid-template-columns:1fr}
  .pillars-flow{grid-template-columns:repeat(3,1fr)}
  .pillar .arrow{display:none}
  .hero h1{font-size:2.1rem}
}
@media(max-width:760px){
  .wrap{padding:0 18px}
  .g2,.g3,.g4,.g5,.g6,.qg-grid,.abgc,.roadmap,.twocol,.pillars-flow{grid-template-columns:1fr}
  nav.menu{display:none}
  .hero h1{font-size:1.7rem}
}
.note-data{font-size:.74rem;color:#56707c;font-style:italic;margin-top:6px}

/* ============================================================
   PENYESUAIAN RESPONSIF TAMBAHAN (mobile / iPad)
   — ditambahkan tanpa mengubah aturan desktop asli
   ============================================================ */

/* Cegah overflow horizontal global & izinkan kata panjang membungkus */
html,body{max-width:100%;overflow-x:hidden}
img{max-width:100%;height:auto}
.wrap{width:100%}

/* Elemen baris memanjang (alur/bridge/funnel) -> bisa di-scroll horizontal di layar kecil */
.bridge,.flow,.funnel{max-width:100%}

/* Canvas grafik Chart.js responsif terhadap kontainer */
canvas{max-width:100% !important;height:auto !important}

/* Tabel (jika ada) bisa di-scroll, tidak memecah layout */
table{max-width:100%;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}

/* iPad / tablet (768–1024px) */
@media(min-width:761px) and (max-width:1024px){
  .wrap{padding:0 24px}
  .g6{grid-template-columns:repeat(3,1fr)}
  .g5{grid-template-columns:repeat(3,1fr)}
  .g4,.qg-grid,.abgc,.roadmap{grid-template-columns:repeat(2,1fr)}
  .matrix-wrap{grid-template-columns:1fr}
  .pillars-flow{grid-template-columns:repeat(3,1fr)}
  .twocol{grid-template-columns:1fr}
  .pillar .arrow{display:none}
  .hero h1{font-size:2rem}
}

/* Ponsel (<=760px): perbaikan lanjutan di atas aturan asli */
@media(max-width:760px){
  body{font-size:15px}
  .hero{padding:36px 0 40px}
  .hero .sub{font-size:1rem}

  /* Header sticky: rapikan brand + tampilkan menu sebagai strip yang bisa digeser
     (menu asli di-hide oleh aturan sebelumnya; di sini kita munculkan kembali
     dalam bentuk scroll-x agar navigasi tetap tersedia di HP) */
  .topbar{flex-direction:column;align-items:flex-start;gap:10px}
  .brand img{height:38px}
  nav.menu{
    display:flex !important;
    flex-wrap:nowrap;
    width:100%;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    gap:4px;
    padding-bottom:4px;
    scrollbar-width:thin;
  }
  nav.menu a{white-space:nowrap;flex:0 0 auto}

  /* Alur horizontal: aktifkan scroll-x agar tidak terpotong */
  .bridge,.flow{overflow-x:auto;-webkit-overflow-scrolling:touch;justify-content:flex-start}
  .frow{flex-wrap:wrap}

  footer .fwrap{flex-direction:column;align-items:flex-start}
}

/* Ponsel kecil (<=420px) */
@media(max-width:420px){
  .hero h1{font-size:1.45rem}
  .wrap{padding:0 14px}
}
