:root{
  --b9:#07195a;--b8:#0d2278;--b7:#1133aa;--b6:#1a44cc;--b5:#2255ee;--b4:#4b7bff;--b3:#7aa3ff;--b1:#dce8ff;--b0:#eef4ff;
  --w:#fff;--g50:#f7f9fc;--g100:#eef1f8;--g200:#dde2ef;--g300:#b8c2d8;--g400:#8892aa;--g600:#4a5568;--g700:#2d3a52;--g800:#1a2233;
  --font:'Plus Jakarta Sans',sans-serif;
  --sh1:0 1px 4px rgba(10,30,100,.07);--sh2:0 4px 20px rgba(10,30,100,.1);--sh3:0 12px 48px rgba(10,30,100,.15);--sh4:0 24px 80px rgba(10,30,100,.2);
  --r:10px;--rl:18px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--g800);background:var(--w);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--g100)}::-webkit-scrollbar-thumb{background:var(--b5);border-radius:4px}

/* ─── TOPBAR ─── */
.topbar{background:var(--b9);color:rgba(255,255,255,.65);font-size:.75rem;padding:7px 0;display:none}
.topbar-inner{max-width:1240px;margin:0 auto;padding:0 5%;display:flex;justify-content:space-between;align-items:center;gap:16px}
.tb-left,.tb-right{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.tb-item{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.65);transition:color .2s}
.tb-item:hover{color:#fff}
.tb-item svg{flex-shrink:0}
@media(min-width:768px){.topbar{display:block}}

/* ─── NAVBAR ─── */
nav{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--g200);transition:box-shadow .3s}
nav.scrolled{box-shadow:var(--sh2)}
.nav-inner{max-width:1240px;margin:0 auto;padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
@media(min-width:1024px){.nav-inner{height:72px}}

.nav-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-brand img{width:36px;height:36px;object-fit:contain}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-size:.95rem;font-weight:800;color:var(--b8);letter-spacing:-.025em}
.brand-sub{font-size:.58rem;font-weight:600;color:var(--g400);letter-spacing:.09em;text-transform:uppercase;margin-top:2px}

.nav-links{display:none;align-items:center;gap:2px;list-style:none}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{display:block;padding:7px 13px;font-size:.82rem;font-weight:600;color:var(--g600);border-radius:8px;transition:all .15s;white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--b6);background:var(--b0)}

.nav-actions{display:none;align-items:center;gap:8px}
@media(min-width:768px){.nav-actions{display:flex}}
.btn-outline{padding:8px 18px;border-radius:8px;border:1.5px solid var(--b4);color:var(--b6);font-size:.8rem;font-weight:700;transition:all .2s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.btn-outline:hover{background:var(--b0)}
.btn-solid{padding:8px 18px;border-radius:8px;background:var(--b6);color:#fff;font-size:.8rem;font-weight:700;transition:all .2s;box-shadow:0 3px 10px rgba(26,68,204,.3);white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.btn-solid:hover{background:var(--b7);transform:translateY(-1px)}

.hamburger{display:flex;flex-direction:column;gap:4.5px;cursor:pointer;padding:8px;border-radius:8px;transition:background .2s;margin-left:auto}
.hamburger:hover{background:var(--g100)}
.hamburger span{display:block;width:20px;height:2px;background:var(--b8);border-radius:2px;transition:all .28s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
@media(min-width:1024px){.hamburger{display:none}}

/* MOBILE DRAWER */
.drawer{position:fixed;top:64px;left:0;right:0;bottom:0;background:var(--w);z-index:850;transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow-y:auto;padding:20px 5% 32px;border-top:1px solid var(--g200)}
.drawer.open{transform:translateX(0)}
@media(min-width:1024px){.drawer{display:none!important}}
.drawer-links{display:flex;flex-direction:column;gap:2px;margin-bottom:20px}
.drawer-links a{padding:13px 16px;border-radius:10px;font-weight:600;font-size:.95rem;color:var(--g700);transition:all .2s;display:flex;align-items:center;justify-content:space-between}
.drawer-links a::after{content:'›';color:var(--g400);font-size:1.1rem}
.drawer-links a:hover{background:var(--b0);color:var(--b6)}
.drawer-divider{height:1px;background:var(--g200);margin:16px 0}
.drawer-btns{display:flex;flex-direction:column;gap:10px}
.drawer-btn{display:block;text-align:center;padding:14px;border-radius:10px;font-weight:700;font-size:.9rem;transition:all .2s}

/* ─── HERO ─── */
#beranda{background:linear-gradient(150deg,var(--b9) 0%,var(--b7) 50%,var(--b5) 100%);position:relative;overflow:hidden;padding:80px 5% 64px}
@media(min-width:768px){#beranda{padding:100px 5% 80px}}
@media(min-width:1024px){#beranda{padding:120px 5% 100px}}

.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:48px 48px}
.hero-orb{position:absolute;border-radius:50%;pointer-events:none}
.hero-orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(122,163,255,.18),transparent 70%);top:-180px;right:-120px}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.06),transparent 70%);bottom:-100px;left:-80px}

