/*:root {*/
/*  --green:      #1A6B45;*/
/*  --green-d:    #145538;*/
/*  --green-mid:  #228B57;*/
/*  --green-pale: #EAF4EE;*/
/*  --gold:       #C8A45A;*/
/*  --gold-d:     #A8853C;*/
/*  --navy:       #0C1B2A;*/
/*  --navy-mid:   #152435;*/
/*  --ink:        #16222D;*/
/*  --body:       #38485A;*/
/*  --muted:      #7A8C9B;*/
/*  --rule:       #DDE6EC;*/
/*  --bg:         #F4F7F5;*/
/*  --bg2:        #EEF2F0;*/
/*  --white:      #FFFFFF;*/
/*  --topbar-h:   40px;*/
/*  --nav-h:      72px;*/
/*  --nav2-h:     44px;*/
/*}*/
:root {
  --green:      #E8A800;
  --green-d:    #C98F00;
  --green-mid:  #F2B800;
  --green-pale: #FFF8E1;
  --yellow:     #FFCD00;
  --yellow-d:   #E6B800;
  --gold:       #F5C200;
  --gold-d:     #D9AB00;
  --navy:       #002147;
  --navy-mid:   #0A3060;
  --ink:        #0A1628;
  --body:       #2D3F5A;
  --muted:      #6A7D94;
  --rule:       #D8E4F0;
  --bg:         #F2F6FA;
  --bg2:        #E8EFF7;
  --white:      #FFFFFF;
  --topbar-h:   40px;
  --nav-h:      72px;
  --nav2-h:     44px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}

/* ── TOPBAR ── */
.topbar{background:var(--navy);height:var(--topbar-h);display:flex;align-items:center;padding:0 2rem;gap:1rem}
.topbar-left{display:flex;align-items:center;gap:.5rem;font-size:.7rem;color:rgba(255,255,255,.4);flex:1}
.topbar-left svg{width:13px;height:13px;flex-shrink:0;stroke:var(--gold);fill:none;stroke-width:2}
.topbar-right{display:flex;align-items:center}
.topbar-right a{height:var(--topbar-h);display:flex;align-items:center;gap:5px;padding:0 .85rem;font-size:.68rem;font-weight:600;color:rgba(255,255,255,.45);letter-spacing:.04em;border-right:1px solid rgba(255,255,255,.06);transition:color .2s,background .2s}
.topbar-right a:first-child{border-left:1px solid rgba(255,255,255,.06)}
.topbar-right a:hover{color:white;background:rgba(255,255,255,.05)}
.topbar-right a svg{width:11px;height:11px;stroke:currentColor;fill:none;stroke-width:2.5}
.tb-cta{background:var(--green)!important;color:white!important;font-weight:700!important}
.tb-cta:hover{background:var(--green-mid)!important}