.hero-inner{position:relative;z-index:1;max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.hero-inner{grid-template-columns:1fr 1fr;gap:64px}}

.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.88);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:100px;margin-bottom:24px}
.badge-dot{width:6px;height:6px;background:#6fffa8;border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero-title{font-size:clamp(2rem,5vw,3.8rem);font-weight:800;color:#fff;line-height:1.08;letter-spacing:-.035em;margin-bottom:20px}
.hero-title-accent{color:#93c5fd;font-style:italic;font-weight:700}
.hero-desc{font-size:clamp(.9rem,1.5vw,1.05rem);color:rgba(255,255,255,.7);line-height:1.8;margin-bottom:36px;max-width:500px}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:48px}
.btn-hero-w{padding:14px 28px;border-radius:10px;background:#fff;color:var(--b7);font-weight:700;font-size:.88rem;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,.15);display:inline-flex;align-items:center;gap:8px}
.btn-hero-w:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.btn-hero-g{padding:14px 28px;border-radius:10px;background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.25);font-weight:700;font-size:.88rem;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.btn-hero-g:hover{background:rgba(255,255,255,.18)}

.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(min-width:480px){.hero-stats{grid-template-columns:repeat(4,1fr)}}
.stat-box{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.13);border-radius:12px;padding:16px;text-align:center}
.stat-num{font-size:1.7rem;font-weight:800;color:#fff;letter-spacing:-.04em;line-height:1}
.stat-num sup{font-size:.75rem;color:#93c5fd;vertical-align:super}
.stat-lbl{font-size:.72rem;color:rgba(255,255,255,.55);margin-top:5px;font-weight:500}

/* HERO RIGHT — CARD */
.hero-card{background:rgba(255,255,255,.08);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:20px}
.hc-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.hc-pills{display:flex;flex-wrap:wrap;gap:8px}
.hc-pill{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:9px 14px;color:rgba(255,255,255,.88);font-size:.8rem;font-weight:600;transition:all .2s}
.hc-pill:hover{background:rgba(255,255,255,.18)}
.hc-pill-icon{width:20px;height:20px;flex-shrink:0}
.hc-footer{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid rgba(255,255,255,.12)}
.hc-cta{background:#fff;color:var(--b7);padding:10px 20px;border-radius:8px;font-weight:700;font-size:.8rem;transition:all .2s}
.hc-cta:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.14)}
.hc-rating{text-align:right}
.hc-stars{color:#fbbf24;font-size:.85rem;letter-spacing:2px}
.hc-rating-txt{font-size:.7rem;color:rgba(255,255,255,.45);margin-top:3px}

/* HERO ILLUSTRATION */
.hero-illustration{position:relative;display:flex;align-items:center;justify-content:center}
.hero-illu-wrap{width:100%;max-width:500px;margin:0 auto}

/* ─── CLIENTS ─── */
.clients-bar{background:var(--g50);border-top:1px solid var(--g200);border-bottom:1px solid var(--g200);padding:18px 5%}
.clients-bar-inner{max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:32px;overflow:hidden;flex-wrap:wrap}
.cb-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--g400);white-space:nowrap;flex-shrink:0}
.cb-logos{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.cb-logo{font-size:.78rem;font-weight:700;color:var(--g300);letter-spacing:.06em;transition:color .2s;cursor:default;white-space:nowrap}
.cb-logo:hover{color:var(--b6)}

/* ─── SECTION BASE ─── */
section{padding:72px 5%}
@media(min-width:768px){section{padding:96px 5%}}
.wrap{max-width:1240px;margin:0 auto}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--b6);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px}
.eyebrow::before{content:'';width:18px;height:2px;background:var(--b5);border-radius:2px;flex-shrink:0}
.h2{font-size:clamp(1.6rem,3vw,2.6rem);font-weight:800;letter-spacing:-.03em;line-height:1.1;color:var(--g800)}
.h2 i{font-style:italic;color:var(--b6);font-weight:600}
.sec-desc{font-size:.9rem;color:var(--g400);line-height:1.8;max-width:480px}
.sec-hd{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:48px;flex-wrap:wrap}