/* ── NAVBAR UTAMA ── */
.navbar{position:sticky;top:0;z-index:500;height:var(--nav-h);background:var(--white);border-bottom:3px solid var(--green);display:flex;align-items:center;padding:0 2rem;gap:1.5rem;transition:box-shadow .3s}
.navbar.scrolled{box-shadow:0 4px 24px rgba(12,27,42,.1)}
.nav-brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-brand-mark{width:48px;height:48px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-brand-name{display:block;font-size:1.15rem;color:var(--ink);letter-spacing:.07em; font-weight: bold}
.nav-brand-sub{display:block;font-size:.6rem;color:var(--muted);letter-spacing:.07em;text-transform:uppercase;font-weight:600;margin-top:1px}
.nav-menu{display:flex;align-items:stretch;list-style:none;flex:1;gap:0;height:100%}
.nav-item{position:relative;display:flex;align-items:stretch}
.nav-link{display:flex;align-items:center;gap:4px;padding:0 .9rem;font-size:.78rem;font-weight:600;color:var(--body);cursor:pointer;white-space:nowrap;border-bottom:3px solid transparent;margin-bottom:-3px;transition:color .2s,border-color .2s}
.nav-link:hover,.nav-item:hover>.nav-link{color:var(--green);border-bottom-color:var(--green)}
.active {color:var(--green);border-bottom-color:var(--green)}
.nav-chev{width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform .2s;flex-shrink:0}
.nav-item:hover>.nav-link .nav-chev{transform:rotate(180deg)}
.dropdown{position:absolute;top:100%;left:0;background:white;border:1px solid var(--rule);border-top:3px solid var(--green);min-width:210px;box-shadow:0 8px 32px rgba(12,27,42,.12);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(4px);transition:opacity .18s,transform .18s,visibility 0s .18s;z-index:10}
.nav-item:hover .dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0);transition:opacity .18s,transform .18s}
.dropdown a{display:flex;align-items:center;gap:8px;padding:.6rem 1rem;font-size:.78rem;font-weight:500;color:var(--body);border-bottom:1px solid var(--rule);transition:background .15s,color .15s,padding-left .15s}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{background:var(--green-pale);color:var(--green);padding-left:1.2rem}
.dropdown-wide{min-width:320px;display:grid;grid-template-columns:1fr 1fr}
.dropdown-wide a{font-size:.75rem}
.nav-actions{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.btn-nav-pmb{background:var(--green);color:white;padding:.55rem 1.2rem;border-radius:4px;font-size:.75rem;font-weight:700;letter-spacing:.03em;display:flex;align-items:center;gap:6px;transition:background .2s;white-space:nowrap}
.btn-nav-pmb:hover{background:var(--green-d)}
.btn-nav-pmb svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border:none;background:none;margin-left:auto}
.nav-burger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── NAVBAR 2 ── */
.navbar2{background:var(--green-d);height:var(--nav2-h);display:flex;align-items:center;padding:0 2rem;overflow-x:auto;scrollbar-width:none}
.navbar2::-webkit-scrollbar{display:none}
.nb2-item{display:flex;align-items:center;gap:6px;padding:0 1rem;height:var(--nav2-h);font-size:.72rem;font-weight:600;color:rgba(255,255,255,.65);white-space:nowrap;border-right:1px solid rgba(255,255,255,.1);transition:color .2s,background .2s;cursor:pointer}
.nb2-item:first-child{border-left:1px solid rgba(255,255,255,.1)}
.nb2-item:hover{color:white;background:rgba(255,255,255,.08)}
.nb2-item svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0;opacity:.7}
.nb2-item:hover svg{opacity:1}
.nb2-sep{flex:1}
.nb2-hl{background:var(--gold)!important;color:var(--navy)!important;font-weight:800!important;padding:0 1.2rem!important;border-left:none!important;border-right:none!important}
.nb2-hl:hover{background:var(--gold-d)!important}
.nb2-hl svg{opacity:1!important}

/* ── MOBILE DRAWER ── */
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:white;z-index:490;overflow-y:auto;padding:1rem 1.5rem 4rem;transform:translateX(100%);transition:transform .3s ease}
.mobile-menu.open{transform:translateX(0)}
.m-item{border-bottom:1px solid var(--rule)}
.m-link{display:flex;align-items:center;justify-content:space-between;padding:.9rem 0;font-size:.9rem;font-weight:600;color:var(--ink);cursor:pointer}
.m-link svg{width:14px;height:14px;stroke:var(--muted);fill:none;stroke-width:2.5;transition:transform .25s}
.m-item.open .m-link svg{transform:rotate(180deg)}
.m-sub{display:none;padding:.2rem 0 .8rem 1rem}
.m-item.open .m-sub{display:block}
.m-sub a{display:block;padding:.45rem 0;font-size:.82rem;color:var(--body);font-weight:500}
.m-sub a:hover{color:var(--green)}
.m-cta{display:block;margin-top:1.5rem;background:var(--green);color:white;text-align:center;padding:.9rem;border-radius:4px;font-weight:700}

/* ── STAT BAR ── */
.statbar{background:var(--green)}
.statbar-inner{max-width:1260px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(4,1fr);border-left:1px solid rgba(255,255,255,.1)}
.statbar-item{display:flex;align-items:center;gap:1rem;padding:1.3rem 1.5rem;border-right:1px solid rgba(255,255,255,.1)}
.statbar-icon svg{width:28px;height:28px;stroke:rgba(255,255,255,.4);fill:none;stroke-width:1.5}
.statbar-num{font-family:'DM Serif Display',serif;font-size:1.9rem;color:white;line-height:1;letter-spacing:-.03em}
.statbar-num sup{font-size:1rem;vertical-align:super}
.statbar-lbl{font-size:.68rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-top:.2rem}

/* ── SHARED ── */
.sp{padding:4.5rem 0}
.wrap{max-width:1260px;margin:0 auto;padding:0 2rem}
.kicker{display:flex;align-items:center;gap:8px;font-size:.65rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:.8rem}
.kicker-w{color:rgba(255,255,255,.7)} .kicker-w::before{background:rgba(255,255,255,.5)}
.h2{font-family:'DM Serif Display',serif;font-size:clamp(1.7rem,2.8vw,2.4rem);line-height:1.12;color:var(--ink);letter-spacing:-.025em}
.h2 em{font-style:italic;color:var(--green)}
.h2-w{color:white} .h2-w em{color:var(--gold)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}
.btn-more{display:inline-flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;color:var(--green);border:1.5px solid var(--rule);padding:.5rem 1rem;border-radius:3px;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}
.btn-more:hover{background:var(--green);color:white;border-color:var(--green)}
.btn-more svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5}
.btn-more-w{border-color:rgba(255,255,255,.25);color:white}
.btn-more-w:hover{background:white;color:var(--green);border-color:white}
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.vis{opacity:1;transform:none}
.rd1{transition-delay:.07s}.rd2{transition-delay:.14s}.rd3{transition-delay:.21s}.rd4{transition-delay:.28s}