/* ─── SERVICES ─── */
#layanan{background:var(--w)}
.svc-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.svc-grid{grid-template-columns:repeat(3,1fr)}}

.svc-card{border:1.5px solid var(--g200);border-radius:var(--rl);padding:28px 24px;transition:all .3s;background:var(--w);position:relative;overflow:hidden;cursor:default}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--b6),var(--b3));transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.65,0,.35,1)}
.svc-card:hover{border-color:var(--b1);box-shadow:var(--sh3);transform:translateY(-4px)}
.svc-card:hover::before{transform:scaleX(1)}
.svc-ico{width:52px;height:52px;border-radius:14px;background:var(--b0);display:flex;align-items:center;justify-content:center;margin-bottom:20px;transition:background .3s}
.svc-ico svg{width:26px;height:26px;color:var(--b6)}
.svc-card:hover .svc-ico{background:var(--b1)}
.svc-name{font-size:.98rem;font-weight:700;color:var(--g800);margin-bottom:9px;letter-spacing:-.01em}
.svc-txt{font-size:.84rem;color:var(--g400);line-height:1.7;margin-bottom:18px}
.svc-tags{display:flex;flex-wrap:wrap;gap:5px}
.tag{font-size:.68rem;font-weight:700;background:var(--b0);color:var(--b6);padding:3px 9px;border-radius:5px;letter-spacing:.03em}

/* ─── PORTFOLIO ─── */
#portfolio{background:var(--g50)}
.port-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.port-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.port-grid{grid-template-columns:repeat(2,1fr)}}

.port-card{background:var(--w);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh1);transition:all .35s;cursor:pointer}
.port-card:hover{transform:translateY(-6px);box-shadow:var(--sh4)}
.port-thumb{aspect-ratio:16/9;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.port-thumb svg{width:80px;height:80px;transition:transform .4s}
.port-card:hover .port-thumb svg{transform:scale(1.08)}
.port-body{padding:22px}
.port-cat{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--b6);margin-bottom:6px}
.port-ttl{font-size:.95rem;font-weight:700;color:var(--g800);margin-bottom:10px;letter-spacing:-.01em}
.port-tech{display:flex;gap:5px;flex-wrap:wrap}
.port-tech span{font-size:.68rem;font-weight:600;background:var(--g100);color:var(--g600);padding:3px 8px;border-radius:5px}

/* ─── HOW WE WORK ─── */
#proses{background:var(--b9);position:relative;overflow:hidden}
#proses::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.03) 1px,transparent 1px);background-size:30px 30px}
#proses .eyebrow{color:var(--b3)}
#proses .eyebrow::before{background:var(--b4)}
#proses .h2{color:#fff}
#proses .sec-desc{color:rgba(255,255,255,.5)}