/* ── FOOTER ── */
.footer{background:var(--navy)}
.footer-top{padding:3.5rem 0 2.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem}
.f-brand-row{display:flex;align-items:center;gap:10px;margin-bottom:1rem}
.f-mark{width:36px;height:36px; border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.f-brand-name{display:block;font-size:1.15rem;color:white;letter-spacing:.07em; font-weight: bold}
.f-brand-sub{display:block;font-size:.6rem;color:var(--muted);letter-spacing:.07em;text-transform:uppercase;font-weight:600;margin-top:1px}
.f-desc{font-size:.77rem;color:rgba(255,255,255,.3);line-height:1.85;margin-bottom:1.3rem}
.f-contact{display:flex;flex-direction:column;gap:.5rem}
.f-contact-row{display:flex;align-items:flex-start;gap:7px;font-size:.73rem;color:rgba(255,255,255,.3)}
.f-contact-row svg{width:13px;height:13px;stroke:var(--gold);fill:none;stroke-width:2;flex-shrink:0;margin-top:1px}
.f-col-title{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:800;margin-bottom:1.2rem;padding-bottom:.6rem;border-bottom:1px solid rgba(255,255,255,.07)}
.f-links{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.f-links li a{font-size:.77rem;color:rgba(255,255,255,.3);display:flex;align-items:center;gap:6px;transition:color .2s,gap .2s}
.f-links li a::before{content:'';width:4px;height:1px;background:rgba(255,255,255,.2);flex-shrink:0;transition:width .2s,background .2s}
.f-links li a:hover{color:rgba(255,255,255,.8);}
.footer-bot{border-top:1px solid rgba(255,255,255,.06);padding:1.3rem 0}
.footer-bot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.f-copy{font-size:.68rem;color:rgba(255,255,255,.2)}
.f-gold{color:var(--gold)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
:root{--nav-h:64px}
.topbar,.navbar2{display:none}
.mobile-menu{top:var(--nav-h);display:block}
.nav-menu,.nav-actions{display:none}
.nav-burger{display:flex}
.statbar-inner{grid-template-columns:repeat(2,1fr)}
.about-grid{grid-template-columns:1fr;gap:3rem}
.about-visual{order:-1}
.about-frame{aspect-ratio:16/9}
.about-badge{bottom:-.8rem;left:-.8rem}
.info-grid{grid-template-columns:1fr}
.fak-grid{grid-template-columns:repeat(2,1fr)}
.news-layout{grid-template-columns:1fr}
.layanan-grid{grid-template-columns:repeat(2,1fr)}
.td-grid{grid-template-columns:1fr}
.pmb-inner{grid-template-columns:1fr}
.pmb-btns{flex-direction:row}
.tautan-grid{grid-template-columns:repeat(4,1fr)}
.footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
.sp{padding:3.2rem 0}
.wrap{padding:0 1.2rem}
.navbar{padding:0 1.2rem}
.hero{height:clamp(220px,70vw,380px)}
.hero-ctrl{bottom:.8rem;right:.8rem}
.hero-btn{width:32px;height:32px}
.hero-dots{bottom:.9rem;left:.8rem}
.hero-dot{width:20px}
.hero-dot.active{width:38px}
.statbar-inner{grid-template-columns:1fr 1fr}
.statbar-item{padding:1rem;gap:.7rem}
.statbar-num{font-size:1.5rem}
.about-stats{grid-template-columns:1fr}
.ast{border-right:none;border-bottom:1px solid var(--rule)}
.ast:last-child{border-bottom:none}
.fak-grid{grid-template-columns:1fr}
.layanan-grid{grid-template-columns:repeat(2,1fr)}
.tautan-grid{grid-template-columns:repeat(3,1fr)}
.pmb-btns{flex-direction:column}
.footer-grid{grid-template-columns:1fr;gap:2rem}
.footer-bot-inner{flex-direction:column;text-align:center}
.about-deco{display:none}
}
@media(max-width:380px){
.tautan-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
.hero{height:clamp(280px,55vw,520px)}
}