.proses-steps{display:grid;grid-template-columns:1fr;gap:16px;margin-top:48px;position:relative;z-index:1}
@media(min-width:640px){.proses-steps{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.proses-steps{grid-template-columns:repeat(5,1fr)}}

.ps-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px 22px;text-align:center;position:relative;transition:all .3s}
.ps-card:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateY(-4px)}
.ps-num{font-size:.68rem;font-weight:700;letter-spacing:.12em;color:rgba(255,255,255,.3);margin-bottom:16px;text-align:right}
.ps-icon{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.ps-icon svg{width:24px;height:24px;color:var(--b3)}
.ps-card:hover .ps-icon{background:var(--b6);border-color:var(--b5)}
.ps-card:hover .ps-icon svg{color:#fff}
.ps-name{font-size:.9rem;font-weight:700;color:#fff;margin-bottom:8px}
.ps-txt{font-size:.78rem;color:rgba(255,255,255,.45);line-height:1.6}

/* ─── TRAINING ─── */
#pelatihan{background:var(--w)}
.train-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.train-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.train-grid{grid-template-columns:repeat(3,1fr)}}

.train-card{background:var(--w);border:1.5px solid var(--g200);border-radius:var(--rl);overflow:hidden;transition:all .3s}
.train-card:hover{border-color:var(--b3);box-shadow:var(--sh3);transform:translateY(-4px)}
.train-head{padding:24px 24px 20px;background:linear-gradient(135deg,var(--b0),#ddeeff);border-bottom:1px solid var(--b1);position:relative;overflow:hidden}
.train-head-deco{position:absolute;right:-20px;top:-20px;width:100px;height:100px;border-radius:50%;background:rgba(26,68,204,.08)}
.train-icon{width:44px;height:44px;border-radius:12px;background:var(--b6);display:flex;align-items:center;justify-content:center;margin-bottom:12px;position:relative;z-index:1}
.train-icon svg{width:22px;height:22px;color:#fff}
.train-badge{display:inline-flex;align-items:center;gap:4px;background:var(--b6);color:#fff;font-size:.65rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:3px 9px;border-radius:5px;margin-bottom:10px;position:relative;z-index:1}
.train-ttl{font-size:.97rem;font-weight:700;color:var(--b9);letter-spacing:-.01em;position:relative;z-index:1}
.train-body{padding:18px 24px 22px}
.train-desc{font-size:.84rem;color:var(--g400);line-height:1.7;margin-bottom:16px}
.train-metas{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.train-meta{font-size:.76rem;color:var(--g600);display:flex;align-items:center;gap:5px;font-weight:500}
.train-meta svg{width:14px;height:14px;color:var(--b5);flex-shrink:0}
.train-cta{display:block;text-align:center;background:var(--b0);color:var(--b7);padding:10px;border-radius:8px;font-size:.84rem;font-weight:700;transition:all .2s}
.train-card:hover .train-cta{background:var(--b6);color:#fff}

/* ─── ABOUT ─── */
#tentang{background:var(--g50)}
.about-grid{display:grid;grid-template-columns:1fr;gap:48px;align-items:center}
@media(min-width:1024px){.about-grid{grid-template-columns:1fr 1fr;gap:80px}}

/* ILLUSTRATION */
.about-illu{position:relative;display:flex;align-items:center;justify-content:center}
.about-illu-svg{width:100%;max-width:440px;margin:0 auto;filter:drop-shadow(0 24px 48px rgba(10,30,100,.18))}

.about-content{}
.about-content .eyebrow{margin-bottom:12px}
.about-content .h2{margin-bottom:18px}
.about-content p{font-size:.9rem;color:var(--g400);line-height:1.8;margin-bottom:12px}
.about-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:28px 0}
.ast{background:var(--w);border:1.5px solid var(--g200);border-radius:var(--r);padding:18px;transition:border-color .2s}
.ast:hover{border-color:var(--b3)}
.ast-num{font-size:1.8rem;font-weight:800;color:var(--b6);letter-spacing:-.04em;line-height:1}
.ast-lbl{font-size:.76rem;color:var(--g400);margin-top:4px;font-weight:500}
.val-list{display:flex;flex-direction:column;gap:10px}
.val-row{display:flex;align-items:center;gap:13px;padding:13px 16px;border-radius:10px;background:var(--w);border:1.5px solid var(--g200);transition:all .2s}
.val-row:hover{border-color:var(--b1);box-shadow:var(--sh1)}
.val-ico{width:36px;height:36px;border-radius:9px;background:var(--b0);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.val-ico svg{width:18px;height:18px;color:var(--b6)}
.val-name{font-size:.88rem;font-weight:700;color:var(--g800)}
.val-desc{font-size:.77rem;color:var(--g400)}

/* ─── TESTIMONIALS ─── */
#testimoni{background:var(--w)}
.testi-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:640px){.testi-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.testi-grid{grid-template-columns:repeat(3,1fr)}}

.testi-card{background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--rl);padding:28px 24px;transition:all .3s;display:flex;flex-direction:column}
.testi-card:hover{border-color:var(--b1);box-shadow:var(--sh2)}
.testi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}
.testi-av{width:44px;height:44px;border-radius:12px;background:var(--b6);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:800;color:#fff;flex-shrink:0}
.testi-stars{display:flex;gap:2px}
.testi-stars svg{width:14px;height:14px;color:#f59e0b;fill:#f59e0b}
.testi-txt{font-size:.86rem;color:var(--g600);line-height:1.75;margin-bottom:20px;flex:1;font-style:italic}
.testi-author{display:flex;align-items:center;gap:10px;border-top:1px solid var(--g200);padding-top:16px;margin-top:auto}
.testi-avt{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--b6),var(--b4));display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:.78rem;flex-shrink:0}
.testi-name{font-size:.84rem;font-weight:700;color:var(--g800)}
.testi-role{font-size:.75rem;color:var(--g400)}

/* ─── PARTNERS ─── */
#kerjasama{background:var(--g50);padding:64px 5%}
.ks-head{text-align:center;margin-bottom:40px}
.ks-head .eyebrow{justify-content:center}
.ks-head .eyebrow::before{display:none}
.ks-head .h2{text-align:center}
.partners-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:1240px;margin:0 auto}
@media(min-width:480px){.partners-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.partners-grid{grid-template-columns:repeat(6,1fr)}}
.partner{background:var(--w);border:1.5px solid var(--g200);border-radius:var(--r);padding:20px 12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;transition:all .2s;cursor:default}
.partner:hover{border-color:var(--b3);box-shadow:var(--sh1);transform:translateY(-2px)}
.partner svg{width:28px;height:28px;color:var(--b3);transition:color .2s}
.partner:hover svg{color:var(--b6)}
.partner-name{font-size:.75rem;font-weight:700;color:var(--g400);letter-spacing:.04em;text-align:center;transition:color .2s}
.partner:hover .partner-name{color:var(--b6)}

/* ─── CTA BAND ─── */
.cta-band{background:linear-gradient(135deg,var(--b8),var(--b5));padding:72px 5%;text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px}
.cta-inner{position:relative;z-index:1;max-width:580px;margin:0 auto}
.cta-inner .h2{color:#fff;margin-bottom:14px}
.cta-inner .h2 i{color:#93c5fd}
.cta-inner p{color:rgba(255,255,255,.7);font-size:.93rem;line-height:1.75;margin-bottom:32px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ─── CONTACT ─── */
#kontak{background:var(--w)}
.kontak-grid{display:grid;grid-template-columns:1fr;gap:40px}
@media(min-width:1024px){.kontak-grid{grid-template-columns:1fr 1.4fr;gap:64px}}

.kontak-info-list{display:flex;flex-direction:column;gap:12px;margin-top:28px}
.ki{display:flex;align-items:flex-start;gap:14px;padding:16px;border-radius:12px;background:var(--g50);border:1.5px solid var(--g200);transition:border-color .2s}
.ki:hover{border-color:var(--b1)}
.ki-ico{width:40px;height:40px;border-radius:10px;background:var(--b0);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ki-ico svg{width:18px;height:18px;color:var(--b6)}
.ki-lbl{font-size:.68rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--g400);margin-bottom:3px}
.ki-val{font-size:.88rem;color:var(--g800);font-weight:600}

.form-box{background:var(--g50);border:1.5px solid var(--g200);border-radius:var(--rl);padding:32px 28px}
@media(min-width:640px){.form-box{padding:36px 40px}}
.form-ttl{font-size:1.1rem;font-weight:800;color:var(--g800);margin-bottom:4px;letter-spacing:-.02em}
.form-sub{font-size:.84rem;color:var(--g400);margin-bottom:24px}
.fg{display:grid;grid-template-columns:1fr;gap:13px}
@media(min-width:480px){.fg{grid-template-columns:1fr 1fr}}
.fc{display:flex;flex-direction:column;gap:6px}
.fc.full{grid-column:1/-1}
.fl{font-size:.73rem;font-weight:700;color:var(--g600);letter-spacing:.05em;text-transform:uppercase}
.fi,.fsel,.fta{background:var(--w);border:1.5px solid var(--g200);color:var(--g800);padding:11px 14px;font-family:var(--font);font-size:.87rem;border-radius:9px;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}
.fi::placeholder,.fta::placeholder{color:var(--g300)}
.fi:focus,.fsel:focus,.fta:focus{border-color:var(--b4);box-shadow:0 0 0 3px rgba(26,68,204,.08)}
.fta{height:108px;resize:none}
.fsel{cursor:pointer;appearance:none}
.fsub{width:100%;padding:13px;background:var(--b6);color:#fff;font-family:var(--font);font-weight:700;font-size:.88rem;border:none;border-radius:9px;cursor:pointer;transition:all .2s;margin-top:4px;box-shadow:0 4px 14px rgba(26,68,204,.28);display:flex;align-items:center;justify-content:center;gap:8px}
.fsub:hover{background:var(--b7);transform:translateY(-1px)}
.fsub svg{width:16px;height:16px}

/* ─── FOOTER ─── */
footer{background:var(--g800);color:rgba(255,255,255,.65);padding:56px 5% 28px}
.ft-inner{max-width:1240px;margin:0 auto}
.ft-top{display:grid;grid-template-columns:1fr;gap:36px;margin-bottom:40px}
@media(min-width:640px){.ft-top{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.ft-top{grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}}
.ft-brand img{width:32px;height:32px;object-fit:contain;margin-bottom:12px}
.ft-brand-name{font-size:.9rem;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:10px}
.ft-brand-desc{font-size:.82rem;line-height:1.7;margin-bottom:18px;max-width:240px;color:rgba(255,255,255,.5)}
.ft-socials{display:flex;gap:6px}
.soc{width:34px;height:34px;border-radius:8px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;transition:all .2s}
.soc svg{width:15px;height:15px;color:rgba(255,255,255,.5)}
.soc:hover{border-color:var(--b4);background:rgba(26,68,204,.2)}
.soc:hover svg{color:var(--b3)}
.ft-col h4{font-size:.73rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:14px}
.ft-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.ft-links a{font-size:.82rem;color:rgba(255,255,255,.45);transition:color .2s}
.ft-links a:hover{color:var(--b3)}
.ft-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:22px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.ft-copy{font-size:.75rem;color:rgba(255,255,255,.3)}

/* ─── MEDIA KREATIF ─── */
#media-kreatif{background:var(--w)}

.mk-intro{display:grid;grid-template-columns:1fr;gap:40px;align-items:center;margin-bottom:64px}
@media(min-width:1024px){.mk-intro{grid-template-columns:1fr 1fr;gap:80px}}

.mk-intro-visual{position:relative;display:flex;align-items:center;justify-content:center;order:-1}
@media(min-width:1024px){.mk-intro-visual{order:1}}
.mk-intro-svg{width:100%;max-width:460px;margin:0 auto}

/* Category tabs */
.mk-cats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:40px}
.mk-cat-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:100px;border:1.5px solid var(--g200);background:var(--w);color:var(--g600);font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:var(--font)}
.mk-cat-btn svg{width:15px;height:15px}
.mk-cat-btn:hover{border-color:var(--b3);color:var(--b6);background:var(--b0)}
.mk-cat-btn.active{border-color:var(--b5);background:var(--b6);color:#fff;box-shadow:0 4px 12px rgba(26,68,204,.28)}
.mk-cat-btn.active svg{color:#fff}

/* Creative grid */
.mk-grid{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:480px){.mk-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.mk-grid{grid-template-columns:repeat(4,1fr)}}

.mk-card{border-radius:var(--rl);overflow:hidden;background:var(--w);box-shadow:var(--sh1);transition:all .35s;cursor:pointer;position:relative}
.mk-card:hover{transform:translateY(-6px);box-shadow:var(--sh4)}

.mk-thumb{aspect-ratio:3/4;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.mk-thumb svg{width:100%;height:100%}
.mk-thumb-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,25,90,.85) 0%,transparent 55%);opacity:0;transition:opacity .3s;display:flex;align-items:flex-end;padding:20px}
.mk-card:hover .mk-thumb-overlay{opacity:1}
.mk-overlay-cta{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.76rem;font-weight:700;padding:7px 14px;border-radius:100px}
.mk-overlay-cta svg{width:13px;height:13px}

.mk-body{padding:16px 18px 20px}
.mk-cat-label{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--b6);margin-bottom:5px}
.mk-ttl{font-size:.9rem;font-weight:700;color:var(--g800);margin-bottom:6px;letter-spacing:-.01em;line-height:1.3}
.mk-desc{font-size:.78rem;color:var(--g400);line-height:1.6}

/* Featured row (Brand Identity — wider) */
.mk-grid-featured{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:20px}
@media(min-width:768px){.mk-grid-featured{grid-template-columns:1.6fr 1fr 1fr}}

.mk-card-featured .mk-thumb{aspect-ratio:16/10}
@media(min-width:768px){.mk-card-featured .mk-thumb{aspect-ratio:auto;height:100%;min-height:280px}}

/* ─── DOKUMENTASI CAROUSEL ─── */
.dok-section{margin-top:72px;padding-top:56px;border-top:1.5px solid var(--g200)}
.dok-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;flex-wrap:wrap;gap:16px}
.dok-head-left{}
.dok-eyebrow{display:inline-flex;align-items:center;gap:7px;color:var(--b6);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.dok-eyebrow::before{content:'';width:16px;height:2px;background:var(--b5);border-radius:2px}
.dok-title{font-size:1.3rem;font-weight:800;color:var(--g800);letter-spacing:-.025em}
.dok-title i{font-style:italic;color:var(--b6)}
.dok-controls{display:flex;align-items:center;gap:10px}
.dok-ctrl-btn{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--g200);background:var(--w);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.dok-ctrl-btn:hover{border-color:var(--b4);background:var(--b0)}
.dok-ctrl-btn svg{width:16px;height:16px;color:var(--g600)}
.dok-ctrl-btn:hover svg{color:var(--b6)}
.dok-counter{font-size:.8rem;font-weight:700;color:var(--g400);min-width:40px;text-align:center}

.dok-track-wrap{position:relative;overflow:hidden;border-radius:var(--rl)}
.dok-track{display:flex;gap:16px;transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform}
.dok-slide{flex:0 0 calc(100% - 0px);border-radius:var(--rl);overflow:hidden;position:relative;background:var(--g100)}
@media(min-width:640px){.dok-slide{flex:0 0 calc(50% - 8px)}}
@media(min-width:1024px){.dok-slide{flex:0 0 calc(33.333% - 11px)}}

.dok-img{aspect-ratio:4/3;width:100%;object-fit:cover;display:block;background:var(--g100)}
.dok-placeholder{aspect-ratio:4/3;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:linear-gradient(135deg,var(--b0),var(--g100));position:relative;overflow:hidden}
.dok-placeholder::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,68,204,.04) 1px,transparent 1px);background-size:20px 20px}
.dok-placeholder-icon{width:56px;height:56px;border-radius:16px;background:var(--w);box-shadow:var(--sh2);display:flex;align-items:center;justify-content:center;position:relative;z-index:1}
.dok-placeholder-icon svg{width:26px;height:26px;color:var(--b5)}
.dok-placeholder-label{font-size:.78rem;font-weight:600;color:var(--b6);letter-spacing:.04em;position:relative;z-index:1;text-align:center;padding:0 16px}
.dok-placeholder-num{position:absolute;top:14px;right:14px;width:28px;height:28px;border-radius:8px;background:rgba(26,68,204,.1);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:var(--b6)}

.dok-caption{padding:16px 18px;background:var(--w);border-top:1px solid var(--g200)}
.dok-caption-title{font-size:.88rem;font-weight:700;color:var(--g800);margin-bottom:4px}
.dok-caption-sub{font-size:.76rem;color:var(--g400);display:flex;align-items:center;gap:5px}
.dok-caption-sub svg{width:12px;height:12px;color:var(--b5);flex-shrink:0}

.dok-dots{display:flex;justify-content:center;gap:6px;margin-top:20px}
.dok-dot{width:6px;height:6px;border-radius:50%;background:var(--g200);cursor:pointer;transition:all .25s}
.dok-dot.active{width:20px;border-radius:3px;background:var(--b6)}

/* ─── REVEAL ─── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .6s,transform .6s cubic-bezier(.4,0,.2,1)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.08s}.d2{transition-delay:.16s}.d3{transition-delay:.24s}.d4{transition-delay:.32s}.d5{transition-delay:.4s}